@commercetools-uikit/collapsible-panel 19.26.0 → 20.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -64,7 +64,7 @@ export default Example;
64
64
  | Props | Type | Required | Default | Description |
65
65
  | ------------------------- | -------------------------------------------------------------------------------------------- | :------: | --------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
66
66
  | `id` | `string` | | | An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.&#xA;<br/>&#xA;Read about `getPanelContentId` below for more about this. |
67
- | `header` | `ReactNode` | ✅ | | The title being rendered at top left of the panel |
67
+ | `header` | `union`<br/>Possible values:<br/>`ReactElement<{ isCondensed?: boolean }> , ReactNode` | ✅ | | The title being rendered at top left of the panel |
68
68
  | `secondaryHeader` | `ReactNode` | | | A secondary header for the panel (only pass if needed) |
69
69
  | `description` | `string` | | | If passed will be shown below the title as more information regarding the panel |
70
70
  | `className` | `string` | | | Allow to override the styles by passing a `className` prop.&#xA;<br/>&#xA;Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence). |
@@ -13,7 +13,6 @@ var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/obje
13
13
  var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
14
14
  var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
15
15
  var _styled = require('@emotion/styled/base');
16
- var _pt = require('prop-types');
17
16
  var react$1 = require('react');
18
17
  var isNil = require('lodash/isNil');
19
18
  var utils = require('@commercetools-uikit/utils');
@@ -39,7 +38,6 @@ var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_O
39
38
  var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
40
39
  var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
41
40
  var _styled__default = /*#__PURE__*/_interopDefault(_styled);
42
- var _pt__default = /*#__PURE__*/_interopDefault(_pt);
43
41
  var isNil__default = /*#__PURE__*/_interopDefault(isNil);
44
42
  var AccessibleButton__default = /*#__PURE__*/_interopDefault(AccessibleButton);
45
43
  var Spacings__default = /*#__PURE__*/_interopDefault(Spacings);
@@ -155,10 +153,6 @@ const CollapsiblePanelHeader = props => props.isCondensed ? jsxRuntime.jsx(jsxRu
155
153
  truncate: true,
156
154
  children: props.children
157
155
  });
158
- CollapsiblePanelHeader.propTypes = process.env.NODE_ENV !== "production" ? {
159
- children: _pt__default["default"].node.isRequired,
160
- isCondensed: _pt__default["default"].bool
161
- } : {};
162
156
  CollapsiblePanelHeader.displayName = 'CollapsiblePanelHeader';
163
157
  var CollapsiblePanelHeader$1 = CollapsiblePanelHeader;
164
158
 
@@ -170,7 +164,7 @@ const HeaderContainer = /*#__PURE__*/_styled__default["default"](AccessibleButto
170
164
  } : {
171
165
  target: "e1923bli0",
172
166
  label: "HeaderContainer"
173
- })(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"]} */");
167
+ })(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, ReactElement, cloneElement, isValidElement } 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: ReactElement<{ isCondensed?: boolean }> | 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      {isValidElement<{ isCondensed?: boolean }>(props.header)\n        ? cloneElement(props.header, {\n            isCondensed: props.condensed,\n          })\n        : props.header}\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"]} */");
174
168
  const panelButtonSequentialId = utils.createSequentialId('collapsible-panel-button-');
175
169
  const panelContentSequentialId = utils.createSequentialId('collapsible-panel-content-');
176
170
  const HeadLineText = props => {
@@ -182,9 +176,9 @@ const HeadLineText = props => {
182
176
  return jsxRuntime.jsx(Text__default["default"].Subheadline, {
183
177
  as: "h4",
184
178
  truncate: true,
185
- children: typeof props.header === 'string' ? props.header : /*#__PURE__*/react$1.cloneElement(props.header, {
179
+ children: /*#__PURE__*/react$1.isValidElement(props.header) ? /*#__PURE__*/react$1.cloneElement(props.header, {
186
180
  isCondensed: props.condensed
187
- })
181
+ }) : props.header
188
182
  });
189
183
  };
190
184
 
@@ -239,7 +233,7 @@ const CollapsiblePanel = _ref => {
239
233
  return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
240
234
  max: horizontalConstraint,
241
235
  children: jsxRuntime.jsxs("div", {
242
- 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"]} */"]
236
+ 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":"AAgNY","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, ReactElement, cloneElement, isValidElement } 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: ReactElement<{ isCondensed?: boolean }> | 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      {isValidElement<{ isCondensed?: boolean }>(props.header)\n        ? cloneElement(props.header, {\n            isCondensed: props.condensed,\n          })\n        : props.header}\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"]} */"]
243
237
  // Allow to override the styles by passing a `className` prop.
244
238
  // Custom styles can also be passed using the `css` prop from emotion.
245
239
  // https://emotion.sh/docs/css-prop#style-precedence
@@ -251,7 +245,7 @@ const CollapsiblePanel = _ref => {
251
245
  condensed,
252
246
  isDisabled,
253
247
  headerControlsAlignment
254
- }, 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"]} */"],
248
+ }, 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":"AAwNc","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, ReactElement, cloneElement, isValidElement } 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: ReactElement<{ isCondensed?: boolean }> | 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      {isValidElement<{ isCondensed?: boolean }>(props.header)\n        ? cloneElement(props.header, {\n            isCondensed: props.condensed,\n          })\n        : props.header}\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"]} */"],
255
249
  id: panelButtonId,
256
250
  label: "",
257
251
  onClick: isDisabled ? undefined : toggle,
@@ -317,33 +311,13 @@ const CollapsiblePanel = _ref => {
317
311
  /**
318
312
  * @deprecated This function is no longer supported.
319
313
  */
320
- CollapsiblePanel.propTypes = process.env.NODE_ENV !== "production" ? {
321
- id: _pt__default["default"].string,
322
- header: _pt__default["default"].node.isRequired,
323
- secondaryHeader: _pt__default["default"].node,
324
- description: _pt__default["default"].string,
325
- className: _pt__default["default"].string,
326
- isSticky: _pt__default["default"].bool,
327
- headerControls: _pt__default["default"].node,
328
- isDisabled: _pt__default["default"].bool,
329
- children: _pt__default["default"].node,
330
- tone: _pt__default["default"].oneOf(['urgent', 'primary']),
331
- theme: _pt__default["default"].oneOf(['dark', 'light']),
332
- condensed: _pt__default["default"].bool,
333
- hideExpansionControls: _pt__default["default"].bool,
334
- headerControlsAlignment: _pt__default["default"].oneOf(['left', 'right']),
335
- isDefaultClosed: _pt__default["default"].bool,
336
- isClosed: _pt__default["default"].bool,
337
- onToggle: _pt__default["default"].func,
338
- horizontalConstraint: _pt__default["default"].oneOf([6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'])
339
- } : {};
340
314
  CollapsiblePanel.getPanelContentId = () => '';
341
315
  CollapsiblePanel.displayName = 'CollapsiblePanel';
342
316
  CollapsiblePanel.Header = CollapsiblePanelHeader$1;
343
317
  var CollapsiblePanel$1 = CollapsiblePanel;
344
318
 
345
319
  // NOTE: This string will be replaced on build time with the package version.
346
- var version = "19.26.0";
320
+ var version = "20.0.0";
347
321
 
348
322
  exports["default"] = CollapsiblePanel$1;
349
323
  exports.version = version;
@@ -13,7 +13,6 @@ var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/obje
13
13
  var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
14
14
  var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
15
15
  var _styled = require('@emotion/styled/base');
16
- require('prop-types');
17
16
  var react$1 = require('react');
18
17
  var isNil = require('lodash/isNil');
19
18
  var utils = require('@commercetools-uikit/utils');
@@ -131,7 +130,6 @@ const CollapsiblePanelHeader = props => props.isCondensed ? jsxRuntime.jsx(jsxRu
131
130
  truncate: true,
132
131
  children: props.children
133
132
  });
134
- CollapsiblePanelHeader.propTypes = {};
135
133
  CollapsiblePanelHeader.displayName = 'CollapsiblePanelHeader';
136
134
  var CollapsiblePanelHeader$1 = CollapsiblePanelHeader;
137
135
 
@@ -152,9 +150,9 @@ const HeadLineText = props => {
152
150
  return jsxRuntime.jsx(Text__default["default"].Subheadline, {
153
151
  as: "h4",
154
152
  truncate: true,
155
- children: typeof props.header === 'string' ? props.header : /*#__PURE__*/react$1.cloneElement(props.header, {
153
+ children: /*#__PURE__*/react$1.isValidElement(props.header) ? /*#__PURE__*/react$1.cloneElement(props.header, {
156
154
  isCondensed: props.condensed
157
- })
155
+ }) : props.header
158
156
  });
159
157
  };
160
158
 
@@ -276,14 +274,13 @@ const CollapsiblePanel = _ref => {
276
274
  /**
277
275
  * @deprecated This function is no longer supported.
278
276
  */
279
- CollapsiblePanel.propTypes = {};
280
277
  CollapsiblePanel.getPanelContentId = () => '';
281
278
  CollapsiblePanel.displayName = 'CollapsiblePanel';
282
279
  CollapsiblePanel.Header = CollapsiblePanelHeader$1;
283
280
  var CollapsiblePanel$1 = CollapsiblePanel;
284
281
 
285
282
  // NOTE: This string will be replaced on build time with the package version.
286
- var version = "19.26.0";
283
+ var version = "20.0.0";
287
284
 
288
285
  exports["default"] = CollapsiblePanel$1;
289
286
  exports.version = version;
@@ -9,8 +9,7 @@ import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object
9
9
  import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
10
10
  import _objectWithoutProperties from '@babel/runtime-corejs3/helpers/esm/objectWithoutProperties';
11
11
  import _styled from '@emotion/styled/base';
12
- import _pt from 'prop-types';
13
- import { forwardRef, cloneElement } from 'react';
12
+ import { forwardRef, isValidElement, cloneElement } from 'react';
14
13
  import isNil from 'lodash/isNil';
15
14
  import { createSequentialId, filterDataAttributes, warning } from '@commercetools-uikit/utils';
16
15
  import AccessibleButton from '@commercetools-uikit/accessible-button';
@@ -132,10 +131,6 @@ const CollapsiblePanelHeader = props => props.isCondensed ? jsx(Fragment, {
132
131
  truncate: true,
133
132
  children: props.children
134
133
  });
135
- CollapsiblePanelHeader.propTypes = process.env.NODE_ENV !== "production" ? {
136
- children: _pt.node.isRequired,
137
- isCondensed: _pt.bool
138
- } : {};
139
134
  CollapsiblePanelHeader.displayName = 'CollapsiblePanelHeader';
140
135
  var CollapsiblePanelHeader$1 = CollapsiblePanelHeader;
141
136
 
@@ -147,7 +142,7 @@ const HeaderContainer = /*#__PURE__*/_styled(AccessibleButton, process.env.NODE_
147
142
  } : {
148
143
  target: "e1923bli0",
149
144
  label: "HeaderContainer"
150
- })(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"]} */");
145
+ })(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, ReactElement, cloneElement, isValidElement } 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: ReactElement<{ isCondensed?: boolean }> | 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      {isValidElement<{ isCondensed?: boolean }>(props.header)\n        ? cloneElement(props.header, {\n            isCondensed: props.condensed,\n          })\n        : props.header}\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"]} */");
151
146
  const panelButtonSequentialId = createSequentialId('collapsible-panel-button-');
152
147
  const panelContentSequentialId = createSequentialId('collapsible-panel-content-');
153
148
  const HeadLineText = props => {
@@ -159,9 +154,9 @@ const HeadLineText = props => {
159
154
  return jsx(Text.Subheadline, {
160
155
  as: "h4",
161
156
  truncate: true,
162
- children: typeof props.header === 'string' ? props.header : /*#__PURE__*/cloneElement(props.header, {
157
+ children: /*#__PURE__*/isValidElement(props.header) ? /*#__PURE__*/cloneElement(props.header, {
163
158
  isCondensed: props.condensed
164
- })
159
+ }) : props.header
165
160
  });
166
161
  };
167
162
 
@@ -216,7 +211,7 @@ const CollapsiblePanel = _ref => {
216
211
  return jsx(Constraints.Horizontal, {
217
212
  max: horizontalConstraint,
218
213
  children: jsxs("div", {
219
- 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
+ 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":"AAgNY","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, ReactElement, cloneElement, isValidElement } 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: ReactElement<{ isCondensed?: boolean }> | 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      {isValidElement<{ isCondensed?: boolean }>(props.header)\n        ? cloneElement(props.header, {\n            isCondensed: props.condensed,\n          })\n        : props.header}\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"]} */"]
220
215
  // Allow to override the styles by passing a `className` prop.
221
216
  // Custom styles can also be passed using the `css` prop from emotion.
222
217
  // https://emotion.sh/docs/css-prop#style-precedence
@@ -228,7 +223,7 @@ const CollapsiblePanel = _ref => {
228
223
  condensed,
229
224
  isDisabled,
230
225
  headerControlsAlignment
231
- }, 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"]} */"],
226
+ }, 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":"AAwNc","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, ReactElement, cloneElement, isValidElement } 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: ReactElement<{ isCondensed?: boolean }> | 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      {isValidElement<{ isCondensed?: boolean }>(props.header)\n        ? cloneElement(props.header, {\n            isCondensed: props.condensed,\n          })\n        : props.header}\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"]} */"],
232
227
  id: panelButtonId,
233
228
  label: "",
234
229
  onClick: isDisabled ? undefined : toggle,
@@ -294,32 +289,12 @@ const CollapsiblePanel = _ref => {
294
289
  /**
295
290
  * @deprecated This function is no longer supported.
296
291
  */
297
- CollapsiblePanel.propTypes = process.env.NODE_ENV !== "production" ? {
298
- id: _pt.string,
299
- header: _pt.node.isRequired,
300
- secondaryHeader: _pt.node,
301
- description: _pt.string,
302
- className: _pt.string,
303
- isSticky: _pt.bool,
304
- headerControls: _pt.node,
305
- isDisabled: _pt.bool,
306
- children: _pt.node,
307
- tone: _pt.oneOf(['urgent', 'primary']),
308
- theme: _pt.oneOf(['dark', 'light']),
309
- condensed: _pt.bool,
310
- hideExpansionControls: _pt.bool,
311
- headerControlsAlignment: _pt.oneOf(['left', 'right']),
312
- isDefaultClosed: _pt.bool,
313
- isClosed: _pt.bool,
314
- onToggle: _pt.func,
315
- horizontalConstraint: _pt.oneOf([6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'])
316
- } : {};
317
292
  CollapsiblePanel.getPanelContentId = () => '';
318
293
  CollapsiblePanel.displayName = 'CollapsiblePanel';
319
294
  CollapsiblePanel.Header = CollapsiblePanelHeader$1;
320
295
  var CollapsiblePanel$1 = CollapsiblePanel;
321
296
 
322
297
  // NOTE: This string will be replaced on build time with the package version.
323
- var version = "19.26.0";
298
+ var version = "20.0.0";
324
299
 
325
300
  export { CollapsiblePanel$1 as default, version };
@@ -1,4 +1,4 @@
1
- import { ReactNode } from 'react';
1
+ import { ReactNode, ReactElement } from 'react';
2
2
  export type TCollapsiblePanel = {
3
3
  /**
4
4
  * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.
@@ -9,7 +9,9 @@ export type TCollapsiblePanel = {
9
9
  /**
10
10
  * The title being rendered at top left of the panel
11
11
  */
12
- header: ReactNode;
12
+ header: ReactElement<{
13
+ isCondensed?: boolean;
14
+ }> | ReactNode;
13
15
  /**
14
16
  * A secondary header for the panel (only pass if needed)
15
17
  */
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.26.0",
4
+ "version": "20.0.0",
5
5
  "bugs": "https://github.com/commercetools/ui-kit/issues",
6
6
  "repository": {
7
7
  "type": "git",
@@ -21,25 +21,24 @@
21
21
  "dependencies": {
22
22
  "@babel/runtime": "^7.20.13",
23
23
  "@babel/runtime-corejs3": "^7.20.13",
24
- "@commercetools-uikit/accessible-button": "19.26.0",
25
- "@commercetools-uikit/collapsible-motion": "19.26.0",
26
- "@commercetools-uikit/constraints": "19.26.0",
27
- "@commercetools-uikit/design-system": "19.26.0",
28
- "@commercetools-uikit/hooks": "19.26.0",
29
- "@commercetools-uikit/icons": "19.26.0",
30
- "@commercetools-uikit/spacings": "19.26.0",
31
- "@commercetools-uikit/text": "19.26.0",
32
- "@commercetools-uikit/utils": "19.26.0",
24
+ "@commercetools-uikit/accessible-button": "20.0.0",
25
+ "@commercetools-uikit/collapsible-motion": "20.0.0",
26
+ "@commercetools-uikit/constraints": "20.0.0",
27
+ "@commercetools-uikit/design-system": "20.0.0",
28
+ "@commercetools-uikit/hooks": "20.0.0",
29
+ "@commercetools-uikit/icons": "20.0.0",
30
+ "@commercetools-uikit/spacings": "20.0.0",
31
+ "@commercetools-uikit/text": "20.0.0",
32
+ "@commercetools-uikit/utils": "20.0.0",
33
33
  "@emotion/react": "^11.10.5",
34
34
  "@emotion/styled": "^11.10.5",
35
35
  "lodash": "4.17.21",
36
- "prop-types": "15.8.1",
37
- "react-intl": "^6.3.2"
36
+ "react-intl": "^7.1.4"
38
37
  },
39
38
  "devDependencies": {
40
- "react": "17.0.2"
39
+ "react": "19.0.0"
41
40
  },
42
41
  "peerDependencies": {
43
- "react": "17.x"
42
+ "react": "19.x"
44
43
  }
45
44
  }