@dxc-technology/halstack-react 0.0.0-9b45027 → 0.0.0-9bd9511
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/BackgroundColorContext.d.ts +2 -2
- package/BackgroundColorContext.js +1 -11
- package/HalstackContext.d.ts +13 -0
- package/HalstackContext.js +318 -0
- package/accordion/Accordion.d.ts +1 -1
- package/accordion/Accordion.js +124 -179
- package/accordion/Accordion.stories.tsx +115 -27
- package/accordion/Accordion.test.js +56 -0
- package/accordion/types.d.ts +12 -11
- package/accordion-group/AccordionGroup.d.ts +1 -1
- package/accordion-group/AccordionGroup.js +28 -77
- package/accordion-group/AccordionGroup.stories.tsx +28 -2
- package/accordion-group/AccordionGroup.test.js +108 -0
- package/accordion-group/types.d.ts +19 -12
- package/alert/Alert.js +18 -46
- package/alert/Alert.stories.tsx +28 -0
- package/alert/Alert.test.js +75 -0
- package/alert/types.d.ts +3 -3
- package/badge/Badge.d.ts +4 -0
- package/badge/Badge.js +6 -16
- package/badge/types.d.ts +5 -0
- package/bleed/Bleed.d.ts +2 -2
- package/bleed/Bleed.js +14 -55
- package/bleed/Bleed.stories.tsx +94 -95
- package/bleed/types.d.ts +26 -2
- package/box/Box.js +34 -63
- package/box/Box.stories.tsx +15 -0
- package/box/Box.test.js +13 -0
- package/box/types.d.ts +5 -4
- package/bulleted-list/BulletedList.d.ts +7 -0
- package/bulleted-list/BulletedList.js +98 -0
- package/bulleted-list/BulletedList.stories.tsx +200 -0
- package/bulleted-list/types.d.ts +11 -0
- package/bulleted-list/types.js +5 -0
- package/button/Button.js +61 -100
- package/button/Button.stories.tsx +159 -8
- package/button/Button.test.js +26 -0
- package/button/types.d.ts +8 -8
- package/card/Card.js +44 -70
- package/card/Card.test.js +39 -0
- package/card/types.d.ts +4 -3
- package/checkbox/Checkbox.d.ts +2 -2
- package/checkbox/Checkbox.js +115 -162
- package/checkbox/Checkbox.stories.tsx +198 -130
- package/checkbox/Checkbox.test.js +128 -0
- package/checkbox/types.d.ts +14 -6
- package/chip/Chip.d.ts +1 -1
- package/chip/Chip.js +29 -91
- package/chip/Chip.stories.tsx +98 -13
- package/chip/Chip.test.js +42 -0
- package/chip/types.d.ts +8 -16
- package/common/utils.js +1 -6
- package/common/variables.d.ts +1431 -0
- package/common/variables.js +480 -554
- package/date-input/Calendar.d.ts +4 -0
- package/date-input/Calendar.js +215 -0
- package/date-input/DateInput.js +164 -300
- package/date-input/DateInput.stories.tsx +199 -33
- package/date-input/DateInput.test.js +648 -0
- package/date-input/DatePicker.d.ts +4 -0
- package/date-input/DatePicker.js +116 -0
- package/date-input/Icons.d.ts +6 -0
- package/date-input/Icons.js +63 -0
- package/date-input/YearPicker.d.ts +4 -0
- package/date-input/YearPicker.js +101 -0
- package/date-input/types.d.ts +71 -13
- package/dialog/Dialog.js +52 -84
- package/dialog/Dialog.stories.tsx +99 -22
- package/dialog/Dialog.test.js +56 -0
- package/dialog/types.d.ts +4 -3
- package/dropdown/Dropdown.d.ts +1 -1
- package/dropdown/Dropdown.js +240 -323
- package/dropdown/Dropdown.stories.tsx +255 -64
- package/dropdown/Dropdown.test.js +479 -0
- package/dropdown/DropdownMenu.d.ts +4 -0
- package/dropdown/DropdownMenu.js +60 -0
- package/dropdown/DropdownMenuItem.d.ts +4 -0
- package/dropdown/DropdownMenuItem.js +70 -0
- package/dropdown/types.d.ts +30 -19
- package/file-input/FileInput.d.ts +2 -2
- package/file-input/FileInput.js +224 -351
- package/file-input/FileInput.stories.tsx +122 -11
- package/file-input/FileInput.test.js +445 -0
- package/file-input/FileItem.d.ts +4 -14
- package/file-input/FileItem.js +48 -97
- package/file-input/types.d.ts +24 -7
- package/flex/Flex.d.ts +4 -0
- package/flex/Flex.js +57 -0
- package/flex/Flex.stories.tsx +103 -0
- package/flex/types.d.ts +32 -0
- package/flex/types.js +5 -0
- package/footer/Footer.js +36 -143
- package/footer/Footer.stories.tsx +99 -1
- package/footer/Footer.test.js +92 -0
- package/footer/Icons.js +1 -5
- package/footer/types.d.ts +7 -6
- package/header/Header.js +112 -177
- package/header/Header.stories.tsx +189 -36
- package/header/Header.test.js +66 -0
- package/header/Icons.js +2 -6
- package/header/types.d.ts +4 -3
- package/heading/Heading.js +8 -29
- package/heading/Heading.test.js +169 -0
- package/heading/types.d.ts +3 -3
- package/inset/Inset.js +14 -55
- package/inset/Inset.stories.tsx +36 -36
- package/inset/types.d.ts +26 -2
- package/layout/ApplicationLayout.d.ts +16 -6
- package/layout/ApplicationLayout.js +71 -164
- package/layout/ApplicationLayout.stories.tsx +84 -93
- package/layout/Icons.d.ts +5 -0
- package/layout/Icons.js +11 -10
- package/layout/SidenavContext.d.ts +5 -0
- package/layout/SidenavContext.js +15 -0
- package/layout/types.d.ts +18 -33
- package/link/Link.d.ts +3 -2
- package/link/Link.js +61 -106
- package/link/Link.stories.tsx +159 -52
- package/link/Link.test.js +65 -0
- package/link/types.d.ts +9 -29
- package/main.d.ts +11 -15
- package/main.js +48 -121
- package/nav-tabs/NavTabs.d.ts +8 -0
- package/nav-tabs/NavTabs.js +95 -0
- package/nav-tabs/NavTabs.stories.tsx +260 -0
- package/nav-tabs/NavTabs.test.js +75 -0
- package/nav-tabs/Tab.d.ts +4 -0
- package/nav-tabs/Tab.js +120 -0
- package/nav-tabs/types.d.ts +53 -0
- package/nav-tabs/types.js +5 -0
- package/number-input/NumberInput.js +21 -38
- package/number-input/NumberInput.stories.tsx +5 -5
- package/number-input/NumberInput.test.js +406 -0
- package/number-input/NumberInputContext.js +0 -5
- package/number-input/numberInputContextTypes.d.ts +1 -1
- package/number-input/types.d.ts +21 -14
- package/package.json +22 -25
- package/paginator/Icons.d.ts +5 -0
- package/paginator/Icons.js +16 -38
- package/paginator/Paginator.js +31 -82
- package/paginator/Paginator.stories.tsx +24 -0
- package/paginator/Paginator.test.js +266 -0
- package/paginator/types.d.ts +1 -1
- package/paragraph/Paragraph.d.ts +6 -0
- package/paragraph/Paragraph.js +28 -0
- package/paragraph/Paragraph.stories.tsx +44 -0
- package/password-input/PasswordInput.js +28 -54
- package/password-input/PasswordInput.test.js +138 -0
- package/password-input/types.d.ts +18 -15
- package/progress-bar/ProgressBar.d.ts +2 -2
- package/progress-bar/ProgressBar.js +65 -84
- package/progress-bar/ProgressBar.stories.jsx +47 -12
- package/progress-bar/ProgressBar.test.js +93 -0
- package/progress-bar/types.d.ts +3 -4
- package/quick-nav/QuickNav.d.ts +4 -0
- package/quick-nav/QuickNav.js +95 -0
- package/quick-nav/QuickNav.stories.tsx +356 -0
- package/quick-nav/types.d.ts +21 -0
- package/quick-nav/types.js +5 -0
- package/radio-group/Radio.d.ts +1 -1
- package/radio-group/Radio.js +61 -66
- package/radio-group/RadioGroup.js +99 -129
- package/radio-group/RadioGroup.stories.tsx +171 -36
- package/radio-group/RadioGroup.test.js +620 -0
- package/radio-group/types.d.ts +85 -7
- package/resultsetTable/Icons.d.ts +7 -0
- package/resultsetTable/Icons.js +48 -0
- package/resultsetTable/ResultsetTable.js +66 -157
- package/resultsetTable/ResultsetTable.stories.tsx +50 -25
- package/resultsetTable/ResultsetTable.test.js +292 -0
- package/resultsetTable/types.d.ts +5 -5
- package/select/Icons.d.ts +10 -0
- package/select/Icons.js +90 -0
- package/select/Listbox.d.ts +4 -0
- package/select/Listbox.js +144 -0
- package/select/Option.d.ts +4 -0
- package/select/Option.js +81 -0
- package/select/Select.js +201 -485
- package/select/Select.stories.tsx +600 -201
- package/select/Select.test.js +1845 -0
- package/select/types.d.ts +62 -22
- package/sidenav/Sidenav.d.ts +6 -5
- package/sidenav/Sidenav.js +164 -74
- package/sidenav/Sidenav.stories.tsx +249 -149
- package/sidenav/Sidenav.test.js +37 -0
- package/sidenav/types.d.ts +50 -27
- package/slider/Slider.d.ts +2 -2
- package/slider/Slider.js +143 -164
- package/slider/Slider.stories.tsx +72 -9
- package/slider/Slider.test.js +222 -0
- package/slider/types.d.ts +11 -3
- package/spinner/Spinner.js +12 -41
- package/spinner/Spinner.stories.jsx +27 -1
- package/spinner/Spinner.test.js +55 -0
- package/spinner/types.d.ts +3 -3
- package/switch/Switch.d.ts +2 -2
- package/switch/Switch.js +148 -107
- package/switch/Switch.stories.tsx +53 -42
- package/switch/Switch.test.js +180 -0
- package/switch/types.d.ts +13 -5
- package/table/Table.js +5 -23
- package/table/Table.stories.jsx +80 -1
- package/table/Table.test.js +21 -0
- package/table/types.d.ts +3 -3
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +115 -0
- package/tabs/Tabs.d.ts +1 -1
- package/tabs/Tabs.js +318 -139
- package/tabs/Tabs.stories.tsx +119 -13
- package/tabs/Tabs.test.js +295 -0
- package/tabs/types.d.ts +21 -7
- package/tag/Tag.d.ts +1 -1
- package/tag/Tag.js +36 -75
- package/tag/Tag.stories.tsx +37 -27
- package/tag/Tag.test.js +49 -0
- package/tag/types.d.ts +25 -16
- package/text-input/Icons.d.ts +8 -0
- package/text-input/Icons.js +57 -0
- package/text-input/Suggestion.d.ts +4 -0
- package/text-input/Suggestion.js +68 -0
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +109 -0
- package/text-input/TextInput.js +232 -438
- package/text-input/TextInput.stories.tsx +310 -197
- package/text-input/TextInput.test.js +1404 -0
- package/text-input/types.d.ts +55 -17
- package/textarea/Textarea.js +53 -96
- package/textarea/Textarea.stories.jsx +93 -13
- package/textarea/Textarea.test.js +360 -0
- package/textarea/types.d.ts +22 -15
- package/toggle-group/ToggleGroup.d.ts +1 -1
- package/toggle-group/ToggleGroup.js +23 -57
- package/toggle-group/ToggleGroup.stories.tsx +46 -4
- package/toggle-group/ToggleGroup.test.js +124 -0
- package/toggle-group/types.d.ts +19 -11
- package/translatedLabelsType.d.ts +82 -0
- package/translatedLabelsType.js +5 -0
- package/typography/Typography.d.ts +4 -0
- package/typography/Typography.js +119 -0
- package/typography/Typography.stories.tsx +198 -0
- package/typography/types.d.ts +18 -0
- package/typography/types.js +5 -0
- package/useTheme.d.ts +1 -1
- package/useTheme.js +3 -9
- package/useTranslatedLabels.d.ts +3 -0
- package/useTranslatedLabels.js +15 -0
- package/wizard/Wizard.d.ts +1 -1
- package/wizard/Wizard.js +68 -98
- package/wizard/Wizard.stories.tsx +48 -19
- package/wizard/Wizard.test.js +114 -0
- package/wizard/types.d.ts +12 -7
- package/ThemeContext.d.ts +0 -15
- package/ThemeContext.js +0 -243
- 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/common/RequiredComponent.js +0 -32
- package/date/Date.js +0 -373
- package/date/index.d.ts +0 -27
- package/input-text/Icons.js +0 -22
- package/input-text/InputText.js +0 -611
- package/input-text/index.d.ts +0 -36
- package/list/List.d.ts +0 -8
- package/list/List.js +0 -47
- package/list/List.stories.tsx +0 -95
- package/radio/Radio.d.ts +0 -4
- package/radio/Radio.js +0 -174
- package/radio/Radio.stories.tsx +0 -192
- package/radio/types.d.ts +0 -54
- package/row/Row.d.ts +0 -11
- package/row/Row.js +0 -127
- package/row/Row.stories.tsx +0 -239
- package/stack/Stack.d.ts +0 -10
- package/stack/Stack.js +0 -97
- package/stack/Stack.stories.tsx +0 -166
- package/text/Text.d.ts +0 -7
- package/text/Text.js +0 -30
- package/text/Text.stories.tsx +0 -19
- package/toggle/Toggle.js +0 -186
- package/toggle/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/{radio → badge}/types.js +0 -0
|
@@ -0,0 +1,222 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _react = _interopRequireDefault(require("react"));
|
|
5
|
+
var _react2 = require("@testing-library/react");
|
|
6
|
+
var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
|
|
7
|
+
var _Slider = _interopRequireDefault(require("./Slider"));
|
|
8
|
+
describe("Slider component tests", function () {
|
|
9
|
+
test("Slider renders with correct text and label id", function () {
|
|
10
|
+
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
11
|
+
label: "label",
|
|
12
|
+
minValue: 0,
|
|
13
|
+
maxValue: 100,
|
|
14
|
+
showLimitsValues: true
|
|
15
|
+
})),
|
|
16
|
+
getByText = _render.getByText,
|
|
17
|
+
getByRole = _render.getByRole;
|
|
18
|
+
expect(getByText("0")).toBeTruthy();
|
|
19
|
+
expect(getByText("100")).toBeTruthy();
|
|
20
|
+
var sliderId = getByText("label").getAttribute("id");
|
|
21
|
+
expect(getByRole("slider").getAttribute("aria-labelledby")).toBe(sliderId);
|
|
22
|
+
expect(getByRole("slider").getAttribute("aria-orientation")).toBe("horizontal");
|
|
23
|
+
});
|
|
24
|
+
test("Slider renders with correct initial value when it is uncontrolled", function () {
|
|
25
|
+
var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
26
|
+
defaultValue: 30,
|
|
27
|
+
minValue: 0,
|
|
28
|
+
maxValue: 100,
|
|
29
|
+
showLimitsValues: true,
|
|
30
|
+
showInput: true
|
|
31
|
+
})),
|
|
32
|
+
getByRole = _render2.getByRole;
|
|
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("Slider correct limit values", function () {
|
|
39
|
+
var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
40
|
+
defaultValue: 125,
|
|
41
|
+
minValue: 30,
|
|
42
|
+
maxValue: 125,
|
|
43
|
+
showLimitsValues: true
|
|
44
|
+
})),
|
|
45
|
+
getByRole = _render3.getByRole,
|
|
46
|
+
getByText = _render3.getByText;
|
|
47
|
+
var slider = getByRole("slider");
|
|
48
|
+
expect(slider.getAttribute("aria-valuemin")).toBe("30");
|
|
49
|
+
expect(slider.getAttribute("aria-valuemax")).toBe("125");
|
|
50
|
+
_userEvent["default"].tab();
|
|
51
|
+
_react2.fireEvent.keyDown(slider, {
|
|
52
|
+
key: "ArrowRight",
|
|
53
|
+
code: "ArrowRight",
|
|
54
|
+
keyCode: 39,
|
|
55
|
+
charCode: 39
|
|
56
|
+
});
|
|
57
|
+
expect(slider.getAttribute("aria-valuenow")).toBe("125");
|
|
58
|
+
expect(getByText("30")).toBeTruthy();
|
|
59
|
+
expect(getByText("125")).toBeTruthy();
|
|
60
|
+
});
|
|
61
|
+
test("Calls correct function onChange in controlled slider", function () {
|
|
62
|
+
var onChange = jest.fn();
|
|
63
|
+
var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
64
|
+
minValue: 0,
|
|
65
|
+
maxValue: 100,
|
|
66
|
+
onChange: onChange,
|
|
67
|
+
showLimitsValues: true,
|
|
68
|
+
value: 13,
|
|
69
|
+
showInput: true
|
|
70
|
+
})),
|
|
71
|
+
getByRole = _render4.getByRole;
|
|
72
|
+
expect(getByRole("slider").getAttribute("aria-valuenow")).toBe("13");
|
|
73
|
+
expect(getByRole("textbox").value).toBe("13");
|
|
74
|
+
(0, _react2.act)(function () {
|
|
75
|
+
_react2.fireEvent.change(getByRole("textbox"), {
|
|
76
|
+
target: {
|
|
77
|
+
value: 25
|
|
78
|
+
}
|
|
79
|
+
});
|
|
80
|
+
});
|
|
81
|
+
expect(onChange).toHaveBeenCalledWith(25);
|
|
82
|
+
expect(getByRole("slider").getAttribute("aria-valuenow")).toBe("13");
|
|
83
|
+
expect(getByRole("textbox").value).toBe("13");
|
|
84
|
+
});
|
|
85
|
+
test("Calls correct function onChange in uncontrolled slider", function () {
|
|
86
|
+
var onChange = jest.fn();
|
|
87
|
+
var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
88
|
+
minValue: 0,
|
|
89
|
+
maxValue: 100,
|
|
90
|
+
onChange: onChange,
|
|
91
|
+
showLimitsValues: true,
|
|
92
|
+
showInput: true
|
|
93
|
+
})),
|
|
94
|
+
getByRole = _render5.getByRole;
|
|
95
|
+
(0, _react2.act)(function () {
|
|
96
|
+
_react2.fireEvent.change(getByRole("textbox"), {
|
|
97
|
+
target: {
|
|
98
|
+
value: 25
|
|
99
|
+
}
|
|
100
|
+
});
|
|
101
|
+
});
|
|
102
|
+
expect(onChange).toHaveBeenCalledWith(25);
|
|
103
|
+
expect(getByRole("slider").getAttribute("aria-valuenow")).toBe("25");
|
|
104
|
+
expect(getByRole("textbox").value).toBe("25");
|
|
105
|
+
});
|
|
106
|
+
test("Disabled slider have disabled input and slider", function () {
|
|
107
|
+
var onChange = jest.fn();
|
|
108
|
+
var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
109
|
+
minValue: 0,
|
|
110
|
+
maxValue: 100,
|
|
111
|
+
onChange: onChange,
|
|
112
|
+
showLimitsValues: true,
|
|
113
|
+
disabled: true,
|
|
114
|
+
showInput: true,
|
|
115
|
+
value: 13
|
|
116
|
+
})),
|
|
117
|
+
getByRole = _render6.getByRole;
|
|
118
|
+
(0, _react2.act)(function () {
|
|
119
|
+
_react2.fireEvent.change(getByRole("textbox"), {
|
|
120
|
+
target: {
|
|
121
|
+
value: 25
|
|
122
|
+
}
|
|
123
|
+
});
|
|
124
|
+
});
|
|
125
|
+
expect(getByRole("textbox").hasAttribute("disabled")).toBeTruthy();
|
|
126
|
+
expect(getByRole("textbox").value).toBe("13");
|
|
127
|
+
expect(getByRole("slider").hasAttribute("disabled")).toBeTruthy();
|
|
128
|
+
});
|
|
129
|
+
test("Calls correct function onDragEnd when it is uncontrolled", function () {
|
|
130
|
+
var onDragEnd = jest.fn();
|
|
131
|
+
var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
132
|
+
minValue: 0,
|
|
133
|
+
maxValue: 150,
|
|
134
|
+
onDragEnd: onDragEnd,
|
|
135
|
+
showInput: true
|
|
136
|
+
})),
|
|
137
|
+
getByRole = _render7.getByRole;
|
|
138
|
+
var slider = getByRole("slider");
|
|
139
|
+
(0, _react2.act)(function () {
|
|
140
|
+
_react2.fireEvent.mouseDown(slider);
|
|
141
|
+
});
|
|
142
|
+
(0, _react2.act)(function () {
|
|
143
|
+
_react2.fireEvent.mouseUp(slider, {
|
|
144
|
+
target: {
|
|
145
|
+
value: 120
|
|
146
|
+
}
|
|
147
|
+
});
|
|
148
|
+
});
|
|
149
|
+
expect(onDragEnd).toHaveBeenCalledWith("120");
|
|
150
|
+
});
|
|
151
|
+
test("Calls correct function onDragEnd when it is controlled", function () {
|
|
152
|
+
var onDragEnd = jest.fn();
|
|
153
|
+
var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
154
|
+
minValue: 0,
|
|
155
|
+
maxValue: 150,
|
|
156
|
+
value: 50,
|
|
157
|
+
onDragEnd: onDragEnd,
|
|
158
|
+
showInput: true
|
|
159
|
+
})),
|
|
160
|
+
getByRole = _render8.getByRole;
|
|
161
|
+
var slider = getByRole("slider");
|
|
162
|
+
(0, _react2.act)(function () {
|
|
163
|
+
_react2.fireEvent.mouseDown(slider);
|
|
164
|
+
});
|
|
165
|
+
(0, _react2.act)(function () {
|
|
166
|
+
_react2.fireEvent.mouseUp(slider, {
|
|
167
|
+
target: {
|
|
168
|
+
value: 120
|
|
169
|
+
}
|
|
170
|
+
});
|
|
171
|
+
});
|
|
172
|
+
expect(onDragEnd).toHaveBeenCalledWith("120");
|
|
173
|
+
expect(slider.getAttribute("aria-valuenow")).toBe("50");
|
|
174
|
+
});
|
|
175
|
+
test("Calls correct function labelFormatCallback", function () {
|
|
176
|
+
var labelFormatCallback = jest.fn(function (x) {
|
|
177
|
+
return "".concat(x, "$");
|
|
178
|
+
});
|
|
179
|
+
var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
180
|
+
minValue: 0,
|
|
181
|
+
maxValue: 100,
|
|
182
|
+
showLimitsValues: true,
|
|
183
|
+
showInput: true,
|
|
184
|
+
value: 25,
|
|
185
|
+
labelFormatCallback: labelFormatCallback
|
|
186
|
+
})),
|
|
187
|
+
getByText = _render9.getByText;
|
|
188
|
+
expect(getByText("0$")).toBeTruthy();
|
|
189
|
+
expect(getByText("100$")).toBeTruthy();
|
|
190
|
+
expect(labelFormatCallback).toHaveBeenCalledTimes(2);
|
|
191
|
+
});
|
|
192
|
+
test("Change value correctly to 0 from external function", function () {
|
|
193
|
+
var onChange = jest.fn();
|
|
194
|
+
var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
195
|
+
minValue: 0,
|
|
196
|
+
maxValue: 100,
|
|
197
|
+
onChange: onChange,
|
|
198
|
+
showLimitsValues: true,
|
|
199
|
+
value: 13,
|
|
200
|
+
showInput: true
|
|
201
|
+
})),
|
|
202
|
+
rerender = _render10.rerender,
|
|
203
|
+
getByRole = _render10.getByRole;
|
|
204
|
+
var slider = getByRole("slider");
|
|
205
|
+
_userEvent["default"].tab();
|
|
206
|
+
_react2.fireEvent.keyDown(slider, {
|
|
207
|
+
key: "ArrowRight",
|
|
208
|
+
code: "ArrowRight",
|
|
209
|
+
keyCode: 39,
|
|
210
|
+
charCode: 39
|
|
211
|
+
});
|
|
212
|
+
rerender( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
213
|
+
minValue: 0,
|
|
214
|
+
maxValue: 100,
|
|
215
|
+
onChange: onChange,
|
|
216
|
+
showLimitsValues: true,
|
|
217
|
+
value: 0,
|
|
218
|
+
showInput: true
|
|
219
|
+
}));
|
|
220
|
+
expect(slider.getAttribute("aria-valuenow")).toBe("0");
|
|
221
|
+
});
|
|
222
|
+
});
|
package/slider/types.d.ts
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
export type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
|
|
2
|
+
export type Margin = {
|
|
3
3
|
top?: Space;
|
|
4
4
|
bottom?: Space;
|
|
5
5
|
left?: Space;
|
|
6
6
|
right?: Space;
|
|
7
7
|
};
|
|
8
|
-
|
|
8
|
+
type Props = {
|
|
9
9
|
/**
|
|
10
10
|
* Text to be placed above the slider.
|
|
11
11
|
*/
|
|
@@ -14,6 +14,10 @@ declare type Props = {
|
|
|
14
14
|
* Name attribute of the input element.
|
|
15
15
|
*/
|
|
16
16
|
name?: string;
|
|
17
|
+
/**
|
|
18
|
+
* Initial value of the slider, only when it is uncontrolled.
|
|
19
|
+
*/
|
|
20
|
+
defaultValue?: number;
|
|
17
21
|
/**
|
|
18
22
|
* The selected value. If undefined, the component will be uncontrolled and the value will be managed internally by the component.
|
|
19
23
|
*/
|
|
@@ -75,4 +79,8 @@ declare type Props = {
|
|
|
75
79
|
*/
|
|
76
80
|
size?: "medium" | "large" | "fillParent";
|
|
77
81
|
};
|
|
82
|
+
/**
|
|
83
|
+
* Reference to the component.
|
|
84
|
+
*/
|
|
85
|
+
export type RefType = HTMLDivElement;
|
|
78
86
|
export default Props;
|
package/spinner/Spinner.js
CHANGED
|
@@ -1,47 +1,34 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
var _typeof3 = require("@babel/runtime/helpers/typeof");
|
|
6
|
-
|
|
7
5
|
Object.defineProperty(exports, "__esModule", {
|
|
8
6
|
value: true
|
|
9
7
|
});
|
|
10
8
|
exports["default"] = void 0;
|
|
11
|
-
|
|
12
9
|
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
|
|
13
|
-
|
|
14
10
|
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
15
|
-
|
|
16
11
|
var _react = _interopRequireWildcard(require("react"));
|
|
17
|
-
|
|
18
12
|
var _styledComponents = _interopRequireWildcard(require("styled-components"));
|
|
19
|
-
|
|
20
|
-
var _variables = require("../common/variables.js");
|
|
21
|
-
|
|
13
|
+
var _variables = require("../common/variables");
|
|
22
14
|
var _useTheme = _interopRequireDefault(require("../useTheme"));
|
|
23
|
-
|
|
24
15
|
var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext"));
|
|
25
|
-
|
|
26
16
|
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11, _templateObject12;
|
|
27
|
-
|
|
28
17
|
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
29
|
-
|
|
30
18
|
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; }
|
|
31
|
-
|
|
32
19
|
var DxcSpinner = function DxcSpinner(_ref) {
|
|
33
20
|
var _ref$label = _ref.label,
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
21
|
+
label = _ref$label === void 0 ? "" : _ref$label,
|
|
22
|
+
value = _ref.value,
|
|
23
|
+
_ref$showValue = _ref.showValue,
|
|
24
|
+
showValue = _ref$showValue === void 0 ? false : _ref$showValue,
|
|
25
|
+
_ref$mode = _ref.mode,
|
|
26
|
+
mode = _ref$mode === void 0 ? "large" : _ref$mode,
|
|
27
|
+
margin = _ref.margin;
|
|
41
28
|
var colorsTheme = (0, _useTheme["default"])();
|
|
42
29
|
var backgroundType = (0, _react.useContext)(_BackgroundColorContext["default"]);
|
|
43
30
|
return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
|
|
44
|
-
theme: colorsTheme
|
|
31
|
+
theme: colorsTheme["spinner"]
|
|
45
32
|
}, /*#__PURE__*/_react["default"].createElement(DXCSpinner, {
|
|
46
33
|
margin: margin,
|
|
47
34
|
mode: mode
|
|
@@ -125,17 +112,13 @@ var DxcSpinner = function DxcSpinner(_ref) {
|
|
|
125
112
|
showValue: showValue
|
|
126
113
|
}, value, "%")))));
|
|
127
114
|
};
|
|
128
|
-
|
|
129
115
|
var determinatedValue = function determinatedValue(props, strokeDashArray) {
|
|
130
116
|
var val = 0;
|
|
131
|
-
|
|
132
117
|
if (props.value >= 0 && props.value <= 100) {
|
|
133
118
|
val = strokeDashArray * (1 - props.value / 100);
|
|
134
119
|
}
|
|
135
|
-
|
|
136
120
|
return val;
|
|
137
121
|
};
|
|
138
|
-
|
|
139
122
|
var DXCSpinner = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n height: ", ";\n width: ", ";\n display: ", ";\n position: ", ";\n top: ", ";\n left: ", ";\n justify-content: ", ";\n align-items: ", ";\n z-index: ", ";\n\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"])), function (props) {
|
|
140
123
|
return props.mode === "overlay" ? "100vh" : "";
|
|
141
124
|
}, function (props) {
|
|
@@ -165,23 +148,18 @@ var DXCSpinner = _styledComponents["default"].div(_templateObject || (_templateO
|
|
|
165
148
|
}, function (props) {
|
|
166
149
|
return props.mode != "overlay" ? props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "" : "";
|
|
167
150
|
});
|
|
168
|
-
|
|
169
151
|
var SpinnerContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n align-items: center;\n display: flex;\n height: ", ";\n width: ", ";\n justify-content: center;\n position: relative;\n background-color: transparent;\n\n @keyframes spinner-svg {\n 0% {\n transform: rotateZ(0deg);\n }\n 100% {\n transform: rotateZ(360deg);\n }\n }\n @keyframes svg-circle-large {\n 0% {\n stroke-dashoffset: 400;\n transform: rotate(0);\n }\n\n 50% {\n stroke-dashoffset: 75;\n transform: rotate(45deg);\n }\n\n 100% {\n stroke-dashoffset: 400;\n transform: rotate(360deg);\n }\n }\n @keyframes svg-circle-small {\n 0% {\n stroke-dashoffset: 35;\n transform: rotate(0);\n }\n\n 50% {\n stroke-dashoffset: 8;\n transform: rotate(45deg);\n }\n\n 100% {\n stroke-dashoffset: 35;\n transform: rotate(360deg);\n }\n }\n"])), function (props) {
|
|
170
152
|
return props.mode === "small" ? "16px" : "140px";
|
|
171
153
|
}, function (props) {
|
|
172
154
|
return props.mode === "small" ? "16px" : "140px";
|
|
173
155
|
});
|
|
174
|
-
|
|
175
156
|
var BackOverlay = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n width: 100vw;\n height: 100vh;\n opacity: 1;\n transition: opacity 225ms cubic-bezier(0.4, 0, 0.2, 1) 0ms;\n position: fixed;\n top: 0;\n left: 0;\n background-color: ", ";\n opacity: ", ";\n"])), function (props) {
|
|
176
157
|
return "".concat(props.theme.overlayBackgroundColor);
|
|
177
158
|
}, function (props) {
|
|
178
159
|
return "".concat(props.theme.overlayOpacity);
|
|
179
160
|
});
|
|
180
|
-
|
|
181
|
-
var BackgroundSpinner = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n height: inherit;\n width: inherit;\n position: absolute;\n z-index: 1;\n"])));
|
|
182
|
-
|
|
161
|
+
var BackgroundSpinner = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n height: inherit;\n width: inherit;\n position: absolute;\n"])));
|
|
183
162
|
var SVGBackground = _styledComponents["default"].svg(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n height: inherit;\n width: inherit;\n"])));
|
|
184
|
-
|
|
185
163
|
var CircleBackground = _styledComponents["default"].circle(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n animation: none;\n fill: transparent;\n stroke: ", ";\n stroke-dasharray: ", ";\n stroke-linecap: initial;\n stroke-width: ", ";\n transform-origin: 50% 50%;\n vector-effect: non-scaling-stroke;\n"])), function (props) {
|
|
186
164
|
return "".concat(props.theme.totalCircleColor);
|
|
187
165
|
}, function (props) {
|
|
@@ -189,17 +167,14 @@ var CircleBackground = _styledComponents["default"].circle(_templateObject6 || (
|
|
|
189
167
|
}, function (props) {
|
|
190
168
|
return props.mode !== "small" ? "8.5px" : "2px";
|
|
191
169
|
});
|
|
192
|
-
|
|
193
|
-
var Spinner = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n height: inherit;\n width: inherit;\n position: relative;\n z-index: 2;\n"])));
|
|
194
|
-
|
|
170
|
+
var Spinner = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n height: inherit;\n width: inherit;\n position: relative;\n"])));
|
|
195
171
|
var SVGSpinner = _styledComponents["default"].svg(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n height: inherit;\n width: inherit;\n transform: rotate(-90deg);\n top: 0;\n left: 0;\n transform-origin: center;\n overflow: visible;\n animation: ", ";\n"])), function (props) {
|
|
196
172
|
return !props.isDeterminated ? "1.4s linear infinite both spinner-svg" : "";
|
|
197
173
|
});
|
|
198
|
-
|
|
199
174
|
var CircleSpinner = _styledComponents["default"].circle(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n fill: transparent;\n stroke-linecap: initial;\n vector-effect: non-scaling-stroke;\n animation: ", ";\n stroke: ", ";\n transform-origin: ", ";\n stroke-dasharray: ", ";\n stroke-width: ", ";\n stroke-dashoffset: ", ";\n"])), function (props) {
|
|
200
175
|
return props.isDeterminated ? "none" : props.mode !== "small" ? "1.4s ease-in-out infinite both svg-circle-large" : "1.4s ease-in-out infinite both svg-circle-small";
|
|
201
176
|
}, function (props) {
|
|
202
|
-
return props.backgroundType === "dark" ? props.theme.
|
|
177
|
+
return props.backgroundType === "dark" || props.mode === "overlay" ? props.theme.trackCircleColorOverlay : props.theme.trackCircleColor;
|
|
203
178
|
}, function (props) {
|
|
204
179
|
return !props.isDeterminated ? "50% 50%" : "";
|
|
205
180
|
}, function (props) {
|
|
@@ -209,9 +184,7 @@ var CircleSpinner = _styledComponents["default"].circle(_templateObject9 || (_te
|
|
|
209
184
|
}, function (props) {
|
|
210
185
|
return props.isDeterminated ? props.mode !== "small" ? determinatedValue(props, 409) : determinatedValue(props, 38) : "";
|
|
211
186
|
});
|
|
212
|
-
|
|
213
187
|
var LabelsContainer = _styledComponents["default"].div(_templateObject10 || (_templateObject10 = (0, _taggedTemplateLiteral2["default"])(["\n display: block;\n margin: 0 auto;\n position: absolute;\n text-align: center;\n width: 110px;\n"])));
|
|
214
|
-
|
|
215
188
|
var SpinnerLabel = _styledComponents["default"].p(_templateObject11 || (_templateObject11 = (0, _taggedTemplateLiteral2["default"])(["\n margin: 0;\n width: 100%;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n font-family: ", ";\n font-weight: ", ";\n font-size: ", ";\n font-style: ", ";\n color: ", ";\n text-align: ", ";\n letter-spacing: ", ";\n"])), function (props) {
|
|
216
189
|
return props.mode === "overlay" ? props.theme.overlayLabelFontFamily : props.theme.labelFontFamily;
|
|
217
190
|
}, function (props) {
|
|
@@ -227,7 +200,6 @@ var SpinnerLabel = _styledComponents["default"].p(_templateObject11 || (_templat
|
|
|
227
200
|
}, function (props) {
|
|
228
201
|
return props.mode === "overlay" ? props.theme.overlayLabelLetterSpacing : props.theme.labelLetterSpacing;
|
|
229
202
|
});
|
|
230
|
-
|
|
231
203
|
var SpinnerProgress = _styledComponents["default"].p(_templateObject12 || (_templateObject12 = (0, _taggedTemplateLiteral2["default"])(["\n margin: 0;\n width: 100%;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n display: ", ";\n font-family: ", ";\n font-weight: ", ";\n font-size: ", ";\n font-style: ", ";\n color: ", ";\n text-align: ", ";\n letter-spacing: ", ";\n"])), function (props) {
|
|
232
204
|
return props.value !== "" && props.showValue === true && "block" || "none";
|
|
233
205
|
}, function (props) {
|
|
@@ -245,6 +217,5 @@ var SpinnerProgress = _styledComponents["default"].p(_templateObject12 || (_temp
|
|
|
245
217
|
}, function (props) {
|
|
246
218
|
return props.mode === "overlay" ? props.theme.overlayProgressValueLetterSpacing : props.theme.progressValueLetterSpacing;
|
|
247
219
|
});
|
|
248
|
-
|
|
249
220
|
var _default = DxcSpinner;
|
|
250
221
|
exports["default"] = _default;
|
|
@@ -2,12 +2,23 @@ import React from "react";
|
|
|
2
2
|
import DxcSpinner from "./Spinner";
|
|
3
3
|
import Title from "../../.storybook/components/Title";
|
|
4
4
|
import ExampleContainer from "../../.storybook/components/ExampleContainer";
|
|
5
|
+
import { HalstackProvider } from "../HalstackContext";
|
|
5
6
|
|
|
6
7
|
export default {
|
|
7
8
|
title: "Spinner",
|
|
8
9
|
component: DxcSpinner,
|
|
9
10
|
};
|
|
10
11
|
|
|
12
|
+
const opinionatedTheme = {
|
|
13
|
+
spinner: {
|
|
14
|
+
accentColor: "#5f249f",
|
|
15
|
+
baseColor: "#ffffff",
|
|
16
|
+
fontColor: "#000000",
|
|
17
|
+
overlayColor: "#a46ede",
|
|
18
|
+
overlayFontColor: "#ffffff",
|
|
19
|
+
},
|
|
20
|
+
};
|
|
21
|
+
|
|
11
22
|
export const Chromatic = () => (
|
|
12
23
|
<>
|
|
13
24
|
<ExampleContainer>
|
|
@@ -62,7 +73,13 @@ export const Chromatic = () => (
|
|
|
62
73
|
<DxcSpinner margin="xlarge" mode="small" value="75"></DxcSpinner>
|
|
63
74
|
<Title title="Xxlarge margin" theme="light" level={4} />
|
|
64
75
|
<DxcSpinner margin="xxlarge" mode="small" value="75"></DxcSpinner>
|
|
65
|
-
|
|
76
|
+
</ExampleContainer>
|
|
77
|
+
<Title title="Opinionated theme" theme="light" level={2} />
|
|
78
|
+
<ExampleContainer>
|
|
79
|
+
<Title title="With label and value label" theme="light" level={4} />
|
|
80
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
81
|
+
<DxcSpinner label="Label" value="50" showValue></DxcSpinner>
|
|
82
|
+
</HalstackProvider>
|
|
66
83
|
</ExampleContainer>
|
|
67
84
|
</>
|
|
68
85
|
);
|
|
@@ -101,3 +118,12 @@ export const SpinnerOverlayWithValueAndLabel = () => (
|
|
|
101
118
|
<DxcSpinner mode="overlay" label="Label" value="50" showValue></DxcSpinner>
|
|
102
119
|
</ExampleContainer>
|
|
103
120
|
);
|
|
121
|
+
|
|
122
|
+
export const SpinnerOverlayWithValueAndLabelOpinionated = () => (
|
|
123
|
+
<ExampleContainer>
|
|
124
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
125
|
+
<Title title="Mode overlay" theme="light" level={4} />
|
|
126
|
+
<DxcSpinner mode="overlay" label="Label" value="50" showValue></DxcSpinner>
|
|
127
|
+
</HalstackProvider>
|
|
128
|
+
</ExampleContainer>
|
|
129
|
+
);
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _react = _interopRequireDefault(require("react"));
|
|
5
|
+
var _react2 = require("@testing-library/react");
|
|
6
|
+
var _Spinner = _interopRequireDefault(require("./Spinner"));
|
|
7
|
+
describe("Spinner component tests", function () {
|
|
8
|
+
test("Spinner renders with correct label", function () {
|
|
9
|
+
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Spinner["default"], {
|
|
10
|
+
label: "test-loading"
|
|
11
|
+
})),
|
|
12
|
+
getByText = _render.getByText;
|
|
13
|
+
expect(getByText("test-loading")).toBeTruthy();
|
|
14
|
+
});
|
|
15
|
+
test("Spinner shows value correctly", function () {
|
|
16
|
+
var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Spinner["default"], {
|
|
17
|
+
label: "test-loading",
|
|
18
|
+
value: 75,
|
|
19
|
+
showValue: true
|
|
20
|
+
})),
|
|
21
|
+
getByText = _render2.getByText;
|
|
22
|
+
expect(getByText("75%")).toBeTruthy();
|
|
23
|
+
});
|
|
24
|
+
test("Small spinner hides value and label correctly", function () {
|
|
25
|
+
var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Spinner["default"], {
|
|
26
|
+
mode: "small",
|
|
27
|
+
label: "test-loading",
|
|
28
|
+
value: 75,
|
|
29
|
+
showValue: true
|
|
30
|
+
})),
|
|
31
|
+
queryByText = _render3.queryByText;
|
|
32
|
+
expect(queryByText("test-loading")).toBeFalsy();
|
|
33
|
+
expect(queryByText("75%")).toBeFalsy();
|
|
34
|
+
});
|
|
35
|
+
test("Overlay spinner shows value and label correctly", function () {
|
|
36
|
+
var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Spinner["default"], {
|
|
37
|
+
mode: "overlay",
|
|
38
|
+
label: "test-loading",
|
|
39
|
+
value: 75,
|
|
40
|
+
showValue: true
|
|
41
|
+
})),
|
|
42
|
+
getByText = _render4.getByText;
|
|
43
|
+
expect(getByText("test-loading")).toBeTruthy();
|
|
44
|
+
expect(getByText("75%")).toBeTruthy();
|
|
45
|
+
});
|
|
46
|
+
test("Get spinner by role", function () {
|
|
47
|
+
var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Spinner["default"], {
|
|
48
|
+
label: "test-loading",
|
|
49
|
+
value: 75,
|
|
50
|
+
showValue: true
|
|
51
|
+
})),
|
|
52
|
+
getByRole = _render5.getByRole;
|
|
53
|
+
expect(getByRole("progressbar")).toBeTruthy();
|
|
54
|
+
});
|
|
55
|
+
});
|
package/spinner/types.d.ts
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
|
|
2
|
+
type Margin = {
|
|
3
3
|
top?: Space;
|
|
4
4
|
bottom?: Space;
|
|
5
5
|
left?: Space;
|
|
6
6
|
right?: Space;
|
|
7
7
|
};
|
|
8
|
-
|
|
8
|
+
type Props = {
|
|
9
9
|
/**
|
|
10
10
|
* Text to be placed inside the spinner.
|
|
11
11
|
*/
|
package/switch/Switch.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
|
|
1
|
+
import React from "react";
|
|
2
2
|
import SwitchPropsType from "./types";
|
|
3
|
-
declare const DxcSwitch:
|
|
3
|
+
declare const DxcSwitch: React.ForwardRefExoticComponent<SwitchPropsType & React.RefAttributes<HTMLDivElement>>;
|
|
4
4
|
export default DxcSwitch;
|