@dxc-technology/halstack-react 0.0.0-ecc45e2 → 0.0.0-ede733c
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 -1
- package/HalstackContext.d.ts +1329 -5
- package/HalstackContext.js +117 -77
- package/accordion/Accordion.js +118 -110
- package/accordion/Accordion.stories.tsx +103 -15
- package/accordion/Accordion.test.js +10 -11
- package/accordion/types.d.ts +1 -0
- package/accordion-group/AccordionGroup.d.ts +4 -3
- package/accordion-group/AccordionGroup.js +24 -65
- package/accordion-group/AccordionGroup.stories.tsx +27 -1
- package/accordion-group/AccordionGroup.test.js +21 -46
- package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
- package/accordion-group/AccordionGroupAccordion.js +43 -0
- package/accordion-group/types.d.ts +7 -0
- package/alert/Alert.js +5 -9
- package/alert/Alert.stories.tsx +28 -0
- package/alert/Alert.test.js +1 -1
- package/bleed/Bleed.stories.tsx +1 -0
- package/box/Box.js +4 -6
- package/box/Box.stories.tsx +15 -0
- package/box/Box.test.js +1 -1
- package/box/types.d.ts +1 -0
- package/bulleted-list/BulletedList.js +4 -2
- package/bulleted-list/BulletedList.stories.tsx +7 -1
- package/bulleted-list/types.d.ts +31 -4
- package/button/Button.js +13 -16
- package/button/Button.stories.tsx +151 -9
- package/button/Button.test.js +1 -1
- package/button/types.d.ts +3 -3
- package/card/Card.js +12 -13
- package/card/Card.stories.tsx +12 -13
- package/card/Card.test.js +1 -1
- package/card/types.d.ts +1 -0
- package/checkbox/Checkbox.d.ts +2 -2
- package/checkbox/Checkbox.js +94 -101
- package/checkbox/Checkbox.stories.tsx +131 -59
- package/checkbox/Checkbox.test.js +94 -17
- package/checkbox/types.d.ts +4 -0
- package/chip/Chip.js +28 -49
- package/chip/Chip.stories.tsx +121 -26
- package/chip/Chip.test.js +3 -5
- package/common/OpenSans.css +68 -80
- package/common/coreTokens.d.ts +146 -0
- package/common/coreTokens.js +167 -0
- package/common/utils.d.ts +1 -0
- package/common/utils.js +4 -4
- package/common/variables.d.ts +1482 -0
- package/common/variables.js +994 -1137
- package/date-input/Calendar.d.ts +4 -0
- package/date-input/Calendar.js +258 -0
- package/date-input/DateInput.js +134 -237
- package/date-input/DateInput.stories.tsx +199 -33
- package/date-input/DateInput.test.js +494 -138
- package/date-input/DatePicker.d.ts +4 -0
- package/date-input/DatePicker.js +146 -0
- package/date-input/Icons.d.ts +6 -0
- package/date-input/Icons.js +75 -0
- package/date-input/YearPicker.d.ts +4 -0
- package/date-input/YearPicker.js +126 -0
- package/date-input/types.d.ts +51 -0
- package/dialog/Dialog.js +60 -73
- package/dialog/Dialog.stories.tsx +229 -121
- package/dialog/Dialog.test.js +302 -3
- package/dialog/types.d.ts +3 -2
- package/dropdown/Dropdown.js +43 -42
- package/dropdown/Dropdown.stories.tsx +210 -84
- package/dropdown/Dropdown.test.js +22 -27
- package/dropdown/DropdownMenu.js +12 -18
- package/dropdown/DropdownMenuItem.js +5 -18
- package/dropdown/types.d.ts +3 -3
- package/file-input/FileInput.d.ts +2 -2
- package/file-input/FileInput.js +174 -220
- package/file-input/FileInput.stories.tsx +122 -11
- package/file-input/FileInput.test.js +14 -14
- package/file-input/FileItem.d.ts +4 -14
- package/file-input/FileItem.js +39 -63
- package/file-input/types.d.ts +17 -0
- package/flex/Flex.d.ts +1 -1
- package/flex/Flex.js +33 -19
- package/flex/Flex.stories.tsx +35 -26
- package/flex/types.d.ts +83 -7
- package/footer/Footer.js +6 -8
- package/footer/Footer.stories.tsx +99 -1
- package/footer/Footer.test.js +14 -26
- package/footer/types.d.ts +1 -0
- package/grid/Grid.d.ts +7 -0
- package/grid/Grid.js +91 -0
- package/grid/Grid.stories.tsx +219 -0
- package/grid/types.d.ts +115 -0
- package/header/Header.d.ts +3 -2
- package/header/Header.js +21 -23
- package/header/Header.stories.tsx +152 -9
- package/header/Header.test.js +2 -2
- package/header/types.d.ts +3 -2
- package/heading/Heading.js +1 -1
- package/heading/Heading.test.js +1 -1
- package/inset/Inset.stories.tsx +2 -1
- package/layout/ApplicationLayout.d.ts +3 -3
- package/layout/ApplicationLayout.js +1 -1
- package/layout/ApplicationLayout.stories.tsx +1 -0
- package/layout/types.d.ts +2 -3
- package/link/Link.js +4 -4
- package/link/Link.stories.tsx +60 -0
- package/link/Link.test.js +2 -4
- package/link/types.d.ts +2 -2
- package/main.d.ts +3 -2
- package/main.js +9 -1
- package/{tabs-nav → nav-tabs}/NavTabs.js +1 -1
- package/{tabs-nav → nav-tabs}/NavTabs.stories.tsx +96 -6
- package/{tabs-nav → nav-tabs}/NavTabs.test.js +1 -1
- package/{tabs-nav → nav-tabs}/Tab.js +38 -18
- package/nav-tabs/types.js +5 -0
- package/number-input/NumberInput.test.js +44 -8
- package/package.json +15 -20
- package/paginator/Icons.d.ts +5 -0
- package/paginator/Icons.js +16 -28
- package/paginator/Paginator.js +7 -15
- package/paginator/Paginator.stories.tsx +24 -0
- package/paginator/Paginator.test.js +45 -48
- package/paragraph/Paragraph.d.ts +3 -4
- package/paragraph/Paragraph.js +5 -5
- package/password-input/PasswordInput.test.js +14 -13
- package/progress-bar/ProgressBar.d.ts +2 -2
- package/progress-bar/ProgressBar.js +5 -5
- package/progress-bar/ProgressBar.stories.jsx +35 -2
- package/progress-bar/ProgressBar.test.js +1 -1
- package/progress-bar/types.d.ts +4 -3
- package/quick-nav/QuickNav.js +11 -12
- package/quick-nav/QuickNav.stories.tsx +111 -19
- package/radio-group/Radio.d.ts +1 -1
- package/radio-group/Radio.js +43 -28
- package/radio-group/RadioGroup.js +15 -13
- package/radio-group/RadioGroup.stories.tsx +132 -18
- package/radio-group/RadioGroup.test.js +124 -97
- package/radio-group/types.d.ts +2 -2
- package/resultsetTable/Icons.d.ts +7 -0
- package/resultsetTable/Icons.js +51 -0
- package/resultsetTable/ResultsetTable.js +49 -108
- package/resultsetTable/ResultsetTable.stories.tsx +50 -25
- package/resultsetTable/ResultsetTable.test.js +41 -64
- package/resultsetTable/types.d.ts +1 -1
- package/select/Listbox.d.ts +1 -1
- package/select/Listbox.js +5 -35
- package/select/Option.js +11 -24
- package/select/Select.js +59 -36
- package/select/Select.stories.tsx +494 -150
- package/select/Select.test.js +341 -288
- package/select/types.d.ts +2 -2
- package/sidenav/Icons.d.ts +7 -0
- package/sidenav/Icons.js +51 -0
- package/sidenav/Sidenav.d.ts +2 -2
- package/sidenav/Sidenav.js +66 -96
- package/sidenav/Sidenav.stories.tsx +165 -63
- package/sidenav/types.d.ts +21 -18
- package/slider/Slider.d.ts +2 -2
- package/slider/Slider.js +119 -95
- package/slider/Slider.stories.tsx +64 -1
- package/slider/Slider.test.js +88 -25
- package/slider/types.d.ts +4 -0
- package/spinner/Spinner.js +17 -23
- package/spinner/Spinner.stories.jsx +53 -27
- package/spinner/Spinner.test.js +1 -1
- package/switch/Switch.d.ts +3 -3
- package/switch/Switch.js +96 -85
- package/switch/Switch.stories.tsx +33 -0
- package/switch/Switch.test.js +27 -14
- package/switch/types.d.ts +8 -3
- package/table/Table.js +3 -3
- package/table/Table.stories.jsx +80 -1
- package/table/Table.test.js +2 -2
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +132 -0
- package/tabs/Tabs.js +358 -108
- package/tabs/Tabs.stories.tsx +119 -5
- package/tabs/Tabs.test.js +220 -10
- package/tabs/types.d.ts +12 -2
- package/tag/Tag.js +8 -10
- package/tag/Tag.stories.tsx +14 -1
- package/tag/Tag.test.js +1 -1
- package/text-input/Icons.d.ts +8 -0
- package/text-input/Icons.js +60 -0
- package/text-input/Suggestion.js +40 -11
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +134 -0
- package/text-input/TextInput.js +189 -277
- package/text-input/TextInput.stories.tsx +280 -184
- package/text-input/TextInput.test.js +736 -725
- package/text-input/types.d.ts +21 -2
- package/textarea/Textarea.js +3 -4
- package/textarea/Textarea.stories.jsx +60 -1
- package/textarea/Textarea.test.js +2 -4
- package/toggle-group/ToggleGroup.d.ts +2 -2
- package/toggle-group/ToggleGroup.js +7 -4
- package/toggle-group/ToggleGroup.stories.tsx +42 -0
- package/toggle-group/ToggleGroup.test.js +1 -1
- package/toggle-group/types.d.ts +1 -1
- package/typography/Typography.d.ts +2 -2
- package/typography/Typography.js +14 -113
- package/typography/Typography.stories.tsx +1 -1
- package/useTheme.d.ts +1234 -1
- package/useTheme.js +1 -1
- package/useTranslatedLabels.d.ts +84 -1
- package/utils/BaseTypography.d.ts +21 -0
- package/utils/BaseTypography.js +108 -0
- package/utils/FocusLock.d.ts +13 -0
- package/utils/FocusLock.js +138 -0
- package/wizard/Wizard.js +2 -2
- package/wizard/Wizard.stories.tsx +20 -0
- package/wizard/Wizard.test.js +1 -1
- package/wizard/types.d.ts +5 -6
- package/common/RequiredComponent.js +0 -32
- /package/{tabs-nav → grid}/types.js +0 -0
- /package/{tabs-nav → nav-tabs}/NavTabs.d.ts +0 -0
- /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
- /package/{tabs-nav → nav-tabs}/types.d.ts +0 -0
package/slider/Slider.test.js
CHANGED
|
@@ -8,19 +8,24 @@ var _react2 = require("@testing-library/react");
|
|
|
8
8
|
|
|
9
9
|
var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
|
|
10
10
|
|
|
11
|
-
var _Slider = _interopRequireDefault(require("./Slider"));
|
|
11
|
+
var _Slider = _interopRequireDefault(require("./Slider.tsx"));
|
|
12
12
|
|
|
13
13
|
describe("Slider component tests", function () {
|
|
14
|
-
test("Slider renders with correct text", function () {
|
|
14
|
+
test("Slider renders with correct text and label id", function () {
|
|
15
15
|
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
16
|
+
label: "label",
|
|
16
17
|
minValue: 0,
|
|
17
18
|
maxValue: 100,
|
|
18
19
|
showLimitsValues: true
|
|
19
20
|
})),
|
|
20
|
-
getByText = _render.getByText
|
|
21
|
+
getByText = _render.getByText,
|
|
22
|
+
getByRole = _render.getByRole;
|
|
21
23
|
|
|
22
24
|
expect(getByText("0")).toBeTruthy();
|
|
23
25
|
expect(getByText("100")).toBeTruthy();
|
|
26
|
+
var sliderId = getByText("label").getAttribute("id");
|
|
27
|
+
expect(getByRole("slider").getAttribute("aria-labelledby")).toBe(sliderId);
|
|
28
|
+
expect(getByRole("slider").getAttribute("aria-orientation")).toBe("horizontal");
|
|
24
29
|
});
|
|
25
30
|
test("Slider renders with correct initial value when it is uncontrolled", function () {
|
|
26
31
|
var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
@@ -37,10 +42,37 @@ describe("Slider component tests", function () {
|
|
|
37
42
|
expect(slider.getAttribute("aria-valuenow")).toBe("30");
|
|
38
43
|
expect(input.value).toBe("30");
|
|
39
44
|
});
|
|
45
|
+
test("Slider correct limit values", function () {
|
|
46
|
+
var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
47
|
+
defaultValue: 125,
|
|
48
|
+
minValue: 30,
|
|
49
|
+
maxValue: 125,
|
|
50
|
+
showLimitsValues: true
|
|
51
|
+
})),
|
|
52
|
+
getByRole = _render3.getByRole,
|
|
53
|
+
getByText = _render3.getByText;
|
|
54
|
+
|
|
55
|
+
var slider = getByRole("slider");
|
|
56
|
+
expect(slider.getAttribute("aria-valuemin")).toBe("30");
|
|
57
|
+
expect(slider.getAttribute("aria-valuemax")).toBe("125");
|
|
58
|
+
|
|
59
|
+
_userEvent["default"].tab();
|
|
60
|
+
|
|
61
|
+
_react2.fireEvent.keyDown(slider, {
|
|
62
|
+
key: "ArrowRight",
|
|
63
|
+
code: "ArrowRight",
|
|
64
|
+
keyCode: 39,
|
|
65
|
+
charCode: 39
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
expect(slider.getAttribute("aria-valuenow")).toBe("125");
|
|
69
|
+
expect(getByText("30")).toBeTruthy();
|
|
70
|
+
expect(getByText("125")).toBeTruthy();
|
|
71
|
+
});
|
|
40
72
|
test("Calls correct function onChange in controlled slider", function () {
|
|
41
73
|
var onChange = jest.fn();
|
|
42
74
|
|
|
43
|
-
var
|
|
75
|
+
var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
44
76
|
minValue: 0,
|
|
45
77
|
maxValue: 100,
|
|
46
78
|
onChange: onChange,
|
|
@@ -48,7 +80,7 @@ describe("Slider component tests", function () {
|
|
|
48
80
|
value: 13,
|
|
49
81
|
showInput: true
|
|
50
82
|
})),
|
|
51
|
-
getByRole =
|
|
83
|
+
getByRole = _render4.getByRole;
|
|
52
84
|
|
|
53
85
|
expect(getByRole("slider").getAttribute("aria-valuenow")).toBe("13");
|
|
54
86
|
expect(getByRole("textbox").value).toBe("13");
|
|
@@ -66,14 +98,14 @@ describe("Slider component tests", function () {
|
|
|
66
98
|
test("Calls correct function onChange in uncontrolled slider", function () {
|
|
67
99
|
var onChange = jest.fn();
|
|
68
100
|
|
|
69
|
-
var
|
|
101
|
+
var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
70
102
|
minValue: 0,
|
|
71
103
|
maxValue: 100,
|
|
72
104
|
onChange: onChange,
|
|
73
105
|
showLimitsValues: true,
|
|
74
106
|
showInput: true
|
|
75
107
|
})),
|
|
76
|
-
getByRole =
|
|
108
|
+
getByRole = _render5.getByRole;
|
|
77
109
|
|
|
78
110
|
(0, _react2.act)(function () {
|
|
79
111
|
_react2.fireEvent.change(getByRole("textbox"), {
|
|
@@ -86,10 +118,10 @@ describe("Slider component tests", function () {
|
|
|
86
118
|
expect(getByRole("slider").getAttribute("aria-valuenow")).toBe("25");
|
|
87
119
|
expect(getByRole("textbox").value).toBe("25");
|
|
88
120
|
});
|
|
89
|
-
test("Disabled slider have disabled input", function () {
|
|
121
|
+
test("Disabled slider have disabled input and slider", function () {
|
|
90
122
|
var onChange = jest.fn();
|
|
91
123
|
|
|
92
|
-
var
|
|
124
|
+
var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
93
125
|
minValue: 0,
|
|
94
126
|
maxValue: 100,
|
|
95
127
|
onChange: onChange,
|
|
@@ -98,7 +130,7 @@ describe("Slider component tests", function () {
|
|
|
98
130
|
showInput: true,
|
|
99
131
|
value: 13
|
|
100
132
|
})),
|
|
101
|
-
getByRole =
|
|
133
|
+
getByRole = _render6.getByRole;
|
|
102
134
|
|
|
103
135
|
(0, _react2.act)(function () {
|
|
104
136
|
_react2.fireEvent.change(getByRole("textbox"), {
|
|
@@ -109,33 +141,64 @@ describe("Slider component tests", function () {
|
|
|
109
141
|
});
|
|
110
142
|
expect(getByRole("textbox").hasAttribute("disabled")).toBeTruthy();
|
|
111
143
|
expect(getByRole("textbox").value).toBe("13");
|
|
144
|
+
expect(getByRole("slider").hasAttribute("disabled")).toBeTruthy();
|
|
112
145
|
});
|
|
113
|
-
test("Calls correct function onDragEnd", function () {
|
|
146
|
+
test("Calls correct function onDragEnd when it is uncontrolled", function () {
|
|
114
147
|
var onDragEnd = jest.fn();
|
|
115
148
|
|
|
116
|
-
var
|
|
149
|
+
var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
117
150
|
minValue: 0,
|
|
118
|
-
maxValue:
|
|
119
|
-
showLimitsValues: true,
|
|
120
|
-
showInput: true,
|
|
151
|
+
maxValue: 150,
|
|
121
152
|
onDragEnd: onDragEnd,
|
|
122
|
-
|
|
153
|
+
showInput: true
|
|
123
154
|
})),
|
|
124
|
-
getByRole =
|
|
155
|
+
getByRole = _render7.getByRole;
|
|
125
156
|
|
|
157
|
+
var slider = getByRole("slider");
|
|
158
|
+
(0, _react2.act)(function () {
|
|
159
|
+
_react2.fireEvent.mouseDown(slider);
|
|
160
|
+
});
|
|
126
161
|
(0, _react2.act)(function () {
|
|
127
|
-
_react2.fireEvent.
|
|
162
|
+
_react2.fireEvent.mouseUp(slider, {
|
|
163
|
+
target: {
|
|
164
|
+
value: 120
|
|
165
|
+
}
|
|
166
|
+
});
|
|
167
|
+
});
|
|
168
|
+
expect(onDragEnd).toHaveBeenCalledWith("120");
|
|
169
|
+
});
|
|
170
|
+
test("Calls correct function onDragEnd when it is controlled", function () {
|
|
171
|
+
var onDragEnd = jest.fn();
|
|
172
|
+
|
|
173
|
+
var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
174
|
+
minValue: 0,
|
|
175
|
+
maxValue: 150,
|
|
176
|
+
value: 50,
|
|
177
|
+
onDragEnd: onDragEnd,
|
|
178
|
+
showInput: true
|
|
179
|
+
})),
|
|
180
|
+
getByRole = _render8.getByRole;
|
|
128
181
|
|
|
129
|
-
|
|
182
|
+
var slider = getByRole("slider");
|
|
183
|
+
(0, _react2.act)(function () {
|
|
184
|
+
_react2.fireEvent.mouseDown(slider);
|
|
130
185
|
});
|
|
131
|
-
|
|
186
|
+
(0, _react2.act)(function () {
|
|
187
|
+
_react2.fireEvent.mouseUp(slider, {
|
|
188
|
+
target: {
|
|
189
|
+
value: 120
|
|
190
|
+
}
|
|
191
|
+
});
|
|
192
|
+
});
|
|
193
|
+
expect(onDragEnd).toHaveBeenCalledWith("120");
|
|
194
|
+
expect(slider.getAttribute("aria-valuenow")).toBe("50");
|
|
132
195
|
});
|
|
133
196
|
test("Calls correct function labelFormatCallback", function () {
|
|
134
197
|
var labelFormatCallback = jest.fn(function (x) {
|
|
135
198
|
return "".concat(x, "$");
|
|
136
199
|
});
|
|
137
200
|
|
|
138
|
-
var
|
|
201
|
+
var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
139
202
|
minValue: 0,
|
|
140
203
|
maxValue: 100,
|
|
141
204
|
showLimitsValues: true,
|
|
@@ -143,7 +206,7 @@ describe("Slider component tests", function () {
|
|
|
143
206
|
value: 25,
|
|
144
207
|
labelFormatCallback: labelFormatCallback
|
|
145
208
|
})),
|
|
146
|
-
getByText =
|
|
209
|
+
getByText = _render9.getByText;
|
|
147
210
|
|
|
148
211
|
expect(getByText("0$")).toBeTruthy();
|
|
149
212
|
expect(getByText("100$")).toBeTruthy();
|
|
@@ -152,7 +215,7 @@ describe("Slider component tests", function () {
|
|
|
152
215
|
test("Change value correctly to 0 from external function", function () {
|
|
153
216
|
var onChange = jest.fn();
|
|
154
217
|
|
|
155
|
-
var
|
|
218
|
+
var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
156
219
|
minValue: 0,
|
|
157
220
|
maxValue: 100,
|
|
158
221
|
onChange: onChange,
|
|
@@ -160,8 +223,8 @@ describe("Slider component tests", function () {
|
|
|
160
223
|
value: 13,
|
|
161
224
|
showInput: true
|
|
162
225
|
})),
|
|
163
|
-
rerender =
|
|
164
|
-
getByRole =
|
|
226
|
+
rerender = _render10.rerender,
|
|
227
|
+
getByRole = _render10.getByRole;
|
|
165
228
|
|
|
166
229
|
var slider = getByRole("slider");
|
|
167
230
|
|
package/slider/types.d.ts
CHANGED
package/spinner/Spinner.js
CHANGED
|
@@ -17,7 +17,7 @@ var _react = _interopRequireWildcard(require("react"));
|
|
|
17
17
|
|
|
18
18
|
var _styledComponents = _interopRequireWildcard(require("styled-components"));
|
|
19
19
|
|
|
20
|
-
var _variables = require("../common/variables
|
|
20
|
+
var _variables = require("../common/variables");
|
|
21
21
|
|
|
22
22
|
var _useTheme = _interopRequireDefault(require("../useTheme"));
|
|
23
23
|
|
|
@@ -46,11 +46,8 @@ var DxcSpinner = function DxcSpinner(_ref) {
|
|
|
46
46
|
margin: margin,
|
|
47
47
|
mode: mode
|
|
48
48
|
}, /*#__PURE__*/_react["default"].createElement(SpinnerContainer, {
|
|
49
|
-
backgroundType: backgroundType,
|
|
50
|
-
mode: mode
|
|
51
|
-
}, mode === "overlay" && /*#__PURE__*/_react["default"].createElement(BackOverlay, null), /*#__PURE__*/_react["default"].createElement(BackgroundSpinner, {
|
|
52
49
|
mode: mode
|
|
53
|
-
}, mode !== "small" && /*#__PURE__*/_react["default"].createElement(SVGBackground, {
|
|
50
|
+
}, mode === "overlay" && /*#__PURE__*/_react["default"].createElement(BackOverlay, null), /*#__PURE__*/_react["default"].createElement(BackgroundSpinner, null, mode !== "small" && /*#__PURE__*/_react["default"].createElement(SVGBackground, {
|
|
54
51
|
viewBox: "0 0 140 140"
|
|
55
52
|
}, /*#__PURE__*/_react["default"].createElement(CircleBackground, {
|
|
56
53
|
cx: "70",
|
|
@@ -65,8 +62,7 @@ var DxcSpinner = function DxcSpinner(_ref) {
|
|
|
65
62
|
r: "6",
|
|
66
63
|
mode: mode
|
|
67
64
|
}))), value >= 0 && value <= 100 ? /*#__PURE__*/_react["default"].createElement(Spinner, {
|
|
68
|
-
role: "progressbar"
|
|
69
|
-
mode: mode
|
|
65
|
+
role: "progressbar"
|
|
70
66
|
}, mode !== "small" && /*#__PURE__*/_react["default"].createElement(SVGSpinner, {
|
|
71
67
|
viewBox: "0 0 140 140",
|
|
72
68
|
isDeterminated: true
|
|
@@ -90,8 +86,7 @@ var DxcSpinner = function DxcSpinner(_ref) {
|
|
|
90
86
|
isDeterminated: true,
|
|
91
87
|
value: value
|
|
92
88
|
}))) : /*#__PURE__*/_react["default"].createElement(Spinner, {
|
|
93
|
-
role: "progressbar"
|
|
94
|
-
mode: mode
|
|
89
|
+
role: "progressbar"
|
|
95
90
|
}, mode !== "small" && /*#__PURE__*/_react["default"].createElement(SVGSpinner, {
|
|
96
91
|
viewBox: "0 0 140 140",
|
|
97
92
|
isDeterminated: false
|
|
@@ -101,7 +96,8 @@ var DxcSpinner = function DxcSpinner(_ref) {
|
|
|
101
96
|
r: "65",
|
|
102
97
|
backgroundType: backgroundType,
|
|
103
98
|
mode: mode,
|
|
104
|
-
isDeterminated: false
|
|
99
|
+
isDeterminated: false,
|
|
100
|
+
value: value
|
|
105
101
|
})), mode === "small" && /*#__PURE__*/_react["default"].createElement(SVGSpinner, {
|
|
106
102
|
viewBox: "0 0 16 16",
|
|
107
103
|
isDeterminated: false
|
|
@@ -111,26 +107,24 @@ var DxcSpinner = function DxcSpinner(_ref) {
|
|
|
111
107
|
r: "6",
|
|
112
108
|
backgroundType: backgroundType,
|
|
113
109
|
mode: mode,
|
|
114
|
-
isDeterminated: false
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
value: value,
|
|
118
|
-
showValue: showValue
|
|
119
|
-
}, /*#__PURE__*/_react["default"].createElement(SpinnerLabel, {
|
|
110
|
+
isDeterminated: false,
|
|
111
|
+
value: value
|
|
112
|
+
}))), mode !== "small" && /*#__PURE__*/_react["default"].createElement(LabelsContainer, null, /*#__PURE__*/_react["default"].createElement(SpinnerLabel, {
|
|
120
113
|
backgroundType: backgroundType,
|
|
121
114
|
mode: mode
|
|
122
115
|
}, label), (value || value === 0) && showValue && /*#__PURE__*/_react["default"].createElement(SpinnerProgress, {
|
|
116
|
+
value: value,
|
|
123
117
|
backgroundType: backgroundType,
|
|
124
118
|
mode: mode,
|
|
125
119
|
showValue: showValue
|
|
126
120
|
}, value, "%")))));
|
|
127
121
|
};
|
|
128
122
|
|
|
129
|
-
var determinatedValue = function determinatedValue(
|
|
123
|
+
var determinatedValue = function determinatedValue(value, strokeDashArray) {
|
|
130
124
|
var val = 0;
|
|
131
125
|
|
|
132
|
-
if (
|
|
133
|
-
val = strokeDashArray * (1 -
|
|
126
|
+
if (value >= 0 && value <= 100) {
|
|
127
|
+
val = strokeDashArray * (1 - value / 100);
|
|
134
128
|
}
|
|
135
129
|
|
|
136
130
|
return val;
|
|
@@ -178,7 +172,7 @@ var BackOverlay = _styledComponents["default"].div(_templateObject3 || (_templat
|
|
|
178
172
|
return "".concat(props.theme.overlayOpacity);
|
|
179
173
|
});
|
|
180
174
|
|
|
181
|
-
var BackgroundSpinner = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n height: inherit;\n width: inherit;\n position: absolute;\n
|
|
175
|
+
var BackgroundSpinner = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n height: inherit;\n width: inherit;\n position: absolute;\n"])));
|
|
182
176
|
|
|
183
177
|
var SVGBackground = _styledComponents["default"].svg(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n height: inherit;\n width: inherit;\n"])));
|
|
184
178
|
|
|
@@ -190,7 +184,7 @@ var CircleBackground = _styledComponents["default"].circle(_templateObject6 || (
|
|
|
190
184
|
return props.mode !== "small" ? "8.5px" : "2px";
|
|
191
185
|
});
|
|
192
186
|
|
|
193
|
-
var Spinner = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n height: inherit;\n width: inherit;\n position: relative;\n
|
|
187
|
+
var Spinner = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n height: inherit;\n width: inherit;\n position: relative;\n"])));
|
|
194
188
|
|
|
195
189
|
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
190
|
return !props.isDeterminated ? "1.4s linear infinite both spinner-svg" : "";
|
|
@@ -207,7 +201,7 @@ var CircleSpinner = _styledComponents["default"].circle(_templateObject9 || (_te
|
|
|
207
201
|
}, function (props) {
|
|
208
202
|
return props.mode !== "small" ? "8.5px" : "2px";
|
|
209
203
|
}, function (props) {
|
|
210
|
-
return props.isDeterminated ? props.mode !== "small" ? determinatedValue(props, 409) : determinatedValue(props, 38) : "";
|
|
204
|
+
return props.isDeterminated ? props.mode !== "small" ? determinatedValue(props.value, 409) : determinatedValue(props.value, 38) : "";
|
|
211
205
|
});
|
|
212
206
|
|
|
213
207
|
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"])));
|
|
@@ -229,7 +223,7 @@ var SpinnerLabel = _styledComponents["default"].p(_templateObject11 || (_templat
|
|
|
229
223
|
});
|
|
230
224
|
|
|
231
225
|
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
|
-
return props.value
|
|
226
|
+
return props.value && props.showValue === true && "block" || "none";
|
|
233
227
|
}, function (props) {
|
|
234
228
|
return props.mode === "overlay" ? props.theme.overlayProgressValueFontFamily : props.theme.progressValueFontFamily;
|
|
235
229
|
}, function (props) {
|
|
@@ -2,67 +2,84 @@ 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>
|
|
14
25
|
<Title title="With label" theme="light" level={4} />
|
|
15
|
-
<DxcSpinner label="Label" value=
|
|
26
|
+
<DxcSpinner label="Label" value={50}></DxcSpinner>
|
|
16
27
|
<Title title="With value label" theme="light" level={4} />
|
|
17
|
-
<DxcSpinner value=
|
|
28
|
+
<DxcSpinner value={50} showValue></DxcSpinner>
|
|
18
29
|
<Title title="With label and value label" theme="light" level={4} />
|
|
19
|
-
<DxcSpinner label="Label" value=
|
|
30
|
+
<DxcSpinner label="Label" value={50} showValue></DxcSpinner>
|
|
20
31
|
<Title title="With 100%" theme="light" level={4} />
|
|
21
|
-
<DxcSpinner label="Label" value=
|
|
32
|
+
<DxcSpinner label="Label" value={100} showValue></DxcSpinner>
|
|
22
33
|
</ExampleContainer>
|
|
23
34
|
<Title title="Modes" theme="light" level={2} />
|
|
24
35
|
<ExampleContainer>
|
|
25
36
|
<Title title="Mode large" theme="light" level={4} />
|
|
26
|
-
<DxcSpinner mode="large" value=
|
|
37
|
+
<DxcSpinner mode="large" value={50}></DxcSpinner>
|
|
27
38
|
<Title title="Mode small" theme="light" level={4} />
|
|
28
|
-
<DxcSpinner mode="small" value=
|
|
39
|
+
<DxcSpinner mode="small" value={50}></DxcSpinner>
|
|
29
40
|
<Title title="Mode small with 100%" theme="light" level={4} />
|
|
30
|
-
<DxcSpinner mode="small" value=
|
|
41
|
+
<DxcSpinner mode="small" value={100} showValue></DxcSpinner>
|
|
31
42
|
</ExampleContainer>
|
|
32
43
|
<Title title="Margins with large mode" theme="light" level={2} />
|
|
33
44
|
<ExampleContainer>
|
|
34
45
|
<Title title="Xxsmall margin" theme="light" level={4} />
|
|
35
|
-
<DxcSpinner margin="xxsmall" value=
|
|
46
|
+
<DxcSpinner margin="xxsmall" value={75}></DxcSpinner>
|
|
36
47
|
<Title title="Xsmall margin" theme="light" level={4} />
|
|
37
|
-
<DxcSpinner margin="xsmall" value=
|
|
48
|
+
<DxcSpinner margin="xsmall" value={75}></DxcSpinner>
|
|
38
49
|
<Title title="Small margin" theme="light" level={4} />
|
|
39
|
-
<DxcSpinner margin="small" value=
|
|
50
|
+
<DxcSpinner margin="small" value={75}></DxcSpinner>
|
|
40
51
|
<Title title="Medium margin" theme="light" level={4} />
|
|
41
|
-
<DxcSpinner margin="medium" value=
|
|
52
|
+
<DxcSpinner margin="medium" value={75}></DxcSpinner>
|
|
42
53
|
<Title title="Large margin" theme="light" level={4} />
|
|
43
|
-
<DxcSpinner margin="large" value=
|
|
54
|
+
<DxcSpinner margin="large" value={75}></DxcSpinner>
|
|
44
55
|
<Title title="Xlarge margin" theme="light" level={4} />
|
|
45
|
-
<DxcSpinner margin="xlarge" value=
|
|
56
|
+
<DxcSpinner margin="xlarge" value={75}></DxcSpinner>
|
|
46
57
|
<Title title="Xxlarge margin" theme="light" level={4} />
|
|
47
|
-
<DxcSpinner margin="xxlarge" value=
|
|
58
|
+
<DxcSpinner margin="xxlarge" value={75}></DxcSpinner>
|
|
48
59
|
</ExampleContainer>
|
|
49
60
|
<Title title="Margins with small mode" theme="light" level={2} />
|
|
50
61
|
<ExampleContainer>
|
|
51
62
|
<Title title="Xxsmall margin" theme="light" level={4} />
|
|
52
|
-
<DxcSpinner margin="xxsmall" mode="small" value=
|
|
63
|
+
<DxcSpinner margin="xxsmall" mode="small" value={75}></DxcSpinner>
|
|
53
64
|
<Title title="Xsmall margin" theme="light" level={4} />
|
|
54
|
-
<DxcSpinner margin="xsmall" mode="small" value=
|
|
65
|
+
<DxcSpinner margin="xsmall" mode="small" value={75}></DxcSpinner>
|
|
55
66
|
<Title title="Small margin" theme="light" level={4} />
|
|
56
|
-
<DxcSpinner margin="small" mode="small" value=
|
|
67
|
+
<DxcSpinner margin="small" mode="small" value={75}></DxcSpinner>
|
|
57
68
|
<Title title="Medium margin" theme="light" level={4} />
|
|
58
|
-
<DxcSpinner margin="medium" mode="small" value=
|
|
69
|
+
<DxcSpinner margin="medium" mode="small" value={75}></DxcSpinner>
|
|
59
70
|
<Title title="Large margin" theme="light" level={4} />
|
|
60
|
-
<DxcSpinner margin="large" mode="small" value=
|
|
71
|
+
<DxcSpinner margin="large" mode="small" value={75}></DxcSpinner>
|
|
61
72
|
<Title title="Xlarge margin" theme="light" level={4} />
|
|
62
|
-
<DxcSpinner margin="xlarge" mode="small" value=
|
|
73
|
+
<DxcSpinner margin="xlarge" mode="small" value={75}></DxcSpinner>
|
|
63
74
|
<Title title="Xxlarge margin" theme="light" level={4} />
|
|
64
|
-
<DxcSpinner margin="xxlarge" mode="small" value=
|
|
65
|
-
|
|
75
|
+
<DxcSpinner margin="xxlarge" mode="small" value={75}></DxcSpinner>
|
|
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
|
);
|
|
@@ -70,34 +87,43 @@ export const Chromatic = () => (
|
|
|
70
87
|
export const SpinnerOverlay = () => (
|
|
71
88
|
<ExampleContainer>
|
|
72
89
|
<Title title="Mode overlay" theme="light" level={4} />
|
|
73
|
-
<DxcSpinner mode="overlay" value=
|
|
90
|
+
<DxcSpinner mode="overlay" value={25}></DxcSpinner>
|
|
74
91
|
</ExampleContainer>
|
|
75
92
|
);
|
|
76
93
|
|
|
77
94
|
export const SpinnerOverlayWith100 = () => (
|
|
78
95
|
<ExampleContainer>
|
|
79
96
|
<Title title="Mode overlay" theme="light" level={4} />
|
|
80
|
-
<DxcSpinner mode="overlay" value=
|
|
97
|
+
<DxcSpinner mode="overlay" value={100}></DxcSpinner>
|
|
81
98
|
</ExampleContainer>
|
|
82
99
|
);
|
|
83
100
|
|
|
84
101
|
export const SpinnerOverlayWithLabel = () => (
|
|
85
102
|
<ExampleContainer>
|
|
86
103
|
<Title title="Mode overlay" theme="light" level={4} />
|
|
87
|
-
<DxcSpinner mode="overlay" value=
|
|
104
|
+
<DxcSpinner mode="overlay" value={50} label="Label"></DxcSpinner>
|
|
88
105
|
</ExampleContainer>
|
|
89
106
|
);
|
|
90
107
|
|
|
91
108
|
export const SpinnerOverlayWithValue = () => (
|
|
92
109
|
<ExampleContainer>
|
|
93
110
|
<Title title="Mode overlay" theme="light" level={4} />
|
|
94
|
-
<DxcSpinner mode="overlay" value=
|
|
111
|
+
<DxcSpinner mode="overlay" value={50} showValue></DxcSpinner>
|
|
95
112
|
</ExampleContainer>
|
|
96
113
|
);
|
|
97
114
|
|
|
98
115
|
export const SpinnerOverlayWithValueAndLabel = () => (
|
|
99
116
|
<ExampleContainer>
|
|
100
117
|
<Title title="Mode overlay" theme="light" level={4} />
|
|
101
|
-
<DxcSpinner mode="overlay" label="Label" value=
|
|
118
|
+
<DxcSpinner mode="overlay" label="Label" value={50} showValue></DxcSpinner>
|
|
119
|
+
</ExampleContainer>
|
|
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>
|
|
102
128
|
</ExampleContainer>
|
|
103
129
|
);
|
package/spinner/Spinner.test.js
CHANGED
|
@@ -6,7 +6,7 @@ var _react = _interopRequireDefault(require("react"));
|
|
|
6
6
|
|
|
7
7
|
var _react2 = require("@testing-library/react");
|
|
8
8
|
|
|
9
|
-
var _Spinner = _interopRequireDefault(require("./Spinner"));
|
|
9
|
+
var _Spinner = _interopRequireDefault(require("./Spinner.tsx"));
|
|
10
10
|
|
|
11
11
|
describe("Spinner component tests", function () {
|
|
12
12
|
test("Spinner renders with correct label", function () {
|
package/switch/Switch.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
import
|
|
3
|
-
declare const DxcSwitch:
|
|
1
|
+
import React from "react";
|
|
2
|
+
import SwitchPropsType from "./types";
|
|
3
|
+
declare const DxcSwitch: React.ForwardRefExoticComponent<SwitchPropsType & React.RefAttributes<HTMLDivElement>>;
|
|
4
4
|
export default DxcSwitch;
|