@dxc-technology/halstack-react 6.1.0 → 6.2.0

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 (41) hide show
  1. package/accordion/Accordion.js +122 -103
  2. package/accordion/Accordion.stories.tsx +1 -2
  3. package/accordion/Accordion.test.js +9 -10
  4. package/accordion/types.d.ts +3 -3
  5. package/accordion-group/AccordionGroup.js +1 -21
  6. package/accordion-group/AccordionGroup.stories.tsx +27 -1
  7. package/accordion-group/AccordionGroup.test.js +20 -45
  8. package/accordion-group/types.d.ts +8 -2
  9. package/alert/Alert.js +1 -1
  10. package/box/Box.js +1 -1
  11. package/checkbox/Checkbox.js +88 -95
  12. package/checkbox/Checkbox.test.js +93 -16
  13. package/checkbox/types.d.ts +2 -2
  14. package/common/variables.js +8 -4
  15. package/dropdown/Dropdown.js +1 -1
  16. package/footer/Footer.stories.tsx +8 -1
  17. package/header/Header.stories.tsx +4 -4
  18. package/layout/ApplicationLayout.stories.tsx +1 -0
  19. package/package.json +8 -8
  20. package/select/Listbox.js +0 -1
  21. package/slider/Slider.js +112 -91
  22. package/slider/Slider.stories.tsx +7 -1
  23. package/slider/Slider.test.js +87 -24
  24. package/slider/types.d.ts +2 -2
  25. package/switch/Switch.js +1 -1
  26. package/tabs/Tab.d.ts +4 -0
  27. package/tabs/Tab.js +135 -0
  28. package/tabs/Tabs.js +360 -104
  29. package/tabs/Tabs.stories.tsx +74 -0
  30. package/tabs/Tabs.test.js +217 -6
  31. package/tabs/types.d.ts +14 -4
  32. package/tag/Tag.js +1 -1
  33. package/text-input/Icons.d.ts +8 -0
  34. package/text-input/Icons.js +60 -0
  35. package/text-input/Suggestion.js +7 -5
  36. package/text-input/Suggestions.d.ts +4 -0
  37. package/text-input/Suggestions.js +134 -0
  38. package/text-input/TextInput.js +103 -201
  39. package/text-input/TextInput.stories.tsx +189 -181
  40. package/text-input/TextInput.test.js +163 -162
  41. package/text-input/types.d.ts +16 -2
@@ -19,14 +19,6 @@ var _react = _interopRequireWildcard(require("react"));
19
19
 
20
20
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
21
21
 
22
- var _ExpansionPanel = _interopRequireDefault(require("@material-ui/core/ExpansionPanel"));
23
-
24
- var _ExpansionPanelSummary = _interopRequireDefault(require("@material-ui/core/ExpansionPanelSummary"));
25
-
26
- var _ExpansionPanelDetails = _interopRequireDefault(require("@material-ui/core/ExpansionPanelDetails"));
27
-
28
- var _ExpandMore = _interopRequireDefault(require("@material-ui/icons/ExpandMore"));
29
-
30
22
  var _utils = require("../common/utils.js");
31
23
 
32
24
  var _variables = require("../common/variables.js");
@@ -35,12 +27,34 @@ var _useTheme = _interopRequireDefault(require("../useTheme"));
35
27
 
36
28
  var _BackgroundColorContext = require("../BackgroundColorContext");
37
29
 
38
- var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7;
30
+ var _Typography = _interopRequireDefault(require("../typography/Typography"));
31
+
32
+ var _uuid = require("uuid");
33
+
34
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10;
39
35
 
40
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); }
41
37
 
42
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; }
43
39
 
40
+ var expandLess = /*#__PURE__*/_react["default"].createElement("svg", {
41
+ xmlns: "http://www.w3.org/2000/svg",
42
+ height: "24",
43
+ width: "24",
44
+ fill: "currentColor"
45
+ }, /*#__PURE__*/_react["default"].createElement("path", {
46
+ d: "m7.4 15.375-1.4-1.4 6-6 6 6-1.4 1.4-4.6-4.6Z"
47
+ }));
48
+
49
+ var expandMore = /*#__PURE__*/_react["default"].createElement("svg", {
50
+ xmlns: "http://www.w3.org/2000/svg",
51
+ height: "24",
52
+ width: "24",
53
+ fill: "currentColor"
54
+ }, /*#__PURE__*/_react["default"].createElement("path", {
55
+ d: "m12 15.375-6-6 1.4-1.4 4.6 4.6 4.6-4.6 1.4 1.4Z"
56
+ }));
57
+
44
58
  var DxcAccordion = function DxcAccordion(_ref) {
45
59
  var _ref$label = _ref.label,
46
60
  label = _ref$label === void 0 ? "" : _ref$label,
@@ -58,57 +72,88 @@ var DxcAccordion = function DxcAccordion(_ref) {
58
72
  _ref$tabIndex = _ref.tabIndex,
59
73
  tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
60
74
 
61
- var _useState = (0, _react.useState)(defaultIsExpanded !== null && defaultIsExpanded !== void 0 ? defaultIsExpanded : false),
62
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
63
- innerIsExpanded = _useState2[0],
64
- setInnerIsExpanded = _useState2[1];
75
+ var _useState = (0, _react.useState)((0, _uuid.v4)()),
76
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
77
+ id = _useState2[0];
78
+
79
+ var _useState3 = (0, _react.useState)(defaultIsExpanded !== null && defaultIsExpanded !== void 0 ? defaultIsExpanded : false),
80
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
81
+ innerIsExpanded = _useState4[0],
82
+ setInnerIsExpanded = _useState4[1];
65
83
 
66
84
  var colorsTheme = (0, _useTheme["default"])();
67
85
 
68
- var handlerAccordion = function handlerAccordion() {
69
- if (isExpanded == null) {
70
- setInnerIsExpanded(!innerIsExpanded);
71
- }
86
+ var handleAccordionState = function handleAccordionState() {
87
+ var _isExpanded;
72
88
 
73
- if (typeof onChange === "function") {
74
- onChange(isExpanded == null ? !innerIsExpanded : !isExpanded);
75
- }
89
+ isExpanded !== null && isExpanded !== void 0 ? isExpanded : setInnerIsExpanded(function (innerIsExpanded) {
90
+ return !innerIsExpanded;
91
+ });
92
+ onChange === null || onChange === void 0 ? void 0 : onChange((_isExpanded = !isExpanded) !== null && _isExpanded !== void 0 ? _isExpanded : !innerIsExpanded);
76
93
  };
77
94
 
78
95
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
79
96
  theme: colorsTheme.accordion
80
- }, /*#__PURE__*/_react["default"].createElement(DXCAccordion, {
97
+ }, /*#__PURE__*/_react["default"].createElement(AccordionContainer, {
98
+ isExpanded: isExpanded !== null && isExpanded !== void 0 ? isExpanded : innerIsExpanded,
81
99
  padding: padding,
82
- margin: margin,
83
- disabled: disabled,
84
- icon: icon
85
- }, /*#__PURE__*/_react["default"].createElement(_ExpansionPanel["default"], {
100
+ margin: margin
101
+ }, /*#__PURE__*/_react["default"].createElement(AccordionHeader, null, /*#__PURE__*/_react["default"].createElement(AccordionTrigger, {
102
+ id: "accordion-".concat(id),
103
+ onClick: disabled ? undefined : handleAccordionState,
86
104
  disabled: disabled,
87
- onChange: handlerAccordion,
88
- expanded: isExpanded != null ? isExpanded : innerIsExpanded
89
- }, /*#__PURE__*/_react["default"].createElement(_ExpansionPanelSummary["default"], {
90
- expandIcon: /*#__PURE__*/_react["default"].createElement(_ExpandMore["default"], null),
91
- tabIndex: disabled ? -1 : tabIndex
105
+ tabIndex: disabled ? -1 : tabIndex,
106
+ "aria-expanded": isExpanded !== null && isExpanded !== void 0 ? isExpanded : innerIsExpanded,
107
+ "aria-controls": "accordion-panel-".concat(id),
108
+ isExpanded: isExpanded !== null && isExpanded !== void 0 ? isExpanded : innerIsExpanded
92
109
  }, /*#__PURE__*/_react["default"].createElement(AccordionInfo, {
93
110
  disabled: disabled
94
- }, icon && /*#__PURE__*/_react["default"].createElement(IconContainer, {
111
+ }, /*#__PURE__*/_react["default"].createElement(AccordionLabel, null, icon && /*#__PURE__*/_react["default"].createElement(IconContainer, {
95
112
  disabled: disabled
96
- }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(AccordionIcon, {
113
+ }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(IconImg, {
97
114
  src: icon
98
- }) : icon), /*#__PURE__*/_react["default"].createElement(AccordionLabel, null, label)), assistiveText && /*#__PURE__*/_react["default"].createElement(AccordionAssistiveText, {
115
+ }) : icon), /*#__PURE__*/_react["default"].createElement(_Typography["default"], {
116
+ color: disabled ? colorsTheme.accordion.disabledTitleLabelFontColor : colorsTheme.accordion.titleLabelFontColor,
117
+ fontFamily: colorsTheme.accordion.titleLabelFontFamily,
118
+ fontSize: colorsTheme.accordion.titleLabelFontSize,
119
+ fontStyle: colorsTheme.accordion.titleLabelFontStyle,
120
+ fontWeight: colorsTheme.accordion.titleLabelFontWeight,
121
+ lineHeight: "1.5em"
122
+ }, label)), assistiveText && /*#__PURE__*/_react["default"].createElement(AccordionAssistiveText, {
99
123
  disabled: disabled
100
- }, assistiveText)), /*#__PURE__*/_react["default"].createElement(_ExpansionPanelDetails["default"], null, /*#__PURE__*/_react["default"].createElement(AccordionContent, {
124
+ }, /*#__PURE__*/_react["default"].createElement(_Typography["default"], {
125
+ color: disabled ? colorsTheme.accordion.disabledAssistiveTextFontColor : colorsTheme.accordion.assistiveTextFontColor,
126
+ fontFamily: colorsTheme.accordion.assistiveTextFontFamily,
127
+ fontSize: colorsTheme.accordion.assistiveTextFontSize,
128
+ fontStyle: colorsTheme.accordion.assistiveTextFontStyle,
129
+ fontWeight: colorsTheme.accordion.assistiveTextFontWeight,
130
+ letterSpacing: colorsTheme.accordion.assistiveTextLetterSpacing,
131
+ lineHeight: "1.5em"
132
+ }, assistiveText))), /*#__PURE__*/_react["default"].createElement(CollapseIndicator, {
101
133
  disabled: disabled
134
+ }, (isExpanded !== null && isExpanded !== void 0 ? isExpanded : innerIsExpanded) ? expandLess : expandMore))), (isExpanded !== null && isExpanded !== void 0 ? isExpanded : innerIsExpanded) && /*#__PURE__*/_react["default"].createElement(AccordionPanel, {
135
+ id: "accordion-panel-".concat(id),
136
+ role: "region",
137
+ "aria-labelledby": "accordion-".concat(id),
138
+ padding: padding
102
139
  }, /*#__PURE__*/_react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
103
140
  color: colorsTheme.accordion.backgroundColor
104
- }, children))))));
141
+ }, children))));
105
142
  };
106
143
 
107
144
  var calculateWidth = function calculateWidth(margin) {
108
145
  return "calc(100% - ".concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
109
146
  };
110
147
 
111
- var DXCAccordion = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n min-width: 280px;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n width: ", ";\n cursor: ", ";\n\n .MuiPaper-root {\n min-width: 0;\n display: flex;\n left: 85px;\n background-color: ", " !important;\n box-shadow: ", ";\n position: static;\n width: 100%;\n border-radius: ", ";\n\n &.Mui-expanded {\n border-radius: ", ";\n }\n &.MuiExpansionPanel-root {\n display: flex;\n flex-direction: column;\n min-height: 48px;\n }\n &.MuiExpansionPanel-rounded {\n border-radius: ", ";\n }\n .MuiButtonBase-root.MuiExpansionPanelSummary-root {\n min-height: 48px;\n height: 48px;\n\n :focus {\n outline-color: ", ";\n outline-style: ", ";\n outline-width: ", ";\n background-color: ", ";\n }\n :hover {\n background-color: ", ";\n }\n :active {\n background-color: ", ";\n }\n &.Mui-disabled {\n opacity: 1;\n }\n }\n .MuiButtonBase-root {\n border-radius: ", ";\n\n &.Mui-expanded {\n border-bottom-right-radius: 0;\n border-bottom-left-radius: 0;\n .MuiSvgIcon-root {\n opacity: 1;\n }\n }\n &.MuiIconButton-root {\n height: auto;\n }\n .MuiExpansionPanelSummary-content {\n padding-top: ", ";\n padding-bottom: ", ";\n padding-right: ", ";\n padding-left: ", ";\n min-width: 0;\n &.Mui-expanded {\n div:nth-child(2) {\n opacity: 1;\n }\n }\n :hover {\n div {\n opacity: 1;\n }\n }\n }\n }\n .MuiTouchRipple-root {\n display: none;\n }\n }\n .MuiCollapse-hidden {\n display: none;\n }\n .MuiCollapse-container {\n border-radius: 0px 0px 4px 4px;\n cursor: default;\n width: 100%;\n }\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n color: ", ";\n }\n }\n .MuiExpansionPanelDetails-root {\n padding: ", ";\n padding-top: ", ";\n padding-right: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n }\n"])), function (props) {
148
+ var AccordionContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n background-color: ", ";\n border-radius: ", ";\n ", "\n box-shadow: ", ";\n min-width: 280px;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n width: ", ";\n"])), function (props) {
149
+ return props.theme.backgroundColor;
150
+ }, function (props) {
151
+ return props.theme.borderRadius;
152
+ }, function (props) {
153
+ return props.isExpanded && "border-bottom-left-radius: 0; border-bottom-right-radius: 0;";
154
+ }, function (props) {
155
+ return "".concat(props.theme.boxShadowOffsetX, " ").concat(props.theme.boxShadowOffsetY, " ").concat(props.theme.boxShadowBlur, " ").concat(props.theme.boxShadowColor);
156
+ }, function (props) {
112
157
  return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
113
158
  }, function (props) {
114
159
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
@@ -120,33 +165,27 @@ var DXCAccordion = _styledComponents["default"].div(_templateObject || (_templat
120
165
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
121
166
  }, function (props) {
122
167
  return calculateWidth(props.margin);
123
- }, function (props) {
124
- return props.disabled && "not-allowed" || "pointer";
125
- }, function (props) {
126
- return props.theme.backgroundColor;
127
- }, function (props) {
128
- return "".concat(props.theme.boxShadowOffsetX, " ").concat(props.theme.boxShadowOffsetY, " ").concat(props.theme.boxShadowBlur, " ").concat(props.theme.boxShadowColor);
129
- }, function (props) {
130
- return props.theme.borderRadius;
131
- }, function (props) {
132
- return props.theme.borderRadius;
133
- }, function (props) {
168
+ });
169
+
170
+ var AccordionHeader = _styledComponents["default"].h3(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n min-height: 48px;\n margin: 0;\n"])));
171
+
172
+ var AccordionTrigger = _styledComponents["default"].button(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n align-items: center;\n gap: 24px;\n width: 100%;\n background-color: transparent;\n border: none;\n border-radius: ", ";\n ", "\n padding: 12px 16px;\n cursor: ", ";\n\n :focus {\n outline: ", ";\n }\n :hover:enabled {\n background-color: ", ";\n }\n :active:enabled {\n background-color: ", ";\n }\n"])), function (props) {
134
173
  return props.theme.borderRadius;
135
174
  }, function (props) {
136
- return props.theme.focusBorderColor;
175
+ return props.isExpanded && "border-bottom-left-radius: 0; border-bottom-right-radius: 0;";
137
176
  }, function (props) {
138
- return props.theme.focusBorderStyle;
177
+ return props.disabled ? "not-allowed" : "pointer";
139
178
  }, function (props) {
140
- return props.theme.focusBorderThickness;
141
- }, function (props) {
142
- return props.theme.backgroundColor;
179
+ return "".concat(props.theme.focusBorderColor, " ").concat(props.theme.focusBorderStyle, " ").concat(props.theme.focusBorderThickness);
143
180
  }, function (props) {
144
181
  return "".concat(props.theme.hoverBackgroundColor);
145
182
  }, function (props) {
146
183
  return "".concat(props.theme.hoverBackgroundColor);
147
- }, function (props) {
148
- return props.theme.borderRadius;
149
- }, function (props) {
184
+ });
185
+
186
+ var AccordionInfo = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n justify-content: space-between;\n width: 100%;\n"])));
187
+
188
+ var AccordionLabel = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n padding-top: ", ";\n padding-bottom: ", ";\n padding-right: ", ";\n padding-left: ", ";\n"])), function (props) {
150
189
  return props.theme.titleLabelPaddingTop;
151
190
  }, function (props) {
152
191
  return props.theme.titleLabelPaddingBottom;
@@ -154,73 +193,53 @@ var DXCAccordion = _styledComponents["default"].div(_templateObject || (_templat
154
193
  return props.theme.titleLabelPaddingRight;
155
194
  }, function (props) {
156
195
  return props.theme.titleLabelPaddingLeft;
157
- }, function (props) {
158
- return props.disabled ? props.theme.disabledArrowColor : props.theme.arrowColor;
159
- }, function (props) {
160
- return props.padding && (0, _typeof2["default"])(props.padding) !== "object" ? _variables.spaces[props.padding] : "0px";
161
- }, function (props) {
162
- return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.top ? _variables.spaces[props.padding.top] : "";
163
- }, function (props) {
164
- return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.right ? _variables.spaces[props.padding.right] : "";
165
- }, function (props) {
166
- return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.bottom ? _variables.spaces[props.padding.bottom] : "";
167
- }, function (props) {
168
- return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.left ? _variables.spaces[props.padding.left] : "";
169
196
  });
170
197
 
171
- var AccordionInfo = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n padding-left: ", ";\n padding-right: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n"])), function (props) {
172
- return props.theme.titlePaddingLeft;
173
- }, function (props) {
174
- return props.theme.titlePaddingRight;
175
- }, function (props) {
176
- return props.theme.titleLabelFontFamily;
198
+ var IconContainer = _styledComponents["default"].span(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n align-content: center;\n height: ", ";\n width: ", ";\n margin-left: ", ";\n margin-right: ", ";\n color: ", ";\n"])), function (props) {
199
+ return props.theme.iconSize;
177
200
  }, function (props) {
178
- return props.theme.titleLabelFontSize;
201
+ return props.theme.iconSize;
179
202
  }, function (props) {
180
- return props.theme.titleLabelFontStyle;
203
+ return props.theme.iconMarginLeft;
181
204
  }, function (props) {
182
- return props.theme.titleFonLabeltWeight;
205
+ return props.theme.iconMarginRigth;
183
206
  }, function (props) {
184
- return props.disabled ? props.theme.disabledTitleLabelFontColor : props.theme.titleLabelFontColor;
207
+ return props.disabled ? props.theme.disabledIconColor : props.theme.iconColor;
185
208
  });
186
209
 
187
- var AccordionLabel = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])([""])));
188
-
189
- var AccordionContent = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n width: 100%;\n"])));
210
+ var IconImg = _styledComponents["default"].img(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n height: ", ";\n width: ", ";\n"])), function (props) {
211
+ return props.theme.iconSize;
212
+ }, function (props) {
213
+ return props.theme.iconSize;
214
+ });
190
215
 
191
- var AccordionAssistiveText = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n padding-left: ", ";\n padding-right: ", ";\n font-size: ", ";\n font-family: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n letter-spacing: ", ";\n flex: 1;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n min-width: ", ";\n text-align: end;\n"])), function (props) {
216
+ var AccordionAssistiveText = _styledComponents["default"].span(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n min-width: ", ";\n padding-left: ", ";\n padding-right: ", ";\n"])), function (props) {
217
+ return props.theme.assistiveTextMinWidth;
218
+ }, function (props) {
192
219
  return props.theme.assistiveTextPaddingLeft;
193
220
  }, function (props) {
194
221
  return props.theme.assistiveTextPaddingRight;
195
- }, function (props) {
196
- return props.theme.assistiveTextFontSize;
197
- }, function (props) {
198
- return props.theme.assistiveTextFontFamily;
199
- }, function (props) {
200
- return props.theme.assistiveTextFontStyle;
201
- }, function (props) {
202
- return props.theme.assistiveTextFontWeight;
203
- }, function (props) {
204
- return props.disabled ? props.theme.disabledAssistiveTextFontColor : props.theme.assistiveTextFontColor;
205
- }, function (props) {
206
- return props.theme.assistiveTextLetterSpacing;
207
- }, function (props) {
208
- return props.theme.assistiveTextMinWidth;
209
222
  });
210
223
 
211
- var IconContainer = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n height: ", ";\n width: ", ";\n margin-left: ", ";\n margin-right: ", ";\n overflow: hidden;\n color: ", ";\n\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
212
- return props.theme.iconSize;
224
+ var CollapseIndicator = _styledComponents["default"].span(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n align-content: center;\n color: ", ";\n"])), function (props) {
225
+ return props.disabled ? props.theme.disabledArrowColor : props.theme.arrowColor;
226
+ });
227
+
228
+ var AccordionPanel = _styledComponents["default"].div(_templateObject10 || (_templateObject10 = (0, _taggedTemplateLiteral2["default"])(["\n border-bottom-left-radius: ", ";\n border-bottom-right-radius: ", ";\n padding: ", ";\n padding-top: ", ";\n padding-right: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n"])), function (props) {
229
+ return props.theme.borderRadius;
213
230
  }, function (props) {
214
- return props.theme.iconSize;
231
+ return props.theme.borderRadius;
215
232
  }, function (props) {
216
- return props.theme.iconMarginLeft;
233
+ return props.padding && (0, _typeof2["default"])(props.padding) !== "object" ? _variables.spaces[props.padding] : "0px";
217
234
  }, function (props) {
218
- return props.theme.iconMarginRigth;
235
+ return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.top ? _variables.spaces[props.padding.top] : "";
219
236
  }, function (props) {
220
- return props.disabled ? props.theme.disabledIconColor : props.theme.iconColor;
237
+ return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.right ? _variables.spaces[props.padding.right] : "";
238
+ }, function (props) {
239
+ return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.bottom ? _variables.spaces[props.padding.bottom] : "";
240
+ }, function (props) {
241
+ return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.left ? _variables.spaces[props.padding.left] : "";
221
242
  });
222
243
 
223
- var AccordionIcon = _styledComponents["default"].img(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])([""])));
224
-
225
244
  var _default = DxcAccordion;
226
245
  exports["default"] = _default;
@@ -133,13 +133,12 @@ export const Chromatic = () => (
133
133
  icon={folderIcon}
134
134
  padding="medium"
135
135
  >
136
- <div style={{ display: "flex", flexDirection: "column" }}>
136
+ <div style={{ display: "flex", flexDirection: "column", gap: "36px" }}>
137
137
  <DxcTextInput
138
138
  label="Label"
139
139
  helperText="HelperText"
140
140
  placeholder="Placeholder"
141
141
  size="fillParent"
142
- margin={{ bottom: "medium" }}
143
142
  />
144
143
  <DxcButton label="Submit" size="medium" />
145
144
  </div>
@@ -9,20 +9,19 @@ var _react2 = require("@testing-library/react");
9
9
  var _Accordion = _interopRequireDefault(require("./Accordion"));
10
10
 
11
11
  describe("Accordion component tests", function () {
12
- test("Accordion renders with correct text", function () {
13
- var onChange = jest.fn();
14
-
12
+ test("Renders with correct aria accessibility attributes", function () {
15
13
  var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Accordion["default"], {
16
14
  label: "Accordion",
17
- assistiveText: "Assistive text",
18
- onChange: onChange
19
- })),
20
- getByText = _render.getByText;
15
+ defaultIsExpanded: true
16
+ }, /*#__PURE__*/_react["default"].createElement("div", null, "test-expanded"))),
17
+ getByRole = _render.getByRole;
21
18
 
22
- expect(getByText("Accordion")).toBeTruthy();
23
- expect(getByText("Assistive text")).toBeTruthy();
19
+ var accordion = getByRole("button");
20
+ var panel = getByRole("region");
21
+ expect(accordion.getAttribute("aria-controls")).toBe(panel.id);
22
+ expect(panel.getAttribute("aria-labelledby")).toBe(accordion.id);
24
23
  });
25
- test("Accordion renders expanded by default when it is uncontrolled", function () {
24
+ test("Renders expanded by default when it is uncontrolled", function () {
26
25
  var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Accordion["default"], {
27
26
  label: "Accordion",
28
27
  defaultIsExpanded: true
@@ -1,12 +1,12 @@
1
1
  /// <reference types="react" />
2
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- declare type Margin = {
2
+ export declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ export declare type Margin = {
4
4
  top?: Space;
5
5
  bottom?: Space;
6
6
  left?: Space;
7
7
  right?: Space;
8
8
  };
9
- declare type Padding = {
9
+ export declare type Padding = {
10
10
  top?: Space;
11
11
  bottom?: Space;
12
12
  left?: Space;
@@ -112,7 +112,7 @@ var calculateWidth = function calculateWidth(margin) {
112
112
  return "calc(100% - ".concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
113
113
  };
114
114
 
115
- var AccordionGroupContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-block;\n width: ", ";\n\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n cursor: ", ";\n\n & > :not(div:last-child) {\n & > div:first-child {\n border-radius: 0;\n border-bottom: ", ";\n border-color: ", ";\n\n & > .Mui-expanded {\n border-radius: 0;\n }\n & > .MuiButtonBase-root {\n border-radius: 0;\n }\n }\n }\n\n & > div:first-child {\n & > div:first-child {\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n border-top-left-radius: ", ";\n border-top-right-radius: ", ";\n border-bottom: ", ";\n border-color: ", ";\n\n & > .Mui-expanded {\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n border-top-left-radius: ", ";\n border-top-right-radius: ", ";\n }\n & > .MuiButtonBase-root {\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n border-top-left-radius: ", ";\n border-top-right-radius: ", ";\n }\n }\n }\n\n & > div:last-child {\n & > div:first-child {\n border-bottom-left-radius: ", ";\n border-bottom-right-radius: ", ";\n border-top-left-radius: 0;\n border-top-right-radius: 0;\n\n & > .Mui-expanded {\n border-bottom-left-radius: ", ";\n border-bottom-right-radius: ", ";\n border-top-left-radius: 0;\n border-top-right-radius: 0;\n }\n & > .MuiButtonBase-root {\n border-bottom-left-radius: ", ";\n border-bottom-right-radius: ", ";\n border-top-left-radius: 0;\n border-top-right-radius: 0;\n }\n }\n }\n"])), function (props) {
115
+ var AccordionGroupContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n cursor: ", ";\n\n > div:not(:last-of-type):not(:only-of-type) {\n border-bottom: ", ";\n border-color: ", ";\n }\n > div:not(:first-of-type):not(:last-of-type):not(:only-of-type) {\n border-radius: 0;\n & > h3 > button {\n border-radius: 0;\n }\n }\n > div:first-of-type:not(:only-of-type) {\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n border-top-left-radius: ", ";\n border-top-right-radius: ", ";\n\n & > h3 > button {\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n }\n }\n > div:last-of-type:not(:only-of-type) {\n border-top-left-radius: 0;\n border-top-right-radius: 0;\n border-bottom-left-radius: ", ";\n border-bottom-right-radius: ", ";\n\n & > h3 > button {\n border-top-left-radius: 0;\n border-top-right-radius: 0;\n }\n }\n"])), function (props) {
116
116
  return calculateWidth(props.margin);
117
117
  }, function (_ref3) {
118
118
  var margin = _ref3.margin;
@@ -139,26 +139,6 @@ var AccordionGroupContainer = _styledComponents["default"].div(_templateObject |
139
139
  return props.theme.borderRadius;
140
140
  }, function (props) {
141
141
  return props.theme.borderRadius;
142
- }, function (props) {
143
- return "".concat(props.theme.accordionGroupSeparatorBorderThickness, " ").concat(props.theme.accordionGroupSeparatorBorderStyle);
144
- }, function (props) {
145
- return props.theme.accordionGroupSeparatorBorderColor;
146
- }, function (props) {
147
- return props.theme.borderRadius;
148
- }, function (props) {
149
- return props.theme.borderRadius;
150
- }, function (props) {
151
- return props.theme.borderRadius;
152
- }, function (props) {
153
- return props.theme.borderRadius;
154
- }, function (props) {
155
- return props.theme.borderRadius;
156
- }, function (props) {
157
- return props.theme.borderRadius;
158
- }, function (props) {
159
- return props.theme.borderRadius;
160
- }, function (props) {
161
- return props.theme.borderRadius;
162
142
  }, function (props) {
163
143
  return props.theme.borderRadius;
164
144
  }, function (props) {
@@ -80,6 +80,32 @@ export const Chromatic = () => (
80
80
  </DxcAccordionGroup.Accordion>
81
81
  </DxcAccordionGroup>
82
82
  </ExampleContainer>
83
+ <ExampleContainer pseudoState="pseudo-focus">
84
+ <Title title="Focused" theme="light" level={4} />
85
+ <DxcAccordionGroup defaultIndexActive={2}>
86
+ <DxcAccordionGroup.Accordion label="Accordion1" padding="medium">
87
+ <div>
88
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
89
+ dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex
90
+ ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat
91
+ nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit
92
+ anim id est laborum.
93
+ </div>
94
+ </DxcAccordionGroup.Accordion>
95
+ <DxcAccordionGroup.Accordion label="Accordion2" padding="medium">
96
+ <div>
97
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada lacus ex, sit amet blandit
98
+ leo lobortis eget.
99
+ </div>
100
+ </DxcAccordionGroup.Accordion>
101
+ <DxcAccordionGroup.Accordion label="Accordion2" padding="medium">
102
+ <div>
103
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada lacus ex, sit amet blandit
104
+ leo lobortis eget.
105
+ </div>
106
+ </DxcAccordionGroup.Accordion>
107
+ </DxcAccordionGroup>
108
+ </ExampleContainer>
83
109
  <Title title="Margins" theme="light" level={2} />
84
110
  <ExampleContainer>
85
111
  <Title title="Xxsmall" theme="light" level={4} />
@@ -222,4 +248,4 @@ export const Chromatic = () => (
222
248
  </DxcAccordionGroup>
223
249
  </ExampleContainer>
224
250
  </>
225
- );
251
+ );
@@ -9,37 +9,10 @@ var _react2 = require("@testing-library/react");
9
9
  var _AccordionGroup = _interopRequireDefault(require("./AccordionGroup"));
10
10
 
11
11
  describe("Accordion component tests", function () {
12
- test("Uncontrolled accordion group renders with children", function () {
13
- var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_AccordionGroup["default"], null, /*#__PURE__*/_react["default"].createElement(_AccordionGroup["default"].Accordion, {
14
- label: "Accordion1",
15
- padding: "medium"
16
- }, /*#__PURE__*/_react["default"].createElement("div", null, "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada lacus ex, sit amet blandit leo lobortis eget.")), /*#__PURE__*/_react["default"].createElement(_AccordionGroup["default"].Accordion, {
17
- label: "Accordion2",
18
- padding: "medium"
19
- }, /*#__PURE__*/_react["default"].createElement("div", null, "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada lacus ex, sit amet blandit leo lobortis eget.")))),
20
- getByText = _render.getByText,
21
- getAllByRole = _render.getAllByRole;
22
-
23
- expect(getByText("Accordion1")).toBeTruthy();
24
- expect(getByText("Accordion2")).toBeTruthy();
25
- expect(getAllByRole("button")[0].getAttribute("aria-expanded")).toBe("false");
26
- expect(getAllByRole("button")[1].getAttribute("aria-expanded")).toBe("false");
27
- });
28
- test("Uncontrolled accordion group renders with only one children", function () {
29
- var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_AccordionGroup["default"], null, /*#__PURE__*/_react["default"].createElement(_AccordionGroup["default"].Accordion, {
30
- label: "Accordion1",
31
- padding: "medium"
32
- }, /*#__PURE__*/_react["default"].createElement("div", null, "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada lacus ex, sit amet blandit leo lobortis eget.")))),
33
- getByText = _render2.getByText,
34
- getAllByRole = _render2.getAllByRole;
35
-
36
- expect(getByText("Accordion1")).toBeTruthy();
37
- expect(getAllByRole("button")[0].getAttribute("aria-expanded")).toBe("false");
38
- });
39
12
  test("Uncontrolled accordion group calls correct function on click", function () {
40
13
  var onActiveChange = jest.fn();
41
14
 
42
- var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_AccordionGroup["default"], {
15
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_AccordionGroup["default"], {
43
16
  margin: "large",
44
17
  onActiveChange: onActiveChange
45
18
  }, /*#__PURE__*/_react["default"].createElement(_AccordionGroup["default"].Accordion, {
@@ -50,8 +23,8 @@ describe("Accordion component tests", function () {
50
23
  label: "Accordion2",
51
24
  padding: "medium"
52
25
  }, /*#__PURE__*/_react["default"].createElement("div", null, "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada lacus ex, sit amet blandit leo lobortis eget.")))),
53
- getByText = _render3.getByText,
54
- getAllByRole = _render3.getAllByRole;
26
+ getByText = _render.getByText,
27
+ getAllByRole = _render.getAllByRole;
55
28
 
56
29
  expect(getAllByRole("button")[0].getAttribute("aria-expanded")).toBe("false");
57
30
  expect(getAllByRole("button")[1].getAttribute("aria-expanded")).toBe("false");
@@ -62,28 +35,29 @@ describe("Accordion component tests", function () {
62
35
  expect(getAllByRole("button")[0].getAttribute("aria-expanded")).toBe("true");
63
36
  expect(getAllByRole("button")[1].getAttribute("aria-expanded")).toBe("false");
64
37
  });
65
- test("Uncontrolled accordion group renders initially with an accordion expanded", function () {
66
- var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_AccordionGroup["default"], {
38
+ test("Uncontrolled accordion group renders initially with an accordion expanded using defaultIndexActive", function () {
39
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_AccordionGroup["default"], {
67
40
  defaultIndexActive: 1
68
41
  }, /*#__PURE__*/_react["default"].createElement(_AccordionGroup["default"].Accordion, {
69
42
  label: "Accordion1",
70
43
  padding: "medium"
71
- }, /*#__PURE__*/_react["default"].createElement("div", null, "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada lacus ex, sit amet blandit leo lobortis eget.")), /*#__PURE__*/_react["default"].createElement(_AccordionGroup["default"].Accordion, {
44
+ }, /*#__PURE__*/_react["default"].createElement("div", null, "First accordion")), /*#__PURE__*/_react["default"].createElement(_AccordionGroup["default"].Accordion, {
72
45
  label: "Accordion2",
73
46
  padding: "medium"
74
- }, /*#__PURE__*/_react["default"].createElement("div", null, "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada lacus ex, sit amet blandit leo lobortis eget.")))),
75
- getByText = _render4.getByText,
76
- getAllByRole = _render4.getAllByRole;
47
+ }, /*#__PURE__*/_react["default"].createElement("div", null, "Second accordion")))),
48
+ queryByText = _render2.queryByText,
49
+ getByText = _render2.getByText,
50
+ getAllByRole = _render2.getAllByRole;
77
51
 
78
- expect(getByText("Accordion1")).toBeTruthy();
79
- expect(getByText("Accordion2")).toBeTruthy();
80
52
  expect(getAllByRole("button")[0].getAttribute("aria-expanded")).toBe("false");
81
53
  expect(getAllByRole("button")[1].getAttribute("aria-expanded")).toBe("true");
54
+ expect(getByText("Second accordion")).toBeTruthy();
55
+ expect(queryByText("First accordion")).toBeFalsy();
82
56
  });
83
57
  test("Controlled accordion with indexActive change", function () {
84
58
  var onActiveChange = jest.fn();
85
59
 
86
- var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_AccordionGroup["default"], {
60
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_AccordionGroup["default"], {
87
61
  margin: "large",
88
62
  indexActive: 1,
89
63
  onActiveChange: onActiveChange
@@ -95,11 +69,12 @@ describe("Accordion component tests", function () {
95
69
  label: "Accordion2",
96
70
  padding: "medium"
97
71
  }, /*#__PURE__*/_react["default"].createElement("div", null, "Text2")))),
98
- getByText = _render5.getByText,
99
- getAllByRole = _render5.getAllByRole,
100
- rerender = _render5.rerender;
72
+ queryByText = _render3.queryByText,
73
+ getByText = _render3.getByText,
74
+ getAllByRole = _render3.getAllByRole,
75
+ rerender = _render3.rerender;
101
76
 
102
- expect(getByText("Text1")).toBeTruthy();
77
+ expect(queryByText("Text1")).toBeFalsy();
103
78
  expect(getByText("Text2")).toBeTruthy();
104
79
 
105
80
  _react2.fireEvent.click(getByText("Accordion1"));
@@ -128,7 +103,7 @@ describe("Accordion component tests", function () {
128
103
  test("Disabled uncontrolled accordion group", function () {
129
104
  var onActiveChange = jest.fn();
130
105
 
131
- var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_AccordionGroup["default"], {
106
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_AccordionGroup["default"], {
132
107
  margin: "large",
133
108
  onActiveChange: onActiveChange,
134
109
  disabled: true
@@ -140,7 +115,7 @@ describe("Accordion component tests", function () {
140
115
  label: "Accordion2",
141
116
  padding: "medium"
142
117
  }, /*#__PURE__*/_react["default"].createElement("div", null, "Text2")))),
143
- getByText = _render6.getByText;
118
+ getByText = _render4.getByText;
144
119
 
145
120
  _react2.fireEvent.click(getByText("Accordion1"));
146
121
 
@@ -1,6 +1,6 @@
1
1
  /// <reference types="react" />
2
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- declare type Margin = {
2
+ export declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ export declare type Margin = {
4
4
  top?: Space;
5
5
  bottom?: Space;
6
6
  left?: Space;
@@ -69,4 +69,10 @@ declare type Props = {
69
69
  */
70
70
  children: React.ReactElement<AccordionPropsType>[] | React.ReactElement<AccordionPropsType>;
71
71
  };
72
+ export declare type AccordionGroupAccordionContextProps = {
73
+ activeIndex: number;
74
+ handlerActiveChange: (index: number) => void;
75
+ disabled: boolean;
76
+ index: number;
77
+ };
72
78
  export default Props;
package/alert/Alert.js CHANGED
@@ -146,7 +146,7 @@ var sizes = {
146
146
  medium: "480px",
147
147
  large: "820px",
148
148
  fillParent: "100%",
149
- fitContent: "auto"
149
+ fitContent: "fit-content"
150
150
  };
151
151
 
152
152
  var calculateWidth = function calculateWidth(margin, size) {