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. Can you also provide with the output from System Information (msinfo32.exe).
Hi Mike,
As requested, please see below. I removed some of the features, but if you need something specific please let me know.
OS Name Microsoft Windows 7 EnterpriseService Pack 1System Type x64-based PCProcessor Intel(R) Core(TM) i7-5600U CPU @ 2.60GHz, 2601 Mhz, 2 Core(s), 4 Logical Processor(s)Installed Physical Memory (RAM) 16.0 GB
I'm not understanding how you are not seeing this behavior. I literally took your sample application and as I said before, the second I click on the scrollbar columns 2+ of the MultiCombobox disappear and I'm left with the first column as in my screenshot from the previous post. This happens on various machines. Would you be able to do a screenshare? (it would save time) I would be curious to see how you are not getting this behavior to happen.
Thanks.
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
Hello Mike,
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 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.
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.