@commercetools-uikit/collapsible-panel 13.0.4 → 14.0.2

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
@@ -79,7 +79,7 @@ export default Example;
79
79
  | `headerControlsAlignment` | `union`<br/>Possible values:<br/>`'left' , 'right'` | | `'right'` | Indicates the position of the control elements in the header component. |
80
80
  | `isDefaultClosed` | `boolean` | | | Indicates if the panel's content should be collapsed or shown by default.&#xA;<br />&#xA;Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.) |
81
81
  | `isClosed` | `boolean` | | | Indicates if the panel's content should be collapsed or shown.&#xA;<br />&#xA;Component becomes \*_controlled_ when this is passed. |
82
- | `onToggle` | `Function`<br/>[See signature.](#signature-onToggle) | | | function to be triggered whenever the user clicks the top area to collapse the panel's content&#xA;<br />&#xA;Becomes required when `isClosed` is passed.&#xA;<br />&#xA;Signature: `() => void` |
82
+ | `onToggle` | `Function`<br/>[See signature.](#signature-onToggle) | | | function to be triggered whenever the user clicks the top area to collapse the panel's content&#xA;<br />&#xA;Becomes required when `isClosed` is passed. |
83
83
  | `horizontalConstraint` | `union`<br/>Possible values:<br/>`, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'` | | `'scale'` | Horizontal size limit of the panel. |
84
84
 
85
85
  ## Signatures
@@ -150,7 +150,7 @@ var HeaderContainer = /*#__PURE__*/_styled__default["default"](AccessibleButton_
150
150
  } : {
151
151
  target: "e1923bli0",
152
152
  label: "HeaderContainer"
153
- })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AAqBgD","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode } from 'react';\nimport isNil from 'lodash/isNil';\nimport uniqueId from 'lodash/uniqueId';\nimport styled from '@emotion/styled';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\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} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelContentIdPrefix = 'panel-content-';\nconst getPanelContentId = (id?: string) => panelContentIdPrefix + id;\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   * <br />\n   * Signature: `() => void`\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'id'\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  id: uniqueId(),\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelContentId = getPanelContentId(props.id);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle(props.theme)]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(props, isOpen),\n                getThemeStyle(props.theme),\n              ]}\n              id={props.id}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"s\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={props.isDisabled || false}\n                    tone={props.tone}\n                    size={props.condensed ? 'small' : 'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"center\" scale={scale}>\n                  {props.condensed ? (\n                    <Text.Detail as=\"span\" isBold truncate>\n                      {props.header}\n                    </Text.Detail>\n                  ) : (\n                    props.header\n                  )}\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper ref={registerContentNode}>\n                {props.description && (\n                  <Spacings.Inset scale={scale}>\n                    <Text.Detail>{props.description}</Text.Detail>\n                  </Spacings.Inset>\n                )}\n                <Spacings.Inset scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    aria-hidden={isOpen ? 'false' : 'true'}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Inset>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\nCollapsiblePanel.getPanelContentId = getPanelContentId;\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */");
153
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AAqBgD","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode } from 'react';\nimport isNil from 'lodash/isNil';\nimport uniqueId from 'lodash/uniqueId';\nimport styled from '@emotion/styled';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\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} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelContentIdPrefix = 'panel-content-';\nconst getPanelContentId = (id?: string) => panelContentIdPrefix + id;\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'id'\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  id: uniqueId(),\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelContentId = getPanelContentId(props.id);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle(props.theme)]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(props, isOpen),\n                getThemeStyle(props.theme),\n              ]}\n              id={props.id}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"s\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={props.isDisabled || false}\n                    tone={props.tone}\n                    size={props.condensed ? 'small' : 'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"center\" scale={scale}>\n                  {props.condensed ? (\n                    <Text.Detail as=\"span\" isBold truncate>\n                      {props.header}\n                    </Text.Detail>\n                  ) : (\n                    props.header\n                  )}\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper ref={registerContentNode}>\n                {props.description && (\n                  <Spacings.Inset scale={scale}>\n                    <Text.Detail>{props.description}</Text.Detail>\n                  </Spacings.Inset>\n                )}\n                <Spacings.Inset scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    aria-hidden={isOpen ? 'false' : 'true'}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Inset>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\nCollapsiblePanel.getPanelContentId = getPanelContentId;\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */");
154
154
 
155
155
  var panelContentIdPrefix = 'panel-content-';
156
156
 
@@ -199,14 +199,14 @@ var CollapsiblePanel = function CollapsiblePanel(props) {
199
199
  return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
200
200
  max: props.horizontalConstraint,
201
201
  children: jsxRuntime.jsxs("div", {
202
- css: [baseContainerStyles, getThemeStyle(props.theme), 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":"AA2LY","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode } from 'react';\nimport isNil from 'lodash/isNil';\nimport uniqueId from 'lodash/uniqueId';\nimport styled from '@emotion/styled';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\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} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelContentIdPrefix = 'panel-content-';\nconst getPanelContentId = (id?: string) => panelContentIdPrefix + id;\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   * <br />\n   * Signature: `() => void`\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'id'\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  id: uniqueId(),\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelContentId = getPanelContentId(props.id);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle(props.theme)]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(props, isOpen),\n                getThemeStyle(props.theme),\n              ]}\n              id={props.id}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"s\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={props.isDisabled || false}\n                    tone={props.tone}\n                    size={props.condensed ? 'small' : 'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"center\" scale={scale}>\n                  {props.condensed ? (\n                    <Text.Detail as=\"span\" isBold truncate>\n                      {props.header}\n                    </Text.Detail>\n                  ) : (\n                    props.header\n                  )}\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper ref={registerContentNode}>\n                {props.description && (\n                  <Spacings.Inset scale={scale}>\n                    <Text.Detail>{props.description}</Text.Detail>\n                  </Spacings.Inset>\n                )}\n                <Spacings.Inset scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    aria-hidden={isOpen ? 'false' : 'true'}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Inset>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\nCollapsiblePanel.getPanelContentId = getPanelContentId;\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"] // Allow to override the styles by passing a `className` prop.
202
+ css: [baseContainerStyles, getThemeStyle(props.theme), 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":"AAyLY","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode } from 'react';\nimport isNil from 'lodash/isNil';\nimport uniqueId from 'lodash/uniqueId';\nimport styled from '@emotion/styled';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\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} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelContentIdPrefix = 'panel-content-';\nconst getPanelContentId = (id?: string) => panelContentIdPrefix + id;\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'id'\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  id: uniqueId(),\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelContentId = getPanelContentId(props.id);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle(props.theme)]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(props, isOpen),\n                getThemeStyle(props.theme),\n              ]}\n              id={props.id}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"s\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={props.isDisabled || false}\n                    tone={props.tone}\n                    size={props.condensed ? 'small' : 'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"center\" scale={scale}>\n                  {props.condensed ? (\n                    <Text.Detail as=\"span\" isBold truncate>\n                      {props.header}\n                    </Text.Detail>\n                  ) : (\n                    props.header\n                  )}\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper ref={registerContentNode}>\n                {props.description && (\n                  <Spacings.Inset scale={scale}>\n                    <Text.Detail>{props.description}</Text.Detail>\n                  </Spacings.Inset>\n                )}\n                <Spacings.Inset scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    aria-hidden={isOpen ? 'false' : 'true'}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Inset>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\nCollapsiblePanel.getPanelContentId = getPanelContentId;\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"] // Allow to override the styles by passing a `className` prop.
203
203
  // Custom styles can also be passed using the `css` prop from emotion.
204
204
  // https://emotion.sh/docs/css-prop#style-precedence
205
205
  ,
206
206
  className: props.className,
207
207
  children: [jsxRuntime.jsxs(HeaderContainer, {
208
208
  as: "div",
209
- css: [getHeaderContainerStyles(props, isOpen), getThemeStyle(props.theme), 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":"AAmMc","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode } from 'react';\nimport isNil from 'lodash/isNil';\nimport uniqueId from 'lodash/uniqueId';\nimport styled from '@emotion/styled';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\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} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelContentIdPrefix = 'panel-content-';\nconst getPanelContentId = (id?: string) => panelContentIdPrefix + id;\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   * <br />\n   * Signature: `() => void`\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'id'\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  id: uniqueId(),\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelContentId = getPanelContentId(props.id);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle(props.theme)]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(props, isOpen),\n                getThemeStyle(props.theme),\n              ]}\n              id={props.id}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"s\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={props.isDisabled || false}\n                    tone={props.tone}\n                    size={props.condensed ? 'small' : 'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"center\" scale={scale}>\n                  {props.condensed ? (\n                    <Text.Detail as=\"span\" isBold truncate>\n                      {props.header}\n                    </Text.Detail>\n                  ) : (\n                    props.header\n                  )}\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper ref={registerContentNode}>\n                {props.description && (\n                  <Spacings.Inset scale={scale}>\n                    <Text.Detail>{props.description}</Text.Detail>\n                  </Spacings.Inset>\n                )}\n                <Spacings.Inset scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    aria-hidden={isOpen ? 'false' : 'true'}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Inset>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\nCollapsiblePanel.getPanelContentId = getPanelContentId;\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"],
209
+ css: [getHeaderContainerStyles(props, isOpen), getThemeStyle(props.theme), 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":"AAiMc","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode } from 'react';\nimport isNil from 'lodash/isNil';\nimport uniqueId from 'lodash/uniqueId';\nimport styled from '@emotion/styled';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\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} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelContentIdPrefix = 'panel-content-';\nconst getPanelContentId = (id?: string) => panelContentIdPrefix + id;\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'id'\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  id: uniqueId(),\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelContentId = getPanelContentId(props.id);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle(props.theme)]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(props, isOpen),\n                getThemeStyle(props.theme),\n              ]}\n              id={props.id}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"s\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={props.isDisabled || false}\n                    tone={props.tone}\n                    size={props.condensed ? 'small' : 'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"center\" scale={scale}>\n                  {props.condensed ? (\n                    <Text.Detail as=\"span\" isBold truncate>\n                      {props.header}\n                    </Text.Detail>\n                  ) : (\n                    props.header\n                  )}\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper ref={registerContentNode}>\n                {props.description && (\n                  <Spacings.Inset scale={scale}>\n                    <Text.Detail>{props.description}</Text.Detail>\n                  </Spacings.Inset>\n                )}\n                <Spacings.Inset scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    aria-hidden={isOpen ? 'false' : 'true'}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Inset>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\nCollapsiblePanel.getPanelContentId = getPanelContentId;\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"],
210
210
  id: props.id,
211
211
  label: "",
212
212
  onClick: props.isDisabled ? undefined : toggle,
@@ -294,7 +294,7 @@ CollapsiblePanel.Header = CollapsiblePanelHeader$1;
294
294
  var CollapsiblePanel$1 = CollapsiblePanel;
295
295
 
296
296
  // NOTE: This string will be replaced on build time with the package version.
297
- var version = "13.0.4";
297
+ var version = "14.0.2";
298
298
 
299
299
  exports["default"] = CollapsiblePanel$1;
300
300
  exports.version = version;
@@ -238,7 +238,7 @@ CollapsiblePanel.Header = CollapsiblePanelHeader$1;
238
238
  var CollapsiblePanel$1 = CollapsiblePanel;
239
239
 
240
240
  // NOTE: This string will be replaced on build time with the package version.
241
- var version = "13.0.4";
241
+ var version = "14.0.2";
242
242
 
243
243
  exports["default"] = CollapsiblePanel$1;
244
244
  exports.version = version;
@@ -133,7 +133,7 @@ var HeaderContainer = /*#__PURE__*/_styled(AccessibleButton, process.env.NODE_EN
133
133
  } : {
134
134
  target: "e1923bli0",
135
135
  label: "HeaderContainer"
136
- })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AAqBgD","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode } from 'react';\nimport isNil from 'lodash/isNil';\nimport uniqueId from 'lodash/uniqueId';\nimport styled from '@emotion/styled';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\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} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelContentIdPrefix = 'panel-content-';\nconst getPanelContentId = (id?: string) => panelContentIdPrefix + id;\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   * <br />\n   * Signature: `() => void`\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'id'\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  id: uniqueId(),\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelContentId = getPanelContentId(props.id);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle(props.theme)]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(props, isOpen),\n                getThemeStyle(props.theme),\n              ]}\n              id={props.id}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"s\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={props.isDisabled || false}\n                    tone={props.tone}\n                    size={props.condensed ? 'small' : 'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"center\" scale={scale}>\n                  {props.condensed ? (\n                    <Text.Detail as=\"span\" isBold truncate>\n                      {props.header}\n                    </Text.Detail>\n                  ) : (\n                    props.header\n                  )}\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper ref={registerContentNode}>\n                {props.description && (\n                  <Spacings.Inset scale={scale}>\n                    <Text.Detail>{props.description}</Text.Detail>\n                  </Spacings.Inset>\n                )}\n                <Spacings.Inset scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    aria-hidden={isOpen ? 'false' : 'true'}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Inset>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\nCollapsiblePanel.getPanelContentId = getPanelContentId;\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */");
136
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AAqBgD","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode } from 'react';\nimport isNil from 'lodash/isNil';\nimport uniqueId from 'lodash/uniqueId';\nimport styled from '@emotion/styled';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\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} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelContentIdPrefix = 'panel-content-';\nconst getPanelContentId = (id?: string) => panelContentIdPrefix + id;\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'id'\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  id: uniqueId(),\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelContentId = getPanelContentId(props.id);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle(props.theme)]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(props, isOpen),\n                getThemeStyle(props.theme),\n              ]}\n              id={props.id}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"s\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={props.isDisabled || false}\n                    tone={props.tone}\n                    size={props.condensed ? 'small' : 'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"center\" scale={scale}>\n                  {props.condensed ? (\n                    <Text.Detail as=\"span\" isBold truncate>\n                      {props.header}\n                    </Text.Detail>\n                  ) : (\n                    props.header\n                  )}\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper ref={registerContentNode}>\n                {props.description && (\n                  <Spacings.Inset scale={scale}>\n                    <Text.Detail>{props.description}</Text.Detail>\n                  </Spacings.Inset>\n                )}\n                <Spacings.Inset scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    aria-hidden={isOpen ? 'false' : 'true'}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Inset>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\nCollapsiblePanel.getPanelContentId = getPanelContentId;\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */");
137
137
 
138
138
  var panelContentIdPrefix = 'panel-content-';
139
139
 
@@ -182,14 +182,14 @@ var CollapsiblePanel = function CollapsiblePanel(props) {
182
182
  return jsx(Constraints.Horizontal, {
183
183
  max: props.horizontalConstraint,
184
184
  children: jsxs("div", {
185
- css: [baseContainerStyles, getThemeStyle(props.theme), 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":"AA2LY","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode } from 'react';\nimport isNil from 'lodash/isNil';\nimport uniqueId from 'lodash/uniqueId';\nimport styled from '@emotion/styled';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\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} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelContentIdPrefix = 'panel-content-';\nconst getPanelContentId = (id?: string) => panelContentIdPrefix + id;\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   * <br />\n   * Signature: `() => void`\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'id'\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  id: uniqueId(),\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelContentId = getPanelContentId(props.id);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle(props.theme)]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(props, isOpen),\n                getThemeStyle(props.theme),\n              ]}\n              id={props.id}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"s\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={props.isDisabled || false}\n                    tone={props.tone}\n                    size={props.condensed ? 'small' : 'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"center\" scale={scale}>\n                  {props.condensed ? (\n                    <Text.Detail as=\"span\" isBold truncate>\n                      {props.header}\n                    </Text.Detail>\n                  ) : (\n                    props.header\n                  )}\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper ref={registerContentNode}>\n                {props.description && (\n                  <Spacings.Inset scale={scale}>\n                    <Text.Detail>{props.description}</Text.Detail>\n                  </Spacings.Inset>\n                )}\n                <Spacings.Inset scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    aria-hidden={isOpen ? 'false' : 'true'}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Inset>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\nCollapsiblePanel.getPanelContentId = getPanelContentId;\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"] // Allow to override the styles by passing a `className` prop.
185
+ css: [baseContainerStyles, getThemeStyle(props.theme), 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":"AAyLY","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode } from 'react';\nimport isNil from 'lodash/isNil';\nimport uniqueId from 'lodash/uniqueId';\nimport styled from '@emotion/styled';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\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} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelContentIdPrefix = 'panel-content-';\nconst getPanelContentId = (id?: string) => panelContentIdPrefix + id;\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'id'\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  id: uniqueId(),\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelContentId = getPanelContentId(props.id);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle(props.theme)]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(props, isOpen),\n                getThemeStyle(props.theme),\n              ]}\n              id={props.id}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"s\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={props.isDisabled || false}\n                    tone={props.tone}\n                    size={props.condensed ? 'small' : 'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"center\" scale={scale}>\n                  {props.condensed ? (\n                    <Text.Detail as=\"span\" isBold truncate>\n                      {props.header}\n                    </Text.Detail>\n                  ) : (\n                    props.header\n                  )}\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper ref={registerContentNode}>\n                {props.description && (\n                  <Spacings.Inset scale={scale}>\n                    <Text.Detail>{props.description}</Text.Detail>\n                  </Spacings.Inset>\n                )}\n                <Spacings.Inset scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    aria-hidden={isOpen ? 'false' : 'true'}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Inset>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\nCollapsiblePanel.getPanelContentId = getPanelContentId;\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"] // Allow to override the styles by passing a `className` prop.
186
186
  // Custom styles can also be passed using the `css` prop from emotion.
187
187
  // https://emotion.sh/docs/css-prop#style-precedence
188
188
  ,
189
189
  className: props.className,
190
190
  children: [jsxs(HeaderContainer, {
191
191
  as: "div",
192
- css: [getHeaderContainerStyles(props, isOpen), getThemeStyle(props.theme), 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":"AAmMc","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode } from 'react';\nimport isNil from 'lodash/isNil';\nimport uniqueId from 'lodash/uniqueId';\nimport styled from '@emotion/styled';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\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} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelContentIdPrefix = 'panel-content-';\nconst getPanelContentId = (id?: string) => panelContentIdPrefix + id;\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   * <br />\n   * Signature: `() => void`\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'id'\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  id: uniqueId(),\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelContentId = getPanelContentId(props.id);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle(props.theme)]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(props, isOpen),\n                getThemeStyle(props.theme),\n              ]}\n              id={props.id}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"s\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={props.isDisabled || false}\n                    tone={props.tone}\n                    size={props.condensed ? 'small' : 'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"center\" scale={scale}>\n                  {props.condensed ? (\n                    <Text.Detail as=\"span\" isBold truncate>\n                      {props.header}\n                    </Text.Detail>\n                  ) : (\n                    props.header\n                  )}\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper ref={registerContentNode}>\n                {props.description && (\n                  <Spacings.Inset scale={scale}>\n                    <Text.Detail>{props.description}</Text.Detail>\n                  </Spacings.Inset>\n                )}\n                <Spacings.Inset scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    aria-hidden={isOpen ? 'false' : 'true'}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Inset>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\nCollapsiblePanel.getPanelContentId = getPanelContentId;\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"],
192
+ css: [getHeaderContainerStyles(props, isOpen), getThemeStyle(props.theme), 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":"AAiMc","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode } from 'react';\nimport isNil from 'lodash/isNil';\nimport uniqueId from 'lodash/uniqueId';\nimport styled from '@emotion/styled';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\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} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelContentIdPrefix = 'panel-content-';\nconst getPanelContentId = (id?: string) => panelContentIdPrefix + id;\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'id'\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  id: uniqueId(),\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelContentId = getPanelContentId(props.id);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle(props.theme)]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(props, isOpen),\n                getThemeStyle(props.theme),\n              ]}\n              id={props.id}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"s\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={props.isDisabled || false}\n                    tone={props.tone}\n                    size={props.condensed ? 'small' : 'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"center\" scale={scale}>\n                  {props.condensed ? (\n                    <Text.Detail as=\"span\" isBold truncate>\n                      {props.header}\n                    </Text.Detail>\n                  ) : (\n                    props.header\n                  )}\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper ref={registerContentNode}>\n                {props.description && (\n                  <Spacings.Inset scale={scale}>\n                    <Text.Detail>{props.description}</Text.Detail>\n                  </Spacings.Inset>\n                )}\n                <Spacings.Inset scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    aria-hidden={isOpen ? 'false' : 'true'}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Inset>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\nCollapsiblePanel.getPanelContentId = getPanelContentId;\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"],
193
193
  id: props.id,
194
194
  label: "",
195
195
  onClick: props.isDisabled ? undefined : toggle,
@@ -277,6 +277,6 @@ CollapsiblePanel.Header = CollapsiblePanelHeader$1;
277
277
  var CollapsiblePanel$1 = CollapsiblePanel;
278
278
 
279
279
  // NOTE: This string will be replaced on build time with the package version.
280
- var version = "13.0.4";
280
+ var version = "14.0.2";
281
281
 
282
282
  export { CollapsiblePanel$1 as default, version };
@@ -23,7 +23,7 @@ declare const CollapsiblePanel: {
23
23
  (props: TCollapsiblePanel): import("@emotion/react/jsx-runtime").JSX.Element;
24
24
  getPanelContentId: (id?: string | undefined) => string;
25
25
  displayName: string;
26
- defaultProps: Pick<TCollapsiblePanel, "id" | "theme" | "condensed" | "isDisabled" | "horizontalConstraint" | "headerControlsAlignment">;
26
+ defaultProps: Pick<TCollapsiblePanel, "id" | "condensed" | "isDisabled" | "theme" | "horizontalConstraint" | "headerControlsAlignment">;
27
27
  Header: {
28
28
  (props: {
29
29
  children: ReactNode;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@commercetools-uikit/collapsible-panel",
3
3
  "description": "A panel to collapse and expand your content.",
4
- "version": "13.0.4",
4
+ "version": "14.0.2",
5
5
  "bugs": "https://github.com/commercetools/ui-kit/issues",
6
6
  "repository": {
7
7
  "type": "git",
@@ -9,7 +9,7 @@
9
9
  "directory": "packages/components/collapsible-panel"
10
10
  },
11
11
  "homepage": "https://uikit.commercetools.com",
12
- "keywords": ["javascript", "design system", "react", "uikit"],
12
+ "keywords": ["javascript", "typescript", "design-system", "react", "uikit"],
13
13
  "license": "MIT",
14
14
  "publishConfig": {
15
15
  "access": "public"
@@ -19,16 +19,16 @@
19
19
  "module": "dist/commercetools-uikit-collapsible-panel.esm.js",
20
20
  "files": ["dist"],
21
21
  "dependencies": {
22
- "@babel/runtime": "7.17.2",
23
- "@babel/runtime-corejs3": "7.17.2",
24
- "@commercetools-uikit/accessible-button": "13.0.4",
25
- "@commercetools-uikit/collapsible-motion": "13.0.2",
26
- "@commercetools-uikit/constraints": "13.0.2",
27
- "@commercetools-uikit/design-system": "13.0.0",
28
- "@commercetools-uikit/icons": "13.0.2",
29
- "@commercetools-uikit/spacings": "13.0.2",
30
- "@commercetools-uikit/text": "13.0.4",
31
- "@commercetools-uikit/utils": "13.0.2",
22
+ "@babel/runtime": "^7.17.2",
23
+ "@babel/runtime-corejs3": "^7.17.2",
24
+ "@commercetools-uikit/accessible-button": "14.0.1",
25
+ "@commercetools-uikit/collapsible-motion": "14.0.1",
26
+ "@commercetools-uikit/constraints": "14.0.1",
27
+ "@commercetools-uikit/design-system": "14.0.0",
28
+ "@commercetools-uikit/icons": "14.0.1",
29
+ "@commercetools-uikit/spacings": "14.0.1",
30
+ "@commercetools-uikit/text": "14.0.1",
31
+ "@commercetools-uikit/utils": "14.0.1",
32
32
  "@emotion/react": "^11.4.0",
33
33
  "@emotion/styled": "^11.3.0",
34
34
  "lodash": "4.17.21",