@dxc-technology/halstack-react 0.0.0-fdc49d2 → 0.0.0-ff5083e

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (145) hide show
  1. package/HalstackContext.d.ts +12 -0
  2. package/HalstackContext.js +295 -0
  3. package/accordion/Accordion.js +5 -27
  4. package/accordion/Accordion.stories.tsx +3 -3
  5. package/accordion-group/AccordionGroup.d.ts +1 -1
  6. package/accordion-group/AccordionGroup.js +13 -15
  7. package/accordion-group/AccordionGroup.stories.tsx +1 -1
  8. package/accordion-group/AccordionGroup.test.js +24 -6
  9. package/accordion-group/types.d.ts +4 -0
  10. package/alert/Alert.js +4 -1
  11. package/badge/Badge.d.ts +1 -1
  12. package/badge/Badge.js +5 -3
  13. package/badge/types.d.ts +1 -0
  14. package/bleed/Bleed.js +1 -34
  15. package/bleed/Bleed.stories.tsx +31 -32
  16. package/bleed/types.d.ts +1 -1
  17. package/box/Box.js +22 -32
  18. package/bulleted-list/BulletedList.d.ts +7 -0
  19. package/bulleted-list/BulletedList.js +120 -0
  20. package/bulleted-list/BulletedList.stories.tsx +203 -0
  21. package/bulleted-list/types.d.ts +11 -0
  22. package/{list → bulleted-list}/types.js +0 -0
  23. package/button/Button.js +14 -11
  24. package/card/Card.js +24 -27
  25. package/checkbox/Checkbox.d.ts +1 -1
  26. package/checkbox/Checkbox.js +38 -28
  27. package/checkbox/Checkbox.stories.tsx +124 -128
  28. package/checkbox/types.d.ts +3 -3
  29. package/common/variables.js +197 -84
  30. package/date-input/DateInput.js +38 -20
  31. package/date-input/DateInput.test.js +9 -22
  32. package/date-input/types.d.ts +12 -9
  33. package/dialog/Dialog.js +4 -32
  34. package/dropdown/Dropdown.js +13 -17
  35. package/file-input/FileInput.js +9 -6
  36. package/file-input/FileItem.js +7 -5
  37. package/footer/Footer.js +15 -88
  38. package/header/Header.js +27 -48
  39. package/header/Header.stories.tsx +46 -36
  40. package/header/Header.test.js +18 -2
  41. package/inset/Inset.js +1 -34
  42. package/inset/Inset.stories.tsx +32 -32
  43. package/inset/types.d.ts +25 -1
  44. package/layout/ApplicationLayout.d.ts +4 -3
  45. package/layout/ApplicationLayout.js +82 -114
  46. package/layout/ApplicationLayout.stories.tsx +14 -59
  47. package/layout/Icons.d.ts +5 -0
  48. package/layout/Icons.js +13 -2
  49. package/layout/SidenavContext.d.ts +5 -0
  50. package/layout/SidenavContext.js +19 -0
  51. package/layout/types.d.ts +5 -10
  52. package/link/Link.d.ts +3 -2
  53. package/link/Link.js +57 -74
  54. package/link/Link.stories.tsx +87 -52
  55. package/link/Link.test.js +7 -15
  56. package/link/types.d.ts +7 -23
  57. package/main.d.ts +6 -5
  58. package/main.js +37 -23
  59. package/number-input/NumberInput.test.js +2 -4
  60. package/number-input/types.d.ts +13 -10
  61. package/package.json +6 -5
  62. package/paginator/Paginator.js +17 -38
  63. package/paragraph/Paragraph.d.ts +6 -0
  64. package/paragraph/Paragraph.js +38 -0
  65. package/paragraph/Paragraph.stories.tsx +44 -0
  66. package/password-input/PasswordInput.js +7 -4
  67. package/password-input/PasswordInput.test.js +3 -6
  68. package/password-input/types.d.ts +14 -11
  69. package/progress-bar/ProgressBar.js +1 -1
  70. package/progress-bar/ProgressBar.stories.jsx +11 -11
  71. package/quick-nav/QuickNav.js +75 -23
  72. package/quick-nav/QuickNav.stories.tsx +13 -13
  73. package/quick-nav/types.d.ts +4 -8
  74. package/radio-group/Radio.js +1 -1
  75. package/radio-group/RadioGroup.js +8 -6
  76. package/select/Listbox.d.ts +4 -0
  77. package/select/Listbox.js +152 -0
  78. package/select/Option.js +1 -1
  79. package/select/Select.js +66 -161
  80. package/select/Select.stories.tsx +14 -2
  81. package/select/Select.test.js +335 -231
  82. package/select/types.d.ts +33 -11
  83. package/sidenav/Sidenav.d.ts +1 -1
  84. package/sidenav/Sidenav.js +20 -9
  85. package/slider/Slider.d.ts +1 -1
  86. package/slider/Slider.js +2 -1
  87. package/slider/Slider.stories.tsx +8 -8
  88. package/slider/Slider.test.js +31 -10
  89. package/slider/types.d.ts +4 -0
  90. package/spinner/Spinner.js +1 -1
  91. package/switch/Switch.d.ts +1 -1
  92. package/switch/Switch.js +19 -16
  93. package/switch/Switch.stories.tsx +8 -8
  94. package/switch/types.d.ts +2 -2
  95. package/tabs/Tabs.d.ts +1 -1
  96. package/tabs/Tabs.js +9 -11
  97. package/tabs/Tabs.stories.tsx +0 -8
  98. package/tabs/Tabs.test.js +26 -9
  99. package/tabs/types.d.ts +4 -0
  100. package/tabs-nav/NavTabs.d.ts +8 -0
  101. package/tabs-nav/NavTabs.js +125 -0
  102. package/tabs-nav/NavTabs.stories.tsx +170 -0
  103. package/tabs-nav/NavTabs.test.js +82 -0
  104. package/tabs-nav/Tab.d.ts +4 -0
  105. package/tabs-nav/Tab.js +132 -0
  106. package/tabs-nav/types.d.ts +53 -0
  107. package/{radio → tabs-nav}/types.js +0 -0
  108. package/tag/Tag.js +5 -8
  109. package/text-input/Suggestion.d.ts +4 -0
  110. package/text-input/Suggestion.js +55 -0
  111. package/text-input/TextInput.js +48 -76
  112. package/text-input/TextInput.test.js +22 -35
  113. package/text-input/types.d.ts +27 -12
  114. package/textarea/Textarea.js +10 -19
  115. package/textarea/types.d.ts +10 -7
  116. package/toggle-group/ToggleGroup.d.ts +1 -1
  117. package/toggle-group/ToggleGroup.js +5 -4
  118. package/toggle-group/ToggleGroup.stories.tsx +4 -4
  119. package/toggle-group/ToggleGroup.test.js +35 -4
  120. package/toggle-group/types.d.ts +8 -0
  121. package/typography/Typography.d.ts +4 -0
  122. package/typography/Typography.js +131 -0
  123. package/typography/Typography.stories.tsx +175 -0
  124. package/typography/types.d.ts +18 -0
  125. package/typography/types.js +5 -0
  126. package/typography/typographyContextTypes.d.ts +16 -0
  127. package/typography/typographyContextTypes.js +5 -0
  128. package/useTheme.js +2 -2
  129. package/useTranslatedLabels.d.ts +2 -0
  130. package/useTranslatedLabels.js +20 -0
  131. package/wizard/Wizard.js +35 -29
  132. package/ThemeContext.d.ts +0 -10
  133. package/ThemeContext.js +0 -243
  134. package/list/List.d.ts +0 -4
  135. package/list/List.js +0 -47
  136. package/list/List.stories.tsx +0 -95
  137. package/list/types.d.ts +0 -7
  138. package/radio/Radio.d.ts +0 -4
  139. package/radio/Radio.js +0 -174
  140. package/radio/Radio.stories.tsx +0 -192
  141. package/radio/Radio.test.js +0 -71
  142. package/radio/types.d.ts +0 -54
  143. package/text/Text.d.ts +0 -7
  144. package/text/Text.js +0 -30
  145. package/text/Text.stories.tsx +0 -19
@@ -118,8 +118,7 @@ describe("TextInput component tests", function () {
118
118
 
119
119
  expect(onBlur).toHaveBeenCalled();
120
120
  expect(onBlur).toHaveBeenCalledWith({
121
- value: "Test",
122
- error: null
121
+ value: "Test"
123
122
  });
124
123
  });
125
124
  test("Not optional constraint (onChange)", function () {
@@ -143,8 +142,7 @@ describe("TextInput component tests", function () {
143
142
 
144
143
  expect(onChange).toHaveBeenCalled();
145
144
  expect(onChange).toHaveBeenCalledWith({
146
- value: "Test",
147
- error: null
145
+ value: "Test"
148
146
  });
149
147
 
150
148
  _userEvent["default"].clear(input);
@@ -205,16 +203,14 @@ describe("TextInput component tests", function () {
205
203
 
206
204
  expect(onChange).toHaveBeenCalled();
207
205
  expect(onChange).toHaveBeenCalledWith({
208
- value: "pattern4&",
209
- error: null
206
+ value: "pattern4&"
210
207
  });
211
208
 
212
209
  _react2.fireEvent.blur(input);
213
210
 
214
211
  expect(onBlur).toHaveBeenCalled();
215
212
  expect(onBlur).toHaveBeenCalledWith({
216
- value: "pattern4&",
217
- error: null
213
+ value: "pattern4&"
218
214
  });
219
215
  });
220
216
  test("Length constraint", function () {
@@ -268,16 +264,14 @@ describe("TextInput component tests", function () {
268
264
 
269
265
  expect(onChange).toHaveBeenCalled();
270
266
  expect(onChange).toHaveBeenCalledWith({
271
- value: "length",
272
- error: null
267
+ value: "length"
273
268
  });
274
269
 
275
270
  _react2.fireEvent.blur(input);
276
271
 
277
272
  expect(onBlur).toHaveBeenCalled();
278
273
  expect(onBlur).toHaveBeenCalledWith({
279
- value: "length",
280
- error: null
274
+ value: "length"
281
275
  });
282
276
  });
283
277
  test("Pattern and length constraints", function () {
@@ -350,16 +344,14 @@ describe("TextInput component tests", function () {
350
344
 
351
345
  expect(onChange).toHaveBeenCalled();
352
346
  expect(onChange).toHaveBeenCalledWith({
353
- value: "tests4&",
354
- error: null
347
+ value: "tests4&"
355
348
  });
356
349
 
357
350
  _react2.fireEvent.blur(input);
358
351
 
359
352
  expect(onBlur).toHaveBeenCalled();
360
353
  expect(onBlur).toHaveBeenCalledWith({
361
- value: "tests4&",
362
- error: null
354
+ value: "tests4&"
363
355
  });
364
356
  });
365
357
  test("onChange function is called correctly", function () {
@@ -378,8 +370,7 @@ describe("TextInput component tests", function () {
378
370
  expect(input.value).toBe("onchange event test");
379
371
  expect(onChange).toHaveBeenCalled();
380
372
  expect(onChange).toHaveBeenCalledWith({
381
- value: "onchange event test",
382
- error: null
373
+ value: "onchange event test"
383
374
  });
384
375
  });
385
376
  test("onBlur function is called correctly", function () {
@@ -405,8 +396,7 @@ describe("TextInput component tests", function () {
405
396
 
406
397
  expect(onBlur).toHaveBeenCalled();
407
398
  expect(onBlur).toHaveBeenCalledWith({
408
- value: "Blur test",
409
- error: null
399
+ value: "Blur test"
410
400
  });
411
401
  });
412
402
  test("Clear action's tooltip is correct", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
@@ -638,7 +628,7 @@ describe("TextInput component tests", function () {
638
628
  expect(input.getAttribute("aria-expanded")).toBe("true");
639
629
  expect(list.getAttribute("aria-label")).toBe("Autocomplete Countries");
640
630
  var options = getAllByRole("option");
641
- expect(options[0].getAttribute("aria-selected")).toBe("false");
631
+ expect(options[0].getAttribute("aria-selected")).toBeNull();
642
632
  });
643
633
  });
644
634
  describe("TextInput component synchronous autosuggest tests", function () {
@@ -944,8 +934,7 @@ describe("TextInput component synchronous autosuggest tests", function () {
944
934
  _userEvent["default"].click(getByRole("option"));
945
935
 
946
936
  expect(onChange).toHaveBeenCalledWith({
947
- value: "Andorra",
948
- error: null
937
+ value: "Andorra"
949
938
  });
950
939
  expect(queryByRole("listbox")).toBeFalsy();
951
940
 
@@ -1291,7 +1280,7 @@ describe("TextInput component asynchronous autosuggest tests", function () {
1291
1280
  resolve(newValue ? countries.filter(function (option) {
1292
1281
  return option.toUpperCase().includes(newValue.toUpperCase());
1293
1282
  }) : countries);
1294
- }, 1000);
1283
+ }, 100);
1295
1284
  });
1296
1285
  return result;
1297
1286
  });
@@ -1363,7 +1352,7 @@ describe("TextInput component asynchronous autosuggest tests", function () {
1363
1352
  resolve(newValue ? countries.filter(function (option) {
1364
1353
  return option.toUpperCase().includes(newValue.toUpperCase());
1365
1354
  }) : countries);
1366
- }, 1000);
1355
+ }, 100);
1367
1356
  });
1368
1357
  return result;
1369
1358
  });
@@ -1412,7 +1401,7 @@ describe("TextInput component asynchronous autosuggest tests", function () {
1412
1401
  resolve(newValue ? countries.filter(function (option) {
1413
1402
  return option.toUpperCase().includes(newValue.toUpperCase());
1414
1403
  }) : countries);
1415
- }, 1000);
1404
+ }, 100);
1416
1405
  });
1417
1406
  return result;
1418
1407
  });
@@ -1481,7 +1470,7 @@ describe("TextInput component asynchronous autosuggest tests", function () {
1481
1470
  resolve(newValue ? countries.filter(function (option) {
1482
1471
  return option.toUpperCase().includes(newValue.toUpperCase());
1483
1472
  }) : countries);
1484
- }, 1000);
1473
+ }, 100);
1485
1474
  });
1486
1475
  return result;
1487
1476
  });
@@ -1508,8 +1497,7 @@ describe("TextInput component asynchronous autosuggest tests", function () {
1508
1497
  _userEvent["default"].click(getByRole("option"));
1509
1498
 
1510
1499
  expect(onChange).toHaveBeenCalledWith({
1511
- value: "Denmark",
1512
- error: null
1500
+ value: "Denmark"
1513
1501
  });
1514
1502
  expect(input.value).toBe("Denmark");
1515
1503
 
@@ -1533,7 +1521,7 @@ describe("TextInput component asynchronous autosuggest tests", function () {
1533
1521
  resolve(newValue ? countries.filter(function (option) {
1534
1522
  return option.toUpperCase().includes(newValue.toUpperCase());
1535
1523
  }) : countries);
1536
- }, 1000);
1524
+ }, 100);
1537
1525
  });
1538
1526
  return result;
1539
1527
  });
@@ -1560,8 +1548,7 @@ describe("TextInput component asynchronous autosuggest tests", function () {
1560
1548
  _userEvent["default"].click(getByRole("option"));
1561
1549
 
1562
1550
  expect(onChange).toHaveBeenCalledWith({
1563
- value: "Denmark",
1564
- error: null
1551
+ value: "Denmark"
1565
1552
  });
1566
1553
  expect(queryByRole("listbox")).toBeFalsy();
1567
1554
 
@@ -1585,7 +1572,7 @@ describe("TextInput component asynchronous autosuggest tests", function () {
1585
1572
  resolve(newValue ? countries.filter(function (option) {
1586
1573
  return option.toUpperCase().includes(newValue.toUpperCase());
1587
1574
  }) : countries);
1588
- }, 1000);
1575
+ }, 100);
1589
1576
  });
1590
1577
  return result;
1591
1578
  });
@@ -1629,7 +1616,7 @@ describe("TextInput component asynchronous autosuggest tests", function () {
1629
1616
  resolve(newValue ? countries.filter(function (option) {
1630
1617
  return option.toUpperCase().includes(newValue.toUpperCase());
1631
1618
  }) : countries);
1632
- }, 1000);
1619
+ }, 100);
1633
1620
  });
1634
1621
  return result;
1635
1622
  });
@@ -1693,7 +1680,7 @@ describe("TextInput component asynchronous autosuggest tests", function () {
1693
1680
  var result = new Promise(function (resolve, reject) {
1694
1681
  return setTimeout(function () {
1695
1682
  reject("err");
1696
- }, 1000);
1683
+ }, 100);
1697
1684
  });
1698
1685
  return result;
1699
1686
  });
@@ -6,7 +6,7 @@ declare type Margin = {
6
6
  left?: Space;
7
7
  right?: Space;
8
8
  };
9
- declare type SVG = React.SVGProps<SVGSVGElement> | React.FunctionComponent<React.SVGProps<SVGSVGElement>>;
9
+ declare type SVG = React.SVGProps<SVGSVGElement>;
10
10
  declare type Action = {
11
11
  /**
12
12
  * This function will be called when the user clicks the action.
@@ -78,26 +78,29 @@ declare type Props = {
78
78
  * This function will be called when the user types within the input
79
79
  * element of the component. An object including the current value and
80
80
  * the error (if the value entered is not valid) will be passed to this
81
- * function. If there is no error, error will be null.
81
+ * function. If there is no error, error will not be defined.
82
82
  */
83
83
  onChange?: (val: {
84
84
  value: string;
85
- error: string | null;
85
+ error?: string;
86
86
  }) => void;
87
87
  /**
88
88
  * This function will be called when the input element loses the focus.
89
89
  * An object including the input value and the error (if the value
90
90
  * entered is not valid) will be passed to this function. If there is no error,
91
- * error will be null.
91
+ * error will not be defined.
92
92
  */
93
93
  onBlur?: (val: {
94
94
  value: string;
95
- error: string | null;
95
+ error?: string;
96
96
  }) => void;
97
97
  /**
98
- * If it is defined, the component will change its appearance, showing
99
- * the error below the input component. If it is not defined, the error
100
- * messages will be managed internally, but never displayed on its own.
98
+ * If it is a defined value and also a truthy string, the component will
99
+ * change its appearance, showing the error below the input component. If
100
+ * the defined value is an empty string, it will reserve a space below
101
+ * the component for a future error, but it would not change its look. In
102
+ * case of being undefined or null, both the appearance and the space for
103
+ * the error message would not be modified.
101
104
  */
102
105
  error?: string;
103
106
  /**
@@ -114,7 +117,7 @@ declare type Props = {
114
117
  * pattern, the onBlur and onChange functions will be called with the
115
118
  * current value and an internal error informing that this value does not
116
119
  * match the pattern. If the pattern is met, the error parameter of both
117
- * events will be null.
120
+ * events will not be defined.
118
121
  */
119
122
  pattern?: string;
120
123
  /**
@@ -124,7 +127,7 @@ declare type Props = {
124
127
  * comply the minimum length, the onBlur and onChange functions will be called
125
128
  * with the current value and an internal error informing that the value
126
129
  * length does not comply the specified range. If a valid length is
127
- * reached, the error parameter of both events will be null.
130
+ * reached, the error parameter of both events will not be defined.
128
131
  */
129
132
  minLength?: number;
130
133
  /**
@@ -134,7 +137,7 @@ declare type Props = {
134
137
  * comply the maximum length, the onBlur and onChange functions will be called
135
138
  * with the current value and an internal error informing that the value
136
139
  * length does not comply the specified range. If a valid length is
137
- * reached, the error parameter of both events will be null.
140
+ * reached, the error parameter of both events will not be defined.
138
141
  */
139
142
  maxLength?: number;
140
143
  /**
@@ -148,7 +151,7 @@ declare type Props = {
148
151
  */
149
152
  margin?: Space | Margin;
150
153
  /**
151
- * Size of the component ('small' | 'medium' | 'large' | 'fillParent').
154
+ * Size of the component.
152
155
  */
153
156
  size?: "small" | "medium" | "large" | "fillParent";
154
157
  /**
@@ -160,4 +163,16 @@ declare type Props = {
160
163
  * Reference to the component.
161
164
  */
162
165
  export declare type RefType = HTMLDivElement;
166
+ /**
167
+ * Single suggestion of the Autosuggest Text Input component.
168
+ */
169
+ export declare type SuggestionProps = {
170
+ id: string;
171
+ value: string;
172
+ onClick: () => void;
173
+ suggestion: string;
174
+ isLast: boolean;
175
+ visuallyFocused: boolean;
176
+ highlighted: boolean;
177
+ };
163
178
  export default Props;
@@ -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,13 +100,13 @@ 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: getNotOptionalErrorMessage()
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: getLengthErrorMessage()
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: getPatternErrorMessage()
109
+ error: translatedLabels.formFields.formatRequestedErrorMessage
119
110
  });else onChange === null || onChange === void 0 ? void 0 : onChange({
120
111
  value: newValue
121
112
  });
@@ -124,13 +115,13 @@ var DxcTextarea = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref)
124
115
  var handleTOnBlur = function handleTOnBlur(event) {
125
116
  if (isNotOptional(event.target.value)) onBlur === null || onBlur === void 0 ? void 0 : onBlur({
126
117
  value: event.target.value,
127
- error: getNotOptionalErrorMessage()
118
+ error: translatedLabels.formFields.requiredValueErrorMessage
128
119
  });else if (isLengthIncorrect(event.target.value)) onBlur === null || onBlur === void 0 ? void 0 : onBlur({
129
120
  value: event.target.value,
130
- error: getLengthErrorMessage()
121
+ error: translatedLabels.formFields.lengthErrorMessage(minLength, maxLength)
131
122
  });else if (event.target.value && pattern && !patternMatch(pattern, event.target.value)) onBlur === null || onBlur === void 0 ? void 0 : onBlur({
132
123
  value: event.target.value,
133
- error: getPatternErrorMessage()
124
+ error: translatedLabels.formFields.formatRequestedErrorMessage
134
125
  });else onBlur === null || onBlur === void 0 ? void 0 : onBlur({
135
126
  value: event.target.value
136
127
  });
@@ -160,7 +151,7 @@ var DxcTextarea = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref)
160
151
  disabled: disabled,
161
152
  backgroundType: backgroundType,
162
153
  helperText: helperText
163
- }, label, " ", optional && /*#__PURE__*/_react["default"].createElement(OptionalLabel, null, "(Optional)")), helperText && /*#__PURE__*/_react["default"].createElement(HelperText, {
154
+ }, label, " ", optional && /*#__PURE__*/_react["default"].createElement(OptionalLabel, null, translatedLabels.formFields.optionalLabel)), helperText && /*#__PURE__*/_react["default"].createElement(HelperText, {
164
155
  disabled: disabled,
165
156
  backgroundType: backgroundType
166
157
  }, helperText), /*#__PURE__*/_react["default"].createElement(Textarea, {
@@ -73,9 +73,12 @@ declare type Props = {
73
73
  error?: string;
74
74
  }) => void;
75
75
  /**
76
- * If it is defined, the component will change its appearance, showing
77
- * the error below the textarea. If it is not defined, the error
78
- * messages will be managed internally, but never displayed on its own.
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 null.
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 null.
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 null.
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 ('small' | 'medium' | 'large' | 'fillParent').
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 && Array.isArray(value) ? value ? value.includes(option.value) : Array.isArray(selectedValue) && selectedValue.includes(option.value) : value ? option.value === value : option.value === selectedValue,
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 && Array.isArray(value) ? value ? value.includes(option.value) : Array.isArray(selectedValue) && selectedValue.includes(option.value) : value ? option.value === value : option.value === selectedValue,
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" value={2} options={options} />
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" value={2} options={options} 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} value={2} />
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
- value={[1, 3]}
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
- getByText = _render5.getByText;
95
+ getAllByRole = _render5.getAllByRole;
96
96
 
97
- var option = getByText("Ebay");
97
+ var toggleOptions = getAllByRole("switch");
98
98
 
99
- _react2.fireEvent.click(option);
99
+ _react2.fireEvent.click(toggleOptions[0]);
100
+
101
+ expect(onChange).toHaveBeenCalledWith([1]);
102
+
103
+ _react2.fireEvent.click(toggleOptions[1]);
100
104
 
101
- expect(onChange).toHaveBeenCalledWith([2]);
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
  });
@@ -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.
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import TypographyPropsTypes from "./types";
3
+ declare function Typography({ as, display, fontFamily, fontSize, fontStyle, fontWeight, letterSpacing, lineHeight, textAlign, color, textDecoration, textOverflow, whiteSpace, children, }: TypographyPropsTypes): JSX.Element;
4
+ export default Typography;