@dxc-technology/halstack-react 0.0.0-cd617f3 → 0.0.0-ce0214d

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 (332) 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 +15 -47
  7. package/accordion/Accordion.stories.tsx +307 -0
  8. package/accordion/Accordion.test.js +72 -0
  9. package/accordion/types.d.ts +8 -8
  10. package/accordion-group/AccordionGroup.d.ts +1 -1
  11. package/accordion-group/AccordionGroup.js +15 -17
  12. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  13. package/accordion-group/AccordionGroup.test.js +151 -0
  14. package/accordion-group/types.d.ts +8 -8
  15. package/alert/Alert.js +6 -3
  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 +84 -0
  25. package/bleed/Bleed.stories.tsx +342 -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 +28 -64
  30. package/box/Box.stories.tsx +132 -0
  31. package/box/Box.test.js +18 -0
  32. package/box/types.d.ts +43 -0
  33. package/box/types.js +5 -0
  34. package/button/Button.d.ts +1 -1
  35. package/button/Button.js +24 -32
  36. package/button/Button.stories.tsx +223 -242
  37. package/button/Button.test.js +35 -0
  38. package/button/types.d.ts +9 -13
  39. package/card/Card.d.ts +4 -0
  40. package/card/Card.js +44 -81
  41. package/card/Card.stories.tsx +201 -0
  42. package/card/Card.test.js +50 -0
  43. package/card/ice-cream.jpg +0 -0
  44. package/card/types.d.ts +67 -0
  45. package/card/types.js +5 -0
  46. package/checkbox/Checkbox.d.ts +1 -1
  47. package/checkbox/Checkbox.js +45 -41
  48. package/checkbox/Checkbox.stories.tsx +188 -0
  49. package/checkbox/Checkbox.test.js +78 -0
  50. package/checkbox/types.d.ts +9 -6
  51. package/chip/Chip.d.ts +4 -0
  52. package/chip/Chip.js +16 -76
  53. package/chip/Chip.stories.tsx +119 -0
  54. package/chip/Chip.test.js +56 -0
  55. package/chip/types.d.ts +45 -0
  56. package/chip/types.js +5 -0
  57. package/common/variables.js +264 -363
  58. package/date-input/DateInput.js +63 -52
  59. package/date-input/DateInput.stories.tsx +138 -0
  60. package/date-input/DateInput.test.js +479 -0
  61. package/date-input/types.d.ts +16 -9
  62. package/dialog/Dialog.d.ts +4 -0
  63. package/dialog/Dialog.js +10 -56
  64. package/dialog/Dialog.stories.tsx +212 -0
  65. package/dialog/Dialog.test.js +40 -0
  66. package/dialog/types.d.ts +43 -0
  67. package/dialog/types.js +5 -0
  68. package/dropdown/Dropdown.d.ts +4 -0
  69. package/dropdown/Dropdown.js +28 -87
  70. package/dropdown/Dropdown.stories.tsx +249 -0
  71. package/dropdown/Dropdown.test.js +189 -0
  72. package/dropdown/types.d.ts +80 -0
  73. package/dropdown/types.js +5 -0
  74. package/file-input/FileInput.d.ts +4 -0
  75. package/file-input/FileInput.js +172 -111
  76. package/file-input/FileInput.stories.tsx +507 -0
  77. package/file-input/FileInput.test.js +457 -0
  78. package/file-input/FileItem.d.ts +14 -0
  79. package/file-input/FileItem.js +16 -23
  80. package/file-input/types.d.ts +112 -0
  81. package/file-input/types.js +5 -0
  82. package/footer/Footer.d.ts +4 -0
  83. package/footer/Footer.js +36 -148
  84. package/footer/Footer.stories.tsx +130 -0
  85. package/footer/Footer.test.js +109 -0
  86. package/footer/Icons.d.ts +2 -0
  87. package/footer/Icons.js +3 -3
  88. package/footer/types.d.ts +65 -0
  89. package/footer/types.js +5 -0
  90. package/header/Header.d.ts +7 -0
  91. package/header/Header.js +55 -78
  92. package/header/Header.stories.tsx +172 -0
  93. package/header/Header.test.js +79 -0
  94. package/header/Icons.d.ts +2 -0
  95. package/header/Icons.js +2 -27
  96. package/header/types.d.ts +47 -0
  97. package/header/types.js +5 -0
  98. package/heading/Heading.d.ts +4 -0
  99. package/heading/Heading.js +7 -24
  100. package/heading/Heading.stories.tsx +54 -0
  101. package/heading/Heading.test.js +186 -0
  102. package/heading/types.d.ts +33 -0
  103. package/heading/types.js +5 -0
  104. package/inset/Inset.d.ts +3 -0
  105. package/inset/Inset.js +84 -0
  106. package/inset/Inset.stories.tsx +229 -0
  107. package/inset/types.d.ts +37 -0
  108. package/inset/types.js +5 -0
  109. package/layout/ApplicationLayout.d.ts +11 -0
  110. package/layout/ApplicationLayout.js +84 -120
  111. package/layout/ApplicationLayout.stories.tsx +126 -0
  112. package/layout/Icons.d.ts +5 -0
  113. package/layout/Icons.js +13 -2
  114. package/layout/SidenavContext.d.ts +5 -0
  115. package/layout/SidenavContext.js +19 -0
  116. package/layout/types.d.ts +52 -0
  117. package/layout/types.js +5 -0
  118. package/link/Link.d.ts +4 -0
  119. package/link/Link.js +60 -107
  120. package/link/Link.stories.tsx +186 -0
  121. package/link/Link.test.js +83 -0
  122. package/link/types.d.ts +54 -0
  123. package/link/types.js +5 -0
  124. package/list/List.d.ts +4 -0
  125. package/list/List.js +47 -0
  126. package/list/List.stories.tsx +95 -0
  127. package/list/types.d.ts +7 -0
  128. package/list/types.js +5 -0
  129. package/main.d.ts +12 -9
  130. package/main.js +72 -42
  131. package/number-input/NumberInput.d.ts +4 -0
  132. package/number-input/NumberInput.js +16 -68
  133. package/number-input/NumberInput.stories.tsx +115 -0
  134. package/number-input/NumberInput.test.js +506 -0
  135. package/number-input/NumberInputContext.d.ts +4 -0
  136. package/number-input/NumberInputContext.js +5 -2
  137. package/number-input/numberInputContextTypes.d.ts +19 -0
  138. package/number-input/numberInputContextTypes.js +5 -0
  139. package/number-input/types.d.ts +124 -0
  140. package/number-input/types.js +5 -0
  141. package/package.json +9 -6
  142. package/paginator/Paginator.js +19 -46
  143. package/paginator/Paginator.stories.tsx +63 -0
  144. package/paginator/Paginator.test.js +266 -0
  145. package/password-input/PasswordInput.d.ts +4 -0
  146. package/password-input/PasswordInput.js +22 -55
  147. package/password-input/{PasswordInput.stories.jsx → PasswordInput.stories.tsx} +4 -4
  148. package/password-input/PasswordInput.test.js +180 -0
  149. package/password-input/types.d.ts +110 -0
  150. package/password-input/types.js +5 -0
  151. package/progress-bar/ProgressBar.d.ts +4 -0
  152. package/progress-bar/ProgressBar.js +6 -24
  153. package/progress-bar/ProgressBar.stories.jsx +58 -0
  154. package/progress-bar/ProgressBar.test.js +65 -0
  155. package/progress-bar/types.d.ts +37 -0
  156. package/progress-bar/types.js +5 -0
  157. package/quick-nav/QuickNav.d.ts +4 -0
  158. package/quick-nav/QuickNav.js +112 -0
  159. package/quick-nav/QuickNav.stories.tsx +237 -0
  160. package/quick-nav/types.d.ts +21 -0
  161. package/quick-nav/types.js +5 -0
  162. package/radio-group/Radio.d.ts +4 -0
  163. package/radio-group/Radio.js +141 -0
  164. package/radio-group/RadioGroup.d.ts +4 -0
  165. package/radio-group/RadioGroup.js +282 -0
  166. package/radio-group/RadioGroup.stories.tsx +100 -0
  167. package/radio-group/RadioGroup.test.js +695 -0
  168. package/radio-group/types.d.ts +114 -0
  169. package/radio-group/types.js +5 -0
  170. package/resultsetTable/ResultsetTable.d.ts +4 -0
  171. package/resultsetTable/ResultsetTable.js +9 -29
  172. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  173. package/resultsetTable/ResultsetTable.test.js +306 -0
  174. package/resultsetTable/types.d.ts +67 -0
  175. package/resultsetTable/types.js +5 -0
  176. package/row/Row.d.ts +3 -0
  177. package/row/Row.js +127 -0
  178. package/row/Row.stories.tsx +237 -0
  179. package/row/types.d.ts +28 -0
  180. package/row/types.js +5 -0
  181. package/select/Icons.d.ts +10 -0
  182. package/select/Icons.js +93 -0
  183. package/select/Listbox.d.ts +4 -0
  184. package/select/Listbox.js +152 -0
  185. package/select/Option.d.ts +4 -0
  186. package/select/Option.js +110 -0
  187. package/select/Select.d.ts +4 -0
  188. package/select/Select.js +122 -342
  189. package/select/Select.stories.tsx +594 -0
  190. package/select/Select.test.js +2120 -0
  191. package/select/types.d.ts +213 -0
  192. package/select/types.js +5 -0
  193. package/sidenav/Sidenav.d.ts +9 -0
  194. package/sidenav/Sidenav.js +26 -24
  195. package/sidenav/Sidenav.stories.tsx +182 -0
  196. package/sidenav/Sidenav.test.js +56 -0
  197. package/sidenav/types.d.ts +50 -0
  198. package/sidenav/types.js +5 -0
  199. package/slider/Slider.d.ts +4 -0
  200. package/slider/Slider.js +63 -85
  201. package/slider/Slider.stories.tsx +177 -0
  202. package/slider/Slider.test.js +150 -0
  203. package/slider/types.d.ts +82 -0
  204. package/slider/types.js +5 -0
  205. package/spinner/Spinner.d.ts +4 -0
  206. package/spinner/Spinner.js +9 -26
  207. package/spinner/Spinner.stories.jsx +103 -0
  208. package/spinner/Spinner.test.js +64 -0
  209. package/spinner/types.d.ts +32 -0
  210. package/spinner/types.js +5 -0
  211. package/stack/Stack.d.ts +3 -0
  212. package/stack/Stack.js +97 -0
  213. package/stack/Stack.stories.tsx +164 -0
  214. package/stack/types.d.ts +24 -0
  215. package/stack/types.js +5 -0
  216. package/switch/Switch.d.ts +1 -1
  217. package/switch/Switch.js +37 -21
  218. package/switch/Switch.stories.tsx +160 -0
  219. package/switch/Switch.test.js +98 -0
  220. package/switch/types.d.ts +6 -2
  221. package/table/Table.d.ts +4 -0
  222. package/table/Table.js +3 -3
  223. package/table/Table.stories.jsx +277 -0
  224. package/table/Table.test.js +26 -0
  225. package/table/types.d.ts +21 -0
  226. package/table/types.js +5 -0
  227. package/tabs/Tabs.d.ts +4 -0
  228. package/tabs/Tabs.js +24 -72
  229. package/tabs/Tabs.stories.tsx +112 -0
  230. package/tabs/Tabs.test.js +140 -0
  231. package/tabs/types.d.ts +82 -0
  232. package/tabs/types.js +5 -0
  233. package/tabs-nav/NavTabs.d.ts +8 -0
  234. package/tabs-nav/NavTabs.js +125 -0
  235. package/tabs-nav/NavTabs.stories.tsx +170 -0
  236. package/tabs-nav/NavTabs.test.js +82 -0
  237. package/tabs-nav/Tab.d.ts +4 -0
  238. package/tabs-nav/Tab.js +132 -0
  239. package/tabs-nav/types.d.ts +53 -0
  240. package/tabs-nav/types.js +5 -0
  241. package/tag/Tag.d.ts +4 -0
  242. package/tag/Tag.js +34 -59
  243. package/tag/Tag.stories.tsx +142 -0
  244. package/tag/Tag.test.js +60 -0
  245. package/tag/types.d.ts +69 -0
  246. package/tag/types.js +5 -0
  247. package/text/Text.d.ts +7 -0
  248. package/text/Text.js +30 -0
  249. package/text/Text.stories.tsx +19 -0
  250. package/text-input/Suggestion.d.ts +4 -0
  251. package/text-input/Suggestion.js +55 -0
  252. package/text-input/TextInput.d.ts +4 -0
  253. package/text-input/TextInput.js +91 -146
  254. package/text-input/TextInput.stories.tsx +474 -0
  255. package/text-input/TextInput.test.js +1712 -0
  256. package/text-input/types.d.ts +178 -0
  257. package/text-input/types.js +5 -0
  258. package/textarea/Textarea.d.ts +4 -0
  259. package/textarea/Textarea.js +39 -79
  260. package/textarea/Textarea.stories.jsx +157 -0
  261. package/textarea/Textarea.test.js +437 -0
  262. package/textarea/types.d.ts +137 -0
  263. package/textarea/types.js +5 -0
  264. package/toggle-group/ToggleGroup.d.ts +4 -0
  265. package/toggle-group/ToggleGroup.js +18 -46
  266. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  267. package/toggle-group/ToggleGroup.test.js +156 -0
  268. package/toggle-group/types.d.ts +105 -0
  269. package/toggle-group/types.js +5 -0
  270. package/useTheme.d.ts +2 -0
  271. package/useTheme.js +2 -2
  272. package/useTranslatedLabels.d.ts +2 -0
  273. package/useTranslatedLabels.js +20 -0
  274. package/wizard/Wizard.d.ts +4 -0
  275. package/wizard/Wizard.js +115 -94
  276. package/wizard/Wizard.stories.tsx +214 -0
  277. package/wizard/Wizard.test.js +141 -0
  278. package/wizard/types.d.ts +64 -0
  279. package/wizard/types.js +5 -0
  280. package/ThemeContext.js +0 -246
  281. package/V3Select/V3Select.js +0 -455
  282. package/V3Select/index.d.ts +0 -27
  283. package/V3Textarea/V3Textarea.js +0 -260
  284. package/V3Textarea/index.d.ts +0 -27
  285. package/box/index.d.ts +0 -25
  286. package/card/index.d.ts +0 -22
  287. package/chip/index.d.ts +0 -22
  288. package/date/Date.js +0 -373
  289. package/date/index.d.ts +0 -27
  290. package/dialog/index.d.ts +0 -18
  291. package/dropdown/index.d.ts +0 -26
  292. package/file-input/index.d.ts +0 -81
  293. package/footer/index.d.ts +0 -25
  294. package/header/index.d.ts +0 -25
  295. package/heading/index.d.ts +0 -17
  296. package/input-text/Icons.js +0 -22
  297. package/input-text/InputText.js +0 -611
  298. package/input-text/index.d.ts +0 -36
  299. package/link/index.d.ts +0 -23
  300. package/number-input/index.d.ts +0 -113
  301. package/password-input/index.d.ts +0 -94
  302. package/progress-bar/index.d.ts +0 -18
  303. package/radio/Radio.d.ts +0 -4
  304. package/radio/Radio.js +0 -174
  305. package/radio/types.d.ts +0 -54
  306. package/resultsetTable/index.d.ts +0 -19
  307. package/select/index.d.ts +0 -131
  308. package/sidenav/index.d.ts +0 -13
  309. package/slider/index.d.ts +0 -29
  310. package/spinner/index.d.ts +0 -17
  311. package/table/index.d.ts +0 -13
  312. package/tabs/index.d.ts +0 -19
  313. package/tag/index.d.ts +0 -24
  314. package/text-input/index.d.ts +0 -135
  315. package/textarea/index.d.ts +0 -117
  316. package/toggle/Toggle.js +0 -186
  317. package/toggle/index.d.ts +0 -21
  318. package/toggle-group/index.d.ts +0 -21
  319. package/upload/Upload.js +0 -201
  320. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  321. package/upload/buttons-upload/Icons.js +0 -40
  322. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  323. package/upload/dragAndDropArea/Icons.js +0 -39
  324. package/upload/file-upload/FileToUpload.js +0 -115
  325. package/upload/file-upload/Icons.js +0 -66
  326. package/upload/files-upload/FilesToUpload.js +0 -109
  327. package/upload/index.d.ts +0 -15
  328. package/upload/transaction/Icons.js +0 -160
  329. package/upload/transaction/Transaction.js +0 -104
  330. package/upload/transactions/Transactions.js +0 -94
  331. package/wizard/Icons.js +0 -65
  332. package/wizard/index.d.ts +0 -18
package/slider/Slider.js CHANGED
@@ -9,8 +9,6 @@ Object.defineProperty(exports, "__esModule", {
9
9
  });
10
10
  exports["default"] = void 0;
11
11
 
12
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
13
-
14
12
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
15
13
 
16
14
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
@@ -23,17 +21,17 @@ var _Slider = _interopRequireDefault(require("@material-ui/lab/Slider"));
23
21
 
24
22
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
25
23
 
26
- var _propTypes = _interopRequireDefault(require("prop-types"));
27
-
28
24
  var _TextInput = _interopRequireDefault(require("../text-input/TextInput"));
29
25
 
30
26
  var _variables = require("../common/variables.js");
31
27
 
32
28
  var _utils = require("../common/utils.js");
33
29
 
34
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
30
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
35
31
 
36
- var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext.js"));
32
+ var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext"));
33
+
34
+ var _uuid = require("uuid");
37
35
 
38
36
  var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7;
39
37
 
@@ -42,38 +40,47 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
42
40
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
43
41
 
44
42
  var DxcSlider = function DxcSlider(_ref) {
45
- var label = _ref.label,
46
- helperText = _ref.helperText,
43
+ var _ref$label = _ref.label,
44
+ label = _ref$label === void 0 ? "" : _ref$label,
45
+ _ref$name = _ref.name,
46
+ name = _ref$name === void 0 ? "" : _ref$name,
47
+ defaultValue = _ref.defaultValue,
48
+ value = _ref.value,
49
+ _ref$helperText = _ref.helperText,
50
+ helperText = _ref$helperText === void 0 ? "" : _ref$helperText,
47
51
  _ref$minValue = _ref.minValue,
48
52
  minValue = _ref$minValue === void 0 ? 0 : _ref$minValue,
49
53
  _ref$maxValue = _ref.maxValue,
50
54
  maxValue = _ref$maxValue === void 0 ? 100 : _ref$maxValue,
51
55
  _ref$step = _ref.step,
52
56
  step = _ref$step === void 0 ? 1 : _ref$step,
53
- value = _ref.value,
54
57
  _ref$showLimitsValues = _ref.showLimitsValues,
55
58
  showLimitsValues = _ref$showLimitsValues === void 0 ? false : _ref$showLimitsValues,
56
59
  _ref$showInput = _ref.showInput,
57
60
  showInput = _ref$showInput === void 0 ? false : _ref$showInput,
58
- name = _ref.name,
59
- onChange = _ref.onChange,
60
- onDragEnd = _ref.onDragEnd,
61
61
  _ref$disabled = _ref.disabled,
62
62
  disabled = _ref$disabled === void 0 ? false : _ref$disabled,
63
63
  _ref$marks = _ref.marks,
64
64
  marks = _ref$marks === void 0 ? false : _ref$marks,
65
+ onChange = _ref.onChange,
66
+ onDragEnd = _ref.onDragEnd,
65
67
  labelFormatCallback = _ref.labelFormatCallback,
66
68
  margin = _ref.margin,
67
69
  _ref$size = _ref.size,
68
70
  size = _ref$size === void 0 ? "fillParent" : _ref$size;
69
71
 
70
- var _useState = (0, _react.useState)(0),
72
+ var _useState = (0, _react.useState)(defaultValue !== null && defaultValue !== void 0 ? defaultValue : 0),
71
73
  _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
72
74
  innerValue = _useState2[0],
73
75
  setInnerValue = _useState2[1];
74
76
 
75
77
  var colorsTheme = (0, _useTheme["default"])();
76
78
  var backgroundType = (0, _react.useContext)(_BackgroundColorContext["default"]);
79
+
80
+ var _useState3 = (0, _react.useState)("label-".concat((0, _uuid.v4)())),
81
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 1),
82
+ labelId = _useState4[0];
83
+
77
84
  var minLabel = (0, _react.useMemo)(function () {
78
85
  return labelFormatCallback ? labelFormatCallback(minValue) : minValue;
79
86
  }, [labelFormatCallback, minValue]);
@@ -82,36 +89,24 @@ var DxcSlider = function DxcSlider(_ref) {
82
89
  }, [labelFormatCallback, maxValue]);
83
90
 
84
91
  var handlerSliderChange = function handlerSliderChange(event, newValue) {
85
- if (value == null) {
86
- var valueToCheck = value !== undefined ? value : innerValue;
87
-
88
- if (valueToCheck !== newValue) {
89
- setInnerValue(newValue);
90
- }
91
- }
92
+ var valueToCheck = value !== null && value !== void 0 ? value : innerValue;
93
+ valueToCheck !== newValue && setInnerValue(newValue);
94
+ onChange === null || onChange === void 0 ? void 0 : onChange(newValue);
95
+ };
92
96
 
93
- if (typeof onChange === "function") {
94
- onChange(newValue);
95
- }
97
+ var handleSliderOnChangeCommited = function handleSliderOnChangeCommited(event, selectedValue) {
98
+ onDragEnd === null || onDragEnd === void 0 ? void 0 : onDragEnd(selectedValue);
96
99
  };
97
100
 
98
101
  var handlerInputChange = function handlerInputChange(event) {
99
102
  var intValue = parseInt(event.value, 10);
100
103
 
101
104
  if (value == null) {
102
- if (!Number.isNaN(intValue)) {
103
- setInnerValue(intValue > maxValue ? maxValue : intValue);
104
- } else {
105
- setInnerValue("");
106
- }
105
+ if (!Number.isNaN(intValue)) setInnerValue(intValue > maxValue ? maxValue : intValue);
107
106
  }
108
107
 
109
- if (typeof onChange === "function") {
110
- if (!Number.isNaN(intValue)) {
111
- onChange(intValue > maxValue ? maxValue : intValue);
112
- } else {
113
- onChange("");
114
- }
108
+ if (!Number.isNaN(intValue)) {
109
+ onChange === null || onChange === void 0 ? void 0 : onChange(intValue > maxValue ? maxValue : intValue);
115
110
  }
116
111
  };
117
112
 
@@ -120,7 +115,14 @@ var DxcSlider = function DxcSlider(_ref) {
120
115
  }, /*#__PURE__*/_react["default"].createElement(Container, {
121
116
  margin: margin,
122
117
  size: size
123
- }, /*#__PURE__*/_react["default"].createElement(Label, null, label), /*#__PURE__*/_react["default"].createElement(HelperText, null, helperText), /*#__PURE__*/_react["default"].createElement(SliderContainer, {
118
+ }, /*#__PURE__*/_react["default"].createElement(Label, {
119
+ id: labelId,
120
+ disabled: disabled,
121
+ backgroundType: backgroundType
122
+ }, label), /*#__PURE__*/_react["default"].createElement(HelperText, {
123
+ disabled: disabled,
124
+ backgroundType: backgroundType
125
+ }, helperText), /*#__PURE__*/_react["default"].createElement(SliderContainer, {
124
126
  backgroundType: backgroundType
125
127
  }, showLimitsValues && /*#__PURE__*/_react["default"].createElement(MinLabelContainer, {
126
128
  backgroundType: backgroundType,
@@ -130,19 +132,18 @@ var DxcSlider = function DxcSlider(_ref) {
130
132
  min: minValue,
131
133
  max: maxValue,
132
134
  onChange: handlerSliderChange,
133
- onChangeCommitted: onDragEnd && function (event, selectedValue) {
134
- return onDragEnd(selectedValue);
135
- },
135
+ onChangeCommitted: handleSliderOnChangeCommited,
136
136
  step: step,
137
137
  marks: marks || [],
138
- disabled: disabled
138
+ disabled: disabled,
139
+ "aria-labelledby": labelId
139
140
  }), showLimitsValues && /*#__PURE__*/_react["default"].createElement(MaxLabelContainer, {
140
141
  backgroundType: backgroundType,
141
142
  disabled: disabled,
142
143
  step: step
143
144
  }, maxLabel), showInput && /*#__PURE__*/_react["default"].createElement(StyledTextInput, null, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
144
145
  name: name,
145
- value: value != null && value >= 0 && value || innerValue,
146
+ value: value != null && value >= 0 && value.toString() || innerValue.toString(),
146
147
  disabled: disabled,
147
148
  onChange: handlerInputChange,
148
149
  size: "fillParent"
@@ -150,7 +151,7 @@ var DxcSlider = function DxcSlider(_ref) {
150
151
  };
151
152
 
152
153
  var sizes = {
153
- medium: "240px",
154
+ medium: "360px",
154
155
  large: "480px",
155
156
  fillParent: "100%"
156
157
  };
@@ -173,10 +174,10 @@ var Container = _styledComponents["default"].div(_templateObject || (_templateOb
173
174
  return calculateWidth(props.margin, props.size);
174
175
  });
175
176
 
176
- var Label = _styledComponents["default"].label(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n"])), function (props) {
177
- return props.theme.labelFontColor;
177
+ var Label = _styledComponents["default"].label(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n"])), function (props) {
178
+ return props.disabled ? props.backgroundType === "dark" ? props.theme.disabledLabelFontColorOnDark : props.theme.disabledLabelFontColor : props.backgroundType === "dark" ? props.theme.labelFontColorOnDark : props.theme.labelFontColor;
178
179
  }, function (props) {
179
- return props.theme.labelFontFamily;
180
+ return props.theme.fontFamily;
180
181
  }, function (props) {
181
182
  return props.theme.labelFontSize;
182
183
  }, function (props) {
@@ -188,20 +189,20 @@ var Label = _styledComponents["default"].label(_templateObject2 || (_templateObj
188
189
  });
189
190
 
190
191
  var HelperText = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n"])), function (props) {
191
- return props.theme.helperTextFontColor;
192
+ return props.disabled ? props.backgroundType === "dark" ? props.theme.disabledHelperTextFontColorOnDark : props.theme.disabledHelperTextFontColor : props.backgroundType === "dark" ? props.theme.helperTextFontColorOnDark : props.theme.helperTextFontColor;
192
193
  }, function (props) {
193
- return props.theme.helperTextFontFamily;
194
+ return props.theme.fontFamily;
194
195
  }, function (props) {
195
196
  return props.theme.helperTextFontSize;
196
197
  }, function (props) {
197
- return props.theme.helperTextFontstyle;
198
+ return props.theme.helperTextFontStyle;
198
199
  }, function (props) {
199
200
  return props.theme.helperTextFontWeight;
200
201
  }, function (props) {
201
202
  return props.theme.helperTextLineHeight;
202
203
  });
203
204
 
204
- var SliderContainer = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n height: 48px;\n align-items: center;\n\n .MultiSlider-root {\n display: flex;\n align-items: center;\n }\n .MuiSlider-container {\n padding: 30px 24px;\n }\n .MuiSlider-root.Mui-disabled {\n color: ", ";\n cursor: not-allowed;\n }\n .Mui-disabled {\n & .MuiSlider-thumb {\n height: ", ";\n width: ", ";\n background-color: ", ";\n top: ", ";\n }\n & .MuiSlider-track {\n background-color: ", ";\n }\n & .MuiSlider-rail {\n background-color: ", ";\n }\n & > .MuiSlider-mark.MuiSlider-markActive {\n background-color: ", " !important;\n }\n & > .MuiSlider-mark {\n background-color: ", ";\n height: ", ";\n width: ", ";\n border-radius: 18px;\n top: ", ";\n }\n }\n .MuiSlider-thumb {\n height: ", ";\n width: ", ";\n background-color: ", ";\n top: ", ";\n border-radius: 9999px;\n\n :hover,\n &.Mui-focusVisible {\n box-shadow: none;\n }\n &.MuiSlider-active {\n box-shadow: none;\n }\n :focus {\n outline: ", "\n auto 1px;\n outline-offset: 2px;\n background-color: ", ";\n }\n :hover {\n background-color: ", ";\n transform: scale(", ");\n transform-origin: center;\n height: ", ";\n width: ", ";\n top: ", ";\n }\n :active {\n background-color: ", ";\n transform: scale(", ");\n transform-origin: center;\n }\n }\n .MuiSlider-track {\n background-color: ", ";\n height: ", ";\n top: ", ";\n border-radius: 9999px;\n }\n .MuiSlider-track.MuiSlider-trackAfter {\n background-color: ", ";\n }\n .MuiSlider-rail {\n background-color: ", ";\n height: ", ";\n top: ", ";\n }\n .MuiSlider-mark.MuiSlider-markActive {\n background-color: ", ";\n }\n .MuiSlider-mark {\n background-color: ", ";\n height: ", ";\n width: ", ";\n border-radius: 18px;\n top: ", ";\n }\n"])), function (props) {
205
+ var SliderContainer = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n height: 48px;\n align-items: center;\n\n .MuiSlider-root {\n min-width: 15rem;\n }\n .MuiSlider-container {\n padding: 30px 24px;\n }\n .MuiSlider-root.Mui-disabled {\n color: ", ";\n cursor: not-allowed;\n }\n .Mui-disabled {\n & .MuiSlider-thumb {\n height: ", ";\n width: ", ";\n background-color: ", ";\n top: ", ";\n }\n & .MuiSlider-track {\n background-color: ", ";\n }\n & .MuiSlider-rail {\n background-color: ", ";\n }\n & > .MuiSlider-mark.MuiSlider-markActive {\n background-color: ", " !important;\n }\n & > .MuiSlider-mark {\n background-color: ", ";\n height: ", ";\n width: ", ";\n border-radius: 18px;\n top: ", ";\n }\n }\n .MuiSlider-thumb {\n height: ", ";\n width: ", ";\n background-color: ", ";\n top: ", ";\n border-radius: 9999px;\n\n :hover,\n &.Mui-focusVisible {\n box-shadow: none;\n }\n &.MuiSlider-active {\n box-shadow: none;\n }\n :focus {\n outline: ", "\n auto 1px;\n outline-offset: 2px;\n background-color: ", ";\n }\n :hover {\n background-color: ", ";\n transform: scale(", ");\n transform-origin: center;\n height: ", ";\n width: ", ";\n top: ", ";\n }\n :active {\n background-color: ", ";\n transform: scale(", ");\n transform-origin: center;\n }\n }\n .MuiSlider-track {\n background-color: ", ";\n height: ", ";\n top: ", ";\n border-radius: 9999px;\n }\n .MuiSlider-track.MuiSlider-trackAfter {\n background-color: ", ";\n }\n .MuiSlider-rail {\n background-color: ", ";\n height: ", ";\n top: ", ";\n }\n .MuiSlider-mark.MuiSlider-markActive {\n background-color: ", ";\n }\n .MuiSlider-mark {\n background-color: ", ";\n height: ", ";\n width: ", ";\n border-radius: 18px;\n top: ", ";\n }\n"])), function (props) {
205
206
  return props.backgroundType === "dark" ? props.theme.disabledThumbBackgroundColorOnDark : props.theme.disabledThumbBackgroundColor;
206
207
  }, function (props) {
207
208
  return props.theme.thumbHeight;
@@ -277,34 +278,34 @@ var SliderContainer = _styledComponents["default"].div(_templateObject4 || (_tem
277
278
  return props.theme.tickVerticalPosition;
278
279
  });
279
280
 
280
- var MinLabelContainer = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n letter-spacing: ", ";\n margin-right: ", ";\n"])), function (props) {
281
- return props.theme.fontFamily;
281
+ var MinLabelContainer = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n letter-spacing: ", ";\n white-space: nowrap;\n margin-right: ", ";\n"])), function (props) {
282
+ return props.disabled ? props.theme.disabledLimitValuesFontColor : props.backgroundType === "dark" ? props.theme.limitValuesFontColorOnDark : props.theme.limitValuesFontColor;
282
283
  }, function (props) {
283
- return props.theme.fontSize;
284
+ return props.theme.fontFamily;
284
285
  }, function (props) {
285
- return props.theme.fontStyle;
286
+ return props.theme.limitValuesFontSize;
286
287
  }, function (props) {
287
- return props.theme.fontWeight;
288
+ return props.theme.limitValuesFontStyle;
288
289
  }, function (props) {
289
- return props.disabled ? props.theme.disabledFontColor : props.backgroundType === "dark" ? props.theme.fontColorOnDark : props.theme.fontColor;
290
+ return props.theme.limitValuesFontWeight;
290
291
  }, function (props) {
291
- return props.theme.fontLetterSpacing;
292
+ return props.theme.limitValuesFontLetterSpacing;
292
293
  }, function (props) {
293
294
  return props.theme.floorLabelMarginRight;
294
295
  });
295
296
 
296
- var MaxLabelContainer = _styledComponents["default"].span(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n letter-spacing: ", ";\n margin-left: ", ";\n"])), function (props) {
297
- return props.theme.fontFamily;
297
+ var MaxLabelContainer = _styledComponents["default"].span(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n letter-spacing: ", ";\n white-space: nowrap;\n margin-left: ", ";\n"])), function (props) {
298
+ return props.disabled ? props.theme.disabledLimitValuesFontColor : props.backgroundType === "dark" ? props.theme.limitValuesFontColorOnDark : props.theme.limitValuesFontColor;
298
299
  }, function (props) {
299
- return props.theme.fontSize;
300
+ return props.theme.fontFamily;
300
301
  }, function (props) {
301
- return props.theme.fontStyle;
302
+ return props.theme.limitValuesFontSize;
302
303
  }, function (props) {
303
- return props.theme.fontWeight;
304
+ return props.theme.limitValuesFontStyle;
304
305
  }, function (props) {
305
- return props.disabled ? props.theme.disabledFontColor : props.backgroundType === "dark" ? props.theme.fontColorOnDark : props.theme.fontColor;
306
+ return props.theme.limitValuesFontWeight;
306
307
  }, function (props) {
307
- return props.theme.fontLetterSpacing;
308
+ return props.theme.limitValuesFontLetterSpacing;
308
309
  }, function (props) {
309
310
  return props.step === 1 ? props.theme.ceilLabelMarginLeft : "1.25rem";
310
311
  });
@@ -313,28 +314,5 @@ var StyledTextInput = _styledComponents["default"].div(_templateObject7 || (_tem
313
314
  return props.theme.inputMarginLeft;
314
315
  });
315
316
 
316
- DxcSlider.propTypes = {
317
- label: _propTypes["default"].string,
318
- helperText: _propTypes["default"].string,
319
- size: _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(sizes))),
320
- minValue: _propTypes["default"].number,
321
- maxValue: _propTypes["default"].number,
322
- step: _propTypes["default"].number,
323
- value: _propTypes["default"].oneOfType([_propTypes["default"].number, _propTypes["default"].string]),
324
- showLimitsValues: _propTypes["default"].bool,
325
- showInput: _propTypes["default"].bool,
326
- name: _propTypes["default"].string,
327
- onChange: _propTypes["default"].func,
328
- onDragEnd: _propTypes["default"].func,
329
- disabled: _propTypes["default"].bool,
330
- marks: _propTypes["default"].bool,
331
- labelFormatCallback: _propTypes["default"].func,
332
- margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
333
- top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
334
- bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
335
- left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
336
- right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
337
- }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))])
338
- };
339
317
  var _default = DxcSlider;
340
318
  exports["default"] = _default;
@@ -0,0 +1,177 @@
1
+ import React from "react";
2
+ import DxcSlider from "./Slider";
3
+ import { BackgroundColorProvider } from "../BackgroundColorContext";
4
+ import Title from "../../.storybook/components/Title";
5
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
+ import DarkContainer from "../../.storybook/components/DarkSection";
7
+
8
+ export default {
9
+ title: "Slider",
10
+ component: DxcSlider,
11
+ };
12
+
13
+ const labelFormat = (value) => `${value}E100000000000000000000000`;
14
+
15
+ export const Chromatic = () => (
16
+ <>
17
+ <Title title="States" theme="light" level={2} />
18
+ <ExampleContainer pseudoState="pseudo-hover">
19
+ <Title title="Hovered" theme="light" level={4} />
20
+ <DxcSlider label="Slider" helperText="Help message" showLimitsValues />
21
+ </ExampleContainer>
22
+ <ExampleContainer pseudoState="pseudo-active">
23
+ <Title title="Active" theme="light" level={4} />
24
+ <DxcSlider label="Slider" helperText="Help message" showLimitsValues />
25
+ </ExampleContainer>
26
+ <ExampleContainer pseudoState="pseudo-focus">
27
+ <Title title="Focused" theme="light" level={4} />
28
+ <DxcSlider label="Slider" helperText="Help message" showLimitsValues />
29
+ </ExampleContainer>
30
+ <ExampleContainer>
31
+ <Title title="Disabled" theme="light" level={4} />
32
+ <DxcSlider label="Slider" helperText="Help message" disabled showLimitsValues />
33
+ </ExampleContainer>
34
+ <ExampleContainer>
35
+ <Title title="Disabled discrete slider with input" theme="light" level={4} />
36
+ <DxcSlider
37
+ label="Slider"
38
+ helperText="Help message"
39
+ disabled
40
+ defaultValue={40}
41
+ minValue={0}
42
+ maxValue={50}
43
+ showLimitsValues
44
+ showInput
45
+ marks
46
+ step={10}
47
+ />
48
+ </ExampleContainer>
49
+ <Title title="Variants" theme="light" level={2} />
50
+ <ExampleContainer>
51
+ <Title title="Continuous slider" theme="light" level={4} />
52
+ <DxcSlider defaultValue={65} label="Slider" helperText="Help message" showLimitsValues />
53
+ </ExampleContainer>
54
+ <ExampleContainer>
55
+ <Title title="Discrete slider" theme="light" level={4} />
56
+ <DxcSlider defaultValue={20} label="Slider" helperText="Help message" showLimitsValues marks step={5} />
57
+ </ExampleContainer>
58
+ <ExampleContainer>
59
+ <Title title="Discrete slider with input" theme="light" level={4} />
60
+ <DxcSlider
61
+ defaultValue={20}
62
+ minValue={0}
63
+ maxValue={50}
64
+ label="Slider"
65
+ helperText="Help message"
66
+ showLimitsValues
67
+ showInput
68
+ marks
69
+ step={10}
70
+ />
71
+ </ExampleContainer>
72
+ <BackgroundColorProvider color="#333333">
73
+ <DarkContainer>
74
+ <Title title="Dark" theme="dark" level={2} />
75
+ <ExampleContainer pseudoState="pseudo-hover">
76
+ <Title title="Hovered" theme="dark" level={4} />
77
+ <DxcSlider label="Slider" helperText="Help message" showLimitsValues />
78
+ </ExampleContainer>
79
+ <ExampleContainer pseudoState="pseudo-active">
80
+ <Title title="Active" theme="dark" level={4} />
81
+ <DxcSlider label="Slider" helperText="Help message" showLimitsValues />
82
+ </ExampleContainer>
83
+ <ExampleContainer pseudoState="pseudo-focus">
84
+ <Title title="Focused" theme="dark" level={4} />
85
+ <DxcSlider label="Slider" helperText="Help message" showLimitsValues />
86
+ </ExampleContainer>
87
+ <ExampleContainer>
88
+ <Title title="Disabled" theme="dark" level={4} />
89
+ <DxcSlider label="Slider" helperText="Help message" disabled showLimitsValues />
90
+ </ExampleContainer>
91
+ <ExampleContainer>
92
+ <Title title="Disabled discrete slider with input" theme="dark" level={4} />
93
+ <DxcSlider
94
+ label="Slider"
95
+ helperText="Help message"
96
+ disabled
97
+ defaultValue={40}
98
+ minValue={0}
99
+ maxValue={50}
100
+ showLimitsValues
101
+ showInput
102
+ marks
103
+ step={5}
104
+ />
105
+ </ExampleContainer>
106
+ <ExampleContainer>
107
+ <Title title="Continuous slider" theme="dark" level={4} />
108
+ <DxcSlider defaultValue={65} label="Slider" helperText="Help message" showLimitsValues />
109
+ </ExampleContainer>
110
+ <ExampleContainer>
111
+ <Title title="Discrete slider" theme="dark" level={4} />
112
+ <DxcSlider defaultValue={20} label="Slider" helperText="Help message" showLimitsValues marks step={5} />
113
+ </ExampleContainer>
114
+ <ExampleContainer>
115
+ <Title title="Discrete slider with input" theme="dark" level={4} />
116
+ <DxcSlider
117
+ defaultValue={20}
118
+ minValue={0}
119
+ maxValue={50}
120
+ label="Slider"
121
+ helperText="Help message"
122
+ showLimitsValues
123
+ showInput
124
+ marks
125
+ step={10}
126
+ />
127
+ </ExampleContainer>
128
+ </DarkContainer>
129
+ </BackgroundColorProvider>
130
+ <Title title="Margins" theme="light" level={2} />
131
+ <ExampleContainer>
132
+ <Title title="Xxsmall" theme="light" level={4} />
133
+ <DxcSlider label="Xxsmall" margin="xxsmall" />
134
+ </ExampleContainer>
135
+ <ExampleContainer>
136
+ <Title title="Xsmall" theme="light" level={4} />
137
+ <DxcSlider label="Xsmall" margin="xsmall" />
138
+ </ExampleContainer>
139
+ <ExampleContainer>
140
+ <Title title="Small" theme="light" level={4} />
141
+ <DxcSlider label="Small" margin="small" />
142
+ </ExampleContainer>
143
+ <ExampleContainer>
144
+ <Title title="Medium" theme="light" level={4} />
145
+ <DxcSlider label="Medium" margin="medium" />
146
+ </ExampleContainer>
147
+ <ExampleContainer>
148
+ <Title title="Large" theme="light" level={4} />
149
+ <DxcSlider label="Large" margin="large" />
150
+ </ExampleContainer>
151
+ <ExampleContainer>
152
+ <Title title="Xlarge" theme="light" level={4} />
153
+ <DxcSlider label="Xlarge" margin="xlarge" />
154
+ </ExampleContainer>
155
+ <ExampleContainer>
156
+ <Title title="Xxlarge" theme="light" level={4} />
157
+ <DxcSlider label="Xxlarge" margin="xxlarge" />
158
+ </ExampleContainer>
159
+ <Title title="Sizes" theme="light" level={2} />
160
+ <ExampleContainer>
161
+ <Title title="Medium" theme="light" level={4} />
162
+ <DxcSlider label="Medium" size="medium" />
163
+ </ExampleContainer>
164
+ <ExampleContainer>
165
+ <Title title="Large" theme="light" level={4} />
166
+ <DxcSlider label="Large" size="large" />
167
+ </ExampleContainer>
168
+ <ExampleContainer>
169
+ <Title title="FillParent" theme="light" level={4} />
170
+ <DxcSlider label="FillParent" size="fillParent" />
171
+ </ExampleContainer>
172
+ <ExampleContainer>
173
+ <Title title="Large limit values labels" theme="light" level={4} />
174
+ <DxcSlider label="Slider" helperText="Help message" showLimitsValues labelFormatCallback={labelFormat} size="large" />
175
+ </ExampleContainer>
176
+ </>
177
+ );
@@ -0,0 +1,150 @@
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 _Slider = _interopRequireDefault(require("./Slider"));
10
+
11
+ describe("Slider component tests", function () {
12
+ test("Slider renders with correct text", function () {
13
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
14
+ minValue: 0,
15
+ maxValue: 100,
16
+ showLimitsValues: true
17
+ })),
18
+ getByText = _render.getByText;
19
+
20
+ expect(getByText("0")).toBeTruthy();
21
+ expect(getByText("100")).toBeTruthy();
22
+ });
23
+ test("Slider renders with correct initial value when it is uncontrolled", function () {
24
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
25
+ defaultValue: 30,
26
+ minValue: 0,
27
+ maxValue: 100,
28
+ showLimitsValues: true,
29
+ showInput: true
30
+ })),
31
+ getByRole = _render2.getByRole;
32
+
33
+ var slider = getByRole("slider");
34
+ var input = getByRole("textbox");
35
+ expect(slider.getAttribute("aria-valuenow")).toBe("30");
36
+ expect(input.value).toBe("30");
37
+ });
38
+ test("Calls correct function onChange in controlled slider", function () {
39
+ var onChange = jest.fn();
40
+
41
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
42
+ minValue: 0,
43
+ maxValue: 100,
44
+ onChange: onChange,
45
+ showLimitsValues: true,
46
+ value: 13,
47
+ showInput: true
48
+ })),
49
+ getByRole = _render3.getByRole;
50
+
51
+ expect(getByRole("slider").getAttribute("aria-valuenow")).toBe("13");
52
+ expect(getByRole("textbox").value).toBe("13");
53
+ (0, _react2.act)(function () {
54
+ _react2.fireEvent.change(getByRole("textbox"), {
55
+ target: {
56
+ value: 25
57
+ }
58
+ });
59
+ });
60
+ expect(onChange).toHaveBeenCalledWith(25);
61
+ expect(getByRole("slider").getAttribute("aria-valuenow")).toBe("13");
62
+ expect(getByRole("textbox").value).toBe("13");
63
+ });
64
+ test("Calls correct function onChange in uncontrolled slider", function () {
65
+ var onChange = jest.fn();
66
+
67
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
68
+ minValue: 0,
69
+ maxValue: 100,
70
+ onChange: onChange,
71
+ showLimitsValues: true,
72
+ showInput: true
73
+ })),
74
+ getByRole = _render4.getByRole;
75
+
76
+ (0, _react2.act)(function () {
77
+ _react2.fireEvent.change(getByRole("textbox"), {
78
+ target: {
79
+ value: 25
80
+ }
81
+ });
82
+ });
83
+ expect(onChange).toHaveBeenCalledWith(25);
84
+ expect(getByRole("slider").getAttribute("aria-valuenow")).toBe("25");
85
+ expect(getByRole("textbox").value).toBe("25");
86
+ });
87
+ test("Disabled slider have disabled input", function () {
88
+ var onChange = jest.fn();
89
+
90
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
91
+ minValue: 0,
92
+ maxValue: 100,
93
+ onChange: onChange,
94
+ showLimitsValues: true,
95
+ disabled: true,
96
+ showInput: true,
97
+ value: 13
98
+ })),
99
+ getByRole = _render5.getByRole;
100
+
101
+ (0, _react2.act)(function () {
102
+ _react2.fireEvent.change(getByRole("textbox"), {
103
+ target: {
104
+ value: 25
105
+ }
106
+ });
107
+ });
108
+ expect(getByRole("textbox").hasAttribute("disabled")).toBeTruthy();
109
+ expect(getByRole("textbox").value).toBe("13");
110
+ });
111
+ test("Calls correct function onDragEnd", function () {
112
+ var onDragEnd = jest.fn();
113
+
114
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
115
+ minValue: 0,
116
+ maxValue: 100,
117
+ showLimitsValues: true,
118
+ showInput: true,
119
+ onDragEnd: onDragEnd,
120
+ value: 25
121
+ })),
122
+ getByRole = _render6.getByRole;
123
+
124
+ (0, _react2.act)(function () {
125
+ _react2.fireEvent.mouseDown(getByRole("slider"));
126
+
127
+ _react2.fireEvent.mouseUp(getByRole("slider"));
128
+ });
129
+ expect(onDragEnd).toHaveBeenCalled();
130
+ });
131
+ test("Calls correct function labelFormatCallback", function () {
132
+ var labelFormatCallback = jest.fn(function (x) {
133
+ return "".concat(x, "$");
134
+ });
135
+
136
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
137
+ minValue: 0,
138
+ maxValue: 100,
139
+ showLimitsValues: true,
140
+ showInput: true,
141
+ value: 25,
142
+ labelFormatCallback: labelFormatCallback
143
+ })),
144
+ getByText = _render7.getByText;
145
+
146
+ expect(getByText("0$")).toBeTruthy();
147
+ expect(getByText("100$")).toBeTruthy();
148
+ expect(labelFormatCallback).toHaveBeenCalledTimes(2);
149
+ });
150
+ });