@dxc-technology/halstack-react 0.0.0-9d82cb9 → 0.0.0-9e54008

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 (307) hide show
  1. package/BackgroundColorContext.d.ts +2 -2
  2. package/BackgroundColorContext.js +1 -1
  3. package/HalstackContext.d.ts +1336 -0
  4. package/HalstackContext.js +335 -0
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +110 -146
  7. package/accordion/Accordion.stories.tsx +108 -118
  8. package/accordion/Accordion.test.js +71 -0
  9. package/accordion/types.d.ts +7 -18
  10. package/accordion-group/AccordionGroup.d.ts +5 -4
  11. package/accordion-group/AccordionGroup.js +34 -76
  12. package/accordion-group/AccordionGroup.stories.tsx +94 -67
  13. package/accordion-group/AccordionGroup.test.js +116 -0
  14. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  15. package/accordion-group/AccordionGroupAccordion.js +43 -0
  16. package/accordion-group/types.d.ts +13 -18
  17. package/alert/Alert.js +9 -10
  18. package/alert/Alert.stories.tsx +28 -0
  19. package/alert/Alert.test.js +92 -0
  20. package/badge/Badge.d.ts +4 -0
  21. package/badge/Badge.js +5 -3
  22. package/badge/types.d.ts +5 -0
  23. package/bleed/Bleed.d.ts +2 -2
  24. package/bleed/Bleed.js +1 -34
  25. package/bleed/Bleed.stories.tsx +95 -95
  26. package/bleed/types.d.ts +25 -1
  27. package/box/Box.d.ts +1 -1
  28. package/box/Box.js +19 -48
  29. package/box/Box.stories.tsx +38 -51
  30. package/box/Box.test.js +18 -0
  31. package/box/types.d.ts +0 -11
  32. package/bulleted-list/BulletedList.d.ts +7 -0
  33. package/bulleted-list/BulletedList.js +125 -0
  34. package/bulleted-list/BulletedList.stories.tsx +206 -0
  35. package/bulleted-list/types.d.ts +38 -0
  36. package/bulleted-list/types.js +5 -0
  37. package/button/Button.js +52 -70
  38. package/button/Button.stories.tsx +159 -8
  39. package/button/Button.test.js +35 -0
  40. package/button/types.d.ts +5 -5
  41. package/card/Card.d.ts +1 -1
  42. package/card/Card.js +37 -58
  43. package/card/Card.stories.tsx +12 -42
  44. package/card/Card.test.js +50 -0
  45. package/card/types.d.ts +1 -6
  46. package/checkbox/Checkbox.d.ts +2 -2
  47. package/checkbox/Checkbox.js +107 -110
  48. package/checkbox/Checkbox.stories.tsx +198 -130
  49. package/checkbox/Checkbox.test.js +155 -0
  50. package/checkbox/types.d.ts +11 -3
  51. package/chip/Chip.d.ts +1 -1
  52. package/chip/Chip.js +36 -95
  53. package/chip/Chip.stories.tsx +123 -30
  54. package/chip/Chip.test.js +54 -0
  55. package/chip/types.d.ts +5 -13
  56. package/common/OpenSans.css +68 -80
  57. package/common/coreTokens.d.ts +146 -0
  58. package/common/coreTokens.js +167 -0
  59. package/common/utils.d.ts +1 -0
  60. package/common/utils.js +4 -4
  61. package/common/variables.d.ts +1482 -0
  62. package/common/variables.js +1097 -1348
  63. package/date-input/Calendar.d.ts +4 -0
  64. package/date-input/Calendar.js +258 -0
  65. package/date-input/DateInput.js +169 -258
  66. package/date-input/DateInput.stories.tsx +199 -33
  67. package/date-input/DateInput.test.js +835 -0
  68. package/date-input/DatePicker.d.ts +4 -0
  69. package/date-input/DatePicker.js +146 -0
  70. package/date-input/Icons.d.ts +6 -0
  71. package/date-input/Icons.js +75 -0
  72. package/date-input/YearPicker.d.ts +4 -0
  73. package/date-input/YearPicker.js +126 -0
  74. package/date-input/types.d.ts +67 -9
  75. package/dialog/Dialog.d.ts +1 -1
  76. package/dialog/Dialog.js +68 -103
  77. package/dialog/Dialog.stories.tsx +154 -171
  78. package/dialog/Dialog.test.js +369 -0
  79. package/dialog/types.d.ts +0 -12
  80. package/dropdown/Dropdown.d.ts +1 -1
  81. package/dropdown/Dropdown.js +248 -277
  82. package/dropdown/Dropdown.stories.tsx +255 -64
  83. package/dropdown/Dropdown.test.js +586 -0
  84. package/dropdown/DropdownMenu.d.ts +4 -0
  85. package/dropdown/DropdownMenu.js +74 -0
  86. package/dropdown/DropdownMenuItem.d.ts +4 -0
  87. package/dropdown/DropdownMenuItem.js +79 -0
  88. package/dropdown/types.d.ts +27 -16
  89. package/file-input/FileInput.d.ts +2 -2
  90. package/file-input/FileInput.js +180 -223
  91. package/file-input/FileInput.stories.tsx +122 -11
  92. package/file-input/FileInput.test.js +457 -0
  93. package/file-input/FileItem.d.ts +4 -14
  94. package/file-input/FileItem.js +44 -66
  95. package/file-input/types.d.ts +18 -1
  96. package/flex/Flex.d.ts +4 -0
  97. package/flex/Flex.js +71 -0
  98. package/flex/Flex.stories.tsx +112 -0
  99. package/flex/types.d.ts +97 -0
  100. package/flex/types.js +5 -0
  101. package/footer/Footer.d.ts +1 -1
  102. package/footer/Footer.js +26 -116
  103. package/footer/Footer.stories.tsx +26 -16
  104. package/footer/Footer.test.js +97 -0
  105. package/footer/Icons.js +1 -1
  106. package/footer/types.d.ts +1 -6
  107. package/grid/Grid.d.ts +7 -0
  108. package/grid/Grid.js +91 -0
  109. package/grid/Grid.stories.tsx +219 -0
  110. package/grid/types.d.ts +115 -0
  111. package/grid/types.js +5 -0
  112. package/header/Header.d.ts +4 -3
  113. package/header/Header.js +102 -150
  114. package/header/Header.stories.tsx +152 -63
  115. package/header/Header.test.js +79 -0
  116. package/header/Icons.js +2 -2
  117. package/header/types.d.ts +0 -13
  118. package/heading/Heading.js +1 -1
  119. package/heading/Heading.test.js +186 -0
  120. package/inset/Inset.js +1 -34
  121. package/inset/Inset.stories.tsx +37 -36
  122. package/inset/types.d.ts +25 -1
  123. package/layout/ApplicationLayout.d.ts +16 -6
  124. package/layout/ApplicationLayout.js +72 -126
  125. package/layout/ApplicationLayout.stories.tsx +84 -93
  126. package/layout/Icons.d.ts +5 -0
  127. package/layout/Icons.js +13 -2
  128. package/layout/SidenavContext.d.ts +5 -0
  129. package/layout/SidenavContext.js +19 -0
  130. package/layout/types.d.ts +19 -35
  131. package/link/Link.d.ts +3 -2
  132. package/link/Link.js +63 -88
  133. package/link/Link.stories.tsx +159 -52
  134. package/link/Link.test.js +81 -0
  135. package/link/types.d.ts +7 -27
  136. package/main.d.ts +12 -15
  137. package/main.js +57 -75
  138. package/nav-tabs/NavTabs.d.ts +8 -0
  139. package/nav-tabs/NavTabs.js +122 -0
  140. package/nav-tabs/NavTabs.stories.tsx +274 -0
  141. package/nav-tabs/NavTabs.test.js +82 -0
  142. package/nav-tabs/Tab.d.ts +4 -0
  143. package/nav-tabs/Tab.js +146 -0
  144. package/nav-tabs/types.d.ts +52 -0
  145. package/nav-tabs/types.js +5 -0
  146. package/number-input/NumberInput.js +11 -18
  147. package/number-input/NumberInput.stories.tsx +5 -5
  148. package/number-input/NumberInput.test.js +542 -0
  149. package/number-input/types.d.ts +17 -10
  150. package/package.json +20 -23
  151. package/paginator/Icons.d.ts +5 -0
  152. package/paginator/Icons.js +16 -28
  153. package/paginator/Paginator.js +20 -49
  154. package/paginator/Paginator.stories.tsx +24 -0
  155. package/paginator/Paginator.test.js +318 -0
  156. package/paragraph/Paragraph.d.ts +5 -0
  157. package/paragraph/Paragraph.js +38 -0
  158. package/paragraph/Paragraph.stories.tsx +44 -0
  159. package/password-input/PasswordInput.js +7 -4
  160. package/password-input/PasswordInput.test.js +181 -0
  161. package/password-input/types.d.ts +14 -11
  162. package/progress-bar/ProgressBar.js +61 -55
  163. package/progress-bar/ProgressBar.stories.jsx +47 -12
  164. package/progress-bar/ProgressBar.test.js +110 -0
  165. package/quick-nav/QuickNav.d.ts +4 -0
  166. package/quick-nav/QuickNav.js +117 -0
  167. package/quick-nav/QuickNav.stories.tsx +356 -0
  168. package/quick-nav/types.d.ts +21 -0
  169. package/quick-nav/types.js +5 -0
  170. package/radio-group/Radio.d.ts +1 -1
  171. package/radio-group/Radio.js +60 -34
  172. package/radio-group/RadioGroup.js +81 -68
  173. package/radio-group/RadioGroup.stories.tsx +171 -36
  174. package/radio-group/RadioGroup.test.js +722 -0
  175. package/radio-group/types.d.ts +81 -3
  176. package/resultsetTable/Icons.d.ts +7 -0
  177. package/resultsetTable/Icons.js +51 -0
  178. package/resultsetTable/ResultsetTable.js +50 -106
  179. package/resultsetTable/ResultsetTable.stories.tsx +50 -25
  180. package/resultsetTable/ResultsetTable.test.js +325 -0
  181. package/resultsetTable/types.d.ts +1 -1
  182. package/select/Icons.d.ts +10 -0
  183. package/select/Icons.js +93 -0
  184. package/select/Listbox.d.ts +4 -0
  185. package/select/Listbox.js +169 -0
  186. package/select/Option.d.ts +4 -0
  187. package/select/Option.js +97 -0
  188. package/select/Select.js +189 -386
  189. package/select/Select.stories.tsx +600 -201
  190. package/select/Select.test.js +2228 -0
  191. package/select/types.d.ts +53 -13
  192. package/sidenav/Icons.d.ts +7 -0
  193. package/sidenav/Icons.js +51 -0
  194. package/sidenav/Sidenav.d.ts +6 -5
  195. package/sidenav/Sidenav.js +146 -44
  196. package/sidenav/Sidenav.stories.tsx +251 -151
  197. package/sidenav/Sidenav.test.js +44 -0
  198. package/sidenav/types.d.ts +52 -26
  199. package/slider/Slider.d.ts +2 -2
  200. package/slider/Slider.js +123 -98
  201. package/slider/Slider.stories.tsx +72 -9
  202. package/slider/Slider.test.js +250 -0
  203. package/slider/types.d.ts +8 -0
  204. package/spinner/Spinner.js +18 -24
  205. package/spinner/Spinner.stories.jsx +53 -27
  206. package/spinner/Spinner.test.js +64 -0
  207. package/switch/Switch.d.ts +2 -2
  208. package/switch/Switch.js +152 -69
  209. package/switch/Switch.stories.tsx +53 -42
  210. package/switch/Switch.test.js +225 -0
  211. package/switch/types.d.ts +10 -2
  212. package/table/Table.js +3 -3
  213. package/table/Table.stories.jsx +80 -1
  214. package/table/Table.test.js +26 -0
  215. package/tabs/Tab.d.ts +4 -0
  216. package/tabs/Tab.js +132 -0
  217. package/tabs/Tabs.d.ts +1 -1
  218. package/tabs/Tabs.js +362 -114
  219. package/tabs/Tabs.stories.tsx +122 -18
  220. package/tabs/Tabs.test.js +350 -0
  221. package/tabs/types.d.ts +37 -15
  222. package/tag/Tag.d.ts +1 -1
  223. package/tag/Tag.js +24 -36
  224. package/tag/Tag.stories.tsx +37 -27
  225. package/tag/Tag.test.js +60 -0
  226. package/tag/types.d.ts +23 -14
  227. package/text-input/Icons.d.ts +8 -0
  228. package/text-input/Icons.js +60 -0
  229. package/text-input/Suggestion.d.ts +4 -0
  230. package/text-input/Suggestion.js +84 -0
  231. package/text-input/Suggestions.d.ts +4 -0
  232. package/text-input/Suggestions.js +134 -0
  233. package/text-input/TextInput.js +225 -346
  234. package/text-input/TextInput.stories.tsx +310 -197
  235. package/text-input/TextInput.test.js +1723 -0
  236. package/text-input/types.d.ts +50 -12
  237. package/textarea/Textarea.js +22 -30
  238. package/textarea/Textarea.stories.jsx +93 -13
  239. package/textarea/Textarea.test.js +435 -0
  240. package/textarea/types.d.ts +18 -11
  241. package/toggle-group/ToggleGroup.d.ts +2 -2
  242. package/toggle-group/ToggleGroup.js +12 -8
  243. package/toggle-group/ToggleGroup.stories.tsx +46 -4
  244. package/toggle-group/ToggleGroup.test.js +156 -0
  245. package/toggle-group/types.d.ts +10 -2
  246. package/typography/Typography.d.ts +4 -0
  247. package/typography/Typography.js +32 -0
  248. package/typography/Typography.stories.tsx +198 -0
  249. package/typography/types.d.ts +18 -0
  250. package/typography/types.js +5 -0
  251. package/useTheme.d.ts +1234 -1
  252. package/useTheme.js +3 -3
  253. package/useTranslatedLabels.d.ts +85 -0
  254. package/useTranslatedLabels.js +20 -0
  255. package/utils/BaseTypography.d.ts +21 -0
  256. package/utils/BaseTypography.js +108 -0
  257. package/utils/FocusLock.d.ts +13 -0
  258. package/utils/FocusLock.js +138 -0
  259. package/wizard/Wizard.d.ts +1 -1
  260. package/wizard/Wizard.js +59 -55
  261. package/wizard/Wizard.stories.tsx +48 -19
  262. package/wizard/Wizard.test.js +141 -0
  263. package/wizard/types.d.ts +8 -4
  264. package/ThemeContext.d.ts +0 -15
  265. package/ThemeContext.js +0 -243
  266. package/V3Select/V3Select.js +0 -455
  267. package/V3Select/index.d.ts +0 -27
  268. package/V3Textarea/V3Textarea.js +0 -260
  269. package/V3Textarea/index.d.ts +0 -27
  270. package/card/ice-cream.jpg +0 -0
  271. package/common/RequiredComponent.js +0 -32
  272. package/date/Date.js +0 -373
  273. package/date/index.d.ts +0 -27
  274. package/input-text/Icons.js +0 -22
  275. package/input-text/InputText.js +0 -611
  276. package/input-text/index.d.ts +0 -36
  277. package/list/List.d.ts +0 -8
  278. package/list/List.js +0 -47
  279. package/list/List.stories.tsx +0 -95
  280. package/radio/Radio.d.ts +0 -4
  281. package/radio/Radio.js +0 -174
  282. package/radio/Radio.stories.tsx +0 -192
  283. package/radio/types.d.ts +0 -54
  284. package/row/Row.d.ts +0 -11
  285. package/row/Row.js +0 -127
  286. package/row/Row.stories.tsx +0 -239
  287. package/stack/Stack.d.ts +0 -10
  288. package/stack/Stack.js +0 -97
  289. package/stack/Stack.stories.tsx +0 -166
  290. package/text/Text.d.ts +0 -7
  291. package/text/Text.js +0 -30
  292. package/text/Text.stories.tsx +0 -19
  293. package/toggle/Toggle.js +0 -186
  294. package/toggle/index.d.ts +0 -21
  295. package/upload/Upload.js +0 -201
  296. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  297. package/upload/buttons-upload/Icons.js +0 -40
  298. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  299. package/upload/dragAndDropArea/Icons.js +0 -39
  300. package/upload/file-upload/FileToUpload.js +0 -115
  301. package/upload/file-upload/Icons.js +0 -66
  302. package/upload/files-upload/FilesToUpload.js +0 -109
  303. package/upload/index.d.ts +0 -15
  304. package/upload/transaction/Icons.js +0 -160
  305. package/upload/transaction/Transaction.js +0 -104
  306. package/upload/transactions/Transactions.js +0 -94
  307. /package/{radio → badge}/types.js +0 -0
@@ -11,27 +11,31 @@ exports["default"] = void 0;
11
11
 
12
12
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
13
 
14
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
15
+
14
16
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
15
17
 
16
18
  var _react = _interopRequireWildcard(require("react"));
17
19
 
18
- var _pickers = require("@material-ui/pickers");
20
+ var _dayjs = _interopRequireDefault(require("dayjs"));
19
21
 
20
- var _core = require("@material-ui/core");
22
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
21
23
 
22
- var _ClickAwayListener = _interopRequireDefault(require("@material-ui/core/ClickAwayListener"));
24
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
23
25
 
24
- var _Popover = _interopRequireDefault(require("@material-ui/core/Popover"));
26
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
25
27
 
26
- var _moment = _interopRequireDefault(require("moment"));
28
+ var _TextInput = _interopRequireDefault(require("../text-input/TextInput"));
27
29
 
28
- var _dateFns = _interopRequireDefault(require("@date-io/date-fns"));
30
+ var _DatePicker = _interopRequireDefault(require("./DatePicker"));
29
31
 
30
- var _styledComponents = _interopRequireWildcard(require("styled-components"));
32
+ var Popover = _interopRequireWildcard(require("@radix-ui/react-popover"));
31
33
 
32
- var _useTheme = _interopRequireDefault(require("../useTheme"));
34
+ var _customParseFormat = _interopRequireDefault(require("dayjs/plugin/customParseFormat"));
33
35
 
34
- var _TextInput = _interopRequireDefault(require("../text-input/TextInput"));
36
+ var _uuid = require("uuid");
37
+
38
+ var _Icons = require("./Icons");
35
39
 
36
40
  var _templateObject;
37
41
 
@@ -39,34 +43,61 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
39
43
 
40
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; }
41
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
+ _dayjs["default"].extend(_customParseFormat["default"]);
51
+
52
+ var getValueForPicker = function getValueForPicker(value, format) {
53
+ return (0, _dayjs["default"])(value, format.toUpperCase(), true);
54
+ };
55
+
56
+ var getDate = function getDate(value, format, lastValidYear, setLastValidYear) {
57
+ if ((value || value === "") && format.toUpperCase().includes("YYYY")) return getValueForPicker(value, format);else {
58
+ var newDate = getValueForPicker(value, format);
59
+
60
+ if (!lastValidYear) {
61
+ if (+newDate.format("YY") < 68) {
62
+ setLastValidYear(2000 + +newDate.format("YY"));
63
+ newDate = newDate.set("year", 2000 + +newDate.format("YY"));
64
+ } else {
65
+ setLastValidYear(1900 + +newDate.format("YY"));
66
+ newDate = newDate.set("year", 1900 + +newDate.format("YY"));
67
+ }
68
+ } else {
69
+ newDate = newDate.set("year", (lastValidYear <= 1999 ? 1900 : 2000) + +newDate.format("YY"));
70
+ }
71
+
72
+ return newDate;
73
+ }
74
+ };
75
+
42
76
  var DxcDateInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
77
+ var _ref2;
78
+
43
79
  var label = _ref.label,
44
- _ref$name = _ref.name,
45
- name = _ref$name === void 0 ? "" : _ref$name,
80
+ name = _ref.name,
81
+ _ref$defaultValue = _ref.defaultValue,
82
+ defaultValue = _ref$defaultValue === void 0 ? "" : _ref$defaultValue,
46
83
  value = _ref.value,
47
84
  _ref$format = _ref.format,
48
85
  format = _ref$format === void 0 ? "dd-MM-yyyy" : _ref$format,
49
86
  helperText = _ref.helperText,
50
87
  _ref$placeholder = _ref.placeholder,
51
88
  placeholder = _ref$placeholder === void 0 ? false : _ref$placeholder,
52
- _ref$clearable = _ref.clearable,
53
- clearable = _ref$clearable === void 0 ? false : _ref$clearable,
54
- _ref$disabled = _ref.disabled,
55
- disabled = _ref$disabled === void 0 ? false : _ref$disabled,
56
- _ref$optional = _ref.optional,
57
- optional = _ref$optional === void 0 ? false : _ref$optional,
89
+ clearable = _ref.clearable,
90
+ disabled = _ref.disabled,
91
+ optional = _ref.optional,
58
92
  onChange = _ref.onChange,
59
93
  onBlur = _ref.onBlur,
60
94
  error = _ref.error,
61
- _ref$autocomplete = _ref.autocomplete,
62
- autocomplete = _ref$autocomplete === void 0 ? "off" : _ref$autocomplete,
95
+ autocomplete = _ref.autocomplete,
63
96
  margin = _ref.margin,
64
- _ref$size = _ref.size,
65
- size = _ref$size === void 0 ? "medium" : _ref$size,
66
- _ref$tabIndex = _ref.tabIndex,
67
- tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
97
+ size = _ref.size,
98
+ tabIndex = _ref.tabIndex;
68
99
 
69
- var _useState = (0, _react.useState)(""),
100
+ var _useState = (0, _react.useState)(defaultValue),
70
101
  _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
71
102
  innerValue = _useState2[0],
72
103
  setInnerValue = _useState2[1];
@@ -76,238 +107,138 @@ var DxcDateInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref
76
107
  isOpen = _useState4[0],
77
108
  setIsOpen = _useState4[1];
78
109
 
79
- var _useState5 = (0, _react.useState)(null),
80
- _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
81
- anchorEl = _useState6[0],
82
- setAnchorEl = _useState6[1];
110
+ var _useState5 = (0, _react.useState)("date-picker-".concat((0, _uuid.v4)())),
111
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 1),
112
+ calendarId = _useState6[0];
113
+
114
+ var _useState7 = (0, _react.useState)(getValueForPicker((_ref2 = value !== null && value !== void 0 ? value : defaultValue) !== null && _ref2 !== void 0 ? _ref2 : "", format)),
115
+ _useState8 = (0, _slicedToArray2["default"])(_useState7, 2),
116
+ dayjsDate = _useState8[0],
117
+ setDayjsDate = _useState8[1];
118
+
119
+ var _useState9 = (0, _react.useState)(innerValue || value ? !format.toUpperCase().includes("YYYY") && +getValueForPicker(value !== null && value !== void 0 ? value : innerValue, format).format("YY") < 68 ? 2000 : 1900 : undefined),
120
+ _useState10 = (0, _slicedToArray2["default"])(_useState9, 2),
121
+ lastValidYear = _useState10[0],
122
+ setLastValidYear = _useState10[1];
83
123
 
84
124
  var colorsTheme = (0, _useTheme["default"])();
85
- var refDate = ref || (0, _react.useRef)(null);
86
-
87
- var handleCalendarOnKeyDown = function handleCalendarOnKeyDown(event) {
88
- switch (event.keyCode) {
89
- case 27:
90
- // Esc
91
- event.preventDefault();
92
- setIsOpen(false);
93
- break;
125
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
126
+ var dateRef = (0, _react.useRef)(null);
127
+ (0, _react.useEffect)(function () {
128
+ if (value || value === "") setDayjsDate(getDate(value, format, lastValidYear, setLastValidYear));
129
+ }, [value, format, lastValidYear]);
130
+ (0, _react.useLayoutEffect)(function () {
131
+ if (!disabled) {
132
+ var actionButtonRef = dateRef === null || dateRef === void 0 ? void 0 : dateRef.current.querySelector("[title='Open calendar']");
133
+ actionButtonRef === null || actionButtonRef === void 0 ? void 0 : actionButtonRef.setAttribute("aria-haspopup", true);
134
+ actionButtonRef === null || actionButtonRef === void 0 ? void 0 : actionButtonRef.setAttribute("role", "combobox");
135
+ actionButtonRef === null || actionButtonRef === void 0 ? void 0 : actionButtonRef.setAttribute("aria-expanded", isOpen);
136
+ actionButtonRef === null || actionButtonRef === void 0 ? void 0 : actionButtonRef.setAttribute("aria-controls", calendarId);
137
+ actionButtonRef === null || actionButtonRef === void 0 ? void 0 : actionButtonRef.setAttribute("aria-describedby", calendarId);
94
138
  }
95
- };
139
+ }, [isOpen, disabled, calendarId]);
96
140
 
97
141
  var handleCalendarOnClick = function handleCalendarOnClick(newDate) {
98
- var newValue = (0, _moment["default"])(newDate).format(format.toUpperCase());
99
- value !== null && value !== void 0 ? value : setInnerValue(newValue);
100
- onChange === null || onChange === void 0 ? void 0 : onChange({
142
+ var newValue = newDate.format(format.toUpperCase());
143
+
144
+ if (!value) {
145
+ setDayjsDate(newDate);
146
+ setInnerValue(newValue);
147
+ }
148
+
149
+ setLastValidYear(newDate.get("year"));
150
+ newDate !== null && newDate !== void 0 && newDate.set("day", newDate.get("date")).toJSON() ? onChange === null || onChange === void 0 ? void 0 : onChange({
101
151
  value: newValue,
102
- error: null,
103
- date: newDate !== null && newDate !== void 0 && newDate.toJSON() ? newDate : null
152
+ date: newDate.toDate()
153
+ }) : onChange === null || onChange === void 0 ? void 0 : onChange({
154
+ value: newValue
104
155
  });
105
156
  };
106
157
 
107
- var handleIOnChange = function handleIOnChange(_ref2) {
108
- var newValue = _ref2.value,
109
- inputError = _ref2.error;
158
+ var handleIOnChange = function handleIOnChange(_ref3) {
159
+ var newValue = _ref3.value,
160
+ inputError = _ref3.error;
110
161
  value !== null && value !== void 0 ? value : setInnerValue(newValue);
111
- var momentDate = (0, _moment["default"])(newValue, format.toUpperCase(), true);
112
- var invalidDateMessage = newValue !== "" && !momentDate.isValid() ? "Invalid date." : null;
113
- onChange === null || onChange === void 0 ? void 0 : onChange({
162
+ var newDate = getDate(newValue, format, lastValidYear, setLastValidYear);
163
+ var invalidDateMessage = newValue !== "" && !newDate.isValid() && translatedLabels.dateInput.invalidDateErrorMessage;
164
+ var callbackParams = inputError || invalidDateMessage ? {
114
165
  value: newValue,
115
- error: inputError || invalidDateMessage,
116
- date: momentDate.isValid() ? momentDate.toDate() : null
117
- });
166
+ error: inputError || invalidDateMessage
167
+ } : {
168
+ value: newValue
169
+ };
170
+
171
+ if (newDate.isValid()) {
172
+ setDayjsDate(newDate);
173
+ onChange === null || onChange === void 0 ? void 0 : onChange(_objectSpread(_objectSpread({}, callbackParams), {}, {
174
+ date: newDate.toDate()
175
+ }));
176
+ } else {
177
+ onChange === null || onChange === void 0 ? void 0 : onChange(callbackParams);
178
+ setLastValidYear(function (validYear) {
179
+ var _dayjsDate$get;
180
+
181
+ return (_dayjsDate$get = dayjsDate === null || dayjsDate === void 0 ? void 0 : dayjsDate.get("year")) !== null && _dayjsDate$get !== void 0 ? _dayjsDate$get : validYear;
182
+ });
183
+ setDayjsDate(null);
184
+ }
118
185
  };
119
186
 
120
- var handleIOnBlur = function handleIOnBlur(_ref3) {
121
- var value = _ref3.value,
122
- inputError = _ref3.error;
123
- var momentDate = (0, _moment["default"])(value, format.toUpperCase(), true);
124
- var invalidDateMessage = value !== "" && !momentDate.isValid() ? "Invalid date." : null;
125
- onBlur === null || onBlur === void 0 ? void 0 : onBlur({
187
+ var handleIOnBlur = function handleIOnBlur(_ref4) {
188
+ var value = _ref4.value,
189
+ inputError = _ref4.error;
190
+ var date = getDate(value, format, lastValidYear, setLastValidYear);
191
+ var invalidDateMessage = value !== "" && !date.isValid() && translatedLabels.dateInput.invalidDateErrorMessage;
192
+ var callbackParams = inputError || invalidDateMessage ? {
126
193
  value: value,
127
- error: inputError || invalidDateMessage,
128
- date: momentDate.isValid() ? momentDate.toDate() : null
129
- });
130
- };
131
-
132
- var getValueForPicker = function getValueForPicker() {
133
- return (0, _moment["default"])(value !== null && value !== void 0 ? value : innerValue, format.toUpperCase(), true).format();
194
+ error: inputError || invalidDateMessage
195
+ } : {
196
+ value: value
197
+ };
198
+ date.isValid() ? onBlur === null || onBlur === void 0 ? void 0 : onBlur(_objectSpread(_objectSpread({}, callbackParams), {}, {
199
+ date: date.toDate()
200
+ })) : onBlur === null || onBlur === void 0 ? void 0 : onBlur(callbackParams);
134
201
  };
135
202
 
136
203
  var openCalendar = function openCalendar() {
137
- var dateBtn = refDate.current.getElementsByTagName("button")[0];
138
204
  setIsOpen(!isOpen);
139
- setAnchorEl(dateBtn);
140
205
  };
141
206
 
142
207
  var closeCalendar = function closeCalendar() {
143
208
  setIsOpen(false);
144
209
  };
145
210
 
146
- var calendarAction = {
147
- onClick: openCalendar,
148
- icon: /*#__PURE__*/_react["default"].createElement("svg", {
149
- xmlns: "http://www.w3.org/2000/svg",
150
- height: "24",
151
- viewBox: "0 0 24 24",
152
- width: "24",
153
- fill: "currentColor"
154
- }, /*#__PURE__*/_react["default"].createElement("path", {
155
- d: "M0 0h24v24H0z",
156
- fill: "none"
157
- }), /*#__PURE__*/_react["default"].createElement("path", {
158
- 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"
159
- }))
211
+ var handleDatePickerEscKeydown = function handleDatePickerEscKeydown(event) {
212
+ event.preventDefault();
213
+ closeCalendar();
214
+ dateRef === null || dateRef === void 0 ? void 0 : dateRef.current.getElementsByTagName("input")[0].focus();
160
215
  };
161
- var dateTheme = (0, _core.createMuiTheme)({
162
- overrides: {
163
- MuiTypography: {
164
- root: {
165
- fontFamily: "".concat(colorsTheme.dateInput.pickerFontFamily, " !important")
166
- }
167
- },
168
- MuiPickersYearSelection: {
169
- container: {
170
- color: colorsTheme.dateInput.pickerYearFontColor,
171
- "&::-webkit-scrollbar": {
172
- width: "3px"
173
- },
174
- "&::-webkit-scrollbar-track": {
175
- backgroundColor: "#D9D9D9",
176
- borderRadius: "3px"
177
- },
178
- "&::-webkit-scrollbar-thumb": {
179
- backgroundColor: "#666666",
180
- borderRadius: "3px"
181
- }
182
- }
183
- },
184
- MuiPickersToolbar: {
185
- toolbar: {
186
- backgroundColor: colorsTheme.dateInput.pickerBackgroundColor,
187
- color: colorsTheme.dateInput.pickerDayFontColor
188
- }
189
- },
190
- MuiIconButton: {
191
- root: {
192
- height: "36px",
193
- width: "36px",
194
- padding: "0px"
195
- }
196
- },
197
- MuiTouchRipple: {
198
- child: {
199
- opacity: "0"
200
- }
201
- },
202
- MuiButtonBase: {
203
- root: {
204
- "&:focus": {
205
- outline: colorsTheme.dateInput.pickerFocusColor + " solid 2px"
206
- }
207
- }
208
- },
209
- MuiPickersBasePicker: {
210
- pickerView: {
211
- minWidth: "unset",
212
- maxWidth: "unset",
213
- minHeight: "unset",
214
- padding: "0px 10px",
215
- height: colorsTheme.dateInput.pickerHeight,
216
- width: colorsTheme.dateInput.pickerWidth,
217
- backgroundColor: colorsTheme.dateInput.pickerBackgroundColor,
218
- fontFamily: colorsTheme.dateInput.pickerFontFamily
219
- }
220
- },
221
- MuiPickersToolbarText: {
222
- toolbarTxt: {
223
- color: colorsTheme.dateInput.pickerActualDateFontColor,
224
- fontFamily: colorsTheme.dateInput.pickerFontFamily,
225
- fontSize: "2rem"
226
- },
227
- toolbarBtnSelected: {
228
- color: colorsTheme.dateInput.pickerActualDateFontColor
229
- }
230
- },
231
- MuiPickersCalendarHeader: {
232
- transitionContainer: {
233
- color: colorsTheme.dateInput.pickerMonthFontColor
234
- },
235
- dayLabel: {
236
- color: colorsTheme.dateInput.pickerWeekFontColor,
237
- fontFamily: colorsTheme.dateInput.pickerFontFamily
238
- },
239
- switchHeader: {
240
- backgroundColor: "#ffffff",
241
- color: colorsTheme.dateInput.pickerDayFontColor
242
- },
243
- iconButton: {
244
- backgroundColor: colorsTheme.dateInput.pickerMonthArrowsBackgroundColor,
245
- "&:hover": {
246
- backgroundColor: colorsTheme.dateInput.pickerMonthArrowsBackgroundColor
247
- }
248
- }
249
- },
250
- MuiPickersCalendar: {
251
- week: {
252
- marginBottom: "2px"
253
- }
254
- },
255
- MuiPickersDay: {
256
- current: {
257
- color: colorsTheme.dateInput.pickerDayFontColor
258
- },
259
- day: {
260
- fontFamily: colorsTheme.dateInput.pickerFontFamily,
261
- color: colorsTheme.dateInput.pickerDayFontColor,
262
- "&:hover": {
263
- backgroundColor: colorsTheme.dateInput.pickerHoverDateBackgroundColor,
264
- color: colorsTheme.dateInput.pickerHoverDateFontColor
265
- }
266
- },
267
- daySelected: {
268
- backgroundColor: colorsTheme.dateInput.pickerSelectedDateBackgroundColor,
269
- color: colorsTheme.dateInput.pickerSelectedDateColor,
270
- "&:hover": {
271
- backgroundColor: colorsTheme.dateInput.pickerSelectedDateBackgroundColor,
272
- color: colorsTheme.dateInput.pickerSelectedDateColor,
273
- opacity: "1"
274
- }
275
- }
276
- },
277
- MuiPickersYear: {
278
- yearSelected: {
279
- color: colorsTheme.dateInput.pickerSelectedDateColor,
280
- backgroundColor: colorsTheme.dateInput.pickerSelectedDateBackgroundColor,
281
- margin: "0px 100px",
282
- borderRadius: "20px"
283
- },
284
- root: {
285
- "&:focus": {
286
- color: colorsTheme.dateInput.pickerHoverDateFontColor,
287
- backgroundColor: colorsTheme.dateInput.pickerHoverDateBackgroundColor
288
- }
289
- }
290
- },
291
- MuiPickersModal: {
292
- dialogAction: {
293
- color: "pink"
294
- }
295
- }
296
- }
297
- });
216
+
217
+ var handleDatePickerOnBlur = function handleDatePickerOnBlur(event) {
218
+ if (!(event !== null && event !== void 0 && event.currentTarget.contains(event.relatedTarget))) closeCalendar();
219
+ };
220
+
298
221
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
299
222
  theme: colorsTheme
300
- }, /*#__PURE__*/_react["default"].createElement(_core.MuiThemeProvider, {
301
- theme: dateTheme
302
- }, /*#__PURE__*/_react["default"].createElement(_pickers.MuiPickersUtilsProvider, {
303
- utils: _dateFns["default"]
304
- }, /*#__PURE__*/_react["default"].createElement(StyledDPicker, null, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
223
+ }, /*#__PURE__*/_react["default"].createElement("div", {
224
+ ref: ref
225
+ }, /*#__PURE__*/_react["default"].createElement(Popover.Root, {
226
+ open: isOpen
227
+ }, /*#__PURE__*/_react["default"].createElement(Popover.Trigger, {
228
+ asChild: true,
229
+ "aria-controls": undefined
230
+ }, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
305
231
  label: label,
306
232
  name: name,
233
+ defaultValue: defaultValue,
307
234
  value: value !== null && value !== void 0 ? value : innerValue,
308
235
  helperText: helperText,
309
236
  placeholder: placeholder ? format.toUpperCase() : null,
310
- action: calendarAction,
237
+ action: {
238
+ onClick: openCalendar,
239
+ icon: _Icons.calendarIcon,
240
+ title: "Open calendar"
241
+ },
311
242
  clearable: clearable,
312
243
  disabled: disabled,
313
244
  optional: optional,
@@ -318,41 +249,21 @@ var DxcDateInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref
318
249
  margin: margin,
319
250
  size: size,
320
251
  tabIndex: tabIndex,
321
- ref: refDate
322
- }), /*#__PURE__*/_react["default"].createElement(_Popover["default"], {
323
- onKeyDown: handleCalendarOnKeyDown,
324
- open: isOpen,
325
- anchorEl: anchorEl,
326
- anchorOrigin: {
327
- vertical: "bottom",
328
- horizontal: "left"
329
- },
330
- transformOrigin: {
331
- vertical: "top",
332
- horizontal: "center"
333
- },
334
- PaperProps: {
335
- style: {
336
- marginTop: "10px"
337
- }
338
- }
339
- }, /*#__PURE__*/_react["default"].createElement(_ClickAwayListener["default"], {
340
- onClickAway: closeCalendar
341
- }, /*#__PURE__*/_react["default"].createElement(_core.Paper, {
342
- role: "dialog",
343
- "aria-modal": "true"
344
- }, /*#__PURE__*/_react["default"].createElement(_pickers.DatePicker, {
345
- variant: "static",
346
- value: getValueForPicker(),
347
- onChange: function onChange(date) {
348
- return handleCalendarOnClick(date);
349
- },
350
- format: format,
351
- disabled: disabled
352
- }))))))));
252
+ ref: dateRef
253
+ })), /*#__PURE__*/_react["default"].createElement(StyledContent, {
254
+ sideOffset: error ? -18 : 2,
255
+ align: "end",
256
+ "aria-modal": true,
257
+ onBlur: handleDatePickerOnBlur,
258
+ onEscapeKeyDown: handleDatePickerEscKeydown,
259
+ avoidCollisions: false
260
+ }, /*#__PURE__*/_react["default"].createElement(_DatePicker["default"], {
261
+ id: calendarId,
262
+ onDateSelect: handleCalendarOnClick,
263
+ date: dayjsDate
264
+ })))));
353
265
  });
354
266
 
355
- var StyledDPicker = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])([""])));
356
-
267
+ var StyledContent = (0, _styledComponents["default"])(Popover.Content)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n &:focus-visible {\n outline: none;\n }\n"])));
357
268
  var _default = DxcDateInput;
358
269
  exports["default"] = _default;