@commercetools-uikit/collapsible-panel 19.20.1 → 19.22.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.
|
@@ -2,6 +2,16 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
+
var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
|
|
6
|
+
var _Object$getOwnPropertySymbols = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols');
|
|
7
|
+
var _filterInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/filter');
|
|
8
|
+
var _Object$getOwnPropertyDescriptor = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor');
|
|
9
|
+
var _forEachInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/for-each');
|
|
10
|
+
var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
|
|
11
|
+
var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
|
|
12
|
+
var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
|
|
13
|
+
var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
14
|
+
var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
|
|
5
15
|
var _styled = require('@emotion/styled/base');
|
|
6
16
|
var _pt = require('prop-types');
|
|
7
17
|
var react$1 = require('react');
|
|
@@ -20,6 +30,14 @@ var jsxRuntime = require('@emotion/react/jsx-runtime');
|
|
|
20
30
|
|
|
21
31
|
function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
|
|
22
32
|
|
|
33
|
+
var _Object$keys__default = /*#__PURE__*/_interopDefault(_Object$keys);
|
|
34
|
+
var _Object$getOwnPropertySymbols__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertySymbols);
|
|
35
|
+
var _filterInstanceProperty__default = /*#__PURE__*/_interopDefault(_filterInstanceProperty);
|
|
36
|
+
var _Object$getOwnPropertyDescriptor__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptor);
|
|
37
|
+
var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachInstanceProperty);
|
|
38
|
+
var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
|
|
39
|
+
var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
|
|
40
|
+
var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
|
|
23
41
|
var _styled__default = /*#__PURE__*/_interopDefault(_styled);
|
|
24
42
|
var _pt__default = /*#__PURE__*/_interopDefault(_pt);
|
|
25
43
|
var isNil__default = /*#__PURE__*/_interopDefault(isNil);
|
|
@@ -29,6 +47,7 @@ var Text__default = /*#__PURE__*/_interopDefault(Text);
|
|
|
29
47
|
var CollapsibleMotion__default = /*#__PURE__*/_interopDefault(CollapsibleMotion);
|
|
30
48
|
var Constraints__default = /*#__PURE__*/_interopDefault(Constraints);
|
|
31
49
|
|
|
50
|
+
const _excluded$1 = ["tone"];
|
|
32
51
|
function _EMOTION_STRINGIFIED_CSS_ERROR__$1() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
33
52
|
const getArrowColor = _ref2 => {
|
|
34
53
|
let tone = _ref2.tone,
|
|
@@ -43,21 +62,24 @@ var _ref$1 = process.env.NODE_ENV === "production" ? {
|
|
|
43
62
|
} : {
|
|
44
63
|
name: "den7ns-HeaderIcon",
|
|
45
64
|
styles: "display:flex;align-items:center;justify-content:center;label:HeaderIcon;",
|
|
46
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhlYWRlci1pY29uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QlciLCJmaWxlIjoiaGVhZGVyLWljb24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgeyBBbmdsZURvd25JY29uLCBBbmdsZVJpZ2h0SWNvbiB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2ljb25zJztcblxuY29uc3QgZ2V0QXJyb3dDb2xvciA9ICh7XG4gIHRvbmUsXG4gIGlzRGlzYWJsZWQsXG59OiBQaWNrPFRIZWFkZXJJY29uLCAnaXNEaXNhYmxlZCcgfCAndG9uZSc+KSA9PiB7XG4gIGlmIChpc0Rpc2FibGVkKSByZXR1cm4gJ25ldXRyYWw2MCc7XG4gIGlmICh0b25lID09PSAndXJnZW50JykgcmV0dXJuICd3YXJuaW5nJztcblxuICByZXR1cm4gJ3NvbGlkJztcbn07XG5cbnR5cGUgVEhlYWRlckljb24gPSB7XG4gIHRvbmU/
|
|
65
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhlYWRlci1pY29uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QlciLCJmaWxlIjoiaGVhZGVyLWljb24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgeyBBbmdsZURvd25JY29uLCBBbmdsZVJpZ2h0SWNvbiB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2ljb25zJztcblxuY29uc3QgZ2V0QXJyb3dDb2xvciA9ICh7XG4gIHRvbmUsXG4gIGlzRGlzYWJsZWQsXG59OiBQaWNrPFRIZWFkZXJJY29uLCAnaXNEaXNhYmxlZCcgfCAndG9uZSc+KSA9PiB7XG4gIGlmIChpc0Rpc2FibGVkKSByZXR1cm4gJ25ldXRyYWw2MCc7XG4gIGlmICh0b25lID09PSAndXJnZW50JykgcmV0dXJuICd3YXJuaW5nJztcblxuICByZXR1cm4gJ3NvbGlkJztcbn07XG5cbnR5cGUgVEhlYWRlckljb24gPSB7XG4gIHRvbmU/OiAndXJnZW50JyB8ICdwcmltYXJ5JztcbiAgaXNDbG9zZWQ6IGJvb2xlYW47XG4gIGlzRGlzYWJsZWQ6IGJvb2xlYW47XG4gIHNpemU6ICdzbWFsbCcgfCAnbWVkaXVtJyB8ICdiaWcnIHwgJ3NjYWxlJztcbn07XG5cbmNvbnN0IEhlYWRlckljb24gPSAoeyB0b25lID0gJ3ByaW1hcnknLCAuLi5wcm9wcyB9OiBUSGVhZGVySWNvbikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXZcbiAgICAgIGNzcz17W1xuICAgICAgICBjc3NgXG4gICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICAgIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICAgICAgICBgLFxuICAgICAgICBwcm9wcy5pc0Rpc2FibGVkICYmXG4gICAgICAgICAgY3NzYFxuICAgICAgICAgICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICAgICAgICAgIGJvcmRlcjogbm9uZTtcbiAgICAgICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gICAgICAgICAgYCxcbiAgICAgIF19XG4gICAgPlxuICAgICAge3Byb3BzLmlzQ2xvc2VkID8gKFxuICAgICAgICA8QW5nbGVSaWdodEljb25cbiAgICAgICAgICBjb2xvcj17Z2V0QXJyb3dDb2xvcih7XG4gICAgICAgICAgICB0b25lOiB0b25lLFxuICAgICAgICAgICAgaXNEaXNhYmxlZDogcHJvcHMuaXNEaXNhYmxlZCxcbiAgICAgICAgICB9KX1cbiAgICAgICAgICBzaXplPXtwcm9wcy5zaXplfVxuICAgICAgICAvPlxuICAgICAgKSA6IChcbiAgICAgICAgPEFuZ2xlRG93bkljb25cbiAgICAgICAgICBjb2xvcj17Z2V0QXJyb3dDb2xvcih7XG4gICAgICAgICAgICB0b25lOiB0b25lLFxuICAgICAgICAgICAgaXNEaXNhYmxlZDogcHJvcHMuaXNEaXNhYmxlZCxcbiAgICAgICAgICB9KX1cbiAgICAgICAgICBzaXplPXtwcm9wcy5zaXplfVxuICAgICAgICAvPlxuICAgICAgKX1cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbkhlYWRlckljb24uZGlzcGxheU5hbWUgPSAnSGVhZGVySWNvbic7XG5cbmV4cG9ydCBkZWZhdWx0IEhlYWRlckljb247XG4iXX0= */",
|
|
47
66
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
48
67
|
};
|
|
49
|
-
const HeaderIcon =
|
|
68
|
+
const HeaderIcon = _ref3 => {
|
|
69
|
+
let _ref3$tone = _ref3.tone,
|
|
70
|
+
tone = _ref3$tone === void 0 ? 'primary' : _ref3$tone,
|
|
71
|
+
props = _objectWithoutProperties(_ref3, _excluded$1);
|
|
50
72
|
return jsxRuntime.jsx("div", {
|
|
51
|
-
css: [_ref$1, props.isDisabled && /*#__PURE__*/react.css("box-shadow:none;border:none;background-color:", designSystem.designTokens.colorSurface, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:HeaderIcon;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhlYWRlci1pY29uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErQmEiLCJmaWxlIjoiaGVhZGVyLWljb24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgeyBBbmdsZURvd25JY29uLCBBbmdsZVJpZ2h0SWNvbiB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2ljb25zJztcblxuY29uc3QgZ2V0QXJyb3dDb2xvciA9ICh7XG4gIHRvbmUsXG4gIGlzRGlzYWJsZWQsXG59OiBQaWNrPFRIZWFkZXJJY29uLCAnaXNEaXNhYmxlZCcgfCAndG9uZSc+KSA9PiB7XG4gIGlmIChpc0Rpc2FibGVkKSByZXR1cm4gJ25ldXRyYWw2MCc7XG4gIGlmICh0b25lID09PSAndXJnZW50JykgcmV0dXJuICd3YXJuaW5nJztcblxuICByZXR1cm4gJ3NvbGlkJztcbn07XG5cbnR5cGUgVEhlYWRlckljb24gPSB7XG4gIHRvbmU/
|
|
73
|
+
css: [_ref$1, props.isDisabled && /*#__PURE__*/react.css("box-shadow:none;border:none;background-color:", designSystem.designTokens.colorSurface, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:HeaderIcon;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhlYWRlci1pY29uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErQmEiLCJmaWxlIjoiaGVhZGVyLWljb24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgeyBBbmdsZURvd25JY29uLCBBbmdsZVJpZ2h0SWNvbiB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2ljb25zJztcblxuY29uc3QgZ2V0QXJyb3dDb2xvciA9ICh7XG4gIHRvbmUsXG4gIGlzRGlzYWJsZWQsXG59OiBQaWNrPFRIZWFkZXJJY29uLCAnaXNEaXNhYmxlZCcgfCAndG9uZSc+KSA9PiB7XG4gIGlmIChpc0Rpc2FibGVkKSByZXR1cm4gJ25ldXRyYWw2MCc7XG4gIGlmICh0b25lID09PSAndXJnZW50JykgcmV0dXJuICd3YXJuaW5nJztcblxuICByZXR1cm4gJ3NvbGlkJztcbn07XG5cbnR5cGUgVEhlYWRlckljb24gPSB7XG4gIHRvbmU/OiAndXJnZW50JyB8ICdwcmltYXJ5JztcbiAgaXNDbG9zZWQ6IGJvb2xlYW47XG4gIGlzRGlzYWJsZWQ6IGJvb2xlYW47XG4gIHNpemU6ICdzbWFsbCcgfCAnbWVkaXVtJyB8ICdiaWcnIHwgJ3NjYWxlJztcbn07XG5cbmNvbnN0IEhlYWRlckljb24gPSAoeyB0b25lID0gJ3ByaW1hcnknLCAuLi5wcm9wcyB9OiBUSGVhZGVySWNvbikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXZcbiAgICAgIGNzcz17W1xuICAgICAgICBjc3NgXG4gICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICAgIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICAgICAgICBgLFxuICAgICAgICBwcm9wcy5pc0Rpc2FibGVkICYmXG4gICAgICAgICAgY3NzYFxuICAgICAgICAgICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICAgICAgICAgIGJvcmRlcjogbm9uZTtcbiAgICAgICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gICAgICAgICAgYCxcbiAgICAgIF19XG4gICAgPlxuICAgICAge3Byb3BzLmlzQ2xvc2VkID8gKFxuICAgICAgICA8QW5nbGVSaWdodEljb25cbiAgICAgICAgICBjb2xvcj17Z2V0QXJyb3dDb2xvcih7XG4gICAgICAgICAgICB0b25lOiB0b25lLFxuICAgICAgICAgICAgaXNEaXNhYmxlZDogcHJvcHMuaXNEaXNhYmxlZCxcbiAgICAgICAgICB9KX1cbiAgICAgICAgICBzaXplPXtwcm9wcy5zaXplfVxuICAgICAgICAvPlxuICAgICAgKSA6IChcbiAgICAgICAgPEFuZ2xlRG93bkljb25cbiAgICAgICAgICBjb2xvcj17Z2V0QXJyb3dDb2xvcih7XG4gICAgICAgICAgICB0b25lOiB0b25lLFxuICAgICAgICAgICAgaXNEaXNhYmxlZDogcHJvcHMuaXNEaXNhYmxlZCxcbiAgICAgICAgICB9KX1cbiAgICAgICAgICBzaXplPXtwcm9wcy5zaXplfVxuICAgICAgICAvPlxuICAgICAgKX1cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbkhlYWRlckljb24uZGlzcGxheU5hbWUgPSAnSGVhZGVySWNvbic7XG5cbmV4cG9ydCBkZWZhdWx0IEhlYWRlckljb247XG4iXX0= */"), process.env.NODE_ENV === "production" ? "" : ";label:HeaderIcon;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhlYWRlci1pY29uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3Qk0iLCJmaWxlIjoiaGVhZGVyLWljb24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgeyBBbmdsZURvd25JY29uLCBBbmdsZVJpZ2h0SWNvbiB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2ljb25zJztcblxuY29uc3QgZ2V0QXJyb3dDb2xvciA9ICh7XG4gIHRvbmUsXG4gIGlzRGlzYWJsZWQsXG59OiBQaWNrPFRIZWFkZXJJY29uLCAnaXNEaXNhYmxlZCcgfCAndG9uZSc+KSA9PiB7XG4gIGlmIChpc0Rpc2FibGVkKSByZXR1cm4gJ25ldXRyYWw2MCc7XG4gIGlmICh0b25lID09PSAndXJnZW50JykgcmV0dXJuICd3YXJuaW5nJztcblxuICByZXR1cm4gJ3NvbGlkJztcbn07XG5cbnR5cGUgVEhlYWRlckljb24gPSB7XG4gIHRvbmU/OiAndXJnZW50JyB8ICdwcmltYXJ5JztcbiAgaXNDbG9zZWQ6IGJvb2xlYW47XG4gIGlzRGlzYWJsZWQ6IGJvb2xlYW47XG4gIHNpemU6ICdzbWFsbCcgfCAnbWVkaXVtJyB8ICdiaWcnIHwgJ3NjYWxlJztcbn07XG5cbmNvbnN0IEhlYWRlckljb24gPSAoeyB0b25lID0gJ3ByaW1hcnknLCAuLi5wcm9wcyB9OiBUSGVhZGVySWNvbikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXZcbiAgICAgIGNzcz17W1xuICAgICAgICBjc3NgXG4gICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICAgIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICAgICAgICBgLFxuICAgICAgICBwcm9wcy5pc0Rpc2FibGVkICYmXG4gICAgICAgICAgY3NzYFxuICAgICAgICAgICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICAgICAgICAgIGJvcmRlcjogbm9uZTtcbiAgICAgICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gICAgICAgICAgYCxcbiAgICAgIF19XG4gICAgPlxuICAgICAge3Byb3BzLmlzQ2xvc2VkID8gKFxuICAgICAgICA8QW5nbGVSaWdodEljb25cbiAgICAgICAgICBjb2xvcj17Z2V0QXJyb3dDb2xvcih7XG4gICAgICAgICAgICB0b25lOiB0b25lLFxuICAgICAgICAgICAgaXNEaXNhYmxlZDogcHJvcHMuaXNEaXNhYmxlZCxcbiAgICAgICAgICB9KX1cbiAgICAgICAgICBzaXplPXtwcm9wcy5zaXplfVxuICAgICAgICAvPlxuICAgICAgKSA6IChcbiAgICAgICAgPEFuZ2xlRG93bkljb25cbiAgICAgICAgICBjb2xvcj17Z2V0QXJyb3dDb2xvcih7XG4gICAgICAgICAgICB0b25lOiB0b25lLFxuICAgICAgICAgICAgaXNEaXNhYmxlZDogcHJvcHMuaXNEaXNhYmxlZCxcbiAgICAgICAgICB9KX1cbiAgICAgICAgICBzaXplPXtwcm9wcy5zaXplfVxuICAgICAgICAvPlxuICAgICAgKX1cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbkhlYWRlckljb24uZGlzcGxheU5hbWUgPSAnSGVhZGVySWNvbic7XG5cbmV4cG9ydCBkZWZhdWx0IEhlYWRlckljb247XG4iXX0= */"],
|
|
52
74
|
children: props.isClosed ? jsxRuntime.jsx(icons.AngleRightIcon, {
|
|
53
75
|
color: getArrowColor({
|
|
54
|
-
tone:
|
|
76
|
+
tone: tone,
|
|
55
77
|
isDisabled: props.isDisabled
|
|
56
78
|
}),
|
|
57
79
|
size: props.size
|
|
58
80
|
}) : jsxRuntime.jsx(icons.AngleDownIcon, {
|
|
59
81
|
color: getArrowColor({
|
|
60
|
-
tone:
|
|
82
|
+
tone: tone,
|
|
61
83
|
isDisabled: props.isDisabled
|
|
62
84
|
}),
|
|
63
85
|
size: props.size
|
|
@@ -65,9 +87,6 @@ const HeaderIcon = props => {
|
|
|
65
87
|
});
|
|
66
88
|
};
|
|
67
89
|
HeaderIcon.displayName = 'HeaderIcon';
|
|
68
|
-
HeaderIcon.defaultProps = {
|
|
69
|
-
tone: 'primary'
|
|
70
|
-
};
|
|
71
90
|
var HeaderIcon$1 = HeaderIcon;
|
|
72
91
|
|
|
73
92
|
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
@@ -146,21 +165,17 @@ CollapsiblePanelHeader.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
146
165
|
CollapsiblePanelHeader.displayName = 'CollapsiblePanelHeader';
|
|
147
166
|
var CollapsiblePanelHeader$1 = CollapsiblePanelHeader;
|
|
148
167
|
|
|
168
|
+
const _excluded = ["theme", "condensed", "isDisabled", "headerControlsAlignment", "horizontalConstraint"];
|
|
169
|
+
function ownKeys(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
170
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
149
171
|
const HeaderContainer = /*#__PURE__*/_styled__default["default"](AccessibleButton__default["default"], process.env.NODE_ENV === "production" ? {
|
|
150
172
|
target: "e1923bli0"
|
|
151
173
|
} : {
|
|
152
174
|
target: "e1923bli0",
|
|
153
175
|
label: "HeaderContainer"
|
|
154
|
-
})(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AA0BgD","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, cloneElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {/* TODO: this is a temporary fix, which will be refactored after we align with the desing team on how to proceed */}\n      {typeof props.header === 'string'\n        ? props.header\n        : cloneElement(props.header as React.ReactElement, {\n            isCondensed: props.condensed,\n          })}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(props, isOpen),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={props.isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText\n                    header={props.header}\n                    condensed={props.condensed}\n                  />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={props.condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */");
|
|
176
|
+
})(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AA0BgD","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, cloneElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {/* TODO: this is a temporary fix, which will be refactored after we align with the desing team on how to proceed */}\n      {typeof props.header === 'string'\n        ? props.header\n        : cloneElement(props.header as React.ReactElement, {\n            isCondensed: props.condensed,\n          })}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = ({\n  theme = 'dark',\n  condensed = false,\n  isDisabled = false,\n  headerControlsAlignment = 'right',\n  horizontalConstraint = 'scale',\n  ...props\n}: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes({\n    theme,\n    condensed,\n    isDisabled,\n    headerControlsAlignment,\n    horizontalConstraint,\n    ...props,\n  });\n  const scale = condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(\n                  {\n                    condensed,\n                    isDisabled,\n                    headerControlsAlignment,\n                    ...props,\n                  },\n                  isOpen\n                ),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={isDisabled ? undefined : toggle}\n              isDisabled={isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText header={props.header} condensed={condensed} />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */");
|
|
155
177
|
const panelButtonSequentialId = utils.createSequentialId('collapsible-panel-button-');
|
|
156
178
|
const panelContentSequentialId = utils.createSequentialId('collapsible-panel-content-');
|
|
157
|
-
const defaultProps = {
|
|
158
|
-
theme: 'dark',
|
|
159
|
-
condensed: false,
|
|
160
|
-
isDisabled: false,
|
|
161
|
-
headerControlsAlignment: 'right',
|
|
162
|
-
horizontalConstraint: 'scale'
|
|
163
|
-
};
|
|
164
179
|
const HeadLineText = props => {
|
|
165
180
|
if (!props.condensed) {
|
|
166
181
|
return jsxRuntime.jsx(jsxRuntime.Fragment, {
|
|
@@ -178,12 +193,29 @@ const HeadLineText = props => {
|
|
|
178
193
|
|
|
179
194
|
// When `isClosed` is provided the component behaves as a controlled component,
|
|
180
195
|
// otherwise it will behave like an uncontrolled component.
|
|
181
|
-
const CollapsiblePanel =
|
|
196
|
+
const CollapsiblePanel = _ref => {
|
|
197
|
+
let _ref$theme = _ref.theme,
|
|
198
|
+
theme = _ref$theme === void 0 ? 'dark' : _ref$theme,
|
|
199
|
+
_ref$condensed = _ref.condensed,
|
|
200
|
+
condensed = _ref$condensed === void 0 ? false : _ref$condensed,
|
|
201
|
+
_ref$isDisabled = _ref.isDisabled,
|
|
202
|
+
isDisabled = _ref$isDisabled === void 0 ? false : _ref$isDisabled,
|
|
203
|
+
_ref$headerControlsAl = _ref.headerControlsAlignment,
|
|
204
|
+
headerControlsAlignment = _ref$headerControlsAl === void 0 ? 'right' : _ref$headerControlsAl,
|
|
205
|
+
_ref$horizontalConstr = _ref.horizontalConstraint,
|
|
206
|
+
horizontalConstraint = _ref$horizontalConstr === void 0 ? 'scale' : _ref$horizontalConstr,
|
|
207
|
+
props = _objectWithoutProperties(_ref, _excluded);
|
|
182
208
|
const panelButtonId = hooks.useFieldId(props.id, panelButtonSequentialId);
|
|
183
209
|
const panelContentId = hooks.useFieldId(undefined, panelContentSequentialId);
|
|
184
210
|
// Pass only `data-*` props
|
|
185
|
-
const dataProps = utils.filterDataAttributes(
|
|
186
|
-
|
|
211
|
+
const dataProps = utils.filterDataAttributes(_objectSpread({
|
|
212
|
+
theme,
|
|
213
|
+
condensed,
|
|
214
|
+
isDisabled,
|
|
215
|
+
headerControlsAlignment,
|
|
216
|
+
horizontalConstraint
|
|
217
|
+
}, props));
|
|
218
|
+
const scale = condensed ? 's' : 'm';
|
|
187
219
|
const isClosedAndIsDefaultClosed = !isNil__default["default"](props.isClosed) && !isNil__default["default"](props.isDefaultClosed);
|
|
188
220
|
process.env.NODE_ENV !== "production" ? utils.warning(!isClosedAndIsDefaultClosed, `Invalid prop \`isDefaultClosed\` supplied to \`CollapsiblePanel\`. Component must either be controlled or uncontrolled. Pass either \`isClosed\` or \`isDefaultClosed\` but not both.`) : void 0;
|
|
189
221
|
const hasOnToggle = !isNil__default["default"](props.onToggle);
|
|
@@ -202,15 +234,15 @@ const CollapsiblePanel = props => {
|
|
|
202
234
|
isClosed: props.isClosed,
|
|
203
235
|
onToggle: props.onToggle,
|
|
204
236
|
isDefaultClosed: props.isDefaultClosed,
|
|
205
|
-
children:
|
|
206
|
-
let isOpen =
|
|
207
|
-
toggle =
|
|
208
|
-
containerStyles =
|
|
209
|
-
registerContentNode =
|
|
237
|
+
children: _ref2 => {
|
|
238
|
+
let isOpen = _ref2.isOpen,
|
|
239
|
+
toggle = _ref2.toggle,
|
|
240
|
+
containerStyles = _ref2.containerStyles,
|
|
241
|
+
registerContentNode = _ref2.registerContentNode;
|
|
210
242
|
return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
|
|
211
|
-
max:
|
|
243
|
+
max: horizontalConstraint,
|
|
212
244
|
children: jsxRuntime.jsxs("div", {
|
|
213
|
-
css: [baseContainerStyles, getThemeStyle('light'), process.env.NODE_ENV === "production" ? "" : ";label:CollapsiblePanel;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AAkNY","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, cloneElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {/* TODO: this is a temporary fix, which will be refactored after we align with the desing team on how to proceed */}\n      {typeof props.header === 'string'\n        ? props.header\n        : cloneElement(props.header as React.ReactElement, {\n            isCondensed: props.condensed,\n          })}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(props, isOpen),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={props.isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText\n                    header={props.header}\n                    condensed={props.condensed}\n                  />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={props.condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"]
|
|
245
|
+
css: [baseContainerStyles, getThemeStyle('light'), process.env.NODE_ENV === "production" ? "" : ";label:CollapsiblePanel;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AAiNY","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, cloneElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {/* TODO: this is a temporary fix, which will be refactored after we align with the desing team on how to proceed */}\n      {typeof props.header === 'string'\n        ? props.header\n        : cloneElement(props.header as React.ReactElement, {\n            isCondensed: props.condensed,\n          })}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = ({\n  theme = 'dark',\n  condensed = false,\n  isDisabled = false,\n  headerControlsAlignment = 'right',\n  horizontalConstraint = 'scale',\n  ...props\n}: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes({\n    theme,\n    condensed,\n    isDisabled,\n    headerControlsAlignment,\n    horizontalConstraint,\n    ...props,\n  });\n  const scale = condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(\n                  {\n                    condensed,\n                    isDisabled,\n                    headerControlsAlignment,\n                    ...props,\n                  },\n                  isOpen\n                ),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={isDisabled ? undefined : toggle}\n              isDisabled={isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText header={props.header} condensed={condensed} />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"]
|
|
214
246
|
// Allow to override the styles by passing a `className` prop.
|
|
215
247
|
// Custom styles can also be passed using the `css` prop from emotion.
|
|
216
248
|
// https://emotion.sh/docs/css-prop#style-precedence
|
|
@@ -218,11 +250,15 @@ const CollapsiblePanel = props => {
|
|
|
218
250
|
className: props.className,
|
|
219
251
|
children: [jsxRuntime.jsxs(HeaderContainer, {
|
|
220
252
|
as: "div",
|
|
221
|
-
css: [getHeaderContainerStyles(props, isOpen), getThemeStyle('light'), process.env.NODE_ENV === "production" ? "" : ";label:CollapsiblePanel;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AA0Nc","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, cloneElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {/* TODO: this is a temporary fix, which will be refactored after we align with the desing team on how to proceed */}\n      {typeof props.header === 'string'\n        ? props.header\n        : cloneElement(props.header as React.ReactElement, {\n            isCondensed: props.condensed,\n          })}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(props, isOpen),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={props.isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText\n                    header={props.header}\n                    condensed={props.condensed}\n                  />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={props.condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"],
|
|
253
|
+
css: [getHeaderContainerStyles(_objectSpread({
|
|
254
|
+
condensed,
|
|
255
|
+
isDisabled,
|
|
256
|
+
headerControlsAlignment
|
|
257
|
+
}, props), isOpen), getThemeStyle('light'), process.env.NODE_ENV === "production" ? "" : ";label:CollapsiblePanel;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AAyNc","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, cloneElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {/* TODO: this is a temporary fix, which will be refactored after we align with the desing team on how to proceed */}\n      {typeof props.header === 'string'\n        ? props.header\n        : cloneElement(props.header as React.ReactElement, {\n            isCondensed: props.condensed,\n          })}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = ({\n  theme = 'dark',\n  condensed = false,\n  isDisabled = false,\n  headerControlsAlignment = 'right',\n  horizontalConstraint = 'scale',\n  ...props\n}: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes({\n    theme,\n    condensed,\n    isDisabled,\n    headerControlsAlignment,\n    horizontalConstraint,\n    ...props,\n  });\n  const scale = condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(\n                  {\n                    condensed,\n                    isDisabled,\n                    headerControlsAlignment,\n                    ...props,\n                  },\n                  isOpen\n                ),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={isDisabled ? undefined : toggle}\n              isDisabled={isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText header={props.header} condensed={condensed} />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"],
|
|
222
258
|
id: panelButtonId,
|
|
223
259
|
label: "",
|
|
224
|
-
onClick:
|
|
225
|
-
isDisabled:
|
|
260
|
+
onClick: isDisabled ? undefined : toggle,
|
|
261
|
+
isDisabled: isDisabled,
|
|
226
262
|
buttonAttributes: dataProps,
|
|
227
263
|
"aria-controls": panelContentId,
|
|
228
264
|
"aria-expanded": isOpen ? 'true' : 'false',
|
|
@@ -231,7 +267,7 @@ const CollapsiblePanel = props => {
|
|
|
231
267
|
scale: "xs",
|
|
232
268
|
children: [!props.hideExpansionControls && jsxRuntime.jsx(HeaderIcon$1, {
|
|
233
269
|
isClosed: !isOpen,
|
|
234
|
-
isDisabled:
|
|
270
|
+
isDisabled: isDisabled || false,
|
|
235
271
|
tone: props.tone,
|
|
236
272
|
size: 'medium'
|
|
237
273
|
}), jsxRuntime.jsxs(Spacings__default["default"].Inline, {
|
|
@@ -239,7 +275,7 @@ const CollapsiblePanel = props => {
|
|
|
239
275
|
scale: scale,
|
|
240
276
|
children: [jsxRuntime.jsx(HeadLineText, {
|
|
241
277
|
header: props.header,
|
|
242
|
-
condensed:
|
|
278
|
+
condensed: condensed
|
|
243
279
|
}), props.secondaryHeader && jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
244
280
|
tone: "secondary",
|
|
245
281
|
truncate: true,
|
|
@@ -256,7 +292,7 @@ const CollapsiblePanel = props => {
|
|
|
256
292
|
// @ts-ignore
|
|
257
293
|
, {
|
|
258
294
|
ref: registerContentNode,
|
|
259
|
-
condensed:
|
|
295
|
+
condensed: condensed,
|
|
260
296
|
isExpandControlHidden: props.hideExpansionControls,
|
|
261
297
|
children: [props.description && jsxRuntime.jsx(SectionDescriptionWrapper, {
|
|
262
298
|
children: jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
@@ -306,12 +342,11 @@ CollapsiblePanel.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
306
342
|
} : {};
|
|
307
343
|
CollapsiblePanel.getPanelContentId = () => '';
|
|
308
344
|
CollapsiblePanel.displayName = 'CollapsiblePanel';
|
|
309
|
-
CollapsiblePanel.defaultProps = defaultProps;
|
|
310
345
|
CollapsiblePanel.Header = CollapsiblePanelHeader$1;
|
|
311
346
|
var CollapsiblePanel$1 = CollapsiblePanel;
|
|
312
347
|
|
|
313
348
|
// NOTE: This string will be replaced on build time with the package version.
|
|
314
|
-
var version = "19.
|
|
349
|
+
var version = "19.22.0";
|
|
315
350
|
|
|
316
351
|
exports["default"] = CollapsiblePanel$1;
|
|
317
352
|
exports.version = version;
|
|
@@ -2,6 +2,16 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
+
var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
|
|
6
|
+
var _Object$getOwnPropertySymbols = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols');
|
|
7
|
+
var _filterInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/filter');
|
|
8
|
+
var _Object$getOwnPropertyDescriptor = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor');
|
|
9
|
+
var _forEachInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/for-each');
|
|
10
|
+
var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
|
|
11
|
+
var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
|
|
12
|
+
var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
|
|
13
|
+
var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
14
|
+
var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
|
|
5
15
|
var _styled = require('@emotion/styled/base');
|
|
6
16
|
require('prop-types');
|
|
7
17
|
var react$1 = require('react');
|
|
@@ -20,6 +30,14 @@ var jsxRuntime = require('@emotion/react/jsx-runtime');
|
|
|
20
30
|
|
|
21
31
|
function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
|
|
22
32
|
|
|
33
|
+
var _Object$keys__default = /*#__PURE__*/_interopDefault(_Object$keys);
|
|
34
|
+
var _Object$getOwnPropertySymbols__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertySymbols);
|
|
35
|
+
var _filterInstanceProperty__default = /*#__PURE__*/_interopDefault(_filterInstanceProperty);
|
|
36
|
+
var _Object$getOwnPropertyDescriptor__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptor);
|
|
37
|
+
var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachInstanceProperty);
|
|
38
|
+
var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
|
|
39
|
+
var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
|
|
40
|
+
var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
|
|
23
41
|
var _styled__default = /*#__PURE__*/_interopDefault(_styled);
|
|
24
42
|
var isNil__default = /*#__PURE__*/_interopDefault(isNil);
|
|
25
43
|
var AccessibleButton__default = /*#__PURE__*/_interopDefault(AccessibleButton);
|
|
@@ -28,6 +46,7 @@ var Text__default = /*#__PURE__*/_interopDefault(Text);
|
|
|
28
46
|
var CollapsibleMotion__default = /*#__PURE__*/_interopDefault(CollapsibleMotion);
|
|
29
47
|
var Constraints__default = /*#__PURE__*/_interopDefault(Constraints);
|
|
30
48
|
|
|
49
|
+
const _excluded$1 = ["tone"];
|
|
31
50
|
const getArrowColor = _ref2 => {
|
|
32
51
|
let tone = _ref2.tone,
|
|
33
52
|
isDisabled = _ref2.isDisabled;
|
|
@@ -39,18 +58,21 @@ var _ref$1 = {
|
|
|
39
58
|
name: "1wnowod",
|
|
40
59
|
styles: "display:flex;align-items:center;justify-content:center"
|
|
41
60
|
} ;
|
|
42
|
-
const HeaderIcon =
|
|
61
|
+
const HeaderIcon = _ref3 => {
|
|
62
|
+
let _ref3$tone = _ref3.tone,
|
|
63
|
+
tone = _ref3$tone === void 0 ? 'primary' : _ref3$tone,
|
|
64
|
+
props = _objectWithoutProperties(_ref3, _excluded$1);
|
|
43
65
|
return jsxRuntime.jsx("div", {
|
|
44
66
|
css: [_ref$1, props.isDisabled && /*#__PURE__*/react.css("box-shadow:none;border:none;background-color:", designSystem.designTokens.colorSurface, ";" + ("" ), "" ), "" , "" ],
|
|
45
67
|
children: props.isClosed ? jsxRuntime.jsx(icons.AngleRightIcon, {
|
|
46
68
|
color: getArrowColor({
|
|
47
|
-
tone:
|
|
69
|
+
tone: tone,
|
|
48
70
|
isDisabled: props.isDisabled
|
|
49
71
|
}),
|
|
50
72
|
size: props.size
|
|
51
73
|
}) : jsxRuntime.jsx(icons.AngleDownIcon, {
|
|
52
74
|
color: getArrowColor({
|
|
53
|
-
tone:
|
|
75
|
+
tone: tone,
|
|
54
76
|
isDisabled: props.isDisabled
|
|
55
77
|
}),
|
|
56
78
|
size: props.size
|
|
@@ -58,9 +80,6 @@ const HeaderIcon = props => {
|
|
|
58
80
|
});
|
|
59
81
|
};
|
|
60
82
|
HeaderIcon.displayName = 'HeaderIcon';
|
|
61
|
-
HeaderIcon.defaultProps = {
|
|
62
|
-
tone: 'primary'
|
|
63
|
-
};
|
|
64
83
|
var HeaderIcon$1 = HeaderIcon;
|
|
65
84
|
|
|
66
85
|
function getThemeStyle(theme) {
|
|
@@ -116,18 +135,14 @@ CollapsiblePanelHeader.propTypes = {};
|
|
|
116
135
|
CollapsiblePanelHeader.displayName = 'CollapsiblePanelHeader';
|
|
117
136
|
var CollapsiblePanelHeader$1 = CollapsiblePanelHeader;
|
|
118
137
|
|
|
138
|
+
const _excluded = ["theme", "condensed", "isDisabled", "headerControlsAlignment", "horizontalConstraint"];
|
|
139
|
+
function ownKeys(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
140
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
119
141
|
const HeaderContainer = /*#__PURE__*/_styled__default["default"](AccessibleButton__default["default"], {
|
|
120
142
|
target: "e1923bli0"
|
|
121
143
|
} )("" );
|
|
122
144
|
const panelButtonSequentialId = utils.createSequentialId('collapsible-panel-button-');
|
|
123
145
|
const panelContentSequentialId = utils.createSequentialId('collapsible-panel-content-');
|
|
124
|
-
const defaultProps = {
|
|
125
|
-
theme: 'dark',
|
|
126
|
-
condensed: false,
|
|
127
|
-
isDisabled: false,
|
|
128
|
-
headerControlsAlignment: 'right',
|
|
129
|
-
horizontalConstraint: 'scale'
|
|
130
|
-
};
|
|
131
146
|
const HeadLineText = props => {
|
|
132
147
|
if (!props.condensed) {
|
|
133
148
|
return jsxRuntime.jsx(jsxRuntime.Fragment, {
|
|
@@ -145,12 +160,29 @@ const HeadLineText = props => {
|
|
|
145
160
|
|
|
146
161
|
// When `isClosed` is provided the component behaves as a controlled component,
|
|
147
162
|
// otherwise it will behave like an uncontrolled component.
|
|
148
|
-
const CollapsiblePanel =
|
|
163
|
+
const CollapsiblePanel = _ref => {
|
|
164
|
+
let _ref$theme = _ref.theme,
|
|
165
|
+
theme = _ref$theme === void 0 ? 'dark' : _ref$theme,
|
|
166
|
+
_ref$condensed = _ref.condensed,
|
|
167
|
+
condensed = _ref$condensed === void 0 ? false : _ref$condensed,
|
|
168
|
+
_ref$isDisabled = _ref.isDisabled,
|
|
169
|
+
isDisabled = _ref$isDisabled === void 0 ? false : _ref$isDisabled,
|
|
170
|
+
_ref$headerControlsAl = _ref.headerControlsAlignment,
|
|
171
|
+
headerControlsAlignment = _ref$headerControlsAl === void 0 ? 'right' : _ref$headerControlsAl,
|
|
172
|
+
_ref$horizontalConstr = _ref.horizontalConstraint,
|
|
173
|
+
horizontalConstraint = _ref$horizontalConstr === void 0 ? 'scale' : _ref$horizontalConstr,
|
|
174
|
+
props = _objectWithoutProperties(_ref, _excluded);
|
|
149
175
|
const panelButtonId = hooks.useFieldId(props.id, panelButtonSequentialId);
|
|
150
176
|
const panelContentId = hooks.useFieldId(undefined, panelContentSequentialId);
|
|
151
177
|
// Pass only `data-*` props
|
|
152
|
-
const dataProps = utils.filterDataAttributes(
|
|
153
|
-
|
|
178
|
+
const dataProps = utils.filterDataAttributes(_objectSpread({
|
|
179
|
+
theme,
|
|
180
|
+
condensed,
|
|
181
|
+
isDisabled,
|
|
182
|
+
headerControlsAlignment,
|
|
183
|
+
horizontalConstraint
|
|
184
|
+
}, props));
|
|
185
|
+
const scale = condensed ? 's' : 'm';
|
|
154
186
|
!isNil__default["default"](props.isClosed) && !isNil__default["default"](props.isDefaultClosed);
|
|
155
187
|
!isNil__default["default"](props.onToggle);
|
|
156
188
|
!isNil__default["default"](props.isClosed);
|
|
@@ -158,13 +190,13 @@ const CollapsiblePanel = props => {
|
|
|
158
190
|
isClosed: props.isClosed,
|
|
159
191
|
onToggle: props.onToggle,
|
|
160
192
|
isDefaultClosed: props.isDefaultClosed,
|
|
161
|
-
children:
|
|
162
|
-
let isOpen =
|
|
163
|
-
toggle =
|
|
164
|
-
containerStyles =
|
|
165
|
-
registerContentNode =
|
|
193
|
+
children: _ref2 => {
|
|
194
|
+
let isOpen = _ref2.isOpen,
|
|
195
|
+
toggle = _ref2.toggle,
|
|
196
|
+
containerStyles = _ref2.containerStyles,
|
|
197
|
+
registerContentNode = _ref2.registerContentNode;
|
|
166
198
|
return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
|
|
167
|
-
max:
|
|
199
|
+
max: horizontalConstraint,
|
|
168
200
|
children: jsxRuntime.jsxs("div", {
|
|
169
201
|
css: [baseContainerStyles, getThemeStyle('light'), "" , "" ]
|
|
170
202
|
// Allow to override the styles by passing a `className` prop.
|
|
@@ -174,11 +206,15 @@ const CollapsiblePanel = props => {
|
|
|
174
206
|
className: props.className,
|
|
175
207
|
children: [jsxRuntime.jsxs(HeaderContainer, {
|
|
176
208
|
as: "div",
|
|
177
|
-
css: [getHeaderContainerStyles(
|
|
209
|
+
css: [getHeaderContainerStyles(_objectSpread({
|
|
210
|
+
condensed,
|
|
211
|
+
isDisabled,
|
|
212
|
+
headerControlsAlignment
|
|
213
|
+
}, props), isOpen), getThemeStyle('light'), "" , "" ],
|
|
178
214
|
id: panelButtonId,
|
|
179
215
|
label: "",
|
|
180
|
-
onClick:
|
|
181
|
-
isDisabled:
|
|
216
|
+
onClick: isDisabled ? undefined : toggle,
|
|
217
|
+
isDisabled: isDisabled,
|
|
182
218
|
buttonAttributes: dataProps,
|
|
183
219
|
"aria-controls": panelContentId,
|
|
184
220
|
"aria-expanded": isOpen ? 'true' : 'false',
|
|
@@ -187,7 +223,7 @@ const CollapsiblePanel = props => {
|
|
|
187
223
|
scale: "xs",
|
|
188
224
|
children: [!props.hideExpansionControls && jsxRuntime.jsx(HeaderIcon$1, {
|
|
189
225
|
isClosed: !isOpen,
|
|
190
|
-
isDisabled:
|
|
226
|
+
isDisabled: isDisabled || false,
|
|
191
227
|
tone: props.tone,
|
|
192
228
|
size: 'medium'
|
|
193
229
|
}), jsxRuntime.jsxs(Spacings__default["default"].Inline, {
|
|
@@ -195,7 +231,7 @@ const CollapsiblePanel = props => {
|
|
|
195
231
|
scale: scale,
|
|
196
232
|
children: [jsxRuntime.jsx(HeadLineText, {
|
|
197
233
|
header: props.header,
|
|
198
|
-
condensed:
|
|
234
|
+
condensed: condensed
|
|
199
235
|
}), props.secondaryHeader && jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
200
236
|
tone: "secondary",
|
|
201
237
|
truncate: true,
|
|
@@ -212,7 +248,7 @@ const CollapsiblePanel = props => {
|
|
|
212
248
|
// @ts-ignore
|
|
213
249
|
, {
|
|
214
250
|
ref: registerContentNode,
|
|
215
|
-
condensed:
|
|
251
|
+
condensed: condensed,
|
|
216
252
|
isExpandControlHidden: props.hideExpansionControls,
|
|
217
253
|
children: [props.description && jsxRuntime.jsx(SectionDescriptionWrapper, {
|
|
218
254
|
children: jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
@@ -243,12 +279,11 @@ const CollapsiblePanel = props => {
|
|
|
243
279
|
CollapsiblePanel.propTypes = {};
|
|
244
280
|
CollapsiblePanel.getPanelContentId = () => '';
|
|
245
281
|
CollapsiblePanel.displayName = 'CollapsiblePanel';
|
|
246
|
-
CollapsiblePanel.defaultProps = defaultProps;
|
|
247
282
|
CollapsiblePanel.Header = CollapsiblePanelHeader$1;
|
|
248
283
|
var CollapsiblePanel$1 = CollapsiblePanel;
|
|
249
284
|
|
|
250
285
|
// NOTE: This string will be replaced on build time with the package version.
|
|
251
|
-
var version = "19.
|
|
286
|
+
var version = "19.22.0";
|
|
252
287
|
|
|
253
288
|
exports["default"] = CollapsiblePanel$1;
|
|
254
289
|
exports.version = version;
|
|
@@ -1,3 +1,13 @@
|
|
|
1
|
+
import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys';
|
|
2
|
+
import _Object$getOwnPropertySymbols from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols';
|
|
3
|
+
import _filterInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/filter';
|
|
4
|
+
import _Object$getOwnPropertyDescriptor from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor';
|
|
5
|
+
import _forEachInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/for-each';
|
|
6
|
+
import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors';
|
|
7
|
+
import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties';
|
|
8
|
+
import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
|
|
9
|
+
import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
|
|
10
|
+
import _objectWithoutProperties from '@babel/runtime-corejs3/helpers/esm/objectWithoutProperties';
|
|
1
11
|
import _styled from '@emotion/styled/base';
|
|
2
12
|
import _pt from 'prop-types';
|
|
3
13
|
import { forwardRef, cloneElement } from 'react';
|
|
@@ -14,6 +24,7 @@ import { designTokens } from '@commercetools-uikit/design-system';
|
|
|
14
24
|
import { AngleRightIcon, AngleDownIcon } from '@commercetools-uikit/icons';
|
|
15
25
|
import { jsx, Fragment, jsxs } from '@emotion/react/jsx-runtime';
|
|
16
26
|
|
|
27
|
+
const _excluded$1 = ["tone"];
|
|
17
28
|
function _EMOTION_STRINGIFIED_CSS_ERROR__$1() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
18
29
|
const getArrowColor = _ref2 => {
|
|
19
30
|
let tone = _ref2.tone,
|
|
@@ -28,21 +39,24 @@ var _ref$1 = process.env.NODE_ENV === "production" ? {
|
|
|
28
39
|
} : {
|
|
29
40
|
name: "den7ns-HeaderIcon",
|
|
30
41
|
styles: "display:flex;align-items:center;justify-content:center;label:HeaderIcon;",
|
|
31
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhlYWRlci1pY29uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QlciLCJmaWxlIjoiaGVhZGVyLWljb24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgeyBBbmdsZURvd25JY29uLCBBbmdsZVJpZ2h0SWNvbiB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2ljb25zJztcblxuY29uc3QgZ2V0QXJyb3dDb2xvciA9ICh7XG4gIHRvbmUsXG4gIGlzRGlzYWJsZWQsXG59OiBQaWNrPFRIZWFkZXJJY29uLCAnaXNEaXNhYmxlZCcgfCAndG9uZSc+KSA9PiB7XG4gIGlmIChpc0Rpc2FibGVkKSByZXR1cm4gJ25ldXRyYWw2MCc7XG4gIGlmICh0b25lID09PSAndXJnZW50JykgcmV0dXJuICd3YXJuaW5nJztcblxuICByZXR1cm4gJ3NvbGlkJztcbn07XG5cbnR5cGUgVEhlYWRlckljb24gPSB7XG4gIHRvbmU/
|
|
42
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhlYWRlci1pY29uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QlciLCJmaWxlIjoiaGVhZGVyLWljb24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgeyBBbmdsZURvd25JY29uLCBBbmdsZVJpZ2h0SWNvbiB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2ljb25zJztcblxuY29uc3QgZ2V0QXJyb3dDb2xvciA9ICh7XG4gIHRvbmUsXG4gIGlzRGlzYWJsZWQsXG59OiBQaWNrPFRIZWFkZXJJY29uLCAnaXNEaXNhYmxlZCcgfCAndG9uZSc+KSA9PiB7XG4gIGlmIChpc0Rpc2FibGVkKSByZXR1cm4gJ25ldXRyYWw2MCc7XG4gIGlmICh0b25lID09PSAndXJnZW50JykgcmV0dXJuICd3YXJuaW5nJztcblxuICByZXR1cm4gJ3NvbGlkJztcbn07XG5cbnR5cGUgVEhlYWRlckljb24gPSB7XG4gIHRvbmU/OiAndXJnZW50JyB8ICdwcmltYXJ5JztcbiAgaXNDbG9zZWQ6IGJvb2xlYW47XG4gIGlzRGlzYWJsZWQ6IGJvb2xlYW47XG4gIHNpemU6ICdzbWFsbCcgfCAnbWVkaXVtJyB8ICdiaWcnIHwgJ3NjYWxlJztcbn07XG5cbmNvbnN0IEhlYWRlckljb24gPSAoeyB0b25lID0gJ3ByaW1hcnknLCAuLi5wcm9wcyB9OiBUSGVhZGVySWNvbikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXZcbiAgICAgIGNzcz17W1xuICAgICAgICBjc3NgXG4gICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICAgIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICAgICAgICBgLFxuICAgICAgICBwcm9wcy5pc0Rpc2FibGVkICYmXG4gICAgICAgICAgY3NzYFxuICAgICAgICAgICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICAgICAgICAgIGJvcmRlcjogbm9uZTtcbiAgICAgICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gICAgICAgICAgYCxcbiAgICAgIF19XG4gICAgPlxuICAgICAge3Byb3BzLmlzQ2xvc2VkID8gKFxuICAgICAgICA8QW5nbGVSaWdodEljb25cbiAgICAgICAgICBjb2xvcj17Z2V0QXJyb3dDb2xvcih7XG4gICAgICAgICAgICB0b25lOiB0b25lLFxuICAgICAgICAgICAgaXNEaXNhYmxlZDogcHJvcHMuaXNEaXNhYmxlZCxcbiAgICAgICAgICB9KX1cbiAgICAgICAgICBzaXplPXtwcm9wcy5zaXplfVxuICAgICAgICAvPlxuICAgICAgKSA6IChcbiAgICAgICAgPEFuZ2xlRG93bkljb25cbiAgICAgICAgICBjb2xvcj17Z2V0QXJyb3dDb2xvcih7XG4gICAgICAgICAgICB0b25lOiB0b25lLFxuICAgICAgICAgICAgaXNEaXNhYmxlZDogcHJvcHMuaXNEaXNhYmxlZCxcbiAgICAgICAgICB9KX1cbiAgICAgICAgICBzaXplPXtwcm9wcy5zaXplfVxuICAgICAgICAvPlxuICAgICAgKX1cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbkhlYWRlckljb24uZGlzcGxheU5hbWUgPSAnSGVhZGVySWNvbic7XG5cbmV4cG9ydCBkZWZhdWx0IEhlYWRlckljb247XG4iXX0= */",
|
|
32
43
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
33
44
|
};
|
|
34
|
-
const HeaderIcon =
|
|
45
|
+
const HeaderIcon = _ref3 => {
|
|
46
|
+
let _ref3$tone = _ref3.tone,
|
|
47
|
+
tone = _ref3$tone === void 0 ? 'primary' : _ref3$tone,
|
|
48
|
+
props = _objectWithoutProperties(_ref3, _excluded$1);
|
|
35
49
|
return jsx("div", {
|
|
36
|
-
css: [_ref$1, props.isDisabled && /*#__PURE__*/css("box-shadow:none;border:none;background-color:", designTokens.colorSurface, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:HeaderIcon;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhlYWRlci1pY29uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErQmEiLCJmaWxlIjoiaGVhZGVyLWljb24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgeyBBbmdsZURvd25JY29uLCBBbmdsZVJpZ2h0SWNvbiB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2ljb25zJztcblxuY29uc3QgZ2V0QXJyb3dDb2xvciA9ICh7XG4gIHRvbmUsXG4gIGlzRGlzYWJsZWQsXG59OiBQaWNrPFRIZWFkZXJJY29uLCAnaXNEaXNhYmxlZCcgfCAndG9uZSc+KSA9PiB7XG4gIGlmIChpc0Rpc2FibGVkKSByZXR1cm4gJ25ldXRyYWw2MCc7XG4gIGlmICh0b25lID09PSAndXJnZW50JykgcmV0dXJuICd3YXJuaW5nJztcblxuICByZXR1cm4gJ3NvbGlkJztcbn07XG5cbnR5cGUgVEhlYWRlckljb24gPSB7XG4gIHRvbmU/
|
|
50
|
+
css: [_ref$1, props.isDisabled && /*#__PURE__*/css("box-shadow:none;border:none;background-color:", designTokens.colorSurface, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:HeaderIcon;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhlYWRlci1pY29uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErQmEiLCJmaWxlIjoiaGVhZGVyLWljb24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgeyBBbmdsZURvd25JY29uLCBBbmdsZVJpZ2h0SWNvbiB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2ljb25zJztcblxuY29uc3QgZ2V0QXJyb3dDb2xvciA9ICh7XG4gIHRvbmUsXG4gIGlzRGlzYWJsZWQsXG59OiBQaWNrPFRIZWFkZXJJY29uLCAnaXNEaXNhYmxlZCcgfCAndG9uZSc+KSA9PiB7XG4gIGlmIChpc0Rpc2FibGVkKSByZXR1cm4gJ25ldXRyYWw2MCc7XG4gIGlmICh0b25lID09PSAndXJnZW50JykgcmV0dXJuICd3YXJuaW5nJztcblxuICByZXR1cm4gJ3NvbGlkJztcbn07XG5cbnR5cGUgVEhlYWRlckljb24gPSB7XG4gIHRvbmU/OiAndXJnZW50JyB8ICdwcmltYXJ5JztcbiAgaXNDbG9zZWQ6IGJvb2xlYW47XG4gIGlzRGlzYWJsZWQ6IGJvb2xlYW47XG4gIHNpemU6ICdzbWFsbCcgfCAnbWVkaXVtJyB8ICdiaWcnIHwgJ3NjYWxlJztcbn07XG5cbmNvbnN0IEhlYWRlckljb24gPSAoeyB0b25lID0gJ3ByaW1hcnknLCAuLi5wcm9wcyB9OiBUSGVhZGVySWNvbikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXZcbiAgICAgIGNzcz17W1xuICAgICAgICBjc3NgXG4gICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICAgIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICAgICAgICBgLFxuICAgICAgICBwcm9wcy5pc0Rpc2FibGVkICYmXG4gICAgICAgICAgY3NzYFxuICAgICAgICAgICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICAgICAgICAgIGJvcmRlcjogbm9uZTtcbiAgICAgICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gICAgICAgICAgYCxcbiAgICAgIF19XG4gICAgPlxuICAgICAge3Byb3BzLmlzQ2xvc2VkID8gKFxuICAgICAgICA8QW5nbGVSaWdodEljb25cbiAgICAgICAgICBjb2xvcj17Z2V0QXJyb3dDb2xvcih7XG4gICAgICAgICAgICB0b25lOiB0b25lLFxuICAgICAgICAgICAgaXNEaXNhYmxlZDogcHJvcHMuaXNEaXNhYmxlZCxcbiAgICAgICAgICB9KX1cbiAgICAgICAgICBzaXplPXtwcm9wcy5zaXplfVxuICAgICAgICAvPlxuICAgICAgKSA6IChcbiAgICAgICAgPEFuZ2xlRG93bkljb25cbiAgICAgICAgICBjb2xvcj17Z2V0QXJyb3dDb2xvcih7XG4gICAgICAgICAgICB0b25lOiB0b25lLFxuICAgICAgICAgICAgaXNEaXNhYmxlZDogcHJvcHMuaXNEaXNhYmxlZCxcbiAgICAgICAgICB9KX1cbiAgICAgICAgICBzaXplPXtwcm9wcy5zaXplfVxuICAgICAgICAvPlxuICAgICAgKX1cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbkhlYWRlckljb24uZGlzcGxheU5hbWUgPSAnSGVhZGVySWNvbic7XG5cbmV4cG9ydCBkZWZhdWx0IEhlYWRlckljb247XG4iXX0= */"), process.env.NODE_ENV === "production" ? "" : ";label:HeaderIcon;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhlYWRlci1pY29uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3Qk0iLCJmaWxlIjoiaGVhZGVyLWljb24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgeyBBbmdsZURvd25JY29uLCBBbmdsZVJpZ2h0SWNvbiB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2ljb25zJztcblxuY29uc3QgZ2V0QXJyb3dDb2xvciA9ICh7XG4gIHRvbmUsXG4gIGlzRGlzYWJsZWQsXG59OiBQaWNrPFRIZWFkZXJJY29uLCAnaXNEaXNhYmxlZCcgfCAndG9uZSc+KSA9PiB7XG4gIGlmIChpc0Rpc2FibGVkKSByZXR1cm4gJ25ldXRyYWw2MCc7XG4gIGlmICh0b25lID09PSAndXJnZW50JykgcmV0dXJuICd3YXJuaW5nJztcblxuICByZXR1cm4gJ3NvbGlkJztcbn07XG5cbnR5cGUgVEhlYWRlckljb24gPSB7XG4gIHRvbmU/OiAndXJnZW50JyB8ICdwcmltYXJ5JztcbiAgaXNDbG9zZWQ6IGJvb2xlYW47XG4gIGlzRGlzYWJsZWQ6IGJvb2xlYW47XG4gIHNpemU6ICdzbWFsbCcgfCAnbWVkaXVtJyB8ICdiaWcnIHwgJ3NjYWxlJztcbn07XG5cbmNvbnN0IEhlYWRlckljb24gPSAoeyB0b25lID0gJ3ByaW1hcnknLCAuLi5wcm9wcyB9OiBUSGVhZGVySWNvbikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXZcbiAgICAgIGNzcz17W1xuICAgICAgICBjc3NgXG4gICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICAgIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICAgICAgICBgLFxuICAgICAgICBwcm9wcy5pc0Rpc2FibGVkICYmXG4gICAgICAgICAgY3NzYFxuICAgICAgICAgICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICAgICAgICAgIGJvcmRlcjogbm9uZTtcbiAgICAgICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gICAgICAgICAgYCxcbiAgICAgIF19XG4gICAgPlxuICAgICAge3Byb3BzLmlzQ2xvc2VkID8gKFxuICAgICAgICA8QW5nbGVSaWdodEljb25cbiAgICAgICAgICBjb2xvcj17Z2V0QXJyb3dDb2xvcih7XG4gICAgICAgICAgICB0b25lOiB0b25lLFxuICAgICAgICAgICAgaXNEaXNhYmxlZDogcHJvcHMuaXNEaXNhYmxlZCxcbiAgICAgICAgICB9KX1cbiAgICAgICAgICBzaXplPXtwcm9wcy5zaXplfVxuICAgICAgICAvPlxuICAgICAgKSA6IChcbiAgICAgICAgPEFuZ2xlRG93bkljb25cbiAgICAgICAgICBjb2xvcj17Z2V0QXJyb3dDb2xvcih7XG4gICAgICAgICAgICB0b25lOiB0b25lLFxuICAgICAgICAgICAgaXNEaXNhYmxlZDogcHJvcHMuaXNEaXNhYmxlZCxcbiAgICAgICAgICB9KX1cbiAgICAgICAgICBzaXplPXtwcm9wcy5zaXplfVxuICAgICAgICAvPlxuICAgICAgKX1cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbkhlYWRlckljb24uZGlzcGxheU5hbWUgPSAnSGVhZGVySWNvbic7XG5cbmV4cG9ydCBkZWZhdWx0IEhlYWRlckljb247XG4iXX0= */"],
|
|
37
51
|
children: props.isClosed ? jsx(AngleRightIcon, {
|
|
38
52
|
color: getArrowColor({
|
|
39
|
-
tone:
|
|
53
|
+
tone: tone,
|
|
40
54
|
isDisabled: props.isDisabled
|
|
41
55
|
}),
|
|
42
56
|
size: props.size
|
|
43
57
|
}) : jsx(AngleDownIcon, {
|
|
44
58
|
color: getArrowColor({
|
|
45
|
-
tone:
|
|
59
|
+
tone: tone,
|
|
46
60
|
isDisabled: props.isDisabled
|
|
47
61
|
}),
|
|
48
62
|
size: props.size
|
|
@@ -50,9 +64,6 @@ const HeaderIcon = props => {
|
|
|
50
64
|
});
|
|
51
65
|
};
|
|
52
66
|
HeaderIcon.displayName = 'HeaderIcon';
|
|
53
|
-
HeaderIcon.defaultProps = {
|
|
54
|
-
tone: 'primary'
|
|
55
|
-
};
|
|
56
67
|
var HeaderIcon$1 = HeaderIcon;
|
|
57
68
|
|
|
58
69
|
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
@@ -131,21 +142,17 @@ CollapsiblePanelHeader.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
131
142
|
CollapsiblePanelHeader.displayName = 'CollapsiblePanelHeader';
|
|
132
143
|
var CollapsiblePanelHeader$1 = CollapsiblePanelHeader;
|
|
133
144
|
|
|
145
|
+
const _excluded = ["theme", "condensed", "isDisabled", "headerControlsAlignment", "horizontalConstraint"];
|
|
146
|
+
function ownKeys(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
147
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
134
148
|
const HeaderContainer = /*#__PURE__*/_styled(AccessibleButton, process.env.NODE_ENV === "production" ? {
|
|
135
149
|
target: "e1923bli0"
|
|
136
150
|
} : {
|
|
137
151
|
target: "e1923bli0",
|
|
138
152
|
label: "HeaderContainer"
|
|
139
|
-
})(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AA0BgD","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, cloneElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {/* TODO: this is a temporary fix, which will be refactored after we align with the desing team on how to proceed */}\n      {typeof props.header === 'string'\n        ? props.header\n        : cloneElement(props.header as React.ReactElement, {\n            isCondensed: props.condensed,\n          })}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(props, isOpen),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={props.isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText\n                    header={props.header}\n                    condensed={props.condensed}\n                  />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={props.condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */");
|
|
153
|
+
})(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AA0BgD","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, cloneElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {/* TODO: this is a temporary fix, which will be refactored after we align with the desing team on how to proceed */}\n      {typeof props.header === 'string'\n        ? props.header\n        : cloneElement(props.header as React.ReactElement, {\n            isCondensed: props.condensed,\n          })}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = ({\n  theme = 'dark',\n  condensed = false,\n  isDisabled = false,\n  headerControlsAlignment = 'right',\n  horizontalConstraint = 'scale',\n  ...props\n}: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes({\n    theme,\n    condensed,\n    isDisabled,\n    headerControlsAlignment,\n    horizontalConstraint,\n    ...props,\n  });\n  const scale = condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(\n                  {\n                    condensed,\n                    isDisabled,\n                    headerControlsAlignment,\n                    ...props,\n                  },\n                  isOpen\n                ),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={isDisabled ? undefined : toggle}\n              isDisabled={isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText header={props.header} condensed={condensed} />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */");
|
|
140
154
|
const panelButtonSequentialId = createSequentialId('collapsible-panel-button-');
|
|
141
155
|
const panelContentSequentialId = createSequentialId('collapsible-panel-content-');
|
|
142
|
-
const defaultProps = {
|
|
143
|
-
theme: 'dark',
|
|
144
|
-
condensed: false,
|
|
145
|
-
isDisabled: false,
|
|
146
|
-
headerControlsAlignment: 'right',
|
|
147
|
-
horizontalConstraint: 'scale'
|
|
148
|
-
};
|
|
149
156
|
const HeadLineText = props => {
|
|
150
157
|
if (!props.condensed) {
|
|
151
158
|
return jsx(Fragment, {
|
|
@@ -163,12 +170,29 @@ const HeadLineText = props => {
|
|
|
163
170
|
|
|
164
171
|
// When `isClosed` is provided the component behaves as a controlled component,
|
|
165
172
|
// otherwise it will behave like an uncontrolled component.
|
|
166
|
-
const CollapsiblePanel =
|
|
173
|
+
const CollapsiblePanel = _ref => {
|
|
174
|
+
let _ref$theme = _ref.theme,
|
|
175
|
+
theme = _ref$theme === void 0 ? 'dark' : _ref$theme,
|
|
176
|
+
_ref$condensed = _ref.condensed,
|
|
177
|
+
condensed = _ref$condensed === void 0 ? false : _ref$condensed,
|
|
178
|
+
_ref$isDisabled = _ref.isDisabled,
|
|
179
|
+
isDisabled = _ref$isDisabled === void 0 ? false : _ref$isDisabled,
|
|
180
|
+
_ref$headerControlsAl = _ref.headerControlsAlignment,
|
|
181
|
+
headerControlsAlignment = _ref$headerControlsAl === void 0 ? 'right' : _ref$headerControlsAl,
|
|
182
|
+
_ref$horizontalConstr = _ref.horizontalConstraint,
|
|
183
|
+
horizontalConstraint = _ref$horizontalConstr === void 0 ? 'scale' : _ref$horizontalConstr,
|
|
184
|
+
props = _objectWithoutProperties(_ref, _excluded);
|
|
167
185
|
const panelButtonId = useFieldId(props.id, panelButtonSequentialId);
|
|
168
186
|
const panelContentId = useFieldId(undefined, panelContentSequentialId);
|
|
169
187
|
// Pass only `data-*` props
|
|
170
|
-
const dataProps = filterDataAttributes(
|
|
171
|
-
|
|
188
|
+
const dataProps = filterDataAttributes(_objectSpread({
|
|
189
|
+
theme,
|
|
190
|
+
condensed,
|
|
191
|
+
isDisabled,
|
|
192
|
+
headerControlsAlignment,
|
|
193
|
+
horizontalConstraint
|
|
194
|
+
}, props));
|
|
195
|
+
const scale = condensed ? 's' : 'm';
|
|
172
196
|
const isClosedAndIsDefaultClosed = !isNil(props.isClosed) && !isNil(props.isDefaultClosed);
|
|
173
197
|
process.env.NODE_ENV !== "production" ? warning(!isClosedAndIsDefaultClosed, `Invalid prop \`isDefaultClosed\` supplied to \`CollapsiblePanel\`. Component must either be controlled or uncontrolled. Pass either \`isClosed\` or \`isDefaultClosed\` but not both.`) : void 0;
|
|
174
198
|
const hasOnToggle = !isNil(props.onToggle);
|
|
@@ -187,15 +211,15 @@ const CollapsiblePanel = props => {
|
|
|
187
211
|
isClosed: props.isClosed,
|
|
188
212
|
onToggle: props.onToggle,
|
|
189
213
|
isDefaultClosed: props.isDefaultClosed,
|
|
190
|
-
children:
|
|
191
|
-
let isOpen =
|
|
192
|
-
toggle =
|
|
193
|
-
containerStyles =
|
|
194
|
-
registerContentNode =
|
|
214
|
+
children: _ref2 => {
|
|
215
|
+
let isOpen = _ref2.isOpen,
|
|
216
|
+
toggle = _ref2.toggle,
|
|
217
|
+
containerStyles = _ref2.containerStyles,
|
|
218
|
+
registerContentNode = _ref2.registerContentNode;
|
|
195
219
|
return jsx(Constraints.Horizontal, {
|
|
196
|
-
max:
|
|
220
|
+
max: horizontalConstraint,
|
|
197
221
|
children: jsxs("div", {
|
|
198
|
-
css: [baseContainerStyles, getThemeStyle('light'), process.env.NODE_ENV === "production" ? "" : ";label:CollapsiblePanel;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AAkNY","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, cloneElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {/* TODO: this is a temporary fix, which will be refactored after we align with the desing team on how to proceed */}\n      {typeof props.header === 'string'\n        ? props.header\n        : cloneElement(props.header as React.ReactElement, {\n            isCondensed: props.condensed,\n          })}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(props, isOpen),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={props.isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText\n                    header={props.header}\n                    condensed={props.condensed}\n                  />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={props.condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"]
|
|
222
|
+
css: [baseContainerStyles, getThemeStyle('light'), process.env.NODE_ENV === "production" ? "" : ";label:CollapsiblePanel;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AAiNY","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, cloneElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {/* TODO: this is a temporary fix, which will be refactored after we align with the desing team on how to proceed */}\n      {typeof props.header === 'string'\n        ? props.header\n        : cloneElement(props.header as React.ReactElement, {\n            isCondensed: props.condensed,\n          })}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = ({\n  theme = 'dark',\n  condensed = false,\n  isDisabled = false,\n  headerControlsAlignment = 'right',\n  horizontalConstraint = 'scale',\n  ...props\n}: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes({\n    theme,\n    condensed,\n    isDisabled,\n    headerControlsAlignment,\n    horizontalConstraint,\n    ...props,\n  });\n  const scale = condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(\n                  {\n                    condensed,\n                    isDisabled,\n                    headerControlsAlignment,\n                    ...props,\n                  },\n                  isOpen\n                ),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={isDisabled ? undefined : toggle}\n              isDisabled={isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText header={props.header} condensed={condensed} />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"]
|
|
199
223
|
// Allow to override the styles by passing a `className` prop.
|
|
200
224
|
// Custom styles can also be passed using the `css` prop from emotion.
|
|
201
225
|
// https://emotion.sh/docs/css-prop#style-precedence
|
|
@@ -203,11 +227,15 @@ const CollapsiblePanel = props => {
|
|
|
203
227
|
className: props.className,
|
|
204
228
|
children: [jsxs(HeaderContainer, {
|
|
205
229
|
as: "div",
|
|
206
|
-
css: [getHeaderContainerStyles(props, isOpen), getThemeStyle('light'), process.env.NODE_ENV === "production" ? "" : ";label:CollapsiblePanel;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AA0Nc","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, cloneElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {/* TODO: this is a temporary fix, which will be refactored after we align with the desing team on how to proceed */}\n      {typeof props.header === 'string'\n        ? props.header\n        : cloneElement(props.header as React.ReactElement, {\n            isCondensed: props.condensed,\n          })}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(props, isOpen),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={props.isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText\n                    header={props.header}\n                    condensed={props.condensed}\n                  />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={props.condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"],
|
|
230
|
+
css: [getHeaderContainerStyles(_objectSpread({
|
|
231
|
+
condensed,
|
|
232
|
+
isDisabled,
|
|
233
|
+
headerControlsAlignment
|
|
234
|
+
}, props), isOpen), getThemeStyle('light'), process.env.NODE_ENV === "production" ? "" : ";label:CollapsiblePanel;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AAyNc","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, cloneElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {/* TODO: this is a temporary fix, which will be refactored after we align with the desing team on how to proceed */}\n      {typeof props.header === 'string'\n        ? props.header\n        : cloneElement(props.header as React.ReactElement, {\n            isCondensed: props.condensed,\n          })}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = ({\n  theme = 'dark',\n  condensed = false,\n  isDisabled = false,\n  headerControlsAlignment = 'right',\n  horizontalConstraint = 'scale',\n  ...props\n}: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes({\n    theme,\n    condensed,\n    isDisabled,\n    headerControlsAlignment,\n    horizontalConstraint,\n    ...props,\n  });\n  const scale = condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(\n                  {\n                    condensed,\n                    isDisabled,\n                    headerControlsAlignment,\n                    ...props,\n                  },\n                  isOpen\n                ),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={isDisabled ? undefined : toggle}\n              isDisabled={isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText header={props.header} condensed={condensed} />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"],
|
|
207
235
|
id: panelButtonId,
|
|
208
236
|
label: "",
|
|
209
|
-
onClick:
|
|
210
|
-
isDisabled:
|
|
237
|
+
onClick: isDisabled ? undefined : toggle,
|
|
238
|
+
isDisabled: isDisabled,
|
|
211
239
|
buttonAttributes: dataProps,
|
|
212
240
|
"aria-controls": panelContentId,
|
|
213
241
|
"aria-expanded": isOpen ? 'true' : 'false',
|
|
@@ -216,7 +244,7 @@ const CollapsiblePanel = props => {
|
|
|
216
244
|
scale: "xs",
|
|
217
245
|
children: [!props.hideExpansionControls && jsx(HeaderIcon$1, {
|
|
218
246
|
isClosed: !isOpen,
|
|
219
|
-
isDisabled:
|
|
247
|
+
isDisabled: isDisabled || false,
|
|
220
248
|
tone: props.tone,
|
|
221
249
|
size: 'medium'
|
|
222
250
|
}), jsxs(Spacings.Inline, {
|
|
@@ -224,7 +252,7 @@ const CollapsiblePanel = props => {
|
|
|
224
252
|
scale: scale,
|
|
225
253
|
children: [jsx(HeadLineText, {
|
|
226
254
|
header: props.header,
|
|
227
|
-
condensed:
|
|
255
|
+
condensed: condensed
|
|
228
256
|
}), props.secondaryHeader && jsx(Text.Detail, {
|
|
229
257
|
tone: "secondary",
|
|
230
258
|
truncate: true,
|
|
@@ -241,7 +269,7 @@ const CollapsiblePanel = props => {
|
|
|
241
269
|
// @ts-ignore
|
|
242
270
|
, {
|
|
243
271
|
ref: registerContentNode,
|
|
244
|
-
condensed:
|
|
272
|
+
condensed: condensed,
|
|
245
273
|
isExpandControlHidden: props.hideExpansionControls,
|
|
246
274
|
children: [props.description && jsx(SectionDescriptionWrapper, {
|
|
247
275
|
children: jsx(Text.Detail, {
|
|
@@ -291,11 +319,10 @@ CollapsiblePanel.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
291
319
|
} : {};
|
|
292
320
|
CollapsiblePanel.getPanelContentId = () => '';
|
|
293
321
|
CollapsiblePanel.displayName = 'CollapsiblePanel';
|
|
294
|
-
CollapsiblePanel.defaultProps = defaultProps;
|
|
295
322
|
CollapsiblePanel.Header = CollapsiblePanelHeader$1;
|
|
296
323
|
var CollapsiblePanel$1 = CollapsiblePanel;
|
|
297
324
|
|
|
298
325
|
// NOTE: This string will be replaced on build time with the package version.
|
|
299
|
-
var version = "19.
|
|
326
|
+
var version = "19.22.0";
|
|
300
327
|
|
|
301
328
|
export { CollapsiblePanel$1 as default, version };
|
|
@@ -85,10 +85,9 @@ export type TCollapsiblePanel = {
|
|
|
85
85
|
horizontalConstraint?: 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';
|
|
86
86
|
};
|
|
87
87
|
declare const CollapsiblePanel: {
|
|
88
|
-
(props: TCollapsiblePanel): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
88
|
+
({ theme, condensed, isDisabled, headerControlsAlignment, horizontalConstraint, ...props }: TCollapsiblePanel): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
89
89
|
getPanelContentId(): string;
|
|
90
90
|
displayName: string;
|
|
91
|
-
defaultProps: Pick<TCollapsiblePanel, "theme" | "isDisabled" | "condensed" | "horizontalConstraint" | "headerControlsAlignment">;
|
|
92
91
|
Header: {
|
|
93
92
|
(props: {
|
|
94
93
|
children: ReactNode;
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@commercetools-uikit/collapsible-panel",
|
|
3
3
|
"description": "A panel to collapse and expand your content.",
|
|
4
|
-
"version": "19.
|
|
4
|
+
"version": "19.22.0",
|
|
5
5
|
"bugs": "https://github.com/commercetools/ui-kit/issues",
|
|
6
6
|
"repository": {
|
|
7
7
|
"type": "git",
|
|
@@ -21,15 +21,15 @@
|
|
|
21
21
|
"dependencies": {
|
|
22
22
|
"@babel/runtime": "^7.20.13",
|
|
23
23
|
"@babel/runtime-corejs3": "^7.20.13",
|
|
24
|
-
"@commercetools-uikit/accessible-button": "19.
|
|
25
|
-
"@commercetools-uikit/collapsible-motion": "19.
|
|
26
|
-
"@commercetools-uikit/constraints": "19.
|
|
27
|
-
"@commercetools-uikit/design-system": "19.
|
|
28
|
-
"@commercetools-uikit/hooks": "19.
|
|
29
|
-
"@commercetools-uikit/icons": "19.
|
|
30
|
-
"@commercetools-uikit/spacings": "19.
|
|
31
|
-
"@commercetools-uikit/text": "19.
|
|
32
|
-
"@commercetools-uikit/utils": "19.
|
|
24
|
+
"@commercetools-uikit/accessible-button": "19.22.0",
|
|
25
|
+
"@commercetools-uikit/collapsible-motion": "19.22.0",
|
|
26
|
+
"@commercetools-uikit/constraints": "19.22.0",
|
|
27
|
+
"@commercetools-uikit/design-system": "19.22.0",
|
|
28
|
+
"@commercetools-uikit/hooks": "19.22.0",
|
|
29
|
+
"@commercetools-uikit/icons": "19.22.0",
|
|
30
|
+
"@commercetools-uikit/spacings": "19.22.0",
|
|
31
|
+
"@commercetools-uikit/text": "19.22.0",
|
|
32
|
+
"@commercetools-uikit/utils": "19.22.0",
|
|
33
33
|
"@emotion/react": "^11.10.5",
|
|
34
34
|
"@emotion/styled": "^11.10.5",
|
|
35
35
|
"lodash": "4.17.21",
|