@dxc-technology/halstack-react 0.0.0-efa7c74 → 0.0.0-eff2879
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/BackgroundColorContext.d.ts +1 -0
- package/BackgroundColorContext.js +6 -26
- package/HalstackContext.d.ts +1248 -0
- package/HalstackContext.js +310 -0
- package/README.md +47 -0
- package/accordion/Accordion.accessibility.test.js +71 -0
- package/accordion/Accordion.d.ts +1 -1
- package/accordion/Accordion.js +106 -193
- package/accordion/Accordion.stories.tsx +251 -0
- package/accordion/Accordion.test.js +56 -0
- package/accordion/types.d.ts +12 -23
- package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
- package/accordion-group/AccordionGroup.d.ts +3 -3
- package/accordion-group/AccordionGroup.js +39 -108
- package/accordion-group/AccordionGroup.stories.tsx +252 -0
- package/accordion-group/AccordionGroup.test.js +98 -0
- package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
- package/accordion-group/AccordionGroupAccordion.js +31 -0
- package/accordion-group/AccordionGroupContext.d.ts +3 -0
- package/accordion-group/AccordionGroupContext.js +8 -0
- package/accordion-group/types.d.ts +18 -23
- package/action-icon/ActionIcon.accessibility.test.js +63 -0
- package/action-icon/ActionIcon.d.ts +4 -0
- package/action-icon/ActionIcon.js +48 -0
- package/action-icon/ActionIcon.stories.tsx +41 -0
- package/action-icon/ActionIcon.test.js +64 -0
- package/action-icon/types.d.ts +26 -0
- package/alert/Alert.accessibility.test.js +95 -0
- package/alert/Alert.js +36 -126
- package/alert/Alert.stories.tsx +28 -0
- package/alert/Alert.test.js +75 -0
- package/alert/types.d.ts +5 -5
- package/badge/Badge.accessibility.test.js +129 -0
- package/badge/Badge.d.ts +4 -0
- package/badge/Badge.js +142 -40
- package/badge/Badge.stories.tsx +210 -0
- package/badge/Badge.test.js +30 -0
- package/badge/types.d.ts +54 -0
- package/bleed/Bleed.d.ts +3 -0
- package/bleed/Bleed.js +43 -0
- package/bleed/Bleed.stories.tsx +342 -0
- package/bleed/types.d.ts +37 -0
- package/box/Box.accessibility.test.js +33 -0
- package/box/Box.d.ts +1 -1
- package/box/Box.js +31 -82
- package/box/Box.stories.tsx +38 -51
- package/box/Box.test.js +13 -0
- package/box/types.d.ts +3 -14
- package/bulleted-list/BulletedList.accessibility.test.js +107 -0
- package/bulleted-list/BulletedList.d.ts +7 -0
- package/bulleted-list/BulletedList.js +92 -0
- package/bulleted-list/BulletedList.stories.tsx +115 -0
- package/bulleted-list/types.d.ts +38 -0
- package/bulleted-list/types.js +5 -0
- package/button/Button.accessibility.test.js +127 -0
- package/button/Button.d.ts +1 -1
- package/button/Button.js +65 -123
- package/button/Button.stories.tsx +155 -106
- package/button/Button.test.js +38 -0
- package/button/types.d.ts +12 -12
- package/card/Card.accessibility.test.js +36 -0
- package/card/Card.d.ts +1 -1
- package/card/Card.js +59 -103
- package/card/Card.stories.tsx +13 -43
- package/card/Card.test.js +39 -0
- package/card/types.d.ts +6 -11
- package/checkbox/Checkbox.accessibility.test.js +87 -0
- package/checkbox/Checkbox.d.ts +2 -2
- package/checkbox/Checkbox.js +145 -183
- package/checkbox/Checkbox.stories.tsx +166 -136
- package/checkbox/Checkbox.test.js +199 -0
- package/checkbox/types.d.ts +19 -7
- package/chip/Chip.accessibility.test.js +67 -0
- package/chip/Chip.d.ts +4 -0
- package/chip/Chip.js +49 -146
- package/chip/Chip.stories.tsx +104 -30
- package/chip/Chip.test.js +41 -0
- package/chip/types.d.ts +45 -0
- package/chip/types.js +5 -0
- package/common/coreTokens.d.ts +237 -0
- package/common/coreTokens.js +184 -0
- package/common/utils.d.ts +1 -0
- package/common/utils.js +6 -12
- package/common/variables.d.ts +1394 -0
- package/common/variables.js +1035 -1346
- package/container/Container.d.ts +4 -0
- package/container/Container.js +194 -0
- package/container/Container.stories.tsx +214 -0
- package/container/types.d.ts +74 -0
- package/container/types.js +5 -0
- package/contextual-menu/ContextualMenu.accessibility.test.js +86 -0
- package/contextual-menu/ContextualMenu.d.ts +5 -0
- package/contextual-menu/ContextualMenu.js +88 -0
- package/contextual-menu/ContextualMenu.stories.tsx +219 -0
- package/contextual-menu/ContextualMenu.test.js +205 -0
- package/contextual-menu/GroupItem.d.ts +4 -0
- package/contextual-menu/GroupItem.js +67 -0
- package/contextual-menu/ItemAction.d.ts +4 -0
- package/contextual-menu/ItemAction.js +52 -0
- package/contextual-menu/MenuItem.d.ts +4 -0
- package/contextual-menu/MenuItem.js +29 -0
- package/contextual-menu/SingleItem.d.ts +4 -0
- package/contextual-menu/SingleItem.js +38 -0
- package/contextual-menu/types.d.ts +58 -0
- package/contextual-menu/types.js +5 -0
- package/date-input/Calendar.d.ts +4 -0
- package/date-input/Calendar.js +214 -0
- package/date-input/DateInput.accessibility.test.js +216 -0
- package/date-input/DateInput.js +174 -313
- package/date-input/DateInput.stories.tsx +203 -56
- package/date-input/DateInput.test.js +808 -0
- package/date-input/DatePicker.d.ts +4 -0
- package/date-input/DatePicker.js +121 -0
- package/date-input/YearPicker.d.ts +4 -0
- package/date-input/YearPicker.js +100 -0
- package/date-input/types.d.ts +86 -22
- package/dialog/Dialog.accessibility.test.js +69 -0
- package/dialog/Dialog.d.ts +1 -1
- package/dialog/Dialog.js +57 -130
- package/dialog/Dialog.stories.tsx +320 -167
- package/dialog/Dialog.test.js +307 -0
- package/dialog/types.d.ts +18 -25
- package/divider/Divider.accessibility.test.js +33 -0
- package/divider/Divider.d.ts +4 -0
- package/divider/Divider.js +36 -0
- package/divider/Divider.stories.tsx +223 -0
- package/divider/Divider.test.js +38 -0
- package/divider/types.d.ts +21 -0
- package/divider/types.js +5 -0
- package/dropdown/Dropdown.accessibility.test.js +180 -0
- package/dropdown/Dropdown.d.ts +1 -1
- package/dropdown/Dropdown.js +232 -330
- package/dropdown/Dropdown.stories.tsx +427 -0
- package/dropdown/Dropdown.test.js +599 -0
- package/dropdown/DropdownMenu.d.ts +4 -0
- package/dropdown/DropdownMenu.js +63 -0
- package/dropdown/DropdownMenuItem.d.ts +4 -0
- package/dropdown/DropdownMenuItem.js +70 -0
- package/dropdown/types.d.ts +38 -31
- package/file-input/FileInput.accessibility.test.js +160 -0
- package/file-input/FileInput.d.ts +2 -2
- package/file-input/FileInput.js +272 -340
- package/file-input/FileInput.stories.tsx +618 -0
- package/file-input/FileInput.test.js +382 -0
- package/file-input/FileItem.d.ts +4 -14
- package/file-input/FileItem.js +60 -121
- package/file-input/types.d.ts +53 -11
- package/flex/Flex.d.ts +4 -0
- package/flex/Flex.js +57 -0
- package/flex/Flex.stories.tsx +112 -0
- package/flex/types.d.ts +97 -0
- package/flex/types.js +5 -0
- package/footer/Footer.accessibility.test.js +117 -0
- package/footer/Footer.d.ts +1 -1
- package/footer/Footer.js +74 -200
- package/footer/{Footer.stories.jsx → Footer.stories.tsx} +84 -39
- package/footer/Footer.test.js +85 -0
- package/footer/Icons.d.ts +3 -0
- package/footer/Icons.js +67 -8
- package/footer/types.d.ts +40 -37
- package/grid/Grid.d.ts +7 -0
- package/grid/Grid.js +76 -0
- package/grid/Grid.stories.tsx +219 -0
- package/grid/types.d.ts +115 -0
- package/grid/types.js +5 -0
- package/header/Header.accessibility.test.js +84 -0
- package/header/Header.d.ts +4 -3
- package/header/Header.js +103 -218
- package/header/Header.stories.tsx +152 -63
- package/header/Header.test.js +66 -0
- package/header/Icons.d.ts +2 -0
- package/header/Icons.js +4 -9
- package/header/types.d.ts +7 -21
- package/heading/Heading.accessibility.test.js +33 -0
- package/heading/Heading.js +11 -33
- package/heading/Heading.stories.tsx +3 -2
- package/heading/Heading.test.js +169 -0
- package/heading/types.d.ts +7 -7
- package/icon/Icon.accessibility.test.js +30 -0
- package/icon/Icon.d.ts +4 -0
- package/icon/Icon.js +33 -0
- package/icon/Icon.stories.tsx +28 -0
- package/icon/types.d.ts +4 -0
- package/icon/types.js +5 -0
- package/image/Image.accessibility.test.js +56 -0
- package/image/Image.d.ts +4 -0
- package/image/Image.js +70 -0
- package/image/Image.stories.tsx +129 -0
- package/image/types.d.ts +72 -0
- package/image/types.js +5 -0
- package/inset/Inset.d.ts +3 -0
- package/inset/Inset.js +43 -0
- package/inset/Inset.stories.tsx +230 -0
- package/inset/types.d.ts +37 -0
- package/inset/types.js +5 -0
- package/layout/ApplicationLayout.d.ts +20 -0
- package/layout/ApplicationLayout.js +86 -184
- package/layout/ApplicationLayout.stories.tsx +162 -0
- package/layout/Icons.d.ts +7 -0
- package/layout/Icons.js +41 -48
- package/layout/types.d.ts +41 -0
- package/layout/types.js +5 -0
- package/link/Link.accessibility.test.js +112 -0
- package/link/Link.d.ts +3 -2
- package/link/Link.js +65 -109
- package/link/Link.stories.tsx +159 -52
- package/link/Link.test.js +63 -0
- package/link/types.d.ts +15 -35
- package/main.d.ts +19 -14
- package/main.js +92 -98
- package/nav-tabs/NavTabs.accessibility.test.js +44 -0
- package/nav-tabs/NavTabs.d.ts +7 -0
- package/nav-tabs/NavTabs.js +93 -0
- package/nav-tabs/NavTabs.stories.tsx +279 -0
- package/nav-tabs/NavTabs.test.js +75 -0
- package/nav-tabs/NavTabsContext.d.ts +3 -0
- package/nav-tabs/NavTabsContext.js +8 -0
- package/nav-tabs/Tab.d.ts +4 -0
- package/nav-tabs/Tab.js +117 -0
- package/nav-tabs/types.d.ts +52 -0
- package/nav-tabs/types.js +5 -0
- package/number-input/NumberInput.accessibility.test.js +228 -0
- package/number-input/NumberInput.js +48 -48
- package/number-input/NumberInput.stories.tsx +44 -28
- package/number-input/NumberInput.test.js +989 -0
- package/number-input/NumberInputContext.d.ts +3 -4
- package/number-input/NumberInputContext.js +3 -14
- package/number-input/types.d.ts +34 -15
- package/package.json +52 -51
- package/paginator/Paginator.accessibility.test.js +79 -0
- package/paginator/Paginator.js +39 -103
- package/paginator/Paginator.stories.tsx +24 -0
- package/paginator/Paginator.test.js +335 -0
- package/paginator/types.d.ts +3 -3
- package/paragraph/Paragraph.accessibility.test.js +28 -0
- package/paragraph/Paragraph.d.ts +5 -0
- package/paragraph/Paragraph.js +22 -0
- package/paragraph/Paragraph.stories.tsx +27 -0
- package/password-input/PasswordInput.accessibility.test.js +153 -0
- package/password-input/PasswordInput.js +59 -125
- package/password-input/PasswordInput.stories.tsx +3 -35
- package/password-input/PasswordInput.test.js +198 -0
- package/password-input/types.d.ts +32 -26
- package/progress-bar/ProgressBar.accessibility.test.js +35 -0
- package/progress-bar/ProgressBar.js +66 -92
- package/progress-bar/ProgressBar.stories.tsx +93 -0
- package/progress-bar/ProgressBar.test.js +93 -0
- package/progress-bar/types.d.ts +3 -3
- package/quick-nav/QuickNav.accessibility.test.js +57 -0
- package/quick-nav/QuickNav.d.ts +4 -0
- package/quick-nav/QuickNav.js +94 -0
- package/quick-nav/QuickNav.stories.tsx +356 -0
- package/quick-nav/types.d.ts +21 -0
- package/quick-nav/types.js +5 -0
- package/radio-group/Radio.d.ts +4 -0
- package/radio-group/Radio.js +124 -0
- package/radio-group/RadioGroup.accessibility.test.js +97 -0
- package/radio-group/RadioGroup.d.ts +4 -0
- package/radio-group/RadioGroup.js +235 -0
- package/radio-group/RadioGroup.stories.tsx +214 -0
- package/radio-group/RadioGroup.test.js +756 -0
- package/radio-group/types.d.ts +114 -0
- package/radio-group/types.js +5 -0
- package/resultset-table/Icons.d.ts +7 -0
- package/resultset-table/Icons.js +47 -0
- package/resultset-table/ResultsetTable.accessibility.test.js +274 -0
- package/resultset-table/ResultsetTable.d.ts +7 -0
- package/resultset-table/ResultsetTable.js +170 -0
- package/resultset-table/ResultsetTable.stories.tsx +401 -0
- package/resultset-table/ResultsetTable.test.js +381 -0
- package/resultset-table/types.d.ts +100 -0
- package/resultset-table/types.js +5 -0
- package/select/Listbox.d.ts +4 -0
- package/select/Listbox.js +145 -0
- package/select/Option.d.ts +4 -0
- package/select/Option.js +88 -0
- package/select/Select.accessibility.test.js +217 -0
- package/select/Select.d.ts +4 -0
- package/select/Select.js +248 -515
- package/select/Select.stories.tsx +590 -255
- package/select/Select.test.js +2276 -0
- package/select/types.d.ts +209 -0
- package/select/types.js +5 -0
- package/sidenav/Sidenav.accessibility.test.js +59 -0
- package/sidenav/Sidenav.d.ts +6 -5
- package/sidenav/Sidenav.js +137 -72
- package/sidenav/Sidenav.stories.tsx +246 -134
- package/sidenav/Sidenav.test.js +37 -0
- package/sidenav/SidenavContext.d.ts +5 -0
- package/sidenav/SidenavContext.js +13 -0
- package/sidenav/types.d.ts +52 -26
- package/slider/Slider.accessibility.test.js +104 -0
- package/slider/Slider.d.ts +2 -2
- package/slider/Slider.js +149 -181
- package/slider/Slider.test.js +254 -0
- package/slider/types.d.ts +11 -3
- package/spinner/Spinner.accessibility.test.js +96 -0
- package/spinner/Spinner.js +32 -76
- package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -26
- package/spinner/Spinner.test.js +55 -0
- package/spinner/types.d.ts +3 -3
- package/status-light/StatusLight.accessibility.test.js +157 -0
- package/status-light/StatusLight.d.ts +4 -0
- package/status-light/StatusLight.js +51 -0
- package/status-light/StatusLight.stories.tsx +74 -0
- package/status-light/StatusLight.test.js +25 -0
- package/status-light/types.d.ts +17 -0
- package/status-light/types.js +5 -0
- package/switch/Switch.accessibility.test.js +89 -0
- package/switch/Switch.d.ts +2 -2
- package/switch/Switch.js +150 -115
- package/switch/Switch.stories.tsx +45 -68
- package/switch/Switch.test.js +180 -0
- package/switch/types.d.ts +13 -5
- package/table/DropdownTheme.js +62 -0
- package/table/Table.accessibility.test.js +82 -0
- package/table/Table.d.ts +6 -2
- package/table/Table.js +79 -36
- package/table/Table.stories.tsx +651 -0
- package/table/Table.test.js +113 -0
- package/table/types.d.ts +34 -6
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +117 -0
- package/tabs/Tabs.accessibility.test.js +56 -0
- package/tabs/Tabs.d.ts +1 -1
- package/tabs/Tabs.js +307 -147
- package/tabs/Tabs.stories.tsx +121 -18
- package/tabs/Tabs.test.js +276 -0
- package/tabs/types.d.ts +46 -24
- package/tag/Tag.accessibility.test.js +69 -0
- package/tag/Tag.d.ts +1 -1
- package/tag/Tag.js +44 -86
- package/tag/Tag.stories.tsx +37 -30
- package/tag/Tag.test.js +41 -0
- package/tag/types.d.ts +25 -16
- package/text-input/Suggestion.d.ts +4 -0
- package/text-input/Suggestion.js +67 -0
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +86 -0
- package/text-input/TextInput.accessibility.test.js +321 -0
- package/text-input/TextInput.js +335 -553
- package/text-input/TextInput.stories.tsx +465 -0
- package/text-input/TextInput.test.js +1756 -0
- package/text-input/types.d.ts +82 -34
- package/textarea/Textarea.accessibility.test.js +155 -0
- package/textarea/Textarea.d.ts +4 -0
- package/textarea/Textarea.js +98 -181
- package/textarea/Textarea.stories.tsx +174 -0
- package/textarea/Textarea.test.js +406 -0
- package/textarea/types.d.ts +141 -0
- package/textarea/types.js +5 -0
- package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
- package/toggle-group/ToggleGroup.d.ts +2 -2
- package/toggle-group/ToggleGroup.js +98 -113
- package/toggle-group/ToggleGroup.stories.tsx +79 -39
- package/toggle-group/ToggleGroup.test.js +137 -0
- package/toggle-group/types.d.ts +68 -38
- package/typography/Typography.accessibility.test.js +339 -0
- package/typography/Typography.d.ts +4 -0
- package/typography/Typography.js +23 -0
- package/typography/Typography.stories.tsx +198 -0
- package/typography/types.d.ts +18 -0
- package/typography/types.js +5 -0
- package/useTheme.d.ts +1147 -0
- package/useTheme.js +4 -11
- package/useTranslatedLabels.d.ts +85 -0
- package/useTranslatedLabels.js +14 -0
- package/utils/BaseTypography.d.ts +21 -0
- package/utils/BaseTypography.js +94 -0
- package/utils/FocusLock.d.ts +13 -0
- package/utils/FocusLock.js +124 -0
- package/wizard/Wizard.accessibility.test.js +55 -0
- package/wizard/Wizard.d.ts +1 -1
- package/wizard/Wizard.js +130 -114
- package/wizard/{Wizard.stories.jsx → Wizard.stories.tsx} +67 -19
- package/wizard/Wizard.test.js +114 -0
- package/wizard/types.d.ts +15 -15
- package/ThemeContext.js +0 -246
- package/V3Select/V3Select.js +0 -455
- package/V3Select/index.d.ts +0 -27
- package/V3Textarea/V3Textarea.js +0 -260
- package/V3Textarea/index.d.ts +0 -27
- package/card/ice-cream.jpg +0 -0
- package/chip/index.d.ts +0 -22
- package/common/OpenSans.css +0 -81
- package/common/RequiredComponent.js +0 -32
- package/common/fonts/OpenSans-Bold.ttf +0 -0
- package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
- package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
- package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
- package/common/fonts/OpenSans-Italic.ttf +0 -0
- package/common/fonts/OpenSans-Light.ttf +0 -0
- package/common/fonts/OpenSans-LightItalic.ttf +0 -0
- package/common/fonts/OpenSans-Regular.ttf +0 -0
- package/common/fonts/OpenSans-SemiBold.ttf +0 -0
- package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
- package/date/Date.js +0 -373
- package/date/index.d.ts +0 -27
- package/input-text/Icons.js +0 -22
- package/input-text/InputText.js +0 -611
- package/input-text/index.d.ts +0 -36
- package/number-input/numberInputContextTypes.d.ts +0 -19
- package/paginator/Icons.js +0 -66
- package/progress-bar/ProgressBar.stories.jsx +0 -58
- package/radio/Radio.d.ts +0 -4
- package/radio/Radio.js +0 -174
- package/radio/Radio.stories.tsx +0 -192
- package/radio/types.d.ts +0 -54
- package/resultsetTable/ResultsetTable.d.ts +0 -4
- package/resultsetTable/ResultsetTable.js +0 -249
- package/resultsetTable/types.d.ts +0 -63
- package/select/index.d.ts +0 -131
- package/slider/Slider.stories.tsx +0 -177
- package/table/Table.stories.jsx +0 -276
- package/textarea/Textarea.stories.jsx +0 -135
- package/textarea/index.d.ts +0 -117
- package/toggle/Toggle.js +0 -186
- package/toggle/index.d.ts +0 -21
- package/upload/Upload.js +0 -201
- package/upload/buttons-upload/ButtonsUpload.js +0 -111
- package/upload/buttons-upload/Icons.js +0 -40
- package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
- package/upload/dragAndDropArea/Icons.js +0 -39
- package/upload/file-upload/FileToUpload.js +0 -115
- package/upload/file-upload/Icons.js +0 -66
- package/upload/files-upload/FilesToUpload.js +0 -109
- package/upload/index.d.ts +0 -15
- package/upload/transaction/Icons.js +0 -160
- package/upload/transaction/Transaction.js +0 -104
- package/upload/transactions/Transactions.js +0 -94
- package/wizard/Icons.js +0 -65
- /package/{radio → action-icon}/types.js +0 -0
- /package/{resultsetTable → badge}/types.js +0 -0
- /package/{number-input/numberInputContextTypes.js → bleed/types.js} +0 -0
|
@@ -1,17 +1,18 @@
|
|
|
1
1
|
import React from "react";
|
|
2
|
-
|
|
3
|
-
import { userEvent, within, waitFor } from "@storybook/testing-library";
|
|
4
|
-
import { fireEvent } from "@testing-library/react";
|
|
5
|
-
|
|
2
|
+
import { userEvent, within } from "@storybook/testing-library";
|
|
6
3
|
import Title from "../../.storybook/components/Title";
|
|
7
4
|
import ExampleContainer from "../../.storybook/components/ExampleContainer";
|
|
8
|
-
|
|
9
5
|
import DxcSelect from "./Select";
|
|
6
|
+
import Listbox from "./Listbox";
|
|
7
|
+
import { ThemeProvider } from "styled-components";
|
|
8
|
+
import useTheme from "../useTheme";
|
|
9
|
+
import { HalstackProvider } from "../HalstackContext";
|
|
10
10
|
|
|
11
11
|
export default {
|
|
12
12
|
title: "Select",
|
|
13
13
|
component: DxcSelect,
|
|
14
14
|
};
|
|
15
|
+
|
|
15
16
|
const one_option = [{ label: "Option 01", value: "1" }];
|
|
16
17
|
|
|
17
18
|
const single_options = [
|
|
@@ -20,6 +21,7 @@ const single_options = [
|
|
|
20
21
|
{ label: "Option 03", value: "3" },
|
|
21
22
|
{ label: "Option 04", value: "4" },
|
|
22
23
|
];
|
|
24
|
+
|
|
23
25
|
const group_options = [
|
|
24
26
|
{
|
|
25
27
|
label: "Group 001",
|
|
@@ -62,25 +64,15 @@ const group_options = [
|
|
|
62
64
|
],
|
|
63
65
|
},
|
|
64
66
|
];
|
|
65
|
-
|
|
67
|
+
|
|
68
|
+
const icon_options_grouped_material = [
|
|
66
69
|
{
|
|
67
70
|
label: "Group 001",
|
|
68
71
|
options: [
|
|
69
72
|
{
|
|
70
73
|
label: "3G Mobile",
|
|
71
74
|
value: "1",
|
|
72
|
-
icon:
|
|
73
|
-
<svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
|
|
74
|
-
<g>
|
|
75
|
-
<path d="M0,0h24v24H0V0z" fill="none" />
|
|
76
|
-
</g>
|
|
77
|
-
<g>
|
|
78
|
-
<g>
|
|
79
|
-
<path d="M3,7v2h5v2H4v2h4v2H3v2h5c1.1,0,2-0.9,2-2v-1.5c0-0.83-0.67-1.5-1.5-1.5c0.83,0,1.5-0.67,1.5-1.5V9c0-1.1-0.9-2-2-2H3z M21,11v4c0,1.1-0.9,2-2,2h-5c-1.1,0-2-0.9-2-2V9c0-1.1,0.9-2,2-2h5c1.1,0,2,0.9,2,2h-7v6h5v-2h-2.5v-2H21z" />
|
|
80
|
-
</g>
|
|
81
|
-
</g>
|
|
82
|
-
</svg>
|
|
83
|
-
),
|
|
75
|
+
icon: "3g_mobiledata",
|
|
84
76
|
},
|
|
85
77
|
],
|
|
86
78
|
},
|
|
@@ -90,12 +82,7 @@ const icon_options_grouped = [
|
|
|
90
82
|
{
|
|
91
83
|
label: "Ethernet",
|
|
92
84
|
value: "2",
|
|
93
|
-
icon:
|
|
94
|
-
<svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
|
|
95
|
-
<path d="M0 0h24v24H0V0z" fill="none" />
|
|
96
|
-
<path d="M7.77 6.76L6.23 5.48.82 12l5.41 6.52 1.54-1.28L3.42 12l4.35-5.24zM7 13h2v-2H7v2zm10-2h-2v2h2v-2zm-6 2h2v-2h-2v2zm6.77-7.52l-1.54 1.28L20.58 12l-4.35 5.24 1.54 1.28L23.18 12l-5.41-6.52z" />
|
|
97
|
-
</svg>
|
|
98
|
-
),
|
|
85
|
+
icon: "settings_ethernet",
|
|
99
86
|
},
|
|
100
87
|
],
|
|
101
88
|
},
|
|
@@ -105,26 +92,17 @@ const icon_options_grouped = [
|
|
|
105
92
|
{
|
|
106
93
|
label: "Wi-fi",
|
|
107
94
|
value: "3",
|
|
108
|
-
icon:
|
|
109
|
-
<svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
|
|
110
|
-
<path d="M0 0h24v24H0V0zm0 0h24v24H0V0z" fill="none" />
|
|
111
|
-
<path d="M1 9l2 2c4.97-4.97 13.03-4.97 18 0l2-2C16.93 2.93 7.08 2.93 1 9zm8 8l3 3 3-3c-1.65-1.66-4.34-1.66-6 0zm-4-4l2 2c2.76-2.76 7.24-2.76 10 0l2-2C15.14 9.14 8.87 9.14 5 13z" />
|
|
112
|
-
</svg>
|
|
113
|
-
),
|
|
95
|
+
icon: "wifi",
|
|
114
96
|
},
|
|
115
97
|
{
|
|
116
98
|
label: "Settings backup restore (just for previous configuration)",
|
|
117
99
|
value: "4",
|
|
118
|
-
icon:
|
|
119
|
-
<svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
|
|
120
|
-
<path d="M0 0h24v24H0V0z" fill="none" />
|
|
121
|
-
<path d="M14 12c0-1.1-.9-2-2-2s-2 .9-2 2 .9 2 2 2 2-.9 2-2zm-2-9c-4.97 0-9 4.03-9 9H0l4 4 4-4H5c0-3.87 3.13-7 7-7s7 3.13 7 7-3.13 7-7 7c-1.51 0-2.91-.49-4.06-1.3l-1.42 1.44C8.04 20.3 9.94 21 12 21c4.97 0 9-4.03 9-9s-4.03-9-9-9z" />
|
|
122
|
-
</svg>
|
|
123
|
-
),
|
|
100
|
+
icon: "settings_backup_restore",
|
|
124
101
|
},
|
|
125
102
|
],
|
|
126
103
|
},
|
|
127
104
|
];
|
|
105
|
+
|
|
128
106
|
const icon_options = [
|
|
129
107
|
{
|
|
130
108
|
label: "3G Mobile",
|
|
@@ -173,61 +151,73 @@ const icon_options = [
|
|
|
173
151
|
),
|
|
174
152
|
},
|
|
175
153
|
];
|
|
176
|
-
|
|
154
|
+
|
|
155
|
+
const options_material = [
|
|
177
156
|
{
|
|
178
|
-
label: "
|
|
157
|
+
label: "Transport",
|
|
179
158
|
options: [
|
|
180
159
|
{
|
|
181
|
-
label: "
|
|
182
|
-
value: "
|
|
183
|
-
icon: "
|
|
160
|
+
label: "Electric Car",
|
|
161
|
+
value: "car",
|
|
162
|
+
icon: "electric_car",
|
|
184
163
|
},
|
|
185
164
|
{
|
|
186
|
-
label: "
|
|
187
|
-
value: "
|
|
188
|
-
icon: "
|
|
165
|
+
label: "Motorcycle",
|
|
166
|
+
value: "motorcycle",
|
|
167
|
+
icon: "Motorcycle",
|
|
189
168
|
},
|
|
190
169
|
{
|
|
191
|
-
label: "
|
|
192
|
-
value: "
|
|
193
|
-
icon: "
|
|
170
|
+
label: "Train",
|
|
171
|
+
value: "train",
|
|
172
|
+
icon: "train",
|
|
194
173
|
},
|
|
195
174
|
{
|
|
196
|
-
label: "
|
|
197
|
-
value: "
|
|
198
|
-
icon: "
|
|
175
|
+
label: "Bike",
|
|
176
|
+
value: "bike",
|
|
177
|
+
icon: "pedal_bike",
|
|
199
178
|
},
|
|
200
179
|
],
|
|
201
180
|
},
|
|
202
181
|
{
|
|
203
|
-
label: "
|
|
182
|
+
label: "Entertainment",
|
|
204
183
|
options: [
|
|
205
184
|
{
|
|
206
|
-
label: "
|
|
207
|
-
value: "
|
|
208
|
-
icon: "
|
|
185
|
+
label: "Movie",
|
|
186
|
+
value: "movie",
|
|
187
|
+
icon: "movie",
|
|
209
188
|
},
|
|
210
189
|
{
|
|
211
|
-
label: "
|
|
212
|
-
value: "
|
|
213
|
-
icon: "
|
|
190
|
+
label: "Music",
|
|
191
|
+
value: "music",
|
|
192
|
+
icon: "music_note",
|
|
214
193
|
},
|
|
215
194
|
{
|
|
216
|
-
label: "
|
|
217
|
-
value: "
|
|
218
|
-
icon: "
|
|
195
|
+
label: "Games",
|
|
196
|
+
value: "games",
|
|
197
|
+
icon: "joystick",
|
|
219
198
|
},
|
|
220
199
|
],
|
|
221
200
|
},
|
|
222
201
|
];
|
|
202
|
+
|
|
223
203
|
const optionsWithEllipsisMedium = [
|
|
224
204
|
{ label: "Optiond1234567890123456789012345678901234", value: "1" },
|
|
225
205
|
{ label: "Optiond12345678901234567890123456789012345", value: "2" },
|
|
226
206
|
{ label: "Option 031111111111111111111111111111222", value: "3" },
|
|
227
|
-
{ label: "Option 03111111111111111111111111111122", value: "4" },
|
|
228
207
|
];
|
|
208
|
+
|
|
209
|
+
const opinionatedTheme = {
|
|
210
|
+
select: {
|
|
211
|
+
selectedOptionBackgroundColor: "#e6f4ff",
|
|
212
|
+
fontColor: "#000000",
|
|
213
|
+
optionFontColor: "#000000",
|
|
214
|
+
hoverBorderColor: "#a46ede",
|
|
215
|
+
},
|
|
216
|
+
};
|
|
217
|
+
|
|
229
218
|
const Select = () => (
|
|
230
219
|
<>
|
|
220
|
+
<Title title="States" theme="light" level={2} />
|
|
231
221
|
<ExampleContainer pseudoState="pseudo-hover">
|
|
232
222
|
<Title title="Hovered" theme="light" level={4} />
|
|
233
223
|
<DxcSelect label="Hovered" options={single_options} />
|
|
@@ -242,126 +232,484 @@ const Select = () => (
|
|
|
242
232
|
</ExampleContainer>
|
|
243
233
|
<ExampleContainer>
|
|
244
234
|
<Title title="Disabled with value" theme="light" level={4} />
|
|
245
|
-
<DxcSelect label="Disabled with value" disabled options={single_options}
|
|
235
|
+
<DxcSelect label="Disabled with value" disabled options={single_options} defaultValue="1" />
|
|
246
236
|
</ExampleContainer>
|
|
247
237
|
<ExampleContainer>
|
|
248
|
-
<Title title="With label" theme="light" level={4} />
|
|
249
|
-
<DxcSelect label="Label" options={single_options} />
|
|
250
|
-
<Title title="Label and placeholder" theme="light" level={4} />
|
|
251
|
-
<DxcSelect label="Label" options={single_options} placeholder="Placeholder" />
|
|
252
|
-
<Title title="Label, placeholder and helper text" theme="light" level={4} />
|
|
253
|
-
<DxcSelect label="Label" options={single_options} helperText="Helper text" placeholder="Placeholder" />
|
|
254
238
|
<Title title="Error" theme="light" level={4} />
|
|
255
239
|
<DxcSelect
|
|
256
240
|
label="Label"
|
|
257
241
|
options={single_options}
|
|
258
|
-
error="Error message"
|
|
242
|
+
error="Error message."
|
|
243
|
+
helperText="Helper text"
|
|
244
|
+
placeholder="Placeholder"
|
|
245
|
+
/>
|
|
246
|
+
</ExampleContainer>
|
|
247
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
248
|
+
<Title title="Hovered error" theme="light" level={4} />
|
|
249
|
+
<DxcSelect
|
|
250
|
+
label="Label"
|
|
251
|
+
options={single_options}
|
|
252
|
+
error="Error message."
|
|
259
253
|
helperText="Helper text"
|
|
260
254
|
placeholder="Placeholder"
|
|
261
255
|
/>
|
|
256
|
+
</ExampleContainer>
|
|
257
|
+
<Title title="Anatomy" theme="light" level={2} />
|
|
258
|
+
<ExampleContainer>
|
|
259
|
+
<Title title="Label, placeholder and helper text" theme="light" level={4} />
|
|
260
|
+
<DxcSelect label="Label" options={single_options} helperText="Helper text" placeholder="Placeholder" />
|
|
261
|
+
</ExampleContainer>
|
|
262
|
+
<Title title="Variants" theme="light" level={2} />
|
|
263
|
+
<ExampleContainer>
|
|
262
264
|
<Title title="Simple selection" theme="light" level={4} />
|
|
263
|
-
<DxcSelect label="Simple selection" searchable options={single_options}
|
|
265
|
+
<DxcSelect label="Simple selection" searchable options={single_options} defaultValue="2" />
|
|
266
|
+
</ExampleContainer>
|
|
267
|
+
<ExampleContainer>
|
|
264
268
|
<Title title="Multiple selection" theme="light" level={4} />
|
|
265
|
-
<DxcSelect label="Multiple select" searchable options={single_options} multiple
|
|
269
|
+
<DxcSelect label="Multiple select" searchable options={single_options} multiple defaultValue={["1", "2"]} />
|
|
266
270
|
</ExampleContainer>
|
|
267
|
-
|
|
268
271
|
<ExampleContainer pseudoState="pseudo-hover">
|
|
269
272
|
<Title title="Multiple clear hovered" theme="light" level={4} />
|
|
270
|
-
<DxcSelect label="Multiple select" options={single_options} multiple
|
|
273
|
+
<DxcSelect label="Multiple select" options={single_options} multiple defaultValue={["1", "2"]} />
|
|
271
274
|
</ExampleContainer>
|
|
272
|
-
|
|
273
275
|
<ExampleContainer pseudoState="pseudo-active">
|
|
274
276
|
<Title title="Multiple clear actived" theme="light" level={4} />
|
|
275
|
-
<DxcSelect label="Multiple select" options={single_options} multiple
|
|
277
|
+
<DxcSelect label="Multiple select" options={single_options} multiple defaultValue={["1", "2"]} />
|
|
278
|
+
</ExampleContainer>
|
|
279
|
+
<Title title="Sizes" theme="light" level={2} />
|
|
280
|
+
<ExampleContainer>
|
|
281
|
+
<Title title="Small size" theme="light" level={4} />
|
|
282
|
+
<DxcSelect label="Small" options={single_options} size="small" />
|
|
283
|
+
</ExampleContainer>
|
|
284
|
+
<ExampleContainer>
|
|
285
|
+
<Title title="Medium size" theme="light" level={4} />
|
|
286
|
+
<DxcSelect label="Medium" options={single_options} size="medium" />
|
|
287
|
+
</ExampleContainer>
|
|
288
|
+
<ExampleContainer>
|
|
289
|
+
<Title title="Large size" theme="light" level={4} />
|
|
290
|
+
<DxcSelect label="Large" options={single_options} size="large" />
|
|
291
|
+
</ExampleContainer>
|
|
292
|
+
<ExampleContainer>
|
|
293
|
+
<Title title="Fillparent size" theme="light" level={4} />
|
|
294
|
+
<DxcSelect label="Fillparent" options={single_options} size="fillParent" />
|
|
295
|
+
</ExampleContainer>
|
|
296
|
+
<Title title="Margins" theme="light" level={2} />
|
|
297
|
+
<ExampleContainer>
|
|
298
|
+
<Title title="xxsmall margin" theme="light" level={4} />
|
|
299
|
+
<DxcSelect label="xxSmall" options={single_options} margin="xxsmall" />
|
|
300
|
+
</ExampleContainer>
|
|
301
|
+
<ExampleContainer>
|
|
302
|
+
<Title title="xsmall margin" theme="light" level={4} />
|
|
303
|
+
<DxcSelect label="xSmall" options={single_options} margin="xsmall" />
|
|
304
|
+
</ExampleContainer>
|
|
305
|
+
<ExampleContainer>
|
|
306
|
+
<Title title="small margin" theme="light" level={4} />
|
|
307
|
+
<DxcSelect label="Small" options={single_options} margin="small" />
|
|
308
|
+
</ExampleContainer>
|
|
309
|
+
<ExampleContainer>
|
|
310
|
+
<Title title="medium margin" theme="light" level={4} />
|
|
311
|
+
<DxcSelect label="Medium" options={single_options} margin="medium" />
|
|
312
|
+
</ExampleContainer>
|
|
313
|
+
<ExampleContainer>
|
|
314
|
+
<Title title="large margin" theme="light" level={4} />
|
|
315
|
+
<DxcSelect label="Large" options={single_options} margin="large" />
|
|
316
|
+
</ExampleContainer>
|
|
317
|
+
<ExampleContainer>
|
|
318
|
+
<Title title="xlarge margin" theme="light" level={4} />
|
|
319
|
+
<DxcSelect label="xLarge" options={single_options} margin="xlarge" />
|
|
320
|
+
</ExampleContainer>
|
|
321
|
+
<ExampleContainer>
|
|
322
|
+
<Title title="xxlarge margin" theme="light" level={4} />
|
|
323
|
+
<DxcSelect label="xxLarge" options={single_options} margin="xxlarge" />
|
|
276
324
|
</ExampleContainer>
|
|
277
|
-
<>
|
|
278
|
-
<Title title="Sizes" theme="light" level={2} />
|
|
279
|
-
<ExampleContainer>
|
|
280
|
-
<Title title="Small size" theme="light" level={4} />
|
|
281
|
-
<DxcSelect label="Small" options={single_options} size="small" />
|
|
282
|
-
</ExampleContainer>
|
|
283
|
-
<ExampleContainer>
|
|
284
|
-
<Title title="Medium size" theme="light" level={4} />
|
|
285
|
-
<DxcSelect label="Medium" options={single_options} size="medium" />
|
|
286
|
-
</ExampleContainer>
|
|
287
|
-
<ExampleContainer>
|
|
288
|
-
<Title title="Large size" theme="light" level={4} />
|
|
289
|
-
<DxcSelect label="Large" options={single_options} size="large" />
|
|
290
|
-
</ExampleContainer>
|
|
291
|
-
<ExampleContainer>
|
|
292
|
-
<Title title="Fillparent size" theme="light" level={4} />
|
|
293
|
-
<DxcSelect label="Fillparent" options={single_options} size="fillParent" />
|
|
294
|
-
</ExampleContainer>
|
|
295
|
-
</>
|
|
296
|
-
<>
|
|
297
|
-
<Title title="Margins" theme="light" level={2} />
|
|
298
|
-
<ExampleContainer>
|
|
299
|
-
<Title title="xxsmall margin" theme="light" level={4} />
|
|
300
|
-
<DxcSelect label="xxSmall" options={single_options} margin="xxsmall" />
|
|
301
|
-
</ExampleContainer>
|
|
302
|
-
<ExampleContainer>
|
|
303
|
-
<Title title="xsmall margin" theme="light" level={4} />
|
|
304
|
-
<DxcSelect label="xSmall" options={single_options} margin="xsmall" />
|
|
305
|
-
</ExampleContainer>
|
|
306
|
-
<ExampleContainer>
|
|
307
|
-
<Title title="small margin" theme="light" level={4} />
|
|
308
|
-
<DxcSelect label="Small" options={single_options} margin="small" />
|
|
309
|
-
</ExampleContainer>
|
|
310
|
-
<ExampleContainer>
|
|
311
|
-
<Title title="medium margin" theme="light" level={4} />
|
|
312
|
-
<DxcSelect label="Medium" options={single_options} margin="medium" />
|
|
313
|
-
</ExampleContainer>
|
|
314
|
-
<ExampleContainer>
|
|
315
|
-
<Title title="large margin" theme="light" level={4} />
|
|
316
|
-
<DxcSelect label="Large" options={single_options} margin="large" />
|
|
317
|
-
</ExampleContainer>
|
|
318
|
-
<ExampleContainer>
|
|
319
|
-
<Title title="xlarge margin" theme="light" level={4} />
|
|
320
|
-
<DxcSelect label="xLarge" options={single_options} margin="xlarge" />
|
|
321
|
-
</ExampleContainer>
|
|
322
|
-
<ExampleContainer>
|
|
323
|
-
<Title title="xxlarge margin" theme="light" level={4} />
|
|
324
|
-
<DxcSelect label="xxLarge" options={single_options} margin="xxlarge" />
|
|
325
|
-
</ExampleContainer>
|
|
326
|
-
</>
|
|
327
325
|
<ExampleContainer expanded>
|
|
328
326
|
<Title title="Ellipsis" theme="light" level={2} />
|
|
329
327
|
<Title title="Multiple selection with ellipsis" theme="light" level={4} />
|
|
330
|
-
<DxcSelect label="Label" options={single_options} multiple
|
|
328
|
+
<DxcSelect label="Label" options={single_options} multiple defaultValue={["1", "2", "3", "4"]} />
|
|
331
329
|
<Title title="Value with ellipsis" theme="light" level={4} />
|
|
332
|
-
<DxcSelect label="Label" options={optionsWithEllipsisMedium}
|
|
333
|
-
<Title title="
|
|
330
|
+
<DxcSelect label="Label" options={optionsWithEllipsisMedium} defaultValue="1" />
|
|
331
|
+
<Title title="Options with ellipsis" theme="light" level={4} />
|
|
334
332
|
<DxcSelect
|
|
335
333
|
label="Label"
|
|
336
334
|
placeholder="Choose an option"
|
|
337
|
-
|
|
335
|
+
defaultValue="1"
|
|
338
336
|
options={optionsWithEllipsisMedium}
|
|
339
|
-
|
|
337
|
+
margin={{ top: "xxlarge" }}
|
|
340
338
|
/>
|
|
341
339
|
</ExampleContainer>
|
|
340
|
+
<Title title="Opinionated theme" theme="light" level={2} />
|
|
341
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
342
|
+
<Title title="Hovered" theme="light" level={4} />
|
|
343
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
344
|
+
<DxcSelect label="Hovered" options={single_options} />
|
|
345
|
+
</HalstackProvider>
|
|
346
|
+
</ExampleContainer>
|
|
347
|
+
<ExampleContainer pseudoState="pseudo-focus-within">
|
|
348
|
+
<Title title="Focused" theme="light" level={4} />
|
|
349
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
350
|
+
<DxcSelect label="Focused" options={single_options} />
|
|
351
|
+
</HalstackProvider>
|
|
352
|
+
</ExampleContainer>
|
|
353
|
+
<ExampleContainer>
|
|
354
|
+
<Title title="Disabled" theme="light" level={4} />
|
|
355
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
356
|
+
<DxcSelect label="Disabled" placeholder="Placeholder" disabled options={single_options} />
|
|
357
|
+
</HalstackProvider>
|
|
358
|
+
</ExampleContainer>
|
|
359
|
+
<ExampleContainer>
|
|
360
|
+
<Title title="Disabled with value" theme="light" level={4} />
|
|
361
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
362
|
+
<DxcSelect label="Disabled with value" disabled options={single_options} defaultValue="1" />
|
|
363
|
+
</HalstackProvider>
|
|
364
|
+
</ExampleContainer>
|
|
365
|
+
<ExampleContainer>
|
|
366
|
+
<Title title="Error" theme="light" level={4} />
|
|
367
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
368
|
+
<DxcSelect
|
|
369
|
+
label="Label"
|
|
370
|
+
options={single_options}
|
|
371
|
+
error="Error message."
|
|
372
|
+
helperText="Helper text"
|
|
373
|
+
placeholder="Placeholder"
|
|
374
|
+
/>
|
|
375
|
+
<ExampleContainer>
|
|
376
|
+
<Title title="Multiple selection" theme="light" level={4} />
|
|
377
|
+
<DxcSelect label="Multiple select" searchable options={single_options} multiple defaultValue={["1", "2"]} />
|
|
378
|
+
</ExampleContainer>
|
|
379
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
380
|
+
<Title title="Multiple clear hovered" theme="light" level={4} />
|
|
381
|
+
<DxcSelect label="Multiple select" options={single_options} multiple defaultValue={["1", "2"]} />
|
|
382
|
+
</ExampleContainer>
|
|
383
|
+
<ExampleContainer pseudoState="pseudo-active">
|
|
384
|
+
<Title title="Multiple clear actived" theme="light" level={4} />
|
|
385
|
+
<DxcSelect label="Multiple select" options={single_options} multiple defaultValue={["1", "2"]} />
|
|
386
|
+
</ExampleContainer>
|
|
387
|
+
</HalstackProvider>
|
|
388
|
+
</ExampleContainer>
|
|
342
389
|
</>
|
|
343
390
|
);
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
const
|
|
347
|
-
|
|
391
|
+
|
|
392
|
+
const SelectListbox = () => {
|
|
393
|
+
const colorsTheme: any = useTheme();
|
|
394
|
+
|
|
395
|
+
return (
|
|
396
|
+
<>
|
|
397
|
+
<ThemeProvider theme={colorsTheme.select}>
|
|
398
|
+
<Title title="Listbox" theme="light" level={2} />
|
|
399
|
+
<ExampleContainer>
|
|
400
|
+
<Title
|
|
401
|
+
title="List dialog uses a Radix Popover to appear over elements with a certain z-index"
|
|
402
|
+
theme="light"
|
|
403
|
+
level={3}
|
|
404
|
+
/>
|
|
405
|
+
<div
|
|
406
|
+
style={{
|
|
407
|
+
position: "relative",
|
|
408
|
+
display: "flex",
|
|
409
|
+
flexDirection: "column",
|
|
410
|
+
gap: "20px",
|
|
411
|
+
height: "150px",
|
|
412
|
+
width: "min-content",
|
|
413
|
+
marginBottom: "100px",
|
|
414
|
+
padding: "20px",
|
|
415
|
+
border: "1px solid black",
|
|
416
|
+
borderRadius: "4px",
|
|
417
|
+
overflow: "auto",
|
|
418
|
+
zIndex: "1300",
|
|
419
|
+
}}
|
|
420
|
+
>
|
|
421
|
+
<DxcSelect label="Label" options={single_options} optional placeholder="Choose an option" />
|
|
422
|
+
<button style={{ zIndex: "1", width: "100px" }}>Submit</button>
|
|
423
|
+
</div>
|
|
424
|
+
</ExampleContainer>
|
|
425
|
+
<Title title="Listbox option states" theme="light" level={3} />
|
|
426
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
427
|
+
<Title title="Hovered option" theme="light" level={4} />
|
|
428
|
+
<Listbox
|
|
429
|
+
id="x"
|
|
430
|
+
currentValue=""
|
|
431
|
+
options={one_option}
|
|
432
|
+
visualFocusIndex={-1}
|
|
433
|
+
lastOptionIndex={0}
|
|
434
|
+
multiple={false}
|
|
435
|
+
optional={false}
|
|
436
|
+
optionalItem={{ label: "Empty", value: "" }}
|
|
437
|
+
searchable={false}
|
|
438
|
+
handleOptionOnClick={() => {}}
|
|
439
|
+
styles={{ width: 360 }}
|
|
440
|
+
/>
|
|
441
|
+
</ExampleContainer>
|
|
442
|
+
<ExampleContainer pseudoState="pseudo-active">
|
|
443
|
+
<Title title="Active option" theme="light" level={4} />
|
|
444
|
+
<Listbox
|
|
445
|
+
id="x"
|
|
446
|
+
currentValue=""
|
|
447
|
+
options={one_option}
|
|
448
|
+
visualFocusIndex={-1}
|
|
449
|
+
lastOptionIndex={0}
|
|
450
|
+
multiple={false}
|
|
451
|
+
optional={false}
|
|
452
|
+
optionalItem={{ label: "Empty", value: "" }}
|
|
453
|
+
searchable={false}
|
|
454
|
+
handleOptionOnClick={() => {}}
|
|
455
|
+
styles={{ width: 360 }}
|
|
456
|
+
/>
|
|
457
|
+
</ExampleContainer>
|
|
458
|
+
<ExampleContainer>
|
|
459
|
+
<Title title="Focused option" theme="light" level={4} />
|
|
460
|
+
<Listbox
|
|
461
|
+
id="x"
|
|
462
|
+
currentValue=""
|
|
463
|
+
options={one_option}
|
|
464
|
+
visualFocusIndex={0}
|
|
465
|
+
lastOptionIndex={0}
|
|
466
|
+
multiple={false}
|
|
467
|
+
optional={false}
|
|
468
|
+
optionalItem={{ label: "Empty", value: "" }}
|
|
469
|
+
searchable={false}
|
|
470
|
+
handleOptionOnClick={() => {}}
|
|
471
|
+
styles={{ width: 360 }}
|
|
472
|
+
/>
|
|
473
|
+
</ExampleContainer>
|
|
474
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
475
|
+
<Title title="Hovered selected option" theme="light" level={4} />
|
|
476
|
+
<Listbox
|
|
477
|
+
id="x"
|
|
478
|
+
currentValue="1"
|
|
479
|
+
options={single_options}
|
|
480
|
+
visualFocusIndex={-1}
|
|
481
|
+
lastOptionIndex={3}
|
|
482
|
+
multiple={false}
|
|
483
|
+
optional={false}
|
|
484
|
+
optionalItem={{ label: "Empty", value: "" }}
|
|
485
|
+
searchable={false}
|
|
486
|
+
handleOptionOnClick={() => {}}
|
|
487
|
+
styles={{ width: 360 }}
|
|
488
|
+
/>
|
|
489
|
+
</ExampleContainer>
|
|
490
|
+
<ExampleContainer pseudoState="pseudo-active">
|
|
491
|
+
<Title title="Active selected option" theme="light" level={4} />
|
|
492
|
+
<Listbox
|
|
493
|
+
id="x"
|
|
494
|
+
currentValue="2"
|
|
495
|
+
options={single_options}
|
|
496
|
+
visualFocusIndex={0}
|
|
497
|
+
lastOptionIndex={3}
|
|
498
|
+
multiple={false}
|
|
499
|
+
optional={false}
|
|
500
|
+
optionalItem={{ label: "Empty", value: "" }}
|
|
501
|
+
searchable={false}
|
|
502
|
+
handleOptionOnClick={() => {}}
|
|
503
|
+
styles={{ width: 360 }}
|
|
504
|
+
/>
|
|
505
|
+
</ExampleContainer>
|
|
506
|
+
<Title title="Listbox with icons" theme="light" level={3} />
|
|
507
|
+
<ExampleContainer>
|
|
508
|
+
<Title title="Icons (SVGs)" theme="light" level={4} />
|
|
509
|
+
<Listbox
|
|
510
|
+
id="x"
|
|
511
|
+
currentValue="3"
|
|
512
|
+
options={icon_options}
|
|
513
|
+
visualFocusIndex={-1}
|
|
514
|
+
lastOptionIndex={3}
|
|
515
|
+
multiple={false}
|
|
516
|
+
optional={false}
|
|
517
|
+
optionalItem={{ label: "Empty", value: "" }}
|
|
518
|
+
searchable={false}
|
|
519
|
+
handleOptionOnClick={() => {}}
|
|
520
|
+
styles={{ width: 360 }}
|
|
521
|
+
/>
|
|
522
|
+
</ExampleContainer>
|
|
523
|
+
<ExampleContainer>
|
|
524
|
+
<Title title="Grouped icons (Material Symbols)" theme="light" level={4} />
|
|
525
|
+
<Listbox
|
|
526
|
+
id="x"
|
|
527
|
+
currentValue={["0", "3"]}
|
|
528
|
+
options={icon_options_grouped_material}
|
|
529
|
+
visualFocusIndex={-1}
|
|
530
|
+
lastOptionIndex={3}
|
|
531
|
+
multiple={false}
|
|
532
|
+
optional={false}
|
|
533
|
+
optionalItem={{ label: "Empty", value: "" }}
|
|
534
|
+
searchable={false}
|
|
535
|
+
handleOptionOnClick={() => {}}
|
|
536
|
+
styles={{ width: 360 }}
|
|
537
|
+
/>
|
|
538
|
+
</ExampleContainer>
|
|
539
|
+
<ExampleContainer>
|
|
540
|
+
<Title title="Grouped icons (Material)" theme="light" level={4} />
|
|
541
|
+
<Listbox
|
|
542
|
+
id="x"
|
|
543
|
+
currentValue={["facebook", "figma"]}
|
|
544
|
+
options={options_material}
|
|
545
|
+
visualFocusIndex={-1}
|
|
546
|
+
lastOptionIndex={6}
|
|
547
|
+
multiple={true}
|
|
548
|
+
optional={false}
|
|
549
|
+
optionalItem={{ label: "Empty", value: "" }}
|
|
550
|
+
searchable={false}
|
|
551
|
+
handleOptionOnClick={() => {}}
|
|
552
|
+
styles={{ width: 360 }}
|
|
553
|
+
/>
|
|
554
|
+
</ExampleContainer>
|
|
555
|
+
</ThemeProvider>
|
|
556
|
+
<ThemeProvider theme={colorsTheme.select}>
|
|
557
|
+
<Title title="Opinionated theme" theme="light" level={2} />
|
|
558
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
559
|
+
<Title title="Hovered option" theme="light" level={4} />
|
|
560
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
561
|
+
<Listbox
|
|
562
|
+
id="x"
|
|
563
|
+
currentValue=""
|
|
564
|
+
options={one_option}
|
|
565
|
+
visualFocusIndex={-1}
|
|
566
|
+
lastOptionIndex={0}
|
|
567
|
+
multiple={false}
|
|
568
|
+
optional={false}
|
|
569
|
+
optionalItem={{ label: "Empty", value: "" }}
|
|
570
|
+
searchable={false}
|
|
571
|
+
handleOptionOnClick={() => {}}
|
|
572
|
+
styles={{ width: 360 }}
|
|
573
|
+
/>
|
|
574
|
+
</HalstackProvider>
|
|
575
|
+
</ExampleContainer>
|
|
576
|
+
<ExampleContainer pseudoState="pseudo-active">
|
|
577
|
+
<Title title="Active option" theme="light" level={4} />{" "}
|
|
578
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
579
|
+
<Listbox
|
|
580
|
+
id="x"
|
|
581
|
+
currentValue=""
|
|
582
|
+
options={one_option}
|
|
583
|
+
visualFocusIndex={-1}
|
|
584
|
+
lastOptionIndex={0}
|
|
585
|
+
multiple={false}
|
|
586
|
+
optional={false}
|
|
587
|
+
optionalItem={{ label: "Empty", value: "" }}
|
|
588
|
+
searchable={false}
|
|
589
|
+
handleOptionOnClick={() => {}}
|
|
590
|
+
styles={{ width: 360 }}
|
|
591
|
+
/>
|
|
592
|
+
</HalstackProvider>
|
|
593
|
+
</ExampleContainer>
|
|
594
|
+
<ExampleContainer>
|
|
595
|
+
<Title title="Focused option" theme="light" level={4} />{" "}
|
|
596
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
597
|
+
<Listbox
|
|
598
|
+
id="x"
|
|
599
|
+
currentValue=""
|
|
600
|
+
options={one_option}
|
|
601
|
+
visualFocusIndex={0}
|
|
602
|
+
lastOptionIndex={0}
|
|
603
|
+
multiple={false}
|
|
604
|
+
optional={false}
|
|
605
|
+
optionalItem={{ label: "Empty", value: "" }}
|
|
606
|
+
searchable={false}
|
|
607
|
+
handleOptionOnClick={() => {}}
|
|
608
|
+
styles={{ width: 360 }}
|
|
609
|
+
/>
|
|
610
|
+
</HalstackProvider>
|
|
611
|
+
</ExampleContainer>
|
|
612
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
613
|
+
<Title title="Hovered selected option" theme="light" level={4} />{" "}
|
|
614
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
615
|
+
<Listbox
|
|
616
|
+
id="x"
|
|
617
|
+
currentValue="1"
|
|
618
|
+
options={single_options}
|
|
619
|
+
visualFocusIndex={-1}
|
|
620
|
+
lastOptionIndex={3}
|
|
621
|
+
multiple={false}
|
|
622
|
+
optional={false}
|
|
623
|
+
optionalItem={{ label: "Empty", value: "" }}
|
|
624
|
+
searchable={false}
|
|
625
|
+
handleOptionOnClick={() => {}}
|
|
626
|
+
styles={{ width: 360 }}
|
|
627
|
+
/>
|
|
628
|
+
</HalstackProvider>
|
|
629
|
+
</ExampleContainer>
|
|
630
|
+
<ExampleContainer pseudoState="pseudo-active">
|
|
631
|
+
<Title title="Active selected option" theme="light" level={4} />{" "}
|
|
632
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
633
|
+
<Listbox
|
|
634
|
+
id="x"
|
|
635
|
+
currentValue="2"
|
|
636
|
+
options={single_options}
|
|
637
|
+
visualFocusIndex={0}
|
|
638
|
+
lastOptionIndex={3}
|
|
639
|
+
multiple={false}
|
|
640
|
+
optional={false}
|
|
641
|
+
optionalItem={{ label: "Empty", value: "" }}
|
|
642
|
+
searchable={false}
|
|
643
|
+
handleOptionOnClick={() => {}}
|
|
644
|
+
styles={{ width: 360 }}
|
|
645
|
+
/>
|
|
646
|
+
</HalstackProvider>
|
|
647
|
+
</ExampleContainer>
|
|
648
|
+
<Title title="Listbox with icons" theme="light" level={3} />
|
|
649
|
+
<ExampleContainer>
|
|
650
|
+
<Title title="Icons (SVGs)" theme="light" level={4} />{" "}
|
|
651
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
652
|
+
<Listbox
|
|
653
|
+
id="x"
|
|
654
|
+
currentValue="3"
|
|
655
|
+
options={icon_options}
|
|
656
|
+
visualFocusIndex={-1}
|
|
657
|
+
lastOptionIndex={3}
|
|
658
|
+
multiple={false}
|
|
659
|
+
optional={false}
|
|
660
|
+
optionalItem={{ label: "Empty", value: "" }}
|
|
661
|
+
searchable={false}
|
|
662
|
+
handleOptionOnClick={() => {}}
|
|
663
|
+
styles={{ width: 360 }}
|
|
664
|
+
/>
|
|
665
|
+
</HalstackProvider>
|
|
666
|
+
</ExampleContainer>
|
|
667
|
+
</ThemeProvider>
|
|
668
|
+
</>
|
|
669
|
+
);
|
|
348
670
|
};
|
|
349
|
-
|
|
671
|
+
|
|
672
|
+
const SearchableSelect = () => (
|
|
350
673
|
<ExampleContainer expanded>
|
|
351
|
-
<Title title="
|
|
352
|
-
<DxcSelect label="Select
|
|
674
|
+
<Title title="Searchable select" theme="light" level={4} />
|
|
675
|
+
<DxcSelect label="Select Label" searchable options={single_options} placeholder="Choose an option" />
|
|
353
676
|
</ExampleContainer>
|
|
354
677
|
);
|
|
355
|
-
|
|
678
|
+
|
|
679
|
+
const SearchableSelectOpinionated = () => (
|
|
356
680
|
<ExampleContainer expanded>
|
|
357
681
|
<Title title="Searchable select" theme="light" level={4} />
|
|
358
|
-
<
|
|
682
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
683
|
+
<DxcSelect label="Select Label" searchable options={single_options} placeholder="Choose an option" />
|
|
684
|
+
</HalstackProvider>
|
|
685
|
+
</ExampleContainer>
|
|
686
|
+
);
|
|
687
|
+
|
|
688
|
+
const SearchValue = () => (
|
|
689
|
+
<ExampleContainer expanded>
|
|
690
|
+
<Title title="Searchable select with value" theme="light" level={4} />
|
|
691
|
+
<DxcSelect
|
|
692
|
+
label="Select Label"
|
|
693
|
+
searchable
|
|
694
|
+
defaultValue="1"
|
|
695
|
+
options={single_options}
|
|
696
|
+
placeholder="Choose an option"
|
|
697
|
+
/>
|
|
359
698
|
</ExampleContainer>
|
|
360
699
|
);
|
|
361
|
-
|
|
700
|
+
|
|
701
|
+
const SearchValueOpinionated = () => (
|
|
362
702
|
<ExampleContainer expanded>
|
|
363
703
|
<Title title="Searchable select with value" theme="light" level={4} />
|
|
364
|
-
<
|
|
704
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
705
|
+
<DxcSelect
|
|
706
|
+
label="Select Label"
|
|
707
|
+
searchable
|
|
708
|
+
defaultValue="1"
|
|
709
|
+
options={single_options}
|
|
710
|
+
placeholder="Choose an option"
|
|
711
|
+
/>
|
|
712
|
+
</HalstackProvider>
|
|
365
713
|
</ExampleContainer>
|
|
366
714
|
);
|
|
367
715
|
|
|
@@ -372,85 +720,73 @@ const MultipleSelect = () => (
|
|
|
372
720
|
<DxcSelect
|
|
373
721
|
label="Select label"
|
|
374
722
|
options={single_options}
|
|
375
|
-
|
|
723
|
+
defaultValue={["1", "4"]}
|
|
376
724
|
multiple
|
|
377
725
|
placeholder="Choose an option"
|
|
378
726
|
/>
|
|
379
727
|
</ExampleContainer>
|
|
380
728
|
</>
|
|
381
729
|
);
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
<Title title="Grouped options simple select" theme="light" level={4} />
|
|
385
|
-
<DxcSelect label="Label" options={group_options} value="9" placeholder="Choose an option" />
|
|
386
|
-
</ExampleContainer>
|
|
387
|
-
);
|
|
388
|
-
const MultipleGroupedOptionsSelect = () => (
|
|
389
|
-
<ExampleContainer expanded>
|
|
390
|
-
<Title title="Grouped options multiple select" theme="light" level={4} />
|
|
391
|
-
<DxcSelect label="Label" options={group_options} value={["0", "2"]} multiple placeholder="Choose an option" />
|
|
392
|
-
</ExampleContainer>
|
|
393
|
-
);
|
|
394
|
-
const RescaledIcons = () => (
|
|
730
|
+
|
|
731
|
+
const MultipleSelectOpinioated = () => (
|
|
395
732
|
<ExampleContainer expanded>
|
|
396
|
-
<Title title="
|
|
397
|
-
<
|
|
733
|
+
<Title title="Multiple select" theme="light" level={4} />
|
|
734
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
735
|
+
<DxcSelect
|
|
736
|
+
label="Select label"
|
|
737
|
+
options={single_options}
|
|
738
|
+
defaultValue={["1", "4"]}
|
|
739
|
+
multiple
|
|
740
|
+
placeholder="Choose an option"
|
|
741
|
+
/>
|
|
742
|
+
</HalstackProvider>
|
|
398
743
|
</ExampleContainer>
|
|
399
744
|
);
|
|
400
|
-
|
|
745
|
+
|
|
746
|
+
const DefaultGroupedOptionsSelect = () => (
|
|
401
747
|
<ExampleContainer expanded>
|
|
402
|
-
<Title title="
|
|
403
|
-
<DxcSelect label="Label" options={
|
|
748
|
+
<Title title="Grouped options simple select" theme="light" level={4} />
|
|
749
|
+
<DxcSelect label="Label" options={group_options} defaultValue="9" placeholder="Choose an option" />
|
|
404
750
|
</ExampleContainer>
|
|
405
751
|
);
|
|
406
|
-
|
|
752
|
+
|
|
753
|
+
const DefaultGroupedOptionsSelectOpinionated = () => (
|
|
407
754
|
<ExampleContainer expanded>
|
|
408
|
-
<Title title="
|
|
409
|
-
<
|
|
755
|
+
<Title title="Grouped options simple select" theme="light" level={4} />
|
|
756
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
757
|
+
<DxcSelect label="Label" options={group_options} defaultValue="9" placeholder="Choose an option" />
|
|
758
|
+
</HalstackProvider>
|
|
410
759
|
</ExampleContainer>
|
|
411
760
|
);
|
|
412
|
-
|
|
761
|
+
|
|
762
|
+
const MultipleGroupedOptionsSelect = () => (
|
|
413
763
|
<ExampleContainer expanded>
|
|
414
|
-
<Title title="
|
|
764
|
+
<Title title="Grouped options multiple select" theme="light" level={4} />
|
|
415
765
|
<DxcSelect
|
|
416
766
|
label="Label"
|
|
417
|
-
options={
|
|
767
|
+
options={group_options}
|
|
768
|
+
defaultValue={["0", "2"]}
|
|
418
769
|
multiple
|
|
419
|
-
value={["3", "2"]}
|
|
420
770
|
placeholder="Choose an option"
|
|
421
771
|
/>
|
|
422
772
|
</ExampleContainer>
|
|
423
773
|
);
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
<
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
<ExampleContainer pseudoState="pseudo-active" expanded>
|
|
438
|
-
<Title title="Actived Option" theme="light" level={4} />
|
|
439
|
-
<DxcSelect label="Actived" options={one_option} placeholder="Choose an option" />
|
|
440
|
-
</ExampleContainer>
|
|
441
|
-
);
|
|
442
|
-
const SelectedOptionHovered = () => (
|
|
443
|
-
<ExampleContainer pseudoState="pseudo-hover" expanded>
|
|
444
|
-
<Title title="Hovered Selected Option" theme="light" level={4} />
|
|
445
|
-
<DxcSelect label="Hovered" value="1" options={one_option} placeholder="Choose an option" />
|
|
446
|
-
</ExampleContainer>
|
|
447
|
-
);
|
|
448
|
-
const SelectedOptionActived = () => (
|
|
449
|
-
<ExampleContainer pseudoState="pseudo-active" expanded>
|
|
450
|
-
<Title title="Actived Selected Option" theme="light" level={4} />
|
|
451
|
-
<DxcSelect label="Actived" value="1" options={one_option} placeholder="Choose an option" />
|
|
774
|
+
|
|
775
|
+
const MultipleGroupedOptionsSelectOpinionated = () => (
|
|
776
|
+
<ExampleContainer expanded>
|
|
777
|
+
<Title title="Grouped options multiple select" theme="light" level={4} />
|
|
778
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
779
|
+
<DxcSelect
|
|
780
|
+
label="Label"
|
|
781
|
+
options={group_options}
|
|
782
|
+
defaultValue={["0", "2"]}
|
|
783
|
+
multiple
|
|
784
|
+
placeholder="Choose an option"
|
|
785
|
+
/>
|
|
786
|
+
</HalstackProvider>
|
|
452
787
|
</ExampleContainer>
|
|
453
788
|
);
|
|
789
|
+
|
|
454
790
|
const MultipleSearchable = () => (
|
|
455
791
|
<ExampleContainer expanded>
|
|
456
792
|
<Title title="Searchable multiple select with value" theme="light" level={4} />
|
|
@@ -458,114 +794,113 @@ const MultipleSearchable = () => (
|
|
|
458
794
|
label="Select Label"
|
|
459
795
|
searchable
|
|
460
796
|
multiple
|
|
461
|
-
|
|
797
|
+
defaultValue={["1", "4"]}
|
|
462
798
|
options={single_options}
|
|
463
799
|
placeholder="Choose an option"
|
|
464
800
|
/>
|
|
465
801
|
</ExampleContainer>
|
|
466
802
|
);
|
|
467
|
-
|
|
468
|
-
|
|
803
|
+
|
|
804
|
+
const MultipleSearchableOpinionated = () => (
|
|
805
|
+
<ExampleContainer expanded>
|
|
806
|
+
<Title title="Searchable multiple select with value" theme="light" level={4} />
|
|
807
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
808
|
+
<DxcSelect
|
|
809
|
+
label="Select Label"
|
|
810
|
+
searchable
|
|
811
|
+
multiple
|
|
812
|
+
defaultValue={["1", "4"]}
|
|
813
|
+
options={single_options}
|
|
814
|
+
placeholder="Choose an option"
|
|
815
|
+
/>
|
|
816
|
+
</HalstackProvider>
|
|
817
|
+
</ExampleContainer>
|
|
818
|
+
);
|
|
819
|
+
|
|
820
|
+
export const Chromatic = Select.bind({});
|
|
821
|
+
Chromatic.play = async ({ canvasElement }) => {
|
|
822
|
+
const canvas = within(canvasElement);
|
|
823
|
+
await userEvent.click(canvas.getAllByRole("combobox")[24]);
|
|
824
|
+
};
|
|
825
|
+
|
|
826
|
+
export const ListboxStates = SelectListbox.bind({});
|
|
827
|
+
ListboxStates.play = async ({ canvasElement }) => {
|
|
469
828
|
const canvas = within(canvasElement);
|
|
470
829
|
const select = canvas.getByRole("combobox");
|
|
471
830
|
await userEvent.click(select);
|
|
472
831
|
};
|
|
832
|
+
|
|
473
833
|
export const Searchable = SearchableSelect.bind({});
|
|
474
834
|
Searchable.play = async ({ canvasElement }) => {
|
|
475
835
|
const canvas = within(canvasElement);
|
|
476
|
-
await userEvent.
|
|
477
|
-
await waitFor(async () => {
|
|
478
|
-
userEvent.type(canvas.getByRole("combobox"), "r");
|
|
479
|
-
});
|
|
836
|
+
await userEvent.type(canvas.getByRole("combobox"), "r");
|
|
480
837
|
};
|
|
481
|
-
|
|
482
|
-
|
|
838
|
+
|
|
839
|
+
export const SearchableOpinionated = SearchableSelectOpinionated.bind({});
|
|
840
|
+
SearchableOpinionated.play = async ({ canvasElement }) => {
|
|
483
841
|
const canvas = within(canvasElement);
|
|
484
|
-
await userEvent.
|
|
842
|
+
await userEvent.type(canvas.getByRole("combobox"), "r");
|
|
485
843
|
};
|
|
486
844
|
|
|
487
|
-
export const
|
|
488
|
-
|
|
845
|
+
export const SearchableWithValue = SearchValue.bind({});
|
|
846
|
+
SearchableWithValue.play = async ({ canvasElement }) => {
|
|
489
847
|
const canvas = within(canvasElement);
|
|
490
|
-
await userEvent.click(canvas.
|
|
848
|
+
await userEvent.click(canvas.getByRole("combobox"));
|
|
491
849
|
};
|
|
492
850
|
|
|
493
|
-
export const
|
|
494
|
-
|
|
851
|
+
export const SearchableWithValueOpinionated = SearchValueOpinionated.bind({});
|
|
852
|
+
SearchableWithValueOpinionated.play = async ({ canvasElement }) => {
|
|
495
853
|
const canvas = within(canvasElement);
|
|
496
|
-
|
|
497
|
-
await userEvent.click(select);
|
|
854
|
+
await userEvent.click(canvas.getByRole("combobox"));
|
|
498
855
|
};
|
|
499
856
|
|
|
500
|
-
export const
|
|
501
|
-
|
|
857
|
+
export const MultipleSearchableWithValue = MultipleSearchable.bind({});
|
|
858
|
+
MultipleSearchableWithValue.play = async ({ canvasElement }) => {
|
|
502
859
|
const canvas = within(canvasElement);
|
|
503
860
|
await userEvent.click(canvas.getAllByRole("combobox")[0]);
|
|
504
861
|
};
|
|
505
862
|
|
|
506
|
-
export const
|
|
507
|
-
|
|
863
|
+
export const MultipleSearchableWithValueOpinionated = MultipleSearchableOpinionated.bind({});
|
|
864
|
+
MultipleSearchableWithValueOpinionated.play = async ({ canvasElement }) => {
|
|
508
865
|
const canvas = within(canvasElement);
|
|
509
|
-
|
|
510
|
-
await userEvent.click(select);
|
|
511
|
-
};
|
|
512
|
-
export const SelectWithIconsDisplayed = SelectWithIcons.bind({});
|
|
513
|
-
SelectWithIconsDisplayed.play = async ({ canvasElement }) => {
|
|
514
|
-
const canvas = within(canvasElement);
|
|
515
|
-
const select = canvas.getByRole("combobox");
|
|
516
|
-
await userEvent.click(select);
|
|
866
|
+
await userEvent.click(canvas.getAllByRole("combobox")[0]);
|
|
517
867
|
};
|
|
518
868
|
|
|
519
|
-
export const
|
|
520
|
-
|
|
521
|
-
const canvas = within(canvasElement);
|
|
522
|
-
const select = canvas.getByRole("combobox");
|
|
523
|
-
await userEvent.click(select);
|
|
524
|
-
};
|
|
525
|
-
export const SelectMultipleWithIconsDisplayed = SelectMultipleWithIcons.bind({});
|
|
526
|
-
SelectMultipleWithIconsDisplayed.play = async ({ canvasElement }) => {
|
|
869
|
+
export const GroupOptionsDisplayed = DefaultGroupedOptionsSelect.bind({});
|
|
870
|
+
GroupOptionsDisplayed.play = async ({ canvasElement }) => {
|
|
527
871
|
const canvas = within(canvasElement);
|
|
528
872
|
const select = canvas.getByRole("combobox");
|
|
529
873
|
await userEvent.click(select);
|
|
530
874
|
};
|
|
531
875
|
|
|
532
|
-
export const
|
|
533
|
-
|
|
876
|
+
export const GroupOptionsDisplayedOpinionated = DefaultGroupedOptionsSelectOpinionated.bind({});
|
|
877
|
+
GroupOptionsDisplayedOpinionated.play = async ({ canvasElement }) => {
|
|
534
878
|
const canvas = within(canvasElement);
|
|
535
879
|
const select = canvas.getByRole("combobox");
|
|
536
880
|
await userEvent.click(select);
|
|
537
881
|
};
|
|
538
882
|
|
|
539
|
-
export const
|
|
540
|
-
|
|
883
|
+
export const MultipleOptionsDisplayed = MultipleSelect.bind({});
|
|
884
|
+
MultipleOptionsDisplayed.play = async ({ canvasElement }) => {
|
|
541
885
|
const canvas = within(canvasElement);
|
|
542
|
-
|
|
543
|
-
await userEvent.click(select);
|
|
886
|
+
await userEvent.click(canvas.getAllByRole("combobox")[0]);
|
|
544
887
|
};
|
|
545
888
|
|
|
546
|
-
export const
|
|
547
|
-
|
|
548
|
-
const canvas = within(canvasElement);
|
|
549
|
-
const select = canvas.getByRole("combobox");
|
|
550
|
-
await userEvent.click(select);
|
|
551
|
-
await waitFor(async () => {
|
|
552
|
-
fireEvent.keyDown(select, { key: "ArrowDown", code: "ArrowDown", keyCode: 40, charCode: 40 });
|
|
553
|
-
});
|
|
554
|
-
};
|
|
555
|
-
export const OptionActived = OnlyOneOptionActived.bind({});
|
|
556
|
-
OptionActived.play = async ({ canvasElement }) => {
|
|
889
|
+
export const MultipleOptionsDisplayedOpinionated = MultipleSelectOpinioated.bind({});
|
|
890
|
+
MultipleOptionsDisplayedOpinionated.play = async ({ canvasElement }) => {
|
|
557
891
|
const canvas = within(canvasElement);
|
|
558
|
-
|
|
559
|
-
await userEvent.click(select);
|
|
892
|
+
await userEvent.click(canvas.getAllByRole("combobox")[0]);
|
|
560
893
|
};
|
|
561
|
-
|
|
562
|
-
|
|
894
|
+
|
|
895
|
+
export const MultipleGroupedOptionsDisplayed = MultipleGroupedOptionsSelect.bind({});
|
|
896
|
+
MultipleGroupedOptionsDisplayed.play = async ({ canvasElement }) => {
|
|
563
897
|
const canvas = within(canvasElement);
|
|
564
898
|
const select = canvas.getByRole("combobox");
|
|
565
899
|
await userEvent.click(select);
|
|
566
900
|
};
|
|
567
|
-
|
|
568
|
-
|
|
901
|
+
|
|
902
|
+
export const MultipleGroupedOptionsDisplayedOpinionated = MultipleGroupedOptionsSelectOpinionated.bind({});
|
|
903
|
+
MultipleGroupedOptionsDisplayedOpinionated.play = async ({ canvasElement }) => {
|
|
569
904
|
const canvas = within(canvasElement);
|
|
570
905
|
const select = canvas.getByRole("combobox");
|
|
571
906
|
await userEvent.click(select);
|