I'm having an issue using XamMultiColumnComboEditor in XamRibbon.ApplicationMenu2010.
I placed a XamMultiColumnComboEditor inside ApplicationMenu2010Item.Content. I handled the DropDownOpened event to set the minimum width to the size of my columns. So once the combo popup opens I see all my columns.Once I use the schroll bar, my columns disappear and only one column is shown. You need to schroll through each column.
This issue only happens for XamMultiColumnComboEditor inside XamRibbon.ApplicationMenu2010. It does not happen in user controls.
Thanks in advance.
Hello Cristina,
Thank you for contacting Infragistics!
I have been unable to reproduce the behavior you describe. I am attaching my sample. Please run it and let me know the result. Please attach an isolated sample that reproduces the behavior you are seeing.
The best way for us to assist you is if you provide a small isolated sample that we can run and use for debugging locally. If you are unable able to provide an isolated sample I may be able to give suggestions if you provide the code for your page.
Hello Mike, Thank you for looking into this.
I am unable to see your sample code. Please see my sample code below. The sample code items causes vertical and horizontal scroll bar to display and only the first column of the combobox to show. You have to use the horizontal scroll bar to scroll through the other columns.
I have the identical code in a user control within an grid and I'm not having this issue. I am only seeing this behavior occur in ApplicationMenu2010Item.Content.
Thank you.
MainWindow.xaml
<ribbon:RibbonWindowContentHost> <ribbon:RibbonWindowContentHost.Ribbon> <ribbon:XamRibbon Grid.Row="0" Name="xamRibbon1" ApplicationMenuMode="Office2010" ApplicationAccentColor="LightGreen" VerticalAlignment="Top" HorizontalAlignment="Stretch" > <ribbon:XamRibbon.Resources> </ribbon:XamRibbon.Resources> <ribbon:XamRibbon.ApplicationMenu2010 > <ribbon:ApplicationMenu2010 Caption="Home"> <ribbon:ApplicationMenu2010.Items > <ribbon:ApplicationMenu2010Item Header="Tab 1"> <ribbon:ApplicationMenu2010Item.Content> <Grid> <ig:XamMultiColumnComboEditor x:Name="xamMultiColumnComboEditor1" Width="75" Height="25" ItemsSource="{Binding Path=Data}" DisplayMemberPath="Name" AutoGenerateColumns="False" DropDownOpened="xamMultiColumnComboEditor1_DropDownOpened"> <ig:XamMultiColumnComboEditor.Columns> <ig:TextComboColumn Key="Value"/> <ig:TextComboColumn Key="Name"/> <ig:ImageComboColumn Key="ImagePath"/> </ig:XamMultiColumnComboEditor.Columns> </ig:XamMultiColumnComboEditor> </Grid> </ribbon:ApplicationMenu2010Item.Content> </ribbon:ApplicationMenu2010Item> </ribbon:ApplicationMenu2010.Items> </ribbon:ApplicationMenu2010> </ribbon:XamRibbon.ApplicationMenu2010> </ribbon:XamRibbon> </ribbon:RibbonWindowContentHost.Ribbon> </ribbon:RibbonWindowContentHost>
MainWindow.xaml.cs
private void xamMultiColumnComboEditor1_DropDownOpened(object sender, EventArgs e) { // The border controls the size of the drop down Border border = GetXamMultiColumnComboEditorBorder(sender as XamMultiColumnComboEditor); Grid grid = border.Child as Grid; // Get child items panel MultiColumnComboItemsPanel gridItemsPanel = grid.Children[0] as MultiColumnComboItemsPanel; // Add Loaded event gridItemsPanel.Loaded -= gridItemsPanel_Loaded; gridItemsPanel.Loaded += gridItemsPanel_Loaded; } private void gridItemsPanel_Loaded(object sender, RoutedEventArgs e) { MultiColumnComboItemsPanel itemsPanel = sender as MultiColumnComboItemsPanel; itemsPanel.Measure(new Size(double.PositiveInfinity, double.PositiveInfinity)); // Get the border and set the desired width Border border = GetXamMultiColumnComboEditorBorder(xamMultiColumnComboEditor1); border.MinWidth = itemsPanel.DesiredSize.Width + 5; // +5 for extra padding border.MinHeight = 30; } private Border GetXamMultiColumnComboEditorBorder(XamMultiColumnComboEditor editor) { // Get Popup Popup popup = Utilities.GetDescendantFromType(editor as DependencyObject, typeof(Popup), true) as Popup; // Get Grid Grid grid = popup.Child as Grid; return grid.Children[0] as Border; }
MainWindowViewModel.cs
public class MainWindowViewModel { // This is the data that gets bound to the ItemsSource property in the XamMultiColumnComboEditors public SampleTestDataForComboEditor Data { get; set; } // Constructor for the view model. public MainWindowViewModel() { // Instantiate the data. Data = new SampleTestDataForComboEditor(); } } public class SampleTestDataForComboEditor : ObservableCollection<SampleData> { public SampleTestDataForComboEditor() { Add(new SampleData(1265454, "This is a really long string number one.")); Add(new SampleData(94654542, "This is a really long string number two.")); Add(new SampleData(657575, "This is a really long string number three.")); Add(new SampleData(987543478, "This is a really long string number four.")); Add(new SampleData(789451271, "This is a really long string number five.")); Add(new SampleData(789451, "This is a really long string.")); Add(new SampleData(789452, "This is a really long string.")); Add(new SampleData(789453, "This is a really long string.")); Add(new SampleData(789454, "This is a really long string.")); Add(new SampleData(789455, "This is a really long string.")); Add(new SampleData(789456, "This is a really long string.")); Add(new SampleData(789457, "This is a really long string.")); Add(new SampleData(789458, "This is a really long string.")); Add(new SampleData(789459, "This is a really long string.")); Add(new SampleData(7894510, "This is a really long string.")); } } public class SampleData { public int Value { get; set; } public string Name { get; set; } public string ImagePath { get; set; } public SampleData(int val, string name) { this.Value = val; this.Name = name; // this.ImagePath = "Assets/img.png"; } }
Thank you for the update. When I test my sample I am unable to see the behavior even after following the steps you describe.
Are there any other steps?What is your OS?
Hi Mike,
I am using Windows 7, other people in my office who use Windows 10 are having the same issue. It's unfortunate that you are unable to see this behavior.
I am using Windows 10 and am unable to see the behavior. The steps I follow are switch to the menu with the combo. Open the combo and then adjust the scroll of the drop down.
Are these the same steps you use? If they are different please provide detailed steps. If they are the same can you please note your .Net Framework versions that is installed on your machine as well as the output from System Information (msinfo32.exe).
Hello Mike,
Those are the steps I use. My installed .netFramework versions are :
4.54.5.14.5.24.64.6.14.6.2
Would you be able to do a screenshare today?
Thanks.
Thank you for the update. Can you also provide with the output from System Information (msinfo32.exe).
Thank you for the update. Our development team is still investigating the item logged from that case. I will update you through the case with further details and questions.
Hello,
I'm following up on this case # CASE NUMBER / CAS-194742-K3Q5P3.
Can I have an update as to when this will be resolved? It's been 6 months since the case was opened.
I have logged this to development with the ID 251301. I have also create a private case CAS-19742-K3Q5P3. Where I will provide further information concerning this matter.
I'm following up to check if you are able to see the issue I'm having and if you are able to provide a solution We have a production release and want to get this resolved.
I was able to duplicate the issue. This happens when I have my Display text size set to medium 125%. See attached. When I have it set to 100% I don't have this issue. Can you please try this and let me know if you are able to see the issue I'm having?
This should work regardless of display text size.
Thanks.displaytextsize.docx