@atlaskit/navigation-system 0.182.0 → 1.0.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 +29 -0
- package/dist/cjs/components/skip-links/skip-links-container.js +25 -17
- package/dist/cjs/context/skip-links/skip-links-data-context.js +28 -10
- package/dist/cjs/context/skip-links/skip-links-provider.js +17 -6
- package/dist/cjs/ui/menu-item/menu-item.js +1 -1
- package/dist/cjs/ui/page-layout/root.js +11 -1
- package/dist/es2019/components/skip-links/skip-links-container.js +24 -16
- package/dist/es2019/context/skip-links/skip-links-data-context.js +25 -8
- package/dist/es2019/context/skip-links/skip-links-provider.js +17 -6
- package/dist/es2019/ui/menu-item/menu-item.js +1 -1
- package/dist/es2019/ui/page-layout/root.js +11 -1
- package/dist/esm/components/skip-links/skip-links-container.js +23 -15
- package/dist/esm/context/skip-links/skip-links-data-context.js +26 -9
- package/dist/esm/context/skip-links/skip-links-provider.js +16 -5
- package/dist/esm/ui/menu-item/menu-item.js +1 -1
- package/dist/esm/ui/page-layout/root.js +11 -1
- package/dist/types/components/skip-links/skip-links-container.d.ts +13 -8
- package/dist/types/context/skip-links/skip-links-data-context.d.ts +15 -1
- package/dist/types/context/skip-links/skip-links-provider.d.ts +9 -4
- package/dist/types-ts4.5/components/skip-links/skip-links-container.d.ts +13 -8
- package/dist/types-ts4.5/context/skip-links/skip-links-data-context.d.ts +15 -1
- package/dist/types-ts4.5/context/skip-links/skip-links-provider.d.ts +9 -4
- package/package.json +9 -10
- package/afm-cc/tsconfig.json +0 -78
- package/afm-dev-agents/tsconfig.json +0 -78
- package/afm-jira/tsconfig.json +0 -78
- package/afm-passionfruit/tsconfig.json +0 -78
- package/afm-post-office/tsconfig.json +0 -78
- package/afm-rovo-extension/tsconfig.json +0 -78
- package/afm-townsquare/tsconfig.json +0 -78
- package/afm-volt/tsconfig.json +0 -78
- package/build/tsconfig.json +0 -23
- package/docs/00-intro.tsx +0 -14
- package/examples/advanced-layout.tsx +0 -144
- package/examples/button-menu-item.tsx +0 -426
- package/examples/company-hub-mock.tsx +0 -219
- package/examples/composition.tsx +0 -424
- package/examples/confluence-mock.tsx +0 -381
- package/examples/constellation/common/mock-content.tsx +0 -39
- package/examples/constellation/common/mock-top-bar.tsx +0 -20
- package/examples/constellation/layout/custom-skip-links.tsx +0 -12
- package/examples/constellation/layout/custom-theming--parse-hex.tsx +0 -19
- package/examples/constellation/layout/custom-theming--parse-hsl.tsx +0 -22
- package/examples/constellation/layout/custom-theming--parse-rgb.tsx +0 -22
- package/examples/constellation/layout/custom-theming--parse-user-color.tsx +0 -22
- package/examples/constellation/layout/custom-theming--rgb-object.tsx +0 -21
- package/examples/constellation/layout/expand-side-nav.tsx +0 -17
- package/examples/constellation/layout/toggle-side-nav-keyboard-shortcut.tsx +0 -25
- package/examples/constellation/side-nav-items/actions-and-actions-on-hover.tsx +0 -153
- package/examples/constellation/side-nav-items/button-menu-item.tsx +0 -133
- package/examples/constellation/side-nav-items/common/global-app-icon-tile.tsx +0 -43
- package/examples/constellation/side-nav-items/common/mock-side-nav.tsx +0 -18
- package/examples/constellation/side-nav-items/container-avatar.tsx +0 -32
- package/examples/constellation/side-nav-items/elem-after.tsx +0 -60
- package/examples/constellation/side-nav-items/elem-before.tsx +0 -116
- package/examples/constellation/side-nav-items/expandable-menu-item-default-variant.tsx +0 -219
- package/examples/constellation/side-nav-items/expandable-menu-item-link-variant.tsx +0 -278
- package/examples/constellation/side-nav-items/flyout-menu-item.tsx +0 -156
- package/examples/constellation/side-nav-items/link-menu-item.tsx +0 -161
- package/examples/constellation/side-nav-items/menu-divider.tsx +0 -114
- package/examples/constellation/side-nav-items/menu-section.tsx +0 -177
- package/examples/constellation/side-nav-items/right-to-left.tsx +0 -144
- package/examples/constellation/side-nav-items/top-level-spacer.tsx +0 -82
- package/examples/constellation/side-nav-items/truncation.tsx +0 -58
- package/examples/constellation/top-nav-items/app-logo.tsx +0 -19
- package/examples/constellation/top-nav-items/custom-logo.tsx +0 -28
- package/examples/constellation/top-nav-items/custom-theming--buttons.tsx +0 -27
- package/examples/constellation/top-nav-items/custom-theming--logo.tsx +0 -27
- package/examples/constellation/top-nav-items/custom-theming--search.tsx +0 -28
- package/examples/constellation/top-nav-items/custom-title.tsx +0 -20
- package/examples/constellation/top-nav-items/end-item.tsx +0 -23
- package/examples/constellation/top-nav-items/top-nav-button.tsx +0 -34
- package/examples/constellation/top-nav-items/top-nav-end.tsx +0 -25
- package/examples/constellation/top-nav-items/top-nav-middle.tsx +0 -19
- package/examples/constellation/top-nav-items/top-nav-start.tsx +0 -31
- package/examples/drag-and-drop/jira/data.tsx +0 -320
- package/examples/drag-and-drop/jira/entry.tsx +0 -89
- package/examples/drag-and-drop/jira/filters/filter-move-modal.tsx +0 -171
- package/examples/drag-and-drop/jira/filters/filter-tree-utils.tsx +0 -134
- package/examples/drag-and-drop/jira/filters/filters-menu-item.tsx +0 -470
- package/examples/drag-and-drop/jira/for-you/for-you-menu-item.tsx +0 -74
- package/examples/drag-and-drop/jira/projects/project-tile.tsx +0 -37
- package/examples/drag-and-drop/jira/projects/project.tsx +0 -257
- package/examples/drag-and-drop/jira/projects/projects-menu-item.tsx +0 -120
- package/examples/drag-and-drop/jira/recent/recent-menu-item.tsx +0 -30
- package/examples/drag-and-drop/jira/reducer.tsx +0 -78
- package/examples/drag-and-drop/jira/registry.tsx +0 -52
- package/examples/drag-and-drop/jira/reorder-actions.tsx +0 -75
- package/examples/drag-and-drop/jira/shared-top-level-flyout.tsx +0 -144
- package/examples/drag-and-drop/jira/sidebar.tsx +0 -361
- package/examples/drag-and-drop/jira/starred/starred-menu-item.tsx +0 -29
- package/examples/drag-and-drop/jira/state-context.tsx +0 -34
- package/examples/drag-and-drop/jira/top-level-shared-more-menu.tsx +0 -99
- package/examples/drag-and-drop/sidebar-example-container.tsx +0 -38
- package/examples/drag-and-drop/simple.tsx +0 -653
- package/examples/drag-and-drop/standalone-jira-sidebar-centered.tsx +0 -27
- package/examples/drag-and-drop/standalone-jira-sidebar.tsx +0 -18
- package/examples/drag-and-drop-in-the-sidebar-flyout.tsx +0 -161
- package/examples/drag-and-drop-jira-scaling-vr.tsx +0 -25
- package/examples/drag-and-drop-jira-sidebar-centered.tsx +0 -1
- package/examples/drag-and-drop-jira-sidebar-standalone.tsx +0 -1
- package/examples/drag-and-drop-jira.tsx +0 -1
- package/examples/drag-and-drop.tsx +0 -1
- package/examples/expandable-menu-item.tsx +0 -775
- package/examples/flyout-menu-item-async-content.tsx +0 -118
- package/examples/flyout-menu-item-multiple.tsx +0 -180
- package/examples/flyout-menu-item.tsx +0 -269
- 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 +0 -9
- package/examples/images/koala.png +0 -0
- package/examples/images/koala.svg +0 -9
- package/examples/images/money.svg +0 -9
- package/examples/images/science.svg +0 -20
- package/examples/interactive-layout.tsx +0 -286
- package/examples/layers-in-main.tsx +0 -294
- package/examples/legacy-var-testing.tsx +0 -173
- package/examples/link-menu-item.tsx +0 -383
- package/examples/main-content-border.tsx +0 -148
- package/examples/menu-item-avatar.tsx +0 -41
- package/examples/menu-item-conditional-tooltip.tsx +0 -304
- package/examples/menu-item-focus-ring-bleed.tsx +0 -50
- package/examples/menu-item-integration.tsx +0 -207
- package/examples/menu-item-narrow.tsx +0 -290
- package/examples/menu-item-scroll-into-view.tsx +0 -283
- package/examples/menu-items-deeply-nested.tsx +0 -330
- package/examples/menu-list.tsx +0 -62
- package/examples/menu-section.tsx +0 -78
- package/examples/page-layout-all-slots-banner-height-zero.tsx +0 -3
- package/examples/page-layout-all-slots-custom-sizes.tsx +0 -3
- package/examples/page-layout-all-slots-rtl.tsx +0 -3
- package/examples/page-layout-all-slots-scrollable.tsx +0 -3
- package/examples/page-layout-all-slots.tsx +0 -3
- package/examples/page-layout-aside-border.tsx +0 -149
- package/examples/page-layout-content-is-iframes.tsx +0 -3
- package/examples/page-layout-edge-case-absolute-positioned-collapsed-custom-sizes.tsx +0 -3
- package/examples/page-layout-edge-case-absolute-positioned-collapsed.tsx +0 -3
- package/examples/page-layout-edge-case-absolute-positioned-panel-visible.tsx +0 -3
- package/examples/page-layout-edge-case-absolute-positioned-resizable.tsx +0 -3
- package/examples/page-layout-edge-case-absolute-positioned.tsx +0 -3
- package/examples/page-layout-edge-case-using-legacy-vars.tsx +0 -3
- package/examples/page-layout-full-screen.tsx +0 -251
- package/examples/page-layout-implicit-rows.tsx +0 -33
- package/examples/page-layout-main-aside-scrollable.tsx +0 -3
- package/examples/page-layout-main-aside.tsx +0 -3
- package/examples/page-layout-panel-aside-default-widths.tsx +0 -241
- package/examples/page-layout-resizable-rtl.tsx +0 -3
- package/examples/page-layout-resizable.tsx +0 -3
- package/examples/page-layout-side-nav-collapse-shortcut.tsx +0 -47
- package/examples/page-layout-side-nav-content-scroll-with-sticky.tsx +0 -135
- package/examples/page-layout-side-nav-custom-width-greater-than-max.tsx +0 -3
- package/examples/page-layout-side-nav-custom-width-smaller-than-min.tsx +0 -3
- package/examples/page-layout-side-nav-main-aside-scrollable.tsx +0 -3
- package/examples/page-layout-side-nav-main-aside.tsx +0 -3
- package/examples/page-layout-side-nav-onboarding.tsx +0 -155
- package/examples/page-layout-side-nav-overflowing-children.tsx +0 -3
- package/examples/page-layout-side-nav-slots.tsx +0 -173
- package/examples/page-layout-side-nav-with-menu-items.tsx +0 -3
- package/examples/page-layout-top-bar-side-nav-main-aside-scrollable.tsx +0 -3
- package/examples/page-layout-top-bar-side-nav-main-aside.tsx +0 -3
- package/examples/page-layout-top-bar-side-nav-main-scrollable.tsx +0 -3
- package/examples/page-layout-top-bar-side-nav-main.tsx +0 -3
- package/examples/page-layout.tsx +0 -941
- package/examples/panel-splitter.tsx +0 -199
- package/examples/resizable-slots.tsx +0 -357
- package/examples/side-nav-flyout.tsx +0 -256
- package/examples/stand-alone-iframe.tsx +0 -23
- package/examples/temp-icons/app-switcher-legacy.tsx +0 -14
- package/examples/temp-icons/atlassian-intelligence.tsx +0 -14
- package/examples/temp-icons/help.tsx +0 -18
- package/examples/temp-icons/menu.tsx +0 -14
- package/examples/temp-icons/settings.tsx +0 -14
- package/examples/top-level-spacer.tsx +0 -55
- package/examples/top-nav-custom-profile-image.tsx +0 -71
- package/examples/top-nav-side-nav-collapsed.tsx +0 -74
- package/examples/top-nav-with-long-name.tsx +0 -63
- package/examples/top-nav-with-temp-nav-app-icon-app-logo.tsx +0 -65
- package/examples/top-nav-with-temp-nav-app-icon-custom-logo.tsx +0 -63
- package/examples/top-navigation-custom-logo.tsx +0 -108
- package/examples/top-navigation-stress.tsx +0 -244
- package/examples/top-navigation-themed-buttons.tsx +0 -63
- package/examples/top-navigation-theming-logged-out.tsx +0 -75
- package/examples/top-navigation-theming-with-picker.tsx +0 -128
- package/examples/top-navigation-theming.tsx +0 -197
- package/examples/top-navigation.tsx +0 -126
- package/examples/utils/example-utils.tsx +0 -14
- package/examples/utils/long-placeholder-content.tsx +0 -161
- package/examples/utils/mock-root.tsx +0 -19
- package/examples/utils/mock-search.tsx +0 -67
- package/src/__tests__/informational-vr-tests/__snapshots__/layering/layers-in-main-slot--desktop--platform-dst-nav4-layering-in-main-slot-fixes-false.png +0 -0
- package/src/__tests__/informational-vr-tests/__snapshots__/layering/layers-in-main-slot--desktop--platform-dst-nav4-layering-in-main-slot-fixes-true.png +0 -0
- package/src/__tests__/informational-vr-tests/__snapshots__/layering/layers-in-main-slot-short-viewport--desktop--platform-dst-nav4-layering-in-main-slot-fixes-false.png +0 -0
- package/src/__tests__/informational-vr-tests/__snapshots__/layering/layers-in-main-slot-short-viewport--desktop--platform-dst-nav4-layering-in-main-slot-fixes-true.png +0 -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 +0 -76
- package/src/__tests__/informational-vr-tests/menu-items-deeply-nested.vr.tsx +0 -33
- package/src/__tests__/informational-vr-tests/sidebar-drag-and-drop.vr.tsx +0 -100
- package/src/__tests__/playwright/drag-and-drop-in-the-sidebar-flyout.spec.tsx +0 -235
- package/src/__tests__/playwright/expandable-menu-item.spec.tsx +0 -20
- package/src/__tests__/playwright/flyout-menu-item.spec.tsx +0 -22
- package/src/__tests__/playwright/legacy-vars.spec.tsx +0 -298
- package/src/__tests__/playwright/menu-item-in-sidebar-drag-and-drop.spec.tsx +0 -70
- package/src/__tests__/playwright/page-layout.spec.tsx +0 -23
- package/src/__tests__/playwright/panel.spec.tsx +0 -241
- package/src/__tests__/playwright/resizing.spec.tsx +0 -541
- package/src/__tests__/playwright/side-nav-flyout.spec.tsx +0 -223
- package/src/__tests__/playwright/side-nav-responsiveness.spec.tsx +0 -208
- package/src/__tests__/playwright/skip-links.spec.tsx +0 -111
- package/src/__tests__/playwright/top-nav-end.spec.tsx +0 -96
- package/src/__tests__/vr-tests/__snapshots__/a11y-scaling/app--desktop.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-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-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/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-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__/skip-links/skip-links--light-mode.png +0 -0
- package/src/__tests__/vr-tests/a11y-scaling.vr.tsx +0 -12
- package/src/__tests__/vr-tests/layering.vr.tsx +0 -82
- package/src/__tests__/vr-tests/skip-links.vr.tsx +0 -14
- package/src/components/__tests__/unit/badge-container.test.tsx +0 -62
- package/src/components/__tests__/unit/list.test.tsx +0 -74
- package/src/components/badge-container.tsx +0 -72
- package/src/components/forward-ref-with-generic.tsx +0 -8
- package/src/components/list-item.tsx +0 -39
- package/src/components/list.tsx +0 -44
- package/src/components/skip-links/__tests__/unit/skip-links-container.test.tsx +0 -411
- package/src/components/skip-links/skip-link.tsx +0 -140
- package/src/components/skip-links/skip-links-container.tsx +0 -112
- package/src/context/skip-links/skip-links-context.tsx +0 -74
- package/src/context/skip-links/skip-links-data-context.tsx +0 -41
- package/src/context/skip-links/skip-links-provider.tsx +0 -74
- package/src/context/skip-links/types.tsx +0 -29
- package/src/context/top-nav-start/top-nav-start-context-provider.tsx +0 -26
- package/src/context/top-nav-start/top-nav-start-context.tsx +0 -21
- package/src/entry-points/experimental/color-utils/parse-hex.tsx +0 -1
- package/src/entry-points/experimental/color-utils/parse-hsl.tsx +0 -1
- package/src/entry-points/experimental/color-utils/parse-rgb.tsx +0 -1
- package/src/entry-points/experimental/color-utils/parse-user-color.tsx +0 -1
- package/src/entry-points/experimental/top-nav-button.tsx +0 -6
- package/src/entry-points/experimental/use-has-custom-theme.tsx +0 -1
- package/src/entry-points/experimental/use-legacy-search-theme.tsx +0 -1
- package/src/entry-points/layout/aside.tsx +0 -1
- package/src/entry-points/layout/banner.tsx +0 -1
- package/src/entry-points/layout/main.tsx +0 -7
- package/src/entry-points/layout/panel-splitter.tsx +0 -3
- package/src/entry-points/layout/panel.tsx +0 -1
- package/src/entry-points/layout/root.tsx +0 -1
- package/src/entry-points/layout/side-nav.tsx +0 -7
- package/src/entry-points/layout/skip-links.tsx +0 -2
- package/src/entry-points/layout/top-nav.tsx +0 -4
- package/src/entry-points/side-nav-items/button-menu-item.tsx +0 -3
- package/src/entry-points/side-nav-items/container-avatar.tsx +0 -1
- package/src/entry-points/side-nav-items/drag-and-drop/drag-preview.tsx +0 -1
- package/src/entry-points/side-nav-items/drag-and-drop/drop-indicator.tsx +0 -5
- package/src/entry-points/side-nav-items/drag-and-drop/group-drop-indicator.tsx +0 -1
- package/src/entry-points/side-nav-items/drag-and-drop/hitbox.tsx +0 -7
- package/src/entry-points/side-nav-items/drag-and-drop/use-menu-item-drag-and-drop.tsx +0 -4
- package/src/entry-points/side-nav-items/expandable-menu-item.tsx +0 -13
- package/src/entry-points/side-nav-items/flyout-menu-item.tsx +0 -13
- package/src/entry-points/side-nav-items/link-menu-item.tsx +0 -3
- package/src/entry-points/side-nav-items/menu-list-item.tsx +0 -1
- package/src/entry-points/side-nav-items/menu-list.tsx +0 -1
- package/src/entry-points/side-nav-items/menu-section.tsx +0 -3
- package/src/entry-points/side-nav-items/top-level-spacer.tsx +0 -1
- package/src/entry-points/top-nav-items/create-button.tsx +0 -1
- package/src/entry-points/top-nav-items/custom-title.tsx +0 -1
- package/src/entry-points/top-nav-items/help.tsx +0 -1
- package/src/entry-points/top-nav-items/index.tsx +0 -14
- package/src/entry-points/top-nav-items/log-in.tsx +0 -1
- package/src/entry-points/top-nav-items/notifications.tsx +0 -1
- package/src/entry-points/top-nav-items/profile.tsx +0 -1
- package/src/entry-points/top-nav-items/settings.tsx +0 -1
- package/src/index.tsx +0 -74
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/flyout-menu-item-async-content/long-content-after-short-skeleton--default.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/flyout-menu-item-async-content/long-skeleton--default.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/flyout-menu-item-async-content/short-content-after-long-skeleton--default.png +0 -0
- package/src/ui/menu-item/__tests__/informational-vr-tests/__snapshots__/flyout-menu-item-async-content/short-skeleton--default.png +0 -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/flyout-menu-item-async-content.vr.tsx +0 -33
- package/src/ui/menu-item/__tests__/informational-vr-tests/menu-item-increased-hitbox.vr.tsx +0 -79
- package/src/ui/menu-item/__tests__/informational-vr-tests/menu-item.vr.tsx +0 -151
- package/src/ui/menu-item/__tests__/playwright/flyout-menu-item.spec.tsx +0 -38
- package/src/ui/menu-item/__tests__/playwright/scroll-into-view.spec.tsx +0 -91
- package/src/ui/menu-item/__tests__/unit/_util.tsx +0 -40
- package/src/ui/menu-item/__tests__/unit/expandable-menu-item.test.tsx +0 -1119
- package/src/ui/menu-item/__tests__/unit/flyout-menu-item.test.tsx +0 -545
- package/src/ui/menu-item/__tests__/unit/menu-item.test.tsx +0 -649
- package/src/ui/menu-item/__tests__/unit/top-level-spacer.test.tsx +0 -94
- 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/top-level-spacer-example--default.png +0 -0
- package/src/ui/menu-item/__tests__/vr-tests/drag-and-drop.vr.tsx +0 -172
- package/src/ui/menu-item/__tests__/vr-tests/expandable.vr.tsx +0 -248
- package/src/ui/menu-item/__tests__/vr-tests/flyout-menu-item.vr.tsx +0 -46
- package/src/ui/menu-item/__tests__/vr-tests/menu-item-conditional-tooltip.vr.tsx +0 -312
- package/src/ui/menu-item/__tests__/vr-tests/menu-item.vr.tsx +0 -210
- package/src/ui/menu-item/__tests__/vr-tests/top-level-spacer.vr.tsx +0 -17
- package/src/ui/menu-item/button-menu-item.tsx +0 -87
- package/src/ui/menu-item/constants.tsx +0 -15
- package/src/ui/menu-item/container-avatar.tsx +0 -39
- package/src/ui/menu-item/drag-and-drop/drag-preview.tsx +0 -98
- package/src/ui/menu-item/drag-and-drop/drop-indicator.tsx +0 -11
- package/src/ui/menu-item/drag-and-drop/group-drop-indicator.tsx +0 -7
- package/src/ui/menu-item/drag-and-drop/hitbox.tsx +0 -13
- package/src/ui/menu-item/drag-and-drop/use-menu-item-drag-and-drop.tsx +0 -243
- package/src/ui/menu-item/drag-handle.tsx +0 -42
- package/src/ui/menu-item/expandable-menu-item/expandable-menu-item-content.tsx +0 -84
- package/src/ui/menu-item/expandable-menu-item/expandable-menu-item-context.tsx +0 -61
- package/src/ui/menu-item/expandable-menu-item/expandable-menu-item-level-context.tsx +0 -9
- package/src/ui/menu-item/expandable-menu-item/expandable-menu-item-trigger.tsx +0 -334
- package/src/ui/menu-item/expandable-menu-item/expandable-menu-item.tsx +0 -114
- package/src/ui/menu-item/flyout-menu-item/flyout-menu-item-content.tsx +0 -188
- package/src/ui/menu-item/flyout-menu-item/flyout-menu-item-context.tsx +0 -19
- package/src/ui/menu-item/flyout-menu-item/flyout-menu-item-trigger.tsx +0 -124
- package/src/ui/menu-item/flyout-menu-item/flyout-menu-item.tsx +0 -98
- package/src/ui/menu-item/link-menu-item.tsx +0 -119
- package/src/ui/menu-item/menu-item-signals.tsx +0 -6
- package/src/ui/menu-item/menu-item.tsx +0 -848
- package/src/ui/menu-item/menu-list-item.tsx +0 -12
- package/src/ui/menu-item/menu-list.tsx +0 -12
- package/src/ui/menu-item/top-level-spacer.tsx +0 -49
- package/src/ui/menu-item/types.tsx +0 -181
- package/src/ui/menu-item/use-scroll-menu-item-into-view.tsx +0 -78
- package/src/ui/menu-section/__tests__/unit/menu-section.test.tsx +0 -96
- 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 +0 -14
- package/src/ui/menu-section/__tests__/vr-tests/menu-section.vr.tsx +0 -14
- package/src/ui/menu-section/divider.tsx +0 -33
- package/src/ui/menu-section/menu-section-context.tsx +0 -15
- package/src/ui/menu-section/menu-section-heading.tsx +0 -43
- package/src/ui/menu-section/menu-section.tsx +0 -70
- 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 +0 -53
- package/src/ui/page-layout/__tests__/informational-vr-tests/slot-borders.vr.tsx +0 -54
- package/src/ui/page-layout/__tests__/informational-vr-tests/top-nav.vr.tsx +0 -170
- package/src/ui/page-layout/__tests__/unit/_test-utils.tsx +0 -185
- package/src/ui/page-layout/__tests__/unit/aside.test.tsx +0 -21
- package/src/ui/page-layout/__tests__/unit/banner.test.tsx +0 -31
- package/src/ui/page-layout/__tests__/unit/get-width.test.tsx +0 -12
- package/src/ui/page-layout/__tests__/unit/hoist-utils.test.tsx +0 -85
- package/src/ui/page-layout/__tests__/unit/page-layout.test.tsx +0 -300
- package/src/ui/page-layout/__tests__/unit/panel-splitter-and-suspense.test.tsx +0 -43
- package/src/ui/page-layout/__tests__/unit/panel-splitter.test.tsx +0 -885
- package/src/ui/page-layout/__tests__/unit/panel.test.tsx +0 -63
- package/src/ui/page-layout/__tests__/unit/react-safety.test.tsx +0 -30
- package/src/ui/page-layout/__tests__/unit/resizing.test.tsx +0 -714
- package/src/ui/page-layout/__tests__/unit/side-nav-flyout.test.tsx +0 -1154
- package/src/ui/page-layout/__tests__/unit/side-nav.test.tsx +0 -771
- package/src/ui/page-layout/__tests__/unit/sticky-header.test.tsx +0 -43
- package/src/ui/page-layout/__tests__/unit/top-nav-end.test.tsx +0 -132
- package/src/ui/page-layout/__tests__/unit/top-nav.test.tsx +0 -28
- package/src/ui/page-layout/__tests__/unit/use-expand-side-nav.test.tsx +0 -278
- package/src/ui/page-layout/__tests__/unit/use-toggle-side-nav.test.tsx +0 -233
- 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/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/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.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-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-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__/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 +0 -47
- package/src/ui/page-layout/__tests__/vr-tests/page-layout.vr.tsx +0 -266
- package/src/ui/page-layout/__tests__/vr-tests/panel-splitter.vr.tsx +0 -72
- package/src/ui/page-layout/__tests__/vr-tests/side-nav-flyout.vr.tsx +0 -170
- package/src/ui/page-layout/aside.tsx +0 -210
- package/src/ui/page-layout/banner.tsx +0 -91
- package/src/ui/page-layout/constants.tsx +0 -56
- package/src/ui/page-layout/hoist-slot-sizes-context.tsx +0 -7
- package/src/ui/page-layout/hoist-utils.tsx +0 -64
- package/src/ui/page-layout/id-utils.tsx +0 -33
- package/src/ui/page-layout/main/main-sticky-header.tsx +0 -45
- package/src/ui/page-layout/main/main.tsx +0 -93
- package/src/ui/page-layout/panel-splitter/context.tsx +0 -60
- package/src/ui/page-layout/panel-splitter/convert-resize-bound-to-pixels.tsx +0 -20
- package/src/ui/page-layout/panel-splitter/get-percentage-within-pixel-bounds.tsx +0 -35
- package/src/ui/page-layout/panel-splitter/get-width.tsx +0 -33
- package/src/ui/page-layout/panel-splitter/keyboard-resize-manager.tsx +0 -89
- package/src/ui/page-layout/panel-splitter/panel-splitter.tsx +0 -560
- package/src/ui/page-layout/panel-splitter/provider.tsx +0 -66
- package/src/ui/page-layout/panel-splitter/types.tsx +0 -25
- package/src/ui/page-layout/panel.tsx +0 -308
- package/src/ui/page-layout/root.tsx +0 -162
- package/src/ui/page-layout/side-nav/element-context.tsx +0 -18
- package/src/ui/page-layout/side-nav/flyout-close-delay-ms.tsx +0 -12
- package/src/ui/page-layout/side-nav/side-nav-content.tsx +0 -57
- package/src/ui/page-layout/side-nav/side-nav-footer.tsx +0 -48
- package/src/ui/page-layout/side-nav/side-nav-header.tsx +0 -32
- package/src/ui/page-layout/side-nav/side-nav.tsx +0 -876
- package/src/ui/page-layout/side-nav/toggle-button-context.tsx +0 -21
- package/src/ui/page-layout/side-nav/toggle-button-provider.tsx +0 -28
- package/src/ui/page-layout/side-nav/toggle-button.tsx +0 -166
- package/src/ui/page-layout/side-nav/types.tsx +0 -18
- package/src/ui/page-layout/side-nav/use-expand-side-nav.tsx +0 -57
- package/src/ui/page-layout/side-nav/use-side-nav-visibility-callbacks.tsx +0 -75
- package/src/ui/page-layout/side-nav/use-side-nav-visibility.tsx +0 -43
- package/src/ui/page-layout/side-nav/use-toggle-side-nav.tsx +0 -47
- package/src/ui/page-layout/side-nav/visibility-context.tsx +0 -17
- package/src/ui/page-layout/side-nav/visibility-provider.tsx +0 -20
- package/src/ui/page-layout/top-nav/top-nav-end.tsx +0 -155
- package/src/ui/page-layout/top-nav/top-nav-middle.tsx +0 -90
- package/src/ui/page-layout/top-nav/top-nav-start.tsx +0 -82
- package/src/ui/page-layout/top-nav/top-nav.tsx +0 -127
- package/src/ui/page-layout/types.tsx +0 -20
- package/src/ui/page-layout/use-resizing-width-css-var-on-root-element.tsx +0 -70
- package/src/ui/top-nav-items/__tests__/informational-vr-tests/__snapshots__/top-navigation/long-product-name-tooltip--default.png +0 -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 +0 -120
- package/src/ui/top-nav-items/__tests__/playwright/theming.spec.tsx +0 -21
- package/src/ui/top-nav-items/__tests__/unit/chat-button.test.tsx +0 -40
- package/src/ui/top-nav-items/__tests__/unit/create-button.test.tsx +0 -34
- package/src/ui/top-nav-items/__tests__/unit/end-item.test.tsx +0 -43
- package/src/ui/top-nav-items/__tests__/unit/help.test.tsx +0 -101
- package/src/ui/top-nav-items/__tests__/unit/notifications.test.tsx +0 -63
- package/src/ui/top-nav-items/__tests__/unit/profile.test.tsx +0 -65
- package/src/ui/top-nav-items/__tests__/unit/settings.test.tsx +0 -51
- package/src/ui/top-nav-items/__tests__/unit/theming.test.tsx +0 -76
- package/src/ui/top-nav-items/__tests__/unit/top-nav-items.test.tsx +0 -181
- 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/theme-is-applied-with-customlogo--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.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-logo-example--desktop.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-custom-logo-example--mobile.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-custom-logo-image200x200example--desktop.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-custom-logo-image200x200example--mobile.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-custom-logo-image200x20example--desktop.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-custom-logo-image200x20example--mobile.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-custom-logo-image20x200example--desktop.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-custom-logo-image20x200example--mobile.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-custom-logo-image20x20example--desktop.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-custom-logo-image20x20example--mobile.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-example--desktop.png +0 -0
- package/src/ui/top-nav-items/__tests__/vr-tests/__snapshots__/top-navigation/top-navigation-example--mobile.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 +0 -160
- package/src/ui/top-nav-items/app-switcher.tsx +0 -81
- package/src/ui/top-nav-items/chat-button.tsx +0 -49
- package/src/ui/top-nav-items/create-button.tsx +0 -51
- package/src/ui/top-nav-items/custom-title.tsx +0 -83
- package/src/ui/top-nav-items/end-item.tsx +0 -120
- package/src/ui/top-nav-items/help.tsx +0 -69
- package/src/ui/top-nav-items/log-in.tsx +0 -66
- package/src/ui/top-nav-items/nav-logo/app-logo.tsx +0 -203
- package/src/ui/top-nav-items/nav-logo/custom-logo.tsx +0 -252
- package/src/ui/top-nav-items/nav-logo/logo-renderer.tsx +0 -66
- package/src/ui/top-nav-items/notifications.tsx +0 -67
- package/src/ui/top-nav-items/profile.tsx +0 -26
- package/src/ui/top-nav-items/search.tsx +0 -124
- package/src/ui/top-nav-items/settings.tsx +0 -16
- package/src/ui/top-nav-items/themed/__tests__/unit/button.test.tsx +0 -57
- package/src/ui/top-nav-items/themed/__tests__/unit/use-custom-theme.test.tsx +0 -43
- package/src/ui/top-nav-items/themed/button.tsx +0 -576
- package/src/ui/top-nav-items/themed/color-utils/__tests__/unit/hex.test.tsx +0 -131
- package/src/ui/top-nav-items/themed/color-utils/__tests__/unit/hsl.test.tsx +0 -117
- package/src/ui/top-nav-items/themed/color-utils/__tests__/unit/rgb.test.tsx +0 -88
- package/src/ui/top-nav-items/themed/color-utils/__tests__/unit/try-parse-user-color.test.tsx +0 -35
- package/src/ui/top-nav-items/themed/color-utils/formats/hex.tsx +0 -47
- package/src/ui/top-nav-items/themed/color-utils/formats/hsl.tsx +0 -112
- package/src/ui/top-nav-items/themed/color-utils/formats/rgb.tsx +0 -41
- package/src/ui/top-nav-items/themed/color-utils/index.tsx +0 -111
- package/src/ui/top-nav-items/themed/color-utils/parse-user-color.tsx +0 -31
- package/src/ui/top-nav-items/themed/color-utils/types.tsx +0 -6
- package/src/ui/top-nav-items/themed/get-custom-theme-styles.tsx +0 -186
- package/src/ui/top-nav-items/themed/has-custom-theme-context.tsx +0 -13
- package/src/ui/top-nav-items/themed/migration.tsx +0 -70
- package/src/ui/top-nav-items/themed/palette.tsx +0 -53
- package/src/ui/top-nav-items/themed/search.tsx +0 -70
- package/src/ui/top-nav-items/themed/use-custom-theme.tsx +0 -51
- package/tsconfig.app.json +0 -91
- package/tsconfig.dev.json +0 -175
- package/tsconfig.json +0 -20
|
@@ -1,576 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @jsxRuntime classic
|
|
3
|
-
* @jsx jsx
|
|
4
|
-
*/
|
|
5
|
-
import React, { forwardRef } from 'react';
|
|
6
|
-
|
|
7
|
-
import { cssMap, cx, jsx } from '@compiled/react';
|
|
8
|
-
|
|
9
|
-
import type { IconButtonProps } from '@atlaskit/button/new';
|
|
10
|
-
import mergeRefs from '@atlaskit/ds-lib/merge-refs';
|
|
11
|
-
import {
|
|
12
|
-
Anchor,
|
|
13
|
-
type AnchorProps,
|
|
14
|
-
Pressable,
|
|
15
|
-
type PressableProps,
|
|
16
|
-
} from '@atlaskit/primitives/compiled';
|
|
17
|
-
import { token } from '@atlaskit/tokens';
|
|
18
|
-
import Tooltip from '@atlaskit/tooltip';
|
|
19
|
-
import VisuallyHidden from '@atlaskit/visually-hidden';
|
|
20
|
-
|
|
21
|
-
import { forwardRefWithGeneric } from '../../../components/forward-ref-with-generic';
|
|
22
|
-
|
|
23
|
-
type ButtonAppearance = 'default' | 'primary' | 'subtle';
|
|
24
|
-
|
|
25
|
-
interface CommonProps {
|
|
26
|
-
/**
|
|
27
|
-
* The button style variation.
|
|
28
|
-
*/
|
|
29
|
-
appearance?: ButtonAppearance;
|
|
30
|
-
/**
|
|
31
|
-
* Whether the button is disabled.
|
|
32
|
-
*/
|
|
33
|
-
isDisabled?: boolean;
|
|
34
|
-
/**
|
|
35
|
-
* Indicates that the button is selected.
|
|
36
|
-
*/
|
|
37
|
-
isSelected?: boolean;
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
/**
|
|
41
|
-
* Props from primitives that we explicitly ignore and remove from spread props,
|
|
42
|
-
* because they apply styles.
|
|
43
|
-
*
|
|
44
|
-
* `css` / `className` are not here because primitives don't support them.
|
|
45
|
-
*
|
|
46
|
-
* See `packages/design-system/primitives/src/components/anchor.tsx` and `packages/design-system/primitives/src/components/pressable.tsx`
|
|
47
|
-
* for where these are defined. These shouldn't change very often as the direction is `xcss` over individual props.
|
|
48
|
-
*/
|
|
49
|
-
type IgnoredPrimitiveProps =
|
|
50
|
-
| 'style'
|
|
51
|
-
| 'xcss'
|
|
52
|
-
| 'backgroundColor'
|
|
53
|
-
| 'padding'
|
|
54
|
-
| 'paddingBlock'
|
|
55
|
-
| 'paddingBlockStart'
|
|
56
|
-
| 'paddingBlockEnd'
|
|
57
|
-
| 'paddingInline'
|
|
58
|
-
| 'paddingInlineStart'
|
|
59
|
-
| 'paddingInlineEnd';
|
|
60
|
-
|
|
61
|
-
/**
|
|
62
|
-
* Returns the spread props to pass through to underlying primitive components.
|
|
63
|
-
*
|
|
64
|
-
* It removes the props which apply styles.
|
|
65
|
-
*/
|
|
66
|
-
function getPrimitiveSpreadProps<Props extends Record<string, unknown>>({
|
|
67
|
-
style,
|
|
68
|
-
xcss,
|
|
69
|
-
backgroundColor,
|
|
70
|
-
padding,
|
|
71
|
-
paddingBlock,
|
|
72
|
-
paddingBlockStart,
|
|
73
|
-
paddingBlockEnd,
|
|
74
|
-
paddingInline,
|
|
75
|
-
paddingInlineStart,
|
|
76
|
-
paddingInlineEnd,
|
|
77
|
-
...props
|
|
78
|
-
}: Props): Omit<Props, IgnoredPrimitiveProps> {
|
|
79
|
-
return props;
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
/**
|
|
83
|
-
* Props present in underlying primitives but we want to override,
|
|
84
|
-
* so we don't want to inherit their definitions
|
|
85
|
-
*/
|
|
86
|
-
type OverridenPrimitiveProps = 'aria-label' | 'children' | IgnoredPrimitiveProps;
|
|
87
|
-
|
|
88
|
-
/**
|
|
89
|
-
* Props that are common between link buttons.
|
|
90
|
-
*/
|
|
91
|
-
interface LinkVariantCommonProps<RouterLinkConfig extends Record<string, any> = never>
|
|
92
|
-
extends CommonProps,
|
|
93
|
-
Omit<AnchorProps<RouterLinkConfig>, OverridenPrimitiveProps> {}
|
|
94
|
-
|
|
95
|
-
/**
|
|
96
|
-
* Props shared by `Button` and `IconButton`
|
|
97
|
-
*/
|
|
98
|
-
interface ActionVariantCommonProps
|
|
99
|
-
extends CommonProps,
|
|
100
|
-
Omit<PressableProps, OverridenPrimitiveProps> {}
|
|
101
|
-
|
|
102
|
-
export const themedButtonBackground = '--ds-top-bar-button-background';
|
|
103
|
-
export const themedButtonBackgroundHovered = '--ds-top-bar-button-background-hovered';
|
|
104
|
-
export const themedButtonBackgroundPressed = '--ds-top-bar-button-background-pressed';
|
|
105
|
-
export const themedButtonBorder = '--ds-top-bar-button-border';
|
|
106
|
-
|
|
107
|
-
export const themedButtonPrimaryText = '--ds-top-bar-button-primary-text';
|
|
108
|
-
export const themedButtonPrimaryBackground = '--ds-top-bar-button-primary-background';
|
|
109
|
-
export const themedButtonPrimaryBackgroundHovered =
|
|
110
|
-
'--ds-top-bar-button-primary-background-hovered';
|
|
111
|
-
export const themedButtonPrimaryBackgroundPressed =
|
|
112
|
-
'--ds-top-bar-button-primary-background-pressed';
|
|
113
|
-
|
|
114
|
-
export const themedButtonSelectedText = '--ds-top-bar-button-selected-text';
|
|
115
|
-
export const themedButtonSelectedBackground = '--ds-top-bar-button-selected-background';
|
|
116
|
-
export const themedButtonSelectedBackgroundHovered =
|
|
117
|
-
'--ds-top-bar-button-selected-background-hovered';
|
|
118
|
-
export const themedButtonSelectedBackgroundPressed =
|
|
119
|
-
'--ds-top-bar-button-selected-background-pressed';
|
|
120
|
-
export const themedButtonSelectedBorder = '--ds-top-bar-button-selected-border';
|
|
121
|
-
|
|
122
|
-
export const themedButtonDisabledText = '--ds-top-bar-button-disabled-text';
|
|
123
|
-
export const themedButtonDisabledBackground = '--ds-top-bar-button-disabled-background';
|
|
124
|
-
|
|
125
|
-
const styles = cssMap({
|
|
126
|
-
root: {
|
|
127
|
-
display: 'flex',
|
|
128
|
-
gap: token('space.075'),
|
|
129
|
-
alignItems: 'center',
|
|
130
|
-
justifyContent: 'center',
|
|
131
|
-
font: token('font.body'),
|
|
132
|
-
height: '2.2857142857142856em',
|
|
133
|
-
paddingBlock: token('space.0'),
|
|
134
|
-
borderRadius: token('border.radius.100', '3px'),
|
|
135
|
-
transition: 'background 0.1s ease-out',
|
|
136
|
-
position: 'relative',
|
|
137
|
-
// Remove the default underline for link buttons
|
|
138
|
-
textDecoration: 'none',
|
|
139
|
-
'&:hover, &:active, &:focus': {
|
|
140
|
-
textDecoration: 'none',
|
|
141
|
-
},
|
|
142
|
-
},
|
|
143
|
-
border: {
|
|
144
|
-
'&::after': {
|
|
145
|
-
content: '""',
|
|
146
|
-
borderRadius: 'inherit',
|
|
147
|
-
borderStyle: 'solid',
|
|
148
|
-
borderWidth: token('border.width'),
|
|
149
|
-
position: 'absolute',
|
|
150
|
-
inset: token('space.0'),
|
|
151
|
-
},
|
|
152
|
-
},
|
|
153
|
-
selected: {
|
|
154
|
-
color: `var(${themedButtonSelectedText})`,
|
|
155
|
-
background: `var(${themedButtonSelectedBackground})`,
|
|
156
|
-
'&:hover': {
|
|
157
|
-
color: `var(${themedButtonSelectedText})`,
|
|
158
|
-
background: `var(${themedButtonSelectedBackgroundHovered})`,
|
|
159
|
-
},
|
|
160
|
-
'&:active': {
|
|
161
|
-
color: `var(${themedButtonSelectedText})`,
|
|
162
|
-
background: `var(${themedButtonSelectedBackgroundPressed})`,
|
|
163
|
-
},
|
|
164
|
-
'&:visited, &:focus': {
|
|
165
|
-
color: `var(${themedButtonSelectedText})`,
|
|
166
|
-
},
|
|
167
|
-
'&::after': {
|
|
168
|
-
borderColor: `var(${themedButtonSelectedBorder})`,
|
|
169
|
-
},
|
|
170
|
-
},
|
|
171
|
-
disabled: {
|
|
172
|
-
color: `var(${themedButtonDisabledText})`,
|
|
173
|
-
background: `var(${themedButtonDisabledBackground})`,
|
|
174
|
-
'&:hover': {
|
|
175
|
-
color: `var(${themedButtonDisabledText})`,
|
|
176
|
-
background: `var(${themedButtonDisabledBackground})`,
|
|
177
|
-
},
|
|
178
|
-
'&:active': {
|
|
179
|
-
color: `var(${themedButtonDisabledText})`,
|
|
180
|
-
background: `var(${themedButtonDisabledBackground})`,
|
|
181
|
-
},
|
|
182
|
-
'&:visited, &:focus': {
|
|
183
|
-
color: `var(${themedButtonDisabledText})`,
|
|
184
|
-
},
|
|
185
|
-
'&::after': {
|
|
186
|
-
borderColor: 'transparent',
|
|
187
|
-
},
|
|
188
|
-
},
|
|
189
|
-
});
|
|
190
|
-
|
|
191
|
-
const shapeStyles = cssMap({
|
|
192
|
-
/**
|
|
193
|
-
* The regular rectangular button shape
|
|
194
|
-
*/
|
|
195
|
-
default: {
|
|
196
|
-
paddingInline: token('space.150'),
|
|
197
|
-
},
|
|
198
|
-
/**
|
|
199
|
-
* A square button shape, used for icon buttons
|
|
200
|
-
*/
|
|
201
|
-
square: {
|
|
202
|
-
width: '2.2857142857142856em',
|
|
203
|
-
paddingInline: token('space.0'),
|
|
204
|
-
// eslint-disable-next-line @atlaskit/design-system/use-tokens-typography
|
|
205
|
-
lineHeight: 0,
|
|
206
|
-
},
|
|
207
|
-
});
|
|
208
|
-
|
|
209
|
-
const appearanceStyles = cssMap({
|
|
210
|
-
default: {
|
|
211
|
-
color: 'currentColor',
|
|
212
|
-
background: `var(${themedButtonBackground})`,
|
|
213
|
-
'&:hover': {
|
|
214
|
-
color: 'currentColor',
|
|
215
|
-
background: `var(${themedButtonBackgroundHovered})`,
|
|
216
|
-
},
|
|
217
|
-
'&:active': {
|
|
218
|
-
color: 'currentColor',
|
|
219
|
-
background: `var(${themedButtonBackgroundPressed})`,
|
|
220
|
-
},
|
|
221
|
-
'&:visited, &:focus': {
|
|
222
|
-
color: 'currentColor',
|
|
223
|
-
},
|
|
224
|
-
'&::after': {
|
|
225
|
-
borderColor: `var(${themedButtonBorder})`,
|
|
226
|
-
},
|
|
227
|
-
},
|
|
228
|
-
subtle: {
|
|
229
|
-
color: 'currentColor',
|
|
230
|
-
background: `var(${themedButtonBackground})`,
|
|
231
|
-
'&:hover': {
|
|
232
|
-
color: 'currentColor',
|
|
233
|
-
background: `var(${themedButtonBackgroundHovered})`,
|
|
234
|
-
},
|
|
235
|
-
'&:active': {
|
|
236
|
-
color: 'currentColor',
|
|
237
|
-
background: `var(${themedButtonBackgroundPressed})`,
|
|
238
|
-
},
|
|
239
|
-
'&:visited, &:focus': {
|
|
240
|
-
color: 'currentColor',
|
|
241
|
-
},
|
|
242
|
-
},
|
|
243
|
-
primary: {
|
|
244
|
-
color: `var(${themedButtonPrimaryText})`,
|
|
245
|
-
background: `var(${themedButtonPrimaryBackground})`,
|
|
246
|
-
'&:hover': {
|
|
247
|
-
color: `var(${themedButtonPrimaryText})`,
|
|
248
|
-
background: `var(${themedButtonPrimaryBackgroundHovered})`,
|
|
249
|
-
},
|
|
250
|
-
'&:active': {
|
|
251
|
-
color: `var(${themedButtonPrimaryText})`,
|
|
252
|
-
background: `var(${themedButtonPrimaryBackgroundPressed})`,
|
|
253
|
-
},
|
|
254
|
-
'&:visited, &:focus': {
|
|
255
|
-
color: `var(${themedButtonPrimaryText})`,
|
|
256
|
-
},
|
|
257
|
-
},
|
|
258
|
-
});
|
|
259
|
-
|
|
260
|
-
/**
|
|
261
|
-
* Props shared by `ThemedPressable` and `ThemedAnchor`
|
|
262
|
-
*/
|
|
263
|
-
interface ThemedPrimitiveProps {
|
|
264
|
-
shape?: 'default' | 'square';
|
|
265
|
-
children: React.ReactNode;
|
|
266
|
-
}
|
|
267
|
-
|
|
268
|
-
interface ThemedPressableProps extends ThemedPrimitiveProps, ActionVariantCommonProps {}
|
|
269
|
-
|
|
270
|
-
/**
|
|
271
|
-
* Intentionally an almost-duplicate of `ThemedAnchor` - make sure to update both.
|
|
272
|
-
*
|
|
273
|
-
* See `ThemedAnchor` for more context.
|
|
274
|
-
*/
|
|
275
|
-
const ThemedPressable = forwardRef<HTMLButtonElement, ThemedPressableProps>(
|
|
276
|
-
function ThemedPressable(
|
|
277
|
-
{ appearance = 'default', shape = 'default', isSelected, isDisabled, ...props },
|
|
278
|
-
ref,
|
|
279
|
-
) {
|
|
280
|
-
const hasBorder = appearance === 'default' || isSelected;
|
|
281
|
-
return (
|
|
282
|
-
<Pressable
|
|
283
|
-
{...getPrimitiveSpreadProps(props)}
|
|
284
|
-
ref={ref}
|
|
285
|
-
type="button"
|
|
286
|
-
/**
|
|
287
|
-
* We are using some style values that are outside of the strict
|
|
288
|
-
* `@atlaskit/css` types.
|
|
289
|
-
*/
|
|
290
|
-
// @ts-expect-error
|
|
291
|
-
// eslint-disable-next-line @compiled/no-suppress-xcss
|
|
292
|
-
xcss={cx(
|
|
293
|
-
styles.root,
|
|
294
|
-
shapeStyles[shape],
|
|
295
|
-
hasBorder && styles.border,
|
|
296
|
-
appearanceStyles[appearance],
|
|
297
|
-
isSelected && styles.selected,
|
|
298
|
-
isDisabled && styles.disabled,
|
|
299
|
-
)}
|
|
300
|
-
isDisabled={isDisabled}
|
|
301
|
-
/>
|
|
302
|
-
);
|
|
303
|
-
},
|
|
304
|
-
);
|
|
305
|
-
|
|
306
|
-
interface ThemedAnchorProps<RouterLinkConfig extends Record<string, any> = never>
|
|
307
|
-
extends ThemedPrimitiveProps,
|
|
308
|
-
LinkVariantCommonProps<RouterLinkConfig> {}
|
|
309
|
-
|
|
310
|
-
/**
|
|
311
|
-
* Intentionally an almost-duplicate of `ThemedPressable` - make sure to update both.
|
|
312
|
-
*
|
|
313
|
-
* More 'clever' solutions were tried but I couldn't get them working in an acceptable state.
|
|
314
|
-
*
|
|
315
|
-
* Polymorphism had many typing issues and required sacrificing type safety.
|
|
316
|
-
*
|
|
317
|
-
* Render props had problems passing down styles through `xcss` to the `children` function.
|
|
318
|
-
*/
|
|
319
|
-
const ThemedAnchor = forwardRefWithGeneric(function ThemedAnchor<
|
|
320
|
-
RouterLinkConfig extends Record<string, any> = never,
|
|
321
|
-
>(
|
|
322
|
-
{
|
|
323
|
-
appearance = 'default',
|
|
324
|
-
shape = 'default',
|
|
325
|
-
isSelected,
|
|
326
|
-
isDisabled,
|
|
327
|
-
...props
|
|
328
|
-
}: ThemedAnchorProps<RouterLinkConfig>,
|
|
329
|
-
ref: React.Ref<HTMLAnchorElement>,
|
|
330
|
-
) {
|
|
331
|
-
const hasBorder = appearance === 'default' || isSelected;
|
|
332
|
-
|
|
333
|
-
return (
|
|
334
|
-
<Anchor
|
|
335
|
-
{...getPrimitiveSpreadProps(props)}
|
|
336
|
-
ref={ref}
|
|
337
|
-
/**
|
|
338
|
-
* We are using some style values that are outside of the strict
|
|
339
|
-
* `@atlaskit/css` types.
|
|
340
|
-
*/
|
|
341
|
-
// @ts-expect-error
|
|
342
|
-
// eslint-disable-next-line @compiled/no-suppress-xcss
|
|
343
|
-
xcss={cx(
|
|
344
|
-
styles.root,
|
|
345
|
-
shapeStyles[shape],
|
|
346
|
-
hasBorder && styles.border,
|
|
347
|
-
appearanceStyles[appearance],
|
|
348
|
-
isSelected && styles.selected,
|
|
349
|
-
isDisabled && styles.disabled,
|
|
350
|
-
)}
|
|
351
|
-
/>
|
|
352
|
-
);
|
|
353
|
-
});
|
|
354
|
-
|
|
355
|
-
const textButtonStyles = cssMap({
|
|
356
|
-
iconBefore: {
|
|
357
|
-
// eslint-disable-next-line @atlaskit/design-system/use-tokens-typography
|
|
358
|
-
lineHeight: 0,
|
|
359
|
-
},
|
|
360
|
-
text: {
|
|
361
|
-
fontWeight: token('font.weight.medium'),
|
|
362
|
-
},
|
|
363
|
-
});
|
|
364
|
-
|
|
365
|
-
/**
|
|
366
|
-
* Props shared by `Button` and `LinkButton`
|
|
367
|
-
*/
|
|
368
|
-
interface TextButtonCommonProps {
|
|
369
|
-
/**
|
|
370
|
-
* Places an icon within the button, before the button's text.
|
|
371
|
-
*/
|
|
372
|
-
iconBefore?: IconButtonProps['icon'];
|
|
373
|
-
/**
|
|
374
|
-
* Text content to be rendered in the button.
|
|
375
|
-
*/
|
|
376
|
-
children: React.ReactNode;
|
|
377
|
-
}
|
|
378
|
-
|
|
379
|
-
export interface ThemedButtonProps extends ActionVariantCommonProps, TextButtonCommonProps {}
|
|
380
|
-
|
|
381
|
-
/**
|
|
382
|
-
* __Themed button__
|
|
383
|
-
*
|
|
384
|
-
* A themed button for the top bar.
|
|
385
|
-
*/
|
|
386
|
-
export const ThemedButton = forwardRef<HTMLButtonElement, ThemedButtonProps>(function ThemedButton(
|
|
387
|
-
{ iconBefore: IconBefore, children, ...props },
|
|
388
|
-
ref,
|
|
389
|
-
) {
|
|
390
|
-
return (
|
|
391
|
-
<ThemedPressable {...props} ref={ref}>
|
|
392
|
-
{IconBefore && (
|
|
393
|
-
<span css={textButtonStyles.iconBefore}>
|
|
394
|
-
<IconBefore label="" color="currentColor" />
|
|
395
|
-
</span>
|
|
396
|
-
)}
|
|
397
|
-
<span css={textButtonStyles.text}>{children}</span>
|
|
398
|
-
</ThemedPressable>
|
|
399
|
-
);
|
|
400
|
-
});
|
|
401
|
-
|
|
402
|
-
export interface ThemedLinkButtonProps<RouterLinkConfig extends Record<string, any> = never>
|
|
403
|
-
extends LinkVariantCommonProps<RouterLinkConfig>,
|
|
404
|
-
TextButtonCommonProps {}
|
|
405
|
-
|
|
406
|
-
/**
|
|
407
|
-
* __Themed link button__
|
|
408
|
-
*
|
|
409
|
-
* A themed link button for the top bar.
|
|
410
|
-
*/
|
|
411
|
-
export const ThemedLinkButton = forwardRefWithGeneric(function ThemedLinkButton<
|
|
412
|
-
RouterLinkConfig extends Record<string, any> = never,
|
|
413
|
-
>(
|
|
414
|
-
{ iconBefore: IconBefore, children, ...props }: ThemedLinkButtonProps<RouterLinkConfig>,
|
|
415
|
-
ref: React.Ref<HTMLAnchorElement>,
|
|
416
|
-
) {
|
|
417
|
-
return (
|
|
418
|
-
<ThemedAnchor {...props} ref={ref}>
|
|
419
|
-
{IconBefore && (
|
|
420
|
-
<span css={textButtonStyles.iconBefore}>
|
|
421
|
-
<IconBefore label="" color="currentColor" />
|
|
422
|
-
</span>
|
|
423
|
-
)}
|
|
424
|
-
<span css={textButtonStyles.text}>{children}</span>
|
|
425
|
-
</ThemedAnchor>
|
|
426
|
-
);
|
|
427
|
-
});
|
|
428
|
-
|
|
429
|
-
/**
|
|
430
|
-
* Props shared by `ThemedIconButtonProps` and `ThemedLinkIconButton`
|
|
431
|
-
*/
|
|
432
|
-
interface IconButtonCommonProps {
|
|
433
|
-
// Icon button doesn't support children
|
|
434
|
-
children?: never;
|
|
435
|
-
// Prevent duplicate labels being added.
|
|
436
|
-
'aria-label'?: never;
|
|
437
|
-
/**
|
|
438
|
-
* Provide an accessible label, often used by screen readers.
|
|
439
|
-
*/
|
|
440
|
-
label: React.ReactNode;
|
|
441
|
-
/**
|
|
442
|
-
* Places an icon within the button.
|
|
443
|
-
*/
|
|
444
|
-
icon: IconButtonProps['icon'];
|
|
445
|
-
/**
|
|
446
|
-
* Props passed down to the Tooltip component.
|
|
447
|
-
*/
|
|
448
|
-
tooltip?: IconButtonProps['tooltip'];
|
|
449
|
-
}
|
|
450
|
-
|
|
451
|
-
export interface ThemedIconButtonProps extends ActionVariantCommonProps, IconButtonCommonProps {}
|
|
452
|
-
|
|
453
|
-
/**
|
|
454
|
-
* __Themed icon button__
|
|
455
|
-
*
|
|
456
|
-
* A themed icon button for the top bar.
|
|
457
|
-
*/
|
|
458
|
-
export const ThemedIconButton = forwardRef<HTMLButtonElement, ThemedIconButtonProps>(
|
|
459
|
-
function ThemedIconButton({ icon: Icon, label, tooltip, ...props }, ref) {
|
|
460
|
-
return (
|
|
461
|
-
<Tooltip {...tooltip} content={tooltip?.content ?? label}>
|
|
462
|
-
{(triggerProps) => (
|
|
463
|
-
/**
|
|
464
|
-
* The `aria-describedby` from `triggerProps` is intentionally not passed down,
|
|
465
|
-
* because it would cause double announcements with the `VisuallyHidden` label.
|
|
466
|
-
*
|
|
467
|
-
* The `@atlaskit/button` IconButton uses the same approach.
|
|
468
|
-
*/
|
|
469
|
-
<ThemedPressable
|
|
470
|
-
{...props}
|
|
471
|
-
shape="square"
|
|
472
|
-
ref={mergeRefs([ref, triggerProps.ref])}
|
|
473
|
-
onClick={(event, analyticsEvent) => {
|
|
474
|
-
props.onClick?.(event, analyticsEvent);
|
|
475
|
-
triggerProps?.onClick?.(event);
|
|
476
|
-
}}
|
|
477
|
-
onMouseOver={(e) => {
|
|
478
|
-
triggerProps.onMouseOver?.(e);
|
|
479
|
-
props.onMouseOver?.(e);
|
|
480
|
-
}}
|
|
481
|
-
onMouseOut={(e) => {
|
|
482
|
-
triggerProps.onMouseOut?.(e);
|
|
483
|
-
props.onMouseOut?.(e);
|
|
484
|
-
}}
|
|
485
|
-
onMouseMove={(e) => {
|
|
486
|
-
triggerProps.onMouseMove?.(e);
|
|
487
|
-
props.onMouseMove?.(e);
|
|
488
|
-
}}
|
|
489
|
-
onMouseDown={(e) => {
|
|
490
|
-
triggerProps.onMouseDown?.(e);
|
|
491
|
-
props.onMouseDown?.(e);
|
|
492
|
-
}}
|
|
493
|
-
onFocus={(e) => {
|
|
494
|
-
triggerProps.onFocus?.(e);
|
|
495
|
-
props.onFocus?.(e);
|
|
496
|
-
}}
|
|
497
|
-
onBlur={(e) => {
|
|
498
|
-
triggerProps.onBlur?.(e);
|
|
499
|
-
props.onBlur?.(e);
|
|
500
|
-
}}
|
|
501
|
-
>
|
|
502
|
-
<Icon label="" color="currentColor" />
|
|
503
|
-
<VisuallyHidden>{label}</VisuallyHidden>
|
|
504
|
-
</ThemedPressable>
|
|
505
|
-
)}
|
|
506
|
-
</Tooltip>
|
|
507
|
-
);
|
|
508
|
-
},
|
|
509
|
-
);
|
|
510
|
-
|
|
511
|
-
export interface ThemedLinkIconButtonProps<RouterLinkConfig extends Record<string, any> = never>
|
|
512
|
-
extends LinkVariantCommonProps<RouterLinkConfig>,
|
|
513
|
-
IconButtonCommonProps {
|
|
514
|
-
href: string | RouterLinkConfig;
|
|
515
|
-
}
|
|
516
|
-
|
|
517
|
-
/**
|
|
518
|
-
* __Themed link icon button__
|
|
519
|
-
*
|
|
520
|
-
* A themed link icon button for the top bar.
|
|
521
|
-
*/
|
|
522
|
-
export const ThemedLinkIconButton = forwardRefWithGeneric(function ThemedLinkIconButton<
|
|
523
|
-
RouterLinkConfig extends Record<string, any> = never,
|
|
524
|
-
>(
|
|
525
|
-
{ icon: Icon, label, tooltip, ...props }: ThemedLinkIconButtonProps<RouterLinkConfig>,
|
|
526
|
-
ref: React.Ref<HTMLAnchorElement>,
|
|
527
|
-
) {
|
|
528
|
-
return (
|
|
529
|
-
<Tooltip {...tooltip} content={tooltip?.content ?? label}>
|
|
530
|
-
{(triggerProps) => (
|
|
531
|
-
/**
|
|
532
|
-
* The `aria-describedby` from `triggerProps` is intentionally not passed down,
|
|
533
|
-
* because it would cause double announcements with the `VisuallyHidden` label.
|
|
534
|
-
*
|
|
535
|
-
* The `@atlaskit/button` IconButton uses the same approach.
|
|
536
|
-
*/
|
|
537
|
-
<ThemedAnchor<RouterLinkConfig>
|
|
538
|
-
{...props}
|
|
539
|
-
shape="square"
|
|
540
|
-
ref={mergeRefs([ref, triggerProps.ref])}
|
|
541
|
-
onClick={(event, analyticsEvent) => {
|
|
542
|
-
props.onClick?.(event, analyticsEvent);
|
|
543
|
-
triggerProps?.onClick?.(event);
|
|
544
|
-
}}
|
|
545
|
-
onMouseOver={(e) => {
|
|
546
|
-
triggerProps.onMouseOver?.(e);
|
|
547
|
-
props.onMouseOver?.(e);
|
|
548
|
-
}}
|
|
549
|
-
onMouseOut={(e) => {
|
|
550
|
-
triggerProps.onMouseOut?.(e);
|
|
551
|
-
props.onMouseOut?.(e);
|
|
552
|
-
}}
|
|
553
|
-
onMouseMove={(e) => {
|
|
554
|
-
triggerProps.onMouseMove?.(e);
|
|
555
|
-
props.onMouseMove?.(e);
|
|
556
|
-
}}
|
|
557
|
-
onMouseDown={(e) => {
|
|
558
|
-
triggerProps.onMouseDown?.(e);
|
|
559
|
-
props.onMouseDown?.(e);
|
|
560
|
-
}}
|
|
561
|
-
onFocus={(e) => {
|
|
562
|
-
triggerProps.onFocus?.(e);
|
|
563
|
-
props.onFocus?.(e);
|
|
564
|
-
}}
|
|
565
|
-
onBlur={(e) => {
|
|
566
|
-
triggerProps.onBlur?.(e);
|
|
567
|
-
props.onBlur?.(e);
|
|
568
|
-
}}
|
|
569
|
-
>
|
|
570
|
-
<Icon label="" color="currentColor" />
|
|
571
|
-
<VisuallyHidden>{label}</VisuallyHidden>
|
|
572
|
-
</ThemedAnchor>
|
|
573
|
-
)}
|
|
574
|
-
</Tooltip>
|
|
575
|
-
);
|
|
576
|
-
});
|
|
@@ -1,131 +0,0 @@
|
|
|
1
|
-
import { parseHex } from '../../formats/hex';
|
|
2
|
-
|
|
3
|
-
describe('parseHex()', () => {
|
|
4
|
-
const consoleError = jest.spyOn(console, 'error');
|
|
5
|
-
beforeEach(() => {
|
|
6
|
-
// Intention of this is to avoid suppressing an unexpected console error
|
|
7
|
-
consoleError.mockReset();
|
|
8
|
-
});
|
|
9
|
-
|
|
10
|
-
describe('invalid input', () => {
|
|
11
|
-
beforeEach(() => {
|
|
12
|
-
consoleError.mockImplementation(() => {});
|
|
13
|
-
});
|
|
14
|
-
|
|
15
|
-
const { NODE_ENV } = process.env;
|
|
16
|
-
|
|
17
|
-
it('should log an error in development environments', () => {
|
|
18
|
-
process.env.NODE_ENV = 'development';
|
|
19
|
-
|
|
20
|
-
parseHex('a#123');
|
|
21
|
-
|
|
22
|
-
expect(consoleError).toHaveBeenCalledTimes(1);
|
|
23
|
-
expect(consoleError.mock.lastCall).toMatchInlineSnapshot(`
|
|
24
|
-
[
|
|
25
|
-
"parseHex failed to parse input: 'a#123'",
|
|
26
|
-
]
|
|
27
|
-
`);
|
|
28
|
-
|
|
29
|
-
process.env.NODE_ENV = NODE_ENV;
|
|
30
|
-
});
|
|
31
|
-
|
|
32
|
-
it('should not log an error in prod environments', () => {
|
|
33
|
-
process.env.NODE_ENV = 'production';
|
|
34
|
-
|
|
35
|
-
parseHex('a#123');
|
|
36
|
-
|
|
37
|
-
expect(consoleError).not.toHaveBeenCalled();
|
|
38
|
-
|
|
39
|
-
process.env.NODE_ENV = NODE_ENV;
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
describe('should return null', () => {
|
|
43
|
-
test.each([
|
|
44
|
-
{ value: '#12', description: 'invalid length (2 characters)' },
|
|
45
|
-
{ value: '#12345', description: 'invalid length (5 characters)' },
|
|
46
|
-
{ value: '#1234567', description: 'invalid length (7 characters)' },
|
|
47
|
-
{ value: '#123456789', description: 'invalid length (9 characters)' },
|
|
48
|
-
{ value: 'a#123', description: 'invalid character at start' },
|
|
49
|
-
{ value: '#123g', description: 'invalid character at end' },
|
|
50
|
-
])('$description', ({ value }) => {
|
|
51
|
-
expect(parseHex(value)).toBeNull();
|
|
52
|
-
});
|
|
53
|
-
});
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
/**
|
|
57
|
-
* For clarity, the tests below have been written with both:
|
|
58
|
-
*
|
|
59
|
-
* - hex literals
|
|
60
|
-
* - decimal literals
|
|
61
|
-
*
|
|
62
|
-
* The hex literals explicitly show how the parsing works,
|
|
63
|
-
* and provide a free level of assurance our test is correct.
|
|
64
|
-
* The hex literal values can be quickly derived from the input string.
|
|
65
|
-
*
|
|
66
|
-
* The decimal literals provide clarity on what numbers the
|
|
67
|
-
* hex literals actually correspond to.
|
|
68
|
-
*/
|
|
69
|
-
|
|
70
|
-
it('should parse a hex value with 3 digits', () => {
|
|
71
|
-
// Each hex digit 'X' is treated as 'XX' for the shorthand syntax
|
|
72
|
-
const result = parseHex('#A24');
|
|
73
|
-
expect(result).toEqual({
|
|
74
|
-
r: 0xaa, // The first hex digit in the input string, but twice
|
|
75
|
-
g: 0x22, // The second hex digit in the input string, but twice
|
|
76
|
-
b: 0x44, // The third hex digit in the input string, but twice
|
|
77
|
-
});
|
|
78
|
-
expect(result).toEqual({
|
|
79
|
-
r: 170,
|
|
80
|
-
g: 34,
|
|
81
|
-
b: 68,
|
|
82
|
-
});
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
it('should parse a hex value with 4 digits', () => {
|
|
86
|
-
// Each hex digit 'X' is treated as 'XX' for the shorthand syntax
|
|
87
|
-
// The alpha channel ('E') will be ignored
|
|
88
|
-
const result = parseHex('#fAcE');
|
|
89
|
-
expect(result).toEqual({
|
|
90
|
-
r: 0xff, // The first hex digit in the input string, but twice
|
|
91
|
-
g: 0xaa, // The second hex digit in the input string, but twice
|
|
92
|
-
b: 0xcc, // The third hex digit in the input string, but twice
|
|
93
|
-
});
|
|
94
|
-
expect(result).toEqual({
|
|
95
|
-
r: 255,
|
|
96
|
-
g: 170,
|
|
97
|
-
b: 204,
|
|
98
|
-
});
|
|
99
|
-
});
|
|
100
|
-
|
|
101
|
-
it('should parse a hex value with 6 digits', () => {
|
|
102
|
-
// Each pair of two hex digits corresponds to a full channel value for the longhand syntax
|
|
103
|
-
const result = parseHex('#123456');
|
|
104
|
-
expect(result).toEqual({
|
|
105
|
-
r: 0x12, // The first pair of hex digits in the input string
|
|
106
|
-
g: 0x34, // The second pair of hex digits in the input string
|
|
107
|
-
b: 0x56, // The third pair of hex digits in the input string
|
|
108
|
-
});
|
|
109
|
-
expect(result).toEqual({
|
|
110
|
-
r: 18,
|
|
111
|
-
g: 52,
|
|
112
|
-
b: 86,
|
|
113
|
-
});
|
|
114
|
-
});
|
|
115
|
-
|
|
116
|
-
it('should parse a hex value with 8 digits', () => {
|
|
117
|
-
// Each two hex digits corresponds to a full channel value for the longhand syntax
|
|
118
|
-
// The alpha channel ('1A') will be ignored
|
|
119
|
-
const result = parseHex('#F0CACC1A');
|
|
120
|
-
expect(result).toEqual({
|
|
121
|
-
r: 0xf0, // The first pair of hex digits in the input string
|
|
122
|
-
g: 0xca, // The second pair of hex digits in the input string
|
|
123
|
-
b: 0xcc, // The third pair of hex digits in the input string
|
|
124
|
-
});
|
|
125
|
-
expect(result).toEqual({
|
|
126
|
-
r: 240,
|
|
127
|
-
g: 202,
|
|
128
|
-
b: 204,
|
|
129
|
-
});
|
|
130
|
-
});
|
|
131
|
-
});
|