@dxc-technology/halstack-react 0.0.0-e30cba6 → 0.0.0-e49dc66

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 (314) hide show
  1. package/BackgroundColorContext.js +50 -0
  2. package/ThemeContext.js +246 -0
  3. package/{dist/select/Select.js → V3Select/V3Select.js} +116 -246
  4. package/V3Select/index.d.ts +27 -0
  5. package/{dist/textarea/Textarea.js → V3Textarea/V3Textarea.js} +14 -18
  6. package/V3Textarea/index.d.ts +27 -0
  7. package/accordion/Accordion.d.ts +4 -0
  8. package/{dist/accordion → accordion}/Accordion.js +35 -130
  9. package/accordion/types.d.ts +68 -0
  10. package/accordion/types.js +5 -0
  11. package/accordion-group/AccordionGroup.d.ts +7 -0
  12. package/accordion-group/AccordionGroup.js +170 -0
  13. package/accordion-group/types.d.ts +72 -0
  14. package/accordion-group/types.js +5 -0
  15. package/alert/Alert.d.ts +4 -0
  16. package/{dist/alert → alert}/Alert.js +42 -155
  17. package/alert/Alert.stories.tsx +170 -0
  18. package/alert/types.d.ts +49 -0
  19. package/alert/types.js +5 -0
  20. package/badge/Badge.js +59 -0
  21. package/box/Box.d.ts +4 -0
  22. package/{dist/box → box}/Box.js +18 -45
  23. package/box/Box.stories.tsx +132 -0
  24. package/box/types.d.ts +47 -0
  25. package/box/types.js +5 -0
  26. package/button/Button.d.ts +4 -0
  27. package/{dist/button → button}/Button.js +23 -84
  28. package/button/Button.stories.tsx +276 -0
  29. package/button/types.d.ts +57 -0
  30. package/button/types.js +5 -0
  31. package/card/Card.d.ts +4 -0
  32. package/{dist/card → card}/Card.js +32 -121
  33. package/card/types.d.ts +69 -0
  34. package/card/types.js +5 -0
  35. package/checkbox/Checkbox.d.ts +4 -0
  36. package/{dist/checkbox → checkbox}/Checkbox.js +16 -63
  37. package/checkbox/Checkbox.stories.tsx +192 -0
  38. package/checkbox/types.d.ts +60 -0
  39. package/checkbox/types.js +5 -0
  40. package/{dist/chip → chip}/Chip.js +17 -61
  41. package/chip/index.d.ts +22 -0
  42. package/{dist/common → common}/OpenSans.css +0 -0
  43. package/{dist/common → common}/RequiredComponent.js +3 -11
  44. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  45. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  46. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  47. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  48. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  49. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  50. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  51. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  52. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  53. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  54. package/{dist/common → common}/utils.js +0 -0
  55. package/{dist/common → common}/variables.js +380 -170
  56. package/{dist/date → date}/Date.js +20 -28
  57. package/date/index.d.ts +27 -0
  58. package/date-input/DateInput.d.ts +4 -0
  59. package/{dist/new-date/NewDate.js → date-input/DateInput.js} +88 -130
  60. package/date-input/DateInput.stories.tsx +138 -0
  61. package/date-input/types.d.ts +100 -0
  62. package/date-input/types.js +5 -0
  63. package/dialog/Dialog.d.ts +4 -0
  64. package/{dist/dialog → dialog}/Dialog.js +20 -73
  65. package/dialog/types.d.ts +43 -0
  66. package/dialog/types.js +5 -0
  67. package/dropdown/Dropdown.d.ts +4 -0
  68. package/{dist/dropdown → dropdown}/Dropdown.js +44 -171
  69. package/dropdown/types.d.ts +89 -0
  70. package/dropdown/types.js +5 -0
  71. package/file-input/FileInput.js +532 -0
  72. package/file-input/FileItem.js +193 -0
  73. package/file-input/index.d.ts +81 -0
  74. package/footer/Footer.d.ts +4 -0
  75. package/footer/Footer.js +266 -0
  76. package/footer/Footer.stories.jsx +151 -0
  77. package/footer/Icons.js +77 -0
  78. package/footer/types.d.ts +61 -0
  79. package/footer/types.js +5 -0
  80. package/header/Header.d.ts +7 -0
  81. package/header/Header.js +324 -0
  82. package/header/Icons.js +34 -0
  83. package/header/types.d.ts +45 -0
  84. package/header/types.js +5 -0
  85. package/{dist/heading → heading}/Heading.js +30 -72
  86. package/heading/index.d.ts +17 -0
  87. package/input-text/Icons.js +22 -0
  88. package/{dist/input-text → input-text}/InputText.js +37 -133
  89. package/input-text/index.d.ts +36 -0
  90. package/{dist/layout → layout}/ApplicationLayout.js +35 -131
  91. package/layout/Icons.js +55 -0
  92. package/link/Link.d.ts +3 -0
  93. package/{dist/link → link}/Link.js +20 -100
  94. package/link/Link.stories.tsx +70 -0
  95. package/link/types.d.ts +74 -0
  96. package/link/types.js +5 -0
  97. package/main.d.ts +44 -0
  98. package/{dist/main.js → main.js} +104 -92
  99. package/{dist/number/Number.js → number-input/NumberInput.js} +10 -20
  100. package/number-input/NumberInput.stories.jsx +115 -0
  101. package/{dist/number/NumberContext.js → number-input/NumberInputContext.js} +2 -2
  102. package/number-input/index.d.ts +113 -0
  103. package/package.json +32 -24
  104. package/paginator/Icons.js +66 -0
  105. package/paginator/Paginator.d.ts +4 -0
  106. package/paginator/Paginator.js +198 -0
  107. package/paginator/Paginator.stories.tsx +63 -0
  108. package/paginator/types.d.ts +38 -0
  109. package/paginator/types.js +5 -0
  110. package/password-input/PasswordInput.d.ts +4 -0
  111. package/{dist/password/Password.js → password-input/PasswordInput.js} +29 -67
  112. package/password-input/PasswordInput.stories.tsx +131 -0
  113. package/password-input/types.d.ts +100 -0
  114. package/password-input/types.js +5 -0
  115. package/progress-bar/ProgressBar.d.ts +4 -0
  116. package/{dist/progress-bar → progress-bar}/ProgressBar.js +20 -92
  117. package/progress-bar/ProgressBar.stories.jsx +58 -0
  118. package/progress-bar/types.d.ts +37 -0
  119. package/progress-bar/types.js +5 -0
  120. package/radio/Radio.d.ts +4 -0
  121. package/{dist/radio → radio}/Radio.js +15 -50
  122. package/radio/Radio.stories.tsx +192 -0
  123. package/radio/types.d.ts +54 -0
  124. package/radio/types.js +5 -0
  125. package/{dist/resultsetTable → resultsetTable}/ResultsetTable.js +35 -119
  126. package/resultsetTable/index.d.ts +19 -0
  127. package/select/Select.js +865 -0
  128. package/select/index.d.ts +131 -0
  129. package/{dist/sidenav → sidenav}/Sidenav.js +17 -49
  130. package/sidenav/index.d.ts +13 -0
  131. package/slider/Slider.d.ts +4 -0
  132. package/slider/Slider.js +317 -0
  133. package/slider/Slider.stories.tsx +172 -0
  134. package/slider/types.d.ts +78 -0
  135. package/slider/types.js +5 -0
  136. package/spinner/Spinner.d.ts +4 -0
  137. package/spinner/Spinner.js +250 -0
  138. package/spinner/Spinner.stories.jsx +102 -0
  139. package/spinner/types.d.ts +32 -0
  140. package/spinner/types.js +5 -0
  141. package/switch/Switch.d.ts +4 -0
  142. package/{dist/switch → switch}/Switch.js +26 -69
  143. package/switch/Switch.stories.tsx +160 -0
  144. package/switch/types.d.ts +58 -0
  145. package/switch/types.js +5 -0
  146. package/table/Table.d.ts +4 -0
  147. package/{dist/table → table}/Table.js +10 -24
  148. package/table/Table.stories.jsx +276 -0
  149. package/table/types.d.ts +21 -0
  150. package/table/types.js +5 -0
  151. package/tabs/Tabs.d.ts +4 -0
  152. package/tabs/Tabs.js +211 -0
  153. package/tabs/types.d.ts +71 -0
  154. package/tabs/types.js +5 -0
  155. package/tag/Tag.d.ts +4 -0
  156. package/tag/Tag.js +193 -0
  157. package/tag/Tag.stories.tsx +145 -0
  158. package/tag/types.d.ts +60 -0
  159. package/tag/types.js +5 -0
  160. package/text-input/TextInput.js +825 -0
  161. package/text-input/index.d.ts +135 -0
  162. package/{dist/new-textarea/NewTextarea.js → textarea/Textarea.js} +81 -110
  163. package/textarea/Textarea.stories.jsx +135 -0
  164. package/textarea/index.d.ts +117 -0
  165. package/{dist/toggle → toggle}/Toggle.js +15 -49
  166. package/toggle/index.d.ts +21 -0
  167. package/toggle-group/ToggleGroup.js +243 -0
  168. package/toggle-group/index.d.ts +21 -0
  169. package/{dist/upload → upload}/Upload.js +11 -15
  170. package/upload/buttons-upload/ButtonsUpload.js +111 -0
  171. package/upload/buttons-upload/Icons.js +40 -0
  172. package/upload/dragAndDropArea/DragAndDropArea.js +225 -0
  173. package/upload/dragAndDropArea/Icons.js +39 -0
  174. package/upload/file-upload/FileToUpload.js +115 -0
  175. package/upload/file-upload/Icons.js +66 -0
  176. package/{dist/upload → upload}/files-upload/FilesToUpload.js +12 -26
  177. package/upload/index.d.ts +15 -0
  178. package/upload/transaction/Icons.js +160 -0
  179. package/upload/transaction/Transaction.js +104 -0
  180. package/upload/transactions/Transactions.js +94 -0
  181. package/{dist/useTheme.js → useTheme.js} +0 -0
  182. package/wizard/Icons.js +65 -0
  183. package/{dist/wizard → wizard}/Wizard.js +32 -172
  184. package/wizard/index.d.ts +18 -0
  185. package/README.md +0 -66
  186. package/babel.config.js +0 -8
  187. package/dist/BackgroundColorContext.js +0 -46
  188. package/dist/ThemeContext.js +0 -240
  189. package/dist/accordion-group/AccordionGroup.js +0 -186
  190. package/dist/badge/Badge.js +0 -63
  191. package/dist/checkbox/Checkbox.stories.js +0 -144
  192. package/dist/checkbox/readme.md +0 -116
  193. package/dist/date/Date.stories.js +0 -205
  194. package/dist/date/readme.md +0 -73
  195. package/dist/footer/Footer.js +0 -395
  196. package/dist/footer/Footer.stories.js +0 -94
  197. package/dist/footer/dxc_logo.svg +0 -15
  198. package/dist/footer/readme.md +0 -41
  199. package/dist/header/Header.js +0 -403
  200. package/dist/header/Header.stories.js +0 -176
  201. package/dist/header/close_icon.svg +0 -1
  202. package/dist/header/dxc_logo_black.svg +0 -8
  203. package/dist/header/hamb_menu_black.svg +0 -1
  204. package/dist/header/hamb_menu_white.svg +0 -1
  205. package/dist/header/readme.md +0 -33
  206. package/dist/input-text/InputText.stories.js +0 -209
  207. package/dist/input-text/error.svg +0 -1
  208. package/dist/input-text/readme.md +0 -91
  209. package/dist/layout/facebook.svg +0 -45
  210. package/dist/layout/linkedin.svg +0 -50
  211. package/dist/layout/twitter.svg +0 -53
  212. package/dist/link/readme.md +0 -51
  213. package/dist/new-input-text/NewInputText.js +0 -961
  214. package/dist/paginator/Paginator.js +0 -289
  215. package/dist/paginator/images/next.svg +0 -3
  216. package/dist/paginator/images/nextPage.svg +0 -3
  217. package/dist/paginator/images/previous.svg +0 -3
  218. package/dist/paginator/images/previousPage.svg +0 -3
  219. package/dist/paginator/readme.md +0 -50
  220. package/dist/password/styles.css +0 -3
  221. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  222. package/dist/progress-bar/readme.md +0 -63
  223. package/dist/radio/Radio.stories.js +0 -166
  224. package/dist/radio/readme.md +0 -70
  225. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  226. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  227. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  228. package/dist/select/Select.stories.js +0 -235
  229. package/dist/select/readme.md +0 -72
  230. package/dist/slider/Slider.js +0 -319
  231. package/dist/slider/Slider.stories.js +0 -241
  232. package/dist/slider/readme.md +0 -64
  233. package/dist/spinner/Spinner.js +0 -218
  234. package/dist/spinner/Spinner.stories.js +0 -183
  235. package/dist/spinner/readme.md +0 -65
  236. package/dist/switch/Switch.stories.js +0 -134
  237. package/dist/switch/readme.md +0 -133
  238. package/dist/tabs/Tabs.js +0 -343
  239. package/dist/tabs/Tabs.stories.js +0 -130
  240. package/dist/tabs/readme.md +0 -78
  241. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  242. package/dist/tabs-for-sections/readme.md +0 -78
  243. package/dist/tag/Tag.js +0 -288
  244. package/dist/toggle/Toggle.stories.js +0 -297
  245. package/dist/toggle/readme.md +0 -80
  246. package/dist/toggle-group/ToggleGroup.js +0 -223
  247. package/dist/upload/Upload.stories.js +0 -72
  248. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -139
  249. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  250. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  251. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  252. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  253. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  254. package/dist/upload/file-upload/FileToUpload.js +0 -184
  255. package/dist/upload/file-upload/audio-icon.svg +0 -4
  256. package/dist/upload/file-upload/close.svg +0 -4
  257. package/dist/upload/file-upload/file-icon.svg +0 -4
  258. package/dist/upload/file-upload/video-icon.svg +0 -4
  259. package/dist/upload/readme.md +0 -37
  260. package/dist/upload/transaction/Transaction.js +0 -175
  261. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  262. package/dist/upload/transaction/audio-icon.svg +0 -4
  263. package/dist/upload/transaction/error-icon.svg +0 -4
  264. package/dist/upload/transaction/file-icon-err.svg +0 -4
  265. package/dist/upload/transaction/file-icon.svg +0 -4
  266. package/dist/upload/transaction/image-icon-err.svg +0 -4
  267. package/dist/upload/transaction/image-icon.svg +0 -4
  268. package/dist/upload/transaction/success-icon.svg +0 -4
  269. package/dist/upload/transaction/video-icon-err.svg +0 -4
  270. package/dist/upload/transaction/video-icon.svg +0 -4
  271. package/dist/upload/transactions/Transactions.js +0 -138
  272. package/dist/wizard/invalid_icon.svg +0 -5
  273. package/dist/wizard/valid_icon.svg +0 -5
  274. package/dist/wizard/validation-wrong.svg +0 -6
  275. package/test/Accordion.test.js +0 -33
  276. package/test/AccordionGroup.test.js +0 -125
  277. package/test/Alert.test.js +0 -53
  278. package/test/Box.test.js +0 -10
  279. package/test/Button.test.js +0 -18
  280. package/test/Card.test.js +0 -30
  281. package/test/Checkbox.test.js +0 -45
  282. package/test/Chip.test.js +0 -25
  283. package/test/Date.test.js +0 -393
  284. package/test/Dialog.test.js +0 -23
  285. package/test/Dropdown.test.js +0 -145
  286. package/test/Footer.test.js +0 -99
  287. package/test/Header.test.js +0 -39
  288. package/test/Heading.test.js +0 -35
  289. package/test/InputText.test.js +0 -240
  290. package/test/Link.test.js +0 -43
  291. package/test/NewDate.test.js +0 -203
  292. package/test/NewInputText.test.js +0 -817
  293. package/test/NewTextarea.test.js +0 -201
  294. package/test/Number.test.js +0 -241
  295. package/test/Paginator.test.js +0 -177
  296. package/test/Password.test.js +0 -76
  297. package/test/ProgressBar.test.js +0 -35
  298. package/test/Radio.test.js +0 -37
  299. package/test/ResultsetTable.test.js +0 -330
  300. package/test/Select.test.js +0 -189
  301. package/test/Sidenav.test.js +0 -45
  302. package/test/Slider.test.js +0 -82
  303. package/test/Spinner.test.js +0 -27
  304. package/test/Switch.test.js +0 -45
  305. package/test/Table.test.js +0 -36
  306. package/test/Tabs.test.js +0 -109
  307. package/test/TabsForSections.test.js +0 -34
  308. package/test/Tag.test.js +0 -32
  309. package/test/TextArea.test.js +0 -52
  310. package/test/ToggleGroup.test.js +0 -81
  311. package/test/Upload.test.js +0 -60
  312. package/test/Wizard.test.js +0 -130
  313. package/test/mocks/pngMock.js +0 -1
  314. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,138 @@
1
+ import React from "react";
2
+ import { userEvent, within, fireEvent, screen } from "@storybook/testing-library";
3
+ import DxcDateInput from "./DateInput";
4
+ import Title from "../../.storybook/components/Title";
5
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
+ import { BackgroundColorProvider } from "../BackgroundColorContext";
7
+ import DarkContainer from "../../.storybook/components/DarkSection";
8
+
9
+ export default {
10
+ title: "Date input",
11
+ component: DxcDateInput,
12
+ };
13
+
14
+ export const Chromatic = () => (
15
+ <>
16
+ <ExampleContainer>
17
+ <Title title="Complete date input" theme="light" level={4} />
18
+ <DxcDateInput label="Date input" helperText="Help message" format="dd/mm/yy" placeholder optional />
19
+ </ExampleContainer>
20
+ <ExampleContainer>
21
+ <Title title="Disabled" theme="light" level={4} />
22
+ <DxcDateInput label="Disabled date input" helperText="Help message" value="06-04-2027" clearable disabled />
23
+ </ExampleContainer>
24
+ <ExampleContainer>
25
+ <Title title="Invalid" theme="light" level={4} />
26
+ <DxcDateInput label="Error date input" error="Error message." placeholder />
27
+ </ExampleContainer>
28
+ <ExampleContainer>
29
+ <Title title="Relation between icons" theme="light" level={4} />
30
+ <DxcDateInput label="Error date input" error="Error message." value="06-04-2027" clearable />
31
+ </ExampleContainer>
32
+ <BackgroundColorProvider color="#333333">
33
+ <DarkContainer>
34
+ <Title title="Dark" theme="dark" level={2} />
35
+ <ExampleContainer>
36
+ <Title title="Complete date input" theme="dark" level={4} />
37
+ <DxcDateInput label="Date input" helperText="Help message" format="yyyy/dd/mm" placeholder optional />
38
+ </ExampleContainer>
39
+ <ExampleContainer>
40
+ <Title title="Disabled" theme="dark" level={4} />
41
+ <DxcDateInput label="Disabled Date input" helperText="Help message" value="06-04-2027" clearable disabled />
42
+ </ExampleContainer>
43
+ <ExampleContainer>
44
+ <Title title="Invalid" theme="dark" level={4} />
45
+ <DxcDateInput label="Error date input" error="Error message." placeholder />
46
+ </ExampleContainer>
47
+ <ExampleContainer>
48
+ <Title title="Relation between icons" theme="dark" level={4} />
49
+ <DxcDateInput label="Error date input" value="06-04-2027" error="Error message." clearable />
50
+ </ExampleContainer>
51
+ </DarkContainer>
52
+ </BackgroundColorProvider>
53
+ <Title title="Margins" theme="light" level={2} />
54
+ <ExampleContainer>
55
+ <Title title="Xxsmall" theme="light" level={4} />
56
+ <DxcDateInput label="Xxsmall" margin="xxsmall" />
57
+ </ExampleContainer>
58
+ <ExampleContainer>
59
+ <Title title="Xsmall" theme="light" level={4} />
60
+ <DxcDateInput label="Xsmall" margin="xsmall" />
61
+ </ExampleContainer>
62
+ <ExampleContainer>
63
+ <Title title="Small" theme="light" level={4} />
64
+ <DxcDateInput label="Small" margin="small" />
65
+ </ExampleContainer>
66
+ <ExampleContainer>
67
+ <Title title="Medium" theme="light" level={4} />
68
+ <DxcDateInput label="Medium" margin="medium" />
69
+ </ExampleContainer>
70
+ <ExampleContainer>
71
+ <Title title="Large" theme="light" level={4} />
72
+ <DxcDateInput label="Large" margin="large" />
73
+ </ExampleContainer>
74
+ <ExampleContainer>
75
+ <Title title="Xlarge" theme="light" level={4} />
76
+ <DxcDateInput label="Xlarge" margin="xlarge" />
77
+ </ExampleContainer>
78
+ <ExampleContainer>
79
+ <Title title="Xxlarge" theme="light" level={4} />
80
+ <DxcDateInput label="Xxlarge" margin="xxlarge" />
81
+ </ExampleContainer>
82
+ <Title title="Sizes" theme="light" level={2} />
83
+ <ExampleContainer>
84
+ <Title title="Medium size" theme="light" level={4} />
85
+ <DxcDateInput label="Medium" size="medium" />
86
+ </ExampleContainer>
87
+ <ExampleContainer>
88
+ <Title title="Large size" theme="light" level={4} />
89
+ <DxcDateInput label="Large" size="large" />
90
+ </ExampleContainer>
91
+ <ExampleContainer>
92
+ <Title title="FillParent size" theme="light" level={4} />
93
+ <DxcDateInput label="FillParent" size="fillParent" />
94
+ </ExampleContainer>
95
+ </>
96
+ );
97
+
98
+ const DatePicker = () => (
99
+ <ExampleContainer expanded>
100
+ <Title title="Show date input" theme="light" level={4} />
101
+ <DxcDateInput label="Date input" value="10-06-2023" />
102
+ </ExampleContainer>
103
+ );
104
+
105
+ export const ShowDatePicker = DatePicker.bind({});
106
+ ShowDatePicker.play = async ({ canvasElement }) => {
107
+ const canvas = within(canvasElement);
108
+ const dateBtn = canvas.getByRole("button");
109
+ await userEvent.click(dateBtn);
110
+ await userEvent.tab();
111
+ };
112
+
113
+ const YearPicker = () => (
114
+ <ExampleContainer expanded>
115
+ <Title title="Show date input" theme="light" level={4} />
116
+ <DxcDateInput label="Date input" value="10-06-2023" />
117
+ </ExampleContainer>
118
+ );
119
+
120
+ export const ShowYearPicker = YearPicker.bind({});
121
+ ShowYearPicker.play = async () => {
122
+ await fireEvent.click(screen.getByRole("button"));
123
+ await fireEvent.click(screen.getByText("2023"));
124
+ };
125
+
126
+ const YearPickerFocus = () => (
127
+ <ExampleContainer expanded>
128
+ <Title title="Show date input" theme="light" level={4} />
129
+ <DxcDateInput label="Date input" value="10-06-2023" />
130
+ </ExampleContainer>
131
+ );
132
+
133
+ export const ShowYearPickerFocus = YearPickerFocus.bind({});
134
+ ShowYearPickerFocus.play = async () => {
135
+ await fireEvent.click(screen.getByRole("button"));
136
+ await fireEvent.click(screen.getByText("2023"));
137
+ await screen.getByText("2021").focus();
138
+ };
@@ -0,0 +1,100 @@
1
+ declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
+ declare type Margin = {
3
+ top?: Space;
4
+ bottom?: Space;
5
+ left?: Space;
6
+ right?: Space;
7
+ };
8
+ declare type Props = {
9
+ /**
10
+ * Text to be placed above the date.
11
+ */
12
+ label?: string;
13
+ /**
14
+ * Name attribute of the input element.
15
+ */
16
+ name?: string;
17
+ /**
18
+ * Value of the input element. If undefined, the component will be uncontrolled and the value will be managed internally by the component.
19
+ */
20
+ value?: string;
21
+ /**
22
+ * The format in which the date value will be displayed. User must use this format when editing the value or it will be considered as an invalid date.
23
+ */
24
+ format?: string;
25
+ /**
26
+ * Helper text to be placed above the date.
27
+ */
28
+ helperText?: string;
29
+ /**
30
+ * If true, the date format will appear as placeholder in the field.
31
+ */
32
+ placeholder?: boolean;
33
+ /**
34
+ * If true, the date input will have an action to clear the entered value.
35
+ */
36
+ clearable?: boolean;
37
+ /**
38
+ * If true, the component will be disabled.
39
+ */
40
+ disabled?: boolean;
41
+ /**
42
+ * If true, the date will be optional, showing '(Optional)'
43
+ * next to the label. Otherwise, the field will be considered required and an error will be
44
+ * passed as a parameter to the OnBlur and onChange functions when it has
45
+ * not been filled.
46
+ */
47
+ optional?: boolean;
48
+ /**
49
+ * This function will be called when the user types within the input
50
+ * element of the component. An object including the string value, the
51
+ * error and the date value will be passed to this function.
52
+ * If the string value is a valid date, error will
53
+ * be null. Also, if the string value is not a valid date, date will be null.
54
+ */
55
+ onChange?: (val: {
56
+ value: string;
57
+ error: string | null;
58
+ date: Date | null;
59
+ }) => void;
60
+ /**
61
+ * This function will be called when the input element loses the focus.
62
+ * An object including the string value, the error and the date value
63
+ * will be passed to this function. If the string value is a valid date, error will
64
+ * be null. Also, if the string value is not a valid date, date will be null.
65
+ */
66
+ onBlur?: (val: {
67
+ value: string;
68
+ error: string | null;
69
+ date: Date | null;
70
+ }) => void;
71
+ /**
72
+ * If it is defined, the component will change its appearance, showing
73
+ * the error below the date input component. If it is not defined, the error
74
+ * messages will be managed internally, but never displayed on its own.
75
+ */
76
+ error?: string;
77
+ /**
78
+ * HTML autocomplete attribute. Lets the user specify if any permission the user agent has to provide automated assistance in filling out the input value.
79
+ * Its value must be one of all the possible values of the HTML autocomplete attribute: 'on', 'off', 'email', 'username', 'new-password', ...
80
+ */
81
+ autocomplete?: string;
82
+ /**
83
+ * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
84
+ * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
85
+ */
86
+ margin?: Space | Margin;
87
+ /**
88
+ * Size of the component.
89
+ */
90
+ size?: "medium" | "large" | "fillParent";
91
+ /**
92
+ * Value of the tabindex attribute.
93
+ */
94
+ tabIndex?: number;
95
+ };
96
+ /**
97
+ * Reference to the component.
98
+ */
99
+ export declare type RefType = HTMLDivElement;
100
+ export default Props;
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import DialogPropsType from "./types";
3
+ declare const DxcDialog: ({ isCloseVisible, onCloseClick, children, overlay, onBackgroundClick, padding, tabIndex, }: DialogPropsType) => JSX.Element;
4
+ export default DxcDialog;
@@ -1,16 +1,14 @@
1
1
  "use strict";
2
2
 
3
- var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
-
5
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
4
 
5
+ var _typeof3 = require("@babel/runtime/helpers/typeof");
6
+
7
7
  Object.defineProperty(exports, "__esModule", {
8
8
  value: true
9
9
  });
10
10
  exports["default"] = void 0;
11
11
 
12
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
13
-
14
12
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
15
13
 
16
14
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
@@ -23,53 +21,17 @@ var _styledComponents = _interopRequireWildcard(require("styled-components"));
23
21
 
24
22
  var _Dialog = _interopRequireDefault(require("@material-ui/core/Dialog"));
25
23
 
26
- var _propTypes = _interopRequireDefault(require("prop-types"));
27
-
28
24
  var _variables = require("../common/variables.js");
29
25
 
30
26
  var _useTheme = _interopRequireDefault(require("../useTheme.js"));
31
27
 
32
28
  var _BackgroundColorContext = require("../BackgroundColorContext.js");
33
29
 
34
- function _templateObject4() {
35
- var data = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n width: ", ";\n height: ", ";\n border-radius: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n"]);
36
-
37
- _templateObject4 = function _templateObject4() {
38
- return data;
39
- };
40
-
41
- return data;
42
- }
43
-
44
- function _templateObject3() {
45
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: flex-end;\n position: absolute;\n top: ", ";\n right: ", ";\n cursor: pointer;\n padding: 0;\n margin: 0;\n background: none;\n color: ", ";\n width: ", ";\n height: ", ";\n border: none;\n"]);
46
-
47
- _templateObject3 = function _templateObject3() {
48
- return data;
49
- };
50
-
51
- return data;
52
- }
53
-
54
- function _templateObject2() {
55
- var data = (0, _taggedTemplateLiteral2["default"])([""]);
56
-
57
- _templateObject2 = function _templateObject2() {
58
- return data;
59
- };
30
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4;
60
31
 
61
- return data;
62
- }
32
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
63
33
 
64
- function _templateObject() {
65
- var data = (0, _taggedTemplateLiteral2["default"])(["\n overflow: unset;\n font-family: ", ";\n\n .MuiBackdrop-root {\n background-color: ", ";\n opacity: ", " !important;\n }\n .MuiDialog-paperWidthSm {\n background-color: ", ";\n max-width: ", ";\n min-width: ", ";\n box-sizing: border-box;\n min-height: ", ";\n box-shadow: ", ";\n\n padding: ", ";\n padding-top: ", ";\n padding-right: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n }\n"]);
66
-
67
- _templateObject = function _templateObject() {
68
- return data;
69
- };
70
-
71
- return data;
72
- }
34
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(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; }
73
35
 
74
36
  var DxcDialog = function DxcDialog(_ref) {
75
37
  var _ref$isCloseVisible = _ref.isCloseVisible,
@@ -83,7 +45,7 @@ var DxcDialog = function DxcDialog(_ref) {
83
45
  _ref$tabIndex = _ref.tabIndex,
84
46
  tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
85
47
 
86
- var _useState = (0, _react.useState)(),
48
+ var _useState = (0, _react.useState)(false),
87
49
  _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
88
50
  isResponsive = _useState2[0],
89
51
  setIsResponsive = _useState2[1];
@@ -91,15 +53,15 @@ var DxcDialog = function DxcDialog(_ref) {
91
53
  var colorsTheme = (0, _useTheme["default"])();
92
54
 
93
55
  var handleClose = function handleClose() {
94
- typeof onCloseClick === "function" && onCloseClick();
56
+ onCloseClick === null || onCloseClick === void 0 ? void 0 : onCloseClick();
95
57
  };
96
58
 
97
59
  var handleOverlayClick = function handleOverlayClick() {
98
- typeof onBackgroundClick === "function" && onBackgroundClick();
60
+ onBackgroundClick === null || onBackgroundClick === void 0 ? void 0 : onBackgroundClick();
99
61
  };
100
62
 
101
63
  var handleResize = function handleResize(width) {
102
- width && width <= _variables.responsiveSizes.tablet ? setIsResponsive(true) : setIsResponsive(false);
64
+ setIsResponsive(width && width <= _variables.responsiveSizes.tablet);
103
65
  };
104
66
 
105
67
  var handleEventListener = function handleEventListener() {
@@ -113,35 +75,35 @@ var DxcDialog = function DxcDialog(_ref) {
113
75
  window.removeEventListener("resize", handleEventListener);
114
76
  };
115
77
  }, []);
116
- return _react["default"].createElement(_styledComponents.ThemeProvider, {
78
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
117
79
  theme: colorsTheme.dialog
118
- }, _react["default"].createElement(DialogContainer, {
80
+ }, /*#__PURE__*/_react["default"].createElement(DialogContainer, {
119
81
  open: true,
120
82
  isCloseVisible: isCloseVisible,
121
83
  onClose: handleOverlayClick,
122
84
  overlay: overlay,
123
85
  padding: padding,
124
86
  isResponsive: isResponsive
125
- }, isCloseVisible && _react["default"].createElement(CloseIconContainer, {
87
+ }, isCloseVisible && /*#__PURE__*/_react["default"].createElement(CloseIconContainer, {
126
88
  onClick: handleClose,
127
89
  tabIndex: tabIndex
128
- }, _react["default"].createElement(CloseIcon, {
90
+ }, /*#__PURE__*/_react["default"].createElement(CloseIcon, {
129
91
  xmlns: "http://www.w3.org/2000/svg",
130
92
  width: "24",
131
93
  height: "24",
132
94
  viewBox: "0 0 24 24",
133
95
  fill: "currentColor"
134
- }, _react["default"].createElement("path", {
96
+ }, /*#__PURE__*/_react["default"].createElement("path", {
135
97
  d: "M0 0h24v24H0V0z",
136
98
  fill: "none"
137
- }), _react["default"].createElement("path", {
99
+ }), /*#__PURE__*/_react["default"].createElement("path", {
138
100
  d: "M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41z"
139
- }))), _react["default"].createElement(Children, null, _react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
101
+ }))), /*#__PURE__*/_react["default"].createElement(Children, null, /*#__PURE__*/_react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
140
102
  color: colorsTheme.dialog.backgroundColor
141
103
  }, children))));
142
104
  };
143
105
 
144
- var DialogContainer = (0, _styledComponents["default"])(_Dialog["default"])(_templateObject(), function (props) {
106
+ var DialogContainer = (0, _styledComponents["default"])(_Dialog["default"])(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n overflow: unset;\n font-family: ", ";\n\n .MuiBackdrop-root {\n background-color: ", ";\n opacity: ", " !important;\n }\n .MuiDialog-paperWidthSm {\n background-color: ", ";\n max-width: ", ";\n min-width: ", ";\n box-sizing: border-box;\n min-height: ", ";\n box-shadow: ", ";\n\n padding: ", ";\n padding-top: ", ";\n padding-right: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n }\n"])), function (props) {
145
107
  return props.theme.fontFamily;
146
108
  }, function (props) {
147
109
  return props.overlay === true ? props.theme.overlayColor : "transparent";
@@ -169,9 +131,9 @@ var DialogContainer = (0, _styledComponents["default"])(_Dialog["default"])(_tem
169
131
  return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.left ? _variables.spaces[props.padding.left] : "";
170
132
  });
171
133
 
172
- var Children = _styledComponents["default"].div(_templateObject2());
134
+ var Children = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])([""])));
173
135
 
174
- var CloseIconContainer = _styledComponents["default"].button(_templateObject3(), function (props) {
136
+ var CloseIconContainer = _styledComponents["default"].button(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: flex-end;\n position: absolute;\n top: ", ";\n right: ", ";\n cursor: pointer;\n padding: 0;\n margin: 0;\n background: none;\n color: ", ";\n width: ", ";\n height: ", ";\n border: none;\n"])), function (props) {
175
137
  return props.theme.closeIconTopPosition;
176
138
  }, function (props) {
177
139
  return props.theme.closeIconRightPosition;
@@ -183,7 +145,7 @@ var CloseIconContainer = _styledComponents["default"].button(_templateObject3(),
183
145
  return props.theme.closeIconHeight;
184
146
  });
185
147
 
186
- var CloseIcon = _styledComponents["default"].svg(_templateObject4(), function (props) {
148
+ var CloseIcon = _styledComponents["default"].svg(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n width: ", ";\n height: ", ";\n border-radius: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n"])), function (props) {
187
149
  return props.theme.closeIconBackgroundColor;
188
150
  }, function (props) {
189
151
  return props.theme.closeIconWidth;
@@ -199,20 +161,5 @@ var CloseIcon = _styledComponents["default"].svg(_templateObject4(), function (p
199
161
  return props.theme.closeIconBorderColor;
200
162
  });
201
163
 
202
- DxcDialog.propTypes = {
203
- padding: _propTypes["default"].oneOfType([_propTypes["default"].shape({
204
- top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
205
- bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
206
- left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
207
- right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
208
- }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))]),
209
- isVisible: _propTypes["default"].bool,
210
- isCloseVisible: _propTypes["default"].bool,
211
- onClose: _propTypes["default"].func,
212
- onCloseClick: _propTypes["default"].func,
213
- onBackgroundClick: _propTypes["default"].func,
214
- overlay: _propTypes["default"].bool,
215
- tabIndex: _propTypes["default"].number
216
- };
217
164
  var _default = DxcDialog;
218
165
  exports["default"] = _default;
@@ -0,0 +1,43 @@
1
+ /// <reference types="react" />
2
+ declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ declare type Padding = {
4
+ top?: Space;
5
+ bottom?: Space;
6
+ left?: Space;
7
+ right?: Space;
8
+ };
9
+ declare type Props = {
10
+ /**
11
+ * If true, the close 'x' button will be visible.
12
+ */
13
+ isCloseVisible?: boolean;
14
+ /**
15
+ * This function will be called when the user clicks the close 'x' button.
16
+ * The responsibility of hiding the modal lies with the user.
17
+ */
18
+ onCloseClick?: () => void;
19
+ /**
20
+ * If true, the dialog will be displayed over a darker background that covers the content behind.
21
+ */
22
+ overlay?: boolean;
23
+ /**
24
+ * This function will be called when the user clicks background of the modal.
25
+ * The responsibility of hiding the modal lies with the user.
26
+ */
27
+ onBackgroundClick?: () => void;
28
+ /**
29
+ * Size of the padding to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
30
+ * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different padding sizes.
31
+ */
32
+ padding?: Padding | Space;
33
+ /**
34
+ * Value of the tabindex given to the close 'x' button.
35
+ */
36
+ tabIndex?: number;
37
+ /**
38
+ * The area inside the dialog. This area can be used to render
39
+ * custom content.
40
+ */
41
+ children: React.ReactNode;
42
+ };
43
+ export default Props;
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import DropdownPropsType from "./types";
3
+ declare const DxcDropdown: ({ options, optionsIconPosition, icon, iconSrc, iconPosition, label, caretHidden, onSelectOption, expandOnHover, margin, size, tabIndex, disabled, }: DropdownPropsType) => JSX.Element;
4
+ export default DxcDropdown;