@dxc-technology/halstack-react 0.0.0-c908d78 → 0.0.0-ca55cbe

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