@dxc-technology/halstack-react 0.0.0-c25d3b6 → 0.0.0-c2834c3
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/HalstackContext.d.ts +12 -0
- package/HalstackContext.js +298 -0
- package/accordion/Accordion.d.ts +1 -1
- package/accordion/Accordion.js +7 -28
- package/accordion/Accordion.stories.tsx +11 -11
- package/accordion/Accordion.test.js +19 -4
- package/accordion/types.d.ts +4 -0
- package/accordion-group/AccordionGroup.d.ts +1 -1
- package/accordion-group/AccordionGroup.js +13 -15
- package/accordion-group/AccordionGroup.stories.tsx +1 -1
- package/accordion-group/AccordionGroup.test.js +24 -6
- package/accordion-group/types.d.ts +4 -0
- package/alert/Alert.js +4 -1
- package/button/Button.js +14 -11
- package/card/Card.js +27 -28
- package/checkbox/Checkbox.d.ts +1 -1
- package/checkbox/Checkbox.js +43 -39
- package/checkbox/Checkbox.stories.tsx +124 -128
- package/checkbox/Checkbox.test.js +13 -0
- package/checkbox/types.d.ts +7 -3
- package/common/variables.js +181 -70
- package/date-input/DateInput.js +38 -20
- package/date-input/DateInput.test.js +9 -22
- package/date-input/types.d.ts +12 -9
- package/dialog/Dialog.js +4 -32
- package/dropdown/Dropdown.js +13 -17
- package/file-input/FileInput.js +9 -6
- package/file-input/FileItem.js +7 -5
- package/footer/Footer.js +15 -88
- package/header/Header.js +27 -48
- package/header/Header.stories.tsx +46 -36
- package/header/Header.test.js +18 -2
- package/inset/types.d.ts +24 -0
- package/layout/ApplicationLayout.js +5 -18
- package/link/Link.d.ts +3 -2
- package/link/Link.js +65 -56
- package/link/Link.stories.tsx +87 -52
- package/link/Link.test.js +7 -15
- package/link/types.d.ts +8 -23
- package/main.d.ts +3 -2
- package/main.js +19 -5
- package/number-input/NumberInput.test.js +2 -4
- package/number-input/types.d.ts +13 -10
- package/package.json +6 -5
- package/paginator/Paginator.js +17 -38
- package/password-input/PasswordInput.js +7 -4
- package/password-input/PasswordInput.test.js +3 -6
- package/password-input/types.d.ts +14 -11
- package/quick-nav/QuickNav.d.ts +4 -0
- package/quick-nav/QuickNav.js +116 -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/Radio.js +10 -11
- package/radio-group/Radio.js +1 -1
- package/radio-group/RadioGroup.js +8 -6
- package/row/types.d.ts +18 -0
- package/select/Listbox.d.ts +4 -0
- package/select/Listbox.js +152 -0
- package/select/Option.js +1 -1
- package/select/Select.js +53 -139
- package/select/Select.stories.tsx +14 -2
- package/select/Select.test.js +83 -42
- package/select/types.d.ts +33 -11
- package/slider/Slider.d.ts +1 -1
- package/slider/Slider.js +2 -1
- package/slider/Slider.stories.tsx +8 -8
- package/slider/Slider.test.js +31 -10
- package/slider/types.d.ts +4 -0
- package/spinner/Spinner.js +1 -1
- package/switch/Switch.d.ts +1 -1
- package/switch/Switch.js +35 -19
- package/switch/Switch.stories.tsx +14 -14
- package/switch/Switch.test.js +25 -0
- package/switch/types.d.ts +6 -2
- package/tabs/Tabs.d.ts +1 -1
- package/tabs/Tabs.js +9 -11
- package/tabs/Tabs.stories.tsx +0 -8
- package/tabs/Tabs.test.js +26 -9
- package/tabs/types.d.ts +4 -0
- package/tag/Tag.js +5 -8
- package/text-input/Suggestion.d.ts +4 -0
- package/text-input/Suggestion.js +55 -0
- package/text-input/TextInput.js +48 -76
- package/text-input/TextInput.test.js +22 -35
- package/text-input/types.d.ts +27 -12
- package/textarea/Textarea.js +12 -23
- package/textarea/Textarea.test.js +10 -20
- package/textarea/types.d.ts +14 -11
- package/toggle-group/ToggleGroup.d.ts +1 -1
- package/toggle-group/ToggleGroup.js +5 -4
- package/toggle-group/ToggleGroup.stories.tsx +4 -4
- package/toggle-group/ToggleGroup.test.js +35 -4
- package/toggle-group/types.d.ts +8 -0
- package/useTheme.js +2 -2
- package/useTranslatedLabels.d.ts +2 -0
- package/useTranslatedLabels.js +20 -0
- package/wizard/Wizard.d.ts +1 -1
- package/wizard/Wizard.js +55 -44
- package/wizard/Wizard.stories.tsx +13 -23
- package/wizard/Wizard.test.js +36 -23
- package/wizard/types.d.ts +6 -2
- package/ThemeContext.d.ts +0 -10
- package/ThemeContext.js +0 -243
package/textarea/Textarea.js
CHANGED
|
@@ -23,6 +23,8 @@ var _utils = require("../common/utils.js");
|
|
|
23
23
|
|
|
24
24
|
var _useTheme = _interopRequireDefault(require("../useTheme"));
|
|
25
25
|
|
|
26
|
+
var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
|
|
27
|
+
|
|
26
28
|
var _variables = require("../common/variables.js");
|
|
27
29
|
|
|
28
30
|
var _uuid = require("uuid");
|
|
@@ -35,14 +37,6 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
|
|
|
35
37
|
|
|
36
38
|
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; }
|
|
37
39
|
|
|
38
|
-
var getNotOptionalErrorMessage = function getNotOptionalErrorMessage() {
|
|
39
|
-
return "This field is required. Please, enter a value.";
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
var getPatternErrorMessage = function getPatternErrorMessage() {
|
|
43
|
-
return "Please match the format requested.";
|
|
44
|
-
};
|
|
45
|
-
|
|
46
40
|
var patternMatch = function patternMatch(pattern, value) {
|
|
47
41
|
return new RegExp(pattern).test(value);
|
|
48
42
|
};
|
|
@@ -90,13 +84,10 @@ var DxcTextarea = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref)
|
|
|
90
84
|
|
|
91
85
|
var colorsTheme = (0, _useTheme["default"])();
|
|
92
86
|
var backgroundType = (0, _react.useContext)(_BackgroundColorContext["default"]);
|
|
87
|
+
var translatedLabels = (0, _useTranslatedLabels["default"])();
|
|
93
88
|
var textareaRef = (0, _react.useRef)(null);
|
|
94
89
|
var errorId = "error-".concat(textareaId);
|
|
95
90
|
|
|
96
|
-
var getLengthErrorMessage = function getLengthErrorMessage() {
|
|
97
|
-
return "Min length ".concat(minLength, ", max length ").concat(maxLength, ".");
|
|
98
|
-
};
|
|
99
|
-
|
|
100
91
|
var isNotOptional = function isNotOptional(value) {
|
|
101
92
|
return value === "" && !optional;
|
|
102
93
|
};
|
|
@@ -109,32 +100,30 @@ var DxcTextarea = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref)
|
|
|
109
100
|
value !== null && value !== void 0 ? value : setInnerValue(newValue);
|
|
110
101
|
if (isNotOptional(newValue)) onChange === null || onChange === void 0 ? void 0 : onChange({
|
|
111
102
|
value: newValue,
|
|
112
|
-
error:
|
|
103
|
+
error: translatedLabels.formFields.requiredValueErrorMessage
|
|
113
104
|
});else if (isLengthIncorrect(newValue)) onChange === null || onChange === void 0 ? void 0 : onChange({
|
|
114
105
|
value: newValue,
|
|
115
|
-
error:
|
|
106
|
+
error: translatedLabels.formFields.lengthErrorMessage(minLength, maxLength)
|
|
116
107
|
});else if (newValue && pattern && !patternMatch(pattern, newValue)) onChange === null || onChange === void 0 ? void 0 : onChange({
|
|
117
108
|
value: newValue,
|
|
118
|
-
error:
|
|
109
|
+
error: translatedLabels.formFields.formatRequestedErrorMessage
|
|
119
110
|
});else onChange === null || onChange === void 0 ? void 0 : onChange({
|
|
120
|
-
value: newValue
|
|
121
|
-
error: null
|
|
111
|
+
value: newValue
|
|
122
112
|
});
|
|
123
113
|
};
|
|
124
114
|
|
|
125
115
|
var handleTOnBlur = function handleTOnBlur(event) {
|
|
126
116
|
if (isNotOptional(event.target.value)) onBlur === null || onBlur === void 0 ? void 0 : onBlur({
|
|
127
117
|
value: event.target.value,
|
|
128
|
-
error:
|
|
118
|
+
error: translatedLabels.formFields.requiredValueErrorMessage
|
|
129
119
|
});else if (isLengthIncorrect(event.target.value)) onBlur === null || onBlur === void 0 ? void 0 : onBlur({
|
|
130
120
|
value: event.target.value,
|
|
131
|
-
error:
|
|
121
|
+
error: translatedLabels.formFields.lengthErrorMessage(minLength, maxLength)
|
|
132
122
|
});else if (event.target.value && pattern && !patternMatch(pattern, event.target.value)) onBlur === null || onBlur === void 0 ? void 0 : onBlur({
|
|
133
123
|
value: event.target.value,
|
|
134
|
-
error:
|
|
124
|
+
error: translatedLabels.formFields.formatRequestedErrorMessage
|
|
135
125
|
});else onBlur === null || onBlur === void 0 ? void 0 : onBlur({
|
|
136
|
-
value: event.target.value
|
|
137
|
-
error: null
|
|
126
|
+
value: event.target.value
|
|
138
127
|
});
|
|
139
128
|
};
|
|
140
129
|
|
|
@@ -162,7 +151,7 @@ var DxcTextarea = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref)
|
|
|
162
151
|
disabled: disabled,
|
|
163
152
|
backgroundType: backgroundType,
|
|
164
153
|
helperText: helperText
|
|
165
|
-
}, label, " ", optional && /*#__PURE__*/_react["default"].createElement(OptionalLabel, null,
|
|
154
|
+
}, label, " ", optional && /*#__PURE__*/_react["default"].createElement(OptionalLabel, null, translatedLabels.formFields.optionalLabel)), helperText && /*#__PURE__*/_react["default"].createElement(HelperText, {
|
|
166
155
|
disabled: disabled,
|
|
167
156
|
backgroundType: backgroundType
|
|
168
157
|
}, helperText), /*#__PURE__*/_react["default"].createElement(Textarea, {
|
|
@@ -152,8 +152,7 @@ describe("Textarea component tests", function () {
|
|
|
152
152
|
|
|
153
153
|
expect(onBlur).toHaveBeenCalled();
|
|
154
154
|
expect(onBlur).toHaveBeenCalledWith({
|
|
155
|
-
value: "Test"
|
|
156
|
-
error: null
|
|
155
|
+
value: "Test"
|
|
157
156
|
});
|
|
158
157
|
});
|
|
159
158
|
test("Not optional constraint (onChange)", function () {
|
|
@@ -178,8 +177,7 @@ describe("Textarea component tests", function () {
|
|
|
178
177
|
|
|
179
178
|
expect(onChange).toHaveBeenCalled();
|
|
180
179
|
expect(onChange).toHaveBeenCalledWith({
|
|
181
|
-
value: "Test"
|
|
182
|
-
error: null
|
|
180
|
+
value: "Test"
|
|
183
181
|
});
|
|
184
182
|
|
|
185
183
|
_userEvent["default"].clear(textarea);
|
|
@@ -239,16 +237,14 @@ describe("Textarea component tests", function () {
|
|
|
239
237
|
|
|
240
238
|
expect(onChange).toHaveBeenCalled();
|
|
241
239
|
expect(onChange).toHaveBeenCalledWith({
|
|
242
|
-
value: "pattern4&"
|
|
243
|
-
error: null
|
|
240
|
+
value: "pattern4&"
|
|
244
241
|
});
|
|
245
242
|
|
|
246
243
|
_react2.fireEvent.blur(textarea);
|
|
247
244
|
|
|
248
245
|
expect(onBlur).toHaveBeenCalled();
|
|
249
246
|
expect(onBlur).toHaveBeenCalledWith({
|
|
250
|
-
value: "pattern4&"
|
|
251
|
-
error: null
|
|
247
|
+
value: "pattern4&"
|
|
252
248
|
});
|
|
253
249
|
});
|
|
254
250
|
test("Length constraint", function () {
|
|
@@ -301,16 +297,14 @@ describe("Textarea component tests", function () {
|
|
|
301
297
|
|
|
302
298
|
expect(onChange).toHaveBeenCalled();
|
|
303
299
|
expect(onChange).toHaveBeenCalledWith({
|
|
304
|
-
value: "length"
|
|
305
|
-
error: null
|
|
300
|
+
value: "length"
|
|
306
301
|
});
|
|
307
302
|
|
|
308
303
|
_react2.fireEvent.blur(textarea);
|
|
309
304
|
|
|
310
305
|
expect(onBlur).toHaveBeenCalled();
|
|
311
306
|
expect(onBlur).toHaveBeenCalledWith({
|
|
312
|
-
value: "length"
|
|
313
|
-
error: null
|
|
307
|
+
value: "length"
|
|
314
308
|
});
|
|
315
309
|
});
|
|
316
310
|
test("Pattern and length constraints", function () {
|
|
@@ -382,16 +376,14 @@ describe("Textarea component tests", function () {
|
|
|
382
376
|
|
|
383
377
|
expect(onChange).toHaveBeenCalled();
|
|
384
378
|
expect(onChange).toHaveBeenCalledWith({
|
|
385
|
-
value: "tests4&"
|
|
386
|
-
error: null
|
|
379
|
+
value: "tests4&"
|
|
387
380
|
});
|
|
388
381
|
|
|
389
382
|
_react2.fireEvent.blur(textarea);
|
|
390
383
|
|
|
391
384
|
expect(onBlur).toHaveBeenCalled();
|
|
392
385
|
expect(onBlur).toHaveBeenCalledWith({
|
|
393
|
-
value: "tests4&"
|
|
394
|
-
error: null
|
|
386
|
+
value: "tests4&"
|
|
395
387
|
});
|
|
396
388
|
});
|
|
397
389
|
test("onBlur function is called correctly", function () {
|
|
@@ -415,8 +407,7 @@ describe("Textarea component tests", function () {
|
|
|
415
407
|
|
|
416
408
|
expect(onBlur).toHaveBeenCalled();
|
|
417
409
|
expect(onBlur).toHaveBeenCalledWith({
|
|
418
|
-
value: "Blur test"
|
|
419
|
-
error: null
|
|
410
|
+
value: "Blur test"
|
|
420
411
|
});
|
|
421
412
|
});
|
|
422
413
|
test("onChange function is called correctly", function () {
|
|
@@ -439,8 +430,7 @@ describe("Textarea component tests", function () {
|
|
|
439
430
|
|
|
440
431
|
expect(onChange).toHaveBeenCalled();
|
|
441
432
|
expect(onChange).toHaveBeenCalledWith({
|
|
442
|
-
value: "Controlled test"
|
|
443
|
-
error: null
|
|
433
|
+
value: "Controlled test"
|
|
444
434
|
});
|
|
445
435
|
expect(textarea.value).toBe("Test value");
|
|
446
436
|
});
|
package/textarea/types.d.ts
CHANGED
|
@@ -56,26 +56,29 @@ declare type Props = {
|
|
|
56
56
|
* This function will be called when the user types within the textarea.
|
|
57
57
|
* An object including the current value and the error (if the value
|
|
58
58
|
* entered is not valid) will be passed to this function.
|
|
59
|
-
* If there is no error, error will be
|
|
59
|
+
* If there is no error, error will not be defined.
|
|
60
60
|
*/
|
|
61
61
|
onChange?: (val: {
|
|
62
62
|
value: string;
|
|
63
|
-
error
|
|
63
|
+
error?: string;
|
|
64
64
|
}) => void;
|
|
65
65
|
/**
|
|
66
66
|
* This function will be called when the textarea loses the focus. An
|
|
67
67
|
* object including the textarea value and the error (if the value entered
|
|
68
68
|
* is not valid) will be passed to this function. If there is no error,
|
|
69
|
-
* error will be
|
|
69
|
+
* error will not be defined.
|
|
70
70
|
*/
|
|
71
71
|
onBlur?: (val: {
|
|
72
72
|
value: string;
|
|
73
|
-
error
|
|
73
|
+
error?: string;
|
|
74
74
|
}) => void;
|
|
75
75
|
/**
|
|
76
|
-
* If it is defined
|
|
77
|
-
* the error below the textarea. If
|
|
78
|
-
*
|
|
76
|
+
* If it is a defined value and also a truthy string, the component will
|
|
77
|
+
* change its appearance, showing the error below the textarea. If the
|
|
78
|
+
* defined value is an empty string, it will reserve a space below the
|
|
79
|
+
* component for a future error, but it would not change its look. In
|
|
80
|
+
* case of being undefined or null, both the appearance and the space for
|
|
81
|
+
* the error message would not be modified.
|
|
79
82
|
*/
|
|
80
83
|
error?: string;
|
|
81
84
|
/**
|
|
@@ -85,7 +88,7 @@ declare type Props = {
|
|
|
85
88
|
* pattern, the onBlur and onChange functions will be called with the
|
|
86
89
|
* current value and an internal error informing that this value does not
|
|
87
90
|
* match the pattern. If the pattern is met, the error parameter of both
|
|
88
|
-
* events will be
|
|
91
|
+
* events will not be defined.
|
|
89
92
|
*/
|
|
90
93
|
pattern?: string;
|
|
91
94
|
/**
|
|
@@ -95,7 +98,7 @@ declare type Props = {
|
|
|
95
98
|
* comply the minimum length, the onBlur and onChange functions will be called
|
|
96
99
|
* with the current value and an internal error informing that the value
|
|
97
100
|
* length does not comply the specified range. If a valid length is
|
|
98
|
-
* reached, the error parameter of both events will be
|
|
101
|
+
* reached, the error parameter of both events will not be defined.
|
|
99
102
|
*/
|
|
100
103
|
minLength?: number;
|
|
101
104
|
/**
|
|
@@ -105,7 +108,7 @@ declare type Props = {
|
|
|
105
108
|
* comply the maximum length, the onBlur and onChange functions will be called
|
|
106
109
|
* with the current value and an internal error informing that the value
|
|
107
110
|
* length does not comply the specified range. If a valid length is
|
|
108
|
-
* reached, the error parameter of both events will be
|
|
111
|
+
* reached, the error parameter of both events will not be defined.
|
|
109
112
|
*/
|
|
110
113
|
maxLength?: number;
|
|
111
114
|
/**
|
|
@@ -119,7 +122,7 @@ declare type Props = {
|
|
|
119
122
|
*/
|
|
120
123
|
margin?: Space | Margin;
|
|
121
124
|
/**
|
|
122
|
-
* Size of the component
|
|
125
|
+
* Size of the component.
|
|
123
126
|
*/
|
|
124
127
|
size?: "small" | "medium" | "large" | "fillParent";
|
|
125
128
|
/**
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import ToogleGroupPropsType from "./types";
|
|
3
|
-
declare const DxcToggleGroup: ({ label, helperText, value, onChange, disabled, options, margin, multiple, tabIndex, }: ToogleGroupPropsType) => JSX.Element;
|
|
3
|
+
declare const DxcToggleGroup: ({ label, helperText, defaultValue, value, onChange, disabled, options, margin, multiple, tabIndex, }: ToogleGroupPropsType) => JSX.Element;
|
|
4
4
|
export default DxcToggleGroup;
|
|
@@ -34,6 +34,7 @@ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj &&
|
|
|
34
34
|
var DxcToggleGroup = function DxcToggleGroup(_ref) {
|
|
35
35
|
var label = _ref.label,
|
|
36
36
|
helperText = _ref.helperText,
|
|
37
|
+
defaultValue = _ref.defaultValue,
|
|
37
38
|
value = _ref.value,
|
|
38
39
|
onChange = _ref.onChange,
|
|
39
40
|
_ref$disabled = _ref.disabled,
|
|
@@ -46,7 +47,7 @@ var DxcToggleGroup = function DxcToggleGroup(_ref) {
|
|
|
46
47
|
tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
|
|
47
48
|
var colorsTheme = (0, _useTheme["default"])();
|
|
48
49
|
|
|
49
|
-
var _useState = (0, _react.useState)(multiple ? [] : -1),
|
|
50
|
+
var _useState = (0, _react.useState)(defaultValue !== null && defaultValue !== void 0 ? defaultValue : multiple ? [] : -1),
|
|
50
51
|
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
51
52
|
selectedValue = _useState2[0],
|
|
52
53
|
setSelectedValue = _useState2[1];
|
|
@@ -108,9 +109,9 @@ var DxcToggleGroup = function DxcToggleGroup(_ref) {
|
|
|
108
109
|
role: multiple ? "group" : "radiogroup"
|
|
109
110
|
}, options.map(function (option, i) {
|
|
110
111
|
return /*#__PURE__*/_react["default"].createElement(ToggleContainer, {
|
|
111
|
-
selected: multiple
|
|
112
|
+
selected: multiple ? value ? Array.isArray(value) && value.includes(option.value) : Array.isArray(selectedValue) && selectedValue.includes(option.value) : value ? option.value === value : option.value === selectedValue,
|
|
112
113
|
role: multiple ? "switch" : "radio",
|
|
113
|
-
"aria-checked": multiple
|
|
114
|
+
"aria-checked": multiple ? value ? Array.isArray(value) && value.includes(option.value) : Array.isArray(selectedValue) && selectedValue.includes(option.value) : value ? option.value === value : option.value === selectedValue,
|
|
114
115
|
tabIndex: !disabled ? tabIndex : -1,
|
|
115
116
|
onClick: function onClick() {
|
|
116
117
|
return !disabled && handleToggleChange(option.value);
|
|
@@ -172,7 +173,7 @@ var ToggleGroup = _styledComponents["default"].div(_templateObject3 || (_templat
|
|
|
172
173
|
return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
|
|
173
174
|
});
|
|
174
175
|
|
|
175
|
-
var OptionsContainer = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: row;\n opacity: 1;\n height: calc(48px - 4px - 4px);\n border-width: ", ";\n border-style: ", ";\n border-radius: ", ";\n border-color: ", ";\n background-color: ", ";\n padding: 4px;\n margin-top: ", ";\n"])), function (props) {
|
|
176
|
+
var OptionsContainer = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: row;\n width: max-content;\n opacity: 1;\n height: calc(48px - 4px - 4px);\n border-width: ", ";\n border-style: ", ";\n border-radius: ", ";\n border-color: ", ";\n background-color: ", ";\n padding: 4px;\n margin-top: ", ";\n"])), function (props) {
|
|
176
177
|
return props.theme.containerBorderThickness;
|
|
177
178
|
}, function (props) {
|
|
178
179
|
return props.theme.containerBorderStyle;
|
|
@@ -97,7 +97,7 @@ export const Chromatic = () => (
|
|
|
97
97
|
</ExampleContainer>
|
|
98
98
|
<ExampleContainer>
|
|
99
99
|
<Title title="Selected" theme="light" level={4} />
|
|
100
|
-
<DxcToggleGroup label="Selected" helperText="HelperText"
|
|
100
|
+
<DxcToggleGroup label="Selected" helperText="HelperText" defaultValue={2} options={options} />
|
|
101
101
|
</ExampleContainer>
|
|
102
102
|
<ExampleContainer>
|
|
103
103
|
<Title title="Icons toggle group" theme="light" level={4} />
|
|
@@ -109,11 +109,11 @@ export const Chromatic = () => (
|
|
|
109
109
|
</ExampleContainer>
|
|
110
110
|
<ExampleContainer>
|
|
111
111
|
<Title title="Disabled" theme="light" level={4} />
|
|
112
|
-
<DxcToggleGroup label="Disabled"
|
|
112
|
+
<DxcToggleGroup label="Disabled" defaultValue={2} options={options} disabled />
|
|
113
113
|
</ExampleContainer>
|
|
114
114
|
<ExampleContainer pseudoState="pseudo-hover">
|
|
115
115
|
<Title title="Hovered" theme="light" level={4} />
|
|
116
|
-
<DxcToggleGroup label="Hovered" options={twoOptions}
|
|
116
|
+
<DxcToggleGroup label="Hovered" options={twoOptions} defaultValue={2} />
|
|
117
117
|
</ExampleContainer>
|
|
118
118
|
<ExampleContainer>
|
|
119
119
|
<Title title="Multiple toggleGroup" theme="light" level={4} />
|
|
@@ -121,7 +121,7 @@ export const Chromatic = () => (
|
|
|
121
121
|
label="Toggle group"
|
|
122
122
|
helperText="Please select one or more"
|
|
123
123
|
options={options}
|
|
124
|
-
|
|
124
|
+
defaultValue={[1, 3]}
|
|
125
125
|
multiple
|
|
126
126
|
></DxcToggleGroup>
|
|
127
127
|
</ExampleContainer>
|
|
@@ -92,13 +92,22 @@ describe("Toggle group component tests", function () {
|
|
|
92
92
|
onChange: onChange,
|
|
93
93
|
multiple: true
|
|
94
94
|
})),
|
|
95
|
-
|
|
95
|
+
getAllByRole = _render5.getAllByRole;
|
|
96
96
|
|
|
97
|
-
var
|
|
97
|
+
var toggleOptions = getAllByRole("switch");
|
|
98
98
|
|
|
99
|
-
_react2.fireEvent.click(
|
|
99
|
+
_react2.fireEvent.click(toggleOptions[0]);
|
|
100
|
+
|
|
101
|
+
expect(onChange).toHaveBeenCalledWith([1]);
|
|
102
|
+
|
|
103
|
+
_react2.fireEvent.click(toggleOptions[1]);
|
|
100
104
|
|
|
101
|
-
|
|
105
|
+
_react2.fireEvent.click(toggleOptions[3]);
|
|
106
|
+
|
|
107
|
+
expect(onChange).toHaveBeenCalledWith([1, 2, 4]);
|
|
108
|
+
expect(toggleOptions[0].getAttribute("aria-checked")).toBe("true");
|
|
109
|
+
expect(toggleOptions[1].getAttribute("aria-checked")).toBe("true");
|
|
110
|
+
expect(toggleOptions[3].getAttribute("aria-checked")).toBe("true");
|
|
102
111
|
});
|
|
103
112
|
test("Controlled multiple toggle returns always same values", function () {
|
|
104
113
|
var onChange = jest.fn();
|
|
@@ -122,4 +131,26 @@ describe("Toggle group component tests", function () {
|
|
|
122
131
|
|
|
123
132
|
expect(onChange).toHaveBeenNthCalledWith(2, [1, 4]);
|
|
124
133
|
});
|
|
134
|
+
test("Single selection: Renders with correct default value", function () {
|
|
135
|
+
var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ToggleGroup["default"], {
|
|
136
|
+
options: options,
|
|
137
|
+
defaultValue: 2
|
|
138
|
+
})),
|
|
139
|
+
getAllByRole = _render7.getAllByRole;
|
|
140
|
+
|
|
141
|
+
var toggleOptions = getAllByRole("radio");
|
|
142
|
+
expect(toggleOptions[1].getAttribute("aria-checked")).toBe("true");
|
|
143
|
+
});
|
|
144
|
+
test("Multiple selection: Renders with correct default value", function () {
|
|
145
|
+
var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ToggleGroup["default"], {
|
|
146
|
+
options: options,
|
|
147
|
+
defaultValue: [2, 4],
|
|
148
|
+
multiple: true
|
|
149
|
+
})),
|
|
150
|
+
getAllByRole = _render8.getAllByRole;
|
|
151
|
+
|
|
152
|
+
var toggleOptions = getAllByRole("switch");
|
|
153
|
+
expect(toggleOptions[1].getAttribute("aria-checked")).toBe("true");
|
|
154
|
+
expect(toggleOptions[3].getAttribute("aria-checked")).toBe("true");
|
|
155
|
+
});
|
|
125
156
|
});
|
package/toggle-group/types.d.ts
CHANGED
|
@@ -66,6 +66,10 @@ declare type SingleSelectionToggle = CommonProps & {
|
|
|
66
66
|
* If true, the toggle group will support multiple selection. In that case, value must be an array of numbers with the keys of the selected values.
|
|
67
67
|
*/
|
|
68
68
|
multiple?: false;
|
|
69
|
+
/**
|
|
70
|
+
* The key of the initially selected value.
|
|
71
|
+
*/
|
|
72
|
+
defaultValue?: number;
|
|
69
73
|
/**
|
|
70
74
|
* The key of the selected value. If the component allows multiple selection, value must be an array.
|
|
71
75
|
* If undefined, the component will be uncontrolled and the value will be managed internally by the component.
|
|
@@ -82,6 +86,10 @@ declare type MultipleSelectionToggle = CommonProps & {
|
|
|
82
86
|
* If true, the toggle group will support multiple selection. In that case, value must be an array of numbers with the keys of the selected values.
|
|
83
87
|
*/
|
|
84
88
|
multiple: true;
|
|
89
|
+
/**
|
|
90
|
+
* The array of keys with the initially selected values.
|
|
91
|
+
*/
|
|
92
|
+
defaultValue?: number[];
|
|
85
93
|
/**
|
|
86
94
|
* An array with the keys of the selected values.
|
|
87
95
|
* If undefined, the component will be uncontrolled and the value will be managed internally by the component.
|
package/useTheme.js
CHANGED
|
@@ -11,10 +11,10 @@ var _react = require("react");
|
|
|
11
11
|
|
|
12
12
|
var _variables = require("./common/variables.js");
|
|
13
13
|
|
|
14
|
-
var
|
|
14
|
+
var _HalstackContext = _interopRequireDefault(require("./HalstackContext"));
|
|
15
15
|
|
|
16
16
|
var useTheme = function useTheme() {
|
|
17
|
-
var colorsTheme = (0, _react.useContext)(
|
|
17
|
+
var colorsTheme = (0, _react.useContext)(_HalstackContext["default"]);
|
|
18
18
|
return colorsTheme || _variables.componentTokens;
|
|
19
19
|
};
|
|
20
20
|
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports["default"] = void 0;
|
|
7
|
+
|
|
8
|
+
var _react = require("react");
|
|
9
|
+
|
|
10
|
+
var _variables = require("./common/variables");
|
|
11
|
+
|
|
12
|
+
var _HalstackContext = require("./HalstackContext");
|
|
13
|
+
|
|
14
|
+
var useTranslatedLabels = function useTranslatedLabels() {
|
|
15
|
+
var labels = (0, _react.useContext)(_HalstackContext.HalstackLanguageContext);
|
|
16
|
+
return labels || _variables.defaultTranslatedComponentLabels;
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
var _default = useTranslatedLabels;
|
|
20
|
+
exports["default"] = _default;
|
package/wizard/Wizard.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import WizardPropsType from "./types";
|
|
3
|
-
declare const DxcWizard: ({ mode, currentStep, onStepClick, steps, margin, tabIndex, }: WizardPropsType) => JSX.Element;
|
|
3
|
+
declare const DxcWizard: ({ mode, defaultCurrentStep, currentStep, onStepClick, steps, margin, tabIndex, }: WizardPropsType) => JSX.Element;
|
|
4
4
|
export default DxcWizard;
|