Top Link Disclosure Menu
An accessible disclosure menu with top-level links in the DOM.
Note
This is a subclass of BaseMenu.
Constructor
Constructs a new TopLinkDisclosureMenu
.
new TopLinkDisclosureMenu({
menuElement,
menuItemSelector,
menuLinkSelector,
submenuItemSelector,
submenuToggleSelector,
submenuSelector,
submenuSubtoggleSelector,
controllerElement,
containerElement,
openClass,
closeClass,
transitionClass,
transitionDuration,
openDuration,
closeDuration,
isTopLevel,
parentMenu,
hoverType,
hoverDelay,
enterDelay,
leaveDelay,
optionalKeySupport,
prefix,
initialize,
});
The constructor will call BaseMenu's constructor with the provided options. It will also populate the optionalSupport property, the new submenuSubtoggle selector, and initialize the menu if the initialize flag is set to true
.
Parameters
Name | Type | Description | Default |
---|---|---|---|
options | object | The options for generating the menu. | undefined |
options.menuElement | HTMLElement | The menu element in the DOM. | undefined |
options.menuItemSelector | string | The query selector string for menu items. | "li" |
options.menuLinkSelector | string | The query selector string for menu links. | "a" |
options.submenuItemSelector | string | The query selector string for menu items containing submenus. | li:has(ul) |
options.submenuToggleSelector | string | The query selector string for submenu toggle buttons/links. | "button" |
options.submenuSelector | string | The query selector string for submenus. | "ul" |
options.submenuSubtoggleSelector | string | The query selector string for submenu toggle buttons/links below the top level. | "a" |
options.controllerElement | HTMLElement , null | The element controlling the menu in the DOM. | null |
options.containerElement | HTMLElement , null | The element containing the menu in the DOM. | null |
options.openClass | (string , string[]) , null | The class to apply when a menu is "open". | "show" |
options.closeClass | (string , string[]) , null | The class to apply when a menu is "closed". | "hide" |
options.transitionClass | (string , string[]) , null | The class to apply when a menu is transitioning between "open" and "closed" states. | "transitioning" |
options.transitionDuration | number | The duration of the transition between "open" and "closed" states (in milliseconds). | 250 |
options.openDuration | number | The duration of the transition from "closed" to "open" states (in milliseconds). | 250 |
options.closeDuration | number | The duration of the transition from "open" to "closed" states (in milliseconds). | 250 |
options.isTopLevel | boolean | A flag to mark the root menu. | true |
options.parentMenu | TopLinkDisclosureMenu , null | The parent menu to this menu. | null |
options.hoverType | string | The type of hoverability a menu has. | "off" |
options.hoverDelay | number | The delay for opening and closing menus if the menu is hoverable (in milliseconds). | 250 |
options.enterDelay | number | The delay for opening a menu if the menu is focusable (in milliseconds). | -1 |
options.leaveDelay | number | The delay for closing a menu if the menu is focusable (in milliseconds). | -1 |
options.optionalKeySupport | boolean | A flag to add optional keyboard support (Arrow keys, Home, and End) to the menu. | false |
options.prefix | string , null | The prefix for the CSS custom properties. | "am-" |
options.initialize | boolean | A flag to initialize the menu immediately upon creation. | true |
Initialize
Initializes the menu.
TopLinkDisclosureMenu.initialize();
Initialize will call BaseMenu's initialize method as well as set up focus (inherited), click, hover, keydown, and keyup events for the menu.
If the BaseMenu's initialize method throws an error, this will catch it and log it to the console.
Properties
Properties are inherited from the BaseMenu class. The following properties are unique to or overwritten in the TopLinkDisclosureMenu class.
_MenuType protected
The class to use when generating submenus.
/**
* @protected
*
* @type {typeof TopLinkDisclosureMenu}
*/
TopLinkDisclosureMenu._MenuType; // Default: `TopLinkDisclosureMenu`.
_MenuItemType protected
The class to use when generating menu items.
/**
* @protected
*
* @type {typeof TopLinkDisclosureMenuItem}
*/
TopLinkDisclosureMenu._MenuItemType; // Default: `TopLinkDisclosureMenuItem`.
_MenuToggleType protected
The class to use when generating menu toggles.
/**
* @protected
*
* @type {typeof TopLinkDisclosureMenuToggle}
*/
TopLinkDisclosureMenu._MenuToggleType; // Default: `TopLinkDisclosureMenuToggle`.
_currentChild protected
The index of the currently selected menu item in the menu.
/**
* @protected
*
* @type {number}
*/
TopLinkDisclosureMenu._currentChild; // Default: `-1`.
_selectors protected
The query selectors used by the menu to populate the dom.
/**
* @protected
*
* @type {Object<string>}
*
* @property {string} menuItems - The query selector for menu items.
* @property {string} menuLinks - The query selector for menu links.
* @property {string} submenuItems - The query selector for menu items containing submenus.
* @property {string} submenuToggles - The query selector for menu links that function as submenu toggles.
* @property {string} submenus - The query selector for for submenus.
* @property {string} submenuSubtoggles - The query selector for menu links that function as submenu toggles below the top level.
*/
TopLinkDisclosureMenu._selectors;
_optionalSupport protected
A flag to add optional keyboard support (Arrow keys, "Home", and "End") to the menu.
/**
* @protected
*
* @type {boolean}
*/
TopLinkDisclosureMenu._optionalSupport; // Default: `false`.
Getters and Setters
Getters and setters are inherited from the BaseMenu class. The following getters and setters are unique to or overwritten in the TopLinkDisclosureMenu class.
optionalKeySupport
A flag to add optional keyboard support (Arrow keys, "Home", and "End") to the menu.
/**
* @type {boolean}
*
* @see _optionalSupport
*/
TopLinkDisclosureMenu.optionalKeySupport;
/**
* @type {boolean}
*/
TopLinkDisclosureMenu.optionalKeySupport = true;
This functions differently for root vs. submenus. Submenus will always inherit their root menu's optionalKeySupport.
Methods
Methods are inherited from the BaseMenu class. The following methods are unique to or overwritten in the TopLinkDisclosureMenu class.
_createChildElements protected
Creates and initializes all menu items and submenus.
TopLinkDisclosureMenu._createChildElements();
This method differs from BaseMenu's _createChildElements method because of the way toggles are handled in submenus. On the top level submenu toggles are their own element, separate from the link, while in submenus they are the link itself.
_validate protected
Validates all aspects of the menu to ensure proper functionality.
/**
* @protected
*
* @returns {boolean} - The result of the validation.
*/
TopLinkDisclosureMenu._validate();
The validation method will call BaseMenu's validation method as well as validate the optionalKeySupport property and the submenuSubtoggleSelector value.
_handleClick protected
Handles click events throughout the menu for proper use.
TopLinkDisclosureMenu._handleClick();
This method will do the following:
- Adds all event listeners listed in BaseMenu's _handleClick method.
- Adds a
pointerup
listener to thedocument
so if the user clicks outside of the menu it will close if it is open.
_handleHover protected
Handles hover events throughout the menu for proper use.
TopLinkDisclosureMenu._handleHover();
This method is essentially the same as BaseMenu's _handleHover method. The only difference is that hovering both the top-level link and the top-level menu toggle for a menu item will trigger the set hover effects.
_handleKeydown protected
Handles keydown events throughout the menu for proper menu use.
TopLinkDisclosureMenu._handleKeydown();
This method exists to assist the _handleKeyup method.
This method will do the following:
- Adds all
keydown
listeners from BaseMenu's _handleKeydown method. - Adds a
keydown
listener to the menu/all submenus.- Blocks propagation on the following keys: "Space", "Enter", and "Escape".
- If optional keyboard support is enabled, blocks propagation on the following keys: "ArrowUp", "ArrowRight", "ArrowDown", "ArrowLeft", "Home", and "End".
_handleKeyup protected
Handles keyup events throughout the menu for proper menu use.
TopLinkDisclosureMenu._handleKeyup();
Adds all keyup
listeners from BaseMenu's _handleKeyup method.
Adds the following keybindings (explanations are taken from the WAI ARIA Practices Example Disclosure for Navigation Menus:
Key | Function |
---|---|
Tab or Shift + Tab | Move keyboard focus among top-level buttons, and if a dropdown is open, into and through links in the dropdown. |
Space or Enter |
|
Escape | If a dropdown is open, closes it and sets focus on the button that controls that dropdown. |
Down Arrow or Right Arrow (Optional}) |
|
Up Arrow or Left Arrow (Optional}) |
|
Home (Optional}) |
|
End (Optional}) |
|
The optional keybindings are controlled by the menu's optionalKeySupport value.