@dxc-technology/halstack-react 0.0.0-b03a399 → 0.0.0-b0616f2

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 (183) hide show
  1. package/HalstackContext.d.ts +12 -0
  2. package/HalstackContext.js +295 -0
  3. package/accordion/Accordion.js +122 -103
  4. package/accordion/Accordion.stories.tsx +5 -6
  5. package/accordion/Accordion.test.js +9 -10
  6. package/accordion/types.d.ts +4 -4
  7. package/accordion-group/AccordionGroup.js +2 -21
  8. package/accordion-group/AccordionGroup.stories.tsx +27 -1
  9. package/accordion-group/AccordionGroup.test.js +20 -45
  10. package/accordion-group/types.d.ts +9 -3
  11. package/alert/Alert.js +5 -2
  12. package/badge/Badge.d.ts +1 -1
  13. package/badge/Badge.js +5 -3
  14. package/badge/types.d.ts +1 -0
  15. package/bleed/Bleed.js +1 -34
  16. package/bleed/Bleed.stories.tsx +94 -95
  17. package/bleed/types.d.ts +1 -1
  18. package/box/Box.js +23 -33
  19. package/bulleted-list/BulletedList.d.ts +7 -0
  20. package/bulleted-list/BulletedList.js +123 -0
  21. package/bulleted-list/BulletedList.stories.tsx +200 -0
  22. package/bulleted-list/types.d.ts +11 -0
  23. package/{list → bulleted-list}/types.js +0 -0
  24. package/button/Button.js +46 -62
  25. package/button/Button.stories.tsx +9 -0
  26. package/button/types.d.ts +7 -7
  27. package/card/Card.js +34 -36
  28. package/checkbox/Checkbox.js +89 -95
  29. package/checkbox/Checkbox.test.js +93 -16
  30. package/checkbox/types.d.ts +2 -2
  31. package/chip/types.d.ts +1 -1
  32. package/common/variables.js +232 -96
  33. package/date-input/DateInput.js +8 -5
  34. package/dialog/Dialog.js +52 -28
  35. package/dialog/Dialog.stories.tsx +1 -2
  36. package/dialog/Dialog.test.js +34 -4
  37. package/dialog/types.d.ts +2 -2
  38. package/dropdown/Dropdown.d.ts +1 -1
  39. package/dropdown/Dropdown.js +243 -247
  40. package/dropdown/Dropdown.stories.tsx +126 -63
  41. package/dropdown/Dropdown.test.js +510 -108
  42. package/dropdown/DropdownMenu.d.ts +4 -0
  43. package/dropdown/DropdownMenu.js +80 -0
  44. package/dropdown/DropdownMenuItem.d.ts +4 -0
  45. package/dropdown/DropdownMenuItem.js +92 -0
  46. package/dropdown/types.d.ts +25 -5
  47. package/file-input/FileInput.js +9 -6
  48. package/file-input/FileItem.js +7 -5
  49. package/flex/Flex.d.ts +4 -0
  50. package/flex/Flex.js +57 -0
  51. package/flex/Flex.stories.tsx +103 -0
  52. package/flex/types.d.ts +21 -0
  53. package/{radio → flex}/types.js +0 -0
  54. package/footer/Footer.js +7 -5
  55. package/footer/Footer.stories.tsx +8 -1
  56. package/footer/Icons.js +1 -1
  57. package/footer/types.d.ts +1 -1
  58. package/header/Header.js +80 -75
  59. package/header/Header.stories.tsx +4 -4
  60. package/header/Icons.js +2 -2
  61. package/header/types.d.ts +2 -2
  62. package/inset/Inset.js +1 -34
  63. package/inset/Inset.stories.tsx +36 -36
  64. package/inset/types.d.ts +1 -1
  65. package/layout/ApplicationLayout.d.ts +16 -6
  66. package/layout/ApplicationLayout.js +70 -117
  67. package/layout/ApplicationLayout.stories.tsx +84 -93
  68. package/layout/Icons.d.ts +5 -0
  69. package/layout/Icons.js +13 -2
  70. package/layout/SidenavContext.d.ts +5 -0
  71. package/layout/SidenavContext.js +19 -0
  72. package/layout/types.d.ts +18 -33
  73. package/link/Link.d.ts +3 -2
  74. package/link/Link.js +57 -70
  75. package/link/Link.stories.tsx +95 -53
  76. package/link/Link.test.js +7 -15
  77. package/link/types.d.ts +7 -23
  78. package/main.d.ts +7 -10
  79. package/main.js +43 -61
  80. package/number-input/types.d.ts +1 -1
  81. package/package.json +10 -8
  82. package/paginator/Paginator.js +17 -38
  83. package/paginator/Paginator.test.js +42 -0
  84. package/paragraph/Paragraph.d.ts +6 -0
  85. package/paragraph/Paragraph.js +38 -0
  86. package/paragraph/Paragraph.stories.tsx +44 -0
  87. package/password-input/PasswordInput.js +7 -4
  88. package/password-input/PasswordInput.test.js +1 -2
  89. package/password-input/types.d.ts +1 -1
  90. package/progress-bar/ProgressBar.d.ts +2 -2
  91. package/progress-bar/ProgressBar.js +57 -51
  92. package/progress-bar/ProgressBar.stories.jsx +13 -11
  93. package/progress-bar/ProgressBar.test.js +67 -22
  94. package/progress-bar/types.d.ts +3 -4
  95. package/quick-nav/QuickNav.js +74 -20
  96. package/quick-nav/QuickNav.stories.tsx +43 -16
  97. package/quick-nav/types.d.ts +4 -4
  98. package/radio-group/Radio.js +1 -1
  99. package/radio-group/RadioGroup.js +21 -20
  100. package/resultsetTable/ResultsetTable.test.js +42 -0
  101. package/select/Listbox.d.ts +1 -1
  102. package/select/Listbox.js +58 -8
  103. package/select/Select.js +78 -90
  104. package/select/Select.stories.tsx +145 -100
  105. package/select/Select.test.js +362 -244
  106. package/select/types.d.ts +2 -5
  107. package/sidenav/Sidenav.d.ts +6 -5
  108. package/sidenav/Sidenav.js +184 -52
  109. package/sidenav/Sidenav.stories.tsx +154 -156
  110. package/sidenav/Sidenav.test.js +25 -37
  111. package/sidenav/types.d.ts +50 -27
  112. package/slider/Slider.js +114 -93
  113. package/slider/Slider.stories.tsx +7 -1
  114. package/slider/Slider.test.js +121 -21
  115. package/slider/types.d.ts +2 -2
  116. package/spinner/Spinner.js +1 -1
  117. package/switch/Switch.d.ts +1 -1
  118. package/switch/Switch.js +114 -55
  119. package/switch/Switch.stories.tsx +8 -30
  120. package/switch/Switch.test.js +122 -8
  121. package/switch/types.d.ts +3 -4
  122. package/tabs/Tab.d.ts +4 -0
  123. package/tabs/Tab.js +135 -0
  124. package/tabs/Tabs.js +360 -104
  125. package/tabs/Tabs.stories.tsx +74 -6
  126. package/tabs/Tabs.test.js +217 -6
  127. package/tabs/types.d.ts +15 -5
  128. package/tabs-nav/NavTabs.d.ts +8 -0
  129. package/tabs-nav/NavTabs.js +125 -0
  130. package/tabs-nav/NavTabs.stories.tsx +170 -0
  131. package/tabs-nav/NavTabs.test.js +82 -0
  132. package/tabs-nav/Tab.d.ts +4 -0
  133. package/tabs-nav/Tab.js +130 -0
  134. package/tabs-nav/types.d.ts +53 -0
  135. package/{row → tabs-nav}/types.js +0 -0
  136. package/tag/Tag.js +1 -1
  137. package/tag/types.d.ts +1 -1
  138. package/text-input/Icons.d.ts +8 -0
  139. package/text-input/Icons.js +60 -0
  140. package/text-input/Suggestion.d.ts +4 -0
  141. package/text-input/Suggestion.js +57 -0
  142. package/text-input/Suggestions.d.ts +4 -0
  143. package/text-input/Suggestions.js +134 -0
  144. package/text-input/TextInput.js +140 -273
  145. package/text-input/TextInput.stories.tsx +189 -182
  146. package/text-input/TextInput.test.js +164 -163
  147. package/text-input/types.d.ts +28 -2
  148. package/textarea/Textarea.js +10 -19
  149. package/textarea/types.d.ts +1 -1
  150. package/toggle-group/types.d.ts +1 -1
  151. package/typography/Typography.d.ts +4 -0
  152. package/typography/Typography.js +131 -0
  153. package/typography/Typography.stories.tsx +198 -0
  154. package/typography/types.d.ts +18 -0
  155. package/{stack → typography}/types.js +0 -0
  156. package/useTheme.js +2 -2
  157. package/useTranslatedLabels.d.ts +2 -0
  158. package/useTranslatedLabels.js +20 -0
  159. package/wizard/Wizard.js +36 -41
  160. package/wizard/Wizard.stories.tsx +20 -1
  161. package/wizard/types.d.ts +5 -4
  162. package/ThemeContext.d.ts +0 -10
  163. package/ThemeContext.js +0 -243
  164. package/list/List.d.ts +0 -4
  165. package/list/List.js +0 -47
  166. package/list/List.stories.tsx +0 -95
  167. package/list/types.d.ts +0 -7
  168. package/radio/Radio.d.ts +0 -4
  169. package/radio/Radio.js +0 -173
  170. package/radio/Radio.stories.tsx +0 -192
  171. package/radio/Radio.test.js +0 -71
  172. package/radio/types.d.ts +0 -54
  173. package/row/Row.d.ts +0 -3
  174. package/row/Row.js +0 -127
  175. package/row/Row.stories.tsx +0 -237
  176. package/row/types.d.ts +0 -28
  177. package/stack/Stack.d.ts +0 -3
  178. package/stack/Stack.js +0 -97
  179. package/stack/Stack.stories.tsx +0 -164
  180. package/stack/types.d.ts +0 -24
  181. package/text/Text.d.ts +0 -7
  182. package/text/Text.js +0 -30
  183. package/text/Text.stories.tsx +0 -19
package/switch/Switch.js CHANGED
@@ -19,8 +19,6 @@ var _react = _interopRequireWildcard(require("react"));
19
19
 
20
20
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
21
21
 
22
- var _core = require("@material-ui/core");
23
-
24
22
  var _uuid = require("uuid");
25
23
 
26
24
  var _variables = require("../common/variables.js");
@@ -29,15 +27,19 @@ var _utils = require("../common/utils.js");
29
27
 
30
28
  var _useTheme = _interopRequireDefault(require("../useTheme"));
31
29
 
30
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
31
+
32
32
  var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext"));
33
33
 
34
- var _templateObject, _templateObject2;
34
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6;
35
35
 
36
36
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
37
37
 
38
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; }
39
39
 
40
40
  var DxcSwitch = function DxcSwitch(_ref) {
41
+ var _ref2;
42
+
41
43
  var defaultChecked = _ref.defaultChecked,
42
44
  checked = _ref.checked,
43
45
  value = _ref.value,
@@ -69,8 +71,32 @@ var DxcSwitch = function DxcSwitch(_ref) {
69
71
  innerChecked = _useState4[0],
70
72
  setInnerChecked = _useState4[1];
71
73
 
74
+ var _useState5 = (0, _react.useState)((_ref2 = label !== "" && label !== null && label !== undefined) !== null && _ref2 !== void 0 ? _ref2 : false),
75
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 1),
76
+ hasLabel = _useState6[0];
77
+
72
78
  var colorsTheme = (0, _useTheme["default"])();
79
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
73
80
  var backgroundType = (0, _react.useContext)(_BackgroundColorContext["default"]);
81
+ var refTrack = (0, _react.useRef)(null);
82
+
83
+ var handleOnKeyDown = function handleOnKeyDown(event) {
84
+ switch (event.key) {
85
+ case "Enter":
86
+ case " ":
87
+ //Space
88
+ event.preventDefault();
89
+ refTrack.current.focus();
90
+ var isChecked = !(checked !== null && checked !== void 0 ? checked : innerChecked);
91
+ setInnerChecked(isChecked);
92
+
93
+ if (typeof onChange === "function") {
94
+ onChange(isChecked);
95
+ }
96
+
97
+ break;
98
+ }
99
+ };
74
100
 
75
101
  var handlerSwitchChange = function handlerSwitchChange(event) {
76
102
  if (checked === undefined) {
@@ -78,40 +104,64 @@ var DxcSwitch = function DxcSwitch(_ref) {
78
104
 
79
105
  var isChecked = (_event$target$checked = event.target.checked) !== null && _event$target$checked !== void 0 ? _event$target$checked : !innerChecked;
80
106
  setInnerChecked(isChecked);
81
- onChange === null || onChange === void 0 ? void 0 : onChange(isChecked);
82
- } else onChange === null || onChange === void 0 ? void 0 : onChange(!checked);
83
- };
84
107
 
85
- var labelComponent = /*#__PURE__*/_react["default"].createElement(LabelContainer, {
86
- id: labelId,
87
- labelPosition: labelPosition,
88
- onClick: !disabled && handlerSwitchChange,
89
- disabled: disabled,
90
- backgroundType: backgroundType
91
- }, labelPosition === "before" ? /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, label, " ", optional && /*#__PURE__*/_react["default"].createElement("span", null, "(Optional)")) : /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, optional && /*#__PURE__*/_react["default"].createElement("span", null, "(Optional)"), " ", label));
108
+ if (typeof onChange === "function") {
109
+ onChange(isChecked);
110
+ }
111
+ } else {
112
+ if (typeof onChange === "function") {
113
+ onChange(!checked);
114
+ }
115
+ }
116
+ };
92
117
 
93
118
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
94
119
  theme: colorsTheme["switch"]
95
120
  }, /*#__PURE__*/_react["default"].createElement(SwitchContainer, {
96
121
  margin: margin,
122
+ size: size,
123
+ onKeyDown: handleOnKeyDown
124
+ }, labelPosition === "before" && hasLabel && /*#__PURE__*/_react["default"].createElement(LabelContainer, {
125
+ id: labelId,
126
+ labelPosition: labelPosition,
127
+ onClick: !disabled ? handlerSwitchChange : undefined,
97
128
  disabled: disabled,
129
+ backgroundType: backgroundType,
130
+ hasLabel: hasLabel
131
+ }, label, " ", optional && /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, translatedLabels.formFields.optionalLabel)), /*#__PURE__*/_react["default"].createElement(SwitchBase, {
98
132
  labelPosition: labelPosition,
99
- size: size,
100
- backgroundType: backgroundType
101
- }, labelPosition === "before" && labelComponent, /*#__PURE__*/_react["default"].createElement(_core.Switch, {
102
- checked: checked !== null && checked !== void 0 ? checked : innerChecked,
103
- inputProps: {
104
- name: name,
105
- "aria-labelledby": labelId,
106
- role: "switch",
107
- "aria-checked": checked !== null && checked !== void 0 ? checked : innerChecked,
108
- tabIndex: tabIndex
109
- },
110
- onChange: handlerSwitchChange,
133
+ hasLabel: hasLabel,
134
+ htmlFor: labelId,
135
+ onClick: disabled === true ? function () {} : handlerSwitchChange
136
+ }, /*#__PURE__*/_react["default"].createElement(SwitchInput, {
137
+ type: "checkbox",
138
+ role: "switch",
139
+ name: name,
140
+ id: labelId,
141
+ disabled: disabled,
111
142
  value: value,
143
+ "aria-labelledby": labelId,
144
+ "aria-label": hasLabel ? label : undefined,
145
+ "aria-checked": checked !== null && checked !== void 0 ? checked : innerChecked,
146
+ defaultChecked: defaultChecked !== null && defaultChecked !== void 0 ? defaultChecked : undefined,
147
+ tabIndex: -1
148
+ }), disabled ? /*#__PURE__*/_react["default"].createElement(DisabledSwitchTrack, {
149
+ backgroundType: backgroundType,
150
+ "data-checked": checked !== null && checked !== void 0 ? checked : innerChecked ? innerChecked : undefined,
151
+ tabIndex: -1
152
+ }) : /*#__PURE__*/_react["default"].createElement(SwitchTrack, {
153
+ backgroundType: backgroundType,
154
+ "data-checked": checked !== null && checked !== void 0 ? checked : innerChecked ? innerChecked : undefined,
155
+ tabIndex: tabIndex,
156
+ ref: refTrack
157
+ })), labelPosition === "after" && hasLabel && /*#__PURE__*/_react["default"].createElement(LabelContainer, {
158
+ id: labelId,
159
+ labelPosition: labelPosition,
160
+ onClick: !disabled ? handlerSwitchChange : undefined,
112
161
  disabled: disabled,
113
- disableRipple: true
114
- }), labelPosition === "after" && labelComponent));
162
+ backgroundType: backgroundType,
163
+ hasLabel: hasLabel
164
+ }, optional && /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, translatedLabels.formFields.optionalLabel), " ", label)));
115
165
  };
116
166
 
117
167
  var sizes = {
@@ -119,14 +169,14 @@ var sizes = {
119
169
  medium: "240px",
120
170
  large: "480px",
121
171
  fillParent: "100%",
122
- fitContent: "unset"
172
+ fitContent: "fit-content"
123
173
  };
124
174
 
125
175
  var calculateWidth = function calculateWidth(margin, size) {
126
176
  return size === "fillParent" ? "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")") : sizes[size];
127
177
  };
128
178
 
129
- var SwitchContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n display: inline-flex;\n align-items: center;\n\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n cursor: ", ";\n\n .MuiSwitch-root {\n align-items: center;\n width: ", ";\n height: 45px;\n margin: 3px;\n\n .Mui-focusVisible {\n outline: ", ";\n outline-offset: -3px;\n }\n\n .MuiSwitch-track {\n /*Enabled and unchecked bar*/\n background-color: ", ";\n height: ", ";\n }\n\n .MuiSwitch-switchBase + .MuiSwitch-track {\n opacity: 1;\n }\n\n .MuiIconButton-root {\n /*Enabled and unchecked*/\n top: unset;\n .MuiSwitch-thumb {\n /*Only for thumb in all states*/\n width: ", ";\n height: ", ";\n }\n color: ", ";\n &:hover {\n background-color: transparent;\n }\n &.Mui-disabled {\n /*Disabled and unchecked*/\n color: ", ";\n + .MuiSwitch-track {\n /*Disabled and unchecked bar*/\n background-color: ", ";\n }\n }\n &.Mui-disabled.Mui-checked {\n /*Disabled and checked*/\n color: ", ";\n + .MuiSwitch-track {\n /*Disabled and checked bar*/\n background-color: ", ";\n }\n }\n &.Mui-checked {\n /*Enabled and checked*/\n color: ", ";\n transform: translateX(", ");\n &:hover {\n background-color: transparent;\n }\n + .MuiSwitch-track {\n /*Enabled and checked bar*/\n background-color: ", ";\n }\n }\n }\n }\n"])), function (props) {
179
+ var SwitchContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n align-items: center;\n width: ", ";\n height: 40px;\n\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"])), function (props) {
130
180
  return calculateWidth(props.margin, props.size);
131
181
  }, function (props) {
132
182
  return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
@@ -138,16 +188,38 @@ var SwitchContainer = _styledComponents["default"].div(_templateObject || (_temp
138
188
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
139
189
  }, function (props) {
140
190
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
191
+ });
192
+
193
+ var LabelContainer = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n color: ", ";\n opacity: 1;\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n cursor: ", ";\n\n ", ";\n\n ", "\n"])), function (props) {
194
+ return props.disabled ? props.backgroundType === "dark" ? props.theme.disabledLabelFontColorOnDark : props.theme.disabledLabelFontColor : props.backgroundType === "dark" ? props.theme.labelFontColorOnDark : props.theme.labelFontColor;
141
195
  }, function (props) {
142
- return props.disabled ? "not-allowed" : "default";
196
+ return props.theme.labelFontFamily;
143
197
  }, function (props) {
144
- return props.theme.trackWidth;
198
+ return props.theme.labelFontSize;
145
199
  }, function (props) {
146
- return "".concat(props.backgroundType === "dark" ? props.theme.thumbFocusColorOnDark : props.theme.thumbFocusColor, " solid 2px");
200
+ return props.disabled ? props.theme.disabledLabelFontStyle : props.theme.labelFontStyle;
147
201
  }, function (props) {
148
- return props.backgroundType === "dark" ? props.theme.uncheckedTrackBackgroundColorOnDark : props.theme.uncheckedTrackBackgroundColor;
202
+ return props.theme.labelFontWeight;
203
+ }, function (props) {
204
+ return props.disabled === true ? "not-allowed" : "pointer";
205
+ }, function (props) {
206
+ return !props.hasLabel ? "margin: 0px;" : props.labelPosition === "after" ? "margin-left: ".concat(props.theme.spaceBetweenLabelSwitch, ";") : "margin-right: ".concat(props.theme.spaceBetweenLabelSwitch, ";");
207
+ }, function (props) {
208
+ return props.labelPosition === "before" && "order: -1";
209
+ });
210
+
211
+ var SwitchBase = _styledComponents["default"].label(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: space-between;\n cursor: pointer;\n margin: ", ";\n"])), function (props) {
212
+ return !props.hasLabel ? "0px 4px" : props.labelPosition === "before" ? "0 4px 0 12px" : "0 12px 0 4px";
213
+ });
214
+
215
+ var SwitchInput = _styledComponents["default"].input(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n opacity: 0;\n width: 0;\n height: 0;\n margin: 0px;\n"])));
216
+
217
+ var SwitchTrack = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n border-radius: 15px;\n width: ", ";\n height: ", ";\n position: relative;\n transition: transform 0.2s ease;\n\n &:focus-visible {\n outline: none;\n ::before {\n outline: ", ";\n outline-offset: 6px;\n }\n }\n\n /* Thumb element */\n ::before {\n content: \"\";\n transform: initial;\n transition: transform 0.2s ease;\n position: absolute;\n width: ", ";\n height: ", ";\n border-radius: 50%;\n z-index: 1;\n box-shadow: 0px 2px 1px -1px rgb(0 0 0 / 20%), 0px 1px 1px 0px rgb(0 0 0 / 14%), 0px 1px 3px 0px rgb(0 0 0 / 12%);\n bottom: -6px;\n left: -4px;\n transform: translateX(0px);\n background-color: ", ";\n }\n\n /* Unchecked */\n background-color: ", ";\n\n /* Checked */\n &[data-checked=\"true\"] {\n background-color: ", ";\n ::before {\n transform: translateX(", ");\n background-color: ", ";\n }\n }\n"])), function (props) {
218
+ return props.theme.trackWidth;
149
219
  }, function (props) {
150
220
  return props.theme.trackHeight;
221
+ }, function (props) {
222
+ return "".concat(props.backgroundType === "dark" ? props.theme.thumbFocusColorOnDark : props.theme.thumbFocusColor, " solid 2px");
151
223
  }, function (props) {
152
224
  return props.theme.thumbWidth;
153
225
  }, function (props) {
@@ -155,38 +227,25 @@ var SwitchContainer = _styledComponents["default"].div(_templateObject || (_temp
155
227
  }, function (props) {
156
228
  return props.backgroundType === "dark" ? props.theme.uncheckedThumbBackgroundColorOnDark : props.theme.uncheckedThumbBackgroundColor;
157
229
  }, function (props) {
158
- return props.backgroundType === "dark" ? props.theme.disabledUncheckedThumbBackgroundColorOnDark : props.theme.disabledUncheckedThumbBackgroundColor;
159
- }, function (props) {
160
- return props.backgroundType === "dark" ? props.theme.disabledUncheckedTrackBackgroundColorOnDark : props.theme.disabledUncheckedTrackBackgroundColor;
161
- }, function (props) {
162
- return props.backgroundType === "dark" ? props.theme.disabledCheckedThumbBackgroundColorOnDark : props.theme.disabledCheckedThumbBackgroundColor;
163
- }, function (props) {
164
- return props.backgroundType === "dark" ? props.theme.disabledCheckedTrackBackgroundColorOnDark : props.theme.disabledCheckedTrackBackgroundColor;
230
+ return props.backgroundType === "dark" ? props.theme.uncheckedTrackBackgroundColorOnDark : props.theme.uncheckedTrackBackgroundColor;
165
231
  }, function (props) {
166
- return props.backgroundType === "dark" ? props.theme.checkedThumbBackgroundColorOnDark : props.theme.checkedThumbBackgroundColor;
232
+ return props.backgroundType === "dark" ? props.theme.checkedTrackBackgroundColorOnDark : props.theme.checkedTrackBackgroundColor;
167
233
  }, function (props) {
168
234
  return props.theme.thumbShift;
169
235
  }, function (props) {
170
- return props.backgroundType === "dark" ? props.theme.checkedTrackBackgroundColorOnDark : props.theme.checkedTrackBackgroundColor;
236
+ return props.backgroundType === "dark" ? props.theme.checkedThumbBackgroundColorOnDark : props.theme.checkedThumbBackgroundColor;
171
237
  });
172
238
 
173
- var LabelContainer = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n color: ", ";\n opacity: 1;\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n cursor: ", ";\n ", "\n\n ", "\n"])), function (props) {
174
- return props.disabled ? props.backgroundType === "dark" ? props.theme.disabledLabelFontColorOnDark : props.theme.disabledLabelFontColor : props.backgroundType === "dark" ? props.theme.labelFontColorOnDark : props.theme.labelFontColor;
175
- }, function (props) {
176
- return props.theme.labelFontFamily;
177
- }, function (props) {
178
- return props.theme.labelFontSize;
179
- }, function (props) {
180
- return props.disabled ? props.theme.disabledLabelFontStyle : props.theme.labelFontStyle;
239
+ var DisabledSwitchTrack = (0, _styledComponents["default"])(SwitchTrack)(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n cursor: not-allowed;\n\n /* Unchecked */\n background-color: ", ";\n\n ::before {\n background-color: ", ";\n }\n\n /* Checked */\n &[data-checked=\"true\"] {\n background-color: ", ";\n\n ::before {\n transform: translateX(", ");\n background-color: ", ";\n }\n }\n"])), function (props) {
240
+ return props.backgroundType === "dark" ? props.theme.disabledUncheckedTrackBackgroundColorOnDark : props.theme.disabledUncheckedTrackBackgroundColor;
181
241
  }, function (props) {
182
- return props.theme.labelFontWeight;
242
+ return props.backgroundType === "dark" ? props.theme.disabledUncheckedThumbBackgroundColorOnDark : props.theme.disabledUncheckedThumbBackgroundColor;
183
243
  }, function (props) {
184
- return props.disabled === true ? "not-allowed" : "pointer";
244
+ return props.backgroundType === "dark" ? props.theme.disabledCheckedTrackBackgroundColorOnDark : props.theme.disabledCheckedTrackBackgroundColor;
185
245
  }, function (props) {
186
- return props.labelPosition === "after" ? "margin-left: ".concat(props.theme.spaceBetweenLabelSwitch, ";") : "margin-right: ".concat(props.theme.spaceBetweenLabelSwitch, ";");
246
+ return props.theme.thumbShift;
187
247
  }, function (props) {
188
- return props.labelPosition === "before" && "order: -1";
248
+ return props.backgroundType === "dark" ? props.theme.disabledCheckedThumbBackgroundColorOnDark : props.theme.disabledCheckedThumbBackgroundColor;
189
249
  });
190
-
191
250
  var _default = DxcSwitch;
192
251
  exports["default"] = _default;
@@ -1,5 +1,4 @@
1
1
  import React from "react";
2
- import { userEvent, within } from "@storybook/testing-library";
3
2
  import DxcSwitch from "./Switch";
4
3
  import { BackgroundColorProvider } from "../BackgroundColorContext";
5
4
  import Title from "../../.storybook/components/Title";
@@ -21,6 +20,10 @@ export const Chromatic = () => (
21
20
  <Title title="Without label" theme="light" level={4} />
22
21
  <DxcSwitch />
23
22
  </ExampleContainer>
23
+ <ExampleContainer pseudoState="pseudo-focus-visible">
24
+ <Title title="Focused" theme="light" level={4} />
25
+ <DxcSwitch label="Switch" labelPosition="after" />
26
+ </ExampleContainer>
24
27
  <ExampleContainer>
25
28
  <Title title="Checked" theme="light" level={4} />
26
29
  <DxcSwitch label="Switch" defaultChecked />
@@ -47,6 +50,10 @@ export const Chromatic = () => (
47
50
  <Title title="With label" theme="dark" level={4} />
48
51
  <DxcSwitch label="Switch" />
49
52
  </ExampleContainer>
53
+ <ExampleContainer pseudoState="pseudo-focus-visible">
54
+ <Title title="Focused" theme="dark" level={4} />
55
+ <DxcSwitch label="Switch" labelPosition="after" />
56
+ </ExampleContainer>
50
57
  <ExampleContainer>
51
58
  <Title title="Checked" theme="dark" level={4} />
52
59
  <DxcSwitch label="Switch" defaultChecked />
@@ -129,32 +136,3 @@ export const Chromatic = () => (
129
136
  </ExampleContainer>
130
137
  </>
131
138
  );
132
-
133
- const Switch = () => (
134
- <ExampleContainer>
135
- <Title title="Focused" theme="light" level={4} />
136
- <DxcSwitch label="Switch" />
137
- </ExampleContainer>
138
- );
139
- export const FocusedSwitch = Switch.bind({});
140
- FocusedSwitch.play = async ({ canvasElement }) => {
141
- const canvas = within(canvasElement);
142
- canvas.getByRole("switch").focus();
143
- };
144
-
145
- const DarkSwitch = () => (
146
- <BackgroundColorProvider color="#333333">
147
- <DarkContainer>
148
- <ExampleContainer>
149
- <Title title="Focused" theme="dark" level={4} />
150
- <DxcSwitch label="Switch" />
151
- </ExampleContainer>
152
- </DarkContainer>
153
- </BackgroundColorProvider>
154
- );
155
-
156
- export const FocusedSwitchOnDark = DarkSwitch.bind({});
157
- FocusedSwitchOnDark.play = async ({ canvasElement }) => {
158
- const canvas = within(canvasElement);
159
- canvas.getByRole("switch").focus();
160
- };
@@ -37,7 +37,7 @@ describe("Switch component tests", function () {
37
37
 
38
38
  expect(onChange).toHaveBeenCalled();
39
39
  });
40
- test("Everytime the user clicks the component the onchange function is called with the correct value CONTROLLED COMPONENT", function () {
40
+ test("Calls correct function on key down", function () {
41
41
  var onChange = jest.fn();
42
42
 
43
43
  var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
@@ -47,6 +47,30 @@ describe("Switch component tests", function () {
47
47
  })),
48
48
  getByText = _render3.getByText;
49
49
 
50
+ _react2.fireEvent.focus(getByText("SwitchComponent"));
51
+
52
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
53
+ key: "Enter"
54
+ });
55
+
56
+ expect(onChange).toHaveBeenCalled();
57
+
58
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
59
+ key: " "
60
+ });
61
+
62
+ expect(onChange).toHaveBeenCalled();
63
+ });
64
+ test("Everytime the user clicks the component the onchange function is called with the correct value CONTROLLED COMPONENT", function () {
65
+ var onChange = jest.fn();
66
+
67
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
68
+ label: "SwitchComponent",
69
+ checked: false,
70
+ onChange: onChange
71
+ })),
72
+ getByText = _render4.getByText;
73
+
50
74
  _react2.fireEvent.click(getByText("SwitchComponent"));
51
75
 
52
76
  _react2.fireEvent.click(getByText("SwitchComponent"));
@@ -54,14 +78,60 @@ describe("Switch component tests", function () {
54
78
  expect(onChange.mock.calls[0][0]).toBe(true);
55
79
  expect(onChange.mock.calls[1][0]).toBe(true);
56
80
  });
81
+ test("Everytime the user use enter in the component, the onchange function is called with the correct value CONTROLLED COMPONENT", function () {
82
+ var onChange = jest.fn();
83
+
84
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
85
+ label: "SwitchComponent",
86
+ checked: false,
87
+ onChange: onChange
88
+ })),
89
+ getByText = _render5.getByText;
90
+
91
+ _react2.fireEvent.focus(getByText("SwitchComponent"));
92
+
93
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
94
+ key: "Enter"
95
+ });
96
+
97
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
98
+ key: "Enter"
99
+ });
100
+
101
+ expect(onChange.mock.calls[0][0]).toBe(true);
102
+ expect(onChange.mock.calls[1][0]).toBe(true);
103
+ });
104
+ test("Everytime the user use space in the component, the onchange function is called with the correct value CONTROLLED COMPONENT", function () {
105
+ var onChange = jest.fn();
106
+
107
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
108
+ label: "SwitchComponent",
109
+ checked: false,
110
+ onChange: onChange
111
+ })),
112
+ getByText = _render6.getByText;
113
+
114
+ _react2.fireEvent.focus(getByText("SwitchComponent"));
115
+
116
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
117
+ key: " "
118
+ });
119
+
120
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
121
+ key: " "
122
+ });
123
+
124
+ expect(onChange.mock.calls[0][0]).toBe(true);
125
+ expect(onChange.mock.calls[1][0]).toBe(true);
126
+ });
57
127
  test("Everytime the user clicks the component the onchange function is called with the correct value UNCONTROLLED COMPONENT", function () {
58
128
  var onChange = jest.fn();
59
129
 
60
- var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
130
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
61
131
  label: "SwitchComponent",
62
132
  onChange: onChange
63
133
  })),
64
- getByText = _render4.getByText;
134
+ getByText = _render7.getByText;
65
135
 
66
136
  _react2.fireEvent.click(getByText("SwitchComponent"));
67
137
 
@@ -70,13 +140,57 @@ describe("Switch component tests", function () {
70
140
  expect(onChange.mock.calls[0][0]).toBe(true);
71
141
  expect(onChange.mock.calls[1][0]).toBe(false);
72
142
  });
143
+ test("Everytime the user use enter in the component, the onchange function is called with the correct value UNCONTROLLED COMPONENT", function () {
144
+ var onChange = jest.fn();
145
+
146
+ var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
147
+ label: "SwitchComponent",
148
+ onChange: onChange
149
+ })),
150
+ getByText = _render8.getByText;
151
+
152
+ _react2.fireEvent.focus(getByText("SwitchComponent"));
153
+
154
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
155
+ key: "Enter"
156
+ });
157
+
158
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
159
+ key: "Enter"
160
+ });
161
+
162
+ expect(onChange.mock.calls[0][0]).toBe(true);
163
+ expect(onChange.mock.calls[1][0]).toBe(false);
164
+ });
165
+ test("Everytime the user use space in the component, the onchange function is called with the correct value UNCONTROLLED COMPONENT", function () {
166
+ var onChange = jest.fn();
167
+
168
+ var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
169
+ label: "SwitchComponent",
170
+ onChange: onChange
171
+ })),
172
+ getByText = _render9.getByText;
173
+
174
+ _react2.fireEvent.focus(getByText("SwitchComponent"));
175
+
176
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
177
+ key: " "
178
+ });
179
+
180
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
181
+ key: " "
182
+ });
183
+
184
+ expect(onChange.mock.calls[0][0]).toBe(true);
185
+ expect(onChange.mock.calls[1][0]).toBe(false);
186
+ });
73
187
  test("Renders with correct initial value and initial state when it is uncontrolled", function () {
74
- var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
188
+ var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
75
189
  label: "Default label",
76
190
  defaultChecked: true,
77
191
  value: "test-defaultChecked"
78
192
  })),
79
- getByRole = _render5.getByRole;
193
+ getByRole = _render10.getByRole;
80
194
 
81
195
  var inputEl = getByRole("switch");
82
196
  expect(inputEl.checked).toBe(true);
@@ -84,11 +198,11 @@ describe("Switch component tests", function () {
84
198
  expect(inputEl.getAttribute("aria-checked")).toBe("true");
85
199
  });
86
200
  test("Renders with correct aria attributes", function () {
87
- var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
201
+ var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
88
202
  label: "Default label"
89
203
  })),
90
- getByRole = _render6.getByRole,
91
- getByText = _render6.getByText;
204
+ getByRole = _render11.getByRole,
205
+ getByText = _render11.getByText;
92
206
 
93
207
  var inputEl = getByRole("switch");
94
208
  var label = getByText("Default label");
package/switch/types.d.ts CHANGED
@@ -1,11 +1,11 @@
1
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
- declare type Margin = {
1
+ export declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
+ export declare type Margin = {
3
3
  top?: Space;
4
4
  bottom?: Space;
5
5
  left?: Space;
6
6
  right?: Space;
7
7
  };
8
- declare type Props = {
8
+ export declare type SwitchPropsType = {
9
9
  /**
10
10
  * Initial state of the switch, only when it is uncontrolled.
11
11
  */
@@ -59,4 +59,3 @@ declare type Props = {
59
59
  */
60
60
  tabIndex?: number;
61
61
  };
62
- export default Props;
package/tabs/Tab.d.ts ADDED
@@ -0,0 +1,4 @@
1
+ import React from "react";
2
+ import { TabProps } from "./types";
3
+ declare const _default: React.MemoExoticComponent<React.ForwardRefExoticComponent<TabProps & React.RefAttributes<HTMLButtonElement>>>;
4
+ export default _default;