@fluentui/react-menu 0.0.0-nightly-20220302-0405.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.json +5046 -0
- package/CHANGELOG.md +1569 -0
- package/LICENSE +15 -0
- package/README.md +5 -0
- package/Spec.md +1039 -0
- package/dist/react-menu.d.ts +662 -0
- package/lib/Menu.d.ts +1 -0
- package/lib/Menu.js +2 -0
- package/lib/Menu.js.map +1 -0
- package/lib/MenuDivider.d.ts +1 -0
- package/lib/MenuDivider.js +2 -0
- package/lib/MenuDivider.js.map +1 -0
- package/lib/MenuGroup.d.ts +1 -0
- package/lib/MenuGroup.js +2 -0
- package/lib/MenuGroup.js.map +1 -0
- package/lib/MenuGroupHeader.d.ts +1 -0
- package/lib/MenuGroupHeader.js +2 -0
- package/lib/MenuGroupHeader.js.map +1 -0
- package/lib/MenuItem.d.ts +1 -0
- package/lib/MenuItem.js +2 -0
- package/lib/MenuItem.js.map +1 -0
- package/lib/MenuItemCheckbox.d.ts +1 -0
- package/lib/MenuItemCheckbox.js +2 -0
- package/lib/MenuItemCheckbox.js.map +1 -0
- package/lib/MenuItemRadio.d.ts +1 -0
- package/lib/MenuItemRadio.js +2 -0
- package/lib/MenuItemRadio.js.map +1 -0
- package/lib/MenuList.d.ts +1 -0
- package/lib/MenuList.js +2 -0
- package/lib/MenuList.js.map +1 -0
- package/lib/MenuPopover.d.ts +1 -0
- package/lib/MenuPopover.js +2 -0
- package/lib/MenuPopover.js.map +1 -0
- package/lib/MenuSplitGroup.d.ts +1 -0
- package/lib/MenuSplitGroup.js +2 -0
- package/lib/MenuSplitGroup.js.map +1 -0
- package/lib/MenuTrigger.d.ts +1 -0
- package/lib/MenuTrigger.js +2 -0
- package/lib/MenuTrigger.js.map +1 -0
- package/lib/components/Menu/Menu.d.ts +6 -0
- package/lib/components/Menu/Menu.js +14 -0
- package/lib/components/Menu/Menu.js.map +1 -0
- package/lib/components/Menu/Menu.types.d.ts +113 -0
- package/lib/components/Menu/Menu.types.js +2 -0
- package/lib/components/Menu/Menu.types.js.map +1 -0
- package/lib/components/Menu/index.d.ts +5 -0
- package/lib/components/Menu/index.js +6 -0
- package/lib/components/Menu/index.js.map +1 -0
- package/lib/components/Menu/renderMenu.d.ts +5 -0
- package/lib/components/Menu/renderMenu.js +12 -0
- package/lib/components/Menu/renderMenu.js.map +1 -0
- package/lib/components/Menu/useMenu.d.ts +10 -0
- package/lib/components/Menu/useMenu.js +260 -0
- package/lib/components/Menu/useMenu.js.map +1 -0
- package/lib/components/Menu/useMenuContextValues.d.ts +2 -0
- package/lib/components/Menu/useMenuContextValues.js +41 -0
- package/lib/components/Menu/useMenuContextValues.js.map +1 -0
- package/lib/components/MenuDivider/MenuDivider.d.ts +6 -0
- package/lib/components/MenuDivider/MenuDivider.js +15 -0
- package/lib/components/MenuDivider/MenuDivider.js.map +1 -0
- package/lib/components/MenuDivider/MenuDivider.types.d.ts +6 -0
- package/lib/components/MenuDivider/MenuDivider.types.js +2 -0
- package/lib/components/MenuDivider/MenuDivider.types.js.map +1 -0
- package/lib/components/MenuDivider/index.d.ts +5 -0
- package/lib/components/MenuDivider/index.js +6 -0
- package/lib/components/MenuDivider/index.js.map +1 -0
- package/lib/components/MenuDivider/renderMenuDivider.d.ts +6 -0
- package/lib/components/MenuDivider/renderMenuDivider.js +16 -0
- package/lib/components/MenuDivider/renderMenuDivider.js.map +1 -0
- package/lib/components/MenuDivider/useMenuDivider.d.ts +6 -0
- package/lib/components/MenuDivider/useMenuDivider.js +19 -0
- package/lib/components/MenuDivider/useMenuDivider.js.map +1 -0
- package/lib/components/MenuDivider/useMenuDividerStyles.d.ts +3 -0
- package/lib/components/MenuDivider/useMenuDividerStyles.js +24 -0
- package/lib/components/MenuDivider/useMenuDividerStyles.js.map +1 -0
- package/lib/components/MenuGroup/MenuGroup.d.ts +6 -0
- package/lib/components/MenuGroup/MenuGroup.js +17 -0
- package/lib/components/MenuGroup/MenuGroup.js.map +1 -0
- package/lib/components/MenuGroup/MenuGroup.types.d.ts +15 -0
- package/lib/components/MenuGroup/MenuGroup.types.js +2 -0
- package/lib/components/MenuGroup/MenuGroup.types.js.map +1 -0
- package/lib/components/MenuGroup/index.d.ts +6 -0
- package/lib/components/MenuGroup/index.js +7 -0
- package/lib/components/MenuGroup/index.js.map +1 -0
- package/lib/components/MenuGroup/renderMenuGroup.d.ts +6 -0
- package/lib/components/MenuGroup/renderMenuGroup.js +19 -0
- package/lib/components/MenuGroup/renderMenuGroup.js.map +1 -0
- package/lib/components/MenuGroup/useMenuGroup.d.ts +6 -0
- package/lib/components/MenuGroup/useMenuGroup.js +21 -0
- package/lib/components/MenuGroup/useMenuGroup.js.map +1 -0
- package/lib/components/MenuGroup/useMenuGroupContextValues.d.ts +2 -0
- package/lib/components/MenuGroup/useMenuGroupContextValues.js +13 -0
- package/lib/components/MenuGroup/useMenuGroupContextValues.js.map +1 -0
- package/lib/components/MenuGroup/useMenuGroupStyles.d.ts +3 -0
- package/lib/components/MenuGroup/useMenuGroupStyles.js +7 -0
- package/lib/components/MenuGroup/useMenuGroupStyles.js.map +1 -0
- package/lib/components/MenuGroupHeader/MenuGroupHeader.d.ts +6 -0
- package/lib/components/MenuGroupHeader/MenuGroupHeader.js +15 -0
- package/lib/components/MenuGroupHeader/MenuGroupHeader.js.map +1 -0
- package/lib/components/MenuGroupHeader/MenuGroupHeader.types.d.ts +6 -0
- package/lib/components/MenuGroupHeader/MenuGroupHeader.types.js +2 -0
- package/lib/components/MenuGroupHeader/MenuGroupHeader.types.js.map +1 -0
- package/lib/components/MenuGroupHeader/index.d.ts +5 -0
- package/lib/components/MenuGroupHeader/index.js +6 -0
- package/lib/components/MenuGroupHeader/index.js.map +1 -0
- package/lib/components/MenuGroupHeader/renderMenuGroupHeader.d.ts +6 -0
- package/lib/components/MenuGroupHeader/renderMenuGroupHeader.js +16 -0
- package/lib/components/MenuGroupHeader/renderMenuGroupHeader.js.map +1 -0
- package/lib/components/MenuGroupHeader/useMenuGroupHeader.d.ts +6 -0
- package/lib/components/MenuGroupHeader/useMenuGroupHeader.js +22 -0
- package/lib/components/MenuGroupHeader/useMenuGroupHeader.js.map +1 -0
- package/lib/components/MenuGroupHeader/useMenuGroupHeaderStyles.d.ts +3 -0
- package/lib/components/MenuGroupHeader/useMenuGroupHeaderStyles.js +25 -0
- package/lib/components/MenuGroupHeader/useMenuGroupHeaderStyles.js.map +1 -0
- package/lib/components/MenuItem/MenuItem.d.ts +6 -0
- package/lib/components/MenuItem/MenuItem.js +15 -0
- package/lib/components/MenuItem/MenuItem.js.map +1 -0
- package/lib/components/MenuItem/MenuItem.types.d.ts +43 -0
- package/lib/components/MenuItem/MenuItem.types.js +2 -0
- package/lib/components/MenuItem/MenuItem.types.js.map +1 -0
- package/lib/components/MenuItem/index.d.ts +5 -0
- package/lib/components/MenuItem/index.js +6 -0
- package/lib/components/MenuItem/index.js.map +1 -0
- package/lib/components/MenuItem/renderMenuItem.d.ts +5 -0
- package/lib/components/MenuItem/renderMenuItem.js +20 -0
- package/lib/components/MenuItem/renderMenuItem.js.map +1 -0
- package/lib/components/MenuItem/useCharacterSearch.d.ts +3 -0
- package/lib/components/MenuItem/useCharacterSearch.js +26 -0
- package/lib/components/MenuItem/useCharacterSearch.js.map +1 -0
- package/lib/components/MenuItem/useMenuItem.d.ts +6 -0
- package/lib/components/MenuItem/useMenuItem.js +125 -0
- package/lib/components/MenuItem/useMenuItem.js.map +1 -0
- package/lib/components/MenuItem/useMenuItemStyles.d.ts +4 -0
- package/lib/components/MenuItem/useMenuItemStyles.js +107 -0
- package/lib/components/MenuItem/useMenuItemStyles.js.map +1 -0
- package/lib/components/MenuItemCheckbox/MenuItemCheckbox.d.ts +6 -0
- package/lib/components/MenuItemCheckbox/MenuItemCheckbox.js +15 -0
- package/lib/components/MenuItemCheckbox/MenuItemCheckbox.js.map +1 -0
- package/lib/components/MenuItemCheckbox/MenuItemCheckbox.types.d.ts +4 -0
- package/lib/components/MenuItemCheckbox/MenuItemCheckbox.types.js +2 -0
- package/lib/components/MenuItemCheckbox/MenuItemCheckbox.types.js.map +1 -0
- package/lib/components/MenuItemCheckbox/index.d.ts +5 -0
- package/lib/components/MenuItemCheckbox/index.js +6 -0
- package/lib/components/MenuItemCheckbox/index.js.map +1 -0
- package/lib/components/MenuItemCheckbox/renderMenuItemCheckbox.d.ts +3 -0
- package/lib/components/MenuItemCheckbox/renderMenuItemCheckbox.js +17 -0
- package/lib/components/MenuItemCheckbox/renderMenuItemCheckbox.js.map +1 -0
- package/lib/components/MenuItemCheckbox/useMenuItemCheckbox.d.ts +4 -0
- package/lib/components/MenuItemCheckbox/useMenuItemCheckbox.js +46 -0
- package/lib/components/MenuItemCheckbox/useMenuItemCheckbox.js.map +1 -0
- package/lib/components/MenuItemCheckbox/useMenuItemCheckboxStyles.d.ts +3 -0
- package/lib/components/MenuItemCheckbox/useMenuItemCheckboxStyles.js +10 -0
- package/lib/components/MenuItemCheckbox/useMenuItemCheckboxStyles.js.map +1 -0
- package/lib/components/MenuItemRadio/MenuItemRadio.d.ts +6 -0
- package/lib/components/MenuItemRadio/MenuItemRadio.js +15 -0
- package/lib/components/MenuItemRadio/MenuItemRadio.js.map +1 -0
- package/lib/components/MenuItemRadio/MenuItemRadio.types.d.ts +4 -0
- package/lib/components/MenuItemRadio/MenuItemRadio.types.js +2 -0
- package/lib/components/MenuItemRadio/MenuItemRadio.types.js.map +1 -0
- package/lib/components/MenuItemRadio/index.d.ts +5 -0
- package/lib/components/MenuItemRadio/index.js +6 -0
- package/lib/components/MenuItemRadio/index.js.map +1 -0
- package/lib/components/MenuItemRadio/renderMenuItemRadio.d.ts +6 -0
- package/lib/components/MenuItemRadio/renderMenuItemRadio.js +20 -0
- package/lib/components/MenuItemRadio/renderMenuItemRadio.js.map +1 -0
- package/lib/components/MenuItemRadio/useMenuItemRadio.d.ts +6 -0
- package/lib/components/MenuItemRadio/useMenuItemRadio.js +49 -0
- package/lib/components/MenuItemRadio/useMenuItemRadio.js.map +1 -0
- package/lib/components/MenuItemRadio/useMenuItemRadioStyles.d.ts +3 -0
- package/lib/components/MenuItemRadio/useMenuItemRadioStyles.js +10 -0
- package/lib/components/MenuItemRadio/useMenuItemRadioStyles.js.map +1 -0
- package/lib/components/MenuList/MenuList.d.ts +6 -0
- package/lib/components/MenuList/MenuList.js +17 -0
- package/lib/components/MenuList/MenuList.js.map +1 -0
- package/lib/components/MenuList/MenuList.types.d.ts +55 -0
- package/lib/components/MenuList/MenuList.types.js +2 -0
- package/lib/components/MenuList/MenuList.types.js.map +1 -0
- package/lib/components/MenuList/index.d.ts +6 -0
- package/lib/components/MenuList/index.js +6 -0
- package/lib/components/MenuList/index.js.map +1 -0
- package/lib/components/MenuList/renderMenuList.d.ts +5 -0
- package/lib/components/MenuList/renderMenuList.js +18 -0
- package/lib/components/MenuList/renderMenuList.js.map +1 -0
- package/lib/components/MenuList/useMenuList.d.ts +6 -0
- package/lib/components/MenuList/useMenuList.js +168 -0
- package/lib/components/MenuList/useMenuList.js.map +1 -0
- package/lib/components/MenuList/useMenuListContextValues.d.ts +2 -0
- package/lib/components/MenuList/useMenuListContextValues.js +25 -0
- package/lib/components/MenuList/useMenuListContextValues.js.map +1 -0
- package/lib/components/MenuList/useMenuListStyles.d.ts +6 -0
- package/lib/components/MenuList/useMenuListStyles.js +24 -0
- package/lib/components/MenuList/useMenuListStyles.js.map +1 -0
- package/lib/components/MenuPopover/MenuPopover.d.ts +6 -0
- package/lib/components/MenuPopover/MenuPopover.js +15 -0
- package/lib/components/MenuPopover/MenuPopover.js.map +1 -0
- package/lib/components/MenuPopover/MenuPopover.types.d.ts +18 -0
- package/lib/components/MenuPopover/MenuPopover.types.js +2 -0
- package/lib/components/MenuPopover/MenuPopover.types.js.map +1 -0
- package/lib/components/MenuPopover/index.d.ts +5 -0
- package/lib/components/MenuPopover/index.js +6 -0
- package/lib/components/MenuPopover/index.js.map +1 -0
- package/lib/components/MenuPopover/renderMenuPopover.d.ts +5 -0
- package/lib/components/MenuPopover/renderMenuPopover.js +22 -0
- package/lib/components/MenuPopover/renderMenuPopover.js.map +1 -0
- package/lib/components/MenuPopover/useMenuPopover.d.ts +12 -0
- package/lib/components/MenuPopover/useMenuPopover.js +104 -0
- package/lib/components/MenuPopover/useMenuPopover.js.map +1 -0
- package/lib/components/MenuPopover/useMenuPopoverStyles.d.ts +6 -0
- package/lib/components/MenuPopover/useMenuPopoverStyles.js +46 -0
- package/lib/components/MenuPopover/useMenuPopoverStyles.js.map +1 -0
- package/lib/components/MenuSplitGroup/MenuSplitGroup.d.ts +6 -0
- package/lib/components/MenuSplitGroup/MenuSplitGroup.js +15 -0
- package/lib/components/MenuSplitGroup/MenuSplitGroup.js.map +1 -0
- package/lib/components/MenuSplitGroup/MenuSplitGroup.types.d.ts +14 -0
- package/lib/components/MenuSplitGroup/MenuSplitGroup.types.js +2 -0
- package/lib/components/MenuSplitGroup/MenuSplitGroup.types.js.map +1 -0
- package/lib/components/MenuSplitGroup/index.d.ts +5 -0
- package/lib/components/MenuSplitGroup/index.js +6 -0
- package/lib/components/MenuSplitGroup/index.js.map +1 -0
- package/lib/components/MenuSplitGroup/renderMenuSplitGroup.d.ts +5 -0
- package/lib/components/MenuSplitGroup/renderMenuSplitGroup.js +15 -0
- package/lib/components/MenuSplitGroup/renderMenuSplitGroup.js.map +1 -0
- package/lib/components/MenuSplitGroup/useMenuSplitGroup.d.ts +12 -0
- package/lib/components/MenuSplitGroup/useMenuSplitGroup.js +67 -0
- package/lib/components/MenuSplitGroup/useMenuSplitGroup.js.map +1 -0
- package/lib/components/MenuSplitGroup/useMenuSplitGroupStyles.d.ts +6 -0
- package/lib/components/MenuSplitGroup/useMenuSplitGroupStyles.js +35 -0
- package/lib/components/MenuSplitGroup/useMenuSplitGroupStyles.js.map +1 -0
- package/lib/components/MenuTrigger/MenuTrigger.d.ts +8 -0
- package/lib/components/MenuTrigger/MenuTrigger.js +14 -0
- package/lib/components/MenuTrigger/MenuTrigger.js.map +1 -0
- package/lib/components/MenuTrigger/MenuTrigger.types.d.ts +20 -0
- package/lib/components/MenuTrigger/MenuTrigger.types.js +2 -0
- package/lib/components/MenuTrigger/MenuTrigger.types.js.map +1 -0
- package/lib/components/MenuTrigger/index.d.ts +4 -0
- package/lib/components/MenuTrigger/index.js +5 -0
- package/lib/components/MenuTrigger/index.js.map +1 -0
- package/lib/components/MenuTrigger/renderMenuTrigger.d.ts +7 -0
- package/lib/components/MenuTrigger/renderMenuTrigger.js +14 -0
- package/lib/components/MenuTrigger/renderMenuTrigger.js.map +1 -0
- package/lib/components/MenuTrigger/useMenuTrigger.d.ts +8 -0
- package/lib/components/MenuTrigger/useMenuTrigger.js +178 -0
- package/lib/components/MenuTrigger/useMenuTrigger.js.map +1 -0
- package/lib/components/index.d.ts +2 -0
- package/lib/components/index.js +3 -0
- package/lib/components/index.js.map +1 -0
- package/lib/contexts/menuContext.d.ts +16 -0
- package/lib/contexts/menuContext.js +23 -0
- package/lib/contexts/menuContext.js.map +1 -0
- package/lib/contexts/menuGroupContext.d.ts +13 -0
- package/lib/contexts/menuGroupContext.js +7 -0
- package/lib/contexts/menuGroupContext.js.map +1 -0
- package/lib/contexts/menuListContext.d.ts +15 -0
- package/lib/contexts/menuListContext.js +13 -0
- package/lib/contexts/menuListContext.js.map +1 -0
- package/lib/contexts/menuTriggerContext.d.ts +3 -0
- package/lib/contexts/menuTriggerContext.js +9 -0
- package/lib/contexts/menuTriggerContext.js.map +1 -0
- package/lib/index.d.ts +16 -0
- package/lib/index.js +17 -0
- package/lib/index.js.map +1 -0
- package/lib/selectable/index.d.ts +2 -0
- package/lib/selectable/index.js +3 -0
- package/lib/selectable/index.js.map +1 -0
- package/lib/selectable/types.d.ts +34 -0
- package/lib/selectable/types.js +2 -0
- package/lib/selectable/types.js.map +1 -0
- package/lib/selectable/useCheckmarkStyles.d.ts +8 -0
- package/lib/selectable/useCheckmarkStyles.js +29 -0
- package/lib/selectable/useCheckmarkStyles.js.map +1 -0
- package/lib/tsdoc-metadata.json +11 -0
- package/lib/utils/index.d.ts +1 -0
- package/lib/utils/index.js +2 -0
- package/lib/utils/index.js.map +1 -0
- package/lib/utils/useIsSubmenu.d.ts +9 -0
- package/lib/utils/useIsSubmenu.js +18 -0
- package/lib/utils/useIsSubmenu.js.map +1 -0
- package/lib/utils/useOnMenuEnter.d.ts +23 -0
- package/lib/utils/useOnMenuEnter.js +72 -0
- package/lib/utils/useOnMenuEnter.js.map +1 -0
- package/lib-commonjs/Menu.d.ts +1 -0
- package/lib-commonjs/Menu.js +10 -0
- package/lib-commonjs/Menu.js.map +1 -0
- package/lib-commonjs/MenuDivider.d.ts +1 -0
- package/lib-commonjs/MenuDivider.js +10 -0
- package/lib-commonjs/MenuDivider.js.map +1 -0
- package/lib-commonjs/MenuGroup.d.ts +1 -0
- package/lib-commonjs/MenuGroup.js +10 -0
- package/lib-commonjs/MenuGroup.js.map +1 -0
- package/lib-commonjs/MenuGroupHeader.d.ts +1 -0
- package/lib-commonjs/MenuGroupHeader.js +10 -0
- package/lib-commonjs/MenuGroupHeader.js.map +1 -0
- package/lib-commonjs/MenuItem.d.ts +1 -0
- package/lib-commonjs/MenuItem.js +10 -0
- package/lib-commonjs/MenuItem.js.map +1 -0
- package/lib-commonjs/MenuItemCheckbox.d.ts +1 -0
- package/lib-commonjs/MenuItemCheckbox.js +10 -0
- package/lib-commonjs/MenuItemCheckbox.js.map +1 -0
- package/lib-commonjs/MenuItemRadio.d.ts +1 -0
- package/lib-commonjs/MenuItemRadio.js +10 -0
- package/lib-commonjs/MenuItemRadio.js.map +1 -0
- package/lib-commonjs/MenuList.d.ts +1 -0
- package/lib-commonjs/MenuList.js +10 -0
- package/lib-commonjs/MenuList.js.map +1 -0
- package/lib-commonjs/MenuPopover.d.ts +1 -0
- package/lib-commonjs/MenuPopover.js +10 -0
- package/lib-commonjs/MenuPopover.js.map +1 -0
- package/lib-commonjs/MenuSplitGroup.d.ts +1 -0
- package/lib-commonjs/MenuSplitGroup.js +10 -0
- package/lib-commonjs/MenuSplitGroup.js.map +1 -0
- package/lib-commonjs/MenuTrigger.d.ts +1 -0
- package/lib-commonjs/MenuTrigger.js +10 -0
- package/lib-commonjs/MenuTrigger.js.map +1 -0
- package/lib-commonjs/components/Menu/Menu.d.ts +6 -0
- package/lib-commonjs/components/Menu/Menu.js +26 -0
- package/lib-commonjs/components/Menu/Menu.js.map +1 -0
- package/lib-commonjs/components/Menu/Menu.types.d.ts +113 -0
- package/lib-commonjs/components/Menu/Menu.types.js +6 -0
- package/lib-commonjs/components/Menu/Menu.types.js.map +1 -0
- package/lib-commonjs/components/Menu/index.d.ts +5 -0
- package/lib-commonjs/components/Menu/index.js +18 -0
- package/lib-commonjs/components/Menu/index.js.map +1 -0
- package/lib-commonjs/components/Menu/renderMenu.d.ts +5 -0
- package/lib-commonjs/components/Menu/renderMenu.js +23 -0
- package/lib-commonjs/components/Menu/renderMenu.js.map +1 -0
- package/lib-commonjs/components/Menu/useMenu.d.ts +10 -0
- package/lib-commonjs/components/Menu/useMenu.js +278 -0
- package/lib-commonjs/components/Menu/useMenu.js.map +1 -0
- package/lib-commonjs/components/Menu/useMenuContextValues.d.ts +2 -0
- package/lib-commonjs/components/Menu/useMenuContextValues.js +50 -0
- package/lib-commonjs/components/Menu/useMenuContextValues.js.map +1 -0
- package/lib-commonjs/components/MenuDivider/MenuDivider.d.ts +6 -0
- package/lib-commonjs/components/MenuDivider/MenuDivider.js +26 -0
- package/lib-commonjs/components/MenuDivider/MenuDivider.js.map +1 -0
- package/lib-commonjs/components/MenuDivider/MenuDivider.types.d.ts +6 -0
- package/lib-commonjs/components/MenuDivider/MenuDivider.types.js +6 -0
- package/lib-commonjs/components/MenuDivider/MenuDivider.types.js.map +1 -0
- package/lib-commonjs/components/MenuDivider/index.d.ts +5 -0
- package/lib-commonjs/components/MenuDivider/index.js +18 -0
- package/lib-commonjs/components/MenuDivider/index.js.map +1 -0
- package/lib-commonjs/components/MenuDivider/renderMenuDivider.d.ts +6 -0
- package/lib-commonjs/components/MenuDivider/renderMenuDivider.js +27 -0
- package/lib-commonjs/components/MenuDivider/renderMenuDivider.js.map +1 -0
- package/lib-commonjs/components/MenuDivider/useMenuDivider.d.ts +6 -0
- package/lib-commonjs/components/MenuDivider/useMenuDivider.js +29 -0
- package/lib-commonjs/components/MenuDivider/useMenuDivider.js.map +1 -0
- package/lib-commonjs/components/MenuDivider/useMenuDividerStyles.d.ts +3 -0
- package/lib-commonjs/components/MenuDivider/useMenuDividerStyles.js +35 -0
- package/lib-commonjs/components/MenuDivider/useMenuDividerStyles.js.map +1 -0
- package/lib-commonjs/components/MenuGroup/MenuGroup.d.ts +6 -0
- package/lib-commonjs/components/MenuGroup/MenuGroup.js +29 -0
- package/lib-commonjs/components/MenuGroup/MenuGroup.js.map +1 -0
- package/lib-commonjs/components/MenuGroup/MenuGroup.types.d.ts +15 -0
- package/lib-commonjs/components/MenuGroup/MenuGroup.types.js +6 -0
- package/lib-commonjs/components/MenuGroup/MenuGroup.types.js.map +1 -0
- package/lib-commonjs/components/MenuGroup/index.d.ts +6 -0
- package/lib-commonjs/components/MenuGroup/index.js +20 -0
- package/lib-commonjs/components/MenuGroup/index.js.map +1 -0
- package/lib-commonjs/components/MenuGroup/renderMenuGroup.d.ts +6 -0
- package/lib-commonjs/components/MenuGroup/renderMenuGroup.js +31 -0
- package/lib-commonjs/components/MenuGroup/renderMenuGroup.js.map +1 -0
- package/lib-commonjs/components/MenuGroup/useMenuGroup.d.ts +6 -0
- package/lib-commonjs/components/MenuGroup/useMenuGroup.js +31 -0
- package/lib-commonjs/components/MenuGroup/useMenuGroup.js.map +1 -0
- package/lib-commonjs/components/MenuGroup/useMenuGroupContextValues.d.ts +2 -0
- package/lib-commonjs/components/MenuGroup/useMenuGroupContextValues.js +23 -0
- package/lib-commonjs/components/MenuGroup/useMenuGroupContextValues.js.map +1 -0
- package/lib-commonjs/components/MenuGroup/useMenuGroupStyles.d.ts +3 -0
- package/lib-commonjs/components/MenuGroup/useMenuGroupStyles.js +18 -0
- package/lib-commonjs/components/MenuGroup/useMenuGroupStyles.js.map +1 -0
- package/lib-commonjs/components/MenuGroupHeader/MenuGroupHeader.d.ts +6 -0
- package/lib-commonjs/components/MenuGroupHeader/MenuGroupHeader.js +26 -0
- package/lib-commonjs/components/MenuGroupHeader/MenuGroupHeader.js.map +1 -0
- package/lib-commonjs/components/MenuGroupHeader/MenuGroupHeader.types.d.ts +6 -0
- package/lib-commonjs/components/MenuGroupHeader/MenuGroupHeader.types.js +6 -0
- package/lib-commonjs/components/MenuGroupHeader/MenuGroupHeader.types.js.map +1 -0
- package/lib-commonjs/components/MenuGroupHeader/index.d.ts +5 -0
- package/lib-commonjs/components/MenuGroupHeader/index.js +18 -0
- package/lib-commonjs/components/MenuGroupHeader/index.js.map +1 -0
- package/lib-commonjs/components/MenuGroupHeader/renderMenuGroupHeader.d.ts +6 -0
- package/lib-commonjs/components/MenuGroupHeader/renderMenuGroupHeader.js +27 -0
- package/lib-commonjs/components/MenuGroupHeader/renderMenuGroupHeader.js.map +1 -0
- package/lib-commonjs/components/MenuGroupHeader/useMenuGroupHeader.d.ts +6 -0
- package/lib-commonjs/components/MenuGroupHeader/useMenuGroupHeader.js +33 -0
- package/lib-commonjs/components/MenuGroupHeader/useMenuGroupHeader.js.map +1 -0
- package/lib-commonjs/components/MenuGroupHeader/useMenuGroupHeaderStyles.d.ts +3 -0
- package/lib-commonjs/components/MenuGroupHeader/useMenuGroupHeaderStyles.js +36 -0
- package/lib-commonjs/components/MenuGroupHeader/useMenuGroupHeaderStyles.js.map +1 -0
- package/lib-commonjs/components/MenuItem/MenuItem.d.ts +6 -0
- package/lib-commonjs/components/MenuItem/MenuItem.js +26 -0
- package/lib-commonjs/components/MenuItem/MenuItem.js.map +1 -0
- package/lib-commonjs/components/MenuItem/MenuItem.types.d.ts +43 -0
- package/lib-commonjs/components/MenuItem/MenuItem.types.js +6 -0
- package/lib-commonjs/components/MenuItem/MenuItem.types.js.map +1 -0
- package/lib-commonjs/components/MenuItem/index.d.ts +5 -0
- package/lib-commonjs/components/MenuItem/index.js +18 -0
- package/lib-commonjs/components/MenuItem/index.js.map +1 -0
- package/lib-commonjs/components/MenuItem/renderMenuItem.d.ts +5 -0
- package/lib-commonjs/components/MenuItem/renderMenuItem.js +31 -0
- package/lib-commonjs/components/MenuItem/renderMenuItem.js.map +1 -0
- package/lib-commonjs/components/MenuItem/useCharacterSearch.d.ts +3 -0
- package/lib-commonjs/components/MenuItem/useCharacterSearch.js +36 -0
- package/lib-commonjs/components/MenuItem/useCharacterSearch.js.map +1 -0
- package/lib-commonjs/components/MenuItem/useMenuItem.d.ts +6 -0
- package/lib-commonjs/components/MenuItem/useMenuItem.js +142 -0
- package/lib-commonjs/components/MenuItem/useMenuItem.js.map +1 -0
- package/lib-commonjs/components/MenuItem/useMenuItemStyles.d.ts +4 -0
- package/lib-commonjs/components/MenuItem/useMenuItemStyles.js +120 -0
- package/lib-commonjs/components/MenuItem/useMenuItemStyles.js.map +1 -0
- package/lib-commonjs/components/MenuItemCheckbox/MenuItemCheckbox.d.ts +6 -0
- package/lib-commonjs/components/MenuItemCheckbox/MenuItemCheckbox.js +26 -0
- package/lib-commonjs/components/MenuItemCheckbox/MenuItemCheckbox.js.map +1 -0
- package/lib-commonjs/components/MenuItemCheckbox/MenuItemCheckbox.types.d.ts +4 -0
- package/lib-commonjs/components/MenuItemCheckbox/MenuItemCheckbox.types.js +6 -0
- package/lib-commonjs/components/MenuItemCheckbox/MenuItemCheckbox.types.js.map +1 -0
- package/lib-commonjs/components/MenuItemCheckbox/index.d.ts +5 -0
- package/lib-commonjs/components/MenuItemCheckbox/index.js +18 -0
- package/lib-commonjs/components/MenuItemCheckbox/index.js.map +1 -0
- package/lib-commonjs/components/MenuItemCheckbox/renderMenuItemCheckbox.d.ts +3 -0
- package/lib-commonjs/components/MenuItemCheckbox/renderMenuItemCheckbox.js +28 -0
- package/lib-commonjs/components/MenuItemCheckbox/renderMenuItemCheckbox.js.map +1 -0
- package/lib-commonjs/components/MenuItemCheckbox/useMenuItemCheckbox.d.ts +4 -0
- package/lib-commonjs/components/MenuItemCheckbox/useMenuItemCheckbox.js +60 -0
- package/lib-commonjs/components/MenuItemCheckbox/useMenuItemCheckbox.js.map +1 -0
- package/lib-commonjs/components/MenuItemCheckbox/useMenuItemCheckboxStyles.d.ts +3 -0
- package/lib-commonjs/components/MenuItemCheckbox/useMenuItemCheckboxStyles.js +23 -0
- package/lib-commonjs/components/MenuItemCheckbox/useMenuItemCheckboxStyles.js.map +1 -0
- package/lib-commonjs/components/MenuItemRadio/MenuItemRadio.d.ts +6 -0
- package/lib-commonjs/components/MenuItemRadio/MenuItemRadio.js +26 -0
- package/lib-commonjs/components/MenuItemRadio/MenuItemRadio.js.map +1 -0
- package/lib-commonjs/components/MenuItemRadio/MenuItemRadio.types.d.ts +4 -0
- package/lib-commonjs/components/MenuItemRadio/MenuItemRadio.types.js +6 -0
- package/lib-commonjs/components/MenuItemRadio/MenuItemRadio.types.js.map +1 -0
- package/lib-commonjs/components/MenuItemRadio/index.d.ts +5 -0
- package/lib-commonjs/components/MenuItemRadio/index.js +18 -0
- package/lib-commonjs/components/MenuItemRadio/index.js.map +1 -0
- package/lib-commonjs/components/MenuItemRadio/renderMenuItemRadio.d.ts +6 -0
- package/lib-commonjs/components/MenuItemRadio/renderMenuItemRadio.js +31 -0
- package/lib-commonjs/components/MenuItemRadio/renderMenuItemRadio.js.map +1 -0
- package/lib-commonjs/components/MenuItemRadio/useMenuItemRadio.d.ts +6 -0
- package/lib-commonjs/components/MenuItemRadio/useMenuItemRadio.js +63 -0
- package/lib-commonjs/components/MenuItemRadio/useMenuItemRadio.js.map +1 -0
- package/lib-commonjs/components/MenuItemRadio/useMenuItemRadioStyles.d.ts +3 -0
- package/lib-commonjs/components/MenuItemRadio/useMenuItemRadioStyles.js +23 -0
- package/lib-commonjs/components/MenuItemRadio/useMenuItemRadioStyles.js.map +1 -0
- package/lib-commonjs/components/MenuList/MenuList.d.ts +6 -0
- package/lib-commonjs/components/MenuList/MenuList.js +29 -0
- package/lib-commonjs/components/MenuList/MenuList.js.map +1 -0
- package/lib-commonjs/components/MenuList/MenuList.types.d.ts +55 -0
- package/lib-commonjs/components/MenuList/MenuList.types.js +6 -0
- package/lib-commonjs/components/MenuList/MenuList.types.js.map +1 -0
- package/lib-commonjs/components/MenuList/index.d.ts +6 -0
- package/lib-commonjs/components/MenuList/index.js +18 -0
- package/lib-commonjs/components/MenuList/index.js.map +1 -0
- package/lib-commonjs/components/MenuList/renderMenuList.d.ts +5 -0
- package/lib-commonjs/components/MenuList/renderMenuList.js +30 -0
- package/lib-commonjs/components/MenuList/renderMenuList.js.map +1 -0
- package/lib-commonjs/components/MenuList/useMenuList.d.ts +6 -0
- package/lib-commonjs/components/MenuList/useMenuList.js +183 -0
- package/lib-commonjs/components/MenuList/useMenuList.js.map +1 -0
- package/lib-commonjs/components/MenuList/useMenuListContextValues.d.ts +2 -0
- package/lib-commonjs/components/MenuList/useMenuListContextValues.js +34 -0
- package/lib-commonjs/components/MenuList/useMenuListContextValues.js.map +1 -0
- package/lib-commonjs/components/MenuList/useMenuListStyles.d.ts +6 -0
- package/lib-commonjs/components/MenuList/useMenuListStyles.js +34 -0
- package/lib-commonjs/components/MenuList/useMenuListStyles.js.map +1 -0
- package/lib-commonjs/components/MenuPopover/MenuPopover.d.ts +6 -0
- package/lib-commonjs/components/MenuPopover/MenuPopover.js +26 -0
- package/lib-commonjs/components/MenuPopover/MenuPopover.js.map +1 -0
- package/lib-commonjs/components/MenuPopover/MenuPopover.types.d.ts +18 -0
- package/lib-commonjs/components/MenuPopover/MenuPopover.types.js +6 -0
- package/lib-commonjs/components/MenuPopover/MenuPopover.types.js.map +1 -0
- package/lib-commonjs/components/MenuPopover/index.d.ts +5 -0
- package/lib-commonjs/components/MenuPopover/index.js +18 -0
- package/lib-commonjs/components/MenuPopover/index.js.map +1 -0
- package/lib-commonjs/components/MenuPopover/renderMenuPopover.d.ts +5 -0
- package/lib-commonjs/components/MenuPopover/renderMenuPopover.js +34 -0
- package/lib-commonjs/components/MenuPopover/renderMenuPopover.js.map +1 -0
- package/lib-commonjs/components/MenuPopover/useMenuPopover.d.ts +12 -0
- package/lib-commonjs/components/MenuPopover/useMenuPopover.js +120 -0
- package/lib-commonjs/components/MenuPopover/useMenuPopover.js.map +1 -0
- package/lib-commonjs/components/MenuPopover/useMenuPopoverStyles.d.ts +6 -0
- package/lib-commonjs/components/MenuPopover/useMenuPopoverStyles.js +57 -0
- package/lib-commonjs/components/MenuPopover/useMenuPopoverStyles.js.map +1 -0
- package/lib-commonjs/components/MenuSplitGroup/MenuSplitGroup.d.ts +6 -0
- package/lib-commonjs/components/MenuSplitGroup/MenuSplitGroup.js +26 -0
- package/lib-commonjs/components/MenuSplitGroup/MenuSplitGroup.js.map +1 -0
- package/lib-commonjs/components/MenuSplitGroup/MenuSplitGroup.types.d.ts +14 -0
- package/lib-commonjs/components/MenuSplitGroup/MenuSplitGroup.types.js +6 -0
- package/lib-commonjs/components/MenuSplitGroup/MenuSplitGroup.types.js.map +1 -0
- package/lib-commonjs/components/MenuSplitGroup/index.d.ts +5 -0
- package/lib-commonjs/components/MenuSplitGroup/index.js +18 -0
- package/lib-commonjs/components/MenuSplitGroup/index.js.map +1 -0
- package/lib-commonjs/components/MenuSplitGroup/renderMenuSplitGroup.d.ts +5 -0
- package/lib-commonjs/components/MenuSplitGroup/renderMenuSplitGroup.js +26 -0
- package/lib-commonjs/components/MenuSplitGroup/renderMenuSplitGroup.js.map +1 -0
- package/lib-commonjs/components/MenuSplitGroup/useMenuSplitGroup.d.ts +12 -0
- package/lib-commonjs/components/MenuSplitGroup/useMenuSplitGroup.js +81 -0
- package/lib-commonjs/components/MenuSplitGroup/useMenuSplitGroup.js.map +1 -0
- package/lib-commonjs/components/MenuSplitGroup/useMenuSplitGroupStyles.d.ts +6 -0
- package/lib-commonjs/components/MenuSplitGroup/useMenuSplitGroupStyles.js +47 -0
- package/lib-commonjs/components/MenuSplitGroup/useMenuSplitGroupStyles.js.map +1 -0
- package/lib-commonjs/components/MenuTrigger/MenuTrigger.d.ts +8 -0
- package/lib-commonjs/components/MenuTrigger/MenuTrigger.js +25 -0
- package/lib-commonjs/components/MenuTrigger/MenuTrigger.js.map +1 -0
- package/lib-commonjs/components/MenuTrigger/MenuTrigger.types.d.ts +20 -0
- package/lib-commonjs/components/MenuTrigger/MenuTrigger.types.js +6 -0
- package/lib-commonjs/components/MenuTrigger/MenuTrigger.types.js.map +1 -0
- package/lib-commonjs/components/MenuTrigger/index.d.ts +4 -0
- package/lib-commonjs/components/MenuTrigger/index.js +16 -0
- package/lib-commonjs/components/MenuTrigger/index.js.map +1 -0
- package/lib-commonjs/components/MenuTrigger/renderMenuTrigger.d.ts +7 -0
- package/lib-commonjs/components/MenuTrigger/renderMenuTrigger.js +25 -0
- package/lib-commonjs/components/MenuTrigger/renderMenuTrigger.js.map +1 -0
- package/lib-commonjs/components/MenuTrigger/useMenuTrigger.d.ts +8 -0
- package/lib-commonjs/components/MenuTrigger/useMenuTrigger.js +195 -0
- package/lib-commonjs/components/MenuTrigger/useMenuTrigger.js.map +1 -0
- package/lib-commonjs/components/index.d.ts +2 -0
- package/lib-commonjs/components/index.js +12 -0
- package/lib-commonjs/components/index.js.map +1 -0
- package/lib-commonjs/contexts/menuContext.d.ts +16 -0
- package/lib-commonjs/contexts/menuContext.js +34 -0
- package/lib-commonjs/contexts/menuContext.js.map +1 -0
- package/lib-commonjs/contexts/menuGroupContext.d.ts +13 -0
- package/lib-commonjs/contexts/menuGroupContext.js +18 -0
- package/lib-commonjs/contexts/menuGroupContext.js.map +1 -0
- package/lib-commonjs/contexts/menuListContext.d.ts +15 -0
- package/lib-commonjs/contexts/menuListContext.js +24 -0
- package/lib-commonjs/contexts/menuListContext.js.map +1 -0
- package/lib-commonjs/contexts/menuTriggerContext.d.ts +3 -0
- package/lib-commonjs/contexts/menuTriggerContext.js +20 -0
- package/lib-commonjs/contexts/menuTriggerContext.js.map +1 -0
- package/lib-commonjs/index.d.ts +16 -0
- package/lib-commonjs/index.js +40 -0
- package/lib-commonjs/index.js.map +1 -0
- package/lib-commonjs/selectable/index.d.ts +2 -0
- package/lib-commonjs/selectable/index.js +12 -0
- package/lib-commonjs/selectable/index.js.map +1 -0
- package/lib-commonjs/selectable/types.d.ts +34 -0
- package/lib-commonjs/selectable/types.js +6 -0
- package/lib-commonjs/selectable/types.js.map +1 -0
- package/lib-commonjs/selectable/useCheckmarkStyles.d.ts +8 -0
- package/lib-commonjs/selectable/useCheckmarkStyles.js +38 -0
- package/lib-commonjs/selectable/useCheckmarkStyles.js.map +1 -0
- package/lib-commonjs/utils/index.d.ts +1 -0
- package/lib-commonjs/utils/index.js +10 -0
- package/lib-commonjs/utils/index.js.map +1 -0
- package/lib-commonjs/utils/useIsSubmenu.d.ts +9 -0
- package/lib-commonjs/utils/useIsSubmenu.js +30 -0
- package/lib-commonjs/utils/useIsSubmenu.js.map +1 -0
- package/lib-commonjs/utils/useOnMenuEnter.d.ts +23 -0
- package/lib-commonjs/utils/useOnMenuEnter.js +86 -0
- package/lib-commonjs/utils/useOnMenuEnter.js.map +1 -0
- package/package.json +71 -0
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { useEventCallback } from '@fluentui/react-utilities';
|
|
3
|
+
import { elementContains } from '@fluentui/react-portal';
|
|
4
|
+
/**
|
|
5
|
+
* Name of the custom event
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
export const MENU_ENTER_EVENT = 'fuimenuenter';
|
|
9
|
+
/**
|
|
10
|
+
* This hook works similarly to @see {useOnClickOutside}
|
|
11
|
+
*
|
|
12
|
+
* Problem: Trying to behave the same as system menus:
|
|
13
|
+
* When the mouse leaves a stack of nested menus the stack should not dismiss.
|
|
14
|
+
* However if the mouse leaves a stack of menus and enters a parent menu all its children menu should dismiss.
|
|
15
|
+
*
|
|
16
|
+
* We don't use the native mouseenter event because it would trigger too many times in the document
|
|
17
|
+
* Instead, dispatch custom DOM event from the menu so that it can bubble
|
|
18
|
+
* Each nested menu can use the listener to check if the event is from a child or parent menu
|
|
19
|
+
*/
|
|
20
|
+
|
|
21
|
+
export const useOnMenuMouseEnter = options => {
|
|
22
|
+
const {
|
|
23
|
+
refs,
|
|
24
|
+
callback,
|
|
25
|
+
element,
|
|
26
|
+
disabled
|
|
27
|
+
} = options; // Keep mouse event here because this is essentially a custom 'mouseenter' event
|
|
28
|
+
|
|
29
|
+
const listener = useEventCallback(ev => {
|
|
30
|
+
var _a;
|
|
31
|
+
|
|
32
|
+
const popoverRef = refs[0];
|
|
33
|
+
const someMenuPopover = ev.target; // someMenu is a child -> will always be contained because of vParents
|
|
34
|
+
// someMenu is a parent -> will always not be contained because no vParent
|
|
35
|
+
// someMenu is the current popover -> it will contain itself
|
|
36
|
+
|
|
37
|
+
const isOutsidePopover = !elementContains((_a = popoverRef.current) !== null && _a !== void 0 ? _a : null, someMenuPopover);
|
|
38
|
+
|
|
39
|
+
if (isOutsidePopover && !disabled) {
|
|
40
|
+
callback(ev);
|
|
41
|
+
}
|
|
42
|
+
});
|
|
43
|
+
React.useEffect(() => {
|
|
44
|
+
// eslint-disable-next-line eqeqeq
|
|
45
|
+
if (element == null) {
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
if (!disabled) {
|
|
50
|
+
element.addEventListener(MENU_ENTER_EVENT, listener);
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
return () => {
|
|
54
|
+
element.removeEventListener(MENU_ENTER_EVENT, listener);
|
|
55
|
+
};
|
|
56
|
+
}, [listener, element, disabled]);
|
|
57
|
+
};
|
|
58
|
+
/**
|
|
59
|
+
* Dispatches the custom MouseEvent enter event. Similar to calling `el.click()`
|
|
60
|
+
* @param el element for the event target
|
|
61
|
+
* @param nativeEvent the native mouse event this is mapped to
|
|
62
|
+
*/
|
|
63
|
+
|
|
64
|
+
export const dispatchMenuEnterEvent = (el, nativeEvent) => {
|
|
65
|
+
el.dispatchEvent(new CustomEvent(MENU_ENTER_EVENT, {
|
|
66
|
+
bubbles: true,
|
|
67
|
+
detail: {
|
|
68
|
+
nativeEvent
|
|
69
|
+
}
|
|
70
|
+
}));
|
|
71
|
+
};
|
|
72
|
+
//# sourceMappingURL=useOnMenuEnter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["utils/useOnMenuEnter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAZ,MAAuB,OAAvB;AACA,SAAS,gBAAT,QAAiC,2BAAjC;AACA,SAAS,eAAT,QAAgC,wBAAhC;AAGA;;AAEG;;AACH,OAAO,MAAM,gBAAgB,GAAG,cAAzB;AAEP;;;;;;;;;;AAUG;;AACH,OAAO,MAAM,mBAAmB,GAAI,OAAD,IAA8C;AAC/E,QAAM;AAAE,IAAA,IAAF;AAAQ,IAAA,QAAR;AAAkB,IAAA,OAAlB;AAA2B,IAAA;AAA3B,MAAwC,OAA9C,CAD+E,CAG/E;;AACA,QAAM,QAAQ,GAAG,gBAAgB,CAAE,EAAD,IAAmB;;;AACnD,UAAM,UAAU,GAAG,IAAI,CAAC,CAAD,CAAvB;AACA,UAAM,eAAe,GAAG,EAAE,CAAC,MAA3B,CAFmD,CAInD;AACA;AACA;;AACA,UAAM,gBAAgB,GAAG,CAAC,eAAe,CAAC,CAAA,EAAA,GAAA,UAAU,CAAC,OAAX,MAAkB,IAAlB,IAAkB,EAAA,KAAA,KAAA,CAAlB,GAAkB,EAAlB,GAAsB,IAAvB,EAA6B,eAA7B,CAAzC;;AACA,QAAI,gBAAgB,IAAI,CAAC,QAAzB,EAAmC;AACjC,MAAA,QAAQ,CAAC,EAAD,CAAR;AACD;AACF,GAXgC,CAAjC;AAaA,EAAA,KAAK,CAAC,SAAN,CAAgB,MAAK;AACnB;AACA,QAAI,OAAO,IAAI,IAAf,EAAqB;AACnB;AACD;;AAUD,QAAI,CAAC,QAAL,EAAe;AACb,MAAA,OAAO,CAAC,gBAAR,CAAyB,gBAAzB,EAA2C,QAA3C;AACD;;AAED,WAAO,MAAK;AACV,MAAA,OAAO,CAAC,mBAAR,CAA4B,gBAA5B,EAA8C,QAA9C;AACD,KAFD;AAGD,GArBD,EAqBG,CAAC,QAAD,EAAW,OAAX,EAAoB,QAApB,CArBH;AAsBD,CAvCM;AAyCP;;;;AAIG;;AACH,OAAO,MAAM,sBAAsB,GAAG,CAAC,EAAD,EAAkB,WAAlB,KAA6C;AACjF,EAAA,EAAE,CAAC,aAAH,CAAiB,IAAI,WAAJ,CAAgB,gBAAhB,EAAkC;AAAE,IAAA,OAAO,EAAE,IAAX;AAAiB,IAAA,MAAM,EAAE;AAAE,MAAA;AAAF;AAAzB,GAAlC,CAAjB;AACD,CAFM","sourcesContent":["import * as React from 'react';\nimport { useEventCallback } from '@fluentui/react-utilities';\nimport { elementContains } from '@fluentui/react-portal';\nimport type { UseOnClickOrScrollOutsideOptions } from '@fluentui/react-utilities';\n\n/**\n * Name of the custom event\n */\nexport const MENU_ENTER_EVENT = 'fuimenuenter';\n\n/**\n * This hook works similarly to @see {useOnClickOutside}\n *\n * Problem: Trying to behave the same as system menus:\n * When the mouse leaves a stack of nested menus the stack should not dismiss.\n * However if the mouse leaves a stack of menus and enters a parent menu all its children menu should dismiss.\n *\n * We don't use the native mouseenter event because it would trigger too many times in the document\n * Instead, dispatch custom DOM event from the menu so that it can bubble\n * Each nested menu can use the listener to check if the event is from a child or parent menu\n */\nexport const useOnMenuMouseEnter = (options: UseOnClickOrScrollOutsideOptions) => {\n const { refs, callback, element, disabled } = options;\n\n // Keep mouse event here because this is essentially a custom 'mouseenter' event\n const listener = useEventCallback((ev: MouseEvent) => {\n const popoverRef = refs[0];\n const someMenuPopover = ev.target as HTMLElement;\n\n // someMenu is a child -> will always be contained because of vParents\n // someMenu is a parent -> will always not be contained because no vParent\n // someMenu is the current popover -> it will contain itself\n const isOutsidePopover = !elementContains(popoverRef.current ?? null, someMenuPopover);\n if (isOutsidePopover && !disabled) {\n callback(ev);\n }\n });\n\n React.useEffect(() => {\n // eslint-disable-next-line eqeqeq\n if (element == null) {\n return;\n }\n\n /**\n * Because `addEventListener` type override falls back to 2nd definition (evt name is unknown string literal)\n * evt is being typed as a base class of MouseEvent -> `Event`.\n * This type is used to override `listener` calls to make TS happy\n */\n\n type ListenerOverride = (evt: Event) => void;\n\n if (!disabled) {\n element.addEventListener(MENU_ENTER_EVENT, listener as ListenerOverride);\n }\n\n return () => {\n element.removeEventListener(MENU_ENTER_EVENT, listener as ListenerOverride);\n };\n }, [listener, element, disabled]);\n};\n\n/**\n * Dispatches the custom MouseEvent enter event. Similar to calling `el.click()`\n * @param el element for the event target\n * @param nativeEvent the native mouse event this is mapped to\n */\nexport const dispatchMenuEnterEvent = (el: HTMLElement, nativeEvent: MouseEvent) => {\n el.dispatchEvent(new CustomEvent(MENU_ENTER_EVENT, { bubbles: true, detail: { nativeEvent } }));\n};\n"],"sourceRoot":"../src/"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './components/Menu/index';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["Menu.ts"],"names":[],"mappings":";;;;;;;;AAAA,OAAA,CAAA,YAAA,CAAA,OAAA,CAAA,yBAAA,CAAA,EAAA,OAAA","sourcesContent":["export * from './components/Menu/index';\n"],"sourceRoot":"../src/"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './components/MenuDivider/index';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["MenuDivider.ts"],"names":[],"mappings":";;;;;;;;AAAA,OAAA,CAAA,YAAA,CAAA,OAAA,CAAA,gCAAA,CAAA,EAAA,OAAA","sourcesContent":["export * from './components/MenuDivider/index';\n"],"sourceRoot":"../src/"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './components/MenuGroup/index';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["MenuGroup.ts"],"names":[],"mappings":";;;;;;;;AAAA,OAAA,CAAA,YAAA,CAAA,OAAA,CAAA,8BAAA,CAAA,EAAA,OAAA","sourcesContent":["export * from './components/MenuGroup/index';\n"],"sourceRoot":"../src/"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './components/MenuGroupHeader/index';
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
|
|
7
|
+
const tslib_1 = /*#__PURE__*/require("tslib");
|
|
8
|
+
|
|
9
|
+
tslib_1.__exportStar(require("./components/MenuGroupHeader/index"), exports);
|
|
10
|
+
//# sourceMappingURL=MenuGroupHeader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["MenuGroupHeader.ts"],"names":[],"mappings":";;;;;;;;AAAA,OAAA,CAAA,YAAA,CAAA,OAAA,CAAA,oCAAA,CAAA,EAAA,OAAA","sourcesContent":["export * from './components/MenuGroupHeader/index';\n"],"sourceRoot":"../src/"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './components/MenuItem/index';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["MenuItem.ts"],"names":[],"mappings":";;;;;;;;AAAA,OAAA,CAAA,YAAA,CAAA,OAAA,CAAA,6BAAA,CAAA,EAAA,OAAA","sourcesContent":["export * from './components/MenuItem/index';\n"],"sourceRoot":"../src/"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './components/MenuItemCheckbox/index';
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
|
|
7
|
+
const tslib_1 = /*#__PURE__*/require("tslib");
|
|
8
|
+
|
|
9
|
+
tslib_1.__exportStar(require("./components/MenuItemCheckbox/index"), exports);
|
|
10
|
+
//# sourceMappingURL=MenuItemCheckbox.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["MenuItemCheckbox.ts"],"names":[],"mappings":";;;;;;;;AAAA,OAAA,CAAA,YAAA,CAAA,OAAA,CAAA,qCAAA,CAAA,EAAA,OAAA","sourcesContent":["export * from './components/MenuItemCheckbox/index';\n"],"sourceRoot":"../src/"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './components/MenuItemRadio/index';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["MenuItemRadio.ts"],"names":[],"mappings":";;;;;;;;AAAA,OAAA,CAAA,YAAA,CAAA,OAAA,CAAA,kCAAA,CAAA,EAAA,OAAA","sourcesContent":["export * from './components/MenuItemRadio/index';\n"],"sourceRoot":"../src/"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './components/MenuList/index';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["MenuList.ts"],"names":[],"mappings":";;;;;;;;AAAA,OAAA,CAAA,YAAA,CAAA,OAAA,CAAA,6BAAA,CAAA,EAAA,OAAA","sourcesContent":["export * from './components/MenuList/index';\n"],"sourceRoot":"../src/"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './components/MenuPopover/index';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["MenuPopover.ts"],"names":[],"mappings":";;;;;;;;AAAA,OAAA,CAAA,YAAA,CAAA,OAAA,CAAA,gCAAA,CAAA,EAAA,OAAA","sourcesContent":["export * from './components/MenuPopover/index';\n"],"sourceRoot":"../src/"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './components/MenuSplitGroup/index';
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
|
|
7
|
+
const tslib_1 = /*#__PURE__*/require("tslib");
|
|
8
|
+
|
|
9
|
+
tslib_1.__exportStar(require("./components/MenuSplitGroup/index"), exports);
|
|
10
|
+
//# sourceMappingURL=MenuSplitGroup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["MenuSplitGroup.ts"],"names":[],"mappings":";;;;;;;;AAAA,OAAA,CAAA,YAAA,CAAA,OAAA,CAAA,mCAAA,CAAA,EAAA,OAAA","sourcesContent":["export * from './components/MenuSplitGroup/index';\n"],"sourceRoot":"../src/"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './components/MenuTrigger/index';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["MenuTrigger.ts"],"names":[],"mappings":";;;;;;;;AAAA,OAAA,CAAA,YAAA,CAAA,OAAA,CAAA,gCAAA,CAAA,EAAA,OAAA","sourcesContent":["export * from './components/MenuTrigger/index';\n"],"sourceRoot":"../src/"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.Menu = void 0;
|
|
7
|
+
|
|
8
|
+
const useMenu_1 = /*#__PURE__*/require("./useMenu");
|
|
9
|
+
|
|
10
|
+
const useMenuContextValues_1 = /*#__PURE__*/require("./useMenuContextValues");
|
|
11
|
+
|
|
12
|
+
const renderMenu_1 = /*#__PURE__*/require("./renderMenu");
|
|
13
|
+
/**
|
|
14
|
+
* Wrapper component that manages state for a popup MenuList and a MenuTrigger
|
|
15
|
+
*/
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
const Menu = props => {
|
|
19
|
+
const state = useMenu_1.useMenu_unstable(props);
|
|
20
|
+
const contextValues = useMenuContextValues_1.useMenuContextValues_unstable(state);
|
|
21
|
+
return renderMenu_1.renderMenu_unstable(state, contextValues);
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
exports.Menu = Menu;
|
|
25
|
+
exports.Menu.displayName = 'Menu';
|
|
26
|
+
//# sourceMappingURL=Menu.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["components/Menu/Menu.tsx"],"names":[],"mappings":";;;;;;;AACA,MAAA,SAAA,gBAAA,OAAA,CAAA,WAAA,CAAA;;AACA,MAAA,sBAAA,gBAAA,OAAA,CAAA,wBAAA,CAAA;;AACA,MAAA,YAAA,gBAAA,OAAA,CAAA,cAAA,CAAA;AAGA;;AAEG;;;AACI,MAAM,IAAI,GAAwB,KAAK,IAAG;AAC/C,QAAM,KAAK,GAAG,SAAA,CAAA,gBAAA,CAAiB,KAAjB,CAAd;AACA,QAAM,aAAa,GAAG,sBAAA,CAAA,6BAAA,CAA8B,KAA9B,CAAtB;AAEA,SAAO,YAAA,CAAA,mBAAA,CAAoB,KAApB,EAA2B,aAA3B,CAAP;AACD,CALM;;AAAM,OAAA,CAAA,IAAA,GAAI,IAAJ;AAOb,OAAA,CAAA,IAAA,CAAK,WAAL,GAAmB,MAAnB","sourcesContent":["import * as React from 'react';\nimport { useMenu_unstable } from './useMenu';\nimport { useMenuContextValues_unstable } from './useMenuContextValues';\nimport { renderMenu_unstable } from './renderMenu';\nimport type { MenuProps } from './Menu.types';\n\n/**\n * Wrapper component that manages state for a popup MenuList and a MenuTrigger\n */\nexport const Menu: React.FC<MenuProps> = props => {\n const state = useMenu_unstable(props);\n const contextValues = useMenuContextValues_unstable(state);\n\n return renderMenu_unstable(state, contextValues);\n};\n\nMenu.displayName = 'Menu';\n"],"sourceRoot":"../src/"}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { ComponentProps, ComponentState } from '@fluentui/react-utilities';
|
|
3
|
+
import { usePopperMouseTarget, PositioningShorthand } from '@fluentui/react-positioning';
|
|
4
|
+
import { MenuListCommons } from '../MenuList/MenuList.types';
|
|
5
|
+
import { MenuContextValue } from '../../contexts/menuContext';
|
|
6
|
+
declare type MenuCommons = MenuListCommons & {
|
|
7
|
+
/**
|
|
8
|
+
* Whether the popup is open
|
|
9
|
+
*/
|
|
10
|
+
open: boolean;
|
|
11
|
+
/**
|
|
12
|
+
* Call back when the component requests to change value
|
|
13
|
+
* The `open` value is used as a hint when directly controlling the component
|
|
14
|
+
*/
|
|
15
|
+
onOpenChange?: (e: MenuOpenEvents, data: MenuOpenChangeData) => void;
|
|
16
|
+
/**
|
|
17
|
+
* Whether the popup is open by default
|
|
18
|
+
*/
|
|
19
|
+
defaultOpen?: boolean;
|
|
20
|
+
openOnHover: boolean;
|
|
21
|
+
/**
|
|
22
|
+
* Opens the menu on right click (context menu), removes all other menu open interactions
|
|
23
|
+
*/
|
|
24
|
+
openOnContext?: boolean;
|
|
25
|
+
/**
|
|
26
|
+
* Root menus are rendered out of DOM order on `document.body`, use this to render the menu in DOM order
|
|
27
|
+
* This option is disregarded for submenus
|
|
28
|
+
*/
|
|
29
|
+
inline?: boolean;
|
|
30
|
+
/**
|
|
31
|
+
* Do not dismiss the menu when a menu item is clicked
|
|
32
|
+
*/
|
|
33
|
+
persistOnItemClick?: boolean;
|
|
34
|
+
/**
|
|
35
|
+
* Sets the delay for mouse open/close for the popover one mouse enter/leave
|
|
36
|
+
*/
|
|
37
|
+
hoverDelay?: number;
|
|
38
|
+
};
|
|
39
|
+
export declare type MenuSlots = {};
|
|
40
|
+
/**
|
|
41
|
+
* Extends and drills down Menulist props to simplify API
|
|
42
|
+
*/
|
|
43
|
+
export declare type MenuProps = Partial<MenuCommons> & ComponentProps<MenuSlots> & {
|
|
44
|
+
/**
|
|
45
|
+
* Can contain two children including {@link MenuTrigger} and {@link MenuPopover}.
|
|
46
|
+
* Alternatively can only contain {@link MenuPopover} if using a custom `target`.
|
|
47
|
+
*/
|
|
48
|
+
children: [JSX.Element, JSX.Element] | JSX.Element;
|
|
49
|
+
/**
|
|
50
|
+
* Configures the positioned menu
|
|
51
|
+
*/
|
|
52
|
+
positioning?: PositioningShorthand;
|
|
53
|
+
};
|
|
54
|
+
export declare type MenuState = MenuCommons & ComponentState<MenuSlots> & {
|
|
55
|
+
/**
|
|
56
|
+
* Callback to open/close the popup
|
|
57
|
+
*/
|
|
58
|
+
setOpen: (e: MenuOpenEvents, data: MenuOpenChangeData) => void;
|
|
59
|
+
/**
|
|
60
|
+
* Internal react node that just simplifies handling children
|
|
61
|
+
*/
|
|
62
|
+
menuPopover: React.ReactNode;
|
|
63
|
+
/**
|
|
64
|
+
* Internal react node that just simplifies handling children
|
|
65
|
+
*/
|
|
66
|
+
menuTrigger: React.ReactNode;
|
|
67
|
+
/**
|
|
68
|
+
* The ref for the popup
|
|
69
|
+
*/
|
|
70
|
+
menuPopoverRef: React.MutableRefObject<HTMLElement>;
|
|
71
|
+
/**
|
|
72
|
+
* The ref for the MenuTrigger, used for popup positioning
|
|
73
|
+
*/
|
|
74
|
+
triggerRef: React.MutableRefObject<HTMLElement>;
|
|
75
|
+
/**
|
|
76
|
+
* Id for the MenuTrigger element for aria relationship
|
|
77
|
+
*/
|
|
78
|
+
triggerId: string;
|
|
79
|
+
/**
|
|
80
|
+
* Whether this menu is a submenu
|
|
81
|
+
*/
|
|
82
|
+
isSubmenu: boolean;
|
|
83
|
+
/**
|
|
84
|
+
* Anchors the popper to the mouse click for context events
|
|
85
|
+
*/
|
|
86
|
+
contextTarget: ReturnType<typeof usePopperMouseTarget>[0];
|
|
87
|
+
/**
|
|
88
|
+
* A callback to set the target of the popper to the mouse click for context events
|
|
89
|
+
*/
|
|
90
|
+
setContextTarget: ReturnType<typeof usePopperMouseTarget>[1];
|
|
91
|
+
};
|
|
92
|
+
/**
|
|
93
|
+
* Data attached to open/close events
|
|
94
|
+
*/
|
|
95
|
+
export declare type MenuOpenChangeData = {
|
|
96
|
+
open: boolean;
|
|
97
|
+
/**
|
|
98
|
+
* Indicates whether the change of state was a keyboard interaction
|
|
99
|
+
*/
|
|
100
|
+
keyboard?: boolean;
|
|
101
|
+
/**
|
|
102
|
+
* indicates whether the request for the open state was bubbled from a nested menu
|
|
103
|
+
*/
|
|
104
|
+
bubble?: boolean;
|
|
105
|
+
};
|
|
106
|
+
export declare type MenuContextValues = {
|
|
107
|
+
menu: MenuContextValue;
|
|
108
|
+
};
|
|
109
|
+
/**
|
|
110
|
+
* The supported events that will trigger open/close of the menu
|
|
111
|
+
*/
|
|
112
|
+
export declare type MenuOpenEvents = MouseEvent | TouchEvent | React.MouseEvent<HTMLElement> | React.KeyboardEvent<HTMLElement> | React.FocusEvent<HTMLElement>;
|
|
113
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":"","sourceRoot":"../src/"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
|
|
7
|
+
const tslib_1 = /*#__PURE__*/require("tslib");
|
|
8
|
+
|
|
9
|
+
tslib_1.__exportStar(require("./Menu"), exports);
|
|
10
|
+
|
|
11
|
+
tslib_1.__exportStar(require("./Menu.types"), exports);
|
|
12
|
+
|
|
13
|
+
tslib_1.__exportStar(require("./renderMenu"), exports);
|
|
14
|
+
|
|
15
|
+
tslib_1.__exportStar(require("./useMenu"), exports);
|
|
16
|
+
|
|
17
|
+
tslib_1.__exportStar(require("./useMenuContextValues"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["components/Menu/index.ts"],"names":[],"mappings":";;;;;;;;AAAA,OAAA,CAAA,YAAA,CAAA,OAAA,CAAA,QAAA,CAAA,EAAA,OAAA;;AACA,OAAA,CAAA,YAAA,CAAA,OAAA,CAAA,cAAA,CAAA,EAAA,OAAA;;AACA,OAAA,CAAA,YAAA,CAAA,OAAA,CAAA,cAAA,CAAA,EAAA,OAAA;;AACA,OAAA,CAAA,YAAA,CAAA,OAAA,CAAA,WAAA,CAAA,EAAA,OAAA;;AACA,OAAA,CAAA,YAAA,CAAA,OAAA,CAAA,wBAAA,CAAA,EAAA,OAAA","sourcesContent":["export * from './Menu';\nexport * from './Menu.types';\nexport * from './renderMenu';\nexport * from './useMenu';\nexport * from './useMenuContextValues';\n"],"sourceRoot":"../src/"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.renderMenu_unstable = void 0;
|
|
7
|
+
|
|
8
|
+
const React = /*#__PURE__*/require("react");
|
|
9
|
+
|
|
10
|
+
const menuContext_1 = /*#__PURE__*/require("../../contexts/menuContext");
|
|
11
|
+
/**
|
|
12
|
+
* Render the final JSX of Menu
|
|
13
|
+
*/
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
const renderMenu_unstable = (state, contextValues) => {
|
|
17
|
+
return React.createElement(menuContext_1.MenuProvider, {
|
|
18
|
+
value: contextValues.menu
|
|
19
|
+
}, state.menuTrigger, state.open && state.menuPopover);
|
|
20
|
+
};
|
|
21
|
+
|
|
22
|
+
exports.renderMenu_unstable = renderMenu_unstable;
|
|
23
|
+
//# sourceMappingURL=renderMenu.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["components/Menu/renderMenu.tsx"],"names":[],"mappings":";;;;;;;AAAA,MAAA,KAAA,gBAAA,OAAA,CAAA,OAAA,CAAA;;AACA,MAAA,aAAA,gBAAA,OAAA,CAAA,4BAAA,CAAA;AAGA;;AAEG;;;AACI,MAAM,mBAAmB,GAAG,CAAC,KAAD,EAAmB,aAAnB,KAAuD;AACxF,SACE,KAAA,CAAA,aAAA,CAAC,aAAA,CAAA,YAAD,EAAa;AAAC,IAAA,KAAK,EAAE,aAAa,CAAC;AAAtB,GAAb,EACG,KAAK,CAAC,WADT,EAEG,KAAK,CAAC,IAAN,IAAc,KAAK,CAAC,WAFvB,CADF;AAMD,CAPM;;AAAM,OAAA,CAAA,mBAAA,GAAmB,mBAAnB","sourcesContent":["import * as React from 'react';\nimport { MenuProvider } from '../../contexts/menuContext';\nimport type { MenuContextValues, MenuState } from './Menu.types';\n\n/**\n * Render the final JSX of Menu\n */\nexport const renderMenu_unstable = (state: MenuState, contextValues: MenuContextValues) => {\n return (\n <MenuProvider value={contextValues.menu}>\n {state.menuTrigger}\n {state.open && state.menuPopover}\n </MenuProvider>\n );\n};\n"],"sourceRoot":"../src/"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { MenuProps, MenuState } from './Menu.types';
|
|
2
|
+
/**
|
|
3
|
+
* Create the state required to render Menu.
|
|
4
|
+
*
|
|
5
|
+
* The returned state can be modified with hooks such as useMenuStyles,
|
|
6
|
+
* before being passed to renderMenu_unstable.
|
|
7
|
+
*
|
|
8
|
+
* @param props - props from this instance of Menu
|
|
9
|
+
*/
|
|
10
|
+
export declare const useMenu_unstable: (props: MenuProps) => MenuState;
|