@dxc-technology/halstack-react 0.0.0-e1386cf → 0.0.0-e19ca5f
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 +122 -106
- package/README.md +47 -0
- package/accordion/Accordion.accessibility.test.js +71 -0
- package/accordion/Accordion.d.ts +1 -1
- package/accordion/Accordion.js +44 -118
- package/accordion/Accordion.stories.tsx +82 -147
- package/accordion/Accordion.test.js +19 -34
- package/accordion/types.d.ts +6 -18
- package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
- package/accordion-group/AccordionGroup.d.ts +2 -2
- package/accordion-group/AccordionGroup.js +29 -77
- package/accordion-group/AccordionGroup.stories.tsx +78 -77
- package/accordion-group/AccordionGroup.test.js +44 -72
- 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 +7 -19
- 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 +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 +1 -0
- 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 +18 -59
- package/box/Box.stories.tsx +38 -51
- package/box/Box.test.js +2 -7
- package/box/types.d.ts +3 -15
- 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 +22 -53
- package/bulleted-list/BulletedList.stories.tsx +8 -93
- 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 +71 -106
- package/button/Button.stories.tsx +143 -101
- package/button/Button.test.js +20 -17
- package/button/types.d.ts +9 -5
- 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 -12
- package/checkbox/Checkbox.accessibility.test.js +87 -0
- package/checkbox/Checkbox.js +90 -125
- package/checkbox/Checkbox.stories.tsx +68 -54
- package/checkbox/Checkbox.test.js +108 -64
- package/checkbox/types.d.ts +8 -4
- 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 +969 -1213
- 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/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 +228 -0
- package/date-input/DateInput.js +149 -299
- package/date-input/DateInput.stories.tsx +210 -56
- package/date-input/DateInput.test.js +694 -429
- 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 +51 -120
- package/dialog/Dialog.stories.tsx +316 -212
- package/dialog/Dialog.test.js +270 -33
- package/dialog/types.d.ts +18 -26
- 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.js +66 -136
- package/dropdown/Dropdown.stories.tsx +209 -94
- package/dropdown/Dropdown.test.js +404 -390
- package/dropdown/DropdownMenu.js +23 -40
- package/dropdown/DropdownMenuItem.js +17 -38
- package/dropdown/types.d.ts +20 -24
- package/file-input/FileInput.accessibility.test.js +160 -0
- package/file-input/FileInput.js +184 -292
- package/file-input/FileInput.stories.tsx +86 -3
- package/file-input/FileInput.test.js +279 -395
- package/file-input/FileItem.js +31 -67
- package/file-input/types.d.ts +10 -10
- package/flex/Flex.js +27 -39
- package/flex/Flex.stories.tsx +35 -26
- package/flex/types.d.ts +74 -9
- 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 +94 -23
- package/footer/Footer.test.js +33 -57
- package/footer/Icons.d.ts +3 -2
- package/footer/Icons.js +53 -22
- package/footer/types.d.ts +26 -28
- 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 +55 -150
- package/header/Header.stories.tsx +130 -35
- package/header/Header.test.js +13 -26
- package/header/Icons.d.ts +2 -2
- package/header/Icons.js +3 -13
- package/header/types.d.ts +7 -22
- 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 +2 -1
- package/inset/types.d.ts +2 -2
- package/layout/ApplicationLayout.d.ts +5 -5
- package/layout/ApplicationLayout.js +36 -70
- package/layout/ApplicationLayout.stories.tsx +1 -1
- package/layout/Icons.d.ts +7 -5
- package/layout/Icons.js +41 -59
- package/layout/types.d.ts +5 -6
- package/link/Link.accessibility.test.js +108 -0
- package/link/Link.js +31 -50
- package/link/Link.stories.tsx +64 -4
- package/link/Link.test.js +24 -44
- package/link/types.d.ts +14 -14
- package/main.d.ts +11 -5
- package/main.js +54 -59
- package/nav-tabs/NavTabs.accessibility.test.js +44 -0
- package/nav-tabs/NavTabs.d.ts +7 -0
- package/{tabs-nav → nav-tabs}/NavTabs.js +25 -57
- 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 -413
- 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 +43 -46
- package/paginator/Paginator.accessibility.test.js +79 -0
- package/paginator/Paginator.js +34 -67
- package/paginator/Paginator.stories.tsx +24 -0
- package/paginator/Paginator.test.js +252 -225
- 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 +6 -22
- package/paragraph/Paragraph.stories.tsx +0 -17
- 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 +158 -141
- package/password-input/types.d.ts +8 -7
- package/progress-bar/ProgressBar.accessibility.test.js +35 -0
- package/progress-bar/ProgressBar.d.ts +2 -2
- package/progress-bar/ProgressBar.js +28 -58
- package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +36 -3
- package/progress-bar/ProgressBar.test.js +36 -53
- package/progress-bar/types.d.ts +4 -3
- package/quick-nav/QuickNav.accessibility.test.js +57 -0
- package/quick-nav/QuickNav.js +4 -27
- package/quick-nav/QuickNav.stories.tsx +15 -1
- package/quick-nav/types.d.ts +10 -10
- package/radio-group/Radio.d.ts +1 -1
- package/radio-group/Radio.js +31 -63
- package/radio-group/RadioGroup.accessibility.test.js +97 -0
- package/radio-group/RadioGroup.js +46 -93
- package/radio-group/RadioGroup.stories.tsx +131 -18
- package/radio-group/RadioGroup.test.js +505 -471
- package/radio-group/types.d.ts +8 -8
- package/resultset-table/Icons.d.ts +7 -0
- package/{text-input → resultset-table}/Icons.js +13 -26
- 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 +43 -86
- package/select/Option.js +35 -56
- package/select/Select.accessibility.test.js +228 -0
- package/select/Select.js +140 -183
- package/select/Select.stories.tsx +496 -204
- package/select/Select.test.js +1949 -1917
- package/select/types.d.ts +17 -18
- package/sidenav/Sidenav.accessibility.test.js +59 -0
- package/sidenav/Sidenav.d.ts +2 -2
- package/sidenav/Sidenav.js +90 -157
- package/sidenav/Sidenav.stories.tsx +160 -63
- package/sidenav/Sidenav.test.js +3 -10
- package/{layout → sidenav}/SidenavContext.d.ts +1 -1
- package/{layout → sidenav}/SidenavContext.js +3 -9
- package/sidenav/types.d.ts +33 -30
- package/slider/Slider.accessibility.test.js +104 -0
- package/slider/Slider.js +75 -132
- package/slider/Slider.test.js +108 -104
- package/slider/types.d.ts +4 -4
- 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.js +52 -100
- package/switch/Switch.stories.tsx +45 -34
- package/switch/Switch.test.js +52 -97
- package/switch/types.d.ts +4 -4
- 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 +94 -7
- package/table/types.d.ts +34 -6
- package/tabs/Tab.js +28 -46
- package/tabs/Tabs.accessibility.test.js +56 -0
- package/tabs/Tabs.js +69 -163
- package/tabs/Tabs.stories.tsx +50 -6
- package/tabs/Tabs.test.js +61 -136
- package/tabs/types.d.ts +21 -21
- package/tag/Tag.accessibility.test.js +69 -0
- package/tag/Tag.js +34 -66
- 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 +35 -25
- package/text-input/Suggestions.d.ts +1 -1
- package/text-input/Suggestions.js +30 -70
- package/text-input/TextInput.accessibility.test.js +321 -0
- package/text-input/TextInput.js +229 -335
- package/text-input/TextInput.stories.tsx +155 -162
- package/text-input/TextInput.test.js +1289 -1157
- package/text-input/types.d.ts +25 -17
- 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 +15 -123
- package/typography/Typography.stories.tsx +1 -1
- 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 +29 -75
- package/wizard/Wizard.stories.tsx +39 -0
- package/wizard/Wizard.test.js +54 -81
- package/wizard/types.d.ts +10 -11
- 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 -252
- package/resultsetTable/ResultsetTable.test.js +0 -348
- package/select/Icons.d.ts +0 -10
- package/select/Icons.js +0 -93
- package/slider/Slider.stories.tsx +0 -183
- 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 -130
- package/text-input/Icons.d.ts +0 -8
- package/textarea/Textarea.stories.jsx +0 -157
- /package/{resultsetTable → action-icon}/types.js +0 -0
- /package/{tabs-nav → breadcrumbs}/types.js +0 -0
- /package/{number-input/numberInputContextTypes.js → container/types.js} +0 -0
- /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
|
@@ -1,49 +1,16 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
6
|
-
|
|
7
5
|
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
8
|
-
|
|
9
6
|
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
10
|
-
|
|
11
7
|
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
12
|
-
|
|
13
8
|
var _react = _interopRequireDefault(require("react"));
|
|
14
|
-
|
|
15
9
|
var _react2 = require("@testing-library/react");
|
|
16
|
-
|
|
17
10
|
var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
|
|
18
|
-
|
|
19
|
-
var _TextInput = _interopRequireDefault(require("./TextInput"));
|
|
20
|
-
|
|
11
|
+
var _TextInput = _interopRequireDefault(require("./TextInput.tsx"));
|
|
21
12
|
// Mocking DOMRect for Radix Primitive Popover
|
|
22
13
|
global.globalThis = global;
|
|
23
|
-
|
|
24
|
-
global.ResizeObserver = /*#__PURE__*/function () {
|
|
25
|
-
function ResizeObserver(cb) {
|
|
26
|
-
(0, _classCallCheck2["default"])(this, ResizeObserver);
|
|
27
|
-
this.cb = cb;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
(0, _createClass2["default"])(ResizeObserver, [{
|
|
31
|
-
key: "observe",
|
|
32
|
-
value: function observe() {
|
|
33
|
-
this.cb([{
|
|
34
|
-
borderBoxSize: {
|
|
35
|
-
inlineSize: 0,
|
|
36
|
-
blockSize: 0
|
|
37
|
-
}
|
|
38
|
-
}]);
|
|
39
|
-
}
|
|
40
|
-
}, {
|
|
41
|
-
key: "unobserve",
|
|
42
|
-
value: function unobserve() {}
|
|
43
|
-
}]);
|
|
44
|
-
return ResizeObserver;
|
|
45
|
-
}();
|
|
46
|
-
|
|
47
14
|
global.DOMRect = {
|
|
48
15
|
fromRect: function fromRect() {
|
|
49
16
|
return {
|
|
@@ -56,17 +23,33 @@ global.DOMRect = {
|
|
|
56
23
|
};
|
|
57
24
|
}
|
|
58
25
|
};
|
|
26
|
+
global.ResizeObserver = /*#__PURE__*/function () {
|
|
27
|
+
function ResizeObserver() {
|
|
28
|
+
(0, _classCallCheck2["default"])(this, ResizeObserver);
|
|
29
|
+
}
|
|
30
|
+
(0, _createClass2["default"])(ResizeObserver, [{
|
|
31
|
+
key: "observe",
|
|
32
|
+
value: function observe() {}
|
|
33
|
+
}, {
|
|
34
|
+
key: "unobserve",
|
|
35
|
+
value: function unobserve() {}
|
|
36
|
+
}, {
|
|
37
|
+
key: "disconnect",
|
|
38
|
+
value: function disconnect() {}
|
|
39
|
+
}]);
|
|
40
|
+
return ResizeObserver;
|
|
41
|
+
}();
|
|
59
42
|
var countries = ["Afghanistan", "Albania", "Algeria", "Andorra", "Angola", "Antigua and Barbuda", "Bahamas", "Bahrain", "Bangladesh", "Barbados", "Cabo Verde", "Cambodia", "Cameroon", "Canada", "Cayman Islands, The", "Central African Republic", "Chad", "Democratic Republic of the Congo", "Dominican Republic", "Dominica", "Denmark", "Djibouti"];
|
|
43
|
+
var specialCharacters = ["/", "\\", "*", "(", ")", "[", "]", "+", "?", "*{[]}|"];
|
|
60
44
|
describe("TextInput component tests", function () {
|
|
61
45
|
test("Renders with correct error aria attributes", function () {
|
|
62
46
|
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
47
|
+
label: "Error label",
|
|
48
|
+
placeholder: "Placeholder",
|
|
49
|
+
error: "Error message."
|
|
50
|
+
})),
|
|
51
|
+
getByText = _render.getByText,
|
|
52
|
+
getByRole = _render.getByRole;
|
|
70
53
|
var input = getByRole("textbox");
|
|
71
54
|
var errorMessage = getByText("Error message.");
|
|
72
55
|
expect(errorMessage).toBeTruthy();
|
|
@@ -76,48 +59,39 @@ describe("TextInput component tests", function () {
|
|
|
76
59
|
});
|
|
77
60
|
test("Renders with correct initial value", function () {
|
|
78
61
|
var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
62
|
+
label: "Default label",
|
|
63
|
+
placeholder: "Placeholder",
|
|
64
|
+
defaultValue: "Example text"
|
|
65
|
+
})),
|
|
66
|
+
getByRole = _render2.getByRole;
|
|
85
67
|
var input = getByRole("textbox");
|
|
86
68
|
expect(input.value).toBe("Example text");
|
|
87
69
|
});
|
|
88
70
|
test("Not optional constraint (onBlur)", function () {
|
|
89
71
|
var onChange = jest.fn();
|
|
90
72
|
var onBlur = jest.fn();
|
|
91
|
-
|
|
92
73
|
var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
74
|
+
label: "Input label",
|
|
75
|
+
placeholder: "Placeholder",
|
|
76
|
+
onChange: onChange,
|
|
77
|
+
onBlur: onBlur,
|
|
78
|
+
clearable: true
|
|
79
|
+
})),
|
|
80
|
+
getByRole = _render3.getByRole;
|
|
101
81
|
var input = getByRole("textbox");
|
|
102
|
-
|
|
103
82
|
_react2.fireEvent.focus(input);
|
|
104
|
-
|
|
105
83
|
_react2.fireEvent.blur(input);
|
|
106
|
-
|
|
107
84
|
expect(onBlur).toHaveBeenCalled();
|
|
108
85
|
expect(onBlur).toHaveBeenCalledWith({
|
|
109
86
|
value: "",
|
|
110
87
|
error: "This field is required. Please, enter a value."
|
|
111
88
|
});
|
|
112
|
-
|
|
113
89
|
_react2.fireEvent.change(input, {
|
|
114
90
|
target: {
|
|
115
91
|
value: "Test"
|
|
116
92
|
}
|
|
117
93
|
});
|
|
118
|
-
|
|
119
94
|
_react2.fireEvent.blur(input);
|
|
120
|
-
|
|
121
95
|
expect(onBlur).toHaveBeenCalled();
|
|
122
96
|
expect(onBlur).toHaveBeenCalledWith({
|
|
123
97
|
value: "Test"
|
|
@@ -125,30 +99,24 @@ describe("TextInput component tests", function () {
|
|
|
125
99
|
});
|
|
126
100
|
test("Not optional constraint (onChange)", function () {
|
|
127
101
|
var onChange = jest.fn();
|
|
128
|
-
|
|
129
102
|
var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
103
|
+
label: "Input label",
|
|
104
|
+
placeholder: "Placeholder",
|
|
105
|
+
onChange: onChange,
|
|
106
|
+
clearable: true
|
|
107
|
+
})),
|
|
108
|
+
getByRole = _render4.getByRole;
|
|
137
109
|
var input = getByRole("textbox");
|
|
138
|
-
|
|
139
110
|
_react2.fireEvent.change(input, {
|
|
140
111
|
target: {
|
|
141
112
|
value: "Test"
|
|
142
113
|
}
|
|
143
114
|
});
|
|
144
|
-
|
|
145
115
|
expect(onChange).toHaveBeenCalled();
|
|
146
116
|
expect(onChange).toHaveBeenCalledWith({
|
|
147
117
|
value: "Test"
|
|
148
118
|
});
|
|
149
|
-
|
|
150
119
|
_userEvent["default"].clear(input);
|
|
151
|
-
|
|
152
120
|
expect(onChange).toHaveBeenCalled();
|
|
153
121
|
expect(onChange).toHaveBeenCalledWith({
|
|
154
122
|
value: "",
|
|
@@ -158,58 +126,47 @@ describe("TextInput component tests", function () {
|
|
|
158
126
|
test("Pattern constraint", function () {
|
|
159
127
|
var onChange = jest.fn();
|
|
160
128
|
var onBlur = jest.fn();
|
|
161
|
-
|
|
162
129
|
var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
130
|
+
label: "Input label",
|
|
131
|
+
placeholder: "Placeholder",
|
|
132
|
+
onChange: onChange,
|
|
133
|
+
onBlur: onBlur,
|
|
134
|
+
margin: {
|
|
135
|
+
left: "medium",
|
|
136
|
+
right: "medium"
|
|
137
|
+
},
|
|
138
|
+
clearable: true,
|
|
139
|
+
pattern: "^.*(?=.*[a-zA-Z])(?=.*\\d)(?=.*[!&$%&? \"]).*$"
|
|
140
|
+
})),
|
|
141
|
+
getByRole = _render5.getByRole;
|
|
176
142
|
var input = getByRole("textbox");
|
|
177
|
-
|
|
178
143
|
_react2.fireEvent.change(input, {
|
|
179
144
|
target: {
|
|
180
145
|
value: "pattern test"
|
|
181
146
|
}
|
|
182
147
|
});
|
|
183
|
-
|
|
184
148
|
expect(onChange).toHaveBeenCalled();
|
|
185
149
|
expect(onChange).toHaveBeenCalledWith({
|
|
186
150
|
value: "pattern test",
|
|
187
151
|
error: "Please match the format requested."
|
|
188
152
|
});
|
|
189
|
-
|
|
190
153
|
_react2.fireEvent.blur(input);
|
|
191
|
-
|
|
192
154
|
expect(onBlur).toHaveBeenCalled();
|
|
193
155
|
expect(onBlur).toHaveBeenCalledWith({
|
|
194
156
|
value: "pattern test",
|
|
195
157
|
error: "Please match the format requested."
|
|
196
158
|
});
|
|
197
|
-
|
|
198
159
|
_userEvent["default"].clear(input);
|
|
199
|
-
|
|
200
160
|
_react2.fireEvent.change(input, {
|
|
201
161
|
target: {
|
|
202
162
|
value: "pattern4&"
|
|
203
163
|
}
|
|
204
164
|
});
|
|
205
|
-
|
|
206
165
|
expect(onChange).toHaveBeenCalled();
|
|
207
166
|
expect(onChange).toHaveBeenCalledWith({
|
|
208
167
|
value: "pattern4&"
|
|
209
168
|
});
|
|
210
|
-
|
|
211
169
|
_react2.fireEvent.blur(input);
|
|
212
|
-
|
|
213
170
|
expect(onBlur).toHaveBeenCalled();
|
|
214
171
|
expect(onBlur).toHaveBeenCalledWith({
|
|
215
172
|
value: "pattern4&"
|
|
@@ -218,59 +175,48 @@ describe("TextInput component tests", function () {
|
|
|
218
175
|
test("Length constraint", function () {
|
|
219
176
|
var onChange = jest.fn();
|
|
220
177
|
var onBlur = jest.fn();
|
|
221
|
-
|
|
222
178
|
var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
179
|
+
label: "Input label",
|
|
180
|
+
placeholder: "Placeholder",
|
|
181
|
+
onChange: onChange,
|
|
182
|
+
onBlur: onBlur,
|
|
183
|
+
margin: {
|
|
184
|
+
left: "medium",
|
|
185
|
+
right: "medium"
|
|
186
|
+
},
|
|
187
|
+
clearable: true,
|
|
188
|
+
minLength: 5,
|
|
189
|
+
maxLength: 10
|
|
190
|
+
})),
|
|
191
|
+
getByRole = _render6.getByRole;
|
|
237
192
|
var input = getByRole("textbox");
|
|
238
|
-
|
|
239
193
|
_react2.fireEvent.change(input, {
|
|
240
194
|
target: {
|
|
241
195
|
value: "test"
|
|
242
196
|
}
|
|
243
197
|
});
|
|
244
|
-
|
|
245
198
|
expect(onChange).toHaveBeenCalled();
|
|
246
199
|
expect(onChange).toHaveBeenCalledWith({
|
|
247
200
|
value: "test",
|
|
248
201
|
error: "Min length 5, max length 10."
|
|
249
202
|
});
|
|
250
|
-
|
|
251
203
|
_react2.fireEvent.blur(input);
|
|
252
|
-
|
|
253
204
|
expect(onBlur).toHaveBeenCalled();
|
|
254
205
|
expect(onBlur).toHaveBeenCalledWith({
|
|
255
206
|
value: "test",
|
|
256
207
|
error: "Min length 5, max length 10."
|
|
257
208
|
});
|
|
258
|
-
|
|
259
209
|
_userEvent["default"].clear(input);
|
|
260
|
-
|
|
261
210
|
_react2.fireEvent.change(input, {
|
|
262
211
|
target: {
|
|
263
212
|
value: "length"
|
|
264
213
|
}
|
|
265
214
|
});
|
|
266
|
-
|
|
267
215
|
expect(onChange).toHaveBeenCalled();
|
|
268
216
|
expect(onChange).toHaveBeenCalledWith({
|
|
269
217
|
value: "length"
|
|
270
218
|
});
|
|
271
|
-
|
|
272
219
|
_react2.fireEvent.blur(input);
|
|
273
|
-
|
|
274
220
|
expect(onBlur).toHaveBeenCalled();
|
|
275
221
|
expect(onBlur).toHaveBeenCalledWith({
|
|
276
222
|
value: "length"
|
|
@@ -279,78 +225,64 @@ describe("TextInput component tests", function () {
|
|
|
279
225
|
test("Pattern and length constraints", function () {
|
|
280
226
|
var onChange = jest.fn();
|
|
281
227
|
var onBlur = jest.fn();
|
|
282
|
-
|
|
283
228
|
var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
229
|
+
label: "Input label",
|
|
230
|
+
placeholder: "Placeholder",
|
|
231
|
+
onChange: onChange,
|
|
232
|
+
onBlur: onBlur,
|
|
233
|
+
margin: {
|
|
234
|
+
left: "medium",
|
|
235
|
+
right: "medium"
|
|
236
|
+
},
|
|
237
|
+
clearable: true,
|
|
238
|
+
pattern: "^.*(?=.*[a-zA-Z])(?=.*\\d)(?=.*[!&$%&? \"]).*$",
|
|
239
|
+
minLength: 5,
|
|
240
|
+
maxLength: 10
|
|
241
|
+
})),
|
|
242
|
+
getByRole = _render7.getByRole;
|
|
299
243
|
var input = getByRole("textbox");
|
|
300
|
-
|
|
301
244
|
_react2.fireEvent.change(input, {
|
|
302
245
|
target: {
|
|
303
246
|
value: "test"
|
|
304
247
|
}
|
|
305
248
|
});
|
|
306
|
-
|
|
307
249
|
expect(onChange).toHaveBeenCalled();
|
|
308
250
|
expect(onChange).toHaveBeenCalledWith({
|
|
309
251
|
value: "test",
|
|
310
252
|
error: "Min length 5, max length 10."
|
|
311
253
|
});
|
|
312
|
-
|
|
313
254
|
_react2.fireEvent.blur(input);
|
|
314
|
-
|
|
315
255
|
expect(onBlur).toHaveBeenCalled();
|
|
316
256
|
expect(onBlur).toHaveBeenCalledWith({
|
|
317
257
|
value: "test",
|
|
318
258
|
error: "Min length 5, max length 10."
|
|
319
259
|
});
|
|
320
|
-
|
|
321
260
|
_react2.fireEvent.change(input, {
|
|
322
261
|
target: {
|
|
323
262
|
value: "tests"
|
|
324
263
|
}
|
|
325
264
|
});
|
|
326
|
-
|
|
327
265
|
expect(onChange).toHaveBeenCalled();
|
|
328
266
|
expect(onChange).toHaveBeenCalledWith({
|
|
329
267
|
value: "tests",
|
|
330
268
|
error: "Please match the format requested."
|
|
331
269
|
});
|
|
332
|
-
|
|
333
270
|
_react2.fireEvent.blur(input);
|
|
334
|
-
|
|
335
271
|
expect(onBlur).toHaveBeenCalled();
|
|
336
272
|
expect(onBlur).toHaveBeenCalledWith({
|
|
337
273
|
value: "tests",
|
|
338
274
|
error: "Please match the format requested."
|
|
339
275
|
});
|
|
340
|
-
|
|
341
276
|
_react2.fireEvent.change(input, {
|
|
342
277
|
target: {
|
|
343
278
|
value: "tests4&"
|
|
344
279
|
}
|
|
345
280
|
});
|
|
346
|
-
|
|
347
281
|
expect(onChange).toHaveBeenCalled();
|
|
348
282
|
expect(onChange).toHaveBeenCalledWith({
|
|
349
283
|
value: "tests4&"
|
|
350
284
|
});
|
|
351
|
-
|
|
352
285
|
_react2.fireEvent.blur(input);
|
|
353
|
-
|
|
354
286
|
expect(onBlur).toHaveBeenCalled();
|
|
355
287
|
expect(onBlur).toHaveBeenCalledWith({
|
|
356
288
|
value: "tests4&"
|
|
@@ -358,17 +290,13 @@ describe("TextInput component tests", function () {
|
|
|
358
290
|
});
|
|
359
291
|
test("onChange function is called correctly", function () {
|
|
360
292
|
var onChange = jest.fn();
|
|
361
|
-
|
|
362
293
|
var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
294
|
+
label: "Input label",
|
|
295
|
+
onChange: onChange
|
|
296
|
+
})),
|
|
297
|
+
getByRole = _render8.getByRole;
|
|
368
298
|
var input = getByRole("textbox");
|
|
369
|
-
|
|
370
299
|
_userEvent["default"].type(input, "onchange event test");
|
|
371
|
-
|
|
372
300
|
expect(input.value).toBe("onchange event test");
|
|
373
301
|
expect(onChange).toHaveBeenCalled();
|
|
374
302
|
expect(onChange).toHaveBeenCalledWith({
|
|
@@ -378,24 +306,19 @@ describe("TextInput component tests", function () {
|
|
|
378
306
|
test("onBlur function is called correctly", function () {
|
|
379
307
|
var onBlur = jest.fn();
|
|
380
308
|
var onChange = jest.fn();
|
|
381
|
-
|
|
382
309
|
var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
310
|
+
label: "Input label",
|
|
311
|
+
onChange: onChange,
|
|
312
|
+
onBlur: onBlur
|
|
313
|
+
})),
|
|
314
|
+
getByRole = _render9.getByRole;
|
|
389
315
|
var input = getByRole("textbox");
|
|
390
|
-
|
|
391
316
|
_react2.fireEvent.change(input, {
|
|
392
317
|
target: {
|
|
393
318
|
value: "Blur test"
|
|
394
319
|
}
|
|
395
320
|
});
|
|
396
|
-
|
|
397
321
|
_react2.fireEvent.blur(input);
|
|
398
|
-
|
|
399
322
|
expect(onBlur).toHaveBeenCalled();
|
|
400
323
|
expect(onBlur).toHaveBeenCalledWith({
|
|
401
324
|
value: "Blur test"
|
|
@@ -403,214 +326,320 @@ describe("TextInput component tests", function () {
|
|
|
403
326
|
});
|
|
404
327
|
test("Clear action tooltip is correct", function () {
|
|
405
328
|
var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
329
|
+
label: "Input label",
|
|
330
|
+
value: "Text",
|
|
331
|
+
clearable: true
|
|
332
|
+
})),
|
|
333
|
+
getByTitle = _render10.getByTitle;
|
|
412
334
|
expect(getByTitle("Clear field")).toBeTruthy();
|
|
413
335
|
});
|
|
414
|
-
test("Clear action onClick cleans the input", function () {
|
|
415
|
-
var _render11
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
336
|
+
test("Clear action onClick cleans the input", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
|
|
337
|
+
var _render11, getByRole, input, closeAction;
|
|
338
|
+
return _regenerator["default"].wrap(function _callee$(_context) {
|
|
339
|
+
while (1) switch (_context.prev = _context.next) {
|
|
340
|
+
case 0:
|
|
341
|
+
_render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
342
|
+
label: "Input label",
|
|
343
|
+
clearable: true
|
|
344
|
+
})), getByRole = _render11.getByRole;
|
|
345
|
+
input = getByRole("textbox");
|
|
346
|
+
_userEvent["default"].type(input, "Test");
|
|
347
|
+
closeAction = getByRole("button");
|
|
348
|
+
_context.next = 6;
|
|
349
|
+
return _userEvent["default"].click(closeAction);
|
|
350
|
+
case 6:
|
|
351
|
+
expect(input.value).toBe("");
|
|
352
|
+
case 7:
|
|
353
|
+
case "end":
|
|
354
|
+
return _context.stop();
|
|
355
|
+
}
|
|
356
|
+
}, _callee);
|
|
357
|
+
})));
|
|
358
|
+
test("Disabled text input renders with correct aria and can not be modified", function () {
|
|
432
359
|
var onChange = jest.fn();
|
|
433
|
-
|
|
434
360
|
var _render12 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
361
|
+
label: "Input label",
|
|
362
|
+
onChange: onChange,
|
|
363
|
+
disabled: true
|
|
364
|
+
})),
|
|
365
|
+
getByRole = _render12.getByRole;
|
|
441
366
|
var input = getByRole("textbox");
|
|
442
|
-
|
|
443
367
|
_userEvent["default"].type(input, "Test");
|
|
444
|
-
|
|
445
368
|
expect(onChange).not.toHaveBeenCalled();
|
|
446
369
|
});
|
|
447
|
-
test("Disabled input (action must be shown but not clickable)", function () {
|
|
448
|
-
var onClick
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
370
|
+
test("Disabled text input (action must be shown but not clickable)", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
|
|
371
|
+
var onClick, action, _render13, getByRole, input;
|
|
372
|
+
return _regenerator["default"].wrap(function _callee2$(_context2) {
|
|
373
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
374
|
+
case 0:
|
|
375
|
+
onClick = jest.fn();
|
|
376
|
+
action = {
|
|
377
|
+
onClick: onClick,
|
|
378
|
+
icon: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
379
|
+
"data-testid": "image",
|
|
380
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
381
|
+
height: "24px",
|
|
382
|
+
viewBox: "0 0 24 24",
|
|
383
|
+
width: "24px",
|
|
384
|
+
fill: "currentColor"
|
|
385
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
386
|
+
d: "M0 0h24v24H0V0z",
|
|
387
|
+
fill: "none"
|
|
388
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
389
|
+
d: "M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z"
|
|
390
|
+
}))
|
|
391
|
+
};
|
|
392
|
+
_render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
393
|
+
label: "Disabled input label",
|
|
394
|
+
action: action,
|
|
395
|
+
disabled: true
|
|
396
|
+
})), getByRole = _render13.getByRole;
|
|
397
|
+
input = getByRole("textbox");
|
|
398
|
+
expect(input.disabled).toBeTruthy();
|
|
399
|
+
_context2.next = 7;
|
|
400
|
+
return _userEvent["default"].click(getByRole("button"));
|
|
401
|
+
case 7:
|
|
402
|
+
expect(onClick).not.toHaveBeenCalled();
|
|
403
|
+
case 8:
|
|
404
|
+
case "end":
|
|
405
|
+
return _context2.stop();
|
|
406
|
+
}
|
|
407
|
+
}, _callee2);
|
|
408
|
+
})));
|
|
409
|
+
test("Disabled text input (clear default action should not be displayed, even with text written on the input)", function () {
|
|
481
410
|
var _render14 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
486
|
-
|
|
487
|
-
|
|
488
|
-
|
|
489
|
-
|
|
411
|
+
label: "Disabled input label",
|
|
412
|
+
value: "Sample text",
|
|
413
|
+
disabled: true,
|
|
414
|
+
clearable: true
|
|
415
|
+
})),
|
|
416
|
+
getByRole = _render14.getByRole,
|
|
417
|
+
queryByRole = _render14.queryByRole;
|
|
490
418
|
var input = getByRole("textbox");
|
|
491
419
|
expect(input.disabled).toBeTruthy();
|
|
492
420
|
expect(queryByRole("button")).toBeFalsy();
|
|
493
421
|
});
|
|
494
|
-
test("Disabled input (suffix and
|
|
422
|
+
test("Disabled text input (suffix and prefix must be displayed)", function () {
|
|
495
423
|
var _render15 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
|
|
504
|
-
|
|
424
|
+
label: "Disabled input label",
|
|
425
|
+
value: "Sample text",
|
|
426
|
+
prefix: "+34",
|
|
427
|
+
suffix: "USD",
|
|
428
|
+
disabled: true
|
|
429
|
+
})),
|
|
430
|
+
getByRole = _render15.getByRole,
|
|
431
|
+
getByText = _render15.getByText;
|
|
505
432
|
var input = getByRole("textbox");
|
|
506
433
|
expect(input.disabled).toBeTruthy();
|
|
507
434
|
expect(getByText("+34")).toBeTruthy();
|
|
508
435
|
expect(getByText("USD")).toBeTruthy();
|
|
509
436
|
});
|
|
510
|
-
test("
|
|
511
|
-
var onClick = jest.fn();
|
|
512
|
-
var action = {
|
|
513
|
-
onClick: onClick,
|
|
514
|
-
icon: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
515
|
-
"data-testid": "image",
|
|
516
|
-
xmlns: "http://www.w3.org/2000/svg",
|
|
517
|
-
height: "24px",
|
|
518
|
-
viewBox: "0 0 24 24",
|
|
519
|
-
width: "24px",
|
|
520
|
-
fill: "currentColor"
|
|
521
|
-
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
522
|
-
d: "M0 0h24v24H0V0z",
|
|
523
|
-
fill: "none"
|
|
524
|
-
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
525
|
-
d: "M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z"
|
|
526
|
-
})),
|
|
527
|
-
title: "Search"
|
|
528
|
-
};
|
|
529
|
-
|
|
437
|
+
test("Read-only text input doesn't render the clear action", function () {
|
|
530
438
|
var _render16 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
|
|
534
|
-
|
|
535
|
-
getByTestId = _render16.getByTestId,
|
|
536
|
-
getByTitle = _render16.getByTitle;
|
|
537
|
-
|
|
538
|
-
expect(getByTestId("image")).toBeTruthy();
|
|
539
|
-
expect(getByTitle("Search")).toBeTruthy();
|
|
540
|
-
|
|
541
|
-
_userEvent["default"].click(getByRole("button"));
|
|
542
|
-
|
|
543
|
-
expect(onClick).toHaveBeenCalled();
|
|
544
|
-
});
|
|
545
|
-
test("Text input submit correctly value in form", function () {
|
|
546
|
-
var onClick = jest.fn();
|
|
547
|
-
var action = {
|
|
548
|
-
onClick: onClick,
|
|
549
|
-
icon: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
550
|
-
"data-testid": "image",
|
|
551
|
-
xmlns: "http://www.w3.org/2000/svg",
|
|
552
|
-
height: "24px",
|
|
553
|
-
viewBox: "0 0 24 24",
|
|
554
|
-
width: "24px",
|
|
555
|
-
fill: "currentColor"
|
|
556
|
-
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
557
|
-
d: "M0 0h24v24H0V0z",
|
|
558
|
-
fill: "none"
|
|
559
|
-
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
560
|
-
d: "M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z"
|
|
439
|
+
label: "Disabled input label",
|
|
440
|
+
defaultValue: "Sample text",
|
|
441
|
+
readOnly: true,
|
|
442
|
+
clearable: true
|
|
561
443
|
})),
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
var handlerOnSubmit = jest.fn(function (e) {
|
|
565
|
-
e.preventDefault();
|
|
566
|
-
var formData = new FormData(e.target);
|
|
567
|
-
var formProps = Object.fromEntries(formData);
|
|
568
|
-
expect(formProps).toStrictEqual({
|
|
569
|
-
data: "test"
|
|
570
|
-
});
|
|
571
|
-
});
|
|
572
|
-
|
|
573
|
-
var _render17 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement("form", {
|
|
574
|
-
onSubmit: handlerOnSubmit
|
|
575
|
-
}, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
576
|
-
label: "Input label",
|
|
577
|
-
name: "data",
|
|
578
|
-
action: action
|
|
579
|
-
}), /*#__PURE__*/_react["default"].createElement("button", {
|
|
580
|
-
type: "submit"
|
|
581
|
-
}, "Submit"))),
|
|
582
|
-
getByText = _render17.getByText,
|
|
583
|
-
getAllByRole = _render17.getAllByRole,
|
|
584
|
-
getByRole = _render17.getByRole;
|
|
585
|
-
|
|
586
|
-
var search = getAllByRole("button")[0];
|
|
587
|
-
var submit = getByText("Submit");
|
|
444
|
+
getByRole = _render16.getByRole,
|
|
445
|
+
queryByRole = _render16.queryByRole;
|
|
588
446
|
var input = getByRole("textbox");
|
|
589
|
-
|
|
590
|
-
|
|
591
|
-
|
|
592
|
-
|
|
593
|
-
|
|
594
|
-
|
|
595
|
-
|
|
596
|
-
|
|
597
|
-
|
|
598
|
-
|
|
599
|
-
|
|
600
|
-
|
|
447
|
+
expect(input.readOnly).toBeTruthy();
|
|
448
|
+
expect(queryByRole("button")).toBeFalsy();
|
|
449
|
+
});
|
|
450
|
+
test("Read-only text input does not trigger onChange function", function () {
|
|
451
|
+
var onChange = jest.fn();
|
|
452
|
+
var _render17 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
453
|
+
label: "Example label",
|
|
454
|
+
onChange: onChange,
|
|
455
|
+
readOnly: true
|
|
456
|
+
})),
|
|
457
|
+
getByLabelText = _render17.getByLabelText;
|
|
458
|
+
var textInput = getByLabelText("Example label");
|
|
459
|
+
_userEvent["default"].type(textInput, "Test");
|
|
460
|
+
expect(onChange).not.toHaveBeenCalled();
|
|
601
461
|
});
|
|
462
|
+
test("Read-only text input sends its value on submit", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
|
|
463
|
+
var handlerOnSubmit, _render18, getByText, submit;
|
|
464
|
+
return _regenerator["default"].wrap(function _callee3$(_context3) {
|
|
465
|
+
while (1) switch (_context3.prev = _context3.next) {
|
|
466
|
+
case 0:
|
|
467
|
+
handlerOnSubmit = jest.fn(function (e) {
|
|
468
|
+
e.preventDefault();
|
|
469
|
+
var formData = new FormData(e.target);
|
|
470
|
+
var formProps = Object.fromEntries(formData);
|
|
471
|
+
expect(formProps).toStrictEqual({
|
|
472
|
+
data: "Text"
|
|
473
|
+
});
|
|
474
|
+
});
|
|
475
|
+
_render18 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement("form", {
|
|
476
|
+
onSubmit: handlerOnSubmit
|
|
477
|
+
}, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
478
|
+
label: "Example label",
|
|
479
|
+
name: "data",
|
|
480
|
+
defaultValue: "Text",
|
|
481
|
+
readOnly: true
|
|
482
|
+
}), /*#__PURE__*/_react["default"].createElement("button", {
|
|
483
|
+
type: "submit"
|
|
484
|
+
}, "Submit"))), getByText = _render18.getByText;
|
|
485
|
+
submit = getByText("Submit");
|
|
486
|
+
_context3.next = 5;
|
|
487
|
+
return _userEvent["default"].click(submit);
|
|
488
|
+
case 5:
|
|
489
|
+
expect(handlerOnSubmit).toHaveBeenCalled();
|
|
490
|
+
case 6:
|
|
491
|
+
case "end":
|
|
492
|
+
return _context3.stop();
|
|
493
|
+
}
|
|
494
|
+
}, _callee3);
|
|
495
|
+
})));
|
|
496
|
+
test("Read-only text input doesn't trigger custom action's onClick event", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee4() {
|
|
497
|
+
var onClick, action, _render19, getByRole;
|
|
498
|
+
return _regenerator["default"].wrap(function _callee4$(_context4) {
|
|
499
|
+
while (1) switch (_context4.prev = _context4.next) {
|
|
500
|
+
case 0:
|
|
501
|
+
onClick = jest.fn();
|
|
502
|
+
action = {
|
|
503
|
+
onClick: onClick,
|
|
504
|
+
icon: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
505
|
+
"data-testid": "image",
|
|
506
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
507
|
+
height: "24px",
|
|
508
|
+
viewBox: "0 0 24 24",
|
|
509
|
+
width: "24px",
|
|
510
|
+
fill: "currentColor"
|
|
511
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
512
|
+
d: "M0 0h24v24H0V0z",
|
|
513
|
+
fill: "none"
|
|
514
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
515
|
+
d: "M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z"
|
|
516
|
+
})),
|
|
517
|
+
title: "Search"
|
|
518
|
+
};
|
|
519
|
+
_render19 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
520
|
+
label: "Input label",
|
|
521
|
+
action: action,
|
|
522
|
+
readOnly: true
|
|
523
|
+
})), getByRole = _render19.getByRole;
|
|
524
|
+
_context4.next = 5;
|
|
525
|
+
return _userEvent["default"].click(getByRole("button"));
|
|
526
|
+
case 5:
|
|
527
|
+
expect(onClick).not.toHaveBeenCalled();
|
|
528
|
+
case 6:
|
|
529
|
+
case "end":
|
|
530
|
+
return _context4.stop();
|
|
531
|
+
}
|
|
532
|
+
}, _callee4);
|
|
533
|
+
})));
|
|
534
|
+
test("Action prop: image displayed with title and onClick event", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee5() {
|
|
535
|
+
var onClick, action, _render20, getByRole, getByTestId, getByTitle;
|
|
536
|
+
return _regenerator["default"].wrap(function _callee5$(_context5) {
|
|
537
|
+
while (1) switch (_context5.prev = _context5.next) {
|
|
538
|
+
case 0:
|
|
539
|
+
onClick = jest.fn();
|
|
540
|
+
action = {
|
|
541
|
+
onClick: onClick,
|
|
542
|
+
icon: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
543
|
+
"data-testid": "image",
|
|
544
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
545
|
+
height: "24px",
|
|
546
|
+
viewBox: "0 0 24 24",
|
|
547
|
+
width: "24px",
|
|
548
|
+
fill: "currentColor"
|
|
549
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
550
|
+
d: "M0 0h24v24H0V0z",
|
|
551
|
+
fill: "none"
|
|
552
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
553
|
+
d: "M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z"
|
|
554
|
+
})),
|
|
555
|
+
title: "Search"
|
|
556
|
+
};
|
|
557
|
+
_render20 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
558
|
+
label: "Input label",
|
|
559
|
+
action: action
|
|
560
|
+
})), getByRole = _render20.getByRole, getByTestId = _render20.getByTestId, getByTitle = _render20.getByTitle;
|
|
561
|
+
expect(getByTestId("image")).toBeTruthy();
|
|
562
|
+
expect(getByTitle("Search")).toBeTruthy();
|
|
563
|
+
_context5.next = 7;
|
|
564
|
+
return _userEvent["default"].click(getByRole("button"));
|
|
565
|
+
case 7:
|
|
566
|
+
expect(onClick).toHaveBeenCalled();
|
|
567
|
+
case 8:
|
|
568
|
+
case "end":
|
|
569
|
+
return _context5.stop();
|
|
570
|
+
}
|
|
571
|
+
}, _callee5);
|
|
572
|
+
})));
|
|
573
|
+
test("Text input submit correctly value in form", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee6() {
|
|
574
|
+
var onClick, action, handlerOnSubmit, _render21, getByText, getAllByRole, getByRole, search, submit, input;
|
|
575
|
+
return _regenerator["default"].wrap(function _callee6$(_context6) {
|
|
576
|
+
while (1) switch (_context6.prev = _context6.next) {
|
|
577
|
+
case 0:
|
|
578
|
+
onClick = jest.fn();
|
|
579
|
+
action = {
|
|
580
|
+
onClick: onClick,
|
|
581
|
+
icon: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
582
|
+
"data-testid": "image",
|
|
583
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
584
|
+
height: "24px",
|
|
585
|
+
viewBox: "0 0 24 24",
|
|
586
|
+
width: "24px",
|
|
587
|
+
fill: "currentColor"
|
|
588
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
589
|
+
d: "M0 0h24v24H0V0z",
|
|
590
|
+
fill: "none"
|
|
591
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
592
|
+
d: "M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z"
|
|
593
|
+
})),
|
|
594
|
+
title: "Search"
|
|
595
|
+
};
|
|
596
|
+
handlerOnSubmit = jest.fn(function (e) {
|
|
597
|
+
e.preventDefault();
|
|
598
|
+
var formData = new FormData(e.target);
|
|
599
|
+
var formProps = Object.fromEntries(formData);
|
|
600
|
+
expect(formProps).toStrictEqual({
|
|
601
|
+
data: "test"
|
|
602
|
+
});
|
|
603
|
+
});
|
|
604
|
+
_render21 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement("form", {
|
|
605
|
+
onSubmit: handlerOnSubmit
|
|
606
|
+
}, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
607
|
+
label: "Input label",
|
|
608
|
+
name: "data",
|
|
609
|
+
action: action
|
|
610
|
+
}), /*#__PURE__*/_react["default"].createElement("button", {
|
|
611
|
+
type: "submit"
|
|
612
|
+
}, "Submit"))), getByText = _render21.getByText, getAllByRole = _render21.getAllByRole, getByRole = _render21.getByRole;
|
|
613
|
+
search = getAllByRole("button")[0];
|
|
614
|
+
submit = getByText("Submit");
|
|
615
|
+
input = getByRole("textbox");
|
|
616
|
+
_userEvent["default"].type(input, "test");
|
|
617
|
+
expect(input.value).toBe("test");
|
|
618
|
+
_context6.next = 11;
|
|
619
|
+
return _userEvent["default"].click(search);
|
|
620
|
+
case 11:
|
|
621
|
+
expect(handlerOnSubmit).not.toHaveBeenCalled();
|
|
622
|
+
_context6.next = 14;
|
|
623
|
+
return _userEvent["default"].click(submit);
|
|
624
|
+
case 14:
|
|
625
|
+
expect(handlerOnSubmit).toHaveBeenCalled();
|
|
626
|
+
case 15:
|
|
627
|
+
case "end":
|
|
628
|
+
return _context6.stop();
|
|
629
|
+
}
|
|
630
|
+
}, _callee6);
|
|
631
|
+
})));
|
|
602
632
|
test("Renders with correct prefix and suffix", function () {
|
|
603
|
-
var
|
|
604
|
-
|
|
605
|
-
|
|
606
|
-
|
|
607
|
-
|
|
608
|
-
|
|
609
|
-
|
|
633
|
+
var _render22 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
634
|
+
label: "Input label",
|
|
635
|
+
prefix: "+34",
|
|
636
|
+
suffix: "USD"
|
|
637
|
+
})),
|
|
638
|
+
getByText = _render22.getByText;
|
|
610
639
|
expect(getByText("+34")).toBeTruthy();
|
|
611
640
|
expect(getByText("USD")).toBeTruthy();
|
|
612
641
|
});
|
|
613
|
-
test("Text Input has correct aria
|
|
642
|
+
test("Text Input has correct aria accessibility attributes", function () {
|
|
614
643
|
var onClick = jest.fn();
|
|
615
644
|
var action = {
|
|
616
645
|
onClick: onClick,
|
|
@@ -629,15 +658,13 @@ describe("TextInput component tests", function () {
|
|
|
629
658
|
})),
|
|
630
659
|
title: "Search"
|
|
631
660
|
};
|
|
632
|
-
|
|
633
|
-
|
|
634
|
-
|
|
635
|
-
|
|
636
|
-
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
getAllByRole = _render19.getAllByRole;
|
|
640
|
-
|
|
661
|
+
var _render23 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
662
|
+
label: "Example label",
|
|
663
|
+
clearable: true,
|
|
664
|
+
action: action
|
|
665
|
+
})),
|
|
666
|
+
getByRole = _render23.getByRole,
|
|
667
|
+
getAllByRole = _render23.getAllByRole;
|
|
641
668
|
var input = getByRole("textbox");
|
|
642
669
|
expect(input.getAttribute("aria-autocomplete")).toBeNull();
|
|
643
670
|
expect(input.getAttribute("aria-controls")).toBeNull();
|
|
@@ -647,76 +674,62 @@ describe("TextInput component tests", function () {
|
|
|
647
674
|
expect(input.getAttribute("aria-invalid")).toBe("false");
|
|
648
675
|
expect(input.getAttribute("aria-errormessage")).toBeNull();
|
|
649
676
|
expect(input.getAttribute("aria-required")).toBe("true");
|
|
650
|
-
|
|
651
677
|
_userEvent["default"].type(input, "Text");
|
|
652
|
-
|
|
653
678
|
var clear = getAllByRole("button")[0];
|
|
654
679
|
expect(clear.getAttribute("aria-label")).toBe("Clear field");
|
|
655
680
|
var search = getAllByRole("button")[1];
|
|
656
681
|
expect(search.getAttribute("aria-label")).toBe("Search");
|
|
657
682
|
});
|
|
658
|
-
test("Autosuggest has correct
|
|
659
|
-
var
|
|
660
|
-
|
|
661
|
-
|
|
662
|
-
|
|
663
|
-
|
|
664
|
-
|
|
665
|
-
|
|
666
|
-
|
|
683
|
+
test("Autosuggest has correct accessibility attributes", function () {
|
|
684
|
+
var _render24 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
685
|
+
label: "Autocomplete Countries",
|
|
686
|
+
optional: true,
|
|
687
|
+
suggestions: countries
|
|
688
|
+
})),
|
|
689
|
+
getByRole = _render24.getByRole,
|
|
690
|
+
getAllByRole = _render24.getAllByRole;
|
|
667
691
|
var input = getByRole("combobox");
|
|
668
692
|
expect(input.getAttribute("aria-autocomplete")).toBe("list");
|
|
669
693
|
expect(input.getAttribute("aria-expanded")).toBe("false");
|
|
670
694
|
expect(input.getAttribute("aria-haspopup")).toBe("listbox");
|
|
671
695
|
expect(input.getAttribute("aria-required")).toBe("false");
|
|
672
|
-
|
|
673
696
|
_react2.fireEvent.focus(input);
|
|
674
|
-
|
|
675
697
|
var list = getByRole("listbox");
|
|
676
698
|
expect(input.getAttribute("aria-controls")).toBe(list.id);
|
|
677
699
|
expect(input.getAttribute("aria-expanded")).toBe("true");
|
|
678
700
|
var options = getAllByRole("option");
|
|
679
701
|
expect(options[0].getAttribute("aria-selected")).toBeNull();
|
|
680
702
|
});
|
|
703
|
+
test("Mouse wheel interaction does not affect the text value", function () {
|
|
704
|
+
var _render25 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
705
|
+
label: "Default label",
|
|
706
|
+
placeholder: "Placeholder",
|
|
707
|
+
defaultValue: "Example text"
|
|
708
|
+
})),
|
|
709
|
+
getByRole = _render25.getByRole;
|
|
710
|
+
var input = getByRole("textbox");
|
|
711
|
+
_react2.fireEvent.wheel(input, {
|
|
712
|
+
deltaY: -100
|
|
713
|
+
});
|
|
714
|
+
expect(input.value).toBe("Example text");
|
|
715
|
+
_react2.fireEvent.wheel(input, {
|
|
716
|
+
deltaY: 100
|
|
717
|
+
});
|
|
718
|
+
expect(input.value).toBe("Example text");
|
|
719
|
+
});
|
|
681
720
|
});
|
|
682
721
|
describe("TextInput component synchronous autosuggest tests", function () {
|
|
683
722
|
test("Autosuggest is displayed when the input gains focus", function () {
|
|
684
723
|
var onChange = jest.fn();
|
|
685
|
-
|
|
686
|
-
|
|
687
|
-
|
|
688
|
-
|
|
689
|
-
|
|
690
|
-
|
|
691
|
-
|
|
692
|
-
getByText = _render21.getByText;
|
|
693
|
-
|
|
724
|
+
var _render26 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
725
|
+
label: "Autocomplete Countries",
|
|
726
|
+
suggestions: countries,
|
|
727
|
+
onChange: onChange
|
|
728
|
+
})),
|
|
729
|
+
getByRole = _render26.getByRole,
|
|
730
|
+
getByText = _render26.getByText;
|
|
694
731
|
var input = getByRole("combobox");
|
|
695
|
-
|
|
696
732
|
_react2.fireEvent.focus(input);
|
|
697
|
-
|
|
698
|
-
var list = getByRole("listbox");
|
|
699
|
-
expect(list).toBeTruthy();
|
|
700
|
-
expect(getByText("Afghanistan")).toBeTruthy();
|
|
701
|
-
expect(getByText("Albania")).toBeTruthy();
|
|
702
|
-
expect(getByText("Algeria")).toBeTruthy();
|
|
703
|
-
expect(getByText("Andorra")).toBeTruthy();
|
|
704
|
-
});
|
|
705
|
-
test("Autosuggest is displayed when the user clicks the input", function () {
|
|
706
|
-
var onChange = jest.fn();
|
|
707
|
-
|
|
708
|
-
var _render22 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
709
|
-
label: "Autocomplete Countries",
|
|
710
|
-
suggestions: countries,
|
|
711
|
-
onChange: onChange
|
|
712
|
-
})),
|
|
713
|
-
getByRole = _render22.getByRole,
|
|
714
|
-
getByText = _render22.getByText;
|
|
715
|
-
|
|
716
|
-
var input = getByRole("combobox");
|
|
717
|
-
|
|
718
|
-
_react2.fireEvent.focus(input);
|
|
719
|
-
|
|
720
733
|
var list = getByRole("listbox");
|
|
721
734
|
expect(list).toBeTruthy();
|
|
722
735
|
expect(getByText("Afghanistan")).toBeTruthy();
|
|
@@ -724,538 +737,707 @@ describe("TextInput component synchronous autosuggest tests", function () {
|
|
|
724
737
|
expect(getByText("Algeria")).toBeTruthy();
|
|
725
738
|
expect(getByText("Andorra")).toBeTruthy();
|
|
726
739
|
});
|
|
727
|
-
test("Autosuggest is displayed
|
|
728
|
-
var onChange
|
|
729
|
-
|
|
730
|
-
|
|
731
|
-
|
|
732
|
-
|
|
733
|
-
|
|
734
|
-
|
|
735
|
-
|
|
736
|
-
|
|
737
|
-
|
|
738
|
-
|
|
739
|
-
|
|
740
|
-
|
|
741
|
-
|
|
742
|
-
|
|
743
|
-
|
|
744
|
-
|
|
745
|
-
|
|
746
|
-
|
|
747
|
-
|
|
748
|
-
|
|
749
|
-
|
|
750
|
-
|
|
751
|
-
|
|
752
|
-
});
|
|
753
|
-
|
|
754
|
-
|
|
755
|
-
|
|
756
|
-
|
|
757
|
-
|
|
758
|
-
|
|
759
|
-
|
|
760
|
-
|
|
761
|
-
|
|
762
|
-
|
|
763
|
-
|
|
764
|
-
|
|
740
|
+
test("Autosuggest is displayed when the user clicks the input", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee7() {
|
|
741
|
+
var onChange, _render27, getByRole, getByText, input, list;
|
|
742
|
+
return _regenerator["default"].wrap(function _callee7$(_context7) {
|
|
743
|
+
while (1) switch (_context7.prev = _context7.next) {
|
|
744
|
+
case 0:
|
|
745
|
+
onChange = jest.fn();
|
|
746
|
+
_render27 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
747
|
+
label: "Autocomplete Countries",
|
|
748
|
+
suggestions: countries,
|
|
749
|
+
onChange: onChange
|
|
750
|
+
})), getByRole = _render27.getByRole, getByText = _render27.getByText;
|
|
751
|
+
input = getByRole("combobox");
|
|
752
|
+
_context7.next = 5;
|
|
753
|
+
return _userEvent["default"].click(input);
|
|
754
|
+
case 5:
|
|
755
|
+
list = getByRole("listbox");
|
|
756
|
+
expect(list).toBeTruthy();
|
|
757
|
+
expect(getByText("Afghanistan")).toBeTruthy();
|
|
758
|
+
expect(getByText("Albania")).toBeTruthy();
|
|
759
|
+
expect(getByText("Algeria")).toBeTruthy();
|
|
760
|
+
expect(getByText("Andorra")).toBeTruthy();
|
|
761
|
+
case 11:
|
|
762
|
+
case "end":
|
|
763
|
+
return _context7.stop();
|
|
764
|
+
}
|
|
765
|
+
}, _callee7);
|
|
766
|
+
})));
|
|
767
|
+
test("Autosuggest is displayed while the user is writing (if closed previously, if it is open stays open)", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee8() {
|
|
768
|
+
var _render28, getByRole, getByText, getAllByText, input;
|
|
769
|
+
return _regenerator["default"].wrap(function _callee8$(_context8) {
|
|
770
|
+
while (1) switch (_context8.prev = _context8.next) {
|
|
771
|
+
case 0:
|
|
772
|
+
_render28 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
773
|
+
label: "Autocomplete Countries",
|
|
774
|
+
suggestions: countries
|
|
775
|
+
})), getByRole = _render28.getByRole, getByText = _render28.getByText, getAllByText = _render28.getAllByText;
|
|
776
|
+
input = getByRole("combobox");
|
|
777
|
+
_context8.next = 4;
|
|
778
|
+
return _userEvent["default"].type(input, "Bah");
|
|
779
|
+
case 4:
|
|
780
|
+
expect(getByRole("listbox")).toBeTruthy();
|
|
781
|
+
expect(getAllByText("Bah").length).toBe(2);
|
|
782
|
+
expect(getByText("amas")).toBeTruthy();
|
|
783
|
+
expect(getByText("rain")).toBeTruthy();
|
|
784
|
+
case 8:
|
|
785
|
+
case "end":
|
|
786
|
+
return _context8.stop();
|
|
787
|
+
}
|
|
788
|
+
}, _callee8);
|
|
789
|
+
})));
|
|
790
|
+
test("Read-only text input does not open the suggestions list", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee9() {
|
|
791
|
+
var onChange, _render29, getByRole, queryByRole, input;
|
|
792
|
+
return _regenerator["default"].wrap(function _callee9$(_context9) {
|
|
793
|
+
while (1) switch (_context9.prev = _context9.next) {
|
|
794
|
+
case 0:
|
|
795
|
+
onChange = jest.fn();
|
|
796
|
+
_render29 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
797
|
+
label: "Autocomplete Countries",
|
|
798
|
+
suggestions: countries,
|
|
799
|
+
onChange: onChange,
|
|
800
|
+
readOnly: true
|
|
801
|
+
})), getByRole = _render29.getByRole, queryByRole = _render29.queryByRole;
|
|
802
|
+
input = getByRole("combobox");
|
|
803
|
+
_react2.fireEvent.focus(input);
|
|
804
|
+
expect(queryByRole("listbox")).toBeFalsy();
|
|
805
|
+
_context9.next = 7;
|
|
806
|
+
return _userEvent["default"].click(input);
|
|
807
|
+
case 7:
|
|
808
|
+
expect(queryByRole("listbox")).toBeFalsy();
|
|
809
|
+
case 8:
|
|
810
|
+
case "end":
|
|
811
|
+
return _context9.stop();
|
|
812
|
+
}
|
|
813
|
+
}, _callee9);
|
|
814
|
+
})));
|
|
765
815
|
test("Autosuggest displays filtered when the input has a default value", function () {
|
|
766
|
-
var
|
|
767
|
-
|
|
768
|
-
|
|
769
|
-
|
|
770
|
-
|
|
771
|
-
|
|
772
|
-
|
|
773
|
-
|
|
774
|
-
|
|
775
|
-
|
|
776
|
-
|
|
777
|
-
|
|
778
|
-
|
|
816
|
+
var _render30 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
817
|
+
label: "Uncontrolled suggestions filtered by default",
|
|
818
|
+
helperText: "Example of helper text",
|
|
819
|
+
placeholder: "Placeholder",
|
|
820
|
+
margin: "medium",
|
|
821
|
+
defaultValue: "Suggestion 2",
|
|
822
|
+
suggestions: ["Suggestion 11", "Suggestion 12", "Suggestion 23", "Suggestion 24"],
|
|
823
|
+
clearable: true
|
|
824
|
+
})),
|
|
825
|
+
getByRole = _render30.getByRole,
|
|
826
|
+
getByText = _render30.getByText,
|
|
827
|
+
getAllByText = _render30.getAllByText;
|
|
779
828
|
var input = getByRole("combobox");
|
|
780
829
|
expect(input.value).toBe("Suggestion 2");
|
|
781
|
-
|
|
782
830
|
_react2.fireEvent.focus(input);
|
|
783
|
-
|
|
784
831
|
expect(getAllByText("Suggestion 2").length).toBe(2);
|
|
785
832
|
expect(getByText("3")).toBeTruthy();
|
|
786
833
|
expect(getByText("4")).toBeTruthy();
|
|
787
834
|
});
|
|
788
835
|
test("Autosuggest is not displayed when prop suggestions is an empty array", function () {
|
|
789
836
|
var onChange = jest.fn();
|
|
790
|
-
|
|
791
|
-
|
|
792
|
-
|
|
793
|
-
|
|
794
|
-
|
|
795
|
-
|
|
796
|
-
queryByRole = _render25.queryByRole;
|
|
797
|
-
|
|
837
|
+
var _render31 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
838
|
+
label: "Autocomplete Countries",
|
|
839
|
+
suggestions: [],
|
|
840
|
+
onChange: onChange
|
|
841
|
+
})),
|
|
842
|
+
queryByRole = _render31.queryByRole;
|
|
798
843
|
var input = queryByRole("textbox");
|
|
799
|
-
|
|
800
844
|
_react2.fireEvent.focus(input);
|
|
801
|
-
|
|
802
845
|
expect(queryByRole("listbox")).toBeFalsy();
|
|
803
846
|
});
|
|
804
|
-
test("Autosuggest closes the listbox when there are no matches for the user's input", function () {
|
|
805
|
-
var onChange
|
|
806
|
-
|
|
807
|
-
|
|
808
|
-
|
|
809
|
-
|
|
810
|
-
|
|
811
|
-
|
|
812
|
-
|
|
813
|
-
|
|
814
|
-
|
|
815
|
-
|
|
816
|
-
|
|
817
|
-
|
|
818
|
-
|
|
819
|
-
|
|
820
|
-
|
|
821
|
-
|
|
822
|
-
|
|
823
|
-
|
|
824
|
-
|
|
825
|
-
|
|
826
|
-
|
|
827
|
-
|
|
828
|
-
|
|
829
|
-
|
|
830
|
-
|
|
831
|
-
|
|
832
|
-
|
|
833
|
-
|
|
834
|
-
|
|
835
|
-
|
|
836
|
-
|
|
837
|
-
|
|
838
|
-
|
|
839
|
-
|
|
840
|
-
|
|
841
|
-
|
|
842
|
-
|
|
843
|
-
|
|
844
|
-
|
|
845
|
-
|
|
846
|
-
|
|
847
|
-
|
|
848
|
-
|
|
849
|
-
|
|
850
|
-
|
|
851
|
-
|
|
852
|
-
|
|
853
|
-
|
|
854
|
-
|
|
855
|
-
|
|
856
|
-
|
|
857
|
-
|
|
858
|
-
|
|
859
|
-
|
|
860
|
-
|
|
861
|
-
|
|
862
|
-
|
|
863
|
-
|
|
864
|
-
|
|
865
|
-
|
|
866
|
-
|
|
867
|
-
|
|
868
|
-
|
|
869
|
-
|
|
870
|
-
|
|
871
|
-
|
|
872
|
-
|
|
873
|
-
|
|
874
|
-
|
|
875
|
-
|
|
876
|
-
|
|
877
|
-
|
|
878
|
-
|
|
879
|
-
|
|
880
|
-
|
|
881
|
-
|
|
882
|
-
|
|
883
|
-
|
|
884
|
-
|
|
885
|
-
|
|
886
|
-
|
|
887
|
-
|
|
888
|
-
|
|
889
|
-
|
|
890
|
-
|
|
891
|
-
|
|
892
|
-
|
|
893
|
-
|
|
894
|
-
|
|
895
|
-
|
|
896
|
-
|
|
897
|
-
|
|
898
|
-
|
|
899
|
-
|
|
900
|
-
|
|
901
|
-
|
|
902
|
-
|
|
903
|
-
|
|
904
|
-
|
|
905
|
-
|
|
906
|
-
|
|
907
|
-
|
|
908
|
-
|
|
909
|
-
|
|
910
|
-
|
|
911
|
-
|
|
912
|
-
|
|
913
|
-
|
|
914
|
-
|
|
915
|
-
|
|
916
|
-
|
|
917
|
-
|
|
918
|
-
|
|
919
|
-
|
|
920
|
-
|
|
921
|
-
|
|
922
|
-
|
|
923
|
-
|
|
924
|
-
|
|
925
|
-
|
|
926
|
-
|
|
927
|
-
|
|
928
|
-
|
|
929
|
-
|
|
930
|
-
|
|
931
|
-
|
|
932
|
-
|
|
933
|
-
|
|
934
|
-
|
|
935
|
-
|
|
936
|
-
|
|
937
|
-
|
|
938
|
-
|
|
939
|
-
|
|
940
|
-
|
|
941
|
-
|
|
942
|
-
|
|
943
|
-
|
|
944
|
-
|
|
945
|
-
|
|
946
|
-
|
|
947
|
-
|
|
948
|
-
|
|
949
|
-
|
|
950
|
-
|
|
951
|
-
|
|
952
|
-
|
|
953
|
-
|
|
954
|
-
|
|
955
|
-
|
|
956
|
-
|
|
957
|
-
|
|
958
|
-
|
|
959
|
-
|
|
960
|
-
|
|
961
|
-
|
|
962
|
-
|
|
963
|
-
|
|
964
|
-
});
|
|
965
|
-
});
|
|
966
|
-
test("Autosuggest -
|
|
967
|
-
var onChange
|
|
968
|
-
|
|
969
|
-
|
|
970
|
-
|
|
971
|
-
|
|
972
|
-
|
|
973
|
-
|
|
974
|
-
|
|
975
|
-
|
|
976
|
-
|
|
977
|
-
|
|
978
|
-
|
|
979
|
-
|
|
980
|
-
|
|
981
|
-
|
|
982
|
-
|
|
983
|
-
|
|
984
|
-
|
|
985
|
-
|
|
986
|
-
|
|
987
|
-
|
|
988
|
-
|
|
989
|
-
|
|
990
|
-
|
|
991
|
-
|
|
992
|
-
|
|
993
|
-
|
|
994
|
-
|
|
995
|
-
|
|
996
|
-
|
|
997
|
-
|
|
998
|
-
|
|
999
|
-
|
|
1000
|
-
|
|
1001
|
-
|
|
1002
|
-
|
|
1003
|
-
|
|
847
|
+
test("Autosuggest closes the listbox when there are no matches for the user's input", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee11() {
|
|
848
|
+
var onChange, _render32, getByRole, queryByRole, input;
|
|
849
|
+
return _regenerator["default"].wrap(function _callee11$(_context11) {
|
|
850
|
+
while (1) switch (_context11.prev = _context11.next) {
|
|
851
|
+
case 0:
|
|
852
|
+
onChange = jest.fn();
|
|
853
|
+
_render32 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
854
|
+
label: "Autocomplete Countries",
|
|
855
|
+
suggestions: countries,
|
|
856
|
+
onChange: onChange
|
|
857
|
+
})), getByRole = _render32.getByRole, queryByRole = _render32.queryByRole;
|
|
858
|
+
input = getByRole("combobox");
|
|
859
|
+
_context11.next = 5;
|
|
860
|
+
return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee10() {
|
|
861
|
+
return _regenerator["default"].wrap(function _callee10$(_context10) {
|
|
862
|
+
while (1) switch (_context10.prev = _context10.next) {
|
|
863
|
+
case 0:
|
|
864
|
+
_userEvent["default"].type(input, "x");
|
|
865
|
+
case 1:
|
|
866
|
+
case "end":
|
|
867
|
+
return _context10.stop();
|
|
868
|
+
}
|
|
869
|
+
}, _callee10);
|
|
870
|
+
})));
|
|
871
|
+
case 5:
|
|
872
|
+
expect(queryByRole("listbox")).toBeFalsy();
|
|
873
|
+
case 6:
|
|
874
|
+
case "end":
|
|
875
|
+
return _context11.stop();
|
|
876
|
+
}
|
|
877
|
+
}, _callee11);
|
|
878
|
+
})));
|
|
879
|
+
test("Autosuggest with no matches founded doesn't let the listbox to be opened", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee13() {
|
|
880
|
+
var onChange, _render33, getByRole, queryByRole, input;
|
|
881
|
+
return _regenerator["default"].wrap(function _callee13$(_context13) {
|
|
882
|
+
while (1) switch (_context13.prev = _context13.next) {
|
|
883
|
+
case 0:
|
|
884
|
+
onChange = jest.fn();
|
|
885
|
+
_render33 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
886
|
+
label: "Autocomplete Countries",
|
|
887
|
+
suggestions: countries,
|
|
888
|
+
onChange: onChange
|
|
889
|
+
})), getByRole = _render33.getByRole, queryByRole = _render33.queryByRole;
|
|
890
|
+
input = getByRole("combobox");
|
|
891
|
+
_context13.next = 5;
|
|
892
|
+
return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee12() {
|
|
893
|
+
return _regenerator["default"].wrap(function _callee12$(_context12) {
|
|
894
|
+
while (1) switch (_context12.prev = _context12.next) {
|
|
895
|
+
case 0:
|
|
896
|
+
_userEvent["default"].type(input, "x");
|
|
897
|
+
case 1:
|
|
898
|
+
case "end":
|
|
899
|
+
return _context12.stop();
|
|
900
|
+
}
|
|
901
|
+
}, _callee12);
|
|
902
|
+
})));
|
|
903
|
+
case 5:
|
|
904
|
+
expect(queryByRole("listbox")).toBeFalsy();
|
|
905
|
+
_react2.fireEvent.focus(input);
|
|
906
|
+
expect(queryByRole("listbox")).toBeFalsy();
|
|
907
|
+
_react2.fireEvent.keyDown(input, {
|
|
908
|
+
key: "ArrowUp",
|
|
909
|
+
code: "ArrowUp",
|
|
910
|
+
keyCode: 38,
|
|
911
|
+
charCode: 38
|
|
912
|
+
});
|
|
913
|
+
expect(queryByRole("listbox")).toBeFalsy();
|
|
914
|
+
_react2.fireEvent.keyDown(input, {
|
|
915
|
+
key: "ArrowDown",
|
|
916
|
+
code: "ArrowDown",
|
|
917
|
+
keyCode: 40,
|
|
918
|
+
charCode: 40
|
|
919
|
+
});
|
|
920
|
+
expect(queryByRole("listbox")).toBeFalsy();
|
|
921
|
+
case 12:
|
|
922
|
+
case "end":
|
|
923
|
+
return _context13.stop();
|
|
924
|
+
}
|
|
925
|
+
}, _callee13);
|
|
926
|
+
})));
|
|
927
|
+
test("Autosuggest uncontrolled - Suggestion selected by click", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee16() {
|
|
928
|
+
var onChange, _render34, getByRole, getByText, queryByRole, input;
|
|
929
|
+
return _regenerator["default"].wrap(function _callee16$(_context16) {
|
|
930
|
+
while (1) switch (_context16.prev = _context16.next) {
|
|
931
|
+
case 0:
|
|
932
|
+
onChange = jest.fn();
|
|
933
|
+
_render34 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
934
|
+
label: "Autocomplete Countries",
|
|
935
|
+
suggestions: countries,
|
|
936
|
+
onChange: onChange
|
|
937
|
+
})), getByRole = _render34.getByRole, getByText = _render34.getByText, queryByRole = _render34.queryByRole;
|
|
938
|
+
input = getByRole("combobox");
|
|
939
|
+
_react2.fireEvent.focus(input);
|
|
940
|
+
_context16.next = 6;
|
|
941
|
+
return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee14() {
|
|
942
|
+
return _regenerator["default"].wrap(function _callee14$(_context14) {
|
|
943
|
+
while (1) switch (_context14.prev = _context14.next) {
|
|
944
|
+
case 0:
|
|
945
|
+
_userEvent["default"].type(input, "Alba");
|
|
946
|
+
case 1:
|
|
947
|
+
case "end":
|
|
948
|
+
return _context14.stop();
|
|
949
|
+
}
|
|
950
|
+
}, _callee14);
|
|
951
|
+
})));
|
|
952
|
+
case 6:
|
|
953
|
+
expect(onChange).toHaveBeenCalled();
|
|
954
|
+
expect(getByText("Alba")).toBeTruthy();
|
|
955
|
+
expect(getByText("nia")).toBeTruthy();
|
|
956
|
+
_context16.next = 11;
|
|
957
|
+
return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee15() {
|
|
958
|
+
return _regenerator["default"].wrap(function _callee15$(_context15) {
|
|
959
|
+
while (1) switch (_context15.prev = _context15.next) {
|
|
960
|
+
case 0:
|
|
961
|
+
_userEvent["default"].click(getByRole("option"));
|
|
962
|
+
case 1:
|
|
963
|
+
case "end":
|
|
964
|
+
return _context15.stop();
|
|
965
|
+
}
|
|
966
|
+
}, _callee15);
|
|
967
|
+
})));
|
|
968
|
+
case 11:
|
|
969
|
+
expect(input.value).toBe("Albania");
|
|
970
|
+
expect(queryByRole("listbox")).toBeFalsy();
|
|
971
|
+
case 13:
|
|
972
|
+
case "end":
|
|
973
|
+
return _context16.stop();
|
|
974
|
+
}
|
|
975
|
+
}, _callee16);
|
|
976
|
+
})));
|
|
977
|
+
test("Autosuggest controlled - Suggestion selected by click", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee17() {
|
|
978
|
+
var onChange, _render35, getByRole, getByText, queryByRole, input;
|
|
979
|
+
return _regenerator["default"].wrap(function _callee17$(_context17) {
|
|
980
|
+
while (1) switch (_context17.prev = _context17.next) {
|
|
981
|
+
case 0:
|
|
982
|
+
onChange = jest.fn();
|
|
983
|
+
_render35 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
984
|
+
label: "Autocomplete Countries",
|
|
985
|
+
value: "Andor",
|
|
986
|
+
suggestions: countries,
|
|
987
|
+
onChange: onChange
|
|
988
|
+
})), getByRole = _render35.getByRole, getByText = _render35.getByText, queryByRole = _render35.queryByRole;
|
|
989
|
+
input = getByRole("combobox");
|
|
990
|
+
_context17.next = 5;
|
|
991
|
+
return _userEvent["default"].click(getByText("Autocomplete Countries"));
|
|
992
|
+
case 5:
|
|
993
|
+
expect(input.value).toBe("Andor");
|
|
994
|
+
expect(getByText("Andor")).toBeTruthy();
|
|
995
|
+
expect(getByText("ra")).toBeTruthy();
|
|
996
|
+
_context17.next = 10;
|
|
997
|
+
return _userEvent["default"].click(getByRole("option"));
|
|
998
|
+
case 10:
|
|
999
|
+
expect(onChange).toHaveBeenCalledWith({
|
|
1000
|
+
value: "Andorra"
|
|
1001
|
+
});
|
|
1002
|
+
expect(queryByRole("listbox")).toBeFalsy();
|
|
1003
|
+
case 12:
|
|
1004
|
+
case "end":
|
|
1005
|
+
return _context17.stop();
|
|
1006
|
+
}
|
|
1007
|
+
}, _callee17);
|
|
1008
|
+
})));
|
|
1009
|
+
test("Autosuggest - Pattern constraint", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee20() {
|
|
1010
|
+
var onChange, onBlur, _render36, getByRole, getByText, input;
|
|
1011
|
+
return _regenerator["default"].wrap(function _callee20$(_context20) {
|
|
1012
|
+
while (1) switch (_context20.prev = _context20.next) {
|
|
1013
|
+
case 0:
|
|
1014
|
+
onChange = jest.fn();
|
|
1015
|
+
onBlur = jest.fn();
|
|
1016
|
+
_render36 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
1017
|
+
label: "Autocomplete Countries",
|
|
1018
|
+
suggestions: countries,
|
|
1019
|
+
onChange: onChange,
|
|
1020
|
+
onBlur: onBlur,
|
|
1021
|
+
pattern: "^.*(?=.*[a-zA-Z])(?=.*\\d)(?=.*[!&$%&? \"]).*$"
|
|
1022
|
+
})), getByRole = _render36.getByRole, getByText = _render36.getByText;
|
|
1023
|
+
input = getByRole("combobox");
|
|
1024
|
+
_react2.fireEvent.focus(input);
|
|
1025
|
+
_context20.next = 7;
|
|
1026
|
+
return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee18() {
|
|
1027
|
+
return _regenerator["default"].wrap(function _callee18$(_context18) {
|
|
1028
|
+
while (1) switch (_context18.prev = _context18.next) {
|
|
1029
|
+
case 0:
|
|
1030
|
+
_userEvent["default"].type(input, "Andor");
|
|
1031
|
+
case 1:
|
|
1032
|
+
case "end":
|
|
1033
|
+
return _context18.stop();
|
|
1034
|
+
}
|
|
1035
|
+
}, _callee18);
|
|
1036
|
+
})));
|
|
1037
|
+
case 7:
|
|
1038
|
+
expect(getByText("Andor")).toBeTruthy();
|
|
1039
|
+
expect(getByText("ra")).toBeTruthy();
|
|
1040
|
+
_context20.next = 11;
|
|
1041
|
+
return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee19() {
|
|
1042
|
+
return _regenerator["default"].wrap(function _callee19$(_context19) {
|
|
1043
|
+
while (1) switch (_context19.prev = _context19.next) {
|
|
1044
|
+
case 0:
|
|
1045
|
+
_userEvent["default"].click(getByRole("option"));
|
|
1046
|
+
case 1:
|
|
1047
|
+
case "end":
|
|
1048
|
+
return _context19.stop();
|
|
1049
|
+
}
|
|
1050
|
+
}, _callee19);
|
|
1051
|
+
})));
|
|
1052
|
+
case 11:
|
|
1053
|
+
expect(onChange).toHaveBeenCalledWith({
|
|
1054
|
+
value: "Andorra",
|
|
1055
|
+
error: "Please match the format requested."
|
|
1056
|
+
});
|
|
1057
|
+
_react2.fireEvent.blur(input);
|
|
1058
|
+
expect(onBlur).toHaveBeenCalledWith({
|
|
1059
|
+
value: "Andorra",
|
|
1060
|
+
error: "Please match the format requested."
|
|
1061
|
+
});
|
|
1062
|
+
case 14:
|
|
1063
|
+
case "end":
|
|
1064
|
+
return _context20.stop();
|
|
1065
|
+
}
|
|
1066
|
+
}, _callee20);
|
|
1067
|
+
})));
|
|
1068
|
+
test("Autosuggest - Length constraint", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee23() {
|
|
1069
|
+
var onChange, onBlur, _render37, getByText, getByRole, input;
|
|
1070
|
+
return _regenerator["default"].wrap(function _callee23$(_context23) {
|
|
1071
|
+
while (1) switch (_context23.prev = _context23.next) {
|
|
1072
|
+
case 0:
|
|
1073
|
+
onChange = jest.fn();
|
|
1074
|
+
onBlur = jest.fn();
|
|
1075
|
+
_render37 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
1076
|
+
label: "Autocomplete Countries",
|
|
1077
|
+
suggestions: countries,
|
|
1078
|
+
onChange: onChange,
|
|
1079
|
+
onBlur: onBlur,
|
|
1080
|
+
minLength: 5,
|
|
1081
|
+
maxLength: 10
|
|
1082
|
+
})), getByText = _render37.getByText, getByRole = _render37.getByRole;
|
|
1083
|
+
input = getByRole("combobox");
|
|
1084
|
+
_react2.fireEvent.focus(input);
|
|
1085
|
+
_context23.next = 7;
|
|
1086
|
+
return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee21() {
|
|
1087
|
+
return _regenerator["default"].wrap(function _callee21$(_context21) {
|
|
1088
|
+
while (1) switch (_context21.prev = _context21.next) {
|
|
1089
|
+
case 0:
|
|
1090
|
+
_userEvent["default"].type(input, "Cha");
|
|
1091
|
+
case 1:
|
|
1092
|
+
case "end":
|
|
1093
|
+
return _context21.stop();
|
|
1094
|
+
}
|
|
1095
|
+
}, _callee21);
|
|
1096
|
+
})));
|
|
1097
|
+
case 7:
|
|
1098
|
+
expect(getByText("Cha")).toBeTruthy();
|
|
1099
|
+
expect(getByText("d")).toBeTruthy();
|
|
1100
|
+
_context23.next = 11;
|
|
1101
|
+
return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee22() {
|
|
1102
|
+
return _regenerator["default"].wrap(function _callee22$(_context22) {
|
|
1103
|
+
while (1) switch (_context22.prev = _context22.next) {
|
|
1104
|
+
case 0:
|
|
1105
|
+
_userEvent["default"].click(getByRole("option"));
|
|
1106
|
+
case 1:
|
|
1107
|
+
case "end":
|
|
1108
|
+
return _context22.stop();
|
|
1109
|
+
}
|
|
1110
|
+
}, _callee22);
|
|
1111
|
+
})));
|
|
1112
|
+
case 11:
|
|
1113
|
+
expect(onChange).toHaveBeenCalledWith({
|
|
1114
|
+
value: "Cha",
|
|
1115
|
+
error: "Min length 5, max length 10."
|
|
1116
|
+
});
|
|
1117
|
+
_react2.fireEvent.blur(input);
|
|
1118
|
+
expect(onBlur).toHaveBeenCalledWith({
|
|
1119
|
+
value: "Chad",
|
|
1120
|
+
error: "Min length 5, max length 10."
|
|
1121
|
+
});
|
|
1122
|
+
case 14:
|
|
1123
|
+
case "end":
|
|
1124
|
+
return _context23.stop();
|
|
1125
|
+
}
|
|
1126
|
+
}, _callee23);
|
|
1127
|
+
})));
|
|
1004
1128
|
test("Autosuggest keys: arrow down key opens autosuggest, active first option is selected with Enter and closes the autosuggest", function () {
|
|
1005
1129
|
var onChange = jest.fn();
|
|
1006
|
-
|
|
1007
|
-
|
|
1008
|
-
|
|
1009
|
-
|
|
1010
|
-
|
|
1011
|
-
|
|
1012
|
-
|
|
1013
|
-
queryByRole = _render32.queryByRole;
|
|
1014
|
-
|
|
1130
|
+
var _render38 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
1131
|
+
label: "Autocomplete Countries",
|
|
1132
|
+
suggestions: countries,
|
|
1133
|
+
onChange: onChange
|
|
1134
|
+
})),
|
|
1135
|
+
getByRole = _render38.getByRole,
|
|
1136
|
+
queryByRole = _render38.queryByRole;
|
|
1015
1137
|
var input = getByRole("combobox");
|
|
1016
|
-
|
|
1017
1138
|
_react2.fireEvent.keyDown(input, {
|
|
1018
1139
|
key: "ArrowDown",
|
|
1019
1140
|
code: "ArrowDown",
|
|
1020
1141
|
keyCode: 40,
|
|
1021
1142
|
charCode: 40
|
|
1022
1143
|
});
|
|
1023
|
-
|
|
1024
1144
|
var list = getByRole("listbox");
|
|
1025
1145
|
expect(list).toBeTruthy();
|
|
1026
|
-
|
|
1027
1146
|
_react2.fireEvent.keyDown(input, {
|
|
1028
1147
|
key: "Enter",
|
|
1029
1148
|
code: "Enter",
|
|
1030
1149
|
keyCode: 13,
|
|
1031
1150
|
charCode: 13
|
|
1032
1151
|
});
|
|
1033
|
-
|
|
1034
1152
|
expect(input.value).toBe("Afghanistan");
|
|
1035
1153
|
expect(queryByRole("list")).toBeFalsy();
|
|
1036
1154
|
});
|
|
1037
1155
|
test("Autosuggest keys: arrow up key opens autosuggest, active last option is selected with Enter and closes the autosuggest", function () {
|
|
1038
1156
|
var onChange = jest.fn();
|
|
1039
|
-
|
|
1040
|
-
|
|
1041
|
-
|
|
1042
|
-
|
|
1043
|
-
|
|
1044
|
-
|
|
1045
|
-
|
|
1046
|
-
queryByRole = _render33.queryByRole;
|
|
1047
|
-
|
|
1157
|
+
var _render39 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
1158
|
+
label: "Autocomplete Countries",
|
|
1159
|
+
suggestions: countries,
|
|
1160
|
+
onChange: onChange
|
|
1161
|
+
})),
|
|
1162
|
+
getByRole = _render39.getByRole,
|
|
1163
|
+
queryByRole = _render39.queryByRole;
|
|
1048
1164
|
var input = getByRole("combobox");
|
|
1049
|
-
|
|
1050
1165
|
_react2.fireEvent.keyDown(input, {
|
|
1051
1166
|
key: "ArrowUp",
|
|
1052
1167
|
code: "ArrowUp",
|
|
1053
1168
|
keyCode: 38,
|
|
1054
1169
|
charCode: 38
|
|
1055
1170
|
});
|
|
1056
|
-
|
|
1057
1171
|
var list = getByRole("listbox");
|
|
1058
1172
|
expect(list).toBeTruthy();
|
|
1059
|
-
|
|
1060
1173
|
_react2.fireEvent.keyDown(input, {
|
|
1061
1174
|
key: "Enter",
|
|
1062
1175
|
code: "Enter",
|
|
1063
1176
|
keyCode: 13,
|
|
1064
1177
|
charCode: 13
|
|
1065
1178
|
});
|
|
1066
|
-
|
|
1067
1179
|
expect(input.value).toBe("Djibouti");
|
|
1068
1180
|
expect(queryByRole("list")).toBeFalsy();
|
|
1069
1181
|
});
|
|
1070
1182
|
test("Autosuggest keys: Esc key closes the autosuggest and cleans the input", function () {
|
|
1071
1183
|
var onChange = jest.fn();
|
|
1072
|
-
|
|
1073
|
-
|
|
1074
|
-
|
|
1075
|
-
|
|
1076
|
-
|
|
1077
|
-
|
|
1078
|
-
|
|
1079
|
-
queryByRole = _render34.queryByRole;
|
|
1080
|
-
|
|
1184
|
+
var _render40 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
1185
|
+
label: "Autocomplete Countries",
|
|
1186
|
+
suggestions: countries,
|
|
1187
|
+
onChange: onChange
|
|
1188
|
+
})),
|
|
1189
|
+
getByRole = _render40.getByRole,
|
|
1190
|
+
queryByRole = _render40.queryByRole;
|
|
1081
1191
|
var input = getByRole("combobox");
|
|
1082
|
-
|
|
1083
1192
|
_react2.fireEvent.focus(input);
|
|
1084
|
-
|
|
1085
1193
|
_userEvent["default"].type(input, "Bangla");
|
|
1086
|
-
|
|
1087
1194
|
var list = getByRole("listbox");
|
|
1088
1195
|
expect(list).toBeTruthy();
|
|
1089
|
-
|
|
1090
1196
|
_react2.fireEvent.keyDown(input, {
|
|
1091
1197
|
key: "Esc",
|
|
1092
1198
|
code: "Esc",
|
|
1093
1199
|
keyCode: 27,
|
|
1094
1200
|
charCode: 27
|
|
1095
1201
|
});
|
|
1096
|
-
|
|
1097
1202
|
expect(input.value).toBe("");
|
|
1098
1203
|
expect(queryByRole("listbox")).toBeFalsy();
|
|
1099
1204
|
});
|
|
1100
1205
|
test("Autosuggest keys: Enter, if no active suggestion closes the autosuggest", function () {
|
|
1101
1206
|
var onChange = jest.fn();
|
|
1102
|
-
|
|
1103
|
-
|
|
1104
|
-
|
|
1105
|
-
|
|
1106
|
-
|
|
1107
|
-
|
|
1108
|
-
|
|
1109
|
-
queryByRole = _render35.queryByRole;
|
|
1110
|
-
|
|
1207
|
+
var _render41 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
1208
|
+
label: "Autocomplete Countries",
|
|
1209
|
+
suggestions: countries,
|
|
1210
|
+
onChange: onChange
|
|
1211
|
+
})),
|
|
1212
|
+
getByRole = _render41.getByRole,
|
|
1213
|
+
queryByRole = _render41.queryByRole;
|
|
1111
1214
|
var input = getByRole("combobox");
|
|
1112
|
-
|
|
1113
1215
|
_react2.fireEvent.focus(input);
|
|
1114
|
-
|
|
1115
1216
|
var list = getByRole("listbox");
|
|
1116
1217
|
expect(list).toBeTruthy();
|
|
1117
|
-
|
|
1118
1218
|
_react2.fireEvent.keyDown(input, {
|
|
1119
1219
|
key: "Enter",
|
|
1120
1220
|
code: "Enter",
|
|
1121
1221
|
keyCode: 27,
|
|
1122
1222
|
charCode: 27
|
|
1123
1223
|
});
|
|
1124
|
-
|
|
1125
1224
|
expect(input.value).toBe("");
|
|
1126
1225
|
expect(queryByRole("list")).toBeFalsy();
|
|
1127
1226
|
});
|
|
1128
|
-
test("Autosuggest complex key
|
|
1227
|
+
test("Autosuggest complex key sequence: write, arrow up two times, arrow down and select with Enter. Then, clean with Esc.", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee25() {
|
|
1228
|
+
var onChange, _render42, getByRole, queryByRole, input;
|
|
1229
|
+
return _regenerator["default"].wrap(function _callee25$(_context25) {
|
|
1230
|
+
while (1) switch (_context25.prev = _context25.next) {
|
|
1231
|
+
case 0:
|
|
1232
|
+
onChange = jest.fn();
|
|
1233
|
+
_render42 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
1234
|
+
label: "Autocomplete Countries",
|
|
1235
|
+
suggestions: countries,
|
|
1236
|
+
onChange: onChange
|
|
1237
|
+
})), getByRole = _render42.getByRole, queryByRole = _render42.queryByRole;
|
|
1238
|
+
input = getByRole("combobox");
|
|
1239
|
+
_react2.fireEvent.focus(input);
|
|
1240
|
+
_context25.next = 6;
|
|
1241
|
+
return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee24() {
|
|
1242
|
+
return _regenerator["default"].wrap(function _callee24$(_context24) {
|
|
1243
|
+
while (1) switch (_context24.prev = _context24.next) {
|
|
1244
|
+
case 0:
|
|
1245
|
+
_userEvent["default"].type(input, "Ba");
|
|
1246
|
+
case 1:
|
|
1247
|
+
case "end":
|
|
1248
|
+
return _context24.stop();
|
|
1249
|
+
}
|
|
1250
|
+
}, _callee24);
|
|
1251
|
+
})));
|
|
1252
|
+
case 6:
|
|
1253
|
+
_react2.fireEvent.keyDown(input, {
|
|
1254
|
+
key: "ArrowUp",
|
|
1255
|
+
code: "ArrowUp",
|
|
1256
|
+
keyCode: 38,
|
|
1257
|
+
charCode: 38
|
|
1258
|
+
});
|
|
1259
|
+
_react2.fireEvent.keyDown(input, {
|
|
1260
|
+
key: "ArrowUp",
|
|
1261
|
+
code: "ArrowUpp",
|
|
1262
|
+
keyCode: 38,
|
|
1263
|
+
charCode: 38
|
|
1264
|
+
});
|
|
1265
|
+
_react2.fireEvent.keyDown(input, {
|
|
1266
|
+
key: "ArrowDown",
|
|
1267
|
+
code: "ArrowDown",
|
|
1268
|
+
keyCode: 40,
|
|
1269
|
+
charCode: 40
|
|
1270
|
+
});
|
|
1271
|
+
_react2.fireEvent.keyDown(input, {
|
|
1272
|
+
key: "Enter",
|
|
1273
|
+
code: "Enter",
|
|
1274
|
+
keyCode: 13,
|
|
1275
|
+
charCode: 13
|
|
1276
|
+
});
|
|
1277
|
+
expect(input.value).toBe("Barbados");
|
|
1278
|
+
expect(queryByRole("listbox")).toBeFalsy();
|
|
1279
|
+
_react2.fireEvent.keyDown(input, {
|
|
1280
|
+
key: "Esc",
|
|
1281
|
+
code: "Esp",
|
|
1282
|
+
keyCode: 27,
|
|
1283
|
+
charCode: 27
|
|
1284
|
+
});
|
|
1285
|
+
expect(input.value).toBe("");
|
|
1286
|
+
expect(queryByRole("listbox")).toBeFalsy();
|
|
1287
|
+
case 15:
|
|
1288
|
+
case "end":
|
|
1289
|
+
return _context25.stop();
|
|
1290
|
+
}
|
|
1291
|
+
}, _callee25);
|
|
1292
|
+
})));
|
|
1293
|
+
test("Autosuggest escapes special characters", function () {
|
|
1129
1294
|
var onChange = jest.fn();
|
|
1130
|
-
|
|
1131
|
-
|
|
1132
|
-
|
|
1133
|
-
|
|
1134
|
-
|
|
1135
|
-
|
|
1136
|
-
|
|
1137
|
-
queryByRole = _render36.queryByRole;
|
|
1138
|
-
|
|
1295
|
+
var _render43 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
1296
|
+
label: "Autocomplete Countries",
|
|
1297
|
+
suggestions: specialCharacters,
|
|
1298
|
+
onChange: onChange
|
|
1299
|
+
})),
|
|
1300
|
+
getAllByText = _render43.getAllByText,
|
|
1301
|
+
getByRole = _render43.getByRole;
|
|
1139
1302
|
var input = getByRole("combobox");
|
|
1140
|
-
|
|
1141
1303
|
_react2.fireEvent.focus(input);
|
|
1142
|
-
|
|
1143
|
-
|
|
1144
|
-
|
|
1145
|
-
|
|
1146
|
-
|
|
1147
|
-
code: "ArrowUp",
|
|
1148
|
-
keyCode: 38,
|
|
1149
|
-
charCode: 38
|
|
1304
|
+
var list = getByRole("listbox");
|
|
1305
|
+
_react2.fireEvent.change(input, {
|
|
1306
|
+
target: {
|
|
1307
|
+
value: "/"
|
|
1308
|
+
}
|
|
1150
1309
|
});
|
|
1151
|
-
|
|
1152
|
-
|
|
1153
|
-
|
|
1154
|
-
|
|
1155
|
-
|
|
1156
|
-
|
|
1310
|
+
expect(list).toBeTruthy();
|
|
1311
|
+
expect(getAllByText("/").length).toBe(1);
|
|
1312
|
+
_react2.fireEvent.change(input, {
|
|
1313
|
+
target: {
|
|
1314
|
+
value: "\\"
|
|
1315
|
+
}
|
|
1157
1316
|
});
|
|
1158
|
-
|
|
1159
|
-
|
|
1160
|
-
|
|
1161
|
-
|
|
1162
|
-
|
|
1163
|
-
|
|
1317
|
+
expect(list).toBeTruthy();
|
|
1318
|
+
expect(getAllByText("\\").length).toBe(1);
|
|
1319
|
+
_react2.fireEvent.change(input, {
|
|
1320
|
+
target: {
|
|
1321
|
+
value: "*"
|
|
1322
|
+
}
|
|
1164
1323
|
});
|
|
1165
|
-
|
|
1166
|
-
|
|
1167
|
-
|
|
1168
|
-
|
|
1169
|
-
|
|
1170
|
-
|
|
1324
|
+
expect(list).toBeTruthy();
|
|
1325
|
+
expect(getAllByText("*").length).toBe(2);
|
|
1326
|
+
_react2.fireEvent.change(input, {
|
|
1327
|
+
target: {
|
|
1328
|
+
value: "("
|
|
1329
|
+
}
|
|
1171
1330
|
});
|
|
1172
|
-
|
|
1173
|
-
expect(
|
|
1174
|
-
|
|
1175
|
-
|
|
1176
|
-
|
|
1177
|
-
|
|
1178
|
-
code: "Esp",
|
|
1179
|
-
keyCode: 27,
|
|
1180
|
-
charCode: 27
|
|
1331
|
+
expect(list).toBeTruthy();
|
|
1332
|
+
expect(getAllByText("(").length).toBe(1);
|
|
1333
|
+
_react2.fireEvent.change(input, {
|
|
1334
|
+
target: {
|
|
1335
|
+
value: ")"
|
|
1336
|
+
}
|
|
1181
1337
|
});
|
|
1182
|
-
|
|
1183
|
-
expect(
|
|
1184
|
-
|
|
1338
|
+
expect(list).toBeTruthy();
|
|
1339
|
+
expect(getAllByText(")").length).toBe(1);
|
|
1340
|
+
_react2.fireEvent.change(input, {
|
|
1341
|
+
target: {
|
|
1342
|
+
value: "["
|
|
1343
|
+
}
|
|
1344
|
+
});
|
|
1345
|
+
expect(list).toBeTruthy();
|
|
1346
|
+
expect(getAllByText("[").length).toBe(1);
|
|
1347
|
+
_react2.fireEvent.change(input, {
|
|
1348
|
+
target: {
|
|
1349
|
+
value: "]"
|
|
1350
|
+
}
|
|
1351
|
+
});
|
|
1352
|
+
expect(list).toBeTruthy();
|
|
1353
|
+
expect(getAllByText("]").length).toBe(1);
|
|
1354
|
+
_react2.fireEvent.change(input, {
|
|
1355
|
+
target: {
|
|
1356
|
+
value: "+"
|
|
1357
|
+
}
|
|
1358
|
+
});
|
|
1359
|
+
expect(list).toBeTruthy();
|
|
1360
|
+
expect(getAllByText("+").length).toBe(1);
|
|
1361
|
+
_react2.fireEvent.change(input, {
|
|
1362
|
+
target: {
|
|
1363
|
+
value: "?"
|
|
1364
|
+
}
|
|
1365
|
+
});
|
|
1366
|
+
expect(list).toBeTruthy();
|
|
1367
|
+
expect(getAllByText("?").length).toBe(1);
|
|
1185
1368
|
});
|
|
1186
1369
|
});
|
|
1187
1370
|
describe("TextInput component asynchronous autosuggest tests", function () {
|
|
1188
|
-
test("Autosuggest 'Searching...' message is shown", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function
|
|
1189
|
-
var callbackFunc, onChange,
|
|
1190
|
-
|
|
1191
|
-
|
|
1192
|
-
|
|
1193
|
-
|
|
1194
|
-
|
|
1195
|
-
|
|
1196
|
-
|
|
1197
|
-
|
|
1198
|
-
|
|
1199
|
-
|
|
1200
|
-
}) : countries);
|
|
1201
|
-
}, 100);
|
|
1202
|
-
});
|
|
1203
|
-
return result;
|
|
1204
|
-
});
|
|
1205
|
-
onChange = jest.fn();
|
|
1206
|
-
_render37 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
1207
|
-
label: "Autosuggest Countries",
|
|
1208
|
-
suggestions: callbackFunc,
|
|
1209
|
-
onChange: onChange
|
|
1210
|
-
})), getByRole = _render37.getByRole, getByText = _render37.getByText;
|
|
1211
|
-
input = getByRole("combobox");
|
|
1212
|
-
|
|
1213
|
-
_react2.fireEvent.focus(input);
|
|
1214
|
-
|
|
1215
|
-
expect(getByRole("listbox")).toBeTruthy();
|
|
1216
|
-
_context.next = 8;
|
|
1217
|
-
return (0, _react2.waitForElementToBeRemoved)(function () {
|
|
1218
|
-
return getByText("Searching...");
|
|
1219
|
-
});
|
|
1220
|
-
|
|
1221
|
-
case 8:
|
|
1222
|
-
expect(getByText("Afghanistan")).toBeTruthy();
|
|
1223
|
-
expect(getByText("Albania")).toBeTruthy();
|
|
1224
|
-
expect(getByText("Algeria")).toBeTruthy();
|
|
1225
|
-
expect(getByText("Andorra")).toBeTruthy();
|
|
1226
|
-
|
|
1227
|
-
_userEvent["default"].type(input, "Ab");
|
|
1228
|
-
|
|
1229
|
-
_context.next = 15;
|
|
1230
|
-
return (0, _react2.waitForElementToBeRemoved)(function () {
|
|
1231
|
-
return getByText("Searching...");
|
|
1232
|
-
});
|
|
1233
|
-
|
|
1234
|
-
case 15:
|
|
1235
|
-
expect(getByText("Cabo Verde")).toBeTruthy();
|
|
1236
|
-
|
|
1237
|
-
_react2.fireEvent.keyDown(input, {
|
|
1238
|
-
key: "ArrowUp",
|
|
1239
|
-
code: "ArrowUp",
|
|
1240
|
-
keyCode: 38,
|
|
1241
|
-
charCode: 38
|
|
1371
|
+
test("Autosuggest 'Searching...' message is shown", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee27() {
|
|
1372
|
+
var callbackFunc, onChange, _render44, getByRole, getByText, input;
|
|
1373
|
+
return _regenerator["default"].wrap(function _callee27$(_context27) {
|
|
1374
|
+
while (1) switch (_context27.prev = _context27.next) {
|
|
1375
|
+
case 0:
|
|
1376
|
+
callbackFunc = jest.fn(function (newValue) {
|
|
1377
|
+
var result = new Promise(function (resolve) {
|
|
1378
|
+
return setTimeout(function () {
|
|
1379
|
+
resolve(newValue ? countries.filter(function (option) {
|
|
1380
|
+
return option.toUpperCase().includes(newValue.toUpperCase());
|
|
1381
|
+
}) : countries);
|
|
1382
|
+
}, 100);
|
|
1242
1383
|
});
|
|
1243
|
-
|
|
1244
|
-
|
|
1245
|
-
|
|
1246
|
-
|
|
1247
|
-
|
|
1248
|
-
|
|
1249
|
-
|
|
1250
|
-
|
|
1251
|
-
|
|
1252
|
-
|
|
1253
|
-
|
|
1254
|
-
|
|
1255
|
-
|
|
1256
|
-
|
|
1384
|
+
return result;
|
|
1385
|
+
});
|
|
1386
|
+
onChange = jest.fn();
|
|
1387
|
+
_render44 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
1388
|
+
label: "Autosuggest Countries",
|
|
1389
|
+
suggestions: callbackFunc,
|
|
1390
|
+
onChange: onChange
|
|
1391
|
+
})), getByRole = _render44.getByRole, getByText = _render44.getByText;
|
|
1392
|
+
input = getByRole("combobox");
|
|
1393
|
+
_react2.fireEvent.focus(input);
|
|
1394
|
+
expect(getByRole("listbox")).toBeTruthy();
|
|
1395
|
+
_context27.next = 8;
|
|
1396
|
+
return (0, _react2.waitForElementToBeRemoved)(function () {
|
|
1397
|
+
return getByText("Searching...");
|
|
1398
|
+
});
|
|
1399
|
+
case 8:
|
|
1400
|
+
expect(getByText("Afghanistan")).toBeTruthy();
|
|
1401
|
+
expect(getByText("Albania")).toBeTruthy();
|
|
1402
|
+
expect(getByText("Algeria")).toBeTruthy();
|
|
1403
|
+
expect(getByText("Andorra")).toBeTruthy();
|
|
1404
|
+
_context27.next = 14;
|
|
1405
|
+
return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee26() {
|
|
1406
|
+
return _regenerator["default"].wrap(function _callee26$(_context26) {
|
|
1407
|
+
while (1) switch (_context26.prev = _context26.next) {
|
|
1408
|
+
case 0:
|
|
1409
|
+
_userEvent["default"].type(input, "Ab");
|
|
1410
|
+
case 1:
|
|
1411
|
+
case "end":
|
|
1412
|
+
return _context26.stop();
|
|
1413
|
+
}
|
|
1414
|
+
}, _callee26);
|
|
1415
|
+
})));
|
|
1416
|
+
case 14:
|
|
1417
|
+
_context27.next = 16;
|
|
1418
|
+
return (0, _react2.waitForElementToBeRemoved)(function () {
|
|
1419
|
+
return getByText("Searching...");
|
|
1420
|
+
});
|
|
1421
|
+
case 16:
|
|
1422
|
+
expect(getByText("Cabo Verde")).toBeTruthy();
|
|
1423
|
+
_react2.fireEvent.keyDown(input, {
|
|
1424
|
+
key: "ArrowUp",
|
|
1425
|
+
code: "ArrowUp",
|
|
1426
|
+
keyCode: 38,
|
|
1427
|
+
charCode: 38
|
|
1428
|
+
});
|
|
1429
|
+
_react2.fireEvent.keyDown(input, {
|
|
1430
|
+
key: "Enter",
|
|
1431
|
+
code: "Enter",
|
|
1432
|
+
keyCode: 13,
|
|
1433
|
+
charCode: 13
|
|
1434
|
+
});
|
|
1435
|
+
expect(input.value).toBe("Cabo Verde");
|
|
1436
|
+
case 20:
|
|
1437
|
+
case "end":
|
|
1438
|
+
return _context27.stop();
|
|
1257
1439
|
}
|
|
1258
|
-
},
|
|
1440
|
+
}, _callee27);
|
|
1259
1441
|
})));
|
|
1260
1442
|
test("Autosuggest Esc key works while 'Searching...' message is shown", function () {
|
|
1261
1443
|
var callbackFunc = jest.fn(function (newValue) {
|
|
@@ -1269,356 +1451,306 @@ describe("TextInput component asynchronous autosuggest tests", function () {
|
|
|
1269
1451
|
return result;
|
|
1270
1452
|
});
|
|
1271
1453
|
var onChange = jest.fn();
|
|
1272
|
-
|
|
1273
|
-
|
|
1274
|
-
|
|
1275
|
-
|
|
1276
|
-
|
|
1277
|
-
|
|
1278
|
-
|
|
1279
|
-
|
|
1280
|
-
queryByRole = _render38.queryByRole;
|
|
1281
|
-
|
|
1454
|
+
var _render45 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
1455
|
+
label: "Autosuggest Countries",
|
|
1456
|
+
suggestions: callbackFunc,
|
|
1457
|
+
onChange: onChange
|
|
1458
|
+
})),
|
|
1459
|
+
getByRole = _render45.getByRole,
|
|
1460
|
+
queryByText = _render45.queryByText,
|
|
1461
|
+
queryByRole = _render45.queryByRole;
|
|
1282
1462
|
var input = getByRole("combobox");
|
|
1283
|
-
|
|
1284
1463
|
_react2.fireEvent.focus(input);
|
|
1285
|
-
|
|
1286
1464
|
expect(getByRole("listbox")).toBeTruthy();
|
|
1287
|
-
|
|
1288
1465
|
_userEvent["default"].type(input, "Ab");
|
|
1289
|
-
|
|
1290
1466
|
_react2.fireEvent.keyDown(input, {
|
|
1291
1467
|
key: "Esc",
|
|
1292
1468
|
code: "Esc",
|
|
1293
1469
|
keyCode: 27,
|
|
1294
1470
|
charCode: 27
|
|
1295
1471
|
});
|
|
1296
|
-
|
|
1297
1472
|
expect(queryByRole("listbox")).toBeFalsy();
|
|
1298
1473
|
expect(queryByText("Searching...")).toBeFalsy();
|
|
1299
1474
|
expect(input.value).toBe("");
|
|
1300
1475
|
});
|
|
1301
|
-
test("Autosuggest Esc + arrow down working while 'Searching...' message is shown", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function
|
|
1302
|
-
var callbackFunc, onChange,
|
|
1303
|
-
|
|
1304
|
-
|
|
1305
|
-
|
|
1306
|
-
|
|
1307
|
-
|
|
1308
|
-
|
|
1309
|
-
|
|
1310
|
-
|
|
1311
|
-
|
|
1312
|
-
|
|
1313
|
-
}) : countries);
|
|
1314
|
-
}, 100);
|
|
1315
|
-
});
|
|
1316
|
-
return result;
|
|
1476
|
+
test("Autosuggest Esc + arrow down working while 'Searching...' message is shown", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee28() {
|
|
1477
|
+
var callbackFunc, onChange, _render46, getByRole, getByText, queryByText, queryByRole, input, list;
|
|
1478
|
+
return _regenerator["default"].wrap(function _callee28$(_context28) {
|
|
1479
|
+
while (1) switch (_context28.prev = _context28.next) {
|
|
1480
|
+
case 0:
|
|
1481
|
+
callbackFunc = jest.fn(function (newValue) {
|
|
1482
|
+
var result = new Promise(function (resolve) {
|
|
1483
|
+
return setTimeout(function () {
|
|
1484
|
+
resolve(newValue ? countries.filter(function (option) {
|
|
1485
|
+
return option.toUpperCase().includes(newValue.toUpperCase());
|
|
1486
|
+
}) : countries);
|
|
1487
|
+
}, 100);
|
|
1317
1488
|
});
|
|
1318
|
-
|
|
1319
|
-
|
|
1320
|
-
|
|
1321
|
-
|
|
1322
|
-
|
|
1323
|
-
|
|
1324
|
-
|
|
1325
|
-
|
|
1326
|
-
|
|
1327
|
-
|
|
1328
|
-
|
|
1329
|
-
|
|
1330
|
-
|
|
1331
|
-
|
|
1332
|
-
|
|
1333
|
-
|
|
1334
|
-
|
|
1335
|
-
|
|
1336
|
-
|
|
1337
|
-
|
|
1338
|
-
|
|
1339
|
-
|
|
1340
|
-
|
|
1341
|
-
|
|
1342
|
-
|
|
1343
|
-
|
|
1344
|
-
|
|
1345
|
-
|
|
1346
|
-
|
|
1347
|
-
|
|
1348
|
-
|
|
1349
|
-
|
|
1350
|
-
|
|
1351
|
-
|
|
1352
|
-
|
|
1353
|
-
|
|
1354
|
-
|
|
1355
|
-
|
|
1356
|
-
|
|
1357
|
-
|
|
1358
|
-
|
|
1359
|
-
expect(getByText("Albania")).toBeTruthy();
|
|
1360
|
-
expect(getByText("Algeria")).toBeTruthy();
|
|
1361
|
-
expect(getByText("Andorra")).toBeTruthy();
|
|
1362
|
-
|
|
1363
|
-
case 20:
|
|
1364
|
-
case "end":
|
|
1365
|
-
return _context2.stop();
|
|
1366
|
-
}
|
|
1489
|
+
return result;
|
|
1490
|
+
});
|
|
1491
|
+
onChange = jest.fn();
|
|
1492
|
+
_render46 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
1493
|
+
label: "Autosuggest Countries",
|
|
1494
|
+
suggestions: callbackFunc,
|
|
1495
|
+
onChange: onChange
|
|
1496
|
+
})), getByRole = _render46.getByRole, getByText = _render46.getByText, queryByText = _render46.queryByText, queryByRole = _render46.queryByRole;
|
|
1497
|
+
input = getByRole("combobox");
|
|
1498
|
+
_react2.fireEvent.focus(input);
|
|
1499
|
+
list = getByRole("listbox");
|
|
1500
|
+
expect(list).toBeTruthy();
|
|
1501
|
+
_userEvent["default"].type(input, "Ab");
|
|
1502
|
+
_react2.fireEvent.keyDown(input, {
|
|
1503
|
+
key: "Esc",
|
|
1504
|
+
code: "Esc",
|
|
1505
|
+
keyCode: 27,
|
|
1506
|
+
charCode: 27
|
|
1507
|
+
});
|
|
1508
|
+
expect(queryByRole("listbox")).toBeFalsy();
|
|
1509
|
+
expect(queryByText("Searching...")).toBeFalsy();
|
|
1510
|
+
expect(input.value).toBe("");
|
|
1511
|
+
_react2.fireEvent.keyDown(input, {
|
|
1512
|
+
key: "ArrowDown",
|
|
1513
|
+
code: "ArrowDown",
|
|
1514
|
+
keyCode: 40,
|
|
1515
|
+
charCode: 40
|
|
1516
|
+
});
|
|
1517
|
+
expect(list).toBeTruthy();
|
|
1518
|
+
_context28.next = 16;
|
|
1519
|
+
return (0, _react2.waitForElementToBeRemoved)(function () {
|
|
1520
|
+
return getByText("Searching...");
|
|
1521
|
+
});
|
|
1522
|
+
case 16:
|
|
1523
|
+
expect(getByText("Afghanistan")).toBeTruthy();
|
|
1524
|
+
expect(getByText("Albania")).toBeTruthy();
|
|
1525
|
+
expect(getByText("Algeria")).toBeTruthy();
|
|
1526
|
+
expect(getByText("Andorra")).toBeTruthy();
|
|
1527
|
+
case 20:
|
|
1528
|
+
case "end":
|
|
1529
|
+
return _context28.stop();
|
|
1367
1530
|
}
|
|
1368
|
-
},
|
|
1531
|
+
}, _callee28);
|
|
1369
1532
|
})));
|
|
1370
|
-
test("Asynchronous uncontrolled autosuggest test", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function
|
|
1371
|
-
var callbackFunc, onChange,
|
|
1372
|
-
|
|
1373
|
-
|
|
1374
|
-
|
|
1375
|
-
|
|
1376
|
-
|
|
1377
|
-
|
|
1378
|
-
|
|
1379
|
-
|
|
1380
|
-
|
|
1381
|
-
|
|
1382
|
-
}) : countries);
|
|
1383
|
-
}, 100);
|
|
1384
|
-
});
|
|
1385
|
-
return result;
|
|
1386
|
-
});
|
|
1387
|
-
onChange = jest.fn();
|
|
1388
|
-
_render40 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
1389
|
-
label: "Autosuggest Countries",
|
|
1390
|
-
onChange: onChange,
|
|
1391
|
-
suggestions: callbackFunc
|
|
1392
|
-
})), getByRole = _render40.getByRole, getByText = _render40.getByText;
|
|
1393
|
-
input = getByRole("combobox");
|
|
1394
|
-
|
|
1395
|
-
_react2.fireEvent.focus(input);
|
|
1396
|
-
|
|
1397
|
-
_userEvent["default"].type(input, "Den");
|
|
1398
|
-
|
|
1399
|
-
_context3.next = 8;
|
|
1400
|
-
return (0, _react2.waitForElementToBeRemoved)(function () {
|
|
1401
|
-
return getByText("Searching...");
|
|
1402
|
-
});
|
|
1403
|
-
|
|
1404
|
-
case 8:
|
|
1405
|
-
expect(getByText("Denmark")).toBeTruthy();
|
|
1406
|
-
|
|
1407
|
-
_userEvent["default"].click(getByRole("option"));
|
|
1408
|
-
|
|
1409
|
-
expect(onChange).toHaveBeenCalledWith({
|
|
1410
|
-
value: "Denmark"
|
|
1533
|
+
test("Asynchronous uncontrolled autosuggest test", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee29() {
|
|
1534
|
+
var callbackFunc, onChange, _render47, getByRole, getByText, input;
|
|
1535
|
+
return _regenerator["default"].wrap(function _callee29$(_context29) {
|
|
1536
|
+
while (1) switch (_context29.prev = _context29.next) {
|
|
1537
|
+
case 0:
|
|
1538
|
+
callbackFunc = jest.fn(function (newValue) {
|
|
1539
|
+
var result = new Promise(function (resolve) {
|
|
1540
|
+
return setTimeout(function () {
|
|
1541
|
+
resolve(newValue ? countries.filter(function (option) {
|
|
1542
|
+
return option.toUpperCase().includes(newValue.toUpperCase());
|
|
1543
|
+
}) : countries);
|
|
1544
|
+
}, 100);
|
|
1411
1545
|
});
|
|
1412
|
-
|
|
1413
|
-
|
|
1414
|
-
|
|
1415
|
-
|
|
1416
|
-
|
|
1417
|
-
|
|
1546
|
+
return result;
|
|
1547
|
+
});
|
|
1548
|
+
onChange = jest.fn();
|
|
1549
|
+
_render47 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
1550
|
+
label: "Autosuggest Countries",
|
|
1551
|
+
onChange: onChange,
|
|
1552
|
+
suggestions: callbackFunc
|
|
1553
|
+
})), getByRole = _render47.getByRole, getByText = _render47.getByText;
|
|
1554
|
+
input = getByRole("combobox");
|
|
1555
|
+
_react2.fireEvent.focus(input);
|
|
1556
|
+
_userEvent["default"].type(input, "Den");
|
|
1557
|
+
_context29.next = 8;
|
|
1558
|
+
return (0, _react2.waitForElementToBeRemoved)(function () {
|
|
1559
|
+
return getByText("Searching...");
|
|
1560
|
+
});
|
|
1561
|
+
case 8:
|
|
1562
|
+
expect(getByText("Denmark")).toBeTruthy();
|
|
1563
|
+
_context29.next = 11;
|
|
1564
|
+
return _userEvent["default"].click(getByRole("option"));
|
|
1565
|
+
case 11:
|
|
1566
|
+
expect(onChange).toHaveBeenCalledWith({
|
|
1567
|
+
value: "Denmark"
|
|
1568
|
+
});
|
|
1569
|
+
expect(input.value).toBe("Denmark");
|
|
1570
|
+
case 13:
|
|
1571
|
+
case "end":
|
|
1572
|
+
return _context29.stop();
|
|
1418
1573
|
}
|
|
1419
|
-
},
|
|
1574
|
+
}, _callee29);
|
|
1420
1575
|
})));
|
|
1421
|
-
test("Asynchronous controlled autosuggest test", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function
|
|
1422
|
-
var callbackFunc, onChange,
|
|
1423
|
-
|
|
1424
|
-
|
|
1425
|
-
|
|
1426
|
-
|
|
1427
|
-
|
|
1428
|
-
|
|
1429
|
-
|
|
1430
|
-
|
|
1431
|
-
|
|
1432
|
-
|
|
1433
|
-
}) : countries);
|
|
1434
|
-
}, 100);
|
|
1435
|
-
});
|
|
1436
|
-
return result;
|
|
1576
|
+
test("Asynchronous controlled autosuggest test", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee30() {
|
|
1577
|
+
var callbackFunc, onChange, _render48, getByRole, getByText, queryByRole, input;
|
|
1578
|
+
return _regenerator["default"].wrap(function _callee30$(_context30) {
|
|
1579
|
+
while (1) switch (_context30.prev = _context30.next) {
|
|
1580
|
+
case 0:
|
|
1581
|
+
callbackFunc = jest.fn(function (newValue) {
|
|
1582
|
+
var result = new Promise(function (resolve) {
|
|
1583
|
+
return setTimeout(function () {
|
|
1584
|
+
resolve(newValue ? countries.filter(function (option) {
|
|
1585
|
+
return option.toUpperCase().includes(newValue.toUpperCase());
|
|
1586
|
+
}) : countries);
|
|
1587
|
+
}, 100);
|
|
1437
1588
|
});
|
|
1438
|
-
|
|
1439
|
-
|
|
1440
|
-
|
|
1441
|
-
|
|
1442
|
-
|
|
1443
|
-
|
|
1444
|
-
|
|
1445
|
-
|
|
1446
|
-
|
|
1447
|
-
|
|
1448
|
-
|
|
1449
|
-
|
|
1450
|
-
|
|
1451
|
-
|
|
1452
|
-
|
|
1453
|
-
|
|
1454
|
-
|
|
1455
|
-
|
|
1456
|
-
|
|
1457
|
-
|
|
1458
|
-
|
|
1459
|
-
|
|
1460
|
-
|
|
1461
|
-
|
|
1462
|
-
|
|
1463
|
-
|
|
1464
|
-
|
|
1465
|
-
|
|
1466
|
-
|
|
1467
|
-
|
|
1468
|
-
|
|
1469
|
-
return _context4.stop();
|
|
1470
|
-
}
|
|
1589
|
+
return result;
|
|
1590
|
+
});
|
|
1591
|
+
onChange = jest.fn();
|
|
1592
|
+
_render48 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
1593
|
+
label: "Autosuggest Countries",
|
|
1594
|
+
value: "Denm",
|
|
1595
|
+
onChange: onChange,
|
|
1596
|
+
suggestions: callbackFunc
|
|
1597
|
+
})), getByRole = _render48.getByRole, getByText = _render48.getByText, queryByRole = _render48.queryByRole;
|
|
1598
|
+
input = getByRole("combobox");
|
|
1599
|
+
expect(input.value).toBe("Denm");
|
|
1600
|
+
_context30.next = 7;
|
|
1601
|
+
return _userEvent["default"].click(getByText("Autosuggest Countries"));
|
|
1602
|
+
case 7:
|
|
1603
|
+
_context30.next = 9;
|
|
1604
|
+
return (0, _react2.waitForElementToBeRemoved)(function () {
|
|
1605
|
+
return getByText("Searching...");
|
|
1606
|
+
});
|
|
1607
|
+
case 9:
|
|
1608
|
+
expect(getByText("Denmark")).toBeTruthy();
|
|
1609
|
+
_react2.fireEvent.focus(getByRole("option"));
|
|
1610
|
+
_context30.next = 13;
|
|
1611
|
+
return _userEvent["default"].click(getByText("Denmark"));
|
|
1612
|
+
case 13:
|
|
1613
|
+
expect(onChange).toHaveBeenCalledWith({
|
|
1614
|
+
value: "Denmark"
|
|
1615
|
+
});
|
|
1616
|
+
expect(queryByRole("listbox")).toBeFalsy();
|
|
1617
|
+
case 15:
|
|
1618
|
+
case "end":
|
|
1619
|
+
return _context30.stop();
|
|
1471
1620
|
}
|
|
1472
|
-
},
|
|
1621
|
+
}, _callee30);
|
|
1473
1622
|
})));
|
|
1474
|
-
test("Asynchronous autosuggest closes the listbox after finishing no matches search", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function
|
|
1475
|
-
var callbackFunc, onChange,
|
|
1476
|
-
|
|
1477
|
-
|
|
1478
|
-
|
|
1479
|
-
|
|
1480
|
-
|
|
1481
|
-
|
|
1482
|
-
|
|
1483
|
-
|
|
1484
|
-
|
|
1485
|
-
|
|
1486
|
-
}) : countries);
|
|
1487
|
-
}, 100);
|
|
1488
|
-
});
|
|
1489
|
-
return result;
|
|
1490
|
-
});
|
|
1491
|
-
onChange = jest.fn();
|
|
1492
|
-
_render42 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
1493
|
-
label: "Autosuggest Countries",
|
|
1494
|
-
onChange: onChange,
|
|
1495
|
-
suggestions: callbackFunc
|
|
1496
|
-
})), getByText = _render42.getByText, getByRole = _render42.getByRole, queryByRole = _render42.queryByRole;
|
|
1497
|
-
input = getByRole("combobox");
|
|
1498
|
-
|
|
1499
|
-
_react2.fireEvent.focus(input);
|
|
1500
|
-
|
|
1501
|
-
_userEvent["default"].type(input, "Example text");
|
|
1502
|
-
|
|
1503
|
-
_context5.next = 8;
|
|
1504
|
-
return (0, _react2.waitForElementToBeRemoved)(function () {
|
|
1505
|
-
return getByText("Searching...");
|
|
1623
|
+
test("Asynchronous autosuggest closes the listbox after finishing no matches search", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee32() {
|
|
1624
|
+
var callbackFunc, onChange, _render49, getByText, getByRole, queryByRole, input;
|
|
1625
|
+
return _regenerator["default"].wrap(function _callee32$(_context32) {
|
|
1626
|
+
while (1) switch (_context32.prev = _context32.next) {
|
|
1627
|
+
case 0:
|
|
1628
|
+
callbackFunc = jest.fn(function (newValue) {
|
|
1629
|
+
var result = new Promise(function (resolve) {
|
|
1630
|
+
return setTimeout(function () {
|
|
1631
|
+
resolve(newValue ? countries.filter(function (option) {
|
|
1632
|
+
return option.toUpperCase().includes(newValue.toUpperCase());
|
|
1633
|
+
}) : countries);
|
|
1634
|
+
}, 100);
|
|
1506
1635
|
});
|
|
1507
|
-
|
|
1508
|
-
|
|
1509
|
-
|
|
1510
|
-
|
|
1511
|
-
|
|
1512
|
-
|
|
1513
|
-
|
|
1514
|
-
|
|
1636
|
+
return result;
|
|
1637
|
+
});
|
|
1638
|
+
onChange = jest.fn();
|
|
1639
|
+
_render49 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
1640
|
+
label: "Autosuggest Countries",
|
|
1641
|
+
onChange: onChange,
|
|
1642
|
+
suggestions: callbackFunc
|
|
1643
|
+
})), getByText = _render49.getByText, getByRole = _render49.getByRole, queryByRole = _render49.queryByRole;
|
|
1644
|
+
input = getByRole("combobox");
|
|
1645
|
+
_react2.fireEvent.focus(input);
|
|
1646
|
+
_context32.next = 7;
|
|
1647
|
+
return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee31() {
|
|
1648
|
+
return _regenerator["default"].wrap(function _callee31$(_context31) {
|
|
1649
|
+
while (1) switch (_context31.prev = _context31.next) {
|
|
1650
|
+
case 0:
|
|
1651
|
+
_userEvent["default"].type(input, "Example text");
|
|
1652
|
+
case 1:
|
|
1653
|
+
case "end":
|
|
1654
|
+
return _context31.stop();
|
|
1655
|
+
}
|
|
1656
|
+
}, _callee31);
|
|
1657
|
+
})));
|
|
1658
|
+
case 7:
|
|
1659
|
+
_context32.next = 9;
|
|
1660
|
+
return (0, _react2.waitForElementToBeRemoved)(function () {
|
|
1661
|
+
return getByText("Searching...");
|
|
1662
|
+
});
|
|
1663
|
+
case 9:
|
|
1664
|
+
expect(queryByRole("listbox")).toBeFalsy();
|
|
1665
|
+
case 10:
|
|
1666
|
+
case "end":
|
|
1667
|
+
return _context32.stop();
|
|
1515
1668
|
}
|
|
1516
|
-
},
|
|
1669
|
+
}, _callee32);
|
|
1517
1670
|
})));
|
|
1518
|
-
test("Asynchronous autosuggest with no matches founded doesn't let the listbox to be opened", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function
|
|
1519
|
-
var callbackFunc, onChange,
|
|
1520
|
-
|
|
1521
|
-
|
|
1522
|
-
|
|
1523
|
-
|
|
1524
|
-
|
|
1525
|
-
|
|
1526
|
-
|
|
1527
|
-
|
|
1528
|
-
|
|
1529
|
-
|
|
1530
|
-
}) : countries);
|
|
1531
|
-
}, 100);
|
|
1532
|
-
});
|
|
1533
|
-
return result;
|
|
1671
|
+
test("Asynchronous autosuggest with no matches founded doesn't let the listbox to be opened", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee33() {
|
|
1672
|
+
var callbackFunc, onChange, _render50, getByText, getByRole, queryByRole, input;
|
|
1673
|
+
return _regenerator["default"].wrap(function _callee33$(_context33) {
|
|
1674
|
+
while (1) switch (_context33.prev = _context33.next) {
|
|
1675
|
+
case 0:
|
|
1676
|
+
callbackFunc = jest.fn(function (newValue) {
|
|
1677
|
+
var result = new Promise(function (resolve) {
|
|
1678
|
+
return setTimeout(function () {
|
|
1679
|
+
resolve(newValue ? countries.filter(function (option) {
|
|
1680
|
+
return option.toUpperCase().includes(newValue.toUpperCase());
|
|
1681
|
+
}) : countries);
|
|
1682
|
+
}, 100);
|
|
1534
1683
|
});
|
|
1535
|
-
|
|
1536
|
-
|
|
1537
|
-
|
|
1538
|
-
|
|
1539
|
-
|
|
1540
|
-
|
|
1541
|
-
|
|
1542
|
-
|
|
1543
|
-
|
|
1544
|
-
|
|
1545
|
-
|
|
1546
|
-
|
|
1547
|
-
|
|
1548
|
-
return (
|
|
1549
|
-
|
|
1550
|
-
|
|
1551
|
-
|
|
1552
|
-
|
|
1553
|
-
|
|
1554
|
-
|
|
1555
|
-
|
|
1556
|
-
|
|
1557
|
-
|
|
1558
|
-
|
|
1559
|
-
|
|
1560
|
-
|
|
1561
|
-
|
|
1562
|
-
|
|
1563
|
-
|
|
1564
|
-
|
|
1565
|
-
|
|
1566
|
-
|
|
1567
|
-
|
|
1568
|
-
|
|
1569
|
-
|
|
1570
|
-
|
|
1571
|
-
keyCode: 40,
|
|
1572
|
-
charCode: 40
|
|
1573
|
-
});
|
|
1574
|
-
|
|
1575
|
-
expect(queryByRole("listbox")).toBeFalsy();
|
|
1576
|
-
|
|
1577
|
-
case 15:
|
|
1578
|
-
case "end":
|
|
1579
|
-
return _context6.stop();
|
|
1580
|
-
}
|
|
1684
|
+
return result;
|
|
1685
|
+
});
|
|
1686
|
+
onChange = jest.fn();
|
|
1687
|
+
_render50 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
1688
|
+
label: "Autosuggest Countries",
|
|
1689
|
+
onChange: onChange,
|
|
1690
|
+
suggestions: callbackFunc
|
|
1691
|
+
})), getByText = _render50.getByText, getByRole = _render50.getByRole, queryByRole = _render50.queryByRole;
|
|
1692
|
+
input = getByRole("combobox");
|
|
1693
|
+
_react2.fireEvent.focus(input);
|
|
1694
|
+
_userEvent["default"].type(input, "wrong");
|
|
1695
|
+
_context33.next = 8;
|
|
1696
|
+
return (0, _react2.waitForElementToBeRemoved)(function () {
|
|
1697
|
+
return getByText("Searching...");
|
|
1698
|
+
});
|
|
1699
|
+
case 8:
|
|
1700
|
+
expect(queryByRole("listbox")).toBeFalsy();
|
|
1701
|
+
_react2.fireEvent.focus(input);
|
|
1702
|
+
expect(queryByRole("listbox")).toBeFalsy();
|
|
1703
|
+
_react2.fireEvent.keyDown(input, {
|
|
1704
|
+
key: "ArrowUp",
|
|
1705
|
+
code: "ArrowUp",
|
|
1706
|
+
keyCode: 38,
|
|
1707
|
+
charCode: 38
|
|
1708
|
+
});
|
|
1709
|
+
expect(queryByRole("listbox")).toBeFalsy();
|
|
1710
|
+
_react2.fireEvent.keyDown(input, {
|
|
1711
|
+
key: "ArrowDown",
|
|
1712
|
+
code: "ArrowDown",
|
|
1713
|
+
keyCode: 40,
|
|
1714
|
+
charCode: 40
|
|
1715
|
+
});
|
|
1716
|
+
expect(queryByRole("listbox")).toBeFalsy();
|
|
1717
|
+
case 15:
|
|
1718
|
+
case "end":
|
|
1719
|
+
return _context33.stop();
|
|
1581
1720
|
}
|
|
1582
|
-
},
|
|
1721
|
+
}, _callee33);
|
|
1583
1722
|
})));
|
|
1584
|
-
test("Asynchronous autosuggest request failed, shows 'Error fetching data' message", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function
|
|
1585
|
-
var errorCallbackFunc, onChange,
|
|
1586
|
-
|
|
1587
|
-
|
|
1588
|
-
|
|
1589
|
-
|
|
1590
|
-
|
|
1591
|
-
|
|
1592
|
-
|
|
1593
|
-
|
|
1594
|
-
reject("err");
|
|
1595
|
-
}, 100);
|
|
1596
|
-
});
|
|
1597
|
-
return result;
|
|
1723
|
+
test("Asynchronous autosuggest request failed, shows 'Error fetching data' message", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee34() {
|
|
1724
|
+
var errorCallbackFunc, onChange, _render51, getByRole, getByText, input;
|
|
1725
|
+
return _regenerator["default"].wrap(function _callee34$(_context34) {
|
|
1726
|
+
while (1) switch (_context34.prev = _context34.next) {
|
|
1727
|
+
case 0:
|
|
1728
|
+
errorCallbackFunc = jest.fn(function () {
|
|
1729
|
+
var result = new Promise(function (resolve, reject) {
|
|
1730
|
+
return setTimeout(function () {
|
|
1731
|
+
reject("err");
|
|
1732
|
+
}, 100);
|
|
1598
1733
|
});
|
|
1599
|
-
|
|
1600
|
-
|
|
1601
|
-
|
|
1602
|
-
|
|
1603
|
-
|
|
1604
|
-
|
|
1605
|
-
|
|
1606
|
-
|
|
1607
|
-
|
|
1608
|
-
|
|
1609
|
-
|
|
1610
|
-
|
|
1611
|
-
|
|
1612
|
-
|
|
1613
|
-
|
|
1614
|
-
|
|
1615
|
-
|
|
1616
|
-
|
|
1617
|
-
|
|
1618
|
-
case "end":
|
|
1619
|
-
return _context7.stop();
|
|
1620
|
-
}
|
|
1734
|
+
return result;
|
|
1735
|
+
});
|
|
1736
|
+
onChange = jest.fn();
|
|
1737
|
+
_render51 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
1738
|
+
label: "Autosuggest Countries",
|
|
1739
|
+
onChange: onChange,
|
|
1740
|
+
suggestions: errorCallbackFunc
|
|
1741
|
+
})), getByRole = _render51.getByRole, getByText = _render51.getByText;
|
|
1742
|
+
input = getByRole("combobox");
|
|
1743
|
+
_react2.fireEvent.focus(input);
|
|
1744
|
+
_context34.next = 7;
|
|
1745
|
+
return (0, _react2.waitForElementToBeRemoved)(function () {
|
|
1746
|
+
return getByText("Searching...");
|
|
1747
|
+
});
|
|
1748
|
+
case 7:
|
|
1749
|
+
expect(getByText("Error fetching data")).toBeTruthy();
|
|
1750
|
+
case 8:
|
|
1751
|
+
case "end":
|
|
1752
|
+
return _context34.stop();
|
|
1621
1753
|
}
|
|
1622
|
-
},
|
|
1754
|
+
}, _callee34);
|
|
1623
1755
|
})));
|
|
1624
1756
|
});
|