@dxc-technology/halstack-react 0.0.0-f4755a1 → 0.0.0-f53d80b

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 (301) hide show
  1. package/BackgroundColorContext.d.ts +2 -2
  2. package/BackgroundColorContext.js +1 -1
  3. package/HalstackContext.d.ts +1339 -0
  4. package/HalstackContext.js +335 -0
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +118 -142
  7. package/accordion/Accordion.stories.tsx +114 -19
  8. package/accordion/Accordion.test.js +71 -0
  9. package/accordion/types.d.ts +8 -7
  10. package/accordion-group/AccordionGroup.d.ts +1 -1
  11. package/accordion-group/AccordionGroup.js +17 -38
  12. package/accordion-group/AccordionGroup.stories.tsx +28 -2
  13. package/accordion-group/AccordionGroup.test.js +126 -0
  14. package/accordion-group/types.d.ts +14 -7
  15. package/alert/Alert.js +8 -7
  16. package/alert/Alert.stories.tsx +28 -0
  17. package/alert/Alert.test.js +92 -0
  18. package/badge/Badge.d.ts +4 -0
  19. package/badge/Badge.js +5 -3
  20. package/badge/types.d.ts +5 -0
  21. package/bleed/Bleed.d.ts +3 -0
  22. package/bleed/Bleed.js +51 -0
  23. package/bleed/Bleed.stories.tsx +341 -0
  24. package/bleed/types.d.ts +37 -0
  25. package/bleed/types.js +5 -0
  26. package/box/Box.js +25 -37
  27. package/box/Box.stories.tsx +15 -0
  28. package/box/Box.test.js +18 -0
  29. package/box/types.d.ts +1 -0
  30. package/bulleted-list/BulletedList.d.ts +7 -0
  31. package/bulleted-list/BulletedList.js +123 -0
  32. package/bulleted-list/BulletedList.stories.tsx +200 -0
  33. package/bulleted-list/types.d.ts +11 -0
  34. package/bulleted-list/types.js +5 -0
  35. package/button/Button.d.ts +1 -1
  36. package/button/Button.js +56 -81
  37. package/button/Button.stories.tsx +163 -14
  38. package/button/Button.test.js +35 -0
  39. package/button/types.d.ts +6 -10
  40. package/card/Card.js +33 -37
  41. package/card/Card.stories.tsx +13 -14
  42. package/card/Card.test.js +50 -0
  43. package/card/types.d.ts +1 -0
  44. package/checkbox/Checkbox.d.ts +2 -2
  45. package/checkbox/Checkbox.js +107 -110
  46. package/checkbox/Checkbox.stories.tsx +198 -130
  47. package/checkbox/Checkbox.test.js +155 -0
  48. package/checkbox/types.d.ts +11 -3
  49. package/chip/Chip.d.ts +1 -1
  50. package/chip/Chip.js +22 -68
  51. package/chip/Chip.stories.tsx +98 -13
  52. package/chip/Chip.test.js +54 -0
  53. package/chip/types.d.ts +5 -13
  54. package/common/utils.d.ts +1 -0
  55. package/common/utils.js +4 -4
  56. package/common/variables.d.ts +1625 -0
  57. package/common/variables.js +490 -591
  58. package/date-input/Calendar.d.ts +4 -0
  59. package/date-input/Calendar.js +258 -0
  60. package/date-input/DateInput.js +171 -260
  61. package/date-input/DateInput.stories.tsx +199 -33
  62. package/date-input/DateInput.test.js +835 -0
  63. package/date-input/DatePicker.d.ts +4 -0
  64. package/date-input/DatePicker.js +146 -0
  65. package/date-input/Icons.d.ts +6 -0
  66. package/date-input/Icons.js +75 -0
  67. package/date-input/YearPicker.d.ts +4 -0
  68. package/date-input/YearPicker.js +126 -0
  69. package/date-input/types.d.ts +67 -9
  70. package/dialog/Dialog.js +76 -93
  71. package/dialog/Dialog.stories.tsx +230 -123
  72. package/dialog/Dialog.test.js +369 -0
  73. package/dialog/types.d.ts +1 -0
  74. package/dropdown/Dropdown.d.ts +1 -1
  75. package/dropdown/Dropdown.js +248 -277
  76. package/dropdown/Dropdown.stories.tsx +255 -64
  77. package/dropdown/Dropdown.test.js +586 -0
  78. package/dropdown/DropdownMenu.d.ts +4 -0
  79. package/dropdown/DropdownMenu.js +70 -0
  80. package/dropdown/DropdownMenuItem.d.ts +4 -0
  81. package/dropdown/DropdownMenuItem.js +79 -0
  82. package/dropdown/types.d.ts +27 -16
  83. package/file-input/FileInput.d.ts +2 -2
  84. package/file-input/FileInput.js +180 -223
  85. package/file-input/FileInput.stories.tsx +122 -10
  86. package/file-input/FileInput.test.js +457 -0
  87. package/file-input/FileItem.d.ts +4 -14
  88. package/file-input/FileItem.js +44 -66
  89. package/file-input/types.d.ts +17 -0
  90. package/flex/Flex.d.ts +4 -0
  91. package/flex/Flex.js +69 -0
  92. package/flex/Flex.stories.tsx +103 -0
  93. package/flex/types.d.ts +32 -0
  94. package/flex/types.js +5 -0
  95. package/footer/Footer.js +26 -103
  96. package/footer/Footer.stories.tsx +99 -1
  97. package/footer/Footer.test.js +97 -0
  98. package/footer/Icons.js +1 -1
  99. package/footer/types.d.ts +2 -1
  100. package/grid/Grid.d.ts +7 -0
  101. package/grid/Grid.js +91 -0
  102. package/grid/Grid.stories.tsx +219 -0
  103. package/grid/types.d.ts +46 -0
  104. package/grid/types.js +5 -0
  105. package/header/Header.d.ts +3 -2
  106. package/header/Header.js +108 -129
  107. package/header/Header.stories.tsx +189 -36
  108. package/header/Header.test.js +79 -0
  109. package/header/Icons.js +2 -2
  110. package/header/types.d.ts +1 -0
  111. package/heading/Heading.js +1 -1
  112. package/heading/Heading.stories.tsx +3 -2
  113. package/heading/Heading.test.js +186 -0
  114. package/inset/Inset.d.ts +3 -0
  115. package/inset/Inset.js +51 -0
  116. package/inset/Inset.stories.tsx +229 -0
  117. package/inset/types.d.ts +37 -0
  118. package/inset/types.js +5 -0
  119. package/layout/ApplicationLayout.d.ts +16 -6
  120. package/layout/ApplicationLayout.js +72 -126
  121. package/layout/ApplicationLayout.stories.tsx +84 -93
  122. package/layout/Icons.d.ts +5 -0
  123. package/layout/Icons.js +13 -2
  124. package/layout/SidenavContext.d.ts +5 -0
  125. package/layout/SidenavContext.js +19 -0
  126. package/layout/types.d.ts +18 -33
  127. package/link/Link.d.ts +3 -2
  128. package/link/Link.js +62 -87
  129. package/link/Link.stories.tsx +159 -52
  130. package/link/Link.test.js +81 -0
  131. package/link/types.d.ts +7 -27
  132. package/main.d.ts +12 -15
  133. package/main.js +57 -75
  134. package/nav-tabs/NavTabs.d.ts +8 -0
  135. package/nav-tabs/NavTabs.js +125 -0
  136. package/nav-tabs/NavTabs.stories.tsx +260 -0
  137. package/nav-tabs/NavTabs.test.js +82 -0
  138. package/nav-tabs/Tab.d.ts +4 -0
  139. package/nav-tabs/Tab.js +150 -0
  140. package/nav-tabs/types.d.ts +53 -0
  141. package/nav-tabs/types.js +5 -0
  142. package/number-input/NumberInput.js +11 -18
  143. package/number-input/NumberInput.stories.tsx +5 -5
  144. package/number-input/NumberInput.test.js +542 -0
  145. package/number-input/types.d.ts +17 -10
  146. package/package.json +20 -23
  147. package/paginator/Icons.d.ts +5 -0
  148. package/paginator/Icons.js +16 -28
  149. package/paginator/Paginator.js +19 -48
  150. package/paginator/Paginator.stories.tsx +24 -0
  151. package/paginator/Paginator.test.js +305 -0
  152. package/paragraph/Paragraph.d.ts +5 -0
  153. package/paragraph/Paragraph.js +38 -0
  154. package/paragraph/Paragraph.stories.tsx +44 -0
  155. package/password-input/PasswordInput.js +7 -4
  156. package/password-input/PasswordInput.stories.tsx +3 -3
  157. package/password-input/PasswordInput.test.js +181 -0
  158. package/password-input/types.d.ts +14 -11
  159. package/progress-bar/ProgressBar.js +61 -55
  160. package/progress-bar/ProgressBar.stories.jsx +47 -12
  161. package/progress-bar/ProgressBar.test.js +110 -0
  162. package/quick-nav/QuickNav.d.ts +4 -0
  163. package/quick-nav/QuickNav.js +117 -0
  164. package/quick-nav/QuickNav.stories.tsx +356 -0
  165. package/quick-nav/types.d.ts +21 -0
  166. package/quick-nav/types.js +5 -0
  167. package/radio-group/Radio.d.ts +1 -1
  168. package/radio-group/Radio.js +79 -32
  169. package/radio-group/RadioGroup.js +153 -36
  170. package/radio-group/RadioGroup.stories.tsx +178 -20
  171. package/radio-group/RadioGroup.test.js +722 -0
  172. package/radio-group/types.d.ts +90 -13
  173. package/resultsetTable/Icons.d.ts +7 -0
  174. package/resultsetTable/Icons.js +51 -0
  175. package/resultsetTable/ResultsetTable.js +50 -106
  176. package/resultsetTable/ResultsetTable.stories.tsx +56 -32
  177. package/resultsetTable/ResultsetTable.test.js +325 -0
  178. package/resultsetTable/types.d.ts +1 -1
  179. package/select/Icons.d.ts +10 -0
  180. package/select/Icons.js +93 -0
  181. package/select/Listbox.d.ts +4 -0
  182. package/select/Listbox.js +169 -0
  183. package/select/Option.d.ts +4 -0
  184. package/select/Option.js +97 -0
  185. package/select/Select.js +189 -386
  186. package/select/Select.stories.tsx +600 -201
  187. package/select/Select.test.js +2228 -0
  188. package/select/types.d.ts +53 -13
  189. package/sidenav/Sidenav.d.ts +6 -5
  190. package/sidenav/Sidenav.js +183 -53
  191. package/sidenav/Sidenav.stories.tsx +249 -132
  192. package/sidenav/Sidenav.test.js +44 -0
  193. package/sidenav/types.d.ts +50 -27
  194. package/slider/Slider.d.ts +2 -2
  195. package/slider/Slider.js +123 -98
  196. package/slider/Slider.stories.tsx +72 -9
  197. package/slider/Slider.test.js +250 -0
  198. package/slider/types.d.ts +8 -0
  199. package/spinner/Spinner.js +18 -24
  200. package/spinner/Spinner.stories.jsx +53 -26
  201. package/spinner/Spinner.test.js +64 -0
  202. package/switch/Switch.d.ts +2 -2
  203. package/switch/Switch.js +152 -69
  204. package/switch/Switch.stories.tsx +54 -43
  205. package/switch/Switch.test.js +225 -0
  206. package/switch/types.d.ts +10 -2
  207. package/table/Table.js +3 -3
  208. package/table/Table.stories.jsx +81 -1
  209. package/table/Table.test.js +26 -0
  210. package/tabs/Tab.d.ts +4 -0
  211. package/tabs/Tab.js +133 -0
  212. package/tabs/Tabs.d.ts +1 -1
  213. package/tabs/Tabs.js +363 -111
  214. package/tabs/Tabs.stories.tsx +122 -17
  215. package/tabs/Tabs.test.js +350 -0
  216. package/tabs/types.d.ts +37 -15
  217. package/tag/Tag.d.ts +1 -1
  218. package/tag/Tag.js +24 -36
  219. package/tag/Tag.stories.tsx +38 -28
  220. package/tag/Tag.test.js +60 -0
  221. package/tag/types.d.ts +23 -14
  222. package/text-input/Icons.d.ts +8 -0
  223. package/text-input/Icons.js +60 -0
  224. package/text-input/Suggestion.d.ts +4 -0
  225. package/text-input/Suggestion.js +84 -0
  226. package/text-input/Suggestions.d.ts +4 -0
  227. package/text-input/Suggestions.js +134 -0
  228. package/text-input/TextInput.js +220 -333
  229. package/text-input/TextInput.stories.tsx +309 -196
  230. package/text-input/TextInput.test.js +1723 -0
  231. package/text-input/types.d.ts +51 -13
  232. package/textarea/Textarea.js +23 -30
  233. package/textarea/Textarea.stories.jsx +96 -15
  234. package/textarea/Textarea.test.js +437 -0
  235. package/textarea/types.d.ts +18 -11
  236. package/toggle-group/ToggleGroup.d.ts +1 -1
  237. package/toggle-group/ToggleGroup.js +12 -8
  238. package/toggle-group/ToggleGroup.stories.tsx +46 -4
  239. package/toggle-group/ToggleGroup.test.js +156 -0
  240. package/toggle-group/types.d.ts +10 -2
  241. package/typography/Typography.d.ts +4 -0
  242. package/typography/Typography.js +32 -0
  243. package/typography/Typography.stories.tsx +198 -0
  244. package/typography/types.d.ts +18 -0
  245. package/typography/types.js +5 -0
  246. package/useTheme.d.ts +1234 -1
  247. package/useTheme.js +3 -3
  248. package/useTranslatedLabels.d.ts +85 -0
  249. package/useTranslatedLabels.js +20 -0
  250. package/utils/BaseTypography.d.ts +21 -0
  251. package/utils/BaseTypography.js +108 -0
  252. package/utils/FocusLock.d.ts +13 -0
  253. package/utils/FocusLock.js +139 -0
  254. package/wizard/Wizard.d.ts +1 -1
  255. package/wizard/Wizard.js +59 -55
  256. package/wizard/Wizard.stories.tsx +48 -19
  257. package/wizard/Wizard.test.js +141 -0
  258. package/wizard/types.d.ts +8 -4
  259. package/ThemeContext.d.ts +0 -15
  260. package/ThemeContext.js +0 -243
  261. package/V3Select/V3Select.js +0 -455
  262. package/V3Select/index.d.ts +0 -27
  263. package/V3Textarea/V3Textarea.js +0 -260
  264. package/V3Textarea/index.d.ts +0 -27
  265. package/common/RequiredComponent.js +0 -32
  266. package/date/Date.js +0 -373
  267. package/date/index.d.ts +0 -27
  268. package/input-text/Icons.js +0 -22
  269. package/input-text/InputText.js +0 -611
  270. package/input-text/index.d.ts +0 -36
  271. package/list/List.d.ts +0 -8
  272. package/list/List.js +0 -47
  273. package/list/List.stories.tsx +0 -95
  274. package/radio/Radio.d.ts +0 -4
  275. package/radio/Radio.js +0 -174
  276. package/radio/Radio.stories.tsx +0 -192
  277. package/radio/types.d.ts +0 -54
  278. package/row/Row.d.ts +0 -11
  279. package/row/Row.js +0 -127
  280. package/row/Row.stories.tsx +0 -239
  281. package/stack/Stack.d.ts +0 -10
  282. package/stack/Stack.js +0 -97
  283. package/stack/Stack.stories.tsx +0 -166
  284. package/text/Text.d.ts +0 -7
  285. package/text/Text.js +0 -30
  286. package/text/Text.stories.tsx +0 -19
  287. package/toggle/Toggle.js +0 -186
  288. package/toggle/index.d.ts +0 -21
  289. package/upload/Upload.js +0 -201
  290. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  291. package/upload/buttons-upload/Icons.js +0 -40
  292. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  293. package/upload/dragAndDropArea/Icons.js +0 -39
  294. package/upload/file-upload/FileToUpload.js +0 -115
  295. package/upload/file-upload/Icons.js +0 -66
  296. package/upload/files-upload/FilesToUpload.js +0 -109
  297. package/upload/index.d.ts +0 -15
  298. package/upload/transaction/Icons.js +0 -160
  299. package/upload/transaction/Transaction.js +0 -104
  300. package/upload/transactions/Transactions.js +0 -94
  301. /package/{radio → badge}/types.js +0 -0
@@ -11,6 +11,8 @@ exports["default"] = void 0;
11
11
 
12
12
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
13
 
14
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
15
+
14
16
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
15
17
 
16
18
  var _react = _interopRequireWildcard(require("react"));
@@ -21,6 +23,8 @@ var _uuid = require("uuid");
21
23
 
22
24
  var _useTheme = _interopRequireDefault(require("../useTheme"));
23
25
 
26
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
27
+
24
28
  var _Radio = _interopRequireDefault(require("./Radio"));
25
29
 
26
30
  var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7;
@@ -29,7 +33,16 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
29
33
 
30
34
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
31
35
 
36
+ var getInitialFocusIndex = function getInitialFocusIndex(innerOptions, value) {
37
+ var initialSelectedOptionIndex = innerOptions.findIndex(function (option) {
38
+ return option.value === value;
39
+ });
40
+ return initialSelectedOptionIndex !== -1 ? initialSelectedOptionIndex : 0;
41
+ };
42
+
32
43
  var DxcRadioGroup = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
44
+ var _ref2;
45
+
33
46
  var label = _ref.label,
34
47
  name = _ref.name,
35
48
  helperText = _ref.helperText,
@@ -38,8 +51,7 @@ var DxcRadioGroup = /*#__PURE__*/_react["default"].forwardRef(function (_ref, re
38
51
  disabled = _ref$disabled === void 0 ? false : _ref$disabled,
39
52
  _ref$optional = _ref.optional,
40
53
  optional = _ref$optional === void 0 ? false : _ref$optional,
41
- _ref$optionalItemLabe = _ref.optionalItemLabel,
42
- optionalItemLabel = _ref$optionalItemLabe === void 0 ? "None" : _ref$optionalItemLabe,
54
+ optionalItemLabel = _ref.optionalItemLabel,
43
55
  _ref$readonly = _ref.readonly,
44
56
  readonly = _ref$readonly === void 0 ? false : _ref$readonly,
45
57
  _ref$stacking = _ref.stacking,
@@ -47,30 +59,122 @@ var DxcRadioGroup = /*#__PURE__*/_react["default"].forwardRef(function (_ref, re
47
59
  defaultValue = _ref.defaultValue,
48
60
  value = _ref.value,
49
61
  onChange = _ref.onChange,
50
- error = _ref.error;
62
+ onBlur = _ref.onBlur,
63
+ error = _ref.error,
64
+ _ref$tabIndex = _ref.tabIndex,
65
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
51
66
 
52
- var _useState = (0, _react.useState)("select-".concat((0, _uuid.v4)())),
67
+ var _useState = (0, _react.useState)("radio-group-".concat((0, _uuid.v4)())),
53
68
  _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
54
69
  radioGroupId = _useState2[0];
55
70
 
56
71
  var radioGroupLabelId = "label-".concat(radioGroupId);
72
+ var errorId = "error-".concat(radioGroupId);
57
73
 
58
74
  var _useState3 = (0, _react.useState)(defaultValue),
59
75
  _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
60
76
  innerValue = _useState4[0],
61
77
  setInnerValue = _useState4[1];
62
78
 
79
+ var _useState5 = (0, _react.useState)(true),
80
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
81
+ firstTimeFocus = _useState6[0],
82
+ setFirstTimeFocus = _useState6[1];
83
+
63
84
  var colorsTheme = (0, _useTheme["default"])();
64
- var handleOnChange = (0, _react.useCallback)(function (optionValue) {
65
- var val = value !== null && value !== void 0 ? value : innerValue;
85
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
86
+ var optionalItem = {
87
+ label: optionalItemLabel || translatedLabels.radioGroup.optionalItemLabelDefault,
88
+ value: "",
89
+ disabled: disabled
90
+ };
91
+ var innerOptions = (0, _react.useMemo)(function () {
92
+ return optional ? [].concat((0, _toConsumableArray2["default"])(options), [optionalItem]) : options;
93
+ }, [optional, options]);
94
+
95
+ var _useState7 = (0, _react.useState)(getInitialFocusIndex(innerOptions, value !== null && value !== void 0 ? value : innerValue)),
96
+ _useState8 = (0, _slicedToArray2["default"])(_useState7, 2),
97
+ currentFocusIndex = _useState8[0],
98
+ setCurrentFocusIndex = _useState8[1];
66
99
 
67
- if (optionValue !== val) {
68
- value !== null && value !== void 0 ? value : setInnerValue(optionValue);
69
- onChange === null || onChange === void 0 ? void 0 : onChange({
70
- value: optionValue
100
+ var handleOnChange = (0, _react.useCallback)(function (newValue) {
101
+ var currentValue = value !== null && value !== void 0 ? value : innerValue;
102
+
103
+ if (newValue !== currentValue && !readonly) {
104
+ value !== null && value !== void 0 ? value : setInnerValue(newValue);
105
+ onChange === null || onChange === void 0 ? void 0 : onChange(newValue);
106
+ }
107
+ }, [value, innerValue, onChange]);
108
+
109
+ var handleOnBlur = function handleOnBlur(event) {
110
+ // If the radio group loses the focus to an element not contained inside it...
111
+ if (!event.currentTarget.contains(event.relatedTarget)) {
112
+ setFirstTimeFocus(true);
113
+ var currentValue = value !== null && value !== void 0 ? value : innerValue;
114
+ !optional && !Boolean(currentValue) ? onBlur === null || onBlur === void 0 ? void 0 : onBlur({
115
+ value: currentValue,
116
+ error: translatedLabels.formFields.requiredSelectionErrorMessage
117
+ }) : onBlur === null || onBlur === void 0 ? void 0 : onBlur({
118
+ value: currentValue
71
119
  });
72
120
  }
73
- }, [value, innerValue, setInnerValue, onChange]);
121
+ };
122
+
123
+ var handleOnFocus = function handleOnFocus() {
124
+ firstTimeFocus && setFirstTimeFocus(false);
125
+ };
126
+
127
+ var setPreviousRadioChecked = function setPreviousRadioChecked() {
128
+ setCurrentFocusIndex(function (currentFocusIndex) {
129
+ var index = currentFocusIndex === 0 ? innerOptions.length - 1 : currentFocusIndex - 1;
130
+
131
+ while (innerOptions[index].disabled) {
132
+ index = index === 0 ? innerOptions.length - 1 : index - 1;
133
+ }
134
+
135
+ handleOnChange(innerOptions[index].value);
136
+ return index;
137
+ });
138
+ };
139
+
140
+ var setNextRadioChecked = function setNextRadioChecked() {
141
+ setCurrentFocusIndex(function (currentFocusIndex) {
142
+ var index = currentFocusIndex === innerOptions.length - 1 ? 0 : currentFocusIndex + 1;
143
+
144
+ while (innerOptions[index].disabled) {
145
+ index = index === innerOptions.length - 1 ? 0 : index + 1;
146
+ }
147
+
148
+ handleOnChange(innerOptions[index].value);
149
+ return index;
150
+ });
151
+ };
152
+
153
+ var handleOnKeyDown = function handleOnKeyDown(event) {
154
+ switch (event.key) {
155
+ case "Left":
156
+ case "ArrowLeft":
157
+ case "Up":
158
+ case "ArrowUp":
159
+ event.preventDefault();
160
+ setPreviousRadioChecked();
161
+ break;
162
+
163
+ case "Right":
164
+ case "ArrowRight":
165
+ case "Down":
166
+ case "ArrowDown":
167
+ event.preventDefault();
168
+ setNextRadioChecked();
169
+ break;
170
+
171
+ case " ":
172
+ event.preventDefault();
173
+ handleOnChange(innerOptions[currentFocusIndex].value);
174
+ break;
175
+ }
176
+ };
177
+
74
178
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
75
179
  theme: colorsTheme.radioGroup
76
180
  }, /*#__PURE__*/_react["default"].createElement(RadioGroupContainer, {
@@ -79,40 +183,49 @@ var DxcRadioGroup = /*#__PURE__*/_react["default"].forwardRef(function (_ref, re
79
183
  id: radioGroupLabelId,
80
184
  helperText: helperText,
81
185
  disabled: disabled
82
- }, label, " ", optional && /*#__PURE__*/_react["default"].createElement(OptionalLabel, null, "(Optional)")), helperText && /*#__PURE__*/_react["default"].createElement(HelperText, {
186
+ }, label, optional && /*#__PURE__*/_react["default"].createElement(OptionalLabel, null, " ".concat(translatedLabels.formFields.optionalLabel))), helperText && /*#__PURE__*/_react["default"].createElement(HelperText, {
83
187
  disabled: disabled
84
188
  }, helperText), /*#__PURE__*/_react["default"].createElement(RadioGroup, {
189
+ onBlur: handleOnBlur,
190
+ onFocus: handleOnFocus,
191
+ onKeyDown: handleOnKeyDown,
85
192
  stacking: stacking,
86
193
  role: "radiogroup",
87
- "aria-labelledby": radioGroupLabelId
194
+ "aria-disabled": disabled,
195
+ "aria-labelledby": radioGroupLabelId,
196
+ "aria-invalid": error ? true : false,
197
+ "aria-errormessage": error ? errorId : undefined,
198
+ "aria-required": !disabled && !readonly && !optional,
199
+ "aria-readonly": readonly,
200
+ "aria-orientation": stacking === "column" ? "vertical" : "horizontal"
88
201
  }, /*#__PURE__*/_react["default"].createElement(ValueInput, {
89
202
  name: name,
90
- value: value !== null && value !== void 0 ? value : innerValue,
203
+ disabled: disabled,
204
+ value: (_ref2 = value !== null && value !== void 0 ? value : innerValue) !== null && _ref2 !== void 0 ? _ref2 : "",
91
205
  readOnly: true,
92
206
  "aria-hidden": "true"
93
- }), options.map(function (option, index) {
207
+ }), innerOptions.map(function (option, index) {
94
208
  return /*#__PURE__*/_react["default"].createElement(_Radio["default"], {
95
- option: option,
96
- currentValue: value !== null && value !== void 0 ? value : innerValue,
97
- onChange: handleOnChange,
98
- disabledRadioGroup: disabled,
209
+ key: "radio-".concat(index),
210
+ label: option.label,
211
+ checked: (value !== null && value !== void 0 ? value : innerValue) === option.value,
212
+ onClick: function onClick() {
213
+ handleOnChange(option.value);
214
+ setCurrentFocusIndex(index);
215
+ },
99
216
  error: error,
100
- first: !value && !innerValue && index === 0
217
+ disabled: option.disabled || disabled,
218
+ focused: currentFocusIndex === index,
219
+ readonly: readonly,
220
+ tabIndex: tabIndex
101
221
  });
102
- }), optional && /*#__PURE__*/_react["default"].createElement(_Radio["default"], {
103
- option: {
104
- label: optionalItemLabel,
105
- value: "",
106
- disabled: disabled
107
- },
108
- currentValue: value !== null && value !== void 0 ? value : innerValue,
109
- onChange: handleOnChange,
110
- disabledRadioGroup: disabled,
111
- error: error
112
- })), !disabled && typeof error === "string" && /*#__PURE__*/_react["default"].createElement(Error, null, error)));
222
+ })), !disabled && typeof error === "string" && /*#__PURE__*/_react["default"].createElement(Error, {
223
+ id: errorId,
224
+ "aria-live": error ? "assertive" : "off"
225
+ }, error)));
113
226
  });
114
227
 
115
- var RadioGroupContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n box-sizing: border-box;\n"])));
228
+ var RadioGroupContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n flex-direction: column;\n box-sizing: border-box;\n"])));
116
229
 
117
230
  var Label = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n ", "\n"])), function (props) {
118
231
  return props.disabled ? props.theme.disabledLabelFontColor : props.theme.labelFontColor;
@@ -127,14 +240,14 @@ var Label = _styledComponents["default"].span(_templateObject2 || (_templateObje
127
240
  }, function (props) {
128
241
  return props.theme.labelLineHeight;
129
242
  }, function (props) {
130
- return !props.helperText && "margin-bottom: 0.25rem;";
243
+ return !props.helperText && "margin-bottom: ".concat(props.theme.groupLabelMargin);
131
244
  });
132
245
 
133
246
  var OptionalLabel = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n font-weight: ", ";\n"])), function (props) {
134
247
  return props.theme.optionalLabelFontWeight;
135
248
  });
136
249
 
137
- var HelperText = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n margin-bottom: 0.5rem;\n"])), function (props) {
250
+ var HelperText = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n margin-bottom: ", ";\n"])), function (props) {
138
251
  return props.disabled ? props.theme.disabledHelperTextFontColor : props.theme.helperTextFontColor;
139
252
  }, function (props) {
140
253
  return props.theme.fontFamily;
@@ -146,12 +259,16 @@ var HelperText = _styledComponents["default"].span(_templateObject4 || (_templat
146
259
  return props.theme.helperTextFontWeight;
147
260
  }, function (props) {
148
261
  return props.theme.helperTextLineHeight;
262
+ }, function (props) {
263
+ return props.theme.groupLabelMargin;
149
264
  });
150
265
 
151
- var RadioGroup = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n flex-direction: ", ";\n\n div + div {\n ", ";\n }\n"])), function (props) {
266
+ var RadioGroup = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n flex-direction: ", ";\n row-gap: ", ";\n column-gap: ", ";\n"])), function (props) {
152
267
  return props.stacking;
153
268
  }, function (props) {
154
- return props.stacking === "column" ? "margin-top: 0.25rem;" : "margin-left: 2rem;";
269
+ return props.theme.groupVerticalGutter;
270
+ }, function (props) {
271
+ return props.theme.groupHorizontalGutter;
155
272
  });
156
273
 
157
274
  var ValueInput = _styledComponents["default"].input(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n display: none;\n"])));
@@ -1,56 +1,214 @@
1
+ import React from "react";
1
2
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
2
3
  import Title from "../../.storybook/components/Title";
3
4
  import DxcRadioGroup from "./RadioGroup";
5
+ import { HalstackProvider } from "../HalstackContext";
4
6
 
5
7
  export default {
6
8
  title: "Radio Group",
7
9
  component: DxcRadioGroup,
8
10
  };
9
11
 
12
+ const single_option = [{ label: "Option A", value: "A" }];
13
+
10
14
  const options = [
11
15
  { label: "Option 1", value: "1" },
12
16
  { label: "Option 2", value: "2" },
13
17
  { label: "Option 3", value: "3" },
18
+ { label: "Option 4", value: "4" },
14
19
  ];
15
20
 
16
- const single_disabled_options = [
17
- { label: "Option 1", value: "1" },
18
- { label: "Option 2", value: "2", disabled: true },
19
- { label: "Option 3", value: "3" },
20
- ];
21
+ const single_disabled_options = [{ label: "Option A", value: "A", disabled: true }];
22
+
23
+ const opinionatedTheme = {
24
+ radioGroup: {
25
+ baseColor: "#0086e6",
26
+ fontColor: "#000000",
27
+ },
28
+ };
21
29
 
22
30
  export const Chromatic = () => (
23
31
  <>
32
+ <Title title="Radio input states" theme="light" level={2} />
24
33
  <ExampleContainer>
25
- <Title title="Default (column)" theme="light" level={4} />
26
- <DxcRadioGroup label="Example" helperText="Helper text" options={options} />
34
+ <Title title="Enabled" theme="light" level={4} />
35
+ <DxcRadioGroup label="Label" helperText="Helper text" defaultValue="A" options={single_option} />
27
36
  </ExampleContainer>
28
- <ExampleContainer>
29
- <Title title="Row" theme="light" level={4} />
30
- <DxcRadioGroup label="Example" helperText="Helper text" options={options} stacking="row" />
37
+ <ExampleContainer pseudoState="pseudo-hover">
38
+ <Title title="Hovered" theme="light" level={4} />
39
+ <DxcRadioGroup label="Label" helperText="Helper text" defaultValue="A" options={single_option} />
40
+ </ExampleContainer>
41
+ <ExampleContainer pseudoState="pseudo-active">
42
+ <Title title="Active" theme="light" level={4} />
43
+ <DxcRadioGroup label="Label" helperText="Helper text" defaultValue="A" options={single_option} />
44
+ </ExampleContainer>
45
+ <ExampleContainer pseudoState="pseudo-focus">
46
+ <Title title="Focused" theme="light" level={4} />
47
+ <DxcRadioGroup label="Label" helperText="Helper text" defaultValue="A" options={single_option} />
31
48
  </ExampleContainer>
32
49
  <ExampleContainer>
33
50
  <Title title="Disabled" theme="light" level={4} />
34
- <DxcRadioGroup label="Disabled" error="Error message" helperText="Helper text" options={options} disabled optional defaultValue="2" />
51
+ <DxcRadioGroup label="Label" helperText="Helper text" options={single_disabled_options} defaultValue="A" />
35
52
  </ExampleContainer>
53
+ <Title title="Readonly radio input sub-states" theme="light" level={3} />
36
54
  <ExampleContainer>
37
- <Title title="Single disabled" theme="light" level={4} />
38
- <DxcRadioGroup label="Disabled" helperText="Helper text" options={single_disabled_options} optional defaultValue="3" />
55
+ <Title title="Enabled" theme="light" level={4} />
56
+ <DxcRadioGroup label="Label" helperText="Helper text" options={single_option} defaultValue="A" readonly />
57
+ </ExampleContainer>
58
+ <ExampleContainer pseudoState="pseudo-hover">
59
+ <Title title="Hovered" theme="light" level={4} />
60
+ <DxcRadioGroup label="Label" helperText="Helper text" options={single_option} defaultValue="A" readonly />
61
+ </ExampleContainer>
62
+ <ExampleContainer pseudoState="pseudo-active">
63
+ <Title title="Active" theme="light" level={4} />
64
+ <DxcRadioGroup label="Label" helperText="Helper text" options={single_option} defaultValue="A" readonly />
39
65
  </ExampleContainer>
66
+ <Title title="Error radio input sub-states" theme="light" level={3} />
40
67
  <ExampleContainer>
41
- <Title title="Optional" theme="light" level={4} />
68
+ <Title title="Enabled" theme="light" level={4} />
42
69
  <DxcRadioGroup
43
- label="Example"
44
- optionalOptionLabel="No selection"
45
- optional
70
+ label="Label"
46
71
  helperText="Helper text"
47
- options={options}
48
- stacking="row"
72
+ options={single_option}
73
+ defaultValue="A"
74
+ error="Error message"
49
75
  />
50
76
  </ExampleContainer>
77
+ <ExampleContainer pseudoState="pseudo-hover">
78
+ <Title title="Hovered" theme="light" level={4} />
79
+ <DxcRadioGroup
80
+ label="Label"
81
+ helperText="Helper text"
82
+ options={single_option}
83
+ defaultValue="A"
84
+ readonly
85
+ error="Error message"
86
+ />
87
+ </ExampleContainer>
88
+ <ExampleContainer pseudoState="pseudo-active">
89
+ <Title title="Active" theme="light" level={4} />
90
+ <DxcRadioGroup
91
+ label="Label"
92
+ helperText="Helper text"
93
+ options={single_option}
94
+ defaultValue="A"
95
+ readonly
96
+ error="Error message"
97
+ />
98
+ </ExampleContainer>
99
+ <Title title="Variants" theme="light" level={2} />
100
+ <ExampleContainer>
101
+ <Title title="Column" theme="light" level={4} />
102
+ <DxcRadioGroup label="Label" helperText="Helper text" options={options} />
103
+ </ExampleContainer>
104
+ <ExampleContainer>
105
+ <Title title="Row" theme="light" level={4} />
106
+ <DxcRadioGroup label="Label" helperText="Helper text" options={options} stacking="row" />
107
+ </ExampleContainer>
108
+ <ExampleContainer>
109
+ <Title title="Optional" theme="light" level={4} />
110
+ <DxcRadioGroup label="Label" optional helperText="Helper text" options={options} stacking="row" />
111
+ </ExampleContainer>
112
+ <ExampleContainer>
113
+ <Title title="Disabled" theme="light" level={4} />
114
+ <DxcRadioGroup label="Label" helperText="Helper text" options={options} disabled />
115
+ </ExampleContainer>
116
+ <ExampleContainer>
117
+ <Title title="Readonly" theme="light" level={4} />
118
+ <DxcRadioGroup label="Label" readonly helperText="Helper text" options={options} />
119
+ </ExampleContainer>
120
+ <ExampleContainer>
121
+ <Title title="Error space reserved" theme="light" level={4} />
122
+ <DxcRadioGroup label="Label" error="" helperText="Helper text" options={options} />
123
+ </ExampleContainer>
51
124
  <ExampleContainer>
52
125
  <Title title="Error" theme="light" level={4} />
53
- <DxcRadioGroup label="Example" error="Error message" helperText="Helper text" options={options} defaultValue="2" />
126
+ <DxcRadioGroup label="Label" error="Error message" helperText="Helper text" options={options} />
127
+ </ExampleContainer>
128
+ <Title title="Opinionated theme" theme="light" level={2} />
129
+ <ExampleContainer>
130
+ <Title title="Enabled" theme="light" level={4} />
131
+ <HalstackProvider theme={opinionatedTheme}>
132
+ <DxcRadioGroup label="Label" helperText="Helper text" defaultValue="A" options={single_option} />
133
+ </HalstackProvider>
134
+ </ExampleContainer>
135
+ <ExampleContainer pseudoState="pseudo-hover">
136
+ <Title title="Hovered" theme="light" level={4} />
137
+ <HalstackProvider theme={opinionatedTheme}>
138
+ <DxcRadioGroup label="Label" helperText="Helper text" defaultValue="A" options={single_option} />
139
+ </HalstackProvider>
140
+ </ExampleContainer>
141
+ <ExampleContainer pseudoState="pseudo-active">
142
+ <Title title="Active" theme="light" level={4} />
143
+ <HalstackProvider theme={opinionatedTheme}>
144
+ <DxcRadioGroup label="Label" helperText="Helper text" defaultValue="A" options={single_option} />
145
+ </HalstackProvider>
146
+ </ExampleContainer>
147
+ <ExampleContainer pseudoState="pseudo-focus">
148
+ <Title title="Focused" theme="light" level={4} />
149
+ <HalstackProvider theme={opinionatedTheme}>
150
+ <DxcRadioGroup label="Label" helperText="Helper text" defaultValue="A" options={single_option} />
151
+ </HalstackProvider>
152
+ </ExampleContainer>
153
+ <ExampleContainer>
154
+ <Title title="Disabled" theme="light" level={4} />
155
+ <HalstackProvider theme={opinionatedTheme}>
156
+ <DxcRadioGroup label="Label" helperText="Helper text" options={single_disabled_options} defaultValue="A" />
157
+ </HalstackProvider>
158
+ </ExampleContainer>
159
+ <ExampleContainer>
160
+ <Title title="Readonly enabled" theme="light" level={4} />
161
+ <HalstackProvider theme={opinionatedTheme}>
162
+ <DxcRadioGroup label="Label" options={single_option} defaultValue="A" readonly />
163
+ </HalstackProvider>
164
+ </ExampleContainer>
165
+ <ExampleContainer pseudoState="pseudo-hover">
166
+ <Title title="Readonly hovered" theme="light" level={4} />
167
+ <HalstackProvider theme={opinionatedTheme}>
168
+ <DxcRadioGroup label="Label" options={single_option} defaultValue="A" readonly />
169
+ </HalstackProvider>
170
+ </ExampleContainer>
171
+ <ExampleContainer pseudoState="pseudo-active">
172
+ <Title title="Readonly active" theme="light" level={4} />
173
+ <HalstackProvider theme={opinionatedTheme}>
174
+ <DxcRadioGroup label="Label" options={single_option} defaultValue="A" readonly />
175
+ </HalstackProvider>
176
+ </ExampleContainer>
177
+ <ExampleContainer pseudoState="pseudo-focus">
178
+ <Title title="Readonly focused" theme="light" level={4} />
179
+ <HalstackProvider theme={opinionatedTheme}>
180
+ <DxcRadioGroup label="Label" options={single_option} defaultValue="A" readonly />
181
+ </HalstackProvider>
182
+ </ExampleContainer>
183
+ <ExampleContainer>
184
+ <Title title="Enabled" theme="light" level={4} />
185
+ <HalstackProvider theme={opinionatedTheme}>
186
+ <DxcRadioGroup label="Label" options={single_option} defaultValue="A" error="Error message" />
187
+ </HalstackProvider>
188
+ </ExampleContainer>
189
+ <ExampleContainer pseudoState="pseudo-hover">
190
+ <Title title="Hovered" theme="light" level={4} />
191
+ <HalstackProvider theme={opinionatedTheme}>
192
+ <DxcRadioGroup label="Label" options={single_option} defaultValue="A" error="Error message" />
193
+ </HalstackProvider>
194
+ </ExampleContainer>
195
+ <ExampleContainer pseudoState="pseudo-active">
196
+ <Title title="Active" theme="light" level={4} />
197
+ <HalstackProvider theme={opinionatedTheme}>
198
+ <DxcRadioGroup label="Label" options={single_option} defaultValue="A" error="Error message" />
199
+ </HalstackProvider>
200
+ </ExampleContainer>
201
+ <ExampleContainer pseudoState="pseudo-focus">
202
+ <Title title="Focused" theme="light" level={4} />
203
+ <HalstackProvider theme={opinionatedTheme}>
204
+ <DxcRadioGroup label="Label" options={single_option} defaultValue="A" error="Error message" />
205
+ </HalstackProvider>
206
+ </ExampleContainer>
207
+ <ExampleContainer>
208
+ <Title title="Disabled" theme="light" level={4} />
209
+ <HalstackProvider theme={opinionatedTheme}>
210
+ <DxcRadioGroup label="Label" helperText="Helper text" options={options} disabled defaultValue="A" />
211
+ </HalstackProvider>
54
212
  </ExampleContainer>
55
213
  </>
56
214
  );