@dxc-technology/halstack-react 0.0.0-e628009 → 0.0.0-e78f5f5

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 (377) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +47 -0
  3. package/ThemeContext.d.ts +10 -0
  4. package/ThemeContext.js +243 -0
  5. package/accordion/Accordion.d.ts +4 -0
  6. package/accordion/Accordion.js +247 -0
  7. package/accordion/Accordion.stories.tsx +307 -0
  8. package/accordion/Accordion.test.js +57 -0
  9. package/accordion/types.d.ts +64 -0
  10. package/accordion/types.js +5 -0
  11. package/accordion-group/AccordionGroup.d.ts +7 -0
  12. package/accordion-group/AccordionGroup.js +170 -0
  13. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  14. package/accordion-group/AccordionGroup.test.js +133 -0
  15. package/accordion-group/types.d.ts +68 -0
  16. package/accordion-group/types.js +5 -0
  17. package/alert/Alert.d.ts +4 -0
  18. package/{dist/alert → 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 +59 -0
  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/{dist/box → 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/{dist/button → button}/Button.js +26 -93
  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/{dist/card → card}/Card.js +34 -124
  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/{dist/checkbox → checkbox}/Checkbox.js +18 -65
  53. package/checkbox/Checkbox.stories.tsx +192 -0
  54. package/checkbox/Checkbox.test.js +65 -0
  55. package/checkbox/types.d.ts +60 -0
  56. package/checkbox/types.js +5 -0
  57. package/chip/Chip.d.ts +4 -0
  58. package/chip/Chip.js +161 -0
  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/{dist/common → common}/OpenSans.css +0 -0
  64. package/{dist/common → common}/RequiredComponent.js +3 -11
  65. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  66. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  67. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  68. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  69. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  70. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  71. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  72. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  73. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  74. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  75. package/{dist/common → common}/utils.js +0 -0
  76. package/{dist/common → common}/variables.js +145 -341
  77. package/date-input/DateInput.d.ts +4 -0
  78. package/{dist/date-input → date-input}/DateInput.js +47 -93
  79. package/date-input/DateInput.stories.tsx +138 -0
  80. package/date-input/DateInput.test.js +492 -0
  81. package/date-input/types.d.ts +104 -0
  82. package/date-input/types.js +5 -0
  83. package/dialog/Dialog.d.ts +4 -0
  84. package/{dist/dialog → dialog}/Dialog.js +24 -76
  85. package/dialog/Dialog.stories.tsx +212 -0
  86. package/dialog/Dialog.test.js +40 -0
  87. package/dialog/types.d.ts +43 -0
  88. package/dialog/types.js +5 -0
  89. package/dropdown/Dropdown.d.ts +4 -0
  90. package/{dist/dropdown → dropdown}/Dropdown.js +48 -197
  91. package/dropdown/Dropdown.stories.tsx +249 -0
  92. package/dropdown/Dropdown.test.js +189 -0
  93. package/dropdown/types.d.ts +80 -0
  94. package/dropdown/types.js +5 -0
  95. package/file-input/FileInput.d.ts +4 -0
  96. package/file-input/FileInput.js +590 -0
  97. package/file-input/FileInput.stories.tsx +507 -0
  98. package/file-input/FileInput.test.js +457 -0
  99. package/file-input/FileItem.d.ts +14 -0
  100. package/file-input/FileItem.js +184 -0
  101. package/file-input/types.d.ts +112 -0
  102. package/file-input/types.js +5 -0
  103. package/footer/Footer.d.ts +4 -0
  104. package/footer/Footer.js +258 -0
  105. package/footer/Footer.stories.tsx +130 -0
  106. package/footer/Footer.test.js +109 -0
  107. package/footer/Icons.d.ts +2 -0
  108. package/{dist/footer → footer}/Icons.js +15 -15
  109. package/footer/types.d.ts +65 -0
  110. package/footer/types.js +5 -0
  111. package/header/Header.d.ts +7 -0
  112. package/header/Header.js +324 -0
  113. package/header/Header.stories.tsx +162 -0
  114. package/header/Header.test.js +63 -0
  115. package/header/Icons.d.ts +2 -0
  116. package/{dist/header → header}/Icons.js +7 -32
  117. package/header/types.d.ts +47 -0
  118. package/header/types.js +5 -0
  119. package/heading/Heading.d.ts +4 -0
  120. package/{dist/heading → heading}/Heading.js +25 -96
  121. package/heading/Heading.stories.tsx +54 -0
  122. package/heading/Heading.test.js +186 -0
  123. package/heading/types.d.ts +33 -0
  124. package/heading/types.js +5 -0
  125. package/inset/Inset.d.ts +3 -0
  126. package/inset/Inset.js +84 -0
  127. package/inset/Inset.stories.tsx +229 -0
  128. package/inset/types.d.ts +13 -0
  129. package/inset/types.js +5 -0
  130. package/layout/ApplicationLayout.d.ts +10 -0
  131. package/{dist/layout → layout}/ApplicationLayout.js +47 -143
  132. package/layout/ApplicationLayout.stories.tsx +171 -0
  133. package/{dist/layout → layout}/Icons.js +7 -7
  134. package/layout/types.d.ts +57 -0
  135. package/layout/types.js +5 -0
  136. package/link/Link.d.ts +3 -0
  137. package/{dist/link → link}/Link.js +22 -106
  138. package/link/Link.stories.tsx +151 -0
  139. package/link/Link.test.js +91 -0
  140. package/link/types.d.ts +70 -0
  141. package/link/types.js +5 -0
  142. package/list/List.d.ts +4 -0
  143. package/list/List.js +47 -0
  144. package/list/List.stories.tsx +95 -0
  145. package/list/types.d.ts +7 -0
  146. package/list/types.js +5 -0
  147. package/main.d.ts +46 -0
  148. package/{dist/main.js → main.js} +113 -101
  149. package/number-input/NumberInput.d.ts +4 -0
  150. package/number-input/NumberInput.js +83 -0
  151. package/number-input/NumberInput.stories.tsx +115 -0
  152. package/number-input/NumberInput.test.js +508 -0
  153. package/number-input/NumberInputContext.d.ts +4 -0
  154. package/{dist/number-input → number-input}/NumberInputContext.js +5 -2
  155. package/number-input/numberInputContextTypes.d.ts +19 -0
  156. package/number-input/numberInputContextTypes.js +5 -0
  157. package/number-input/types.d.ts +117 -0
  158. package/number-input/types.js +5 -0
  159. package/package.json +34 -25
  160. package/{dist/paginator → paginator}/Icons.js +9 -9
  161. package/paginator/Paginator.d.ts +4 -0
  162. package/paginator/Paginator.js +192 -0
  163. package/paginator/Paginator.stories.tsx +63 -0
  164. package/paginator/Paginator.test.js +266 -0
  165. package/paginator/types.d.ts +38 -0
  166. package/paginator/types.js +5 -0
  167. package/password-input/PasswordInput.d.ts +4 -0
  168. package/{dist/password-input → password-input}/PasswordInput.js +43 -78
  169. package/password-input/PasswordInput.stories.tsx +131 -0
  170. package/password-input/PasswordInput.test.js +183 -0
  171. package/password-input/types.d.ts +107 -0
  172. package/password-input/types.js +5 -0
  173. package/progress-bar/ProgressBar.d.ts +4 -0
  174. package/{dist/progress-bar → progress-bar}/ProgressBar.js +22 -94
  175. package/progress-bar/ProgressBar.stories.jsx +58 -0
  176. package/progress-bar/ProgressBar.test.js +65 -0
  177. package/progress-bar/types.d.ts +37 -0
  178. package/progress-bar/types.js +5 -0
  179. package/radio/Radio.d.ts +4 -0
  180. package/{dist/radio → radio}/Radio.js +17 -52
  181. package/radio/Radio.stories.tsx +192 -0
  182. package/radio/Radio.test.js +71 -0
  183. package/radio/types.d.ts +54 -0
  184. package/radio/types.js +5 -0
  185. package/radio-group/Radio.d.ts +4 -0
  186. package/radio-group/Radio.js +141 -0
  187. package/radio-group/RadioGroup.d.ts +4 -0
  188. package/radio-group/RadioGroup.js +280 -0
  189. package/radio-group/RadioGroup.stories.tsx +100 -0
  190. package/radio-group/RadioGroup.test.js +695 -0
  191. package/radio-group/types.d.ts +114 -0
  192. package/radio-group/types.js +5 -0
  193. package/resultsetTable/ResultsetTable.d.ts +4 -0
  194. package/{dist/resultsetTable → resultsetTable}/ResultsetTable.js +43 -147
  195. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  196. package/resultsetTable/ResultsetTable.test.js +306 -0
  197. package/resultsetTable/types.d.ts +67 -0
  198. package/resultsetTable/types.js +5 -0
  199. package/row/Row.d.ts +3 -0
  200. package/row/Row.js +127 -0
  201. package/row/Row.stories.tsx +237 -0
  202. package/row/types.d.ts +10 -0
  203. package/row/types.js +5 -0
  204. package/select/Icons.d.ts +10 -0
  205. package/select/Icons.js +93 -0
  206. package/select/Option.d.ts +4 -0
  207. package/select/Option.js +110 -0
  208. package/select/Select.d.ts +4 -0
  209. package/select/Select.js +740 -0
  210. package/select/Select.stories.tsx +582 -0
  211. package/select/Select.test.js +2016 -0
  212. package/select/types.d.ts +191 -0
  213. package/select/types.js +5 -0
  214. package/sidenav/Sidenav.d.ts +9 -0
  215. package/{dist/sidenav → sidenav}/Sidenav.js +21 -64
  216. package/sidenav/Sidenav.stories.tsx +182 -0
  217. package/sidenav/Sidenav.test.js +56 -0
  218. package/sidenav/types.d.ts +50 -0
  219. package/sidenav/types.js +5 -0
  220. package/slider/Slider.d.ts +4 -0
  221. package/{dist/slider → slider}/Slider.js +74 -161
  222. package/slider/Slider.stories.tsx +177 -0
  223. package/slider/Slider.test.js +129 -0
  224. package/slider/types.d.ts +78 -0
  225. package/slider/types.js +5 -0
  226. package/spinner/Spinner.d.ts +4 -0
  227. package/spinner/Spinner.js +250 -0
  228. package/spinner/Spinner.stories.jsx +103 -0
  229. package/spinner/Spinner.test.js +64 -0
  230. package/spinner/types.d.ts +32 -0
  231. package/spinner/types.js +5 -0
  232. package/stack/Stack.d.ts +3 -0
  233. package/stack/Stack.js +97 -0
  234. package/stack/Stack.stories.tsx +164 -0
  235. package/stack/types.d.ts +24 -0
  236. package/stack/types.js +5 -0
  237. package/switch/Switch.d.ts +4 -0
  238. package/{dist/switch → switch}/Switch.js +28 -71
  239. package/switch/Switch.stories.tsx +160 -0
  240. package/switch/Switch.test.js +73 -0
  241. package/switch/types.d.ts +58 -0
  242. package/switch/types.js +5 -0
  243. package/table/Table.d.ts +4 -0
  244. package/{dist/table → table}/Table.js +12 -26
  245. package/table/Table.stories.jsx +277 -0
  246. package/table/Table.test.js +26 -0
  247. package/table/types.d.ts +21 -0
  248. package/table/types.js +5 -0
  249. package/tabs/Tabs.d.ts +4 -0
  250. package/tabs/Tabs.js +213 -0
  251. package/tabs/Tabs.stories.tsx +120 -0
  252. package/tabs/Tabs.test.js +123 -0
  253. package/tabs/types.d.ts +78 -0
  254. package/tabs/types.js +5 -0
  255. package/tag/Tag.d.ts +4 -0
  256. package/tag/Tag.js +186 -0
  257. package/tag/Tag.stories.tsx +142 -0
  258. package/tag/Tag.test.js +60 -0
  259. package/tag/types.d.ts +69 -0
  260. package/tag/types.js +5 -0
  261. package/text/Text.d.ts +7 -0
  262. package/text/Text.js +30 -0
  263. package/text/Text.stories.tsx +19 -0
  264. package/text-input/TextInput.d.ts +4 -0
  265. package/{dist/text-input → text-input}/TextInput.js +286 -459
  266. package/text-input/TextInput.stories.tsx +474 -0
  267. package/text-input/TextInput.test.js +1725 -0
  268. package/text-input/types.d.ts +163 -0
  269. package/text-input/types.js +5 -0
  270. package/textarea/Textarea.d.ts +4 -0
  271. package/{dist/textarea → textarea}/Textarea.js +46 -127
  272. package/textarea/Textarea.stories.jsx +157 -0
  273. package/textarea/Textarea.test.js +447 -0
  274. package/textarea/types.d.ts +134 -0
  275. package/textarea/types.js +5 -0
  276. package/toggle-group/ToggleGroup.d.ts +4 -0
  277. package/{dist/toggle-group → toggle-group}/ToggleGroup.js +35 -148
  278. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  279. package/toggle-group/ToggleGroup.test.js +125 -0
  280. package/toggle-group/types.d.ts +97 -0
  281. package/toggle-group/types.js +5 -0
  282. package/useTheme.d.ts +2 -0
  283. package/{dist/useTheme.js → useTheme.js} +1 -1
  284. package/wizard/Wizard.d.ts +4 -0
  285. package/wizard/Wizard.js +281 -0
  286. package/wizard/Wizard.stories.tsx +224 -0
  287. package/wizard/Wizard.test.js +128 -0
  288. package/wizard/types.d.ts +60 -0
  289. package/wizard/types.js +5 -0
  290. package/README.md +0 -66
  291. package/babel.config.js +0 -8
  292. package/dist/BackgroundColorContext.js +0 -46
  293. package/dist/ThemeContext.js +0 -248
  294. package/dist/V3Textarea/V3Textarea.js +0 -264
  295. package/dist/accordion/Accordion.js +0 -353
  296. package/dist/accordion-group/AccordionGroup.js +0 -186
  297. package/dist/alert/index.d.ts +0 -51
  298. package/dist/badge/Badge.js +0 -63
  299. package/dist/chip/Chip.js +0 -265
  300. package/dist/date/Date.js +0 -379
  301. package/dist/date-input/index.d.ts +0 -95
  302. package/dist/file-input/FileInput.js +0 -644
  303. package/dist/file-input/FileItem.js +0 -280
  304. package/dist/file-input/index.d.ts +0 -81
  305. package/dist/footer/Footer.js +0 -421
  306. package/dist/header/Header.js +0 -434
  307. package/dist/input-text/Icons.js +0 -22
  308. package/dist/input-text/InputText.js +0 -705
  309. package/dist/main.d.ts +0 -8
  310. package/dist/new-select/NewSelect.js +0 -836
  311. package/dist/new-select/index.d.ts +0 -53
  312. package/dist/number-input/NumberInput.js +0 -136
  313. package/dist/number-input/index.d.ts +0 -113
  314. package/dist/paginator/Paginator.js +0 -283
  315. package/dist/password-input/index.d.ts +0 -94
  316. package/dist/select/Select.js +0 -549
  317. package/dist/spinner/Spinner.js +0 -381
  318. package/dist/tabs/Tabs.js +0 -343
  319. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  320. package/dist/tag/Tag.js +0 -282
  321. package/dist/text-input/index.d.ts +0 -135
  322. package/dist/textarea/index.d.ts +0 -117
  323. package/dist/toggle/Toggle.js +0 -220
  324. package/dist/upload/Upload.js +0 -205
  325. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -135
  326. package/dist/upload/buttons-upload/Icons.js +0 -40
  327. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  328. package/dist/upload/dragAndDropArea/Icons.js +0 -39
  329. package/dist/upload/file-upload/FileToUpload.js +0 -189
  330. package/dist/upload/file-upload/Icons.js +0 -66
  331. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  332. package/dist/upload/transaction/Icons.js +0 -160
  333. package/dist/upload/transaction/Transaction.js +0 -148
  334. package/dist/upload/transactions/Transactions.js +0 -138
  335. package/dist/wizard/Icons.js +0 -65
  336. package/dist/wizard/Wizard.js +0 -405
  337. package/test/Accordion.test.js +0 -33
  338. package/test/AccordionGroup.test.js +0 -125
  339. package/test/Alert.test.js +0 -53
  340. package/test/Box.test.js +0 -10
  341. package/test/Button.test.js +0 -18
  342. package/test/Card.test.js +0 -30
  343. package/test/Checkbox.test.js +0 -45
  344. package/test/Chip.test.js +0 -25
  345. package/test/Date.test.js +0 -397
  346. package/test/DateInput.test.js +0 -242
  347. package/test/Dialog.test.js +0 -23
  348. package/test/Dropdown.test.js +0 -145
  349. package/test/FileInput.test.js +0 -201
  350. package/test/Footer.test.js +0 -94
  351. package/test/Header.test.js +0 -34
  352. package/test/Heading.test.js +0 -83
  353. package/test/InputText.test.js +0 -248
  354. package/test/Link.test.js +0 -43
  355. package/test/NumberInput.test.js +0 -259
  356. package/test/Paginator.test.js +0 -177
  357. package/test/PasswordInput.test.js +0 -83
  358. package/test/ProgressBar.test.js +0 -35
  359. package/test/Radio.test.js +0 -37
  360. package/test/ResultsetTable.test.js +0 -329
  361. package/test/Select.test.js +0 -212
  362. package/test/Sidenav.test.js +0 -45
  363. package/test/Slider.test.js +0 -74
  364. package/test/Spinner.test.js +0 -32
  365. package/test/Switch.test.js +0 -45
  366. package/test/Table.test.js +0 -36
  367. package/test/Tabs.test.js +0 -109
  368. package/test/TabsForSections.test.js +0 -34
  369. package/test/Tag.test.js +0 -32
  370. package/test/TextInput.test.js +0 -732
  371. package/test/Textarea.test.js +0 -193
  372. package/test/ToggleGroup.test.js +0 -85
  373. package/test/Upload.test.js +0 -60
  374. package/test/V3TextArea.test.js +0 -51
  375. package/test/Wizard.test.js +0 -130
  376. package/test/mocks/pngMock.js +0 -1
  377. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,266 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _react = _interopRequireDefault(require("react"));
6
+
7
+ var _react2 = require("@testing-library/react");
8
+
9
+ var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
10
+
11
+ var _Paginator = _interopRequireDefault(require("./Paginator"));
12
+
13
+ describe("Paginator component tests", function () {
14
+ test("Paginator renders with default values", function () {
15
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Paginator["default"], null)),
16
+ getByText = _render.getByText;
17
+
18
+ expect(getByText("1 to 1 of 1")).toBeTruthy();
19
+ expect(getByText("Page: 1 of 1")).toBeTruthy();
20
+ });
21
+ test("Paginator renders with currentPage", function () {
22
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
23
+ currentPage: 2
24
+ })),
25
+ getByText = _render2.getByText;
26
+
27
+ expect(getByText("Page: 2 of 1")).toBeTruthy();
28
+ });
29
+ test("Paginator renders with itemsPerPageOptions", function () {
30
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
31
+ currentPage: 1,
32
+ itemsPerPage: 10,
33
+ itemsPerPageOptions: [10, 15],
34
+ totalItems: 20
35
+ })),
36
+ getByText = _render3.getByText;
37
+
38
+ expect(getByText("Items per page")).toBeTruthy();
39
+ });
40
+ test("Paginator renders with itemsPerPageOptions", function () {
41
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
42
+ currentPage: 1,
43
+ itemsPerPage: 10,
44
+ totalItems: 20
45
+ })),
46
+ getByText = _render4.getByText;
47
+
48
+ expect(getByText("1 to 10 of 20")).toBeTruthy();
49
+ expect(getByText("Page: 1 of 2")).toBeTruthy();
50
+ });
51
+ test("Paginator renders with totalItems", function () {
52
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
53
+ totalItems: 20
54
+ })),
55
+ getByText = _render5.getByText;
56
+
57
+ expect(getByText("1 to 5 of 20")).toBeTruthy();
58
+ expect(getByText("Page: 1 of 4")).toBeTruthy();
59
+ });
60
+ test("Paginator renders with correct text in second page", function () {
61
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
62
+ currentPage: 2,
63
+ itemsPerPage: 10,
64
+ totalItems: 20
65
+ })),
66
+ getByText = _render6.getByText;
67
+
68
+ expect(getByText("11 to 20 of 20")).toBeTruthy();
69
+ expect(getByText("Page: 2 of 2")).toBeTruthy();
70
+ });
71
+ test("Paginator renders goToPage select", function () {
72
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
73
+ currentPage: 2,
74
+ showGoToPage: true,
75
+ itemsPerPage: 10,
76
+ totalItems: 20
77
+ })),
78
+ getByText = _render7.getByText;
79
+
80
+ expect(getByText("Go to page:")).toBeTruthy();
81
+ });
82
+ test("Paginator goToPage call correct function", function () {
83
+ var onClick = jest.fn();
84
+
85
+ window.HTMLElement.prototype.scrollIntoView = function () {};
86
+
87
+ window.HTMLElement.prototype.scrollTo = function () {};
88
+
89
+ var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
90
+ currentPage: 1,
91
+ itemsPerPage: 10,
92
+ totalItems: 27,
93
+ showGoToPage: true,
94
+ onPageChange: onClick
95
+ })),
96
+ getByText = _render8.getByText,
97
+ getAllByRole = _render8.getAllByRole,
98
+ getByRole = _render8.getByRole;
99
+
100
+ var goToPageSelect = getAllByRole("combobox")[0];
101
+ (0, _react2.act)(function () {
102
+ _userEvent["default"].click(goToPageSelect);
103
+ });
104
+ var goToPageOption = getByText("2");
105
+ (0, _react2.act)(function () {
106
+ _userEvent["default"].click(goToPageOption);
107
+ });
108
+ expect(onClick).toHaveBeenCalledWith(2);
109
+ });
110
+ test("Call correct goToPageFunction", function () {
111
+ var onClick = jest.fn();
112
+
113
+ var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
114
+ onPageChange: onClick,
115
+ currentPage: 1,
116
+ itemsPerPage: 10,
117
+ totalItems: 20
118
+ })),
119
+ getAllByRole = _render9.getAllByRole;
120
+
121
+ var nextButton = getAllByRole("button")[2];
122
+
123
+ _userEvent["default"].click(nextButton);
124
+
125
+ expect(onClick).toHaveBeenCalled();
126
+ });
127
+ test("Call correct itemsPerPageFunction", function () {
128
+ var onClick = jest.fn();
129
+
130
+ window.HTMLElement.prototype.scrollIntoView = function () {};
131
+
132
+ window.HTMLElement.prototype.scrollTo = function () {};
133
+
134
+ var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
135
+ currentPage: 1,
136
+ itemsPerPage: 10,
137
+ itemsPerPageOptions: [10, 15],
138
+ itemsPerPageFunction: onClick,
139
+ totalItems: 20
140
+ })),
141
+ getAllByText = _render10.getAllByText,
142
+ getByText = _render10.getByText;
143
+
144
+ var select = getAllByText("10")[0];
145
+ (0, _react2.act)(function () {
146
+ _userEvent["default"].click(select);
147
+ });
148
+ var itemPerPageOption = getByText("15");
149
+ (0, _react2.act)(function () {
150
+ _userEvent["default"].click(itemPerPageOption);
151
+ });
152
+ expect(onClick).toHaveBeenCalledWith(15);
153
+ });
154
+ test("Next button is disable in last page", function () {
155
+ var onClick = jest.fn();
156
+
157
+ var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
158
+ onPageChange: onClick,
159
+ currentPage: 2,
160
+ itemsPerPage: 10,
161
+ totalItems: 20
162
+ })),
163
+ getAllByRole = _render11.getAllByRole;
164
+
165
+ var nextButton = getAllByRole("button")[2];
166
+ expect(nextButton.hasAttribute("disabled")).toBeTruthy();
167
+
168
+ _userEvent["default"].click(nextButton);
169
+
170
+ expect(onClick).toHaveBeenCalledTimes(0);
171
+ });
172
+ test("Last button is disable in last page", function () {
173
+ var onClick = jest.fn();
174
+
175
+ var _render12 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
176
+ onPageChange: onClick,
177
+ currentPage: 2,
178
+ itemsPerPage: 10,
179
+ totalItems: 20
180
+ })),
181
+ getAllByRole = _render12.getAllByRole;
182
+
183
+ var lastButton = getAllByRole("button")[3];
184
+ expect(lastButton.hasAttribute("disabled")).toBeTruthy();
185
+
186
+ _userEvent["default"].click(lastButton);
187
+
188
+ expect(onClick).toHaveBeenCalledTimes(0);
189
+ });
190
+ test("First button is disable in first page", function () {
191
+ var onClick = jest.fn();
192
+
193
+ var _render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
194
+ onPageChange: onClick,
195
+ currentPage: 1,
196
+ itemsPerPage: 10,
197
+ totalItems: 20
198
+ })),
199
+ getAllByRole = _render13.getAllByRole;
200
+
201
+ var lastButton = getAllByRole("button")[0];
202
+ expect(lastButton.hasAttribute("disabled")).toBeTruthy();
203
+
204
+ _userEvent["default"].click(lastButton);
205
+
206
+ expect(onClick).toHaveBeenCalledTimes(0);
207
+ });
208
+ test("Previous button is disable in first page", function () {
209
+ var onClick = jest.fn();
210
+
211
+ var _render14 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
212
+ onPageChange: onClick,
213
+ currentPage: 1,
214
+ itemsPerPage: 10,
215
+ totalItems: 20
216
+ })),
217
+ getAllByRole = _render14.getAllByRole;
218
+
219
+ var lastButton = getAllByRole("button")[1];
220
+ expect(lastButton.hasAttribute("disabled")).toBeTruthy();
221
+
222
+ _userEvent["default"].click(lastButton);
223
+
224
+ expect(onClick).toHaveBeenCalledTimes(0);
225
+ });
226
+ test("Last and next buttons are disable in last page", function () {
227
+ var onClick = jest.fn();
228
+
229
+ var _render15 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
230
+ onPageChange: onClick,
231
+ currentPage: 2,
232
+ itemsPerPage: 10,
233
+ totalItems: 20
234
+ })),
235
+ getAllByRole = _render15.getAllByRole;
236
+
237
+ var firstButton = getAllByRole("button")[0];
238
+ var prevButton = getAllByRole("button")[1];
239
+ var nextButton = getAllByRole("button")[2];
240
+ var lastButton = getAllByRole("button")[3];
241
+ expect(firstButton.hasAttribute("disabled")).toBeFalsy();
242
+ expect(prevButton.hasAttribute("disabled")).toBeFalsy();
243
+ expect(nextButton.hasAttribute("disabled")).toBeTruthy();
244
+ expect(lastButton.hasAttribute("disabled")).toBeTruthy();
245
+ });
246
+ test("First and previous buttons are disable in first page", function () {
247
+ var onClick = jest.fn();
248
+
249
+ var _render16 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
250
+ onPageChange: onClick,
251
+ currentPage: 1,
252
+ itemsPerPage: 10,
253
+ totalItems: 20
254
+ })),
255
+ getAllByRole = _render16.getAllByRole;
256
+
257
+ var firstButton = getAllByRole("button")[0];
258
+ var prevButton = getAllByRole("button")[1];
259
+ var nextButton = getAllByRole("button")[2];
260
+ var lastButton = getAllByRole("button")[3];
261
+ expect(firstButton.hasAttribute("disabled")).toBeTruthy();
262
+ expect(prevButton.hasAttribute("disabled")).toBeTruthy();
263
+ expect(nextButton.hasAttribute("disabled")).toBeFalsy();
264
+ expect(lastButton.hasAttribute("disabled")).toBeFalsy();
265
+ });
266
+ });
@@ -0,0 +1,38 @@
1
+ declare type Props = {
2
+ /**
3
+ * Number of the current selected page.
4
+ */
5
+ currentPage?: number;
6
+ /**
7
+ * Number of items per page.
8
+ */
9
+ itemsPerPage?: number;
10
+ /**
11
+ * Array of numbers representing the items per page options.
12
+ * If undefined, the select with items per page options will not be displayed.
13
+ */
14
+ itemsPerPageOptions?: number[];
15
+ /**
16
+ * This function will be called when the user selects an item per page option.
17
+ * The number will be passed as a parameter to this function.
18
+ */
19
+ itemsPerPageFunction?: (val: number) => void;
20
+ /**
21
+ * Total number of items in the pages.
22
+ */
23
+ totalItems?: number;
24
+ /**
25
+ * If true, a select will be displayed with the page numbers to move through them.
26
+ */
27
+ showGoToPage?: boolean;
28
+ /**
29
+ * This function will be called when the user clicks on any of the button to change pages.
30
+ * The page number will be passed as a parameter to this function.
31
+ */
32
+ onPageChange?: (val: number) => void;
33
+ /**
34
+ * Value of the tabindex attribute.
35
+ */
36
+ tabIndex?: number;
37
+ };
38
+ export default Props;
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
@@ -0,0 +1,4 @@
1
+ import React from "react";
2
+ import PasswordInputPropsType from "./types";
3
+ declare const DxcPasswordInput: React.ForwardRefExoticComponent<PasswordInputPropsType & React.RefAttributes<HTMLDivElement>>;
4
+ export default DxcPasswordInput;
@@ -1,16 +1,14 @@
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
  });
10
10
  exports["default"] = void 0;
11
11
 
12
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
13
-
14
12
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
13
 
16
14
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
@@ -19,38 +17,28 @@ var _react = _interopRequireWildcard(require("react"));
19
17
 
20
18
  var _styledComponents = _interopRequireDefault(require("styled-components"));
21
19
 
22
- var _propTypes = _interopRequireDefault(require("prop-types"));
23
-
24
20
  var _TextInput = _interopRequireDefault(require("../text-input/TextInput"));
25
21
 
26
- var _variables = require("../common/variables.js");
27
-
28
- function _templateObject() {
29
- var data = (0, _taggedTemplateLiteral2["default"])(["\n & ::-ms-reveal {\n display: none;\n }\n"]);
22
+ var _templateObject;
30
23
 
31
- _templateObject = function _templateObject() {
32
- return data;
33
- };
24
+ 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); }
34
25
 
35
- return data;
36
- }
26
+ 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; }
37
27
 
38
- var DxcPasswordInput = _react["default"].forwardRef(function (_ref, ref) {
39
- var _ref$label = _ref.label,
40
- label = _ref$label === void 0 ? "" : _ref$label,
28
+ var DxcPasswordInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
29
+ var label = _ref.label,
41
30
  _ref$name = _ref.name,
42
31
  name = _ref$name === void 0 ? "" : _ref$name,
43
32
  value = _ref.value,
44
- _ref$helperText = _ref.helperText,
45
- helperText = _ref$helperText === void 0 ? "" : _ref$helperText,
33
+ helperText = _ref.helperText,
46
34
  _ref$clearable = _ref.clearable,
47
35
  clearable = _ref$clearable === void 0 ? false : _ref$clearable,
48
36
  onChange = _ref.onChange,
49
37
  onBlur = _ref.onBlur,
50
- _ref$error = _ref.error,
51
- error = _ref$error === void 0 ? "" : _ref$error,
38
+ error = _ref.error,
52
39
  pattern = _ref.pattern,
53
- length = _ref.length,
40
+ minLength = _ref.minLength,
41
+ maxLength = _ref.maxLength,
54
42
  _ref$autocomplete = _ref.autocomplete,
55
43
  autocomplete = _ref$autocomplete === void 0 ? "off" : _ref$autocomplete,
56
44
  margin = _ref.margin,
@@ -69,37 +57,43 @@ var DxcPasswordInput = _react["default"].forwardRef(function (_ref, ref) {
69
57
  var setInputType = function setInputType(type) {
70
58
  var _inputRef$current, _inputRef$current$chi;
71
59
 
72
- inputRef === null || inputRef === void 0 ? void 0 : (_inputRef$current = inputRef.current) === null || _inputRef$current === void 0 ? void 0 : (_inputRef$current$chi = _inputRef$current.children[2]) === null || _inputRef$current$chi === void 0 ? void 0 : _inputRef$current$chi.children[0].setAttribute("type", type);
60
+ inputRef === null || inputRef === void 0 ? void 0 : (_inputRef$current = inputRef.current) === null || _inputRef$current === void 0 ? void 0 : (_inputRef$current$chi = _inputRef$current.children[label && helperText ? 2 : label || helperText ? 1 : 0]) === null || _inputRef$current$chi === void 0 ? void 0 : _inputRef$current$chi.children[0].setAttribute("type", type);
73
61
  };
74
62
 
75
63
  var setAriaAttributes = function setAriaAttributes(ariaExpanded, ariaLabel) {
64
+ var inputIndex = label && helperText ? 2 : label || helperText ? 1 : 0;
65
+
76
66
  if (error && clearable && value) {
77
67
  var _inputRef$current2, _inputRef$current2$ch, _inputRef$current2$ch2, _inputRef$current3, _inputRef$current3$ch, _inputRef$current3$ch2;
78
68
 
79
- inputRef === null || inputRef === void 0 ? void 0 : (_inputRef$current2 = inputRef.current) === null || _inputRef$current2 === void 0 ? void 0 : (_inputRef$current2$ch = _inputRef$current2.children[2]) === null || _inputRef$current2$ch === void 0 ? void 0 : (_inputRef$current2$ch2 = _inputRef$current2$ch.children[3]) === null || _inputRef$current2$ch2 === void 0 ? void 0 : _inputRef$current2$ch2.setAttribute("aria-expanded", ariaExpanded);
80
- inputRef === null || inputRef === void 0 ? void 0 : (_inputRef$current3 = inputRef.current) === null || _inputRef$current3 === void 0 ? void 0 : (_inputRef$current3$ch = _inputRef$current3.children[2]) === null || _inputRef$current3$ch === void 0 ? void 0 : (_inputRef$current3$ch2 = _inputRef$current3$ch.children[3]) === null || _inputRef$current3$ch2 === void 0 ? void 0 : _inputRef$current3$ch2.setAttribute("aria-label", ariaLabel);
69
+ inputRef === null || inputRef === void 0 ? void 0 : (_inputRef$current2 = inputRef.current) === null || _inputRef$current2 === void 0 ? void 0 : (_inputRef$current2$ch = _inputRef$current2.children[inputIndex]) === null || _inputRef$current2$ch === void 0 ? void 0 : (_inputRef$current2$ch2 = _inputRef$current2$ch.children[3]) === null || _inputRef$current2$ch2 === void 0 ? void 0 : _inputRef$current2$ch2.setAttribute("aria-expanded", ariaExpanded);
70
+ inputRef === null || inputRef === void 0 ? void 0 : (_inputRef$current3 = inputRef.current) === null || _inputRef$current3 === void 0 ? void 0 : (_inputRef$current3$ch = _inputRef$current3.children[inputIndex]) === null || _inputRef$current3$ch === void 0 ? void 0 : (_inputRef$current3$ch2 = _inputRef$current3$ch.children[3]) === null || _inputRef$current3$ch2 === void 0 ? void 0 : _inputRef$current3$ch2.setAttribute("aria-label", ariaLabel);
81
71
  } else if (error || clearable && !value) {
82
72
  var _inputRef$current4, _inputRef$current4$ch, _inputRef$current4$ch2, _inputRef$current5, _inputRef$current5$ch, _inputRef$current5$ch2;
83
73
 
84
- inputRef === null || inputRef === void 0 ? void 0 : (_inputRef$current4 = inputRef.current) === null || _inputRef$current4 === void 0 ? void 0 : (_inputRef$current4$ch = _inputRef$current4.children[2]) === null || _inputRef$current4$ch === void 0 ? void 0 : (_inputRef$current4$ch2 = _inputRef$current4$ch.children[2]) === null || _inputRef$current4$ch2 === void 0 ? void 0 : _inputRef$current4$ch2.setAttribute("aria-expanded", ariaExpanded);
85
- inputRef === null || inputRef === void 0 ? void 0 : (_inputRef$current5 = inputRef.current) === null || _inputRef$current5 === void 0 ? void 0 : (_inputRef$current5$ch = _inputRef$current5.children[2]) === null || _inputRef$current5$ch === void 0 ? void 0 : (_inputRef$current5$ch2 = _inputRef$current5$ch.children[2]) === null || _inputRef$current5$ch2 === void 0 ? void 0 : _inputRef$current5$ch2.setAttribute("aria-label", ariaLabel);
74
+ inputRef === null || inputRef === void 0 ? void 0 : (_inputRef$current4 = inputRef.current) === null || _inputRef$current4 === void 0 ? void 0 : (_inputRef$current4$ch = _inputRef$current4.children[inputIndex]) === null || _inputRef$current4$ch === void 0 ? void 0 : (_inputRef$current4$ch2 = _inputRef$current4$ch.children[2]) === null || _inputRef$current4$ch2 === void 0 ? void 0 : _inputRef$current4$ch2.setAttribute("aria-expanded", ariaExpanded);
75
+ inputRef === null || inputRef === void 0 ? void 0 : (_inputRef$current5 = inputRef.current) === null || _inputRef$current5 === void 0 ? void 0 : (_inputRef$current5$ch = _inputRef$current5.children[inputIndex]) === null || _inputRef$current5$ch === void 0 ? void 0 : (_inputRef$current5$ch2 = _inputRef$current5$ch.children[2]) === null || _inputRef$current5$ch2 === void 0 ? void 0 : _inputRef$current5$ch2.setAttribute("aria-label", ariaLabel);
86
76
  } else {
87
77
  var _inputRef$current6, _inputRef$current6$ch, _inputRef$current6$ch2, _inputRef$current7, _inputRef$current7$ch, _inputRef$current7$ch2;
88
78
 
89
- inputRef === null || inputRef === void 0 ? void 0 : (_inputRef$current6 = inputRef.current) === null || _inputRef$current6 === void 0 ? void 0 : (_inputRef$current6$ch = _inputRef$current6.children[2]) === null || _inputRef$current6$ch === void 0 ? void 0 : (_inputRef$current6$ch2 = _inputRef$current6$ch.children[1]) === null || _inputRef$current6$ch2 === void 0 ? void 0 : _inputRef$current6$ch2.setAttribute("aria-expanded", ariaExpanded);
90
- inputRef === null || inputRef === void 0 ? void 0 : (_inputRef$current7 = inputRef.current) === null || _inputRef$current7 === void 0 ? void 0 : (_inputRef$current7$ch = _inputRef$current7.children[2]) === null || _inputRef$current7$ch === void 0 ? void 0 : (_inputRef$current7$ch2 = _inputRef$current7$ch.children[1]) === null || _inputRef$current7$ch2 === void 0 ? void 0 : _inputRef$current7$ch2.setAttribute("aria-label", ariaLabel);
79
+ inputRef === null || inputRef === void 0 ? void 0 : (_inputRef$current6 = inputRef.current) === null || _inputRef$current6 === void 0 ? void 0 : (_inputRef$current6$ch = _inputRef$current6.children[inputIndex]) === null || _inputRef$current6$ch === void 0 ? void 0 : (_inputRef$current6$ch2 = _inputRef$current6$ch.children[1]) === null || _inputRef$current6$ch2 === void 0 ? void 0 : _inputRef$current6$ch2.setAttribute("aria-expanded", ariaExpanded);
80
+ inputRef === null || inputRef === void 0 ? void 0 : (_inputRef$current7 = inputRef.current) === null || _inputRef$current7 === void 0 ? void 0 : (_inputRef$current7$ch = _inputRef$current7.children[inputIndex]) === null || _inputRef$current7$ch === void 0 ? void 0 : (_inputRef$current7$ch2 = _inputRef$current7$ch.children[1]) === null || _inputRef$current7$ch2 === void 0 ? void 0 : _inputRef$current7$ch2.setAttribute("aria-label", ariaLabel);
91
81
  }
92
82
  };
93
83
 
84
+ var getIconTitle = function getIconTitle() {
85
+ return isPasswordVisible ? "Hide password" : "Show password";
86
+ };
87
+
94
88
  (0, _react.useEffect)(function () {
95
- setAriaAttributes(false, "Show");
89
+ setAriaAttributes(false, "Show password");
96
90
 
97
91
  if (isPasswordVisible) {
98
92
  setInputType("text");
99
- setAriaAttributes(true, "Hide");
93
+ setAriaAttributes(true, "Hide password");
100
94
  } else {
101
95
  setInputType("password");
102
- setAriaAttributes(false, "Show");
96
+ setAriaAttributes(false, "Show password");
103
97
  }
104
98
  }, [isPasswordVisible]);
105
99
 
@@ -115,33 +109,34 @@ var DxcPasswordInput = _react["default"].forwardRef(function (_ref, ref) {
115
109
 
116
110
  var action = {
117
111
  onClick: isPasswordVisible ? hidePassword : viewPassword,
118
- icon: isPasswordVisible ? _react["default"].createElement("svg", {
112
+ icon: isPasswordVisible ? /*#__PURE__*/_react["default"].createElement("svg", {
119
113
  xmlns: "http://www.w3.org/2000/svg",
120
114
  height: "24px",
121
115
  viewBox: "0 0 24 24",
122
116
  width: "24px",
123
- fill: "#000000"
124
- }, _react["default"].createElement("path", {
117
+ fill: "currentColor"
118
+ }, /*#__PURE__*/_react["default"].createElement("path", {
125
119
  d: "M0 0h24v24H0V0zm0 0h24v24H0V0zm0 0h24v24H0V0zm0 0h24v24H0V0z",
126
120
  fill: "none"
127
- }), _react["default"].createElement("path", {
121
+ }), /*#__PURE__*/_react["default"].createElement("path", {
128
122
  d: "M12 6c3.79 0 7.17 2.13 8.82 5.5-.59 1.22-1.42 2.27-2.41 3.12l1.41 1.41c1.39-1.23 2.49-2.77 3.18-4.53C21.27 7.11 17 4 12 4c-1.27 0-2.49.2-3.64.57l1.65 1.65C10.66 6.09 11.32 6 12 6zm-1.07 1.14L13 9.21c.57.25 1.03.71 1.28 1.28l2.07 2.07c.08-.34.14-.7.14-1.07C16.5 9.01 14.48 7 12 7c-.37 0-.72.05-1.07.14zM2.01 3.87l2.68 2.68C3.06 7.83 1.77 9.53 1 11.5 2.73 15.89 7 19 12 19c1.52 0 2.98-.29 4.32-.82l3.42 3.42 1.41-1.41L3.42 2.45 2.01 3.87zm7.5 7.5l2.61 2.61c-.04.01-.08.02-.12.02-1.38 0-2.5-1.12-2.5-2.5 0-.05.01-.08.01-.13zm-3.4-3.4l1.75 1.75c-.23.55-.36 1.15-.36 1.78 0 2.48 2.02 4.5 4.5 4.5.63 0 1.23-.13 1.77-.36l.98.98c-.88.24-1.8.38-2.75.38-3.79 0-7.17-2.13-8.82-5.5.7-1.43 1.72-2.61 2.93-3.53z"
129
- })) : _react["default"].createElement("svg", {
123
+ })) : /*#__PURE__*/_react["default"].createElement("svg", {
130
124
  xmlns: "http://www.w3.org/2000/svg",
131
125
  height: "24px",
132
126
  viewBox: "0 0 24 24",
133
127
  width: "24px",
134
- fill: "#000000"
135
- }, _react["default"].createElement("path", {
128
+ fill: "currentColor"
129
+ }, /*#__PURE__*/_react["default"].createElement("path", {
136
130
  d: "M0 0h24v24H0V0z",
137
131
  fill: "none"
138
- }), _react["default"].createElement("path", {
132
+ }), /*#__PURE__*/_react["default"].createElement("path", {
139
133
  d: "M12 6c3.79 0 7.17 2.13 8.82 5.5C19.17 14.87 15.79 17 12 17s-7.17-2.13-8.82-5.5C4.83 8.13 8.21 6 12 6m0-2C7 4 2.73 7.11 1 11.5 2.73 15.89 7 19 12 19s9.27-3.11 11-7.5C21.27 7.11 17 4 12 4zm0 5c1.38 0 2.5 1.12 2.5 2.5S13.38 14 12 14s-2.5-1.12-2.5-2.5S10.62 9 12 9m0-2c-2.48 0-4.5 2.02-4.5 4.5S9.52 16 12 16s4.5-2.02 4.5-4.5S14.48 7 12 7z"
140
- }))
134
+ })),
135
+ title: getIconTitle()
141
136
  };
142
- return _react["default"].createElement(PasswordInput, {
137
+ return /*#__PURE__*/_react["default"].createElement(PasswordInput, {
143
138
  ref: ref
144
- }, _react["default"].createElement(_TextInput["default"], {
139
+ }, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
145
140
  ref: inputRef,
146
141
  label: label,
147
142
  name: name,
@@ -155,44 +150,14 @@ var DxcPasswordInput = _react["default"].forwardRef(function (_ref, ref) {
155
150
  margin: margin,
156
151
  size: size,
157
152
  pattern: pattern,
158
- length: length,
153
+ minLength: minLength,
154
+ maxLength: maxLength,
159
155
  autocomplete: autocomplete,
160
156
  tabIndex: tabIndex
161
157
  }));
162
158
  });
163
159
 
164
- var sizes = {
165
- small: "240px",
166
- medium: "360px",
167
- large: "480px",
168
- fillParent: "100%"
169
- };
170
-
171
- var PasswordInput = _styledComponents["default"].div(_templateObject());
172
-
173
- DxcPasswordInput.propTypes = {
174
- label: _propTypes["default"].string,
175
- name: _propTypes["default"].string,
176
- value: _propTypes["default"].string,
177
- helperText: _propTypes["default"].string,
178
- error: _propTypes["default"].string,
179
- clearable: _propTypes["default"].bool,
180
- onChange: _propTypes["default"].func,
181
- onBlur: _propTypes["default"].func,
182
- autocomplete: _propTypes["default"].string,
183
- margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
184
- top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
185
- bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
186
- left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
187
- right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
188
- }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))]),
189
- size: _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(sizes))),
190
- pattern: _propTypes["default"].string,
191
- length: _propTypes["default"].shape({
192
- min: _propTypes["default"].number,
193
- max: _propTypes["default"].number
194
- }),
195
- tabIndex: _propTypes["default"].number
196
- };
160
+ var PasswordInput = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n & ::-ms-reveal {\n display: none;\n }\n"])));
161
+
197
162
  var _default = DxcPasswordInput;
198
163
  exports["default"] = _default;
@@ -0,0 +1,131 @@
1
+ import React from "react";
2
+ import { userEvent, within } from "@storybook/testing-library";
3
+ import DxcPasswordInput from "./PasswordInput";
4
+ import { BackgroundColorProvider } from "../BackgroundColorContext";
5
+ import Title from "../../.storybook/components/Title";
6
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
7
+ import DarkContainer from "../../.storybook/components/DarkSection";
8
+
9
+ export default {
10
+ title: "Password input",
11
+ component: DxcPasswordInput,
12
+ };
13
+
14
+ export const Chromatic = () => (
15
+ <>
16
+ <ExampleContainer>
17
+ <Title title="Without label" theme="light" level={4} />
18
+ <DxcPasswordInput />
19
+ </ExampleContainer>
20
+ <ExampleContainer>
21
+ <Title title="With label" theme="light" level={4} />
22
+ <DxcPasswordInput label="Password input" clearable />
23
+ </ExampleContainer>
24
+ <ExampleContainer>
25
+ <Title title="Clearable" theme="light" level={4} />
26
+ <DxcPasswordInput label="Password input" clearable value="password" />
27
+ </ExampleContainer>
28
+ <ExampleContainer>
29
+ <Title title="Non clearable" theme="light" level={4} />
30
+ <DxcPasswordInput label="Non clearable password input" value="password" />
31
+ </ExampleContainer>
32
+ <ExampleContainer>
33
+ <Title title="Helper text" theme="light" level={4} />
34
+ <DxcPasswordInput label="Help password input" helperText="Help message" />
35
+ </ExampleContainer>
36
+ <ExampleContainer>
37
+ <Title title="Invalid" theme="light" level={4} />
38
+ <DxcPasswordInput label="Error password input" error="Error message." />
39
+ </ExampleContainer>
40
+ <BackgroundColorProvider color="#333333">
41
+ <DarkContainer>
42
+ <Title title="Dark" theme="dark" level={2} />
43
+ <ExampleContainer>
44
+ <Title title="With label, helper text and value" theme="dark" level={4} />
45
+ <DxcPasswordInput label="Password input" helperText="Help message" value="Password" />
46
+ </ExampleContainer>
47
+ <ExampleContainer>
48
+ <Title title="With label, helper text, value and error" theme="dark" level={4} />
49
+ <DxcPasswordInput label="Password input" helperText="Help message" error="Error message." value="Password" />
50
+ </ExampleContainer>
51
+ </DarkContainer>
52
+ </BackgroundColorProvider>
53
+ <Title title="Margins" theme="light" level={2} />
54
+ <ExampleContainer>
55
+ <Title title="Xxsmall margin" theme="light" level={4} />
56
+ <DxcPasswordInput label="Xxsmall" margin="xxsmall" />
57
+ </ExampleContainer>
58
+ <ExampleContainer>
59
+ <Title title="Xsmall margin" theme="light" level={4} />
60
+ <DxcPasswordInput label="Xsmall" margin="xsmall" />
61
+ </ExampleContainer>
62
+ <ExampleContainer>
63
+ <Title title="Small margin" theme="light" level={4} />
64
+ <DxcPasswordInput label="Small" margin="small" />
65
+ </ExampleContainer>
66
+ <ExampleContainer>
67
+ <Title title="Medium margin" theme="light" level={4} />
68
+ <DxcPasswordInput label="Medium" margin="medium" />
69
+ </ExampleContainer>
70
+ <ExampleContainer>
71
+ <Title title="Large margin" theme="light" level={4} />
72
+ <DxcPasswordInput label="Large" margin="large" />
73
+ </ExampleContainer>
74
+ <ExampleContainer>
75
+ <Title title="Xlarge margin" theme="light" level={4} />
76
+ <DxcPasswordInput label="Xlarge" margin="xlarge" />
77
+ </ExampleContainer>
78
+ <ExampleContainer>
79
+ <Title title="Xxlarge margin" theme="light" level={4} />
80
+ <DxcPasswordInput label="Xxlarge" margin="xxlarge" />
81
+ </ExampleContainer>
82
+ <Title title="Sizes" theme="light" level={2} />
83
+ <ExampleContainer>
84
+ <Title title="Small size" theme="light" level={4} />
85
+ <DxcPasswordInput label="Small" size="small" />
86
+ </ExampleContainer>
87
+ <ExampleContainer>
88
+ <Title title="Medium size" theme="light" level={4} />
89
+ <DxcPasswordInput label="Medium" size="medium" />
90
+ </ExampleContainer>
91
+ <ExampleContainer>
92
+ <Title title="Large size" theme="light" level={4} />
93
+ <DxcPasswordInput label="Large" size="large" />
94
+ </ExampleContainer>
95
+ <ExampleContainer>
96
+ <Title title="FillParent size" theme="light" level={4} />
97
+ <DxcPasswordInput label="FillParent" size="fillParent" />
98
+ </ExampleContainer>
99
+ </>
100
+ );
101
+
102
+ const Password = () => (
103
+ <ExampleContainer expanded>
104
+ <Title title="Show password" theme="light" level={4} />
105
+ <DxcPasswordInput label="Password input" value="Password" />
106
+ </ExampleContainer>
107
+ );
108
+ const PasswordDark = () => (
109
+ <BackgroundColorProvider color="#333333">
110
+ <DarkContainer>
111
+ <ExampleContainer expanded>
112
+ <Title title="Show password" theme="dark" level={4} />
113
+ <DxcPasswordInput label="Password input" value="Password" />
114
+ </ExampleContainer>
115
+ </DarkContainer>
116
+ </BackgroundColorProvider>
117
+ );
118
+
119
+ export const ShowPassword = Password.bind({});
120
+ ShowPassword.play = async ({ canvasElement }) => {
121
+ const canvas = within(canvasElement);
122
+ const passwordBtn = canvas.getByRole("button");
123
+ await userEvent.click(passwordBtn);
124
+ };
125
+
126
+ export const ShowPasswordDark = PasswordDark.bind({});
127
+ ShowPasswordDark.play = async ({ canvasElement }) => {
128
+ const canvas = within(canvasElement);
129
+ const passwordBtn = canvas.getByRole("button");
130
+ await userEvent.click(passwordBtn);
131
+ };