@dxc-technology/halstack-react 0.0.0-dcd93c4 → 0.0.0-dcee34a
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/HalstackContext.js +98 -50
- package/accordion/Accordion.js +117 -104
- package/accordion/Accordion.stories.tsx +103 -15
- package/accordion/Accordion.test.js +9 -10
- package/accordion/types.d.ts +5 -4
- 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 +10 -3
- package/alert/Alert.js +1 -1
- package/alert/Alert.stories.tsx +28 -0
- package/bleed/Bleed.stories.tsx +63 -63
- package/box/Box.js +1 -1
- package/box/Box.stories.tsx +15 -0
- package/box/types.d.ts +1 -0
- package/bulleted-list/BulletedList.d.ts +7 -0
- package/bulleted-list/BulletedList.js +123 -0
- package/bulleted-list/BulletedList.stories.tsx +200 -0
- package/bulleted-list/types.d.ts +11 -0
- package/button/Button.js +50 -70
- package/button/Button.stories.tsx +159 -8
- package/button/types.d.ts +7 -7
- package/card/types.d.ts +1 -0
- package/checkbox/Checkbox.d.ts +2 -2
- package/checkbox/Checkbox.js +92 -99
- package/checkbox/Checkbox.stories.tsx +131 -59
- package/checkbox/Checkbox.test.js +93 -16
- package/checkbox/types.d.ts +6 -2
- package/chip/Chip.js +16 -22
- package/chip/Chip.stories.tsx +96 -9
- package/chip/types.d.ts +1 -1
- package/common/variables.js +328 -260
- package/date-input/Calendar.d.ts +4 -0
- package/date-input/Calendar.js +258 -0
- package/date-input/DateInput.js +134 -237
- package/date-input/DateInput.stories.tsx +199 -33
- package/date-input/DateInput.test.js +494 -138
- package/date-input/DatePicker.d.ts +4 -0
- package/date-input/DatePicker.js +146 -0
- package/date-input/Icons.d.ts +6 -0
- package/date-input/Icons.js +75 -0
- package/date-input/YearPicker.d.ts +4 -0
- package/date-input/YearPicker.js +126 -0
- package/date-input/types.d.ts +51 -0
- package/dialog/Dialog.js +50 -28
- package/dialog/Dialog.stories.tsx +99 -22
- package/dialog/Dialog.test.js +34 -4
- package/dialog/types.d.ts +3 -2
- package/dropdown/Dropdown.d.ts +1 -1
- package/dropdown/Dropdown.js +246 -249
- package/dropdown/Dropdown.stories.tsx +245 -56
- package/dropdown/Dropdown.test.js +504 -108
- package/dropdown/DropdownMenu.d.ts +4 -0
- package/dropdown/DropdownMenu.js +70 -0
- package/dropdown/DropdownMenuItem.d.ts +4 -0
- package/dropdown/DropdownMenuItem.js +81 -0
- package/dropdown/types.d.ts +25 -5
- package/file-input/FileInput.d.ts +2 -2
- package/file-input/FileInput.js +177 -219
- package/file-input/FileInput.stories.tsx +122 -11
- package/file-input/FileInput.test.js +53 -12
- package/file-input/FileItem.d.ts +4 -14
- package/file-input/FileItem.js +38 -63
- package/file-input/types.d.ts +17 -0
- package/flex/Flex.d.ts +4 -0
- package/flex/Flex.js +69 -0
- package/flex/Flex.stories.tsx +103 -0
- package/flex/types.d.ts +32 -0
- package/footer/Footer.stories.tsx +99 -1
- package/footer/types.d.ts +2 -1
- package/header/Header.js +87 -87
- package/header/Header.stories.tsx +152 -9
- package/header/Icons.js +2 -2
- package/header/types.d.ts +3 -2
- package/inset/Inset.stories.tsx +4 -4
- package/layout/ApplicationLayout.d.ts +15 -6
- package/layout/ApplicationLayout.js +36 -64
- package/layout/ApplicationLayout.stories.tsx +80 -44
- package/layout/types.d.ts +17 -27
- package/link/Link.js +2 -2
- package/link/Link.stories.tsx +72 -5
- package/link/types.d.ts +1 -1
- package/main.d.ts +6 -10
- package/main.js +28 -60
- package/{tabs-nav → nav-tabs}/NavTabs.js +6 -6
- package/{tabs-nav → nav-tabs}/NavTabs.stories.tsx +96 -6
- package/{tabs-nav → nav-tabs}/Tab.js +37 -20
- package/{tabs-nav → nav-tabs}/types.d.ts +1 -1
- package/number-input/NumberInput.test.js +43 -7
- package/package.json +16 -21
- package/paginator/Icons.d.ts +5 -0
- package/paginator/Icons.js +16 -28
- package/paginator/Paginator.js +6 -12
- package/paginator/Paginator.stories.tsx +24 -0
- package/paginator/Paginator.test.js +18 -11
- package/paragraph/Paragraph.d.ts +6 -0
- package/paragraph/Paragraph.js +38 -0
- package/paragraph/Paragraph.stories.tsx +44 -0
- package/password-input/PasswordInput.test.js +13 -12
- package/progress-bar/ProgressBar.d.ts +2 -2
- package/progress-bar/ProgressBar.js +59 -53
- package/progress-bar/ProgressBar.stories.jsx +38 -3
- package/progress-bar/ProgressBar.test.js +67 -22
- package/progress-bar/types.d.ts +3 -4
- package/quick-nav/QuickNav.js +18 -17
- package/quick-nav/QuickNav.stories.tsx +145 -26
- package/radio-group/Radio.d.ts +1 -1
- package/radio-group/Radio.js +43 -28
- package/radio-group/RadioGroup.js +24 -24
- package/radio-group/RadioGroup.stories.tsx +132 -18
- package/radio-group/RadioGroup.test.js +123 -96
- package/radio-group/types.d.ts +2 -2
- package/resultsetTable/Icons.d.ts +7 -0
- package/resultsetTable/Icons.js +51 -0
- package/resultsetTable/ResultsetTable.js +48 -107
- package/resultsetTable/ResultsetTable.stories.tsx +50 -25
- package/resultsetTable/ResultsetTable.test.js +40 -63
- package/resultsetTable/types.d.ts +2 -2
- package/select/Listbox.js +4 -10
- package/select/Option.js +11 -24
- package/select/Select.js +54 -50
- package/select/Select.stories.tsx +494 -149
- package/select/Select.test.js +338 -272
- package/select/types.d.ts +3 -5
- package/sidenav/Sidenav.d.ts +6 -5
- package/sidenav/Sidenav.js +174 -55
- package/sidenav/Sidenav.stories.tsx +249 -149
- package/sidenav/Sidenav.test.js +25 -37
- package/sidenav/types.d.ts +50 -27
- package/slider/Slider.d.ts +2 -2
- package/slider/Slider.js +120 -95
- package/slider/Slider.stories.tsx +64 -1
- package/slider/Slider.test.js +121 -21
- package/slider/types.d.ts +6 -2
- package/spinner/Spinner.js +2 -2
- package/spinner/Spinner.stories.jsx +27 -1
- package/switch/Switch.d.ts +2 -2
- package/switch/Switch.js +135 -68
- package/switch/Switch.stories.tsx +41 -30
- package/switch/Switch.test.js +144 -17
- package/switch/types.d.ts +6 -2
- package/table/Table.js +1 -1
- package/table/Table.stories.jsx +80 -1
- package/table/Table.test.js +1 -1
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +133 -0
- package/tabs/Tabs.js +360 -104
- package/tabs/Tabs.stories.tsx +119 -5
- package/tabs/Tabs.test.js +217 -6
- package/tabs/types.d.ts +15 -5
- package/tag/Tag.js +1 -1
- package/tag/Tag.stories.tsx +14 -1
- package/tag/types.d.ts +1 -1
- package/text-input/Icons.d.ts +8 -0
- package/text-input/Icons.js +60 -0
- package/text-input/Suggestion.js +38 -9
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +134 -0
- package/text-input/TextInput.js +195 -292
- package/text-input/TextInput.stories.tsx +280 -185
- package/text-input/TextInput.test.js +737 -725
- package/text-input/types.d.ts +22 -3
- package/textarea/Textarea.stories.jsx +60 -1
- package/toggle-group/ToggleGroup.stories.tsx +42 -0
- package/toggle-group/types.d.ts +1 -1
- package/typography/Typography.d.ts +4 -0
- package/typography/Typography.js +131 -0
- package/typography/Typography.stories.tsx +198 -0
- package/typography/types.d.ts +18 -0
- package/wizard/Wizard.js +9 -16
- package/wizard/Wizard.stories.tsx +40 -1
- package/wizard/types.d.ts +5 -4
- package/common/RequiredComponent.js +0 -32
- package/inline/Inline.d.ts +0 -4
- package/inline/Inline.js +0 -60
- package/inline/Inline.stories.tsx +0 -319
- package/inline/types.d.ts +0 -36
- package/list/List.d.ts +0 -4
- package/list/List.js +0 -47
- package/list/List.stories.tsx +0 -89
- package/list/types.d.ts +0 -7
- package/row/Row.d.ts +0 -3
- package/row/Row.js +0 -127
- package/row/Row.stories.tsx +0 -237
- package/row/types.d.ts +0 -28
- package/stack/Stack.d.ts +0 -4
- package/stack/Stack.js +0 -56
- package/stack/Stack.stories.tsx +0 -263
- package/stack/types.d.ts +0 -32
- package/tabs-nav/types.js +0 -5
- package/text/Text.d.ts +0 -7
- package/text/Text.js +0 -30
- package/text/Text.stories.tsx +0 -19
- /package/{inline → bulleted-list}/types.js +0 -0
- /package/{list → flex}/types.js +0 -0
- /package/{tabs-nav → nav-tabs}/NavTabs.d.ts +0 -0
- /package/{tabs-nav → nav-tabs}/NavTabs.test.js +0 -0
- /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
- /package/{row → nav-tabs}/types.js +0 -0
- /package/{stack → typography}/types.js +0 -0
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;
|
|
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("img", {
|
|
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.
|
|
137
|
-
}, function (props) {
|
|
138
|
-
return props.theme.focusBorderStyle;
|
|
175
|
+
return props.isExpanded && "border-bottom-left-radius: 0; border-bottom-right-radius: 0;";
|
|
139
176
|
}, function (props) {
|
|
140
|
-
return props.
|
|
177
|
+
return props.disabled ? "not-allowed" : "pointer";
|
|
141
178
|
}, function (props) {
|
|
142
|
-
return props.theme.
|
|
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,47 @@ 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 margin-left: ", ";\n margin-right: ", ";\n color: ", ";\n\n svg,\n img {\n height: ", ";\n width: ", ";\n }\n"])), function (props) {
|
|
199
|
+
return props.theme.iconMarginLeft;
|
|
177
200
|
}, function (props) {
|
|
178
|
-
return props.theme.
|
|
201
|
+
return props.theme.iconMarginRigth;
|
|
179
202
|
}, function (props) {
|
|
180
|
-
return props.theme.
|
|
203
|
+
return props.disabled ? props.theme.disabledIconColor : props.theme.iconColor;
|
|
181
204
|
}, function (props) {
|
|
182
|
-
return props.theme.
|
|
205
|
+
return props.theme.iconSize;
|
|
183
206
|
}, function (props) {
|
|
184
|
-
return props.
|
|
207
|
+
return props.theme.iconSize;
|
|
185
208
|
});
|
|
186
209
|
|
|
187
|
-
var
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
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) {
|
|
210
|
+
var AccordionAssistiveText = _styledComponents["default"].span(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n min-width: ", ";\n padding-left: ", ";\n padding-right: ", ";\n"])), function (props) {
|
|
211
|
+
return props.theme.assistiveTextMinWidth;
|
|
212
|
+
}, function (props) {
|
|
192
213
|
return props.theme.assistiveTextPaddingLeft;
|
|
193
214
|
}, function (props) {
|
|
194
215
|
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
216
|
});
|
|
210
217
|
|
|
211
|
-
var
|
|
212
|
-
return props.theme.
|
|
218
|
+
var CollapseIndicator = _styledComponents["default"].span(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n align-content: center;\n color: ", ";\n"])), function (props) {
|
|
219
|
+
return props.disabled ? props.theme.disabledArrowColor : props.theme.arrowColor;
|
|
220
|
+
});
|
|
221
|
+
|
|
222
|
+
var AccordionPanel = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (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) {
|
|
223
|
+
return props.theme.borderRadius;
|
|
213
224
|
}, function (props) {
|
|
214
|
-
return props.theme.
|
|
225
|
+
return props.theme.borderRadius;
|
|
215
226
|
}, function (props) {
|
|
216
|
-
return props.
|
|
227
|
+
return props.padding && (0, _typeof2["default"])(props.padding) !== "object" ? _variables.spaces[props.padding] : "0px";
|
|
217
228
|
}, function (props) {
|
|
218
|
-
return props.
|
|
229
|
+
return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.top ? _variables.spaces[props.padding.top] : "";
|
|
219
230
|
}, function (props) {
|
|
220
|
-
return props.
|
|
231
|
+
return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.right ? _variables.spaces[props.padding.right] : "";
|
|
232
|
+
}, function (props) {
|
|
233
|
+
return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.bottom ? _variables.spaces[props.padding.bottom] : "";
|
|
234
|
+
}, function (props) {
|
|
235
|
+
return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.left ? _variables.spaces[props.padding.left] : "";
|
|
221
236
|
});
|
|
222
237
|
|
|
223
|
-
var AccordionIcon = _styledComponents["default"].img(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])([""])));
|
|
224
|
-
|
|
225
238
|
var _default = DxcAccordion;
|
|
226
239
|
exports["default"] = _default;
|
|
@@ -30,10 +30,33 @@ const folderIcon = (
|
|
|
30
30
|
</svg>
|
|
31
31
|
);
|
|
32
32
|
|
|
33
|
-
const
|
|
34
|
-
<svg xmlns="http://www.w3.org/2000/svg"
|
|
35
|
-
<path d="
|
|
36
|
-
|
|
33
|
+
const smallIcon = (
|
|
34
|
+
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20" height="20" width="20">
|
|
35
|
+
<path d="m7.646 18.333-.313-2.625q-.208-.125-.458-.27-.25-.146-.458-.271l-2.438 1.021-2.354-4.063 2.083-1.583V9.458L1.625 7.875l2.354-4.063 2.438 1.021q.208-.125.458-.27.25-.146.458-.271l.313-2.625h4.708l.313 2.625q.208.125.458.271.25.145.458.27l2.438-1.021 2.354 4.063-2.063 1.583v1.084l2.063 1.583-2.354 4.063-2.438-1.021q-.208.125-.458.271-.25.145-.458.27l-.313 2.625ZM10 12.979q1.229 0 2.104-.875T12.979 10q0-1.229-.875-2.104T10 7.021q-1.229 0-2.104.875T7.021 10q0 1.229.875 2.104t2.104.875Zm0-1.75q-.5 0-.865-.364-.364-.365-.364-.865t.364-.865q.365-.364.865-.364t.865.364q.364.365.364.865t-.364.865q-.365.364-.865.364ZM10.021 10Zm-.854 6.583h1.666l.25-2.166q.605-.167 1.167-.5.562-.334 1.021-.792l2.021.854.833-1.375-1.771-1.354q.104-.292.146-.604.042-.313.042-.646 0-.292-.042-.594t-.125-.635l1.771-1.375-.834-1.375-2.02.875q-.48-.479-1.032-.802-.552-.323-1.156-.49l-.271-2.187H9.167l-.271 2.187q-.604.167-1.156.49-.552.323-1.011.781l-2.021-.854-.833 1.375 1.75 1.354q-.083.333-.125.646-.042.312-.042.604t.042.594q.042.302.125.635l-1.75 1.375.833 1.375 2.021-.854q.459.458 1.011.781.552.323 1.156.49Z" />
|
|
36
|
+
</svg>
|
|
37
|
+
);
|
|
38
|
+
|
|
39
|
+
const facebookIcon = (
|
|
40
|
+
<svg
|
|
41
|
+
version="1.1"
|
|
42
|
+
id="Capa_1"
|
|
43
|
+
x="0px"
|
|
44
|
+
y="0px"
|
|
45
|
+
width="438.536px"
|
|
46
|
+
height="438.536px"
|
|
47
|
+
viewBox="0 0 438.536 438.536"
|
|
48
|
+
fill="currentColor"
|
|
49
|
+
>
|
|
50
|
+
<g>
|
|
51
|
+
<path
|
|
52
|
+
d="M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123
|
|
53
|
+
C8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126
|
|
54
|
+
h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225
|
|
55
|
+
C438.532,59.576,430.49,40.204,414.41,24.123z M373.155,225.548h-49.963V406.84h-74.802V225.548H210.99V163.02h37.401v-37.402
|
|
56
|
+
c0-26.838,6.283-47.107,18.843-60.813c12.559-13.706,33.304-20.555,62.242-20.555h49.963v62.526h-31.401
|
|
57
|
+
c-10.663,0-17.467,1.853-20.417,5.568c-2.949,3.711-4.428,10.23-4.428,19.558v31.119h56.534L373.155,225.548z"
|
|
58
|
+
/>
|
|
59
|
+
</g>
|
|
37
60
|
</svg>
|
|
38
61
|
);
|
|
39
62
|
|
|
@@ -47,6 +70,14 @@ const advancedTheme = {
|
|
|
47
70
|
},
|
|
48
71
|
};
|
|
49
72
|
|
|
73
|
+
const opinionatedTheme = {
|
|
74
|
+
accordion: {
|
|
75
|
+
accentColor: "#5f249f",
|
|
76
|
+
titleFontColor: "#000000",
|
|
77
|
+
assistiveTextFontColor: "#666666",
|
|
78
|
+
},
|
|
79
|
+
};
|
|
80
|
+
|
|
50
81
|
export const Chromatic = () => (
|
|
51
82
|
<>
|
|
52
83
|
<Title title="Component anatomy" theme="light" level={2} />
|
|
@@ -78,8 +109,30 @@ export const Chromatic = () => (
|
|
|
78
109
|
</DxcAccordion>
|
|
79
110
|
</ExampleContainer>
|
|
80
111
|
<ExampleContainer>
|
|
81
|
-
<Title title="With
|
|
82
|
-
<DxcAccordion label="Accordion" assistiveText="Assistive text" icon={
|
|
112
|
+
<Title title="With smaller icon" theme="light" level={4} />
|
|
113
|
+
<DxcAccordion label="Accordion" assistiveText="Assistive text" icon={smallIcon}>
|
|
114
|
+
<div>
|
|
115
|
+
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada lacus ex, sit amet blandit leo
|
|
116
|
+
lobortis eget.
|
|
117
|
+
</div>
|
|
118
|
+
</DxcAccordion>
|
|
119
|
+
</ExampleContainer>
|
|
120
|
+
<ExampleContainer>
|
|
121
|
+
<Title title="With bigger icon (SVG)" theme="light" level={4} />
|
|
122
|
+
<DxcAccordion label="AccordionTest" assistiveText="Assistive text" icon={facebookIcon}>
|
|
123
|
+
<div>
|
|
124
|
+
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada lacus ex, sit amet blandit leo
|
|
125
|
+
lobortis eget.
|
|
126
|
+
</div>
|
|
127
|
+
</DxcAccordion>
|
|
128
|
+
</ExampleContainer>
|
|
129
|
+
<ExampleContainer>
|
|
130
|
+
<Title title="With bigger icon (image)" theme="light" level={4} />
|
|
131
|
+
<DxcAccordion
|
|
132
|
+
label="Accordion"
|
|
133
|
+
assistiveText="Assistive text"
|
|
134
|
+
icon="https://developer.apple.com/design/human-interface-guidelines/foundations/app-icons/images/icon-and-image-large-icon-settings_2x.png"
|
|
135
|
+
>
|
|
83
136
|
<div>
|
|
84
137
|
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada lacus ex, sit amet blandit leo
|
|
85
138
|
lobortis eget.
|
|
@@ -133,14 +186,8 @@ export const Chromatic = () => (
|
|
|
133
186
|
icon={folderIcon}
|
|
134
187
|
padding="medium"
|
|
135
188
|
>
|
|
136
|
-
<div style={{ display: "flex", flexDirection: "column" }}>
|
|
137
|
-
<DxcTextInput
|
|
138
|
-
label="Label"
|
|
139
|
-
helperText="HelperText"
|
|
140
|
-
placeholder="Placeholder"
|
|
141
|
-
size="fillParent"
|
|
142
|
-
margin={{ bottom: "medium" }}
|
|
143
|
-
/>
|
|
189
|
+
<div style={{ display: "flex", flexDirection: "column", gap: "36px" }}>
|
|
190
|
+
<DxcTextInput label="Label" helperText="HelperText" placeholder="Placeholder" size="fillParent" />
|
|
144
191
|
<DxcButton label="Submit" size="medium" />
|
|
145
192
|
</div>
|
|
146
193
|
</DxcAccordion>
|
|
@@ -301,7 +348,48 @@ export const Chromatic = () => (
|
|
|
301
348
|
lobortis eget.
|
|
302
349
|
</div>
|
|
303
350
|
</DxcAccordion>
|
|
304
|
-
|
|
351
|
+
</ExampleContainer>
|
|
352
|
+
<Title title="Opinionated theme" theme="light" level={2} />
|
|
353
|
+
<ExampleContainer>
|
|
354
|
+
<Title title="With assistive text and icon" theme="light" level={4} />
|
|
355
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
356
|
+
<DxcAccordion label="Accordion" assistiveText="Assistive text" icon={folderIcon}>
|
|
357
|
+
Content
|
|
358
|
+
</DxcAccordion>
|
|
359
|
+
</HalstackProvider>
|
|
360
|
+
</ExampleContainer>
|
|
361
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
362
|
+
<Title title="Hovered" theme="light" level={4} />
|
|
363
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
364
|
+
<DxcAccordion label="Hovered">
|
|
365
|
+
<div>
|
|
366
|
+
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada lacus ex, sit amet blandit
|
|
367
|
+
leo lobortis eget.
|
|
368
|
+
</div>
|
|
369
|
+
</DxcAccordion>
|
|
370
|
+
</HalstackProvider>
|
|
371
|
+
</ExampleContainer>
|
|
372
|
+
<ExampleContainer pseudoState="pseudo-active">
|
|
373
|
+
<Title title="Active" theme="light" level={4} />
|
|
374
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
375
|
+
<DxcAccordion label="Active">
|
|
376
|
+
<div>
|
|
377
|
+
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada lacus ex, sit amet blandit
|
|
378
|
+
leo lobortis eget.
|
|
379
|
+
</div>
|
|
380
|
+
</DxcAccordion>
|
|
381
|
+
</HalstackProvider>
|
|
382
|
+
</ExampleContainer>
|
|
383
|
+
<ExampleContainer>
|
|
384
|
+
<Title title="Disabled" theme="light" level={4} />
|
|
385
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
386
|
+
<DxcAccordion label="Disabled" assistiveText="Assistive text" icon={folderIcon} disabled>
|
|
387
|
+
<div>
|
|
388
|
+
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada lacus ex, sit amet blandit
|
|
389
|
+
leo lobortis eget.
|
|
390
|
+
</div>
|
|
391
|
+
</DxcAccordion>
|
|
392
|
+
</HalstackProvider>
|
|
305
393
|
</ExampleContainer>
|
|
306
394
|
</>
|
|
307
395
|
);
|
|
@@ -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,18 +1,18 @@
|
|
|
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;
|
|
13
13
|
right?: Space;
|
|
14
14
|
};
|
|
15
|
-
declare type SVG = React.SVGProps<SVGSVGElement>;
|
|
15
|
+
declare type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
|
|
16
16
|
declare type Props = {
|
|
17
17
|
/**
|
|
18
18
|
* The panel label.
|
|
@@ -56,6 +56,7 @@ declare type Props = {
|
|
|
56
56
|
*/
|
|
57
57
|
margin?: Space | Margin;
|
|
58
58
|
/**
|
|
59
|
+
* @deprecated This prop will be removed shortly, consider using the Inset component for this purpose.
|
|
59
60
|
* Size of the padding to be applied to the custom area ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
|
|
60
61
|
* You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different padding sizes.
|
|
61
62
|
*/
|
|
@@ -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
|
+
);
|