@atlaskit/navigation-system 0.166.0
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.md +3278 -0
- package/README.md +26 -0
- package/afm-cc/tsconfig.json +75 -0
- package/afm-jira/tsconfig.json +75 -0
- package/afm-passionfruit/tsconfig.json +75 -0
- package/afm-post-office/tsconfig.json +75 -0
- package/afm-townsquare/tsconfig.json +75 -0
- package/build/tsconfig.json +17 -0
- package/constellation/index/examples.mdx +44 -0
- package/constellation/index/props.mdx +1 -0
- package/constellation/layout/code.mdx +129 -0
- package/constellation/layout/diagram.tsx +125 -0
- package/constellation/layout/examples.mdx +197 -0
- package/constellation/side-navigation/code.mdx +89 -0
- package/constellation/side-navigation/drag-and-drop.mdx +1079 -0
- package/constellation/side-navigation/examples.mdx +120 -0
- package/constellation/top-navigation/code.mdx +93 -0
- package/constellation/top-navigation/examples.mdx +167 -0
- package/dist/cjs/components/badge-container.compiled.css +7 -0
- package/dist/cjs/components/badge-container.js +37 -0
- package/dist/cjs/components/forward-ref-with-generic.js +11 -0
- package/dist/cjs/components/list-item.js +30 -0
- package/dist/cjs/components/list.js +40 -0
- package/dist/cjs/components/skip-links/skip-link.compiled.css +1 -0
- package/dist/cjs/components/skip-links/skip-link.js +121 -0
- package/dist/cjs/components/skip-links/skip-links-container.compiled.css +21 -0
- package/dist/cjs/components/skip-links/skip-links-container.js +74 -0
- package/dist/cjs/context/skip-links/skip-links-context.js +68 -0
- package/dist/cjs/context/skip-links/skip-links-data-context.js +51 -0
- package/dist/cjs/context/skip-links/skip-links-provider.js +83 -0
- package/dist/cjs/context/skip-links/types.js +1 -0
- package/dist/cjs/context/top-nav-start/top-nav-start-context-provider.js +37 -0
- package/dist/cjs/context/top-nav-start/top-nav-start-context.js +26 -0
- package/dist/cjs/entry-points/experimental/color-utils/parse-hex.js +12 -0
- package/dist/cjs/entry-points/experimental/color-utils/parse-hsl.js +12 -0
- package/dist/cjs/entry-points/experimental/color-utils/parse-rgb.js +12 -0
- package/dist/cjs/entry-points/experimental/color-utils/parse-user-color.js +12 -0
- package/dist/cjs/entry-points/experimental/top-nav-button.js +30 -0
- package/dist/cjs/entry-points/experimental/use-has-custom-theme.js +12 -0
- package/dist/cjs/entry-points/experimental/use-legacy-search-theme.js +12 -0
- package/dist/cjs/entry-points/layout/aside.js +12 -0
- package/dist/cjs/entry-points/layout/banner.js +12 -0
- package/dist/cjs/entry-points/layout/main.js +38 -0
- package/dist/cjs/entry-points/layout/panel-splitter.js +19 -0
- package/dist/cjs/entry-points/layout/panel.js +12 -0
- package/dist/cjs/entry-points/layout/root.js +12 -0
- package/dist/cjs/entry-points/layout/side-nav.js +54 -0
- package/dist/cjs/entry-points/layout/skip-links.js +19 -0
- package/dist/cjs/entry-points/layout/top-nav.js +33 -0
- package/dist/cjs/entry-points/side-nav-items/button-menu-item.js +19 -0
- package/dist/cjs/entry-points/side-nav-items/container-avatar.js +12 -0
- package/dist/cjs/entry-points/side-nav-items/drag-and-drop/drag-preview.js +12 -0
- package/dist/cjs/entry-points/side-nav-items/drag-and-drop/drop-indicator.js +12 -0
- package/dist/cjs/entry-points/side-nav-items/drag-and-drop/group-drop-indicator.js +12 -0
- package/dist/cjs/entry-points/side-nav-items/drag-and-drop/hitbox.js +18 -0
- package/dist/cjs/entry-points/side-nav-items/drag-and-drop/use-menu-item-drag-and-drop.js +12 -0
- package/dist/cjs/entry-points/side-nav-items/expandable-menu-item.js +33 -0
- package/dist/cjs/entry-points/side-nav-items/flyout-menu-item.js +26 -0
- package/dist/cjs/entry-points/side-nav-items/link-menu-item.js +19 -0
- package/dist/cjs/entry-points/side-nav-items/menu-list-item.js +12 -0
- package/dist/cjs/entry-points/side-nav-items/menu-list.js +12 -0
- package/dist/cjs/entry-points/side-nav-items/menu-section.js +26 -0
- package/dist/cjs/entry-points/side-nav-items/top-level-spacer.js +12 -0
- package/dist/cjs/entry-points/top-nav-items/create-button.js +12 -0
- package/dist/cjs/entry-points/top-nav-items/custom-title.js +12 -0
- package/dist/cjs/entry-points/top-nav-items/help.js +12 -0
- package/dist/cjs/entry-points/top-nav-items/index.js +96 -0
- package/dist/cjs/entry-points/top-nav-items/log-in.js +12 -0
- package/dist/cjs/entry-points/top-nav-items/notifications.js +12 -0
- package/dist/cjs/entry-points/top-nav-items/profile.js +12 -0
- package/dist/cjs/entry-points/top-nav-items/settings.js +12 -0
- package/dist/cjs/index.js +327 -0
- package/dist/cjs/ui/menu-item/button-menu-item.js +63 -0
- package/dist/cjs/ui/menu-item/constants.js +21 -0
- package/dist/cjs/ui/menu-item/container-avatar.compiled.css +4 -0
- package/dist/cjs/ui/menu-item/container-avatar.js +34 -0
- package/dist/cjs/ui/menu-item/drag-and-drop/drag-preview.compiled.css +8 -0
- package/dist/cjs/ui/menu-item/drag-and-drop/drag-preview.js +63 -0
- package/dist/cjs/ui/menu-item/drag-and-drop/drop-indicator.js +12 -0
- package/dist/cjs/ui/menu-item/drag-and-drop/group-drop-indicator.js +12 -0
- package/dist/cjs/ui/menu-item/drag-and-drop/hitbox.js +18 -0
- package/dist/cjs/ui/menu-item/drag-and-drop/use-menu-item-drag-and-drop.js +202 -0
- package/dist/cjs/ui/menu-item/drag-handle.compiled.css +9 -0
- package/dist/cjs/ui/menu-item/drag-handle.js +28 -0
- package/dist/cjs/ui/menu-item/expandable-menu-item/expandable-menu-item-content.compiled.css +2 -0
- package/dist/cjs/ui/menu-item/expandable-menu-item/expandable-menu-item-content.js +50 -0
- package/dist/cjs/ui/menu-item/expandable-menu-item/expandable-menu-item-context.js +64 -0
- package/dist/cjs/ui/menu-item/expandable-menu-item/expandable-menu-item-level-context.js +14 -0
- package/dist/cjs/ui/menu-item/expandable-menu-item/expandable-menu-item-trigger.compiled.css +11 -0
- package/dist/cjs/ui/menu-item/expandable-menu-item/expandable-menu-item-trigger.js +136 -0
- package/dist/cjs/ui/menu-item/expandable-menu-item/expandable-menu-item.compiled.css +1 -0
- package/dist/cjs/ui/menu-item/expandable-menu-item/expandable-menu-item.js +67 -0
- package/dist/cjs/ui/menu-item/flyout-menu-item/flyout-menu-item-content.compiled.css +5 -0
- package/dist/cjs/ui/menu-item/flyout-menu-item/flyout-menu-item-content.js +60 -0
- package/dist/cjs/ui/menu-item/flyout-menu-item/flyout-menu-item-context.js +28 -0
- package/dist/cjs/ui/menu-item/flyout-menu-item/flyout-menu-item-trigger.compiled.css +2 -0
- package/dist/cjs/ui/menu-item/flyout-menu-item/flyout-menu-item-trigger.js +68 -0
- package/dist/cjs/ui/menu-item/flyout-menu-item/flyout-menu-item.js +74 -0
- package/dist/cjs/ui/menu-item/link-menu-item.compiled.css +1 -0
- package/dist/cjs/ui/menu-item/link-menu-item.js +81 -0
- package/dist/cjs/ui/menu-item/menu-item-signals.js +11 -0
- package/dist/cjs/ui/menu-item/menu-item.compiled.css +95 -0
- package/dist/cjs/ui/menu-item/menu-item.js +422 -0
- package/dist/cjs/ui/menu-item/menu-list-item.js +18 -0
- package/dist/cjs/ui/menu-item/menu-list.js +14 -0
- package/dist/cjs/ui/menu-item/top-level-spacer.compiled.css +1 -0
- package/dist/cjs/ui/menu-item/top-level-spacer.js +46 -0
- package/dist/cjs/ui/menu-item/types.js +5 -0
- package/dist/cjs/ui/menu-item/use-scroll-menu-item-into-view.js +69 -0
- package/dist/cjs/ui/menu-section/divider.compiled.css +4 -0
- package/dist/cjs/ui/menu-section/divider.js +35 -0
- package/dist/cjs/ui/menu-section/menu-section-context.js +19 -0
- package/dist/cjs/ui/menu-section/menu-section-heading.compiled.css +4 -0
- package/dist/cjs/ui/menu-section/menu-section-heading.js +30 -0
- package/dist/cjs/ui/menu-section/menu-section.js +49 -0
- package/dist/cjs/ui/page-layout/aside.compiled.css +8 -0
- package/dist/cjs/ui/page-layout/aside.js +159 -0
- package/dist/cjs/ui/page-layout/banner.compiled.css +7 -0
- package/dist/cjs/ui/page-layout/banner.js +70 -0
- package/dist/cjs/ui/page-layout/constants.js +61 -0
- package/dist/cjs/ui/page-layout/hoist-slot-sizes-context.js +12 -0
- package/dist/cjs/ui/page-layout/hoist-utils.js +57 -0
- package/dist/cjs/ui/page-layout/id-utils.js +32 -0
- package/dist/cjs/ui/page-layout/main/main-sticky-context.js +11 -0
- package/dist/cjs/ui/page-layout/main/main-sticky-header.compiled.css +4 -0
- package/dist/cjs/ui/page-layout/main/main-sticky-header.js +33 -0
- package/dist/cjs/ui/page-layout/main/main.compiled.css +6 -0
- package/dist/cjs/ui/page-layout/main/main.js +49 -0
- package/dist/cjs/ui/page-layout/panel-splitter/context.js +14 -0
- package/dist/cjs/ui/page-layout/panel-splitter/convert-resize-bound-to-pixels.js +24 -0
- package/dist/cjs/ui/page-layout/panel-splitter/get-percentage-within-pixel-bounds.js +32 -0
- package/dist/cjs/ui/page-layout/panel-splitter/get-width.js +31 -0
- package/dist/cjs/ui/page-layout/panel-splitter/keyboard-resize-manager.js +82 -0
- package/dist/cjs/ui/page-layout/panel-splitter/panel-splitter.compiled.css +34 -0
- package/dist/cjs/ui/page-layout/panel-splitter/panel-splitter.js +342 -0
- package/dist/cjs/ui/page-layout/panel-splitter/provider.js +47 -0
- package/dist/cjs/ui/page-layout/panel-splitter/types.js +1 -0
- package/dist/cjs/ui/page-layout/panel-splitter/use-text-direction.js +23 -0
- package/dist/cjs/ui/page-layout/panel.compiled.css +19 -0
- package/dist/cjs/ui/page-layout/panel.js +195 -0
- package/dist/cjs/ui/page-layout/root.compiled.css +8 -0
- package/dist/cjs/ui/page-layout/root.js +65 -0
- package/dist/cjs/ui/page-layout/side-nav/element-context.js +29 -0
- package/dist/cjs/ui/page-layout/side-nav/flyout-close-delay-ms.js +18 -0
- package/dist/cjs/ui/page-layout/side-nav/side-nav-content.compiled.css +9 -0
- package/dist/cjs/ui/page-layout/side-nav/side-nav-content.js +37 -0
- package/dist/cjs/ui/page-layout/side-nav/side-nav-footer.compiled.css +7 -0
- package/dist/cjs/ui/page-layout/side-nav/side-nav-footer.js +26 -0
- package/dist/cjs/ui/page-layout/side-nav/side-nav-header.compiled.css +3 -0
- package/dist/cjs/ui/page-layout/side-nav/side-nav-header.js +25 -0
- package/dist/cjs/ui/page-layout/side-nav/side-nav.compiled.css +20 -0
- package/dist/cjs/ui/page-layout/side-nav/side-nav.js +608 -0
- package/dist/cjs/ui/page-layout/side-nav/toggle-button-context.js +26 -0
- package/dist/cjs/ui/page-layout/side-nav/toggle-button-provider.js +37 -0
- package/dist/cjs/ui/page-layout/side-nav/toggle-button.compiled.css +2 -0
- package/dist/cjs/ui/page-layout/side-nav/toggle-button.js +119 -0
- package/dist/cjs/ui/page-layout/side-nav/types.js +1 -0
- package/dist/cjs/ui/page-layout/side-nav/use-expand-side-nav.js +56 -0
- package/dist/cjs/ui/page-layout/side-nav/use-side-nav-visibility-callbacks.js +74 -0
- package/dist/cjs/ui/page-layout/side-nav/use-side-nav-visibility.js +34 -0
- package/dist/cjs/ui/page-layout/side-nav/use-toggle-side-nav.js +46 -0
- package/dist/cjs/ui/page-layout/side-nav/visibility-context.js +19 -0
- package/dist/cjs/ui/page-layout/side-nav/visibility-provider.js +28 -0
- package/dist/cjs/ui/page-layout/top-nav/top-nav-end.compiled.css +10 -0
- package/dist/cjs/ui/page-layout/top-nav/top-nav-end.js +103 -0
- package/dist/cjs/ui/page-layout/top-nav/top-nav-middle.compiled.css +8 -0
- package/dist/cjs/ui/page-layout/top-nav/top-nav-middle.js +32 -0
- package/dist/cjs/ui/page-layout/top-nav/top-nav-start.compiled.css +7 -0
- package/dist/cjs/ui/page-layout/top-nav/top-nav-start.js +43 -0
- package/dist/cjs/ui/page-layout/top-nav/top-nav.compiled.css +16 -0
- package/dist/cjs/ui/page-layout/top-nav/top-nav.js +71 -0
- package/dist/cjs/ui/page-layout/types.js +1 -0
- package/dist/cjs/ui/page-layout/use-resizing-width-css-var-on-root-element.js +67 -0
- package/dist/cjs/ui/top-nav-items/app-switcher.js +48 -0
- package/dist/cjs/ui/top-nav-items/chat-button.js +30 -0
- package/dist/cjs/ui/top-nav-items/create-button.js +31 -0
- package/dist/cjs/ui/top-nav-items/custom-title.compiled.css +11 -0
- package/dist/cjs/ui/top-nav-items/custom-title.js +36 -0
- package/dist/cjs/ui/top-nav-items/end-item.js +48 -0
- package/dist/cjs/ui/top-nav-items/help.js +60 -0
- package/dist/cjs/ui/top-nav-items/log-in.js +48 -0
- package/dist/cjs/ui/top-nav-items/nav-logo.compiled.css +22 -0
- package/dist/cjs/ui/top-nav-items/nav-logo.js +127 -0
- package/dist/cjs/ui/top-nav-items/notifications.js +55 -0
- package/dist/cjs/ui/top-nav-items/profile.js +35 -0
- package/dist/cjs/ui/top-nav-items/search.compiled.css +20 -0
- package/dist/cjs/ui/top-nav-items/search.js +68 -0
- package/dist/cjs/ui/top-nav-items/settings.js +24 -0
- package/dist/cjs/ui/top-nav-items/themed/button.compiled.css +58 -0
- package/dist/cjs/ui/top-nav-items/themed/button.js +352 -0
- package/dist/cjs/ui/top-nav-items/themed/color-utils/formats/hex.js +51 -0
- package/dist/cjs/ui/top-nav-items/themed/color-utils/formats/hsl.js +126 -0
- package/dist/cjs/ui/top-nav-items/themed/color-utils/formats/rgb.js +55 -0
- package/dist/cjs/ui/top-nav-items/themed/color-utils/index.js +118 -0
- package/dist/cjs/ui/top-nav-items/themed/color-utils/parse-user-color.js +32 -0
- package/dist/cjs/ui/top-nav-items/themed/color-utils/types.js +1 -0
- package/dist/cjs/ui/top-nav-items/themed/get-custom-theme-styles.js +112 -0
- package/dist/cjs/ui/top-nav-items/themed/has-custom-theme-context.js +19 -0
- package/dist/cjs/ui/top-nav-items/themed/migration.js +53 -0
- package/dist/cjs/ui/top-nav-items/themed/palette.js +68 -0
- package/dist/cjs/ui/top-nav-items/themed/search.js +71 -0
- package/dist/cjs/ui/top-nav-items/themed/use-custom-theme.js +50 -0
- package/dist/es2019/components/badge-container.compiled.css +7 -0
- package/dist/es2019/components/badge-container.js +27 -0
- package/dist/es2019/components/forward-ref-with-generic.js +6 -0
- package/dist/es2019/components/list-item.js +23 -0
- package/dist/es2019/components/list.js +33 -0
- package/dist/es2019/components/skip-links/skip-link.compiled.css +1 -0
- package/dist/es2019/components/skip-links/skip-link.js +114 -0
- package/dist/es2019/components/skip-links/skip-links-container.compiled.css +21 -0
- package/dist/es2019/components/skip-links/skip-links-container.js +66 -0
- package/dist/es2019/context/skip-links/skip-links-context.js +61 -0
- package/dist/es2019/context/skip-links/skip-links-data-context.js +33 -0
- package/dist/es2019/context/skip-links/skip-links-provider.js +70 -0
- package/dist/es2019/context/skip-links/types.js +0 -0
- package/dist/es2019/context/top-nav-start/top-nav-start-context-provider.js +26 -0
- package/dist/es2019/context/top-nav-start/top-nav-start-context.js +20 -0
- package/dist/es2019/entry-points/experimental/color-utils/parse-hex.js +1 -0
- package/dist/es2019/entry-points/experimental/color-utils/parse-hsl.js +1 -0
- package/dist/es2019/entry-points/experimental/color-utils/parse-rgb.js +1 -0
- package/dist/es2019/entry-points/experimental/color-utils/parse-user-color.js +1 -0
- package/dist/es2019/entry-points/experimental/top-nav-button.js +1 -0
- package/dist/es2019/entry-points/experimental/use-has-custom-theme.js +1 -0
- package/dist/es2019/entry-points/experimental/use-legacy-search-theme.js +1 -0
- package/dist/es2019/entry-points/layout/aside.js +1 -0
- package/dist/es2019/entry-points/layout/banner.js +1 -0
- package/dist/es2019/entry-points/layout/main.js +3 -0
- package/dist/es2019/entry-points/layout/panel-splitter.js +2 -0
- package/dist/es2019/entry-points/layout/panel.js +1 -0
- package/dist/es2019/entry-points/layout/root.js +1 -0
- package/dist/es2019/entry-points/layout/side-nav.js +7 -0
- package/dist/es2019/entry-points/layout/skip-links.js +2 -0
- package/dist/es2019/entry-points/layout/top-nav.js +4 -0
- package/dist/es2019/entry-points/side-nav-items/button-menu-item.js +2 -0
- package/dist/es2019/entry-points/side-nav-items/container-avatar.js +1 -0
- package/dist/es2019/entry-points/side-nav-items/drag-and-drop/drag-preview.js +1 -0
- package/dist/es2019/entry-points/side-nav-items/drag-and-drop/drop-indicator.js +1 -0
- package/dist/es2019/entry-points/side-nav-items/drag-and-drop/group-drop-indicator.js +1 -0
- package/dist/es2019/entry-points/side-nav-items/drag-and-drop/hitbox.js +1 -0
- package/dist/es2019/entry-points/side-nav-items/drag-and-drop/use-menu-item-drag-and-drop.js +1 -0
- package/dist/es2019/entry-points/side-nav-items/expandable-menu-item.js +4 -0
- package/dist/es2019/entry-points/side-nav-items/flyout-menu-item.js +3 -0
- package/dist/es2019/entry-points/side-nav-items/link-menu-item.js +2 -0
- package/dist/es2019/entry-points/side-nav-items/menu-list-item.js +1 -0
- package/dist/es2019/entry-points/side-nav-items/menu-list.js +1 -0
- package/dist/es2019/entry-points/side-nav-items/menu-section.js +3 -0
- package/dist/es2019/entry-points/side-nav-items/top-level-spacer.js +1 -0
- package/dist/es2019/entry-points/top-nav-items/create-button.js +1 -0
- package/dist/es2019/entry-points/top-nav-items/custom-title.js +1 -0
- package/dist/es2019/entry-points/top-nav-items/help.js +1 -0
- package/dist/es2019/entry-points/top-nav-items/index.js +13 -0
- package/dist/es2019/entry-points/top-nav-items/log-in.js +1 -0
- package/dist/es2019/entry-points/top-nav-items/notifications.js +1 -0
- package/dist/es2019/entry-points/top-nav-items/profile.js +1 -0
- package/dist/es2019/entry-points/top-nav-items/settings.js +1 -0
- package/dist/es2019/index.js +46 -0
- package/dist/es2019/ui/menu-item/button-menu-item.js +55 -0
- package/dist/es2019/ui/menu-item/constants.js +15 -0
- package/dist/es2019/ui/menu-item/container-avatar.compiled.css +4 -0
- package/dist/es2019/ui/menu-item/container-avatar.js +25 -0
- package/dist/es2019/ui/menu-item/drag-and-drop/drag-preview.compiled.css +8 -0
- package/dist/es2019/ui/menu-item/drag-and-drop/drag-preview.js +58 -0
- package/dist/es2019/ui/menu-item/drag-and-drop/drop-indicator.js +7 -0
- package/dist/es2019/ui/menu-item/drag-and-drop/group-drop-indicator.js +7 -0
- package/dist/es2019/ui/menu-item/drag-and-drop/hitbox.js +7 -0
- package/dist/es2019/ui/menu-item/drag-and-drop/use-menu-item-drag-and-drop.js +192 -0
- package/dist/es2019/ui/menu-item/drag-handle.compiled.css +9 -0
- package/dist/es2019/ui/menu-item/drag-handle.js +19 -0
- package/dist/es2019/ui/menu-item/expandable-menu-item/expandable-menu-item-content.compiled.css +2 -0
- package/dist/es2019/ui/menu-item/expandable-menu-item/expandable-menu-item-content.js +43 -0
- package/dist/es2019/ui/menu-item/expandable-menu-item/expandable-menu-item-context.js +53 -0
- package/dist/es2019/ui/menu-item/expandable-menu-item/expandable-menu-item-level-context.js +9 -0
- package/dist/es2019/ui/menu-item/expandable-menu-item/expandable-menu-item-trigger.compiled.css +11 -0
- package/dist/es2019/ui/menu-item/expandable-menu-item/expandable-menu-item-trigger.js +127 -0
- package/dist/es2019/ui/menu-item/expandable-menu-item/expandable-menu-item.compiled.css +1 -0
- package/dist/es2019/ui/menu-item/expandable-menu-item/expandable-menu-item.js +52 -0
- package/dist/es2019/ui/menu-item/flyout-menu-item/flyout-menu-item-content.compiled.css +5 -0
- package/dist/es2019/ui/menu-item/flyout-menu-item/flyout-menu-item-content.js +51 -0
- package/dist/es2019/ui/menu-item/flyout-menu-item/flyout-menu-item-context.js +18 -0
- package/dist/es2019/ui/menu-item/flyout-menu-item/flyout-menu-item-trigger.compiled.css +2 -0
- package/dist/es2019/ui/menu-item/flyout-menu-item/flyout-menu-item-trigger.js +57 -0
- package/dist/es2019/ui/menu-item/flyout-menu-item/flyout-menu-item.js +59 -0
- package/dist/es2019/ui/menu-item/link-menu-item.compiled.css +1 -0
- package/dist/es2019/ui/menu-item/link-menu-item.js +73 -0
- package/dist/es2019/ui/menu-item/menu-item-signals.js +5 -0
- package/dist/es2019/ui/menu-item/menu-item.compiled.css +95 -0
- package/dist/es2019/ui/menu-item/menu-item.js +406 -0
- package/dist/es2019/ui/menu-item/menu-list-item.js +12 -0
- package/dist/es2019/ui/menu-item/menu-list.js +9 -0
- package/dist/es2019/ui/menu-item/top-level-spacer.compiled.css +1 -0
- package/dist/es2019/ui/menu-item/top-level-spacer.js +38 -0
- package/dist/es2019/ui/menu-item/types.js +1 -0
- package/dist/es2019/ui/menu-item/use-scroll-menu-item-into-view.js +63 -0
- package/dist/es2019/ui/menu-section/divider.compiled.css +4 -0
- package/dist/es2019/ui/menu-section/divider.js +22 -0
- package/dist/es2019/ui/menu-section/menu-section-context.js +13 -0
- package/dist/es2019/ui/menu-section/menu-section-heading.compiled.css +4 -0
- package/dist/es2019/ui/menu-section/menu-section-heading.js +23 -0
- package/dist/es2019/ui/menu-section/menu-section.js +42 -0
- package/dist/es2019/ui/page-layout/aside.compiled.css +8 -0
- package/dist/es2019/ui/page-layout/aside.js +145 -0
- package/dist/es2019/ui/page-layout/banner.compiled.css +7 -0
- package/dist/es2019/ui/page-layout/banner.js +62 -0
- package/dist/es2019/ui/page-layout/constants.js +55 -0
- package/dist/es2019/ui/page-layout/hoist-slot-sizes-context.js +7 -0
- package/dist/es2019/ui/page-layout/hoist-utils.js +49 -0
- package/dist/es2019/ui/page-layout/id-utils.js +26 -0
- package/dist/es2019/ui/page-layout/main/main-sticky-context.js +6 -0
- package/dist/es2019/ui/page-layout/main/main-sticky-header.compiled.css +4 -0
- package/dist/es2019/ui/page-layout/main/main-sticky-header.js +26 -0
- package/dist/es2019/ui/page-layout/main/main.compiled.css +6 -0
- package/dist/es2019/ui/page-layout/main/main.js +41 -0
- package/dist/es2019/ui/page-layout/panel-splitter/context.js +9 -0
- package/dist/es2019/ui/page-layout/panel-splitter/convert-resize-bound-to-pixels.js +18 -0
- package/dist/es2019/ui/page-layout/panel-splitter/get-percentage-within-pixel-bounds.js +27 -0
- package/dist/es2019/ui/page-layout/panel-splitter/get-width.js +27 -0
- package/dist/es2019/ui/page-layout/panel-splitter/keyboard-resize-manager.js +79 -0
- package/dist/es2019/ui/page-layout/panel-splitter/panel-splitter.compiled.css +34 -0
- package/dist/es2019/ui/page-layout/panel-splitter/panel-splitter.js +318 -0
- package/dist/es2019/ui/page-layout/panel-splitter/provider.js +36 -0
- package/dist/es2019/ui/page-layout/panel-splitter/types.js +0 -0
- package/dist/es2019/ui/page-layout/panel-splitter/use-text-direction.js +17 -0
- package/dist/es2019/ui/page-layout/panel.compiled.css +19 -0
- package/dist/es2019/ui/page-layout/panel.js +182 -0
- package/dist/es2019/ui/page-layout/root.compiled.css +8 -0
- package/dist/es2019/ui/page-layout/root.js +65 -0
- package/dist/es2019/ui/page-layout/side-nav/element-context.js +21 -0
- package/dist/es2019/ui/page-layout/side-nav/flyout-close-delay-ms.js +12 -0
- package/dist/es2019/ui/page-layout/side-nav/side-nav-content.compiled.css +9 -0
- package/dist/es2019/ui/page-layout/side-nav/side-nav-content.js +30 -0
- package/dist/es2019/ui/page-layout/side-nav/side-nav-footer.compiled.css +7 -0
- package/dist/es2019/ui/page-layout/side-nav/side-nav-footer.js +22 -0
- package/dist/es2019/ui/page-layout/side-nav/side-nav-header.compiled.css +3 -0
- package/dist/es2019/ui/page-layout/side-nav/side-nav-header.js +18 -0
- package/dist/es2019/ui/page-layout/side-nav/side-nav.compiled.css +20 -0
- package/dist/es2019/ui/page-layout/side-nav/side-nav.js +601 -0
- package/dist/es2019/ui/page-layout/side-nav/toggle-button-context.js +19 -0
- package/dist/es2019/ui/page-layout/side-nav/toggle-button-provider.js +26 -0
- package/dist/es2019/ui/page-layout/side-nav/toggle-button.compiled.css +2 -0
- package/dist/es2019/ui/page-layout/side-nav/toggle-button.js +106 -0
- package/dist/es2019/ui/page-layout/side-nav/types.js +0 -0
- package/dist/es2019/ui/page-layout/side-nav/use-expand-side-nav.js +50 -0
- package/dist/es2019/ui/page-layout/side-nav/use-side-nav-visibility-callbacks.js +68 -0
- package/dist/es2019/ui/page-layout/side-nav/use-side-nav-visibility.js +27 -0
- package/dist/es2019/ui/page-layout/side-nav/use-toggle-side-nav.js +40 -0
- package/dist/es2019/ui/page-layout/side-nav/visibility-context.js +12 -0
- package/dist/es2019/ui/page-layout/side-nav/visibility-provider.js +17 -0
- package/dist/es2019/ui/page-layout/top-nav/top-nav-end.compiled.css +10 -0
- package/dist/es2019/ui/page-layout/top-nav/top-nav-end.js +78 -0
- package/dist/es2019/ui/page-layout/top-nav/top-nav-middle.compiled.css +8 -0
- package/dist/es2019/ui/page-layout/top-nav/top-nav-middle.js +26 -0
- package/dist/es2019/ui/page-layout/top-nav/top-nav-start.compiled.css +7 -0
- package/dist/es2019/ui/page-layout/top-nav/top-nav-start.js +36 -0
- package/dist/es2019/ui/page-layout/top-nav/top-nav.compiled.css +16 -0
- package/dist/es2019/ui/page-layout/top-nav/top-nav.js +62 -0
- package/dist/es2019/ui/page-layout/types.js +0 -0
- package/dist/es2019/ui/page-layout/use-resizing-width-css-var-on-root-element.js +64 -0
- package/dist/es2019/ui/top-nav-items/app-switcher.js +38 -0
- package/dist/es2019/ui/top-nav-items/chat-button.js +23 -0
- package/dist/es2019/ui/top-nav-items/create-button.js +21 -0
- package/dist/es2019/ui/top-nav-items/custom-title.compiled.css +11 -0
- package/dist/es2019/ui/top-nav-items/custom-title.js +29 -0
- package/dist/es2019/ui/top-nav-items/end-item.js +40 -0
- package/dist/es2019/ui/top-nav-items/help.js +51 -0
- package/dist/es2019/ui/top-nav-items/log-in.js +37 -0
- package/dist/es2019/ui/top-nav-items/nav-logo.compiled.css +22 -0
- package/dist/es2019/ui/top-nav-items/nav-logo.js +122 -0
- package/dist/es2019/ui/top-nav-items/notifications.js +47 -0
- package/dist/es2019/ui/top-nav-items/profile.js +23 -0
- package/dist/es2019/ui/top-nav-items/search.compiled.css +20 -0
- package/dist/es2019/ui/top-nav-items/search.js +57 -0
- package/dist/es2019/ui/top-nav-items/settings.js +13 -0
- package/dist/es2019/ui/top-nav-items/themed/button.compiled.css +58 -0
- package/dist/es2019/ui/top-nav-items/themed/button.js +333 -0
- package/dist/es2019/ui/top-nav-items/themed/color-utils/formats/hex.js +42 -0
- package/dist/es2019/ui/top-nav-items/themed/color-utils/formats/hsl.js +113 -0
- package/dist/es2019/ui/top-nav-items/themed/color-utils/formats/rgb.js +37 -0
- package/dist/es2019/ui/top-nav-items/themed/color-utils/index.js +111 -0
- package/dist/es2019/ui/top-nav-items/themed/color-utils/parse-user-color.js +26 -0
- package/dist/es2019/ui/top-nav-items/themed/color-utils/types.js +0 -0
- package/dist/es2019/ui/top-nav-items/themed/get-custom-theme-styles.js +158 -0
- package/dist/es2019/ui/top-nav-items/themed/has-custom-theme-context.js +13 -0
- package/dist/es2019/ui/top-nav-items/themed/migration.js +45 -0
- package/dist/es2019/ui/top-nav-items/themed/palette.js +62 -0
- package/dist/es2019/ui/top-nav-items/themed/search.js +64 -0
- package/dist/es2019/ui/top-nav-items/themed/use-custom-theme.js +44 -0
- package/dist/esm/components/badge-container.compiled.css +7 -0
- package/dist/esm/components/badge-container.js +29 -0
- package/dist/esm/components/forward-ref-with-generic.js +6 -0
- package/dist/esm/components/list-item.js +22 -0
- package/dist/esm/components/list.js +32 -0
- package/dist/esm/components/skip-links/skip-link.compiled.css +1 -0
- package/dist/esm/components/skip-links/skip-link.js +113 -0
- package/dist/esm/components/skip-links/skip-links-container.compiled.css +21 -0
- package/dist/esm/components/skip-links/skip-links-container.js +66 -0
- package/dist/esm/context/skip-links/skip-links-context.js +61 -0
- package/dist/esm/context/skip-links/skip-links-data-context.js +44 -0
- package/dist/esm/context/skip-links/skip-links-provider.js +74 -0
- package/dist/esm/context/skip-links/types.js +0 -0
- package/dist/esm/context/top-nav-start/top-nav-start-context-provider.js +29 -0
- package/dist/esm/context/top-nav-start/top-nav-start-context.js +20 -0
- package/dist/esm/entry-points/experimental/color-utils/parse-hex.js +1 -0
- package/dist/esm/entry-points/experimental/color-utils/parse-hsl.js +1 -0
- package/dist/esm/entry-points/experimental/color-utils/parse-rgb.js +1 -0
- package/dist/esm/entry-points/experimental/color-utils/parse-user-color.js +1 -0
- package/dist/esm/entry-points/experimental/top-nav-button.js +1 -0
- package/dist/esm/entry-points/experimental/use-has-custom-theme.js +1 -0
- package/dist/esm/entry-points/experimental/use-legacy-search-theme.js +1 -0
- package/dist/esm/entry-points/layout/aside.js +1 -0
- package/dist/esm/entry-points/layout/banner.js +1 -0
- package/dist/esm/entry-points/layout/main.js +3 -0
- package/dist/esm/entry-points/layout/panel-splitter.js +2 -0
- package/dist/esm/entry-points/layout/panel.js +1 -0
- package/dist/esm/entry-points/layout/root.js +1 -0
- package/dist/esm/entry-points/layout/side-nav.js +7 -0
- package/dist/esm/entry-points/layout/skip-links.js +2 -0
- package/dist/esm/entry-points/layout/top-nav.js +4 -0
- package/dist/esm/entry-points/side-nav-items/button-menu-item.js +2 -0
- package/dist/esm/entry-points/side-nav-items/container-avatar.js +1 -0
- package/dist/esm/entry-points/side-nav-items/drag-and-drop/drag-preview.js +1 -0
- package/dist/esm/entry-points/side-nav-items/drag-and-drop/drop-indicator.js +1 -0
- package/dist/esm/entry-points/side-nav-items/drag-and-drop/group-drop-indicator.js +1 -0
- package/dist/esm/entry-points/side-nav-items/drag-and-drop/hitbox.js +1 -0
- package/dist/esm/entry-points/side-nav-items/drag-and-drop/use-menu-item-drag-and-drop.js +1 -0
- package/dist/esm/entry-points/side-nav-items/expandable-menu-item.js +4 -0
- package/dist/esm/entry-points/side-nav-items/flyout-menu-item.js +3 -0
- package/dist/esm/entry-points/side-nav-items/link-menu-item.js +2 -0
- package/dist/esm/entry-points/side-nav-items/menu-list-item.js +1 -0
- package/dist/esm/entry-points/side-nav-items/menu-list.js +1 -0
- package/dist/esm/entry-points/side-nav-items/menu-section.js +3 -0
- package/dist/esm/entry-points/side-nav-items/top-level-spacer.js +1 -0
- package/dist/esm/entry-points/top-nav-items/create-button.js +1 -0
- package/dist/esm/entry-points/top-nav-items/custom-title.js +1 -0
- package/dist/esm/entry-points/top-nav-items/help.js +1 -0
- package/dist/esm/entry-points/top-nav-items/index.js +13 -0
- package/dist/esm/entry-points/top-nav-items/log-in.js +1 -0
- package/dist/esm/entry-points/top-nav-items/notifications.js +1 -0
- package/dist/esm/entry-points/top-nav-items/profile.js +1 -0
- package/dist/esm/entry-points/top-nav-items/settings.js +1 -0
- package/dist/esm/index.js +46 -0
- package/dist/esm/ui/menu-item/button-menu-item.js +56 -0
- package/dist/esm/ui/menu-item/constants.js +15 -0
- package/dist/esm/ui/menu-item/container-avatar.compiled.css +4 -0
- package/dist/esm/ui/menu-item/container-avatar.js +26 -0
- package/dist/esm/ui/menu-item/drag-and-drop/drag-preview.compiled.css +8 -0
- package/dist/esm/ui/menu-item/drag-and-drop/drag-preview.js +56 -0
- package/dist/esm/ui/menu-item/drag-and-drop/drop-indicator.js +7 -0
- package/dist/esm/ui/menu-item/drag-and-drop/group-drop-indicator.js +7 -0
- package/dist/esm/ui/menu-item/drag-and-drop/hitbox.js +7 -0
- package/dist/esm/ui/menu-item/drag-and-drop/use-menu-item-drag-and-drop.js +193 -0
- package/dist/esm/ui/menu-item/drag-handle.compiled.css +9 -0
- package/dist/esm/ui/menu-item/drag-handle.js +19 -0
- package/dist/esm/ui/menu-item/expandable-menu-item/expandable-menu-item-content.compiled.css +2 -0
- package/dist/esm/ui/menu-item/expandable-menu-item/expandable-menu-item-content.js +42 -0
- package/dist/esm/ui/menu-item/expandable-menu-item/expandable-menu-item-context.js +57 -0
- package/dist/esm/ui/menu-item/expandable-menu-item/expandable-menu-item-level-context.js +9 -0
- package/dist/esm/ui/menu-item/expandable-menu-item/expandable-menu-item-trigger.compiled.css +11 -0
- package/dist/esm/ui/menu-item/expandable-menu-item/expandable-menu-item-trigger.js +127 -0
- package/dist/esm/ui/menu-item/expandable-menu-item/expandable-menu-item.compiled.css +1 -0
- package/dist/esm/ui/menu-item/expandable-menu-item/expandable-menu-item.js +58 -0
- package/dist/esm/ui/menu-item/flyout-menu-item/flyout-menu-item-content.compiled.css +5 -0
- package/dist/esm/ui/menu-item/flyout-menu-item/flyout-menu-item-content.js +52 -0
- package/dist/esm/ui/menu-item/flyout-menu-item/flyout-menu-item-context.js +22 -0
- package/dist/esm/ui/menu-item/flyout-menu-item/flyout-menu-item-trigger.compiled.css +2 -0
- package/dist/esm/ui/menu-item/flyout-menu-item/flyout-menu-item-trigger.js +59 -0
- package/dist/esm/ui/menu-item/flyout-menu-item/flyout-menu-item.js +65 -0
- package/dist/esm/ui/menu-item/link-menu-item.compiled.css +1 -0
- package/dist/esm/ui/menu-item/link-menu-item.js +72 -0
- package/dist/esm/ui/menu-item/menu-item-signals.js +5 -0
- package/dist/esm/ui/menu-item/menu-item.compiled.css +95 -0
- package/dist/esm/ui/menu-item/menu-item.js +411 -0
- package/dist/esm/ui/menu-item/menu-list-item.js +12 -0
- package/dist/esm/ui/menu-item/menu-list.js +9 -0
- package/dist/esm/ui/menu-item/top-level-spacer.compiled.css +1 -0
- package/dist/esm/ui/menu-item/top-level-spacer.js +38 -0
- package/dist/esm/ui/menu-item/types.js +1 -0
- package/dist/esm/ui/menu-item/use-scroll-menu-item-into-view.js +62 -0
- package/dist/esm/ui/menu-section/divider.compiled.css +4 -0
- package/dist/esm/ui/menu-section/divider.js +27 -0
- package/dist/esm/ui/menu-section/menu-section-context.js +13 -0
- package/dist/esm/ui/menu-section/menu-section-heading.compiled.css +4 -0
- package/dist/esm/ui/menu-section/menu-section-heading.js +22 -0
- package/dist/esm/ui/menu-section/menu-section.js +42 -0
- package/dist/esm/ui/page-layout/aside.compiled.css +8 -0
- package/dist/esm/ui/page-layout/aside.js +150 -0
- package/dist/esm/ui/page-layout/banner.compiled.css +7 -0
- package/dist/esm/ui/page-layout/banner.js +62 -0
- package/dist/esm/ui/page-layout/constants.js +55 -0
- package/dist/esm/ui/page-layout/hoist-slot-sizes-context.js +7 -0
- package/dist/esm/ui/page-layout/hoist-utils.js +51 -0
- package/dist/esm/ui/page-layout/id-utils.js +26 -0
- package/dist/esm/ui/page-layout/main/main-sticky-context.js +6 -0
- package/dist/esm/ui/page-layout/main/main-sticky-header.compiled.css +4 -0
- package/dist/esm/ui/page-layout/main/main-sticky-header.js +25 -0
- package/dist/esm/ui/page-layout/main/main.compiled.css +6 -0
- package/dist/esm/ui/page-layout/main/main.js +41 -0
- package/dist/esm/ui/page-layout/panel-splitter/context.js +9 -0
- package/dist/esm/ui/page-layout/panel-splitter/convert-resize-bound-to-pixels.js +18 -0
- package/dist/esm/ui/page-layout/panel-splitter/get-percentage-within-pixel-bounds.js +26 -0
- package/dist/esm/ui/page-layout/panel-splitter/get-width.js +25 -0
- package/dist/esm/ui/page-layout/panel-splitter/keyboard-resize-manager.js +76 -0
- package/dist/esm/ui/page-layout/panel-splitter/panel-splitter.compiled.css +34 -0
- package/dist/esm/ui/page-layout/panel-splitter/panel-splitter.js +332 -0
- package/dist/esm/ui/page-layout/panel-splitter/provider.js +39 -0
- package/dist/esm/ui/page-layout/panel-splitter/types.js +0 -0
- package/dist/esm/ui/page-layout/panel-splitter/use-text-direction.js +18 -0
- package/dist/esm/ui/page-layout/panel.compiled.css +19 -0
- package/dist/esm/ui/page-layout/panel.js +186 -0
- package/dist/esm/ui/page-layout/root.compiled.css +8 -0
- package/dist/esm/ui/page-layout/root.js +57 -0
- package/dist/esm/ui/page-layout/side-nav/element-context.js +20 -0
- package/dist/esm/ui/page-layout/side-nav/flyout-close-delay-ms.js +12 -0
- package/dist/esm/ui/page-layout/side-nav/side-nav-content.compiled.css +9 -0
- package/dist/esm/ui/page-layout/side-nav/side-nav-content.js +29 -0
- package/dist/esm/ui/page-layout/side-nav/side-nav-footer.compiled.css +7 -0
- package/dist/esm/ui/page-layout/side-nav/side-nav-footer.js +18 -0
- package/dist/esm/ui/page-layout/side-nav/side-nav-header.compiled.css +3 -0
- package/dist/esm/ui/page-layout/side-nav/side-nav-header.js +17 -0
- package/dist/esm/ui/page-layout/side-nav/side-nav.compiled.css +20 -0
- package/dist/esm/ui/page-layout/side-nav/side-nav.js +599 -0
- package/dist/esm/ui/page-layout/side-nav/toggle-button-context.js +19 -0
- package/dist/esm/ui/page-layout/side-nav/toggle-button-provider.js +29 -0
- package/dist/esm/ui/page-layout/side-nav/toggle-button.compiled.css +2 -0
- package/dist/esm/ui/page-layout/side-nav/toggle-button.js +110 -0
- package/dist/esm/ui/page-layout/side-nav/types.js +0 -0
- package/dist/esm/ui/page-layout/side-nav/use-expand-side-nav.js +49 -0
- package/dist/esm/ui/page-layout/side-nav/use-side-nav-visibility-callbacks.js +67 -0
- package/dist/esm/ui/page-layout/side-nav/use-side-nav-visibility.js +28 -0
- package/dist/esm/ui/page-layout/side-nav/use-toggle-side-nav.js +39 -0
- package/dist/esm/ui/page-layout/side-nav/visibility-context.js +12 -0
- package/dist/esm/ui/page-layout/side-nav/visibility-provider.js +20 -0
- package/dist/esm/ui/page-layout/top-nav/top-nav-end.compiled.css +10 -0
- package/dist/esm/ui/page-layout/top-nav/top-nav-end.js +94 -0
- package/dist/esm/ui/page-layout/top-nav/top-nav-middle.compiled.css +8 -0
- package/dist/esm/ui/page-layout/top-nav/top-nav-middle.js +25 -0
- package/dist/esm/ui/page-layout/top-nav/top-nav-start.compiled.css +7 -0
- package/dist/esm/ui/page-layout/top-nav/top-nav-start.js +35 -0
- package/dist/esm/ui/page-layout/top-nav/top-nav.compiled.css +16 -0
- package/dist/esm/ui/page-layout/top-nav/top-nav.js +63 -0
- package/dist/esm/ui/page-layout/types.js +0 -0
- package/dist/esm/ui/page-layout/use-resizing-width-css-var-on-root-element.js +62 -0
- package/dist/esm/ui/top-nav-items/app-switcher.js +39 -0
- package/dist/esm/ui/top-nav-items/chat-button.js +24 -0
- package/dist/esm/ui/top-nav-items/create-button.js +22 -0
- package/dist/esm/ui/top-nav-items/custom-title.compiled.css +11 -0
- package/dist/esm/ui/top-nav-items/custom-title.js +28 -0
- package/dist/esm/ui/top-nav-items/end-item.js +40 -0
- package/dist/esm/ui/top-nav-items/help.js +50 -0
- package/dist/esm/ui/top-nav-items/log-in.js +39 -0
- package/dist/esm/ui/top-nav-items/nav-logo.compiled.css +22 -0
- package/dist/esm/ui/top-nav-items/nav-logo.js +119 -0
- package/dist/esm/ui/top-nav-items/notifications.js +46 -0
- package/dist/esm/ui/top-nav-items/profile.js +26 -0
- package/dist/esm/ui/top-nav-items/search.compiled.css +20 -0
- package/dist/esm/ui/top-nav-items/search.js +59 -0
- package/dist/esm/ui/top-nav-items/settings.js +15 -0
- package/dist/esm/ui/top-nav-items/themed/button.compiled.css +58 -0
- package/dist/esm/ui/top-nav-items/themed/button.js +344 -0
- package/dist/esm/ui/top-nav-items/themed/color-utils/formats/hex.js +45 -0
- package/dist/esm/ui/top-nav-items/themed/color-utils/formats/hsl.js +119 -0
- package/dist/esm/ui/top-nav-items/themed/color-utils/formats/rgb.js +48 -0
- package/dist/esm/ui/top-nav-items/themed/color-utils/index.js +109 -0
- package/dist/esm/ui/top-nav-items/themed/color-utils/parse-user-color.js +26 -0
- package/dist/esm/ui/top-nav-items/themed/color-utils/types.js +0 -0
- package/dist/esm/ui/top-nav-items/themed/get-custom-theme-styles.js +106 -0
- package/dist/esm/ui/top-nav-items/themed/has-custom-theme-context.js +13 -0
- package/dist/esm/ui/top-nav-items/themed/migration.js +45 -0
- package/dist/esm/ui/top-nav-items/themed/palette.js +62 -0
- package/dist/esm/ui/top-nav-items/themed/search.js +64 -0
- package/dist/esm/ui/top-nav-items/themed/use-custom-theme.js +44 -0
- package/dist/types/components/badge-container.d.ts +32 -0
- package/dist/types/components/forward-ref-with-generic.d.ts +4 -0
- package/dist/types/components/list-item.d.ts +27 -0
- package/dist/types/components/list.d.ts +28 -0
- package/dist/types/components/skip-links/skip-link.d.ts +16 -0
- package/dist/types/components/skip-links/skip-links-container.d.ts +13 -0
- package/dist/types/context/skip-links/skip-links-context.d.ts +23 -0
- package/dist/types/context/skip-links/skip-links-data-context.d.ts +7 -0
- package/dist/types/context/skip-links/skip-links-provider.d.ts +7 -0
- package/dist/types/context/skip-links/types.d.ts +27 -0
- package/dist/types/context/top-nav-start/top-nav-start-context-provider.d.ts +17 -0
- package/dist/types/context/top-nav-start/top-nav-start-context.d.ts +17 -0
- package/dist/types/entry-points/experimental/color-utils/parse-hex.d.ts +1 -0
- package/dist/types/entry-points/experimental/color-utils/parse-hsl.d.ts +1 -0
- package/dist/types/entry-points/experimental/color-utils/parse-rgb.d.ts +1 -0
- package/dist/types/entry-points/experimental/color-utils/parse-user-color.d.ts +1 -0
- package/dist/types/entry-points/experimental/top-nav-button.d.ts +1 -0
- package/dist/types/entry-points/experimental/use-has-custom-theme.d.ts +1 -0
- package/dist/types/entry-points/experimental/use-legacy-search-theme.d.ts +1 -0
- package/dist/types/entry-points/layout/aside.d.ts +1 -0
- package/dist/types/entry-points/layout/banner.d.ts +1 -0
- package/dist/types/entry-points/layout/main.d.ts +3 -0
- package/dist/types/entry-points/layout/panel-splitter.d.ts +3 -0
- package/dist/types/entry-points/layout/panel.d.ts +1 -0
- package/dist/types/entry-points/layout/root.d.ts +1 -0
- package/dist/types/entry-points/layout/side-nav.d.ts +7 -0
- package/dist/types/entry-points/layout/skip-links.d.ts +2 -0
- package/dist/types/entry-points/layout/top-nav.d.ts +4 -0
- package/dist/types/entry-points/side-nav-items/button-menu-item.d.ts +3 -0
- package/dist/types/entry-points/side-nav-items/container-avatar.d.ts +1 -0
- package/dist/types/entry-points/side-nav-items/drag-and-drop/drag-preview.d.ts +1 -0
- package/dist/types/entry-points/side-nav-items/drag-and-drop/drop-indicator.d.ts +1 -0
- package/dist/types/entry-points/side-nav-items/drag-and-drop/group-drop-indicator.d.ts +1 -0
- package/dist/types/entry-points/side-nav-items/drag-and-drop/hitbox.d.ts +1 -0
- package/dist/types/entry-points/side-nav-items/drag-and-drop/use-menu-item-drag-and-drop.d.ts +1 -0
- package/dist/types/entry-points/side-nav-items/expandable-menu-item.d.ts +4 -0
- package/dist/types/entry-points/side-nav-items/flyout-menu-item.d.ts +3 -0
- package/dist/types/entry-points/side-nav-items/link-menu-item.d.ts +3 -0
- package/dist/types/entry-points/side-nav-items/menu-list-item.d.ts +1 -0
- package/dist/types/entry-points/side-nav-items/menu-list.d.ts +1 -0
- package/dist/types/entry-points/side-nav-items/menu-section.d.ts +3 -0
- package/dist/types/entry-points/side-nav-items/top-level-spacer.d.ts +1 -0
- package/dist/types/entry-points/top-nav-items/create-button.d.ts +1 -0
- package/dist/types/entry-points/top-nav-items/custom-title.d.ts +1 -0
- package/dist/types/entry-points/top-nav-items/help.d.ts +1 -0
- package/dist/types/entry-points/top-nav-items/index.d.ts +13 -0
- package/dist/types/entry-points/top-nav-items/log-in.d.ts +1 -0
- package/dist/types/entry-points/top-nav-items/notifications.d.ts +1 -0
- package/dist/types/entry-points/top-nav-items/profile.d.ts +1 -0
- package/dist/types/entry-points/top-nav-items/settings.d.ts +1 -0
- package/dist/types/index.d.ts +47 -0
- package/dist/types/ui/menu-item/button-menu-item.d.ts +55 -0
- package/dist/types/ui/menu-item/constants.d.ts +15 -0
- package/dist/types/ui/menu-item/container-avatar.d.ts +19 -0
- package/dist/types/ui/menu-item/drag-and-drop/drag-preview.d.ts +24 -0
- package/dist/types/ui/menu-item/drag-and-drop/drop-indicator.d.ts +6 -0
- package/dist/types/ui/menu-item/drag-and-drop/group-drop-indicator.d.ts +6 -0
- package/dist/types/ui/menu-item/drag-and-drop/hitbox.d.ts +6 -0
- package/dist/types/ui/menu-item/drag-and-drop/use-menu-item-drag-and-drop.d.ts +62 -0
- package/dist/types/ui/menu-item/drag-handle.d.ts +7 -0
- package/dist/types/ui/menu-item/expandable-menu-item/expandable-menu-item-content.d.ts +17 -0
- package/dist/types/ui/menu-item/expandable-menu-item/expandable-menu-item-context.d.ts +37 -0
- package/dist/types/ui/menu-item/expandable-menu-item/expandable-menu-item-level-context.d.ts +5 -0
- package/dist/types/ui/menu-item/expandable-menu-item/expandable-menu-item-trigger.d.ts +121 -0
- package/dist/types/ui/menu-item/expandable-menu-item/expandable-menu-item.d.ts +61 -0
- package/dist/types/ui/menu-item/flyout-menu-item/flyout-menu-item-content.d.ts +32 -0
- package/dist/types/ui/menu-item/flyout-menu-item/flyout-menu-item-context.d.ts +15 -0
- package/dist/types/ui/menu-item/flyout-menu-item/flyout-menu-item-trigger.d.ts +86 -0
- package/dist/types/ui/menu-item/flyout-menu-item/flyout-menu-item.d.ts +52 -0
- package/dist/types/ui/menu-item/link-menu-item.d.ts +43 -0
- package/dist/types/ui/menu-item/menu-item-signals.d.ts +6 -0
- package/dist/types/ui/menu-item/menu-item.d.ts +42 -0
- package/dist/types/ui/menu-item/menu-list-item.d.ts +11 -0
- package/dist/types/ui/menu-item/menu-list.d.ts +9 -0
- package/dist/types/ui/menu-item/top-level-spacer.d.ts +21 -0
- package/dist/types/ui/menu-item/types.d.ts +160 -0
- package/dist/types/ui/menu-item/use-scroll-menu-item-into-view.d.ts +13 -0
- package/dist/types/ui/menu-section/divider.d.ts +7 -0
- package/dist/types/ui/menu-section/menu-section-context.d.ts +7 -0
- package/dist/types/ui/menu-section/menu-section-heading.d.ts +16 -0
- package/dist/types/ui/menu-section/menu-section.d.ts +41 -0
- package/dist/types/ui/page-layout/aside.d.ts +49 -0
- package/dist/types/ui/page-layout/banner.d.ts +23 -0
- package/dist/types/ui/page-layout/constants.d.ts +40 -0
- package/dist/types/ui/page-layout/hoist-slot-sizes-context.d.ts +6 -0
- package/dist/types/ui/page-layout/hoist-utils.d.ts +24 -0
- package/dist/types/ui/page-layout/id-utils.d.ts +17 -0
- package/dist/types/ui/page-layout/main/main-sticky-context.d.ts +5 -0
- package/dist/types/ui/page-layout/main/main-sticky-header.d.ts +23 -0
- package/dist/types/ui/page-layout/main/main.d.ts +38 -0
- package/dist/types/ui/page-layout/panel-splitter/context.d.ts +54 -0
- package/dist/types/ui/page-layout/panel-splitter/convert-resize-bound-to-pixels.d.ts +7 -0
- package/dist/types/ui/page-layout/panel-splitter/get-percentage-within-pixel-bounds.d.ts +18 -0
- package/dist/types/ui/page-layout/panel-splitter/get-width.d.ts +11 -0
- package/dist/types/ui/page-layout/panel-splitter/keyboard-resize-manager.d.ts +15 -0
- package/dist/types/ui/page-layout/panel-splitter/panel-splitter.d.ts +45 -0
- package/dist/types/ui/page-layout/panel-splitter/provider.d.ts +12 -0
- package/dist/types/ui/page-layout/panel-splitter/types.d.ts +23 -0
- package/dist/types/ui/page-layout/panel-splitter/use-text-direction.d.ts +10 -0
- package/dist/types/ui/page-layout/panel.d.ts +41 -0
- package/dist/types/ui/page-layout/root.d.ts +38 -0
- package/dist/types/ui/page-layout/side-nav/element-context.d.ts +10 -0
- package/dist/types/ui/page-layout/side-nav/flyout-close-delay-ms.d.ts +5 -0
- package/dist/types/ui/page-layout/side-nav/side-nav-content.d.ts +24 -0
- package/dist/types/ui/page-layout/side-nav/side-nav-footer.d.ts +19 -0
- package/dist/types/ui/page-layout/side-nav/side-nav-header.d.ts +14 -0
- package/dist/types/ui/page-layout/side-nav/side-nav.d.ts +57 -0
- package/dist/types/ui/page-layout/side-nav/toggle-button-context.d.ts +17 -0
- package/dist/types/ui/page-layout/side-nav/toggle-button-provider.d.ts +17 -0
- package/dist/types/ui/page-layout/side-nav/toggle-button.d.ts +45 -0
- package/dist/types/ui/page-layout/side-nav/types.d.ts +42 -0
- package/dist/types/ui/page-layout/side-nav/use-expand-side-nav.d.ts +12 -0
- package/dist/types/ui/page-layout/side-nav/use-side-nav-visibility-callbacks.d.ts +13 -0
- package/dist/types/ui/page-layout/side-nav/use-side-nav-visibility.d.ts +20 -0
- package/dist/types/ui/page-layout/side-nav/use-toggle-side-nav.d.ts +12 -0
- package/dist/types/ui/page-layout/side-nav/visibility-context.d.ts +11 -0
- package/dist/types/ui/page-layout/side-nav/visibility-provider.d.ts +7 -0
- package/dist/types/ui/page-layout/top-nav/top-nav-end.d.ts +29 -0
- package/dist/types/ui/page-layout/top-nav/top-nav-middle.d.ts +24 -0
- package/dist/types/ui/page-layout/top-nav/top-nav-start.d.ts +22 -0
- package/dist/types/ui/page-layout/top-nav/top-nav.d.ts +29 -0
- package/dist/types/ui/page-layout/types.d.ts +20 -0
- package/dist/types/ui/page-layout/use-resizing-width-css-var-on-root-element.d.ts +9 -0
- package/dist/types/ui/top-nav-items/app-switcher.d.ts +32 -0
- package/dist/types/ui/top-nav-items/chat-button.d.ts +25 -0
- package/dist/types/ui/top-nav-items/create-button.d.ts +30 -0
- package/dist/types/ui/top-nav-items/custom-title.d.ts +23 -0
- package/dist/types/ui/top-nav-items/end-item.d.ts +73 -0
- package/dist/types/ui/top-nav-items/help.d.ts +19 -0
- package/dist/types/ui/top-nav-items/log-in.d.ts +36 -0
- package/dist/types/ui/top-nav-items/nav-logo.d.ts +39 -0
- package/dist/types/ui/top-nav-items/notifications.d.ts +16 -0
- package/dist/types/ui/top-nav-items/profile.d.ts +15 -0
- package/dist/types/ui/top-nav-items/search.d.ts +35 -0
- package/dist/types/ui/top-nav-items/settings.d.ts +11 -0
- package/dist/types/ui/top-nav-items/themed/button.d.ts +128 -0
- package/dist/types/ui/top-nav-items/themed/color-utils/formats/hex.d.ts +9 -0
- package/dist/types/ui/top-nav-items/themed/color-utils/formats/hsl.d.ts +7 -0
- package/dist/types/ui/top-nav-items/themed/color-utils/formats/rgb.d.ts +7 -0
- package/dist/types/ui/top-nav-items/themed/color-utils/index.d.ts +21 -0
- package/dist/types/ui/top-nav-items/themed/color-utils/parse-user-color.d.ts +13 -0
- package/dist/types/ui/top-nav-items/themed/color-utils/types.d.ts +17 -0
- package/dist/types/ui/top-nav-items/themed/get-custom-theme-styles.d.ts +22 -0
- package/dist/types/ui/top-nav-items/themed/has-custom-theme-context.d.ts +9 -0
- package/dist/types/ui/top-nav-items/themed/migration.d.ts +10 -0
- package/dist/types/ui/top-nav-items/themed/palette.d.ts +62 -0
- package/dist/types/ui/top-nav-items/themed/search.d.ts +55 -0
- package/dist/types/ui/top-nav-items/themed/use-custom-theme.d.ts +13 -0
- package/dist/types-ts4.5/components/badge-container.d.ts +32 -0
- package/dist/types-ts4.5/components/forward-ref-with-generic.d.ts +4 -0
- package/dist/types-ts4.5/components/list-item.d.ts +27 -0
- package/dist/types-ts4.5/components/list.d.ts +28 -0
- package/dist/types-ts4.5/components/skip-links/skip-link.d.ts +16 -0
- package/dist/types-ts4.5/components/skip-links/skip-links-container.d.ts +13 -0
- package/dist/types-ts4.5/context/skip-links/skip-links-context.d.ts +23 -0
- package/dist/types-ts4.5/context/skip-links/skip-links-data-context.d.ts +7 -0
- package/dist/types-ts4.5/context/skip-links/skip-links-provider.d.ts +7 -0
- package/dist/types-ts4.5/context/skip-links/types.d.ts +27 -0
- package/dist/types-ts4.5/context/top-nav-start/top-nav-start-context-provider.d.ts +17 -0
- package/dist/types-ts4.5/context/top-nav-start/top-nav-start-context.d.ts +17 -0
- package/dist/types-ts4.5/entry-points/experimental/color-utils/parse-hex.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/experimental/color-utils/parse-hsl.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/experimental/color-utils/parse-rgb.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/experimental/color-utils/parse-user-color.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/experimental/top-nav-button.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/experimental/use-has-custom-theme.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/experimental/use-legacy-search-theme.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/layout/aside.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/layout/banner.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/layout/main.d.ts +3 -0
- package/dist/types-ts4.5/entry-points/layout/panel-splitter.d.ts +3 -0
- package/dist/types-ts4.5/entry-points/layout/panel.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/layout/root.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/layout/side-nav.d.ts +7 -0
- package/dist/types-ts4.5/entry-points/layout/skip-links.d.ts +2 -0
- package/dist/types-ts4.5/entry-points/layout/top-nav.d.ts +4 -0
- package/dist/types-ts4.5/entry-points/side-nav-items/button-menu-item.d.ts +3 -0
- package/dist/types-ts4.5/entry-points/side-nav-items/container-avatar.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/side-nav-items/drag-and-drop/drag-preview.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/side-nav-items/drag-and-drop/drop-indicator.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/side-nav-items/drag-and-drop/group-drop-indicator.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/side-nav-items/drag-and-drop/hitbox.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/side-nav-items/drag-and-drop/use-menu-item-drag-and-drop.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/side-nav-items/expandable-menu-item.d.ts +4 -0
- package/dist/types-ts4.5/entry-points/side-nav-items/flyout-menu-item.d.ts +3 -0
- package/dist/types-ts4.5/entry-points/side-nav-items/link-menu-item.d.ts +3 -0
- package/dist/types-ts4.5/entry-points/side-nav-items/menu-list-item.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/side-nav-items/menu-list.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/side-nav-items/menu-section.d.ts +3 -0
- package/dist/types-ts4.5/entry-points/side-nav-items/top-level-spacer.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/top-nav-items/create-button.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/top-nav-items/custom-title.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/top-nav-items/help.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/top-nav-items/index.d.ts +13 -0
- package/dist/types-ts4.5/entry-points/top-nav-items/log-in.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/top-nav-items/notifications.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/top-nav-items/profile.d.ts +1 -0
- package/dist/types-ts4.5/entry-points/top-nav-items/settings.d.ts +1 -0
- package/dist/types-ts4.5/index.d.ts +47 -0
- package/dist/types-ts4.5/ui/menu-item/button-menu-item.d.ts +55 -0
- package/dist/types-ts4.5/ui/menu-item/constants.d.ts +15 -0
- package/dist/types-ts4.5/ui/menu-item/container-avatar.d.ts +19 -0
- package/dist/types-ts4.5/ui/menu-item/drag-and-drop/drag-preview.d.ts +24 -0
- package/dist/types-ts4.5/ui/menu-item/drag-and-drop/drop-indicator.d.ts +6 -0
- package/dist/types-ts4.5/ui/menu-item/drag-and-drop/group-drop-indicator.d.ts +6 -0
- package/dist/types-ts4.5/ui/menu-item/drag-and-drop/hitbox.d.ts +6 -0
- package/dist/types-ts4.5/ui/menu-item/drag-and-drop/use-menu-item-drag-and-drop.d.ts +62 -0
- package/dist/types-ts4.5/ui/menu-item/drag-handle.d.ts +7 -0
- package/dist/types-ts4.5/ui/menu-item/expandable-menu-item/expandable-menu-item-content.d.ts +17 -0
- package/dist/types-ts4.5/ui/menu-item/expandable-menu-item/expandable-menu-item-context.d.ts +37 -0
- package/dist/types-ts4.5/ui/menu-item/expandable-menu-item/expandable-menu-item-level-context.d.ts +5 -0
- package/dist/types-ts4.5/ui/menu-item/expandable-menu-item/expandable-menu-item-trigger.d.ts +121 -0
- package/dist/types-ts4.5/ui/menu-item/expandable-menu-item/expandable-menu-item.d.ts +61 -0
- package/dist/types-ts4.5/ui/menu-item/flyout-menu-item/flyout-menu-item-content.d.ts +32 -0
- package/dist/types-ts4.5/ui/menu-item/flyout-menu-item/flyout-menu-item-context.d.ts +15 -0
- package/dist/types-ts4.5/ui/menu-item/flyout-menu-item/flyout-menu-item-trigger.d.ts +86 -0
- package/dist/types-ts4.5/ui/menu-item/flyout-menu-item/flyout-menu-item.d.ts +52 -0
- package/dist/types-ts4.5/ui/menu-item/link-menu-item.d.ts +43 -0
- package/dist/types-ts4.5/ui/menu-item/menu-item-signals.d.ts +6 -0
- package/dist/types-ts4.5/ui/menu-item/menu-item.d.ts +42 -0
- package/dist/types-ts4.5/ui/menu-item/menu-list-item.d.ts +11 -0
- package/dist/types-ts4.5/ui/menu-item/menu-list.d.ts +9 -0
- package/dist/types-ts4.5/ui/menu-item/top-level-spacer.d.ts +21 -0
- package/dist/types-ts4.5/ui/menu-item/types.d.ts +160 -0
- package/dist/types-ts4.5/ui/menu-item/use-scroll-menu-item-into-view.d.ts +13 -0
- package/dist/types-ts4.5/ui/menu-section/divider.d.ts +7 -0
- package/dist/types-ts4.5/ui/menu-section/menu-section-context.d.ts +7 -0
- package/dist/types-ts4.5/ui/menu-section/menu-section-heading.d.ts +16 -0
- package/dist/types-ts4.5/ui/menu-section/menu-section.d.ts +41 -0
- package/dist/types-ts4.5/ui/page-layout/aside.d.ts +49 -0
- package/dist/types-ts4.5/ui/page-layout/banner.d.ts +23 -0
- package/dist/types-ts4.5/ui/page-layout/constants.d.ts +40 -0
- package/dist/types-ts4.5/ui/page-layout/hoist-slot-sizes-context.d.ts +6 -0
- package/dist/types-ts4.5/ui/page-layout/hoist-utils.d.ts +24 -0
- package/dist/types-ts4.5/ui/page-layout/id-utils.d.ts +17 -0
- package/dist/types-ts4.5/ui/page-layout/main/main-sticky-context.d.ts +5 -0
- package/dist/types-ts4.5/ui/page-layout/main/main-sticky-header.d.ts +23 -0
- package/dist/types-ts4.5/ui/page-layout/main/main.d.ts +38 -0
- package/dist/types-ts4.5/ui/page-layout/panel-splitter/context.d.ts +54 -0
- package/dist/types-ts4.5/ui/page-layout/panel-splitter/convert-resize-bound-to-pixels.d.ts +7 -0
- package/dist/types-ts4.5/ui/page-layout/panel-splitter/get-percentage-within-pixel-bounds.d.ts +18 -0
- package/dist/types-ts4.5/ui/page-layout/panel-splitter/get-width.d.ts +11 -0
- package/dist/types-ts4.5/ui/page-layout/panel-splitter/keyboard-resize-manager.d.ts +15 -0
- package/dist/types-ts4.5/ui/page-layout/panel-splitter/panel-splitter.d.ts +45 -0
- package/dist/types-ts4.5/ui/page-layout/panel-splitter/provider.d.ts +12 -0
- package/dist/types-ts4.5/ui/page-layout/panel-splitter/types.d.ts +23 -0
- package/dist/types-ts4.5/ui/page-layout/panel-splitter/use-text-direction.d.ts +10 -0
- package/dist/types-ts4.5/ui/page-layout/panel.d.ts +41 -0
- package/dist/types-ts4.5/ui/page-layout/root.d.ts +38 -0
- package/dist/types-ts4.5/ui/page-layout/side-nav/element-context.d.ts +10 -0
- package/dist/types-ts4.5/ui/page-layout/side-nav/flyout-close-delay-ms.d.ts +5 -0
- package/dist/types-ts4.5/ui/page-layout/side-nav/side-nav-content.d.ts +24 -0
- package/dist/types-ts4.5/ui/page-layout/side-nav/side-nav-footer.d.ts +19 -0
- package/dist/types-ts4.5/ui/page-layout/side-nav/side-nav-header.d.ts +14 -0
- package/dist/types-ts4.5/ui/page-layout/side-nav/side-nav.d.ts +57 -0
- package/dist/types-ts4.5/ui/page-layout/side-nav/toggle-button-context.d.ts +17 -0
- package/dist/types-ts4.5/ui/page-layout/side-nav/toggle-button-provider.d.ts +17 -0
- package/dist/types-ts4.5/ui/page-layout/side-nav/toggle-button.d.ts +45 -0
- package/dist/types-ts4.5/ui/page-layout/side-nav/types.d.ts +42 -0
- package/dist/types-ts4.5/ui/page-layout/side-nav/use-expand-side-nav.d.ts +12 -0
- package/dist/types-ts4.5/ui/page-layout/side-nav/use-side-nav-visibility-callbacks.d.ts +13 -0
- package/dist/types-ts4.5/ui/page-layout/side-nav/use-side-nav-visibility.d.ts +20 -0
- package/dist/types-ts4.5/ui/page-layout/side-nav/use-toggle-side-nav.d.ts +12 -0
- package/dist/types-ts4.5/ui/page-layout/side-nav/visibility-context.d.ts +11 -0
- package/dist/types-ts4.5/ui/page-layout/side-nav/visibility-provider.d.ts +7 -0
- package/dist/types-ts4.5/ui/page-layout/top-nav/top-nav-end.d.ts +29 -0
- package/dist/types-ts4.5/ui/page-layout/top-nav/top-nav-middle.d.ts +24 -0
- package/dist/types-ts4.5/ui/page-layout/top-nav/top-nav-start.d.ts +22 -0
- package/dist/types-ts4.5/ui/page-layout/top-nav/top-nav.d.ts +29 -0
- package/dist/types-ts4.5/ui/page-layout/types.d.ts +20 -0
- package/dist/types-ts4.5/ui/page-layout/use-resizing-width-css-var-on-root-element.d.ts +9 -0
- package/dist/types-ts4.5/ui/top-nav-items/app-switcher.d.ts +32 -0
- package/dist/types-ts4.5/ui/top-nav-items/chat-button.d.ts +25 -0
- package/dist/types-ts4.5/ui/top-nav-items/create-button.d.ts +30 -0
- package/dist/types-ts4.5/ui/top-nav-items/custom-title.d.ts +23 -0
- package/dist/types-ts4.5/ui/top-nav-items/end-item.d.ts +73 -0
- package/dist/types-ts4.5/ui/top-nav-items/help.d.ts +19 -0
- package/dist/types-ts4.5/ui/top-nav-items/log-in.d.ts +36 -0
- package/dist/types-ts4.5/ui/top-nav-items/nav-logo.d.ts +39 -0
- package/dist/types-ts4.5/ui/top-nav-items/notifications.d.ts +16 -0
- package/dist/types-ts4.5/ui/top-nav-items/profile.d.ts +15 -0
- package/dist/types-ts4.5/ui/top-nav-items/search.d.ts +35 -0
- package/dist/types-ts4.5/ui/top-nav-items/settings.d.ts +11 -0
- package/dist/types-ts4.5/ui/top-nav-items/themed/button.d.ts +128 -0
- package/dist/types-ts4.5/ui/top-nav-items/themed/color-utils/formats/hex.d.ts +9 -0
- package/dist/types-ts4.5/ui/top-nav-items/themed/color-utils/formats/hsl.d.ts +7 -0
- package/dist/types-ts4.5/ui/top-nav-items/themed/color-utils/formats/rgb.d.ts +7 -0
- package/dist/types-ts4.5/ui/top-nav-items/themed/color-utils/index.d.ts +21 -0
- package/dist/types-ts4.5/ui/top-nav-items/themed/color-utils/parse-user-color.d.ts +13 -0
- package/dist/types-ts4.5/ui/top-nav-items/themed/color-utils/types.d.ts +17 -0
- package/dist/types-ts4.5/ui/top-nav-items/themed/get-custom-theme-styles.d.ts +22 -0
- package/dist/types-ts4.5/ui/top-nav-items/themed/has-custom-theme-context.d.ts +9 -0
- package/dist/types-ts4.5/ui/top-nav-items/themed/migration.d.ts +10 -0
- package/dist/types-ts4.5/ui/top-nav-items/themed/palette.d.ts +62 -0
- package/dist/types-ts4.5/ui/top-nav-items/themed/search.d.ts +55 -0
- package/dist/types-ts4.5/ui/top-nav-items/themed/use-custom-theme.d.ts +13 -0
- package/examples/button-menu-item.tsx +426 -0
- package/examples/company-hub-mock.tsx +241 -0
- package/examples/composition.tsx +502 -0
- package/examples/confluence-mock.tsx +387 -0
- package/examples/constellation/integration.tsx +203 -0
- package/examples/constellation/layout/advanced-layout.tsx +141 -0
- package/examples/constellation/layout/aside.tsx +10 -0
- package/examples/constellation/layout/banner.tsx +16 -0
- package/examples/constellation/layout/custom-skip-links.tsx +10 -0
- package/examples/constellation/layout/expand-side-nav.tsx +15 -0
- package/examples/constellation/layout/main.tsx +10 -0
- package/examples/constellation/layout/panel-splitter.tsx +13 -0
- package/examples/constellation/layout/panel.tsx +10 -0
- package/examples/constellation/layout/side-nav-slots.tsx +19 -0
- package/examples/constellation/layout/side-nav.tsx +27 -0
- package/examples/constellation/layout/toggle-side-nav-keyboard-shortcut.tsx +23 -0
- package/examples/constellation/layout/top-nav.tsx +21 -0
- package/examples/constellation/side-navigation/button-menu-item-disabled.tsx +20 -0
- package/examples/constellation/side-navigation/common/global-app-icon-tile.tsx +43 -0
- package/examples/constellation/side-navigation/common/mock-side-nav.tsx +16 -0
- package/examples/constellation/side-navigation/composing-menus.tsx +87 -0
- package/examples/constellation/side-navigation/expandable-menu-item.tsx +44 -0
- package/examples/constellation/side-navigation/flyout-menu-item.tsx +96 -0
- package/examples/constellation/side-navigation/global-apps.tsx +97 -0
- package/examples/constellation/side-navigation/link-menu-item.tsx +45 -0
- package/examples/constellation/side-navigation/menu-section.tsx +70 -0
- package/examples/constellation/top-navigation/common/mock-content.tsx +39 -0
- package/examples/constellation/top-navigation/common/mock-top-bar.tsx +19 -0
- package/examples/constellation/top-navigation/custom-nav-logo.tsx +27 -0
- package/examples/constellation/top-navigation/custom-theming--buttons.tsx +25 -0
- package/examples/constellation/top-navigation/custom-theming--logo.tsx +25 -0
- package/examples/constellation/top-navigation/custom-theming--parse-hex.tsx +18 -0
- package/examples/constellation/top-navigation/custom-theming--parse-hsl.tsx +21 -0
- package/examples/constellation/top-navigation/custom-theming--parse-rgb.tsx +21 -0
- package/examples/constellation/top-navigation/custom-theming--parse-user-color.tsx +21 -0
- package/examples/constellation/top-navigation/custom-theming--rgb-object.tsx +20 -0
- package/examples/constellation/top-navigation/custom-theming--search.tsx +26 -0
- package/examples/constellation/top-navigation/nav-logo.tsx +22 -0
- package/examples/constellation/top-navigation/top-nav-end.tsx +23 -0
- package/examples/constellation/top-navigation/top-nav-middle.tsx +17 -0
- package/examples/constellation/top-navigation/top-nav-start.tsx +29 -0
- package/examples/drag-and-drop/jira/data.tsx +320 -0
- package/examples/drag-and-drop/jira/entry.tsx +89 -0
- package/examples/drag-and-drop/jira/filters/filter-move-modal.tsx +172 -0
- package/examples/drag-and-drop/jira/filters/filter-tree-utils.tsx +134 -0
- package/examples/drag-and-drop/jira/filters/filters-menu-item.tsx +470 -0
- package/examples/drag-and-drop/jira/for-you/for-you-menu-item.tsx +74 -0
- package/examples/drag-and-drop/jira/projects/project-tile.tsx +37 -0
- package/examples/drag-and-drop/jira/projects/project.tsx +260 -0
- package/examples/drag-and-drop/jira/projects/projects-menu-item.tsx +120 -0
- package/examples/drag-and-drop/jira/recent/recent-menu-item.tsx +30 -0
- package/examples/drag-and-drop/jira/reducer.tsx +78 -0
- package/examples/drag-and-drop/jira/registry.tsx +52 -0
- package/examples/drag-and-drop/jira/reorder-actions.tsx +75 -0
- package/examples/drag-and-drop/jira/shared-top-level-flyout.tsx +144 -0
- package/examples/drag-and-drop/jira/sidebar.tsx +361 -0
- package/examples/drag-and-drop/jira/starred/starred-menu-item.tsx +29 -0
- package/examples/drag-and-drop/jira/state-context.tsx +34 -0
- package/examples/drag-and-drop/jira/top-level-shared-more-menu.tsx +99 -0
- package/examples/drag-and-drop/sidebar-example-container.tsx +38 -0
- package/examples/drag-and-drop/simple.tsx +653 -0
- package/examples/drag-and-drop/standalone-jira-sidebar-centered.tsx +27 -0
- package/examples/drag-and-drop/standalone-jira-sidebar.tsx +18 -0
- package/examples/drag-and-drop-in-the-sidebar-flyout.tsx +160 -0
- package/examples/drag-and-drop-jira-sidebar-centered.tsx +1 -0
- package/examples/drag-and-drop-jira-sidebar-standalone.tsx +1 -0
- package/examples/drag-and-drop-jira.tsx +1 -0
- package/examples/drag-and-drop.tsx +1 -0
- package/examples/expandable-menu-item.tsx +761 -0
- package/examples/flyout-menu-item-multiple.tsx +180 -0
- package/examples/flyout-menu-item.tsx +269 -0
- package/examples/images/200x20.png +0 -0
- package/examples/images/200x200.png +0 -0
- package/examples/images/20x20.png +0 -0
- package/examples/images/20x200.png +0 -0
- package/examples/images/cd.svg +9 -0
- package/examples/images/koala.png +0 -0
- package/examples/images/koala.svg +9 -0
- package/examples/images/money.svg +9 -0
- package/examples/legacy-var-testing.tsx +173 -0
- package/examples/link-menu-item.tsx +382 -0
- package/examples/main-content-border.tsx +147 -0
- package/examples/menu-item-avatar.tsx +41 -0
- package/examples/menu-item-conditional-tooltip.tsx +304 -0
- package/examples/menu-item-focus-ring-bleed.tsx +50 -0
- package/examples/menu-item-integration.tsx +206 -0
- package/examples/menu-item-narrow.tsx +290 -0
- package/examples/menu-item-scroll-into-view.tsx +283 -0
- package/examples/menu-items-deeply-nested.tsx +330 -0
- package/examples/menu-list.tsx +62 -0
- package/examples/menu-section.tsx +78 -0
- package/examples/page-layout-all-slots-banner-height-zero.tsx +3 -0
- package/examples/page-layout-all-slots-custom-sizes.tsx +3 -0
- package/examples/page-layout-all-slots-rtl.tsx +3 -0
- package/examples/page-layout-all-slots-scrollable-fixed.tsx +3 -0
- package/examples/page-layout-all-slots-scrollable.tsx +3 -0
- package/examples/page-layout-all-slots.tsx +3 -0
- package/examples/page-layout-aside-border.tsx +148 -0
- package/examples/page-layout-content-is-iframes.tsx +3 -0
- package/examples/page-layout-edge-case-absolute-positioned-collapsed-custom-sizes.tsx +3 -0
- package/examples/page-layout-edge-case-absolute-positioned-collapsed.tsx +3 -0
- package/examples/page-layout-edge-case-absolute-positioned-panel-visible.tsx +3 -0
- package/examples/page-layout-edge-case-absolute-positioned-resizable.tsx +3 -0
- package/examples/page-layout-edge-case-absolute-positioned.tsx +3 -0
- package/examples/page-layout-edge-case-using-legacy-vars.tsx +3 -0
- package/examples/page-layout-full-screen.tsx +253 -0
- package/examples/page-layout-implicit-rows.tsx +33 -0
- package/examples/page-layout-main-aside-scrollable-fixed.tsx +3 -0
- package/examples/page-layout-main-aside-scrollable.tsx +3 -0
- package/examples/page-layout-main-aside.tsx +3 -0
- package/examples/page-layout-panel-aside-default-widths.tsx +243 -0
- package/examples/page-layout-resizable-rtl.tsx +3 -0
- package/examples/page-layout-resizable.tsx +3 -0
- package/examples/page-layout-side-nav-collapse-shortcut.tsx +47 -0
- package/examples/page-layout-side-nav-content-scroll-with-sticky.tsx +135 -0
- package/examples/page-layout-side-nav-custom-width-greater-than-max.tsx +3 -0
- package/examples/page-layout-side-nav-custom-width-smaller-than-min.tsx +3 -0
- package/examples/page-layout-side-nav-main-aside-scrollable-fixed.tsx +3 -0
- package/examples/page-layout-side-nav-main-aside-scrollable.tsx +3 -0
- package/examples/page-layout-side-nav-main-aside.tsx +3 -0
- package/examples/page-layout-side-nav-onboarding.tsx +154 -0
- package/examples/page-layout-side-nav-overflowing-children.tsx +3 -0
- package/examples/page-layout-side-nav-slots.tsx +173 -0
- package/examples/page-layout-side-nav-with-menu-items.tsx +3 -0
- package/examples/page-layout-top-bar-side-nav-main-aside-scrollable-fixed.tsx +3 -0
- package/examples/page-layout-top-bar-side-nav-main-aside-scrollable.tsx +3 -0
- package/examples/page-layout-top-bar-side-nav-main-aside.tsx +3 -0
- package/examples/page-layout-top-bar-side-nav-main-scrollable-fixed.tsx +3 -0
- package/examples/page-layout-top-bar-side-nav-main-scrollable.tsx +3 -0
- package/examples/page-layout-top-bar-side-nav-main.tsx +3 -0
- package/examples/page-layout.tsx +1063 -0
- package/examples/panel-splitter.tsx +198 -0
- package/examples/resizable-slots.tsx +359 -0
- package/examples/side-nav-flyout.tsx +255 -0
- package/examples/stand-alone-iframe.tsx +22 -0
- package/examples/temp-icons/app-switcher-legacy.tsx +14 -0
- package/examples/temp-icons/atlassian-intelligence.tsx +14 -0
- package/examples/temp-icons/help.tsx +18 -0
- package/examples/temp-icons/menu.tsx +14 -0
- package/examples/temp-icons/settings.tsx +14 -0
- package/examples/top-nav-custom-profile-image.tsx +71 -0
- package/examples/top-nav-side-nav-collapsed.tsx +74 -0
- package/examples/top-nav-with-temp-nav-app-icon.tsx +63 -0
- package/examples/top-navigation-custom-logo.tsx +74 -0
- package/examples/top-navigation-stress.tsx +242 -0
- package/examples/top-navigation-themed-buttons.tsx +63 -0
- package/examples/top-navigation-theming-logged-out.tsx +75 -0
- package/examples/top-navigation-theming-with-picker.tsx +130 -0
- package/examples/top-navigation-theming.tsx +173 -0
- package/examples/top-navigation.tsx +128 -0
- package/examples/utils/example-utils.tsx +14 -0
- package/examples/utils/mock-root.tsx +18 -0
- package/examples/utils/mock-search.tsx +67 -0
- package/experimental/color-utils/parse-hex/package.json +17 -0
- package/experimental/color-utils/parse-hsl/package.json +17 -0
- package/experimental/color-utils/parse-rgb/package.json +17 -0
- package/experimental/color-utils/parse-user-color/package.json +17 -0
- package/experimental/top-nav-button/package.json +17 -0
- package/experimental/use-has-custom-theme/package.json +17 -0
- package/experimental/use-legacy-search-theme/package.json +17 -0
- package/layout/aside/package.json +17 -0
- package/layout/banner/package.json +17 -0
- package/layout/main/package.json +17 -0
- package/layout/panel/package.json +17 -0
- package/layout/panel-splitter/package.json +17 -0
- package/layout/root/package.json +17 -0
- package/layout/side-nav/package.json +17 -0
- package/layout/skip-links/package.json +17 -0
- package/layout/top-nav/package.json +17 -0
- package/package.json +245 -0
- package/side-nav-items/button-menu-item/package.json +17 -0
- package/side-nav-items/container-avatar/package.json +17 -0
- package/side-nav-items/drag-and-drop/drag-preview/package.json +17 -0
- package/side-nav-items/drag-and-drop/drop-indicator/package.json +17 -0
- package/side-nav-items/drag-and-drop/group-drop-indicator/package.json +17 -0
- package/side-nav-items/drag-and-drop/hitbox/package.json +17 -0
- package/side-nav-items/drag-and-drop/use-menu-item-drag-and-drop/package.json +17 -0
- package/side-nav-items/expandable-menu-item/package.json +17 -0
- package/side-nav-items/flyout-menu-item/package.json +17 -0
- package/side-nav-items/link-menu-item/package.json +17 -0
- package/side-nav-items/menu-list/package.json +17 -0
- package/side-nav-items/menu-list-item/package.json +17 -0
- package/side-nav-items/menu-section/package.json +17 -0
- package/side-nav-items/top-level-spacer/package.json +17 -0
- package/src/__tests__/informational-vr-tests/__snapshots__/layering/side-nav-expanded-on-mobile--mobile.png +0 -0
- package/src/__tests__/informational-vr-tests/__snapshots__/layering/side-nav-expanded-on-mobile-without-panel--mobile.png +0 -0
- package/src/__tests__/informational-vr-tests/__snapshots__/menu-items-deeply-nested/side-nav-with-deeply-nested-menu-items---nested-menu-item-selected--default.png +0 -0
- package/src/__tests__/informational-vr-tests/__snapshots__/menu-items-deeply-nested/side-nav-with-deeply-nested-menu-items---scrolled-to-the-end--default.png +0 -0
- package/src/__tests__/informational-vr-tests/__snapshots__/menu-items-deeply-nested/side-nav-with-deeply-nested-menu-items--default.png +0 -0
- package/src/__tests__/informational-vr-tests/__snapshots__/sidebar-drag-and-drop/sidebar-drag-and-drop---hover-bug--desktop-chrome.png +0 -0
- package/src/__tests__/informational-vr-tests/__snapshots__/sidebar-drag-and-drop/sidebar-drag-and-drop---hover-bug--desktop-firefox.png +0 -0
- package/src/__tests__/informational-vr-tests/__snapshots__/sidebar-drag-and-drop/sidebar-drag-and-drop---hover-bug--desktop-webkit.png +0 -0
- package/src/__tests__/informational-vr-tests/__snapshots__/sidebar-drag-and-drop/sidebar-drag-and-drop--desktop-chrome.png +0 -0
- package/src/__tests__/informational-vr-tests/__snapshots__/sidebar-drag-and-drop/sidebar-drag-and-drop--desktop-firefox.png +0 -0
- package/src/__tests__/informational-vr-tests/__snapshots__/sidebar-drag-and-drop/sidebar-drag-and-drop--desktop-webkit.png +0 -0
- package/src/__tests__/informational-vr-tests/layering.vr.tsx +35 -0
- package/src/__tests__/informational-vr-tests/menu-items-deeply-nested.vr.tsx +33 -0
- package/src/__tests__/informational-vr-tests/sidebar-drag-and-drop.vr.tsx +100 -0
- package/src/__tests__/playwright/drag-and-drop-in-the-sidebar-flyout.spec.tsx +235 -0
- package/src/__tests__/playwright/expandable-menu-item.spec.tsx +20 -0
- package/src/__tests__/playwright/flyout-menu-item.spec.tsx +22 -0
- package/src/__tests__/playwright/legacy-vars.spec.tsx +533 -0
- package/src/__tests__/playwright/menu-item-in-sidebar-drag-and-drop.spec.tsx +70 -0
- package/src/__tests__/playwright/page-layout.spec.tsx +47 -0
- package/src/__tests__/playwright/panel.spec.tsx +243 -0
- package/src/__tests__/playwright/resizing.spec.tsx +541 -0
- package/src/__tests__/playwright/side-nav-flyout.spec.tsx +223 -0
- package/src/__tests__/playwright/side-nav-responsiveness.spec.tsx +208 -0
- package/src/__tests__/playwright/skip-links.spec.tsx +111 -0
- package/src/__tests__/playwright/top-nav-end.spec.tsx +96 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-fixed-no-panel-vr--desktop-large.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-fixed-no-panel-vr--desktop.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-fixed-no-panel-vr--mobile.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-fixed-vr--desktop-large-splitter.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-fixed-vr--desktop-large.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-fixed-vr--desktop.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-fixed-vr--mobile.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-no-panel-vr--desktop-large.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-no-panel-vr--desktop.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-no-panel-vr--mobile.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-no-panel-with-forced-isfixed-temp---desktop.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-scrolled-fixed-vr--desktop-large.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-scrolled-fixed-vr--desktop.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-scrolled-fixed-vr--mobile.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-scrolled-vr--desktop-large.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-scrolled-vr--desktop.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-scrolled-vr--mobile.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-scrolled-with-forced-isfixed-temp---desktop.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-vr--desktop-large-splitter.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-vr--desktop-large.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-vr--desktop.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-vr--mobile.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/scrollable-with-forced-isfixed-temp---desktop.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/unscrollable-fixed-vr--desktop-large.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/unscrollable-fixed-vr--desktop.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/unscrollable-fixed-vr--mobile.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/unscrollable-no-panel-fixed-vr--desktop-large.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/unscrollable-no-panel-fixed-vr--desktop.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/unscrollable-no-panel-fixed-vr--mobile.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/unscrollable-no-panel-vr--desktop-large.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/unscrollable-no-panel-vr--desktop.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/unscrollable-no-panel-vr--mobile.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/unscrollable-no-panel-with-forced-isfixed-temp---desktop.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/unscrollable-vr--desktop-large.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/unscrollable-vr--desktop.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/unscrollable-vr--mobile.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/layering/unscrollable-with-forced-isfixed-temp---desktop.png +0 -0
- package/src/__tests__/vr-tests/__snapshots__/skip-links/skip-links--light-mode.png +0 -0
- package/src/__tests__/vr-tests/layering.vr.tsx +226 -0
- package/src/__tests__/vr-tests/skip-links.vr.tsx +14 -0
- package/src/components/__tests__/unit/badge-container.test.tsx +62 -0
- package/src/components/__tests__/unit/list.test.tsx +74 -0
- package/src/components/badge-container.tsx +72 -0
- package/src/components/forward-ref-with-generic.tsx +8 -0
- package/src/components/list-item.tsx +39 -0
- package/src/components/list.tsx +44 -0
- package/src/components/skip-links/__tests__/unit/skip-links-container.test.tsx +411 -0
- package/src/components/skip-links/skip-link.tsx +139 -0
- package/src/components/skip-links/skip-links-container.tsx +111 -0
- package/src/context/skip-links/skip-links-context.tsx +74 -0
- package/src/context/skip-links/skip-links-data-context.tsx +41 -0
- package/src/context/skip-links/skip-links-provider.tsx +74 -0
- package/src/context/skip-links/types.tsx +29 -0
- package/src/context/top-nav-start/top-nav-start-context-provider.tsx +26 -0
- package/src/context/top-nav-start/top-nav-start-context.tsx +21 -0
- package/src/entry-points/experimental/color-utils/parse-hex.tsx +1 -0
- package/src/entry-points/experimental/color-utils/parse-hsl.tsx +1 -0
- package/src/entry-points/experimental/color-utils/parse-rgb.tsx +1 -0
- package/src/entry-points/experimental/color-utils/parse-user-color.tsx +1 -0
- package/src/entry-points/experimental/top-nav-button.tsx +6 -0
- package/src/entry-points/experimental/use-has-custom-theme.tsx +1 -0
- package/src/entry-points/experimental/use-legacy-search-theme.tsx +1 -0
- package/src/entry-points/layout/aside.tsx +1 -0
- package/src/entry-points/layout/banner.tsx +1 -0
- package/src/entry-points/layout/main.tsx +7 -0
- package/src/entry-points/layout/panel-splitter.tsx +3 -0
- package/src/entry-points/layout/panel.tsx +1 -0
- package/src/entry-points/layout/root.tsx +1 -0
- package/src/entry-points/layout/side-nav.tsx +7 -0
- package/src/entry-points/layout/skip-links.tsx +2 -0
- package/src/entry-points/layout/top-nav.tsx +4 -0
- package/src/entry-points/side-nav-items/button-menu-item.tsx +3 -0
- package/src/entry-points/side-nav-items/container-avatar.tsx +1 -0
- package/src/entry-points/side-nav-items/drag-and-drop/drag-preview.tsx +1 -0
- package/src/entry-points/side-nav-items/drag-and-drop/drop-indicator.tsx +5 -0
- package/src/entry-points/side-nav-items/drag-and-drop/group-drop-indicator.tsx +1 -0
- package/src/entry-points/side-nav-items/drag-and-drop/hitbox.tsx +7 -0
- package/src/entry-points/side-nav-items/drag-and-drop/use-menu-item-drag-and-drop.tsx +4 -0
- package/src/entry-points/side-nav-items/expandable-menu-item.tsx +13 -0
- package/src/entry-points/side-nav-items/flyout-menu-item.tsx +12 -0
- package/src/entry-points/side-nav-items/link-menu-item.tsx +3 -0
- package/src/entry-points/side-nav-items/menu-list-item.tsx +1 -0
- package/src/entry-points/side-nav-items/menu-list.tsx +1 -0
- package/src/entry-points/side-nav-items/menu-section.tsx +3 -0
- package/src/entry-points/side-nav-items/top-level-spacer.tsx +1 -0
- package/src/entry-points/top-nav-items/create-button.tsx +1 -0
- package/src/entry-points/top-nav-items/custom-title.tsx +1 -0
- package/src/entry-points/top-nav-items/help.tsx +1 -0
- package/src/entry-points/top-nav-items/index.tsx +13 -0
- package/src/entry-points/top-nav-items/log-in.tsx +1 -0
- package/src/entry-points/top-nav-items/notifications.tsx +1 -0
- package/src/entry-points/top-nav-items/profile.tsx +1 -0
- package/src/entry-points/top-nav-items/settings.tsx +1 -0
- package/src/index.tsx +73 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/menu-item/button-menu-item---disabled---pressed--default.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/menu-item/button-menu-item---pressed--default.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/menu-item/expandable-menu-item---not-selectable---pressed--default.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/menu-item/expandable-menu-item---selectable---pressed--default.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/menu-item/expandable-menu-item---selected---pressed--default.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/menu-item/flyout-menu-item---pressed--default.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/menu-item/flyout-menu-item---selected---pressed--default.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/menu-item/link-menu-item---pressed--default.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/menu-item/link-menu-item---scroll-into-view-behavior--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/menu-item/link-menu-item---scroll-into-view-behavior--desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/menu-item/link-menu-item---scroll-into-view-behavior--desktop-safari.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/menu-item/link-menu-item---selected---pressed--default.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/menu-item-increased-hitbox/increasing-hitbox-for-nested-items-click-target---desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/menu-item-increased-hitbox/increasing-hitbox-for-nested-items-click-target---desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/menu-item-increased-hitbox/increasing-hitbox-for-nested-items-click-target---desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/menu-item-increased-hitbox/increasing-hitbox-for-nested-items-hover---desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/menu-item-increased-hitbox/increasing-hitbox-for-nested-items-hover---desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/menu-item-increased-hitbox/increasing-hitbox-for-nested-items-hover---desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/menu-item-increased-hitbox/increasing-hitbox-for-nested-items-too-far-back---desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/menu-item-increased-hitbox/increasing-hitbox-for-nested-items-too-far-back---desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/menu-item-increased-hitbox/increasing-hitbox-for-nested-items-too-far-back---desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/menu-item-increased-hitbox.vr.tsx +79 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/menu-item.vr.tsx +151 -0
- package/src/ui/menu-item/__tests__/playwright/scroll-into-view.spec.tsx +92 -0
- package/src/ui/menu-item/__tests__/unit/_util.tsx +40 -0
- package/src/ui/menu-item/__tests__/unit/expandable-menu-item.test.tsx +1094 -0
- package/src/ui/menu-item/__tests__/unit/flyout-menu-item.test.tsx +422 -0
- package/src/ui/menu-item/__tests__/unit/menu-item.test.tsx +649 -0
- package/src/ui/menu-item/__tests__/unit/top-level-spacer.test.tsx +94 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/button-menu-item--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/button-menu-item--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/button-menu-item-combine--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/button-menu-item-combine--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/button-menu-item-reorder-after--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/button-menu-item-reorder-after--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/button-menu-item-reorder-before--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/button-menu-item-reorder-before--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/expandable-menu-item-combine--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/expandable-menu-item-combine--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/expandable-menu-item-reorder-after--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/expandable-menu-item-reorder-after--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/expandable-menu-item-reorder-before--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/expandable-menu-item-reorder-before--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/expandable-menu-item-trigger--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/expandable-menu-item-trigger--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/flyout-menu-item-combine--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/flyout-menu-item-combine--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/flyout-menu-item-reorder-after--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/flyout-menu-item-reorder-after--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/flyout-menu-item-reorder-before--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/flyout-menu-item-reorder-before--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/flyout-menu-item-trigger--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/flyout-menu-item-trigger--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/link-menu-item--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/link-menu-item--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/link-menu-item-combine--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/link-menu-item-combine--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/link-menu-item-combine-blocked--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/link-menu-item-combine-blocked--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/link-menu-item-reorder-after--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/link-menu-item-reorder-after--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/link-menu-item-reorder-after-blocked--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/link-menu-item-reorder-after-blocked--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/link-menu-item-reorder-before--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/link-menu-item-reorder-before--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/link-menu-item-reorder-before-blocked--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/drag-and-drop/link-menu-item-reorder-before-blocked--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item---custom-elembefore---action-focused--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item---custom-elembefore---action-hovered--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item---custom-elembefore---default-state--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item---custom-elembefore---elembefore-focused--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item---custom-elembefore---elembefore-hovered--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item---custom-elembefore---menu-item-focused--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item---custom-elembefore---menu-item-hovered--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item---selected-with-dropdown-action-open--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item---with-dropdown-action-open--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item---with-dropdown-action-open-and-hovered--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item-collapsed-with-selected-child--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item-expanded-with-actions-on-hover--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item-expanded-with-actions-on-hover-and-elem-after--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item-expanded-with-elem-after--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item-nested--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item-nested-rtl--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item-selected--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item-selected-with-icon--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item-with-actions--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item-with-actions-on-hover---hovered--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item-with-actions-on-hover---selected-and-hovered--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item-with-actions-on-hover--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item-with-actions-on-hover-and-elem-after---hovered--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/expandable/expandable-menu-item-with-actions-on-hover-and-elem-after--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/flyout-menu-item/a-flyout-menu-with-a-nested-popup-using-shouldrendertoparent---default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/flyout-menu-item/flyout-menu-item-default-open-example--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/flyout-menu-item/flyout-menu-item-default-open-rtl--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/flyout-menu-item/flyout-menu-item-default-open-selected-vr--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/flyout-menu-item/flyout-menu-item-example--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/flyout-menu-item/flyout-menu-item-rtl--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item---disabled---hovered--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item---disabled---hovered--desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item---disabled---hovered--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item---disabled--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item---disabled--desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item---disabled--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item---disabled-with-actions--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item---disabled-with-actions--desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item---disabled-with-actions--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item---with-dropdown-action-open--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item---with-dropdown-action-open--desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item---with-dropdown-action-open--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item-example--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item-example--desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item-example--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item-rtlexample--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item-rtlexample--desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item-rtlexample--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item-with-actions-on-hover-appearing-on-focus--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item-with-actions-on-hover-appearing-on-focus--desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item-with-actions-on-hover-appearing-on-focus--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item-with-actions-on-hover-appearing-on-hover--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item-with-actions-on-hover-appearing-on-hover--desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item-with-actions-on-hover-appearing-on-hover--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item-with-elem-after-and-hovered--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item-with-elem-after-and-hovered--desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item-with-elem-after-and-hovered--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item-with-popup--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item-with-popup--desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/button-menu-item-with-popup--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/link-menu-item---with-dropdown-action-open--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/link-menu-item---with-dropdown-action-open--desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/link-menu-item---with-dropdown-action-open--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/link-menu-item-bleed--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/link-menu-item-bleed--desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/link-menu-item-bleed--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/link-menu-item-example--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/link-menu-item-example--desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/link-menu-item-example--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/link-menu-item-rtlexample--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/link-menu-item-rtlexample--desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/link-menu-item-rtlexample--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/link-menu-item-with-actions-on-hover-appearing-on-focus--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/link-menu-item-with-actions-on-hover-appearing-on-focus--desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/link-menu-item-with-actions-on-hover-appearing-on-focus--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/link-menu-item-with-actions-on-hover-appearing-on-hover--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/link-menu-item-with-actions-on-hover-appearing-on-hover--desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/link-menu-item-with-actions-on-hover-appearing-on-hover--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/link-menu-item-with-elem-after-and-hovered--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/link-menu-item-with-elem-after-and-hovered--desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/link-menu-item-with-elem-after-and-hovered--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/menu-item-avatar-example--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/menu-item-avatar-example--desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/menu-item-avatar-example--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/menu-items-in-a-narrow-container--desktop-chrome.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/menu-items-in-a-narrow-container--desktop-firefox.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item/menu-items-in-a-narrow-container--desktop-webkit.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/button-menu-item--content-long---description-long---default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/button-menu-item--content-long---description-none---default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/button-menu-item--content-long---description-short---default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/button-menu-item--content-short---description-long---default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/button-menu-item--content-short---description-none---default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/button-menu-item--content-short---description-short---default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/button-menu-item-add-action-button--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/button-menu-item-with-tooltip-disabled--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/expandable-menu-item--content-long---default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/expandable-menu-item--content-short---default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/expandable-menu-item-with-tooltip-disabled--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/flyout-menu-item--content-long---default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/flyout-menu-item--content-short---default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/flyout-menu-item-with-tooltip-disabled--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/link-menu-item--content-long---description-long---default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/link-menu-item--content-long---description-none---default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/link-menu-item--content-long---description-short---default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/link-menu-item--content-short---description-long---default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/link-menu-item--content-short---description-none---default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/link-menu-item--content-short---description-short---default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/link-menu-item-with-tooltip-disabled--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/menu-item-conditional-tooltip/menu-item-button-with-nested-children--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/__snapshots__/top-level-spacer/global-apps-example--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/drag-and-drop.vr.tsx +172 -0
- package/src/ui/menu-item/__tests__/vr-tests/expandable.vr.tsx +248 -0
- package/src/ui/menu-item/__tests__/vr-tests/flyout-menu-item.vr.tsx +46 -0
- package/src/ui/menu-item/__tests__/vr-tests/menu-item-conditional-tooltip.vr.tsx +312 -0
- package/src/ui/menu-item/__tests__/vr-tests/menu-item.vr.tsx +210 -0
- package/src/ui/menu-item/__tests__/vr-tests/top-level-spacer.vr.tsx +17 -0
- package/src/ui/menu-item/button-menu-item.tsx +87 -0
- package/src/ui/menu-item/constants.tsx +15 -0
- package/src/ui/menu-item/container-avatar.tsx +39 -0
- package/src/ui/menu-item/drag-and-drop/drag-preview.tsx +98 -0
- package/src/ui/menu-item/drag-and-drop/drop-indicator.tsx +11 -0
- package/src/ui/menu-item/drag-and-drop/group-drop-indicator.tsx +7 -0
- package/src/ui/menu-item/drag-and-drop/hitbox.tsx +13 -0
- package/src/ui/menu-item/drag-and-drop/use-menu-item-drag-and-drop.tsx +243 -0
- package/src/ui/menu-item/drag-handle.tsx +42 -0
- package/src/ui/menu-item/expandable-menu-item/expandable-menu-item-content.tsx +84 -0
- package/src/ui/menu-item/expandable-menu-item/expandable-menu-item-context.tsx +61 -0
- package/src/ui/menu-item/expandable-menu-item/expandable-menu-item-level-context.tsx +9 -0
- package/src/ui/menu-item/expandable-menu-item/expandable-menu-item-trigger.tsx +308 -0
- package/src/ui/menu-item/expandable-menu-item/expandable-menu-item.tsx +114 -0
- package/src/ui/menu-item/flyout-menu-item/flyout-menu-item-content.tsx +92 -0
- package/src/ui/menu-item/flyout-menu-item/flyout-menu-item-context.tsx +19 -0
- package/src/ui/menu-item/flyout-menu-item/flyout-menu-item-trigger.tsx +124 -0
- package/src/ui/menu-item/flyout-menu-item/flyout-menu-item.tsx +98 -0
- package/src/ui/menu-item/link-menu-item.tsx +119 -0
- package/src/ui/menu-item/menu-item-signals.tsx +6 -0
- package/src/ui/menu-item/menu-item.tsx +853 -0
- package/src/ui/menu-item/menu-list-item.tsx +12 -0
- package/src/ui/menu-item/menu-list.tsx +12 -0
- package/src/ui/menu-item/top-level-spacer.tsx +49 -0
- package/src/ui/menu-item/types.tsx +181 -0
- package/src/ui/menu-item/use-scroll-menu-item-into-view.tsx +78 -0
- package/src/ui/menu-section/__tests__/unit/menu-section.test.tsx +96 -0
- package/src/ui/menu-section/__tests__/vr-tests/__snapshots__/divider/divider--default.png +0 -0
- package/src/ui/menu-section/__tests__/vr-tests/__snapshots__/menu-section/menu-section-example--default.png +0 -0
- package/src/ui/menu-section/__tests__/vr-tests/divider.vr.tsx +14 -0
- package/src/ui/menu-section/__tests__/vr-tests/menu-section.vr.tsx +14 -0
- package/src/ui/menu-section/divider.tsx +33 -0
- package/src/ui/menu-section/menu-section-context.tsx +15 -0
- package/src/ui/menu-section/menu-section-heading.tsx +43 -0
- package/src/ui/menu-section/menu-section.tsx +70 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/page-layout/large-panel-default-width-on-mobile--desktop--platform-design-system-nav4-panel-mobile-width-fix-false.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/page-layout/large-panel-default-width-on-mobile--desktop--platform-design-system-nav4-panel-mobile-width-fix-true.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/page-layout/small-panel-default-width-on-mobile--desktop--platform-design-system-nav4-panel-mobile-width-fix-false.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/page-layout/small-panel-default-width-on-mobile--desktop--platform-design-system-nav4-panel-mobile-width-fix-true.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/slot-borders/above-md-breakpoint---side-nav-expanded--default--platform-design-system-nav4-panel-default-border-false-platform-design-system-nav4-sidenav-border-false.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/slot-borders/above-md-breakpoint---side-nav-expanded--default--platform-design-system-nav4-panel-default-border-false-platform-design-system-nav4-sidenav-border-true.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/slot-borders/above-md-breakpoint---side-nav-expanded--default--platform-design-system-nav4-panel-default-border-true-platform-design-system-nav4-sidenav-border-false.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/slot-borders/above-md-breakpoint---side-nav-expanded--default--platform-design-system-nav4-panel-default-border-true-platform-design-system-nav4-sidenav-border-true.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/slot-borders/above-md-breakpoint---side-nav-flyout--default--platform-design-system-nav4-panel-default-border-false-platform-design-system-nav4-sidenav-border-false.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/slot-borders/above-md-breakpoint---side-nav-flyout--default--platform-design-system-nav4-panel-default-border-false-platform-design-system-nav4-sidenav-border-true.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/slot-borders/above-md-breakpoint---side-nav-flyout--default--platform-design-system-nav4-panel-default-border-true-platform-design-system-nav4-sidenav-border-false.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/slot-borders/above-md-breakpoint---side-nav-flyout--default--platform-design-system-nav4-panel-default-border-true-platform-design-system-nav4-sidenav-border-true.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/slot-borders/below-md-breakpoint---side-nav-expanded--default--platform-design-system-nav4-panel-default-border-false-platform-design-system-nav4-sidenav-border-false.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/slot-borders/below-md-breakpoint---side-nav-expanded--default--platform-design-system-nav4-panel-default-border-false-platform-design-system-nav4-sidenav-border-true.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/slot-borders/below-md-breakpoint---side-nav-expanded--default--platform-design-system-nav4-panel-default-border-true-platform-design-system-nav4-sidenav-border-false.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/slot-borders/below-md-breakpoint---side-nav-expanded--default--platform-design-system-nav4-panel-default-border-true-platform-design-system-nav4-sidenav-border-true.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/top-nav/breakpoint-lg---composition--firefox.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/top-nav/breakpoint-lg---with-min-widths--firefox.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/top-nav/breakpoint-lg--firefox.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/top-nav/breakpoint-md---composition--firefox.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/top-nav/breakpoint-md---with-min-widths--firefox.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/top-nav/breakpoint-md--firefox.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/top-nav/breakpoint-sm---with-min-widths--firefox.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/top-nav/breakpoint-sm--firefox.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/top-nav/breakpoint-xl---composition--firefox.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/top-nav/breakpoint-xl---with-min-widths--firefox.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/top-nav/breakpoint-xl--firefox.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/top-nav/breakpoint-xs---with-min-widths--firefox.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/__snapshots__/top-nav/breakpoint-xs--firefox.png +0 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/page-layout.vr.tsx +53 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/slot-borders.vr.tsx +54 -0
- package/src/ui/page-layout/__tests__/informational-vr-tests/top-nav.vr.tsx +207 -0
- package/src/ui/page-layout/__tests__/unit/aside.test.tsx +21 -0
- package/src/ui/page-layout/__tests__/unit/banner.test.tsx +31 -0
- package/src/ui/page-layout/__tests__/unit/get-width.test.tsx +12 -0
- package/src/ui/page-layout/__tests__/unit/hoist-utils.test.tsx +85 -0
- package/src/ui/page-layout/__tests__/unit/page-layout.test.tsx +278 -0
- package/src/ui/page-layout/__tests__/unit/panel-splitter.test.tsx +771 -0
- package/src/ui/page-layout/__tests__/unit/panel.test.tsx +77 -0
- package/src/ui/page-layout/__tests__/unit/resizing.test.tsx +706 -0
- package/src/ui/page-layout/__tests__/unit/side-nav-flyout.test.tsx +1154 -0
- package/src/ui/page-layout/__tests__/unit/side-nav.test.tsx +771 -0
- package/src/ui/page-layout/__tests__/unit/sticky-header.test.tsx +57 -0
- package/src/ui/page-layout/__tests__/unit/test-utils.tsx +185 -0
- package/src/ui/page-layout/__tests__/unit/top-nav-end.test.tsx +132 -0
- package/src/ui/page-layout/__tests__/unit/top-nav.test.tsx +28 -0
- package/src/ui/page-layout/__tests__/unit/use-expand-side-nav.test.tsx +278 -0
- package/src/ui/page-layout/__tests__/unit/use-text-direction.test.tsx +37 -0
- package/src/ui/page-layout/__tests__/unit/use-toggle-side-nav.test.tsx +233 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/main-content-border/main-content-border---theming-disabled--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/main-content-border/main-content-border---theming-disabled--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/main-content-border/main-content-border---theming-disabled-side-nav-collapsed--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/main-content-border/main-content-border---theming-disabled-side-nav-collapsed--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/main-content-border/main-content-border---theming-enabled--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/main-content-border/main-content-border---theming-enabled--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/main-content-border/main-content-border---theming-enabled-full-screen-mode--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/main-content-border/main-content-border---theming-enabled-full-screen-mode--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/main-content-border/main-content-border---theming-enabled-side-nav-collapsed--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/main-content-border/main-content-border---theming-enabled-side-nav-collapsed--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/all-slots--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/all-slots--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/all-slots-banner-height-zero--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/all-slots-banner-height-zero--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/all-slots-custom-sizes--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/all-slots-custom-sizes--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/all-slots-rtl--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/all-slots-rtl--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/all-slots-scrollable--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/all-slots-scrollable--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/all-slots-scrollable-fixed--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/all-slots-scrollable-fixed--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/aside-composed-with-border--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/aside-composed-with-border--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/edge-case-sibling-absolute-positioned--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/edge-case-sibling-absolute-positioned--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/edge-case-sibling-absolute-positioned-collapsed--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/edge-case-sibling-absolute-positioned-collapsed--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/edge-case-sibling-absolute-positioned-custom-sizes--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/edge-case-sibling-absolute-positioned-custom-sizes--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/edge-case-sibling-absolute-positioned-panel-visible--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/edge-case-sibling-absolute-positioned-panel-visible--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/edge-case-sibling-absolute-positioned-resizable--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/edge-case-sibling-absolute-positioned-resizable--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/edge-case-using-legacy-vars--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/edge-case-using-legacy-vars--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/main-aside--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/main-aside--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/main-aside-scrollable--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/main-aside-scrollable--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/main-aside-scrollable-fixed--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/main-aside-scrollable-fixed--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/page-layout-implicit-rows--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/page-layout-implicit-rows--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/panel-and-aside---default-widths--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/panel-and-aside---default-widths--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/panel-and-aside---zero-widths--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/panel-and-aside---zero-widths--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/panel-default-background-color--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/panel-default-background-color--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/panel-should-have-correct-width-when-there-is-no-sidenav-mounted--desktop--platform-design-system-nav4-preview-panel-support-false.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/panel-should-have-correct-width-when-there-is-no-sidenav-mounted--desktop--platform-design-system-nav4-preview-panel-support-true.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/resizable--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/side-nav-content-slot---scroll-with-sticky-child--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/side-nav-custom-width-greater-than-max-width--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/side-nav-custom-width-smaller-than-min-width--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/side-nav-main-aside--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/side-nav-main-aside--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/side-nav-main-aside-scrollable--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/side-nav-main-aside-scrollable--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/side-nav-main-aside-scrollable-fixed--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/side-nav-main-aside-scrollable-fixed--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/side-nav-overflowing-children--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/side-nav-slots--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/side-nav-with-menu-items--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/side-nav-with-menu-items--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/top-bar-side-nav-main--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/top-bar-side-nav-main--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/top-bar-side-nav-main-aside--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/top-bar-side-nav-main-aside--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/top-bar-side-nav-main-aside-scrollable--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/top-bar-side-nav-main-aside-scrollable--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/top-bar-side-nav-main-aside-scrollable-fixed--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/top-bar-side-nav-main-aside-scrollable-fixed--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/top-bar-side-nav-main-scrollable--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/top-bar-side-nav-main-scrollable--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/top-bar-side-nav-main-scrollable-fixed--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/page-layout/top-bar-side-nav-main-scrollable-fixed--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/panel-splitter/focused-panel-splitter-with-position-end--default.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/panel-splitter/focused-panel-splitter-with-position-start--default.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/panel-splitter/hovered-panel-splitter-with-position-end--default--platform-nav4-panel-splitter-keyboard-a11y-false.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/panel-splitter/hovered-panel-splitter-with-position-end--default--platform-nav4-panel-splitter-keyboard-a11y-true.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/panel-splitter/hovered-panel-splitter-with-position-start--default--platform-nav4-panel-splitter-keyboard-a11y-false.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/panel-splitter/hovered-panel-splitter-with-position-start--default--platform-nav4-panel-splitter-keyboard-a11y-true.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/side-nav-flyout/side-nav-default-collapsed--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/side-nav-flyout/side-nav-default-collapsed--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/side-nav-flyout/side-nav-default-collapsed-toggle-button-hovered--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/side-nav-flyout/side-nav-default-collapsed-toggle-button-hovered--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/side-nav-flyout/side-nav-default-collapsed-with-open-child-layer--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/side-nav-flyout/side-nav-default-collapsed-with-open-child-layer--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/side-nav-flyout/side-nav-default-collapsed-with-open-child-layer-toggle-button-hovered--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/side-nav-flyout/side-nav-default-collapsed-with-open-child-layer-toggle-button-hovered--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/side-nav-flyout/side-nav-default-expanded--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/side-nav-flyout/side-nav-default-expanded--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/side-nav-flyout/side-nav-default-expanded-toggle-button-hovered--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/side-nav-flyout/side-nav-default-expanded-toggle-button-hovered--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/side-nav-flyout/side-nav-default-expanded-with-open-child-layer--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/side-nav-flyout/side-nav-default-expanded-with-open-child-layer--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/side-nav-flyout/side-nav-default-expanded-with-open-child-layer-toggle-button-hovered--desktop.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/__snapshots__/side-nav-flyout/side-nav-default-expanded-with-open-child-layer-toggle-button-hovered--mobile.png +0 -0
- package/src/ui/page-layout/__tests__/vr-tests/main-content-border.vr.tsx +47 -0
- package/src/ui/page-layout/__tests__/vr-tests/page-layout.vr.tsx +337 -0
- package/src/ui/page-layout/__tests__/vr-tests/panel-splitter.vr.tsx +72 -0
- package/src/ui/page-layout/__tests__/vr-tests/side-nav-flyout.vr.tsx +170 -0
- package/src/ui/page-layout/aside.tsx +246 -0
- package/src/ui/page-layout/banner.tsx +92 -0
- package/src/ui/page-layout/constants.tsx +56 -0
- package/src/ui/page-layout/hoist-slot-sizes-context.tsx +7 -0
- package/src/ui/page-layout/hoist-utils.tsx +64 -0
- package/src/ui/page-layout/id-utils.tsx +33 -0
- package/src/ui/page-layout/main/main-sticky-context.tsx +6 -0
- package/src/ui/page-layout/main/main-sticky-header.tsx +64 -0
- package/src/ui/page-layout/main/main.tsx +109 -0
- package/src/ui/page-layout/panel-splitter/context.tsx +60 -0
- package/src/ui/page-layout/panel-splitter/convert-resize-bound-to-pixels.tsx +20 -0
- package/src/ui/page-layout/panel-splitter/get-percentage-within-pixel-bounds.tsx +35 -0
- package/src/ui/page-layout/panel-splitter/get-width.tsx +33 -0
- package/src/ui/page-layout/panel-splitter/keyboard-resize-manager.tsx +89 -0
- package/src/ui/page-layout/panel-splitter/panel-splitter.tsx +469 -0
- package/src/ui/page-layout/panel-splitter/provider.tsx +65 -0
- package/src/ui/page-layout/panel-splitter/types.tsx +25 -0
- package/src/ui/page-layout/panel-splitter/use-text-direction.tsx +17 -0
- package/src/ui/page-layout/panel.tsx +338 -0
- package/src/ui/page-layout/root.tsx +162 -0
- package/src/ui/page-layout/side-nav/element-context.tsx +18 -0
- package/src/ui/page-layout/side-nav/flyout-close-delay-ms.tsx +12 -0
- package/src/ui/page-layout/side-nav/side-nav-content.tsx +57 -0
- package/src/ui/page-layout/side-nav/side-nav-footer.tsx +48 -0
- package/src/ui/page-layout/side-nav/side-nav-header.tsx +32 -0
- package/src/ui/page-layout/side-nav/side-nav.tsx +886 -0
- package/src/ui/page-layout/side-nav/toggle-button-context.tsx +21 -0
- package/src/ui/page-layout/side-nav/toggle-button-provider.tsx +28 -0
- package/src/ui/page-layout/side-nav/toggle-button.tsx +176 -0
- package/src/ui/page-layout/side-nav/types.tsx +18 -0
- package/src/ui/page-layout/side-nav/use-expand-side-nav.tsx +57 -0
- package/src/ui/page-layout/side-nav/use-side-nav-visibility-callbacks.tsx +75 -0
- package/src/ui/page-layout/side-nav/use-side-nav-visibility.tsx +43 -0
- package/src/ui/page-layout/side-nav/use-toggle-side-nav.tsx +47 -0
- package/src/ui/page-layout/side-nav/visibility-context.tsx +17 -0
- package/src/ui/page-layout/side-nav/visibility-provider.tsx +20 -0
- package/src/ui/page-layout/top-nav/top-nav-end.tsx +168 -0
- package/src/ui/page-layout/top-nav/top-nav-middle.tsx +111 -0
- package/src/ui/page-layout/top-nav/top-nav-start.tsx +96 -0
- package/src/ui/page-layout/top-nav/top-nav.tsx +142 -0
- package/src/ui/page-layout/types.tsx +20 -0
- package/src/ui/page-layout/use-resizing-width-css-var-on-root-element.tsx +70 -0
- package/src/ui/top-nav-items/__tests__/informational-vr-tests/__snapshots__/top-navigation/nav-logo-hover---custom-theming--desktop.png +0 -0
- package/src/ui/top-nav-items/__tests__/informational-vr-tests/__snapshots__/top-navigation/nav-logo-hover---custom-theming--mobile.png +0 -0
- package/src/ui/top-nav-items/__tests__/informational-vr-tests/__snapshots__/top-navigation/nav-logo-hover--desktop.png +0 -0
- package/src/ui/top-nav-items/__tests__/informational-vr-tests/__snapshots__/top-navigation/nav-logo-hover--mobile.png +0 -0
- package/src/ui/top-nav-items/__tests__/informational-vr-tests/__snapshots__/top-navigation/nav-logo-pressed---custom-theming--desktop.png +0 -0
- package/src/ui/top-nav-items/__tests__/informational-vr-tests/__snapshots__/top-navigation/nav-logo-pressed---custom-theming--mobile.png +0 -0
- package/src/ui/top-nav-items/__tests__/informational-vr-tests/__snapshots__/top-navigation/nav-logo-pressed--desktop.png +0 -0
- package/src/ui/top-nav-items/__tests__/informational-vr-tests/__snapshots__/top-navigation/nav-logo-pressed--mobile.png +0 -0
- package/src/ui/top-nav-items/__tests__/informational-vr-tests/__snapshots__/top-navigation/responsive-menu-items--mobile.png +0 -0
- package/src/ui/top-nav-items/__tests__/informational-vr-tests/__snapshots__/top-navigation/responsive-menu-items-on-click--mobile.png +0 -0
- package/src/ui/top-nav-items/__tests__/informational-vr-tests/top-navigation.vr.tsx +108 -0
- package/src/ui/top-nav-items/__tests__/playwright/theming.spec.tsx +21 -0
- package/src/ui/top-nav-items/__tests__/unit/chat-button.test.tsx +40 -0
- package/src/ui/top-nav-items/__tests__/unit/create-button.test.tsx +34 -0
- package/src/ui/top-nav-items/__tests__/unit/end-item.test.tsx +43 -0
- package/src/ui/top-nav-items/__tests__/unit/help.test.tsx +101 -0
- package/src/ui/top-nav-items/__tests__/unit/notifications.test.tsx +63 -0
- package/src/ui/top-nav-items/__tests__/unit/profile.test.tsx +65 -0
- package/src/ui/top-nav-items/__tests__/unit/settings.test.tsx +51 -0
- package/src/ui/top-nav-items/__tests__/unit/theming.test.tsx +76 -0
- package/src/ui/top-nav-items/__tests__/unit/top-nav-items.test.tsx +181 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/log-in-button--desktop.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/search-right-elem--default.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/theme-is-applied-with-an-hsl-color--desktop.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/theme-is-applied-with-an-rgb-color--desktop.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/themed-button-focus-state--default.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/themed-button-hover-state--default.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/themed-create-button-hover-state--desktop.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/themed-link-button-focus-state--default.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/themed-link-button-hover-state--default.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/themed-search-focus-state--default.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/theming-is-enabled--desktop--platform-team25-app-icon-tiles-false.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/theming-is-enabled--desktop--platform-team25-app-icon-tiles-true.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-nav-custom-profile-image--default.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-nav-side-nav-collapsed--desktop.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-nav-side-nav-collapsed--mobile.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-custom-logo200x200example--desktop.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-custom-logo200x200example--mobile.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-custom-logo200x20example--desktop.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-custom-logo200x20example--mobile.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-custom-logo20x200example--desktop.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-custom-logo20x200example--mobile.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-custom-logo20x20example--desktop.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-custom-logo20x20example--mobile.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-example--desktop--platform-team25-app-icon-tiles-false.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-example--desktop--platform-team25-app-icon-tiles-true.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-example--mobile--platform-team25-app-icon-tiles-false.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-example--mobile--platform-team25-app-icon-tiles-true.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-with-a-large-search-input-in-focus-state--default.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/top-navigation.vr.tsx +154 -0
- package/src/ui/top-nav-items/app-switcher.tsx +81 -0
- package/src/ui/top-nav-items/chat-button.tsx +49 -0
- package/src/ui/top-nav-items/create-button.tsx +51 -0
- package/src/ui/top-nav-items/custom-title.tsx +88 -0
- package/src/ui/top-nav-items/end-item.tsx +120 -0
- package/src/ui/top-nav-items/help.tsx +69 -0
- package/src/ui/top-nav-items/log-in.tsx +66 -0
- package/src/ui/top-nav-items/nav-logo.tsx +287 -0
- package/src/ui/top-nav-items/notifications.tsx +67 -0
- package/src/ui/top-nav-items/profile.tsx +26 -0
- package/src/ui/top-nav-items/search.tsx +120 -0
- package/src/ui/top-nav-items/settings.tsx +16 -0
- package/src/ui/top-nav-items/themed/__tests__/unit/button.test.tsx +57 -0
- package/src/ui/top-nav-items/themed/__tests__/unit/use-custom-theme.test.tsx +43 -0
- package/src/ui/top-nav-items/themed/button.tsx +576 -0
- package/src/ui/top-nav-items/themed/color-utils/__tests__/unit/hex.test.tsx +131 -0
- package/src/ui/top-nav-items/themed/color-utils/__tests__/unit/hsl.test.tsx +117 -0
- package/src/ui/top-nav-items/themed/color-utils/__tests__/unit/rgb.test.tsx +88 -0
- package/src/ui/top-nav-items/themed/color-utils/__tests__/unit/try-parse-user-color.test.tsx +35 -0
- package/src/ui/top-nav-items/themed/color-utils/formats/hex.tsx +47 -0
- package/src/ui/top-nav-items/themed/color-utils/formats/hsl.tsx +112 -0
- package/src/ui/top-nav-items/themed/color-utils/formats/rgb.tsx +41 -0
- package/src/ui/top-nav-items/themed/color-utils/index.tsx +111 -0
- package/src/ui/top-nav-items/themed/color-utils/parse-user-color.tsx +31 -0
- package/src/ui/top-nav-items/themed/color-utils/types.tsx +6 -0
- package/src/ui/top-nav-items/themed/get-custom-theme-styles.tsx +186 -0
- package/src/ui/top-nav-items/themed/has-custom-theme-context.tsx +13 -0
- package/src/ui/top-nav-items/themed/migration.tsx +70 -0
- package/src/ui/top-nav-items/themed/palette.tsx +53 -0
- package/src/ui/top-nav-items/themed/search.tsx +70 -0
- package/src/ui/top-nav-items/themed/use-custom-theme.tsx +51 -0
- package/top-nav-items/create-button/package.json +17 -0
- package/top-nav-items/custom-title/package.json +17 -0
- package/top-nav-items/help/package.json +17 -0
- package/top-nav-items/log-in/package.json +17 -0
- package/top-nav-items/notifications/package.json +17 -0
- package/top-nav-items/package.json +17 -0
- package/top-nav-items/profile/package.json +17 -0
- package/top-nav-items/settings/package.json +17 -0
- package/tsconfig.app.json +92 -0
- package/tsconfig.dev.json +173 -0
- package/tsconfig.json +16 -0
|
@@ -0,0 +1,599 @@
|
|
|
1
|
+
/* side-nav.tsx generated by @compiled/babel-plugin v0.36.1 */
|
|
2
|
+
import _extends from "@babel/runtime/helpers/extends";
|
|
3
|
+
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
4
|
+
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
|
|
5
|
+
import "./side-nav.compiled.css";
|
|
6
|
+
import * as React from 'react';
|
|
7
|
+
import { ax, ix } from "@compiled/react/runtime";
|
|
8
|
+
import { useCallback, useContext, useEffect, useMemo, useRef, useState } from 'react';
|
|
9
|
+
import { bind } from 'bind-event-listener';
|
|
10
|
+
import { flushSync } from 'react-dom';
|
|
11
|
+
import mergeRefs from '@atlaskit/ds-lib/merge-refs';
|
|
12
|
+
import { OpenLayerObserverNamespaceProvider, useOpenLayerObserver } from '@atlaskit/layering/experimental/open-layer-observer';
|
|
13
|
+
import { fg } from '@atlaskit/platform-feature-flags';
|
|
14
|
+
import { monitorForElements } from '@atlaskit/pragmatic-drag-and-drop/element/adapter';
|
|
15
|
+
import { media } from '@atlaskit/primitives/responsive';
|
|
16
|
+
import { useSkipLinkInternal } from '../../../context/skip-links/skip-links-context';
|
|
17
|
+
import { TopNavStartElement } from '../../../context/top-nav-start/top-nav-start-context';
|
|
18
|
+
import { contentHeightWhenFixed, contentInsetBlockStart, localSlotLayers, sideNavLiveWidthVar, sideNavPanelSplitterId, sideNavVar, UNSAFE_sideNavLayoutVar } from '../constants';
|
|
19
|
+
import { DangerouslyHoistSlotSizes } from '../hoist-slot-sizes-context';
|
|
20
|
+
import { DangerouslyHoistCssVarToDocumentRoot } from '../hoist-utils';
|
|
21
|
+
import { useLayoutId } from '../id-utils';
|
|
22
|
+
import { PanelSplitterProvider } from '../panel-splitter/provider';
|
|
23
|
+
import { useResizingWidthCssVarOnRootElement } from '../use-resizing-width-css-var-on-root-element';
|
|
24
|
+
import { useSideNavRef } from './element-context';
|
|
25
|
+
import { sideNavFlyoutCloseDelayMs } from './flyout-close-delay-ms';
|
|
26
|
+
import { SideNavToggleButtonElement } from './toggle-button-context';
|
|
27
|
+
import { useExpandSideNav } from './use-expand-side-nav';
|
|
28
|
+
import { useSideNavVisibility } from './use-side-nav-visibility';
|
|
29
|
+
import { useSideNavVisibilityCallbacks } from './use-side-nav-visibility-callbacks';
|
|
30
|
+
import { useToggleSideNav } from './use-toggle-side-nav';
|
|
31
|
+
import { SetSideNavVisibilityState, SideNavVisibilityState } from './visibility-context';
|
|
32
|
+
var panelSplitterResizingVar = '--n_snvRsz';
|
|
33
|
+
var widthResizeBounds = {
|
|
34
|
+
min: '240px',
|
|
35
|
+
max: '50vw'
|
|
36
|
+
};
|
|
37
|
+
function getResizeBounds() {
|
|
38
|
+
return widthResizeBounds;
|
|
39
|
+
}
|
|
40
|
+
var openLayerObserverSideNavNamespace = 'side-nav';
|
|
41
|
+
var styles = {
|
|
42
|
+
root: "_nd5l1b6c _bfhk1bhr _16qs1cd0 _vchhusvi _4t3ieqxy _152timx3 _kqsw1if8 _1bsb1ego _1pbycs5v _14b5hc79 _qilnk0mc _4ap3vuon _scbpglyw",
|
|
43
|
+
oldBorder: "_t51zzgxb",
|
|
44
|
+
newBorder: "_191wglyw _t51zglyw _p5clzgxb",
|
|
45
|
+
newBorderFlyoutOpen: "_p5clglyw",
|
|
46
|
+
flyoutOpen: "_qiln1gzg _4ap31bhr _scbp1cd0 _139f8iot _1tpvfnf5 _sylc1a5r _oyeijq3t",
|
|
47
|
+
flyoutAnimateClosed: "_1e0cglyw _qiln1gzg _139f8iot _1tpvfnf5 _sylc1a5r _1uwsjq3t",
|
|
48
|
+
flexContainer: "_4t3i1osq _1e0c1txw _2lx21bp4 _1bah1yb4",
|
|
49
|
+
hiddenMobileAndDesktop: "_1e0cglyw",
|
|
50
|
+
hiddenMobileOnly: "_1e0cglyw _dm2518uv",
|
|
51
|
+
hiddenDesktopOnly: "_dm25glyw"
|
|
52
|
+
};
|
|
53
|
+
/**
|
|
54
|
+
* We need an additional component layer so we can wrap the side nav in a `OpenLayerObserver` and have access to the
|
|
55
|
+
* context value.
|
|
56
|
+
*/
|
|
57
|
+
function SideNavInternal(_ref) {
|
|
58
|
+
var children = _ref.children,
|
|
59
|
+
defaultCollapsed = _ref.defaultCollapsed,
|
|
60
|
+
_ref$defaultWidth = _ref.defaultWidth,
|
|
61
|
+
defaultWidth = _ref$defaultWidth === void 0 ? 320 : _ref$defaultWidth,
|
|
62
|
+
testId = _ref.testId,
|
|
63
|
+
_ref$label = _ref.label,
|
|
64
|
+
label = _ref$label === void 0 ? 'Sidebar' : _ref$label,
|
|
65
|
+
_ref$skipLinkLabel = _ref.skipLinkLabel,
|
|
66
|
+
skipLinkLabel = _ref$skipLinkLabel === void 0 ? label : _ref$skipLinkLabel,
|
|
67
|
+
onExpand = _ref.onExpand,
|
|
68
|
+
onCollapse = _ref.onCollapse,
|
|
69
|
+
providedId = _ref.id;
|
|
70
|
+
var id = useLayoutId({
|
|
71
|
+
providedId: providedId
|
|
72
|
+
});
|
|
73
|
+
var expandSideNav = useExpandSideNav();
|
|
74
|
+
/**
|
|
75
|
+
* Called after clicking on the side nav skip link, and ensures the side nav is expanded so that it is focusable.
|
|
76
|
+
*
|
|
77
|
+
* We need to update the DOM synchronously because `.focus()` is called synchronously after this state update.
|
|
78
|
+
*/
|
|
79
|
+
var synchronouslyExpandSideNav = useCallback(function () {
|
|
80
|
+
flushSync(function () {
|
|
81
|
+
/**
|
|
82
|
+
* Calling this unconditionally and relying on it to avoid no-op renders.
|
|
83
|
+
*
|
|
84
|
+
* We _could_ call it conditionally, but we'd be duplicating the screen size checks `expandSideNav` makes.
|
|
85
|
+
*/
|
|
86
|
+
expandSideNav();
|
|
87
|
+
});
|
|
88
|
+
}, [expandSideNav]);
|
|
89
|
+
useSkipLinkInternal({
|
|
90
|
+
id: id,
|
|
91
|
+
label: skipLinkLabel,
|
|
92
|
+
onBeforeNavigate: synchronouslyExpandSideNav
|
|
93
|
+
});
|
|
94
|
+
var sideNavState = useContext(SideNavVisibilityState);
|
|
95
|
+
var setSideNavState = useContext(SetSideNavVisibilityState);
|
|
96
|
+
var _useSideNavVisibility = useSideNavVisibility({
|
|
97
|
+
defaultCollapsed: defaultCollapsed
|
|
98
|
+
}),
|
|
99
|
+
isExpandedOnDesktop = _useSideNavVisibility.isExpandedOnDesktop,
|
|
100
|
+
isExpandedOnMobile = _useSideNavVisibility.isExpandedOnMobile;
|
|
101
|
+
// We are placing `defaultCollapsed` into a state container so we can have a stable reference to the initial value.
|
|
102
|
+
// This is so we can use it in an effect _that only runs once_, after the initial render on the client,
|
|
103
|
+
// to sync the side nav context (provided in `<Root>`) with the `defaultCollapsed` prop provided to `<SideNav>`.
|
|
104
|
+
var _useState = useState(defaultCollapsed),
|
|
105
|
+
_useState2 = _slicedToArray(_useState, 1),
|
|
106
|
+
initialDefaultCollapsed = _useState2[0];
|
|
107
|
+
var _useState3 = useState(defaultWidth),
|
|
108
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
109
|
+
width = _useState4[0],
|
|
110
|
+
setWidth = _useState4[1];
|
|
111
|
+
var clampedWidth = "clamp(".concat(widthResizeBounds.min, ", ").concat(width, "px, ").concat(widthResizeBounds.max, ")");
|
|
112
|
+
var dangerouslyHoistSlotSizes = useContext(DangerouslyHoistSlotSizes);
|
|
113
|
+
var navRef = useRef(null);
|
|
114
|
+
/**
|
|
115
|
+
* Used to share the side nav element with the `Panel`,
|
|
116
|
+
* which observes the side nav to determine its maximum width.
|
|
117
|
+
*/
|
|
118
|
+
var sharedRef = useSideNavRef();
|
|
119
|
+
var mergedRef = mergeRefs([navRef, sharedRef]);
|
|
120
|
+
var toggleButtonElement = useContext(SideNavToggleButtonElement);
|
|
121
|
+
var topNavStartElement = useContext(TopNavStartElement);
|
|
122
|
+
var devTimeOnlyAttributes = {};
|
|
123
|
+
var openLayerObserver = useOpenLayerObserver();
|
|
124
|
+
var flyoutStateRef = useRef({
|
|
125
|
+
type: 'not-active'
|
|
126
|
+
});
|
|
127
|
+
var isFlyoutVisible = (sideNavState === null || sideNavState === void 0 ? void 0 : sideNavState.flyout) === 'open';
|
|
128
|
+
var updateFlyoutState = useMemo(function () {
|
|
129
|
+
function tryAbortPendingClose() {
|
|
130
|
+
if (flyoutStateRef.current.type === 'waiting-for-close') {
|
|
131
|
+
flyoutStateRef.current.abort();
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
function open() {
|
|
135
|
+
tryAbortPendingClose();
|
|
136
|
+
flyoutStateRef.current = {
|
|
137
|
+
type: 'open'
|
|
138
|
+
};
|
|
139
|
+
setSideNavState(function (currentState) {
|
|
140
|
+
if ((currentState === null || currentState === void 0 ? void 0 : currentState.desktop) === 'collapsed' && (currentState === null || currentState === void 0 ? void 0 : currentState.flyout) !== 'open') {
|
|
141
|
+
return {
|
|
142
|
+
desktop: currentState.desktop,
|
|
143
|
+
mobile: currentState.mobile,
|
|
144
|
+
flyout: 'open'
|
|
145
|
+
};
|
|
146
|
+
}
|
|
147
|
+
return currentState;
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
function close() {
|
|
151
|
+
tryAbortPendingClose();
|
|
152
|
+
flyoutStateRef.current = {
|
|
153
|
+
type: 'not-active'
|
|
154
|
+
};
|
|
155
|
+
setSideNavState(function (currentState) {
|
|
156
|
+
if ((currentState === null || currentState === void 0 ? void 0 : currentState.desktop) === 'collapsed' && (currentState === null || currentState === void 0 ? void 0 : currentState.flyout) === 'open') {
|
|
157
|
+
return {
|
|
158
|
+
desktop: currentState.desktop,
|
|
159
|
+
mobile: currentState.mobile,
|
|
160
|
+
flyout: 'triggered-animate-close'
|
|
161
|
+
};
|
|
162
|
+
}
|
|
163
|
+
return currentState;
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
return function onAction(action) {
|
|
167
|
+
if (action === 'drag-from-flyout-started') {
|
|
168
|
+
open();
|
|
169
|
+
flyoutStateRef.current = {
|
|
170
|
+
type: 'is-dragging-from-flyout'
|
|
171
|
+
};
|
|
172
|
+
return;
|
|
173
|
+
}
|
|
174
|
+
if (action === 'drag-from-flyout-finished') {
|
|
175
|
+
open();
|
|
176
|
+
return;
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
// ignoring all actions until the drag is finished
|
|
180
|
+
if (flyoutStateRef.current.type === 'is-dragging-from-flyout') {
|
|
181
|
+
return;
|
|
182
|
+
}
|
|
183
|
+
if (action === 'open') {
|
|
184
|
+
open();
|
|
185
|
+
return;
|
|
186
|
+
}
|
|
187
|
+
if (action === 'waiting-for-close') {
|
|
188
|
+
if (flyoutStateRef.current.type === 'waiting-for-close') {
|
|
189
|
+
return;
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
// A timeout is used to close the flyout after a delay when the user mouses out of the flyout area, and to allow
|
|
193
|
+
// us to cancel the close if the user mouses back in.
|
|
194
|
+
var timeout = setTimeout(function () {
|
|
195
|
+
updateFlyoutState('ready-to-close');
|
|
196
|
+
}, sideNavFlyoutCloseDelayMs);
|
|
197
|
+
flyoutStateRef.current = {
|
|
198
|
+
type: 'waiting-for-close',
|
|
199
|
+
abort: function abort() {
|
|
200
|
+
clearTimeout(timeout);
|
|
201
|
+
}
|
|
202
|
+
};
|
|
203
|
+
return;
|
|
204
|
+
}
|
|
205
|
+
if (action === 'ready-to-close') {
|
|
206
|
+
// If there are no open layers, we can close the flyout.
|
|
207
|
+
if (openLayerObserver.getCount({
|
|
208
|
+
namespace: openLayerObserverSideNavNamespace
|
|
209
|
+
}) === 0) {
|
|
210
|
+
close();
|
|
211
|
+
return;
|
|
212
|
+
}
|
|
213
|
+
flyoutStateRef.current = {
|
|
214
|
+
type: 'ready-to-close'
|
|
215
|
+
};
|
|
216
|
+
return;
|
|
217
|
+
}
|
|
218
|
+
if (action === 'force-close') {
|
|
219
|
+
close();
|
|
220
|
+
return;
|
|
221
|
+
}
|
|
222
|
+
};
|
|
223
|
+
}, [openLayerObserver, setSideNavState]);
|
|
224
|
+
var toggleVisibility = useToggleSideNav();
|
|
225
|
+
useEffect(function () {
|
|
226
|
+
// Sync the visibility in context (provided in `<Root>`) with the local `defaultCollapsed` prop provided to `SideNav`
|
|
227
|
+
// after SSR hydration. This should only run once, after the initial render on the client.
|
|
228
|
+
setSideNavState({
|
|
229
|
+
desktop: initialDefaultCollapsed ? 'collapsed' : 'expanded',
|
|
230
|
+
mobile: 'collapsed',
|
|
231
|
+
flyout: 'closed'
|
|
232
|
+
});
|
|
233
|
+
}, [initialDefaultCollapsed, setSideNavState]);
|
|
234
|
+
var handleExpand = useCallback(function (_ref2) {
|
|
235
|
+
var screen = _ref2.screen;
|
|
236
|
+
onExpand === null || onExpand === void 0 || onExpand({
|
|
237
|
+
screen: screen
|
|
238
|
+
});
|
|
239
|
+
|
|
240
|
+
// When the side nav gets expanded, we close the flyout to reset it.
|
|
241
|
+
// This prevents the flyout from staying open and ensures we are respecting the user's intent to expand.
|
|
242
|
+
updateFlyoutState('force-close');
|
|
243
|
+
}, [onExpand, updateFlyoutState]);
|
|
244
|
+
var handleCollapse = useCallback(function (_ref3) {
|
|
245
|
+
var screen = _ref3.screen;
|
|
246
|
+
onCollapse === null || onCollapse === void 0 || onCollapse({
|
|
247
|
+
screen: screen
|
|
248
|
+
});
|
|
249
|
+
|
|
250
|
+
// When the side nav gets collapsed, we close the flyout to reset it.
|
|
251
|
+
// This prevents the flyout from staying open and ensures we are respecting the user's intent to collapse.
|
|
252
|
+
updateFlyoutState('force-close');
|
|
253
|
+
}, [onCollapse, updateFlyoutState]);
|
|
254
|
+
useSideNavVisibilityCallbacks({
|
|
255
|
+
onExpand: handleExpand,
|
|
256
|
+
onCollapse: handleCollapse,
|
|
257
|
+
isExpandedOnDesktop: isExpandedOnDesktop,
|
|
258
|
+
isExpandedOnMobile: isExpandedOnMobile
|
|
259
|
+
});
|
|
260
|
+
useEffect(function () {
|
|
261
|
+
var mediaQueryList = window.matchMedia('(min-width: 64rem)');
|
|
262
|
+
return bind(mediaQueryList, {
|
|
263
|
+
type: 'change',
|
|
264
|
+
listener: function listener() {
|
|
265
|
+
if (mediaQueryList.matches) {
|
|
266
|
+
// We're transitioning from tablet to desktop viewport size.
|
|
267
|
+
// We forcibly show the side nav if it was shown on mobile.
|
|
268
|
+
if (isExpandedOnMobile && !isExpandedOnDesktop) {
|
|
269
|
+
toggleVisibility();
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
});
|
|
274
|
+
}, [toggleVisibility, isExpandedOnDesktop, isExpandedOnMobile]);
|
|
275
|
+
|
|
276
|
+
/**
|
|
277
|
+
* Close the mobile side nav if there is a click outside.
|
|
278
|
+
*
|
|
279
|
+
* Binding/unbinding on changes to `isExpandedOnMobile` instead of window size changes for simplicity.
|
|
280
|
+
* If we listened to window size changes we'd need nested `bind()` calls.
|
|
281
|
+
*/
|
|
282
|
+
useEffect(function () {
|
|
283
|
+
if (!isExpandedOnMobile) {
|
|
284
|
+
return;
|
|
285
|
+
}
|
|
286
|
+
|
|
287
|
+
/**
|
|
288
|
+
* The expected URL fragment used by the side nav skip link.
|
|
289
|
+
*/
|
|
290
|
+
var skipLinkUrlFragment = "#".concat(id);
|
|
291
|
+
return bind(window, {
|
|
292
|
+
type: 'click',
|
|
293
|
+
listener: function listener(event) {
|
|
294
|
+
if (window.matchMedia('(min-width: 64rem)').matches) {
|
|
295
|
+
// Clicks on desktop should do nothing
|
|
296
|
+
return;
|
|
297
|
+
}
|
|
298
|
+
var sideNav = navRef.current;
|
|
299
|
+
if (!sideNav || !(event.target instanceof Node)) {
|
|
300
|
+
// Ignore if our element references are invalid
|
|
301
|
+
return;
|
|
302
|
+
}
|
|
303
|
+
if (sideNav.contains(event.target)) {
|
|
304
|
+
// Clicks inside the side nav should not close it
|
|
305
|
+
return;
|
|
306
|
+
}
|
|
307
|
+
if (toggleButtonElement !== null && toggleButtonElement !== void 0 && toggleButtonElement.contains(event.target)) {
|
|
308
|
+
// Clicks on the toggle button will already toggle the side nav,
|
|
309
|
+
// so we need to ignore it or we end up doing a double toggle
|
|
310
|
+
return;
|
|
311
|
+
}
|
|
312
|
+
if (event.target instanceof HTMLAnchorElement &&
|
|
313
|
+
/**
|
|
314
|
+
* Intentionally using `.getAttribute()` for simplicity to match exactly what we expect
|
|
315
|
+
* for skip links.
|
|
316
|
+
*
|
|
317
|
+
* Alternatives considered:
|
|
318
|
+
*
|
|
319
|
+
* - Using `.href` returns a full URL, which would then require extra parsing.
|
|
320
|
+
* - Using `.hash` could incorrectly capture `<a href="/another-page#skip-link-id>` so we'd need extra checks.
|
|
321
|
+
*
|
|
322
|
+
* This approach has an edge case of `<a href="/same-page#skip-link-id>` not being captured,
|
|
323
|
+
* but we are okay with that trade-off.
|
|
324
|
+
*/
|
|
325
|
+
event.target.getAttribute('href') === skipLinkUrlFragment) {
|
|
326
|
+
// This was a click on a link to the side nav, so we shouldn't try to collapse the SideNav.
|
|
327
|
+
// It was most likely the skip link, although anyone can render a link with the ID.
|
|
328
|
+
// In either case keeping the SideNav expanded makes sense.
|
|
329
|
+
return;
|
|
330
|
+
}
|
|
331
|
+
toggleVisibility();
|
|
332
|
+
}
|
|
333
|
+
});
|
|
334
|
+
}, [id, isExpandedOnMobile, toggleButtonElement, toggleVisibility]);
|
|
335
|
+
useEffect(function () {
|
|
336
|
+
if (!toggleButtonElement) {
|
|
337
|
+
return;
|
|
338
|
+
}
|
|
339
|
+
return bind(toggleButtonElement, {
|
|
340
|
+
type: 'mouseenter',
|
|
341
|
+
listener: function listener() {
|
|
342
|
+
// Only flyout the side nav if the user hovered while the side nav was collapsed
|
|
343
|
+
if (isExpandedOnDesktop) {
|
|
344
|
+
return;
|
|
345
|
+
}
|
|
346
|
+
|
|
347
|
+
// Only flyout the side nav on desktop viewports
|
|
348
|
+
var _window$matchMedia = window.matchMedia('(min-width: 64rem)'),
|
|
349
|
+
matches = _window$matchMedia.matches;
|
|
350
|
+
if (matches) {
|
|
351
|
+
updateFlyoutState('open');
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
});
|
|
355
|
+
}, [updateFlyoutState, toggleButtonElement, isExpandedOnDesktop]);
|
|
356
|
+
useEffect(function () {
|
|
357
|
+
if (!toggleButtonElement) {
|
|
358
|
+
return;
|
|
359
|
+
}
|
|
360
|
+
return bind(toggleButtonElement, {
|
|
361
|
+
type: 'mouseleave',
|
|
362
|
+
listener: function listener() {
|
|
363
|
+
// If the side nav is not in flyout mode, we don't need to do anything
|
|
364
|
+
if (!isFlyoutVisible) {
|
|
365
|
+
return;
|
|
366
|
+
}
|
|
367
|
+
updateFlyoutState('waiting-for-close');
|
|
368
|
+
}
|
|
369
|
+
});
|
|
370
|
+
}, [isFlyoutVisible, toggleButtonElement, updateFlyoutState]);
|
|
371
|
+
useEffect(function () {
|
|
372
|
+
if (!navRef.current) {
|
|
373
|
+
return;
|
|
374
|
+
}
|
|
375
|
+
return bind(navRef.current, {
|
|
376
|
+
type: 'mouseenter',
|
|
377
|
+
listener: function listener() {
|
|
378
|
+
// If the side nav is not in flyout mode, we don't need to do anything
|
|
379
|
+
if (isExpandedOnDesktop || !isFlyoutVisible) {
|
|
380
|
+
return;
|
|
381
|
+
}
|
|
382
|
+
|
|
383
|
+
// The user mouses has moused back over the side nav
|
|
384
|
+
updateFlyoutState('open');
|
|
385
|
+
}
|
|
386
|
+
});
|
|
387
|
+
}, [isFlyoutVisible, updateFlyoutState, isExpandedOnDesktop]);
|
|
388
|
+
useEffect(function () {
|
|
389
|
+
if (!navRef.current) {
|
|
390
|
+
return;
|
|
391
|
+
}
|
|
392
|
+
return bind(navRef.current, {
|
|
393
|
+
type: 'mouseleave',
|
|
394
|
+
listener: function listener() {
|
|
395
|
+
// If the side nav is not in flyout mode, we don't need to do anything
|
|
396
|
+
if (!isFlyoutVisible) {
|
|
397
|
+
return;
|
|
398
|
+
}
|
|
399
|
+
updateFlyoutState('waiting-for-close');
|
|
400
|
+
}
|
|
401
|
+
});
|
|
402
|
+
}, [isFlyoutVisible, updateFlyoutState]);
|
|
403
|
+
useEffect(function () {
|
|
404
|
+
var nav = navRef.current;
|
|
405
|
+
if (!nav) {
|
|
406
|
+
return;
|
|
407
|
+
}
|
|
408
|
+
if (!isFlyoutVisible) {
|
|
409
|
+
return;
|
|
410
|
+
}
|
|
411
|
+
|
|
412
|
+
// Using a monitor rather than a drop target. Rationale:
|
|
413
|
+
// - We are not creating a drop target for the users to drop on,
|
|
414
|
+
// we are just interested in listening to events within an element
|
|
415
|
+
// - We do not want to impact `location.{*}.dropTargets` in events
|
|
416
|
+
return monitorForElements({
|
|
417
|
+
canMonitor: function canMonitor(_ref4) {
|
|
418
|
+
var source = _ref4.source;
|
|
419
|
+
return nav.contains(source.element);
|
|
420
|
+
},
|
|
421
|
+
onGenerateDragPreview: function onGenerateDragPreview() {
|
|
422
|
+
updateFlyoutState('drag-from-flyout-started');
|
|
423
|
+
},
|
|
424
|
+
onDrop: function onDrop(_ref5) {
|
|
425
|
+
var location = _ref5.location;
|
|
426
|
+
// Always marking the drag and done
|
|
427
|
+
updateFlyoutState('drag-from-flyout-finished');
|
|
428
|
+
|
|
429
|
+
// If the user dropped outside of the flyout, we will close the flyout
|
|
430
|
+
var underUsersPointer = document.elementFromPoint(location.current.input.clientX, location.current.input.clientY);
|
|
431
|
+
if (!nav.contains(underUsersPointer)) {
|
|
432
|
+
updateFlyoutState('waiting-for-close');
|
|
433
|
+
}
|
|
434
|
+
}
|
|
435
|
+
});
|
|
436
|
+
}, [isFlyoutVisible, updateFlyoutState]);
|
|
437
|
+
useEffect(function () {
|
|
438
|
+
if (!topNavStartElement || !toggleButtonElement) {
|
|
439
|
+
return;
|
|
440
|
+
}
|
|
441
|
+
return bind(topNavStartElement, {
|
|
442
|
+
type: 'mouseover',
|
|
443
|
+
listener: function listener(event) {
|
|
444
|
+
// If the side nav is not in flyout mode, we don't need to do anything
|
|
445
|
+
if (isExpandedOnDesktop || !isFlyoutVisible) {
|
|
446
|
+
return;
|
|
447
|
+
}
|
|
448
|
+
if (event.target === topNavStartElement) {
|
|
449
|
+
// The mouse is directly over the TopNavStart element, so cancel any pending flyout closes.
|
|
450
|
+
updateFlyoutState('open');
|
|
451
|
+
return;
|
|
452
|
+
}
|
|
453
|
+
if (event.target instanceof Element && toggleButtonElement.contains(event.target)) {
|
|
454
|
+
// The mouse is over the toggle button or any of its children, so we don't want to close the flyout.
|
|
455
|
+
// We also don't need to cancel any pending closes, as we have separate event listeners for the toggle button mouse events.
|
|
456
|
+
return;
|
|
457
|
+
}
|
|
458
|
+
|
|
459
|
+
// The user has moused over a child element of the TopNavStart element that isn't the toggle button, e.g. the app switcher or nav logo,
|
|
460
|
+
// so we should close the flyout (with a delay).
|
|
461
|
+
updateFlyoutState('waiting-for-close');
|
|
462
|
+
}
|
|
463
|
+
});
|
|
464
|
+
}, [topNavStartElement, isFlyoutVisible, toggleButtonElement, isExpandedOnDesktop, updateFlyoutState]);
|
|
465
|
+
useEffect(function () {
|
|
466
|
+
if (!topNavStartElement) {
|
|
467
|
+
return;
|
|
468
|
+
}
|
|
469
|
+
return bind(topNavStartElement, {
|
|
470
|
+
type: 'mouseleave',
|
|
471
|
+
listener: function listener() {
|
|
472
|
+
// If the side nav is not in flyout mode, we don't need to do anything
|
|
473
|
+
if (!isFlyoutVisible) {
|
|
474
|
+
return;
|
|
475
|
+
}
|
|
476
|
+
|
|
477
|
+
// The mouse has left the TopNavStart element, so we should close the flyout with a delay.
|
|
478
|
+
updateFlyoutState('waiting-for-close');
|
|
479
|
+
}
|
|
480
|
+
});
|
|
481
|
+
}, [topNavStartElement, isFlyoutVisible, updateFlyoutState]);
|
|
482
|
+
useEffect(function () {
|
|
483
|
+
// Close the flyout if there are no more layers open and the user is not mousing over the
|
|
484
|
+
// flyout areas (side nav, TopNavStart element)
|
|
485
|
+
|
|
486
|
+
return openLayerObserver.onChange(function (_ref6) {
|
|
487
|
+
var count = _ref6.count;
|
|
488
|
+
if (flyoutStateRef.current.type === 'ready-to-close' && count === 0) {
|
|
489
|
+
updateFlyoutState('force-close');
|
|
490
|
+
}
|
|
491
|
+
}, {
|
|
492
|
+
namespace: openLayerObserverSideNavNamespace
|
|
493
|
+
});
|
|
494
|
+
}, [openLayerObserver, updateFlyoutState]);
|
|
495
|
+
useEffect(function () {
|
|
496
|
+
// Clear flyout close timer if being unmounted
|
|
497
|
+
return function cleanupPendingFlyoutClose() {
|
|
498
|
+
if (flyoutStateRef.current.type === 'waiting-for-close') {
|
|
499
|
+
flyoutStateRef.current.abort();
|
|
500
|
+
}
|
|
501
|
+
};
|
|
502
|
+
}, []);
|
|
503
|
+
if (process.env.NODE_ENV !== 'production') {
|
|
504
|
+
var visible = [];
|
|
505
|
+
if (isExpandedOnMobile) {
|
|
506
|
+
visible.push('small');
|
|
507
|
+
}
|
|
508
|
+
if (isExpandedOnDesktop) {
|
|
509
|
+
visible.push('large');
|
|
510
|
+
}
|
|
511
|
+
if (isFlyoutVisible) {
|
|
512
|
+
visible.push('flyout');
|
|
513
|
+
}
|
|
514
|
+
devTimeOnlyAttributes['data-visible'] = visible.length ? visible.join(',') : 'false';
|
|
515
|
+
}
|
|
516
|
+
useResizingWidthCssVarOnRootElement({
|
|
517
|
+
isEnabled: fg('platform_design_system_nav4_preview_panel_support'),
|
|
518
|
+
cssVar: panelSplitterResizingVar,
|
|
519
|
+
panelId: sideNavPanelSplitterId
|
|
520
|
+
});
|
|
521
|
+
return /*#__PURE__*/React.createElement("nav", _extends({
|
|
522
|
+
id: id
|
|
523
|
+
}, devTimeOnlyAttributes, {
|
|
524
|
+
"data-layout-slot": true,
|
|
525
|
+
"aria-label": label,
|
|
526
|
+
style: _defineProperty({}, sideNavVar, clampedWidth),
|
|
527
|
+
ref: fg('platform_design_system_nav4_preview_panel_support') ? mergedRef : navRef,
|
|
528
|
+
"data-testid": testId,
|
|
529
|
+
className: ax([styles.root, fg('platform_design_system_nav4_sidenav_border') ? styles.newBorder : styles.oldBorder, isExpandedOnDesktop && !isExpandedOnMobile && !isFlyoutVisible && styles.hiddenMobileOnly, !isExpandedOnDesktop && isExpandedOnMobile && !isFlyoutVisible && styles.hiddenDesktopOnly, !isExpandedOnDesktop && !isExpandedOnMobile && !isFlyoutVisible && styles.hiddenMobileAndDesktop, (sideNavState === null || sideNavState === void 0 ? void 0 : sideNavState.flyout) === 'open' && styles.flyoutOpen, (sideNavState === null || sideNavState === void 0 ? void 0 : sideNavState.flyout) === 'open' && fg('platform_design_system_nav4_sidenav_border') && styles.newBorderFlyoutOpen, (sideNavState === null || sideNavState === void 0 ? void 0 : sideNavState.flyout) === 'triggered-animate-close' && styles.flyoutAnimateClosed])
|
|
530
|
+
}), fg('platform_design_system_nav4_preview_panel_support') &&
|
|
531
|
+
/*#__PURE__*/
|
|
532
|
+
// This CSS var is used by the `Panel` slot to enforce its maximum width constraint.
|
|
533
|
+
// When we remove the UNSAFE legacy usage, we can change this to `HoistCssVarToLocalGrid`
|
|
534
|
+
React.createElement(DangerouslyHoistCssVarToDocumentRoot, {
|
|
535
|
+
variableName: sideNavLiveWidthVar,
|
|
536
|
+
value: "0px",
|
|
537
|
+
mediaQuery: media.above.md,
|
|
538
|
+
responsiveValue: isExpandedOnDesktop ? "var(".concat(panelSplitterResizingVar, ", ").concat(clampedWidth, ")") : 0
|
|
539
|
+
}), dangerouslyHoistSlotSizes && (fg('platform_design_system_nav4_preview_panel_support') ?
|
|
540
|
+
/*#__PURE__*/
|
|
541
|
+
// ------ START UNSAFE STYLES ------
|
|
542
|
+
// These styles are only needed for the UNSAFE legacy use case for Jira + Confluence.
|
|
543
|
+
// When they aren't needed anymore we can delete them wholesale.
|
|
544
|
+
React.createElement(DangerouslyHoistCssVarToDocumentRoot, {
|
|
545
|
+
variableName: UNSAFE_sideNavLayoutVar,
|
|
546
|
+
value: "var(".concat(sideNavLiveWidthVar, ")")
|
|
547
|
+
}) : /*#__PURE__*/React.createElement(DangerouslyHoistCssVarToDocumentRoot, {
|
|
548
|
+
variableName: UNSAFE_sideNavLayoutVar,
|
|
549
|
+
value: "0px",
|
|
550
|
+
mediaQuery: media.above.md,
|
|
551
|
+
responsiveValue: isExpandedOnDesktop ? clampedWidth : 0
|
|
552
|
+
})
|
|
553
|
+
// ------ END UNSAFE STYLES ------
|
|
554
|
+
), /*#__PURE__*/React.createElement(PanelSplitterProvider, {
|
|
555
|
+
panelId: sideNavPanelSplitterId,
|
|
556
|
+
panelRef: navRef,
|
|
557
|
+
panelWidth: width,
|
|
558
|
+
onCompleteResize: setWidth,
|
|
559
|
+
getResizeBounds: getResizeBounds,
|
|
560
|
+
resizingCssVar: panelSplitterResizingVar,
|
|
561
|
+
isEnabled: isExpandedOnDesktop && !isFlyoutVisible
|
|
562
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
563
|
+
className: ax([styles.flexContainer])
|
|
564
|
+
}, children)));
|
|
565
|
+
}
|
|
566
|
+
|
|
567
|
+
/**
|
|
568
|
+
* The side navigation layout area. It will show on the left (inline start) of the screen.
|
|
569
|
+
*
|
|
570
|
+
* Use the side nav area components (`SideNavHeader`, `SideNavContent`, `SideNavFooter`) to position
|
|
571
|
+
* content within areas of the side nav.
|
|
572
|
+
*
|
|
573
|
+
* You can optionally render a `PanelSplitter` as a child to make the side navigation slot resizable.
|
|
574
|
+
*/
|
|
575
|
+
export function SideNav(_ref8) {
|
|
576
|
+
var children = _ref8.children,
|
|
577
|
+
defaultCollapsed = _ref8.defaultCollapsed,
|
|
578
|
+
_ref8$defaultWidth = _ref8.defaultWidth,
|
|
579
|
+
defaultWidth = _ref8$defaultWidth === void 0 ? 320 : _ref8$defaultWidth,
|
|
580
|
+
testId = _ref8.testId,
|
|
581
|
+
label = _ref8.label,
|
|
582
|
+
_ref8$skipLinkLabel = _ref8.skipLinkLabel,
|
|
583
|
+
skipLinkLabel = _ref8$skipLinkLabel === void 0 ? label : _ref8$skipLinkLabel,
|
|
584
|
+
onExpand = _ref8.onExpand,
|
|
585
|
+
onCollapse = _ref8.onCollapse,
|
|
586
|
+
id = _ref8.id;
|
|
587
|
+
return /*#__PURE__*/React.createElement(OpenLayerObserverNamespaceProvider, {
|
|
588
|
+
namespace: openLayerObserverSideNavNamespace
|
|
589
|
+
}, /*#__PURE__*/React.createElement(SideNavInternal, {
|
|
590
|
+
defaultCollapsed: defaultCollapsed,
|
|
591
|
+
defaultWidth: defaultWidth,
|
|
592
|
+
testId: testId,
|
|
593
|
+
label: label,
|
|
594
|
+
skipLinkLabel: skipLinkLabel,
|
|
595
|
+
onExpand: onExpand,
|
|
596
|
+
onCollapse: onCollapse,
|
|
597
|
+
id: id
|
|
598
|
+
}, children));
|
|
599
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { createContext } from 'react';
|
|
2
|
+
import __noop from '@atlaskit/ds-lib/noop';
|
|
3
|
+
/**
|
|
4
|
+
* Context for the side nav toggle button element.
|
|
5
|
+
* Used to power the side nav flyout by allowing the side nav to bind event listeners to the button element.
|
|
6
|
+
*/
|
|
7
|
+
export var SideNavToggleButtonElement = /*#__PURE__*/createContext(null);
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Context for the callback ref used to respond to toggle button ref being attached. It is used to update the
|
|
11
|
+
* `SideNavToggleButtonRef` state so consumers can react to the ref being attached.
|
|
12
|
+
*
|
|
13
|
+
* e.g. Once the side nav toggle button has been mounted, the side nav can bind mouse event listeners to it
|
|
14
|
+
* to power the sidenav flyout.
|
|
15
|
+
*
|
|
16
|
+
* A callback ref is needed because the side nav can be mounted before the elements in the top bar (e.g. if the element
|
|
17
|
+
* is lazy loaded, which happens in Jira and Confluence), which would prevent the event listeners from being set up.
|
|
18
|
+
*/
|
|
19
|
+
export var SideNavToggleButtonAttachRef = /*#__PURE__*/createContext(__noop);
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
|
|
2
|
+
import React, { useState } from 'react';
|
|
3
|
+
import { SideNavToggleButtonAttachRef, SideNavToggleButtonElement } from './toggle-button-context';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Provider for the side nav toggle button contexts.
|
|
7
|
+
*
|
|
8
|
+
* We are using a [ref callback](https://react.dev/reference/react-dom/components/common#ref-callback) along with a state
|
|
9
|
+
* for storing the button element once it has mounted, so that the side nav can bind event listeners to the button
|
|
10
|
+
* once it is mounted.
|
|
11
|
+
*
|
|
12
|
+
* Otherwise, the side nav can be mounted before the button (e.g. if the button is lazy loaded), which would prevent the
|
|
13
|
+
* event listeners from being set up.
|
|
14
|
+
*
|
|
15
|
+
* State is required as opposed to just a ref so that the effects in the side nav can react the element actually being mounted,
|
|
16
|
+
* as ref values cannot be added as effect dependencies.
|
|
17
|
+
*/
|
|
18
|
+
export var SideNavToggleButtonProvider = function SideNavToggleButtonProvider(_ref) {
|
|
19
|
+
var children = _ref.children;
|
|
20
|
+
var _useState = useState(null),
|
|
21
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
22
|
+
element = _useState2[0],
|
|
23
|
+
setElement = _useState2[1];
|
|
24
|
+
return /*#__PURE__*/React.createElement(SideNavToggleButtonElement.Provider, {
|
|
25
|
+
value: element
|
|
26
|
+
}, /*#__PURE__*/React.createElement(SideNavToggleButtonAttachRef.Provider, {
|
|
27
|
+
value: setElement
|
|
28
|
+
}, children));
|
|
29
|
+
};
|