@dxc-technology/halstack-react 0.0.0-f4bae62 → 0.0.0-f54247d

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 (462) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +47 -0
  3. package/HalstackContext.d.ts +12 -0
  4. package/HalstackContext.js +294 -0
  5. package/accordion/Accordion.d.ts +4 -0
  6. package/accordion/Accordion.js +245 -0
  7. package/accordion/Accordion.stories.tsx +306 -0
  8. package/accordion/Accordion.test.js +71 -0
  9. package/accordion/types.d.ts +69 -0
  10. package/accordion/types.js +5 -0
  11. package/accordion-group/AccordionGroup.d.ts +7 -0
  12. package/accordion-group/AccordionGroup.js +149 -0
  13. package/accordion-group/AccordionGroup.stories.tsx +251 -0
  14. package/accordion-group/AccordionGroup.test.js +126 -0
  15. package/accordion-group/types.d.ts +79 -0
  16. package/accordion-group/types.js +5 -0
  17. package/alert/Alert.d.ts +4 -0
  18. package/{dist/alert → alert}/Alert.js +44 -154
  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 +61 -0
  25. package/badge/types.d.ts +5 -0
  26. package/badge/types.js +5 -0
  27. package/bleed/Bleed.d.ts +3 -0
  28. package/bleed/Bleed.js +51 -0
  29. package/bleed/Bleed.stories.tsx +341 -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 +116 -0
  34. package/box/Box.stories.tsx +132 -0
  35. package/box/Box.test.js +18 -0
  36. package/box/types.d.ts +44 -0
  37. package/box/types.js +5 -0
  38. package/bulleted-list/BulletedList.d.ts +7 -0
  39. package/bulleted-list/BulletedList.js +123 -0
  40. package/bulleted-list/BulletedList.stories.tsx +200 -0
  41. package/bulleted-list/types.d.ts +11 -0
  42. package/bulleted-list/types.js +5 -0
  43. package/button/Button.d.ts +4 -0
  44. package/button/Button.js +156 -0
  45. package/button/Button.stories.tsx +283 -0
  46. package/button/Button.test.js +35 -0
  47. package/button/types.d.ts +53 -0
  48. package/button/types.js +5 -0
  49. package/card/Card.d.ts +4 -0
  50. package/card/Card.js +161 -0
  51. package/card/Card.stories.tsx +201 -0
  52. package/card/Card.test.js +50 -0
  53. package/card/ice-cream.jpg +0 -0
  54. package/card/types.d.ts +68 -0
  55. package/card/types.js +5 -0
  56. package/checkbox/Checkbox.d.ts +4 -0
  57. package/checkbox/Checkbox.js +250 -0
  58. package/checkbox/Checkbox.stories.tsx +208 -0
  59. package/checkbox/Checkbox.test.js +155 -0
  60. package/checkbox/types.d.ts +68 -0
  61. package/checkbox/types.js +5 -0
  62. package/chip/Chip.d.ts +4 -0
  63. package/chip/Chip.js +161 -0
  64. package/chip/Chip.stories.tsx +119 -0
  65. package/chip/Chip.test.js +56 -0
  66. package/chip/types.d.ts +45 -0
  67. package/chip/types.js +5 -0
  68. package/{dist/common → common}/OpenSans.css +0 -0
  69. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  70. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  71. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  72. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  73. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  74. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  75. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  76. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  77. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  78. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  79. package/{dist/common → common}/utils.js +0 -0
  80. package/{dist/common → common}/variables.js +383 -440
  81. package/date-input/Calendar.d.ts +4 -0
  82. package/date-input/Calendar.js +258 -0
  83. package/date-input/DateInput.d.ts +4 -0
  84. package/date-input/DateInput.js +227 -0
  85. package/date-input/DateInput.stories.tsx +151 -0
  86. package/date-input/DateInput.test.js +752 -0
  87. package/date-input/DatePicker.d.ts +4 -0
  88. package/date-input/DatePicker.js +160 -0
  89. package/date-input/YearPicker.d.ts +4 -0
  90. package/date-input/YearPicker.js +115 -0
  91. package/date-input/types.d.ts +160 -0
  92. package/date-input/types.js +5 -0
  93. package/dialog/Dialog.d.ts +4 -0
  94. package/dialog/Dialog.js +162 -0
  95. package/dialog/Dialog.stories.tsx +267 -0
  96. package/dialog/Dialog.test.js +70 -0
  97. package/dialog/types.d.ts +44 -0
  98. package/dialog/types.js +5 -0
  99. package/dropdown/Dropdown.d.ts +4 -0
  100. package/dropdown/Dropdown.js +391 -0
  101. package/dropdown/Dropdown.stories.tsx +312 -0
  102. package/dropdown/Dropdown.test.js +585 -0
  103. package/dropdown/DropdownMenu.d.ts +4 -0
  104. package/dropdown/DropdownMenu.js +80 -0
  105. package/dropdown/DropdownMenuItem.d.ts +4 -0
  106. package/dropdown/DropdownMenuItem.js +92 -0
  107. package/dropdown/types.d.ts +100 -0
  108. package/dropdown/types.js +5 -0
  109. package/file-input/FileInput.d.ts +4 -0
  110. package/file-input/FileInput.js +551 -0
  111. package/file-input/FileInput.stories.tsx +535 -0
  112. package/file-input/FileInput.test.js +498 -0
  113. package/file-input/FileItem.d.ts +4 -0
  114. package/file-input/FileItem.js +161 -0
  115. package/file-input/types.d.ts +129 -0
  116. package/file-input/types.js +5 -0
  117. package/flex/Flex.d.ts +4 -0
  118. package/flex/Flex.js +69 -0
  119. package/flex/Flex.stories.tsx +103 -0
  120. package/flex/types.d.ts +32 -0
  121. package/flex/types.js +5 -0
  122. package/footer/Footer.d.ts +4 -0
  123. package/footer/Footer.js +185 -0
  124. package/footer/Footer.stories.tsx +137 -0
  125. package/footer/Footer.test.js +109 -0
  126. package/footer/Icons.d.ts +2 -0
  127. package/{dist/footer → footer}/Icons.js +16 -16
  128. package/footer/types.d.ts +66 -0
  129. package/footer/types.js +5 -0
  130. package/header/Header.d.ts +7 -0
  131. package/header/Header.js +305 -0
  132. package/header/Header.stories.tsx +172 -0
  133. package/header/Header.test.js +79 -0
  134. package/header/Icons.d.ts +2 -0
  135. package/{dist/header → header}/Icons.js +9 -34
  136. package/header/types.d.ts +48 -0
  137. package/header/types.js +5 -0
  138. package/heading/Heading.d.ts +4 -0
  139. package/{dist/heading → heading}/Heading.js +31 -90
  140. package/heading/Heading.stories.tsx +54 -0
  141. package/heading/Heading.test.js +186 -0
  142. package/heading/types.d.ts +33 -0
  143. package/heading/types.js +5 -0
  144. package/inset/Inset.d.ts +3 -0
  145. package/inset/Inset.js +51 -0
  146. package/inset/Inset.stories.tsx +229 -0
  147. package/inset/types.d.ts +37 -0
  148. package/inset/types.js +5 -0
  149. package/layout/ApplicationLayout.d.ts +20 -0
  150. package/layout/ApplicationLayout.js +171 -0
  151. package/layout/ApplicationLayout.stories.tsx +162 -0
  152. package/layout/Icons.d.ts +5 -0
  153. package/{dist/layout → layout}/Icons.js +19 -8
  154. package/layout/SidenavContext.d.ts +5 -0
  155. package/layout/SidenavContext.js +19 -0
  156. package/layout/types.d.ts +42 -0
  157. package/layout/types.js +5 -0
  158. package/link/Link.d.ts +4 -0
  159. package/link/Link.js +136 -0
  160. package/link/Link.stories.tsx +193 -0
  161. package/link/Link.test.js +83 -0
  162. package/link/types.d.ts +54 -0
  163. package/link/types.js +5 -0
  164. package/main.d.ts +44 -0
  165. package/{dist/main.js → main.js} +111 -109
  166. package/number-input/NumberInput.d.ts +4 -0
  167. package/number-input/NumberInput.js +76 -0
  168. package/number-input/NumberInput.stories.tsx +115 -0
  169. package/number-input/NumberInput.test.js +542 -0
  170. package/number-input/NumberInputContext.d.ts +4 -0
  171. package/{dist/number-input → number-input}/NumberInputContext.js +5 -2
  172. package/number-input/numberInputContextTypes.d.ts +19 -0
  173. package/number-input/numberInputContextTypes.js +5 -0
  174. package/number-input/types.d.ts +124 -0
  175. package/number-input/types.js +5 -0
  176. package/package.json +46 -40
  177. package/{dist/paginator → paginator}/Icons.js +9 -9
  178. package/paginator/Paginator.d.ts +4 -0
  179. package/paginator/Paginator.js +171 -0
  180. package/paginator/Paginator.stories.tsx +63 -0
  181. package/paginator/Paginator.test.js +308 -0
  182. package/paginator/types.d.ts +38 -0
  183. package/paginator/types.js +5 -0
  184. package/paragraph/Paragraph.d.ts +6 -0
  185. package/paragraph/Paragraph.js +38 -0
  186. package/paragraph/Paragraph.stories.tsx +44 -0
  187. package/password-input/PasswordInput.d.ts +4 -0
  188. package/{dist/password-input → password-input}/PasswordInput.js +45 -77
  189. package/password-input/PasswordInput.stories.tsx +131 -0
  190. package/password-input/PasswordInput.test.js +181 -0
  191. package/password-input/types.d.ts +110 -0
  192. package/password-input/types.js +5 -0
  193. package/progress-bar/ProgressBar.d.ts +4 -0
  194. package/progress-bar/ProgressBar.js +176 -0
  195. package/progress-bar/ProgressBar.stories.jsx +60 -0
  196. package/progress-bar/ProgressBar.test.js +110 -0
  197. package/progress-bar/types.d.ts +36 -0
  198. package/progress-bar/types.js +5 -0
  199. package/quick-nav/QuickNav.d.ts +4 -0
  200. package/quick-nav/QuickNav.js +117 -0
  201. package/quick-nav/QuickNav.stories.tsx +342 -0
  202. package/quick-nav/types.d.ts +21 -0
  203. package/quick-nav/types.js +5 -0
  204. package/radio-group/Radio.d.ts +4 -0
  205. package/radio-group/Radio.js +156 -0
  206. package/radio-group/RadioGroup.d.ts +4 -0
  207. package/radio-group/RadioGroup.js +283 -0
  208. package/radio-group/RadioGroup.stories.tsx +101 -0
  209. package/radio-group/RadioGroup.test.js +722 -0
  210. package/radio-group/types.d.ts +114 -0
  211. package/radio-group/types.js +5 -0
  212. package/resultsetTable/Icons.d.ts +7 -0
  213. package/resultsetTable/Icons.js +51 -0
  214. package/resultsetTable/ResultsetTable.d.ts +4 -0
  215. package/resultsetTable/ResultsetTable.js +195 -0
  216. package/resultsetTable/ResultsetTable.stories.tsx +300 -0
  217. package/resultsetTable/ResultsetTable.test.js +330 -0
  218. package/resultsetTable/types.d.ts +67 -0
  219. package/resultsetTable/types.js +5 -0
  220. package/select/Icons.d.ts +10 -0
  221. package/select/Icons.js +93 -0
  222. package/select/Listbox.d.ts +4 -0
  223. package/select/Listbox.js +198 -0
  224. package/select/Option.d.ts +4 -0
  225. package/select/Option.js +110 -0
  226. package/select/Select.d.ts +4 -0
  227. package/select/Select.js +645 -0
  228. package/select/Select.stories.tsx +624 -0
  229. package/select/Select.test.js +2233 -0
  230. package/select/types.d.ts +210 -0
  231. package/select/types.js +5 -0
  232. package/sidenav/Sidenav.d.ts +10 -0
  233. package/sidenav/Sidenav.js +268 -0
  234. package/sidenav/Sidenav.stories.tsx +180 -0
  235. package/sidenav/Sidenav.test.js +44 -0
  236. package/sidenav/types.d.ts +73 -0
  237. package/sidenav/types.js +5 -0
  238. package/slider/Slider.d.ts +4 -0
  239. package/slider/Slider.js +343 -0
  240. package/slider/Slider.stories.tsx +183 -0
  241. package/slider/Slider.test.js +250 -0
  242. package/slider/types.d.ts +86 -0
  243. package/slider/types.js +5 -0
  244. package/spinner/Spinner.d.ts +4 -0
  245. package/spinner/Spinner.js +250 -0
  246. package/spinner/Spinner.stories.jsx +103 -0
  247. package/spinner/Spinner.test.js +64 -0
  248. package/spinner/types.d.ts +32 -0
  249. package/spinner/types.js +5 -0
  250. package/switch/Switch.d.ts +4 -0
  251. package/switch/Switch.js +262 -0
  252. package/switch/Switch.stories.tsx +138 -0
  253. package/switch/Switch.test.js +225 -0
  254. package/switch/types.d.ts +66 -0
  255. package/switch/types.js +5 -0
  256. package/table/Table.d.ts +4 -0
  257. package/{dist/table → table}/Table.js +12 -26
  258. package/table/Table.stories.jsx +277 -0
  259. package/table/Table.test.js +26 -0
  260. package/table/types.d.ts +21 -0
  261. package/table/types.js +5 -0
  262. package/tabs/Tab.d.ts +4 -0
  263. package/tabs/Tab.js +135 -0
  264. package/tabs/Tabs.d.ts +4 -0
  265. package/tabs/Tabs.js +467 -0
  266. package/tabs/Tabs.stories.tsx +186 -0
  267. package/tabs/Tabs.test.js +351 -0
  268. package/tabs/types.d.ts +92 -0
  269. package/tabs/types.js +5 -0
  270. package/tabs-nav/NavTabs.d.ts +8 -0
  271. package/tabs-nav/NavTabs.js +125 -0
  272. package/tabs-nav/NavTabs.stories.tsx +170 -0
  273. package/tabs-nav/NavTabs.test.js +82 -0
  274. package/tabs-nav/Tab.d.ts +4 -0
  275. package/tabs-nav/Tab.js +130 -0
  276. package/tabs-nav/types.d.ts +53 -0
  277. package/tabs-nav/types.js +5 -0
  278. package/tag/Tag.d.ts +4 -0
  279. package/tag/Tag.js +183 -0
  280. package/tag/Tag.stories.tsx +142 -0
  281. package/tag/Tag.test.js +60 -0
  282. package/tag/types.d.ts +69 -0
  283. package/tag/types.js +5 -0
  284. package/text-input/Icons.d.ts +8 -0
  285. package/text-input/Icons.js +60 -0
  286. package/text-input/Suggestion.d.ts +4 -0
  287. package/text-input/Suggestion.js +57 -0
  288. package/text-input/Suggestions.d.ts +4 -0
  289. package/text-input/Suggestions.js +134 -0
  290. package/text-input/TextInput.d.ts +4 -0
  291. package/text-input/TextInput.js +677 -0
  292. package/text-input/TextInput.stories.tsx +481 -0
  293. package/text-input/TextInput.test.js +1624 -0
  294. package/text-input/types.d.ts +197 -0
  295. package/text-input/types.js +5 -0
  296. package/textarea/Textarea.d.ts +4 -0
  297. package/{dist/textarea → textarea}/Textarea.js +50 -142
  298. package/textarea/Textarea.stories.jsx +157 -0
  299. package/textarea/Textarea.test.js +437 -0
  300. package/textarea/types.d.ts +137 -0
  301. package/textarea/types.js +5 -0
  302. package/toggle-group/ToggleGroup.d.ts +4 -0
  303. package/{dist/toggle-group → toggle-group}/ToggleGroup.js +36 -148
  304. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  305. package/toggle-group/ToggleGroup.test.js +156 -0
  306. package/toggle-group/types.d.ts +105 -0
  307. package/toggle-group/types.js +5 -0
  308. package/typography/Typography.d.ts +4 -0
  309. package/typography/Typography.js +131 -0
  310. package/typography/Typography.stories.tsx +198 -0
  311. package/typography/types.d.ts +18 -0
  312. package/typography/types.js +5 -0
  313. package/useTheme.d.ts +2 -0
  314. package/{dist/useTheme.js → useTheme.js} +2 -2
  315. package/useTranslatedLabels.d.ts +2 -0
  316. package/useTranslatedLabels.js +20 -0
  317. package/wizard/Wizard.d.ts +4 -0
  318. package/wizard/Wizard.js +285 -0
  319. package/wizard/Wizard.stories.tsx +233 -0
  320. package/wizard/Wizard.test.js +141 -0
  321. package/wizard/types.d.ts +65 -0
  322. package/wizard/types.js +5 -0
  323. package/README.md +0 -66
  324. package/babel.config.js +0 -8
  325. package/dist/BackgroundColorContext.js +0 -46
  326. package/dist/ThemeContext.js +0 -248
  327. package/dist/V3Textarea/V3Textarea.js +0 -264
  328. package/dist/accordion/Accordion.js +0 -353
  329. package/dist/accordion-group/AccordionGroup.js +0 -186
  330. package/dist/alert/index.d.ts +0 -51
  331. package/dist/badge/Badge.js +0 -63
  332. package/dist/box/Box.js +0 -156
  333. package/dist/button/Button.js +0 -238
  334. package/dist/card/Card.js +0 -254
  335. package/dist/checkbox/Checkbox.js +0 -300
  336. package/dist/checkbox/Checkbox.stories.js +0 -144
  337. package/dist/checkbox/readme.md +0 -116
  338. package/dist/chip/Chip.js +0 -265
  339. package/dist/common/RequiredComponent.js +0 -40
  340. package/dist/date/Date.js +0 -379
  341. package/dist/date/Date.stories.js +0 -205
  342. package/dist/date/readme.md +0 -73
  343. package/dist/date-input/DateInput.js +0 -400
  344. package/dist/date-input/index.d.ts +0 -95
  345. package/dist/dialog/Dialog.js +0 -218
  346. package/dist/dropdown/Dropdown.js +0 -544
  347. package/dist/file-input/FileInput.js +0 -644
  348. package/dist/file-input/FileItem.js +0 -280
  349. package/dist/file-input/index.d.ts +0 -81
  350. package/dist/footer/Footer.js +0 -421
  351. package/dist/header/Header.js +0 -434
  352. package/dist/input-text/Icons.js +0 -22
  353. package/dist/input-text/InputText.js +0 -705
  354. package/dist/layout/ApplicationLayout.js +0 -327
  355. package/dist/link/Link.js +0 -237
  356. package/dist/link/readme.md +0 -51
  357. package/dist/main.d.ts +0 -8
  358. package/dist/new-select/NewSelect.js +0 -836
  359. package/dist/new-select/index.d.ts +0 -53
  360. package/dist/number-input/NumberInput.js +0 -136
  361. package/dist/number-input/index.d.ts +0 -113
  362. package/dist/paginator/Paginator.js +0 -283
  363. package/dist/password-input/index.d.ts +0 -94
  364. package/dist/progress-bar/ProgressBar.js +0 -242
  365. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  366. package/dist/progress-bar/readme.md +0 -63
  367. package/dist/radio/Radio.js +0 -209
  368. package/dist/radio/Radio.stories.js +0 -166
  369. package/dist/radio/readme.md +0 -70
  370. package/dist/resultsetTable/ResultsetTable.js +0 -358
  371. package/dist/select/Select.js +0 -549
  372. package/dist/sidenav/Sidenav.js +0 -179
  373. package/dist/slider/Slider.js +0 -404
  374. package/dist/slider/readme.md +0 -64
  375. package/dist/spinner/Spinner.js +0 -381
  376. package/dist/spinner/Spinner.stories.js +0 -183
  377. package/dist/spinner/readme.md +0 -65
  378. package/dist/switch/Switch.js +0 -222
  379. package/dist/switch/Switch.stories.js +0 -134
  380. package/dist/switch/readme.md +0 -133
  381. package/dist/tabs/Tabs.js +0 -343
  382. package/dist/tabs/Tabs.stories.js +0 -130
  383. package/dist/tabs/readme.md +0 -78
  384. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  385. package/dist/tabs-for-sections/readme.md +0 -78
  386. package/dist/tag/Tag.js +0 -282
  387. package/dist/text-input/TextInput.js +0 -971
  388. package/dist/text-input/index.d.ts +0 -135
  389. package/dist/textarea/index.d.ts +0 -117
  390. package/dist/toggle/Toggle.js +0 -220
  391. package/dist/toggle/Toggle.stories.js +0 -297
  392. package/dist/toggle/readme.md +0 -80
  393. package/dist/upload/Upload.js +0 -205
  394. package/dist/upload/Upload.stories.js +0 -72
  395. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -139
  396. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  397. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  398. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  399. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  400. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  401. package/dist/upload/file-upload/FileToUpload.js +0 -184
  402. package/dist/upload/file-upload/audio-icon.svg +0 -4
  403. package/dist/upload/file-upload/close.svg +0 -4
  404. package/dist/upload/file-upload/file-icon.svg +0 -4
  405. package/dist/upload/file-upload/video-icon.svg +0 -4
  406. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  407. package/dist/upload/readme.md +0 -37
  408. package/dist/upload/transaction/Transaction.js +0 -175
  409. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  410. package/dist/upload/transaction/audio-icon.svg +0 -4
  411. package/dist/upload/transaction/error-icon.svg +0 -4
  412. package/dist/upload/transaction/file-icon-err.svg +0 -4
  413. package/dist/upload/transaction/file-icon.svg +0 -4
  414. package/dist/upload/transaction/image-icon-err.svg +0 -4
  415. package/dist/upload/transaction/image-icon.svg +0 -4
  416. package/dist/upload/transaction/success-icon.svg +0 -4
  417. package/dist/upload/transaction/video-icon-err.svg +0 -4
  418. package/dist/upload/transaction/video-icon.svg +0 -4
  419. package/dist/upload/transactions/Transactions.js +0 -138
  420. package/dist/wizard/Icons.js +0 -65
  421. package/dist/wizard/Wizard.js +0 -405
  422. package/test/Accordion.test.js +0 -33
  423. package/test/AccordionGroup.test.js +0 -125
  424. package/test/Alert.test.js +0 -53
  425. package/test/Box.test.js +0 -10
  426. package/test/Button.test.js +0 -18
  427. package/test/Card.test.js +0 -30
  428. package/test/Checkbox.test.js +0 -45
  429. package/test/Chip.test.js +0 -25
  430. package/test/Date.test.js +0 -397
  431. package/test/DateInput.test.js +0 -242
  432. package/test/Dialog.test.js +0 -23
  433. package/test/Dropdown.test.js +0 -145
  434. package/test/FileInput.test.js +0 -201
  435. package/test/Footer.test.js +0 -94
  436. package/test/Header.test.js +0 -34
  437. package/test/Heading.test.js +0 -35
  438. package/test/InputText.test.js +0 -248
  439. package/test/Link.test.js +0 -43
  440. package/test/NumberInput.test.js +0 -259
  441. package/test/Paginator.test.js +0 -177
  442. package/test/PasswordInput.test.js +0 -83
  443. package/test/ProgressBar.test.js +0 -35
  444. package/test/Radio.test.js +0 -37
  445. package/test/ResultsetTable.test.js +0 -329
  446. package/test/Select.test.js +0 -212
  447. package/test/Sidenav.test.js +0 -45
  448. package/test/Slider.test.js +0 -74
  449. package/test/Spinner.test.js +0 -32
  450. package/test/Switch.test.js +0 -45
  451. package/test/Table.test.js +0 -36
  452. package/test/Tabs.test.js +0 -109
  453. package/test/TabsForSections.test.js +0 -34
  454. package/test/Tag.test.js +0 -32
  455. package/test/TextInput.test.js +0 -732
  456. package/test/Textarea.test.js +0 -193
  457. package/test/ToggleGroup.test.js +0 -85
  458. package/test/Upload.test.js +0 -60
  459. package/test/V3TextArea.test.js +0 -51
  460. package/test/Wizard.test.js +0 -130
  461. package/test/mocks/pngMock.js +0 -1
  462. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,4 @@
1
+ import React from "react";
2
+ import { CalendarPropsType } from "./types";
3
+ declare const _default: React.MemoExoticComponent<({ selectedDate, innerDate, onInnerDateChange, onDaySelect }: CalendarPropsType) => JSX.Element>;
4
+ export default _default;
@@ -0,0 +1,258 @@
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 _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
+
14
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
15
+
16
+ var _dayjs = _interopRequireDefault(require("dayjs"));
17
+
18
+ var _react = _interopRequireWildcard(require("react"));
19
+
20
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
21
+
22
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
23
+
24
+ var _main = require("../main");
25
+
26
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
27
+
28
+ 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); }
29
+
30
+ 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; }
31
+
32
+ var getDays = function getDays(innerDate) {
33
+ var monthDayCells = [];
34
+ var lastMonthNumberOfDays = innerDate.set("month", innerDate.get("month") - 1).endOf("month");
35
+ var firstDayOfMonth = innerDate.startOf("month").day() === 0 ? 6 : innerDate.startOf("month").day() - 1;
36
+ var daysInMonth = firstDayOfMonth + innerDate.daysInMonth();
37
+
38
+ for (var i = 0; i < 42; i++) {
39
+ if (i < firstDayOfMonth) {
40
+ monthDayCells.push({
41
+ day: lastMonthNumberOfDays.get("date") - firstDayOfMonth + i + 1,
42
+ month: innerDate.get("month") ? innerDate.get("month") - 1 : 11,
43
+ year: innerDate.set("month", innerDate.get("month") - 1).get("year")
44
+ });
45
+ } else if (i < daysInMonth) {
46
+ monthDayCells.push({
47
+ day: i - firstDayOfMonth + 1,
48
+ month: innerDate.get("month"),
49
+ year: innerDate.get("year")
50
+ });
51
+ } else {
52
+ monthDayCells.push({
53
+ day: i - daysInMonth + 1,
54
+ month: innerDate.get("month") === 11 ? 0 : innerDate.get("month") + 1,
55
+ year: innerDate.set("month", innerDate.get("month") + 1).get("year")
56
+ });
57
+ }
58
+ }
59
+
60
+ return monthDayCells;
61
+ };
62
+
63
+ var isDaySelected = function isDaySelected(date, selectedDate) {
64
+ return (selectedDate === null || selectedDate === void 0 ? void 0 : selectedDate.get("month")) === date.month && (selectedDate === null || selectedDate === void 0 ? void 0 : selectedDate.get("year")) === date.year && (selectedDate === null || selectedDate === void 0 ? void 0 : selectedDate.get("date")) === date.day;
65
+ };
66
+
67
+ var Calendar = function Calendar(_ref) {
68
+ var selectedDate = _ref.selectedDate,
69
+ innerDate = _ref.innerDate,
70
+ onInnerDateChange = _ref.onInnerDateChange,
71
+ onDaySelect = _ref.onDaySelect;
72
+
73
+ var _useState = (0, _react.useState)((selectedDate === null || selectedDate === void 0 ? void 0 : selectedDate.get("month")) === innerDate.get("month") && (selectedDate === null || selectedDate === void 0 ? void 0 : selectedDate.get("year")) === innerDate.get("year") ? selectedDate : (0, _dayjs["default"])()),
74
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
75
+ dateToFocus = _useState2[0],
76
+ setDateToFocus = _useState2[1];
77
+
78
+ var _useState3 = (0, _react.useState)(false),
79
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
80
+ toFocus = _useState4[0],
81
+ setToFocus = _useState4[1];
82
+
83
+ var today = (0, _dayjs["default"])();
84
+ var dayCells = (0, _react.useMemo)(function () {
85
+ return getDays(innerDate);
86
+ }, [innerDate]);
87
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
88
+ var weekDays = translatedLabels.calendar.daysShort;
89
+
90
+ var onDateClickHandler = function onDateClickHandler(date) {
91
+ var newDate = innerDate.set("month", date.month).set("date", date.day);
92
+ onDaySelect(newDate);
93
+ setDateToFocus(newDate);
94
+ };
95
+
96
+ var handleOnBlur = function handleOnBlur(event) {
97
+ if (!(event !== null && event !== void 0 && event.currentTarget.contains(event.relatedTarget))) {
98
+ updateDateToFocus();
99
+ }
100
+ };
101
+
102
+ var updateDateToFocus = function updateDateToFocus() {
103
+ if ((selectedDate === null || selectedDate === void 0 ? void 0 : selectedDate.get("month")) === innerDate.get("month") && (selectedDate === null || selectedDate === void 0 ? void 0 : selectedDate.get("year")) === innerDate.get("year")) {
104
+ setDateToFocus(selectedDate);
105
+ } else if (today.get("month") === innerDate.get("month") && today.get("year") === innerDate.get("year")) {
106
+ setDateToFocus(today);
107
+ } else {
108
+ setDateToFocus(innerDate.set("date", 1));
109
+ }
110
+ };
111
+
112
+ var focusDate = function focusDate(date) {
113
+ if (innerDate.get("month") !== date.get("month") || innerDate.get("year") !== date.get("year")) {
114
+ onInnerDateChange(date);
115
+ }
116
+
117
+ setDateToFocus(date);
118
+ setToFocus(true);
119
+ };
120
+
121
+ (0, _react.useEffect)(function () {
122
+ if (toFocus) {
123
+ var _document$getElementB;
124
+
125
+ (_document$getElementB = document.getElementById("day_".concat(dateToFocus.get("date"), "_month").concat(dateToFocus.get("month")))) === null || _document$getElementB === void 0 ? void 0 : _document$getElementB.focus();
126
+ setToFocus(false);
127
+ }
128
+ }, [dateToFocus, toFocus]);
129
+ (0, _react.useEffect)(function () {
130
+ if (dateToFocus.get("month") !== innerDate.get("month") || dateToFocus.get("year") !== innerDate.get("year")) {
131
+ updateDateToFocus();
132
+ }
133
+ }, [innerDate, dateToFocus, selectedDate]);
134
+
135
+ var handleDayKeyboardEvent = function handleDayKeyboardEvent(event, date) {
136
+ var dateToFocusTemp = date.month === innerDate.get("month") ? innerDate.set("date", date.day) : innerDate.set("date", date.day).set("month", date.month);
137
+
138
+ switch (event.key) {
139
+ case "PageUp":
140
+ event.preventDefault();
141
+ event.shiftKey ? dateToFocusTemp = dateToFocusTemp.set("year", dateToFocusTemp.get("year") - 1) : dateToFocusTemp = dateToFocusTemp.set("month", dateToFocusTemp.get("month") - 1);
142
+ focusDate(dateToFocusTemp);
143
+ break;
144
+
145
+ case "PageDown":
146
+ event.preventDefault();
147
+ event.shiftKey ? dateToFocusTemp = dateToFocusTemp.set("year", dateToFocusTemp.get("year") + 1) : dateToFocusTemp = dateToFocusTemp.set("month", dateToFocusTemp.get("month") + 1);
148
+ focusDate(dateToFocusTemp);
149
+ break;
150
+
151
+ case "ArrowLeft":
152
+ event.preventDefault();
153
+ dateToFocusTemp = dateToFocusTemp.set("date", dateToFocusTemp.get("date") - 1);
154
+ focusDate(dateToFocusTemp);
155
+ break;
156
+
157
+ case "ArrowRight":
158
+ event.preventDefault();
159
+ dateToFocusTemp = dateToFocusTemp.set("date", dateToFocusTemp.get("date") + 1);
160
+ focusDate(dateToFocusTemp);
161
+ break;
162
+
163
+ case "ArrowUp":
164
+ event.preventDefault();
165
+ dateToFocusTemp = dateToFocusTemp.set("date", dateToFocusTemp.get("date") - 7);
166
+ focusDate(dateToFocusTemp);
167
+ break;
168
+
169
+ case "ArrowDown":
170
+ event.preventDefault();
171
+ dateToFocusTemp = dateToFocusTemp.set("date", dateToFocusTemp.get("date") + 7);
172
+ focusDate(dateToFocusTemp);
173
+ break;
174
+
175
+ case "Home":
176
+ event.preventDefault();
177
+ dateToFocus.get("day") !== 0 ? dateToFocusTemp = dateToFocusTemp.day(1) : dateToFocusTemp = innerDate.date(date.day - 1).day(1);
178
+ focusDate(dateToFocusTemp);
179
+ break;
180
+
181
+ case "End":
182
+ event.preventDefault();
183
+ dateToFocusTemp.get("day") !== 0 && (dateToFocusTemp = dateToFocusTemp.day(7));
184
+ focusDate(dateToFocusTemp);
185
+ break;
186
+
187
+ case " ":
188
+ event.preventDefault();
189
+ onDaySelect(dateToFocusTemp);
190
+ break;
191
+ }
192
+ };
193
+
194
+ return /*#__PURE__*/_react["default"].createElement(CalendarContainer, null, /*#__PURE__*/_react["default"].createElement(_main.DxcFlex, {
195
+ alignItems: "center",
196
+ justifyContent: "space-between"
197
+ }, weekDays.map(function (weekDay) {
198
+ return /*#__PURE__*/_react["default"].createElement(WeekHeaderCell, {
199
+ key: weekDay
200
+ }, weekDay);
201
+ })), /*#__PURE__*/_react["default"].createElement(DayCellsContainer, {
202
+ onBlur: handleOnBlur
203
+ }, dayCells.map(function (date, index) {
204
+ return date !== 0 ? /*#__PURE__*/_react["default"].createElement(DayCell, {
205
+ onKeyDown: function onKeyDown(event) {
206
+ return handleDayKeyboardEvent(event, date);
207
+ },
208
+ "aria-label": date.day,
209
+ id: "day_".concat(date.day, "_month").concat(date.month),
210
+ key: "day_".concat(index),
211
+ onClick: function onClick() {
212
+ return onDateClickHandler(date);
213
+ },
214
+ selected: isDaySelected(date, selectedDate),
215
+ actualMonth: date.month === innerDate.get("month"),
216
+ autoFocus: date.day === dateToFocus.get("date") && date.month === dateToFocus.get("month"),
217
+ "aria-selected": isDaySelected(date, selectedDate),
218
+ tabIndex: date.day === dateToFocus.get("date") && date.month === dateToFocus.get("month") ? 0 : -1,
219
+ isCurrentDay: today.get("date") === date.day && today.get("month") === innerDate.get("month") && today.get("month") === date.month && today.get("year") === innerDate.get("year")
220
+ }, date.day) : /*#__PURE__*/_react["default"].createElement(EmptyDayCell, {
221
+ key: "empty_".concat(index)
222
+ });
223
+ })));
224
+ };
225
+
226
+ var CalendarContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: flex;\n flex-direction: column;\n justify-content: center;\n padding: 0px 8px 8px 8px;\n width: ", ";\n"])), function (props) {
227
+ return props.theme.dateInput.pickerWidth;
228
+ });
229
+
230
+ var WeekHeaderCell = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n width: 36px;\n height: 36px;\n font-family: ", ";\n font-size: 14px;\n line-height: 19px;\n color: ", ";\n"])), function (props) {
231
+ return props.theme.dateInput.pickerFontFamily;
232
+ }, function (props) {
233
+ return props.theme.dateInput.pickerWeekFontColor;
234
+ });
235
+
236
+ var DayCellsContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: flex;\n gap: 4px;\n flex-wrap: wrap;\n justify-content: space-between;\n"])));
237
+
238
+ var DayCell = _styledComponents["default"].button(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n justify-content: center;\n align-items: center;\n width: 36px;\n height: 36px;\n padding: 0;\n font-size: 0.875rem;\n font-family: ", ";\n font-weight: 400;\n border: none;\n border-radius: 50%;\n cursor: pointer;\n\n &:focus {\n outline: ", " solid 2px;\n }\n &:hover {\n background-color: ", ";\n color: ", ";\n }\n &:active {\n background-color: #4b1c7d;\n color: #ffffff;\n }\n\n ", "\n background-color: ", ";\n color: ", ";\n"])), function (props) {
239
+ return props.theme.dateInput.pickerFontFamily;
240
+ }, function (props) {
241
+ return props.theme.dateInput.pickerFocusColor;
242
+ }, function (props) {
243
+ return props.selected ? props.theme.dateInput.pickerSelectedDateBackgroundColor : props.theme.dateInput.pickerHoverDateBackgroundColor;
244
+ }, function (props) {
245
+ return props.selected ? props.theme.dateInput.pickerSelectedDateColor : props.theme.dateInput.pickerHoverDateFontColor;
246
+ }, function (props) {
247
+ return props.isCurrentDay && !props.selected && "border: 1px solid #cbacec;";
248
+ }, function (props) {
249
+ return props.selected ? props.theme.dateInput.pickerSelectedDateBackgroundColor : "transparent";
250
+ }, function (props) {
251
+ return props.selected ? props.theme.dateInput.pickerSelectedDateColor : props.isCurrentDay ? props.theme.dateInput.pickerActualDateFontColor : !props.actualMonth ? "#999999" : props.theme.dateInput.pickerDayFontColor;
252
+ });
253
+
254
+ var EmptyDayCell = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-block;\n width: 40px;\n height: 36px;\n"])));
255
+
256
+ var _default = /*#__PURE__*/_react["default"].memo(Calendar);
257
+
258
+ exports["default"] = _default;
@@ -0,0 +1,4 @@
1
+ import React from "react";
2
+ import DateInputPropsType from "./types";
3
+ declare const DxcDateInput: React.ForwardRefExoticComponent<DateInputPropsType & React.RefAttributes<HTMLDivElement>>;
4
+ export default DxcDateInput;
@@ -0,0 +1,227 @@
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 _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
+
14
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
15
+
16
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
17
+
18
+ var _react = _interopRequireWildcard(require("react"));
19
+
20
+ var _dayjs = _interopRequireDefault(require("dayjs"));
21
+
22
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
23
+
24
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
25
+
26
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
27
+
28
+ var _TextInput = _interopRequireDefault(require("../text-input/TextInput"));
29
+
30
+ var _DatePicker = _interopRequireDefault(require("./DatePicker"));
31
+
32
+ var Popover = _interopRequireWildcard(require("@radix-ui/react-popover"));
33
+
34
+ var _customParseFormat = _interopRequireDefault(require("dayjs/plugin/customParseFormat"));
35
+
36
+ var _uuid = require("uuid");
37
+
38
+ var _templateObject;
39
+
40
+ 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); }
41
+
42
+ 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; }
43
+
44
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
45
+
46
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
47
+
48
+ _dayjs["default"].extend(_customParseFormat["default"]);
49
+
50
+ var calendarIcon = /*#__PURE__*/_react["default"].createElement("svg", {
51
+ xmlns: "http://www.w3.org/2000/svg",
52
+ height: "24",
53
+ viewBox: "0 0 24 24",
54
+ width: "24",
55
+ fill: "currentColor"
56
+ }, /*#__PURE__*/_react["default"].createElement("path", {
57
+ d: "M0 0h24v24H0z",
58
+ fill: "none"
59
+ }), /*#__PURE__*/_react["default"].createElement("path", {
60
+ d: "M20 3h-1V1h-2v2H7V1H5v2H4c-1.1 0-2 .9-2 2v16c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 18H4V8h16v13z"
61
+ }));
62
+
63
+ var getValueForPicker = function getValueForPicker(value, format) {
64
+ return (0, _dayjs["default"])(value, format.toUpperCase(), true);
65
+ };
66
+
67
+ var DxcDateInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
68
+ var label = _ref.label,
69
+ name = _ref.name,
70
+ _ref$defaultValue = _ref.defaultValue,
71
+ defaultValue = _ref$defaultValue === void 0 ? "" : _ref$defaultValue,
72
+ value = _ref.value,
73
+ _ref$format = _ref.format,
74
+ format = _ref$format === void 0 ? "dd-MM-yyyy" : _ref$format,
75
+ helperText = _ref.helperText,
76
+ _ref$placeholder = _ref.placeholder,
77
+ placeholder = _ref$placeholder === void 0 ? false : _ref$placeholder,
78
+ clearable = _ref.clearable,
79
+ disabled = _ref.disabled,
80
+ optional = _ref.optional,
81
+ onChange = _ref.onChange,
82
+ onBlur = _ref.onBlur,
83
+ error = _ref.error,
84
+ autocomplete = _ref.autocomplete,
85
+ margin = _ref.margin,
86
+ size = _ref.size,
87
+ tabIndex = _ref.tabIndex;
88
+
89
+ var _useState = (0, _react.useState)(defaultValue),
90
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
91
+ innerValue = _useState2[0],
92
+ setInnerValue = _useState2[1];
93
+
94
+ var _useState3 = (0, _react.useState)(false),
95
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
96
+ isOpen = _useState4[0],
97
+ setIsOpen = _useState4[1];
98
+
99
+ var _useState5 = (0, _react.useState)("date-picker-".concat((0, _uuid.v4)())),
100
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 1),
101
+ calendarId = _useState6[0];
102
+
103
+ var colorsTheme = (0, _useTheme["default"])();
104
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
105
+ var dateRef = (0, _react.useRef)(null);
106
+ (0, _react.useLayoutEffect)(function () {
107
+ if (!disabled) {
108
+ var actionButtonRef = dateRef === null || dateRef === void 0 ? void 0 : dateRef.current.querySelector("[title='Open calendar']");
109
+ actionButtonRef === null || actionButtonRef === void 0 ? void 0 : actionButtonRef.setAttribute("aria-haspopup", true);
110
+ actionButtonRef === null || actionButtonRef === void 0 ? void 0 : actionButtonRef.setAttribute("role", "combobox");
111
+ actionButtonRef === null || actionButtonRef === void 0 ? void 0 : actionButtonRef.setAttribute("aria-expanded", isOpen);
112
+ actionButtonRef === null || actionButtonRef === void 0 ? void 0 : actionButtonRef.setAttribute("aria-controls", calendarId);
113
+ actionButtonRef === null || actionButtonRef === void 0 ? void 0 : actionButtonRef.setAttribute("aria-describedby", calendarId);
114
+ }
115
+ }, [isOpen, disabled, calendarId]);
116
+
117
+ var handleCalendarOnClick = function handleCalendarOnClick(newDate) {
118
+ var newValue = newDate.format(format.toUpperCase());
119
+ value !== null && value !== void 0 ? value : setInnerValue(newValue);
120
+ newDate !== null && newDate !== void 0 && newDate.set("day", newDate.get("date")).toJSON() ? onChange === null || onChange === void 0 ? void 0 : onChange({
121
+ value: newValue,
122
+ date: newDate
123
+ }) : onChange === null || onChange === void 0 ? void 0 : onChange({
124
+ value: newValue
125
+ });
126
+ };
127
+
128
+ var handleIOnChange = function handleIOnChange(_ref2) {
129
+ var newValue = _ref2.value,
130
+ inputError = _ref2.error;
131
+ value !== null && value !== void 0 ? value : setInnerValue(newValue);
132
+ var dayjsDate = getValueForPicker(newValue, format);
133
+ var invalidDateMessage = newValue !== "" && !dayjsDate.isValid() && translatedLabels.dateInput.invalidDateErrorMessage;
134
+ var callbackParams = inputError || invalidDateMessage ? {
135
+ value: newValue,
136
+ error: inputError || invalidDateMessage
137
+ } : {
138
+ value: newValue
139
+ };
140
+ dayjsDate.isValid() ? onChange === null || onChange === void 0 ? void 0 : onChange(_objectSpread(_objectSpread({}, callbackParams), {}, {
141
+ date: dayjsDate.toDate()
142
+ })) : onChange === null || onChange === void 0 ? void 0 : onChange(callbackParams);
143
+ };
144
+
145
+ var handleIOnBlur = function handleIOnBlur(_ref3) {
146
+ var value = _ref3.value,
147
+ inputError = _ref3.error;
148
+ var dayjsDate = getValueForPicker(value, format);
149
+ var invalidDateMessage = value !== "" && !dayjsDate.isValid() && translatedLabels.dateInput.invalidDateErrorMessage;
150
+ var callbackParams = inputError || invalidDateMessage ? {
151
+ value: value,
152
+ error: inputError || invalidDateMessage
153
+ } : {
154
+ value: value
155
+ };
156
+ dayjsDate.isValid() ? onBlur === null || onBlur === void 0 ? void 0 : onBlur(_objectSpread(_objectSpread({}, callbackParams), {}, {
157
+ date: dayjsDate.toDate()
158
+ })) : onBlur === null || onBlur === void 0 ? void 0 : onBlur(callbackParams);
159
+ };
160
+
161
+ var openCalendar = function openCalendar() {
162
+ setIsOpen(!isOpen);
163
+ };
164
+
165
+ var closeCalendar = function closeCalendar() {
166
+ setIsOpen(false);
167
+ };
168
+
169
+ var handleDatePickerEscKeydown = function handleDatePickerEscKeydown(event) {
170
+ event.preventDefault();
171
+ closeCalendar();
172
+ dateRef === null || dateRef === void 0 ? void 0 : dateRef.current.getElementsByTagName("input")[0].focus();
173
+ };
174
+
175
+ var handleDatePickerOnBlur = function handleDatePickerOnBlur(event) {
176
+ if (!(event !== null && event !== void 0 && event.currentTarget.contains(event.relatedTarget))) closeCalendar();
177
+ };
178
+
179
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
180
+ theme: colorsTheme
181
+ }, /*#__PURE__*/_react["default"].createElement("div", {
182
+ ref: ref
183
+ }, /*#__PURE__*/_react["default"].createElement(Popover.Root, {
184
+ open: isOpen
185
+ }, /*#__PURE__*/_react["default"].createElement(Popover.Trigger, {
186
+ asChild: true,
187
+ "aria-controls": undefined
188
+ }, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
189
+ label: label,
190
+ name: name,
191
+ defaultValue: defaultValue,
192
+ value: value !== null && value !== void 0 ? value : innerValue,
193
+ helperText: helperText,
194
+ placeholder: placeholder ? format.toUpperCase() : null,
195
+ action: {
196
+ onClick: openCalendar,
197
+ icon: calendarIcon,
198
+ title: "Open calendar"
199
+ },
200
+ clearable: clearable,
201
+ disabled: disabled,
202
+ optional: optional,
203
+ onChange: handleIOnChange,
204
+ onBlur: handleIOnBlur,
205
+ error: error,
206
+ autocomplete: autocomplete,
207
+ margin: margin,
208
+ size: size,
209
+ tabIndex: tabIndex,
210
+ ref: dateRef
211
+ })), /*#__PURE__*/_react["default"].createElement(StyledContent, {
212
+ sideOffset: error ? -18 : 2,
213
+ align: "end",
214
+ "aria-modal": true,
215
+ onBlur: handleDatePickerOnBlur,
216
+ onEscapeKeyDown: handleDatePickerEscKeydown,
217
+ avoidCollisions: false
218
+ }, /*#__PURE__*/_react["default"].createElement(_DatePicker["default"], {
219
+ id: calendarId,
220
+ onDateSelect: handleCalendarOnClick,
221
+ date: getValueForPicker(value !== null && value !== void 0 ? value : innerValue, format.toUpperCase())
222
+ })))));
223
+ });
224
+
225
+ var StyledContent = (0, _styledComponents["default"])(Popover.Content)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n &:focus-visible {\n outline: none;\n }\n"])));
226
+ var _default = DxcDateInput;
227
+ exports["default"] = _default;
@@ -0,0 +1,151 @@
1
+ import React from "react";
2
+ import { userEvent, within, fireEvent, screen } from "@storybook/testing-library";
3
+ import DxcDateInput from "./DateInput";
4
+ import Title from "../../.storybook/components/Title";
5
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
+ import { BackgroundColorProvider } from "../BackgroundColorContext";
7
+ import DarkContainer from "../../.storybook/components/DarkSection";
8
+
9
+ export default {
10
+ title: "Date input",
11
+ component: DxcDateInput,
12
+ };
13
+
14
+ export const Chromatic = () => (
15
+ <>
16
+ <ExampleContainer>
17
+ <Title title="Complete date input" theme="light" level={4} />
18
+ <DxcDateInput label="Date input" helperText="Help message" format="dd/mm/yy" placeholder optional />
19
+ </ExampleContainer>
20
+ <ExampleContainer>
21
+ <Title title="Disabled" theme="light" level={4} />
22
+ <DxcDateInput
23
+ label="Disabled date input"
24
+ helperText="Help message"
25
+ defaultValue="06-04-2027"
26
+ clearable
27
+ disabled
28
+ />
29
+ </ExampleContainer>
30
+ <ExampleContainer>
31
+ <Title title="Invalid" theme="light" level={4} />
32
+ <DxcDateInput label="Error date input" error="Error message." placeholder />
33
+ </ExampleContainer>
34
+ <ExampleContainer>
35
+ <Title title="Relation between icons" theme="light" level={4} />
36
+ <DxcDateInput label="Error date input" error="Error message." defaultValue="06-04-2027" clearable />
37
+ </ExampleContainer>
38
+ <BackgroundColorProvider color="#333333">
39
+ <DarkContainer>
40
+ <Title title="Dark" theme="dark" level={2} />
41
+ <ExampleContainer>
42
+ <Title title="Complete date input" theme="dark" level={4} />
43
+ <DxcDateInput label="Date input" helperText="Help message" format="yyyy/dd/mm" placeholder optional />
44
+ </ExampleContainer>
45
+ <ExampleContainer>
46
+ <Title title="Disabled" theme="dark" level={4} />
47
+ <DxcDateInput
48
+ label="Disabled Date input"
49
+ helperText="Help message"
50
+ defaultValue="06-04-2027"
51
+ clearable
52
+ disabled
53
+ />
54
+ </ExampleContainer>
55
+ <ExampleContainer>
56
+ <Title title="Invalid" theme="dark" level={4} />
57
+ <DxcDateInput label="Error date input" error="Error message." placeholder />
58
+ </ExampleContainer>
59
+ <ExampleContainer>
60
+ <Title title="Relation between icons" theme="dark" level={4} />
61
+ <DxcDateInput label="Error date input" defaultValue="06-04-2027" error="Error message." clearable />
62
+ </ExampleContainer>
63
+ </DarkContainer>
64
+ </BackgroundColorProvider>
65
+ <Title title="Margins" theme="light" level={2} />
66
+ <ExampleContainer>
67
+ <Title title="Xxsmall" theme="light" level={4} />
68
+ <DxcDateInput label="Xxsmall" margin="xxsmall" />
69
+ </ExampleContainer>
70
+ <ExampleContainer>
71
+ <Title title="Xsmall" theme="light" level={4} />
72
+ <DxcDateInput label="Xsmall" margin="xsmall" />
73
+ </ExampleContainer>
74
+ <ExampleContainer>
75
+ <Title title="Small" theme="light" level={4} />
76
+ <DxcDateInput label="Small" margin="small" />
77
+ </ExampleContainer>
78
+ <ExampleContainer>
79
+ <Title title="Medium" theme="light" level={4} />
80
+ <DxcDateInput label="Medium" margin="medium" />
81
+ </ExampleContainer>
82
+ <ExampleContainer>
83
+ <Title title="Large" theme="light" level={4} />
84
+ <DxcDateInput label="Large" margin="large" />
85
+ </ExampleContainer>
86
+ <ExampleContainer>
87
+ <Title title="Xlarge" theme="light" level={4} />
88
+ <DxcDateInput label="Xlarge" margin="xlarge" />
89
+ </ExampleContainer>
90
+ <ExampleContainer>
91
+ <Title title="Xxlarge" theme="light" level={4} />
92
+ <DxcDateInput label="Xxlarge" margin="xxlarge" />
93
+ </ExampleContainer>
94
+ <Title title="Sizes" theme="light" level={2} />
95
+ <ExampleContainer>
96
+ <Title title="Medium size" theme="light" level={4} />
97
+ <DxcDateInput label="Medium" size="medium" />
98
+ </ExampleContainer>
99
+ <ExampleContainer>
100
+ <Title title="Large size" theme="light" level={4} />
101
+ <DxcDateInput label="Large" size="large" />
102
+ </ExampleContainer>
103
+ <ExampleContainer>
104
+ <Title title="FillParent size" theme="light" level={4} />
105
+ <DxcDateInput label="FillParent" size="fillParent" />
106
+ </ExampleContainer>
107
+ </>
108
+ );
109
+
110
+ const DatePicker = () => (
111
+ <ExampleContainer expanded>
112
+ <Title title="Show date picker" theme="light" level={4} />
113
+ <DxcDateInput label="Date input" defaultValue="06-04-2027" />
114
+ </ExampleContainer>
115
+ );
116
+
117
+ export const ShowDatePicker = DatePicker.bind({});
118
+ ShowDatePicker.play = async ({ canvasElement }) => {
119
+ const canvas = within(canvasElement);
120
+ const dateBtn = canvas.getByRole("combobox");
121
+ await userEvent.click(dateBtn);
122
+ };
123
+
124
+ const YearPicker = () => (
125
+ <ExampleContainer expanded>
126
+ <Title title="Show year picker" theme="light" level={4} />
127
+ <DxcDateInput label="Date input" defaultValue="06-04-2027" />
128
+ </ExampleContainer>
129
+ );
130
+
131
+ export const ShowYearPicker = YearPicker.bind({});
132
+ ShowYearPicker.play = async ({ canvasElement }) => {
133
+ const canvas = within(canvasElement);
134
+ await userEvent.click(canvas.getByRole("combobox"));
135
+ await fireEvent.click(screen.getByText("April 2027"));
136
+ };
137
+
138
+ const YearPickerFocus = () => (
139
+ <ExampleContainer expanded>
140
+ <Title title="Show year picker and focus" theme="light" level={4} />
141
+ <DxcDateInput label="Date input" defaultValue="06-04-2027" />
142
+ </ExampleContainer>
143
+ );
144
+
145
+ export const ShowYearPickerFocus = YearPickerFocus.bind({});
146
+ ShowYearPickerFocus.play = async ({ canvasElement }) => {
147
+ const canvas = within(canvasElement);
148
+ await userEvent.click(canvas.getByRole("combobox"));
149
+ await fireEvent.click(screen.getByText("April 2027"));
150
+ await userEvent.tab();
151
+ };