@primer/components 29.1.0-rc.79e8b21e → 29.1.0
Sign up to get free protection for your applications and to get access to all the features.
- package/package.json +1 -1
- package/.changeset/README.md +0 -8
- package/.changeset/config.json +0 -10
- package/.devcontainer/devcontainer.json +0 -8
- package/.eslintrc.json +0 -106
- package/.github/ISSUE_TEMPLATE/bug_report.md +0 -38
- package/.github/ISSUE_TEMPLATE/new_component_proposal_template.md +0 -41
- package/.github/dependabot.yml +0 -18
- package/.github/pull_request_template.md +0 -18
- package/.github/workflows/ci.yml +0 -31
- package/.github/workflows/deploy_preview.yml +0 -47
- package/.github/workflows/deploy_production.yml +0 -70
- package/.github/workflows/release.yml +0 -35
- package/.github/workflows/release_canary.yml +0 -70
- package/.github/workflows/release_candidate.yml +0 -60
- package/.github/workflows/size.yml +0 -13
- package/.github/workflows/stale.yml +0 -26
- package/.gitignore +0 -10
- package/.npmrc +0 -4
- package/.nvmrc +0 -1
- package/.storybook/main.js +0 -11
- package/.storybook/preview.js +0 -11
- package/.vscode/launch.json +0 -21
- package/.vscode/settings.json +0 -13
- package/@types/@styled-system/index.d.ts +0 -0
- package/@types/@styled-system/prop-types/index.d.ts +0 -1
- package/@types/@styled-system/props/index.d.ts +0 -1
- package/@types/jest-styled-components/index.d.ts +0 -1
- package/CODEOWNERS +0 -2
- package/babel-defines.js +0 -13
- package/babel.config.js +0 -39
- package/contributor-docs/CODE_OF_CONDUCT.md +0 -76
- package/contributor-docs/CONTRIBUTING.md +0 -274
- package/contributor-docs/adrs/adr-001-typescript.md +0 -23
- package/contributor-docs/adrs/adr-002-behavior-isolation.md +0 -106
- package/contributor-docs/behaviors.md +0 -132
- package/contributor-docs/component-contents-api-patterns.md +0 -315
- package/contributor-docs/principles.md +0 -39
- package/docs/.eslintrc +0 -0
- package/docs/.gitignore +0 -91
- package/docs/components/PropsList.js +0 -5
- package/docs/components/State.js +0 -9
- package/docs/components/constants.js +0 -34
- package/docs/components/index.js +0 -2
- package/docs/content/ActionList.mdx +0 -72
- package/docs/content/ActionMenu.mdx +0 -80
- package/docs/content/AnchoredOverlay.mdx +0 -37
- package/docs/content/Avatar.mdx +0 -33
- package/docs/content/AvatarStack.mdx +0 -43
- package/docs/content/BorderBox.md +0 -46
- package/docs/content/Box.md +0 -74
- package/docs/content/BranchName.md +0 -18
- package/docs/content/Breadcrumbs.md +0 -52
- package/docs/content/Buttons.md +0 -54
- package/docs/content/CircleBadge.md +0 -45
- package/docs/content/CircleOcticon.md +0 -18
- package/docs/content/CounterLabel.md +0 -30
- package/docs/content/Details.md +0 -105
- package/docs/content/Dialog.md +0 -108
- package/docs/content/Dialog2.mdx +0 -179
- package/docs/content/Dropdown.md +0 -72
- package/docs/content/DropdownMenu.mdx +0 -49
- package/docs/content/FilterList.md +0 -44
- package/docs/content/FilteredSearch.md +0 -39
- package/docs/content/Flash.md +0 -42
- package/docs/content/Flex.md +0 -58
- package/docs/content/FormGroup.md +0 -44
- package/docs/content/Grid.md +0 -59
- package/docs/content/Header.md +0 -79
- package/docs/content/Heading.md +0 -22
- package/docs/content/Label.md +0 -40
- package/docs/content/LabelGroup.md +0 -31
- package/docs/content/Link.md +0 -37
- package/docs/content/Overlay.mdx +0 -94
- package/docs/content/Pagehead.md +0 -27
- package/docs/content/Pagination.md +0 -187
- package/docs/content/PointerBox.md +0 -81
- package/docs/content/Popover.md +0 -137
- package/docs/content/Portal.mdx +0 -73
- package/docs/content/Position.md +0 -97
- package/docs/content/ProgressBar.mdx +0 -29
- package/docs/content/SelectMenu.md +0 -433
- package/docs/content/SelectPanel.mdx +0 -67
- package/docs/content/SideNav.md +0 -179
- package/docs/content/Spinner.mdx +0 -32
- package/docs/content/StateLabel.md +0 -33
- package/docs/content/StyledOcticon.md +0 -34
- package/docs/content/SubNav.md +0 -102
- package/docs/content/TabNav.md +0 -50
- package/docs/content/Text.md +0 -29
- package/docs/content/TextInput.md +0 -32
- package/docs/content/Timeline.md +0 -138
- package/docs/content/Tooltip.md +0 -41
- package/docs/content/Truncate.md +0 -65
- package/docs/content/UnderlineNav.md +0 -53
- package/docs/content/anchoredPosition.mdx +0 -163
- package/docs/content/core-concepts.md +0 -70
- package/docs/content/focusTrap.mdx +0 -103
- package/docs/content/focusZone.mdx +0 -145
- package/docs/content/getting-started.md +0 -134
- package/docs/content/index.md +0 -33
- package/docs/content/linting.md +0 -35
- package/docs/content/overriding-styles.mdx +0 -79
- package/docs/content/philosophy.md +0 -23
- package/docs/content/primer-theme.md +0 -89
- package/docs/content/ssr.mdx +0 -43
- package/docs/content/system-props.mdx +0 -37
- package/docs/content/theme-reference.md +0 -16
- package/docs/content/theming.md +0 -249
- package/docs/content/useOnEscapePress.mdx +0 -56
- package/docs/content/useOnOutsideClick.mdx +0 -57
- package/docs/content/useOpenAndCloseFocus.mdx +0 -49
- package/docs/content/useOverlay.mdx +0 -62
- package/docs/content/useSafeTimeout.mdx +0 -32
- package/docs/gatsby-config.js +0 -30
- package/docs/gatsby-node.js +0 -101
- package/docs/package-lock.json +0 -20979
- package/docs/package.json +0 -35
- package/docs/src/@primer/gatsby-theme-doctocat/components/hero.js +0 -21
- package/docs/src/@primer/gatsby-theme-doctocat/components/live-code.js +0 -84
- package/docs/src/@primer/gatsby-theme-doctocat/components/live-preview-wrapper.js +0 -39
- package/docs/src/@primer/gatsby-theme-doctocat/components/nav-dropdown.js +0 -48
- package/docs/src/@primer/gatsby-theme-doctocat/components/wrap-page-element.js +0 -25
- package/docs/src/@primer/gatsby-theme-doctocat/live-code-scope.js +0 -54
- package/docs/src/@primer/gatsby-theme-doctocat/nav.yml +0 -127
- package/docs/src/@primer/gatsby-theme-doctocat/primer-components-hero.svg +0 -1411
- package/docs/src/props.js +0 -77
- package/jest.config.js +0 -13
- package/lib/__tests__/ActionList.d.ts +0 -1
- package/lib/__tests__/ActionList.js +0 -67
- package/lib/__tests__/ActionMenu.d.ts +0 -1
- package/lib/__tests__/ActionMenu.js +0 -154
- package/lib/__tests__/AnchoredOverlay.d.ts +0 -1
- package/lib/__tests__/AnchoredOverlay.js +0 -161
- package/lib/__tests__/Avatar.d.ts +0 -1
- package/lib/__tests__/Avatar.js +0 -70
- package/lib/__tests__/AvatarStack.d.ts +0 -1
- package/lib/__tests__/AvatarStack.js +0 -71
- package/lib/__tests__/BorderBox.d.ts +0 -1
- package/lib/__tests__/BorderBox.js +0 -61
- package/lib/__tests__/Box.d.ts +0 -1
- package/lib/__tests__/Box.js +0 -81
- package/lib/__tests__/BranchName.d.ts +0 -1
- package/lib/__tests__/BranchName.js +0 -39
- package/lib/__tests__/Breadcrumb.d.ts +0 -1
- package/lib/__tests__/Breadcrumb.js +0 -42
- package/lib/__tests__/BreadcrumbItem.d.ts +0 -1
- package/lib/__tests__/BreadcrumbItem.js +0 -52
- package/lib/__tests__/Button.d.ts +0 -1
- package/lib/__tests__/Button.js +0 -152
- package/lib/__tests__/Caret.d.ts +0 -1
- package/lib/__tests__/Caret.js +0 -52
- package/lib/__tests__/CircleBadge.d.ts +0 -1
- package/lib/__tests__/CircleBadge.js +0 -87
- package/lib/__tests__/CircleOcticon.d.ts +0 -1
- package/lib/__tests__/CircleOcticon.js +0 -74
- package/lib/__tests__/CounterLabel.d.ts +0 -1
- package/lib/__tests__/CounterLabel.js +0 -61
- package/lib/__tests__/Details.d.ts +0 -1
- package/lib/__tests__/Details.js +0 -120
- package/lib/__tests__/Dialog.d.ts +0 -1
- package/lib/__tests__/Dialog.js +0 -188
- package/lib/__tests__/Dropdown.d.ts +0 -1
- package/lib/__tests__/Dropdown.js +0 -70
- package/lib/__tests__/DropdownMenu.d.ts +0 -1
- package/lib/__tests__/DropdownMenu.js +0 -153
- package/lib/__tests__/FilterList.d.ts +0 -1
- package/lib/__tests__/FilterList.js +0 -39
- package/lib/__tests__/FilterListItem.d.ts +0 -1
- package/lib/__tests__/FilterListItem.js +0 -49
- package/lib/__tests__/FilteredSearch.d.ts +0 -1
- package/lib/__tests__/FilteredSearch.js +0 -39
- package/lib/__tests__/Flash.d.ts +0 -1
- package/lib/__tests__/Flash.js +0 -65
- package/lib/__tests__/Flex.d.ts +0 -1
- package/lib/__tests__/Flex.js +0 -77
- package/lib/__tests__/FormGroup.d.ts +0 -1
- package/lib/__tests__/FormGroup.js +0 -58
- package/lib/__tests__/Grid.d.ts +0 -1
- package/lib/__tests__/Grid.js +0 -107
- package/lib/__tests__/Header.d.ts +0 -1
- package/lib/__tests__/Header.js +0 -63
- package/lib/__tests__/Heading.d.ts +0 -1
- package/lib/__tests__/Heading.js +0 -112
- package/lib/__tests__/Label.d.ts +0 -1
- package/lib/__tests__/Label.js +0 -49
- package/lib/__tests__/LabelGroup.d.ts +0 -1
- package/lib/__tests__/LabelGroup.js +0 -41
- package/lib/__tests__/Link.d.ts +0 -1
- package/lib/__tests__/Link.js +0 -73
- package/lib/__tests__/Overlay.d.ts +0 -1
- package/lib/__tests__/Overlay.js +0 -145
- package/lib/__tests__/Pagehead.d.ts +0 -1
- package/lib/__tests__/Pagehead.js +0 -40
- package/lib/__tests__/Pagination/Pagination.d.ts +0 -1
- package/lib/__tests__/Pagination/Pagination.js +0 -50
- package/lib/__tests__/Pagination/PaginationModel.d.ts +0 -1
- package/lib/__tests__/Pagination/PaginationModel.js +0 -186
- package/lib/__tests__/PointerBox.d.ts +0 -1
- package/lib/__tests__/PointerBox.js +0 -49
- package/lib/__tests__/Popover.d.ts +0 -1
- package/lib/__tests__/Popover.js +0 -70
- package/lib/__tests__/Portal.d.ts +0 -1
- package/lib/__tests__/Portal.js +0 -124
- package/lib/__tests__/Position.d.ts +0 -1
- package/lib/__tests__/Position.js +0 -149
- package/lib/__tests__/ProgressBar.d.ts +0 -1
- package/lib/__tests__/ProgressBar.js +0 -71
- package/lib/__tests__/SelectMenu.d.ts +0 -1
- package/lib/__tests__/SelectMenu.js +0 -155
- package/lib/__tests__/SelectPanel.d.ts +0 -1
- package/lib/__tests__/SelectPanel.js +0 -83
- package/lib/__tests__/SideNav.d.ts +0 -1
- package/lib/__tests__/SideNav.js +0 -75
- package/lib/__tests__/Spinner.d.ts +0 -1
- package/lib/__tests__/Spinner.js +0 -56
- package/lib/__tests__/StateLabel.d.ts +0 -1
- package/lib/__tests__/StateLabel.js +0 -74
- package/lib/__tests__/StyledOcticon.d.ts +0 -1
- package/lib/__tests__/StyledOcticon.js +0 -43
- package/lib/__tests__/SubNav.d.ts +0 -1
- package/lib/__tests__/SubNav.js +0 -65
- package/lib/__tests__/SubNavLink.d.ts +0 -1
- package/lib/__tests__/SubNavLink.js +0 -52
- package/lib/__tests__/TabNav.d.ts +0 -1
- package/lib/__tests__/TabNav.js +0 -53
- package/lib/__tests__/Text.d.ts +0 -1
- package/lib/__tests__/Text.js +0 -108
- package/lib/__tests__/TextInput.d.ts +0 -1
- package/lib/__tests__/TextInput.js +0 -81
- package/lib/__tests__/ThemeProvider.d.ts +0 -1
- package/lib/__tests__/ThemeProvider.js +0 -444
- package/lib/__tests__/Timeline.d.ts +0 -1
- package/lib/__tests__/Timeline.js +0 -80
- package/lib/__tests__/Tooltip.d.ts +0 -1
- package/lib/__tests__/Tooltip.js +0 -72
- package/lib/__tests__/Truncate.d.ts +0 -1
- package/lib/__tests__/Truncate.js +0 -66
- package/lib/__tests__/UnderlineNav.d.ts +0 -1
- package/lib/__tests__/UnderlineNav.js +0 -75
- package/lib/__tests__/UnderlineNavLink.d.ts +0 -1
- package/lib/__tests__/UnderlineNavLink.js +0 -54
- package/lib/__tests__/behaviors/anchoredPosition.d.ts +0 -1
- package/lib/__tests__/behaviors/anchoredPosition.js +0 -390
- package/lib/__tests__/behaviors/focusTrap.d.ts +0 -1
- package/lib/__tests__/behaviors/focusTrap.js +0 -234
- package/lib/__tests__/behaviors/focusZone.d.ts +0 -1
- package/lib/__tests__/behaviors/focusZone.js +0 -570
- package/lib/__tests__/behaviors/iterateFocusableElements.d.ts +0 -1
- package/lib/__tests__/behaviors/iterateFocusableElements.js +0 -55
- package/lib/__tests__/filterObject.d.ts +0 -1
- package/lib/__tests__/filterObject.js +0 -30
- package/lib/__tests__/hooks/useAnchoredPosition.d.ts +0 -1
- package/lib/__tests__/hooks/useAnchoredPosition.js +0 -54
- package/lib/__tests__/hooks/useOnEscapePress.d.ts +0 -1
- package/lib/__tests__/hooks/useOnEscapePress.js +0 -32
- package/lib/__tests__/hooks/useOnOutsideClick.d.ts +0 -1
- package/lib/__tests__/hooks/useOnOutsideClick.js +0 -87
- package/lib/__tests__/hooks/useOpenAndCloseFocus.d.ts +0 -1
- package/lib/__tests__/hooks/useOpenAndCloseFocus.js +0 -60
- package/lib/__tests__/hooks/useProvidedStateOrCreate.d.ts +0 -1
- package/lib/__tests__/hooks/useProvidedStateOrCreate.js +0 -45
- package/lib/__tests__/theme.d.ts +0 -1
- package/lib/__tests__/theme.js +0 -36
- package/lib/__tests__/themeGet.d.ts +0 -1
- package/lib/__tests__/themeGet.js +0 -25
- package/lib/__tests__/useSafeTimeout.d.ts +0 -1
- package/lib/__tests__/useSafeTimeout.js +0 -45
- package/lib/stories/ActionList.stories.d.ts +0 -40
- package/lib/stories/ActionList.stories.js +0 -382
- package/lib/stories/ActionMenu.stories.d.ts +0 -29
- package/lib/stories/ActionMenu.stories.js +0 -338
- package/lib/stories/AnchoredOverlay.stories.d.ts +0 -6
- package/lib/stories/AnchoredOverlay.stories.js +0 -127
- package/lib/stories/AvatarStack.stories.d.ts +0 -8
- package/lib/stories/AvatarStack.stories.js +0 -49
- package/lib/stories/Button.stories.d.ts +0 -57
- package/lib/stories/Button.stories.js +0 -114
- package/lib/stories/ConfirmationDialog.stories.d.ts +0 -7
- package/lib/stories/ConfirmationDialog.stories.js +0 -111
- package/lib/stories/Dialog.stories.d.ts +0 -13
- package/lib/stories/Dialog.stories.js +0 -265
- package/lib/stories/DropdownMenu.stories.d.ts +0 -12
- package/lib/stories/DropdownMenu.stories.js +0 -122
- package/lib/stories/Overlay.stories.d.ts +0 -7
- package/lib/stories/Overlay.stories.js +0 -185
- package/lib/stories/Portal.stories.d.ts +0 -8
- package/lib/stories/Portal.stories.js +0 -104
- package/lib/stories/SelectPanel.stories.d.ts +0 -32
- package/lib/stories/SelectPanel.stories.js +0 -342
- package/lib/stories/ThemeProvider.stories.d.ts +0 -6
- package/lib/stories/ThemeProvider.stories.js +0 -102
- package/lib/stories/useAnchoredPosition.stories.d.ts +0 -8
- package/lib/stories/useAnchoredPosition.stories.js +0 -351
- package/lib/stories/useFocusTrap.stories.d.ts +0 -9
- package/lib/stories/useFocusTrap.stories.js +0 -356
- package/lib/stories/useFocusZone.stories.d.ts +0 -12
- package/lib/stories/useFocusZone.stories.js +0 -599
- package/lib-esm/__tests__/ActionList.d.ts +0 -1
- package/lib-esm/__tests__/ActionList.js +0 -54
- package/lib-esm/__tests__/ActionMenu.d.ts +0 -1
- package/lib-esm/__tests__/ActionMenu.js +0 -141
- package/lib-esm/__tests__/AnchoredOverlay.d.ts +0 -1
- package/lib-esm/__tests__/AnchoredOverlay.js +0 -135
- package/lib-esm/__tests__/Avatar.d.ts +0 -1
- package/lib-esm/__tests__/Avatar.js +0 -58
- package/lib-esm/__tests__/AvatarStack.d.ts +0 -1
- package/lib-esm/__tests__/AvatarStack.js +0 -57
- package/lib-esm/__tests__/BorderBox.d.ts +0 -1
- package/lib-esm/__tests__/BorderBox.js +0 -49
- package/lib-esm/__tests__/Box.d.ts +0 -1
- package/lib-esm/__tests__/Box.js +0 -69
- package/lib-esm/__tests__/BranchName.d.ts +0 -1
- package/lib-esm/__tests__/BranchName.js +0 -28
- package/lib-esm/__tests__/Breadcrumb.d.ts +0 -1
- package/lib-esm/__tests__/Breadcrumb.js +0 -31
- package/lib-esm/__tests__/BreadcrumbItem.d.ts +0 -1
- package/lib-esm/__tests__/BreadcrumbItem.js +0 -41
- package/lib-esm/__tests__/Button.d.ts +0 -1
- package/lib-esm/__tests__/Button.js +0 -141
- package/lib-esm/__tests__/Caret.d.ts +0 -1
- package/lib-esm/__tests__/Caret.js +0 -42
- package/lib-esm/__tests__/CircleBadge.d.ts +0 -1
- package/lib-esm/__tests__/CircleBadge.js +0 -73
- package/lib-esm/__tests__/CircleOcticon.d.ts +0 -1
- package/lib-esm/__tests__/CircleOcticon.js +0 -61
- package/lib-esm/__tests__/CounterLabel.d.ts +0 -1
- package/lib-esm/__tests__/CounterLabel.js +0 -49
- package/lib-esm/__tests__/Details.d.ts +0 -1
- package/lib-esm/__tests__/Details.js +0 -109
- package/lib-esm/__tests__/Dialog.d.ts +0 -1
- package/lib-esm/__tests__/Dialog.js +0 -174
- package/lib-esm/__tests__/Dropdown.d.ts +0 -1
- package/lib-esm/__tests__/Dropdown.js +0 -59
- package/lib-esm/__tests__/DropdownMenu.d.ts +0 -1
- package/lib-esm/__tests__/DropdownMenu.js +0 -139
- package/lib-esm/__tests__/FilterList.d.ts +0 -1
- package/lib-esm/__tests__/FilterList.js +0 -28
- package/lib-esm/__tests__/FilterListItem.d.ts +0 -1
- package/lib-esm/__tests__/FilterListItem.js +0 -38
- package/lib-esm/__tests__/FilteredSearch.d.ts +0 -1
- package/lib-esm/__tests__/FilteredSearch.js +0 -28
- package/lib-esm/__tests__/Flash.d.ts +0 -1
- package/lib-esm/__tests__/Flash.js +0 -53
- package/lib-esm/__tests__/Flex.d.ts +0 -1
- package/lib-esm/__tests__/Flex.js +0 -66
- package/lib-esm/__tests__/FormGroup.d.ts +0 -1
- package/lib-esm/__tests__/FormGroup.js +0 -47
- package/lib-esm/__tests__/Grid.d.ts +0 -1
- package/lib-esm/__tests__/Grid.js +0 -96
- package/lib-esm/__tests__/Header.d.ts +0 -1
- package/lib-esm/__tests__/Header.js +0 -52
- package/lib-esm/__tests__/Heading.d.ts +0 -1
- package/lib-esm/__tests__/Heading.js +0 -101
- package/lib-esm/__tests__/Label.d.ts +0 -1
- package/lib-esm/__tests__/Label.js +0 -38
- package/lib-esm/__tests__/LabelGroup.d.ts +0 -1
- package/lib-esm/__tests__/LabelGroup.js +0 -28
- package/lib-esm/__tests__/Link.d.ts +0 -1
- package/lib-esm/__tests__/Link.js +0 -62
- package/lib-esm/__tests__/Overlay.d.ts +0 -1
- package/lib-esm/__tests__/Overlay.js +0 -123
- package/lib-esm/__tests__/Pagehead.d.ts +0 -1
- package/lib-esm/__tests__/Pagehead.js +0 -28
- package/lib-esm/__tests__/Pagination/Pagination.d.ts +0 -1
- package/lib-esm/__tests__/Pagination/Pagination.js +0 -37
- package/lib-esm/__tests__/Pagination/PaginationModel.d.ts +0 -1
- package/lib-esm/__tests__/Pagination/PaginationModel.js +0 -182
- package/lib-esm/__tests__/PointerBox.d.ts +0 -1
- package/lib-esm/__tests__/PointerBox.js +0 -38
- package/lib-esm/__tests__/Popover.d.ts +0 -1
- package/lib-esm/__tests__/Popover.js +0 -56
- package/lib-esm/__tests__/Portal.d.ts +0 -1
- package/lib-esm/__tests__/Portal.js +0 -104
- package/lib-esm/__tests__/Position.d.ts +0 -1
- package/lib-esm/__tests__/Position.js +0 -138
- package/lib-esm/__tests__/ProgressBar.d.ts +0 -1
- package/lib-esm/__tests__/ProgressBar.js +0 -60
- package/lib-esm/__tests__/SelectMenu.d.ts +0 -1
- package/lib-esm/__tests__/SelectMenu.js +0 -145
- package/lib-esm/__tests__/SelectPanel.d.ts +0 -1
- package/lib-esm/__tests__/SelectPanel.js +0 -67
- package/lib-esm/__tests__/SideNav.d.ts +0 -1
- package/lib-esm/__tests__/SideNav.js +0 -63
- package/lib-esm/__tests__/Spinner.d.ts +0 -1
- package/lib-esm/__tests__/Spinner.js +0 -45
- package/lib-esm/__tests__/StateLabel.d.ts +0 -1
- package/lib-esm/__tests__/StateLabel.js +0 -63
- package/lib-esm/__tests__/StyledOcticon.d.ts +0 -1
- package/lib-esm/__tests__/StyledOcticon.js +0 -31
- package/lib-esm/__tests__/SubNav.d.ts +0 -1
- package/lib-esm/__tests__/SubNav.js +0 -52
- package/lib-esm/__tests__/SubNavLink.d.ts +0 -1
- package/lib-esm/__tests__/SubNavLink.js +0 -41
- package/lib-esm/__tests__/TabNav.d.ts +0 -1
- package/lib-esm/__tests__/TabNav.js +0 -42
- package/lib-esm/__tests__/Text.d.ts +0 -1
- package/lib-esm/__tests__/Text.js +0 -95
- package/lib-esm/__tests__/TextInput.d.ts +0 -1
- package/lib-esm/__tests__/TextInput.js +0 -70
- package/lib-esm/__tests__/ThemeProvider.d.ts +0 -1
- package/lib-esm/__tests__/ThemeProvider.js +0 -408
- package/lib-esm/__tests__/Timeline.d.ts +0 -1
- package/lib-esm/__tests__/Timeline.js +0 -69
- package/lib-esm/__tests__/Tooltip.d.ts +0 -1
- package/lib-esm/__tests__/Tooltip.js +0 -61
- package/lib-esm/__tests__/Truncate.d.ts +0 -1
- package/lib-esm/__tests__/Truncate.js +0 -55
- package/lib-esm/__tests__/UnderlineNav.d.ts +0 -1
- package/lib-esm/__tests__/UnderlineNav.js +0 -62
- package/lib-esm/__tests__/UnderlineNavLink.d.ts +0 -1
- package/lib-esm/__tests__/UnderlineNavLink.js +0 -43
- package/lib-esm/__tests__/behaviors/anchoredPosition.d.ts +0 -1
- package/lib-esm/__tests__/behaviors/anchoredPosition.js +0 -388
- package/lib-esm/__tests__/behaviors/focusTrap.d.ts +0 -1
- package/lib-esm/__tests__/behaviors/focusTrap.js +0 -227
- package/lib-esm/__tests__/behaviors/focusZone.d.ts +0 -1
- package/lib-esm/__tests__/behaviors/focusZone.js +0 -487
- package/lib-esm/__tests__/behaviors/iterateFocusableElements.d.ts +0 -1
- package/lib-esm/__tests__/behaviors/iterateFocusableElements.js +0 -48
- package/lib-esm/__tests__/filterObject.d.ts +0 -1
- package/lib-esm/__tests__/filterObject.js +0 -27
- package/lib-esm/__tests__/hooks/useAnchoredPosition.d.ts +0 -1
- package/lib-esm/__tests__/hooks/useAnchoredPosition.js +0 -46
- package/lib-esm/__tests__/hooks/useOnEscapePress.d.ts +0 -1
- package/lib-esm/__tests__/hooks/useOnEscapePress.js +0 -23
- package/lib-esm/__tests__/hooks/useOnOutsideClick.d.ts +0 -1
- package/lib-esm/__tests__/hooks/useOnOutsideClick.js +0 -68
- package/lib-esm/__tests__/hooks/useOpenAndCloseFocus.d.ts +0 -1
- package/lib-esm/__tests__/hooks/useOpenAndCloseFocus.js +0 -52
- package/lib-esm/__tests__/hooks/useProvidedStateOrCreate.d.ts +0 -1
- package/lib-esm/__tests__/hooks/useProvidedStateOrCreate.js +0 -36
- package/lib-esm/__tests__/theme.d.ts +0 -1
- package/lib-esm/__tests__/theme.js +0 -33
- package/lib-esm/__tests__/themeGet.d.ts +0 -1
- package/lib-esm/__tests__/themeGet.js +0 -22
- package/lib-esm/__tests__/useSafeTimeout.d.ts +0 -1
- package/lib-esm/__tests__/useSafeTimeout.js +0 -39
- package/lib-esm/stories/ActionList.stories.d.ts +0 -40
- package/lib-esm/stories/ActionList.stories.js +0 -334
- package/lib-esm/stories/ActionMenu.stories.d.ts +0 -29
- package/lib-esm/stories/ActionMenu.stories.js +0 -293
- package/lib-esm/stories/AnchoredOverlay.stories.d.ts +0 -6
- package/lib-esm/stories/AnchoredOverlay.stories.js +0 -101
- package/lib-esm/stories/AvatarStack.stories.d.ts +0 -8
- package/lib-esm/stories/AvatarStack.stories.js +0 -32
- package/lib-esm/stories/Button.stories.d.ts +0 -57
- package/lib-esm/stories/Button.stories.js +0 -78
- package/lib-esm/stories/ConfirmationDialog.stories.d.ts +0 -7
- package/lib-esm/stories/ConfirmationDialog.stories.js +0 -86
- package/lib-esm/stories/Dialog.stories.d.ts +0 -13
- package/lib-esm/stories/Dialog.stories.js +0 -240
- package/lib-esm/stories/DropdownMenu.stories.d.ts +0 -12
- package/lib-esm/stories/DropdownMenu.stories.js +0 -94
- package/lib-esm/stories/Overlay.stories.d.ts +0 -7
- package/lib-esm/stories/Overlay.stories.js +0 -154
- package/lib-esm/stories/Portal.stories.d.ts +0 -8
- package/lib-esm/stories/Portal.stories.js +0 -68
- package/lib-esm/stories/SelectPanel.stories.d.ts +0 -32
- package/lib-esm/stories/SelectPanel.stories.js +0 -284
- package/lib-esm/stories/ThemeProvider.stories.d.ts +0 -6
- package/lib-esm/stories/ThemeProvider.stories.js +0 -83
- package/lib-esm/stories/useAnchoredPosition.stories.d.ts +0 -8
- package/lib-esm/stories/useAnchoredPosition.stories.js +0 -313
- package/lib-esm/stories/useFocusTrap.stories.d.ts +0 -9
- package/lib-esm/stories/useFocusTrap.stories.js +0 -309
- package/lib-esm/stories/useFocusZone.stories.d.ts +0 -12
- package/lib-esm/stories/useFocusZone.stories.js +0 -554
- package/migrating.md +0 -250
- package/now.json +0 -17
- package/package-lock.json +0 -28661
- package/rollup.config.js +0 -36
- package/script/build +0 -19
- package/script/setup +0 -12
- package/src/ActionList/Divider.tsx +0 -25
- package/src/ActionList/Group.tsx +0 -45
- package/src/ActionList/Header.tsx +0 -74
- package/src/ActionList/Item.tsx +0 -460
- package/src/ActionList/List.tsx +0 -253
- package/src/ActionList/index.ts +0 -21
- package/src/ActionMenu.tsx +0 -106
- package/src/AnchoredOverlay/AnchoredOverlay.tsx +0 -180
- package/src/AnchoredOverlay/index.ts +0 -2
- package/src/Avatar.tsx +0 -46
- package/src/AvatarPair.tsx +0 -35
- package/src/AvatarStack.tsx +0 -161
- package/src/BaseStyles.tsx +0 -53
- package/src/BorderBox.tsx +0 -18
- package/src/Box.tsx +0 -54
- package/src/BranchName.tsx +0 -19
- package/src/Breadcrumb.tsx +0 -87
- package/src/Button/Button.tsx +0 -40
- package/src/Button/ButtonBase.tsx +0 -43
- package/src/Button/ButtonClose.tsx +0 -40
- package/src/Button/ButtonDanger.tsx +0 -43
- package/src/Button/ButtonGroup.tsx +0 -55
- package/src/Button/ButtonInvisible.tsx +0 -27
- package/src/Button/ButtonOutline.tsx +0 -43
- package/src/Button/ButtonPrimary.tsx +0 -41
- package/src/Button/ButtonStyles.tsx +0 -36
- package/src/Button/ButtonTableList.tsx +0 -58
- package/src/Button/index.ts +0 -16
- package/src/Caret.tsx +0 -133
- package/src/CircleBadge.tsx +0 -55
- package/src/CircleOcticon.tsx +0 -37
- package/src/CounterLabel.tsx +0 -52
- package/src/Details.tsx +0 -23
- package/src/Dialog/ConfirmationDialog.tsx +0 -184
- package/src/Dialog/Dialog.tsx +0 -419
- package/src/Dialog.tsx +0 -149
- package/src/Dropdown.tsx +0 -158
- package/src/DropdownMenu/DropdownButton.tsx +0 -15
- package/src/DropdownMenu/DropdownMenu.tsx +0 -115
- package/src/DropdownMenu/index.ts +0 -4
- package/src/DropdownStyles.ts +0 -128
- package/src/FilterList.tsx +0 -81
- package/src/FilteredActionList/FilteredActionList.tsx +0 -152
- package/src/FilteredActionList/index.ts +0 -2
- package/src/FilteredSearch.tsx +0 -28
- package/src/Flash.tsx +0 -77
- package/src/Flex.tsx +0 -15
- package/src/FormGroup.tsx +0 -27
- package/src/Grid.tsx +0 -15
- package/src/Header.tsx +0 -84
- package/src/Heading.tsx +0 -21
- package/src/Label.tsx +0 -75
- package/src/LabelGroup.tsx +0 -18
- package/src/Link.tsx +0 -46
- package/src/Overlay.tsx +0 -194
- package/src/Pagehead.tsx +0 -17
- package/src/Pagination/Pagination.tsx +0 -214
- package/src/Pagination/index.ts +0 -4
- package/src/Pagination/model.tsx +0 -187
- package/src/PointerBox.tsx +0 -31
- package/src/Popover.tsx +0 -236
- package/src/Portal/Portal.tsx +0 -96
- package/src/Portal/index.ts +0 -5
- package/src/Position.tsx +0 -63
- package/src/ProgressBar.tsx +0 -52
- package/src/SelectMenu/SelectMenu.tsx +0 -125
- package/src/SelectMenu/SelectMenuContext.tsx +0 -9
- package/src/SelectMenu/SelectMenuDivider.tsx +0 -25
- package/src/SelectMenu/SelectMenuFilter.tsx +0 -51
- package/src/SelectMenu/SelectMenuFooter.tsx +0 -28
- package/src/SelectMenu/SelectMenuHeader.tsx +0 -50
- package/src/SelectMenu/SelectMenuItem.tsx +0 -137
- package/src/SelectMenu/SelectMenuList.tsx +0 -42
- package/src/SelectMenu/SelectMenuLoadingAnimation.tsx +0 -24
- package/src/SelectMenu/SelectMenuModal.tsx +0 -121
- package/src/SelectMenu/SelectMenuTab.tsx +0 -88
- package/src/SelectMenu/SelectMenuTabPanel.tsx +0 -30
- package/src/SelectMenu/SelectMenuTabs.tsx +0 -44
- package/src/SelectMenu/hooks/useKeyboardNav.js +0 -90
- package/src/SelectMenu/index.ts +0 -15
- package/src/SelectPanel/SelectPanel.tsx +0 -173
- package/src/SelectPanel/index.ts +0 -2
- package/src/SideNav.tsx +0 -193
- package/src/Spinner.tsx +0 -59
- package/src/StateLabel.tsx +0 -110
- package/src/StyledOcticon.tsx +0 -24
- package/src/SubNav.tsx +0 -129
- package/src/TabNav.tsx +0 -77
- package/src/Text.tsx +0 -13
- package/src/TextInput.tsx +0 -183
- package/src/ThemeProvider.tsx +0 -176
- package/src/Timeline.tsx +0 -141
- package/src/Tooltip.tsx +0 -263
- package/src/Truncate.tsx +0 -36
- package/src/UnderlineNav.tsx +0 -110
- package/src/__tests__/.eslintrc.json +0 -11
- package/src/__tests__/ActionList.tsx +0 -49
- package/src/__tests__/ActionMenu.tsx +0 -138
- package/src/__tests__/AnchoredOverlay.tsx +0 -151
- package/src/__tests__/Avatar.tsx +0 -45
- package/src/__tests__/AvatarStack.tsx +0 -45
- package/src/__tests__/BorderBox.tsx +0 -44
- package/src/__tests__/Box.tsx +0 -43
- package/src/__tests__/BranchName.tsx +0 -27
- package/src/__tests__/Breadcrumb.tsx +0 -31
- package/src/__tests__/BreadcrumbItem.tsx +0 -32
- package/src/__tests__/Button.tsx +0 -129
- package/src/__tests__/Caret.tsx +0 -36
- package/src/__tests__/CircleBadge.tsx +0 -69
- package/src/__tests__/CircleOcticon.tsx +0 -52
- package/src/__tests__/CounterLabel.tsx +0 -51
- package/src/__tests__/Details.tsx +0 -116
- package/src/__tests__/Dialog.tsx +0 -157
- package/src/__tests__/Dropdown.tsx +0 -57
- package/src/__tests__/DropdownMenu.tsx +0 -138
- package/src/__tests__/FilterList.tsx +0 -27
- package/src/__tests__/FilterListItem.tsx +0 -32
- package/src/__tests__/FilteredSearch.tsx +0 -27
- package/src/__tests__/Flash.tsx +0 -46
- package/src/__tests__/Flex.tsx +0 -59
- package/src/__tests__/FormGroup.tsx +0 -39
- package/src/__tests__/Grid.tsx +0 -83
- package/src/__tests__/Header.tsx +0 -50
- package/src/__tests__/Heading.tsx +0 -92
- package/src/__tests__/Label.tsx +0 -35
- package/src/__tests__/LabelGroup.tsx +0 -31
- package/src/__tests__/Link.tsx +0 -48
- package/src/__tests__/Overlay.tsx +0 -103
- package/src/__tests__/Pagehead.tsx +0 -24
- package/src/__tests__/Pagination/Pagination.tsx +0 -31
- package/src/__tests__/Pagination/PaginationModel.tsx +0 -133
- package/src/__tests__/Pagination/__snapshots__/Pagination.tsx.snap +0 -184
- package/src/__tests__/PointerBox.tsx +0 -35
- package/src/__tests__/Popover.tsx +0 -69
- package/src/__tests__/Portal.tsx +0 -103
- package/src/__tests__/Position.tsx +0 -118
- package/src/__tests__/ProgressBar.tsx +0 -41
- package/src/__tests__/SelectMenu.tsx +0 -142
- package/src/__tests__/SelectPanel.tsx +0 -65
- package/src/__tests__/SideNav.tsx +0 -63
- package/src/__tests__/Spinner.tsx +0 -44
- package/src/__tests__/StateLabel.tsx +0 -50
- package/src/__tests__/StyledOcticon.tsx +0 -28
- package/src/__tests__/SubNav.tsx +0 -51
- package/src/__tests__/SubNavLink.tsx +0 -32
- package/src/__tests__/TabNav.tsx +0 -33
- package/src/__tests__/Text.tsx +0 -79
- package/src/__tests__/TextInput.tsx +0 -50
- package/src/__tests__/ThemeProvider.tsx +0 -441
- package/src/__tests__/Timeline.tsx +0 -59
- package/src/__tests__/Tooltip.tsx +0 -53
- package/src/__tests__/Truncate.tsx +0 -45
- package/src/__tests__/UnderlineNav.tsx +0 -59
- package/src/__tests__/UnderlineNavLink.tsx +0 -32
- package/src/__tests__/__snapshots__/ActionList.tsx.snap +0 -27
- package/src/__tests__/__snapshots__/ActionMenu.tsx.snap +0 -80
- package/src/__tests__/__snapshots__/AnchoredOverlay.tsx.snap +0 -332
- package/src/__tests__/__snapshots__/Avatar.tsx.snap +0 -19
- package/src/__tests__/__snapshots__/AvatarStack.tsx.snap +0 -377
- package/src/__tests__/__snapshots__/BorderBox.tsx.snap +0 -14
- package/src/__tests__/__snapshots__/Box.tsx.snap +0 -201
- package/src/__tests__/__snapshots__/BranchName.tsx.snap +0 -17
- package/src/__tests__/__snapshots__/Breadcrumb.tsx.snap +0 -29
- package/src/__tests__/__snapshots__/BreadcrumbItem.tsx.snap +0 -79
- package/src/__tests__/__snapshots__/Button.tsx.snap +0 -832
- package/src/__tests__/__snapshots__/Caret.tsx.snap +0 -373
- package/src/__tests__/__snapshots__/CircleBadge.tsx.snap +0 -141
- package/src/__tests__/__snapshots__/CircleOcticon.tsx.snap +0 -64
- package/src/__tests__/__snapshots__/CounterLabel.tsx.snap +0 -22
- package/src/__tests__/__snapshots__/Details.tsx.snap +0 -15
- package/src/__tests__/__snapshots__/Dialog.tsx.snap +0 -200
- package/src/__tests__/__snapshots__/Dropdown.tsx.snap +0 -249
- package/src/__tests__/__snapshots__/DropdownMenu.tsx.snap +0 -106
- package/src/__tests__/__snapshots__/FilterList.tsx.snap +0 -13
- package/src/__tests__/__snapshots__/FilterListItem.tsx.snap +0 -80
- package/src/__tests__/__snapshots__/FilteredSearch.tsx.snap +0 -32
- package/src/__tests__/__snapshots__/Flash.tsx.snap +0 -32
- package/src/__tests__/__snapshots__/Flex.tsx.snap +0 -130
- package/src/__tests__/__snapshots__/FormGroup.tsx.snap +0 -25
- package/src/__tests__/__snapshots__/Grid.tsx.snap +0 -178
- package/src/__tests__/__snapshots__/Header.tsx.snap +0 -79
- package/src/__tests__/__snapshots__/Heading.tsx.snap +0 -13
- package/src/__tests__/__snapshots__/Label.tsx.snap +0 -74
- package/src/__tests__/__snapshots__/LabelGroup.tsx.snap +0 -15
- package/src/__tests__/__snapshots__/Link.tsx.snap +0 -213
- package/src/__tests__/__snapshots__/Pagehead.tsx.snap +0 -15
- package/src/__tests__/__snapshots__/PointerBox.tsx.snap +0 -174
- package/src/__tests__/__snapshots__/Popover.tsx.snap +0 -4687
- package/src/__tests__/__snapshots__/Position.tsx.snap +0 -44
- package/src/__tests__/__snapshots__/ProgressBar.tsx.snap +0 -53
- package/src/__tests__/__snapshots__/SelectMenu.tsx.snap +0 -469
- package/src/__tests__/__snapshots__/SelectPanel.tsx.snap +0 -123
- package/src/__tests__/__snapshots__/SideNav.tsx.snap +0 -143
- package/src/__tests__/__snapshots__/Spinner.tsx.snap +0 -33
- package/src/__tests__/__snapshots__/StateLabel.tsx.snap +0 -409
- package/src/__tests__/__snapshots__/StyledOcticon.tsx.snap +0 -25
- package/src/__tests__/__snapshots__/SubNav.tsx.snap +0 -44
- package/src/__tests__/__snapshots__/SubNavLink.tsx.snap +0 -199
- package/src/__tests__/__snapshots__/TabNav.tsx.snap +0 -58
- package/src/__tests__/__snapshots__/Text.tsx.snap +0 -7
- package/src/__tests__/__snapshots__/TextInput.tsx.snap +0 -440
- package/src/__tests__/__snapshots__/ThemeProvider.tsx.snap +0 -15
- package/src/__tests__/__snapshots__/Timeline.tsx.snap +0 -159
- package/src/__tests__/__snapshots__/Tooltip.tsx.snap +0 -227
- package/src/__tests__/__snapshots__/Truncate.tsx.snap +0 -17
- package/src/__tests__/__snapshots__/UnderlineNav.tsx.snap +0 -59
- package/src/__tests__/__snapshots__/UnderlineNavLink.tsx.snap +0 -130
- package/src/__tests__/behaviors/anchoredPosition.ts +0 -295
- package/src/__tests__/behaviors/focusTrap.tsx +0 -236
- package/src/__tests__/behaviors/focusZone.tsx +0 -549
- package/src/__tests__/behaviors/iterateFocusableElements.tsx +0 -61
- package/src/__tests__/filterObject.ts +0 -54
- package/src/__tests__/hooks/useAnchoredPosition.tsx +0 -31
- package/src/__tests__/hooks/useOnEscapePress.tsx +0 -16
- package/src/__tests__/hooks/useOnOutsideClick.tsx +0 -48
- package/src/__tests__/hooks/useOpenAndCloseFocus.tsx +0 -48
- package/src/__tests__/hooks/useProvidedStateOrCreate.tsx +0 -39
- package/src/__tests__/theme.ts +0 -41
- package/src/__tests__/themeGet.ts +0 -15
- package/src/__tests__/useSafeTimeout.tsx +0 -36
- package/src/behaviors/anchoredPosition.ts +0 -442
- package/src/behaviors/focusTrap.ts +0 -184
- package/src/behaviors/focusZone.ts +0 -713
- package/src/constants.ts +0 -62
- package/src/hooks/index.ts +0 -11
- package/src/hooks/useAnchoredPosition.ts +0 -53
- package/src/hooks/useCombinedRefs.ts +0 -40
- package/src/hooks/useDetails.tsx +0 -54
- package/src/hooks/useDialog.ts +0 -121
- package/src/hooks/useFocusTrap.ts +0 -80
- package/src/hooks/useFocusZone.ts +0 -64
- package/src/hooks/useOnEscapePress.ts +0 -63
- package/src/hooks/useOnOutsideClick.tsx +0 -82
- package/src/hooks/useOpenAndCloseFocus.ts +0 -27
- package/src/hooks/useOverlay.tsx +0 -32
- package/src/hooks/useProvidedRefOrCreate.ts +0 -14
- package/src/hooks/useProvidedStateOrCreate.ts +0 -27
- package/src/hooks/useRenderForcingRef.ts +0 -22
- package/src/hooks/useResizeObserver.ts +0 -11
- package/src/hooks/useSafeTimeout.ts +0 -38
- package/src/hooks/useScrollFlash.ts +0 -21
- package/src/index.ts +0 -165
- package/src/polyfills/eventListenerSignal.ts +0 -66
- package/src/stories/ActionList.stories.tsx +0 -364
- package/src/stories/ActionMenu.stories.tsx +0 -322
- package/src/stories/AnchoredOverlay.stories.tsx +0 -117
- package/src/stories/AvatarStack.stories.tsx +0 -37
- package/src/stories/Button.stories.tsx +0 -88
- package/src/stories/ConfirmationDialog.stories.tsx +0 -105
- package/src/stories/Dialog.stories.tsx +0 -240
- package/src/stories/DropdownMenu.stories.tsx +0 -84
- package/src/stories/Overlay.stories.tsx +0 -186
- package/src/stories/Portal.stories.tsx +0 -109
- package/src/stories/SelectPanel.stories.tsx +0 -300
- package/src/stories/ThemeProvider.stories.tsx +0 -104
- package/src/stories/useAnchoredPosition.stories.tsx +0 -320
- package/src/stories/useFocusTrap.stories.tsx +0 -400
- package/src/stories/useFocusZone.stories.tsx +0 -663
- package/src/sx.ts +0 -9
- package/src/theme-preval.js +0 -136
- package/src/theme.ts +0 -3
- package/src/utils/deprecate.tsx +0 -73
- package/src/utils/isNumeric.tsx +0 -4
- package/src/utils/iterateFocusableElements.ts +0 -121
- package/src/utils/ssr.tsx +0 -1
- package/src/utils/test-deprecations.tsx +0 -19
- package/src/utils/test-helpers.tsx +0 -7
- package/src/utils/test-matchers.tsx +0 -109
- package/src/utils/testing.tsx +0 -243
- package/src/utils/theme.js +0 -64
- package/src/utils/types.ts +0 -90
- package/src/utils/uniqueId.ts +0 -6
- package/src/utils/userAgent.ts +0 -7
- package/stats.html +0 -3279
- package/tsconfig.json +0 -20
@@ -1,13 +0,0 @@
|
|
1
|
-
/// <reference types="react" />
|
2
|
-
import { Meta } from '@storybook/react';
|
3
|
-
import { DialogWidth, DialogHeight } from '../Dialog/Dialog';
|
4
|
-
declare const _default: Meta<import("@storybook/react").Args>;
|
5
|
-
export default _default;
|
6
|
-
interface DialogStoryProps {
|
7
|
-
width: DialogWidth;
|
8
|
-
height: DialogHeight;
|
9
|
-
subtitle: boolean;
|
10
|
-
}
|
11
|
-
export declare const BasicDialog: ({ width, height, subtitle }: DialogStoryProps) => JSX.Element;
|
12
|
-
export declare const WithCustomRenderers: ({ width, height, subtitle }: DialogStoryProps) => JSX.Element;
|
13
|
-
export declare const StressTest: ({ width, height, subtitle }: DialogStoryProps) => JSX.Element;
|
@@ -1,240 +0,0 @@
|
|
1
|
-
import React, { useState, useRef, useCallback } from 'react';
|
2
|
-
import { BaseStyles, Button, ThemeProvider, Box } from '..';
|
3
|
-
import { Dialog } from '../Dialog/Dialog';
|
4
|
-
export default {
|
5
|
-
title: 'Internal components/Dialog',
|
6
|
-
component: Dialog,
|
7
|
-
decorators: [Story => {
|
8
|
-
// Since portal roots are registered globally, we need this line so that each storybook
|
9
|
-
// story works in isolation.
|
10
|
-
return /*#__PURE__*/React.createElement(ThemeProvider, null, /*#__PURE__*/React.createElement(BaseStyles, null, /*#__PURE__*/React.createElement(Story, null)));
|
11
|
-
}],
|
12
|
-
argTypes: {
|
13
|
-
width: {
|
14
|
-
defaultValue: 'xlarge',
|
15
|
-
control: {
|
16
|
-
type: 'radio',
|
17
|
-
options: ['small', 'medium', 'large', 'xlarge']
|
18
|
-
}
|
19
|
-
},
|
20
|
-
height: {
|
21
|
-
defaultValue: 'auto',
|
22
|
-
control: {
|
23
|
-
type: 'radio',
|
24
|
-
options: ['small', 'large', 'auto']
|
25
|
-
}
|
26
|
-
},
|
27
|
-
subtitle: {
|
28
|
-
name: 'show subtitle',
|
29
|
-
defaultValue: true,
|
30
|
-
control: {
|
31
|
-
type: 'boolean'
|
32
|
-
}
|
33
|
-
},
|
34
|
-
title: {
|
35
|
-
table: {
|
36
|
-
disable: true
|
37
|
-
}
|
38
|
-
},
|
39
|
-
renderHeader: {
|
40
|
-
table: {
|
41
|
-
disable: true
|
42
|
-
}
|
43
|
-
},
|
44
|
-
renderBody: {
|
45
|
-
table: {
|
46
|
-
disable: true
|
47
|
-
}
|
48
|
-
},
|
49
|
-
renderFooter: {
|
50
|
-
table: {
|
51
|
-
disable: true
|
52
|
-
}
|
53
|
-
},
|
54
|
-
onClose: {
|
55
|
-
table: {
|
56
|
-
disable: true
|
57
|
-
}
|
58
|
-
},
|
59
|
-
role: {
|
60
|
-
table: {
|
61
|
-
disable: true
|
62
|
-
}
|
63
|
-
},
|
64
|
-
ref: {
|
65
|
-
table: {
|
66
|
-
disable: true
|
67
|
-
}
|
68
|
-
},
|
69
|
-
key: {
|
70
|
-
table: {
|
71
|
-
disable: true
|
72
|
-
}
|
73
|
-
},
|
74
|
-
footerButtons: {
|
75
|
-
table: {
|
76
|
-
disable: true
|
77
|
-
}
|
78
|
-
}
|
79
|
-
}
|
80
|
-
};
|
81
|
-
const lipsum = /*#__PURE__*/React.createElement("div", {
|
82
|
-
style: {
|
83
|
-
fontSize: '14px'
|
84
|
-
}
|
85
|
-
}, /*#__PURE__*/React.createElement("p", {
|
86
|
-
style: {
|
87
|
-
marginBlockStart: 0
|
88
|
-
}
|
89
|
-
}, "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque sollicitudin mauris maximus elit sagittis, nec lobortis ligula elementum. Nam iaculis, urna nec lobortis posuere, eros urna venenatis eros, vel accumsan turpis nunc vitae enim. Maecenas et lorem lectus. Vivamus iaculis tortor eget ante placerat, nec posuere nisl tincidunt. Cras condimentum ante in accumsan ultricies. Morbi quis porta est, sit amet congue augue. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Ut consequat nunc id quam tempus, id tincidunt neque venenatis. Mauris fringilla tempor est, vitae fermentum enim elementum vitae. Nullam eleifend odio ut porta efficitur. Phasellus luctus tempus posuere."), /*#__PURE__*/React.createElement("p", null, "Curabitur scelerisque bibendum faucibus. Duis rhoncus nunc est, at pharetra eros tristique a. Nam sodales turpis lectus, quis faucibus felis fermentum in. Curabitur vel velit vel eros laoreet pharetra. Aenean in facilisis sapien, eu porttitor ex. Donec ultrices ac arcu ut lobortis. Pellentesque vitae rutrum orci. Etiam pretium et enim sit amet scelerisque. Nulla sed odio nec lorem dapibus condimentum at sagittis quam. Sed in ornare ex, sed luctus sem. Mauris a est tellus."), /*#__PURE__*/React.createElement("p", null, "Sed fringilla est ac urna aliquet, eget condimentum felis vulputate. Sed sagittis eros non mauris sodales molestie. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia curae; Nullam ante leo, condimentum sed lectus non, rutrum octopodes urna. Mauris neque ante, interdum molestie tellus pharetra, eleifend dapibus justo. Sed at diam ligula. Donec dapibus ipsum quis elit euismod, sed suscipit eros euismod. Aliquam pretium felis quis risus luctus fringilla. Ut purus lacus, mattis a turpis eget, sollicitudin pellentesque neque."), /*#__PURE__*/React.createElement("p", null, "Nunc sodales quis ante quis porttitor. Vestibulum ornare lacinia ante. Donec a nisi nec arcu aliquam pretium in nec nunc. Donec fringilla erat vitae viverra feugiat. Sed non odio vel ipsum porttitor maximus. Donec id eleifend lectus. Proin varius felis sit amet neque eleifend, vitae porttitor ligula commodo."), /*#__PURE__*/React.createElement("p", null, "Vivamus felis quam, porttitor a justo sit amet, placerat ultricies nisl. Suspendisse potenti. Maecenas non consequat lorem, eu porta ante. Pellentesque elementum diam sapien, nec ultrices risus convallis eget. Nam pharetra dolor at dictum tempor. Quisque ut est a ligula hendrerit sodales. Curabitur ornare a nulla in laoreet. Maecenas semper mi egestas, dignissim nisi et, elementum neque."));
|
90
|
-
export const BasicDialog = ({
|
91
|
-
width,
|
92
|
-
height,
|
93
|
-
subtitle
|
94
|
-
}) => {
|
95
|
-
const [isOpen, setIsOpen] = useState(false);
|
96
|
-
const [secondOpen, setSecondOpen] = useState(false);
|
97
|
-
const buttonRef = useRef(null);
|
98
|
-
const onDialogClose = useCallback(() => setIsOpen(false), []);
|
99
|
-
const onSecondDialogClose = useCallback(() => setSecondOpen(false), []);
|
100
|
-
const openSecondDialog = useCallback(() => setSecondOpen(true), []);
|
101
|
-
return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(Button, {
|
102
|
-
ref: buttonRef,
|
103
|
-
onClick: () => setIsOpen(!isOpen)
|
104
|
-
}, "Show dialog"), isOpen && /*#__PURE__*/React.createElement(Dialog, {
|
105
|
-
title: "My Dialog",
|
106
|
-
subtitle: subtitle ? 'This is a subtitle!' : undefined,
|
107
|
-
onClose: onDialogClose,
|
108
|
-
width: width,
|
109
|
-
height: height,
|
110
|
-
footerButtons: [{
|
111
|
-
buttonType: 'danger',
|
112
|
-
content: 'Delete the universe',
|
113
|
-
onClick: onDialogClose
|
114
|
-
}, {
|
115
|
-
buttonType: 'primary',
|
116
|
-
content: 'Proceed',
|
117
|
-
onClick: openSecondDialog,
|
118
|
-
autoFocus: true
|
119
|
-
}]
|
120
|
-
}, lipsum, secondOpen && /*#__PURE__*/React.createElement(Dialog, {
|
121
|
-
title: "Inner dialog!",
|
122
|
-
onClose: onSecondDialogClose,
|
123
|
-
width: "small"
|
124
|
-
}, "Hello world")));
|
125
|
-
};
|
126
|
-
|
127
|
-
function CustomHeader({
|
128
|
-
title,
|
129
|
-
subtitle,
|
130
|
-
dialogLabelId,
|
131
|
-
dialogDescriptionId,
|
132
|
-
onClose
|
133
|
-
}) {
|
134
|
-
const onCloseClick = useCallback(() => {
|
135
|
-
onClose('close-button');
|
136
|
-
}, [onClose]);
|
137
|
-
|
138
|
-
if (typeof title === 'string' && typeof subtitle === 'string') {
|
139
|
-
return /*#__PURE__*/React.createElement(Box, {
|
140
|
-
bg: "auto.blue.3"
|
141
|
-
}, /*#__PURE__*/React.createElement("h1", {
|
142
|
-
id: dialogLabelId
|
143
|
-
}, title.toUpperCase()), /*#__PURE__*/React.createElement("h2", {
|
144
|
-
id: dialogDescriptionId
|
145
|
-
}, subtitle.toLowerCase()), /*#__PURE__*/React.createElement(Dialog.CloseButton, {
|
146
|
-
onClose: onCloseClick
|
147
|
-
}));
|
148
|
-
}
|
149
|
-
|
150
|
-
return null;
|
151
|
-
}
|
152
|
-
|
153
|
-
function CustomBody({
|
154
|
-
children
|
155
|
-
}) {
|
156
|
-
return /*#__PURE__*/React.createElement(Dialog.Body, {
|
157
|
-
bg: "auto.red.3"
|
158
|
-
}, children);
|
159
|
-
}
|
160
|
-
|
161
|
-
CustomBody.displayName = "CustomBody";
|
162
|
-
|
163
|
-
function CustomFooter({
|
164
|
-
footerButtons
|
165
|
-
}) {
|
166
|
-
return /*#__PURE__*/React.createElement(Dialog.Footer, {
|
167
|
-
bg: "auto.yellow.3"
|
168
|
-
}, footerButtons ? /*#__PURE__*/React.createElement(Dialog.Buttons, {
|
169
|
-
buttons: footerButtons
|
170
|
-
}) : null);
|
171
|
-
}
|
172
|
-
|
173
|
-
CustomFooter.displayName = "CustomFooter";
|
174
|
-
export const WithCustomRenderers = ({
|
175
|
-
width,
|
176
|
-
height,
|
177
|
-
subtitle
|
178
|
-
}) => {
|
179
|
-
const [isOpen, setIsOpen] = useState(false);
|
180
|
-
const onDialogClose = useCallback(() => setIsOpen(false), []);
|
181
|
-
return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(Button, {
|
182
|
-
onClick: () => setIsOpen(!isOpen)
|
183
|
-
}, "Show dialog"), isOpen && /*#__PURE__*/React.createElement(Dialog, {
|
184
|
-
title: "My Dialog",
|
185
|
-
subtitle: subtitle ? 'This is a subtitle!' : undefined,
|
186
|
-
width: width,
|
187
|
-
height: height,
|
188
|
-
renderHeader: CustomHeader,
|
189
|
-
renderBody: CustomBody,
|
190
|
-
renderFooter: CustomFooter,
|
191
|
-
onClose: onDialogClose,
|
192
|
-
footerButtons: [{
|
193
|
-
buttonType: 'danger',
|
194
|
-
content: 'Delete the universe',
|
195
|
-
onClick: onDialogClose
|
196
|
-
}, {
|
197
|
-
buttonType: 'primary',
|
198
|
-
content: 'Proceed'
|
199
|
-
}]
|
200
|
-
}, lipsum));
|
201
|
-
};
|
202
|
-
export const StressTest = ({
|
203
|
-
width,
|
204
|
-
height,
|
205
|
-
subtitle
|
206
|
-
}) => {
|
207
|
-
const [isOpen, setIsOpen] = useState(false);
|
208
|
-
const [secondOpen, setSecondOpen] = useState(false);
|
209
|
-
const buttonRef = useRef(null);
|
210
|
-
const onDialogClose = useCallback(() => setIsOpen(false), []);
|
211
|
-
const onSecondDialogClose = useCallback(() => setSecondOpen(false), []);
|
212
|
-
const openSecondDialog = useCallback(() => setSecondOpen(true), []);
|
213
|
-
const manyButtons = new Array(10).fill(undefined).map((_, i) => ({
|
214
|
-
content: `Button ${i}`
|
215
|
-
}));
|
216
|
-
return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(Button, {
|
217
|
-
ref: buttonRef,
|
218
|
-
onClick: () => setIsOpen(!isOpen)
|
219
|
-
}, "Show dialog"), isOpen && /*#__PURE__*/React.createElement(Dialog, {
|
220
|
-
title: "This dialog has a really long title. So long, in fact, that it should cause wrapping, going to multiple lines!.",
|
221
|
-
subtitle: subtitle ? "It's not a common scenario, sure, but what if the subtitle is generated from a really long value? Do we just break the dialog? Or do we handle it because we are pros?" : undefined,
|
222
|
-
onClose: onDialogClose,
|
223
|
-
width: width,
|
224
|
-
height: height,
|
225
|
-
footerButtons: [...manyButtons, {
|
226
|
-
buttonType: 'danger',
|
227
|
-
content: 'Delete the universe',
|
228
|
-
onClick: onDialogClose
|
229
|
-
}, {
|
230
|
-
buttonType: 'primary',
|
231
|
-
content: 'Proceed',
|
232
|
-
onClick: openSecondDialog,
|
233
|
-
autoFocus: true
|
234
|
-
}]
|
235
|
-
}, lipsum, secondOpen && /*#__PURE__*/React.createElement(Dialog, {
|
236
|
-
title: "Inner dialog!",
|
237
|
-
onClose: onSecondDialogClose,
|
238
|
-
width: "small"
|
239
|
-
}, "Hello world")));
|
240
|
-
};
|
@@ -1,12 +0,0 @@
|
|
1
|
-
/// <reference types="react" />
|
2
|
-
import { Meta } from '@storybook/react';
|
3
|
-
declare const meta: Meta;
|
4
|
-
export default meta;
|
5
|
-
export declare function FavoriteColorStory(): JSX.Element;
|
6
|
-
export declare namespace FavoriteColorStory {
|
7
|
-
var storyName: string;
|
8
|
-
}
|
9
|
-
export declare function ExternalAnchorStory(): JSX.Element;
|
10
|
-
export declare namespace ExternalAnchorStory {
|
11
|
-
var storyName: string;
|
12
|
-
}
|
@@ -1,94 +0,0 @@
|
|
1
|
-
function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
2
|
-
|
3
|
-
import React from 'react';
|
4
|
-
import { theme, ThemeProvider } from '..';
|
5
|
-
import BaseStyles from '../BaseStyles';
|
6
|
-
import Box from '../Box';
|
7
|
-
import { DropdownMenu, DropdownButton } from '../DropdownMenu';
|
8
|
-
import TextInput from '../TextInput';
|
9
|
-
const meta = {
|
10
|
-
title: 'Composite components/DropdownMenu',
|
11
|
-
component: DropdownMenu,
|
12
|
-
decorators: [Story => {
|
13
|
-
return /*#__PURE__*/React.createElement(ThemeProvider, {
|
14
|
-
theme: theme
|
15
|
-
}, /*#__PURE__*/React.createElement(BaseStyles, null, /*#__PURE__*/React.createElement(Story, null)));
|
16
|
-
}],
|
17
|
-
parameters: {
|
18
|
-
controls: {
|
19
|
-
disable: true
|
20
|
-
}
|
21
|
-
}
|
22
|
-
};
|
23
|
-
export default meta;
|
24
|
-
export function FavoriteColorStory() {
|
25
|
-
const items = React.useMemo(() => [{
|
26
|
-
text: '🔵 Cyan'
|
27
|
-
}, {
|
28
|
-
text: '🔴 Magenta'
|
29
|
-
}, {
|
30
|
-
text: '🟡 Yellow'
|
31
|
-
}], []);
|
32
|
-
const [selectedItem, setSelectedItem] = React.useState();
|
33
|
-
return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("h1", null, "Favorite Color"), /*#__PURE__*/React.createElement(TextInput, {
|
34
|
-
placeholder: "Input for focus testing",
|
35
|
-
sx: {
|
36
|
-
mb: 2
|
37
|
-
}
|
38
|
-
}), /*#__PURE__*/React.createElement("div", {
|
39
|
-
id: "favorite-color-label"
|
40
|
-
}, "Please select your favorite color:"), /*#__PURE__*/React.createElement(DropdownMenu, {
|
41
|
-
renderAnchor: ({
|
42
|
-
children,
|
43
|
-
'aria-labelledby': ariaLabelledBy,
|
44
|
-
...anchorProps
|
45
|
-
}) => /*#__PURE__*/React.createElement(DropdownButton, _extends({
|
46
|
-
"aria-labelledby": `favorite-color-label ${ariaLabelledBy}`
|
47
|
-
}, anchorProps), children),
|
48
|
-
placeholder: "\uD83C\uDFA8",
|
49
|
-
items: items,
|
50
|
-
selectedItem: selectedItem,
|
51
|
-
onChange: setSelectedItem
|
52
|
-
}));
|
53
|
-
}
|
54
|
-
FavoriteColorStory.storyName = 'Favorite Color';
|
55
|
-
export function ExternalAnchorStory() {
|
56
|
-
const items = React.useMemo(() => [{
|
57
|
-
text: '🔵 Cyan'
|
58
|
-
}, {
|
59
|
-
text: '🔴 Magenta'
|
60
|
-
}, {
|
61
|
-
text: '🟡 Yellow'
|
62
|
-
}], []);
|
63
|
-
const [selectedItem, setSelectedItem] = React.useState();
|
64
|
-
const anchorRef = React.useRef(null);
|
65
|
-
const [open, setOpen] = React.useState(false);
|
66
|
-
return /*#__PURE__*/React.createElement(Box, {
|
67
|
-
display: "flex",
|
68
|
-
flexDirection: "column",
|
69
|
-
alignItems: "flex-start"
|
70
|
-
}, /*#__PURE__*/React.createElement(Box, {
|
71
|
-
display: "flex",
|
72
|
-
flexDirection: "row"
|
73
|
-
}, /*#__PURE__*/React.createElement(DropdownButton, {
|
74
|
-
onClick: () => setOpen(true)
|
75
|
-
}, "Click me to open the dropdown"), /*#__PURE__*/React.createElement(Box, {
|
76
|
-
ref: anchorRef,
|
77
|
-
bg: "papayawhip",
|
78
|
-
p: 4,
|
79
|
-
ml: 40,
|
80
|
-
borderRadius: 2,
|
81
|
-
display: "inline-block"
|
82
|
-
}, "Anchored on me!")), /*#__PURE__*/React.createElement(DropdownMenu, {
|
83
|
-
renderAnchor: null,
|
84
|
-
anchorRef: anchorRef,
|
85
|
-
open: open,
|
86
|
-
onOpenChange: setOpen,
|
87
|
-
placeholder: "\uD83C\uDFA8",
|
88
|
-
items: items,
|
89
|
-
selectedItem: selectedItem,
|
90
|
-
onChange: setSelectedItem
|
91
|
-
}));
|
92
|
-
}
|
93
|
-
ExternalAnchorStory.displayName = "ExternalAnchorStory";
|
94
|
-
ExternalAnchorStory.storyName = 'DropdownMenu with External Anchor';
|
@@ -1,7 +0,0 @@
|
|
1
|
-
/// <reference types="react" />
|
2
|
-
import { Meta } from '@storybook/react';
|
3
|
-
declare const _default: Meta<import("@storybook/react").Args>;
|
4
|
-
export default _default;
|
5
|
-
export declare const DropdownOverlay: () => JSX.Element;
|
6
|
-
export declare const DialogOverlay: () => JSX.Element;
|
7
|
-
export declare const OverlayOnTopOfOverlay: () => JSX.Element;
|
@@ -1,154 +0,0 @@
|
|
1
|
-
function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
2
|
-
|
3
|
-
import React, { useState, useRef, useCallback } from 'react';
|
4
|
-
import styled from 'styled-components';
|
5
|
-
import { BaseStyles, Overlay, Button, Text, ButtonDanger, ThemeProvider, Box } from '..';
|
6
|
-
import { DropdownMenu, DropdownButton } from '../DropdownMenu';
|
7
|
-
export default {
|
8
|
-
title: 'Internal components/Overlay',
|
9
|
-
component: Overlay,
|
10
|
-
decorators: [Story => {
|
11
|
-
return /*#__PURE__*/React.createElement(ThemeProvider, null, /*#__PURE__*/React.createElement(BaseStyles, null, /*#__PURE__*/React.createElement(Story, null)));
|
12
|
-
}]
|
13
|
-
};
|
14
|
-
const DummyItem = styled.button.withConfig({
|
15
|
-
displayName: "Overlaystories__DummyItem",
|
16
|
-
componentId: "sc-92ppmu-0"
|
17
|
-
})(["border-radius:6px;font-weight:400;padding:6px 8px;font-weight:400;text-align:left;margin:0;font-size:14px;background:none;border:none;&:hover{background:#f0f3f5;}&:focus{background:red;}"]);
|
18
|
-
export const DropdownOverlay = () => {
|
19
|
-
const [isOpen, setIsOpen] = useState(false);
|
20
|
-
const buttonRef = useRef(null);
|
21
|
-
return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(Button, {
|
22
|
-
ref: buttonRef,
|
23
|
-
sx: {
|
24
|
-
position: 'relative'
|
25
|
-
},
|
26
|
-
onClick: () => setIsOpen(!isOpen)
|
27
|
-
}, "open overlay"), isOpen ? /*#__PURE__*/React.createElement(Overlay, {
|
28
|
-
returnFocusRef: buttonRef,
|
29
|
-
height: "auto",
|
30
|
-
width: "small",
|
31
|
-
ignoreClickRefs: [buttonRef],
|
32
|
-
onEscape: () => setIsOpen(false),
|
33
|
-
onClickOutside: () => setIsOpen(false)
|
34
|
-
}, /*#__PURE__*/React.createElement(Box, {
|
35
|
-
display: "flex",
|
36
|
-
flexDirection: "column",
|
37
|
-
p: 2
|
38
|
-
}, /*#__PURE__*/React.createElement(DummyItem, null, "Copy link"), /*#__PURE__*/React.createElement(DummyItem, null, "Quote reply"), /*#__PURE__*/React.createElement(DummyItem, null, "Reference in new issue"), /*#__PURE__*/React.createElement(DummyItem, null, "Edit"), /*#__PURE__*/React.createElement(DummyItem, null, "Delete"))) : null);
|
39
|
-
};
|
40
|
-
export const DialogOverlay = () => {
|
41
|
-
const [isOpen, setIsOpen] = useState(false);
|
42
|
-
const buttonRef = useRef(null);
|
43
|
-
const confirmButtonRef = useRef(null);
|
44
|
-
const anchorRef = useRef(null);
|
45
|
-
|
46
|
-
const closeOverlay = () => setIsOpen(false);
|
47
|
-
|
48
|
-
return /*#__PURE__*/React.createElement(Box, {
|
49
|
-
position: "absolute",
|
50
|
-
top: 0,
|
51
|
-
left: 0,
|
52
|
-
bottom: 0,
|
53
|
-
right: 0,
|
54
|
-
ref: anchorRef
|
55
|
-
}, /*#__PURE__*/React.createElement(Button, {
|
56
|
-
ref: buttonRef,
|
57
|
-
onClick: () => setIsOpen(!isOpen)
|
58
|
-
}, "open overlay"), isOpen ? /*#__PURE__*/React.createElement(Overlay, {
|
59
|
-
initialFocusRef: confirmButtonRef,
|
60
|
-
returnFocusRef: buttonRef,
|
61
|
-
ignoreClickRefs: [buttonRef],
|
62
|
-
onEscape: closeOverlay,
|
63
|
-
onClickOutside: closeOverlay,
|
64
|
-
width: "small"
|
65
|
-
}, /*#__PURE__*/React.createElement(Box, {
|
66
|
-
display: "flex",
|
67
|
-
flexDirection: "column",
|
68
|
-
p: 2
|
69
|
-
}, /*#__PURE__*/React.createElement(Text, null, "Are you sure?"), /*#__PURE__*/React.createElement(ButtonDanger, {
|
70
|
-
onClick: closeOverlay
|
71
|
-
}, "Cancel"), /*#__PURE__*/React.createElement(Button, {
|
72
|
-
onClick: closeOverlay,
|
73
|
-
ref: confirmButtonRef
|
74
|
-
}, "Confirm"))) : null);
|
75
|
-
};
|
76
|
-
DialogOverlay.displayName = "DialogOverlay";
|
77
|
-
export const OverlayOnTopOfOverlay = () => {
|
78
|
-
const [isOpen, setIsOpen] = useState(false);
|
79
|
-
const [isSecondaryOpen, setIsSecondaryOpen] = useState(false);
|
80
|
-
const buttonRef = useRef(null);
|
81
|
-
const secondaryButtonRef = useRef(null);
|
82
|
-
const confirmButtonRef = useRef(null);
|
83
|
-
const anchorRef = useRef(null);
|
84
|
-
|
85
|
-
const closeOverlay = () => setIsOpen(false); // intentionally not memoized
|
86
|
-
|
87
|
-
|
88
|
-
const closeSecondaryOverlay = useCallback(() => setIsSecondaryOpen(false), [setIsSecondaryOpen]);
|
89
|
-
const items = React.useMemo(() => [{
|
90
|
-
text: '🔵 Cyan',
|
91
|
-
onMouseDown: e => {
|
92
|
-
e.preventDefault();
|
93
|
-
}
|
94
|
-
}, {
|
95
|
-
text: '🔴 Magenta',
|
96
|
-
onMouseDown: e => {
|
97
|
-
e.preventDefault();
|
98
|
-
}
|
99
|
-
}, {
|
100
|
-
text: '🟡 Yellow',
|
101
|
-
onMouseDown: e => {
|
102
|
-
e.preventDefault();
|
103
|
-
}
|
104
|
-
}], []);
|
105
|
-
const [selectedItem, setSelectedItem] = React.useState();
|
106
|
-
return /*#__PURE__*/React.createElement(Box, {
|
107
|
-
position: "absolute",
|
108
|
-
top: 0,
|
109
|
-
left: 0,
|
110
|
-
bottom: 0,
|
111
|
-
right: 0,
|
112
|
-
ref: anchorRef
|
113
|
-
}, /*#__PURE__*/React.createElement("input", {
|
114
|
-
placeholder: "Input for focus testing"
|
115
|
-
}), /*#__PURE__*/React.createElement("br", null), /*#__PURE__*/React.createElement(Button, {
|
116
|
-
ref: buttonRef,
|
117
|
-
onClick: () => setIsOpen(!isOpen)
|
118
|
-
}, "open overlay"), isOpen ? /*#__PURE__*/React.createElement(Overlay, {
|
119
|
-
initialFocusRef: confirmButtonRef,
|
120
|
-
returnFocusRef: buttonRef,
|
121
|
-
onEscape: closeOverlay,
|
122
|
-
onClickOutside: closeOverlay,
|
123
|
-
width: "small"
|
124
|
-
}, /*#__PURE__*/React.createElement(Button, {
|
125
|
-
ref: secondaryButtonRef,
|
126
|
-
onClick: () => setIsSecondaryOpen(!isSecondaryOpen)
|
127
|
-
}, "open overlay"), isSecondaryOpen ? /*#__PURE__*/React.createElement(Overlay, {
|
128
|
-
initialFocusRef: confirmButtonRef,
|
129
|
-
returnFocusRef: secondaryButtonRef,
|
130
|
-
onEscape: closeSecondaryOverlay,
|
131
|
-
onClickOutside: closeSecondaryOverlay,
|
132
|
-
width: "small",
|
133
|
-
sx: {
|
134
|
-
top: '40px'
|
135
|
-
}
|
136
|
-
}, /*#__PURE__*/React.createElement(Box, {
|
137
|
-
display: "flex",
|
138
|
-
flexDirection: "column",
|
139
|
-
p: 2
|
140
|
-
}, /*#__PURE__*/React.createElement(Text, null, "Select an option!"), /*#__PURE__*/React.createElement(DropdownMenu, {
|
141
|
-
renderAnchor: ({
|
142
|
-
children,
|
143
|
-
'aria-labelledby': ariaLabelledBy,
|
144
|
-
...anchorProps
|
145
|
-
}) => /*#__PURE__*/React.createElement(DropdownButton, _extends({
|
146
|
-
"aria-labelledby": `favorite-color-label ${ariaLabelledBy}`
|
147
|
-
}, anchorProps), children),
|
148
|
-
placeholder: "\uD83C\uDFA8",
|
149
|
-
items: items,
|
150
|
-
selectedItem: selectedItem,
|
151
|
-
onChange: setSelectedItem
|
152
|
-
}))) : null) : null);
|
153
|
-
};
|
154
|
-
OverlayOnTopOfOverlay.displayName = "OverlayOnTopOfOverlay";
|
@@ -1,8 +0,0 @@
|
|
1
|
-
import React from 'react';
|
2
|
-
import { Meta } from '@storybook/react';
|
3
|
-
declare const _default: Meta<import("@storybook/react").Args>;
|
4
|
-
export default _default;
|
5
|
-
export declare const defaultPortal: () => JSX.Element;
|
6
|
-
export declare const customPortalRootById: () => JSX.Element;
|
7
|
-
export declare const CustomPortalRootByRegistration: React.FC<Record<string, never>>;
|
8
|
-
export declare const MultiplePortalRoots: React.FC<Record<string, never>>;
|
@@ -1,68 +0,0 @@
|
|
1
|
-
import React from 'react';
|
2
|
-
import { BaseStyles, Box, ThemeProvider } from '..';
|
3
|
-
import Portal, { registerPortalRoot } from '../Portal';
|
4
|
-
export default {
|
5
|
-
title: 'Generic behaviors/Portal',
|
6
|
-
component: Portal,
|
7
|
-
decorators: [Story => {
|
8
|
-
return /*#__PURE__*/React.createElement(ThemeProvider, null, /*#__PURE__*/React.createElement(BaseStyles, null, /*#__PURE__*/React.createElement(Story, null)));
|
9
|
-
}]
|
10
|
-
};
|
11
|
-
export const defaultPortal = () => /*#__PURE__*/React.createElement(React.Fragment, null, "Root position", /*#__PURE__*/React.createElement(Box, {
|
12
|
-
bg: "red.2",
|
13
|
-
p: 3
|
14
|
-
}, "Outer container", /*#__PURE__*/React.createElement(Box, {
|
15
|
-
bg: "green.2",
|
16
|
-
p: 3
|
17
|
-
}, "Inner container", /*#__PURE__*/React.createElement(Portal, null, "Portaled content rendered at ", /*#__PURE__*/React.createElement("code", null, "<BaseStyles>"), " root."))));
|
18
|
-
export const customPortalRootById = () => /*#__PURE__*/React.createElement(React.Fragment, null, "Root position", /*#__PURE__*/React.createElement(Box, {
|
19
|
-
bg: "red.2",
|
20
|
-
p: 3,
|
21
|
-
id: "__primerPortalRoot__"
|
22
|
-
}, "Outer container", /*#__PURE__*/React.createElement(Box, {
|
23
|
-
bg: "green.2",
|
24
|
-
p: 3
|
25
|
-
}, "Inner container", /*#__PURE__*/React.createElement(Portal, null, "Portaled content rendered at the outer container."))));
|
26
|
-
export const CustomPortalRootByRegistration = () => {
|
27
|
-
const outerContainerRef = React.useRef(null);
|
28
|
-
const [mounted, setMounted] = React.useState(false);
|
29
|
-
React.useEffect(() => {
|
30
|
-
if (outerContainerRef.current instanceof HTMLElement) {
|
31
|
-
registerPortalRoot(outerContainerRef.current);
|
32
|
-
setMounted(true);
|
33
|
-
}
|
34
|
-
}, []);
|
35
|
-
return /*#__PURE__*/React.createElement(React.Fragment, null, "Root position", /*#__PURE__*/React.createElement(Box, {
|
36
|
-
bg: "red.2",
|
37
|
-
p: 3,
|
38
|
-
ref: outerContainerRef
|
39
|
-
}, mounted ? /*#__PURE__*/React.createElement(React.Fragment, null, "Outer container", /*#__PURE__*/React.createElement(Box, {
|
40
|
-
bg: "green.2",
|
41
|
-
p: 3
|
42
|
-
}, "Inner container", /*#__PURE__*/React.createElement(Portal, null, "Portaled content rendered at the outer container."))) : null));
|
43
|
-
};
|
44
|
-
export const MultiplePortalRoots = () => {
|
45
|
-
const outerContainerRef = React.useRef(null);
|
46
|
-
const innerContainerRef = React.useRef(null);
|
47
|
-
const [mounted, setMounted] = React.useState(false);
|
48
|
-
React.useEffect(() => {
|
49
|
-
if (outerContainerRef.current instanceof HTMLElement && innerContainerRef.current instanceof HTMLElement) {
|
50
|
-
registerPortalRoot(outerContainerRef.current, 'outer');
|
51
|
-
registerPortalRoot(innerContainerRef.current, 'inner');
|
52
|
-
setMounted(true);
|
53
|
-
}
|
54
|
-
}, [outerContainerRef]);
|
55
|
-
return /*#__PURE__*/React.createElement(React.Fragment, null, "Root position", /*#__PURE__*/React.createElement(Box, {
|
56
|
-
bg: "red.2",
|
57
|
-
p: 3,
|
58
|
-
ref: outerContainerRef
|
59
|
-
}, "Outer container", /*#__PURE__*/React.createElement(Box, {
|
60
|
-
bg: "green.2",
|
61
|
-
p: 3,
|
62
|
-
ref: innerContainerRef
|
63
|
-
}, mounted ? /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(Portal, {
|
64
|
-
containerName: "outer"
|
65
|
-
}, "Portaled content rendered at the outer container."), /*#__PURE__*/React.createElement(Portal, {
|
66
|
-
containerName: "inner"
|
67
|
-
}, "Portaled content rendered at the end of the inner container."), /*#__PURE__*/React.createElement(Portal, null, "Portaled content rendered at ", /*#__PURE__*/React.createElement("code", null, "<BaseStyles>"), " root.")) : null, "Inner container")));
|
68
|
-
};
|
@@ -1,32 +0,0 @@
|
|
1
|
-
/// <reference types="react" />
|
2
|
-
import { Meta } from '@storybook/react';
|
3
|
-
declare const meta: Meta;
|
4
|
-
export default meta;
|
5
|
-
export declare function MultiSelectStory(): JSX.Element;
|
6
|
-
export declare namespace MultiSelectStory {
|
7
|
-
var storyName: string;
|
8
|
-
}
|
9
|
-
export declare function SingleSelectStory(): JSX.Element;
|
10
|
-
export declare namespace SingleSelectStory {
|
11
|
-
var storyName: string;
|
12
|
-
}
|
13
|
-
export declare function ExternalAnchorStory(): JSX.Element;
|
14
|
-
export declare namespace ExternalAnchorStory {
|
15
|
-
var storyName: string;
|
16
|
-
}
|
17
|
-
export declare function SelectPanelHeightInitialWithOverflowingItemsStory(): JSX.Element;
|
18
|
-
export declare namespace SelectPanelHeightInitialWithOverflowingItemsStory {
|
19
|
-
var storyName: string;
|
20
|
-
}
|
21
|
-
export declare function SelectPanelHeightInitialWithUnderflowingItemsStory(): JSX.Element;
|
22
|
-
export declare namespace SelectPanelHeightInitialWithUnderflowingItemsStory {
|
23
|
-
var storyName: string;
|
24
|
-
}
|
25
|
-
export declare function SelectPanelHeightInitialWithUnderflowingItemsAfterFetch(): JSX.Element;
|
26
|
-
export declare namespace SelectPanelHeightInitialWithUnderflowingItemsAfterFetch {
|
27
|
-
var storyName: string;
|
28
|
-
}
|
29
|
-
export declare function SelectPanelAboveTallBody(): JSX.Element;
|
30
|
-
export declare namespace SelectPanelAboveTallBody {
|
31
|
-
var storyName: string;
|
32
|
-
}
|