@dxc-technology/halstack-react 0.0.0-da224ae → 0.0.0-da4b2be

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 (329) 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 +5 -4
  11. package/accordion-group/AccordionGroup.js +34 -76
  12. package/accordion-group/AccordionGroup.stories.tsx +251 -0
  13. package/accordion-group/AccordionGroup.test.js +126 -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 +15 -8
  17. package/alert/Alert.js +11 -12
  18. package/alert/Alert.stories.tsx +28 -0
  19. package/alert/Alert.test.js +92 -0
  20. package/alert/types.d.ts +1 -1
  21. package/badge/Badge.d.ts +4 -0
  22. package/badge/Badge.js +6 -4
  23. package/badge/types.d.ts +5 -0
  24. package/bleed/Bleed.d.ts +3 -0
  25. package/bleed/Bleed.js +51 -0
  26. package/bleed/Bleed.stories.tsx +342 -0
  27. package/bleed/types.d.ts +37 -0
  28. package/bleed/types.js +5 -0
  29. package/box/Box.d.ts +1 -1
  30. package/box/Box.js +23 -55
  31. package/box/Box.stories.tsx +38 -51
  32. package/box/Box.test.js +18 -0
  33. package/box/types.d.ts +0 -15
  34. package/bulleted-list/BulletedList.d.ts +7 -0
  35. package/bulleted-list/BulletedList.js +125 -0
  36. package/bulleted-list/BulletedList.stories.tsx +206 -0
  37. package/bulleted-list/types.d.ts +38 -0
  38. package/bulleted-list/types.js +5 -0
  39. package/button/Button.d.ts +1 -1
  40. package/button/Button.js +61 -85
  41. package/button/Button.stories.tsx +163 -14
  42. package/button/Button.test.js +35 -0
  43. package/button/types.d.ts +8 -12
  44. package/card/Card.js +35 -40
  45. package/card/Card.stories.tsx +200 -0
  46. package/card/Card.test.js +50 -0
  47. package/card/ice-cream.jpg +0 -0
  48. package/card/types.d.ts +5 -6
  49. package/checkbox/Checkbox.d.ts +2 -2
  50. package/checkbox/Checkbox.js +108 -111
  51. package/checkbox/Checkbox.stories.tsx +198 -130
  52. package/checkbox/Checkbox.test.js +155 -0
  53. package/checkbox/types.d.ts +13 -5
  54. package/chip/Chip.d.ts +4 -0
  55. package/chip/Chip.js +37 -118
  56. package/chip/Chip.stories.tsx +123 -30
  57. package/chip/Chip.test.js +54 -0
  58. package/chip/types.d.ts +45 -0
  59. package/chip/types.js +5 -0
  60. package/common/OpenSans.css +68 -80
  61. package/common/coreTokens.d.ts +146 -0
  62. package/common/coreTokens.js +167 -0
  63. package/common/utils.d.ts +1 -0
  64. package/common/utils.js +4 -4
  65. package/common/variables.d.ts +1482 -0
  66. package/common/variables.js +1100 -1316
  67. package/date-input/Calendar.d.ts +4 -0
  68. package/date-input/Calendar.js +258 -0
  69. package/date-input/DateInput.js +174 -266
  70. package/date-input/DateInput.stories.tsx +199 -33
  71. package/date-input/DateInput.test.js +835 -0
  72. package/date-input/DatePicker.d.ts +4 -0
  73. package/date-input/DatePicker.js +146 -0
  74. package/date-input/Icons.d.ts +6 -0
  75. package/date-input/Icons.js +75 -0
  76. package/date-input/YearPicker.d.ts +4 -0
  77. package/date-input/YearPicker.js +126 -0
  78. package/date-input/types.d.ts +67 -9
  79. package/dialog/Dialog.d.ts +1 -1
  80. package/dialog/Dialog.js +69 -103
  81. package/dialog/Dialog.stories.tsx +154 -171
  82. package/dialog/Dialog.test.js +369 -0
  83. package/dialog/types.d.ts +0 -12
  84. package/dropdown/Dropdown.d.ts +1 -1
  85. package/dropdown/Dropdown.js +248 -277
  86. package/dropdown/Dropdown.stories.tsx +438 -0
  87. package/dropdown/Dropdown.test.js +586 -0
  88. package/dropdown/DropdownMenu.d.ts +4 -0
  89. package/dropdown/DropdownMenu.js +74 -0
  90. package/dropdown/DropdownMenuItem.d.ts +4 -0
  91. package/dropdown/DropdownMenuItem.js +79 -0
  92. package/dropdown/types.d.ts +28 -17
  93. package/file-input/FileInput.d.ts +4 -0
  94. package/file-input/FileInput.js +183 -168
  95. package/file-input/FileInput.stories.tsx +618 -0
  96. package/file-input/FileInput.test.js +457 -0
  97. package/file-input/FileItem.d.ts +4 -0
  98. package/file-input/FileItem.js +50 -81
  99. package/file-input/types.d.ts +129 -0
  100. package/file-input/types.js +5 -0
  101. package/flex/Flex.d.ts +4 -0
  102. package/flex/Flex.js +71 -0
  103. package/flex/Flex.stories.tsx +112 -0
  104. package/flex/types.d.ts +97 -0
  105. package/flex/types.js +5 -0
  106. package/footer/Footer.d.ts +1 -1
  107. package/footer/Footer.js +34 -117
  108. package/footer/Footer.stories.tsx +228 -0
  109. package/footer/Footer.test.js +97 -0
  110. package/footer/Icons.d.ts +2 -0
  111. package/footer/Icons.js +4 -4
  112. package/footer/types.d.ts +23 -18
  113. package/grid/Grid.d.ts +7 -0
  114. package/grid/Grid.js +91 -0
  115. package/grid/Grid.stories.tsx +219 -0
  116. package/grid/types.d.ts +115 -0
  117. package/grid/types.js +5 -0
  118. package/header/Header.d.ts +3 -2
  119. package/header/Header.js +110 -131
  120. package/header/Header.stories.tsx +315 -0
  121. package/header/Header.test.js +79 -0
  122. package/header/Icons.d.ts +2 -0
  123. package/header/Icons.js +2 -2
  124. package/header/types.d.ts +5 -2
  125. package/heading/Heading.js +2 -2
  126. package/heading/Heading.stories.tsx +54 -0
  127. package/heading/Heading.test.js +186 -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 +199 -16
  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 +122 -0
  151. package/nav-tabs/NavTabs.stories.tsx +274 -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 +146 -0
  155. package/nav-tabs/types.d.ts +52 -0
  156. package/nav-tabs/types.js +5 -0
  157. package/number-input/NumberInput.js +14 -24
  158. package/number-input/NumberInput.stories.tsx +5 -5
  159. package/number-input/NumberInput.test.js +542 -0
  160. package/number-input/NumberInputContext.d.ts +4 -0
  161. package/number-input/NumberInputContext.js +5 -2
  162. package/number-input/numberInputContextTypes.d.ts +19 -0
  163. package/number-input/numberInputContextTypes.js +5 -0
  164. package/number-input/types.d.ts +17 -10
  165. package/package.json +22 -23
  166. package/paginator/Icons.d.ts +5 -0
  167. package/paginator/Icons.js +16 -28
  168. package/paginator/Paginator.js +22 -57
  169. package/paginator/Paginator.stories.tsx +24 -0
  170. package/paginator/Paginator.test.js +318 -0
  171. package/paragraph/Paragraph.d.ts +5 -0
  172. package/paragraph/Paragraph.js +38 -0
  173. package/paragraph/Paragraph.stories.tsx +44 -0
  174. package/password-input/PasswordInput.js +23 -19
  175. package/password-input/PasswordInput.stories.tsx +3 -3
  176. package/password-input/PasswordInput.test.js +181 -0
  177. package/password-input/types.d.ts +29 -19
  178. package/progress-bar/ProgressBar.js +63 -57
  179. package/progress-bar/ProgressBar.stories.jsx +47 -12
  180. package/progress-bar/ProgressBar.test.js +110 -0
  181. package/quick-nav/QuickNav.d.ts +4 -0
  182. package/quick-nav/QuickNav.js +117 -0
  183. package/quick-nav/QuickNav.stories.tsx +356 -0
  184. package/quick-nav/types.d.ts +21 -0
  185. package/quick-nav/types.js +5 -0
  186. package/radio-group/Radio.d.ts +4 -0
  187. package/radio-group/Radio.js +156 -0
  188. package/radio-group/RadioGroup.d.ts +4 -0
  189. package/radio-group/RadioGroup.js +281 -0
  190. package/radio-group/RadioGroup.stories.tsx +214 -0
  191. package/radio-group/RadioGroup.test.js +722 -0
  192. package/radio-group/types.d.ts +114 -0
  193. package/radio-group/types.js +5 -0
  194. package/resultsetTable/Icons.d.ts +7 -0
  195. package/resultsetTable/Icons.js +51 -0
  196. package/resultsetTable/ResultsetTable.d.ts +4 -0
  197. package/resultsetTable/ResultsetTable.js +54 -133
  198. package/resultsetTable/ResultsetTable.stories.tsx +300 -0
  199. package/resultsetTable/ResultsetTable.test.js +325 -0
  200. package/resultsetTable/types.d.ts +67 -0
  201. package/resultsetTable/types.js +5 -0
  202. package/select/Icons.d.ts +10 -0
  203. package/select/Icons.js +93 -0
  204. package/select/Listbox.d.ts +4 -0
  205. package/select/Listbox.js +169 -0
  206. package/select/Option.d.ts +4 -0
  207. package/select/Option.js +97 -0
  208. package/select/Select.d.ts +4 -0
  209. package/select/Select.js +202 -401
  210. package/select/Select.stories.tsx +600 -201
  211. package/select/Select.test.js +2228 -0
  212. package/select/types.d.ts +210 -0
  213. package/select/types.js +5 -0
  214. package/sidenav/Icons.d.ts +7 -0
  215. package/sidenav/Icons.js +51 -0
  216. package/sidenav/Sidenav.d.ts +6 -5
  217. package/sidenav/Sidenav.js +148 -46
  218. package/sidenav/Sidenav.stories.tsx +282 -0
  219. package/sidenav/Sidenav.test.js +44 -0
  220. package/sidenav/types.d.ts +52 -26
  221. package/slider/Slider.d.ts +2 -2
  222. package/slider/Slider.js +124 -99
  223. package/slider/Slider.stories.tsx +72 -9
  224. package/slider/Slider.test.js +250 -0
  225. package/slider/types.d.ts +8 -0
  226. package/spinner/Spinner.js +20 -26
  227. package/spinner/Spinner.stories.jsx +53 -26
  228. package/spinner/Spinner.test.js +64 -0
  229. package/switch/Switch.d.ts +2 -2
  230. package/switch/Switch.js +153 -70
  231. package/switch/Switch.stories.tsx +54 -43
  232. package/switch/Switch.test.js +225 -0
  233. package/switch/types.d.ts +10 -2
  234. package/table/Table.js +6 -6
  235. package/table/Table.stories.jsx +81 -1
  236. package/table/Table.test.js +26 -0
  237. package/tabs/Tab.d.ts +4 -0
  238. package/tabs/Tab.js +132 -0
  239. package/tabs/Tabs.d.ts +1 -1
  240. package/tabs/Tabs.js +362 -112
  241. package/tabs/Tabs.stories.tsx +226 -0
  242. package/tabs/Tabs.test.js +350 -0
  243. package/tabs/types.d.ts +39 -18
  244. package/tag/Tag.d.ts +1 -1
  245. package/tag/Tag.js +25 -37
  246. package/tag/Tag.stories.tsx +38 -28
  247. package/tag/Tag.test.js +60 -0
  248. package/tag/types.d.ts +23 -14
  249. package/text-input/Icons.d.ts +8 -0
  250. package/text-input/Icons.js +60 -0
  251. package/text-input/Suggestion.d.ts +4 -0
  252. package/text-input/Suggestion.js +84 -0
  253. package/text-input/Suggestions.d.ts +4 -0
  254. package/text-input/Suggestions.js +134 -0
  255. package/text-input/TextInput.d.ts +4 -0
  256. package/text-input/TextInput.js +236 -388
  257. package/text-input/TextInput.stories.tsx +569 -0
  258. package/text-input/TextInput.test.js +1723 -0
  259. package/text-input/types.d.ts +197 -0
  260. package/text-input/types.js +5 -0
  261. package/textarea/Textarea.d.ts +4 -0
  262. package/textarea/Textarea.js +41 -82
  263. package/textarea/Textarea.stories.jsx +96 -15
  264. package/textarea/Textarea.test.js +435 -0
  265. package/textarea/types.d.ts +137 -0
  266. package/textarea/types.js +5 -0
  267. package/toggle-group/ToggleGroup.d.ts +4 -0
  268. package/toggle-group/ToggleGroup.js +24 -49
  269. package/toggle-group/ToggleGroup.stories.tsx +69 -32
  270. package/toggle-group/ToggleGroup.test.js +156 -0
  271. package/toggle-group/types.d.ts +105 -0
  272. package/toggle-group/types.js +5 -0
  273. package/typography/Typography.d.ts +4 -0
  274. package/typography/Typography.js +32 -0
  275. package/typography/Typography.stories.tsx +198 -0
  276. package/typography/types.d.ts +18 -0
  277. package/typography/types.js +5 -0
  278. package/useTheme.d.ts +1235 -0
  279. package/useTheme.js +3 -3
  280. package/useTranslatedLabels.d.ts +85 -0
  281. package/useTranslatedLabels.js +20 -0
  282. package/utils/BaseTypography.d.ts +21 -0
  283. package/utils/BaseTypography.js +108 -0
  284. package/utils/FocusLock.d.ts +13 -0
  285. package/utils/FocusLock.js +138 -0
  286. package/wizard/Wizard.d.ts +1 -1
  287. package/wizard/Wizard.js +113 -59
  288. package/wizard/{Wizard.stories.jsx → Wizard.stories.tsx} +48 -19
  289. package/wizard/Wizard.test.js +141 -0
  290. package/wizard/types.d.ts +10 -10
  291. package/ThemeContext.js +0 -246
  292. package/V3Select/V3Select.js +0 -455
  293. package/V3Select/index.d.ts +0 -27
  294. package/V3Textarea/V3Textarea.js +0 -260
  295. package/V3Textarea/index.d.ts +0 -27
  296. package/chip/index.d.ts +0 -22
  297. package/common/RequiredComponent.js +0 -32
  298. package/date/Date.js +0 -373
  299. package/date/index.d.ts +0 -27
  300. package/file-input/index.d.ts +0 -81
  301. package/footer/Footer.stories.jsx +0 -151
  302. package/input-text/Icons.js +0 -22
  303. package/input-text/InputText.js +0 -611
  304. package/input-text/index.d.ts +0 -36
  305. package/radio/Radio.d.ts +0 -4
  306. package/radio/Radio.js +0 -174
  307. package/radio/Radio.stories.tsx +0 -192
  308. package/radio/types.d.ts +0 -54
  309. package/resultsetTable/index.d.ts +0 -19
  310. package/select/index.d.ts +0 -131
  311. package/text-input/index.d.ts +0 -135
  312. package/textarea/index.d.ts +0 -117
  313. package/toggle/Toggle.js +0 -186
  314. package/toggle/index.d.ts +0 -21
  315. package/toggle-group/index.d.ts +0 -21
  316. package/upload/Upload.js +0 -201
  317. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  318. package/upload/buttons-upload/Icons.js +0 -40
  319. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  320. package/upload/dragAndDropArea/Icons.js +0 -39
  321. package/upload/file-upload/FileToUpload.js +0 -115
  322. package/upload/file-upload/Icons.js +0 -66
  323. package/upload/files-upload/FilesToUpload.js +0 -109
  324. package/upload/index.d.ts +0 -15
  325. package/upload/transaction/Icons.js +0 -160
  326. package/upload/transaction/Transaction.js +0 -104
  327. package/upload/transactions/Transactions.js +0 -94
  328. package/wizard/Icons.js +0 -65
  329. /package/{radio → badge}/types.js +0 -0
@@ -1,17 +1,31 @@
1
1
  import React from "react";
2
2
  import { userEvent, within, fireEvent, screen } from "@storybook/testing-library";
3
3
  import DxcDateInput from "./DateInput";
4
+ import DxcDatePicker from "./DatePicker";
5
+ import YearPicker from "./YearPicker";
6
+ import Calendar from "./Calendar";
4
7
  import Title from "../../.storybook/components/Title";
5
8
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
9
  import { BackgroundColorProvider } from "../BackgroundColorContext";
7
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";
8
15
 
9
16
  export default {
10
17
  title: "Date input",
11
18
  component: DxcDateInput,
12
19
  };
13
20
 
14
- export const Chromatic = () => (
21
+ const opinionatedTheme = {
22
+ dateInput: {
23
+ baseColor: "#5f249f",
24
+ selectedFontColor: "#ffffff",
25
+ },
26
+ };
27
+
28
+ const DateInputChromatic = () => (
15
29
  <>
16
30
  <ExampleContainer>
17
31
  <Title title="Complete date input" theme="light" level={4} />
@@ -19,7 +33,13 @@ export const Chromatic = () => (
19
33
  </ExampleContainer>
20
34
  <ExampleContainer>
21
35
  <Title title="Disabled" theme="light" level={4} />
22
- <DxcDateInput label="Disabled date input" helperText="Help message" value="06-04-2027" clearable disabled />
36
+ <DxcDateInput
37
+ label="Disabled date input"
38
+ helperText="Help message"
39
+ defaultValue="06-04-2007"
40
+ clearable
41
+ disabled
42
+ />
23
43
  </ExampleContainer>
24
44
  <ExampleContainer>
25
45
  <Title title="Invalid" theme="light" level={4} />
@@ -27,7 +47,7 @@ export const Chromatic = () => (
27
47
  </ExampleContainer>
28
48
  <ExampleContainer>
29
49
  <Title title="Relation between icons" theme="light" level={4} />
30
- <DxcDateInput label="Error date input" error="Error message." value="06-04-2027" clearable />
50
+ <DxcDateInput label="Error date input" error="Error message." defaultValue="06-04-2007" clearable />
31
51
  </ExampleContainer>
32
52
  <BackgroundColorProvider color="#333333">
33
53
  <DarkContainer>
@@ -38,7 +58,13 @@ export const Chromatic = () => (
38
58
  </ExampleContainer>
39
59
  <ExampleContainer>
40
60
  <Title title="Disabled" theme="dark" level={4} />
41
- <DxcDateInput label="Disabled Date input" helperText="Help message" value="06-04-2027" clearable disabled />
61
+ <DxcDateInput
62
+ label="Disabled Date input"
63
+ helperText="Help message"
64
+ defaultValue="06-04-2027"
65
+ clearable
66
+ disabled
67
+ />
42
68
  </ExampleContainer>
43
69
  <ExampleContainer>
44
70
  <Title title="Invalid" theme="dark" level={4} />
@@ -46,7 +72,7 @@ export const Chromatic = () => (
46
72
  </ExampleContainer>
47
73
  <ExampleContainer>
48
74
  <Title title="Relation between icons" theme="dark" level={4} />
49
- <DxcDateInput label="Error date input" value="06-04-2027" error="Error message." clearable />
75
+ <DxcDateInput label="Error date input" defaultValue="06-04-2007" error="Error message." clearable />
50
76
  </ExampleContainer>
51
77
  </DarkContainer>
52
78
  </BackgroundColorProvider>
@@ -92,47 +118,187 @@ export const Chromatic = () => (
92
118
  <Title title="FillParent size" theme="light" level={4} />
93
119
  <DxcDateInput label="FillParent" size="fillParent" />
94
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>
95
125
  </>
96
126
  );
97
127
 
98
- const DatePicker = () => (
99
- <ExampleContainer expanded>
100
- <Title title="Show date input" theme="light" level={4} />
101
- <DxcDateInput label="Date input" value="10-06-2023" />
102
- </ExampleContainer>
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
+ </>
103
170
  );
104
171
 
105
- export const ShowDatePicker = DatePicker.bind({});
106
- ShowDatePicker.play = async ({ canvasElement }) => {
172
+ export const DateInputOpinionated = DateInputOpinionatedTheme.bind({});
173
+ DateInputOpinionated.play = async ({ canvasElement }) => {
107
174
  const canvas = within(canvasElement);
108
- const dateBtn = canvas.getByRole("button");
109
- await userEvent.click(dateBtn);
110
- await userEvent.tab();
175
+ await userEvent.click(canvas.getAllByRole("combobox")[canvas.getAllByRole("combobox").length - 1]);
111
176
  };
112
177
 
113
- const YearPicker = () => (
178
+ const YearPickerOpinionatedTheme = () => (
114
179
  <ExampleContainer expanded>
115
- <Title title="Show date input" theme="light" level={4} />
116
- <DxcDateInput label="Date input" value="10-06-2023" />
180
+ <Title title="Year picker" theme="light" level={4} />
181
+ <HalstackProvider theme={opinionatedTheme}>
182
+ <DxcDateInput label="Date input" defaultValue="06-04-1905" />
183
+ </HalstackProvider>
117
184
  </ExampleContainer>
118
185
  );
119
186
 
120
- export const ShowYearPicker = YearPicker.bind({});
121
- ShowYearPicker.play = async () => {
122
- await fireEvent.click(screen.getByRole("button"));
123
- await fireEvent.click(screen.getByText("2023"));
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"));
124
192
  };
125
193
 
126
- const YearPickerFocus = () => (
127
- <ExampleContainer expanded>
128
- <Title title="Show date input" theme="light" level={4} />
129
- <DxcDateInput label="Date input" value="10-06-2023" />
130
- </ExampleContainer>
131
- );
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
+ };
132
279
 
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();
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
+ );
138
304
  };