@dxc-technology/halstack-react 0.0.0-ba408d4 → 0.0.0-bb8df10

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 (351) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +1 -4
  3. package/HalstackContext.d.ts +12 -0
  4. package/HalstackContext.js +295 -0
  5. package/accordion/Accordion.d.ts +4 -0
  6. package/accordion/Accordion.js +18 -81
  7. package/accordion/Accordion.stories.tsx +307 -0
  8. package/accordion/Accordion.test.js +72 -0
  9. package/accordion/types.d.ts +68 -0
  10. package/accordion/types.js +5 -0
  11. package/accordion-group/AccordionGroup.d.ts +7 -0
  12. package/accordion-group/AccordionGroup.js +61 -76
  13. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  14. package/accordion-group/AccordionGroup.test.js +151 -0
  15. package/accordion-group/types.d.ts +72 -0
  16. package/accordion-group/types.js +5 -0
  17. package/alert/Alert.d.ts +4 -0
  18. package/alert/Alert.js +7 -23
  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 +6 -4
  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 +28 -64
  34. package/box/Box.stories.tsx +132 -0
  35. package/box/Box.test.js +18 -0
  36. package/box/types.d.ts +43 -0
  37. package/box/types.js +5 -0
  38. package/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 +1 -1
  44. package/button/Button.js +61 -87
  45. package/button/Button.stories.tsx +259 -282
  46. package/button/Button.test.js +35 -0
  47. package/button/types.d.ts +14 -18
  48. package/card/Card.d.ts +4 -0
  49. package/card/Card.js +38 -77
  50. package/card/Card.stories.tsx +201 -0
  51. package/card/Card.test.js +50 -0
  52. package/card/ice-cream.jpg +0 -0
  53. package/card/types.d.ts +67 -0
  54. package/card/types.js +5 -0
  55. package/checkbox/Checkbox.d.ts +4 -0
  56. package/checkbox/Checkbox.js +45 -63
  57. package/checkbox/Checkbox.stories.tsx +188 -0
  58. package/checkbox/Checkbox.test.js +78 -0
  59. package/checkbox/types.d.ts +64 -0
  60. package/checkbox/types.js +5 -0
  61. package/chip/Chip.d.ts +4 -0
  62. package/chip/Chip.js +16 -76
  63. package/chip/Chip.stories.tsx +119 -0
  64. package/chip/Chip.test.js +56 -0
  65. package/chip/types.d.ts +45 -0
  66. package/chip/types.js +5 -0
  67. package/common/variables.js +316 -377
  68. package/date-input/DateInput.d.ts +4 -0
  69. package/date-input/DateInput.js +65 -89
  70. package/date-input/DateInput.stories.tsx +138 -0
  71. package/date-input/DateInput.test.js +479 -0
  72. package/date-input/types.d.ts +107 -0
  73. package/date-input/types.js +5 -0
  74. package/dialog/Dialog.d.ts +4 -0
  75. package/dialog/Dialog.js +52 -74
  76. package/dialog/Dialog.stories.tsx +211 -0
  77. package/dialog/Dialog.test.js +70 -0
  78. package/dialog/types.d.ts +43 -0
  79. package/dialog/types.js +5 -0
  80. package/dropdown/Dropdown.d.ts +4 -0
  81. package/dropdown/Dropdown.js +239 -302
  82. package/dropdown/Dropdown.stories.tsx +312 -0
  83. package/dropdown/Dropdown.test.js +591 -0
  84. package/dropdown/DropdownMenu.d.ts +4 -0
  85. package/dropdown/DropdownMenu.js +80 -0
  86. package/dropdown/DropdownMenuItem.d.ts +4 -0
  87. package/dropdown/DropdownMenuItem.js +92 -0
  88. package/dropdown/types.d.ts +100 -0
  89. package/dropdown/types.js +5 -0
  90. package/file-input/FileInput.d.ts +4 -0
  91. package/file-input/FileInput.js +172 -111
  92. package/file-input/FileInput.stories.tsx +507 -0
  93. package/file-input/FileInput.test.js +457 -0
  94. package/file-input/FileItem.d.ts +14 -0
  95. package/file-input/FileItem.js +16 -23
  96. package/file-input/types.d.ts +112 -0
  97. package/file-input/types.js +5 -0
  98. package/flex/Flex.d.ts +4 -0
  99. package/flex/Flex.js +57 -0
  100. package/flex/Flex.stories.tsx +103 -0
  101. package/flex/types.d.ts +21 -0
  102. package/flex/types.js +5 -0
  103. package/footer/Footer.d.ts +4 -0
  104. package/footer/Footer.js +36 -148
  105. package/footer/Footer.stories.tsx +130 -0
  106. package/footer/Footer.test.js +109 -0
  107. package/footer/Icons.d.ts +2 -0
  108. package/footer/Icons.js +4 -4
  109. package/footer/types.d.ts +65 -0
  110. package/footer/types.js +5 -0
  111. package/header/Header.d.ts +7 -0
  112. package/header/Header.js +119 -140
  113. package/header/Header.stories.tsx +172 -0
  114. package/header/Header.test.js +79 -0
  115. package/header/Icons.d.ts +2 -0
  116. package/header/Icons.js +4 -29
  117. package/header/types.d.ts +47 -0
  118. package/header/types.js +5 -0
  119. package/heading/Heading.d.ts +4 -0
  120. package/heading/Heading.js +7 -24
  121. package/heading/Heading.stories.tsx +54 -0
  122. package/heading/Heading.test.js +186 -0
  123. package/heading/types.d.ts +33 -0
  124. package/heading/types.js +5 -0
  125. package/inset/Inset.d.ts +3 -0
  126. package/inset/Inset.js +51 -0
  127. package/inset/Inset.stories.tsx +229 -0
  128. package/inset/types.d.ts +37 -0
  129. package/inset/types.js +5 -0
  130. package/layout/ApplicationLayout.d.ts +20 -0
  131. package/layout/ApplicationLayout.js +71 -135
  132. package/layout/ApplicationLayout.stories.tsx +161 -0
  133. package/layout/Icons.d.ts +5 -0
  134. package/layout/Icons.js +13 -2
  135. package/layout/SidenavContext.d.ts +5 -0
  136. package/layout/SidenavContext.js +19 -0
  137. package/layout/types.d.ts +42 -0
  138. package/layout/types.js +5 -0
  139. package/link/Link.d.ts +4 -0
  140. package/link/Link.js +60 -107
  141. package/link/Link.stories.tsx +193 -0
  142. package/link/Link.test.js +83 -0
  143. package/link/types.d.ts +54 -0
  144. package/link/types.js +5 -0
  145. package/main.d.ts +12 -12
  146. package/main.js +64 -58
  147. package/number-input/NumberInput.d.ts +4 -0
  148. package/number-input/NumberInput.js +16 -68
  149. package/number-input/NumberInput.stories.tsx +115 -0
  150. package/number-input/NumberInput.test.js +506 -0
  151. package/number-input/NumberInputContext.d.ts +4 -0
  152. package/number-input/NumberInputContext.js +5 -2
  153. package/number-input/numberInputContextTypes.d.ts +19 -0
  154. package/number-input/numberInputContextTypes.js +5 -0
  155. package/number-input/types.d.ts +124 -0
  156. package/number-input/types.js +5 -0
  157. package/package.json +17 -13
  158. package/paginator/Paginator.js +19 -46
  159. package/paginator/Paginator.stories.tsx +63 -0
  160. package/paginator/Paginator.test.js +308 -0
  161. package/paragraph/Paragraph.d.ts +6 -0
  162. package/paragraph/Paragraph.js +38 -0
  163. package/paragraph/Paragraph.stories.tsx +44 -0
  164. package/password-input/PasswordInput.d.ts +4 -0
  165. package/password-input/PasswordInput.js +24 -57
  166. package/password-input/PasswordInput.stories.tsx +131 -0
  167. package/password-input/PasswordInput.test.js +180 -0
  168. package/password-input/types.d.ts +110 -0
  169. package/password-input/types.js +5 -0
  170. package/progress-bar/ProgressBar.d.ts +4 -0
  171. package/progress-bar/ProgressBar.js +60 -72
  172. package/progress-bar/ProgressBar.stories.jsx +60 -0
  173. package/progress-bar/ProgressBar.test.js +110 -0
  174. package/progress-bar/types.d.ts +36 -0
  175. package/progress-bar/types.js +5 -0
  176. package/quick-nav/QuickNav.d.ts +4 -0
  177. package/quick-nav/QuickNav.js +118 -0
  178. package/quick-nav/QuickNav.stories.tsx +264 -0
  179. package/quick-nav/types.d.ts +21 -0
  180. package/quick-nav/types.js +5 -0
  181. package/radio-group/Radio.d.ts +4 -0
  182. package/radio-group/Radio.js +141 -0
  183. package/radio-group/RadioGroup.d.ts +4 -0
  184. package/radio-group/RadioGroup.js +281 -0
  185. package/radio-group/RadioGroup.stories.tsx +100 -0
  186. package/radio-group/RadioGroup.test.js +695 -0
  187. package/radio-group/types.d.ts +114 -0
  188. package/radio-group/types.js +5 -0
  189. package/resultsetTable/ResultsetTable.d.ts +4 -0
  190. package/resultsetTable/ResultsetTable.js +9 -29
  191. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  192. package/resultsetTable/ResultsetTable.test.js +348 -0
  193. package/resultsetTable/types.d.ts +67 -0
  194. package/resultsetTable/types.js +5 -0
  195. package/select/Icons.d.ts +10 -0
  196. package/select/Icons.js +93 -0
  197. package/select/Listbox.d.ts +4 -0
  198. package/select/Listbox.js +199 -0
  199. package/select/Option.d.ts +4 -0
  200. package/select/Option.js +110 -0
  201. package/select/Select.d.ts +4 -0
  202. package/select/Select.js +158 -380
  203. package/select/Select.stories.tsx +627 -0
  204. package/select/Select.test.js +2175 -0
  205. package/select/types.d.ts +210 -0
  206. package/select/types.js +5 -0
  207. package/sidenav/Sidenav.d.ts +10 -0
  208. package/sidenav/Sidenav.js +186 -63
  209. package/sidenav/Sidenav.stories.tsx +180 -0
  210. package/sidenav/Sidenav.test.js +44 -0
  211. package/sidenav/types.d.ts +73 -0
  212. package/sidenav/types.js +5 -0
  213. package/slider/Slider.d.ts +4 -0
  214. package/slider/Slider.js +147 -154
  215. package/slider/Slider.stories.tsx +183 -0
  216. package/slider/Slider.test.js +250 -0
  217. package/slider/types.d.ts +82 -0
  218. package/slider/types.js +5 -0
  219. package/spinner/Spinner.d.ts +4 -0
  220. package/spinner/Spinner.js +9 -26
  221. package/spinner/Spinner.stories.jsx +103 -0
  222. package/spinner/Spinner.test.js +64 -0
  223. package/spinner/types.d.ts +32 -0
  224. package/spinner/types.js +5 -0
  225. package/switch/Switch.d.ts +4 -0
  226. package/switch/Switch.js +129 -86
  227. package/switch/Switch.stories.tsx +138 -0
  228. package/switch/Switch.test.js +212 -0
  229. package/switch/types.d.ts +61 -0
  230. package/switch/types.js +5 -0
  231. package/table/Table.d.ts +4 -0
  232. package/table/Table.js +3 -3
  233. package/table/Table.stories.jsx +277 -0
  234. package/table/Table.test.js +26 -0
  235. package/table/types.d.ts +21 -0
  236. package/table/types.js +5 -0
  237. package/tabs/Tab.d.ts +4 -0
  238. package/tabs/Tab.js +135 -0
  239. package/tabs/Tabs.d.ts +4 -0
  240. package/tabs/Tabs.js +364 -156
  241. package/tabs/Tabs.stories.tsx +186 -0
  242. package/tabs/Tabs.test.js +351 -0
  243. package/tabs/types.d.ts +92 -0
  244. package/tabs/types.js +5 -0
  245. package/tabs-nav/NavTabs.d.ts +8 -0
  246. package/tabs-nav/NavTabs.js +125 -0
  247. package/tabs-nav/NavTabs.stories.tsx +170 -0
  248. package/tabs-nav/NavTabs.test.js +82 -0
  249. package/tabs-nav/Tab.d.ts +4 -0
  250. package/tabs-nav/Tab.js +130 -0
  251. package/tabs-nav/types.d.ts +53 -0
  252. package/tabs-nav/types.js +5 -0
  253. package/tag/Tag.d.ts +4 -0
  254. package/tag/Tag.js +34 -59
  255. package/tag/Tag.stories.tsx +142 -0
  256. package/tag/Tag.test.js +60 -0
  257. package/tag/types.d.ts +69 -0
  258. package/tag/types.js +5 -0
  259. package/text-input/Suggestion.d.ts +4 -0
  260. package/text-input/Suggestion.js +55 -0
  261. package/text-input/TextInput.d.ts +4 -0
  262. package/text-input/TextInput.js +103 -167
  263. package/text-input/TextInput.stories.tsx +473 -0
  264. package/text-input/TextInput.test.js +1712 -0
  265. package/text-input/types.d.ts +178 -0
  266. package/text-input/types.js +5 -0
  267. package/textarea/Textarea.d.ts +4 -0
  268. package/textarea/Textarea.js +39 -79
  269. package/textarea/Textarea.stories.jsx +157 -0
  270. package/textarea/Textarea.test.js +437 -0
  271. package/textarea/types.d.ts +137 -0
  272. package/textarea/types.js +5 -0
  273. package/toggle-group/ToggleGroup.d.ts +4 -0
  274. package/toggle-group/ToggleGroup.js +18 -46
  275. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  276. package/toggle-group/ToggleGroup.test.js +156 -0
  277. package/toggle-group/types.d.ts +105 -0
  278. package/toggle-group/types.js +5 -0
  279. package/typography/Typography.d.ts +4 -0
  280. package/typography/Typography.js +131 -0
  281. package/typography/Typography.stories.tsx +198 -0
  282. package/typography/types.d.ts +18 -0
  283. package/typography/types.js +5 -0
  284. package/useTheme.d.ts +2 -0
  285. package/useTheme.js +2 -2
  286. package/useTranslatedLabels.d.ts +2 -0
  287. package/useTranslatedLabels.js +20 -0
  288. package/wizard/Wizard.d.ts +4 -0
  289. package/wizard/Wizard.js +118 -104
  290. package/wizard/Wizard.stories.tsx +233 -0
  291. package/wizard/Wizard.test.js +141 -0
  292. package/wizard/types.d.ts +65 -0
  293. package/wizard/types.js +5 -0
  294. package/ThemeContext.js +0 -246
  295. package/V3Select/V3Select.js +0 -455
  296. package/V3Select/index.d.ts +0 -27
  297. package/V3Textarea/V3Textarea.js +0 -260
  298. package/V3Textarea/index.d.ts +0 -27
  299. package/accordion/index.d.ts +0 -28
  300. package/accordion-group/index.d.ts +0 -16
  301. package/alert/index.d.ts +0 -51
  302. package/box/index.d.ts +0 -25
  303. package/card/index.d.ts +0 -22
  304. package/checkbox/index.d.ts +0 -24
  305. package/chip/index.d.ts +0 -22
  306. package/date/Date.js +0 -373
  307. package/date/index.d.ts +0 -27
  308. package/date-input/index.d.ts +0 -95
  309. package/dialog/index.d.ts +0 -18
  310. package/dropdown/index.d.ts +0 -26
  311. package/file-input/index.d.ts +0 -81
  312. package/footer/index.d.ts +0 -25
  313. package/header/index.d.ts +0 -25
  314. package/heading/index.d.ts +0 -17
  315. package/input-text/Icons.js +0 -22
  316. package/input-text/InputText.js +0 -611
  317. package/input-text/index.d.ts +0 -36
  318. package/link/index.d.ts +0 -23
  319. package/number-input/index.d.ts +0 -113
  320. package/password-input/index.d.ts +0 -94
  321. package/progress-bar/index.d.ts +0 -18
  322. package/radio/Radio.js +0 -195
  323. package/radio/index.d.ts +0 -23
  324. package/resultsetTable/index.d.ts +0 -19
  325. package/select/index.d.ts +0 -131
  326. package/sidenav/index.d.ts +0 -13
  327. package/slider/index.d.ts +0 -29
  328. package/spinner/index.d.ts +0 -17
  329. package/switch/index.d.ts +0 -24
  330. package/table/index.d.ts +0 -13
  331. package/tabs/index.d.ts +0 -19
  332. package/tag/index.d.ts +0 -24
  333. package/text-input/index.d.ts +0 -135
  334. package/textarea/index.d.ts +0 -117
  335. package/toggle/Toggle.js +0 -186
  336. package/toggle/index.d.ts +0 -21
  337. package/toggle-group/index.d.ts +0 -21
  338. package/upload/Upload.js +0 -201
  339. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  340. package/upload/buttons-upload/Icons.js +0 -40
  341. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  342. package/upload/dragAndDropArea/Icons.js +0 -39
  343. package/upload/file-upload/FileToUpload.js +0 -115
  344. package/upload/file-upload/Icons.js +0 -66
  345. package/upload/files-upload/FilesToUpload.js +0 -109
  346. package/upload/index.d.ts +0 -15
  347. package/upload/transaction/Icons.js +0 -160
  348. package/upload/transaction/Transaction.js +0 -104
  349. package/upload/transactions/Transactions.js +0 -94
  350. package/wizard/Icons.js +0 -65
  351. package/wizard/index.d.ts +0 -18
@@ -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;
@@ -9,10 +9,10 @@ Object.defineProperty(exports, "__esModule", {
9
9
  });
10
10
  exports["default"] = void 0;
11
11
 
12
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
13
-
14
12
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
13
 
14
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
15
+
16
16
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
17
17
 
18
18
  var _react = _interopRequireWildcard(require("react"));
@@ -25,17 +25,15 @@ var _ClickAwayListener = _interopRequireDefault(require("@material-ui/core/Click
25
25
 
26
26
  var _Popover = _interopRequireDefault(require("@material-ui/core/Popover"));
27
27
 
28
- var _moment = _interopRequireDefault(require("moment"));
28
+ var _dayjs = _interopRequireDefault(require("dayjs"));
29
29
 
30
- var _dateFns = _interopRequireDefault(require("@date-io/date-fns"));
30
+ var _dayjs2 = _interopRequireDefault(require("@date-io/dayjs"));
31
31
 
32
32
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
33
33
 
34
- var _propTypes = _interopRequireDefault(require("prop-types"));
34
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
35
35
 
36
- var _variables = require("../common/variables.js");
37
-
38
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
36
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
39
37
 
40
38
  var _TextInput = _interopRequireDefault(require("../text-input/TextInput"));
41
39
 
@@ -45,37 +43,37 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
45
43
 
46
44
  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; }
47
45
 
46
+ 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; }
47
+
48
+ 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; }
49
+
50
+ var getValueForPicker = function getValueForPicker(value, format) {
51
+ return (0, _dayjs["default"])(value, format.toUpperCase(), true).format();
52
+ };
53
+
48
54
  var DxcDateInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
49
- var _ref$label = _ref.label,
50
- label = _ref$label === void 0 ? "" : _ref$label,
51
- _ref$name = _ref.name,
52
- name = _ref$name === void 0 ? "" : _ref$name,
55
+ var label = _ref.label,
56
+ name = _ref.name,
57
+ _ref$defaultValue = _ref.defaultValue,
58
+ defaultValue = _ref$defaultValue === void 0 ? "" : _ref$defaultValue,
53
59
  value = _ref.value,
54
60
  _ref$format = _ref.format,
55
61
  format = _ref$format === void 0 ? "dd-MM-yyyy" : _ref$format,
56
- _ref$helperText = _ref.helperText,
57
- helperText = _ref$helperText === void 0 ? "" : _ref$helperText,
62
+ helperText = _ref.helperText,
58
63
  _ref$placeholder = _ref.placeholder,
59
64
  placeholder = _ref$placeholder === void 0 ? false : _ref$placeholder,
60
- _ref$clearable = _ref.clearable,
61
- clearable = _ref$clearable === void 0 ? false : _ref$clearable,
62
- _ref$disabled = _ref.disabled,
63
- disabled = _ref$disabled === void 0 ? false : _ref$disabled,
64
- _ref$optional = _ref.optional,
65
- optional = _ref$optional === void 0 ? false : _ref$optional,
65
+ clearable = _ref.clearable,
66
+ disabled = _ref.disabled,
67
+ optional = _ref.optional,
66
68
  onChange = _ref.onChange,
67
69
  onBlur = _ref.onBlur,
68
- _ref$error = _ref.error,
69
- error = _ref$error === void 0 ? "" : _ref$error,
70
- _ref$autocomplete = _ref.autocomplete,
71
- autocomplete = _ref$autocomplete === void 0 ? "off" : _ref$autocomplete,
70
+ error = _ref.error,
71
+ autocomplete = _ref.autocomplete,
72
72
  margin = _ref.margin,
73
- _ref$size = _ref.size,
74
- size = _ref$size === void 0 ? "medium" : _ref$size,
75
- _ref$tabIndex = _ref.tabIndex,
76
- tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
73
+ size = _ref.size,
74
+ tabIndex = _ref.tabIndex;
77
75
 
78
- var _useState = (0, _react.useState)(""),
76
+ var _useState = (0, _react.useState)(defaultValue),
79
77
  _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
80
78
  innerValue = _useState2[0],
81
79
  setInnerValue = _useState2[1];
@@ -91,11 +89,13 @@ var DxcDateInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref
91
89
  setAnchorEl = _useState6[1];
92
90
 
93
91
  var colorsTheme = (0, _useTheme["default"])();
92
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
93
+ var refDate = ref || (0, _react.useRef)(null);
94
94
 
95
95
  var handleCalendarOnKeyDown = function handleCalendarOnKeyDown(event) {
96
- switch (event.keyCode) {
97
- case 27:
98
- // Esc
96
+ switch (event.key) {
97
+ case "Esc":
98
+ case "Escape":
99
99
  event.preventDefault();
100
100
  setIsOpen(false);
101
101
  break;
@@ -103,12 +103,13 @@ var DxcDateInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref
103
103
  };
104
104
 
105
105
  var handleCalendarOnClick = function handleCalendarOnClick(newDate) {
106
- var newValue = (0, _moment["default"])(newDate).format(format.toUpperCase());
106
+ var newValue = (0, _dayjs["default"])(newDate).format(format.toUpperCase());
107
107
  value !== null && value !== void 0 ? value : setInnerValue(newValue);
108
- onChange === null || onChange === void 0 ? void 0 : onChange({
108
+ newDate !== null && newDate !== void 0 && newDate.toJSON() ? onChange === null || onChange === void 0 ? void 0 : onChange({
109
109
  value: newValue,
110
- error: null,
111
- date: newDate && newDate.toJSON() ? newDate : null
110
+ date: newDate
111
+ }) : onChange === null || onChange === void 0 ? void 0 : onChange({
112
+ value: newValue
112
113
  });
113
114
  };
114
115
 
@@ -116,36 +117,39 @@ var DxcDateInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref
116
117
  var newValue = _ref2.value,
117
118
  inputError = _ref2.error;
118
119
  value !== null && value !== void 0 ? value : setInnerValue(newValue);
119
- var momentDate = (0, _moment["default"])(newValue, format.toUpperCase(), true);
120
- var invalidDateMessage = newValue !== "" && !momentDate.isValid() ? "Invalid date." : null;
121
- onChange === null || onChange === void 0 ? void 0 : onChange({
120
+ var dayjsDate = (0, _dayjs["default"])(newValue, format.toUpperCase(), true);
121
+ var invalidDateMessage = newValue !== "" && !dayjsDate.isValid() && translatedLabels.dateInput.invalidDateErrorMessage;
122
+ var callbackParams = inputError || invalidDateMessage ? {
122
123
  value: newValue,
123
- error: inputError || invalidDateMessage,
124
- date: momentDate.isValid() ? momentDate._d : null
125
- });
124
+ error: inputError || invalidDateMessage
125
+ } : {
126
+ value: newValue
127
+ };
128
+ dayjsDate.isValid() ? onChange === null || onChange === void 0 ? void 0 : onChange(_objectSpread(_objectSpread({}, callbackParams), {}, {
129
+ date: dayjsDate.toDate()
130
+ })) : onChange === null || onChange === void 0 ? void 0 : onChange(callbackParams);
126
131
  };
127
132
 
128
133
  var handleIOnBlur = function handleIOnBlur(_ref3) {
129
134
  var value = _ref3.value,
130
135
  inputError = _ref3.error;
131
- var momentDate = (0, _moment["default"])(value, format.toUpperCase(), true);
132
- var invalidDateMessage = value !== "" && !momentDate.isValid() ? "Invalid date." : null;
133
- onBlur === null || onBlur === void 0 ? void 0 : onBlur({
136
+ var dayjsDate = (0, _dayjs["default"])(value, format.toUpperCase(), true);
137
+ var invalidDateMessage = value !== "" && !dayjsDate.isValid() && translatedLabels.dateInput.invalidDateErrorMessage;
138
+ var callbackParams = inputError || invalidDateMessage ? {
134
139
  value: value,
135
- error: inputError || invalidDateMessage,
136
- date: momentDate.isValid() ? momentDate._d : null
137
- });
138
- };
139
-
140
- var getValueForPicker = function getValueForPicker() {
141
- return (0, _moment["default"])(value !== null && value !== void 0 ? value : innerValue, format.toUpperCase(), true).format();
140
+ error: inputError || invalidDateMessage
141
+ } : {
142
+ value: value
143
+ };
144
+ dayjsDate.isValid() ? onBlur === null || onBlur === void 0 ? void 0 : onBlur(_objectSpread(_objectSpread({}, callbackParams), {}, {
145
+ date: dayjsDate.toDate()
146
+ })) : onBlur === null || onBlur === void 0 ? void 0 : onBlur(callbackParams);
142
147
  };
143
148
 
144
- var openCalendar = function openCalendar(event) {
145
- if (event) {
146
- setIsOpen(!isOpen);
147
- setAnchorEl(event.currentTarget);
148
- }
149
+ var openCalendar = function openCalendar() {
150
+ var dateBtn = refDate.current.getElementsByTagName("button")[0];
151
+ setIsOpen(!isOpen);
152
+ setAnchorEl(dateBtn);
149
153
  };
150
154
 
151
155
  var closeCalendar = function closeCalendar() {
@@ -309,10 +313,11 @@ var DxcDateInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref
309
313
  }, /*#__PURE__*/_react["default"].createElement(_core.MuiThemeProvider, {
310
314
  theme: dateTheme
311
315
  }, /*#__PURE__*/_react["default"].createElement(_pickers.MuiPickersUtilsProvider, {
312
- utils: _dateFns["default"]
316
+ utils: _dayjs2["default"]
313
317
  }, /*#__PURE__*/_react["default"].createElement(StyledDPicker, null, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
314
318
  label: label,
315
319
  name: name,
320
+ defaultValue: defaultValue,
316
321
  value: value !== null && value !== void 0 ? value : innerValue,
317
322
  helperText: helperText,
318
323
  placeholder: placeholder ? format.toUpperCase() : null,
@@ -327,7 +332,7 @@ var DxcDateInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref
327
332
  margin: margin,
328
333
  size: size,
329
334
  tabIndex: tabIndex,
330
- ref: ref
335
+ ref: refDate
331
336
  }), /*#__PURE__*/_react["default"].createElement(_Popover["default"], {
332
337
  onKeyDown: handleCalendarOnKeyDown,
333
338
  open: isOpen,
@@ -352,7 +357,7 @@ var DxcDateInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref
352
357
  "aria-modal": "true"
353
358
  }, /*#__PURE__*/_react["default"].createElement(_pickers.DatePicker, {
354
359
  variant: "static",
355
- value: getValueForPicker(),
360
+ value: getValueForPicker(value !== null && value !== void 0 ? value : innerValue, format),
356
361
  onChange: function onChange(date) {
357
362
  return handleCalendarOnClick(date);
358
363
  },
@@ -361,36 +366,7 @@ var DxcDateInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref
361
366
  }))))))));
362
367
  });
363
368
 
364
- var sizes = {
365
- medium: "360px",
366
- large: "480px",
367
- fillParent: "100%"
368
- };
369
-
370
369
  var StyledDPicker = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])([""])));
371
370
 
372
- DxcDateInput.propTypes = {
373
- label: _propTypes["default"].string,
374
- name: _propTypes["default"].string,
375
- value: _propTypes["default"].string,
376
- format: _propTypes["default"].string,
377
- helperText: _propTypes["default"].string,
378
- placeholder: _propTypes["default"].bool,
379
- clearable: _propTypes["default"].bool,
380
- disabled: _propTypes["default"].bool,
381
- optional: _propTypes["default"].bool,
382
- onChange: _propTypes["default"].func,
383
- onBlur: _propTypes["default"].func,
384
- error: _propTypes["default"].string,
385
- autocomplete: _propTypes["default"].string,
386
- size: _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(sizes))),
387
- margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
388
- top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
389
- bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
390
- left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
391
- right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
392
- }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))]),
393
- tabIndex: _propTypes["default"].number
394
- };
395
371
  var _default = DxcDateInput;
396
372
  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" defaultValue="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." defaultValue="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" defaultValue="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" defaultValue="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" defaultValue="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" defaultValue="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" defaultValue="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
+ };