@dxc-technology/halstack-react 0.0.0-8d998c7 → 0.0.0-8ded8ca

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 (382) hide show
  1. package/BackgroundColorContext.d.ts +1 -0
  2. package/BackgroundColorContext.js +6 -26
  3. package/HalstackContext.d.ts +1235 -0
  4. package/HalstackContext.js +310 -0
  5. package/README.md +47 -0
  6. package/accordion/Accordion.d.ts +1 -1
  7. package/accordion/Accordion.js +118 -194
  8. package/accordion/Accordion.stories.tsx +283 -0
  9. package/accordion/Accordion.test.js +56 -0
  10. package/accordion/types.d.ts +12 -23
  11. package/accordion-group/AccordionGroup.d.ts +5 -4
  12. package/accordion-group/AccordionGroup.js +39 -108
  13. package/accordion-group/AccordionGroup.stories.tsx +252 -0
  14. package/accordion-group/AccordionGroup.test.js +98 -0
  15. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  16. package/accordion-group/AccordionGroupAccordion.js +31 -0
  17. package/accordion-group/types.d.ts +18 -23
  18. package/action-icon/ActionIcon.d.ts +4 -0
  19. package/action-icon/ActionIcon.js +43 -0
  20. package/action-icon/types.d.ts +26 -0
  21. package/alert/Alert.js +24 -60
  22. package/alert/Alert.stories.tsx +198 -0
  23. package/alert/Alert.test.js +75 -0
  24. package/alert/types.d.ts +6 -6
  25. package/badge/Badge.d.ts +4 -0
  26. package/badge/Badge.js +9 -20
  27. package/badge/types.d.ts +5 -0
  28. package/badge/types.js +5 -0
  29. package/bleed/Bleed.d.ts +3 -0
  30. package/bleed/Bleed.js +43 -0
  31. package/bleed/Bleed.stories.tsx +342 -0
  32. package/bleed/types.d.ts +37 -0
  33. package/bleed/types.js +5 -0
  34. package/box/Box.d.ts +4 -0
  35. package/box/Box.js +32 -109
  36. package/box/{Box.stories.jsx → Box.stories.tsx} +38 -51
  37. package/box/Box.test.js +13 -0
  38. package/box/types.d.ts +32 -0
  39. package/box/types.js +5 -0
  40. package/bulleted-list/BulletedList.d.ts +7 -0
  41. package/bulleted-list/BulletedList.js +89 -0
  42. package/bulleted-list/BulletedList.stories.tsx +115 -0
  43. package/bulleted-list/types.d.ts +38 -0
  44. package/bulleted-list/types.js +5 -0
  45. package/button/Button.d.ts +1 -1
  46. package/button/Button.js +65 -127
  47. package/button/Button.stories.tsx +329 -278
  48. package/button/Button.test.js +36 -0
  49. package/button/types.d.ts +18 -18
  50. package/card/Card.d.ts +1 -1
  51. package/card/Card.js +59 -104
  52. package/card/Card.stories.tsx +171 -0
  53. package/card/Card.test.js +39 -0
  54. package/card/types.d.ts +8 -15
  55. package/checkbox/Checkbox.d.ts +2 -2
  56. package/checkbox/Checkbox.js +145 -183
  57. package/checkbox/Checkbox.stories.tsx +222 -0
  58. package/checkbox/Checkbox.test.js +199 -0
  59. package/checkbox/types.d.ts +20 -8
  60. package/chip/Chip.d.ts +4 -0
  61. package/chip/Chip.js +48 -148
  62. package/chip/Chip.stories.tsx +214 -0
  63. package/chip/Chip.test.js +41 -0
  64. package/chip/types.d.ts +45 -0
  65. package/chip/types.js +5 -0
  66. package/common/OpenSans.css +68 -80
  67. package/common/coreTokens.d.ts +237 -0
  68. package/common/coreTokens.js +184 -0
  69. package/common/utils.d.ts +1 -0
  70. package/common/utils.js +6 -12
  71. package/common/variables.d.ts +1381 -0
  72. package/common/variables.js +1006 -1322
  73. package/container/Container.d.ts +4 -0
  74. package/container/Container.js +194 -0
  75. package/container/Container.stories.tsx +214 -0
  76. package/container/types.d.ts +74 -0
  77. package/container/types.js +5 -0
  78. package/date-input/Calendar.d.ts +4 -0
  79. package/date-input/Calendar.js +214 -0
  80. package/date-input/DateInput.js +175 -313
  81. package/date-input/DateInput.stories.tsx +285 -0
  82. package/date-input/DateInput.test.js +808 -0
  83. package/date-input/DatePicker.d.ts +4 -0
  84. package/date-input/DatePicker.js +115 -0
  85. package/date-input/Icons.d.ts +6 -0
  86. package/date-input/Icons.js +58 -0
  87. package/date-input/YearPicker.d.ts +4 -0
  88. package/date-input/YearPicker.js +100 -0
  89. package/date-input/types.d.ts +86 -22
  90. package/dialog/Dialog.d.ts +4 -0
  91. package/dialog/Dialog.js +69 -149
  92. package/dialog/Dialog.stories.tsx +365 -0
  93. package/dialog/Dialog.test.js +307 -0
  94. package/dialog/types.d.ts +36 -0
  95. package/dialog/types.js +5 -0
  96. package/dropdown/Dropdown.d.ts +1 -1
  97. package/dropdown/Dropdown.js +245 -328
  98. package/dropdown/Dropdown.stories.tsx +438 -0
  99. package/dropdown/Dropdown.test.js +599 -0
  100. package/dropdown/DropdownMenu.d.ts +4 -0
  101. package/dropdown/DropdownMenu.js +63 -0
  102. package/dropdown/DropdownMenuItem.d.ts +4 -0
  103. package/dropdown/DropdownMenuItem.js +67 -0
  104. package/dropdown/types.d.ts +37 -28
  105. package/file-input/FileInput.d.ts +4 -0
  106. package/file-input/FileInput.js +274 -327
  107. package/file-input/FileInput.stories.tsx +618 -0
  108. package/file-input/FileInput.test.js +459 -0
  109. package/file-input/FileItem.d.ts +4 -0
  110. package/file-input/FileItem.js +54 -112
  111. package/file-input/types.d.ts +129 -0
  112. package/file-input/types.js +5 -0
  113. package/flex/Flex.d.ts +4 -0
  114. package/flex/Flex.js +57 -0
  115. package/flex/Flex.stories.tsx +112 -0
  116. package/flex/types.d.ts +97 -0
  117. package/flex/types.js +5 -0
  118. package/footer/Footer.d.ts +1 -1
  119. package/footer/Footer.js +73 -201
  120. package/footer/Footer.stories.tsx +171 -0
  121. package/footer/Footer.test.js +85 -0
  122. package/footer/Icons.d.ts +3 -0
  123. package/footer/Icons.js +67 -8
  124. package/footer/types.d.ts +41 -38
  125. package/grid/Grid.d.ts +7 -0
  126. package/grid/Grid.js +76 -0
  127. package/grid/Grid.stories.tsx +219 -0
  128. package/grid/types.d.ts +115 -0
  129. package/grid/types.js +5 -0
  130. package/header/Header.d.ts +8 -0
  131. package/header/Header.js +115 -221
  132. package/header/Header.stories.tsx +251 -0
  133. package/header/Header.test.js +66 -0
  134. package/header/Icons.d.ts +2 -0
  135. package/header/Icons.js +5 -35
  136. package/header/types.d.ts +33 -0
  137. package/header/types.js +5 -0
  138. package/heading/Heading.d.ts +4 -0
  139. package/heading/Heading.js +16 -55
  140. package/heading/Heading.stories.tsx +54 -0
  141. package/heading/Heading.test.js +169 -0
  142. package/heading/types.d.ts +33 -0
  143. package/heading/types.js +5 -0
  144. package/image/Image.d.ts +4 -0
  145. package/image/Image.js +70 -0
  146. package/image/Image.stories.tsx +127 -0
  147. package/image/types.d.ts +72 -0
  148. package/image/types.js +5 -0
  149. package/inset/Inset.d.ts +3 -0
  150. package/inset/Inset.js +43 -0
  151. package/inset/Inset.stories.tsx +230 -0
  152. package/inset/types.d.ts +37 -0
  153. package/inset/types.js +5 -0
  154. package/layout/ApplicationLayout.d.ts +20 -0
  155. package/layout/ApplicationLayout.js +83 -184
  156. package/layout/ApplicationLayout.stories.tsx +162 -0
  157. package/layout/Icons.d.ts +8 -0
  158. package/layout/Icons.js +51 -48
  159. package/layout/SidenavContext.d.ts +5 -0
  160. package/layout/SidenavContext.js +13 -0
  161. package/layout/types.d.ts +41 -0
  162. package/layout/types.js +5 -0
  163. package/link/Link.d.ts +4 -0
  164. package/link/Link.js +65 -133
  165. package/link/Link.stories.tsx +253 -0
  166. package/link/Link.test.js +63 -0
  167. package/link/types.d.ts +54 -0
  168. package/link/types.js +5 -0
  169. package/main.d.ts +16 -13
  170. package/main.js +77 -97
  171. package/nav-tabs/NavTabs.d.ts +8 -0
  172. package/nav-tabs/NavTabs.js +93 -0
  173. package/nav-tabs/NavTabs.stories.tsx +274 -0
  174. package/nav-tabs/NavTabs.test.js +75 -0
  175. package/nav-tabs/Tab.d.ts +4 -0
  176. package/nav-tabs/Tab.js +117 -0
  177. package/nav-tabs/types.d.ts +52 -0
  178. package/nav-tabs/types.js +5 -0
  179. package/number-input/NumberInput.d.ts +11 -0
  180. package/number-input/NumberInput.js +28 -89
  181. package/number-input/NumberInput.stories.tsx +131 -0
  182. package/number-input/NumberInput.test.js +830 -0
  183. package/number-input/types.d.ts +130 -0
  184. package/number-input/types.js +5 -0
  185. package/package.json +46 -45
  186. package/paginator/Icons.d.ts +5 -0
  187. package/paginator/Icons.js +21 -47
  188. package/paginator/Paginator.js +35 -98
  189. package/paginator/Paginator.stories.tsx +87 -0
  190. package/paginator/Paginator.test.js +335 -0
  191. package/paginator/types.d.ts +3 -3
  192. package/paragraph/Paragraph.d.ts +5 -0
  193. package/paragraph/Paragraph.js +22 -0
  194. package/paragraph/Paragraph.stories.tsx +27 -0
  195. package/password-input/Icons.d.ts +6 -0
  196. package/password-input/Icons.js +35 -0
  197. package/password-input/PasswordInput.d.ts +4 -0
  198. package/password-input/PasswordInput.js +60 -162
  199. package/password-input/{PasswordInput.stories.jsx → PasswordInput.stories.tsx} +3 -35
  200. package/password-input/PasswordInput.test.js +198 -0
  201. package/password-input/types.d.ts +111 -0
  202. package/password-input/types.js +5 -0
  203. package/progress-bar/ProgressBar.js +67 -93
  204. package/progress-bar/ProgressBar.stories.tsx +93 -0
  205. package/progress-bar/ProgressBar.test.js +93 -0
  206. package/progress-bar/types.d.ts +3 -3
  207. package/quick-nav/QuickNav.d.ts +4 -0
  208. package/quick-nav/QuickNav.js +94 -0
  209. package/quick-nav/QuickNav.stories.tsx +356 -0
  210. package/quick-nav/types.d.ts +21 -0
  211. package/quick-nav/types.js +5 -0
  212. package/radio-group/Radio.d.ts +4 -0
  213. package/radio-group/Radio.js +124 -0
  214. package/radio-group/RadioGroup.d.ts +4 -0
  215. package/radio-group/RadioGroup.js +235 -0
  216. package/radio-group/RadioGroup.stories.tsx +214 -0
  217. package/radio-group/RadioGroup.test.js +756 -0
  218. package/radio-group/types.d.ts +114 -0
  219. package/radio-group/types.js +5 -0
  220. package/resultset-table/Icons.d.ts +7 -0
  221. package/resultset-table/Icons.js +47 -0
  222. package/resultset-table/ResultsetTable.d.ts +4 -0
  223. package/resultset-table/ResultsetTable.js +159 -0
  224. package/resultset-table/ResultsetTable.stories.tsx +300 -0
  225. package/resultset-table/ResultsetTable.test.js +305 -0
  226. package/resultset-table/types.d.ts +67 -0
  227. package/resultset-table/types.js +5 -0
  228. package/select/Icons.d.ts +10 -0
  229. package/select/Icons.js +89 -0
  230. package/select/Listbox.d.ts +4 -0
  231. package/select/Listbox.js +143 -0
  232. package/select/Option.d.ts +4 -0
  233. package/select/Option.js +87 -0
  234. package/select/Select.d.ts +4 -0
  235. package/select/Select.js +240 -515
  236. package/select/Select.stories.tsx +971 -0
  237. package/select/Select.test.js +2370 -0
  238. package/select/types.d.ts +209 -0
  239. package/select/types.js +5 -0
  240. package/sidenav/Icons.d.ts +7 -0
  241. package/sidenav/Icons.js +47 -0
  242. package/sidenav/Sidenav.d.ts +10 -0
  243. package/sidenav/Sidenav.js +132 -81
  244. package/sidenav/Sidenav.stories.tsx +282 -0
  245. package/sidenav/Sidenav.test.js +37 -0
  246. package/sidenav/types.d.ts +76 -0
  247. package/sidenav/types.js +5 -0
  248. package/slider/Slider.d.ts +2 -2
  249. package/slider/Slider.js +162 -183
  250. package/slider/Slider.test.js +254 -0
  251. package/slider/types.d.ts +13 -10
  252. package/spinner/Spinner.d.ts +4 -0
  253. package/spinner/Spinner.js +38 -99
  254. package/spinner/Spinner.stories.tsx +129 -0
  255. package/spinner/Spinner.test.js +55 -0
  256. package/spinner/types.d.ts +32 -0
  257. package/spinner/types.js +5 -0
  258. package/status-light/StatusLight.d.ts +4 -0
  259. package/status-light/StatusLight.js +51 -0
  260. package/status-light/StatusLight.stories.tsx +74 -0
  261. package/status-light/StatusLight.test.js +25 -0
  262. package/status-light/types.d.ts +17 -0
  263. package/status-light/types.js +5 -0
  264. package/switch/Switch.d.ts +2 -2
  265. package/switch/Switch.js +150 -115
  266. package/switch/Switch.stories.tsx +137 -0
  267. package/switch/Switch.test.js +180 -0
  268. package/switch/types.d.ts +13 -5
  269. package/table/Table.d.ts +4 -0
  270. package/table/Table.js +10 -32
  271. package/table/Table.stories.tsx +356 -0
  272. package/table/Table.test.js +21 -0
  273. package/table/types.d.ts +21 -0
  274. package/table/types.js +5 -0
  275. package/tabs/Tab.d.ts +4 -0
  276. package/tabs/Tab.js +113 -0
  277. package/tabs/Tabs.d.ts +1 -1
  278. package/tabs/Tabs.js +318 -145
  279. package/tabs/Tabs.stories.tsx +226 -0
  280. package/tabs/Tabs.test.js +294 -0
  281. package/tabs/types.d.ts +48 -27
  282. package/tag/Tag.d.ts +4 -0
  283. package/tag/Tag.js +55 -112
  284. package/tag/Tag.stories.tsx +155 -0
  285. package/tag/Tag.test.js +49 -0
  286. package/tag/types.d.ts +69 -0
  287. package/tag/types.js +5 -0
  288. package/text-input/Icons.d.ts +8 -0
  289. package/text-input/Icons.js +56 -0
  290. package/text-input/Suggestion.d.ts +4 -0
  291. package/text-input/Suggestion.js +67 -0
  292. package/text-input/Suggestions.d.ts +4 -0
  293. package/text-input/Suggestions.js +84 -0
  294. package/text-input/TextInput.d.ts +4 -0
  295. package/text-input/TextInput.js +332 -585
  296. package/text-input/TextInput.stories.tsx +465 -0
  297. package/text-input/TextInput.test.js +1739 -0
  298. package/text-input/types.d.ts +205 -0
  299. package/text-input/types.js +5 -0
  300. package/textarea/Textarea.d.ts +4 -0
  301. package/textarea/Textarea.js +98 -181
  302. package/textarea/Textarea.stories.tsx +174 -0
  303. package/textarea/Textarea.test.js +406 -0
  304. package/textarea/types.d.ts +141 -0
  305. package/textarea/types.js +5 -0
  306. package/toggle-group/ToggleGroup.d.ts +4 -0
  307. package/toggle-group/ToggleGroup.js +100 -142
  308. package/toggle-group/ToggleGroup.stories.tsx +218 -0
  309. package/toggle-group/ToggleGroup.test.js +137 -0
  310. package/toggle-group/types.d.ts +114 -0
  311. package/toggle-group/types.js +5 -0
  312. package/typography/Typography.d.ts +4 -0
  313. package/typography/Typography.js +23 -0
  314. package/typography/Typography.stories.tsx +198 -0
  315. package/typography/types.d.ts +18 -0
  316. package/typography/types.js +5 -0
  317. package/useTheme.d.ts +1134 -0
  318. package/useTheme.js +4 -11
  319. package/useTranslatedLabels.d.ts +85 -0
  320. package/useTranslatedLabels.js +14 -0
  321. package/utils/BaseTypography.d.ts +21 -0
  322. package/utils/BaseTypography.js +94 -0
  323. package/utils/FocusLock.d.ts +13 -0
  324. package/utils/FocusLock.js +121 -0
  325. package/wizard/Wizard.d.ts +4 -0
  326. package/wizard/Wizard.js +130 -151
  327. package/wizard/Wizard.stories.tsx +253 -0
  328. package/wizard/Wizard.test.js +114 -0
  329. package/wizard/types.d.ts +64 -0
  330. package/wizard/types.js +5 -0
  331. package/ThemeContext.js +0 -246
  332. package/V3Select/V3Select.js +0 -455
  333. package/V3Select/index.d.ts +0 -27
  334. package/V3Textarea/V3Textarea.js +0 -260
  335. package/V3Textarea/index.d.ts +0 -27
  336. package/box/index.d.ts +0 -25
  337. package/chip/index.d.ts +0 -22
  338. package/common/RequiredComponent.js +0 -32
  339. package/date/Date.js +0 -373
  340. package/date/index.d.ts +0 -27
  341. package/dialog/index.d.ts +0 -18
  342. package/file-input/index.d.ts +0 -81
  343. package/header/index.d.ts +0 -25
  344. package/heading/index.d.ts +0 -17
  345. package/input-text/Icons.js +0 -22
  346. package/input-text/InputText.js +0 -611
  347. package/input-text/index.d.ts +0 -36
  348. package/link/index.d.ts +0 -23
  349. package/number-input/NumberInputContext.js +0 -16
  350. package/number-input/index.d.ts +0 -113
  351. package/password-input/index.d.ts +0 -94
  352. package/radio/Radio.d.ts +0 -4
  353. package/radio/Radio.js +0 -174
  354. package/radio/types.d.ts +0 -54
  355. package/resultsetTable/ResultsetTable.js +0 -274
  356. package/resultsetTable/index.d.ts +0 -19
  357. package/select/index.d.ts +0 -131
  358. package/sidenav/index.d.ts +0 -13
  359. package/spinner/index.d.ts +0 -17
  360. package/table/index.d.ts +0 -13
  361. package/tag/index.d.ts +0 -24
  362. package/text-input/index.d.ts +0 -135
  363. package/textarea/Textarea.stories.jsx +0 -135
  364. package/textarea/index.d.ts +0 -117
  365. package/toggle/Toggle.js +0 -186
  366. package/toggle/index.d.ts +0 -21
  367. package/toggle-group/index.d.ts +0 -21
  368. package/upload/Upload.js +0 -201
  369. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  370. package/upload/buttons-upload/Icons.js +0 -40
  371. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  372. package/upload/dragAndDropArea/Icons.js +0 -39
  373. package/upload/file-upload/FileToUpload.js +0 -115
  374. package/upload/file-upload/Icons.js +0 -66
  375. package/upload/files-upload/FilesToUpload.js +0 -109
  376. package/upload/index.d.ts +0 -15
  377. package/upload/transaction/Icons.js +0 -160
  378. package/upload/transaction/Transaction.js +0 -104
  379. package/upload/transactions/Transactions.js +0 -94
  380. package/wizard/Icons.js +0 -65
  381. package/wizard/index.d.ts +0 -18
  382. /package/{radio → action-icon}/types.js +0 -0
@@ -0,0 +1,285 @@
1
+ import React from "react";
2
+ import { userEvent, within, fireEvent, screen } from "@storybook/testing-library";
3
+ import DxcDateInput from "./DateInput";
4
+ import DxcDatePicker from "./DatePicker";
5
+ import YearPicker from "./YearPicker";
6
+ import Calendar from "./Calendar";
7
+ import Title from "../../.storybook/components/Title";
8
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
9
+ import dayjs from "dayjs";
10
+ import useTheme from "../useTheme";
11
+ import { ThemeProvider } from "styled-components";
12
+ import { HalstackProvider } from "../HalstackContext";
13
+
14
+ export default {
15
+ title: "Date Input",
16
+ component: DxcDateInput,
17
+ };
18
+
19
+ const opinionatedTheme = {
20
+ dateInput: {
21
+ baseColor: "#5f249f",
22
+ selectedFontColor: "#ffffff",
23
+ },
24
+ };
25
+
26
+ const DateInputChromatic = () => (
27
+ <>
28
+ <ExampleContainer>
29
+ <Title title="Complete date input" theme="light" level={4} />
30
+ <DxcDateInput label="Date input" helperText="Help message" format="dd/mm/yy" placeholder optional />
31
+ </ExampleContainer>
32
+ <ExampleContainer>
33
+ <Title title="Disabled" theme="light" level={4} />
34
+ <DxcDateInput
35
+ label="Disabled date input"
36
+ helperText="Help message"
37
+ defaultValue="06-04-2007"
38
+ clearable
39
+ disabled
40
+ />
41
+ </ExampleContainer>
42
+ <ExampleContainer>
43
+ <Title title="Read only" theme="light" level={4} />
44
+ <DxcDateInput
45
+ label="Example label"
46
+ helperText="Help message"
47
+ defaultValue="06-04-2007"
48
+ clearable
49
+ readOnly
50
+ />
51
+ </ExampleContainer>
52
+ <ExampleContainer>
53
+ <Title title="Invalid" theme="light" level={4} />
54
+ <DxcDateInput label="Error date input" error="Error message." placeholder />
55
+ </ExampleContainer>
56
+ <ExampleContainer>
57
+ <Title title="Relation between icons" theme="light" level={4} />
58
+ <DxcDateInput label="Error date input" error="Error message." defaultValue="06-04-2007" clearable />
59
+ </ExampleContainer>
60
+ <Title title="Margins" theme="light" level={2} />
61
+ <ExampleContainer>
62
+ <Title title="Xxsmall" theme="light" level={4} />
63
+ <DxcDateInput label="Xxsmall" margin="xxsmall" />
64
+ </ExampleContainer>
65
+ <ExampleContainer>
66
+ <Title title="Xsmall" theme="light" level={4} />
67
+ <DxcDateInput label="Xsmall" margin="xsmall" />
68
+ </ExampleContainer>
69
+ <ExampleContainer>
70
+ <Title title="Small" theme="light" level={4} />
71
+ <DxcDateInput label="Small" margin="small" />
72
+ </ExampleContainer>
73
+ <ExampleContainer>
74
+ <Title title="Medium" theme="light" level={4} />
75
+ <DxcDateInput label="Medium" margin="medium" />
76
+ </ExampleContainer>
77
+ <ExampleContainer>
78
+ <Title title="Large" theme="light" level={4} />
79
+ <DxcDateInput label="Large" margin="large" />
80
+ </ExampleContainer>
81
+ <ExampleContainer>
82
+ <Title title="Xlarge" theme="light" level={4} />
83
+ <DxcDateInput label="Xlarge" margin="xlarge" />
84
+ </ExampleContainer>
85
+ <ExampleContainer>
86
+ <Title title="Xxlarge" theme="light" level={4} />
87
+ <DxcDateInput label="Xxlarge" margin="xxlarge" />
88
+ </ExampleContainer>
89
+ <Title title="Sizes" theme="light" level={2} />
90
+ <ExampleContainer>
91
+ <Title title="Medium size" theme="light" level={4} />
92
+ <DxcDateInput label="Medium" size="medium" />
93
+ </ExampleContainer>
94
+ <ExampleContainer>
95
+ <Title title="Large size" theme="light" level={4} />
96
+ <DxcDateInput label="Large" size="large" />
97
+ </ExampleContainer>
98
+ <ExampleContainer>
99
+ <Title title="FillParent size" theme="light" level={4} />
100
+ <DxcDateInput label="FillParent" size="fillParent" />
101
+ </ExampleContainer>
102
+ <ExampleContainer expanded>
103
+ <Title title="Year picker" theme="light" level={4} />
104
+ <DxcDateInput label="Date input" defaultValue="06-04-1905" />
105
+ </ExampleContainer>
106
+ </>
107
+ );
108
+
109
+ export const Chromatic = DateInputChromatic.bind({});
110
+ Chromatic.play = async ({ canvasElement }) => {
111
+ const canvas = within(canvasElement);
112
+ await userEvent.click(canvas.getAllByRole("combobox")[canvas.getAllByRole("combobox").length - 1]);
113
+ await fireEvent.click(screen.getByText("April 1905"));
114
+ };
115
+
116
+ const DateInputOpinionatedTheme = () => (
117
+ <>
118
+ <Title title="Opinionated theme" theme="light" level={2} />
119
+ <ExampleContainer>
120
+ <Title title="Enabled" theme="light" level={4} />
121
+ <HalstackProvider theme={opinionatedTheme}>
122
+ <DxcDateInput
123
+ label="Date input"
124
+ helperText="Help message"
125
+ format="dd/mm/yy"
126
+ placeholder
127
+ optional
128
+ defaultValue="10-10-2022"
129
+ />
130
+ </HalstackProvider>
131
+ </ExampleContainer>
132
+ <ExampleContainer>
133
+ <Title title="Disabled" theme="light" level={4} />
134
+ <HalstackProvider theme={opinionatedTheme}>
135
+ <DxcDateInput label="Date input" helperText="Help message" format="dd/mm/yy" placeholder optional />
136
+ </HalstackProvider>
137
+ </ExampleContainer>
138
+ <ExampleContainer>
139
+ <Title title="Invalid" theme="light" level={4} />
140
+ <HalstackProvider theme={opinionatedTheme}>
141
+ <DxcDateInput label="Error date input" error="Error message." placeholder />
142
+ </HalstackProvider>
143
+ </ExampleContainer>
144
+ <ExampleContainer expanded>
145
+ <Title title="Date picker" theme="light" level={4} />
146
+ <HalstackProvider theme={opinionatedTheme}>
147
+ <DxcDateInput label="Date input" defaultValue="06-04-1905" />
148
+ </HalstackProvider>
149
+ </ExampleContainer>
150
+ </>
151
+ );
152
+
153
+ export const DateInputOpinionated = DateInputOpinionatedTheme.bind({});
154
+ DateInputOpinionated.play = async ({ canvasElement }) => {
155
+ const canvas = within(canvasElement);
156
+ await userEvent.click(canvas.getAllByRole("combobox")[canvas.getAllByRole("combobox").length - 1]);
157
+ };
158
+
159
+ const YearPickerOpinionatedTheme = () => (
160
+ <ExampleContainer expanded>
161
+ <Title title="Year picker" theme="light" level={4} />
162
+ <HalstackProvider theme={opinionatedTheme}>
163
+ <DxcDateInput label="Date input" defaultValue="06-04-1905" />
164
+ </HalstackProvider>
165
+ </ExampleContainer>
166
+ );
167
+
168
+ export const YearPickerOpinionated = YearPickerOpinionatedTheme.bind({});
169
+ YearPickerOpinionated.play = async ({ canvasElement }) => {
170
+ const canvas = within(canvasElement);
171
+ await userEvent.click(canvas.getByRole("combobox"));
172
+ await fireEvent.click(screen.getByText("April 1905"));
173
+ };
174
+
175
+ const DatePickerButtonStates = () => {
176
+ const colorsTheme: any = useTheme();
177
+ return (
178
+ <>
179
+ <ExampleContainer>
180
+ <Title title="Show date picker over another element with z-index 0" theme="light" level={4} />
181
+ <div
182
+ style={{
183
+ display: "flex",
184
+ flexDirection: "column",
185
+ gap: "20px",
186
+ height: "200px",
187
+ width: "500px",
188
+ marginBottom: "250px",
189
+ padding: "20px",
190
+ border: "1px solid black",
191
+ borderRadius: "4px",
192
+ overflow: "auto",
193
+ zIndex: "1300",
194
+ position: "relative",
195
+ }}
196
+ >
197
+ <DxcDateInput label="From" defaultValue="01-12-1995" />
198
+ <DxcDateInput label="To" />
199
+ <button style={{ zIndex: "1", width: "100px" }}>Submit</button>
200
+ </div>
201
+ </ExampleContainer>
202
+ <ThemeProvider theme={colorsTheme}>
203
+ <ExampleContainer pseudoState="pseudo-focus">
204
+ <Title title="Isolated calendar focused" theme="light" level={4} />
205
+ <DxcDatePicker date={dayjs("06-04-1950", "DD-MM-YYYY")} onDateSelect={() => {}} id="test-calendar" />
206
+ </ExampleContainer>
207
+ <ExampleContainer pseudoState="pseudo-hover">
208
+ <Title title="Isolated calendar hovered" theme="light" level={4} />
209
+ <DxcDatePicker date={dayjs("06-04-1950", "DD-MM-YYYY")} onDateSelect={() => {}} id="test-calendar" />
210
+ </ExampleContainer>
211
+ <ExampleContainer pseudoState="pseudo-active">
212
+ <Title title="Isolated calendar actived" theme="light" level={4} />
213
+ <DxcDatePicker date={dayjs("06-04-1950", "DD-MM-YYYY")} onDateSelect={() => {}} id="test-calendar" />
214
+ </ExampleContainer>
215
+ </ThemeProvider>
216
+ </>
217
+ );
218
+ };
219
+
220
+ export const DatePickerStates = DatePickerButtonStates.bind({});
221
+ DatePickerStates.play = async ({ canvasElement }) => {
222
+ const canvas = within(canvasElement);
223
+ const dateBtn = canvas.getAllByTitle("Open calendar")[0];
224
+ await userEvent.click(dateBtn);
225
+ };
226
+
227
+ export const YearPickerStates = () => {
228
+ const colorsTheme: any = useTheme();
229
+ return (
230
+ <>
231
+ <ThemeProvider theme={colorsTheme}>
232
+ <ExampleContainer pseudoState="pseudo-focus">
233
+ <Title title="Isolated year picker focused" theme="light" level={4} />
234
+ <YearPicker
235
+ selectedDate={dayjs("06-04-1905", "DD-MM-YYYY")}
236
+ onYearSelect={() => {}}
237
+ today={dayjs("1904-04-03", "YYYY-MM-DD")}
238
+ />
239
+ </ExampleContainer>
240
+ <ExampleContainer pseudoState="pseudo-hover">
241
+ <Title title="Isolated year picker hovered" theme="light" level={4} />
242
+ <YearPicker
243
+ selectedDate={dayjs("06-04-1905", "DD-MM-YYYY")}
244
+ onYearSelect={() => {}}
245
+ today={dayjs("1904-04-03", "YYYY-MM-DD")}
246
+ />
247
+ </ExampleContainer>
248
+ <ExampleContainer pseudoState="pseudo-active">
249
+ <Title title="Isolated year picker actived" theme="light" level={4} />
250
+ <YearPicker
251
+ selectedDate={dayjs("06-04-1905", "DD-MM-YYYY")}
252
+ onYearSelect={() => {}}
253
+ today={dayjs("1904-04-03", "YYYY-MM-DD")}
254
+ />
255
+ </ExampleContainer>
256
+ </ThemeProvider>
257
+ </>
258
+ );
259
+ };
260
+
261
+ export const DatePickerWithToday = () => {
262
+ const colorsTheme: any = useTheme();
263
+ return (
264
+ <ThemeProvider theme={colorsTheme}>
265
+ <ExampleContainer>
266
+ <Title title="Isolated calendar with today" theme="light" level={4} />
267
+ <Calendar
268
+ selectedDate={dayjs("06-04-1904", "DD-MM-YYYY")}
269
+ today={dayjs("1904-04-03", "YYYY-MM-DD")}
270
+ onInnerDateChange={() => {}}
271
+ onDaySelect={() => {}}
272
+ innerDate={dayjs("06-04-1904", "DD-MM-YYYY")}
273
+ />
274
+ </ExampleContainer>
275
+ <ExampleContainer>
276
+ <Title title="Isolated year picker with today" theme="light" level={4} />
277
+ <YearPicker
278
+ selectedDate={dayjs("06-04-1905", "DD-MM-YYYY")}
279
+ onYearSelect={() => {}}
280
+ today={dayjs("1904-04-03", "YYYY-MM-DD")}
281
+ />
282
+ </ExampleContainer>
283
+ </ThemeProvider>
284
+ );
285
+ };