@dxc-technology/halstack-react 0.0.0-c593452 → 0.0.0-c5cf7cd

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 (331) 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 +1 -1
  6. package/accordion/Accordion.js +124 -137
  7. package/accordion/Accordion.stories.tsx +306 -0
  8. package/accordion/Accordion.test.js +71 -0
  9. package/accordion/types.d.ts +12 -11
  10. package/accordion-group/AccordionGroup.d.ts +1 -1
  11. package/accordion-group/AccordionGroup.js +16 -37
  12. package/accordion-group/AccordionGroup.stories.tsx +251 -0
  13. package/accordion-group/AccordionGroup.test.js +126 -0
  14. package/accordion-group/types.d.ts +17 -10
  15. package/alert/Alert.js +7 -4
  16. package/alert/Alert.stories.tsx +170 -0
  17. package/alert/Alert.test.js +92 -0
  18. package/alert/types.d.ts +1 -1
  19. package/badge/Badge.d.ts +4 -0
  20. package/badge/Badge.js +6 -4
  21. package/badge/types.d.ts +5 -0
  22. package/{radio → badge}/types.js +0 -0
  23. package/bleed/Bleed.d.ts +3 -0
  24. package/bleed/Bleed.js +51 -0
  25. package/bleed/Bleed.stories.tsx +341 -0
  26. package/bleed/types.d.ts +37 -0
  27. package/bleed/types.js +5 -0
  28. package/box/Box.d.ts +4 -0
  29. package/box/Box.js +29 -65
  30. package/box/Box.stories.tsx +132 -0
  31. package/box/Box.test.js +18 -0
  32. package/box/types.d.ts +44 -0
  33. package/box/types.js +5 -0
  34. package/bulleted-list/BulletedList.d.ts +7 -0
  35. package/bulleted-list/BulletedList.js +123 -0
  36. package/bulleted-list/BulletedList.stories.tsx +200 -0
  37. package/bulleted-list/types.d.ts +11 -0
  38. package/bulleted-list/types.js +5 -0
  39. package/button/Button.d.ts +1 -1
  40. package/button/Button.js +61 -87
  41. package/button/Button.stories.tsx +232 -242
  42. package/button/Button.test.js +35 -0
  43. package/button/types.d.ts +14 -18
  44. package/card/Card.js +26 -30
  45. package/card/Card.stories.tsx +201 -0
  46. package/card/Card.test.js +50 -0
  47. package/card/ice-cream.jpg +0 -0
  48. package/card/types.d.ts +5 -6
  49. package/checkbox/Checkbox.d.ts +2 -2
  50. package/checkbox/Checkbox.js +108 -111
  51. package/checkbox/Checkbox.stories.tsx +208 -0
  52. package/checkbox/Checkbox.test.js +155 -0
  53. package/checkbox/types.d.ts +15 -7
  54. package/chip/Chip.d.ts +4 -0
  55. package/chip/Chip.js +16 -76
  56. package/chip/Chip.stories.tsx +119 -0
  57. package/chip/Chip.test.js +56 -0
  58. package/chip/types.d.ts +45 -0
  59. package/chip/types.js +5 -0
  60. package/common/variables.js +318 -378
  61. package/date-input/DateInput.js +66 -55
  62. package/date-input/DateInput.stories.tsx +138 -0
  63. package/date-input/DateInput.test.js +479 -0
  64. package/date-input/types.d.ts +16 -9
  65. package/dialog/Dialog.d.ts +4 -0
  66. package/dialog/Dialog.js +52 -74
  67. package/dialog/Dialog.stories.tsx +267 -0
  68. package/dialog/Dialog.test.js +70 -0
  69. package/dialog/types.d.ts +44 -0
  70. package/dialog/types.js +5 -0
  71. package/dropdown/Dropdown.d.ts +1 -1
  72. package/dropdown/Dropdown.js +244 -273
  73. package/dropdown/Dropdown.stories.tsx +312 -0
  74. package/dropdown/Dropdown.test.js +590 -0
  75. package/dropdown/DropdownMenu.d.ts +4 -0
  76. package/dropdown/DropdownMenu.js +80 -0
  77. package/dropdown/DropdownMenuItem.d.ts +4 -0
  78. package/dropdown/DropdownMenuItem.js +92 -0
  79. package/dropdown/types.d.ts +30 -19
  80. package/file-input/FileInput.d.ts +4 -0
  81. package/file-input/FileInput.js +183 -166
  82. package/file-input/FileInput.stories.tsx +535 -0
  83. package/file-input/FileInput.test.js +498 -0
  84. package/file-input/FileItem.d.ts +4 -0
  85. package/file-input/FileItem.js +49 -81
  86. package/file-input/types.d.ts +129 -0
  87. package/file-input/types.js +5 -0
  88. package/flex/Flex.d.ts +4 -0
  89. package/flex/Flex.js +69 -0
  90. package/flex/Flex.stories.tsx +103 -0
  91. package/flex/types.d.ts +32 -0
  92. package/flex/types.js +5 -0
  93. package/footer/Footer.d.ts +4 -0
  94. package/footer/Footer.js +36 -148
  95. package/footer/Footer.stories.tsx +137 -0
  96. package/footer/Footer.test.js +109 -0
  97. package/footer/Icons.d.ts +2 -0
  98. package/footer/Icons.js +4 -4
  99. package/footer/types.d.ts +66 -0
  100. package/footer/types.js +5 -0
  101. package/header/Header.d.ts +7 -0
  102. package/header/Header.js +119 -140
  103. package/header/Header.stories.tsx +172 -0
  104. package/header/Header.test.js +79 -0
  105. package/header/Icons.d.ts +2 -0
  106. package/header/Icons.js +4 -29
  107. package/header/types.d.ts +48 -0
  108. package/header/types.js +5 -0
  109. package/heading/Heading.d.ts +4 -0
  110. package/heading/Heading.js +7 -24
  111. package/heading/Heading.stories.tsx +54 -0
  112. package/heading/Heading.test.js +186 -0
  113. package/heading/types.d.ts +33 -0
  114. package/heading/types.js +5 -0
  115. package/inset/Inset.d.ts +3 -0
  116. package/inset/Inset.js +51 -0
  117. package/inset/Inset.stories.tsx +229 -0
  118. package/inset/types.d.ts +37 -0
  119. package/inset/types.js +5 -0
  120. package/layout/ApplicationLayout.d.ts +20 -0
  121. package/layout/ApplicationLayout.js +71 -135
  122. package/layout/ApplicationLayout.stories.tsx +162 -0
  123. package/layout/Icons.d.ts +5 -0
  124. package/layout/Icons.js +13 -2
  125. package/layout/SidenavContext.d.ts +5 -0
  126. package/layout/SidenavContext.js +19 -0
  127. package/layout/types.d.ts +42 -0
  128. package/layout/types.js +5 -0
  129. package/link/Link.d.ts +4 -0
  130. package/link/Link.js +60 -107
  131. package/link/Link.stories.tsx +193 -0
  132. package/link/Link.test.js +83 -0
  133. package/link/types.d.ts +54 -0
  134. package/link/types.js +5 -0
  135. package/main.d.ts +12 -12
  136. package/main.js +64 -58
  137. package/number-input/NumberInput.d.ts +4 -0
  138. package/number-input/NumberInput.js +16 -68
  139. package/number-input/NumberInput.stories.tsx +115 -0
  140. package/number-input/NumberInput.test.js +543 -0
  141. package/number-input/NumberInputContext.d.ts +4 -0
  142. package/number-input/NumberInputContext.js +5 -2
  143. package/number-input/numberInputContextTypes.d.ts +19 -0
  144. package/number-input/numberInputContextTypes.js +5 -0
  145. package/number-input/types.d.ts +124 -0
  146. package/number-input/types.js +5 -0
  147. package/package.json +16 -12
  148. package/paginator/Paginator.js +19 -46
  149. package/paginator/Paginator.stories.tsx +63 -0
  150. package/paginator/Paginator.test.js +308 -0
  151. package/paragraph/Paragraph.d.ts +6 -0
  152. package/paragraph/Paragraph.js +38 -0
  153. package/paragraph/Paragraph.stories.tsx +44 -0
  154. package/password-input/PasswordInput.d.ts +4 -0
  155. package/password-input/PasswordInput.js +22 -55
  156. package/password-input/{PasswordInput.stories.jsx → PasswordInput.stories.tsx} +4 -4
  157. package/password-input/PasswordInput.test.js +181 -0
  158. package/password-input/types.d.ts +110 -0
  159. package/password-input/types.js +5 -0
  160. package/progress-bar/ProgressBar.d.ts +2 -2
  161. package/progress-bar/ProgressBar.js +60 -54
  162. package/progress-bar/ProgressBar.stories.jsx +60 -0
  163. package/progress-bar/ProgressBar.test.js +110 -0
  164. package/progress-bar/types.d.ts +3 -4
  165. package/quick-nav/QuickNav.d.ts +4 -0
  166. package/quick-nav/QuickNav.js +117 -0
  167. package/quick-nav/QuickNav.stories.tsx +342 -0
  168. package/quick-nav/types.d.ts +21 -0
  169. package/quick-nav/types.js +5 -0
  170. package/radio-group/Radio.d.ts +4 -0
  171. package/radio-group/Radio.js +156 -0
  172. package/radio-group/RadioGroup.d.ts +4 -0
  173. package/radio-group/RadioGroup.js +283 -0
  174. package/radio-group/RadioGroup.stories.tsx +101 -0
  175. package/radio-group/RadioGroup.test.js +722 -0
  176. package/radio-group/types.d.ts +114 -0
  177. package/radio-group/types.js +5 -0
  178. package/resultsetTable/ResultsetTable.d.ts +4 -0
  179. package/resultsetTable/ResultsetTable.js +10 -32
  180. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  181. package/resultsetTable/ResultsetTable.test.js +348 -0
  182. package/resultsetTable/types.d.ts +67 -0
  183. package/resultsetTable/types.js +5 -0
  184. package/select/Icons.d.ts +10 -0
  185. package/select/Icons.js +93 -0
  186. package/select/Listbox.d.ts +4 -0
  187. package/select/Listbox.js +198 -0
  188. package/select/Option.d.ts +4 -0
  189. package/select/Option.js +110 -0
  190. package/select/Select.d.ts +4 -0
  191. package/select/Select.js +160 -380
  192. package/select/Select.stories.tsx +627 -0
  193. package/select/Select.test.js +2233 -0
  194. package/select/types.d.ts +210 -0
  195. package/select/types.js +5 -0
  196. package/sidenav/Sidenav.d.ts +10 -0
  197. package/sidenav/Sidenav.js +186 -63
  198. package/sidenav/Sidenav.stories.tsx +180 -0
  199. package/sidenav/Sidenav.test.js +44 -0
  200. package/sidenav/types.d.ts +73 -0
  201. package/sidenav/types.js +5 -0
  202. package/slider/Slider.d.ts +2 -2
  203. package/slider/Slider.js +149 -112
  204. package/slider/Slider.stories.tsx +183 -0
  205. package/slider/Slider.test.js +250 -0
  206. package/slider/types.d.ts +12 -9
  207. package/spinner/Spinner.d.ts +4 -0
  208. package/spinner/Spinner.js +9 -26
  209. package/spinner/Spinner.stories.jsx +103 -0
  210. package/spinner/Spinner.test.js +64 -0
  211. package/spinner/types.d.ts +32 -0
  212. package/spinner/types.js +5 -0
  213. package/switch/Switch.d.ts +2 -2
  214. package/switch/Switch.js +152 -69
  215. package/switch/Switch.stories.tsx +138 -0
  216. package/switch/Switch.test.js +225 -0
  217. package/switch/types.d.ts +12 -4
  218. package/table/Table.d.ts +4 -0
  219. package/table/Table.js +4 -4
  220. package/table/Table.stories.jsx +277 -0
  221. package/table/Table.test.js +26 -0
  222. package/table/types.d.ts +21 -0
  223. package/table/types.js +5 -0
  224. package/tabs/Tab.d.ts +4 -0
  225. package/tabs/Tab.js +135 -0
  226. package/tabs/Tabs.d.ts +1 -1
  227. package/tabs/Tabs.js +364 -108
  228. package/tabs/Tabs.stories.tsx +186 -0
  229. package/tabs/Tabs.test.js +351 -0
  230. package/tabs/types.d.ts +41 -20
  231. package/tabs-nav/NavTabs.d.ts +8 -0
  232. package/tabs-nav/NavTabs.js +125 -0
  233. package/tabs-nav/NavTabs.stories.tsx +170 -0
  234. package/tabs-nav/NavTabs.test.js +82 -0
  235. package/tabs-nav/Tab.d.ts +4 -0
  236. package/tabs-nav/Tab.js +130 -0
  237. package/tabs-nav/types.d.ts +53 -0
  238. package/tabs-nav/types.js +5 -0
  239. package/tag/Tag.d.ts +4 -0
  240. package/tag/Tag.js +35 -60
  241. package/tag/Tag.stories.tsx +142 -0
  242. package/tag/Tag.test.js +60 -0
  243. package/tag/types.d.ts +69 -0
  244. package/tag/types.js +5 -0
  245. package/text-input/Icons.d.ts +8 -0
  246. package/text-input/Icons.js +60 -0
  247. package/text-input/Suggestion.d.ts +4 -0
  248. package/text-input/Suggestion.js +57 -0
  249. package/text-input/Suggestions.d.ts +4 -0
  250. package/text-input/Suggestions.js +134 -0
  251. package/text-input/TextInput.d.ts +4 -0
  252. package/text-input/TextInput.js +228 -376
  253. package/text-input/TextInput.stories.tsx +481 -0
  254. package/text-input/TextInput.test.js +1771 -0
  255. package/text-input/types.d.ts +197 -0
  256. package/text-input/types.js +5 -0
  257. package/textarea/Textarea.d.ts +4 -0
  258. package/textarea/Textarea.js +39 -79
  259. package/textarea/Textarea.stories.jsx +37 -15
  260. package/textarea/Textarea.test.js +437 -0
  261. package/textarea/types.d.ts +137 -0
  262. package/textarea/types.js +5 -0
  263. package/toggle-group/ToggleGroup.d.ts +4 -0
  264. package/toggle-group/ToggleGroup.js +18 -46
  265. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  266. package/toggle-group/ToggleGroup.test.js +156 -0
  267. package/toggle-group/types.d.ts +105 -0
  268. package/toggle-group/types.js +5 -0
  269. package/typography/Typography.d.ts +4 -0
  270. package/typography/Typography.js +131 -0
  271. package/typography/Typography.stories.tsx +198 -0
  272. package/typography/types.d.ts +18 -0
  273. package/typography/types.js +5 -0
  274. package/useTheme.d.ts +2 -0
  275. package/useTheme.js +2 -2
  276. package/useTranslatedLabels.d.ts +2 -0
  277. package/useTranslatedLabels.js +20 -0
  278. package/wizard/Wizard.d.ts +4 -0
  279. package/wizard/Wizard.js +118 -104
  280. package/wizard/Wizard.stories.tsx +233 -0
  281. package/wizard/Wizard.test.js +141 -0
  282. package/wizard/types.d.ts +65 -0
  283. package/wizard/types.js +5 -0
  284. package/ThemeContext.js +0 -246
  285. package/V3Select/V3Select.js +0 -455
  286. package/V3Select/index.d.ts +0 -27
  287. package/V3Textarea/V3Textarea.js +0 -260
  288. package/V3Textarea/index.d.ts +0 -27
  289. package/box/index.d.ts +0 -25
  290. package/chip/index.d.ts +0 -22
  291. package/date/Date.js +0 -373
  292. package/date/index.d.ts +0 -27
  293. package/dialog/index.d.ts +0 -18
  294. package/file-input/index.d.ts +0 -81
  295. package/footer/index.d.ts +0 -25
  296. package/header/index.d.ts +0 -25
  297. package/heading/index.d.ts +0 -17
  298. package/input-text/Icons.js +0 -22
  299. package/input-text/InputText.js +0 -611
  300. package/input-text/index.d.ts +0 -36
  301. package/link/index.d.ts +0 -23
  302. package/number-input/index.d.ts +0 -113
  303. package/password-input/index.d.ts +0 -94
  304. package/radio/Radio.d.ts +0 -4
  305. package/radio/Radio.js +0 -174
  306. package/radio/types.d.ts +0 -54
  307. package/resultsetTable/index.d.ts +0 -19
  308. package/select/index.d.ts +0 -131
  309. package/sidenav/index.d.ts +0 -13
  310. package/spinner/index.d.ts +0 -17
  311. package/table/index.d.ts +0 -13
  312. package/tag/index.d.ts +0 -24
  313. package/text-input/index.d.ts +0 -135
  314. package/textarea/index.d.ts +0 -117
  315. package/toggle/Toggle.js +0 -186
  316. package/toggle/index.d.ts +0 -21
  317. package/toggle-group/index.d.ts +0 -21
  318. package/upload/Upload.js +0 -201
  319. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  320. package/upload/buttons-upload/Icons.js +0 -40
  321. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  322. package/upload/dragAndDropArea/Icons.js +0 -39
  323. package/upload/file-upload/FileToUpload.js +0 -115
  324. package/upload/file-upload/Icons.js +0 -66
  325. package/upload/files-upload/FilesToUpload.js +0 -109
  326. package/upload/index.d.ts +0 -15
  327. package/upload/transaction/Icons.js +0 -160
  328. package/upload/transaction/Transaction.js +0 -104
  329. package/upload/transactions/Transactions.js +0 -94
  330. package/wizard/Icons.js +0 -65
  331. package/wizard/index.d.ts +0 -18
@@ -0,0 +1,225 @@
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 component = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
189
+ label: "Default label",
190
+ defaultChecked: true,
191
+ value: "test-defaultChecked",
192
+ name: "test"
193
+ }));
194
+ var switchEl = component.getByRole("switch");
195
+ var inputEl = component.container.querySelector("input[name=\"test\"]");
196
+ expect(inputEl.value).toBe("test-defaultChecked");
197
+ expect(switchEl.getAttribute("aria-checked")).toBe("true");
198
+ });
199
+ test("Renders with correct aria attributes", function () {
200
+ var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
201
+ label: "Default label"
202
+ })),
203
+ getByText = _render10.getByText,
204
+ getByRole = _render10.getByRole;
205
+
206
+ var switchEl = getByRole("switch");
207
+ var label = getByText("Default label");
208
+ expect(switchEl.getAttribute("aria-labelledby")).toBe(label.id);
209
+ expect(switchEl.getAttribute("aria-checked")).toBe("false");
210
+ });
211
+ test("Renders disabled switch correctly", function () {
212
+ var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
213
+ label: "Default label",
214
+ disabled: true
215
+ })),
216
+ getByText = _render11.getByText,
217
+ getByRole = _render11.getByRole;
218
+
219
+ var switchEl = getByRole("switch");
220
+ var label = getByText("Default label");
221
+ expect(switchEl.getAttribute("aria-labelledby")).toBe(label.id);
222
+ expect(switchEl.getAttribute("aria-checked")).toBe("false");
223
+ expect(switchEl.getAttribute("aria-disabled")).toBe("true");
224
+ });
225
+ });
package/switch/types.d.ts CHANGED
@@ -1,11 +1,15 @@
1
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
- declare type Margin = {
1
+ export declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
+ export declare type Margin = {
3
3
  top?: Space;
4
4
  bottom?: Space;
5
5
  left?: Space;
6
6
  right?: Space;
7
7
  };
8
8
  declare type Props = {
9
+ /**
10
+ * Initial state of the switch, 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 uncontrolled
11
15
  * and the checked attribute will be managed internally by the component.
@@ -38,9 +42,9 @@ declare type Props = {
38
42
  */
39
43
  onChange?: (checked: boolean) => void;
40
44
  /**
41
- * If true, the switch will change its appearence, showing that the value is required.
45
+ * If true, the component will display '(Optional)' next to the label.
42
46
  */
43
- required?: boolean;
47
+ optional?: boolean;
44
48
  /**
45
49
  * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
46
50
  * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
@@ -55,4 +59,8 @@ declare type Props = {
55
59
  */
56
60
  tabIndex?: number;
57
61
  };
62
+ /**
63
+ * Reference to the component.
64
+ */
65
+ export declare type RefType = HTMLDivElement;
58
66
  export default Props;
@@ -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";
@@ -66,7 +66,7 @@ var DxcTableContainer = _styledComponents["default"].div(_templateObject || (_te
66
66
  return props.theme.scrollBarTrackColor;
67
67
  });
68
68
 
69
- var DxcTableContent = _styledComponents["default"].table(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n border-collapse: collapse;\n width: 100%;\n\n & tr {\n border-bottom: ", ";\n }\n & td {\n background-color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n text-transform: ", ";\n text-align: ", ";\n line-height: ", ";\n padding: ", ";\n }\n & th {\n background-color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n text-transform: ", ";\n text-align: ", ";\n line-height: ", ";\n padding: ", ";\n }\n & th:first-child {\n border-top-left-radius: ", ";\n }\n & th:last-child {\n border-top-right-radius: ", ";\n }\n"])), function (props) {
69
+ var DxcTableContent = _styledComponents["default"].table(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n border-collapse: collapse;\n width: 100%;\n\n & tr {\n border-bottom: ", ";\n height: 60px;\n }\n & td {\n background-color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n text-transform: ", ";\n text-align: ", ";\n line-height: ", ";\n padding: ", ";\n }\n & th {\n background-color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n text-transform: ", ";\n text-align: ", ";\n line-height: ", ";\n padding: ", ";\n }\n & th:first-child {\n border-top-left-radius: ", ";\n }\n & th:last-child {\n border-top-right-radius: ", ";\n }\n & td:last-child {\n padding-right: 40px;\n }\n"])), function (props) {
70
70
  return "".concat(props.theme.rowSeparatorThickness, " ").concat(props.theme.rowSeparatorStyle, " ").concat(props.theme.rowSeparatorColor);
71
71
  }, function (props) {
72
72
  return props.theme.dataBackgroundColor;
@@ -0,0 +1,277 @@
1
+ import React from "react";
2
+ import DxcTable from "./Table";
3
+ import Title from "../../.storybook/components/Title";
4
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
+
6
+ export default {
7
+ title: "Table",
8
+ component: DxcTable,
9
+ };
10
+
11
+ export const Chromatic = () => (
12
+ <>
13
+ <ExampleContainer>
14
+ <Title title="Default" theme="light" level={4} />
15
+ <DxcTable>
16
+ <tr>
17
+ <th>header 1</th>
18
+ <th>header 2</th>
19
+ <th>header 3</th>
20
+ </tr>
21
+ <tr>
22
+ <td>cell 1</td>
23
+ <td>cell 2</td>
24
+ <td>cell 3</td>
25
+ </tr>
26
+ <tr>
27
+ <td>cell 4</td>
28
+ <td>cell 5</td>
29
+ <td>cell 6</td>
30
+ </tr>
31
+ <tr>
32
+ <td>cell 7</td>
33
+ <td>cell 8</td>
34
+ <td>Cell 9</td>
35
+ </tr>
36
+ </DxcTable>
37
+ </ExampleContainer>
38
+ <ExampleContainer>
39
+ <Title title="With scrollbar" theme="light" level={4} />
40
+ <div
41
+ style={{ height: 200 + "px", display: "flex", flexDirection: "row", width: 100 + "%", marginBottom: 50 + "px" }}
42
+ >
43
+ <DxcTable>
44
+ <tr>
45
+ <th>
46
+ header<br></br>subheader
47
+ </th>
48
+ <th>
49
+ header<br></br>subheader
50
+ </th>
51
+ <th>
52
+ header<br></br>subheader
53
+ </th>
54
+ </tr>
55
+ <tr>
56
+ <td>
57
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
58
+ dolore magna aliqua.
59
+ </td>
60
+ <td>
61
+ Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo
62
+ consequat.
63
+ </td>
64
+ <td>
65
+ Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.
66
+ </td>
67
+ </tr>
68
+ <tr>
69
+ <td>cell data</td>
70
+ <td>cell data</td>
71
+ <td>cell data</td>
72
+ </tr>
73
+ <tr>
74
+ <td>cell data</td>
75
+ <td>cell data</td>
76
+ <td>cell data</td>
77
+ </tr>
78
+ <tr>
79
+ <td>cell data</td>
80
+ <td>cell data</td>
81
+ <td>cell data</td>
82
+ </tr>
83
+ <tr>
84
+ <td>cell data</td>
85
+ <td>cell data</td>
86
+ <td>cell data</td>
87
+ </tr>
88
+ <tr>
89
+ <td>cell data</td>
90
+ <td>cell data</td>
91
+ <td>cell data</td>
92
+ </tr>
93
+ <tr>
94
+ <td>cell data</td>
95
+ <td>cell data</td>
96
+ <td>cell data</td>
97
+ </tr>
98
+ <tr>
99
+ <td>cell data</td>
100
+ <td>cell data</td>
101
+ <td>cell data</td>
102
+ </tr>
103
+ <tr>
104
+ <td>cell data</td>
105
+ <td>cell data</td>
106
+ <td>cell data</td>
107
+ </tr>
108
+ </DxcTable>
109
+ </div>
110
+ </ExampleContainer>
111
+ <Title title="Margins" theme="light" level={2} />
112
+ <ExampleContainer>
113
+ <Title title="Xxsmall margin" theme="light" level={4} />
114
+ <DxcTable margin="xxsmall">
115
+ <tr>
116
+ <th>header 1</th>
117
+ <th>header 2</th>
118
+ <th>header 3</th>
119
+ </tr>
120
+ <tr>
121
+ <td>cell 1</td>
122
+ <td>cell 2</td>
123
+ <td>cell 3</td>
124
+ </tr>
125
+ <tr>
126
+ <td>cell 4</td>
127
+ <td>cell 5</td>
128
+ <td>cell 6</td>
129
+ </tr>
130
+ <tr>
131
+ <td>cell 7</td>
132
+ <td>cell 8</td>
133
+ <td>Cell 9</td>
134
+ </tr>
135
+ </DxcTable>
136
+ <Title title="Xsmall margin" theme="light" level={4} />
137
+ <DxcTable margin="xsmall">
138
+ <tr>
139
+ <th>header 1</th>
140
+ <th>header 2</th>
141
+ <th>header 3</th>
142
+ </tr>
143
+ <tr>
144
+ <td>cell 1</td>
145
+ <td>cell 2</td>
146
+ <td>cell 3</td>
147
+ </tr>
148
+ <tr>
149
+ <td>cell 4</td>
150
+ <td>cell 5</td>
151
+ <td>cell 6</td>
152
+ </tr>
153
+ <tr>
154
+ <td>cell 7</td>
155
+ <td>cell 8</td>
156
+ <td>Cell 9</td>
157
+ </tr>
158
+ </DxcTable>
159
+ <Title title="Small margin" theme="light" level={4} />
160
+ <DxcTable margin="small">
161
+ <tr>
162
+ <th>header 1</th>
163
+ <th>header 2</th>
164
+ <th>header 3</th>
165
+ </tr>
166
+ <tr>
167
+ <td>cell 1</td>
168
+ <td>cell 2</td>
169
+ <td>cell 3</td>
170
+ </tr>
171
+ <tr>
172
+ <td>cell 4</td>
173
+ <td>cell 5</td>
174
+ <td>cell 6</td>
175
+ </tr>
176
+ <tr>
177
+ <td>cell 7</td>
178
+ <td>cell 8</td>
179
+ <td>Cell 9</td>
180
+ </tr>
181
+ </DxcTable>
182
+ <Title title="Medium margin" theme="light" level={4} />
183
+ <DxcTable margin="medium">
184
+ <tr>
185
+ <th>header 1</th>
186
+ <th>header 2</th>
187
+ <th>header 3</th>
188
+ </tr>
189
+ <tr>
190
+ <td>cell 1</td>
191
+ <td>cell 2</td>
192
+ <td>cell 3</td>
193
+ </tr>
194
+ <tr>
195
+ <td>cell 4</td>
196
+ <td>cell 5</td>
197
+ <td>cell 6</td>
198
+ </tr>
199
+ <tr>
200
+ <td>cell 7</td>
201
+ <td>cell 8</td>
202
+ <td>Cell 9</td>
203
+ </tr>
204
+ </DxcTable>
205
+ <Title title="Large margin" theme="light" level={4} />
206
+ <DxcTable margin="large">
207
+ <tr>
208
+ <th>header 1</th>
209
+ <th>header 2</th>
210
+ <th>header 3</th>
211
+ </tr>
212
+ <tr>
213
+ <td>cell 1</td>
214
+ <td>cell 2</td>
215
+ <td>cell 3</td>
216
+ </tr>
217
+ <tr>
218
+ <td>cell 4</td>
219
+ <td>cell 5</td>
220
+ <td>cell 6</td>
221
+ </tr>
222
+ <tr>
223
+ <td>cell 7</td>
224
+ <td>cell 8</td>
225
+ <td>Cell 9</td>
226
+ </tr>
227
+ </DxcTable>
228
+ <Title title="Xlarge margin" theme="light" level={4} />
229
+ <DxcTable margin="xlarge">
230
+ <tr>
231
+ <th>header 1</th>
232
+ <th>header 2</th>
233
+ <th>header 3</th>
234
+ </tr>
235
+ <tr>
236
+ <td>cell 1</td>
237
+ <td>cell 2</td>
238
+ <td>cell 3</td>
239
+ </tr>
240
+ <tr>
241
+ <td>cell 4</td>
242
+ <td>cell 5</td>
243
+ <td>cell 6</td>
244
+ </tr>
245
+ <tr>
246
+ <td>cell 7</td>
247
+ <td>cell 8</td>
248
+ <td>Cell 9</td>
249
+ </tr>
250
+ </DxcTable>
251
+ <Title title="Xxlarge margin" theme="light" level={4} />
252
+ <DxcTable margin="xxlarge">
253
+ <tr>
254
+ <th>header 1</th>
255
+ <th>header 2</th>
256
+ <th>header 3</th>
257
+ </tr>
258
+ <tr>
259
+ <td>cell 1</td>
260
+ <td>cell 2</td>
261
+ <td>cell 3</td>
262
+ </tr>
263
+ <tr>
264
+ <td>cell 4</td>
265
+ <td>cell 5</td>
266
+ <td>cell 6</td>
267
+ </tr>
268
+ <tr>
269
+ <td>cell 7</td>
270
+ <td>cell 8</td>
271
+ <td>Cell 9</td>
272
+ </tr>
273
+ </DxcTable>
274
+ <hr />
275
+ </ExampleContainer>
276
+ </>
277
+ );
@@ -0,0 +1,26 @@
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 _Table = _interopRequireDefault(require("./Table"));
10
+
11
+ describe("Table component tests", function () {
12
+ test("Table renders with correct content", function () {
13
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Table["default"], null, /*#__PURE__*/_react["default"].createElement("tr", null, /*#__PURE__*/_react["default"].createElement("th", null, "header-1"), /*#__PURE__*/_react["default"].createElement("th", null, "header-2"), /*#__PURE__*/_react["default"].createElement("th", null, "header-3")), /*#__PURE__*/_react["default"].createElement("tr", null, /*#__PURE__*/_react["default"].createElement("td", null, "cell-1"), /*#__PURE__*/_react["default"].createElement("td", null, "cell-2"), /*#__PURE__*/_react["default"].createElement("td", null, "cell-3")), /*#__PURE__*/_react["default"].createElement("tr", null, /*#__PURE__*/_react["default"].createElement("td", null, "cell-4"), /*#__PURE__*/_react["default"].createElement("td", null, "cell-5"), /*#__PURE__*/_react["default"].createElement("td", null, "cell-6")))),
14
+ getByText = _render.getByText;
15
+
16
+ expect(getByText("header-1")).toBeTruthy();
17
+ expect(getByText("header-2")).toBeTruthy();
18
+ expect(getByText("header-3")).toBeTruthy();
19
+ expect(getByText("cell-1")).toBeTruthy();
20
+ expect(getByText("cell-2")).toBeTruthy();
21
+ expect(getByText("cell-3")).toBeTruthy();
22
+ expect(getByText("cell-4")).toBeTruthy();
23
+ expect(getByText("cell-5")).toBeTruthy();
24
+ expect(getByText("cell-6")).toBeTruthy();
25
+ });
26
+ });
@@ -0,0 +1,21 @@
1
+ /// <reference types="react" />
2
+ declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ declare type Margin = {
4
+ top?: Space;
5
+ bottom?: Space;
6
+ left?: Space;
7
+ right?: Space;
8
+ };
9
+ declare type Props = {
10
+ /**
11
+ * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
12
+ * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
13
+ */
14
+ margin?: Space | Margin;
15
+ /**
16
+ * The center section of the table. Can be used to render custom
17
+ * content in this area.
18
+ */
19
+ children: React.ReactNode;
20
+ };
21
+ export default Props;
package/table/types.js ADDED
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
package/tabs/Tab.d.ts ADDED
@@ -0,0 +1,4 @@
1
+ import React from "react";
2
+ import { TabProps } from "./types";
3
+ declare const _default: React.MemoExoticComponent<React.ForwardRefExoticComponent<TabProps & React.RefAttributes<HTMLButtonElement>>>;
4
+ export default _default;