@dxc-technology/halstack-react 7.0.0 → 9.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.
Files changed (109) hide show
  1. package/HalstackContext.js +98 -50
  2. package/accordion/Accordion.js +7 -13
  3. package/accordion/Accordion.stories.tsx +102 -13
  4. package/alert/Alert.stories.tsx +28 -0
  5. package/box/Box.js +1 -3
  6. package/box/Box.stories.tsx +15 -0
  7. package/button/Button.js +11 -13
  8. package/button/Button.stories.tsx +150 -8
  9. package/checkbox/Checkbox.d.ts +2 -2
  10. package/checkbox/Checkbox.js +16 -15
  11. package/checkbox/Checkbox.stories.tsx +131 -59
  12. package/checkbox/types.d.ts +4 -0
  13. package/chip/Chip.js +16 -22
  14. package/chip/Chip.stories.tsx +96 -9
  15. package/common/variables.js +286 -290
  16. package/date-input/Calendar.d.ts +4 -0
  17. package/date-input/Calendar.js +258 -0
  18. package/date-input/DateInput.js +134 -237
  19. package/date-input/DateInput.stories.tsx +199 -33
  20. package/date-input/DateInput.test.js +494 -138
  21. package/date-input/DatePicker.d.ts +4 -0
  22. package/date-input/DatePicker.js +146 -0
  23. package/date-input/Icons.d.ts +6 -0
  24. package/date-input/Icons.js +75 -0
  25. package/date-input/YearPicker.d.ts +4 -0
  26. package/date-input/YearPicker.js +126 -0
  27. package/date-input/types.d.ts +51 -0
  28. package/dialog/Dialog.js +60 -73
  29. package/dialog/Dialog.stories.tsx +211 -159
  30. package/dialog/Dialog.test.js +301 -2
  31. package/dropdown/Dropdown.js +35 -35
  32. package/dropdown/Dropdown.stories.tsx +210 -84
  33. package/dropdown/Dropdown.test.js +17 -22
  34. package/dropdown/DropdownMenu.js +8 -18
  35. package/dropdown/DropdownMenuItem.js +4 -15
  36. package/file-input/FileInput.d.ts +2 -2
  37. package/file-input/FileInput.js +169 -222
  38. package/file-input/FileInput.stories.tsx +122 -11
  39. package/file-input/FileInput.test.js +12 -53
  40. package/file-input/FileItem.d.ts +4 -14
  41. package/file-input/FileItem.js +39 -63
  42. package/file-input/types.d.ts +17 -0
  43. package/footer/Footer.stories.tsx +91 -0
  44. package/header/Header.js +18 -20
  45. package/header/Header.stories.tsx +149 -6
  46. package/link/Link.js +1 -1
  47. package/link/Link.stories.tsx +60 -0
  48. package/main.d.ts +1 -1
  49. package/main.js +1 -1
  50. package/{tabs-nav → nav-tabs}/NavTabs.js +1 -1
  51. package/{tabs-nav → nav-tabs}/NavTabs.stories.tsx +96 -6
  52. package/{tabs-nav → nav-tabs}/Tab.js +35 -15
  53. package/number-input/NumberInput.test.js +5 -6
  54. package/package.json +7 -12
  55. package/paginator/Icons.d.ts +5 -0
  56. package/paginator/Icons.js +16 -28
  57. package/paginator/Paginator.js +5 -11
  58. package/paginator/Paginator.stories.tsx +24 -0
  59. package/paginator/Paginator.test.js +17 -10
  60. package/progress-bar/ProgressBar.js +4 -4
  61. package/progress-bar/ProgressBar.stories.jsx +35 -2
  62. package/quick-nav/QuickNav.stories.tsx +14 -0
  63. package/radio-group/RadioGroup.stories.tsx +131 -18
  64. package/resultsetTable/Icons.d.ts +7 -0
  65. package/resultsetTable/Icons.js +51 -0
  66. package/resultsetTable/ResultsetTable.js +48 -105
  67. package/resultsetTable/ResultsetTable.stories.tsx +50 -25
  68. package/resultsetTable/ResultsetTable.test.js +40 -63
  69. package/resultsetTable/types.d.ts +2 -2
  70. package/select/Listbox.d.ts +1 -1
  71. package/select/Listbox.js +5 -34
  72. package/select/Option.js +11 -24
  73. package/select/Select.js +43 -24
  74. package/select/Select.stories.tsx +494 -150
  75. package/select/Select.test.js +17 -22
  76. package/select/types.d.ts +2 -2
  77. package/sidenav/Sidenav.js +8 -10
  78. package/sidenav/Sidenav.stories.tsx +148 -46
  79. package/slider/Slider.d.ts +2 -2
  80. package/slider/Slider.js +9 -8
  81. package/slider/Slider.stories.tsx +57 -0
  82. package/slider/types.d.ts +4 -0
  83. package/spinner/Spinner.js +2 -2
  84. package/spinner/Spinner.stories.jsx +27 -1
  85. package/switch/Switch.d.ts +3 -3
  86. package/switch/Switch.js +5 -4
  87. package/switch/Switch.stories.tsx +33 -0
  88. package/switch/types.d.ts +6 -1
  89. package/table/Table.stories.jsx +80 -1
  90. package/table/Table.test.js +1 -1
  91. package/tabs/Tab.js +3 -5
  92. package/tabs/Tabs.js +3 -3
  93. package/tabs/Tabs.stories.tsx +45 -5
  94. package/tag/Tag.stories.tsx +14 -1
  95. package/text-input/Suggestion.js +32 -5
  96. package/text-input/TextInput.js +7 -11
  97. package/text-input/TextInput.stories.tsx +92 -4
  98. package/text-input/TextInput.test.js +587 -634
  99. package/textarea/Textarea.stories.jsx +60 -1
  100. package/toggle-group/ToggleGroup.stories.tsx +42 -0
  101. package/utils/FocusLock.d.ts +13 -0
  102. package/utils/FocusLock.js +139 -0
  103. package/wizard/Wizard.stories.tsx +20 -0
  104. package/common/RequiredComponent.js +0 -32
  105. /package/{tabs-nav → nav-tabs}/NavTabs.d.ts +0 -0
  106. /package/{tabs-nav → nav-tabs}/NavTabs.test.js +0 -0
  107. /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
  108. /package/{tabs-nav → nav-tabs}/types.d.ts +0 -0
  109. /package/{tabs-nav → nav-tabs}/types.js +0 -0
@@ -2,14 +2,62 @@
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
4
 
5
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
6
+
7
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
8
+
9
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
10
+
11
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
12
+
5
13
  var _react = _interopRequireDefault(require("react"));
6
14
 
7
15
  var _react2 = require("@testing-library/react");
8
16
 
9
17
  var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
10
18
 
11
- var _DateInput = _interopRequireDefault(require("./DateInput"));
12
-
19
+ var _dayjs = _interopRequireDefault(require("dayjs"));
20
+
21
+ var _DateInput = _interopRequireDefault(require("./DateInput.tsx"));
22
+
23
+ // Mocking DOMRect for Radix Primitive Popover
24
+ global.globalThis = global;
25
+
26
+ global.ResizeObserver = /*#__PURE__*/function () {
27
+ function ResizeObserver(cb) {
28
+ (0, _classCallCheck2["default"])(this, ResizeObserver);
29
+ this.cb = cb;
30
+ }
31
+
32
+ (0, _createClass2["default"])(ResizeObserver, [{
33
+ key: "observe",
34
+ value: function observe() {
35
+ this.cb([{
36
+ borderBoxSize: {
37
+ inlineSize: 0,
38
+ blockSize: 0
39
+ }
40
+ }]);
41
+ }
42
+ }, {
43
+ key: "unobserve",
44
+ value: function unobserve() {}
45
+ }]);
46
+ return ResizeObserver;
47
+ }();
48
+
49
+ global.DOMRect = {
50
+ fromRect: function fromRect() {
51
+ return {
52
+ top: 0,
53
+ left: 0,
54
+ bottom: 0,
55
+ right: 0,
56
+ width: 0,
57
+ height: 0
58
+ };
59
+ }
60
+ };
13
61
  describe("DateInput component tests", function () {
14
62
  test("Renders with correct label, helper text, optional, placeholder and clearable action", function () {
15
63
  var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
@@ -55,115 +103,161 @@ describe("DateInput component tests", function () {
55
103
  getByRole = _render3.getByRole;
56
104
 
57
105
  var input = getByRole("textbox");
58
- var calendarAction = getByRole("button");
59
- var d = new Date(2015, 9, 21);
60
- var options = {
61
- weekday: "short",
62
- month: "short",
63
- day: "numeric"
64
- };
106
+ var calendarAction = getByRole("combobox");
65
107
  expect(input.value).toBe("21-10-2015");
66
108
 
67
109
  _userEvent["default"].click(calendarAction);
68
110
 
69
- expect(getByText(d.toLocaleString("en-US", options))).toBeTruthy();
70
- });
71
- test("Renders with correct format: user typed date but it's invalid, onBlur error", function () {
72
- var onBlur = jest.fn(function (_ref) {
73
- var value = _ref.value,
74
- error = _ref.error;
75
- expect(value).toBe("10/90/2010");
76
- expect(error).toBe("Invalid date.");
77
- });
78
-
79
- var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
80
- label: "With format MM/dd/yyyy",
81
- format: "MM/dd/yyyy",
82
- onBlur: onBlur
83
- })),
84
- getByRole = _render4.getByRole;
85
-
86
- var input = getByRole("textbox");
87
-
88
- _userEvent["default"].type(input, "10/90/2010");
89
-
90
- _react2.fireEvent.blur(input);
91
- });
92
- test("Renders with correct format: user typed date but it's invalid, onChange error", function () {
93
- var onChange = jest.fn();
94
-
95
- var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
96
- label: "With format MM/dd/yyyy",
97
- format: "MM/dd/yyyy",
98
- onChange: onChange
99
- })),
100
- getByRole = _render5.getByRole;
101
-
102
- var input = getByRole("textbox");
103
-
104
- _userEvent["default"].type(input, "10/90/2010");
105
-
106
- expect(onChange).toHaveBeenCalledTimes(10);
107
- expect(onChange).toHaveBeenCalledWith({
108
- value: "10/90/2010",
109
- error: "Invalid date."
110
- });
111
+ expect(getByText("21").getAttribute("aria-selected")).toBe("true");
112
+ expect(getByText("October 2015")).toBeTruthy();
111
113
  });
114
+ test("Renders with correct format: user typed date but it's invalid, onBlur error", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
115
+ var onBlur, _render4, getByRole, input;
116
+
117
+ return _regenerator["default"].wrap(function _callee$(_context) {
118
+ while (1) {
119
+ switch (_context.prev = _context.next) {
120
+ case 0:
121
+ onBlur = jest.fn(function (_ref2) {
122
+ var value = _ref2.value,
123
+ error = _ref2.error;
124
+ expect(value).toBe("10/90/2010");
125
+ expect(error).toBe("Invalid date.");
126
+ });
127
+ _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
128
+ label: "With format MM/dd/yyyy",
129
+ format: "MM/dd/yyyy",
130
+ onBlur: onBlur
131
+ })), getByRole = _render4.getByRole;
132
+ input = getByRole("textbox");
133
+
134
+ _userEvent["default"].click(input);
135
+
136
+ _context.next = 6;
137
+ return _userEvent["default"].keyboard("10");
138
+
139
+ case 6:
140
+ _context.next = 8;
141
+ return _userEvent["default"].keyboard("/");
142
+
143
+ case 8:
144
+ _context.next = 10;
145
+ return _userEvent["default"].keyboard("90");
146
+
147
+ case 10:
148
+ _context.next = 12;
149
+ return _userEvent["default"].keyboard("/");
150
+
151
+ case 12:
152
+ _context.next = 14;
153
+ return _userEvent["default"].keyboard("2010");
154
+
155
+ case 14:
156
+ _react2.fireEvent.blur(input);
157
+
158
+ case 15:
159
+ case "end":
160
+ return _context.stop();
161
+ }
162
+ }
163
+ }, _callee);
164
+ })));
165
+ test("Renders with correct format: user typed date but it's invalid, onChange error", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
166
+ var onChange, _render5, getByRole, input;
167
+
168
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
169
+ while (1) {
170
+ switch (_context2.prev = _context2.next) {
171
+ case 0:
172
+ onChange = jest.fn();
173
+ _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
174
+ label: "With format MM/dd/yyyy",
175
+ format: "MM/dd/yyyy",
176
+ onChange: onChange
177
+ })), getByRole = _render5.getByRole;
178
+ input = getByRole("textbox");
179
+
180
+ _userEvent["default"].click(input);
181
+
182
+ _context2.next = 6;
183
+ return _userEvent["default"].keyboard("10");
184
+
185
+ case 6:
186
+ _context2.next = 8;
187
+ return _userEvent["default"].keyboard("/");
188
+
189
+ case 8:
190
+ _context2.next = 10;
191
+ return _userEvent["default"].keyboard("90");
192
+
193
+ case 10:
194
+ _context2.next = 12;
195
+ return _userEvent["default"].keyboard("/");
196
+
197
+ case 12:
198
+ _context2.next = 14;
199
+ return _userEvent["default"].keyboard("2010");
200
+
201
+ case 14:
202
+ expect(onChange).toHaveBeenCalledTimes(10);
203
+ expect(onChange).toHaveBeenCalledWith({
204
+ value: "10/90/2010",
205
+ error: "Invalid date."
206
+ });
207
+
208
+ case 16:
209
+ case "end":
210
+ return _context2.stop();
211
+ }
212
+ }
213
+ }, _callee2);
214
+ })));
112
215
  test("Calendar renders with correct date: today's date", function () {
113
216
  var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], null)),
114
217
  getByText = _render6.getByText,
115
- getByRole = _render6.getByRole;
218
+ getByRole = _render6.getByRole,
219
+ getAllByText = _render6.getAllByText;
116
220
 
117
- var calendarAction = getByRole("button");
118
- var d = new Date();
119
- var options = {
120
- weekday: "short",
121
- month: "short",
122
- day: "numeric"
123
- };
221
+ var calendarAction = getByRole("combobox");
222
+ var d = (0, _dayjs["default"])();
124
223
 
125
224
  _userEvent["default"].click(calendarAction);
126
225
 
127
- expect(getByText(d.toLocaleString("en-US", options))).toBeTruthy();
226
+ expect(document.activeElement === getAllByText(d.get("date")).length === 2 && +d.get("date") > 20 ? getAllByText(d.get("date"))[1] : getAllByText(d.get("date"))[0]).toBeTruthy();
227
+ expect(getByText(d.format("MMMM YYYY"))).toBeTruthy();
128
228
  });
129
229
  test("Calendar renders with correct date: value prop", function () {
130
230
  var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
131
231
  value: "20-10-2019"
132
232
  })),
133
233
  getByText = _render7.getByText,
134
- getByRole = _render7.getByRole;
234
+ getByRole = _render7.getByRole,
235
+ getAllByText = _render7.getAllByText;
135
236
 
136
- var calendarAction = getByRole("button");
137
- var d = new Date(2019, 9, 20);
138
- var options = {
139
- weekday: "short",
140
- month: "short",
141
- day: "numeric"
142
- };
237
+ var calendarAction = getByRole("combobox");
238
+ var d = (0, _dayjs["default"])("2019-10-20");
143
239
 
144
240
  _userEvent["default"].click(calendarAction);
145
241
 
146
- expect(getByText(d.toLocaleString("en-US", options))).toBeTruthy();
242
+ expect(getAllByText(d.get("date"))[0].getAttribute("aria-selected")).toBe("true");
243
+ expect(getByText(d.format("MMMM YYYY"))).toBeTruthy();
147
244
  });
148
245
  test("Calendar renders with correct date: user typed value", function () {
149
246
  var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], null)),
150
247
  getByText = _render8.getByText,
151
- getByRole = _render8.getByRole;
248
+ getByRole = _render8.getByRole,
249
+ getAllByText = _render8.getAllByText;
152
250
 
153
- var calendarAction = getByRole("button");
154
- var d = new Date(2010, 0, 1);
155
- var options = {
156
- weekday: "short",
157
- month: "short",
158
- day: "numeric"
159
- };
251
+ var calendarAction = getByRole("combobox");
252
+ var d = (0, _dayjs["default"])("2010-1-1");
160
253
  var input = getByRole("textbox");
161
254
 
162
255
  _userEvent["default"].type(input, "01-01-2010");
163
256
 
164
257
  _userEvent["default"].click(calendarAction);
165
258
 
166
- expect(getByText(d.toLocaleString("en-US", options))).toBeTruthy();
259
+ expect(getAllByText(d.get("date"))[0].getAttribute("aria-selected")).toBe("true");
260
+ expect(getByText(d.format("MMMM YYYY"))).toBeTruthy();
167
261
  });
168
262
  test("Calendar renders with correct date: invalid date, renders with today's date", function () {
169
263
  var onBlur = jest.fn();
@@ -172,15 +266,11 @@ describe("DateInput component tests", function () {
172
266
  onBlur: onBlur
173
267
  })),
174
268
  getByText = _render9.getByText,
175
- getByRole = _render9.getByRole;
269
+ getByRole = _render9.getByRole,
270
+ getAllByText = _render9.getAllByText;
176
271
 
177
- var calendarAction = getByRole("button");
178
- var d = new Date();
179
- var options = {
180
- weekday: "short",
181
- month: "short",
182
- day: "numeric"
183
- };
272
+ var calendarAction = getByRole("combobox");
273
+ var d = (0, _dayjs["default"])();
184
274
  var input = getByRole("textbox");
185
275
 
186
276
  _userEvent["default"].type(input, "01-01-xxxx");
@@ -195,100 +285,295 @@ describe("DateInput component tests", function () {
195
285
 
196
286
  _userEvent["default"].click(calendarAction);
197
287
 
198
- expect(getByText(d.toLocaleString("en-US", options))).toBeTruthy();
288
+ expect(document.activeElement === getAllByText(d.get("date")).length === 2 && +d.get("date") > 20 ? getAllByText(d.get("date"))[1] : getAllByText(d.get("date"))[0]).toBeTruthy();
289
+ expect(getByText(d.format("MMMM YYYY"))).toBeTruthy();
199
290
  });
200
291
  test("Selecting a date from the calendar with an specific format", function () {
201
292
  var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
202
293
  label: "With format M-dd-yyyy",
203
294
  format: "M-dd-yyyy"
204
295
  })),
296
+ getAllByText = _render10.getAllByText,
205
297
  getByText = _render10.getByText,
206
298
  getByRole = _render10.getByRole;
207
299
 
208
300
  var input = getByRole("textbox");
209
- var calendarAction = getByRole("button");
301
+ var calendarAction = getByRole("combobox");
210
302
 
211
303
  _userEvent["default"].click(calendarAction);
212
304
 
213
- var dayButton = getByText("10").closest("button");
305
+ var dayButton = getAllByText("10")[0].closest("button");
214
306
 
215
307
  _react2.fireEvent.click(dayButton);
216
308
 
217
- var d = new Date();
218
- d.setDate(10);
219
- var options = {
220
- weekday: "short",
221
- month: "short",
222
- day: "numeric"
223
- };
224
- expect(getByText(d.toLocaleString("en-US", options))).toBeTruthy();
309
+ var d = (0, _dayjs["default"])();
310
+ d = d.set("date", 10);
311
+ expect(getAllByText(d.get("date"))[0].getAttribute("aria-selected")).toBe("true");
312
+ expect(getByText(d.format("MMMM YYYY"))).toBeTruthy();
313
+
314
+ _react2.fireEvent.keyDown(document, {
315
+ key: "Escape",
316
+ code: "Escape",
317
+ keyCode: 27,
318
+ charCode: 27
319
+ });
320
+
321
+ expect(input.value).toBe(d.format("M-DD-YYYY"));
322
+ });
323
+ test("Changing months using the arrows", function () {
324
+ var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
325
+ label: "label",
326
+ format: "dd-mm-yyyy",
327
+ defaultValue: "10-10-2000"
328
+ })),
329
+ getByText = _render11.getByText,
330
+ getByRole = _render11.getByRole,
331
+ getByTitle = _render11.getByTitle;
332
+
333
+ var calendarAction = getByRole("combobox");
334
+
335
+ _userEvent["default"].click(calendarAction);
336
+
337
+ var d = (0, _dayjs["default"])("10-10-2000", "DD-MM-YYYY", true);
338
+ d = d.set("date", 10);
339
+ expect(getByText(d.format("MMMM YYYY"))).toBeTruthy();
340
+ var previousMonth = getByTitle("Previous month");
341
+
342
+ _userEvent["default"].click(previousMonth);
343
+
344
+ expect(getByText(d.set("month", d.get("month") - 1).format("MMMM YYYY"))).toBeTruthy();
345
+ var nextMonth = getByTitle("Next month");
346
+
347
+ _userEvent["default"].click(nextMonth);
348
+
349
+ expect(getByText(d.format("MMMM YYYY"))).toBeTruthy();
350
+ });
351
+ test("Selecting a date from the calendar from another month", function () {
352
+ var _render12 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
353
+ format: "dd-mm-yyyy",
354
+ defaultValue: "10-08-2021"
355
+ })),
356
+ getAllByText = _render12.getAllByText,
357
+ getByText = _render12.getByText,
358
+ getByRole = _render12.getByRole;
359
+
360
+ var input = getByRole("textbox");
361
+ var calendarAction = getByRole("combobox");
362
+
363
+ _userEvent["default"].click(calendarAction);
364
+
365
+ var dayButton = getAllByText("31")[0].closest("button");
366
+
367
+ _react2.fireEvent.click(dayButton);
368
+
369
+ var d = (0, _dayjs["default"])("10-08-2021", "DD-MM-YYYY", true);
370
+ d = d.set("date", 31).set("month", 6);
371
+ expect(getAllByText(d.get("date"))[0].getAttribute("aria-selected")).toBe("true");
372
+ expect(getByText(d.format("MMMM YYYY"))).toBeTruthy();
225
373
 
226
374
  _react2.fireEvent.keyDown(document, {
227
- key: "Esc",
228
- code: "Esc",
375
+ key: "Escape",
376
+ code: "Escape",
229
377
  keyCode: 27,
230
378
  charCode: 27
231
379
  });
232
380
 
233
- expect(input.value).toBe("".concat(d.getMonth() + 1, "-10-").concat(d.getFullYear()));
381
+ expect(input.value).toBe(d.format("DD-MM-YYYY"));
382
+ });
383
+ test("Selecting a year from the calendar year picker", function () {
384
+ var _render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
385
+ format: "dd-mm-yyyy",
386
+ defaultValue: "10-08-2021"
387
+ })),
388
+ getByText = _render13.getByText,
389
+ getByRole = _render13.getByRole;
390
+
391
+ var input = getByRole("textbox");
392
+ var calendarAction = getByRole("combobox");
393
+
394
+ _userEvent["default"].click(calendarAction);
395
+
396
+ var d = (0, _dayjs["default"])("10-08-2021", "DD-MM-YYYY", true);
397
+
398
+ _userEvent["default"].click(getByText(d.format("MMMM YYYY")));
399
+
400
+ expect(getByText("2024")).toBeTruthy();
401
+
402
+ _userEvent["default"].click(getByText("2024"));
403
+
404
+ _userEvent["default"].click(getByText(d.set("year", 2024).format("MMMM YYYY")));
405
+
406
+ _react2.fireEvent.keyDown(document, {
407
+ key: "Escape",
408
+ code: "Escape",
409
+ keyCode: 27,
410
+ charCode: 27
411
+ });
412
+
413
+ expect(input.value).toBe(d.format("DD-MM-YYYY"));
234
414
  });
235
415
  test("Selecting a date from the calendar (using keyboard presses)", function () {
236
- var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], null)),
237
- getByRole = _render11.getByRole;
416
+ var _render14 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], null)),
417
+ getByRole = _render14.getByRole,
418
+ getAllByText = _render14.getAllByText,
419
+ getByText = _render14.getByText;
238
420
 
239
- var calendarAction = getByRole("button");
421
+ var calendarAction = getByRole("combobox");
240
422
  var input = getByRole("textbox");
241
423
 
242
424
  _userEvent["default"].type(input, "01-01-2010");
243
425
 
426
+ expect(input.value).toBe("01-01-2010");
427
+
244
428
  _userEvent["default"].click(calendarAction);
245
429
 
246
- _react2.fireEvent.keyDown(document, {
430
+ expect(document.activeElement === getAllByText("1")[0].closest("button")).toBeTruthy();
431
+
432
+ _react2.fireEvent.keyDown(getAllByText("1")[0].closest("button"), {
247
433
  key: "ArrowRight",
248
434
  code: "ArrowRight",
249
435
  keyCode: 39,
250
436
  charCode: 39
251
437
  });
252
438
 
253
- _react2.fireEvent.keyDown(document, {
254
- key: "ArrowRight",
255
- code: "ArrowRight",
256
- keyCode: 39,
257
- charCode: 39
439
+ expect(document.activeElement === getAllByText("2")[0].closest("button")).toBeTruthy();
440
+
441
+ _react2.fireEvent.keyDown(getAllByText("2")[0].closest("button"), {
442
+ key: "PageUp",
443
+ code: "PageUp",
444
+ keyCode: 33,
445
+ charCode: 33
258
446
  });
259
447
 
260
- _react2.fireEvent.keyDown(document, {
261
- key: "ArrowRight",
262
- code: "ArrowRight",
263
- keyCode: 39,
264
- charCode: 39
448
+ expect(document.activeElement === getAllByText("2")[0].closest("button")).toBeTruthy();
449
+ expect(getByText("December 2009")).toBeTruthy();
450
+
451
+ _react2.fireEvent.keyDown(getAllByText("2")[0].closest("button"), {
452
+ key: "PageDown",
453
+ code: "PageDown",
454
+ keyCode: 34,
455
+ charCode: 34
265
456
  });
266
457
 
267
- _react2.fireEvent.keyDown(document, {
268
- key: "ArrowLeft",
269
- code: "ArrowLeft",
270
- keyCode: 37,
271
- charCode: 37
458
+ expect(document.activeElement === getAllByText("2")[0].closest("button")).toBeTruthy();
459
+ expect(getByText("January 2010")).toBeTruthy();
460
+
461
+ _react2.fireEvent.keyDown(getAllByText("2")[0].closest("button"), {
462
+ key: "PageDown",
463
+ code: "PageDown",
464
+ keyCode: 34,
465
+ charCode: 34,
466
+ shiftKey: true
467
+ });
468
+
469
+ expect(getByText("January 2011")).toBeTruthy();
470
+
471
+ _react2.fireEvent.keyDown(getAllByText("2")[0].closest("button"), {
472
+ key: "PageUp",
473
+ code: "PageUp",
474
+ keyCode: 33,
475
+ charCode: 33,
476
+ shiftKey: true
477
+ });
478
+
479
+ expect(getByText("January 2010")).toBeTruthy();
480
+ expect(document.activeElement === getAllByText("2")[0].closest("button")).toBeTruthy();
481
+
482
+ _react2.fireEvent.click(getAllByText("2")[0].closest("button"), {
483
+ key: " ",
484
+ code: "Space",
485
+ keyCode: 32,
486
+ charCode: 32
272
487
  });
273
488
 
489
+ expect(getAllByText("2")[0].closest("button").getAttribute("aria-selected")).toBe("true");
490
+
274
491
  _react2.fireEvent.keyDown(document, {
275
- key: "Esc",
276
- code: "Esc",
492
+ key: "Escape",
493
+ code: "Escape",
277
494
  keyCode: 27,
278
495
  charCode: 27
279
496
  });
280
497
 
281
- expect(input.value).toBe("03-01-2010");
498
+ expect(input.value).toBe("02-01-2010");
499
+ });
500
+ test("Selecting a date from the calendar (using keyboard presses) part II", function () {
501
+ var _render15 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], null)),
502
+ getByRole = _render15.getByRole,
503
+ getAllByText = _render15.getAllByText;
504
+
505
+ var calendarAction = getByRole("combobox");
506
+ var input = getByRole("textbox");
507
+
508
+ _userEvent["default"].type(input, "01-01-2010");
509
+
510
+ expect(input.value).toBe("01-01-2010");
511
+
512
+ _userEvent["default"].click(calendarAction);
513
+
514
+ expect(document.activeElement === getAllByText("1")[0].closest("button")).toBeTruthy();
515
+
516
+ _react2.fireEvent.keyDown(getAllByText("1")[0].closest("button"), {
517
+ key: "ArrowDown",
518
+ code: "ArrowDown",
519
+ keyCode: 40,
520
+ charCode: 40
521
+ });
522
+
523
+ expect(document.activeElement === getAllByText("8")[0].closest("button")).toBeTruthy();
524
+
525
+ _react2.fireEvent.keyDown(getAllByText("8")[0].closest("button"), {
526
+ key: "ArrowDown",
527
+ code: "ArrowDown",
528
+ keyCode: 40,
529
+ charCode: 40
530
+ });
531
+
532
+ expect(document.activeElement === getAllByText("15")[0].closest("button")).toBeTruthy();
533
+
534
+ _react2.fireEvent.keyDown(getAllByText("15")[0].closest("button"), {
535
+ key: "ArrowUp",
536
+ code: "ArrowUp",
537
+ keyCode: 38,
538
+ charCode: 38
539
+ });
540
+
541
+ expect(document.activeElement === getAllByText("8")[0].closest("button")).toBeTruthy();
542
+
543
+ _react2.fireEvent.keyDown(getAllByText("8")[0].closest("button"), {
544
+ key: "End",
545
+ code: "End",
546
+ keyCode: 35,
547
+ charCode: 35
548
+ });
549
+
550
+ expect(document.activeElement === getAllByText("10")[0].closest("button")).toBeTruthy();
551
+
552
+ _react2.fireEvent.keyDown(getAllByText("10")[0].closest("button"), {
553
+ key: "Home",
554
+ code: "Home",
555
+ keyCode: 36,
556
+ charCode: 36
557
+ });
558
+
559
+ _react2.fireEvent.keyDown(getAllByText("10")[0].closest("button"), {
560
+ key: " ",
561
+ code: "Space",
562
+ keyCode: 32,
563
+ charCode: 32
564
+ });
565
+
566
+ expect(input.value).toBe("10-01-2010");
282
567
  });
283
568
  test("onChange & onBlur functions are called correctly", function () {
284
569
  var onBlur = jest.fn();
285
570
  var onChange = jest.fn();
286
571
 
287
- var _render12 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
572
+ var _render16 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
288
573
  onChange: onChange,
289
574
  onBlur: onBlur
290
575
  })),
291
- getByRole = _render12.getByRole;
576
+ getByRole = _render16.getByRole;
292
577
 
293
578
  var input = getByRole("textbox");
294
579
  var d = new Date(2011, 9, 10);
@@ -314,11 +599,11 @@ describe("DateInput component tests", function () {
314
599
  var onBlur = jest.fn();
315
600
  var onChange = jest.fn();
316
601
 
317
- var _render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
602
+ var _render17 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
318
603
  onChange: onChange,
319
604
  onBlur: onBlur
320
605
  })),
321
- getByRole = _render13.getByRole;
606
+ getByRole = _render17.getByRole;
322
607
 
323
608
  var input = getByRole("textbox");
324
609
 
@@ -342,10 +627,10 @@ describe("DateInput component tests", function () {
342
627
  test("onBlur function removes the error when it is fixed", function () {
343
628
  var onBlur = jest.fn();
344
629
 
345
- var _render14 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
630
+ var _render18 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
346
631
  onBlur: onBlur
347
632
  })),
348
- getByRole = _render14.getByRole;
633
+ getByRole = _render18.getByRole;
349
634
 
350
635
  var input = getByRole("textbox");
351
636
  var d = new Date(2002, 1, 20);
@@ -379,11 +664,11 @@ describe("DateInput component tests", function () {
379
664
  test("onBlur function removes the error when the input is empty", function () {
380
665
  var onBlur = jest.fn();
381
666
 
382
- var _render15 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
667
+ var _render19 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
383
668
  onBlur: onBlur,
384
669
  optional: true
385
670
  })),
386
- getByRole = _render15.getByRole;
671
+ getByRole = _render19.getByRole;
387
672
 
388
673
  var input = getByRole("textbox");
389
674
 
@@ -412,11 +697,11 @@ describe("DateInput component tests", function () {
412
697
  var onBlur = jest.fn();
413
698
  var onChange = jest.fn();
414
699
 
415
- var _render16 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
700
+ var _render20 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
416
701
  onBlur: onBlur,
417
702
  onChange: onChange
418
703
  })),
419
- getByRole = _render16.getByRole;
704
+ getByRole = _render20.getByRole;
420
705
 
421
706
  var date = getByRole("textbox");
422
707
 
@@ -440,11 +725,11 @@ describe("DateInput component tests", function () {
440
725
  });
441
726
  });
442
727
  test("Disabled date input (calendar action must be shown but not clickable)", function () {
443
- var _render17 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
728
+ var _render21 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
444
729
  disabled: true
445
730
  })),
446
- getByRole = _render17.getByRole,
447
- queryByText = _render17.queryByText;
731
+ getByRole = _render21.getByRole,
732
+ queryByText = _render21.queryByText;
448
733
 
449
734
  var calendarAction = getByRole("button");
450
735
  var d = new Date();
@@ -460,20 +745,91 @@ describe("DateInput component tests", function () {
460
745
  expect(queryByText(d.toLocaleString("en-US", options))).toBeFalsy();
461
746
  });
462
747
  test("Input has correct accesibility attributes", function () {
463
- var _render18 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
748
+ var _render22 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
464
749
  label: "Date input label"
465
750
  })),
466
- getByRole = _render18.getByRole;
751
+ getByRole = _render22.getByRole;
467
752
 
468
753
  var input = getByRole("textbox");
469
754
  expect(input.getAttribute("aria-autocomplete")).toBeNull();
470
755
  expect(input.getAttribute("aria-controls")).toBeNull();
471
756
  expect(input.getAttribute("aria-expanded")).toBeNull();
472
- var calendarAction = getByRole("button");
757
+ var calendarAction = getByRole("combobox");
758
+ expect(calendarAction.getAttribute("aria-autocomplete")).toBeNull();
759
+ expect(calendarAction.getAttribute("aria-controls")).toBeTruthy();
760
+ expect(calendarAction.getAttribute("aria-describedby")).toBeTruthy();
761
+ expect(calendarAction.getAttribute("aria-describedby") === calendarAction.getAttribute("aria-controls")).toBeTruthy();
762
+ expect(calendarAction.getAttribute("aria-expanded")).toBe("false");
473
763
 
474
764
  _userEvent["default"].click(calendarAction);
475
765
 
476
766
  var datePicker = getByRole("dialog");
477
767
  expect(datePicker.getAttribute("aria-modal")).toBe("true");
768
+ expect(calendarAction.getAttribute("aria-expanded")).toBe("true");
769
+ expect(document.getElementById(calendarAction.getAttribute("aria-describedby"))).toBeTruthy();
770
+
771
+ _react2.fireEvent.keyDown(document, {
772
+ key: "Escape",
773
+ code: "Escape",
774
+ keyCode: 27,
775
+ charCode: 27
776
+ });
777
+
778
+ expect(calendarAction.getAttribute("aria-expanded")).toBe("false");
779
+ });
780
+ test("Chooses the correct year when two digit format", function () {
781
+ var _render23 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
782
+ label: "Default label",
783
+ placeholder: "Placeholder",
784
+ format: "dd-mm-yy",
785
+ defaultValue: "21-10-80"
786
+ })),
787
+ getByText = _render23.getByText,
788
+ getByRole = _render23.getByRole,
789
+ getAllByText = _render23.getAllByText;
790
+
791
+ var input = getByRole("textbox");
792
+ var calendarAction = getByRole("combobox");
793
+ expect(input.value).toBe("21-10-80");
794
+
795
+ _userEvent["default"].click(calendarAction);
796
+
797
+ expect(getByText("21").getAttribute("aria-selected")).toBe("true");
798
+ expect(getByText("October 1980")).toBeTruthy();
799
+
800
+ _react2.fireEvent.keyDown(document, {
801
+ key: "Escape",
802
+ code: "Escape",
803
+ keyCode: 27,
804
+ charCode: 27
805
+ });
806
+
807
+ _react2.fireEvent.change(input, {
808
+ target: {
809
+ value: "21-10-10"
810
+ }
811
+ });
812
+
813
+ _userEvent["default"].click(calendarAction);
814
+
815
+ expect(getByText("October 1910")).toBeTruthy();
816
+
817
+ _userEvent["default"].click(getByText("October 1910"));
818
+
819
+ _userEvent["default"].click(getByText("2010"));
820
+
821
+ _userEvent["default"].click(getAllByText("1")[0]);
822
+
823
+ expect(input.value).toBe("01-10-10");
824
+
825
+ _react2.fireEvent.change(input, {
826
+ target: {
827
+ value: "21-10-80"
828
+ }
829
+ });
830
+
831
+ _userEvent["default"].click(calendarAction);
832
+
833
+ expect(getByText("October 2080")).toBeTruthy();
478
834
  });
479
835
  });