@commercetools-uikit/primary-action-dropdown 12.2.3 → 12.2.4

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.
@@ -54,11 +54,11 @@ var DropdownHead = function DropdownHead(props) {
54
54
 
55
55
  return jsxRuntime.jsxs("div", {
56
56
  css: _ref3,
57
- children: [jsxRuntime.jsxs(AccessibleButton__default['default'], {
57
+ children: [jsxRuntime.jsxs(AccessibleButton__default["default"], {
58
58
  label: props.children,
59
59
  onClick: props.onClick,
60
60
  isDisabled: props.isDisabled,
61
- css: _concatInstanceProperty__default['default'](_context = []).call(_context, _toConsumableArray(getButtonStyles(props.isDisabled)), [/*#__PURE__*/react.css("padding:0 ", designSystem.customProperties.spacingS, ";border-radius:", designSystem.customProperties.borderRadius6, " 0 0 ", designSystem.customProperties.borderRadius6, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:DropdownHead;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AA8DW","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport { warning } from '@commercetools-uikit/utils';\nimport { CaretUpIcon, CaretDownIcon } from '@commercetools-uikit/icons';\nimport { useToggleState } from '@commercetools-uikit/hooks';\n\nconst getButtonStyles = (isDisabled) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        {cloneElement(props.iconLeft, {\n          size: 'big',\n          color: props.isDisabled ? 'neutral60' : 'solid',\n        })}\n      </span>\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\n      `,\n    ]}\n  >\n    {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n    <div\n      // The margin-top is to center the icon as the caret visually looks too high otherwise\n      css={css`\n        pointer-events: none;\n        margin-top: 3px;\n      `}\n    >\n      {cloneElement(\n        props.isOpen && !props.isDisabled ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\n};\n\n/*\n  This component registers a global click event listener to close the dropdown.\n  It uses this global listener to close when:\n    - an element outside of the dropdown is clicked\n    - an element in the dropdown options is clicked\n\n  In order to be still able to open the dropdown we have to avoid auto-closing\n  when the dropdown trigger itself is clicked. Otherwise it would open and close\n  immediately.\n */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n  const handleClickOnHead = useCallback(\n    (event) => {\n      if (isOpen) {\n        toggle(true);\n      } else {\n        onClick(event);\n      }\n    },\n    [isOpen, onClick, toggle]\n  );\n  const handleClickOnChevron = useCallback(() => {\n    toggle();\n  }, [toggle]);\n\n  warning(\n    childrenAsArray.length > 1,\n    '@commercetools-frontend/ui-kit/dropdowns/primary-action-dropdown: must contain at least two options'\n  );\n\n  return (\n    <div\n      css={css`\n        position: relative;\n        display: inline-flex;\n        align-items: column;\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AA4DM","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport { warning } from '@commercetools-uikit/utils';\nimport { CaretUpIcon, CaretDownIcon } from '@commercetools-uikit/icons';\nimport { useToggleState } from '@commercetools-uikit/hooks';\n\nconst getButtonStyles = (isDisabled) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        {cloneElement(props.iconLeft, {\n          size: 'big',\n          color: props.isDisabled ? 'neutral60' : 'solid',\n        })}\n      </span>\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\n      `,\n    ]}\n  >\n    {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n    <div\n      // The margin-top is to center the icon as the caret visually looks too high otherwise\n      css={css`\n        pointer-events: none;\n        margin-top: 3px;\n      `}\n    >\n      {cloneElement(\n        props.isOpen && !props.isDisabled ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\n};\n\n/*\n  This component registers a global click event listener to close the dropdown.\n  It uses this global listener to close when:\n    - an element outside of the dropdown is clicked\n    - an element in the dropdown options is clicked\n\n  In order to be still able to open the dropdown we have to avoid auto-closing\n  when the dropdown trigger itself is clicked. Otherwise it would open and close\n  immediately.\n */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n  const handleClickOnHead = useCallback(\n    (event) => {\n      if (isOpen) {\n        toggle(true);\n      } else {\n        onClick(event);\n      }\n    },\n    [isOpen, onClick, toggle]\n  );\n  const handleClickOnChevron = useCallback(() => {\n    toggle();\n  }, [toggle]);\n\n  warning(\n    childrenAsArray.length > 1,\n    '@commercetools-frontend/ui-kit/dropdowns/primary-action-dropdown: must contain at least two options'\n  );\n\n  return (\n    <div\n      css={css`\n        position: relative;\n        display: inline-flex;\n        align-items: column;\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"]),
61
+ css: _concatInstanceProperty__default["default"](_context = []).call(_context, _toConsumableArray(getButtonStyles(props.isDisabled)), [/*#__PURE__*/react.css("padding:0 ", designSystem.customProperties.spacingS, ";border-radius:", designSystem.customProperties.borderRadius6, " 0 0 ", designSystem.customProperties.borderRadius6, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:DropdownHead;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AA8DW","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport { warning } from '@commercetools-uikit/utils';\nimport { CaretUpIcon, CaretDownIcon } from '@commercetools-uikit/icons';\nimport { useToggleState } from '@commercetools-uikit/hooks';\n\nconst getButtonStyles = (isDisabled) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        {cloneElement(props.iconLeft, {\n          size: 'big',\n          color: props.isDisabled ? 'neutral60' : 'solid',\n        })}\n      </span>\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\n      `,\n    ]}\n  >\n    {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n    <div\n      // The margin-top is to center the icon as the caret visually looks too high otherwise\n      css={css`\n        pointer-events: none;\n        margin-top: 3px;\n      `}\n    >\n      {cloneElement(\n        props.isOpen && !props.isDisabled ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\n};\n\n/*\n  This component registers a global click event listener to close the dropdown.\n  It uses this global listener to close when:\n    - an element outside of the dropdown is clicked\n    - an element in the dropdown options is clicked\n\n  In order to be still able to open the dropdown we have to avoid auto-closing\n  when the dropdown trigger itself is clicked. Otherwise it would open and close\n  immediately.\n */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n  const handleClickOnHead = useCallback(\n    (event) => {\n      if (isOpen) {\n        toggle(true);\n      } else {\n        onClick(event);\n      }\n    },\n    [isOpen, onClick, toggle]\n  );\n  const handleClickOnChevron = useCallback(() => {\n    toggle();\n  }, [toggle]);\n\n  warning(\n    childrenAsArray.length > 1,\n    '@commercetools-frontend/ui-kit/dropdowns/primary-action-dropdown: must contain at least two options'\n  );\n\n  return (\n    <div\n      css={css`\n        position: relative;\n        display: inline-flex;\n        align-items: column;\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AA4DM","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport { warning } from '@commercetools-uikit/utils';\nimport { CaretUpIcon, CaretDownIcon } from '@commercetools-uikit/icons';\nimport { useToggleState } from '@commercetools-uikit/hooks';\n\nconst getButtonStyles = (isDisabled) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        {cloneElement(props.iconLeft, {\n          size: 'big',\n          color: props.isDisabled ? 'neutral60' : 'solid',\n        })}\n      </span>\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\n      `,\n    ]}\n  >\n    {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n    <div\n      // The margin-top is to center the icon as the caret visually looks too high otherwise\n      css={css`\n        pointer-events: none;\n        margin-top: 3px;\n      `}\n    >\n      {cloneElement(\n        props.isOpen && !props.isDisabled ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\n};\n\n/*\n  This component registers a global click event listener to close the dropdown.\n  It uses this global listener to close when:\n    - an element outside of the dropdown is clicked\n    - an element in the dropdown options is clicked\n\n  In order to be still able to open the dropdown we have to avoid auto-closing\n  when the dropdown trigger itself is clicked. Otherwise it would open and close\n  immediately.\n */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n  const handleClickOnHead = useCallback(\n    (event) => {\n      if (isOpen) {\n        toggle(true);\n      } else {\n        onClick(event);\n      }\n    },\n    [isOpen, onClick, toggle]\n  );\n  const handleClickOnChevron = useCallback(() => {\n    toggle();\n  }, [toggle]);\n\n  warning(\n    childrenAsArray.length > 1,\n    '@commercetools-frontend/ui-kit/dropdowns/primary-action-dropdown: must contain at least two options'\n  );\n\n  return (\n    <div\n      css={css`\n        position: relative;\n        display: inline-flex;\n        align-items: column;\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"]),
62
62
  children: [jsxRuntime.jsx("span", {
63
63
  css: /*#__PURE__*/react.css("margin:0 ", designSystem.customProperties.spacingXs, " 0 0;display:flex;align-items:center;justify-content:center;" + (process.env.NODE_ENV === "production" ? "" : ";label:DropdownHead;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AAqEgB","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport { warning } from '@commercetools-uikit/utils';\nimport { CaretUpIcon, CaretDownIcon } from '@commercetools-uikit/icons';\nimport { useToggleState } from '@commercetools-uikit/hooks';\n\nconst getButtonStyles = (isDisabled) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        {cloneElement(props.iconLeft, {\n          size: 'big',\n          color: props.isDisabled ? 'neutral60' : 'solid',\n        })}\n      </span>\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\n      `,\n    ]}\n  >\n    {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n    <div\n      // The margin-top is to center the icon as the caret visually looks too high otherwise\n      css={css`\n        pointer-events: none;\n        margin-top: 3px;\n      `}\n    >\n      {cloneElement(\n        props.isOpen && !props.isDisabled ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\n};\n\n/*\n  This component registers a global click event listener to close the dropdown.\n  It uses this global listener to close when:\n    - an element outside of the dropdown is clicked\n    - an element in the dropdown options is clicked\n\n  In order to be still able to open the dropdown we have to avoid auto-closing\n  when the dropdown trigger itself is clicked. Otherwise it would open and close\n  immediately.\n */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n  const handleClickOnHead = useCallback(\n    (event) => {\n      if (isOpen) {\n        toggle(true);\n      } else {\n        onClick(event);\n      }\n    },\n    [isOpen, onClick, toggle]\n  );\n  const handleClickOnChevron = useCallback(() => {\n    toggle();\n  }, [toggle]);\n\n  warning(\n    childrenAsArray.length > 1,\n    '@commercetools-frontend/ui-kit/dropdowns/primary-action-dropdown: must contain at least two options'\n  );\n\n  return (\n    <div\n      css={css`\n        position: relative;\n        display: inline-flex;\n        align-items: column;\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"),
64
64
  children: /*#__PURE__*/react$1.cloneElement(props.iconLeft, {
@@ -67,7 +67,7 @@ var DropdownHead = function DropdownHead(props) {
67
67
  })
68
68
  }), jsxRuntime.jsx("span", {
69
69
  css: /*#__PURE__*/react.css("margin:0 ", designSystem.customProperties.spacingXs, " 0 0;display:flex;align-items:center;justify-content:center;" + (process.env.NODE_ENV === "production" ? "" : ";label:DropdownHead;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AAkFgB","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport { warning } from '@commercetools-uikit/utils';\nimport { CaretUpIcon, CaretDownIcon } from '@commercetools-uikit/icons';\nimport { useToggleState } from '@commercetools-uikit/hooks';\n\nconst getButtonStyles = (isDisabled) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        {cloneElement(props.iconLeft, {\n          size: 'big',\n          color: props.isDisabled ? 'neutral60' : 'solid',\n        })}\n      </span>\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\n      `,\n    ]}\n  >\n    {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n    <div\n      // The margin-top is to center the icon as the caret visually looks too high otherwise\n      css={css`\n        pointer-events: none;\n        margin-top: 3px;\n      `}\n    >\n      {cloneElement(\n        props.isOpen && !props.isDisabled ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\n};\n\n/*\n  This component registers a global click event listener to close the dropdown.\n  It uses this global listener to close when:\n    - an element outside of the dropdown is clicked\n    - an element in the dropdown options is clicked\n\n  In order to be still able to open the dropdown we have to avoid auto-closing\n  when the dropdown trigger itself is clicked. Otherwise it would open and close\n  immediately.\n */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n  const handleClickOnHead = useCallback(\n    (event) => {\n      if (isOpen) {\n        toggle(true);\n      } else {\n        onClick(event);\n      }\n    },\n    [isOpen, onClick, toggle]\n  );\n  const handleClickOnChevron = useCallback(() => {\n    toggle();\n  }, [toggle]);\n\n  warning(\n    childrenAsArray.length > 1,\n    '@commercetools-frontend/ui-kit/dropdowns/primary-action-dropdown: must contain at least two options'\n  );\n\n  return (\n    <div\n      css={css`\n        position: relative;\n        display: inline-flex;\n        align-items: column;\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"),
70
- children: jsxRuntime.jsx(Text__default['default'].Detail, {
70
+ children: jsxRuntime.jsx(Text__default["default"].Detail, {
71
71
  tone: props.isDisabled ? 'secondary' : undefined,
72
72
  children: props.children
73
73
  })
@@ -78,11 +78,11 @@ var DropdownHead = function DropdownHead(props) {
78
78
 
79
79
  DropdownHead.displayName = 'DropdownHead';
80
80
  DropdownHead.propTypes = process.env.NODE_ENV !== "production" ? {
81
- iconLeft: PropTypes__default['default'].element.isRequired,
82
- onClick: PropTypes__default['default'].func,
83
- children: PropTypes__default['default'].node.isRequired,
84
- isDisabled: PropTypes__default['default'].bool.isRequired,
85
- chevron: PropTypes__default['default'].element.isRequired
81
+ iconLeft: PropTypes__default["default"].element.isRequired,
82
+ onClick: PropTypes__default["default"].func,
83
+ children: PropTypes__default["default"].node.isRequired,
84
+ isDisabled: PropTypes__default["default"].bool.isRequired,
85
+ chevron: PropTypes__default["default"].element.isRequired
86
86
  } : {};
87
87
 
88
88
  var _ref2 = process.env.NODE_ENV === "production" ? {
@@ -98,13 +98,13 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
98
98
  var DropdownChevron = /*#__PURE__*/react$1.forwardRef(function (props, ref) {
99
99
  var _context2;
100
100
 
101
- return jsxRuntime.jsx(AccessibleButton__default['default'], {
101
+ return jsxRuntime.jsx(AccessibleButton__default["default"], {
102
102
  ref: ref,
103
103
  label: "Open Dropdown",
104
104
  onClick: props.onClick,
105
105
  isDisabled: props.isDisabled,
106
106
  isOpen: props.isOpen,
107
- css: _concatInstanceProperty__default['default'](_context2 = []).call(_context2, _toConsumableArray(getButtonStyles(props.isDisabled)), [/*#__PURE__*/react.css("padding:0 ", designSystem.customProperties.spacingXs, ";border-left:1px solid ", designSystem.customProperties.colorNeutral, ";border-radius:0 ", designSystem.customProperties.borderRadius6, " ", designSystem.customProperties.borderRadius6, " 0;" + (process.env.NODE_ENV === "production" ? "" : ";label:DropdownChevron;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AAoHS","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport { warning } from '@commercetools-uikit/utils';\nimport { CaretUpIcon, CaretDownIcon } from '@commercetools-uikit/icons';\nimport { useToggleState } from '@commercetools-uikit/hooks';\n\nconst getButtonStyles = (isDisabled) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        {cloneElement(props.iconLeft, {\n          size: 'big',\n          color: props.isDisabled ? 'neutral60' : 'solid',\n        })}\n      </span>\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\n      `,\n    ]}\n  >\n    {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n    <div\n      // The margin-top is to center the icon as the caret visually looks too high otherwise\n      css={css`\n        pointer-events: none;\n        margin-top: 3px;\n      `}\n    >\n      {cloneElement(\n        props.isOpen && !props.isDisabled ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\n};\n\n/*\n  This component registers a global click event listener to close the dropdown.\n  It uses this global listener to close when:\n    - an element outside of the dropdown is clicked\n    - an element in the dropdown options is clicked\n\n  In order to be still able to open the dropdown we have to avoid auto-closing\n  when the dropdown trigger itself is clicked. Otherwise it would open and close\n  immediately.\n */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n  const handleClickOnHead = useCallback(\n    (event) => {\n      if (isOpen) {\n        toggle(true);\n      } else {\n        onClick(event);\n      }\n    },\n    [isOpen, onClick, toggle]\n  );\n  const handleClickOnChevron = useCallback(() => {\n    toggle();\n  }, [toggle]);\n\n  warning(\n    childrenAsArray.length > 1,\n    '@commercetools-frontend/ui-kit/dropdowns/primary-action-dropdown: must contain at least two options'\n  );\n\n  return (\n    <div\n      css={css`\n        position: relative;\n        display: inline-flex;\n        align-items: column;\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AAkHI","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport { warning } from '@commercetools-uikit/utils';\nimport { CaretUpIcon, CaretDownIcon } from '@commercetools-uikit/icons';\nimport { useToggleState } from '@commercetools-uikit/hooks';\n\nconst getButtonStyles = (isDisabled) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        {cloneElement(props.iconLeft, {\n          size: 'big',\n          color: props.isDisabled ? 'neutral60' : 'solid',\n        })}\n      </span>\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\n      `,\n    ]}\n  >\n    {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n    <div\n      // The margin-top is to center the icon as the caret visually looks too high otherwise\n      css={css`\n        pointer-events: none;\n        margin-top: 3px;\n      `}\n    >\n      {cloneElement(\n        props.isOpen && !props.isDisabled ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\n};\n\n/*\n  This component registers a global click event listener to close the dropdown.\n  It uses this global listener to close when:\n    - an element outside of the dropdown is clicked\n    - an element in the dropdown options is clicked\n\n  In order to be still able to open the dropdown we have to avoid auto-closing\n  when the dropdown trigger itself is clicked. Otherwise it would open and close\n  immediately.\n */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n  const handleClickOnHead = useCallback(\n    (event) => {\n      if (isOpen) {\n        toggle(true);\n      } else {\n        onClick(event);\n      }\n    },\n    [isOpen, onClick, toggle]\n  );\n  const handleClickOnChevron = useCallback(() => {\n    toggle();\n  }, [toggle]);\n\n  warning(\n    childrenAsArray.length > 1,\n    '@commercetools-frontend/ui-kit/dropdowns/primary-action-dropdown: must contain at least two options'\n  );\n\n  return (\n    <div\n      css={css`\n        position: relative;\n        display: inline-flex;\n        align-items: column;\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"]),
107
+ css: _concatInstanceProperty__default["default"](_context2 = []).call(_context2, _toConsumableArray(getButtonStyles(props.isDisabled)), [/*#__PURE__*/react.css("padding:0 ", designSystem.customProperties.spacingXs, ";border-left:1px solid ", designSystem.customProperties.colorNeutral, ";border-radius:0 ", designSystem.customProperties.borderRadius6, " ", designSystem.customProperties.borderRadius6, " 0;" + (process.env.NODE_ENV === "production" ? "" : ";label:DropdownChevron;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AAoHS","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport { warning } from '@commercetools-uikit/utils';\nimport { CaretUpIcon, CaretDownIcon } from '@commercetools-uikit/icons';\nimport { useToggleState } from '@commercetools-uikit/hooks';\n\nconst getButtonStyles = (isDisabled) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        {cloneElement(props.iconLeft, {\n          size: 'big',\n          color: props.isDisabled ? 'neutral60' : 'solid',\n        })}\n      </span>\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\n      `,\n    ]}\n  >\n    {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n    <div\n      // The margin-top is to center the icon as the caret visually looks too high otherwise\n      css={css`\n        pointer-events: none;\n        margin-top: 3px;\n      `}\n    >\n      {cloneElement(\n        props.isOpen && !props.isDisabled ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\n};\n\n/*\n  This component registers a global click event listener to close the dropdown.\n  It uses this global listener to close when:\n    - an element outside of the dropdown is clicked\n    - an element in the dropdown options is clicked\n\n  In order to be still able to open the dropdown we have to avoid auto-closing\n  when the dropdown trigger itself is clicked. Otherwise it would open and close\n  immediately.\n */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n  const handleClickOnHead = useCallback(\n    (event) => {\n      if (isOpen) {\n        toggle(true);\n      } else {\n        onClick(event);\n      }\n    },\n    [isOpen, onClick, toggle]\n  );\n  const handleClickOnChevron = useCallback(() => {\n    toggle();\n  }, [toggle]);\n\n  warning(\n    childrenAsArray.length > 1,\n    '@commercetools-frontend/ui-kit/dropdowns/primary-action-dropdown: must contain at least two options'\n  );\n\n  return (\n    <div\n      css={css`\n        position: relative;\n        display: inline-flex;\n        align-items: column;\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AAkHI","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport { warning } from '@commercetools-uikit/utils';\nimport { CaretUpIcon, CaretDownIcon } from '@commercetools-uikit/icons';\nimport { useToggleState } from '@commercetools-uikit/hooks';\n\nconst getButtonStyles = (isDisabled) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        {cloneElement(props.iconLeft, {\n          size: 'big',\n          color: props.isDisabled ? 'neutral60' : 'solid',\n        })}\n      </span>\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\n      `,\n    ]}\n  >\n    {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n    <div\n      // The margin-top is to center the icon as the caret visually looks too high otherwise\n      css={css`\n        pointer-events: none;\n        margin-top: 3px;\n      `}\n    >\n      {cloneElement(\n        props.isOpen && !props.isDisabled ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\n};\n\n/*\n  This component registers a global click event listener to close the dropdown.\n  It uses this global listener to close when:\n    - an element outside of the dropdown is clicked\n    - an element in the dropdown options is clicked\n\n  In order to be still able to open the dropdown we have to avoid auto-closing\n  when the dropdown trigger itself is clicked. Otherwise it would open and close\n  immediately.\n */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n  const handleClickOnHead = useCallback(\n    (event) => {\n      if (isOpen) {\n        toggle(true);\n      } else {\n        onClick(event);\n      }\n    },\n    [isOpen, onClick, toggle]\n  );\n  const handleClickOnChevron = useCallback(() => {\n    toggle();\n  }, [toggle]);\n\n  warning(\n    childrenAsArray.length > 1,\n    '@commercetools-frontend/ui-kit/dropdowns/primary-action-dropdown: must contain at least two options'\n  );\n\n  return (\n    <div\n      css={css`\n        position: relative;\n        display: inline-flex;\n        align-items: column;\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"]),
108
108
  children: jsxRuntime.jsx("div", {
109
109
  // The margin-top is to center the icon as the caret visually looks too high otherwise
110
110
  css: _ref2,
@@ -117,12 +117,12 @@ var DropdownChevron = /*#__PURE__*/react$1.forwardRef(function (props, ref) {
117
117
  });
118
118
  DropdownChevron.displayName = 'DropdownChevron';
119
119
  DropdownChevron.propTypes = {
120
- onClick: PropTypes__default['default'].func.isRequired,
121
- isDisabled: PropTypes__default['default'].bool.isRequired,
122
- isOpen: PropTypes__default['default'].bool.isRequired
120
+ onClick: PropTypes__default["default"].func.isRequired,
121
+ isDisabled: PropTypes__default["default"].bool.isRequired,
122
+ isOpen: PropTypes__default["default"].bool.isRequired
123
123
  };
124
124
 
125
- var Options = _styled__default['default']("div", process.env.NODE_ENV === "production" ? {
125
+ var Options = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
126
126
  target: "e102bf7i0"
127
127
  } : {
128
128
  target: "e102bf7i0",
@@ -130,7 +130,7 @@ var Options = _styled__default['default']("div", process.env.NODE_ENV === "produ
130
130
  })("position:absolute;z-index:5;width:100%;top:calc(", designSystem.customProperties.spacingS, " + ", designSystem.customProperties.bigButtonHeight, ");left:0;border:1px solid ", designSystem.customProperties.colorNeutral, ";border-radius:", designSystem.customProperties.borderRadius6, ";box-shadow:", designSystem.customProperties.shadow1, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AA2J0B","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport { warning } from '@commercetools-uikit/utils';\nimport { CaretUpIcon, CaretDownIcon } from '@commercetools-uikit/icons';\nimport { useToggleState } from '@commercetools-uikit/hooks';\n\nconst getButtonStyles = (isDisabled) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        {cloneElement(props.iconLeft, {\n          size: 'big',\n          color: props.isDisabled ? 'neutral60' : 'solid',\n        })}\n      </span>\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\n          display: flex;\n          align-items: center;\n          justify-content: center;\n        `}\n      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\n      `,\n    ]}\n  >\n    {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n    <div\n      // The margin-top is to center the icon as the caret visually looks too high otherwise\n      css={css`\n        pointer-events: none;\n        margin-top: 3px;\n      `}\n    >\n      {cloneElement(\n        props.isOpen && !props.isDisabled ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\n};\n\n/*\n  This component registers a global click event listener to close the dropdown.\n  It uses this global listener to close when:\n    - an element outside of the dropdown is clicked\n    - an element in the dropdown options is clicked\n\n  In order to be still able to open the dropdown we have to avoid auto-closing\n  when the dropdown trigger itself is clicked. Otherwise it would open and close\n  immediately.\n */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n  const handleClickOnHead = useCallback(\n    (event) => {\n      if (isOpen) {\n        toggle(true);\n      } else {\n        onClick(event);\n      }\n    },\n    [isOpen, onClick, toggle]\n  );\n  const handleClickOnChevron = useCallback(() => {\n    toggle();\n  }, [toggle]);\n\n  warning(\n    childrenAsArray.length > 1,\n    '@commercetools-frontend/ui-kit/dropdowns/primary-action-dropdown: must contain at least two options'\n  );\n\n  return (\n    <div\n      css={css`\n        position: relative;\n        display: inline-flex;\n        align-items: column;\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"));
131
131
 
132
132
  var Option = function Option(props) {
133
- return jsxRuntime.jsx(AccessibleButton__default['default'], {
133
+ return jsxRuntime.jsx(AccessibleButton__default["default"], {
134
134
  label: props.children,
135
135
  onClick: props.onClick,
136
136
  isDisabled: props.isDisabled,
@@ -140,11 +140,11 @@ var Option = function Option(props) {
140
140
  };
141
141
  Option.displayName = 'Option';
142
142
  Option.propTypes = process.env.NODE_ENV !== "production" ? {
143
- onClick: PropTypes__default['default'].func.isRequired,
144
- isDisabled: PropTypes__default['default'].bool,
145
- children: PropTypes__default['default'].string.isRequired,
143
+ onClick: PropTypes__default["default"].func.isRequired,
144
+ isDisabled: PropTypes__default["default"].bool,
145
+ children: PropTypes__default["default"].string.isRequired,
146
146
  // eslint-disable-next-line react/no-unused-prop-types
147
- iconLeft: PropTypes__default['default'].node.isRequired
147
+ iconLeft: PropTypes__default["default"].node.isRequired
148
148
  } : {};
149
149
  Option.defaultProps = {
150
150
  isDisabled: false
@@ -192,7 +192,7 @@ var PrimaryActionDropdown = function PrimaryActionDropdown(props) {
192
192
  };
193
193
  }, [handleGlobalClick]);
194
194
  var childrenAsArray = react$1.Children.toArray(props.children);
195
- var primaryOption = _findInstanceProperty__default['default'](childrenAsArray).call(childrenAsArray, function (option) {
195
+ var primaryOption = _findInstanceProperty__default["default"](childrenAsArray).call(childrenAsArray, function (option) {
196
196
  return !option.props.isDisabled;
197
197
  }) || childrenAsArray[0];
198
198
  var onClick = primaryOption.props.onClick;
@@ -228,13 +228,13 @@ var PrimaryActionDropdown = function PrimaryActionDropdown(props) {
228
228
 
229
229
  PrimaryActionDropdown.displayName = 'PrimaryActionDropdown';
230
230
  PrimaryActionDropdown.propTypes = process.env.NODE_ENV !== "production" ? {
231
- children: PropTypes__default['default'].node.isRequired
231
+ children: PropTypes__default["default"].node.isRequired
232
232
  } : {};
233
233
  var PrimaryActionDropdown$1 = PrimaryActionDropdown;
234
234
 
235
235
  // NOTE: This string will be replaced in the `prepare` script by the `scripts/version.js` file.
236
- var version = '12.2.3';
236
+ var version = '12.2.4';
237
237
 
238
238
  exports.Option = Option;
239
- exports['default'] = PrimaryActionDropdown$1;
239
+ exports["default"] = PrimaryActionDropdown$1;
240
240
  exports.version = version;
@@ -47,11 +47,11 @@ var DropdownHead = function DropdownHead(props) {
47
47
 
48
48
  return jsxRuntime.jsxs("div", {
49
49
  css: _ref3,
50
- children: [jsxRuntime.jsxs(AccessibleButton__default['default'], {
50
+ children: [jsxRuntime.jsxs(AccessibleButton__default["default"], {
51
51
  label: props.children,
52
52
  onClick: props.onClick,
53
53
  isDisabled: props.isDisabled,
54
- css: _concatInstanceProperty__default['default'](_context = []).call(_context, _toConsumableArray(getButtonStyles(props.isDisabled)), [/*#__PURE__*/react.css("padding:0 ", designSystem.customProperties.spacingS, ";border-radius:", designSystem.customProperties.borderRadius6, " 0 0 ", designSystem.customProperties.borderRadius6, ";" + ("" ), "" ), "" ]),
54
+ css: _concatInstanceProperty__default["default"](_context = []).call(_context, _toConsumableArray(getButtonStyles(props.isDisabled)), [/*#__PURE__*/react.css("padding:0 ", designSystem.customProperties.spacingS, ";border-radius:", designSystem.customProperties.borderRadius6, " 0 0 ", designSystem.customProperties.borderRadius6, ";" + ("" ), "" ), "" ]),
55
55
  children: [jsxRuntime.jsx("span", {
56
56
  css: /*#__PURE__*/react.css("margin:0 ", designSystem.customProperties.spacingXs, " 0 0;display:flex;align-items:center;justify-content:center;" + ("" ), "" ),
57
57
  children: /*#__PURE__*/react$1.cloneElement(props.iconLeft, {
@@ -60,7 +60,7 @@ var DropdownHead = function DropdownHead(props) {
60
60
  })
61
61
  }), jsxRuntime.jsx("span", {
62
62
  css: /*#__PURE__*/react.css("margin:0 ", designSystem.customProperties.spacingXs, " 0 0;display:flex;align-items:center;justify-content:center;" + ("" ), "" ),
63
- children: jsxRuntime.jsx(Text__default['default'].Detail, {
63
+ children: jsxRuntime.jsx(Text__default["default"].Detail, {
64
64
  tone: props.isDisabled ? 'secondary' : undefined,
65
65
  children: props.children
66
66
  })
@@ -80,13 +80,13 @@ var _ref2 = {
80
80
  var DropdownChevron = /*#__PURE__*/react$1.forwardRef(function (props, ref) {
81
81
  var _context2;
82
82
 
83
- return jsxRuntime.jsx(AccessibleButton__default['default'], {
83
+ return jsxRuntime.jsx(AccessibleButton__default["default"], {
84
84
  ref: ref,
85
85
  label: "Open Dropdown",
86
86
  onClick: props.onClick,
87
87
  isDisabled: props.isDisabled,
88
88
  isOpen: props.isOpen,
89
- css: _concatInstanceProperty__default['default'](_context2 = []).call(_context2, _toConsumableArray(getButtonStyles(props.isDisabled)), [/*#__PURE__*/react.css("padding:0 ", designSystem.customProperties.spacingXs, ";border-left:1px solid ", designSystem.customProperties.colorNeutral, ";border-radius:0 ", designSystem.customProperties.borderRadius6, " ", designSystem.customProperties.borderRadius6, " 0;" + ("" ), "" ), "" ]),
89
+ css: _concatInstanceProperty__default["default"](_context2 = []).call(_context2, _toConsumableArray(getButtonStyles(props.isDisabled)), [/*#__PURE__*/react.css("padding:0 ", designSystem.customProperties.spacingXs, ";border-left:1px solid ", designSystem.customProperties.colorNeutral, ";border-radius:0 ", designSystem.customProperties.borderRadius6, " ", designSystem.customProperties.borderRadius6, " 0;" + ("" ), "" ), "" ]),
90
90
  children: jsxRuntime.jsx("div", {
91
91
  // The margin-top is to center the icon as the caret visually looks too high otherwise
92
92
  css: _ref2,
@@ -99,17 +99,17 @@ var DropdownChevron = /*#__PURE__*/react$1.forwardRef(function (props, ref) {
99
99
  });
100
100
  DropdownChevron.displayName = 'DropdownChevron';
101
101
  DropdownChevron.propTypes = {
102
- onClick: PropTypes__default['default'].func.isRequired,
103
- isDisabled: PropTypes__default['default'].bool.isRequired,
104
- isOpen: PropTypes__default['default'].bool.isRequired
102
+ onClick: PropTypes__default["default"].func.isRequired,
103
+ isDisabled: PropTypes__default["default"].bool.isRequired,
104
+ isOpen: PropTypes__default["default"].bool.isRequired
105
105
  };
106
106
 
107
- var Options = _styled__default['default']("div", {
107
+ var Options = _styled__default["default"]("div", {
108
108
  target: "e102bf7i0"
109
109
  } )("position:absolute;z-index:5;width:100%;top:calc(", designSystem.customProperties.spacingS, " + ", designSystem.customProperties.bigButtonHeight, ");left:0;border:1px solid ", designSystem.customProperties.colorNeutral, ";border-radius:", designSystem.customProperties.borderRadius6, ";box-shadow:", designSystem.customProperties.shadow1, ";" + ("" ));
110
110
 
111
111
  var Option = function Option(props) {
112
- return jsxRuntime.jsx(AccessibleButton__default['default'], {
112
+ return jsxRuntime.jsx(AccessibleButton__default["default"], {
113
113
  label: props.children,
114
114
  onClick: props.onClick,
115
115
  isDisabled: props.isDisabled,
@@ -160,7 +160,7 @@ var PrimaryActionDropdown = function PrimaryActionDropdown(props) {
160
160
  };
161
161
  }, [handleGlobalClick]);
162
162
  var childrenAsArray = react$1.Children.toArray(props.children);
163
- var primaryOption = _findInstanceProperty__default['default'](childrenAsArray).call(childrenAsArray, function (option) {
163
+ var primaryOption = _findInstanceProperty__default["default"](childrenAsArray).call(childrenAsArray, function (option) {
164
164
  return !option.props.isDisabled;
165
165
  }) || childrenAsArray[0];
166
166
  var onClick = primaryOption.props.onClick;
@@ -198,8 +198,8 @@ PrimaryActionDropdown.propTypes = {};
198
198
  var PrimaryActionDropdown$1 = PrimaryActionDropdown;
199
199
 
200
200
  // NOTE: This string will be replaced in the `prepare` script by the `scripts/version.js` file.
201
- var version = '12.2.3';
201
+ var version = '12.2.4';
202
202
 
203
203
  exports.Option = Option;
204
- exports['default'] = PrimaryActionDropdown$1;
204
+ exports["default"] = PrimaryActionDropdown$1;
205
205
  exports.version = version;
@@ -220,6 +220,6 @@ PrimaryActionDropdown.propTypes = process.env.NODE_ENV !== "production" ? {
220
220
  var PrimaryActionDropdown$1 = PrimaryActionDropdown;
221
221
 
222
222
  // NOTE: This string will be replaced in the `prepare` script by the `scripts/version.js` file.
223
- var version = '12.2.3';
223
+ var version = '12.2.4';
224
224
 
225
225
  export { Option, PrimaryActionDropdown$1 as default, version };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@commercetools-uikit/primary-action-dropdown",
3
3
  "description": "A dropdown component with any number of action, where the first action of the dropdown can be triggered without opening the dropdown itself.",
4
- "version": "12.2.3",
4
+ "version": "12.2.4",
5
5
  "bugs": "https://github.com/commercetools/ui-kit/issues",
6
6
  "repository": {
7
7
  "type": "git",
@@ -23,14 +23,14 @@
23
23
  "prepare": "../../../scripts/version.js replace"
24
24
  },
25
25
  "dependencies": {
26
- "@babel/runtime": "7.14.8",
27
- "@babel/runtime-corejs3": "7.14.9",
28
- "@commercetools-uikit/accessible-button": "12.2.3",
29
- "@commercetools-uikit/buttons": "12.2.3",
30
- "@commercetools-uikit/design-system": "12.2.3",
26
+ "@babel/runtime": "7.15.4",
27
+ "@babel/runtime-corejs3": "7.15.4",
28
+ "@commercetools-uikit/accessible-button": "12.2.4",
29
+ "@commercetools-uikit/buttons": "12.2.4",
30
+ "@commercetools-uikit/design-system": "12.2.4",
31
31
  "@commercetools-uikit/hooks": "12.2.3",
32
- "@commercetools-uikit/icons": "12.2.3",
33
- "@commercetools-uikit/text": "12.2.3",
32
+ "@commercetools-uikit/icons": "12.2.4",
33
+ "@commercetools-uikit/text": "12.2.4",
34
34
  "@commercetools-uikit/utils": "12.2.0",
35
35
  "@emotion/react": "^11.4.0",
36
36
  "@emotion/styled": "^11.3.0",