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