@dxc-technology/halstack-react 0.0.0-ba408d4 → 0.0.0-bb8df10

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 (351) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +1 -4
  3. package/HalstackContext.d.ts +12 -0
  4. package/HalstackContext.js +295 -0
  5. package/accordion/Accordion.d.ts +4 -0
  6. package/accordion/Accordion.js +18 -81
  7. package/accordion/Accordion.stories.tsx +307 -0
  8. package/accordion/Accordion.test.js +72 -0
  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 +61 -76
  13. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  14. package/accordion-group/AccordionGroup.test.js +151 -0
  15. package/accordion-group/types.d.ts +72 -0
  16. package/accordion-group/types.js +5 -0
  17. package/alert/Alert.d.ts +4 -0
  18. package/alert/Alert.js +7 -23
  19. package/alert/Alert.stories.tsx +170 -0
  20. package/alert/Alert.test.js +92 -0
  21. package/alert/types.d.ts +49 -0
  22. package/alert/types.js +5 -0
  23. package/badge/Badge.d.ts +4 -0
  24. package/badge/Badge.js +6 -4
  25. package/badge/types.d.ts +5 -0
  26. package/badge/types.js +5 -0
  27. package/bleed/Bleed.d.ts +3 -0
  28. package/bleed/Bleed.js +51 -0
  29. package/bleed/Bleed.stories.tsx +341 -0
  30. package/bleed/types.d.ts +37 -0
  31. package/bleed/types.js +5 -0
  32. package/box/Box.d.ts +4 -0
  33. package/box/Box.js +28 -64
  34. package/box/Box.stories.tsx +132 -0
  35. package/box/Box.test.js +18 -0
  36. package/box/types.d.ts +43 -0
  37. package/box/types.js +5 -0
  38. package/bulleted-list/BulletedList.d.ts +7 -0
  39. package/bulleted-list/BulletedList.js +123 -0
  40. package/bulleted-list/BulletedList.stories.tsx +200 -0
  41. package/bulleted-list/types.d.ts +11 -0
  42. package/bulleted-list/types.js +5 -0
  43. package/button/Button.d.ts +1 -1
  44. package/button/Button.js +61 -87
  45. package/button/Button.stories.tsx +259 -282
  46. package/button/Button.test.js +35 -0
  47. package/button/types.d.ts +14 -18
  48. package/card/Card.d.ts +4 -0
  49. package/card/Card.js +38 -77
  50. package/card/Card.stories.tsx +201 -0
  51. package/card/Card.test.js +50 -0
  52. package/card/ice-cream.jpg +0 -0
  53. package/card/types.d.ts +67 -0
  54. package/card/types.js +5 -0
  55. package/checkbox/Checkbox.d.ts +4 -0
  56. package/checkbox/Checkbox.js +45 -63
  57. package/checkbox/Checkbox.stories.tsx +188 -0
  58. package/checkbox/Checkbox.test.js +78 -0
  59. package/checkbox/types.d.ts +64 -0
  60. package/checkbox/types.js +5 -0
  61. package/chip/Chip.d.ts +4 -0
  62. package/chip/Chip.js +16 -76
  63. package/chip/Chip.stories.tsx +119 -0
  64. package/chip/Chip.test.js +56 -0
  65. package/chip/types.d.ts +45 -0
  66. package/chip/types.js +5 -0
  67. package/common/variables.js +316 -377
  68. package/date-input/DateInput.d.ts +4 -0
  69. package/date-input/DateInput.js +65 -89
  70. package/date-input/DateInput.stories.tsx +138 -0
  71. package/date-input/DateInput.test.js +479 -0
  72. package/date-input/types.d.ts +107 -0
  73. package/date-input/types.js +5 -0
  74. package/dialog/Dialog.d.ts +4 -0
  75. package/dialog/Dialog.js +52 -74
  76. package/dialog/Dialog.stories.tsx +211 -0
  77. package/dialog/Dialog.test.js +70 -0
  78. package/dialog/types.d.ts +43 -0
  79. package/dialog/types.js +5 -0
  80. package/dropdown/Dropdown.d.ts +4 -0
  81. package/dropdown/Dropdown.js +239 -302
  82. package/dropdown/Dropdown.stories.tsx +312 -0
  83. package/dropdown/Dropdown.test.js +591 -0
  84. package/dropdown/DropdownMenu.d.ts +4 -0
  85. package/dropdown/DropdownMenu.js +80 -0
  86. package/dropdown/DropdownMenuItem.d.ts +4 -0
  87. package/dropdown/DropdownMenuItem.js +92 -0
  88. package/dropdown/types.d.ts +100 -0
  89. package/dropdown/types.js +5 -0
  90. package/file-input/FileInput.d.ts +4 -0
  91. package/file-input/FileInput.js +172 -111
  92. package/file-input/FileInput.stories.tsx +507 -0
  93. package/file-input/FileInput.test.js +457 -0
  94. package/file-input/FileItem.d.ts +14 -0
  95. package/file-input/FileItem.js +16 -23
  96. package/file-input/types.d.ts +112 -0
  97. package/file-input/types.js +5 -0
  98. package/flex/Flex.d.ts +4 -0
  99. package/flex/Flex.js +57 -0
  100. package/flex/Flex.stories.tsx +103 -0
  101. package/flex/types.d.ts +21 -0
  102. package/flex/types.js +5 -0
  103. package/footer/Footer.d.ts +4 -0
  104. package/footer/Footer.js +36 -148
  105. package/footer/Footer.stories.tsx +130 -0
  106. package/footer/Footer.test.js +109 -0
  107. package/footer/Icons.d.ts +2 -0
  108. package/footer/Icons.js +4 -4
  109. package/footer/types.d.ts +65 -0
  110. package/footer/types.js +5 -0
  111. package/header/Header.d.ts +7 -0
  112. package/header/Header.js +119 -140
  113. package/header/Header.stories.tsx +172 -0
  114. package/header/Header.test.js +79 -0
  115. package/header/Icons.d.ts +2 -0
  116. package/header/Icons.js +4 -29
  117. package/header/types.d.ts +47 -0
  118. package/header/types.js +5 -0
  119. package/heading/Heading.d.ts +4 -0
  120. package/heading/Heading.js +7 -24
  121. package/heading/Heading.stories.tsx +54 -0
  122. package/heading/Heading.test.js +186 -0
  123. package/heading/types.d.ts +33 -0
  124. package/heading/types.js +5 -0
  125. package/inset/Inset.d.ts +3 -0
  126. package/inset/Inset.js +51 -0
  127. package/inset/Inset.stories.tsx +229 -0
  128. package/inset/types.d.ts +37 -0
  129. package/inset/types.js +5 -0
  130. package/layout/ApplicationLayout.d.ts +20 -0
  131. package/layout/ApplicationLayout.js +71 -135
  132. package/layout/ApplicationLayout.stories.tsx +161 -0
  133. package/layout/Icons.d.ts +5 -0
  134. package/layout/Icons.js +13 -2
  135. package/layout/SidenavContext.d.ts +5 -0
  136. package/layout/SidenavContext.js +19 -0
  137. package/layout/types.d.ts +42 -0
  138. package/layout/types.js +5 -0
  139. package/link/Link.d.ts +4 -0
  140. package/link/Link.js +60 -107
  141. package/link/Link.stories.tsx +193 -0
  142. package/link/Link.test.js +83 -0
  143. package/link/types.d.ts +54 -0
  144. package/link/types.js +5 -0
  145. package/main.d.ts +12 -12
  146. package/main.js +64 -58
  147. package/number-input/NumberInput.d.ts +4 -0
  148. package/number-input/NumberInput.js +16 -68
  149. package/number-input/NumberInput.stories.tsx +115 -0
  150. package/number-input/NumberInput.test.js +506 -0
  151. package/number-input/NumberInputContext.d.ts +4 -0
  152. package/number-input/NumberInputContext.js +5 -2
  153. package/number-input/numberInputContextTypes.d.ts +19 -0
  154. package/number-input/numberInputContextTypes.js +5 -0
  155. package/number-input/types.d.ts +124 -0
  156. package/number-input/types.js +5 -0
  157. package/package.json +17 -13
  158. package/paginator/Paginator.js +19 -46
  159. package/paginator/Paginator.stories.tsx +63 -0
  160. package/paginator/Paginator.test.js +308 -0
  161. package/paragraph/Paragraph.d.ts +6 -0
  162. package/paragraph/Paragraph.js +38 -0
  163. package/paragraph/Paragraph.stories.tsx +44 -0
  164. package/password-input/PasswordInput.d.ts +4 -0
  165. package/password-input/PasswordInput.js +24 -57
  166. package/password-input/PasswordInput.stories.tsx +131 -0
  167. package/password-input/PasswordInput.test.js +180 -0
  168. package/password-input/types.d.ts +110 -0
  169. package/password-input/types.js +5 -0
  170. package/progress-bar/ProgressBar.d.ts +4 -0
  171. package/progress-bar/ProgressBar.js +60 -72
  172. package/progress-bar/ProgressBar.stories.jsx +60 -0
  173. package/progress-bar/ProgressBar.test.js +110 -0
  174. package/progress-bar/types.d.ts +36 -0
  175. package/progress-bar/types.js +5 -0
  176. package/quick-nav/QuickNav.d.ts +4 -0
  177. package/quick-nav/QuickNav.js +118 -0
  178. package/quick-nav/QuickNav.stories.tsx +264 -0
  179. package/quick-nav/types.d.ts +21 -0
  180. package/quick-nav/types.js +5 -0
  181. package/radio-group/Radio.d.ts +4 -0
  182. package/radio-group/Radio.js +141 -0
  183. package/radio-group/RadioGroup.d.ts +4 -0
  184. package/radio-group/RadioGroup.js +281 -0
  185. package/radio-group/RadioGroup.stories.tsx +100 -0
  186. package/radio-group/RadioGroup.test.js +695 -0
  187. package/radio-group/types.d.ts +114 -0
  188. package/radio-group/types.js +5 -0
  189. package/resultsetTable/ResultsetTable.d.ts +4 -0
  190. package/resultsetTable/ResultsetTable.js +9 -29
  191. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  192. package/resultsetTable/ResultsetTable.test.js +348 -0
  193. package/resultsetTable/types.d.ts +67 -0
  194. package/resultsetTable/types.js +5 -0
  195. package/select/Icons.d.ts +10 -0
  196. package/select/Icons.js +93 -0
  197. package/select/Listbox.d.ts +4 -0
  198. package/select/Listbox.js +199 -0
  199. package/select/Option.d.ts +4 -0
  200. package/select/Option.js +110 -0
  201. package/select/Select.d.ts +4 -0
  202. package/select/Select.js +158 -380
  203. package/select/Select.stories.tsx +627 -0
  204. package/select/Select.test.js +2175 -0
  205. package/select/types.d.ts +210 -0
  206. package/select/types.js +5 -0
  207. package/sidenav/Sidenav.d.ts +10 -0
  208. package/sidenav/Sidenav.js +186 -63
  209. package/sidenav/Sidenav.stories.tsx +180 -0
  210. package/sidenav/Sidenav.test.js +44 -0
  211. package/sidenav/types.d.ts +73 -0
  212. package/sidenav/types.js +5 -0
  213. package/slider/Slider.d.ts +4 -0
  214. package/slider/Slider.js +147 -154
  215. package/slider/Slider.stories.tsx +183 -0
  216. package/slider/Slider.test.js +250 -0
  217. package/slider/types.d.ts +82 -0
  218. package/slider/types.js +5 -0
  219. package/spinner/Spinner.d.ts +4 -0
  220. package/spinner/Spinner.js +9 -26
  221. package/spinner/Spinner.stories.jsx +103 -0
  222. package/spinner/Spinner.test.js +64 -0
  223. package/spinner/types.d.ts +32 -0
  224. package/spinner/types.js +5 -0
  225. package/switch/Switch.d.ts +4 -0
  226. package/switch/Switch.js +129 -86
  227. package/switch/Switch.stories.tsx +138 -0
  228. package/switch/Switch.test.js +212 -0
  229. package/switch/types.d.ts +61 -0
  230. package/switch/types.js +5 -0
  231. package/table/Table.d.ts +4 -0
  232. package/table/Table.js +3 -3
  233. package/table/Table.stories.jsx +277 -0
  234. package/table/Table.test.js +26 -0
  235. package/table/types.d.ts +21 -0
  236. package/table/types.js +5 -0
  237. package/tabs/Tab.d.ts +4 -0
  238. package/tabs/Tab.js +135 -0
  239. package/tabs/Tabs.d.ts +4 -0
  240. package/tabs/Tabs.js +364 -156
  241. package/tabs/Tabs.stories.tsx +186 -0
  242. package/tabs/Tabs.test.js +351 -0
  243. package/tabs/types.d.ts +92 -0
  244. package/tabs/types.js +5 -0
  245. package/tabs-nav/NavTabs.d.ts +8 -0
  246. package/tabs-nav/NavTabs.js +125 -0
  247. package/tabs-nav/NavTabs.stories.tsx +170 -0
  248. package/tabs-nav/NavTabs.test.js +82 -0
  249. package/tabs-nav/Tab.d.ts +4 -0
  250. package/tabs-nav/Tab.js +130 -0
  251. package/tabs-nav/types.d.ts +53 -0
  252. package/tabs-nav/types.js +5 -0
  253. package/tag/Tag.d.ts +4 -0
  254. package/tag/Tag.js +34 -59
  255. package/tag/Tag.stories.tsx +142 -0
  256. package/tag/Tag.test.js +60 -0
  257. package/tag/types.d.ts +69 -0
  258. package/tag/types.js +5 -0
  259. package/text-input/Suggestion.d.ts +4 -0
  260. package/text-input/Suggestion.js +55 -0
  261. package/text-input/TextInput.d.ts +4 -0
  262. package/text-input/TextInput.js +103 -167
  263. package/text-input/TextInput.stories.tsx +473 -0
  264. package/text-input/TextInput.test.js +1712 -0
  265. package/text-input/types.d.ts +178 -0
  266. package/text-input/types.js +5 -0
  267. package/textarea/Textarea.d.ts +4 -0
  268. package/textarea/Textarea.js +39 -79
  269. package/textarea/Textarea.stories.jsx +157 -0
  270. package/textarea/Textarea.test.js +437 -0
  271. package/textarea/types.d.ts +137 -0
  272. package/textarea/types.js +5 -0
  273. package/toggle-group/ToggleGroup.d.ts +4 -0
  274. package/toggle-group/ToggleGroup.js +18 -46
  275. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  276. package/toggle-group/ToggleGroup.test.js +156 -0
  277. package/toggle-group/types.d.ts +105 -0
  278. package/toggle-group/types.js +5 -0
  279. package/typography/Typography.d.ts +4 -0
  280. package/typography/Typography.js +131 -0
  281. package/typography/Typography.stories.tsx +198 -0
  282. package/typography/types.d.ts +18 -0
  283. package/typography/types.js +5 -0
  284. package/useTheme.d.ts +2 -0
  285. package/useTheme.js +2 -2
  286. package/useTranslatedLabels.d.ts +2 -0
  287. package/useTranslatedLabels.js +20 -0
  288. package/wizard/Wizard.d.ts +4 -0
  289. package/wizard/Wizard.js +118 -104
  290. package/wizard/Wizard.stories.tsx +233 -0
  291. package/wizard/Wizard.test.js +141 -0
  292. package/wizard/types.d.ts +65 -0
  293. package/wizard/types.js +5 -0
  294. package/ThemeContext.js +0 -246
  295. package/V3Select/V3Select.js +0 -455
  296. package/V3Select/index.d.ts +0 -27
  297. package/V3Textarea/V3Textarea.js +0 -260
  298. package/V3Textarea/index.d.ts +0 -27
  299. package/accordion/index.d.ts +0 -28
  300. package/accordion-group/index.d.ts +0 -16
  301. package/alert/index.d.ts +0 -51
  302. package/box/index.d.ts +0 -25
  303. package/card/index.d.ts +0 -22
  304. package/checkbox/index.d.ts +0 -24
  305. package/chip/index.d.ts +0 -22
  306. package/date/Date.js +0 -373
  307. package/date/index.d.ts +0 -27
  308. package/date-input/index.d.ts +0 -95
  309. package/dialog/index.d.ts +0 -18
  310. package/dropdown/index.d.ts +0 -26
  311. package/file-input/index.d.ts +0 -81
  312. package/footer/index.d.ts +0 -25
  313. package/header/index.d.ts +0 -25
  314. package/heading/index.d.ts +0 -17
  315. package/input-text/Icons.js +0 -22
  316. package/input-text/InputText.js +0 -611
  317. package/input-text/index.d.ts +0 -36
  318. package/link/index.d.ts +0 -23
  319. package/number-input/index.d.ts +0 -113
  320. package/password-input/index.d.ts +0 -94
  321. package/progress-bar/index.d.ts +0 -18
  322. package/radio/Radio.js +0 -195
  323. package/radio/index.d.ts +0 -23
  324. package/resultsetTable/index.d.ts +0 -19
  325. package/select/index.d.ts +0 -131
  326. package/sidenav/index.d.ts +0 -13
  327. package/slider/index.d.ts +0 -29
  328. package/spinner/index.d.ts +0 -17
  329. package/switch/index.d.ts +0 -24
  330. package/table/index.d.ts +0 -13
  331. package/tabs/index.d.ts +0 -19
  332. package/tag/index.d.ts +0 -24
  333. package/text-input/index.d.ts +0 -135
  334. package/textarea/index.d.ts +0 -117
  335. package/toggle/Toggle.js +0 -186
  336. package/toggle/index.d.ts +0 -21
  337. package/toggle-group/index.d.ts +0 -21
  338. package/upload/Upload.js +0 -201
  339. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  340. package/upload/buttons-upload/Icons.js +0 -40
  341. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  342. package/upload/dragAndDropArea/Icons.js +0 -39
  343. package/upload/file-upload/FileToUpload.js +0 -115
  344. package/upload/file-upload/Icons.js +0 -66
  345. package/upload/files-upload/FilesToUpload.js +0 -109
  346. package/upload/index.d.ts +0 -15
  347. package/upload/transaction/Icons.js +0 -160
  348. package/upload/transaction/Transaction.js +0 -104
  349. package/upload/transactions/Transactions.js +0 -94
  350. package/wizard/Icons.js +0 -65
  351. package/wizard/index.d.ts +0 -18
@@ -0,0 +1,138 @@
1
+ import React from "react";
2
+ import DxcSwitch from "./Switch";
3
+ import { BackgroundColorProvider } from "../BackgroundColorContext";
4
+ import Title from "../../.storybook/components/Title";
5
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
+ import DarkContainer from "../../.storybook/components/DarkSection";
7
+
8
+ export default {
9
+ title: "Switch",
10
+ component: DxcSwitch,
11
+ };
12
+
13
+ export const Chromatic = () => (
14
+ <>
15
+ <ExampleContainer>
16
+ <Title title="With label after" theme="light" level={4} />
17
+ <DxcSwitch label="Switch" labelPosition="after" />
18
+ </ExampleContainer>
19
+ <ExampleContainer>
20
+ <Title title="Without label" theme="light" level={4} />
21
+ <DxcSwitch />
22
+ </ExampleContainer>
23
+ <ExampleContainer pseudoState="pseudo-focus-visible">
24
+ <Title title="Focused" theme="light" level={4} />
25
+ <DxcSwitch label="Switch" labelPosition="after" />
26
+ </ExampleContainer>
27
+ <ExampleContainer>
28
+ <Title title="Checked" theme="light" level={4} />
29
+ <DxcSwitch label="Switch" defaultChecked />
30
+ </ExampleContainer>
31
+ <ExampleContainer>
32
+ <Title title="Optional" theme="light" level={4} />
33
+ <DxcSwitch label="Switch" optional />
34
+ </ExampleContainer>
35
+ <ExampleContainer>
36
+ <Title title="Disabled" theme="light" level={4} />
37
+ <DxcSwitch label="Switch" disabled />
38
+ </ExampleContainer>
39
+ <ExampleContainer>
40
+ <Title title="Disabled optional" theme="light" level={4} />
41
+ <DxcSwitch label="Switch" disabled optional labelPosition="after" />
42
+ </ExampleContainer>
43
+ <ExampleContainer>
44
+ <Title title="Disabled checked" theme="light" level={4} />
45
+ <DxcSwitch label="Switch" disabled defaultChecked labelPosition="after" />
46
+ </ExampleContainer>
47
+ <BackgroundColorProvider color="#333333">
48
+ <DarkContainer>
49
+ <ExampleContainer>
50
+ <Title title="With label" theme="dark" level={4} />
51
+ <DxcSwitch label="Switch" />
52
+ </ExampleContainer>
53
+ <ExampleContainer pseudoState="pseudo-focus-visible">
54
+ <Title title="Focused" theme="dark" level={4} />
55
+ <DxcSwitch label="Switch" labelPosition="after" />
56
+ </ExampleContainer>
57
+ <ExampleContainer>
58
+ <Title title="Checked" theme="dark" level={4} />
59
+ <DxcSwitch label="Switch" defaultChecked />
60
+ </ExampleContainer>
61
+ <ExampleContainer>
62
+ <Title title="Optional" theme="dark" level={4} />
63
+ <DxcSwitch label="Switch" optional />
64
+ </ExampleContainer>
65
+ <ExampleContainer>
66
+ <Title title="Disabled" theme="dark" level={4} />
67
+ <DxcSwitch label="Switch" disabled />
68
+ </ExampleContainer>
69
+ <ExampleContainer>
70
+ <Title title="Disabled optional" theme="dark" level={4} />
71
+ <DxcSwitch label="Switch" disabled optional labelPosition="after" />
72
+ </ExampleContainer>
73
+ <ExampleContainer>
74
+ <Title title="Disabled checked" theme="dark" level={4} />
75
+ <DxcSwitch label="Switch" disabled defaultChecked labelPosition="after" />
76
+ </ExampleContainer>
77
+ </DarkContainer>
78
+ </BackgroundColorProvider>
79
+ <Title title="Margins" theme="light" level={2} />
80
+ <ExampleContainer>
81
+ <Title title="Xxsmall margin" theme="light" level={4} />
82
+ <DxcSwitch label="Xxsmall" margin="xxsmall" />
83
+ </ExampleContainer>
84
+ <ExampleContainer>
85
+ <Title title="Xsmall margin" theme="light" level={4} />
86
+ <DxcSwitch label="Xsmall" margin="xsmall" />
87
+ </ExampleContainer>
88
+ <ExampleContainer>
89
+ <Title title="Small margin" theme="light" level={4} />
90
+ <DxcSwitch label="Small" margin="small" />
91
+ </ExampleContainer>
92
+ <ExampleContainer>
93
+ <Title title="Medium margin" theme="light" level={4} />
94
+ <DxcSwitch label="Medium" margin="medium" />
95
+ </ExampleContainer>
96
+ <ExampleContainer>
97
+ <Title title="Large margin" theme="light" level={4} />
98
+ <DxcSwitch label="Large" margin="large" />
99
+ </ExampleContainer>
100
+ <ExampleContainer>
101
+ <Title title="Xlarge margin" theme="light" level={4} />
102
+ <DxcSwitch label="Xlarge" margin="xlarge" />
103
+ </ExampleContainer>
104
+ <ExampleContainer>
105
+ <Title title="Xxlarge margin" theme="light" level={4} />
106
+ <DxcSwitch label="Xxlarge" margin="xxlarge" />
107
+ </ExampleContainer>
108
+ <Title title="Sizes" theme="light" level={2} />
109
+ <ExampleContainer>
110
+ <Title title="Small size" theme="light" level={4} />
111
+ <DxcSwitch label="Small" size="small" />
112
+ </ExampleContainer>
113
+ <ExampleContainer>
114
+ <Title title="Medium size (with large label)" theme="light" level={4} />
115
+ <DxcSwitch label="Very very very large label or even huge" size="medium" />
116
+ </ExampleContainer>
117
+ <ExampleContainer>
118
+ <Title title="Medium size (with long label)" theme="light" level={4} />
119
+ <DxcSwitch
120
+ label="Large texttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttt"
121
+ labelPosition="after"
122
+ size="medium"
123
+ />
124
+ </ExampleContainer>
125
+ <ExampleContainer>
126
+ <Title title="Large size" theme="light" level={4} />
127
+ <DxcSwitch label="Large" size="large" />
128
+ </ExampleContainer>
129
+ <ExampleContainer>
130
+ <Title title="FillParent size" theme="light" level={4} />
131
+ <DxcSwitch label="FillParent" size="fillParent" />
132
+ </ExampleContainer>
133
+ <ExampleContainer>
134
+ <Title title="FitContent size" theme="light" level={4} />
135
+ <DxcSwitch label="FitContent" size="fitContent" />
136
+ </ExampleContainer>
137
+ </>
138
+ );
@@ -0,0 +1,212 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _react = _interopRequireDefault(require("react"));
6
+
7
+ var _react2 = require("@testing-library/react");
8
+
9
+ var _Switch = _interopRequireDefault(require("./Switch"));
10
+
11
+ describe("Switch component tests", function () {
12
+ test("Switch renders with correct text", function () {
13
+ var onChange = jest.fn(function (returnedValue) {
14
+ expect(returnedValue).toBe(true);
15
+ });
16
+
17
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
18
+ label: "SwitchComponent",
19
+ checked: false,
20
+ onChange: onChange
21
+ })),
22
+ getByText = _render.getByText;
23
+
24
+ expect(getByText("SwitchComponent")).toBeTruthy();
25
+ });
26
+ test("Calls correct function on click", function () {
27
+ var onChange = jest.fn();
28
+
29
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
30
+ label: "SwitchComponent",
31
+ checked: false,
32
+ onChange: onChange
33
+ })),
34
+ getByText = _render2.getByText;
35
+
36
+ _react2.fireEvent.click(getByText("SwitchComponent"));
37
+
38
+ expect(onChange).toHaveBeenCalled();
39
+ });
40
+ test("Calls correct function on key down", function () {
41
+ var onChange = jest.fn();
42
+
43
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
44
+ label: "SwitchComponent",
45
+ checked: false,
46
+ onChange: onChange
47
+ })),
48
+ getByText = _render3.getByText;
49
+
50
+ _react2.fireEvent.focus(getByText("SwitchComponent"));
51
+
52
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
53
+ key: "Enter"
54
+ });
55
+
56
+ expect(onChange).toHaveBeenCalled();
57
+
58
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
59
+ key: " "
60
+ });
61
+
62
+ expect(onChange).toHaveBeenCalled();
63
+ });
64
+ test("Everytime the user clicks the component the onchange function is called with the correct value CONTROLLED COMPONENT", function () {
65
+ var onChange = jest.fn();
66
+
67
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
68
+ label: "SwitchComponent",
69
+ checked: false,
70
+ onChange: onChange
71
+ })),
72
+ getByText = _render4.getByText;
73
+
74
+ _react2.fireEvent.click(getByText("SwitchComponent"));
75
+
76
+ _react2.fireEvent.click(getByText("SwitchComponent"));
77
+
78
+ expect(onChange.mock.calls[0][0]).toBe(true);
79
+ expect(onChange.mock.calls[1][0]).toBe(true);
80
+ });
81
+ test("Everytime the user use enter in the component, the onchange function is called with the correct value CONTROLLED COMPONENT", function () {
82
+ var onChange = jest.fn();
83
+
84
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
85
+ label: "SwitchComponent",
86
+ checked: false,
87
+ onChange: onChange
88
+ })),
89
+ getByText = _render5.getByText;
90
+
91
+ _react2.fireEvent.focus(getByText("SwitchComponent"));
92
+
93
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
94
+ key: "Enter"
95
+ });
96
+
97
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
98
+ key: "Enter"
99
+ });
100
+
101
+ expect(onChange.mock.calls[0][0]).toBe(true);
102
+ expect(onChange.mock.calls[1][0]).toBe(true);
103
+ });
104
+ test("Everytime the user use space in the component, the onchange function is called with the correct value CONTROLLED COMPONENT", function () {
105
+ var onChange = jest.fn();
106
+
107
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
108
+ label: "SwitchComponent",
109
+ checked: false,
110
+ onChange: onChange
111
+ })),
112
+ getByText = _render6.getByText;
113
+
114
+ _react2.fireEvent.focus(getByText("SwitchComponent"));
115
+
116
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
117
+ key: " "
118
+ });
119
+
120
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
121
+ key: " "
122
+ });
123
+
124
+ expect(onChange.mock.calls[0][0]).toBe(true);
125
+ expect(onChange.mock.calls[1][0]).toBe(true);
126
+ });
127
+ test("Everytime the user clicks the component the onchange function is called with the correct value UNCONTROLLED COMPONENT", function () {
128
+ var onChange = jest.fn();
129
+
130
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
131
+ label: "SwitchComponent",
132
+ onChange: onChange
133
+ })),
134
+ getByText = _render7.getByText;
135
+
136
+ _react2.fireEvent.click(getByText("SwitchComponent"));
137
+
138
+ _react2.fireEvent.click(getByText("SwitchComponent"));
139
+
140
+ expect(onChange.mock.calls[0][0]).toBe(true);
141
+ expect(onChange.mock.calls[1][0]).toBe(false);
142
+ });
143
+ test("Everytime the user use enter in the component, the onchange function is called with the correct value UNCONTROLLED COMPONENT", function () {
144
+ var onChange = jest.fn();
145
+
146
+ var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
147
+ label: "SwitchComponent",
148
+ onChange: onChange
149
+ })),
150
+ getByText = _render8.getByText;
151
+
152
+ _react2.fireEvent.focus(getByText("SwitchComponent"));
153
+
154
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
155
+ key: "Enter"
156
+ });
157
+
158
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
159
+ key: "Enter"
160
+ });
161
+
162
+ expect(onChange.mock.calls[0][0]).toBe(true);
163
+ expect(onChange.mock.calls[1][0]).toBe(false);
164
+ });
165
+ test("Everytime the user use space in the component, the onchange function is called with the correct value UNCONTROLLED COMPONENT", function () {
166
+ var onChange = jest.fn();
167
+
168
+ var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
169
+ label: "SwitchComponent",
170
+ onChange: onChange
171
+ })),
172
+ getByText = _render9.getByText;
173
+
174
+ _react2.fireEvent.focus(getByText("SwitchComponent"));
175
+
176
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
177
+ key: " "
178
+ });
179
+
180
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
181
+ key: " "
182
+ });
183
+
184
+ expect(onChange.mock.calls[0][0]).toBe(true);
185
+ expect(onChange.mock.calls[1][0]).toBe(false);
186
+ });
187
+ test("Renders with correct initial value and initial state when it is uncontrolled", function () {
188
+ var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
189
+ label: "Default label",
190
+ defaultChecked: true,
191
+ value: "test-defaultChecked"
192
+ })),
193
+ getByRole = _render10.getByRole;
194
+
195
+ var inputEl = getByRole("switch");
196
+ expect(inputEl.checked).toBe(true);
197
+ expect(inputEl.value).toBe("test-defaultChecked");
198
+ expect(inputEl.getAttribute("aria-checked")).toBe("true");
199
+ });
200
+ test("Renders with correct aria attributes", function () {
201
+ var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
202
+ label: "Default label"
203
+ })),
204
+ getByRole = _render11.getByRole,
205
+ getByText = _render11.getByText;
206
+
207
+ var inputEl = getByRole("switch");
208
+ var label = getByText("Default label");
209
+ expect(inputEl.getAttribute("aria-labelledby")).toBe(label.id);
210
+ expect(inputEl.getAttribute("aria-checked")).toBe("false");
211
+ });
212
+ });
@@ -0,0 +1,61 @@
1
+ export declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
+ export declare type Margin = {
3
+ top?: Space;
4
+ bottom?: Space;
5
+ left?: Space;
6
+ right?: Space;
7
+ };
8
+ export declare type SwitchPropsType = {
9
+ /**
10
+ * Initial state of the switch, only when it is uncontrolled.
11
+ */
12
+ defaultChecked?: boolean;
13
+ /**
14
+ * If true, the component is checked. If undefined, the component will be uncontrolled
15
+ * and the checked attribute will be managed internally by the component.
16
+ */
17
+ checked?: boolean;
18
+ /**
19
+ * Will be passed to the value attribute of the html input element. When inside a form,
20
+ * this value will be only submitted if the switch is checked.
21
+ */
22
+ value?: string;
23
+ /**
24
+ * Text to be placed next to the switch.
25
+ */
26
+ label?: string;
27
+ /**
28
+ * Whether the label should appear after or before the switch.
29
+ */
30
+ labelPosition?: "before" | "after";
31
+ /**
32
+ * Name attribute of the input element.
33
+ */
34
+ name?: string;
35
+ /**
36
+ * If true, the component will be disabled.
37
+ */
38
+ disabled?: boolean;
39
+ /**
40
+ * This function will be called when the user changes the state of the switch.
41
+ * The new value of the checked attribute will be passed as a parameter.
42
+ */
43
+ onChange?: (checked: boolean) => void;
44
+ /**
45
+ * If true, the component will display '(Optional)' next to the label.
46
+ */
47
+ optional?: boolean;
48
+ /**
49
+ * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
50
+ * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
51
+ */
52
+ margin?: Space | Margin;
53
+ /**
54
+ * Size of the component.
55
+ */
56
+ size?: "small" | "medium" | "large" | "fillParent" | "fitContent";
57
+ /**
58
+ * Value of the tabindex.
59
+ */
60
+ tabIndex?: number;
61
+ };
@@ -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 TablePropsType from "./types";
3
+ declare const DxcTable: ({ children, margin }: TablePropsType) => JSX.Element;
4
+ export default DxcTable;
package/table/Table.js CHANGED
@@ -21,9 +21,9 @@ var _variables = require("../common/variables.js");
21
21
 
22
22
  var _utils = require("../common/utils.js");
23
23
 
24
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
24
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
25
25
 
26
- var _BackgroundColorContext = require("../BackgroundColorContext.js");
26
+ var _BackgroundColorContext = require("../BackgroundColorContext");
27
27
 
28
28
  var _templateObject, _templateObject2;
29
29
 
@@ -48,7 +48,7 @@ var calculateWidth = function calculateWidth(margin) {
48
48
  return "calc(100% - ".concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
49
49
  };
50
50
 
51
- var DxcTableContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n overflow: hidden auto;\n &::-webkit-scrollbar {\n width: 8px;\n }\n &::-webkit-scrollbar-thumb {\n background-color: ", ";\n border-radius: 6px;\n }\n &::-webkit-scrollbar-track {\n background-color: ", ";\n border-radius: 6px;\n }\n"])), function (props) {
51
+ var DxcTableContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n overflow: auto;\n &::-webkit-scrollbar {\n width: 8px;\n height: 8px;\n }\n &::-webkit-scrollbar-thumb {\n background-color: ", ";\n border-radius: 6px;\n }\n &::-webkit-scrollbar-track {\n background-color: ", ";\n border-radius: 6px;\n }\n"])), function (props) {
52
52
  return calculateWidth(props.margin);
53
53
  }, function (props) {
54
54
  return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";