@dreamworld/dw-menu v2.5.10
<dw-menu> 
- Menus displays a list of choices on temporary surfaces like Popover dialog in Desktop and Tablet.
- On mobile, the Menu is displayed on the bottom sheet. When menu items are overflowed Menu items are shown as Fit Dialog.
- Menu is composed of various menu items.
- It may have Divider to group menu items.
Note:
dw-menuextendsdw-composite-dialogto render a temporary surface. So,dw-menuhas all the behaviors ofdw-composite-dialog.
Installation
npm install @dreamworld/dw-menuExample usage
Default
<dw-menu .actions="${actions}" .disabledActions="${disabledActions}" .hiddenActions="${hiddenActions}" @action="${handler}"></dw-menu>Mobile Mode
<dw-menu
  mobile-mode
  .heading="${'Heading'}"
  .actions="${actions}"
  .disabledActions="${disabledActions}"
  .hiddenActions="${hiddenActions}"
  @action="${handler}"
></dw-menu>API
Properties/Attributes
| Name | Type | Default | Description | 
|---|---|---|---|
| opened | boolean | false | Set to trueto show it opened. | 
| actions | Action[] | undefined | Represent total available actions/sub actions in the menu. | 
| disabledActions | Object | undefined | Specifies actions that are disabled. key = action name, value = Tooltip message to be shown for that action. | 
| hiddenActions | String[] | [] | Actions specified here aren't visible (rendered) in the menu. | 
| mobileMode | boolean | false | Displayed on the bottom sheet in most cases. When menu items are overflowed Menu items are shown as Fit dialog. | 
| anchor | HTMLElement|null | null | Element to which this menu should be anchored. Applicable only when mobileMode=false. | 
| keepAnchorVisible | boolean | false | By default, When the menu is opened, it covers (hides) the anchor elements. Set it to true, to make it visible. Applicable only whenmobileMode=false. | 
| placement | String | top-start | Possible values: top-start,top-end,bottom-startandbottom-end. Applicable only whenmobileMode=false. | 
| heading | String | null | Set it if you would like to show a heading on the menu. By default no heading. | 
| showClose | boolean | false | Shows an icon-button with a close icon, in the top-rightcorner. As the menu is closed when the user clicks away, this isn't needed in most cases. Though, if you would like to show it sometimes, e.g. whenmobileMode=true. | 
| disableAutoClose | Boolean | false | To prevent the closeevent from triggering on menu item clicks, it has been disabled.  Thecloseevent will now be dispatched exclusively when the close icon is clicked, when a user clicks outside the menu, or when the menu is closed through any other appropriate means. | 
Action
Object
| Key | Type | Description | 
|---|---|---|
| name | String | name of the action. It's available in actionevent detail. | 
| label | String | label of the action | 
| icon | String | Name of the icon to show as a leading icon | 
| danger | Boolean | Shows action in danger mode. e.g. For delete action, you might need it. | 
| type | String | Type of the action. Applicable only when action has subActions. possible values:collapsible,submenu. default value:collapsible | 
| subActions | Array[] | Sub Actions of the current action. Used when a group of actions comes under any same parent item. | 
| divider | Boolean | Set border bottom of the list item. | 
| hasLeadingIconSpace | Boolean | Leave space for the icon (40px) in the list item. only applicable when an iconvalue has not been set. | 
Example
Basic
{
  name: "ADD",
  label: "Add",
  icon: "add",
}With Sub Actions
{
  name: "ADD",
  label: "Add",
  icon: "add",
  subActions: [
    {name: "TOP", label: "Move to Top", icon: 'arrow_up'},
    {name: "BOTTOM", label: "Move to Bottom", icon: 'arrow_down'}
  ]
}Danger action
{
  name: "DELETE",
  label: "Delete",
  icon: "delete",
  danger: true
}Sub Actions Without Leading Icon
[{ name: "ADD", label: "Add", icon: "add", subActions: {name: "TOP", label: "Move to Top", hasLeadingIconSpace: true}, {name: "BOTTOM", label: "Move to Bottom", hasLeadingIconSpace: true} }, { name: "ADD", label: "Add", hasLeadingIconSpace: true subActions: {name: "TOP", label: "Move to Top", hasLeadingIconSpace: true}, {name: "BOTTOM", label: "Move to Bottom", hasLeadingIconSpace: true} }]
disabledActions
- Specifies actions that are disabled.
- key = action name
- value = text (Tooltip message to be shown for that action) OR true(disable an item but don't want to show any tip).
- NOTE: These actions must be declared in the actionsproperty.
{
  SHARE: "Share is disabled"
  DELETE: true
}Events
| Event Name | Target | Detail | Description | 
|---|---|---|---|
| action | dw-menu | {name} | Fired when a menu item is selected by the User (keyboard or mouse interaction). namerepresents the action represented by the selected menu item. | 
CSS Custom Properties
| Name | Default | Description | 
|---|---|---|
| --dw-menu-header-padding | 0 0 0 16px | Padding of header area. | 
| --dw-menu-content-padding | 0 | Padding of content area. | 
| --dw-menu-danger-action-color | #B00020 | Danger action color | 
| --dw-menu-list-item-divider-color | rgba(0, 0, 0, 0.12) | Divider color for collapsible list item | 
Design Decisions
- No property to configure animation. Animation style would be as suggested by the material standards.
Future Enhancements
- Keyboard Navigation
- Custom Footer (via slotor template override)
- Group Items (divider)
- Tooltip for the Disabled Items.
- Expandable Menu Items
- href(Link) support for an Item. It may be set to open in a new window only. In that case, it’s trailing icon is also auto-chosen.
- Sub-Menu: Opens another menu on the side of the current menu. (Long-term deferred)
10 months ago
11 months ago
7 months ago
7 months ago
10 months ago
10 months ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
3 years ago
2 years ago
2 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago