@commercetools-uikit/collapsible-panel 14.0.3 → 15.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -61,26 +61,26 @@ export default Example;
61
61
 
62
62
  ## Properties
63
63
 
64
- | Props | Type | Required | Default | Description |
65
- | ------------------------- | -------------------------------------------------------------------------------------------- | :------: | ------------ | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
66
- | `id` | `string` | | `uniqueId()` | An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.&#xA;<br/>&#xA;Read about `getPanelContentId` below for more about this. |
67
- | `header` | `ReactNode` | ✅ | | The title being rendered at top left of the panel |
68
- | `secondaryHeader` | `ReactNode` | | | A secondary header for the panel (only pass if needed) |
69
- | `description` | `string` | | | If passed will be shown below the title as more information regarding the panel |
70
- | `className` | `string` | | | Allow to override the styles by passing a `className` prop.&#xA;<br/>&#xA;Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence). |
71
- | `isSticky` | `boolean` | | | Makes the panel's header sticky in regards to the page's scroll |
72
- | `headerControls` | `ReactNode` | | | Controls at the top right part of the panel |
73
- | `isDisabled` | `boolean` | | `false` | Disables the panel and all interactions with it |
74
- | `children` | `ReactNode` | | | The actual content rendered inside the panel |
75
- | `tone` | `union`<br/>Possible values:<br/>`'urgent' , 'primary'` | | | Indicates the color scheme of the panel. |
76
- | `theme` | `union`<br/>Possible values:<br/>`'dark' , 'light'` | | `'dark'` | Determines the background color of the panel. |
77
- | `condensed` | `boolean` | | `false` | Whenever `true` the headers and content itself&#xA;will consume less space in that to the borders are smaller and everything has less padding |
78
- | `hideExpansionControls` | `boolean` | | | Controls the visibility of the expansion controls on the left |
79
- | `headerControlsAlignment` | `union`<br/>Possible values:<br/>`'left' , 'right'` | | `'right'` | Indicates the position of the control elements in the header component. |
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
- | `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. |
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. |
64
+ | Props | Type | Required | Default | Description |
65
+ | ------------------------- | -------------------------------------------------------------------------------------------- | :------: | --------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
66
+ | `id` | `string` | | | An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.&#xA;<br/>&#xA;Read about `getPanelContentId` below for more about this. |
67
+ | `header` | `ReactNode` | ✅ | | The title being rendered at top left of the panel |
68
+ | `secondaryHeader` | `ReactNode` | | | A secondary header for the panel (only pass if needed) |
69
+ | `description` | `string` | | | If passed will be shown below the title as more information regarding the panel |
70
+ | `className` | `string` | | | Allow to override the styles by passing a `className` prop.&#xA;<br/>&#xA;Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence). |
71
+ | `isSticky` | `boolean` | | | Makes the panel's header sticky in regards to the page's scroll |
72
+ | `headerControls` | `ReactNode` | | | Controls at the top right part of the panel |
73
+ | `isDisabled` | `boolean` | | `false` | Disables the panel and all interactions with it |
74
+ | `children` | `ReactNode` | | | The actual content rendered inside the panel |
75
+ | `tone` | `union`<br/>Possible values:<br/>`'urgent' , 'primary'` | | | Indicates the color scheme of the panel. |
76
+ | `theme` | `union`<br/>Possible values:<br/>`'dark' , 'light'` | | `'dark'` | Determines the background color of the panel. |
77
+ | `condensed` | `boolean` | | `false` | Whenever `true` the headers and content itself&#xA;will consume less space in that to the borders are smaller and everything has less padding |
78
+ | `hideExpansionControls` | `boolean` | | | Controls the visibility of the expansion controls on the left |
79
+ | `headerControlsAlignment` | `union`<br/>Possible values:<br/>`'left' , 'right'` | | `'right'` | Indicates the position of the control elements in the header component. |
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
+ | `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. |
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
86
86
 
@@ -6,9 +6,9 @@ var _styled = require('@emotion/styled/base');
6
6
  var _pt = require('prop-types');
7
7
  require('react');
8
8
  var isNil = require('lodash/isNil');
9
- var uniqueId = require('lodash/uniqueId');
10
9
  var utils = require('@commercetools-uikit/utils');
11
10
  var AccessibleButton = require('@commercetools-uikit/accessible-button');
11
+ var hooks = require('@commercetools-uikit/hooks');
12
12
  var Spacings = require('@commercetools-uikit/spacings');
13
13
  var Text = require('@commercetools-uikit/text');
14
14
  var CollapsibleMotion = require('@commercetools-uikit/collapsible-motion');
@@ -24,7 +24,6 @@ function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e };
24
24
  var _styled__default = /*#__PURE__*/_interopDefault(_styled);
25
25
  var _pt__default = /*#__PURE__*/_interopDefault(_pt);
26
26
  var isNil__default = /*#__PURE__*/_interopDefault(isNil);
27
- var uniqueId__default = /*#__PURE__*/_interopDefault(uniqueId);
28
27
  var AccessibleButton__default = /*#__PURE__*/_interopDefault(AccessibleButton);
29
28
  var Spacings__default = /*#__PURE__*/_interopDefault(Spacings);
30
29
  var Text__default = /*#__PURE__*/_interopDefault(Text);
@@ -150,16 +149,11 @@ var HeaderContainer = /*#__PURE__*/_styled__default["default"](AccessibleButton_
150
149
  } : {
151
150
  target: "e1923bli0",
152
151
  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   */\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
-
155
- var panelContentIdPrefix = 'panel-content-';
156
-
157
- var getPanelContentId = function getPanelContentId(id) {
158
- return panelContentIdPrefix + id;
159
- };
152
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AAyBgD","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle(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={panelButtonId}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"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                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Inset>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */");
160
153
 
154
+ var panelButtonSequentialId = utils.createSequentialId('collapsible-panel-button-');
155
+ var panelContentSequentialId = utils.createSequentialId('collapsible-panel-content-');
161
156
  var defaultProps = {
162
- id: uniqueId__default["default"](),
163
157
  theme: 'dark',
164
158
  condensed: false,
165
159
  isDisabled: false,
@@ -169,7 +163,8 @@ var defaultProps = {
169
163
  // otherwise it will behave like an uncontrolled component.
170
164
 
171
165
  var CollapsiblePanel = function CollapsiblePanel(props) {
172
- var panelContentId = getPanelContentId(props.id); // Pass only `data-*` props
166
+ var panelButtonId = hooks.useFieldId(props.id, panelButtonSequentialId);
167
+ var panelContentId = hooks.useFieldId(undefined, panelContentSequentialId); // Pass only `data-*` props
173
168
 
174
169
  var dataProps = utils.filterDataAttributes(props);
175
170
  var scale = props.condensed ? 's' : 'm';
@@ -199,15 +194,15 @@ var CollapsiblePanel = function CollapsiblePanel(props) {
199
194
  return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
200
195
  max: props.horizontalConstraint,
201
196
  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":"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.
197
+ 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":"AA8LY","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle(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={panelButtonId}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"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                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Inset>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"] // Allow to override the styles by passing a `className` prop.
203
198
  // Custom styles can also be passed using the `css` prop from emotion.
204
199
  // https://emotion.sh/docs/css-prop#style-precedence
205
200
  ,
206
201
  className: props.className,
207
202
  children: [jsxRuntime.jsxs(HeaderContainer, {
208
203
  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":"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
- id: props.id,
204
+ 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":"AAsMc","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle(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={panelButtonId}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"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                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Inset>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"],
205
+ id: panelButtonId,
211
206
  label: "",
212
207
  onClick: props.isDisabled ? undefined : toggle,
213
208
  isDisabled: props.isDisabled,
@@ -255,7 +250,9 @@ var CollapsiblePanel = function CollapsiblePanel(props) {
255
250
  scale: scale,
256
251
  children: jsxRuntime.jsx(SectionContent, {
257
252
  id: panelContentId,
258
- "aria-hidden": isOpen ? 'false' : 'true',
253
+ role: "region",
254
+ "aria-labelledby": panelButtonId,
255
+ hidden: !isOpen,
259
256
  children: props.children
260
257
  })
261
258
  })]
@@ -266,6 +263,10 @@ var CollapsiblePanel = function CollapsiblePanel(props) {
266
263
  }
267
264
  });
268
265
  };
266
+ /**
267
+ * @deprecated This function is no longer supported.
268
+ */
269
+
269
270
 
270
271
  CollapsiblePanel.propTypes = process.env.NODE_ENV !== "production" ? {
271
272
  id: _pt__default["default"].string,
@@ -287,14 +288,18 @@ CollapsiblePanel.propTypes = process.env.NODE_ENV !== "production" ? {
287
288
  onToggle: _pt__default["default"].func,
288
289
  horizontalConstraint: _pt__default["default"].oneOf([6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'])
289
290
  } : {};
290
- CollapsiblePanel.getPanelContentId = getPanelContentId;
291
+
292
+ CollapsiblePanel.getPanelContentId = function () {
293
+ return '';
294
+ };
295
+
291
296
  CollapsiblePanel.displayName = 'CollapsiblePanel';
292
297
  CollapsiblePanel.defaultProps = defaultProps;
293
298
  CollapsiblePanel.Header = CollapsiblePanelHeader$1;
294
299
  var CollapsiblePanel$1 = CollapsiblePanel;
295
300
 
296
301
  // NOTE: This string will be replaced on build time with the package version.
297
- var version = "14.0.3";
302
+ var version = "15.1.0";
298
303
 
299
304
  exports["default"] = CollapsiblePanel$1;
300
305
  exports.version = version;
@@ -6,9 +6,9 @@ var _styled = require('@emotion/styled/base');
6
6
  require('prop-types');
7
7
  require('react');
8
8
  var isNil = require('lodash/isNil');
9
- var uniqueId = require('lodash/uniqueId');
10
9
  var utils = require('@commercetools-uikit/utils');
11
10
  var AccessibleButton = require('@commercetools-uikit/accessible-button');
11
+ var hooks = require('@commercetools-uikit/hooks');
12
12
  var Spacings = require('@commercetools-uikit/spacings');
13
13
  var Text = require('@commercetools-uikit/text');
14
14
  var CollapsibleMotion = require('@commercetools-uikit/collapsible-motion');
@@ -23,7 +23,6 @@ function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e };
23
23
 
24
24
  var _styled__default = /*#__PURE__*/_interopDefault(_styled);
25
25
  var isNil__default = /*#__PURE__*/_interopDefault(isNil);
26
- var uniqueId__default = /*#__PURE__*/_interopDefault(uniqueId);
27
26
  var AccessibleButton__default = /*#__PURE__*/_interopDefault(AccessibleButton);
28
27
  var Spacings__default = /*#__PURE__*/_interopDefault(Spacings);
29
28
  var Text__default = /*#__PURE__*/_interopDefault(Text);
@@ -125,14 +124,9 @@ var HeaderContainer = /*#__PURE__*/_styled__default["default"](AccessibleButton_
125
124
  target: "e1923bli0"
126
125
  } )("" );
127
126
 
128
- var panelContentIdPrefix = 'panel-content-';
129
-
130
- var getPanelContentId = function getPanelContentId(id) {
131
- return panelContentIdPrefix + id;
132
- };
133
-
127
+ var panelButtonSequentialId = utils.createSequentialId('collapsible-panel-button-');
128
+ var panelContentSequentialId = utils.createSequentialId('collapsible-panel-content-');
134
129
  var defaultProps = {
135
- id: uniqueId__default["default"](),
136
130
  theme: 'dark',
137
131
  condensed: false,
138
132
  isDisabled: false,
@@ -142,7 +136,8 @@ var defaultProps = {
142
136
  // otherwise it will behave like an uncontrolled component.
143
137
 
144
138
  var CollapsiblePanel = function CollapsiblePanel(props) {
145
- var panelContentId = getPanelContentId(props.id); // Pass only `data-*` props
139
+ var panelButtonId = hooks.useFieldId(props.id, panelButtonSequentialId);
140
+ var panelContentId = hooks.useFieldId(undefined, panelContentSequentialId); // Pass only `data-*` props
146
141
 
147
142
  var dataProps = utils.filterDataAttributes(props);
148
143
  var scale = props.condensed ? 's' : 'm';
@@ -170,7 +165,7 @@ var CollapsiblePanel = function CollapsiblePanel(props) {
170
165
  children: [jsxRuntime.jsxs(HeaderContainer, {
171
166
  as: "div",
172
167
  css: [getHeaderContainerStyles(props, isOpen), getThemeStyle(props.theme), "" , "" ],
173
- id: props.id,
168
+ id: panelButtonId,
174
169
  label: "",
175
170
  onClick: props.isDisabled ? undefined : toggle,
176
171
  isDisabled: props.isDisabled,
@@ -218,7 +213,9 @@ var CollapsiblePanel = function CollapsiblePanel(props) {
218
213
  scale: scale,
219
214
  children: jsxRuntime.jsx(SectionContent, {
220
215
  id: panelContentId,
221
- "aria-hidden": isOpen ? 'false' : 'true',
216
+ role: "region",
217
+ "aria-labelledby": panelButtonId,
218
+ hidden: !isOpen,
222
219
  children: props.children
223
220
  })
224
221
  })]
@@ -229,16 +226,24 @@ var CollapsiblePanel = function CollapsiblePanel(props) {
229
226
  }
230
227
  });
231
228
  };
229
+ /**
230
+ * @deprecated This function is no longer supported.
231
+ */
232
+
232
233
 
233
234
  CollapsiblePanel.propTypes = {};
234
- CollapsiblePanel.getPanelContentId = getPanelContentId;
235
+
236
+ CollapsiblePanel.getPanelContentId = function () {
237
+ return '';
238
+ };
239
+
235
240
  CollapsiblePanel.displayName = 'CollapsiblePanel';
236
241
  CollapsiblePanel.defaultProps = defaultProps;
237
242
  CollapsiblePanel.Header = CollapsiblePanelHeader$1;
238
243
  var CollapsiblePanel$1 = CollapsiblePanel;
239
244
 
240
245
  // NOTE: This string will be replaced on build time with the package version.
241
- var version = "14.0.3";
246
+ var version = "15.1.0";
242
247
 
243
248
  exports["default"] = CollapsiblePanel$1;
244
249
  exports.version = version;
@@ -2,9 +2,9 @@ import _styled from '@emotion/styled/base';
2
2
  import _pt from 'prop-types';
3
3
  import 'react';
4
4
  import isNil from 'lodash/isNil';
5
- import uniqueId from 'lodash/uniqueId';
6
- import { filterDataAttributes, warning } from '@commercetools-uikit/utils';
5
+ import { createSequentialId, filterDataAttributes, warning } from '@commercetools-uikit/utils';
7
6
  import AccessibleButton from '@commercetools-uikit/accessible-button';
7
+ import { useFieldId } from '@commercetools-uikit/hooks';
8
8
  import Spacings from '@commercetools-uikit/spacings';
9
9
  import Text from '@commercetools-uikit/text';
10
10
  import CollapsibleMotion from '@commercetools-uikit/collapsible-motion';
@@ -133,16 +133,11 @@ 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   */\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
-
138
- var panelContentIdPrefix = 'panel-content-';
139
-
140
- var getPanelContentId = function getPanelContentId(id) {
141
- return panelContentIdPrefix + id;
142
- };
136
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AAyBgD","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle(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={panelButtonId}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"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                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Inset>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */");
143
137
 
138
+ var panelButtonSequentialId = createSequentialId('collapsible-panel-button-');
139
+ var panelContentSequentialId = createSequentialId('collapsible-panel-content-');
144
140
  var defaultProps = {
145
- id: uniqueId(),
146
141
  theme: 'dark',
147
142
  condensed: false,
148
143
  isDisabled: false,
@@ -152,7 +147,8 @@ var defaultProps = {
152
147
  // otherwise it will behave like an uncontrolled component.
153
148
 
154
149
  var CollapsiblePanel = function CollapsiblePanel(props) {
155
- var panelContentId = getPanelContentId(props.id); // Pass only `data-*` props
150
+ var panelButtonId = useFieldId(props.id, panelButtonSequentialId);
151
+ var panelContentId = useFieldId(undefined, panelContentSequentialId); // Pass only `data-*` props
156
152
 
157
153
  var dataProps = filterDataAttributes(props);
158
154
  var scale = props.condensed ? 's' : 'm';
@@ -182,15 +178,15 @@ var CollapsiblePanel = function CollapsiblePanel(props) {
182
178
  return jsx(Constraints.Horizontal, {
183
179
  max: props.horizontalConstraint,
184
180
  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":"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.
181
+ 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":"AA8LY","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle(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={panelButtonId}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"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                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Inset>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"] // Allow to override the styles by passing a `className` prop.
186
182
  // Custom styles can also be passed using the `css` prop from emotion.
187
183
  // https://emotion.sh/docs/css-prop#style-precedence
188
184
  ,
189
185
  className: props.className,
190
186
  children: [jsxs(HeaderContainer, {
191
187
  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":"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
- id: props.id,
188
+ 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":"AAsMc","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst defaultProps: Pick<\n  TCollapsiblePanel,\n  | 'theme'\n  | 'condensed'\n  | 'isDisabled'\n  | 'headerControlsAlignment'\n  | 'horizontalConstraint'\n> = {\n  theme: 'dark',\n  condensed: false,\n  isDisabled: false,\n  headerControlsAlignment: 'right',\n  horizontalConstraint: 'scale',\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = (props: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes(props);\n  const scale = props.condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={props.horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle(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={panelButtonId}\n              label=\"\"\n              onClick={props.isDisabled ? undefined : toggle}\n              isDisabled={props.isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"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                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Inset>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.defaultProps = defaultProps;\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"],
189
+ id: panelButtonId,
194
190
  label: "",
195
191
  onClick: props.isDisabled ? undefined : toggle,
196
192
  isDisabled: props.isDisabled,
@@ -238,7 +234,9 @@ var CollapsiblePanel = function CollapsiblePanel(props) {
238
234
  scale: scale,
239
235
  children: jsx(SectionContent, {
240
236
  id: panelContentId,
241
- "aria-hidden": isOpen ? 'false' : 'true',
237
+ role: "region",
238
+ "aria-labelledby": panelButtonId,
239
+ hidden: !isOpen,
242
240
  children: props.children
243
241
  })
244
242
  })]
@@ -249,6 +247,10 @@ var CollapsiblePanel = function CollapsiblePanel(props) {
249
247
  }
250
248
  });
251
249
  };
250
+ /**
251
+ * @deprecated This function is no longer supported.
252
+ */
253
+
252
254
 
253
255
  CollapsiblePanel.propTypes = process.env.NODE_ENV !== "production" ? {
254
256
  id: _pt.string,
@@ -270,13 +272,17 @@ CollapsiblePanel.propTypes = process.env.NODE_ENV !== "production" ? {
270
272
  onToggle: _pt.func,
271
273
  horizontalConstraint: _pt.oneOf([6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'])
272
274
  } : {};
273
- CollapsiblePanel.getPanelContentId = getPanelContentId;
275
+
276
+ CollapsiblePanel.getPanelContentId = function () {
277
+ return '';
278
+ };
279
+
274
280
  CollapsiblePanel.displayName = 'CollapsiblePanel';
275
281
  CollapsiblePanel.defaultProps = defaultProps;
276
282
  CollapsiblePanel.Header = CollapsiblePanelHeader$1;
277
283
  var CollapsiblePanel$1 = CollapsiblePanel;
278
284
 
279
285
  // NOTE: This string will be replaced on build time with the package version.
280
- var version = "14.0.3";
286
+ var version = "15.1.0";
281
287
 
282
288
  export { CollapsiblePanel$1 as default, version };
@@ -21,9 +21,9 @@ export declare type TCollapsiblePanel = {
21
21
  };
22
22
  declare const CollapsiblePanel: {
23
23
  (props: TCollapsiblePanel): import("@emotion/react/jsx-runtime").JSX.Element;
24
- getPanelContentId: (id?: string | undefined) => string;
24
+ getPanelContentId(): string;
25
25
  displayName: string;
26
- defaultProps: Pick<TCollapsiblePanel, "id" | "theme" | "isDisabled" | "condensed" | "horizontalConstraint" | "headerControlsAlignment">;
26
+ defaultProps: Pick<TCollapsiblePanel, "theme" | "condensed" | "isDisabled" | "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": "14.0.3",
4
+ "version": "15.1.0",
5
5
  "bugs": "https://github.com/commercetools/ui-kit/issues",
6
6
  "repository": {
7
7
  "type": "git",
@@ -21,14 +21,15 @@
21
21
  "dependencies": {
22
22
  "@babel/runtime": "^7.17.2",
23
23
  "@babel/runtime-corejs3": "^7.17.2",
24
- "@commercetools-uikit/accessible-button": "14.0.1",
25
- "@commercetools-uikit/collapsible-motion": "14.0.3",
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",
24
+ "@commercetools-uikit/accessible-button": "15.1.0",
25
+ "@commercetools-uikit/collapsible-motion": "15.1.0",
26
+ "@commercetools-uikit/constraints": "15.1.0",
27
+ "@commercetools-uikit/design-system": "15.1.0",
28
+ "@commercetools-uikit/hooks": "15.1.0",
29
+ "@commercetools-uikit/icons": "15.1.0",
30
+ "@commercetools-uikit/spacings": "15.1.0",
31
+ "@commercetools-uikit/text": "15.1.0",
32
+ "@commercetools-uikit/utils": "15.1.0",
32
33
  "@emotion/react": "^11.4.0",
33
34
  "@emotion/styled": "^11.3.0",
34
35
  "lodash": "4.17.21",