@dxc-technology/halstack-react 0.0.0-ee10f17 → 0.0.0-efa7c74

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 (379) hide show
  1. package/BackgroundColorContext.js +50 -0
  2. package/ThemeContext.js +246 -0
  3. package/V3Select/V3Select.js +455 -0
  4. package/V3Select/index.d.ts +27 -0
  5. package/V3Textarea/V3Textarea.js +260 -0
  6. package/V3Textarea/index.d.ts +27 -0
  7. package/accordion/Accordion.d.ts +4 -0
  8. package/accordion/Accordion.js +258 -0
  9. package/accordion/types.d.ts +68 -0
  10. package/accordion/types.js +5 -0
  11. package/accordion-group/AccordionGroup.d.ts +7 -0
  12. package/accordion-group/AccordionGroup.js +170 -0
  13. package/accordion-group/types.d.ts +72 -0
  14. package/accordion-group/types.js +5 -0
  15. package/alert/Alert.d.ts +4 -0
  16. package/alert/Alert.js +290 -0
  17. package/alert/Alert.stories.tsx +170 -0
  18. package/alert/types.d.ts +49 -0
  19. package/alert/types.js +5 -0
  20. package/badge/Badge.js +59 -0
  21. package/box/Box.d.ts +4 -0
  22. package/box/Box.js +126 -0
  23. package/box/Box.stories.tsx +132 -0
  24. package/box/types.d.ts +43 -0
  25. package/box/types.js +5 -0
  26. package/button/Button.d.ts +4 -0
  27. package/button/Button.js +179 -0
  28. package/button/Button.stories.tsx +276 -0
  29. package/button/types.d.ts +57 -0
  30. package/button/types.js +5 -0
  31. package/card/Card.d.ts +4 -0
  32. package/card/Card.js +164 -0
  33. package/card/Card.stories.tsx +201 -0
  34. package/card/ice-cream.jpg +0 -0
  35. package/card/types.d.ts +67 -0
  36. package/card/types.js +5 -0
  37. package/checkbox/Checkbox.d.ts +4 -0
  38. package/checkbox/Checkbox.js +253 -0
  39. package/checkbox/Checkbox.stories.tsx +192 -0
  40. package/checkbox/types.d.ts +60 -0
  41. package/checkbox/types.js +5 -0
  42. package/chip/Chip.js +221 -0
  43. package/chip/Chip.stories.tsx +121 -0
  44. package/chip/index.d.ts +22 -0
  45. package/{dist/common → common}/OpenSans.css +0 -0
  46. package/common/RequiredComponent.js +32 -0
  47. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  48. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  49. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  50. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  51. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  52. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  53. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  54. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  55. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  56. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  57. package/common/utils.js +22 -0
  58. package/common/variables.js +1577 -0
  59. package/{dist/date → date}/Date.js +121 -90
  60. package/date/index.d.ts +27 -0
  61. package/date-input/DateInput.d.ts +4 -0
  62. package/date-input/DateInput.js +361 -0
  63. package/date-input/DateInput.stories.tsx +138 -0
  64. package/date-input/types.d.ts +100 -0
  65. package/date-input/types.js +5 -0
  66. package/dialog/Dialog.d.ts +4 -0
  67. package/dialog/Dialog.js +165 -0
  68. package/dialog/Dialog.stories.tsx +212 -0
  69. package/dialog/types.d.ts +43 -0
  70. package/dialog/types.js +5 -0
  71. package/dropdown/Dropdown.d.ts +4 -0
  72. package/dropdown/Dropdown.js +417 -0
  73. package/dropdown/types.d.ts +89 -0
  74. package/dropdown/types.js +5 -0
  75. package/file-input/FileInput.d.ts +4 -0
  76. package/file-input/FileInput.js +511 -0
  77. package/file-input/FileItem.d.ts +14 -0
  78. package/file-input/FileItem.js +182 -0
  79. package/file-input/types.d.ts +87 -0
  80. package/file-input/types.js +5 -0
  81. package/footer/Footer.d.ts +4 -0
  82. package/footer/Footer.js +266 -0
  83. package/footer/Footer.stories.jsx +151 -0
  84. package/footer/Icons.js +77 -0
  85. package/footer/types.d.ts +61 -0
  86. package/footer/types.js +5 -0
  87. package/header/Header.d.ts +7 -0
  88. package/header/Header.js +324 -0
  89. package/header/Header.stories.tsx +162 -0
  90. package/header/Icons.js +34 -0
  91. package/header/types.d.ts +47 -0
  92. package/header/types.js +5 -0
  93. package/heading/Heading.d.ts +4 -0
  94. package/heading/Heading.js +159 -0
  95. package/heading/Heading.stories.tsx +53 -0
  96. package/heading/types.d.ts +33 -0
  97. package/heading/types.js +5 -0
  98. package/input-text/Icons.js +22 -0
  99. package/input-text/InputText.js +611 -0
  100. package/input-text/index.d.ts +36 -0
  101. package/layout/ApplicationLayout.js +235 -0
  102. package/layout/Icons.js +55 -0
  103. package/link/Link.d.ts +3 -0
  104. package/link/Link.js +161 -0
  105. package/link/Link.stories.tsx +146 -0
  106. package/link/types.d.ts +74 -0
  107. package/link/types.js +5 -0
  108. package/main.d.ts +44 -0
  109. package/{dist/main.js → main.js} +143 -43
  110. package/number-input/NumberInput.d.ts +4 -0
  111. package/number-input/NumberInput.js +86 -0
  112. package/number-input/NumberInput.stories.tsx +115 -0
  113. package/number-input/NumberInputContext.d.ts +4 -0
  114. package/{dist/ThemeContext.js → number-input/NumberInputContext.js} +6 -2
  115. package/number-input/numberInputContextTypes.d.ts +19 -0
  116. package/number-input/numberInputContextTypes.js +5 -0
  117. package/number-input/types.d.ts +117 -0
  118. package/number-input/types.js +5 -0
  119. package/package.json +39 -24
  120. package/paginator/Icons.js +66 -0
  121. package/paginator/Paginator.d.ts +4 -0
  122. package/paginator/Paginator.js +198 -0
  123. package/paginator/Paginator.stories.tsx +63 -0
  124. package/paginator/types.d.ts +38 -0
  125. package/paginator/types.js +5 -0
  126. package/password-input/PasswordInput.d.ts +4 -0
  127. package/password-input/PasswordInput.js +162 -0
  128. package/password-input/PasswordInput.stories.tsx +131 -0
  129. package/password-input/types.d.ts +105 -0
  130. package/password-input/types.js +5 -0
  131. package/progress-bar/ProgressBar.d.ts +4 -0
  132. package/progress-bar/ProgressBar.js +170 -0
  133. package/progress-bar/ProgressBar.stories.jsx +58 -0
  134. package/progress-bar/types.d.ts +37 -0
  135. package/progress-bar/types.js +5 -0
  136. package/radio/Radio.d.ts +4 -0
  137. package/radio/Radio.js +174 -0
  138. package/radio/Radio.stories.tsx +192 -0
  139. package/radio/types.d.ts +54 -0
  140. package/radio/types.js +5 -0
  141. package/resultsetTable/ResultsetTable.d.ts +4 -0
  142. package/resultsetTable/ResultsetTable.js +249 -0
  143. package/resultsetTable/types.d.ts +63 -0
  144. package/resultsetTable/types.js +5 -0
  145. package/select/Select.js +865 -0
  146. package/select/Select.stories.tsx +572 -0
  147. package/select/index.d.ts +131 -0
  148. package/sidenav/Sidenav.d.ts +9 -0
  149. package/sidenav/Sidenav.js +136 -0
  150. package/sidenav/Sidenav.stories.tsx +165 -0
  151. package/sidenav/types.d.ts +50 -0
  152. package/sidenav/types.js +5 -0
  153. package/slider/Slider.d.ts +4 -0
  154. package/slider/Slider.js +317 -0
  155. package/slider/Slider.stories.tsx +177 -0
  156. package/slider/types.d.ts +78 -0
  157. package/slider/types.js +5 -0
  158. package/spinner/Spinner.d.ts +4 -0
  159. package/spinner/Spinner.js +250 -0
  160. package/spinner/Spinner.stories.jsx +102 -0
  161. package/spinner/types.d.ts +32 -0
  162. package/spinner/types.js +5 -0
  163. package/switch/Switch.d.ts +4 -0
  164. package/switch/Switch.js +179 -0
  165. package/switch/Switch.stories.tsx +160 -0
  166. package/switch/types.d.ts +58 -0
  167. package/switch/types.js +5 -0
  168. package/table/Table.d.ts +4 -0
  169. package/table/Table.js +118 -0
  170. package/table/Table.stories.jsx +276 -0
  171. package/table/types.d.ts +21 -0
  172. package/table/types.js +5 -0
  173. package/tabs/Tabs.d.ts +4 -0
  174. package/tabs/Tabs.js +213 -0
  175. package/tabs/Tabs.stories.tsx +121 -0
  176. package/tabs/types.d.ts +70 -0
  177. package/tabs/types.js +5 -0
  178. package/tag/Tag.d.ts +4 -0
  179. package/tag/Tag.js +193 -0
  180. package/tag/Tag.stories.tsx +145 -0
  181. package/tag/types.d.ts +60 -0
  182. package/tag/types.js +5 -0
  183. package/text-input/TextInput.d.ts +4 -0
  184. package/text-input/TextInput.js +785 -0
  185. package/text-input/types.d.ts +157 -0
  186. package/text-input/types.js +5 -0
  187. package/textarea/Textarea.js +317 -0
  188. package/textarea/Textarea.stories.jsx +135 -0
  189. package/textarea/index.d.ts +117 -0
  190. package/{dist/toggle → toggle}/Toggle.js +30 -67
  191. package/toggle/index.d.ts +21 -0
  192. package/toggle-group/ToggleGroup.d.ts +4 -0
  193. package/toggle-group/ToggleGroup.js +217 -0
  194. package/toggle-group/ToggleGroup.stories.tsx +178 -0
  195. package/toggle-group/types.d.ts +84 -0
  196. package/toggle-group/types.js +5 -0
  197. package/{dist/upload → upload}/Upload.js +23 -22
  198. package/upload/buttons-upload/ButtonsUpload.js +111 -0
  199. package/upload/buttons-upload/Icons.js +40 -0
  200. package/upload/dragAndDropArea/DragAndDropArea.js +225 -0
  201. package/upload/dragAndDropArea/Icons.js +39 -0
  202. package/upload/file-upload/FileToUpload.js +115 -0
  203. package/upload/file-upload/Icons.js +66 -0
  204. package/upload/files-upload/FilesToUpload.js +109 -0
  205. package/upload/index.d.ts +15 -0
  206. package/upload/transaction/Icons.js +160 -0
  207. package/upload/transaction/Transaction.js +104 -0
  208. package/upload/transactions/Transactions.js +94 -0
  209. package/useTheme.js +22 -0
  210. package/wizard/Icons.js +65 -0
  211. package/wizard/Wizard.d.ts +4 -0
  212. package/wizard/Wizard.js +231 -0
  213. package/wizard/Wizard.stories.jsx +224 -0
  214. package/wizard/types.d.ts +64 -0
  215. package/wizard/types.js +5 -0
  216. package/README.md +0 -66
  217. package/babel.config.js +0 -4
  218. package/dist/accordion/Accordion.js +0 -264
  219. package/dist/accordion/Accordion.stories.js +0 -207
  220. package/dist/accordion/readme.md +0 -96
  221. package/dist/alert/Alert.js +0 -302
  222. package/dist/alert/Alert.stories.js +0 -158
  223. package/dist/alert/close.svg +0 -4
  224. package/dist/alert/error.svg +0 -4
  225. package/dist/alert/info.svg +0 -4
  226. package/dist/alert/readme.md +0 -43
  227. package/dist/alert/success.svg +0 -4
  228. package/dist/alert/warning.svg +0 -4
  229. package/dist/box/Box.js +0 -136
  230. package/dist/button/Button.js +0 -182
  231. package/dist/button/Button.stories.js +0 -224
  232. package/dist/button/readme.md +0 -93
  233. package/dist/card/Card.js +0 -246
  234. package/dist/checkbox/Checkbox.js +0 -224
  235. package/dist/checkbox/Checkbox.stories.js +0 -144
  236. package/dist/checkbox/readme.md +0 -116
  237. package/dist/chip/Chip.js +0 -170
  238. package/dist/common/RequiredComponent.js +0 -50
  239. package/dist/common/services/example-service.js +0 -10
  240. package/dist/common/services/example-service.test.js +0 -12
  241. package/dist/common/utils.js +0 -42
  242. package/dist/common/variables.js +0 -154
  243. package/dist/date/Date.stories.js +0 -205
  244. package/dist/date/calendar.svg +0 -1
  245. package/dist/date/calendar_dark.svg +0 -1
  246. package/dist/date/readme.md +0 -73
  247. package/dist/dialog/Dialog.js +0 -193
  248. package/dist/dialog/Dialog.stories.js +0 -217
  249. package/dist/dialog/readme.md +0 -32
  250. package/dist/dropdown/Dropdown.js +0 -412
  251. package/dist/dropdown/Dropdown.stories.js +0 -249
  252. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  253. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  254. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  255. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  256. package/dist/dropdown/readme.md +0 -69
  257. package/dist/footer/Footer.js +0 -341
  258. package/dist/footer/Footer.stories.js +0 -94
  259. package/dist/footer/dxc_logo_wht.png +0 -0
  260. package/dist/footer/readme.md +0 -41
  261. package/dist/header/Header.js +0 -343
  262. package/dist/header/Header.stories.js +0 -176
  263. package/dist/header/close_icon.svg +0 -1
  264. package/dist/header/dxc_logo_black.png +0 -0
  265. package/dist/header/dxc_logo_white.png +0 -0
  266. package/dist/header/hamb_menu_black.svg +0 -1
  267. package/dist/header/hamb_menu_white.svg +0 -1
  268. package/dist/header/readme.md +0 -33
  269. package/dist/heading/Heading.js +0 -159
  270. package/dist/input-text/InputText.js +0 -517
  271. package/dist/input-text/InputText.stories.js +0 -209
  272. package/dist/input-text/error.svg +0 -1
  273. package/dist/input-text/readme.md +0 -91
  274. package/dist/link/Link.js +0 -129
  275. package/dist/link/readme.md +0 -51
  276. package/dist/paginator/Paginator.js +0 -178
  277. package/dist/paginator/images/next.svg +0 -3
  278. package/dist/paginator/images/nextPage.svg +0 -3
  279. package/dist/paginator/images/previous.svg +0 -3
  280. package/dist/paginator/images/previousPage.svg +0 -3
  281. package/dist/paginator/readme.md +0 -50
  282. package/dist/progress-bar/ProgressBar.js +0 -189
  283. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  284. package/dist/progress-bar/readme.md +0 -63
  285. package/dist/radio/Radio.js +0 -191
  286. package/dist/radio/Radio.stories.js +0 -166
  287. package/dist/radio/readme.md +0 -70
  288. package/dist/resultsetTable/ResultsetTable.js +0 -334
  289. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  290. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  291. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  292. package/dist/select/Select.js +0 -425
  293. package/dist/select/Select.stories.js +0 -235
  294. package/dist/select/readme.md +0 -72
  295. package/dist/sidenav/Sidenav.js +0 -217
  296. package/dist/sidenav/arrow_icon.svg +0 -3
  297. package/dist/slider/Slider.js +0 -258
  298. package/dist/slider/Slider.stories.js +0 -241
  299. package/dist/slider/readme.md +0 -64
  300. package/dist/spinner/Spinner.js +0 -196
  301. package/dist/spinner/Spinner.stories.js +0 -183
  302. package/dist/spinner/readme.md +0 -65
  303. package/dist/switch/Switch.js +0 -219
  304. package/dist/switch/Switch.stories.js +0 -134
  305. package/dist/switch/readme.md +0 -133
  306. package/dist/table/Table.js +0 -84
  307. package/dist/tabs/Tabs.js +0 -183
  308. package/dist/tabs/Tabs.stories.js +0 -130
  309. package/dist/tabs/readme.md +0 -78
  310. package/dist/tabs-for-sections/TabsForSections.js +0 -107
  311. package/dist/tabs-for-sections/readme.md +0 -78
  312. package/dist/tag/Tag.js +0 -217
  313. package/dist/textarea/Textarea.js +0 -226
  314. package/dist/toggle/Toggle.stories.js +0 -297
  315. package/dist/toggle/readme.md +0 -80
  316. package/dist/upload/Upload.stories.js +0 -72
  317. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -125
  318. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  319. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  320. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -282
  321. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  322. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  323. package/dist/upload/file-upload/FileToUpload.js +0 -158
  324. package/dist/upload/file-upload/audio-icon.svg +0 -4
  325. package/dist/upload/file-upload/close.svg +0 -4
  326. package/dist/upload/file-upload/file-icon.svg +0 -4
  327. package/dist/upload/file-upload/video-icon.svg +0 -4
  328. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  329. package/dist/upload/readme.md +0 -37
  330. package/dist/upload/transaction/Transaction.js +0 -155
  331. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  332. package/dist/upload/transaction/audio-icon.svg +0 -4
  333. package/dist/upload/transaction/error-icon.svg +0 -4
  334. package/dist/upload/transaction/file-icon-err.svg +0 -4
  335. package/dist/upload/transaction/file-icon.svg +0 -4
  336. package/dist/upload/transaction/image-icon-err.svg +0 -4
  337. package/dist/upload/transaction/image-icon.svg +0 -4
  338. package/dist/upload/transaction/success-icon.svg +0 -4
  339. package/dist/upload/transaction/video-icon-err.svg +0 -4
  340. package/dist/upload/transaction/video-icon.svg +0 -4
  341. package/dist/upload/transactions/Transactions.js +0 -120
  342. package/dist/wizard/Wizard.js +0 -310
  343. package/dist/wizard/invalid_icon.svg +0 -6
  344. package/dist/wizard/valid_icon.svg +0 -6
  345. package/dist/wizard/validation-wrong.svg +0 -6
  346. package/test/Accordion.test.js +0 -33
  347. package/test/Alert.test.js +0 -53
  348. package/test/Box.test.js +0 -10
  349. package/test/Button.test.js +0 -18
  350. package/test/Card.test.js +0 -30
  351. package/test/Checkbox.test.js +0 -45
  352. package/test/Chip.test.js +0 -25
  353. package/test/Date.test.js +0 -393
  354. package/test/Dialog.test.js +0 -23
  355. package/test/Dropdown.test.js +0 -130
  356. package/test/Footer.test.js +0 -99
  357. package/test/Header.test.js +0 -39
  358. package/test/Heading.test.js +0 -35
  359. package/test/InputText.test.js +0 -236
  360. package/test/Link.test.js +0 -25
  361. package/test/Paginator.test.js +0 -165
  362. package/test/ProgressBar.test.js +0 -35
  363. package/test/Radio.test.js +0 -37
  364. package/test/ResultsetTable.test.js +0 -282
  365. package/test/Select.test.js +0 -191
  366. package/test/Sidenav.test.js +0 -87
  367. package/test/Slider.test.js +0 -65
  368. package/test/Spinner.test.js +0 -27
  369. package/test/Switch.test.js +0 -45
  370. package/test/Table.test.js +0 -36
  371. package/test/Tabs.test.js +0 -88
  372. package/test/TabsForSections.test.js +0 -34
  373. package/test/Tag.test.js +0 -32
  374. package/test/TextArea.test.js +0 -52
  375. package/test/Toggle.test.js +0 -43
  376. package/test/Upload.test.js +0 -60
  377. package/test/Wizard.test.js +0 -130
  378. package/test/mocks/pngMock.js +0 -1
  379. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,361 @@
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 _react = _interopRequireWildcard(require("react"));
17
+
18
+ var _pickers = require("@material-ui/pickers");
19
+
20
+ var _core = require("@material-ui/core");
21
+
22
+ var _ClickAwayListener = _interopRequireDefault(require("@material-ui/core/ClickAwayListener"));
23
+
24
+ var _Popover = _interopRequireDefault(require("@material-ui/core/Popover"));
25
+
26
+ var _moment = _interopRequireDefault(require("moment"));
27
+
28
+ var _dateFns = _interopRequireDefault(require("@date-io/date-fns"));
29
+
30
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
31
+
32
+ var _useTheme = _interopRequireDefault(require("../useTheme.js"));
33
+
34
+ var _TextInput = _interopRequireDefault(require("../text-input/TextInput"));
35
+
36
+ var _templateObject;
37
+
38
+ 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); }
39
+
40
+ 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; }
41
+
42
+ var DxcDateInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
43
+ var _ref$label = _ref.label,
44
+ label = _ref$label === void 0 ? "" : _ref$label,
45
+ _ref$name = _ref.name,
46
+ name = _ref$name === void 0 ? "" : _ref$name,
47
+ value = _ref.value,
48
+ _ref$format = _ref.format,
49
+ format = _ref$format === void 0 ? "dd-MM-yyyy" : _ref$format,
50
+ _ref$helperText = _ref.helperText,
51
+ helperText = _ref$helperText === void 0 ? "" : _ref$helperText,
52
+ _ref$placeholder = _ref.placeholder,
53
+ placeholder = _ref$placeholder === void 0 ? false : _ref$placeholder,
54
+ _ref$clearable = _ref.clearable,
55
+ clearable = _ref$clearable === void 0 ? false : _ref$clearable,
56
+ _ref$disabled = _ref.disabled,
57
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
58
+ _ref$optional = _ref.optional,
59
+ optional = _ref$optional === void 0 ? false : _ref$optional,
60
+ onChange = _ref.onChange,
61
+ onBlur = _ref.onBlur,
62
+ _ref$error = _ref.error,
63
+ error = _ref$error === void 0 ? "" : _ref$error,
64
+ _ref$autocomplete = _ref.autocomplete,
65
+ autocomplete = _ref$autocomplete === void 0 ? "off" : _ref$autocomplete,
66
+ margin = _ref.margin,
67
+ _ref$size = _ref.size,
68
+ size = _ref$size === void 0 ? "medium" : _ref$size,
69
+ _ref$tabIndex = _ref.tabIndex,
70
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
71
+
72
+ var _useState = (0, _react.useState)(""),
73
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
74
+ innerValue = _useState2[0],
75
+ setInnerValue = _useState2[1];
76
+
77
+ var _useState3 = (0, _react.useState)(false),
78
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
79
+ isOpen = _useState4[0],
80
+ setIsOpen = _useState4[1];
81
+
82
+ var _useState5 = (0, _react.useState)(null),
83
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
84
+ anchorEl = _useState6[0],
85
+ setAnchorEl = _useState6[1];
86
+
87
+ var colorsTheme = (0, _useTheme["default"])();
88
+
89
+ var handleCalendarOnKeyDown = function handleCalendarOnKeyDown(event) {
90
+ switch (event.keyCode) {
91
+ case 27:
92
+ // Esc
93
+ event.preventDefault();
94
+ setIsOpen(false);
95
+ break;
96
+ }
97
+ };
98
+
99
+ var handleCalendarOnClick = function handleCalendarOnClick(newDate) {
100
+ var newValue = (0, _moment["default"])(newDate).format(format.toUpperCase());
101
+ value !== null && value !== void 0 ? value : setInnerValue(newValue);
102
+ onChange === null || onChange === void 0 ? void 0 : onChange({
103
+ value: newValue,
104
+ error: null,
105
+ date: newDate !== null && newDate !== void 0 && newDate.toJSON() ? newDate : null
106
+ });
107
+ };
108
+
109
+ var handleIOnChange = function handleIOnChange(_ref2) {
110
+ var newValue = _ref2.value,
111
+ inputError = _ref2.error;
112
+ value !== null && value !== void 0 ? value : setInnerValue(newValue);
113
+ var momentDate = (0, _moment["default"])(newValue, format.toUpperCase(), true);
114
+ var invalidDateMessage = newValue !== "" && !momentDate.isValid() ? "Invalid date." : null;
115
+ onChange === null || onChange === void 0 ? void 0 : onChange({
116
+ value: newValue,
117
+ error: inputError || invalidDateMessage,
118
+ date: momentDate.isValid() ? momentDate.toDate() : null
119
+ });
120
+ };
121
+
122
+ var handleIOnBlur = function handleIOnBlur(_ref3) {
123
+ var value = _ref3.value,
124
+ inputError = _ref3.error;
125
+ var momentDate = (0, _moment["default"])(value, format.toUpperCase(), true);
126
+ var invalidDateMessage = value !== "" && !momentDate.isValid() ? "Invalid date." : null;
127
+ onBlur === null || onBlur === void 0 ? void 0 : onBlur({
128
+ value: value,
129
+ error: inputError || invalidDateMessage,
130
+ date: momentDate.isValid() ? momentDate.toDate() : null
131
+ });
132
+ };
133
+
134
+ var getValueForPicker = function getValueForPicker() {
135
+ return (0, _moment["default"])(value !== null && value !== void 0 ? value : innerValue, format.toUpperCase(), true).format();
136
+ };
137
+
138
+ var openCalendar = function openCalendar(event) {
139
+ if (event) {
140
+ setIsOpen(!isOpen);
141
+ setAnchorEl(event.currentTarget);
142
+ }
143
+ };
144
+
145
+ var closeCalendar = function closeCalendar() {
146
+ setIsOpen(false);
147
+ };
148
+
149
+ var calendarAction = {
150
+ onClick: openCalendar,
151
+ icon: /*#__PURE__*/_react["default"].createElement("svg", {
152
+ xmlns: "http://www.w3.org/2000/svg",
153
+ height: "24",
154
+ viewBox: "0 0 24 24",
155
+ width: "24",
156
+ fill: "currentColor"
157
+ }, /*#__PURE__*/_react["default"].createElement("path", {
158
+ d: "M0 0h24v24H0z",
159
+ fill: "none"
160
+ }), /*#__PURE__*/_react["default"].createElement("path", {
161
+ 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"
162
+ }))
163
+ };
164
+ var dateTheme = (0, _core.createMuiTheme)({
165
+ overrides: {
166
+ MuiTypography: {
167
+ root: {
168
+ fontFamily: "".concat(colorsTheme.dateInput.pickerFontFamily, " !important")
169
+ }
170
+ },
171
+ MuiPickersYearSelection: {
172
+ container: {
173
+ color: colorsTheme.dateInput.pickerYearFontColor,
174
+ "&::-webkit-scrollbar": {
175
+ width: "3px"
176
+ },
177
+ "&::-webkit-scrollbar-track": {
178
+ backgroundColor: "#D9D9D9",
179
+ borderRadius: "3px"
180
+ },
181
+ "&::-webkit-scrollbar-thumb": {
182
+ backgroundColor: "#666666",
183
+ borderRadius: "3px"
184
+ }
185
+ }
186
+ },
187
+ MuiPickersToolbar: {
188
+ toolbar: {
189
+ backgroundColor: colorsTheme.dateInput.pickerBackgroundColor,
190
+ color: colorsTheme.dateInput.pickerDayFontColor
191
+ }
192
+ },
193
+ MuiIconButton: {
194
+ root: {
195
+ height: "36px",
196
+ width: "36px",
197
+ padding: "0px"
198
+ }
199
+ },
200
+ MuiTouchRipple: {
201
+ child: {
202
+ opacity: "0"
203
+ }
204
+ },
205
+ MuiButtonBase: {
206
+ root: {
207
+ "&:focus": {
208
+ outline: colorsTheme.dateInput.pickerFocusColor + " solid 2px"
209
+ }
210
+ }
211
+ },
212
+ MuiPickersBasePicker: {
213
+ pickerView: {
214
+ minWidth: "unset",
215
+ maxWidth: "unset",
216
+ minHeight: "unset",
217
+ padding: "0px 10px",
218
+ height: colorsTheme.dateInput.pickerHeight,
219
+ width: colorsTheme.dateInput.pickerWidth,
220
+ backgroundColor: colorsTheme.dateInput.pickerBackgroundColor,
221
+ fontFamily: colorsTheme.dateInput.pickerFontFamily
222
+ }
223
+ },
224
+ MuiPickersToolbarText: {
225
+ toolbarTxt: {
226
+ color: colorsTheme.dateInput.pickerActualDateFontColor,
227
+ fontFamily: colorsTheme.dateInput.pickerFontFamily,
228
+ fontSize: "2rem"
229
+ },
230
+ toolbarBtnSelected: {
231
+ color: colorsTheme.dateInput.pickerActualDateFontColor
232
+ }
233
+ },
234
+ MuiPickersCalendarHeader: {
235
+ transitionContainer: {
236
+ color: colorsTheme.dateInput.pickerMonthFontColor
237
+ },
238
+ dayLabel: {
239
+ color: colorsTheme.dateInput.pickerWeekFontColor,
240
+ fontFamily: colorsTheme.dateInput.pickerFontFamily
241
+ },
242
+ switchHeader: {
243
+ backgroundColor: "#ffffff",
244
+ color: colorsTheme.dateInput.pickerDayFontColor
245
+ },
246
+ iconButton: {
247
+ backgroundColor: colorsTheme.dateInput.pickerMonthArrowsBackgroundColor,
248
+ "&:hover": {
249
+ backgroundColor: colorsTheme.dateInput.pickerMonthArrowsBackgroundColor
250
+ }
251
+ }
252
+ },
253
+ MuiPickersCalendar: {
254
+ week: {
255
+ marginBottom: "2px"
256
+ }
257
+ },
258
+ MuiPickersDay: {
259
+ current: {
260
+ color: colorsTheme.dateInput.pickerDayFontColor
261
+ },
262
+ day: {
263
+ fontFamily: colorsTheme.dateInput.pickerFontFamily,
264
+ color: colorsTheme.dateInput.pickerDayFontColor,
265
+ "&:hover": {
266
+ backgroundColor: colorsTheme.dateInput.pickerHoverDateBackgroundColor,
267
+ color: colorsTheme.dateInput.pickerHoverDateFontColor
268
+ }
269
+ },
270
+ daySelected: {
271
+ backgroundColor: colorsTheme.dateInput.pickerSelectedDateBackgroundColor,
272
+ color: colorsTheme.dateInput.pickerSelectedDateColor,
273
+ "&:hover": {
274
+ backgroundColor: colorsTheme.dateInput.pickerSelectedDateBackgroundColor,
275
+ color: colorsTheme.dateInput.pickerSelectedDateColor,
276
+ opacity: "1"
277
+ }
278
+ }
279
+ },
280
+ MuiPickersYear: {
281
+ yearSelected: {
282
+ color: colorsTheme.dateInput.pickerSelectedDateColor,
283
+ backgroundColor: colorsTheme.dateInput.pickerSelectedDateBackgroundColor,
284
+ margin: "0px 100px",
285
+ borderRadius: "20px"
286
+ },
287
+ root: {
288
+ "&:focus": {
289
+ color: colorsTheme.dateInput.pickerHoverDateFontColor,
290
+ backgroundColor: colorsTheme.dateInput.pickerHoverDateBackgroundColor
291
+ }
292
+ }
293
+ },
294
+ MuiPickersModal: {
295
+ dialogAction: {
296
+ color: "pink"
297
+ }
298
+ }
299
+ }
300
+ });
301
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
302
+ theme: colorsTheme
303
+ }, /*#__PURE__*/_react["default"].createElement(_core.MuiThemeProvider, {
304
+ theme: dateTheme
305
+ }, /*#__PURE__*/_react["default"].createElement(_pickers.MuiPickersUtilsProvider, {
306
+ utils: _dateFns["default"]
307
+ }, /*#__PURE__*/_react["default"].createElement(StyledDPicker, null, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
308
+ label: label,
309
+ name: name,
310
+ value: value !== null && value !== void 0 ? value : innerValue,
311
+ helperText: helperText,
312
+ placeholder: placeholder ? format.toUpperCase() : null,
313
+ action: calendarAction,
314
+ clearable: clearable,
315
+ disabled: disabled,
316
+ optional: optional,
317
+ onChange: handleIOnChange,
318
+ onBlur: handleIOnBlur,
319
+ error: error,
320
+ autocomplete: autocomplete,
321
+ margin: margin,
322
+ size: size,
323
+ tabIndex: tabIndex,
324
+ ref: ref
325
+ }), /*#__PURE__*/_react["default"].createElement(_Popover["default"], {
326
+ onKeyDown: handleCalendarOnKeyDown,
327
+ open: isOpen,
328
+ anchorEl: anchorEl,
329
+ anchorOrigin: {
330
+ vertical: "bottom",
331
+ horizontal: "left"
332
+ },
333
+ transformOrigin: {
334
+ vertical: "top",
335
+ horizontal: "center"
336
+ },
337
+ PaperProps: {
338
+ style: {
339
+ marginTop: "10px"
340
+ }
341
+ }
342
+ }, /*#__PURE__*/_react["default"].createElement(_ClickAwayListener["default"], {
343
+ onClickAway: closeCalendar
344
+ }, /*#__PURE__*/_react["default"].createElement(_core.Paper, {
345
+ role: "dialog",
346
+ "aria-modal": "true"
347
+ }, /*#__PURE__*/_react["default"].createElement(_pickers.DatePicker, {
348
+ variant: "static",
349
+ value: getValueForPicker(),
350
+ onChange: function onChange(date) {
351
+ return handleCalendarOnClick(date);
352
+ },
353
+ format: format,
354
+ disabled: disabled
355
+ }))))))));
356
+ });
357
+
358
+ var StyledDPicker = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])([""])));
359
+
360
+ var _default = DxcDateInput;
361
+ exports["default"] = _default;
@@ -0,0 +1,138 @@
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 label="Disabled date input" helperText="Help message" value="06-04-2027" clearable disabled />
23
+ </ExampleContainer>
24
+ <ExampleContainer>
25
+ <Title title="Invalid" theme="light" level={4} />
26
+ <DxcDateInput label="Error date input" error="Error message." placeholder />
27
+ </ExampleContainer>
28
+ <ExampleContainer>
29
+ <Title title="Relation between icons" theme="light" level={4} />
30
+ <DxcDateInput label="Error date input" error="Error message." value="06-04-2027" clearable />
31
+ </ExampleContainer>
32
+ <BackgroundColorProvider color="#333333">
33
+ <DarkContainer>
34
+ <Title title="Dark" theme="dark" level={2} />
35
+ <ExampleContainer>
36
+ <Title title="Complete date input" theme="dark" level={4} />
37
+ <DxcDateInput label="Date input" helperText="Help message" format="yyyy/dd/mm" placeholder optional />
38
+ </ExampleContainer>
39
+ <ExampleContainer>
40
+ <Title title="Disabled" theme="dark" level={4} />
41
+ <DxcDateInput label="Disabled Date input" helperText="Help message" value="06-04-2027" clearable disabled />
42
+ </ExampleContainer>
43
+ <ExampleContainer>
44
+ <Title title="Invalid" theme="dark" level={4} />
45
+ <DxcDateInput label="Error date input" error="Error message." placeholder />
46
+ </ExampleContainer>
47
+ <ExampleContainer>
48
+ <Title title="Relation between icons" theme="dark" level={4} />
49
+ <DxcDateInput label="Error date input" value="06-04-2027" error="Error message." clearable />
50
+ </ExampleContainer>
51
+ </DarkContainer>
52
+ </BackgroundColorProvider>
53
+ <Title title="Margins" theme="light" level={2} />
54
+ <ExampleContainer>
55
+ <Title title="Xxsmall" theme="light" level={4} />
56
+ <DxcDateInput label="Xxsmall" margin="xxsmall" />
57
+ </ExampleContainer>
58
+ <ExampleContainer>
59
+ <Title title="Xsmall" theme="light" level={4} />
60
+ <DxcDateInput label="Xsmall" margin="xsmall" />
61
+ </ExampleContainer>
62
+ <ExampleContainer>
63
+ <Title title="Small" theme="light" level={4} />
64
+ <DxcDateInput label="Small" margin="small" />
65
+ </ExampleContainer>
66
+ <ExampleContainer>
67
+ <Title title="Medium" theme="light" level={4} />
68
+ <DxcDateInput label="Medium" margin="medium" />
69
+ </ExampleContainer>
70
+ <ExampleContainer>
71
+ <Title title="Large" theme="light" level={4} />
72
+ <DxcDateInput label="Large" margin="large" />
73
+ </ExampleContainer>
74
+ <ExampleContainer>
75
+ <Title title="Xlarge" theme="light" level={4} />
76
+ <DxcDateInput label="Xlarge" margin="xlarge" />
77
+ </ExampleContainer>
78
+ <ExampleContainer>
79
+ <Title title="Xxlarge" theme="light" level={4} />
80
+ <DxcDateInput label="Xxlarge" margin="xxlarge" />
81
+ </ExampleContainer>
82
+ <Title title="Sizes" theme="light" level={2} />
83
+ <ExampleContainer>
84
+ <Title title="Medium size" theme="light" level={4} />
85
+ <DxcDateInput label="Medium" size="medium" />
86
+ </ExampleContainer>
87
+ <ExampleContainer>
88
+ <Title title="Large size" theme="light" level={4} />
89
+ <DxcDateInput label="Large" size="large" />
90
+ </ExampleContainer>
91
+ <ExampleContainer>
92
+ <Title title="FillParent size" theme="light" level={4} />
93
+ <DxcDateInput label="FillParent" size="fillParent" />
94
+ </ExampleContainer>
95
+ </>
96
+ );
97
+
98
+ const DatePicker = () => (
99
+ <ExampleContainer expanded>
100
+ <Title title="Show date input" theme="light" level={4} />
101
+ <DxcDateInput label="Date input" value="10-06-2023" />
102
+ </ExampleContainer>
103
+ );
104
+
105
+ export const ShowDatePicker = DatePicker.bind({});
106
+ ShowDatePicker.play = async ({ canvasElement }) => {
107
+ const canvas = within(canvasElement);
108
+ const dateBtn = canvas.getByRole("button");
109
+ await userEvent.click(dateBtn);
110
+ await userEvent.tab();
111
+ };
112
+
113
+ const YearPicker = () => (
114
+ <ExampleContainer expanded>
115
+ <Title title="Show date input" theme="light" level={4} />
116
+ <DxcDateInput label="Date input" value="10-06-2023" />
117
+ </ExampleContainer>
118
+ );
119
+
120
+ export const ShowYearPicker = YearPicker.bind({});
121
+ ShowYearPicker.play = async () => {
122
+ await fireEvent.click(screen.getByRole("button"));
123
+ await fireEvent.click(screen.getByText("2023"));
124
+ };
125
+
126
+ const YearPickerFocus = () => (
127
+ <ExampleContainer expanded>
128
+ <Title title="Show date input" theme="light" level={4} />
129
+ <DxcDateInput label="Date input" value="10-06-2023" />
130
+ </ExampleContainer>
131
+ );
132
+
133
+ export const ShowYearPickerFocus = YearPickerFocus.bind({});
134
+ ShowYearPickerFocus.play = async () => {
135
+ await fireEvent.click(screen.getByRole("button"));
136
+ await fireEvent.click(screen.getByText("2023"));
137
+ await screen.getByText("2021").focus();
138
+ };
@@ -0,0 +1,100 @@
1
+ declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
+ declare type Margin = {
3
+ top?: Space;
4
+ bottom?: Space;
5
+ left?: Space;
6
+ right?: Space;
7
+ };
8
+ declare type Props = {
9
+ /**
10
+ * Text to be placed above the date.
11
+ */
12
+ label?: string;
13
+ /**
14
+ * Name attribute of the input element.
15
+ */
16
+ name?: string;
17
+ /**
18
+ * Value of the input element. If undefined, the component will be uncontrolled and the value will be managed internally by the component.
19
+ */
20
+ value?: string;
21
+ /**
22
+ * The format in which the date value will be displayed. User must use this format when editing the value or it will be considered as an invalid date.
23
+ */
24
+ format?: string;
25
+ /**
26
+ * Helper text to be placed above the date.
27
+ */
28
+ helperText?: string;
29
+ /**
30
+ * If true, the date format will appear as placeholder in the field.
31
+ */
32
+ placeholder?: boolean;
33
+ /**
34
+ * If true, the date input will have an action to clear the entered value.
35
+ */
36
+ clearable?: boolean;
37
+ /**
38
+ * If true, the component will be disabled.
39
+ */
40
+ disabled?: boolean;
41
+ /**
42
+ * If true, the date will be optional, showing '(Optional)'
43
+ * next to the label. Otherwise, the field will be considered required and an error will be
44
+ * passed as a parameter to the OnBlur and onChange functions when it has
45
+ * not been filled.
46
+ */
47
+ optional?: boolean;
48
+ /**
49
+ * This function will be called when the user types within the input
50
+ * element of the component. An object including the string value, the
51
+ * error and the date value will be passed to this function.
52
+ * If the string value is a valid date, error will
53
+ * be null. Also, if the string value is not a valid date, date will be null.
54
+ */
55
+ onChange?: (val: {
56
+ value: string;
57
+ error: string | null;
58
+ date: Date | null;
59
+ }) => void;
60
+ /**
61
+ * This function will be called when the input element loses the focus.
62
+ * An object including the string value, the error and the date value
63
+ * will be passed to this function. If the string value is a valid date, error will
64
+ * be null. Also, if the string value is not a valid date, date will be null.
65
+ */
66
+ onBlur?: (val: {
67
+ value: string;
68
+ error: string | null;
69
+ date: Date | null;
70
+ }) => void;
71
+ /**
72
+ * If it is defined, the component will change its appearance, showing
73
+ * the error below the date input component. If it is not defined, the error
74
+ * messages will be managed internally, but never displayed on its own.
75
+ */
76
+ error?: string;
77
+ /**
78
+ * HTML autocomplete attribute. Lets the user specify if any permission the user agent has to provide automated assistance in filling out the input value.
79
+ * Its value must be one of all the possible values of the HTML autocomplete attribute: 'on', 'off', 'email', 'username', 'new-password', ...
80
+ */
81
+ autocomplete?: string;
82
+ /**
83
+ * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
84
+ * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
85
+ */
86
+ margin?: Space | Margin;
87
+ /**
88
+ * Size of the component.
89
+ */
90
+ size?: "medium" | "large" | "fillParent";
91
+ /**
92
+ * Value of the tabindex attribute.
93
+ */
94
+ tabIndex?: number;
95
+ };
96
+ /**
97
+ * Reference to the component.
98
+ */
99
+ export declare type RefType = HTMLDivElement;
100
+ 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
+ /// <reference types="react" />
2
+ import DialogPropsType from "./types";
3
+ declare const DxcDialog: ({ isCloseVisible, onCloseClick, children, overlay, onBackgroundClick, padding, tabIndex, }: DialogPropsType) => JSX.Element;
4
+ export default DxcDialog;