@dxc-technology/halstack-react 4.0.1 → 5.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 (344) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +7 -6
  3. package/HalstackContext.d.ts +10 -0
  4. package/HalstackContext.js +243 -0
  5. package/accordion/Accordion.d.ts +4 -0
  6. package/accordion/Accordion.js +35 -162
  7. package/accordion/Accordion.stories.tsx +307 -0
  8. package/accordion/Accordion.test.js +72 -0
  9. package/accordion/types.d.ts +68 -0
  10. package/accordion/types.js +5 -0
  11. package/accordion-group/AccordionGroup.d.ts +7 -0
  12. package/accordion-group/AccordionGroup.js +67 -85
  13. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  14. package/accordion-group/AccordionGroup.test.js +151 -0
  15. package/accordion-group/types.d.ts +72 -0
  16. package/accordion-group/types.js +5 -0
  17. package/alert/Alert.d.ts +4 -0
  18. package/alert/Alert.js +40 -153
  19. package/alert/Alert.stories.tsx +170 -0
  20. package/alert/Alert.test.js +92 -0
  21. package/alert/types.d.ts +49 -0
  22. package/alert/types.js +5 -0
  23. package/badge/Badge.d.ts +4 -0
  24. package/badge/Badge.js +10 -14
  25. package/badge/types.d.ts +4 -0
  26. package/badge/types.js +5 -0
  27. package/bleed/Bleed.d.ts +3 -0
  28. package/bleed/Bleed.js +84 -0
  29. package/bleed/Bleed.stories.tsx +342 -0
  30. package/bleed/types.d.ts +37 -0
  31. package/bleed/types.js +5 -0
  32. package/box/Box.d.ts +4 -0
  33. package/box/Box.js +15 -45
  34. package/box/Box.stories.tsx +132 -0
  35. package/box/Box.test.js +18 -0
  36. package/box/types.d.ts +43 -0
  37. package/box/types.js +5 -0
  38. package/button/Button.d.ts +4 -0
  39. package/button/Button.js +33 -99
  40. package/button/Button.stories.tsx +274 -0
  41. package/button/Button.test.js +35 -0
  42. package/button/types.d.ts +53 -0
  43. package/button/types.js +5 -0
  44. package/card/Card.d.ts +4 -0
  45. package/card/Card.js +53 -144
  46. package/card/Card.stories.tsx +201 -0
  47. package/card/Card.test.js +50 -0
  48. package/card/ice-cream.jpg +0 -0
  49. package/card/types.d.ts +67 -0
  50. package/card/types.js +5 -0
  51. package/checkbox/Checkbox.d.ts +4 -0
  52. package/checkbox/Checkbox.js +50 -95
  53. package/checkbox/Checkbox.stories.tsx +188 -0
  54. package/checkbox/Checkbox.test.js +78 -0
  55. package/checkbox/types.d.ts +64 -0
  56. package/checkbox/types.js +5 -0
  57. package/chip/Chip.d.ts +4 -0
  58. package/chip/Chip.js +26 -130
  59. package/chip/Chip.stories.tsx +119 -0
  60. package/chip/Chip.test.js +56 -0
  61. package/chip/types.d.ts +45 -0
  62. package/chip/types.js +5 -0
  63. package/common/RequiredComponent.js +3 -11
  64. package/common/variables.js +94 -289
  65. package/date-input/DateInput.d.ts +4 -0
  66. package/date-input/DateInput.js +77 -108
  67. package/date-input/DateInput.stories.tsx +138 -0
  68. package/date-input/DateInput.test.js +479 -0
  69. package/date-input/types.d.ts +107 -0
  70. package/date-input/types.js +5 -0
  71. package/dialog/Dialog.d.ts +4 -0
  72. package/dialog/Dialog.js +25 -105
  73. package/dialog/Dialog.stories.tsx +212 -0
  74. package/dialog/Dialog.test.js +40 -0
  75. package/dialog/types.d.ts +43 -0
  76. package/dialog/types.js +5 -0
  77. package/dropdown/Dropdown.d.ts +4 -0
  78. package/dropdown/Dropdown.js +54 -207
  79. package/dropdown/Dropdown.stories.tsx +249 -0
  80. package/dropdown/Dropdown.test.js +189 -0
  81. package/dropdown/types.d.ts +80 -0
  82. package/dropdown/types.js +5 -0
  83. package/file-input/FileInput.d.ts +4 -0
  84. package/file-input/FileInput.js +195 -249
  85. package/file-input/FileInput.stories.tsx +507 -0
  86. package/file-input/FileInput.test.js +457 -0
  87. package/file-input/FileItem.d.ts +14 -0
  88. package/file-input/FileItem.js +40 -143
  89. package/file-input/types.d.ts +112 -0
  90. package/file-input/types.js +5 -0
  91. package/footer/Footer.d.ts +4 -0
  92. package/footer/Footer.js +47 -285
  93. package/footer/Footer.stories.tsx +130 -0
  94. package/footer/Footer.test.js +109 -0
  95. package/footer/Icons.d.ts +2 -0
  96. package/footer/Icons.js +15 -15
  97. package/footer/types.d.ts +65 -0
  98. package/footer/types.js +5 -0
  99. package/header/Header.d.ts +7 -0
  100. package/header/Header.js +76 -246
  101. package/header/Header.stories.tsx +172 -0
  102. package/header/Header.test.js +79 -0
  103. package/header/Icons.d.ts +2 -0
  104. package/header/Icons.js +7 -32
  105. package/header/types.d.ts +47 -0
  106. package/header/types.js +5 -0
  107. package/heading/Heading.d.ts +4 -0
  108. package/heading/Heading.js +25 -96
  109. package/heading/Heading.stories.tsx +54 -0
  110. package/heading/Heading.test.js +186 -0
  111. package/heading/types.d.ts +33 -0
  112. package/heading/types.js +5 -0
  113. package/inset/Inset.d.ts +3 -0
  114. package/inset/Inset.js +84 -0
  115. package/inset/Inset.stories.tsx +229 -0
  116. package/inset/types.d.ts +37 -0
  117. package/inset/types.js +5 -0
  118. package/layout/ApplicationLayout.d.ts +10 -0
  119. package/layout/ApplicationLayout.js +44 -153
  120. package/layout/ApplicationLayout.stories.tsx +171 -0
  121. package/layout/Icons.js +7 -7
  122. package/layout/types.d.ts +57 -0
  123. package/layout/types.js +5 -0
  124. package/link/Link.d.ts +3 -0
  125. package/link/Link.js +22 -110
  126. package/link/Link.stories.tsx +151 -0
  127. package/link/Link.test.js +91 -0
  128. package/link/types.d.ts +70 -0
  129. package/link/types.js +5 -0
  130. package/list/List.d.ts +4 -0
  131. package/list/List.js +47 -0
  132. package/list/List.stories.tsx +95 -0
  133. package/list/types.d.ts +7 -0
  134. package/list/types.js +5 -0
  135. package/main.d.ts +47 -40
  136. package/main.js +124 -96
  137. package/number-input/NumberInput.d.ts +4 -0
  138. package/number-input/NumberInput.js +21 -81
  139. package/number-input/NumberInput.stories.tsx +115 -0
  140. package/number-input/NumberInput.test.js +506 -0
  141. package/number-input/NumberInputContext.d.ts +4 -0
  142. package/number-input/NumberInputContext.js +5 -2
  143. package/number-input/numberInputContextTypes.d.ts +19 -0
  144. package/number-input/numberInputContextTypes.js +5 -0
  145. package/number-input/types.d.ts +124 -0
  146. package/number-input/types.js +5 -0
  147. package/package.json +21 -16
  148. package/paginator/Icons.js +9 -9
  149. package/paginator/Paginator.d.ts +4 -0
  150. package/paginator/Paginator.js +26 -139
  151. package/paginator/Paginator.stories.tsx +63 -0
  152. package/paginator/Paginator.test.js +266 -0
  153. package/paginator/types.d.ts +38 -0
  154. package/paginator/types.js +5 -0
  155. package/password-input/PasswordInput.d.ts +4 -0
  156. package/password-input/PasswordInput.js +37 -77
  157. package/password-input/PasswordInput.stories.tsx +131 -0
  158. package/password-input/PasswordInput.test.js +181 -0
  159. package/password-input/types.d.ts +110 -0
  160. package/password-input/types.js +5 -0
  161. package/progress-bar/ProgressBar.d.ts +4 -0
  162. package/progress-bar/ProgressBar.js +22 -94
  163. package/progress-bar/ProgressBar.stories.jsx +58 -0
  164. package/progress-bar/ProgressBar.test.js +65 -0
  165. package/progress-bar/types.d.ts +37 -0
  166. package/progress-bar/types.js +5 -0
  167. package/quick-nav/QuickNav.d.ts +4 -0
  168. package/quick-nav/QuickNav.js +64 -0
  169. package/quick-nav/QuickNav.stories.tsx +237 -0
  170. package/quick-nav/types.d.ts +21 -0
  171. package/quick-nav/types.js +5 -0
  172. package/radio/Radio.d.ts +4 -0
  173. package/radio/Radio.js +23 -59
  174. package/radio/Radio.stories.tsx +192 -0
  175. package/radio/Radio.test.js +71 -0
  176. package/radio/types.d.ts +54 -0
  177. package/radio/types.js +5 -0
  178. package/radio-group/Radio.d.ts +4 -0
  179. package/radio-group/Radio.js +141 -0
  180. package/radio-group/RadioGroup.d.ts +4 -0
  181. package/radio-group/RadioGroup.js +280 -0
  182. package/radio-group/RadioGroup.stories.tsx +100 -0
  183. package/radio-group/RadioGroup.test.js +695 -0
  184. package/radio-group/types.d.ts +114 -0
  185. package/radio-group/types.js +5 -0
  186. package/resultsetTable/ResultsetTable.d.ts +4 -0
  187. package/resultsetTable/ResultsetTable.js +43 -147
  188. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  189. package/resultsetTable/ResultsetTable.test.js +306 -0
  190. package/resultsetTable/types.d.ts +67 -0
  191. package/resultsetTable/types.js +5 -0
  192. package/row/Row.d.ts +3 -0
  193. package/row/Row.js +127 -0
  194. package/row/Row.stories.tsx +237 -0
  195. package/row/types.d.ts +28 -0
  196. package/row/types.js +5 -0
  197. package/select/Icons.d.ts +10 -0
  198. package/select/Icons.js +93 -0
  199. package/select/Listbox.d.ts +4 -0
  200. package/select/Listbox.js +148 -0
  201. package/select/Option.d.ts +4 -0
  202. package/select/Option.js +110 -0
  203. package/select/Select.d.ts +4 -0
  204. package/select/Select.js +181 -664
  205. package/select/Select.stories.tsx +582 -0
  206. package/select/Select.test.js +2057 -0
  207. package/select/types.d.ts +213 -0
  208. package/select/types.js +5 -0
  209. package/sidenav/Sidenav.d.ts +9 -0
  210. package/sidenav/Sidenav.js +21 -64
  211. package/sidenav/Sidenav.stories.tsx +182 -0
  212. package/sidenav/Sidenav.test.js +56 -0
  213. package/sidenav/types.d.ts +50 -0
  214. package/sidenav/types.js +5 -0
  215. package/slider/Slider.d.ts +4 -0
  216. package/slider/Slider.js +76 -162
  217. package/slider/Slider.stories.tsx +177 -0
  218. package/slider/Slider.test.js +150 -0
  219. package/slider/types.d.ts +82 -0
  220. package/slider/types.js +5 -0
  221. package/spinner/Spinner.d.ts +4 -0
  222. package/spinner/Spinner.js +45 -176
  223. package/spinner/Spinner.stories.jsx +103 -0
  224. package/spinner/Spinner.test.js +64 -0
  225. package/spinner/types.d.ts +32 -0
  226. package/spinner/types.js +5 -0
  227. package/stack/Stack.d.ts +3 -0
  228. package/stack/Stack.js +97 -0
  229. package/stack/Stack.stories.tsx +164 -0
  230. package/stack/types.d.ts +24 -0
  231. package/stack/types.js +5 -0
  232. package/switch/Switch.d.ts +4 -0
  233. package/switch/Switch.js +53 -83
  234. package/switch/Switch.stories.tsx +160 -0
  235. package/switch/Switch.test.js +98 -0
  236. package/switch/types.d.ts +62 -0
  237. package/switch/types.js +5 -0
  238. package/table/Table.d.ts +4 -0
  239. package/table/Table.js +12 -26
  240. package/table/Table.stories.jsx +277 -0
  241. package/table/Table.test.js +26 -0
  242. package/table/types.d.ts +21 -0
  243. package/table/types.js +5 -0
  244. package/tabs/Tabs.d.ts +4 -0
  245. package/tabs/Tabs.js +43 -175
  246. package/tabs/Tabs.stories.tsx +118 -0
  247. package/tabs/Tabs.test.js +140 -0
  248. package/tabs/types.d.ts +82 -0
  249. package/tabs/types.js +5 -0
  250. package/tag/Tag.d.ts +4 -0
  251. package/tag/Tag.js +44 -143
  252. package/tag/Tag.stories.tsx +142 -0
  253. package/tag/Tag.test.js +60 -0
  254. package/tag/types.d.ts +69 -0
  255. package/tag/types.js +5 -0
  256. package/text/Text.d.ts +7 -0
  257. package/text/Text.js +30 -0
  258. package/text/Text.stories.tsx +19 -0
  259. package/text-input/TextInput.d.ts +4 -0
  260. package/text-input/TextInput.js +156 -352
  261. package/text-input/TextInput.stories.tsx +474 -0
  262. package/text-input/TextInput.test.js +1712 -0
  263. package/text-input/types.d.ts +166 -0
  264. package/text-input/types.js +5 -0
  265. package/textarea/Textarea.d.ts +4 -0
  266. package/textarea/Textarea.js +48 -131
  267. package/textarea/Textarea.stories.jsx +157 -0
  268. package/textarea/Textarea.test.js +437 -0
  269. package/textarea/types.d.ts +137 -0
  270. package/textarea/types.js +5 -0
  271. package/toggle-group/ToggleGroup.d.ts +4 -0
  272. package/toggle-group/ToggleGroup.js +36 -148
  273. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  274. package/toggle-group/ToggleGroup.test.js +156 -0
  275. package/toggle-group/types.d.ts +105 -0
  276. package/toggle-group/types.js +5 -0
  277. package/useTheme.d.ts +2 -0
  278. package/useTheme.js +2 -2
  279. package/wizard/Wizard.d.ts +4 -0
  280. package/wizard/Wizard.js +106 -221
  281. package/wizard/Wizard.stories.tsx +214 -0
  282. package/wizard/Wizard.test.js +141 -0
  283. package/wizard/types.d.ts +64 -0
  284. package/wizard/types.js +5 -0
  285. package/ThemeContext.js +0 -250
  286. package/V3Select/V3Select.js +0 -549
  287. package/V3Select/index.d.ts +0 -27
  288. package/V3Textarea/V3Textarea.js +0 -264
  289. package/V3Textarea/index.d.ts +0 -27
  290. package/accordion/index.d.ts +0 -28
  291. package/accordion-group/index.d.ts +0 -16
  292. package/alert/index.d.ts +0 -51
  293. package/box/index.d.ts +0 -25
  294. package/button/Button.stories.js +0 -27
  295. package/button/index.d.ts +0 -24
  296. package/card/index.d.ts +0 -22
  297. package/checkbox/index.d.ts +0 -24
  298. package/chip/index.d.ts +0 -22
  299. package/date/Date.js +0 -379
  300. package/date/index.d.ts +0 -27
  301. package/date-input/index.d.ts +0 -95
  302. package/dialog/index.d.ts +0 -18
  303. package/dropdown/index.d.ts +0 -26
  304. package/file-input/index.d.ts +0 -81
  305. package/footer/index.d.ts +0 -25
  306. package/header/index.d.ts +0 -25
  307. package/heading/index.d.ts +0 -17
  308. package/input-text/Icons.js +0 -22
  309. package/input-text/InputText.js +0 -705
  310. package/input-text/index.d.ts +0 -36
  311. package/link/index.d.ts +0 -23
  312. package/number-input/index.d.ts +0 -113
  313. package/paginator/index.d.ts +0 -20
  314. package/password-input/index.d.ts +0 -94
  315. package/progress-bar/index.d.ts +0 -18
  316. package/radio/index.d.ts +0 -23
  317. package/resultsetTable/index.d.ts +0 -19
  318. package/select/index.d.ts +0 -131
  319. package/sidenav/index.d.ts +0 -13
  320. package/slider/index.d.ts +0 -29
  321. package/spinner/index.d.ts +0 -17
  322. package/switch/index.d.ts +0 -24
  323. package/table/index.d.ts +0 -13
  324. package/tabs/index.d.ts +0 -19
  325. package/tag/index.d.ts +0 -24
  326. package/text-input/index.d.ts +0 -135
  327. package/textarea/index.d.ts +0 -117
  328. package/toggle/Toggle.js +0 -220
  329. package/toggle/index.d.ts +0 -21
  330. package/toggle-group/index.d.ts +0 -21
  331. package/upload/Upload.js +0 -205
  332. package/upload/buttons-upload/ButtonsUpload.js +0 -135
  333. package/upload/buttons-upload/Icons.js +0 -40
  334. package/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  335. package/upload/dragAndDropArea/Icons.js +0 -39
  336. package/upload/file-upload/FileToUpload.js +0 -189
  337. package/upload/file-upload/Icons.js +0 -66
  338. package/upload/files-upload/FilesToUpload.js +0 -123
  339. package/upload/index.d.ts +0 -15
  340. package/upload/transaction/Icons.js +0 -160
  341. package/upload/transaction/Transaction.js +0 -148
  342. package/upload/transactions/Transactions.js +0 -138
  343. package/wizard/Icons.js +0 -65
  344. package/wizard/index.d.ts +0 -18
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dxc-technology/halstack-react",
3
- "version": "4.0.1",
3
+ "version": "5.0.0",
4
4
  "description": "DXC Halstack React components library",
5
5
  "repository": "dxc-technology/halstack-react",
6
6
  "homepage": "http://developer.dxc.com/tools/react",
@@ -18,42 +18,45 @@
18
18
  "styled-components": "^5.0.1"
19
19
  },
20
20
  "dependencies": {
21
- "@date-io/date-fns": "^1.3.9",
21
+ "@date-io/dayjs": "^1.3.9",
22
22
  "@material-ui/core": "4.11.1",
23
23
  "@material-ui/icons": "4.4.3",
24
24
  "@material-ui/lab": "4.0.0-alpha.17",
25
25
  "@material-ui/pickers": "3.2.2",
26
26
  "@material-ui/styles": "4.0.2",
27
- "@testing-library/user-event": "^12.6.3",
27
+ "@types/styled-components": "^5.1.24",
28
+ "@types/uuid": "^8.3.4",
28
29
  "color": "^3.1.3",
29
- "date-fns": "^2.0.0-beta.4",
30
- "moment": "2.24.0",
30
+ "dayjs": "^1.11.1",
31
31
  "prop-types": "^15.7.2",
32
32
  "rgb-hex": "^3.0.0",
33
+ "slugify": "^1.6.5",
33
34
  "uuid": "^8.3.2"
34
35
  },
35
36
  "scripts": {
36
37
  "test": "jest",
37
38
  "test:watch": "npm test -- --watch --coverage",
38
- "build": "babel src --out-dir ../dist --copy-files --verbose && node ../scripts/build/copy-readme.js",
39
- "build:watch": "babel src --watch --out-dir ../dist --copy-files --verbose",
39
+ "build": "babel src --extensions .js,.jsx,.ts,.tsx --out-dir ../dist --copy-files --verbose && node ../scripts/build/copy-package.js && tsc ",
40
+ "build:watch": "babel src --watch --extensions .js,.jsx,.ts,.tsx --out-dir ../dist --copy-files --verbose",
40
41
  "storybook": "start-storybook -p 6006",
41
42
  "build-storybook": "build-storybook"
42
43
  },
43
44
  "devDependencies": {
44
- "@babel/cli": "^7.6.2",
45
- "@babel/core": "^7.6.2",
46
- "@babel/plugin-proposal-class-properties": "^7.5.5",
47
- "@babel/plugin-proposal-nullish-coalescing-operator": "7.13.8",
48
- "@babel/plugin-proposal-optional-chaining": "7.13.8",
49
- "@babel/plugin-transform-runtime": "^7.10.1",
50
- "@babel/preset-env": "^7.6.2",
51
- "@babel/preset-react": "^7.0.0",
45
+ "@babel/cli": "^7.16.8",
46
+ "@babel/core": "^7.16.7",
47
+ "@babel/plugin-proposal-nullish-coalescing-operator": "^7.13.8",
48
+ "@babel/plugin-proposal-optional-chaining": "^7.13.8",
49
+ "@babel/plugin-transform-runtime": "^7.16.8",
50
+ "@babel/preset-env": "^7.16.8",
51
+ "@babel/preset-react": "^7.16.7",
52
+ "@babel/preset-typescript": "^7.16.7",
52
53
  "@storybook/addon-actions": "^6.4.9",
53
54
  "@storybook/addon-essentials": "^6.4.9",
54
55
  "@storybook/addon-links": "^6.4.9",
55
56
  "@storybook/react": "^6.4.9",
57
+ "@storybook/testing-library": "0.0.7",
56
58
  "@testing-library/react": "^11.2.5",
59
+ "@testing-library/user-event": "^12.6.3",
57
60
  "babel-jest": "^24.8.0",
58
61
  "babel-loader": "^8.0.6",
59
62
  "chromatic": "^6.3.3",
@@ -70,8 +73,10 @@
70
73
  "jest": "^25.5.4",
71
74
  "react": "^17.0.1",
72
75
  "react-dom": "^17.0.1",
76
+ "react-test-renderer": "^16.8.6",
77
+ "storybook-addon-pseudo-states": "^1.0.0",
73
78
  "styled-components": "^5.0.1",
74
- "react-test-renderer": "^16.8.6"
79
+ "typescript": "^4.5.4"
75
80
  },
76
81
  "jest": {
77
82
  "moduleNameMapper": {
@@ -5,16 +5,16 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.lastIcon = exports.nextIcon = exports.previousIcon = exports.firstIcon = void 0;
8
+ exports.previousIcon = exports.nextIcon = exports.lastIcon = exports.firstIcon = void 0;
9
9
 
10
10
  var _react = _interopRequireDefault(require("react"));
11
11
 
12
- var firstIcon = _react["default"].createElement("svg", {
12
+ var firstIcon = /*#__PURE__*/_react["default"].createElement("svg", {
13
13
  xmlns: "http://www.w3.org/2000/svg",
14
14
  width: "12.41",
15
15
  height: "12",
16
16
  viewBox: "0 0 12.41 12"
17
- }, _react["default"].createElement("path", {
17
+ }, /*#__PURE__*/_react["default"].createElement("path", {
18
18
  id: "Path_2463",
19
19
  "data-name": "Path 2463",
20
20
  d: "M18.41,16.59,13.82,12l4.59-4.59L17,6l-6,6,6,6ZM6,6H8V18H6Z",
@@ -23,12 +23,12 @@ var firstIcon = _react["default"].createElement("svg", {
23
23
 
24
24
  exports.firstIcon = firstIcon;
25
25
 
26
- var previousIcon = _react["default"].createElement("svg", {
26
+ var previousIcon = /*#__PURE__*/_react["default"].createElement("svg", {
27
27
  xmlns: "http://www.w3.org/2000/svg",
28
28
  width: "7.41",
29
29
  height: "12",
30
30
  viewBox: "0 0 7.41 12"
31
- }, _react["default"].createElement("path", {
31
+ }, /*#__PURE__*/_react["default"].createElement("path", {
32
32
  id: "Path_2459",
33
33
  "data-name": "Path 2459",
34
34
  d: "M15.41,7.41,14,6,8,12l6,6,1.41-1.41L10.83,12Z",
@@ -37,12 +37,12 @@ var previousIcon = _react["default"].createElement("svg", {
37
37
 
38
38
  exports.previousIcon = previousIcon;
39
39
 
40
- var nextIcon = _react["default"].createElement("svg", {
40
+ var nextIcon = /*#__PURE__*/_react["default"].createElement("svg", {
41
41
  xmlns: "http://www.w3.org/2000/svg",
42
42
  width: "7.41",
43
43
  height: "12",
44
44
  viewBox: "0 0 7.41 12"
45
- }, _react["default"].createElement("path", {
45
+ }, /*#__PURE__*/_react["default"].createElement("path", {
46
46
  id: "Path_2461",
47
47
  "data-name": "Path 2461",
48
48
  d: "M10,6,8.59,7.41,13.17,12,8.59,16.59,10,18l6-6Z",
@@ -51,12 +51,12 @@ var nextIcon = _react["default"].createElement("svg", {
51
51
 
52
52
  exports.nextIcon = nextIcon;
53
53
 
54
- var lastIcon = _react["default"].createElement("svg", {
54
+ var lastIcon = /*#__PURE__*/_react["default"].createElement("svg", {
55
55
  xmlns: "http://www.w3.org/2000/svg",
56
56
  width: "12.41",
57
57
  height: "12",
58
58
  viewBox: "0 0 12.41 12"
59
- }, _react["default"].createElement("path", {
59
+ }, /*#__PURE__*/_react["default"].createElement("path", {
60
60
  id: "Path_2465",
61
61
  "data-name": "Path 2465",
62
62
  d: "M5.59,7.41,10.18,12,5.59,16.59,7,18l6-6L7,6ZM16,6h2V18H16Z",
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import PaginatorPropsType from "./types";
3
+ declare const DxcPaginator: ({ currentPage, itemsPerPage, itemsPerPageOptions, totalItems, showGoToPage, onPageChange, itemsPerPageFunction, tabIndex, }: PaginatorPropsType) => JSX.Element;
4
+ export default DxcPaginator;
@@ -1,9 +1,9 @@
1
1
  "use strict";
2
2
 
3
- var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
-
5
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
4
 
5
+ var _typeof = require("@babel/runtime/helpers/typeof");
6
+
7
7
  Object.defineProperty(exports, "__esModule", {
8
8
  value: true
9
9
  });
@@ -11,15 +11,11 @@ exports["default"] = void 0;
11
11
 
12
12
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
13
 
14
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
15
-
16
14
  var _react = _interopRequireDefault(require("react"));
17
15
 
18
16
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
19
17
 
20
- var _propTypes = _interopRequireDefault(require("prop-types"));
21
-
22
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
18
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
23
19
 
24
20
  var _Button = _interopRequireDefault(require("../button/Button"));
25
21
 
@@ -27,97 +23,13 @@ var _Select = _interopRequireDefault(require("../select/Select"));
27
23
 
28
24
  var _Icons = require("./Icons");
29
25
 
30
- var _BackgroundColorContext = require("../BackgroundColorContext.js");
31
-
32
- function _templateObject9() {
33
- var data = (0, _taggedTemplateLiteral2["default"])([""]);
34
-
35
- _templateObject9 = function _templateObject9() {
36
- return data;
37
- };
38
-
39
- return data;
40
- }
41
-
42
- function _templateObject8() {
43
- var data = (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"]);
44
-
45
- _templateObject8 = function _templateObject8() {
46
- return data;
47
- };
48
-
49
- return data;
50
- }
51
-
52
- function _templateObject7() {
53
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n width: 100%;\n justify-content: flex-end;\n align-items: center;\n margin: 0 ", " 0 ", ";\n"]);
54
-
55
- _templateObject7 = function _templateObject7() {
56
- return data;
57
- };
58
-
59
- return data;
60
- }
61
-
62
- function _templateObject6() {
63
- var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: ", ";\n margin-left: ", ";\n"]);
64
-
65
- _templateObject6 = function _templateObject6() {
66
- return data;
67
- };
68
-
69
- return data;
70
- }
71
-
72
- function _templateObject5() {
73
- var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 10px;\n margin-left: 10px;\n"]);
26
+ var _BackgroundColorContext = require("../BackgroundColorContext");
74
27
 
75
- _templateObject5 = function _templateObject5() {
76
- return data;
77
- };
28
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9;
78
29
 
79
- return data;
80
- }
30
+ 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); }
81
31
 
82
- function _templateObject4() {
83
- var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 15px;\n"]);
84
-
85
- _templateObject4 = function _templateObject4() {
86
- return data;
87
- };
88
-
89
- return data;
90
- }
91
-
92
- function _templateObject3() {
93
- var data = (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"]);
94
-
95
- _templateObject3 = function _templateObject3() {
96
- return data;
97
- };
98
-
99
- return data;
100
- }
101
-
102
- function _templateObject2() {
103
- var data = (0, _taggedTemplateLiteral2["default"])(["\n max-width: 100px;\n"]);
104
-
105
- _templateObject2 = function _templateObject2() {
106
- return data;
107
- };
108
-
109
- return data;
110
- }
111
-
112
- function _templateObject() {
113
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n height: ", ";\n width: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n font-style: ", ";\n text-transform: ", ";\n background-color: ", ";\n color: ", ";\n\n button {\n &:disabled {\n background-color: transparent !important;\n opacity: 0.3 !important;\n }\n }\n"]);
114
-
115
- _templateObject = function _templateObject() {
116
- return data;
117
- };
118
-
119
- return data;
120
- }
32
+ 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; }
121
33
 
122
34
  var DxcPaginator = function DxcPaginator(_ref) {
123
35
  var _ref$currentPage = _ref.currentPage,
@@ -137,13 +49,13 @@ var DxcPaginator = function DxcPaginator(_ref) {
137
49
  var minItemsPerPage = currentPageInternal === 1 || currentPageInternal === 0 ? currentPageInternal : (currentPageInternal - 1) * itemsPerPage + 1;
138
50
  var maxItemsPerPage = minItemsPerPage - 1 + itemsPerPage > totalItems ? totalItems : minItemsPerPage - 1 + itemsPerPage;
139
51
  var colorsTheme = (0, _useTheme["default"])();
140
- return _react["default"].createElement(_styledComponents.ThemeProvider, {
52
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
141
53
  theme: colorsTheme.paginator
142
- }, _react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
54
+ }, /*#__PURE__*/_react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
143
55
  color: colorsTheme.paginator.backgroundColor
144
- }, _react["default"].createElement(DxcPaginatorContainer, {
56
+ }, /*#__PURE__*/_react["default"].createElement(DxcPaginatorContainer, {
145
57
  disabled: currentPageInternal === 1
146
- }, _react["default"].createElement(LabelsContainer, null, itemsPerPageOptions && _react["default"].createElement(ItemsPageContainer, null, _react["default"].createElement(ItemsLabel, null, "Items per page "), _react["default"].createElement(SelectContainer, null, _react["default"].createElement(_Select["default"], {
58
+ }, /*#__PURE__*/_react["default"].createElement(LabelsContainer, null, itemsPerPageOptions && /*#__PURE__*/_react["default"].createElement(ItemsPageContainer, null, /*#__PURE__*/_react["default"].createElement(ItemsLabel, null, "Items per page "), /*#__PURE__*/_react["default"].createElement(SelectContainer, null, /*#__PURE__*/_react["default"].createElement(_Select["default"], {
147
59
  options: itemsPerPageOptions.map(function (num) {
148
60
  return {
149
61
  label: num.toString(),
@@ -155,11 +67,8 @@ var DxcPaginator = function DxcPaginator(_ref) {
155
67
  },
156
68
  value: itemsPerPage.toString(),
157
69
  size: "fillParent",
158
- margin: {
159
- top: "xsmall"
160
- },
161
70
  tabIndex: tabIndex
162
- }))), _react["default"].createElement(TotalItemsContainer, null, minItemsPerPage, " to ", maxItemsPerPage, " of ", totalItems), onPageChange && _react["default"].createElement(_Button["default"], {
71
+ }))), /*#__PURE__*/_react["default"].createElement(TotalItemsContainer, null, minItemsPerPage, " to ", maxItemsPerPage, " of ", totalItems), onPageChange && /*#__PURE__*/_react["default"].createElement(_Button["default"], {
163
72
  size: "small",
164
73
  mode: "secondary",
165
74
  disabled: currentPageInternal === 1 || currentPageInternal === 0,
@@ -172,7 +81,7 @@ var DxcPaginator = function DxcPaginator(_ref) {
172
81
  onClick: function onClick() {
173
82
  onPageChange(1);
174
83
  }
175
- }), onPageChange && _react["default"].createElement(_Button["default"], {
84
+ }), onPageChange && /*#__PURE__*/_react["default"].createElement(_Button["default"], {
176
85
  size: "small",
177
86
  mode: "secondary",
178
87
  disabled: currentPageInternal === 1 || currentPageInternal === 0,
@@ -185,8 +94,8 @@ var DxcPaginator = function DxcPaginator(_ref) {
185
94
  onClick: function onClick() {
186
95
  onPageChange(currentPage - 1);
187
96
  }
188
- }), showGoToPage && _react["default"].createElement(PageToSelectContainer, null, _react["default"].createElement(GoToLabel, null, "Go to page: "), _react["default"].createElement(SelectContainer, null, _react["default"].createElement(_Select["default"], {
189
- options: (0, _toConsumableArray2["default"])(Array(totalPages).keys()).map(function (num) {
97
+ }), showGoToPage && /*#__PURE__*/_react["default"].createElement(PageToSelectContainer, null, /*#__PURE__*/_react["default"].createElement(GoToLabel, null, "Go to page: "), /*#__PURE__*/_react["default"].createElement(SelectContainer, null, /*#__PURE__*/_react["default"].createElement(_Select["default"], {
98
+ options: Array.from(Array(totalPages), function (e, num) {
190
99
  return {
191
100
  label: (num + 1).toString(),
192
101
  value: (num + 1).toString()
@@ -197,11 +106,8 @@ var DxcPaginator = function DxcPaginator(_ref) {
197
106
  },
198
107
  value: currentPage.toString(),
199
108
  size: "fillParent",
200
- margin: {
201
- top: "xsmall"
202
- },
203
109
  tabIndex: tabIndex
204
- }))) || _react["default"].createElement(TextContainer, null, "Page: ", currentPageInternal, " of ", totalPages), onPageChange && _react["default"].createElement(_Button["default"], {
110
+ }))) || /*#__PURE__*/_react["default"].createElement(TextContainer, null, "Page: ", currentPageInternal, " of ", totalPages), onPageChange && /*#__PURE__*/_react["default"].createElement(_Button["default"], {
205
111
  size: "small",
206
112
  mode: "secondary",
207
113
  disabled: currentPageInternal === totalPages,
@@ -214,7 +120,7 @@ var DxcPaginator = function DxcPaginator(_ref) {
214
120
  onClick: function onClick() {
215
121
  onPageChange(currentPage + 1);
216
122
  }
217
- }), onPageChange && _react["default"].createElement(_Button["default"], {
123
+ }), onPageChange && /*#__PURE__*/_react["default"].createElement(_Button["default"], {
218
124
  size: "small",
219
125
  mode: "secondary",
220
126
  disabled: currentPageInternal === totalPages,
@@ -230,7 +136,7 @@ var DxcPaginator = function DxcPaginator(_ref) {
230
136
  })))));
231
137
  };
232
138
 
233
- var DxcPaginatorContainer = _styledComponents["default"].div(_templateObject(), function (props) {
139
+ var DxcPaginatorContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n height: ", ";\n width: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n font-style: ", ";\n text-transform: ", ";\n background-color: ", ";\n color: ", ";\n\n button {\n &:disabled {\n background-color: transparent !important;\n opacity: 0.3 !important;\n }\n }\n"])), function (props) {
234
140
  return props.theme.height;
235
141
  }, function (props) {
236
142
  return props.theme.width;
@@ -250,56 +156,37 @@ var DxcPaginatorContainer = _styledComponents["default"].div(_templateObject(),
250
156
  return props.theme.fontColor;
251
157
  });
252
158
 
253
- var SelectContainer = _styledComponents["default"].div(_templateObject2());
159
+ var SelectContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n max-width: 100px;\n"])));
254
160
 
255
- var ItemsPageContainer = _styledComponents["default"].span(_templateObject3(), function (props) {
161
+ 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) {
256
162
  return props.theme.itemsPerPageSelectorMarginRight;
257
163
  }, function (props) {
258
164
  return props.theme.itemsPerPageSelectorMarginLeft;
259
165
  });
260
166
 
261
- var ItemsLabel = _styledComponents["default"].span(_templateObject4());
167
+ var ItemsLabel = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 15px;\n"])));
262
168
 
263
- var GoToLabel = _styledComponents["default"].span(_templateObject5());
169
+ var GoToLabel = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 10px;\n margin-left: 10px;\n"])));
264
170
 
265
- var TotalItemsContainer = _styledComponents["default"].span(_templateObject6(), function (props) {
171
+ var TotalItemsContainer = _styledComponents["default"].span(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: ", ";\n margin-left: ", ";\n"])), function (props) {
266
172
  return props.theme.totalItemsContainerMarginRight;
267
173
  }, function (props) {
268
174
  return props.theme.totalItemsContainerMarginLeft;
269
175
  });
270
176
 
271
- var LabelsContainer = _styledComponents["default"].div(_templateObject7(), function (props) {
177
+ var LabelsContainer = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n width: 100%;\n justify-content: flex-end;\n align-items: center;\n margin: 0 ", " 0 ", ";\n"])), function (props) {
272
178
  return props.theme.marginRight;
273
179
  }, function (props) {
274
180
  return props.theme.marginLeft;
275
181
  });
276
182
 
277
- var PageToSelectContainer = _styledComponents["default"].span(_templateObject8(), function (props) {
183
+ var PageToSelectContainer = _styledComponents["default"].span(_templateObject8 || (_templateObject8 = (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) {
278
184
  return props.theme.pageSelectorMarginRight;
279
185
  }, function (props) {
280
186
  return props.theme.pageSelectorMarginLeft;
281
187
  });
282
188
 
283
- var TextContainer = _styledComponents["default"].span(_templateObject9());
189
+ var TextContainer = _styledComponents["default"].span(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])([""])));
284
190
 
285
- DxcPaginator.propTypes = {
286
- currentPage: _propTypes["default"].number,
287
- itemsPerPage: _propTypes["default"].number,
288
- itemsPerPageOptions: _propTypes["default"].arrayOf(_propTypes["default"].number),
289
- totalItems: _propTypes["default"].number.isRequired,
290
- showGoToPage: _propTypes["default"].bool,
291
- onPageChange: _propTypes["default"].func,
292
- itemsPerPageFunction: _propTypes["default"].func,
293
- tabIndex: _propTypes["default"].number
294
- };
295
- DxcPaginator.defaultProps = {
296
- currentPage: 1,
297
- itemsPerPage: 5,
298
- itemsPerPageOptions: null,
299
- showGoToPage: false,
300
- onPageChange: null,
301
- itemsPerPageFunction: null,
302
- tabIndex: 0
303
- };
304
191
  var _default = DxcPaginator;
305
192
  exports["default"] = _default;
@@ -0,0 +1,63 @@
1
+ import React from "react";
2
+ import DxcPaginator from "./Paginator";
3
+ import Title from "../../.storybook/components/Title";
4
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
+
6
+ export default {
7
+ title: "Paginator",
8
+ component: DxcPaginator,
9
+ };
10
+
11
+ export const Chromatic = () => (
12
+ <>
13
+ <ExampleContainer>
14
+ <Title title="Default" theme="light" level={4} />
15
+ <DxcPaginator />
16
+ </ExampleContainer>
17
+ <ExampleContainer>
18
+ <Title title="Default with items per page options" theme="light" level={4} />
19
+ <DxcPaginator itemsPerPageOptions={[5, 10, 15]} />
20
+ </ExampleContainer>
21
+ <ExampleContainer>
22
+ <Title title="Default with show go to page selector" theme="light" level={4} />
23
+ <DxcPaginator showGoToPage />
24
+ </ExampleContainer>
25
+ <ExampleContainer>
26
+ <Title title="Page change in first page" theme="light" level={4} />
27
+ <DxcPaginator currentPage={1} itemsPerPage={10} totalItems={27} onPageChange={() => {}} />
28
+ </ExampleContainer>
29
+ <ExampleContainer>
30
+ <Title title="Page change in middle page" theme="light" level={4} />
31
+ <DxcPaginator currentPage={2} itemsPerPage={10} totalItems={27} onPageChange={() => {}} />
32
+ </ExampleContainer>
33
+ <ExampleContainer>
34
+ <Title title="Page change in last page" theme="light" level={4} />
35
+ <DxcPaginator currentPage={3} itemsPerPage={10} totalItems={27} onPageChange={() => {}} />
36
+ </ExampleContainer>
37
+ <ExampleContainer>
38
+ <Title title="Page change and items per page options" theme="light" level={4} />
39
+ <DxcPaginator
40
+ currentPage={1}
41
+ itemsPerPage={10}
42
+ totalItems={27}
43
+ onPageChange={() => {}}
44
+ itemsPerPageOptions={[5, 10, 15]}
45
+ />
46
+ </ExampleContainer>
47
+ <ExampleContainer>
48
+ <Title title="Page change and show go to page selector" theme="light" level={4} />
49
+ <DxcPaginator currentPage={1} itemsPerPage={10} totalItems={27} onPageChange={() => {}} showGoToPage />
50
+ </ExampleContainer>
51
+ <ExampleContainer>
52
+ <Title title="Page change, show go to page and items per page selectors" theme="light" level={4} />
53
+ <DxcPaginator
54
+ currentPage={1}
55
+ itemsPerPage={10}
56
+ totalItems={27}
57
+ onPageChange={() => {}}
58
+ itemsPerPageOptions={[5, 10, 15]}
59
+ showGoToPage
60
+ />
61
+ </ExampleContainer>
62
+ </>
63
+ );