@dxc-technology/halstack-react 0.0.0-9b45027 → 0.0.0-9bd9511

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 (294) hide show
  1. package/BackgroundColorContext.d.ts +2 -2
  2. package/BackgroundColorContext.js +1 -11
  3. package/HalstackContext.d.ts +13 -0
  4. package/HalstackContext.js +318 -0
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +124 -179
  7. package/accordion/Accordion.stories.tsx +115 -27
  8. package/accordion/Accordion.test.js +56 -0
  9. package/accordion/types.d.ts +12 -11
  10. package/accordion-group/AccordionGroup.d.ts +1 -1
  11. package/accordion-group/AccordionGroup.js +28 -77
  12. package/accordion-group/AccordionGroup.stories.tsx +28 -2
  13. package/accordion-group/AccordionGroup.test.js +108 -0
  14. package/accordion-group/types.d.ts +19 -12
  15. package/alert/Alert.js +18 -46
  16. package/alert/Alert.stories.tsx +28 -0
  17. package/alert/Alert.test.js +75 -0
  18. package/alert/types.d.ts +3 -3
  19. package/badge/Badge.d.ts +4 -0
  20. package/badge/Badge.js +6 -16
  21. package/badge/types.d.ts +5 -0
  22. package/bleed/Bleed.d.ts +2 -2
  23. package/bleed/Bleed.js +14 -55
  24. package/bleed/Bleed.stories.tsx +94 -95
  25. package/bleed/types.d.ts +26 -2
  26. package/box/Box.js +34 -63
  27. package/box/Box.stories.tsx +15 -0
  28. package/box/Box.test.js +13 -0
  29. package/box/types.d.ts +5 -4
  30. package/bulleted-list/BulletedList.d.ts +7 -0
  31. package/bulleted-list/BulletedList.js +98 -0
  32. package/bulleted-list/BulletedList.stories.tsx +200 -0
  33. package/bulleted-list/types.d.ts +11 -0
  34. package/bulleted-list/types.js +5 -0
  35. package/button/Button.js +61 -100
  36. package/button/Button.stories.tsx +159 -8
  37. package/button/Button.test.js +26 -0
  38. package/button/types.d.ts +8 -8
  39. package/card/Card.js +44 -70
  40. package/card/Card.test.js +39 -0
  41. package/card/types.d.ts +4 -3
  42. package/checkbox/Checkbox.d.ts +2 -2
  43. package/checkbox/Checkbox.js +115 -162
  44. package/checkbox/Checkbox.stories.tsx +198 -130
  45. package/checkbox/Checkbox.test.js +128 -0
  46. package/checkbox/types.d.ts +14 -6
  47. package/chip/Chip.d.ts +1 -1
  48. package/chip/Chip.js +29 -91
  49. package/chip/Chip.stories.tsx +98 -13
  50. package/chip/Chip.test.js +42 -0
  51. package/chip/types.d.ts +8 -16
  52. package/common/utils.js +1 -6
  53. package/common/variables.d.ts +1431 -0
  54. package/common/variables.js +480 -554
  55. package/date-input/Calendar.d.ts +4 -0
  56. package/date-input/Calendar.js +215 -0
  57. package/date-input/DateInput.js +164 -300
  58. package/date-input/DateInput.stories.tsx +199 -33
  59. package/date-input/DateInput.test.js +648 -0
  60. package/date-input/DatePicker.d.ts +4 -0
  61. package/date-input/DatePicker.js +116 -0
  62. package/date-input/Icons.d.ts +6 -0
  63. package/date-input/Icons.js +63 -0
  64. package/date-input/YearPicker.d.ts +4 -0
  65. package/date-input/YearPicker.js +101 -0
  66. package/date-input/types.d.ts +71 -13
  67. package/dialog/Dialog.js +52 -84
  68. package/dialog/Dialog.stories.tsx +99 -22
  69. package/dialog/Dialog.test.js +56 -0
  70. package/dialog/types.d.ts +4 -3
  71. package/dropdown/Dropdown.d.ts +1 -1
  72. package/dropdown/Dropdown.js +240 -323
  73. package/dropdown/Dropdown.stories.tsx +255 -64
  74. package/dropdown/Dropdown.test.js +479 -0
  75. package/dropdown/DropdownMenu.d.ts +4 -0
  76. package/dropdown/DropdownMenu.js +60 -0
  77. package/dropdown/DropdownMenuItem.d.ts +4 -0
  78. package/dropdown/DropdownMenuItem.js +70 -0
  79. package/dropdown/types.d.ts +30 -19
  80. package/file-input/FileInput.d.ts +2 -2
  81. package/file-input/FileInput.js +224 -351
  82. package/file-input/FileInput.stories.tsx +122 -11
  83. package/file-input/FileInput.test.js +445 -0
  84. package/file-input/FileItem.d.ts +4 -14
  85. package/file-input/FileItem.js +48 -97
  86. package/file-input/types.d.ts +24 -7
  87. package/flex/Flex.d.ts +4 -0
  88. package/flex/Flex.js +57 -0
  89. package/flex/Flex.stories.tsx +103 -0
  90. package/flex/types.d.ts +32 -0
  91. package/flex/types.js +5 -0
  92. package/footer/Footer.js +36 -143
  93. package/footer/Footer.stories.tsx +99 -1
  94. package/footer/Footer.test.js +92 -0
  95. package/footer/Icons.js +1 -5
  96. package/footer/types.d.ts +7 -6
  97. package/header/Header.js +112 -177
  98. package/header/Header.stories.tsx +189 -36
  99. package/header/Header.test.js +66 -0
  100. package/header/Icons.js +2 -6
  101. package/header/types.d.ts +4 -3
  102. package/heading/Heading.js +8 -29
  103. package/heading/Heading.test.js +169 -0
  104. package/heading/types.d.ts +3 -3
  105. package/inset/Inset.js +14 -55
  106. package/inset/Inset.stories.tsx +36 -36
  107. package/inset/types.d.ts +26 -2
  108. package/layout/ApplicationLayout.d.ts +16 -6
  109. package/layout/ApplicationLayout.js +71 -164
  110. package/layout/ApplicationLayout.stories.tsx +84 -93
  111. package/layout/Icons.d.ts +5 -0
  112. package/layout/Icons.js +11 -10
  113. package/layout/SidenavContext.d.ts +5 -0
  114. package/layout/SidenavContext.js +15 -0
  115. package/layout/types.d.ts +18 -33
  116. package/link/Link.d.ts +3 -2
  117. package/link/Link.js +61 -106
  118. package/link/Link.stories.tsx +159 -52
  119. package/link/Link.test.js +65 -0
  120. package/link/types.d.ts +9 -29
  121. package/main.d.ts +11 -15
  122. package/main.js +48 -121
  123. package/nav-tabs/NavTabs.d.ts +8 -0
  124. package/nav-tabs/NavTabs.js +95 -0
  125. package/nav-tabs/NavTabs.stories.tsx +260 -0
  126. package/nav-tabs/NavTabs.test.js +75 -0
  127. package/nav-tabs/Tab.d.ts +4 -0
  128. package/nav-tabs/Tab.js +120 -0
  129. package/nav-tabs/types.d.ts +53 -0
  130. package/nav-tabs/types.js +5 -0
  131. package/number-input/NumberInput.js +21 -38
  132. package/number-input/NumberInput.stories.tsx +5 -5
  133. package/number-input/NumberInput.test.js +406 -0
  134. package/number-input/NumberInputContext.js +0 -5
  135. package/number-input/numberInputContextTypes.d.ts +1 -1
  136. package/number-input/types.d.ts +21 -14
  137. package/package.json +22 -25
  138. package/paginator/Icons.d.ts +5 -0
  139. package/paginator/Icons.js +16 -38
  140. package/paginator/Paginator.js +31 -82
  141. package/paginator/Paginator.stories.tsx +24 -0
  142. package/paginator/Paginator.test.js +266 -0
  143. package/paginator/types.d.ts +1 -1
  144. package/paragraph/Paragraph.d.ts +6 -0
  145. package/paragraph/Paragraph.js +28 -0
  146. package/paragraph/Paragraph.stories.tsx +44 -0
  147. package/password-input/PasswordInput.js +28 -54
  148. package/password-input/PasswordInput.test.js +138 -0
  149. package/password-input/types.d.ts +18 -15
  150. package/progress-bar/ProgressBar.d.ts +2 -2
  151. package/progress-bar/ProgressBar.js +65 -84
  152. package/progress-bar/ProgressBar.stories.jsx +47 -12
  153. package/progress-bar/ProgressBar.test.js +93 -0
  154. package/progress-bar/types.d.ts +3 -4
  155. package/quick-nav/QuickNav.d.ts +4 -0
  156. package/quick-nav/QuickNav.js +95 -0
  157. package/quick-nav/QuickNav.stories.tsx +356 -0
  158. package/quick-nav/types.d.ts +21 -0
  159. package/quick-nav/types.js +5 -0
  160. package/radio-group/Radio.d.ts +1 -1
  161. package/radio-group/Radio.js +61 -66
  162. package/radio-group/RadioGroup.js +99 -129
  163. package/radio-group/RadioGroup.stories.tsx +171 -36
  164. package/radio-group/RadioGroup.test.js +620 -0
  165. package/radio-group/types.d.ts +85 -7
  166. package/resultsetTable/Icons.d.ts +7 -0
  167. package/resultsetTable/Icons.js +48 -0
  168. package/resultsetTable/ResultsetTable.js +66 -157
  169. package/resultsetTable/ResultsetTable.stories.tsx +50 -25
  170. package/resultsetTable/ResultsetTable.test.js +292 -0
  171. package/resultsetTable/types.d.ts +5 -5
  172. package/select/Icons.d.ts +10 -0
  173. package/select/Icons.js +90 -0
  174. package/select/Listbox.d.ts +4 -0
  175. package/select/Listbox.js +144 -0
  176. package/select/Option.d.ts +4 -0
  177. package/select/Option.js +81 -0
  178. package/select/Select.js +201 -485
  179. package/select/Select.stories.tsx +600 -201
  180. package/select/Select.test.js +1845 -0
  181. package/select/types.d.ts +62 -22
  182. package/sidenav/Sidenav.d.ts +6 -5
  183. package/sidenav/Sidenav.js +164 -74
  184. package/sidenav/Sidenav.stories.tsx +249 -149
  185. package/sidenav/Sidenav.test.js +37 -0
  186. package/sidenav/types.d.ts +50 -27
  187. package/slider/Slider.d.ts +2 -2
  188. package/slider/Slider.js +143 -164
  189. package/slider/Slider.stories.tsx +72 -9
  190. package/slider/Slider.test.js +222 -0
  191. package/slider/types.d.ts +11 -3
  192. package/spinner/Spinner.js +12 -41
  193. package/spinner/Spinner.stories.jsx +27 -1
  194. package/spinner/Spinner.test.js +55 -0
  195. package/spinner/types.d.ts +3 -3
  196. package/switch/Switch.d.ts +2 -2
  197. package/switch/Switch.js +148 -107
  198. package/switch/Switch.stories.tsx +53 -42
  199. package/switch/Switch.test.js +180 -0
  200. package/switch/types.d.ts +13 -5
  201. package/table/Table.js +5 -23
  202. package/table/Table.stories.jsx +80 -1
  203. package/table/Table.test.js +21 -0
  204. package/table/types.d.ts +3 -3
  205. package/tabs/Tab.d.ts +4 -0
  206. package/tabs/Tab.js +115 -0
  207. package/tabs/Tabs.d.ts +1 -1
  208. package/tabs/Tabs.js +318 -139
  209. package/tabs/Tabs.stories.tsx +119 -13
  210. package/tabs/Tabs.test.js +295 -0
  211. package/tabs/types.d.ts +21 -7
  212. package/tag/Tag.d.ts +1 -1
  213. package/tag/Tag.js +36 -75
  214. package/tag/Tag.stories.tsx +37 -27
  215. package/tag/Tag.test.js +49 -0
  216. package/tag/types.d.ts +25 -16
  217. package/text-input/Icons.d.ts +8 -0
  218. package/text-input/Icons.js +57 -0
  219. package/text-input/Suggestion.d.ts +4 -0
  220. package/text-input/Suggestion.js +68 -0
  221. package/text-input/Suggestions.d.ts +4 -0
  222. package/text-input/Suggestions.js +109 -0
  223. package/text-input/TextInput.js +232 -438
  224. package/text-input/TextInput.stories.tsx +310 -197
  225. package/text-input/TextInput.test.js +1404 -0
  226. package/text-input/types.d.ts +55 -17
  227. package/textarea/Textarea.js +53 -96
  228. package/textarea/Textarea.stories.jsx +93 -13
  229. package/textarea/Textarea.test.js +360 -0
  230. package/textarea/types.d.ts +22 -15
  231. package/toggle-group/ToggleGroup.d.ts +1 -1
  232. package/toggle-group/ToggleGroup.js +23 -57
  233. package/toggle-group/ToggleGroup.stories.tsx +46 -4
  234. package/toggle-group/ToggleGroup.test.js +124 -0
  235. package/toggle-group/types.d.ts +19 -11
  236. package/translatedLabelsType.d.ts +82 -0
  237. package/translatedLabelsType.js +5 -0
  238. package/typography/Typography.d.ts +4 -0
  239. package/typography/Typography.js +119 -0
  240. package/typography/Typography.stories.tsx +198 -0
  241. package/typography/types.d.ts +18 -0
  242. package/typography/types.js +5 -0
  243. package/useTheme.d.ts +1 -1
  244. package/useTheme.js +3 -9
  245. package/useTranslatedLabels.d.ts +3 -0
  246. package/useTranslatedLabels.js +15 -0
  247. package/wizard/Wizard.d.ts +1 -1
  248. package/wizard/Wizard.js +68 -98
  249. package/wizard/Wizard.stories.tsx +48 -19
  250. package/wizard/Wizard.test.js +114 -0
  251. package/wizard/types.d.ts +12 -7
  252. package/ThemeContext.d.ts +0 -15
  253. package/ThemeContext.js +0 -243
  254. package/V3Select/V3Select.js +0 -455
  255. package/V3Select/index.d.ts +0 -27
  256. package/V3Textarea/V3Textarea.js +0 -260
  257. package/V3Textarea/index.d.ts +0 -27
  258. package/common/RequiredComponent.js +0 -32
  259. package/date/Date.js +0 -373
  260. package/date/index.d.ts +0 -27
  261. package/input-text/Icons.js +0 -22
  262. package/input-text/InputText.js +0 -611
  263. package/input-text/index.d.ts +0 -36
  264. package/list/List.d.ts +0 -8
  265. package/list/List.js +0 -47
  266. package/list/List.stories.tsx +0 -95
  267. package/radio/Radio.d.ts +0 -4
  268. package/radio/Radio.js +0 -174
  269. package/radio/Radio.stories.tsx +0 -192
  270. package/radio/types.d.ts +0 -54
  271. package/row/Row.d.ts +0 -11
  272. package/row/Row.js +0 -127
  273. package/row/Row.stories.tsx +0 -239
  274. package/stack/Stack.d.ts +0 -10
  275. package/stack/Stack.js +0 -97
  276. package/stack/Stack.stories.tsx +0 -166
  277. package/text/Text.d.ts +0 -7
  278. package/text/Text.js +0 -30
  279. package/text/Text.stories.tsx +0 -19
  280. package/toggle/Toggle.js +0 -186
  281. package/toggle/index.d.ts +0 -21
  282. package/upload/Upload.js +0 -201
  283. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  284. package/upload/buttons-upload/Icons.js +0 -40
  285. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  286. package/upload/dragAndDropArea/Icons.js +0 -39
  287. package/upload/file-upload/FileToUpload.js +0 -115
  288. package/upload/file-upload/Icons.js +0 -66
  289. package/upload/files-upload/FilesToUpload.js +0 -109
  290. package/upload/index.d.ts +0 -15
  291. package/upload/transaction/Icons.js +0 -160
  292. package/upload/transaction/Transaction.js +0 -104
  293. package/upload/transactions/Transactions.js +0 -94
  294. /package/{radio → badge}/types.js +0 -0
@@ -4,137 +4,122 @@ import { BackgroundColorProvider } from "../BackgroundColorContext";
4
4
  import Title from "../../.storybook/components/Title";
5
5
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
6
  import DarkContainer from "../../.storybook/components/DarkSection";
7
- import { userEvent, within } from "@storybook/testing-library";
7
+ import styled from "styled-components";
8
+ import { HalstackProvider } from "../HalstackContext";
8
9
 
9
10
  export default {
10
11
  title: "Checkbox",
11
12
  component: DxcCheckbox,
12
13
  };
13
14
 
15
+ const opinionatedTheme = {
16
+ checkbox: {
17
+ baseColor: "#0067b3",
18
+ checkColor: "#ffffff",
19
+ fontColor: "#000000",
20
+ },
21
+ };
22
+
14
23
  const Checkbox = () => (
15
24
  <>
16
- <>
17
- <ExampleContainer>
18
- <Title title="Default" theme="light" level={4} />
19
- <DxcCheckbox label="Checkbox" />
20
- </ExampleContainer>
21
- <ExampleContainer>
22
- <Title title="Focused" theme="light" level={4} />
23
- <DxcCheckbox label="Focused" />
24
- </ExampleContainer>
25
- <ExampleContainer>
26
- <Title title="Checked" theme="light" level={4} />
27
- <DxcCheckbox label="Checkbox" checked />
28
- </ExampleContainer>
29
- <ExampleContainer>
30
- <Title title="Required" theme="light" level={4} />
31
- <DxcCheckbox label="Checkbox" required />
32
- </ExampleContainer>
33
- <ExampleContainer>
34
- <Title title="Disabled and checked" theme="light" level={4} />
35
- <DxcCheckbox label="Checkbox" disabled checked />
36
- </ExampleContainer>
37
- <ExampleContainer>
38
- <Title title="Disabled and required" theme="light" level={4} />
39
- <DxcCheckbox label="Checkbox" disabled required />
40
- </ExampleContainer>
41
- <ExampleContainer>
42
- <Title title="Disabled, required and checked" theme="light" level={4} />
43
- <DxcCheckbox label="Checkbox" disabled required checked />
44
- </ExampleContainer>
45
- <ExampleContainer>
46
- <Title title="Label after" theme="light" level={4} />
47
- <DxcCheckbox label="Checkbox" labelPosition="after" />
48
- </ExampleContainer>
49
- <ExampleContainer>
50
- <Title title="Checked with label after" theme="light" level={4} />
51
- <DxcCheckbox label="Checkbox" checked labelPosition="after" />
52
- </ExampleContainer>
53
- <ExampleContainer>
54
- <Title title="Required with label after" theme="light" level={4} />
55
- <DxcCheckbox label="Checkbox" required labelPosition="after" />
56
- </ExampleContainer>
57
- <ExampleContainer>
58
- <Title title="Disabled and checked with label after" theme="light" level={4} />
59
- <DxcCheckbox label="Checkbox" disabled checked labelPosition="after" />
60
- </ExampleContainer>
61
- <ExampleContainer>
62
- <Title title="Disabled and required with label after" theme="light" level={4} />
63
- <DxcCheckbox label="Checkbox" disabled required labelPosition="after" />
64
- </ExampleContainer>
65
- <ExampleContainer>
66
- <Title title="Disabled, required and checked with label after" theme="light" level={4} />
67
- <DxcCheckbox label="Checkbox" disabled required checked labelPosition="after" />
68
- </ExampleContainer>
69
- <ExampleContainer pseudoState="pseudo-hover">
70
- <Title title="Hovered" theme="light" level={4} />
71
- <DxcCheckbox label="Hovered" />
72
- </ExampleContainer>
73
- <ExampleContainer pseudoState="pseudo-hover">
74
- <Title title="Hovered and checked" theme="light" level={4} />
75
- <DxcCheckbox label="Hovered" checked />
76
- </ExampleContainer>
77
- </>
25
+ <ExampleContainer>
26
+ <Title title="Default" theme="light" level={4} />
27
+ <DxcCheckbox label="Checkbox" />
28
+ </ExampleContainer>
29
+ <ExampleContainer>
30
+ <Title title="Checked" theme="light" level={4} />
31
+ <DxcCheckbox label="Checkbox" defaultChecked />
32
+ </ExampleContainer>
33
+ <ExampleContainer>
34
+ <Title title="Disabled" theme="light" level={4} />
35
+ <DxcCheckbox label="Checkbox" disabled />
36
+ </ExampleContainer>
37
+ <ExampleContainer>
38
+ <Title title="Disabled, checked and optional" theme="light" level={4} />
39
+ <DxcCheckbox label="Checkbox" disabled defaultChecked optional />
40
+ </ExampleContainer>
41
+ <ExampleContainer pseudoState="pseudo-focus">
42
+ <Title title="Focused" theme="light" level={4} />
43
+ <DxcCheckbox label="Focused" />
44
+ </ExampleContainer>
45
+ <ExampleContainer pseudoState="pseudo-hover">
46
+ <Title title="Hovered" theme="light" level={4} />
47
+ <DxcCheckbox label="Hovered" />
48
+ </ExampleContainer>
49
+ <ExampleContainer pseudoState="pseudo-hover">
50
+ <Title title="Hovered and checked" theme="light" level={4} />
51
+ <DxcCheckbox label="Hovered" defaultChecked />
52
+ </ExampleContainer>
53
+ <ExampleContainer>
54
+ <Title title="Optional" theme="light" level={4} />
55
+ <DxcCheckbox label="Checkbox" optional />
56
+ </ExampleContainer>
57
+ <ExampleContainer>
58
+ <Title title="Label after" theme="light" level={4} />
59
+ <DxcCheckbox label="Checkbox" labelPosition="after" />
60
+ </ExampleContainer>
61
+ <ExampleContainer>
62
+ <Title title="Checked with label after" theme="light" level={4} />
63
+ <DxcCheckbox label="Checkbox" defaultChecked labelPosition="after" />
64
+ </ExampleContainer>
65
+ <ExampleContainer>
66
+ <Title title="Optional with label after" theme="light" level={4} />
67
+ <DxcCheckbox label="Checkbox" optional labelPosition="after" />
68
+ </ExampleContainer>
69
+ <ExampleContainer>
70
+ <Title title="Disabled and optional with label after" theme="light" level={4} />
71
+ <DxcCheckbox label="Checkbox" disabled labelPosition="after" optional />
72
+ </ExampleContainer>
78
73
  <BackgroundColorProvider color="#333333">
79
74
  <DarkContainer>
80
- <>
81
- <ExampleContainer>
82
- <Title title="Default" theme="dark" level={4} />
83
- <DxcCheckbox label="Checkbox" />
84
- </ExampleContainer>
85
- <ExampleContainer>
86
- <Title title="Checked" theme="dark" level={4} />
87
- <DxcCheckbox label="Checkbox" checked />
88
- </ExampleContainer>
89
- <ExampleContainer>
90
- <Title title="Required" theme="dark" level={4} />
91
- <DxcCheckbox label="Checkbox" required />
92
- </ExampleContainer>
93
- <ExampleContainer>
94
- <Title title="Disabled and checked" theme="dark" level={4} />
95
- <DxcCheckbox label="Checkbox" disabled checked />
96
- </ExampleContainer>
97
- <ExampleContainer>
98
- <Title title="Disabled and required" theme="dark" level={4} />
99
- <DxcCheckbox label="Checkbox" disabled required />
100
- </ExampleContainer>
101
- <ExampleContainer>
102
- <Title title="Disabled, required and checked" theme="dark" level={4} />
103
- <DxcCheckbox label="Checkbox" disabled required checked />
104
- </ExampleContainer>
105
- <ExampleContainer>
106
- <Title title="Label after" theme="dark" level={4} />
107
- <DxcCheckbox label="Checkbox" labelPosition="after" />
108
- </ExampleContainer>
109
- <ExampleContainer>
110
- <Title title="Checked with label after" theme="dark" level={4} />
111
- <DxcCheckbox label="Checkbox" checked labelPosition="after" />
112
- </ExampleContainer>
113
- <ExampleContainer>
114
- <Title title="Required with label after" theme="dark" level={4} />
115
- <DxcCheckbox label="Checkbox" required labelPosition="after" />
116
- </ExampleContainer>
117
- <ExampleContainer>
118
- <Title title="Disabled and checked with label after" theme="dark" level={4} />
119
- <DxcCheckbox label="Checkbox" disabled checked labelPosition="after" />
120
- </ExampleContainer>
121
- <ExampleContainer>
122
- <Title title="Disabled and required with label after" theme="dark" level={4} />
123
- <DxcCheckbox label="Checkbox" disabled required labelPosition="after" />
124
- </ExampleContainer>
125
- <ExampleContainer>
126
- <Title title="Disabled, required and checked with label after" theme="dark" level={4} />
127
- <DxcCheckbox label="Checkbox" disabled required checked labelPosition="after" />
128
- </ExampleContainer>
129
- <ExampleContainer pseudoState="pseudo-hover">
130
- <Title title="Hovered" theme="dark" level={4} />
131
- <DxcCheckbox label="Hovered" />
132
- </ExampleContainer>
133
- <ExampleContainer pseudoState="pseudo-hover">
134
- <Title title="Hovered and checked" theme="dark" level={4} />
135
- <DxcCheckbox label="Hovered" checked />
136
- </ExampleContainer>
137
- </>
75
+ <ExampleContainer>
76
+ <Title title="Default" theme="dark" level={4} />
77
+ <DxcCheckbox label="Checkbox" />
78
+ </ExampleContainer>
79
+ <ExampleContainer>
80
+ <Title title="Checked" theme="dark" level={4} />
81
+ <DxcCheckbox label="Checkbox" defaultChecked />
82
+ </ExampleContainer>
83
+ <ExampleContainer>
84
+ <Title title="Disabled" theme="dark" level={4} />
85
+ <DxcCheckbox label="Checkbox" disabled />
86
+ </ExampleContainer>
87
+ <ExampleContainer>
88
+ <Title title="Disabled, checked and optional" theme="dark" level={4} />
89
+ <DxcCheckbox label="Checkbox" disabled defaultChecked optional />
90
+ </ExampleContainer>
91
+ <ExampleContainer pseudoState="pseudo-focus">
92
+ <Title title="Focused" theme="dark" level={4} />
93
+ <DxcCheckbox label="Focused" />
94
+ </ExampleContainer>
95
+ <ExampleContainer pseudoState="pseudo-hover">
96
+ <Title title="Hovered" theme="dark" level={4} />
97
+ <DxcCheckbox label="Hovered" />
98
+ </ExampleContainer>
99
+ <ExampleContainer pseudoState="pseudo-hover">
100
+ <Title title="Hovered and checked" theme="dark" level={4} />
101
+ <DxcCheckbox label="Hovered" defaultChecked />
102
+ </ExampleContainer>
103
+ <ExampleContainer>
104
+ <Title title="Optional" theme="dark" level={4} />
105
+ <DxcCheckbox label="Checkbox" optional />
106
+ </ExampleContainer>
107
+ <ExampleContainer>
108
+ <Title title="Label after" theme="dark" level={4} />
109
+ <DxcCheckbox label="Checkbox" labelPosition="after" />
110
+ </ExampleContainer>
111
+ <ExampleContainer>
112
+ <Title title="Checked with label after" theme="dark" level={4} />
113
+ <DxcCheckbox label="Checkbox" defaultChecked labelPosition="after" />
114
+ </ExampleContainer>
115
+ <ExampleContainer>
116
+ <Title title="Optional with label after" theme="dark" level={4} />
117
+ <DxcCheckbox label="Checkbox" optional labelPosition="after" />
118
+ </ExampleContainer>
119
+ <ExampleContainer>
120
+ <Title title="Disabled and optional with label after" theme="dark" level={4} />
121
+ <DxcCheckbox label="Checkbox" disabled labelPosition="after" optional />
122
+ </ExampleContainer>
138
123
  </DarkContainer>
139
124
  </BackgroundColorProvider>
140
125
  <Title title="Sizes" theme="light" level={2} />
@@ -156,37 +141,120 @@ const Checkbox = () => (
156
141
  <Title title="Margins" theme="light" level={2} />
157
142
  <ExampleContainer>
158
143
  <Title title="Xxsmall" theme="light" level={4} />
159
- <DxcCheckbox label="Xxsmall" margin={"xxsmall"} />
144
+ <DxcCheckbox label="Xxsmall" margin="xxsmall" />
160
145
  </ExampleContainer>
161
146
  <ExampleContainer>
162
147
  <Title title="Xsmall" theme="light" level={4} />
163
- <DxcCheckbox label="Xsmall" margin={"xsmall"} />
148
+ <DxcCheckbox label="Xsmall" margin="xsmall" />
164
149
  </ExampleContainer>
165
150
  <ExampleContainer>
166
151
  <Title title="Small" theme="light" level={4} />
167
- <DxcCheckbox label="Small" margin={"small"} />
152
+ <DxcCheckbox label="Small" margin="small" />
168
153
  </ExampleContainer>
169
154
  <ExampleContainer>
170
155
  <Title title="Medium" theme="light" level={4} />
171
- <DxcCheckbox label="Medium" margin={"medium"} />
156
+ <DxcCheckbox label="Medium" margin="medium" />
172
157
  </ExampleContainer>
173
158
  <ExampleContainer>
174
159
  <Title title="Large" theme="light" level={4} />
175
- <DxcCheckbox label="Large" margin={"large"} />
160
+ <DxcCheckbox label="Large" margin="large" />
176
161
  </ExampleContainer>
177
162
  <ExampleContainer>
178
163
  <Title title="Xlarge" theme="light" level={4} />
179
- <DxcCheckbox label="Xlarge" margin={"xlarge"} />
164
+ <DxcCheckbox label="Xlarge" margin="xlarge" />
180
165
  </ExampleContainer>
181
166
  <ExampleContainer>
182
167
  <Title title="Xxlarge" theme="light" level={4} />
183
- <DxcCheckbox label="Xxlarge" margin={"xxlarge"} />
168
+ <DxcCheckbox label="Xxlarge" margin="xxlarge" />
169
+ </ExampleContainer>
170
+ <ExampleContainer>
171
+ <Title title="Overflow container" theme="light" level={4} />
172
+ <ScrollableContainer id="scroll-container">
173
+ <DxcCheckbox label="Checkbox" defaultChecked />
174
+ <DxcCheckbox label="Checkbox" defaultChecked />
175
+ <DxcCheckbox label="Checkbox" />
176
+ <DxcCheckbox label="Checkbox" defaultChecked />
177
+ <DxcCheckbox label="Checkbox" />
178
+ <DxcCheckbox label="Checkbox" />
179
+ <DxcCheckbox label="Checkbox" />
180
+ <DxcCheckbox label="Checkbox" defaultChecked />
181
+ </ScrollableContainer>
182
+ </ExampleContainer>
183
+ <ExampleContainer>
184
+ <Title title="Label overflow" theme="light" level={4} />
185
+ <SmallContainer>
186
+ <DxcCheckbox label="Very long label to check its overflowing" defaultChecked />
187
+ <DxcCheckbox label="Very long label to check its overflowing" labelPosition="after" />
188
+ </SmallContainer>
189
+ </ExampleContainer>
190
+ <Title title="Opinionated theme" theme="light" level={2} />
191
+ <ExampleContainer>
192
+ <Title title="Default" theme="light" level={4} />
193
+ <HalstackProvider theme={opinionatedTheme}>
194
+ <DxcCheckbox label="Checkbox" />
195
+ </HalstackProvider>
196
+ </ExampleContainer>
197
+ <ExampleContainer>
198
+ <Title title="Checked" theme="light" level={4} />
199
+ <HalstackProvider theme={opinionatedTheme}>
200
+ <DxcCheckbox label="Checkbox" defaultChecked />
201
+ </HalstackProvider>
202
+ </ExampleContainer>
203
+ <ExampleContainer>
204
+ <Title title="Disabled" theme="light" level={4} />
205
+ <HalstackProvider theme={opinionatedTheme}>
206
+ <DxcCheckbox label="Checkbox" disabled />
207
+ </HalstackProvider>
208
+ </ExampleContainer>
209
+ <ExampleContainer>
210
+ <Title title="Disabled checked" theme="light" level={4} />
211
+ <HalstackProvider theme={opinionatedTheme}>
212
+ <DxcCheckbox label="Checkbox" defaultChecked disabled />
213
+ </HalstackProvider>
214
+ </ExampleContainer>
215
+ <ExampleContainer pseudoState="pseudo-focus">
216
+ <Title title="Focused" theme="light" level={4} />
217
+ <HalstackProvider theme={opinionatedTheme}>
218
+ <DxcCheckbox label="Focused" />
219
+ </HalstackProvider>
220
+ </ExampleContainer>
221
+ <ExampleContainer pseudoState="pseudo-hover">
222
+ <Title title="Hovered" theme="light" level={4} />
223
+ <HalstackProvider theme={opinionatedTheme}>
224
+ <DxcCheckbox label="Hovered" />
225
+ </HalstackProvider>
226
+ </ExampleContainer>
227
+ <ExampleContainer pseudoState="pseudo-hover">
228
+ <Title title="Hovered and checked" theme="light" level={4} />
229
+ <HalstackProvider theme={opinionatedTheme}>
230
+ <DxcCheckbox label="Hovered" defaultChecked />
231
+ </HalstackProvider>
184
232
  </ExampleContainer>
185
233
  </>
186
234
  );
187
235
 
188
236
  export const Chromatic = Checkbox.bind({});
237
+
189
238
  Chromatic.play = async () => {
190
- await userEvent.tab();
191
- await userEvent.tab();
239
+ const listEl = document.getElementById("scroll-container");
240
+ listEl?.scrollTo?.({ top: 50 });
192
241
  };
242
+
243
+ const ScrollableContainer = styled.div`
244
+ display: flex;
245
+ flex-direction: column;
246
+ gap: 14px;
247
+ width: 200px;
248
+ height: 200px;
249
+ border: 1px solid #000;
250
+ padding: 14px;
251
+ overflow: auto;
252
+ `;
253
+
254
+ const SmallContainer = styled.div`
255
+ display: flex;
256
+ flex-direction: column;
257
+ gap: 14px;
258
+ width: 150px;
259
+ height: 150px;
260
+ `;
@@ -0,0 +1,128 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _react = _interopRequireDefault(require("react"));
5
+ var _react2 = require("@testing-library/react");
6
+ var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
7
+ var _Checkbox = _interopRequireDefault(require("./Checkbox"));
8
+ describe("Checkbox component tests", function () {
9
+ test("Checkbox renders with correct aria-labelledby and aria-required", function () {
10
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
11
+ label: "Checkbox"
12
+ })),
13
+ getByText = _render.getByText,
14
+ getByRole = _render.getByRole;
15
+ var labelId = getByText("Checkbox").getAttribute("id");
16
+ expect(getByRole("checkbox").getAttribute("aria-labelledby")).toBe(labelId);
17
+ expect(getByRole("checkbox").getAttribute("aria-required")).toBe("true");
18
+ });
19
+ test("Optional checkbox renders with correct aria-required", function () {
20
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
21
+ label: "Checkbox",
22
+ optional: true
23
+ })),
24
+ getByRole = _render2.getByRole;
25
+ expect(getByRole("checkbox").getAttribute("aria-required")).toBe("false");
26
+ });
27
+ test("Calls correct function on click", function () {
28
+ var onChange = jest.fn();
29
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
30
+ label: "Checkbox",
31
+ onChange: onChange
32
+ })),
33
+ getByText = _render3.getByText;
34
+ _react2.fireEvent.click(getByText("Checkbox"));
35
+ expect(onChange).toHaveBeenCalled();
36
+ });
37
+ test("Uncontrolled checkbox", function () {
38
+ var onChange = jest.fn();
39
+ var component = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
40
+ label: "Checkbox",
41
+ onChange: onChange,
42
+ name: "test"
43
+ }));
44
+ var visibleCheckbox = component.getByText("Checkbox");
45
+ var input = component.getByRole("checkbox");
46
+ var submitInput = component.container.querySelector("input[name=\"test\"]");
47
+ expect(input.getAttribute("aria-checked")).toBe("false");
48
+ expect(submitInput.checked).toBe(false);
49
+ _react2.fireEvent.click(visibleCheckbox);
50
+ expect(onChange).toHaveBeenCalled();
51
+ expect(onChange).toHaveBeenCalledWith(true);
52
+ expect(input.getAttribute("aria-checked")).toBe("true");
53
+ expect(submitInput.checked).toBe(true);
54
+ });
55
+ test("Controlled checkbox", function () {
56
+ var onChange = jest.fn();
57
+ var component = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
58
+ label: "Checkbox",
59
+ checked: false,
60
+ onChange: onChange,
61
+ name: "test"
62
+ }));
63
+ var input = component.getByRole("checkbox");
64
+ var visibleCheckbox = component.getByText("Checkbox");
65
+ var submitInput = component.container.querySelector("input[name=\"test\"]");
66
+ _react2.fireEvent.click(visibleCheckbox);
67
+ expect(onChange).toHaveBeenCalled();
68
+ expect(onChange).toHaveBeenCalledWith(true);
69
+ expect(input.getAttribute("aria-checked")).toBe("false");
70
+ expect(submitInput.checked).toBe(false);
71
+ });
72
+ test("Renders with correct initial value and initial state when it is uncontrolled", function () {
73
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
74
+ label: "Default label",
75
+ defaultChecked: true,
76
+ value: "test-defaultChecked",
77
+ name: "test"
78
+ })),
79
+ getByRole = _render4.getByRole,
80
+ container = _render4.container;
81
+ var checkbox = getByRole("checkbox");
82
+ var submitInput = container.querySelector("input[name=\"test\"]");
83
+ expect(submitInput.value).toBe("test-defaultChecked");
84
+ expect(checkbox.getAttribute("aria-checked")).toBe("true");
85
+ expect(submitInput.checked).toBe(true);
86
+ });
87
+ test("Test disable keyboard and mouse interactions", function () {
88
+ var onChange = jest.fn();
89
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
90
+ label: "Checkbox",
91
+ onChange: onChange,
92
+ disabled: true,
93
+ name: "test"
94
+ })),
95
+ getByRole = _render5.getByRole,
96
+ getByText = _render5.getByText,
97
+ container = _render5.container;
98
+ var input = getByRole("checkbox");
99
+ var visibleCheckbox = getByText("Checkbox");
100
+ var submitInput = container.querySelector("input[name=\"test\"]");
101
+ _react2.fireEvent.click(visibleCheckbox);
102
+ expect(onChange).toHaveBeenCalledTimes(0);
103
+ expect(input.getAttribute("aria-checked")).toBe("false");
104
+ expect(input.getAttribute("aria-disabled")).toBe("true");
105
+ expect(submitInput.checked).toBe(false);
106
+ _userEvent["default"].tab();
107
+ expect(document.activeElement === input).toBeFalsy();
108
+ });
109
+ test("Test keyboard interactions", function () {
110
+ var onChange = jest.fn();
111
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
112
+ label: "Checkbox",
113
+ name: "test",
114
+ onChange: onChange
115
+ })),
116
+ getByRole = _render6.getByRole;
117
+ var checkbox = getByRole("checkbox");
118
+ _userEvent["default"].tab();
119
+ expect(document.activeElement === checkbox).toBeTruthy();
120
+ _react2.fireEvent.keyDown(checkbox, {
121
+ key: " ",
122
+ code: "Space",
123
+ keyCode: 32,
124
+ charCode: 32
125
+ });
126
+ expect(onChange).toHaveBeenCalledWith(true);
127
+ });
128
+ });
@@ -1,11 +1,15 @@
1
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
- declare type Margin = {
1
+ export type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
+ export type Margin = {
3
3
  top?: Space;
4
4
  bottom?: Space;
5
5
  left?: Space;
6
6
  right?: Space;
7
7
  };
8
- declare type Props = {
8
+ type Props = {
9
+ /**
10
+ * Initial state of the checkbox, only when it is uncontrolled.
11
+ */
12
+ defaultChecked?: boolean;
9
13
  /**
10
14
  * If true, the component is checked. If undefined the component will be
11
15
  * uncontrolled and the value will be managed internally by the component.
@@ -33,14 +37,14 @@ declare type Props = {
33
37
  */
34
38
  disabled?: boolean;
35
39
  /**
36
- * If true, the checkbox will change its appearence, showing that the value is required.
40
+ * If true, the component will display '(Optional)' next to the label.
37
41
  */
38
- required?: boolean;
42
+ optional?: boolean;
39
43
  /**
40
44
  * This function will be called when the user clicks the checkbox.
41
45
  * The new value will be passed as a parameter.
42
46
  */
43
- onChange?: (val: boolean) => void;
47
+ onChange?: (value: boolean) => void;
44
48
  /**
45
49
  * Size of the margin to be applied to the component
46
50
  * ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
@@ -57,4 +61,8 @@ declare type Props = {
57
61
  */
58
62
  tabIndex?: number;
59
63
  };
64
+ /**
65
+ * Reference to the component.
66
+ */
67
+ export type RefType = HTMLDivElement;
60
68
  export default Props;
package/chip/Chip.d.ts CHANGED
@@ -1,4 +1,4 @@
1
1
  /// <reference types="react" />
2
2
  import ChipPropsType from "./types";
3
- declare const DxcChip: ({ label, suffixIcon, prefixIcon, suffixIconSrc, onClickSuffix, prefixIconSrc, onClickPrefix, disabled, margin, tabIndex, }: ChipPropsType) => JSX.Element;
3
+ declare const DxcChip: ({ label, suffixIcon, prefixIcon, onClickSuffix, onClickPrefix, disabled, margin, tabIndex, }: ChipPropsType) => JSX.Element;
4
4
  export default DxcChip;