@commercetools-uikit/collapsible-panel 19.26.0 → 20.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/commercetools-uikit-collapsible-panel.cjs.dev.js +6 -32
- package/dist/commercetools-uikit-collapsible-panel.cjs.prod.js +3 -6
- package/dist/commercetools-uikit-collapsible-panel.esm.js +7 -32
- package/dist/declarations/src/collapsible-panel.d.ts +4 -2
- package/package.json +13 -14
package/README.md
CHANGED
|
@@ -64,7 +64,7 @@ export default Example;
|
|
|
64
64
|
| Props | Type | Required | Default | Description |
|
|
65
65
|
| ------------------------- | -------------------------------------------------------------------------------------------- | :------: | --------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
|
66
66
|
| `id` | `string` | | | An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.
<br/>
Read about `getPanelContentId` below for more about this. |
|
|
67
|
-
| `header` | `ReactNode`
|
|
67
|
+
| `header` | `union`<br/>Possible values:<br/>`ReactElement<{ isCondensed?: boolean }> , ReactNode` | ✅ | | The title being rendered at top left of the panel |
|
|
68
68
|
| `secondaryHeader` | `ReactNode` | | | A secondary header for the panel (only pass if needed) |
|
|
69
69
|
| `description` | `string` | | | If passed will be shown below the title as more information regarding the panel |
|
|
70
70
|
| `className` | `string` | | | Allow to override the styles by passing a `className` prop.
<br/>
Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence). |
|
|
@@ -13,7 +13,6 @@ var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/obje
|
|
|
13
13
|
var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
14
14
|
var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
|
|
15
15
|
var _styled = require('@emotion/styled/base');
|
|
16
|
-
var _pt = require('prop-types');
|
|
17
16
|
var react$1 = require('react');
|
|
18
17
|
var isNil = require('lodash/isNil');
|
|
19
18
|
var utils = require('@commercetools-uikit/utils');
|
|
@@ -39,7 +38,6 @@ var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_O
|
|
|
39
38
|
var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
|
|
40
39
|
var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
|
|
41
40
|
var _styled__default = /*#__PURE__*/_interopDefault(_styled);
|
|
42
|
-
var _pt__default = /*#__PURE__*/_interopDefault(_pt);
|
|
43
41
|
var isNil__default = /*#__PURE__*/_interopDefault(isNil);
|
|
44
42
|
var AccessibleButton__default = /*#__PURE__*/_interopDefault(AccessibleButton);
|
|
45
43
|
var Spacings__default = /*#__PURE__*/_interopDefault(Spacings);
|
|
@@ -155,10 +153,6 @@ const CollapsiblePanelHeader = props => props.isCondensed ? jsxRuntime.jsx(jsxRu
|
|
|
155
153
|
truncate: true,
|
|
156
154
|
children: props.children
|
|
157
155
|
});
|
|
158
|
-
CollapsiblePanelHeader.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
159
|
-
children: _pt__default["default"].node.isRequired,
|
|
160
|
-
isCondensed: _pt__default["default"].bool
|
|
161
|
-
} : {};
|
|
162
156
|
CollapsiblePanelHeader.displayName = 'CollapsiblePanelHeader';
|
|
163
157
|
var CollapsiblePanelHeader$1 = CollapsiblePanelHeader;
|
|
164
158
|
|
|
@@ -170,7 +164,7 @@ const HeaderContainer = /*#__PURE__*/_styled__default["default"](AccessibleButto
|
|
|
170
164
|
} : {
|
|
171
165
|
target: "e1923bli0",
|
|
172
166
|
label: "HeaderContainer"
|
|
173
|
-
})(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AA0BgD","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, cloneElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {/* TODO: this is a temporary fix, which will be refactored after we align with the desing team on how to proceed */}\n      {typeof props.header === 'string'\n        ? props.header\n        : cloneElement(props.header as React.ReactElement, {\n            isCondensed: props.condensed,\n          })}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = ({\n  theme = 'dark',\n  condensed = false,\n  isDisabled = false,\n  headerControlsAlignment = 'right',\n  horizontalConstraint = 'scale',\n  ...props\n}: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes({\n    theme,\n    condensed,\n    isDisabled,\n    headerControlsAlignment,\n    horizontalConstraint,\n    ...props,\n  });\n  const scale = condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(\n                  {\n                    condensed,\n                    isDisabled,\n                    headerControlsAlignment,\n                    ...props,\n                  },\n                  isOpen\n                ),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={isDisabled ? undefined : toggle}\n              isDisabled={isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText header={props.header} condensed={condensed} />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */");
|
|
167
|
+
})(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AA0BgD","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, ReactElement, cloneElement, isValidElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactElement<{ isCondensed?: boolean }> | ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {isValidElement<{ isCondensed?: boolean }>(props.header)\n        ? cloneElement(props.header, {\n            isCondensed: props.condensed,\n          })\n        : props.header}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = ({\n  theme = 'dark',\n  condensed = false,\n  isDisabled = false,\n  headerControlsAlignment = 'right',\n  horizontalConstraint = 'scale',\n  ...props\n}: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes({\n    theme,\n    condensed,\n    isDisabled,\n    headerControlsAlignment,\n    horizontalConstraint,\n    ...props,\n  });\n  const scale = condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(\n                  {\n                    condensed,\n                    isDisabled,\n                    headerControlsAlignment,\n                    ...props,\n                  },\n                  isOpen\n                ),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={isDisabled ? undefined : toggle}\n              isDisabled={isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText header={props.header} condensed={condensed} />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */");
|
|
174
168
|
const panelButtonSequentialId = utils.createSequentialId('collapsible-panel-button-');
|
|
175
169
|
const panelContentSequentialId = utils.createSequentialId('collapsible-panel-content-');
|
|
176
170
|
const HeadLineText = props => {
|
|
@@ -182,9 +176,9 @@ const HeadLineText = props => {
|
|
|
182
176
|
return jsxRuntime.jsx(Text__default["default"].Subheadline, {
|
|
183
177
|
as: "h4",
|
|
184
178
|
truncate: true,
|
|
185
|
-
children:
|
|
179
|
+
children: /*#__PURE__*/react$1.isValidElement(props.header) ? /*#__PURE__*/react$1.cloneElement(props.header, {
|
|
186
180
|
isCondensed: props.condensed
|
|
187
|
-
})
|
|
181
|
+
}) : props.header
|
|
188
182
|
});
|
|
189
183
|
};
|
|
190
184
|
|
|
@@ -239,7 +233,7 @@ const CollapsiblePanel = _ref => {
|
|
|
239
233
|
return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
|
|
240
234
|
max: horizontalConstraint,
|
|
241
235
|
children: jsxRuntime.jsxs("div", {
|
|
242
|
-
css: [baseContainerStyles, getThemeStyle('light'), process.env.NODE_ENV === "production" ? "" : ";label:CollapsiblePanel;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AAiNY","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, cloneElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {/* TODO: this is a temporary fix, which will be refactored after we align with the desing team on how to proceed */}\n      {typeof props.header === 'string'\n        ? props.header\n        : cloneElement(props.header as React.ReactElement, {\n            isCondensed: props.condensed,\n          })}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = ({\n  theme = 'dark',\n  condensed = false,\n  isDisabled = false,\n  headerControlsAlignment = 'right',\n  horizontalConstraint = 'scale',\n  ...props\n}: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes({\n    theme,\n    condensed,\n    isDisabled,\n    headerControlsAlignment,\n    horizontalConstraint,\n    ...props,\n  });\n  const scale = condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(\n                  {\n                    condensed,\n                    isDisabled,\n                    headerControlsAlignment,\n                    ...props,\n                  },\n                  isOpen\n                ),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={isDisabled ? undefined : toggle}\n              isDisabled={isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText header={props.header} condensed={condensed} />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"]
|
|
236
|
+
css: [baseContainerStyles, getThemeStyle('light'), process.env.NODE_ENV === "production" ? "" : ";label:CollapsiblePanel;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AAgNY","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, ReactElement, cloneElement, isValidElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactElement<{ isCondensed?: boolean }> | ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {isValidElement<{ isCondensed?: boolean }>(props.header)\n        ? cloneElement(props.header, {\n            isCondensed: props.condensed,\n          })\n        : props.header}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = ({\n  theme = 'dark',\n  condensed = false,\n  isDisabled = false,\n  headerControlsAlignment = 'right',\n  horizontalConstraint = 'scale',\n  ...props\n}: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes({\n    theme,\n    condensed,\n    isDisabled,\n    headerControlsAlignment,\n    horizontalConstraint,\n    ...props,\n  });\n  const scale = condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(\n                  {\n                    condensed,\n                    isDisabled,\n                    headerControlsAlignment,\n                    ...props,\n                  },\n                  isOpen\n                ),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={isDisabled ? undefined : toggle}\n              isDisabled={isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText header={props.header} condensed={condensed} />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"]
|
|
243
237
|
// Allow to override the styles by passing a `className` prop.
|
|
244
238
|
// Custom styles can also be passed using the `css` prop from emotion.
|
|
245
239
|
// https://emotion.sh/docs/css-prop#style-precedence
|
|
@@ -251,7 +245,7 @@ const CollapsiblePanel = _ref => {
|
|
|
251
245
|
condensed,
|
|
252
246
|
isDisabled,
|
|
253
247
|
headerControlsAlignment
|
|
254
|
-
}, props), isOpen), getThemeStyle('light'), process.env.NODE_ENV === "production" ? "" : ";label:CollapsiblePanel;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AAyNc","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, cloneElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {/* TODO: this is a temporary fix, which will be refactored after we align with the desing team on how to proceed */}\n      {typeof props.header === 'string'\n        ? props.header\n        : cloneElement(props.header as React.ReactElement, {\n            isCondensed: props.condensed,\n          })}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = ({\n  theme = 'dark',\n  condensed = false,\n  isDisabled = false,\n  headerControlsAlignment = 'right',\n  horizontalConstraint = 'scale',\n  ...props\n}: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes({\n    theme,\n    condensed,\n    isDisabled,\n    headerControlsAlignment,\n    horizontalConstraint,\n    ...props,\n  });\n  const scale = condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(\n                  {\n                    condensed,\n                    isDisabled,\n                    headerControlsAlignment,\n                    ...props,\n                  },\n                  isOpen\n                ),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={isDisabled ? undefined : toggle}\n              isDisabled={isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText header={props.header} condensed={condensed} />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"],
|
|
248
|
+
}, props), isOpen), getThemeStyle('light'), process.env.NODE_ENV === "production" ? "" : ";label:CollapsiblePanel;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AAwNc","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, ReactElement, cloneElement, isValidElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactElement<{ isCondensed?: boolean }> | ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {isValidElement<{ isCondensed?: boolean }>(props.header)\n        ? cloneElement(props.header, {\n            isCondensed: props.condensed,\n          })\n        : props.header}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = ({\n  theme = 'dark',\n  condensed = false,\n  isDisabled = false,\n  headerControlsAlignment = 'right',\n  horizontalConstraint = 'scale',\n  ...props\n}: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes({\n    theme,\n    condensed,\n    isDisabled,\n    headerControlsAlignment,\n    horizontalConstraint,\n    ...props,\n  });\n  const scale = condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(\n                  {\n                    condensed,\n                    isDisabled,\n                    headerControlsAlignment,\n                    ...props,\n                  },\n                  isOpen\n                ),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={isDisabled ? undefined : toggle}\n              isDisabled={isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText header={props.header} condensed={condensed} />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"],
|
|
255
249
|
id: panelButtonId,
|
|
256
250
|
label: "",
|
|
257
251
|
onClick: isDisabled ? undefined : toggle,
|
|
@@ -317,33 +311,13 @@ const CollapsiblePanel = _ref => {
|
|
|
317
311
|
/**
|
|
318
312
|
* @deprecated This function is no longer supported.
|
|
319
313
|
*/
|
|
320
|
-
CollapsiblePanel.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
321
|
-
id: _pt__default["default"].string,
|
|
322
|
-
header: _pt__default["default"].node.isRequired,
|
|
323
|
-
secondaryHeader: _pt__default["default"].node,
|
|
324
|
-
description: _pt__default["default"].string,
|
|
325
|
-
className: _pt__default["default"].string,
|
|
326
|
-
isSticky: _pt__default["default"].bool,
|
|
327
|
-
headerControls: _pt__default["default"].node,
|
|
328
|
-
isDisabled: _pt__default["default"].bool,
|
|
329
|
-
children: _pt__default["default"].node,
|
|
330
|
-
tone: _pt__default["default"].oneOf(['urgent', 'primary']),
|
|
331
|
-
theme: _pt__default["default"].oneOf(['dark', 'light']),
|
|
332
|
-
condensed: _pt__default["default"].bool,
|
|
333
|
-
hideExpansionControls: _pt__default["default"].bool,
|
|
334
|
-
headerControlsAlignment: _pt__default["default"].oneOf(['left', 'right']),
|
|
335
|
-
isDefaultClosed: _pt__default["default"].bool,
|
|
336
|
-
isClosed: _pt__default["default"].bool,
|
|
337
|
-
onToggle: _pt__default["default"].func,
|
|
338
|
-
horizontalConstraint: _pt__default["default"].oneOf([6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'])
|
|
339
|
-
} : {};
|
|
340
314
|
CollapsiblePanel.getPanelContentId = () => '';
|
|
341
315
|
CollapsiblePanel.displayName = 'CollapsiblePanel';
|
|
342
316
|
CollapsiblePanel.Header = CollapsiblePanelHeader$1;
|
|
343
317
|
var CollapsiblePanel$1 = CollapsiblePanel;
|
|
344
318
|
|
|
345
319
|
// NOTE: This string will be replaced on build time with the package version.
|
|
346
|
-
var version = "
|
|
320
|
+
var version = "20.0.0";
|
|
347
321
|
|
|
348
322
|
exports["default"] = CollapsiblePanel$1;
|
|
349
323
|
exports.version = version;
|
|
@@ -13,7 +13,6 @@ var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/obje
|
|
|
13
13
|
var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
14
14
|
var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
|
|
15
15
|
var _styled = require('@emotion/styled/base');
|
|
16
|
-
require('prop-types');
|
|
17
16
|
var react$1 = require('react');
|
|
18
17
|
var isNil = require('lodash/isNil');
|
|
19
18
|
var utils = require('@commercetools-uikit/utils');
|
|
@@ -131,7 +130,6 @@ const CollapsiblePanelHeader = props => props.isCondensed ? jsxRuntime.jsx(jsxRu
|
|
|
131
130
|
truncate: true,
|
|
132
131
|
children: props.children
|
|
133
132
|
});
|
|
134
|
-
CollapsiblePanelHeader.propTypes = {};
|
|
135
133
|
CollapsiblePanelHeader.displayName = 'CollapsiblePanelHeader';
|
|
136
134
|
var CollapsiblePanelHeader$1 = CollapsiblePanelHeader;
|
|
137
135
|
|
|
@@ -152,9 +150,9 @@ const HeadLineText = props => {
|
|
|
152
150
|
return jsxRuntime.jsx(Text__default["default"].Subheadline, {
|
|
153
151
|
as: "h4",
|
|
154
152
|
truncate: true,
|
|
155
|
-
children:
|
|
153
|
+
children: /*#__PURE__*/react$1.isValidElement(props.header) ? /*#__PURE__*/react$1.cloneElement(props.header, {
|
|
156
154
|
isCondensed: props.condensed
|
|
157
|
-
})
|
|
155
|
+
}) : props.header
|
|
158
156
|
});
|
|
159
157
|
};
|
|
160
158
|
|
|
@@ -276,14 +274,13 @@ const CollapsiblePanel = _ref => {
|
|
|
276
274
|
/**
|
|
277
275
|
* @deprecated This function is no longer supported.
|
|
278
276
|
*/
|
|
279
|
-
CollapsiblePanel.propTypes = {};
|
|
280
277
|
CollapsiblePanel.getPanelContentId = () => '';
|
|
281
278
|
CollapsiblePanel.displayName = 'CollapsiblePanel';
|
|
282
279
|
CollapsiblePanel.Header = CollapsiblePanelHeader$1;
|
|
283
280
|
var CollapsiblePanel$1 = CollapsiblePanel;
|
|
284
281
|
|
|
285
282
|
// NOTE: This string will be replaced on build time with the package version.
|
|
286
|
-
var version = "
|
|
283
|
+
var version = "20.0.0";
|
|
287
284
|
|
|
288
285
|
exports["default"] = CollapsiblePanel$1;
|
|
289
286
|
exports.version = version;
|
|
@@ -9,8 +9,7 @@ import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object
|
|
|
9
9
|
import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
|
|
10
10
|
import _objectWithoutProperties from '@babel/runtime-corejs3/helpers/esm/objectWithoutProperties';
|
|
11
11
|
import _styled from '@emotion/styled/base';
|
|
12
|
-
import
|
|
13
|
-
import { forwardRef, cloneElement } from 'react';
|
|
12
|
+
import { forwardRef, isValidElement, cloneElement } from 'react';
|
|
14
13
|
import isNil from 'lodash/isNil';
|
|
15
14
|
import { createSequentialId, filterDataAttributes, warning } from '@commercetools-uikit/utils';
|
|
16
15
|
import AccessibleButton from '@commercetools-uikit/accessible-button';
|
|
@@ -132,10 +131,6 @@ const CollapsiblePanelHeader = props => props.isCondensed ? jsx(Fragment, {
|
|
|
132
131
|
truncate: true,
|
|
133
132
|
children: props.children
|
|
134
133
|
});
|
|
135
|
-
CollapsiblePanelHeader.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
136
|
-
children: _pt.node.isRequired,
|
|
137
|
-
isCondensed: _pt.bool
|
|
138
|
-
} : {};
|
|
139
134
|
CollapsiblePanelHeader.displayName = 'CollapsiblePanelHeader';
|
|
140
135
|
var CollapsiblePanelHeader$1 = CollapsiblePanelHeader;
|
|
141
136
|
|
|
@@ -147,7 +142,7 @@ const HeaderContainer = /*#__PURE__*/_styled(AccessibleButton, process.env.NODE_
|
|
|
147
142
|
} : {
|
|
148
143
|
target: "e1923bli0",
|
|
149
144
|
label: "HeaderContainer"
|
|
150
|
-
})(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AA0BgD","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, cloneElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {/* TODO: this is a temporary fix, which will be refactored after we align with the desing team on how to proceed */}\n      {typeof props.header === 'string'\n        ? props.header\n        : cloneElement(props.header as React.ReactElement, {\n            isCondensed: props.condensed,\n          })}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = ({\n  theme = 'dark',\n  condensed = false,\n  isDisabled = false,\n  headerControlsAlignment = 'right',\n  horizontalConstraint = 'scale',\n  ...props\n}: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes({\n    theme,\n    condensed,\n    isDisabled,\n    headerControlsAlignment,\n    horizontalConstraint,\n    ...props,\n  });\n  const scale = condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(\n                  {\n                    condensed,\n                    isDisabled,\n                    headerControlsAlignment,\n                    ...props,\n                  },\n                  isOpen\n                ),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={isDisabled ? undefined : toggle}\n              isDisabled={isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText header={props.header} condensed={condensed} />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */");
|
|
145
|
+
})(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AA0BgD","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, ReactElement, cloneElement, isValidElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactElement<{ isCondensed?: boolean }> | ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {isValidElement<{ isCondensed?: boolean }>(props.header)\n        ? cloneElement(props.header, {\n            isCondensed: props.condensed,\n          })\n        : props.header}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = ({\n  theme = 'dark',\n  condensed = false,\n  isDisabled = false,\n  headerControlsAlignment = 'right',\n  horizontalConstraint = 'scale',\n  ...props\n}: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes({\n    theme,\n    condensed,\n    isDisabled,\n    headerControlsAlignment,\n    horizontalConstraint,\n    ...props,\n  });\n  const scale = condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(\n                  {\n                    condensed,\n                    isDisabled,\n                    headerControlsAlignment,\n                    ...props,\n                  },\n                  isOpen\n                ),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={isDisabled ? undefined : toggle}\n              isDisabled={isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText header={props.header} condensed={condensed} />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */");
|
|
151
146
|
const panelButtonSequentialId = createSequentialId('collapsible-panel-button-');
|
|
152
147
|
const panelContentSequentialId = createSequentialId('collapsible-panel-content-');
|
|
153
148
|
const HeadLineText = props => {
|
|
@@ -159,9 +154,9 @@ const HeadLineText = props => {
|
|
|
159
154
|
return jsx(Text.Subheadline, {
|
|
160
155
|
as: "h4",
|
|
161
156
|
truncate: true,
|
|
162
|
-
children:
|
|
157
|
+
children: /*#__PURE__*/isValidElement(props.header) ? /*#__PURE__*/cloneElement(props.header, {
|
|
163
158
|
isCondensed: props.condensed
|
|
164
|
-
})
|
|
159
|
+
}) : props.header
|
|
165
160
|
});
|
|
166
161
|
};
|
|
167
162
|
|
|
@@ -216,7 +211,7 @@ const CollapsiblePanel = _ref => {
|
|
|
216
211
|
return jsx(Constraints.Horizontal, {
|
|
217
212
|
max: horizontalConstraint,
|
|
218
213
|
children: jsxs("div", {
|
|
219
|
-
css: [baseContainerStyles, getThemeStyle('light'), process.env.NODE_ENV === "production" ? "" : ";label:CollapsiblePanel;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AAiNY","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, cloneElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {/* TODO: this is a temporary fix, which will be refactored after we align with the desing team on how to proceed */}\n      {typeof props.header === 'string'\n        ? props.header\n        : cloneElement(props.header as React.ReactElement, {\n            isCondensed: props.condensed,\n          })}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = ({\n  theme = 'dark',\n  condensed = false,\n  isDisabled = false,\n  headerControlsAlignment = 'right',\n  horizontalConstraint = 'scale',\n  ...props\n}: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes({\n    theme,\n    condensed,\n    isDisabled,\n    headerControlsAlignment,\n    horizontalConstraint,\n    ...props,\n  });\n  const scale = condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(\n                  {\n                    condensed,\n                    isDisabled,\n                    headerControlsAlignment,\n                    ...props,\n                  },\n                  isOpen\n                ),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={isDisabled ? undefined : toggle}\n              isDisabled={isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText header={props.header} condensed={condensed} />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"]
|
|
214
|
+
css: [baseContainerStyles, getThemeStyle('light'), process.env.NODE_ENV === "production" ? "" : ";label:CollapsiblePanel;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AAgNY","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, ReactElement, cloneElement, isValidElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactElement<{ isCondensed?: boolean }> | ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {isValidElement<{ isCondensed?: boolean }>(props.header)\n        ? cloneElement(props.header, {\n            isCondensed: props.condensed,\n          })\n        : props.header}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = ({\n  theme = 'dark',\n  condensed = false,\n  isDisabled = false,\n  headerControlsAlignment = 'right',\n  horizontalConstraint = 'scale',\n  ...props\n}: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes({\n    theme,\n    condensed,\n    isDisabled,\n    headerControlsAlignment,\n    horizontalConstraint,\n    ...props,\n  });\n  const scale = condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(\n                  {\n                    condensed,\n                    isDisabled,\n                    headerControlsAlignment,\n                    ...props,\n                  },\n                  isOpen\n                ),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={isDisabled ? undefined : toggle}\n              isDisabled={isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText header={props.header} condensed={condensed} />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"]
|
|
220
215
|
// Allow to override the styles by passing a `className` prop.
|
|
221
216
|
// Custom styles can also be passed using the `css` prop from emotion.
|
|
222
217
|
// https://emotion.sh/docs/css-prop#style-precedence
|
|
@@ -228,7 +223,7 @@ const CollapsiblePanel = _ref => {
|
|
|
228
223
|
condensed,
|
|
229
224
|
isDisabled,
|
|
230
225
|
headerControlsAlignment
|
|
231
|
-
}, props), isOpen), getThemeStyle('light'), process.env.NODE_ENV === "production" ? "" : ";label:CollapsiblePanel;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AAyNc","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, cloneElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {/* TODO: this is a temporary fix, which will be refactored after we align with the desing team on how to proceed */}\n      {typeof props.header === 'string'\n        ? props.header\n        : cloneElement(props.header as React.ReactElement, {\n            isCondensed: props.condensed,\n          })}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = ({\n  theme = 'dark',\n  condensed = false,\n  isDisabled = false,\n  headerControlsAlignment = 'right',\n  horizontalConstraint = 'scale',\n  ...props\n}: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes({\n    theme,\n    condensed,\n    isDisabled,\n    headerControlsAlignment,\n    horizontalConstraint,\n    ...props,\n  });\n  const scale = condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(\n                  {\n                    condensed,\n                    isDisabled,\n                    headerControlsAlignment,\n                    ...props,\n                  },\n                  isOpen\n                ),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={isDisabled ? undefined : toggle}\n              isDisabled={isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText header={props.header} condensed={condensed} />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"],
|
|
226
|
+
}, props), isOpen), getThemeStyle('light'), process.env.NODE_ENV === "production" ? "" : ";label:CollapsiblePanel;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["collapsible-panel.tsx"],"names":[],"mappings":"AAwNc","file":"collapsible-panel.tsx","sourcesContent":["import { ReactNode, ReactElement, cloneElement, isValidElement } from 'react';\nimport isNil from 'lodash/isNil';\nimport styled from '@emotion/styled';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Constraints from '@commercetools-uikit/constraints';\nimport HeaderIcon from './header-icon';\nimport {\n  baseContainerStyles,\n  getHeaderContainerStyles,\n  getThemeStyle,\n  HeaderControlsWrapper,\n  SectionWrapper,\n  SectionContent,\n  SectionDescriptionWrapper,\n} from './collapsible-panel.styles';\nimport CollapsiblePanelHeader from './collapsible-panel-header';\n\nconst HeaderContainer = styled(AccessibleButton)``;\n\nconst panelButtonSequentialId = createSequentialId('collapsible-panel-button-');\nconst panelContentSequentialId = createSequentialId(\n  'collapsible-panel-content-'\n);\n\nexport type TCollapsiblePanel = {\n  /**\n   * An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.\n   * <br/>\n   * Read about `getPanelContentId` below for more about this.\n   */\n  id?: string;\n  /**\n   * The title being rendered at top left of the panel\n   */\n  header: ReactElement<{ isCondensed?: boolean }> | ReactNode;\n  /**\n   * A secondary header for the panel (only pass if needed)\n   */\n  secondaryHeader?: ReactNode;\n  /**\n   * If passed will be shown below the title as more information regarding the panel\n   */\n  description?: string;\n  /**\n   * Allow to override the styles by passing a `className` prop.\n   * <br/>\n   * Custom styles can also be passed using the [`css` prop from emotion](https://emotion.sh/docs/css-prop#style-precedence).\n   */\n  className?: string;\n  /**\n   * Makes the panel's header sticky in regards to the page's scroll\n   */\n  isSticky?: boolean;\n  /**\n   * Controls at the top right part of the panel\n   */\n  headerControls?: ReactNode;\n  /**\n   * Disables the panel and all interactions with it\n   */\n  isDisabled?: boolean;\n  /**\n   * The actual content rendered inside the panel\n   */\n  children?: ReactNode;\n  /**\n   * Indicates the color scheme of the panel.\n   */\n  tone?: 'urgent' | 'primary';\n  /**\n   * Determines the background color of the panel.\n   */\n  theme?: 'dark' | 'light';\n  /**\n   * Whenever `true` the headers and content itself\n   * will consume less space in that to the borders are smaller and everything has less padding\n   */\n  condensed?: boolean;\n  /**\n   * Controls the visibility of the expansion controls on the left\n   */\n  hideExpansionControls?: boolean;\n  /**\n   * Indicates the position of the control elements in the header component.\n   */\n  headerControlsAlignment?: 'left' | 'right';\n  /**\n   * Indicates if the panel's content should be collapsed or shown by default.\n   * <br />\n   * Updates to this value are not respected. Only used for **uncontrolled** mode (when no`onToggle` is passed.)\n   */\n  isDefaultClosed?: boolean;\n  /**\n   * Indicates if the panel's content should be collapsed or shown.\n   * <br />\n   * Component becomes **controlled* when this is passed.\n   */\n  isClosed?: boolean;\n  /**\n   * function to be triggered whenever the user clicks the top area to collapse the panel's content\n   * <br />\n   * Becomes required when `isClosed` is passed.\n   */\n  onToggle?: () => void;\n  /**\n   * Horizontal size limit of the panel.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst HeadLineText = (\n  props: Pick<TCollapsiblePanel, 'condensed' | 'header'>\n) => {\n  if (!props.condensed) {\n    return <>{props.header}</>;\n  }\n\n  return (\n    <Text.Subheadline as=\"h4\" truncate>\n      {isValidElement<{ isCondensed?: boolean }>(props.header)\n        ? cloneElement(props.header, {\n            isCondensed: props.condensed,\n          })\n        : props.header}\n    </Text.Subheadline>\n  );\n};\n\n// When `isClosed` is provided the component behaves as a controlled component,\n// otherwise it will behave like an uncontrolled component.\nconst CollapsiblePanel = ({\n  theme = 'dark',\n  condensed = false,\n  isDisabled = false,\n  headerControlsAlignment = 'right',\n  horizontalConstraint = 'scale',\n  ...props\n}: TCollapsiblePanel) => {\n  const panelButtonId = useFieldId(props.id, panelButtonSequentialId);\n  const panelContentId = useFieldId(undefined, panelContentSequentialId);\n  // Pass only `data-*` props\n  const dataProps = filterDataAttributes({\n    theme,\n    condensed,\n    isDisabled,\n    headerControlsAlignment,\n    horizontalConstraint,\n    ...props,\n  });\n  const scale = condensed ? 's' : 'm';\n\n  const isClosedAndIsDefaultClosed =\n    !isNil(props.isClosed) && !isNil(props.isDefaultClosed);\n  warning(\n    !isClosedAndIsDefaultClosed,\n    `Invalid prop \\`isDefaultClosed\\` supplied to \\`CollapsiblePanel\\`. Component must either be controlled or uncontrolled. Pass either \\`isClosed\\` or \\`isDefaultClosed\\` but not both.`\n  );\n\n  const hasOnToggle = !isNil(props.onToggle);\n  const isControlledComponent = !isNil(props.isClosed);\n\n  // controlled\n  if (isControlledComponent) {\n    warning(\n      hasOnToggle,\n      `missing required prop \\`onToggle\\` when using the \"isClosed\" prop (controlled component).`\n    );\n  }\n\n  // uncontrolled\n  if (!isControlledComponent) {\n    warning(\n      !hasOnToggle,\n      `Invalid prop \\`onToggle\\` supplied to \\`CollapsiblePanel\\`. \\`onToggle\\` does not have any effect when the component is uncontrolled.`\n    );\n  }\n\n  return (\n    <CollapsibleMotion\n      isClosed={props.isClosed}\n      onToggle={props.onToggle}\n      isDefaultClosed={props.isDefaultClosed}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => (\n        <Constraints.Horizontal max={horizontalConstraint}>\n          <div\n            css={[baseContainerStyles, getThemeStyle('light')]}\n            // Allow to override the styles by passing a `className` prop.\n            // Custom styles can also be passed using the `css` prop from emotion.\n            // https://emotion.sh/docs/css-prop#style-precedence\n            className={props.className}\n          >\n            <HeaderContainer\n              as=\"div\"\n              css={[\n                getHeaderContainerStyles(\n                  {\n                    condensed,\n                    isDisabled,\n                    headerControlsAlignment,\n                    ...props,\n                  },\n                  isOpen\n                ),\n                getThemeStyle('light'),\n              ]}\n              id={panelButtonId}\n              label=\"\"\n              onClick={isDisabled ? undefined : toggle}\n              isDisabled={isDisabled}\n              buttonAttributes={dataProps}\n              aria-controls={panelContentId}\n              aria-expanded={isOpen ? 'true' : 'false'}\n            >\n              <Spacings.Inline alignItems=\"center\" scale=\"xs\">\n                {!props.hideExpansionControls && (\n                  <HeaderIcon\n                    isClosed={!isOpen}\n                    isDisabled={isDisabled || false}\n                    tone={props.tone}\n                    size={'medium'}\n                  />\n                )}\n                <Spacings.Inline alignItems=\"baseline\" scale={scale}>\n                  <HeadLineText header={props.header} condensed={condensed} />\n                  {props.secondaryHeader && (\n                    <Text.Detail tone=\"secondary\" truncate={true}>\n                      {props.secondaryHeader}\n                    </Text.Detail>\n                  )}\n                </Spacings.Inline>\n              </Spacings.Inline>\n              {props.headerControls && (\n                <HeaderControlsWrapper\n                  onClick={(event) => event.stopPropagation()}\n                >\n                  {props.headerControls}\n                </HeaderControlsWrapper>\n              )}\n            </HeaderContainer>\n            <div style={containerStyles}>\n              <SectionWrapper\n                // @ts-ignore\n                ref={registerContentNode}\n                condensed={condensed}\n                isExpandControlHidden={props.hideExpansionControls}\n              >\n                {props.description && (\n                  <SectionDescriptionWrapper>\n                    <Text.Detail tone=\"secondary\">\n                      {props.description}\n                    </Text.Detail>\n                  </SectionDescriptionWrapper>\n                )}\n                <Spacings.Stack scale={scale}>\n                  <SectionContent\n                    id={panelContentId}\n                    role=\"region\"\n                    aria-labelledby={panelButtonId}\n                    hidden={!isOpen}\n                  >\n                    {props.children}\n                  </SectionContent>\n                </Spacings.Stack>\n              </SectionWrapper>\n            </div>\n          </div>\n        </Constraints.Horizontal>\n      )}\n    </CollapsibleMotion>\n  );\n};\n\n/**\n * @deprecated This function is no longer supported.\n */\nCollapsiblePanel.getPanelContentId = () => '';\nCollapsiblePanel.displayName = 'CollapsiblePanel';\nCollapsiblePanel.Header = CollapsiblePanelHeader;\n\nexport default CollapsiblePanel;\n"]} */"],
|
|
232
227
|
id: panelButtonId,
|
|
233
228
|
label: "",
|
|
234
229
|
onClick: isDisabled ? undefined : toggle,
|
|
@@ -294,32 +289,12 @@ const CollapsiblePanel = _ref => {
|
|
|
294
289
|
/**
|
|
295
290
|
* @deprecated This function is no longer supported.
|
|
296
291
|
*/
|
|
297
|
-
CollapsiblePanel.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
298
|
-
id: _pt.string,
|
|
299
|
-
header: _pt.node.isRequired,
|
|
300
|
-
secondaryHeader: _pt.node,
|
|
301
|
-
description: _pt.string,
|
|
302
|
-
className: _pt.string,
|
|
303
|
-
isSticky: _pt.bool,
|
|
304
|
-
headerControls: _pt.node,
|
|
305
|
-
isDisabled: _pt.bool,
|
|
306
|
-
children: _pt.node,
|
|
307
|
-
tone: _pt.oneOf(['urgent', 'primary']),
|
|
308
|
-
theme: _pt.oneOf(['dark', 'light']),
|
|
309
|
-
condensed: _pt.bool,
|
|
310
|
-
hideExpansionControls: _pt.bool,
|
|
311
|
-
headerControlsAlignment: _pt.oneOf(['left', 'right']),
|
|
312
|
-
isDefaultClosed: _pt.bool,
|
|
313
|
-
isClosed: _pt.bool,
|
|
314
|
-
onToggle: _pt.func,
|
|
315
|
-
horizontalConstraint: _pt.oneOf([6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'])
|
|
316
|
-
} : {};
|
|
317
292
|
CollapsiblePanel.getPanelContentId = () => '';
|
|
318
293
|
CollapsiblePanel.displayName = 'CollapsiblePanel';
|
|
319
294
|
CollapsiblePanel.Header = CollapsiblePanelHeader$1;
|
|
320
295
|
var CollapsiblePanel$1 = CollapsiblePanel;
|
|
321
296
|
|
|
322
297
|
// NOTE: This string will be replaced on build time with the package version.
|
|
323
|
-
var version = "
|
|
298
|
+
var version = "20.0.0";
|
|
324
299
|
|
|
325
300
|
export { CollapsiblePanel$1 as default, version };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ReactNode } from 'react';
|
|
1
|
+
import { ReactNode, ReactElement } from 'react';
|
|
2
2
|
export type TCollapsiblePanel = {
|
|
3
3
|
/**
|
|
4
4
|
* An unique id for the panel header, which will also be used to generate a prefixed id for the panel content section.
|
|
@@ -9,7 +9,9 @@ export type TCollapsiblePanel = {
|
|
|
9
9
|
/**
|
|
10
10
|
* The title being rendered at top left of the panel
|
|
11
11
|
*/
|
|
12
|
-
header:
|
|
12
|
+
header: ReactElement<{
|
|
13
|
+
isCondensed?: boolean;
|
|
14
|
+
}> | ReactNode;
|
|
13
15
|
/**
|
|
14
16
|
* A secondary header for the panel (only pass if needed)
|
|
15
17
|
*/
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@commercetools-uikit/collapsible-panel",
|
|
3
3
|
"description": "A panel to collapse and expand your content.",
|
|
4
|
-
"version": "
|
|
4
|
+
"version": "20.0.0",
|
|
5
5
|
"bugs": "https://github.com/commercetools/ui-kit/issues",
|
|
6
6
|
"repository": {
|
|
7
7
|
"type": "git",
|
|
@@ -21,25 +21,24 @@
|
|
|
21
21
|
"dependencies": {
|
|
22
22
|
"@babel/runtime": "^7.20.13",
|
|
23
23
|
"@babel/runtime-corejs3": "^7.20.13",
|
|
24
|
-
"@commercetools-uikit/accessible-button": "
|
|
25
|
-
"@commercetools-uikit/collapsible-motion": "
|
|
26
|
-
"@commercetools-uikit/constraints": "
|
|
27
|
-
"@commercetools-uikit/design-system": "
|
|
28
|
-
"@commercetools-uikit/hooks": "
|
|
29
|
-
"@commercetools-uikit/icons": "
|
|
30
|
-
"@commercetools-uikit/spacings": "
|
|
31
|
-
"@commercetools-uikit/text": "
|
|
32
|
-
"@commercetools-uikit/utils": "
|
|
24
|
+
"@commercetools-uikit/accessible-button": "20.0.0",
|
|
25
|
+
"@commercetools-uikit/collapsible-motion": "20.0.0",
|
|
26
|
+
"@commercetools-uikit/constraints": "20.0.0",
|
|
27
|
+
"@commercetools-uikit/design-system": "20.0.0",
|
|
28
|
+
"@commercetools-uikit/hooks": "20.0.0",
|
|
29
|
+
"@commercetools-uikit/icons": "20.0.0",
|
|
30
|
+
"@commercetools-uikit/spacings": "20.0.0",
|
|
31
|
+
"@commercetools-uikit/text": "20.0.0",
|
|
32
|
+
"@commercetools-uikit/utils": "20.0.0",
|
|
33
33
|
"@emotion/react": "^11.10.5",
|
|
34
34
|
"@emotion/styled": "^11.10.5",
|
|
35
35
|
"lodash": "4.17.21",
|
|
36
|
-
"
|
|
37
|
-
"react-intl": "^6.3.2"
|
|
36
|
+
"react-intl": "^7.1.4"
|
|
38
37
|
},
|
|
39
38
|
"devDependencies": {
|
|
40
|
-
"react": "
|
|
39
|
+
"react": "19.0.0"
|
|
41
40
|
},
|
|
42
41
|
"peerDependencies": {
|
|
43
|
-
"react": "
|
|
42
|
+
"react": "19.x"
|
|
44
43
|
}
|
|
45
44
|
}
|