@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.
- package/BackgroundColorContext.d.ts +10 -0
- package/BackgroundColorContext.js +1 -4
- package/HalstackContext.d.ts +12 -0
- package/HalstackContext.js +295 -0
- package/accordion/Accordion.d.ts +1 -1
- package/accordion/Accordion.js +15 -47
- package/accordion/Accordion.stories.tsx +307 -0
- package/accordion/Accordion.test.js +72 -0
- package/accordion/types.d.ts +8 -8
- package/accordion-group/AccordionGroup.d.ts +1 -1
- package/accordion-group/AccordionGroup.js +15 -17
- package/accordion-group/AccordionGroup.stories.tsx +225 -0
- package/accordion-group/AccordionGroup.test.js +151 -0
- package/accordion-group/types.d.ts +8 -8
- package/alert/Alert.js +6 -3
- package/alert/Alert.stories.tsx +170 -0
- package/alert/Alert.test.js +92 -0
- package/alert/types.d.ts +1 -1
- package/badge/Badge.d.ts +4 -0
- package/badge/Badge.js +6 -4
- package/badge/types.d.ts +5 -0
- package/{radio → badge}/types.js +0 -0
- package/bleed/Bleed.d.ts +3 -0
- package/bleed/Bleed.js +84 -0
- package/bleed/Bleed.stories.tsx +342 -0
- package/bleed/types.d.ts +37 -0
- package/bleed/types.js +5 -0
- package/box/Box.d.ts +4 -0
- package/box/Box.js +28 -64
- package/box/Box.stories.tsx +132 -0
- package/box/Box.test.js +18 -0
- package/box/types.d.ts +43 -0
- package/box/types.js +5 -0
- package/button/Button.d.ts +1 -1
- package/button/Button.js +24 -32
- package/button/Button.stories.tsx +223 -242
- package/button/Button.test.js +35 -0
- package/button/types.d.ts +9 -13
- package/card/Card.d.ts +4 -0
- package/card/Card.js +44 -81
- package/card/Card.stories.tsx +201 -0
- package/card/Card.test.js +50 -0
- package/card/ice-cream.jpg +0 -0
- package/card/types.d.ts +67 -0
- package/card/types.js +5 -0
- package/checkbox/Checkbox.d.ts +1 -1
- package/checkbox/Checkbox.js +45 -41
- package/checkbox/Checkbox.stories.tsx +188 -0
- package/checkbox/Checkbox.test.js +78 -0
- package/checkbox/types.d.ts +9 -6
- package/chip/Chip.d.ts +4 -0
- package/chip/Chip.js +16 -76
- package/chip/Chip.stories.tsx +119 -0
- package/chip/Chip.test.js +56 -0
- package/chip/types.d.ts +45 -0
- package/chip/types.js +5 -0
- package/common/variables.js +264 -363
- package/date-input/DateInput.js +63 -52
- package/date-input/DateInput.stories.tsx +138 -0
- package/date-input/DateInput.test.js +479 -0
- package/date-input/types.d.ts +16 -9
- package/dialog/Dialog.d.ts +4 -0
- package/dialog/Dialog.js +10 -56
- package/dialog/Dialog.stories.tsx +212 -0
- package/dialog/Dialog.test.js +40 -0
- package/dialog/types.d.ts +43 -0
- package/dialog/types.js +5 -0
- package/dropdown/Dropdown.d.ts +4 -0
- package/dropdown/Dropdown.js +28 -87
- package/dropdown/Dropdown.stories.tsx +249 -0
- package/dropdown/Dropdown.test.js +189 -0
- package/dropdown/types.d.ts +80 -0
- package/dropdown/types.js +5 -0
- package/file-input/FileInput.d.ts +4 -0
- package/file-input/FileInput.js +172 -111
- package/file-input/FileInput.stories.tsx +507 -0
- package/file-input/FileInput.test.js +457 -0
- package/file-input/FileItem.d.ts +14 -0
- package/file-input/FileItem.js +16 -23
- package/file-input/types.d.ts +112 -0
- package/file-input/types.js +5 -0
- package/footer/Footer.d.ts +4 -0
- package/footer/Footer.js +36 -148
- package/footer/Footer.stories.tsx +130 -0
- package/footer/Footer.test.js +109 -0
- package/footer/Icons.d.ts +2 -0
- package/footer/Icons.js +3 -3
- package/footer/types.d.ts +65 -0
- package/footer/types.js +5 -0
- package/header/Header.d.ts +7 -0
- package/header/Header.js +55 -78
- package/header/Header.stories.tsx +172 -0
- package/header/Header.test.js +79 -0
- package/header/Icons.d.ts +2 -0
- package/header/Icons.js +2 -27
- package/header/types.d.ts +47 -0
- package/header/types.js +5 -0
- package/heading/Heading.d.ts +4 -0
- package/heading/Heading.js +7 -24
- package/heading/Heading.stories.tsx +54 -0
- package/heading/Heading.test.js +186 -0
- package/heading/types.d.ts +33 -0
- package/heading/types.js +5 -0
- package/inset/Inset.d.ts +3 -0
- package/inset/Inset.js +84 -0
- package/inset/Inset.stories.tsx +229 -0
- package/inset/types.d.ts +37 -0
- package/inset/types.js +5 -0
- package/layout/ApplicationLayout.d.ts +11 -0
- package/layout/ApplicationLayout.js +84 -120
- package/layout/ApplicationLayout.stories.tsx +126 -0
- package/layout/Icons.d.ts +5 -0
- package/layout/Icons.js +13 -2
- package/layout/SidenavContext.d.ts +5 -0
- package/layout/SidenavContext.js +19 -0
- package/layout/types.d.ts +52 -0
- package/layout/types.js +5 -0
- package/link/Link.d.ts +4 -0
- package/link/Link.js +60 -107
- package/link/Link.stories.tsx +186 -0
- package/link/Link.test.js +83 -0
- package/link/types.d.ts +54 -0
- package/link/types.js +5 -0
- package/list/List.d.ts +4 -0
- package/list/List.js +47 -0
- package/list/List.stories.tsx +95 -0
- package/list/types.d.ts +7 -0
- package/list/types.js +5 -0
- package/main.d.ts +12 -9
- package/main.js +72 -42
- package/number-input/NumberInput.d.ts +4 -0
- package/number-input/NumberInput.js +16 -68
- package/number-input/NumberInput.stories.tsx +115 -0
- package/number-input/NumberInput.test.js +506 -0
- package/number-input/NumberInputContext.d.ts +4 -0
- package/number-input/NumberInputContext.js +5 -2
- package/number-input/numberInputContextTypes.d.ts +19 -0
- package/number-input/numberInputContextTypes.js +5 -0
- package/number-input/types.d.ts +124 -0
- package/number-input/types.js +5 -0
- package/package.json +9 -6
- package/paginator/Paginator.js +19 -46
- package/paginator/Paginator.stories.tsx +63 -0
- package/paginator/Paginator.test.js +266 -0
- package/password-input/PasswordInput.d.ts +4 -0
- package/password-input/PasswordInput.js +22 -55
- package/password-input/{PasswordInput.stories.jsx → PasswordInput.stories.tsx} +4 -4
- package/password-input/PasswordInput.test.js +180 -0
- package/password-input/types.d.ts +110 -0
- package/password-input/types.js +5 -0
- package/progress-bar/ProgressBar.d.ts +4 -0
- package/progress-bar/ProgressBar.js +6 -24
- package/progress-bar/ProgressBar.stories.jsx +58 -0
- package/progress-bar/ProgressBar.test.js +65 -0
- package/progress-bar/types.d.ts +37 -0
- package/progress-bar/types.js +5 -0
- package/quick-nav/QuickNav.d.ts +4 -0
- package/quick-nav/QuickNav.js +112 -0
- package/quick-nav/QuickNav.stories.tsx +237 -0
- package/quick-nav/types.d.ts +21 -0
- package/quick-nav/types.js +5 -0
- package/radio-group/Radio.d.ts +4 -0
- package/radio-group/Radio.js +141 -0
- package/radio-group/RadioGroup.d.ts +4 -0
- package/radio-group/RadioGroup.js +282 -0
- package/radio-group/RadioGroup.stories.tsx +100 -0
- package/radio-group/RadioGroup.test.js +695 -0
- package/radio-group/types.d.ts +114 -0
- package/radio-group/types.js +5 -0
- package/resultsetTable/ResultsetTable.d.ts +4 -0
- package/resultsetTable/ResultsetTable.js +9 -29
- package/resultsetTable/ResultsetTable.stories.tsx +275 -0
- package/resultsetTable/ResultsetTable.test.js +306 -0
- package/resultsetTable/types.d.ts +67 -0
- package/resultsetTable/types.js +5 -0
- package/row/Row.d.ts +3 -0
- package/row/Row.js +127 -0
- package/row/Row.stories.tsx +237 -0
- package/row/types.d.ts +28 -0
- package/row/types.js +5 -0
- package/select/Icons.d.ts +10 -0
- package/select/Icons.js +93 -0
- package/select/Listbox.d.ts +4 -0
- package/select/Listbox.js +152 -0
- package/select/Option.d.ts +4 -0
- package/select/Option.js +110 -0
- package/select/Select.d.ts +4 -0
- package/select/Select.js +122 -342
- package/select/Select.stories.tsx +594 -0
- package/select/Select.test.js +2120 -0
- package/select/types.d.ts +213 -0
- package/select/types.js +5 -0
- package/sidenav/Sidenav.d.ts +9 -0
- package/sidenav/Sidenav.js +26 -24
- package/sidenav/Sidenav.stories.tsx +182 -0
- package/sidenav/Sidenav.test.js +56 -0
- package/sidenav/types.d.ts +50 -0
- package/sidenav/types.js +5 -0
- package/slider/Slider.d.ts +4 -0
- package/slider/Slider.js +63 -85
- package/slider/Slider.stories.tsx +177 -0
- package/slider/Slider.test.js +150 -0
- package/slider/types.d.ts +82 -0
- package/slider/types.js +5 -0
- package/spinner/Spinner.d.ts +4 -0
- package/spinner/Spinner.js +9 -26
- package/spinner/Spinner.stories.jsx +103 -0
- package/spinner/Spinner.test.js +64 -0
- package/spinner/types.d.ts +32 -0
- package/spinner/types.js +5 -0
- package/stack/Stack.d.ts +3 -0
- package/stack/Stack.js +97 -0
- package/stack/Stack.stories.tsx +164 -0
- package/stack/types.d.ts +24 -0
- package/stack/types.js +5 -0
- package/switch/Switch.d.ts +1 -1
- package/switch/Switch.js +37 -21
- package/switch/Switch.stories.tsx +160 -0
- package/switch/Switch.test.js +98 -0
- package/switch/types.d.ts +6 -2
- package/table/Table.d.ts +4 -0
- package/table/Table.js +3 -3
- package/table/Table.stories.jsx +277 -0
- package/table/Table.test.js +26 -0
- package/table/types.d.ts +21 -0
- package/table/types.js +5 -0
- package/tabs/Tabs.d.ts +4 -0
- package/tabs/Tabs.js +24 -72
- package/tabs/Tabs.stories.tsx +112 -0
- package/tabs/Tabs.test.js +140 -0
- package/tabs/types.d.ts +82 -0
- package/tabs/types.js +5 -0
- package/tabs-nav/NavTabs.d.ts +8 -0
- package/tabs-nav/NavTabs.js +125 -0
- package/tabs-nav/NavTabs.stories.tsx +170 -0
- package/tabs-nav/NavTabs.test.js +82 -0
- package/tabs-nav/Tab.d.ts +4 -0
- package/tabs-nav/Tab.js +132 -0
- package/tabs-nav/types.d.ts +53 -0
- package/tabs-nav/types.js +5 -0
- package/tag/Tag.d.ts +4 -0
- package/tag/Tag.js +34 -59
- package/tag/Tag.stories.tsx +142 -0
- package/tag/Tag.test.js +60 -0
- package/tag/types.d.ts +69 -0
- package/tag/types.js +5 -0
- package/text/Text.d.ts +7 -0
- package/text/Text.js +30 -0
- package/text/Text.stories.tsx +19 -0
- package/text-input/Suggestion.d.ts +4 -0
- package/text-input/Suggestion.js +55 -0
- package/text-input/TextInput.d.ts +4 -0
- package/text-input/TextInput.js +91 -146
- package/text-input/TextInput.stories.tsx +474 -0
- package/text-input/TextInput.test.js +1712 -0
- package/text-input/types.d.ts +178 -0
- package/text-input/types.js +5 -0
- package/textarea/Textarea.d.ts +4 -0
- package/textarea/Textarea.js +39 -79
- package/textarea/Textarea.stories.jsx +157 -0
- package/textarea/Textarea.test.js +437 -0
- package/textarea/types.d.ts +137 -0
- package/textarea/types.js +5 -0
- package/toggle-group/ToggleGroup.d.ts +4 -0
- package/toggle-group/ToggleGroup.js +18 -46
- package/toggle-group/ToggleGroup.stories.tsx +173 -0
- package/toggle-group/ToggleGroup.test.js +156 -0
- package/toggle-group/types.d.ts +105 -0
- package/toggle-group/types.js +5 -0
- package/useTheme.d.ts +2 -0
- package/useTheme.js +2 -2
- package/useTranslatedLabels.d.ts +2 -0
- package/useTranslatedLabels.js +20 -0
- package/wizard/Wizard.d.ts +4 -0
- package/wizard/Wizard.js +115 -94
- package/wizard/Wizard.stories.tsx +214 -0
- package/wizard/Wizard.test.js +141 -0
- package/wizard/types.d.ts +64 -0
- package/wizard/types.js +5 -0
- package/ThemeContext.js +0 -246
- package/V3Select/V3Select.js +0 -455
- package/V3Select/index.d.ts +0 -27
- package/V3Textarea/V3Textarea.js +0 -260
- package/V3Textarea/index.d.ts +0 -27
- package/box/index.d.ts +0 -25
- package/card/index.d.ts +0 -22
- package/chip/index.d.ts +0 -22
- package/date/Date.js +0 -373
- package/date/index.d.ts +0 -27
- package/dialog/index.d.ts +0 -18
- package/dropdown/index.d.ts +0 -26
- package/file-input/index.d.ts +0 -81
- package/footer/index.d.ts +0 -25
- package/header/index.d.ts +0 -25
- package/heading/index.d.ts +0 -17
- package/input-text/Icons.js +0 -22
- package/input-text/InputText.js +0 -611
- package/input-text/index.d.ts +0 -36
- package/link/index.d.ts +0 -23
- package/number-input/index.d.ts +0 -113
- package/password-input/index.d.ts +0 -94
- package/progress-bar/index.d.ts +0 -18
- package/radio/Radio.d.ts +0 -4
- package/radio/Radio.js +0 -174
- package/radio/types.d.ts +0 -54
- package/resultsetTable/index.d.ts +0 -19
- package/select/index.d.ts +0 -131
- package/sidenav/index.d.ts +0 -13
- package/slider/index.d.ts +0 -29
- package/spinner/index.d.ts +0 -17
- package/table/index.d.ts +0 -13
- package/tabs/index.d.ts +0 -19
- package/tag/index.d.ts +0 -24
- package/text-input/index.d.ts +0 -135
- package/textarea/index.d.ts +0 -117
- package/toggle/Toggle.js +0 -186
- package/toggle/index.d.ts +0 -21
- package/toggle-group/index.d.ts +0 -21
- package/upload/Upload.js +0 -201
- package/upload/buttons-upload/ButtonsUpload.js +0 -111
- package/upload/buttons-upload/Icons.js +0 -40
- package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
- package/upload/dragAndDropArea/Icons.js +0 -39
- package/upload/file-upload/FileToUpload.js +0 -115
- package/upload/file-upload/Icons.js +0 -66
- package/upload/files-upload/FilesToUpload.js +0 -109
- package/upload/index.d.ts +0 -15
- package/upload/transaction/Icons.js +0 -160
- package/upload/transaction/Transaction.js +0 -104
- package/upload/transactions/Transactions.js +0 -94
- package/wizard/Icons.js +0 -65
- 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
|
|
30
|
+
var _useTheme = _interopRequireDefault(require("../useTheme"));
|
|
35
31
|
|
|
36
|
-
var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext
|
|
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
|
-
|
|
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
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
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
|
-
|
|
94
|
-
|
|
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 (
|
|
110
|
-
|
|
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,
|
|
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:
|
|
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: "
|
|
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.
|
|
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.
|
|
194
|
+
return props.theme.fontFamily;
|
|
194
195
|
}, function (props) {
|
|
195
196
|
return props.theme.helperTextFontSize;
|
|
196
197
|
}, function (props) {
|
|
197
|
-
return props.theme.
|
|
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 .
|
|
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
|
|
281
|
-
return props.theme.
|
|
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.
|
|
284
|
+
return props.theme.fontFamily;
|
|
284
285
|
}, function (props) {
|
|
285
|
-
return props.theme.
|
|
286
|
+
return props.theme.limitValuesFontSize;
|
|
286
287
|
}, function (props) {
|
|
287
|
-
return props.theme.
|
|
288
|
+
return props.theme.limitValuesFontStyle;
|
|
288
289
|
}, function (props) {
|
|
289
|
-
return props.
|
|
290
|
+
return props.theme.limitValuesFontWeight;
|
|
290
291
|
}, function (props) {
|
|
291
|
-
return props.theme.
|
|
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
|
|
297
|
-
return props.theme.
|
|
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.
|
|
300
|
+
return props.theme.fontFamily;
|
|
300
301
|
}, function (props) {
|
|
301
|
-
return props.theme.
|
|
302
|
+
return props.theme.limitValuesFontSize;
|
|
302
303
|
}, function (props) {
|
|
303
|
-
return props.theme.
|
|
304
|
+
return props.theme.limitValuesFontStyle;
|
|
304
305
|
}, function (props) {
|
|
305
|
-
return props.
|
|
306
|
+
return props.theme.limitValuesFontWeight;
|
|
306
307
|
}, function (props) {
|
|
307
|
-
return props.theme.
|
|
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
|
+
});
|