I am not sure if WebDataMenu was a new control in v11.1, but it seems really buggy.
I added 4 root menu items and made the third root menu item have 2 child menu items. The 4th item does not show up - there seems to be space for it, but hovering or clicking does nothing and the words for the menu item do appear to show up at all.
Also when I try to reduce the font using the webdatamenu property Font-size, the any of the other CssClass properties available at different levels, the font size (and also color) do not change.
Additionally I wanted to change the height of the menu "bar" and this did shrink to the appropriate size, but the text stayed in the same position it was in before and I could find no way to get it to shift so that it was no longer partially "cut off". Also there is now a "gap" between the 3rd root menu item and its children.
Any help with this would be much appreciated.
Hello Greg,
I have heard back from the Engineering team that the WebDataMenu minimum height is 26 pixels. If you set the menu height to 18px directly in its settings its height will be still 26 pixels, but only 18px will be visible. If it’s set in the GroupSettings the menu will keep its minimum height (26px). This is because WDM items have default padding on which base is calculated their height. I have attached the Markup for demonstrating the same.
The work around is to override the root menu padding like this:
.igdm_MenuItemHorizontalRoot
{
padding: 2px 4px;
}
The result is WDM with height exactly 18px.
Please let me know if you have any further questions regarding this matter.
Thank you for looking into this. I will have to look at what you have regarding the missing fourth item in the menu. Did you happen to look at the Sandbox example I attached in the OP? It had all the issues I mentioned. I had the problem in that sample which is as basic as it gets.
As to the other issues. You mention editting the weddatamenu.css directly. Where might I find that and how might I include that in my project so that the each other developers will not have to make this change, too? Also will I have to overwrite this css each time we get a new version of Infragistics?
I can work around this by using the class you mentioned above (igdm_MenuItemHorizontalRootLink) instead. However it is strange that it would act that way using regular CSS class.
What are the other css classes that are available for the WebDataMenu? For example the sample you gave handles the Root level, but not the child level. Is there a reference that lists all of css classes that you use for a particular control?
After delving into the Source I was able to determine that it is the "igdm_MenuItemVerticalLink" and "igdm_MenuItemVertical" css classes that I needed to override for the menu items.
In the next post I will detail the issues with the solutions so that all answers are in one place.
Issues 1: To a horizontal menu, added 4 root menu items and made the third root menu item have 2 child menu items. The 4th item does not show up - there seems to be space for it, but hovering or clicking does nothing and the words for the menu item do appear to show up at all. This was caused by the use of a non-Infragistics style set to the WebDataMenu's CssClass property that contained the "font-weight:bold" style.
Solution 1: You create your own ".igdm_MenuItemHorizontalRootLink" which combines/overwrites the Infragistics class with the same style.
Issues 2: Tried to reduce the font using the WebDataMenu property font-size, as well as any of the other CssClass properties available at different levels, the font size (and also color) do not change.
Solution 2: You create your own ".igdm_MenuItemHorizontalRootLink" and ".igdm_MenuItemHorizontalRoot" which combines/overwrites the Infragistics classes with the same style. To change the sub menu items you need to overwrite/use the ".igdm_MenuItemVerticalLink" and ".igdm_MenuItemVertical" css classes.
Issues 3: Change the height of the menu "bar" and this did shrink to the appropriate size, but the text stayed in the same position it was in before and I could find no way to get it to shift so that it was no longer partially "cut off". Also there is now a "gap" between the 3rd root menu item and its children.
Solution 3: You create your own ".igdm_MenuItemHorizontalRoot" and set the property of the Height of the WebDataMenu. The Infragistics default is 26px. So to make it work for 18px I set the height of the WebDataMenu to 18px and added padding of 2px to the top and 4px to the right in the css class ".igdm_MenuItemHorizontalRoot". Not this was also further exasperated by some "inline" ASP.NET <%%>. used Page_Init and a Literal control to write the scripts to the header so as to not need the "inline" code.
The only trouble with using these Infragistics css classes is that if you have two menus on a page (Form Menu and "sub control" menu or Application Menu and Page Menu), the styles will be exactly the same for both. So you will have to figure out a way to get them to be different.
Issue needs fixing: Despite the workaround to Issue 1, you should be able to use your own css classes without it causing issues with Infragistics UI so this still needs to be fixed.
Thank you for the update.
This update is let you know that I am currently discussing with my team lead to find out why using of a non-Infragistics style set to the WebDataMenu's CssClass property that contained the "font-weight:bold" style causing the fourth item missing. I will update you on or before Friday.
FYI - an additional issue that I found while using the above changes to the igdm_* classes was that, when I was using the horizontal menu with a sub menu that had a sub menu, the arrow image appeared behind the text instead of after the text. Here are the class overrides I was using. (see attached screen shot for what happens)
.igdm_MenuItemHorizontalRoot { padding: 4px 4px 3px; background-color:#5D7B9D; } .igdm_MenuItemHorizontalRootLink { font-size: x-small; font-weight:bold; color:#FFFFFF; } .igdm_MenuItemVertical { padding: 2px 4px; background-color:#5D7B9D; } .igdm_MenuItemVerticalLink { font-size: x-small; font-weight:bold; color:#FFFFFF; }
Found a solution: http://codecorner.galanter.net/2012/12/28/infragistics-webdatamenu-last-item-disappears/
What if I do need my menu to scroll? My horizontal menu is limited by certain width, and the items are added to it in server-side code at runtime. So when there're more items than menu can fit, I need it to scroll. And it works - it scrolls and all items appear correctly - in all browsers but FireFox. In FireFox last item is always missing.
Any idea how to make this work with scrolling enabled? thanks
Thanks, Prabha, that did the trick.
For others reading this thread, EnableScrolling is a WebDataMenu property, not some obscure CSS tag.
Charles
Hello Charles,
I heard back from development team that setting Enablescrolling property to false will resolve the issue of missing item. By default this property is true.
Setting EnableScrolling to true will result to fixed width of the <ul> element which holds all the root menu items. The problem comes when there is bold style applied to the menu container, because in the calculation of the <ul> element width is not taken.
As a follow-up to my previous post: