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. I have modified my sample with your code and I have still been unable to reproduce the behavior you describe. I am attaching the sample let me know what behavior you see. I used version v17.2 service release 2029 in my test. What version are you using?
XamMultiColumnEdito_XamRibbon.zip
Screenshot1.docxScreenShot2.docxHello Mike,
Thank you for your post and sorry in the late reply. I have downloaded your code and the problem I describe in my initial post is happening in your code.
Once you bring up your application and click on the dropdown arrow of the MultiSelect combobox all columns display correctly as in ScreenShot1. The second you click on the scrollbar columns 2+ disappear and you are left with column1 (as in ScreenShot2). This is not normal behavior. When you scroll you should continue to see all columns of the MultiSelect Combobox. This behavior only happens in XamRibbon.ApplicationMenu2010.
Thanks.
What version of our product are you using? And What service release of that version?
Hi Mike,
I'm using 17.2
17.2.20172.2029
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?
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.
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 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