@dxc-technology/halstack-react 0.0.0-b9523dd → 0.0.0-b98c25c

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 (315) 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.jsx → Box.stories.tsx} +0 -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 +62 -83
  41. package/button/Button.stories.tsx +231 -241
  42. package/button/Button.test.js +35 -0
  43. package/button/types.d.ts +10 -14
  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 +1 -1
  50. package/checkbox/Checkbox.js +104 -108
  51. package/checkbox/Checkbox.stories.tsx +124 -128
  52. package/checkbox/Checkbox.test.js +155 -0
  53. package/checkbox/types.d.ts +11 -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 +319 -380
  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.js +50 -53
  66. package/dialog/Dialog.stories.tsx +267 -0
  67. package/dialog/Dialog.test.js +70 -0
  68. package/dialog/types.d.ts +3 -2
  69. package/dropdown/Dropdown.d.ts +1 -1
  70. package/dropdown/Dropdown.js +243 -273
  71. package/dropdown/Dropdown.stories.tsx +312 -0
  72. package/dropdown/Dropdown.test.js +591 -0
  73. package/dropdown/DropdownMenu.d.ts +4 -0
  74. package/dropdown/DropdownMenu.js +80 -0
  75. package/dropdown/DropdownMenuItem.d.ts +4 -0
  76. package/dropdown/DropdownMenuItem.js +92 -0
  77. package/dropdown/types.d.ts +30 -19
  78. package/file-input/FileInput.d.ts +4 -0
  79. package/file-input/FileInput.js +172 -111
  80. package/file-input/FileInput.stories.tsx +507 -0
  81. package/file-input/FileInput.test.js +457 -0
  82. package/file-input/FileItem.d.ts +14 -0
  83. package/file-input/FileItem.js +16 -23
  84. package/file-input/types.d.ts +112 -0
  85. package/file-input/types.js +5 -0
  86. package/flex/Flex.d.ts +4 -0
  87. package/flex/Flex.js +57 -0
  88. package/flex/Flex.stories.tsx +103 -0
  89. package/flex/types.d.ts +21 -0
  90. package/flex/types.js +5 -0
  91. package/footer/Footer.d.ts +1 -1
  92. package/footer/Footer.js +32 -113
  93. package/footer/{Footer.stories.jsx → Footer.stories.tsx} +5 -19
  94. package/footer/Footer.test.js +109 -0
  95. package/footer/Icons.d.ts +2 -0
  96. package/footer/Icons.js +4 -4
  97. package/footer/types.d.ts +23 -18
  98. package/header/Header.js +97 -116
  99. package/header/Header.stories.tsx +172 -0
  100. package/header/Header.test.js +79 -0
  101. package/header/Icons.d.ts +2 -0
  102. package/header/Icons.js +2 -2
  103. package/header/types.d.ts +7 -4
  104. package/heading/Heading.d.ts +4 -0
  105. package/heading/Heading.js +7 -24
  106. package/heading/Heading.stories.tsx +54 -0
  107. package/heading/Heading.test.js +186 -0
  108. package/heading/types.d.ts +33 -0
  109. package/heading/types.js +5 -0
  110. package/inset/Inset.d.ts +3 -0
  111. package/inset/Inset.js +51 -0
  112. package/inset/Inset.stories.tsx +229 -0
  113. package/inset/types.d.ts +37 -0
  114. package/inset/types.js +5 -0
  115. package/layout/ApplicationLayout.d.ts +20 -0
  116. package/layout/ApplicationLayout.js +71 -135
  117. package/layout/ApplicationLayout.stories.tsx +162 -0
  118. package/layout/Icons.d.ts +5 -0
  119. package/layout/Icons.js +13 -2
  120. package/layout/SidenavContext.d.ts +5 -0
  121. package/layout/SidenavContext.js +19 -0
  122. package/layout/types.d.ts +42 -0
  123. package/layout/types.js +5 -0
  124. package/link/Link.d.ts +4 -0
  125. package/link/Link.js +60 -107
  126. package/link/Link.stories.tsx +193 -0
  127. package/link/Link.test.js +83 -0
  128. package/link/types.d.ts +54 -0
  129. package/link/types.js +5 -0
  130. package/main.d.ts +12 -12
  131. package/main.js +64 -58
  132. package/number-input/NumberInput.d.ts +4 -0
  133. package/number-input/NumberInput.js +16 -68
  134. package/number-input/{NumberInput.stories.jsx → NumberInput.stories.tsx} +5 -5
  135. package/number-input/NumberInput.test.js +506 -0
  136. package/number-input/NumberInputContext.d.ts +4 -0
  137. package/number-input/NumberInputContext.js +5 -2
  138. package/number-input/numberInputContextTypes.d.ts +19 -0
  139. package/number-input/numberInputContextTypes.js +5 -0
  140. package/number-input/types.d.ts +124 -0
  141. package/number-input/types.js +5 -0
  142. package/package.json +16 -12
  143. package/paginator/Paginator.js +19 -46
  144. package/paginator/Paginator.test.js +308 -0
  145. package/paragraph/Paragraph.d.ts +6 -0
  146. package/paragraph/Paragraph.js +38 -0
  147. package/paragraph/Paragraph.stories.tsx +44 -0
  148. package/password-input/PasswordInput.d.ts +4 -0
  149. package/password-input/PasswordInput.js +22 -55
  150. package/password-input/{PasswordInput.stories.jsx → PasswordInput.stories.tsx} +3 -3
  151. package/password-input/PasswordInput.test.js +180 -0
  152. package/password-input/types.d.ts +110 -0
  153. package/password-input/types.js +5 -0
  154. package/progress-bar/ProgressBar.d.ts +2 -2
  155. package/progress-bar/ProgressBar.js +59 -53
  156. package/progress-bar/ProgressBar.stories.jsx +60 -0
  157. package/progress-bar/ProgressBar.test.js +110 -0
  158. package/progress-bar/types.d.ts +3 -4
  159. package/quick-nav/QuickNav.d.ts +4 -0
  160. package/quick-nav/QuickNav.js +115 -0
  161. package/quick-nav/QuickNav.stories.tsx +300 -0
  162. package/quick-nav/types.d.ts +21 -0
  163. package/quick-nav/types.js +5 -0
  164. package/radio-group/Radio.d.ts +4 -0
  165. package/radio-group/Radio.js +156 -0
  166. package/radio-group/RadioGroup.d.ts +4 -0
  167. package/radio-group/RadioGroup.js +279 -0
  168. package/radio-group/RadioGroup.stories.tsx +101 -0
  169. package/radio-group/RadioGroup.test.js +665 -0
  170. package/radio-group/types.d.ts +114 -0
  171. package/radio-group/types.js +5 -0
  172. package/resultsetTable/ResultsetTable.d.ts +4 -0
  173. package/resultsetTable/ResultsetTable.js +9 -29
  174. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  175. package/resultsetTable/ResultsetTable.test.js +348 -0
  176. package/resultsetTable/types.d.ts +67 -0
  177. package/resultsetTable/types.js +5 -0
  178. package/select/Icons.d.ts +10 -0
  179. package/select/Icons.js +93 -0
  180. package/select/Listbox.d.ts +4 -0
  181. package/select/Listbox.js +198 -0
  182. package/select/Option.d.ts +4 -0
  183. package/select/Option.js +110 -0
  184. package/select/Select.d.ts +4 -0
  185. package/select/Select.js +158 -380
  186. package/select/Select.stories.tsx +627 -0
  187. package/select/Select.test.js +2175 -0
  188. package/select/types.d.ts +210 -0
  189. package/select/types.js +5 -0
  190. package/sidenav/Sidenav.d.ts +10 -0
  191. package/sidenav/Sidenav.js +186 -63
  192. package/sidenav/Sidenav.stories.tsx +180 -0
  193. package/sidenav/Sidenav.test.js +44 -0
  194. package/sidenav/types.d.ts +73 -0
  195. package/sidenav/types.js +5 -0
  196. package/slider/Slider.d.ts +1 -1
  197. package/slider/Slider.js +145 -109
  198. package/slider/Slider.stories.tsx +183 -0
  199. package/slider/Slider.test.js +250 -0
  200. package/slider/types.d.ts +8 -9
  201. package/spinner/Spinner.js +3 -3
  202. package/spinner/Spinner.stories.jsx +1 -0
  203. package/spinner/Spinner.test.js +64 -0
  204. package/switch/Switch.d.ts +2 -2
  205. package/switch/Switch.js +149 -67
  206. package/switch/Switch.stories.tsx +138 -0
  207. package/switch/Switch.test.js +225 -0
  208. package/switch/types.d.ts +9 -6
  209. package/table/Table.js +3 -3
  210. package/table/Table.stories.jsx +2 -1
  211. package/table/Table.test.js +26 -0
  212. package/tabs/Tab.d.ts +4 -0
  213. package/tabs/Tab.js +135 -0
  214. package/tabs/Tabs.d.ts +1 -1
  215. package/tabs/Tabs.js +364 -108
  216. package/tabs/Tabs.stories.tsx +186 -0
  217. package/tabs/Tabs.test.js +351 -0
  218. package/tabs/types.d.ts +41 -20
  219. package/tabs-nav/NavTabs.d.ts +8 -0
  220. package/tabs-nav/NavTabs.js +125 -0
  221. package/tabs-nav/NavTabs.stories.tsx +170 -0
  222. package/tabs-nav/NavTabs.test.js +82 -0
  223. package/tabs-nav/Tab.d.ts +4 -0
  224. package/tabs-nav/Tab.js +130 -0
  225. package/tabs-nav/types.d.ts +53 -0
  226. package/tabs-nav/types.js +5 -0
  227. package/tag/Tag.d.ts +4 -0
  228. package/tag/Tag.js +21 -52
  229. package/tag/{Tag.stories.jsx → Tag.stories.tsx} +26 -29
  230. package/tag/Tag.test.js +60 -0
  231. package/tag/types.d.ts +69 -0
  232. package/tag/types.js +5 -0
  233. package/text-input/Icons.d.ts +8 -0
  234. package/text-input/Icons.js +60 -0
  235. package/text-input/Suggestion.d.ts +4 -0
  236. package/text-input/Suggestion.js +57 -0
  237. package/text-input/Suggestions.d.ts +4 -0
  238. package/text-input/Suggestions.js +134 -0
  239. package/text-input/TextInput.d.ts +4 -0
  240. package/text-input/TextInput.js +166 -328
  241. package/text-input/TextInput.stories.tsx +481 -0
  242. package/text-input/TextInput.test.js +1713 -0
  243. package/text-input/types.d.ts +192 -0
  244. package/text-input/types.js +5 -0
  245. package/textarea/Textarea.d.ts +4 -0
  246. package/textarea/Textarea.js +39 -79
  247. package/textarea/Textarea.stories.jsx +37 -15
  248. package/textarea/Textarea.test.js +437 -0
  249. package/textarea/types.d.ts +137 -0
  250. package/textarea/types.js +5 -0
  251. package/toggle-group/ToggleGroup.d.ts +4 -0
  252. package/toggle-group/ToggleGroup.js +18 -46
  253. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  254. package/toggle-group/ToggleGroup.test.js +156 -0
  255. package/toggle-group/types.d.ts +105 -0
  256. package/toggle-group/types.js +5 -0
  257. package/typography/Typography.d.ts +4 -0
  258. package/typography/Typography.js +131 -0
  259. package/typography/Typography.stories.tsx +198 -0
  260. package/typography/types.d.ts +18 -0
  261. package/typography/types.js +5 -0
  262. package/useTheme.d.ts +2 -0
  263. package/useTheme.js +2 -2
  264. package/useTranslatedLabels.d.ts +2 -0
  265. package/useTranslatedLabels.js +20 -0
  266. package/wizard/Wizard.d.ts +4 -0
  267. package/wizard/Wizard.js +118 -104
  268. package/wizard/Wizard.stories.tsx +233 -0
  269. package/wizard/Wizard.test.js +141 -0
  270. package/wizard/types.d.ts +65 -0
  271. package/wizard/types.js +5 -0
  272. package/ThemeContext.js +0 -246
  273. package/V3Select/V3Select.js +0 -455
  274. package/V3Select/index.d.ts +0 -27
  275. package/V3Textarea/V3Textarea.js +0 -260
  276. package/V3Textarea/index.d.ts +0 -27
  277. package/box/index.d.ts +0 -25
  278. package/chip/index.d.ts +0 -22
  279. package/date/Date.js +0 -373
  280. package/date/index.d.ts +0 -27
  281. package/file-input/index.d.ts +0 -81
  282. package/heading/index.d.ts +0 -17
  283. package/input-text/Icons.js +0 -22
  284. package/input-text/InputText.js +0 -611
  285. package/input-text/index.d.ts +0 -36
  286. package/link/index.d.ts +0 -23
  287. package/number-input/index.d.ts +0 -113
  288. package/password-input/index.d.ts +0 -94
  289. package/radio/Radio.d.ts +0 -4
  290. package/radio/Radio.js +0 -174
  291. package/radio/Radio.stories.tsx +0 -192
  292. package/radio/types.d.ts +0 -54
  293. package/resultsetTable/index.d.ts +0 -19
  294. package/select/index.d.ts +0 -131
  295. package/sidenav/index.d.ts +0 -13
  296. package/tag/index.d.ts +0 -24
  297. package/text-input/index.d.ts +0 -135
  298. package/textarea/index.d.ts +0 -117
  299. package/toggle/Toggle.js +0 -186
  300. package/toggle/index.d.ts +0 -21
  301. package/toggle-group/index.d.ts +0 -21
  302. package/upload/Upload.js +0 -201
  303. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  304. package/upload/buttons-upload/Icons.js +0 -40
  305. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  306. package/upload/dragAndDropArea/Icons.js +0 -39
  307. package/upload/file-upload/FileToUpload.js +0 -115
  308. package/upload/file-upload/Icons.js +0 -66
  309. package/upload/files-upload/FilesToUpload.js +0 -109
  310. package/upload/index.d.ts +0 -15
  311. package/upload/transaction/Icons.js +0 -160
  312. package/upload/transaction/Transaction.js +0 -104
  313. package/upload/transactions/Transactions.js +0 -94
  314. package/wizard/Icons.js +0 -65
  315. package/wizard/index.d.ts +0 -18
@@ -0,0 +1,250 @@
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 _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
10
+
11
+ var _Slider = _interopRequireDefault(require("./Slider"));
12
+
13
+ describe("Slider component tests", function () {
14
+ test("Slider renders with correct text and label id", function () {
15
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
16
+ label: "label",
17
+ minValue: 0,
18
+ maxValue: 100,
19
+ showLimitsValues: true
20
+ })),
21
+ getByText = _render.getByText,
22
+ getByRole = _render.getByRole;
23
+
24
+ expect(getByText("0")).toBeTruthy();
25
+ expect(getByText("100")).toBeTruthy();
26
+ var sliderId = getByText("label").getAttribute("id");
27
+ expect(getByRole("slider").getAttribute("aria-labelledby")).toBe(sliderId);
28
+ expect(getByRole("slider").getAttribute("aria-orientation")).toBe("horizontal");
29
+ });
30
+ test("Slider renders with correct initial value when it is uncontrolled", function () {
31
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
32
+ defaultValue: 30,
33
+ minValue: 0,
34
+ maxValue: 100,
35
+ showLimitsValues: true,
36
+ showInput: true
37
+ })),
38
+ getByRole = _render2.getByRole;
39
+
40
+ var slider = getByRole("slider");
41
+ var input = getByRole("textbox");
42
+ expect(slider.getAttribute("aria-valuenow")).toBe("30");
43
+ expect(input.value).toBe("30");
44
+ });
45
+ test("Slider correct limit values", function () {
46
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
47
+ defaultValue: 125,
48
+ minValue: 30,
49
+ maxValue: 125,
50
+ showLimitsValues: true
51
+ })),
52
+ getByRole = _render3.getByRole,
53
+ getByText = _render3.getByText;
54
+
55
+ var slider = getByRole("slider");
56
+ expect(slider.getAttribute("aria-valuemin")).toBe("30");
57
+ expect(slider.getAttribute("aria-valuemax")).toBe("125");
58
+
59
+ _userEvent["default"].tab();
60
+
61
+ _react2.fireEvent.keyDown(slider, {
62
+ key: "ArrowRight",
63
+ code: "ArrowRight",
64
+ keyCode: 39,
65
+ charCode: 39
66
+ });
67
+
68
+ expect(slider.getAttribute("aria-valuenow")).toBe("125");
69
+ expect(getByText("30")).toBeTruthy();
70
+ expect(getByText("125")).toBeTruthy();
71
+ });
72
+ test("Calls correct function onChange in controlled slider", function () {
73
+ var onChange = jest.fn();
74
+
75
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
76
+ minValue: 0,
77
+ maxValue: 100,
78
+ onChange: onChange,
79
+ showLimitsValues: true,
80
+ value: 13,
81
+ showInput: true
82
+ })),
83
+ getByRole = _render4.getByRole;
84
+
85
+ expect(getByRole("slider").getAttribute("aria-valuenow")).toBe("13");
86
+ expect(getByRole("textbox").value).toBe("13");
87
+ (0, _react2.act)(function () {
88
+ _react2.fireEvent.change(getByRole("textbox"), {
89
+ target: {
90
+ value: 25
91
+ }
92
+ });
93
+ });
94
+ expect(onChange).toHaveBeenCalledWith(25);
95
+ expect(getByRole("slider").getAttribute("aria-valuenow")).toBe("13");
96
+ expect(getByRole("textbox").value).toBe("13");
97
+ });
98
+ test("Calls correct function onChange in uncontrolled slider", function () {
99
+ var onChange = jest.fn();
100
+
101
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
102
+ minValue: 0,
103
+ maxValue: 100,
104
+ onChange: onChange,
105
+ showLimitsValues: true,
106
+ showInput: true
107
+ })),
108
+ getByRole = _render5.getByRole;
109
+
110
+ (0, _react2.act)(function () {
111
+ _react2.fireEvent.change(getByRole("textbox"), {
112
+ target: {
113
+ value: 25
114
+ }
115
+ });
116
+ });
117
+ expect(onChange).toHaveBeenCalledWith(25);
118
+ expect(getByRole("slider").getAttribute("aria-valuenow")).toBe("25");
119
+ expect(getByRole("textbox").value).toBe("25");
120
+ });
121
+ test("Disabled slider have disabled input and slider", function () {
122
+ var onChange = jest.fn();
123
+
124
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
125
+ minValue: 0,
126
+ maxValue: 100,
127
+ onChange: onChange,
128
+ showLimitsValues: true,
129
+ disabled: true,
130
+ showInput: true,
131
+ value: 13
132
+ })),
133
+ getByRole = _render6.getByRole;
134
+
135
+ (0, _react2.act)(function () {
136
+ _react2.fireEvent.change(getByRole("textbox"), {
137
+ target: {
138
+ value: 25
139
+ }
140
+ });
141
+ });
142
+ expect(getByRole("textbox").hasAttribute("disabled")).toBeTruthy();
143
+ expect(getByRole("textbox").value).toBe("13");
144
+ expect(getByRole("slider").hasAttribute("disabled")).toBeTruthy();
145
+ });
146
+ test("Calls correct function onDragEnd when it is uncontrolled", function () {
147
+ var onDragEnd = jest.fn();
148
+
149
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
150
+ minValue: 0,
151
+ maxValue: 150,
152
+ onDragEnd: onDragEnd,
153
+ showInput: true
154
+ })),
155
+ getByRole = _render7.getByRole;
156
+
157
+ var slider = getByRole("slider");
158
+ (0, _react2.act)(function () {
159
+ _react2.fireEvent.mouseDown(slider);
160
+ });
161
+ (0, _react2.act)(function () {
162
+ _react2.fireEvent.mouseUp(slider, {
163
+ target: {
164
+ value: 120
165
+ }
166
+ });
167
+ });
168
+ expect(onDragEnd).toHaveBeenCalledWith("120");
169
+ });
170
+ test("Calls correct function onDragEnd when it is controlled", function () {
171
+ var onDragEnd = jest.fn();
172
+
173
+ var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
174
+ minValue: 0,
175
+ maxValue: 150,
176
+ value: 50,
177
+ onDragEnd: onDragEnd,
178
+ showInput: true
179
+ })),
180
+ getByRole = _render8.getByRole;
181
+
182
+ var slider = getByRole("slider");
183
+ (0, _react2.act)(function () {
184
+ _react2.fireEvent.mouseDown(slider);
185
+ });
186
+ (0, _react2.act)(function () {
187
+ _react2.fireEvent.mouseUp(slider, {
188
+ target: {
189
+ value: 120
190
+ }
191
+ });
192
+ });
193
+ expect(onDragEnd).toHaveBeenCalledWith("120");
194
+ expect(slider.getAttribute("aria-valuenow")).toBe("50");
195
+ });
196
+ test("Calls correct function labelFormatCallback", function () {
197
+ var labelFormatCallback = jest.fn(function (x) {
198
+ return "".concat(x, "$");
199
+ });
200
+
201
+ var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
202
+ minValue: 0,
203
+ maxValue: 100,
204
+ showLimitsValues: true,
205
+ showInput: true,
206
+ value: 25,
207
+ labelFormatCallback: labelFormatCallback
208
+ })),
209
+ getByText = _render9.getByText;
210
+
211
+ expect(getByText("0$")).toBeTruthy();
212
+ expect(getByText("100$")).toBeTruthy();
213
+ expect(labelFormatCallback).toHaveBeenCalledTimes(2);
214
+ });
215
+ test("Change value correctly to 0 from external function", function () {
216
+ var onChange = jest.fn();
217
+
218
+ var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
219
+ minValue: 0,
220
+ maxValue: 100,
221
+ onChange: onChange,
222
+ showLimitsValues: true,
223
+ value: 13,
224
+ showInput: true
225
+ })),
226
+ rerender = _render10.rerender,
227
+ getByRole = _render10.getByRole;
228
+
229
+ var slider = getByRole("slider");
230
+
231
+ _userEvent["default"].tab();
232
+
233
+ _react2.fireEvent.keyDown(slider, {
234
+ key: "ArrowRight",
235
+ code: "ArrowRight",
236
+ keyCode: 39,
237
+ charCode: 39
238
+ });
239
+
240
+ rerender( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
241
+ minValue: 0,
242
+ maxValue: 100,
243
+ onChange: onChange,
244
+ showLimitsValues: true,
245
+ value: 0,
246
+ showInput: true
247
+ }));
248
+ expect(slider.getAttribute("aria-valuenow")).toBe("0");
249
+ });
250
+ });
package/slider/types.d.ts CHANGED
@@ -1,6 +1,5 @@
1
- declare type Size = "medium" | "large" | "fillParent";
2
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- declare type Margin = {
1
+ export declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
+ export declare type Margin = {
4
3
  top?: Space;
5
4
  bottom?: Space;
6
5
  left?: Space;
@@ -15,6 +14,10 @@ declare type Props = {
15
14
  * Name attribute of the input element.
16
15
  */
17
16
  name?: string;
17
+ /**
18
+ * Initial value of the slider, only when it is uncontrolled.
19
+ */
20
+ defaultValue?: number;
18
21
  /**
19
22
  * The selected value. If undefined, the component will be uncontrolled and the value will be managed internally by the component.
20
23
  */
@@ -65,7 +68,7 @@ declare type Props = {
65
68
  * This function will be used to format the labels displayed next to the slider.
66
69
  * The value will be passed as parameter and the function must return the formatted value.
67
70
  */
68
- labelFormatCallback?: (value: number) => void;
71
+ labelFormatCallback?: (value: number) => string;
69
72
  /**
70
73
  * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
71
74
  * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
@@ -74,10 +77,6 @@ declare type Props = {
74
77
  /**
75
78
  * Size of the component.
76
79
  */
77
- size?: Size;
78
- /**
79
- * Value of the tabindex attribute.
80
- */
81
- tabIndex?: number;
80
+ size?: "medium" | "large" | "fillParent";
82
81
  };
83
82
  export default Props;
@@ -19,9 +19,9 @@ var _styledComponents = _interopRequireWildcard(require("styled-components"));
19
19
 
20
20
  var _variables = require("../common/variables.js");
21
21
 
22
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
22
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
23
23
 
24
- var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext.js"));
24
+ var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext"));
25
25
 
26
26
  var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11, _templateObject12;
27
27
 
@@ -199,7 +199,7 @@ var SVGSpinner = _styledComponents["default"].svg(_templateObject8 || (_template
199
199
  var CircleSpinner = _styledComponents["default"].circle(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n fill: transparent;\n stroke-linecap: initial;\n vector-effect: non-scaling-stroke;\n animation: ", ";\n stroke: ", ";\n transform-origin: ", ";\n stroke-dasharray: ", ";\n stroke-width: ", ";\n stroke-dashoffset: ", ";\n"])), function (props) {
200
200
  return props.isDeterminated ? "none" : props.mode !== "small" ? "1.4s ease-in-out infinite both svg-circle-large" : "1.4s ease-in-out infinite both svg-circle-small";
201
201
  }, function (props) {
202
- return props.backgroundType === "dark" ? props.theme.trackCircleColorOnDark : props.theme.trackCircleColor;
202
+ return props.backgroundType === "dark" || props.mode === "overlay" ? props.theme.trackCircleColorOverlay : props.theme.trackCircleColor;
203
203
  }, function (props) {
204
204
  return !props.isDeterminated ? "50% 50%" : "";
205
205
  }, function (props) {
@@ -62,6 +62,7 @@ export const Chromatic = () => (
62
62
  <DxcSpinner margin="xlarge" mode="small" value="75"></DxcSpinner>
63
63
  <Title title="Xxlarge margin" theme="light" level={4} />
64
64
  <DxcSpinner margin="xxlarge" mode="small" value="75"></DxcSpinner>
65
+ <hr />
65
66
  </ExampleContainer>
66
67
  </>
67
68
  );
@@ -0,0 +1,64 @@
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 _Spinner = _interopRequireDefault(require("./Spinner"));
10
+
11
+ describe("Spinner component tests", function () {
12
+ test("Spinner renders with correct label", function () {
13
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Spinner["default"], {
14
+ label: "test-loading"
15
+ })),
16
+ getByText = _render.getByText;
17
+
18
+ expect(getByText("test-loading")).toBeTruthy();
19
+ });
20
+ test("Spinner shows value correctly", function () {
21
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Spinner["default"], {
22
+ label: "test-loading",
23
+ value: 75,
24
+ showValue: true
25
+ })),
26
+ getByText = _render2.getByText;
27
+
28
+ expect(getByText("75%")).toBeTruthy();
29
+ });
30
+ test("Small spinner hides value and label correctly", function () {
31
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Spinner["default"], {
32
+ mode: "small",
33
+ label: "test-loading",
34
+ value: 75,
35
+ showValue: true
36
+ })),
37
+ queryByText = _render3.queryByText;
38
+
39
+ expect(queryByText("test-loading")).toBeFalsy();
40
+ expect(queryByText("75%")).toBeFalsy();
41
+ });
42
+ test("Overlay spinner shows value and label correctly", function () {
43
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Spinner["default"], {
44
+ mode: "overlay",
45
+ label: "test-loading",
46
+ value: 75,
47
+ showValue: true
48
+ })),
49
+ getByText = _render4.getByText;
50
+
51
+ expect(getByText("test-loading")).toBeTruthy();
52
+ expect(getByText("75%")).toBeTruthy();
53
+ });
54
+ test("Get spinner by role", function () {
55
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Spinner["default"], {
56
+ label: "test-loading",
57
+ value: 75,
58
+ showValue: true
59
+ })),
60
+ getByRole = _render5.getByRole;
61
+
62
+ expect(getByRole("progressbar")).toBeTruthy();
63
+ });
64
+ });
@@ -1,4 +1,4 @@
1
1
  /// <reference types="react" />
2
- import SwitchPropsType from "./types";
3
- declare const DxcSwitch: ({ checked, value, label, labelPosition, name, disabled, onChange, required, margin, size, tabIndex, }: SwitchPropsType) => JSX.Element;
2
+ import { SwitchPropsType } from "./types";
3
+ declare const DxcSwitch: ({ defaultChecked, checked, value, label, labelPosition, name, disabled, optional, onChange, margin, size, tabIndex, }: SwitchPropsType) => JSX.Element;
4
4
  export default DxcSwitch;