@dxc-technology/halstack-react 0.0.0-910214a → 0.0.0-918d2c8

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 (195) hide show
  1. package/HalstackContext.js +90 -50
  2. package/accordion/Accordion.js +117 -104
  3. package/accordion/Accordion.stories.tsx +104 -16
  4. package/accordion/Accordion.test.js +9 -10
  5. package/accordion/types.d.ts +5 -4
  6. package/accordion-group/AccordionGroup.js +2 -21
  7. package/accordion-group/AccordionGroup.stories.tsx +27 -1
  8. package/accordion-group/AccordionGroup.test.js +20 -45
  9. package/accordion-group/types.d.ts +10 -3
  10. package/alert/Alert.js +1 -1
  11. package/alert/Alert.stories.tsx +28 -0
  12. package/bleed/Bleed.stories.tsx +63 -63
  13. package/box/Box.js +1 -1
  14. package/box/Box.stories.tsx +15 -0
  15. package/box/types.d.ts +1 -0
  16. package/bulleted-list/BulletedList.d.ts +7 -0
  17. package/bulleted-list/BulletedList.js +123 -0
  18. package/bulleted-list/BulletedList.stories.tsx +200 -0
  19. package/bulleted-list/types.d.ts +11 -0
  20. package/{list → bulleted-list}/types.js +0 -0
  21. package/button/Button.js +50 -70
  22. package/button/Button.stories.tsx +159 -8
  23. package/button/types.d.ts +7 -7
  24. package/card/types.d.ts +1 -0
  25. package/checkbox/Checkbox.d.ts +2 -2
  26. package/checkbox/Checkbox.js +92 -99
  27. package/checkbox/Checkbox.stories.tsx +131 -59
  28. package/checkbox/Checkbox.test.js +93 -16
  29. package/checkbox/types.d.ts +6 -2
  30. package/chip/Chip.js +16 -22
  31. package/chip/Chip.stories.tsx +96 -9
  32. package/chip/types.d.ts +1 -1
  33. package/common/variables.js +309 -260
  34. package/date-input/Calendar.d.ts +4 -0
  35. package/date-input/Calendar.js +258 -0
  36. package/date-input/DateInput.js +134 -237
  37. package/date-input/DateInput.stories.tsx +199 -33
  38. package/date-input/DateInput.test.js +494 -138
  39. package/date-input/DatePicker.d.ts +4 -0
  40. package/date-input/DatePicker.js +146 -0
  41. package/date-input/Icons.d.ts +6 -0
  42. package/date-input/Icons.js +75 -0
  43. package/date-input/YearPicker.d.ts +4 -0
  44. package/date-input/YearPicker.js +126 -0
  45. package/date-input/types.d.ts +51 -0
  46. package/dialog/Dialog.js +50 -28
  47. package/dialog/Dialog.stories.tsx +99 -22
  48. package/dialog/Dialog.test.js +34 -4
  49. package/dialog/types.d.ts +3 -2
  50. package/dropdown/Dropdown.d.ts +1 -1
  51. package/dropdown/Dropdown.js +246 -249
  52. package/dropdown/Dropdown.stories.tsx +245 -56
  53. package/dropdown/Dropdown.test.js +504 -108
  54. package/dropdown/DropdownMenu.d.ts +4 -0
  55. package/dropdown/DropdownMenu.js +70 -0
  56. package/dropdown/DropdownMenuItem.d.ts +4 -0
  57. package/dropdown/DropdownMenuItem.js +81 -0
  58. package/dropdown/types.d.ts +25 -5
  59. package/file-input/FileInput.d.ts +2 -2
  60. package/file-input/FileInput.js +177 -219
  61. package/file-input/FileInput.stories.tsx +122 -11
  62. package/file-input/FileInput.test.js +53 -12
  63. package/file-input/FileItem.d.ts +4 -14
  64. package/file-input/FileItem.js +38 -63
  65. package/file-input/types.d.ts +17 -0
  66. package/flex/Flex.d.ts +4 -0
  67. package/flex/Flex.js +69 -0
  68. package/flex/Flex.stories.tsx +103 -0
  69. package/flex/types.d.ts +32 -0
  70. package/{row → flex}/types.js +0 -0
  71. package/footer/Footer.stories.tsx +99 -1
  72. package/footer/Icons.js +1 -1
  73. package/footer/types.d.ts +2 -1
  74. package/header/Header.js +87 -87
  75. package/header/Header.stories.tsx +152 -9
  76. package/header/Icons.js +2 -2
  77. package/header/types.d.ts +3 -2
  78. package/inset/Inset.js +1 -34
  79. package/inset/Inset.stories.tsx +36 -36
  80. package/inset/types.d.ts +1 -1
  81. package/layout/ApplicationLayout.d.ts +15 -6
  82. package/layout/ApplicationLayout.js +37 -65
  83. package/layout/ApplicationLayout.stories.tsx +80 -44
  84. package/layout/types.d.ts +17 -27
  85. package/link/Link.js +2 -2
  86. package/link/Link.stories.tsx +73 -6
  87. package/link/types.d.ts +1 -1
  88. package/main.d.ts +5 -8
  89. package/main.js +28 -52
  90. package/number-input/NumberInput.test.js +43 -7
  91. package/package.json +16 -20
  92. package/paginator/Icons.d.ts +5 -0
  93. package/paginator/Icons.js +16 -28
  94. package/paginator/Paginator.js +6 -12
  95. package/paginator/Paginator.stories.tsx +24 -0
  96. package/paginator/Paginator.test.js +50 -1
  97. package/paragraph/Paragraph.d.ts +6 -0
  98. package/paragraph/Paragraph.js +38 -0
  99. package/paragraph/Paragraph.stories.tsx +44 -0
  100. package/password-input/PasswordInput.test.js +13 -12
  101. package/progress-bar/ProgressBar.d.ts +2 -2
  102. package/progress-bar/ProgressBar.js +59 -53
  103. package/progress-bar/ProgressBar.stories.jsx +38 -3
  104. package/progress-bar/ProgressBar.test.js +67 -22
  105. package/progress-bar/types.d.ts +3 -4
  106. package/quick-nav/QuickNav.js +25 -20
  107. package/quick-nav/QuickNav.stories.tsx +145 -26
  108. package/radio-group/Radio.d.ts +1 -1
  109. package/radio-group/Radio.js +43 -28
  110. package/radio-group/RadioGroup.js +23 -22
  111. package/radio-group/RadioGroup.stories.tsx +132 -18
  112. package/radio-group/RadioGroup.test.js +123 -96
  113. package/radio-group/types.d.ts +2 -2
  114. package/resultsetTable/Icons.d.ts +7 -0
  115. package/resultsetTable/Icons.js +51 -0
  116. package/resultsetTable/ResultsetTable.js +48 -107
  117. package/resultsetTable/ResultsetTable.stories.tsx +50 -25
  118. package/resultsetTable/ResultsetTable.test.js +60 -41
  119. package/resultsetTable/types.d.ts +2 -2
  120. package/select/Listbox.d.ts +1 -1
  121. package/select/Listbox.js +33 -16
  122. package/select/Option.js +11 -24
  123. package/select/Select.js +79 -60
  124. package/select/Select.stories.tsx +513 -136
  125. package/select/Select.test.js +358 -250
  126. package/select/types.d.ts +3 -6
  127. package/sidenav/Sidenav.d.ts +6 -5
  128. package/sidenav/Sidenav.js +174 -55
  129. package/sidenav/Sidenav.stories.tsx +249 -149
  130. package/sidenav/Sidenav.test.js +25 -37
  131. package/sidenav/types.d.ts +50 -27
  132. package/slider/Slider.d.ts +2 -2
  133. package/slider/Slider.js +120 -95
  134. package/slider/Slider.stories.tsx +64 -1
  135. package/slider/Slider.test.js +121 -21
  136. package/slider/types.d.ts +6 -2
  137. package/spinner/Spinner.js +2 -2
  138. package/spinner/Spinner.stories.jsx +27 -1
  139. package/switch/Switch.d.ts +2 -2
  140. package/switch/Switch.js +135 -68
  141. package/switch/Switch.stories.tsx +41 -30
  142. package/switch/Switch.test.js +144 -17
  143. package/switch/types.d.ts +6 -2
  144. package/table/Table.js +1 -1
  145. package/table/Table.stories.jsx +80 -1
  146. package/table/Table.test.js +1 -1
  147. package/tabs/Tab.d.ts +4 -0
  148. package/tabs/Tab.js +133 -0
  149. package/tabs/Tabs.js +360 -104
  150. package/tabs/Tabs.stories.tsx +119 -5
  151. package/tabs/Tabs.test.js +217 -6
  152. package/tabs/types.d.ts +15 -5
  153. package/tabs-nav/NavTabs.js +5 -5
  154. package/tabs-nav/NavTabs.stories.tsx +8 -6
  155. package/tabs-nav/Tab.js +8 -12
  156. package/tabs-nav/types.d.ts +1 -1
  157. package/tag/Tag.js +1 -1
  158. package/tag/Tag.stories.tsx +14 -1
  159. package/tag/types.d.ts +1 -1
  160. package/text-input/Icons.d.ts +8 -0
  161. package/text-input/Icons.js +60 -0
  162. package/text-input/Suggestion.js +38 -9
  163. package/text-input/Suggestions.d.ts +4 -0
  164. package/text-input/Suggestions.js +134 -0
  165. package/text-input/TextInput.js +195 -292
  166. package/text-input/TextInput.stories.tsx +280 -185
  167. package/text-input/TextInput.test.js +737 -725
  168. package/text-input/types.d.ts +22 -3
  169. package/textarea/Textarea.stories.jsx +60 -1
  170. package/toggle-group/ToggleGroup.stories.tsx +42 -0
  171. package/toggle-group/types.d.ts +1 -1
  172. package/typography/Typography.d.ts +4 -0
  173. package/typography/Typography.js +131 -0
  174. package/typography/Typography.stories.tsx +198 -0
  175. package/typography/types.d.ts +18 -0
  176. package/{stack → typography}/types.js +0 -0
  177. package/wizard/Wizard.js +9 -16
  178. package/wizard/Wizard.stories.tsx +40 -1
  179. package/wizard/types.d.ts +5 -4
  180. package/common/RequiredComponent.js +0 -32
  181. package/list/List.d.ts +0 -4
  182. package/list/List.js +0 -47
  183. package/list/List.stories.tsx +0 -95
  184. package/list/types.d.ts +0 -7
  185. package/row/Row.d.ts +0 -3
  186. package/row/Row.js +0 -127
  187. package/row/Row.stories.tsx +0 -237
  188. package/row/types.d.ts +0 -28
  189. package/stack/Stack.d.ts +0 -3
  190. package/stack/Stack.js +0 -97
  191. package/stack/Stack.stories.tsx +0 -164
  192. package/stack/types.d.ts +0 -24
  193. package/text/Text.d.ts +0 -7
  194. package/text/Text.js +0 -30
  195. package/text/Text.stories.tsx +0 -19
package/main.js CHANGED
@@ -55,6 +55,12 @@ Object.defineProperty(exports, "DxcBox", {
55
55
  return _Box["default"];
56
56
  }
57
57
  });
58
+ Object.defineProperty(exports, "DxcBulletedList", {
59
+ enumerable: true,
60
+ get: function get() {
61
+ return _BulletedList["default"];
62
+ }
63
+ });
58
64
  Object.defineProperty(exports, "DxcButton", {
59
65
  enumerable: true,
60
66
  get: function get() {
@@ -103,16 +109,10 @@ Object.defineProperty(exports, "DxcFileInput", {
103
109
  return _FileInput["default"];
104
110
  }
105
111
  });
106
- Object.defineProperty(exports, "DxcFooter", {
107
- enumerable: true,
108
- get: function get() {
109
- return _Footer["default"];
110
- }
111
- });
112
- Object.defineProperty(exports, "DxcHeader", {
112
+ Object.defineProperty(exports, "DxcFlex", {
113
113
  enumerable: true,
114
114
  get: function get() {
115
- return _Header["default"];
115
+ return _Flex["default"];
116
116
  }
117
117
  });
118
118
  Object.defineProperty(exports, "DxcHeading", {
@@ -133,12 +133,6 @@ Object.defineProperty(exports, "DxcLink", {
133
133
  return _Link["default"];
134
134
  }
135
135
  });
136
- Object.defineProperty(exports, "DxcList", {
137
- enumerable: true,
138
- get: function get() {
139
- return _List["default"];
140
- }
141
- });
142
136
  Object.defineProperty(exports, "DxcNavTabs", {
143
137
  enumerable: true,
144
138
  get: function get() {
@@ -157,6 +151,12 @@ Object.defineProperty(exports, "DxcPaginator", {
157
151
  return _Paginator["default"];
158
152
  }
159
153
  });
154
+ Object.defineProperty(exports, "DxcParagraph", {
155
+ enumerable: true,
156
+ get: function get() {
157
+ return _Paragraph["default"];
158
+ }
159
+ });
160
160
  Object.defineProperty(exports, "DxcPasswordInput", {
161
161
  enumerable: true,
162
162
  get: function get() {
@@ -187,24 +187,12 @@ Object.defineProperty(exports, "DxcResultsetTable", {
187
187
  return _ResultsetTable["default"];
188
188
  }
189
189
  });
190
- Object.defineProperty(exports, "DxcRow", {
191
- enumerable: true,
192
- get: function get() {
193
- return _Row["default"];
194
- }
195
- });
196
190
  Object.defineProperty(exports, "DxcSelect", {
197
191
  enumerable: true,
198
192
  get: function get() {
199
193
  return _Select["default"];
200
194
  }
201
195
  });
202
- Object.defineProperty(exports, "DxcSidenav", {
203
- enumerable: true,
204
- get: function get() {
205
- return _Sidenav["default"];
206
- }
207
- });
208
196
  Object.defineProperty(exports, "DxcSlider", {
209
197
  enumerable: true,
210
198
  get: function get() {
@@ -217,12 +205,6 @@ Object.defineProperty(exports, "DxcSpinner", {
217
205
  return _Spinner["default"];
218
206
  }
219
207
  });
220
- Object.defineProperty(exports, "DxcStack", {
221
- enumerable: true,
222
- get: function get() {
223
- return _Stack["default"];
224
- }
225
- });
226
208
  Object.defineProperty(exports, "DxcSwitch", {
227
209
  enumerable: true,
228
210
  get: function get() {
@@ -247,12 +229,6 @@ Object.defineProperty(exports, "DxcTag", {
247
229
  return _Tag["default"];
248
230
  }
249
231
  });
250
- Object.defineProperty(exports, "DxcText", {
251
- enumerable: true,
252
- get: function get() {
253
- return _Text["default"];
254
- }
255
- });
256
232
  Object.defineProperty(exports, "DxcTextInput", {
257
233
  enumerable: true,
258
234
  get: function get() {
@@ -271,6 +247,12 @@ Object.defineProperty(exports, "DxcToggleGroup", {
271
247
  return _ToggleGroup["default"];
272
248
  }
273
249
  });
250
+ Object.defineProperty(exports, "DxcTypography", {
251
+ enumerable: true,
252
+ get: function get() {
253
+ return _Typography["default"];
254
+ }
255
+ });
274
256
  Object.defineProperty(exports, "DxcWizard", {
275
257
  enumerable: true,
276
258
  get: function get() {
@@ -310,10 +292,6 @@ var _Dialog = _interopRequireDefault(require("./dialog/Dialog"));
310
292
 
311
293
  var _Dropdown = _interopRequireDefault(require("./dropdown/Dropdown"));
312
294
 
313
- var _Footer = _interopRequireDefault(require("./footer/Footer"));
314
-
315
- var _Header = _interopRequireDefault(require("./header/Header"));
316
-
317
295
  var _Slider = _interopRequireDefault(require("./slider/Slider"));
318
296
 
319
297
  var _Switch = _interopRequireDefault(require("./switch/Switch"));
@@ -332,8 +310,6 @@ var _Tag = _interopRequireDefault(require("./tag/Tag"));
332
310
 
333
311
  var _Paginator = _interopRequireDefault(require("./paginator/Paginator"));
334
312
 
335
- var _Sidenav = _interopRequireDefault(require("./sidenav/Sidenav"));
336
-
337
313
  var _Wizard = _interopRequireDefault(require("./wizard/Wizard"));
338
314
 
339
315
  var _Link = _interopRequireDefault(require("./link/Link"));
@@ -366,14 +342,6 @@ var _Select = _interopRequireDefault(require("./select/Select"));
366
342
 
367
343
  var _FileInput = _interopRequireDefault(require("./file-input/FileInput"));
368
344
 
369
- var _Stack = _interopRequireDefault(require("./stack/Stack"));
370
-
371
- var _Row = _interopRequireDefault(require("./row/Row"));
372
-
373
- var _Text = _interopRequireDefault(require("./text/Text"));
374
-
375
- var _List = _interopRequireDefault(require("./list/List"));
376
-
377
345
  var _RadioGroup = _interopRequireDefault(require("./radio-group/RadioGroup"));
378
346
 
379
347
  var _Bleed = _interopRequireDefault(require("./bleed/Bleed"));
@@ -384,6 +352,14 @@ var _QuickNav = _interopRequireDefault(require("./quick-nav/QuickNav"));
384
352
 
385
353
  var _NavTabs = _interopRequireDefault(require("./tabs-nav/NavTabs"));
386
354
 
355
+ var _Flex = _interopRequireDefault(require("./flex/Flex"));
356
+
357
+ var _Typography = _interopRequireDefault(require("./typography/Typography"));
358
+
359
+ var _Paragraph = _interopRequireDefault(require("./paragraph/Paragraph"));
360
+
361
+ var _BulletedList = _interopRequireDefault(require("./bulleted-list/BulletedList"));
362
+
387
363
  var _HalstackContext = _interopRequireWildcard(require("./HalstackContext"));
388
364
 
389
365
  var _BackgroundColorContext = require("./BackgroundColorContext");
@@ -83,7 +83,7 @@ describe("Number input component tests", function () {
83
83
  })),
84
84
  getByRole = _render8.getByRole;
85
85
 
86
- var input = getByRole("textbox");
86
+ var input = getByRole("spinbutton");
87
87
 
88
88
  _userEvent["default"].type(input, "1");
89
89
 
@@ -366,12 +366,7 @@ describe("Number input component tests", function () {
366
366
  expect(number.value).toBe("10");
367
367
  });
368
368
  test("Increment and decrement the value with min, max and step", function () {
369
- var onBlur = jest.fn(function (_ref3) {
370
- var value = _ref3.value,
371
- error = _ref3.error;
372
- expect(value).toBe("1");
373
- expect(error).toBe("Value must be greater than or equal to 5.");
374
- });
369
+ var onBlur = jest.fn();
375
370
 
376
371
  var _render20 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
377
372
  label: "Number input label",
@@ -389,6 +384,10 @@ describe("Number input component tests", function () {
389
384
 
390
385
  _react2.fireEvent.blur(number);
391
386
 
387
+ expect(onBlur).toHaveBeenCalledWith({
388
+ value: "1",
389
+ error: "Value must be greater than or equal to 5."
390
+ });
392
391
  var increment = getAllByRole("button")[1];
393
392
 
394
393
  _userEvent["default"].click(increment);
@@ -503,4 +502,41 @@ describe("Number input component tests", function () {
503
502
  var increment = getAllByRole("button")[1];
504
503
  expect(increment.getAttribute("aria-label")).toBe("Increment value");
505
504
  });
505
+ test("Number input submits correct values in a form", function () {
506
+ var handlerOnSubmit = jest.fn(function (e) {
507
+ e.preventDefault();
508
+ var formData = new FormData(e.target);
509
+ var formProps = Object.fromEntries(formData);
510
+ expect(formProps).toStrictEqual({
511
+ data: "0"
512
+ });
513
+ });
514
+
515
+ var _render23 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement("form", {
516
+ onSubmit: handlerOnSubmit
517
+ }, /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
518
+ label: "Number input label",
519
+ name: "data"
520
+ }), /*#__PURE__*/_react["default"].createElement("button", {
521
+ type: "submit"
522
+ }, "Submit"))),
523
+ getByText = _render23.getByText,
524
+ getAllByRole = _render23.getAllByRole;
525
+
526
+ var less = getAllByRole("button")[0];
527
+ var more = getAllByRole("button")[1];
528
+ var submit = getByText("Submit");
529
+
530
+ _userEvent["default"].click(more);
531
+
532
+ expect(handlerOnSubmit).not.toHaveBeenCalled();
533
+
534
+ _userEvent["default"].click(less);
535
+
536
+ expect(handlerOnSubmit).not.toHaveBeenCalled();
537
+
538
+ _userEvent["default"].click(submit);
539
+
540
+ expect(handlerOnSubmit).toHaveBeenCalled();
541
+ });
506
542
  });
package/package.json CHANGED
@@ -1,40 +1,34 @@
1
1
  {
2
2
  "name": "@dxc-technology/halstack-react",
3
- "version": "0.0.0-910214a",
3
+ "version": "0.0.0-918d2c8",
4
4
  "description": "DXC Halstack React components library",
5
5
  "repository": "dxc-technology/halstack-react",
6
- "homepage": "http://developer.dxc.com/tools/react",
6
+ "homepage": "https://developer.dxc.com/halstack",
7
7
  "license": "Apache-2.0",
8
8
  "author": {
9
9
  "name": "DXC Technology",
10
10
  "email": "DigitalInsurance@dxc.com",
11
- "url": "https://dxc.com"
11
+ "url": "https://developer.dxc.com"
12
12
  },
13
13
  "main": "./main.js",
14
14
  "types": "./main.d.ts",
15
15
  "peerDependencies": {
16
- "react": "^17.0.1",
17
- "react-dom": "^17.0.1",
16
+ "react": "^18.x",
17
+ "react-dom": "^18.x",
18
18
  "styled-components": "^5.0.1"
19
19
  },
20
20
  "dependencies": {
21
- "@date-io/dayjs": "^1.3.9",
22
- "@material-ui/core": "4.11.1",
23
- "@material-ui/icons": "4.4.3",
24
- "@material-ui/lab": "4.0.0-alpha.17",
25
- "@material-ui/pickers": "3.2.2",
26
- "@material-ui/styles": "4.0.2",
21
+ "@radix-ui/react-popover": "0.1.6",
27
22
  "@types/styled-components": "^5.1.24",
28
23
  "@types/uuid": "^8.3.4",
29
24
  "color": "^3.1.3",
30
25
  "dayjs": "^1.11.1",
31
- "prop-types": "^15.7.2",
32
26
  "rgb-hex": "^3.0.0",
33
27
  "slugify": "^1.6.5",
34
28
  "uuid": "^8.3.2"
35
29
  },
36
30
  "scripts": {
37
- "test": "jest",
31
+ "test": "jest --env=jsdom",
38
32
  "test:watch": "npm test -- --watch --coverage",
39
33
  "build": "babel src --extensions .js,.jsx,.ts,.tsx --out-dir ../dist --copy-files --verbose && node ../scripts/build/copy-package.js && tsc ",
40
34
  "build:watch": "babel src --watch --extensions .js,.jsx,.ts,.tsx --out-dir ../dist --copy-files --verbose",
@@ -55,9 +49,9 @@
55
49
  "@storybook/addon-links": "^6.4.9",
56
50
  "@storybook/react": "^6.4.9",
57
51
  "@storybook/testing-library": "0.0.7",
58
- "@testing-library/react": "^11.2.5",
59
- "@testing-library/user-event": "^12.6.3",
60
- "@types/react": "16.9.5",
52
+ "@testing-library/react": "^13.0.0",
53
+ "@testing-library/user-event": "^13.0.0",
54
+ "@types/react": "^18.0.18",
61
55
  "babel-jest": "^24.8.0",
62
56
  "babel-loader": "^8.0.6",
63
57
  "chromatic": "^6.3.3",
@@ -71,9 +65,10 @@
71
65
  "eslint-plugin-react-hooks": "^4.2.0",
72
66
  "eslint-plugin-storybook": "^0.5.5",
73
67
  "identity-obj-proxy": "^3.0.0",
74
- "jest": "^25.5.4",
75
- "react": "^17.0.1",
76
- "react-dom": "^17.0.1",
68
+ "jest": "^29.2.2",
69
+ "jest-environment-jsdom": "^29.3.1",
70
+ "react": "^18.x",
71
+ "react-dom": "^18.x",
77
72
  "react-test-renderer": "^16.8.6",
78
73
  "storybook-addon-pseudo-states": "^1.0.0",
79
74
  "styled-components": "^5.0.1",
@@ -83,7 +78,8 @@
83
78
  "moduleNameMapper": {
84
79
  "\\.(css|less|scss|sass)$": "identity-obj-proxy",
85
80
  "\\.(svg)$": "<rootDir>/test/mocks/svgMock.js",
86
- "\\.(png)$": "<rootDir>/test/mocks/pngMock.js"
81
+ "\\.(png)$": "<rootDir>/test/mocks/pngMock.js",
82
+ "^uuid$": "uuid"
87
83
  }
88
84
  }
89
85
  }
@@ -0,0 +1,5 @@
1
+ /// <reference types="react" />
2
+ export declare const firstIcon: JSX.Element;
3
+ export declare const previousIcon: JSX.Element;
4
+ export declare const nextIcon: JSX.Element;
5
+ export declare const lastIcon: JSX.Element;
@@ -11,56 +11,44 @@ var _react = _interopRequireDefault(require("react"));
11
11
 
12
12
  var firstIcon = /*#__PURE__*/_react["default"].createElement("svg", {
13
13
  xmlns: "http://www.w3.org/2000/svg",
14
- width: "12.41",
15
- height: "12",
16
- viewBox: "0 0 12.41 12"
14
+ height: "24",
15
+ width: "24",
16
+ fill: "currentColor"
17
17
  }, /*#__PURE__*/_react["default"].createElement("path", {
18
- id: "Path_2463",
19
- "data-name": "Path 2463",
20
- d: "M18.41,16.59,13.82,12l4.59-4.59L17,6l-6,6,6,6ZM6,6H8V18H6Z",
21
- transform: "translate(-6 -6)"
18
+ d: "M6 18V6h2v12Zm11 0-6-6 6-6 1.4 1.4-4.6 4.6 4.6 4.6Z"
22
19
  }));
23
20
 
24
21
  exports.firstIcon = firstIcon;
25
22
 
26
23
  var previousIcon = /*#__PURE__*/_react["default"].createElement("svg", {
27
24
  xmlns: "http://www.w3.org/2000/svg",
28
- width: "7.41",
29
- height: "12",
30
- viewBox: "0 0 7.41 12"
25
+ height: "24",
26
+ width: "24",
27
+ fill: "currentColor"
31
28
  }, /*#__PURE__*/_react["default"].createElement("path", {
32
- id: "Path_2459",
33
- "data-name": "Path 2459",
34
- d: "M15.41,7.41,14,6,8,12l6,6,1.41-1.41L10.83,12Z",
35
- transform: "translate(-8 -6)"
29
+ d: "m14 18-6-6 6-6 1.4 1.4-4.6 4.6 4.6 4.6Z"
36
30
  }));
37
31
 
38
32
  exports.previousIcon = previousIcon;
39
33
 
40
34
  var nextIcon = /*#__PURE__*/_react["default"].createElement("svg", {
41
35
  xmlns: "http://www.w3.org/2000/svg",
42
- width: "7.41",
43
- height: "12",
44
- viewBox: "0 0 7.41 12"
36
+ height: "24",
37
+ width: "24",
38
+ fill: "currentColor"
45
39
  }, /*#__PURE__*/_react["default"].createElement("path", {
46
- id: "Path_2461",
47
- "data-name": "Path 2461",
48
- d: "M10,6,8.59,7.41,13.17,12,8.59,16.59,10,18l6-6Z",
49
- transform: "translate(-8.59 -6)"
40
+ d: "M9.4 18 8 16.6l4.6-4.6L8 7.4 9.4 6l6 6Z"
50
41
  }));
51
42
 
52
43
  exports.nextIcon = nextIcon;
53
44
 
54
45
  var lastIcon = /*#__PURE__*/_react["default"].createElement("svg", {
55
46
  xmlns: "http://www.w3.org/2000/svg",
56
- width: "12.41",
57
- height: "12",
58
- viewBox: "0 0 12.41 12"
47
+ height: "24",
48
+ width: "24",
49
+ fill: "currentColor"
59
50
  }, /*#__PURE__*/_react["default"].createElement("path", {
60
- id: "Path_2465",
61
- "data-name": "Path 2465",
62
- d: "M5.59,7.41,10.18,12,5.59,16.59,7,18l6-6L7,6ZM16,6h2V18H16Z",
63
- transform: "translate(-5.59 -6)"
51
+ d: "m7 18-1.4-1.4 4.6-4.6-4.6-4.6L7 6l6 6Zm9 0V6h2v12Z"
64
52
  }));
65
53
 
66
54
  exports.lastIcon = lastIcon;
@@ -27,7 +27,7 @@ var _Icons = require("./Icons");
27
27
 
28
28
  var _BackgroundColorContext = require("../BackgroundColorContext");
29
29
 
30
- var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9;
30
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8;
31
31
 
32
32
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
33
33
 
@@ -72,7 +72,6 @@ var DxcPaginator = function DxcPaginator(_ref) {
72
72
  size: "fillParent",
73
73
  tabIndex: tabIndex
74
74
  }))), /*#__PURE__*/_react["default"].createElement(TotalItemsContainer, null, translatedLabels.paginator.minToMaxOfText(minItemsPerPage, maxItemsPerPage, totalItems)), onPageChange && /*#__PURE__*/_react["default"].createElement(_Button["default"], {
75
- size: "small",
76
75
  mode: "secondary",
77
76
  disabled: currentPageInternal === 1 || currentPageInternal === 0,
78
77
  icon: _Icons.firstIcon,
@@ -81,7 +80,6 @@ var DxcPaginator = function DxcPaginator(_ref) {
81
80
  onPageChange(1);
82
81
  }
83
82
  }), onPageChange && /*#__PURE__*/_react["default"].createElement(_Button["default"], {
84
- size: "small",
85
83
  mode: "secondary",
86
84
  disabled: currentPageInternal === 1 || currentPageInternal === 0,
87
85
  icon: _Icons.previousIcon,
@@ -89,7 +87,7 @@ var DxcPaginator = function DxcPaginator(_ref) {
89
87
  onClick: function onClick() {
90
88
  onPageChange(currentPage - 1);
91
89
  }
92
- }), showGoToPage && /*#__PURE__*/_react["default"].createElement(PageToSelectContainer, null, /*#__PURE__*/_react["default"].createElement(GoToLabel, null, translatedLabels.paginator.goToPageText, " "), /*#__PURE__*/_react["default"].createElement(SelectContainer, null, /*#__PURE__*/_react["default"].createElement(_Select["default"], {
90
+ }), showGoToPage ? /*#__PURE__*/_react["default"].createElement(PageToSelectContainer, null, /*#__PURE__*/_react["default"].createElement(GoToLabel, null, translatedLabels.paginator.goToPageText, " "), /*#__PURE__*/_react["default"].createElement(SelectContainer, null, /*#__PURE__*/_react["default"].createElement(_Select["default"], {
93
91
  options: Array.from(Array(totalPages), function (e, num) {
94
92
  return {
95
93
  label: (num + 1).toString(),
@@ -102,8 +100,7 @@ var DxcPaginator = function DxcPaginator(_ref) {
102
100
  value: currentPage.toString(),
103
101
  size: "fillParent",
104
102
  tabIndex: tabIndex
105
- }))) || /*#__PURE__*/_react["default"].createElement(TextContainer, null, translatedLabels.paginator.pageOfText(currentPageInternal, totalPages)), onPageChange && /*#__PURE__*/_react["default"].createElement(_Button["default"], {
106
- size: "small",
103
+ }))) : /*#__PURE__*/_react["default"].createElement("span", null, translatedLabels.paginator.pageOfText(currentPageInternal, totalPages)), onPageChange && /*#__PURE__*/_react["default"].createElement(_Button["default"], {
107
104
  mode: "secondary",
108
105
  disabled: currentPageInternal === totalPages,
109
106
  icon: _Icons.nextIcon,
@@ -112,7 +109,6 @@ var DxcPaginator = function DxcPaginator(_ref) {
112
109
  onPageChange(currentPage + 1);
113
110
  }
114
111
  }), onPageChange && /*#__PURE__*/_react["default"].createElement(_Button["default"], {
115
- size: "small",
116
112
  mode: "secondary",
117
113
  disabled: currentPageInternal === totalPages,
118
114
  icon: _Icons.lastIcon,
@@ -145,7 +141,7 @@ var DxcPaginatorContainer = _styledComponents["default"].div(_templateObject ||
145
141
 
146
142
  var SelectContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n min-width: 5.25rem;\n"])));
147
143
 
148
- var ItemsPageContainer = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n margin-right: ", ";\n margin-left: ", ";\n\n label {\n height: 0px;\n }\n label + .MuiInput-formControl {\n margin-top: 0px;\n }\n"])), function (props) {
144
+ var ItemsPageContainer = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n margin-right: ", ";\n margin-left: ", ";\n"])), function (props) {
149
145
  return props.theme.itemsPerPageSelectorMarginRight;
150
146
  }, function (props) {
151
147
  return props.theme.itemsPerPageSelectorMarginLeft;
@@ -153,7 +149,7 @@ var ItemsPageContainer = _styledComponents["default"].span(_templateObject3 || (
153
149
 
154
150
  var ItemsLabel = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 0.5rem;\n"])));
155
151
 
156
- var GoToLabel = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 0.5rem;\n margin-left: 1rem;\n"])));
152
+ var GoToLabel = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 0.5rem;\n margin-left: 0.5rem;\n"])));
157
153
 
158
154
  var TotalItemsContainer = _styledComponents["default"].span(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: ", ";\n margin-left: ", ";\n"])), function (props) {
159
155
  return props.theme.totalItemsContainerMarginRight;
@@ -163,9 +159,7 @@ var TotalItemsContainer = _styledComponents["default"].span(_templateObject6 ||
163
159
 
164
160
  var LabelsContainer = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n gap: 0.5rem;\n width: 100%;\n justify-content: flex-end;\n align-items: center;\n"])));
165
161
 
166
- var PageToSelectContainer = _styledComponents["default"].span(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n\n label {\n height: 0px;\n }\n label + .MuiInput-formControl {\n margin-top: 0px;\n }\n"])));
167
-
168
- var TextContainer = _styledComponents["default"].span(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])([""])));
162
+ var PageToSelectContainer = _styledComponents["default"].span(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n margin-right: 0.5rem;\n"])));
169
163
 
170
164
  var _default = DxcPaginator;
171
165
  exports["default"] = _default;
@@ -2,12 +2,20 @@ import React from "react";
2
2
  import DxcPaginator from "./Paginator";
3
3
  import Title from "../../.storybook/components/Title";
4
4
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
+ import { HalstackProvider } from "../HalstackContext";
5
6
 
6
7
  export default {
7
8
  title: "Paginator",
8
9
  component: DxcPaginator,
9
10
  };
10
11
 
12
+ const opinionatedTheme = {
13
+ paginator: {
14
+ baseColor: "#f2f2f2",
15
+ fontColor: "#000000",
16
+ },
17
+ };
18
+
11
19
  export const Chromatic = () => (
12
20
  <>
13
21
  <ExampleContainer>
@@ -59,5 +67,21 @@ export const Chromatic = () => (
59
67
  showGoToPage
60
68
  />
61
69
  </ExampleContainer>
70
+ <Title title="Opinionated theme" theme="light" level={2} />
71
+ <ExampleContainer>
72
+ <HalstackProvider theme={opinionatedTheme}>
73
+ <ExampleContainer>
74
+ <Title title="Page change and items per page options" theme="light" level={4} />
75
+ <DxcPaginator
76
+ currentPage={1}
77
+ itemsPerPage={10}
78
+ totalItems={27}
79
+ onPageChange={() => {}}
80
+ itemsPerPageOptions={[5, 10, 15]}
81
+ showGoToPage
82
+ />
83
+ </ExampleContainer>
84
+ </HalstackProvider>
85
+ </ExampleContainer>
62
86
  </>
63
87
  );
@@ -2,6 +2,10 @@
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
4
 
5
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
6
+
7
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
8
+
5
9
  var _react = _interopRequireDefault(require("react"));
6
10
 
7
11
  var _react2 = require("@testing-library/react");
@@ -10,6 +14,51 @@ var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
10
14
 
11
15
  var _Paginator = _interopRequireDefault(require("./Paginator"));
12
16
 
17
+ // Mocking DOMRect for Radix Primitive Popover
18
+ global.globalThis = global;
19
+ global.DOMRect = {
20
+ fromRect: function fromRect() {
21
+ return {
22
+ top: 0,
23
+ left: 0,
24
+ bottom: 0,
25
+ right: 0,
26
+ width: 0,
27
+ height: 0
28
+ };
29
+ }
30
+ };
31
+
32
+ global.ResizeObserver = /*#__PURE__*/function () {
33
+ function ResizeObserver() {
34
+ (0, _classCallCheck2["default"])(this, ResizeObserver);
35
+ }
36
+
37
+ (0, _createClass2["default"])(ResizeObserver, [{
38
+ key: "observe",
39
+ value: function observe() {}
40
+ }, {
41
+ key: "unobserve",
42
+ value: function unobserve() {}
43
+ }, {
44
+ key: "disconnect",
45
+ value: function disconnect() {}
46
+ }]);
47
+ return ResizeObserver;
48
+ }();
49
+
50
+ global.DOMRect = {
51
+ fromRect: function fromRect() {
52
+ return {
53
+ top: 0,
54
+ left: 0,
55
+ bottom: 0,
56
+ right: 0,
57
+ width: 0,
58
+ height: 0
59
+ };
60
+ }
61
+ };
13
62
  describe("Paginator component tests", function () {
14
63
  test("Paginator renders with default values", function () {
15
64
  var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Paginator["default"], null)),
@@ -35,7 +84,7 @@ describe("Paginator component tests", function () {
35
84
  })),
36
85
  getByText = _render3.getByText;
37
86
 
38
- expect(getByText("Items per page")).toBeTruthy();
87
+ expect(getByText("Items per page:")).toBeTruthy();
39
88
  });
40
89
  test("Paginator renders with itemsPerPageOptions", function () {
41
90
  var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
@@ -0,0 +1,6 @@
1
+ import React from "react";
2
+ declare type ParagraphPropsType = {
3
+ children: React.ReactNode;
4
+ };
5
+ declare const Paragraph: ({ children }: ParagraphPropsType) => JSX.Element;
6
+ export default Paragraph;
@@ -0,0 +1,38 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof = require("@babel/runtime/helpers/typeof");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports["default"] = void 0;
11
+
12
+ var _react = _interopRequireWildcard(require("react"));
13
+
14
+ var _Typography = _interopRequireDefault(require("../typography/Typography"));
15
+
16
+ var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext"));
17
+
18
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
19
+
20
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
21
+
22
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
23
+
24
+ var Paragraph = function Paragraph(_ref) {
25
+ var children = _ref.children;
26
+ var colorsTheme = (0, _useTheme["default"])();
27
+ var backgroundType = (0, _react.useContext)(_BackgroundColorContext["default"]);
28
+ return /*#__PURE__*/_react["default"].createElement(_Typography["default"], {
29
+ as: "p",
30
+ display: colorsTheme.paragraph.display,
31
+ fontSize: colorsTheme.paragraph.fontSize,
32
+ fontWeight: colorsTheme.paragraph.fontWeight,
33
+ color: backgroundType && backgroundType === "dark" ? colorsTheme.paragraph.fontColorOnDark : colorsTheme.paragraph.fontColor
34
+ }, children);
35
+ };
36
+
37
+ var _default = Paragraph;
38
+ exports["default"] = _default;