@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.
- package/accordion/Accordion.js +122 -103
- package/accordion/Accordion.stories.tsx +1 -2
- package/accordion/Accordion.test.js +9 -10
- package/accordion/types.d.ts +3 -3
- package/accordion-group/AccordionGroup.js +1 -21
- package/accordion-group/AccordionGroup.stories.tsx +27 -1
- package/accordion-group/AccordionGroup.test.js +20 -45
- package/accordion-group/types.d.ts +8 -2
- package/alert/Alert.js +1 -1
- package/box/Box.js +1 -1
- package/checkbox/Checkbox.js +88 -95
- package/checkbox/Checkbox.test.js +93 -16
- package/checkbox/types.d.ts +2 -2
- package/common/variables.js +8 -4
- package/dropdown/Dropdown.js +1 -1
- package/footer/Footer.stories.tsx +8 -1
- package/header/Header.stories.tsx +4 -4
- package/layout/ApplicationLayout.stories.tsx +1 -0
- package/package.json +8 -8
- package/select/Listbox.js +0 -1
- package/slider/Slider.js +112 -91
- package/slider/Slider.stories.tsx +7 -1
- package/slider/Slider.test.js +87 -24
- package/slider/types.d.ts +2 -2
- package/switch/Switch.js +1 -1
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +135 -0
- package/tabs/Tabs.js +360 -104
- package/tabs/Tabs.stories.tsx +74 -0
- package/tabs/Tabs.test.js +217 -6
- package/tabs/types.d.ts +14 -4
- package/tag/Tag.js +1 -1
- package/text-input/Icons.d.ts +8 -0
- package/text-input/Icons.js +60 -0
- package/text-input/Suggestion.js +7 -5
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +134 -0
- package/text-input/TextInput.js +103 -201
- package/text-input/TextInput.stories.tsx +189 -181
- package/text-input/TextInput.test.js +163 -162
- package/text-input/types.d.ts +16 -2
package/accordion/Accordion.js
CHANGED
|
@@ -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
|
|
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)(
|
|
62
|
-
_useState2 = (0, _slicedToArray2["default"])(_useState,
|
|
63
|
-
|
|
64
|
-
|
|
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
|
|
69
|
-
|
|
70
|
-
setInnerIsExpanded(!innerIsExpanded);
|
|
71
|
-
}
|
|
86
|
+
var handleAccordionState = function handleAccordionState() {
|
|
87
|
+
var _isExpanded;
|
|
72
88
|
|
|
73
|
-
|
|
74
|
-
|
|
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(
|
|
97
|
+
}, /*#__PURE__*/_react["default"].createElement(AccordionContainer, {
|
|
98
|
+
isExpanded: isExpanded !== null && isExpanded !== void 0 ? isExpanded : innerIsExpanded,
|
|
81
99
|
padding: padding,
|
|
82
|
-
margin: margin
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
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
|
-
|
|
88
|
-
expanded: isExpanded
|
|
89
|
-
|
|
90
|
-
|
|
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(
|
|
113
|
+
}, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(IconImg, {
|
|
97
114
|
src: icon
|
|
98
|
-
}) : icon), /*#__PURE__*/_react["default"].createElement(
|
|
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
|
-
},
|
|
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
|
|
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
|
-
}
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
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.
|
|
175
|
+
return props.isExpanded && "border-bottom-left-radius: 0; border-bottom-right-radius: 0;";
|
|
137
176
|
}, function (props) {
|
|
138
|
-
return props.
|
|
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
|
-
}
|
|
148
|
-
|
|
149
|
-
|
|
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
|
|
172
|
-
return props.theme.
|
|
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.
|
|
201
|
+
return props.theme.iconSize;
|
|
179
202
|
}, function (props) {
|
|
180
|
-
return props.theme.
|
|
203
|
+
return props.theme.iconMarginLeft;
|
|
181
204
|
}, function (props) {
|
|
182
|
-
return props.theme.
|
|
205
|
+
return props.theme.iconMarginRigth;
|
|
183
206
|
}, function (props) {
|
|
184
|
-
return props.disabled ? props.theme.
|
|
207
|
+
return props.disabled ? props.theme.disabledIconColor : props.theme.iconColor;
|
|
185
208
|
});
|
|
186
209
|
|
|
187
|
-
var
|
|
188
|
-
|
|
189
|
-
|
|
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"].
|
|
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
|
|
212
|
-
return props.theme.
|
|
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.
|
|
231
|
+
return props.theme.borderRadius;
|
|
215
232
|
}, function (props) {
|
|
216
|
-
return props.
|
|
233
|
+
return props.padding && (0, _typeof2["default"])(props.padding) !== "object" ? _variables.spaces[props.padding] : "0px";
|
|
217
234
|
}, function (props) {
|
|
218
|
-
return props.
|
|
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.
|
|
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("
|
|
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
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
getByText = _render.getByText;
|
|
15
|
+
defaultIsExpanded: true
|
|
16
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, "test-expanded"))),
|
|
17
|
+
getByRole = _render.getByRole;
|
|
21
18
|
|
|
22
|
-
|
|
23
|
-
|
|
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("
|
|
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
|
package/accordion/types.d.ts
CHANGED
|
@@ -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
|
|
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
|
|
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 =
|
|
54
|
-
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
|
|
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, "
|
|
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, "
|
|
75
|
-
|
|
76
|
-
|
|
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
|
|
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
|
-
|
|
99
|
-
|
|
100
|
-
|
|
72
|
+
queryByText = _render3.queryByText,
|
|
73
|
+
getByText = _render3.getByText,
|
|
74
|
+
getAllByRole = _render3.getAllByRole,
|
|
75
|
+
rerender = _render3.rerender;
|
|
101
76
|
|
|
102
|
-
expect(
|
|
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
|
|
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 =
|
|
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;
|