@dxc-technology/halstack-react 0.0.0-ff5083e → 0.0.0-ff6c8bf
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 -10
- package/BackgroundColorContext.js +5 -22
- package/HalstackContext.d.ts +1240 -6
- package/HalstackContext.js +126 -111
- package/README.md +47 -0
- package/accordion/Accordion.accessibility.test.js +71 -0
- package/accordion/Accordion.d.ts +1 -1
- package/accordion/Accordion.js +105 -160
- package/accordion/Accordion.stories.tsx +82 -148
- package/accordion/Accordion.test.js +25 -41
- package/accordion/types.d.ts +6 -17
- package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
- package/accordion-group/AccordionGroup.d.ts +2 -2
- package/accordion-group/AccordionGroup.js +31 -98
- package/accordion-group/AccordionGroup.stories.tsx +94 -67
- package/accordion-group/AccordionGroup.test.js +52 -105
- 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 +12 -17
- 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 +37 -127
- package/alert/Alert.stories.tsx +28 -0
- package/alert/Alert.test.js +29 -46
- package/alert/types.d.ts +5 -5
- package/badge/Badge.accessibility.test.js +129 -0
- package/badge/Badge.d.ts +1 -1
- package/badge/Badge.js +142 -42
- package/badge/Badge.stories.tsx +210 -0
- package/badge/Badge.test.js +30 -0
- package/badge/types.d.ts +52 -3
- package/bleed/Bleed.js +13 -21
- package/bleed/Bleed.stories.tsx +64 -63
- package/bleed/types.d.ts +2 -2
- package/box/Box.accessibility.test.js +33 -0
- package/box/Box.d.ts +1 -1
- package/box/Box.js +19 -60
- package/box/Box.stories.tsx +38 -51
- package/box/Box.test.js +2 -7
- package/box/types.d.ts +3 -14
- package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
- package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
- package/breadcrumbs/Breadcrumbs.d.ts +4 -0
- package/breadcrumbs/Breadcrumbs.js +79 -0
- package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
- package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
- package/breadcrumbs/Breadcrumbs.test.js +169 -0
- package/breadcrumbs/Item.d.ts +4 -0
- package/breadcrumbs/Item.js +52 -0
- package/breadcrumbs/dropdownTheme.d.ts +53 -0
- package/breadcrumbs/dropdownTheme.js +62 -0
- package/breadcrumbs/types.d.ts +16 -0
- package/bulleted-list/BulletedList.accessibility.test.js +119 -0
- package/bulleted-list/BulletedList.js +35 -63
- package/bulleted-list/BulletedList.stories.tsx +18 -106
- package/bulleted-list/types.d.ts +32 -5
- package/button/Button.accessibility.test.js +127 -0
- package/button/Button.d.ts +1 -1
- package/button/Button.js +64 -117
- package/button/Button.stories.tsx +151 -100
- package/button/Button.test.js +20 -17
- package/button/types.d.ts +12 -8
- package/card/Card.accessibility.test.js +36 -0
- package/card/Card.d.ts +1 -1
- package/card/Card.js +49 -89
- package/card/Card.stories.tsx +12 -42
- package/card/Card.test.js +11 -22
- 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 +139 -181
- package/checkbox/Checkbox.stories.tsx +128 -94
- package/checkbox/Checkbox.test.js +160 -39
- package/checkbox/types.d.ts +11 -3
- package/chip/Chip.accessibility.test.js +67 -0
- package/chip/Chip.js +45 -80
- package/chip/Chip.stories.tsx +107 -27
- package/chip/Chip.test.js +18 -33
- package/chip/types.d.ts +4 -4
- 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 +1392 -0
- package/common/variables.js +984 -1206
- 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/contextual-menu/ContextualMenu.accessibility.test.js +97 -0
- package/contextual-menu/ContextualMenu.d.ts +5 -0
- package/contextual-menu/ContextualMenu.js +88 -0
- package/contextual-menu/ContextualMenu.stories.tsx +232 -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 +51 -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/date-input/Calendar.d.ts +4 -0
- package/date-input/Calendar.js +214 -0
- package/date-input/DateInput.accessibility.test.js +228 -0
- package/date-input/DateInput.js +149 -299
- package/date-input/DateInput.stories.tsx +210 -56
- package/date-input/DateInput.test.js +700 -371
- 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 +72 -15
- package/dialog/Dialog.accessibility.test.js +69 -0
- package/dialog/Dialog.d.ts +1 -1
- package/dialog/Dialog.js +61 -106
- package/dialog/Dialog.stories.tsx +326 -167
- package/dialog/Dialog.test.js +287 -20
- 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/dropdown/Dropdown.accessibility.test.js +180 -0
- package/dropdown/Dropdown.d.ts +1 -1
- package/dropdown/Dropdown.js +233 -303
- package/dropdown/Dropdown.stories.tsx +235 -57
- package/dropdown/Dropdown.test.js +575 -165
- package/dropdown/DropdownMenu.d.ts +4 -0
- package/dropdown/DropdownMenu.js +63 -0
- package/dropdown/DropdownMenuItem.d.ts +4 -0
- package/dropdown/DropdownMenuItem.js +71 -0
- package/dropdown/types.d.ts +35 -19
- package/file-input/FileInput.accessibility.test.js +160 -0
- package/file-input/FileInput.d.ts +2 -2
- package/file-input/FileInput.js +241 -391
- package/file-input/FileInput.stories.tsx +123 -12
- package/file-input/FileInput.test.js +306 -367
- package/file-input/FileItem.d.ts +4 -14
- package/file-input/FileItem.js +56 -117
- package/file-input/types.d.ts +25 -8
- 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/footer/Footer.accessibility.test.js +125 -0
- package/footer/Footer.d.ts +1 -1
- package/footer/Footer.js +73 -118
- package/footer/Footer.stories.tsx +99 -21
- package/footer/Footer.test.js +33 -57
- package/footer/Icons.d.ts +3 -2
- package/footer/Icons.js +54 -23
- package/footer/types.d.ts +26 -27
- 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 +93 -0
- package/header/Header.d.ts +4 -3
- package/header/Header.js +90 -183
- package/header/Header.stories.tsx +133 -38
- package/header/Header.test.js +13 -26
- package/header/Icons.d.ts +2 -2
- package/header/Icons.js +5 -15
- package/header/types.d.ts +7 -21
- package/heading/Heading.accessibility.test.js +33 -0
- package/heading/Heading.js +10 -32
- package/heading/Heading.test.js +71 -88
- 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.js +13 -21
- package/inset/Inset.stories.tsx +5 -4
- package/inset/types.d.ts +2 -2
- package/layout/ApplicationLayout.d.ts +15 -6
- package/layout/ApplicationLayout.js +57 -119
- package/layout/ApplicationLayout.stories.tsx +81 -45
- package/layout/Icons.d.ts +7 -5
- package/layout/Icons.js +41 -59
- package/layout/types.d.ts +21 -32
- package/link/Link.accessibility.test.js +108 -0
- package/link/Link.js +32 -51
- package/link/Link.stories.tsx +76 -9
- package/link/Link.test.js +24 -44
- package/link/types.d.ts +14 -14
- package/main.d.ts +14 -12
- package/main.js +51 -88
- package/nav-tabs/NavTabs.accessibility.test.js +44 -0
- package/nav-tabs/NavTabs.d.ts +7 -0
- package/{tabs-nav → nav-tabs}/NavTabs.js +30 -62
- package/nav-tabs/NavTabs.stories.tsx +279 -0
- package/nav-tabs/NavTabs.test.js +77 -0
- package/nav-tabs/NavTabsContext.d.ts +3 -0
- package/nav-tabs/NavTabsContext.js +8 -0
- package/nav-tabs/Tab.js +117 -0
- package/{tabs-nav → nav-tabs}/types.d.ts +15 -16
- package/nav-tabs/types.js +5 -0
- package/number-input/NumberInput.accessibility.test.js +228 -0
- package/number-input/NumberInput.js +46 -36
- package/number-input/NumberInput.stories.tsx +42 -26
- package/number-input/NumberInput.test.js +860 -377
- package/number-input/NumberInputContext.d.ts +3 -4
- package/number-input/NumberInputContext.js +3 -14
- package/number-input/types.d.ts +17 -5
- package/package.json +51 -51
- package/paginator/Paginator.accessibility.test.js +79 -0
- package/paginator/Paginator.js +35 -68
- package/paginator/Paginator.stories.tsx +24 -0
- package/paginator/Paginator.test.js +280 -211
- package/paginator/types.d.ts +3 -3
- package/paragraph/Paragraph.accessibility.test.js +28 -0
- package/paragraph/Paragraph.d.ts +3 -4
- package/paragraph/Paragraph.js +7 -23
- package/paragraph/Paragraph.stories.tsx +1 -18
- package/password-input/PasswordInput.accessibility.test.js +153 -0
- package/password-input/PasswordInput.js +58 -127
- package/password-input/PasswordInput.stories.tsx +1 -33
- package/password-input/PasswordInput.test.js +160 -142
- package/password-input/types.d.ts +8 -7
- package/progress-bar/ProgressBar.accessibility.test.js +35 -0
- package/progress-bar/ProgressBar.js +68 -92
- package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +39 -4
- package/progress-bar/ProgressBar.test.js +72 -44
- package/progress-bar/types.d.ts +3 -3
- package/quick-nav/QuickNav.accessibility.test.js +57 -0
- package/quick-nav/QuickNav.js +24 -42
- package/quick-nav/QuickNav.stories.tsx +146 -27
- package/quick-nav/types.d.ts +10 -10
- package/radio-group/Radio.d.ts +1 -1
- package/radio-group/Radio.js +59 -76
- package/radio-group/RadioGroup.accessibility.test.js +97 -0
- package/radio-group/RadioGroup.js +68 -114
- package/radio-group/RadioGroup.stories.tsx +132 -18
- package/radio-group/RadioGroup.test.js +518 -457
- package/radio-group/types.d.ts +10 -10
- package/resultset-table/Icons.d.ts +7 -0
- package/resultset-table/Icons.js +47 -0
- package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
- package/resultset-table/ResultsetTable.d.ts +7 -0
- package/resultset-table/ResultsetTable.js +171 -0
- package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +168 -30
- package/resultset-table/ResultsetTable.test.js +381 -0
- package/{resultsetTable → resultset-table}/types.d.ts +44 -11
- package/resultset-table/types.js +5 -0
- package/select/Listbox.d.ts +1 -1
- package/select/Listbox.js +68 -65
- package/select/Option.js +35 -56
- package/select/Select.accessibility.test.js +228 -0
- package/select/Select.js +171 -214
- package/select/Select.stories.tsx +515 -190
- package/select/Select.test.js +1934 -1789
- package/select/types.d.ts +17 -21
- package/sidenav/Sidenav.accessibility.test.js +59 -0
- package/sidenav/Sidenav.d.ts +6 -5
- package/sidenav/Sidenav.js +132 -78
- package/sidenav/Sidenav.stories.tsx +246 -151
- package/sidenav/Sidenav.test.js +26 -45
- package/{layout → sidenav}/SidenavContext.d.ts +1 -1
- package/{layout → sidenav}/SidenavContext.js +3 -9
- 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.stories.tsx +64 -61
- package/slider/Slider.test.js +185 -81
- package/slider/types.d.ts +7 -3
- package/spinner/Spinner.accessibility.test.js +96 -0
- package/spinner/Spinner.js +34 -74
- package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
- package/spinner/Spinner.test.js +26 -35
- 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 +98 -0
- package/switch/Switch.d.ts +2 -2
- package/switch/Switch.js +145 -126
- package/switch/Switch.stories.tsx +49 -60
- package/switch/Switch.test.js +138 -56
- package/switch/types.d.ts +7 -3
- package/table/DropdownTheme.js +62 -0
- package/table/Table.accessibility.test.js +93 -0
- package/table/Table.d.ts +6 -2
- package/table/Table.js +78 -35
- package/table/Table.stories.tsx +663 -0
- package/table/Table.test.js +95 -8
- 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.js +303 -141
- package/tabs/Tabs.stories.tsx +124 -6
- package/tabs/Tabs.test.js +213 -77
- package/tabs/types.d.ts +30 -20
- package/tag/Tag.accessibility.test.js +69 -0
- package/tag/Tag.js +35 -67
- package/tag/Tag.stories.tsx +18 -8
- package/tag/Tag.test.js +18 -37
- package/tag/types.d.ts +9 -9
- package/text-input/Suggestion.js +40 -28
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +94 -0
- package/text-input/TextInput.accessibility.test.js +321 -0
- package/text-input/TextInput.js +316 -515
- package/text-input/TextInput.stories.tsx +276 -276
- package/text-input/TextInput.test.js +1419 -1375
- package/text-input/types.d.ts +43 -16
- package/textarea/Textarea.accessibility.test.js +155 -0
- package/textarea/Textarea.js +71 -113
- package/textarea/Textarea.stories.tsx +174 -0
- package/textarea/Textarea.test.js +152 -183
- package/textarea/types.d.ts +9 -5
- package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
- package/toggle-group/ToggleGroup.d.ts +2 -2
- package/toggle-group/ToggleGroup.js +94 -107
- package/toggle-group/ToggleGroup.stories.tsx +52 -7
- package/toggle-group/ToggleGroup.test.js +69 -88
- package/toggle-group/types.d.ts +28 -19
- package/typography/Typography.accessibility.test.js +339 -0
- package/typography/Typography.d.ts +2 -2
- package/typography/Typography.js +16 -124
- package/typography/Typography.stories.tsx +185 -162
- package/typography/types.d.ts +1 -1
- package/useTheme.d.ts +1144 -1
- package/useTheme.js +2 -9
- package/useTranslatedLabels.d.ts +84 -1
- package/useTranslatedLabels.js +1 -7
- 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.js +34 -87
- package/wizard/Wizard.stories.tsx +59 -1
- package/wizard/Wizard.test.js +54 -81
- package/wizard/types.d.ts +9 -9
- package/card/ice-cream.jpg +0 -0
- 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/number-input/numberInputContextTypes.d.ts +0 -19
- package/paginator/Icons.js +0 -66
- package/resultsetTable/ResultsetTable.d.ts +0 -4
- package/resultsetTable/ResultsetTable.js +0 -254
- package/resultsetTable/ResultsetTable.test.js +0 -306
- package/row/Row.d.ts +0 -3
- package/row/Row.js +0 -127
- package/row/Row.stories.tsx +0 -237
- package/row/types.d.ts +0 -28
- package/select/Icons.d.ts +0 -10
- package/select/Icons.js +0 -93
- package/stack/Stack.d.ts +0 -3
- package/stack/Stack.js +0 -97
- package/stack/Stack.stories.tsx +0 -164
- package/stack/types.d.ts +0 -24
- package/table/Table.stories.jsx +0 -277
- package/tabs-nav/NavTabs.d.ts +0 -8
- package/tabs-nav/NavTabs.stories.tsx +0 -170
- package/tabs-nav/NavTabs.test.js +0 -82
- package/tabs-nav/Tab.js +0 -132
- package/textarea/Textarea.stories.jsx +0 -157
- package/typography/typographyContextTypes.d.ts +0 -16
- /package/{resultsetTable → action-icon}/types.js +0 -0
- /package/{row → breadcrumbs}/types.js +0 -0
- /package/{stack → container}/types.js +0 -0
- /package/{tabs-nav → contextual-menu}/types.js +0 -0
- /package/{number-input/numberInputContextTypes.js → divider/types.js} +0 -0
- /package/{typography/typographyContextTypes.js → flex/types.js} +0 -0
- /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports["default"] = void 0;
|
|
9
|
+
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
10
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
11
|
+
var _dayjs = _interopRequireDefault(require("dayjs"));
|
|
12
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
13
|
+
var _styledComponents = _interopRequireDefault(require("styled-components"));
|
|
14
|
+
var _Calendar = _interopRequireDefault(require("./Calendar"));
|
|
15
|
+
var _YearPicker = _interopRequireDefault(require("./YearPicker"));
|
|
16
|
+
var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
|
|
17
|
+
var _Icon = _interopRequireDefault(require("../icon/Icon"));
|
|
18
|
+
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
|
|
19
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
|
20
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
|
|
21
|
+
var today = (0, _dayjs["default"])();
|
|
22
|
+
var DxcDatePicker = function DxcDatePicker(_ref) {
|
|
23
|
+
var date = _ref.date,
|
|
24
|
+
onDateSelect = _ref.onDateSelect,
|
|
25
|
+
id = _ref.id;
|
|
26
|
+
var _useState = (0, _react.useState)(date !== null && date !== void 0 && date.isValid() ? date : (0, _dayjs["default"])()),
|
|
27
|
+
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
28
|
+
innerDate = _useState2[0],
|
|
29
|
+
setInnerDate = _useState2[1];
|
|
30
|
+
var _useState3 = (0, _react.useState)("calendar"),
|
|
31
|
+
_useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
|
|
32
|
+
content = _useState4[0],
|
|
33
|
+
setContent = _useState4[1];
|
|
34
|
+
var selectedDate = date !== null && date !== void 0 && date.isValid() ? date : null;
|
|
35
|
+
var translatedLabels = (0, _useTranslatedLabels["default"])();
|
|
36
|
+
var handleDateSelect = function handleDateSelect(date) {
|
|
37
|
+
setInnerDate(date);
|
|
38
|
+
onDateSelect(date);
|
|
39
|
+
};
|
|
40
|
+
var handleOnYearSelect = function handleOnYearSelect(year) {
|
|
41
|
+
setInnerDate(innerDate.set("year", year));
|
|
42
|
+
setContent("calendar");
|
|
43
|
+
};
|
|
44
|
+
var handleMonthChange = function handleMonthChange(date) {
|
|
45
|
+
setInnerDate(date);
|
|
46
|
+
};
|
|
47
|
+
return /*#__PURE__*/_react["default"].createElement(DatePicker, {
|
|
48
|
+
id: id
|
|
49
|
+
}, /*#__PURE__*/_react["default"].createElement(PickerHeader, null, /*#__PURE__*/_react["default"].createElement(HeaderButton, {
|
|
50
|
+
"aria-label": translatedLabels.calendar.previousMonthTitle,
|
|
51
|
+
title: translatedLabels.calendar.previousMonthTitle,
|
|
52
|
+
onClick: function onClick() {
|
|
53
|
+
return handleMonthChange(innerDate.set("month", innerDate.get("month") - 1));
|
|
54
|
+
}
|
|
55
|
+
}, /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
|
|
56
|
+
icon: "keyboard_arrow_left"
|
|
57
|
+
})), /*#__PURE__*/_react["default"].createElement(HeaderYearTrigger, {
|
|
58
|
+
"aria-live": "polite",
|
|
59
|
+
onClick: function onClick() {
|
|
60
|
+
return setContent(function (content) {
|
|
61
|
+
return content === "yearPicker" ? "calendar" : "yearPicker";
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
}, /*#__PURE__*/_react["default"].createElement(HeaderYearTriggerLabel, null, translatedLabels.calendar.months[innerDate.get("month")], " ", innerDate.format("YYYY")), /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
|
|
65
|
+
icon: content === "yearPicker" ? "arrow_drop_up" : "arrow_drop_down"
|
|
66
|
+
})), /*#__PURE__*/_react["default"].createElement(HeaderButton, {
|
|
67
|
+
"aria-label": translatedLabels.calendar.nextMonthTitle,
|
|
68
|
+
title: translatedLabels.calendar.nextMonthTitle,
|
|
69
|
+
onClick: function onClick() {
|
|
70
|
+
return handleMonthChange(innerDate.set("month", innerDate.get("month") + 1));
|
|
71
|
+
}
|
|
72
|
+
}, /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
|
|
73
|
+
icon: "keyboard_arrow_right"
|
|
74
|
+
}))), content === "calendar" && /*#__PURE__*/_react["default"].createElement(_Calendar["default"], {
|
|
75
|
+
innerDate: innerDate,
|
|
76
|
+
selectedDate: selectedDate,
|
|
77
|
+
onInnerDateChange: setInnerDate,
|
|
78
|
+
onDaySelect: handleDateSelect,
|
|
79
|
+
today: today
|
|
80
|
+
}), content === "yearPicker" && /*#__PURE__*/_react["default"].createElement(_YearPicker["default"], {
|
|
81
|
+
selectedDate: selectedDate,
|
|
82
|
+
onYearSelect: handleOnYearSelect,
|
|
83
|
+
today: today
|
|
84
|
+
}));
|
|
85
|
+
};
|
|
86
|
+
var DatePicker = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n padding-top: 16px;\n background-color: ", ";\n box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);\n border: ", ";\n border-radius: 4px;\n width: fit-content;\n font-family: ", ";\n font-size: ", ";\n color: ", ";\n font-weight: ", ";\n"])), function (props) {
|
|
87
|
+
return props.theme.dateInput.pickerBackgroundColor;
|
|
88
|
+
}, function (props) {
|
|
89
|
+
return "".concat(props.theme.dateInput.pickerBorderWidth, " ").concat(props.theme.dateInput.pickerBorderStyle, "\n ").concat(props.theme.dateInput.pickerBorderColor);
|
|
90
|
+
}, function (props) {
|
|
91
|
+
return props.theme.dateInput.pickerFontFamily;
|
|
92
|
+
}, function (props) {
|
|
93
|
+
return props.theme.dateInput.pickerFontSize;
|
|
94
|
+
}, function (props) {
|
|
95
|
+
return props.theme.dateInput.pickerFontColor;
|
|
96
|
+
}, function (props) {
|
|
97
|
+
return props.theme.dateInput.pickerFontWeight;
|
|
98
|
+
});
|
|
99
|
+
var PickerHeader = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: flex;\n gap: 8px;\n align-items: center;\n justify-content: space-between;\n padding: 0px 16px;\n"])));
|
|
100
|
+
var HeaderButton = _styledComponents["default"].button(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n width: 24px;\n height: 24px;\n padding: 0px;\n color: ", ";\n background-color: ", ";\n border-radius: 4px;\n border: none;\n cursor: pointer;\n\n &:hover {\n color: ", ";\n background-color: ", ";\n }\n &:focus {\n outline: ", ";\n }\n &:active {\n color: ", ";\n background-color: ", ";\n }\n\n span::before {\n font-size: 24px;\n }\n"])), function (props) {
|
|
101
|
+
return props.theme.dateInput.pickerHeaderFontColor;
|
|
102
|
+
}, function (props) {
|
|
103
|
+
return props.theme.dateInput.pickerHeaderBackgroundColor;
|
|
104
|
+
}, function (props) {
|
|
105
|
+
return props.theme.dateInput.pickerHeaderHoverFontColor;
|
|
106
|
+
}, function (props) {
|
|
107
|
+
return props.theme.dateInput.pickerHeaderHoverBackgroundColor;
|
|
108
|
+
}, function (props) {
|
|
109
|
+
return "".concat(props.theme.dateInput.pickerFocusColor, " solid\n ").concat(props.theme.dateInput.pickerFocusWidth);
|
|
110
|
+
}, function (props) {
|
|
111
|
+
return props.theme.dateInput.pickerHeaderActiveFontColor;
|
|
112
|
+
}, function (props) {
|
|
113
|
+
return props.theme.dateInput.pickerHeaderActiveBackgroundColor;
|
|
114
|
+
});
|
|
115
|
+
var HeaderYearTrigger = (0, _styledComponents["default"])(HeaderButton)(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n gap: 8px;\n height: 40px;\n width: 172px;\n font-size: 24px;\n span::before {\n font-size: 24px;\n }\n"])));
|
|
116
|
+
var HeaderYearTriggerLabel = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n font-family: ", ";\n font-size: ", ";\n"])), function (props) {
|
|
117
|
+
return props.theme.dateInput.pickerFontFamily;
|
|
118
|
+
}, function (props) {
|
|
119
|
+
return props.theme.dateInput.pickerHeaderFontSize;
|
|
120
|
+
});
|
|
121
|
+
var _default = exports["default"] = /*#__PURE__*/_react["default"].memo(DxcDatePicker);
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports["default"] = void 0;
|
|
9
|
+
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
10
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
11
|
+
var _dayjs = _interopRequireDefault(require("dayjs"));
|
|
12
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
13
|
+
var _styledComponents = _interopRequireDefault(require("styled-components"));
|
|
14
|
+
var _templateObject, _templateObject2;
|
|
15
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
|
16
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
|
|
17
|
+
var getYearsArray = function getYearsArray() {
|
|
18
|
+
var yearList = [];
|
|
19
|
+
for (var i = 1899; i <= 2100; i++) {
|
|
20
|
+
yearList.push(i);
|
|
21
|
+
}
|
|
22
|
+
return yearList;
|
|
23
|
+
};
|
|
24
|
+
var yearList = getYearsArray();
|
|
25
|
+
var YearPicker = function YearPicker(_ref) {
|
|
26
|
+
var onYearSelect = _ref.onYearSelect,
|
|
27
|
+
selectedDate = _ref.selectedDate,
|
|
28
|
+
today = _ref.today;
|
|
29
|
+
var _useState = (0, _react.useState)(selectedDate ? selectedDate.get("year") : (0, _dayjs["default"])().get("year")),
|
|
30
|
+
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
31
|
+
yearToFocus = _useState2[0],
|
|
32
|
+
setYearToFocus = _useState2[1];
|
|
33
|
+
(0, _react.useEffect)(function () {
|
|
34
|
+
var _yearToFocusEl$scroll;
|
|
35
|
+
var yearToFocusEl = document.getElementById("year_".concat(yearToFocus));
|
|
36
|
+
yearToFocusEl === null || yearToFocusEl === void 0 ? void 0 : (_yearToFocusEl$scroll = yearToFocusEl.scrollIntoView) === null || _yearToFocusEl$scroll === void 0 ? void 0 : _yearToFocusEl$scroll.call(yearToFocusEl, {
|
|
37
|
+
block: "nearest",
|
|
38
|
+
inline: "start"
|
|
39
|
+
});
|
|
40
|
+
yearToFocusEl === null || yearToFocusEl === void 0 ? void 0 : yearToFocusEl.focus();
|
|
41
|
+
}, [yearToFocus]);
|
|
42
|
+
var handleDayKeyboardEvent = function handleDayKeyboardEvent(event) {
|
|
43
|
+
switch (event.key) {
|
|
44
|
+
case "ArrowUp":
|
|
45
|
+
setYearToFocus(function (prev) {
|
|
46
|
+
return prev > 1899 ? prev - 1 : prev;
|
|
47
|
+
});
|
|
48
|
+
break;
|
|
49
|
+
case "ArrowDown":
|
|
50
|
+
setYearToFocus(function (prev) {
|
|
51
|
+
return prev < 2100 ? prev + 1 : prev;
|
|
52
|
+
});
|
|
53
|
+
break;
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
return /*#__PURE__*/_react["default"].createElement(YearPickerContainer, null, yearList.map(function (year) {
|
|
57
|
+
return /*#__PURE__*/_react["default"].createElement(YearPickerButton, {
|
|
58
|
+
"aria-label": year,
|
|
59
|
+
key: year,
|
|
60
|
+
selected: (selectedDate === null || selectedDate === void 0 ? void 0 : selectedDate.get("year")) === year,
|
|
61
|
+
"aria-selected": (selectedDate === null || selectedDate === void 0 ? void 0 : selectedDate.get("year")) === year,
|
|
62
|
+
tabIndex: yearToFocus === year ? 0 : -1,
|
|
63
|
+
isCurrentYear: today.get("year") === year,
|
|
64
|
+
onKeyDown: function onKeyDown(event) {
|
|
65
|
+
return handleDayKeyboardEvent(event);
|
|
66
|
+
},
|
|
67
|
+
id: "year_".concat(year),
|
|
68
|
+
onClick: function onClick() {
|
|
69
|
+
onYearSelect(year);
|
|
70
|
+
}
|
|
71
|
+
}, year);
|
|
72
|
+
}));
|
|
73
|
+
};
|
|
74
|
+
var YearPickerContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: flex;\n flex-direction: column;\n gap: 4px;\n align-items: center;\n overflow-y: scroll;\n width: 292px;\n height: 312px;\n padding: 2px 8px 8px 8px;\n"])));
|
|
75
|
+
var YearPickerButton = _styledComponents["default"].button(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n width: 80px;\n min-height: 40px;\n line-height: 21px;\n background-color: transparent;\n border: none;\n border-radius: 50px;\n cursor: pointer;\n font-family: ", ";\n font-size: ", ";\n color: ", ";\n font-weight: ", ";\n\n ", "\n\n &:hover, &:focus, &:active {\n font-size: ", ";\n line-height: 36px;\n }\n &:hover {\n color: ", ";\n background-color: ", ";\n }\n &:focus {\n color: ", ";\n outline: ", ";\n }\n &:active {\n color: ", ";\n background-color: ", " !important;\n }\n"])), function (props) {
|
|
76
|
+
return props.theme.dateInput.pickerFontFamily;
|
|
77
|
+
}, function (props) {
|
|
78
|
+
return props.theme.dateInput.pickerFontSize;
|
|
79
|
+
}, function (props) {
|
|
80
|
+
return props.theme.dateInput.pickerFontColor;
|
|
81
|
+
}, function (props) {
|
|
82
|
+
return props.theme.dateInput.pickerFontWeight;
|
|
83
|
+
}, function (props) {
|
|
84
|
+
return props.selected ? "font-size: ".concat(props.theme.dateInput.pickerInteractedYearFontSize, ";\n line-height: 36px;\n color: ").concat(props.theme.dateInput.pickerSelectedFontColor, " !important;\n background-color: ").concat(props.theme.dateInput.pickerSelectedBackgroundColor, " !important;") : props.isCurrentYear ? "border: 1px solid ".concat(props.theme.dateInput.pickerCurrentDateBorderColor, "; \n color: ").concat(props.theme.dateInput.pickerCurrentYearFontColor, ";") : "";
|
|
85
|
+
}, function (props) {
|
|
86
|
+
return props.theme.dateInput.pickerInteractedYearFontSize;
|
|
87
|
+
}, function (props) {
|
|
88
|
+
return props.theme.dateInput.pickerHoverFontColor;
|
|
89
|
+
}, function (props) {
|
|
90
|
+
return props.theme.dateInput.pickerHoverBackgroundColor;
|
|
91
|
+
}, function (props) {
|
|
92
|
+
return props.theme.dateInput.pickerHoverFontColor;
|
|
93
|
+
}, function (props) {
|
|
94
|
+
return "".concat(props.theme.dateInput.pickerFocusColor, " solid\n ").concat(props.theme.dateInput.pickerFocusWidth);
|
|
95
|
+
}, function (props) {
|
|
96
|
+
return props.theme.dateInput.pickerActiveFontColor;
|
|
97
|
+
}, function (props) {
|
|
98
|
+
return props.theme.dateInput.pickerActiveBackgroundColor;
|
|
99
|
+
});
|
|
100
|
+
var _default = exports["default"] = /*#__PURE__*/_react["default"].memo(YearPicker);
|
package/date-input/types.d.ts
CHANGED
|
@@ -1,19 +1,12 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import { Dayjs } from "dayjs";
|
|
2
|
+
type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
|
|
3
|
+
type Margin = {
|
|
3
4
|
top?: Space;
|
|
4
5
|
bottom?: Space;
|
|
5
6
|
left?: Space;
|
|
6
7
|
right?: Space;
|
|
7
8
|
};
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* Text to be placed above the date.
|
|
11
|
-
*/
|
|
12
|
-
label?: string;
|
|
13
|
-
/**
|
|
14
|
-
* Name attribute of the input element.
|
|
15
|
-
*/
|
|
16
|
-
name?: string;
|
|
9
|
+
type Props = {
|
|
17
10
|
/**
|
|
18
11
|
* Initial value of the input element, only when it is uncontrolled.
|
|
19
12
|
*/
|
|
@@ -23,9 +16,13 @@ declare type Props = {
|
|
|
23
16
|
*/
|
|
24
17
|
value?: string;
|
|
25
18
|
/**
|
|
26
|
-
*
|
|
19
|
+
* Text to be placed above the date input.
|
|
27
20
|
*/
|
|
28
|
-
|
|
21
|
+
label?: string;
|
|
22
|
+
/**
|
|
23
|
+
* Name attribute of the input element.
|
|
24
|
+
*/
|
|
25
|
+
name?: string;
|
|
29
26
|
/**
|
|
30
27
|
* Helper text to be placed above the date.
|
|
31
28
|
*/
|
|
@@ -34,6 +31,10 @@ declare type Props = {
|
|
|
34
31
|
* If true, the date format will appear as placeholder in the field.
|
|
35
32
|
*/
|
|
36
33
|
placeholder?: boolean;
|
|
34
|
+
/**
|
|
35
|
+
* The format in which the date value will be displayed. User must use this format when editing the value or it will be considered as an invalid date.
|
|
36
|
+
*/
|
|
37
|
+
format?: string;
|
|
37
38
|
/**
|
|
38
39
|
* If true, the date input will have an action to clear the entered value.
|
|
39
40
|
*/
|
|
@@ -43,12 +44,18 @@ declare type Props = {
|
|
|
43
44
|
*/
|
|
44
45
|
disabled?: boolean;
|
|
45
46
|
/**
|
|
46
|
-
* If true, the date will be optional, showing '(Optional)'
|
|
47
|
+
* If true, the date will be optional, showing the text '(Optional)'
|
|
47
48
|
* next to the label. Otherwise, the field will be considered required and an error will be
|
|
48
49
|
* passed as a parameter to the OnBlur and onChange functions when it has
|
|
49
50
|
* not been filled.
|
|
50
51
|
*/
|
|
51
52
|
optional?: boolean;
|
|
53
|
+
/**
|
|
54
|
+
* If true, the component will not be mutable, meaning the user can not edit the control.
|
|
55
|
+
* The date picker cannot be opened either. In addition, the clear action will not be displayed
|
|
56
|
+
* even if the flag is set to true.
|
|
57
|
+
*/
|
|
58
|
+
readOnly?: boolean;
|
|
52
59
|
/**
|
|
53
60
|
* This function will be called when the user types within the input
|
|
54
61
|
* element of the component. An object including the string value, the
|
|
@@ -100,8 +107,58 @@ declare type Props = {
|
|
|
100
107
|
*/
|
|
101
108
|
tabIndex?: number;
|
|
102
109
|
};
|
|
110
|
+
export type DatePickerPropsType = {
|
|
111
|
+
/**
|
|
112
|
+
* Initial selected date value. If invalid the actual date will be used instead.
|
|
113
|
+
*/
|
|
114
|
+
date: Dayjs;
|
|
115
|
+
/**
|
|
116
|
+
* Function called when a date is selected.
|
|
117
|
+
*/
|
|
118
|
+
onDateSelect: (date: Dayjs) => void;
|
|
119
|
+
/**
|
|
120
|
+
* Id assigned to the date picker.
|
|
121
|
+
*/
|
|
122
|
+
id: string;
|
|
123
|
+
};
|
|
124
|
+
export type CalendarPropsType = {
|
|
125
|
+
/**
|
|
126
|
+
* Initial selected date value. If invalid the actual date will be used instead.
|
|
127
|
+
*/
|
|
128
|
+
selectedDate: Dayjs;
|
|
129
|
+
/**
|
|
130
|
+
* Date shown by the calendar.
|
|
131
|
+
*/
|
|
132
|
+
innerDate: Dayjs;
|
|
133
|
+
/**
|
|
134
|
+
* Function called when the shown date needs to be updated.
|
|
135
|
+
*/
|
|
136
|
+
onInnerDateChange: (date: Dayjs) => void;
|
|
137
|
+
/**
|
|
138
|
+
* Function called when a date is selected.
|
|
139
|
+
*/
|
|
140
|
+
onDaySelect: (date: Dayjs) => void;
|
|
141
|
+
/**
|
|
142
|
+
* Current date.
|
|
143
|
+
*/
|
|
144
|
+
today: Dayjs;
|
|
145
|
+
};
|
|
146
|
+
export type YearPickerPropsType = {
|
|
147
|
+
/**
|
|
148
|
+
* Initial selected date value. If invalid the actual date will be used instead.
|
|
149
|
+
*/
|
|
150
|
+
selectedDate: Dayjs;
|
|
151
|
+
/**
|
|
152
|
+
* Function called when a year is selected.
|
|
153
|
+
*/
|
|
154
|
+
onYearSelect: (year: number) => void;
|
|
155
|
+
/**
|
|
156
|
+
* Current date.
|
|
157
|
+
*/
|
|
158
|
+
today: Dayjs;
|
|
159
|
+
};
|
|
103
160
|
/**
|
|
104
161
|
* Reference to the component.
|
|
105
162
|
*/
|
|
106
|
-
export
|
|
163
|
+
export type RefType = HTMLDivElement;
|
|
107
164
|
export default Props;
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
5
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
6
|
+
var _react = _interopRequireDefault(require("react"));
|
|
7
|
+
var _react2 = require("@testing-library/react");
|
|
8
|
+
var _axeHelper = require("../../test/accessibility/axe-helper.js");
|
|
9
|
+
var _Dialog = _interopRequireDefault(require("./Dialog.tsx"));
|
|
10
|
+
describe("Dialog component accessibility tests", function () {
|
|
11
|
+
it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
|
|
12
|
+
var _render, baseElement, results;
|
|
13
|
+
return _regenerator["default"].wrap(function _callee$(_context) {
|
|
14
|
+
while (1) switch (_context.prev = _context.next) {
|
|
15
|
+
case 0:
|
|
16
|
+
// baseElement is needed when using React Portals
|
|
17
|
+
_render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, "Dialog text")), baseElement = _render.baseElement;
|
|
18
|
+
_context.next = 3;
|
|
19
|
+
return (0, _axeHelper.axe)(baseElement);
|
|
20
|
+
case 3:
|
|
21
|
+
results = _context.sent;
|
|
22
|
+
expect(results).toHaveNoViolations();
|
|
23
|
+
case 5:
|
|
24
|
+
case "end":
|
|
25
|
+
return _context.stop();
|
|
26
|
+
}
|
|
27
|
+
}, _callee);
|
|
28
|
+
})));
|
|
29
|
+
it("Should not have basic accessibility issues for close button not visible", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
|
|
30
|
+
var _render2, baseElement, results;
|
|
31
|
+
return _regenerator["default"].wrap(function _callee2$(_context2) {
|
|
32
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
33
|
+
case 0:
|
|
34
|
+
// baseElement is needed when using React Portals
|
|
35
|
+
_render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], {
|
|
36
|
+
isCloseVisible: false
|
|
37
|
+
}, "Dialog text")), baseElement = _render2.baseElement;
|
|
38
|
+
_context2.next = 3;
|
|
39
|
+
return (0, _axeHelper.axe)(baseElement);
|
|
40
|
+
case 3:
|
|
41
|
+
results = _context2.sent;
|
|
42
|
+
expect(results).toHaveNoViolations();
|
|
43
|
+
case 5:
|
|
44
|
+
case "end":
|
|
45
|
+
return _context2.stop();
|
|
46
|
+
}
|
|
47
|
+
}, _callee2);
|
|
48
|
+
})));
|
|
49
|
+
it("Should not have basic accessibility issues for overlay not visible", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
|
|
50
|
+
var _render3, baseElement, results;
|
|
51
|
+
return _regenerator["default"].wrap(function _callee3$(_context3) {
|
|
52
|
+
while (1) switch (_context3.prev = _context3.next) {
|
|
53
|
+
case 0:
|
|
54
|
+
// baseElement is needed when using React Portals
|
|
55
|
+
_render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], {
|
|
56
|
+
overlay: false
|
|
57
|
+
}, "Dialog text")), baseElement = _render3.baseElement;
|
|
58
|
+
_context3.next = 3;
|
|
59
|
+
return (0, _axeHelper.axe)(baseElement);
|
|
60
|
+
case 3:
|
|
61
|
+
results = _context3.sent;
|
|
62
|
+
expect(results).toHaveNoViolations();
|
|
63
|
+
case 5:
|
|
64
|
+
case "end":
|
|
65
|
+
return _context3.stop();
|
|
66
|
+
}
|
|
67
|
+
}, _callee3);
|
|
68
|
+
})));
|
|
69
|
+
});
|
package/dialog/Dialog.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import DialogPropsType from "./types";
|
|
3
|
-
declare const DxcDialog: ({ isCloseVisible, onCloseClick, children, overlay, onBackgroundClick,
|
|
3
|
+
declare const DxcDialog: ({ isCloseVisible, onCloseClick, children, overlay, onBackgroundClick, tabIndex, }: DialogPropsType) => JSX.Element;
|
|
4
4
|
export default DxcDialog;
|
package/dialog/Dialog.js
CHANGED
|
@@ -1,129 +1,84 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
|
-
var _typeof3 = require("@babel/runtime/helpers/typeof");
|
|
6
|
-
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
7
5
|
Object.defineProperty(exports, "__esModule", {
|
|
8
6
|
value: true
|
|
9
7
|
});
|
|
10
8
|
exports["default"] = void 0;
|
|
11
|
-
|
|
12
|
-
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
|
|
13
|
-
|
|
14
9
|
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
15
|
-
|
|
16
|
-
var _react = _interopRequireDefault(require("react"));
|
|
17
|
-
|
|
10
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
18
11
|
var _styledComponents = _interopRequireWildcard(require("styled-components"));
|
|
19
|
-
|
|
20
|
-
var _Dialog = _interopRequireDefault(require("@material-ui/core/Dialog"));
|
|
21
|
-
|
|
22
|
-
var _variables = require("../common/variables.js");
|
|
23
|
-
|
|
12
|
+
var _variables = require("../common/variables");
|
|
24
13
|
var _useTheme = _interopRequireDefault(require("../useTheme"));
|
|
25
|
-
|
|
26
|
-
var
|
|
27
|
-
|
|
28
|
-
var
|
|
29
|
-
|
|
30
|
-
function _getRequireWildcardCache(
|
|
31
|
-
|
|
32
|
-
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
33
|
-
|
|
14
|
+
var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
|
|
15
|
+
var _reactDom = require("react-dom");
|
|
16
|
+
var _FocusLock = _interopRequireDefault(require("../utils/FocusLock"));
|
|
17
|
+
var _Icon = _interopRequireDefault(require("../icon/Icon"));
|
|
18
|
+
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
|
|
19
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
|
20
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
|
|
34
21
|
var DxcDialog = function DxcDialog(_ref) {
|
|
35
22
|
var _ref$isCloseVisible = _ref.isCloseVisible,
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
_ref$tabIndex = _ref.tabIndex,
|
|
45
|
-
tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
|
|
23
|
+
isCloseVisible = _ref$isCloseVisible === void 0 ? true : _ref$isCloseVisible,
|
|
24
|
+
onCloseClick = _ref.onCloseClick,
|
|
25
|
+
children = _ref.children,
|
|
26
|
+
_ref$overlay = _ref.overlay,
|
|
27
|
+
overlay = _ref$overlay === void 0 ? true : _ref$overlay,
|
|
28
|
+
onBackgroundClick = _ref.onBackgroundClick,
|
|
29
|
+
_ref$tabIndex = _ref.tabIndex,
|
|
30
|
+
tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
|
|
46
31
|
var colorsTheme = (0, _useTheme["default"])();
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
32
|
+
var translatedLabels = (0, _useTranslatedLabels["default"])();
|
|
33
|
+
(0, _react.useEffect)(function () {
|
|
34
|
+
var handleKeyDown = function handleKeyDown(event) {
|
|
35
|
+
if (event.key === "Escape") {
|
|
36
|
+
event.preventDefault();
|
|
37
|
+
onCloseClick === null || onCloseClick === void 0 ? void 0 : onCloseClick();
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
document.addEventListener("keydown", handleKeyDown);
|
|
41
|
+
return function () {
|
|
42
|
+
document.removeEventListener("keydown", handleKeyDown);
|
|
43
|
+
};
|
|
44
|
+
}, [onCloseClick]);
|
|
56
45
|
return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
|
|
57
46
|
theme: colorsTheme.dialog
|
|
58
|
-
}, /*#__PURE__*/_react["default"].createElement(DialogContainer, {
|
|
59
|
-
|
|
47
|
+
}, /*#__PURE__*/_react["default"].createElement(BodyStyle, null), /*#__PURE__*/(0, _reactDom.createPortal)( /*#__PURE__*/_react["default"].createElement(DialogContainer, null, overlay && /*#__PURE__*/_react["default"].createElement(Overlay, {
|
|
48
|
+
onClick: function onClick() {
|
|
49
|
+
onBackgroundClick === null || onBackgroundClick === void 0 ? void 0 : onBackgroundClick();
|
|
50
|
+
}
|
|
51
|
+
}), /*#__PURE__*/_react["default"].createElement(Dialog, {
|
|
52
|
+
role: "dialog",
|
|
53
|
+
"aria-modal": overlay,
|
|
60
54
|
isCloseVisible: isCloseVisible,
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
55
|
+
"aria-label": "Dialog"
|
|
56
|
+
}, /*#__PURE__*/_react["default"].createElement(_FocusLock["default"], null, children, isCloseVisible && /*#__PURE__*/_react["default"].createElement(CloseIconAction, {
|
|
57
|
+
onClick: function onClick() {
|
|
58
|
+
onCloseClick === null || onCloseClick === void 0 ? void 0 : onCloseClick();
|
|
59
|
+
},
|
|
60
|
+
"aria-label": translatedLabels.dialog.closeIconAriaLabel,
|
|
66
61
|
tabIndex: tabIndex
|
|
67
|
-
}, /*#__PURE__*/_react["default"].createElement(
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
height: "24",
|
|
71
|
-
viewBox: "0 0 24 24",
|
|
72
|
-
fill: "currentColor"
|
|
73
|
-
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
74
|
-
d: "M0 0h24v24H0V0z",
|
|
75
|
-
fill: "none"
|
|
76
|
-
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
77
|
-
d: "M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41z"
|
|
78
|
-
}))), /*#__PURE__*/_react["default"].createElement(Children, null, /*#__PURE__*/_react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
|
|
79
|
-
color: colorsTheme.dialog.backgroundColor
|
|
80
|
-
}, children))));
|
|
62
|
+
}, /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
|
|
63
|
+
icon: "close"
|
|
64
|
+
}))))), document.body));
|
|
81
65
|
};
|
|
82
|
-
|
|
83
|
-
var DialogContainer =
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
return props.overlay === true ? props.theme.overlayColor : "transparent";
|
|
87
|
-
}, function (props) {
|
|
88
|
-
return props.overlay === true && props.theme.overlayOpacity;
|
|
89
|
-
}, function (props) {
|
|
90
|
-
return props.theme.backgroundColor;
|
|
91
|
-
}, _variables.responsiveSizes.medium, _variables.responsiveSizes.medium, function (props) {
|
|
92
|
-
return props.isCloseVisible ? "72px" : "";
|
|
93
|
-
}, function (props) {
|
|
94
|
-
return "".concat(props.theme.boxShadowOffsetX, " ").concat(props.theme.boxShadowOffsetY, " ").concat(props.theme.boxShadowBlur, " ").concat(props.theme.boxShadowColor);
|
|
95
|
-
}, function (props) {
|
|
96
|
-
return props.padding && (0, _typeof2["default"])(props.padding) !== "object" ? _variables.spaces[props.padding] : _variables.spaces["small"];
|
|
97
|
-
}, function (props) {
|
|
98
|
-
return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.top ? _variables.spaces[props.padding.top] : "";
|
|
99
|
-
}, function (props) {
|
|
100
|
-
return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.right ? _variables.spaces[props.padding.right] : "";
|
|
101
|
-
}, function (props) {
|
|
102
|
-
return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.bottom ? _variables.spaces[props.padding.bottom] : "";
|
|
103
|
-
}, function (props) {
|
|
104
|
-
return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.left ? _variables.spaces[props.padding.left] : "";
|
|
66
|
+
var BodyStyle = (0, _styledComponents.createGlobalStyle)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n body {\n overflow: hidden;\n }\n"])));
|
|
67
|
+
var DialogContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n position: fixed;\n inset: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n height: 100%;\n z-index: 2147483647;\n"])));
|
|
68
|
+
var Overlay = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n position: fixed;\n inset: 0;\n height: 100%;\n background-color: ", ";\n"])), function (props) {
|
|
69
|
+
return props.theme.overlayColor;
|
|
105
70
|
});
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
var CloseIconContainer = _styledComponents["default"].button(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: flex-end;\n position: absolute;\n top: ", ";\n right: ", ";\n cursor: pointer;\n padding: 0;\n margin: 0;\n background: none;\n color: ", ";\n width: ", ";\n height: ", ";\n border: none;\n"])), function (props) {
|
|
110
|
-
return props.theme.closeIconTopPosition;
|
|
111
|
-
}, function (props) {
|
|
112
|
-
return props.theme.closeIconRightPosition;
|
|
113
|
-
}, function (props) {
|
|
114
|
-
return props.theme.closeIconColor;
|
|
71
|
+
var Dialog = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n box-sizing: border-box;\n max-width: 80%;\n min-width: 696px;\n border-radius: 4px;\n background-color: ", ";\n ", "\n box-shadow: ", ";\n z-index: 2147483647;\n\n @media (max-width: ", "rem) {\n max-width: 92%;\n min-width: 92%;\n }\n"])), function (props) {
|
|
72
|
+
return props.theme.backgroundColor;
|
|
115
73
|
}, function (props) {
|
|
116
|
-
return props.
|
|
74
|
+
return props.isCloseVisible && "min-height: 72px;";
|
|
117
75
|
}, function (props) {
|
|
118
|
-
return props.theme.
|
|
119
|
-
});
|
|
120
|
-
|
|
121
|
-
var CloseIcon = _styledComponents["default"].svg(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n width: ", ";\n height: ", ";\n border-radius: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n"])), function (props) {
|
|
76
|
+
return "".concat(props.theme.boxShadowOffsetX, " ").concat(props.theme.boxShadowOffsetY, " ").concat(props.theme.boxShadowBlur, " ").concat(props.theme.boxShadowColor);
|
|
77
|
+
}, _variables.responsiveSizes.medium);
|
|
78
|
+
var CloseIconAction = _styledComponents["default"].button(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n all: unset;\n position: absolute;\n top: 24px;\n right: 24px;\n display: flex;\n align-items: center;\n justify-content: center;\n background-color: ", ";\n box-shadow: 0 0 0 2px transparent;\n color: ", ";\n border-radius: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n cursor: pointer;\n z-index: 1;\n\n &:focus {\n outline: none;\n box-shadow: 0 0 0 2px #0095ff;\n }\n &:hover {\n background-color: #f2f2f2;\n }\n &:active {\n background-color: #cccccc;\n }\n span {\n font-size: ", ";\n }\n"])), function (props) {
|
|
122
79
|
return props.theme.closeIconBackgroundColor;
|
|
123
80
|
}, function (props) {
|
|
124
|
-
return props.theme.
|
|
125
|
-
}, function (props) {
|
|
126
|
-
return props.theme.closeIconHeight;
|
|
81
|
+
return props.theme.closeIconColor;
|
|
127
82
|
}, function (props) {
|
|
128
83
|
return props.theme.closeIconBorderRadius;
|
|
129
84
|
}, function (props) {
|
|
@@ -132,7 +87,7 @@ var CloseIcon = _styledComponents["default"].svg(_templateObject4 || (_templateO
|
|
|
132
87
|
return props.theme.closeIconBorderStyle;
|
|
133
88
|
}, function (props) {
|
|
134
89
|
return props.theme.closeIconBorderColor;
|
|
90
|
+
}, function (props) {
|
|
91
|
+
return props.theme.closeIconSize;
|
|
135
92
|
});
|
|
136
|
-
|
|
137
|
-
var _default = DxcDialog;
|
|
138
|
-
exports["default"] = _default;
|
|
93
|
+
var _default = exports["default"] = DxcDialog;
|