@commercetools-uikit/primary-action-dropdown 19.26.0 → 20.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -4,7 +4,6 @@ Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
6
6
  var _styled = require('@emotion/styled/base');
7
- var _pt = require('prop-types');
8
7
  var _findInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/find');
9
8
  var react = require('react');
10
9
  var react$1 = require('@emotion/react');
@@ -20,25 +19,24 @@ var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWit
20
19
  function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
21
20
 
22
21
  var _styled__default = /*#__PURE__*/_interopDefault(_styled);
23
- var _pt__default = /*#__PURE__*/_interopDefault(_pt);
24
22
  var _findInstanceProperty__default = /*#__PURE__*/_interopDefault(_findInstanceProperty);
25
23
  var AccessibleButton__default = /*#__PURE__*/_interopDefault(AccessibleButton);
26
24
  var Text__default = /*#__PURE__*/_interopDefault(Text);
27
25
 
28
26
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
29
27
  const getButtonStyles = isDisabled => {
30
- const baseButtonStyles = /*#__PURE__*/react$1.css("display:flex;align-items:center;height:", designSystem.designTokens.heightForButtonAs30, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:baseButtonStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AAuB8B","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  MouseEvent,\n  KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\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' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAs30}\n  );\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>();\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 = (childrenAsArray.find(\n    (option) => isValidElement(option) && !option.props.isDisabled\n  ) || childrenAsArray[0]) as ReactElement;\n\n  const { onClick } = primaryOption.props;\n\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */");
28
+ const baseButtonStyles = /*#__PURE__*/react$1.css("display:flex;align-items:center;height:", designSystem.designTokens.heightForButtonAs30, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:baseButtonStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AAuB8B","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  type MouseEvent,\n  type KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement<{ size: string; color: string }>;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\n            display: flex;\n            align-items: center;\n            justify-content: center;\n          `}\n        >\n          {cloneElement(props.iconLeft, {\n            size: '40',\n            color: props.isDisabled ? 'neutral60' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.heightForButtonAs30});\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\n  }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement<TDropdownHead>[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>(null);\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event: Event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target as HTMLElement)\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(\n    props.children\n  ) as ReactElement<TDropdownHead>[];\n  const primaryOption =\n    childrenAsArray.find(\n      (option) => isValidElement(option) && !option.props.isDisabled\n    ) || childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n\n  const handleClickOnHead = useCallback(\n    (\n      event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => {\n      if (isOpen) {\n        toggle(true);\n      } else if (onClick) {\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */");
31
29
  if (isDisabled) {
32
- return [baseButtonStyles, /*#__PURE__*/react$1.css("box-shadow:none;background-color:", designSystem.designTokens.colorNeutral95, ";border:", `1px solid ${designSystem.designTokens.colorNeutral}`, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:getButtonStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AA+BS","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  MouseEvent,\n  KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\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' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAs30}\n  );\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>();\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 = (childrenAsArray.find(\n    (option) => isValidElement(option) && !option.props.isDisabled\n  ) || childrenAsArray[0]) as ReactElement;\n\n  const { onClick } = primaryOption.props;\n\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */")];
30
+ return [baseButtonStyles, /*#__PURE__*/react$1.css("box-shadow:none;background-color:", designSystem.designTokens.colorNeutral95, ";border:", `1px solid ${designSystem.designTokens.colorNeutral}`, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:getButtonStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AA+BS","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  type MouseEvent,\n  type KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement<{ size: string; color: string }>;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\n            display: flex;\n            align-items: center;\n            justify-content: center;\n          `}\n        >\n          {cloneElement(props.iconLeft, {\n            size: '40',\n            color: props.isDisabled ? 'neutral60' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.heightForButtonAs30});\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\n  }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement<TDropdownHead>[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>(null);\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event: Event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target as HTMLElement)\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(\n    props.children\n  ) as ReactElement<TDropdownHead>[];\n  const primaryOption =\n    childrenAsArray.find(\n      (option) => isValidElement(option) && !option.props.isDisabled\n    ) || childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n\n  const handleClickOnHead = useCallback(\n    (\n      event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => {\n      if (isOpen) {\n        toggle(true);\n      } else if (onClick) {\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */")];
33
31
  }
34
- return [baseButtonStyles, /*#__PURE__*/react$1.css("background-color:", designSystem.designTokens.colorSurface, ";box-shadow:", designSystem.designTokens.shadow0, ";border:1px solid ", designSystem.designTokens.colorPrimary85, ";&:hover{box-shadow:", designSystem.designTokens.shadow0, ";background-color:", designSystem.designTokens.colorPrimary95, ";}&:active{box-shadow:", designSystem.designTokens.shadow0, ";background-color:", designSystem.designTokens.colorPrimary90, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getButtonStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AAwCO","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  MouseEvent,\n  KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\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' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAs30}\n  );\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>();\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 = (childrenAsArray.find(\n    (option) => isValidElement(option) && !option.props.isDisabled\n  ) || childrenAsArray[0]) as ReactElement;\n\n  const { onClick } = primaryOption.props;\n\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */")];
32
+ return [baseButtonStyles, /*#__PURE__*/react$1.css("background-color:", designSystem.designTokens.colorSurface, ";box-shadow:", designSystem.designTokens.shadow0, ";border:1px solid ", designSystem.designTokens.colorPrimary85, ";&:hover{box-shadow:", designSystem.designTokens.shadow0, ";background-color:", designSystem.designTokens.colorPrimary95, ";}&:active{box-shadow:", designSystem.designTokens.shadow0, ";background-color:", designSystem.designTokens.colorPrimary90, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getButtonStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AAwCO","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  type MouseEvent,\n  type KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement<{ size: string; color: string }>;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\n            display: flex;\n            align-items: center;\n            justify-content: center;\n          `}\n        >\n          {cloneElement(props.iconLeft, {\n            size: '40',\n            color: props.isDisabled ? 'neutral60' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.heightForButtonAs30});\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\n  }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement<TDropdownHead>[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>(null);\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event: Event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target as HTMLElement)\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(\n    props.children\n  ) as ReactElement<TDropdownHead>[];\n  const primaryOption =\n    childrenAsArray.find(\n      (option) => isValidElement(option) && !option.props.isDisabled\n    ) || childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n\n  const handleClickOnHead = useCallback(\n    (\n      event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => {\n      if (isOpen) {\n        toggle(true);\n      } else if (onClick) {\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */")];
35
33
  };
36
34
  var _ref2 = process.env.NODE_ENV === "production" ? {
37
35
  name: "s5xdrg",
38
36
  styles: "display:flex;align-items:center"
39
37
  } : {
40
38
  name: "2jmmma-DropdownHead",
41
- styles: "display:flex;align-items:center;label:DropdownHead;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AAqEc","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  MouseEvent,\n  KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\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' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAs30}\n  );\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>();\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 = (childrenAsArray.find(\n    (option) => isValidElement(option) && !option.props.isDisabled\n  ) || childrenAsArray[0]) as ReactElement;\n\n  const { onClick } = primaryOption.props;\n\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */",
39
+ styles: "display:flex;align-items:center;label:DropdownHead;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AAqEc","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  type MouseEvent,\n  type KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement<{ size: string; color: string }>;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\n            display: flex;\n            align-items: center;\n            justify-content: center;\n          `}\n        >\n          {cloneElement(props.iconLeft, {\n            size: '40',\n            color: props.isDisabled ? 'neutral60' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.heightForButtonAs30});\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\n  }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement<TDropdownHead>[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>(null);\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event: Event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target as HTMLElement)\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(\n    props.children\n  ) as ReactElement<TDropdownHead>[];\n  const primaryOption =\n    childrenAsArray.find(\n      (option) => isValidElement(option) && !option.props.isDisabled\n    ) || childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n\n  const handleClickOnHead = useCallback(\n    (\n      event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => {\n      if (isOpen) {\n        toggle(true);\n      } else if (onClick) {\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */",
42
40
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
43
41
  };
44
42
  const DropdownHead = props => {
@@ -48,15 +46,15 @@ const DropdownHead = props => {
48
46
  label: props.children,
49
47
  onClick: props.onClick,
50
48
  isDisabled: props.isDisabled,
51
- css: [...getButtonStyles(props.isDisabled), /*#__PURE__*/react$1.css("padding:0 ", designSystem.designTokens.spacing30, ";border-radius:", designSystem.designTokens.borderRadius4, " 0 0 ", designSystem.designTokens.borderRadius4, ";" + (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.tsx"],"names":[],"mappings":"AAgFa","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  MouseEvent,\n  KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\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' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAs30}\n  );\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>();\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 = (childrenAsArray.find(\n    (option) => isValidElement(option) && !option.props.isDisabled\n  ) || childrenAsArray[0]) as ReactElement;\n\n  const { onClick } = primaryOption.props;\n\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AA8EQ","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  MouseEvent,\n  KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\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' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAs30}\n  );\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>();\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 = (childrenAsArray.find(\n    (option) => isValidElement(option) && !option.props.isDisabled\n  ) || childrenAsArray[0]) as ReactElement;\n\n  const { onClick } = primaryOption.props;\n\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"],
49
+ css: [...getButtonStyles(props.isDisabled), /*#__PURE__*/react$1.css("padding:0 ", designSystem.designTokens.spacing30, ";border-radius:", designSystem.designTokens.borderRadius4, " 0 0 ", designSystem.designTokens.borderRadius4, ";" + (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.tsx"],"names":[],"mappings":"AAgFa","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  type MouseEvent,\n  type KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement<{ size: string; color: string }>;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\n            display: flex;\n            align-items: center;\n            justify-content: center;\n          `}\n        >\n          {cloneElement(props.iconLeft, {\n            size: '40',\n            color: props.isDisabled ? 'neutral60' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.heightForButtonAs30});\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\n  }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement<TDropdownHead>[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>(null);\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event: Event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target as HTMLElement)\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(\n    props.children\n  ) as ReactElement<TDropdownHead>[];\n  const primaryOption =\n    childrenAsArray.find(\n      (option) => isValidElement(option) && !option.props.isDisabled\n    ) || childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n\n  const handleClickOnHead = useCallback(\n    (\n      event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => {\n      if (isOpen) {\n        toggle(true);\n      } else if (onClick) {\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AA8EQ","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  type MouseEvent,\n  type KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement<{ size: string; color: string }>;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\n            display: flex;\n            align-items: center;\n            justify-content: center;\n          `}\n        >\n          {cloneElement(props.iconLeft, {\n            size: '40',\n            color: props.isDisabled ? 'neutral60' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.heightForButtonAs30});\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\n  }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement<TDropdownHead>[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>(null);\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event: Event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target as HTMLElement)\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(\n    props.children\n  ) as ReactElement<TDropdownHead>[];\n  const primaryOption =\n    childrenAsArray.find(\n      (option) => isValidElement(option) && !option.props.isDisabled\n    ) || childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n\n  const handleClickOnHead = useCallback(\n    (\n      event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => {\n      if (isOpen) {\n        toggle(true);\n      } else if (onClick) {\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"],
52
50
  children: [jsxRuntime.jsx("span", {
53
- css: /*#__PURE__*/react$1.css("margin-right:", designSystem.designTokens.spacing20, ";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.tsx"],"names":[],"mappings":"AAwFkB","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  MouseEvent,\n  KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\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' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAs30}\n  );\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>();\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 = (childrenAsArray.find(\n    (option) => isValidElement(option) && !option.props.isDisabled\n  ) || childrenAsArray[0]) as ReactElement;\n\n  const { onClick } = primaryOption.props;\n\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"),
51
+ css: /*#__PURE__*/react$1.css("margin-right:", designSystem.designTokens.spacing20, ";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.tsx"],"names":[],"mappings":"AAwFkB","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  type MouseEvent,\n  type KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement<{ size: string; color: string }>;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\n            display: flex;\n            align-items: center;\n            justify-content: center;\n          `}\n        >\n          {cloneElement(props.iconLeft, {\n            size: '40',\n            color: props.isDisabled ? 'neutral60' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.heightForButtonAs30});\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\n  }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement<TDropdownHead>[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>(null);\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event: Event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target as HTMLElement)\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(\n    props.children\n  ) as ReactElement<TDropdownHead>[];\n  const primaryOption =\n    childrenAsArray.find(\n      (option) => isValidElement(option) && !option.props.isDisabled\n    ) || childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n\n  const handleClickOnHead = useCallback(\n    (\n      event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => {\n      if (isOpen) {\n        toggle(true);\n      } else if (onClick) {\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"),
54
52
  children: /*#__PURE__*/react.cloneElement(props.iconLeft, {
55
- size: 'big',
53
+ size: '40',
56
54
  color: props.isDisabled ? 'neutral60' : 'primary'
57
55
  })
58
56
  }), jsxRuntime.jsx("span", {
59
- css: /*#__PURE__*/react$1.css("margin:0 ", designSystem.designTokens.spacing10, " 0 0;display:flex;align-items:center;justify-content:center;", !props.isDisabled && /*#__PURE__*/react$1.css(">div{color:", designSystem.designTokens.fontColorForButtonAsSecondary, "!important;}" + (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.tsx"],"names":[],"mappings":"AA4Ge","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  MouseEvent,\n  KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\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' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAs30}\n  );\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>();\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 = (childrenAsArray.find(\n    (option) => isValidElement(option) && !option.props.isDisabled\n  ) || childrenAsArray[0]) as ReactElement;\n\n  const { onClick } = primaryOption.props;\n\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"), ";" + (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.tsx"],"names":[],"mappings":"AAqGkB","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  MouseEvent,\n  KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\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' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAs30}\n  );\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>();\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 = (childrenAsArray.find(\n    (option) => isValidElement(option) && !option.props.isDisabled\n  ) || childrenAsArray[0]) as ReactElement;\n\n  const { onClick } = primaryOption.props;\n\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"),
57
+ css: /*#__PURE__*/react$1.css("margin:0 ", designSystem.designTokens.spacing10, " 0 0;display:flex;align-items:center;justify-content:center;", !props.isDisabled && /*#__PURE__*/react$1.css(">div{color:", designSystem.designTokens.fontColorForButtonAsSecondary, "!important;}" + (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.tsx"],"names":[],"mappings":"AA4Ge","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  type MouseEvent,\n  type KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement<{ size: string; color: string }>;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\n            display: flex;\n            align-items: center;\n            justify-content: center;\n          `}\n        >\n          {cloneElement(props.iconLeft, {\n            size: '40',\n            color: props.isDisabled ? 'neutral60' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.heightForButtonAs30});\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\n  }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement<TDropdownHead>[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>(null);\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event: Event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target as HTMLElement)\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(\n    props.children\n  ) as ReactElement<TDropdownHead>[];\n  const primaryOption =\n    childrenAsArray.find(\n      (option) => isValidElement(option) && !option.props.isDisabled\n    ) || childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n\n  const handleClickOnHead = useCallback(\n    (\n      event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => {\n      if (isOpen) {\n        toggle(true);\n      } else if (onClick) {\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"), ";" + (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.tsx"],"names":[],"mappings":"AAqGkB","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  type MouseEvent,\n  type KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement<{ size: string; color: string }>;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\n            display: flex;\n            align-items: center;\n            justify-content: center;\n          `}\n        >\n          {cloneElement(props.iconLeft, {\n            size: '40',\n            color: props.isDisabled ? 'neutral60' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.heightForButtonAs30});\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\n  }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement<TDropdownHead>[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>(null);\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event: Event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target as HTMLElement)\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(\n    props.children\n  ) as ReactElement<TDropdownHead>[];\n  const primaryOption =\n    childrenAsArray.find(\n      (option) => isValidElement(option) && !option.props.isDisabled\n    ) || childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n\n  const handleClickOnHead = useCallback(\n    (\n      event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => {\n      if (isOpen) {\n        toggle(true);\n      } else if (onClick) {\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"),
60
58
  children: jsxRuntime.jsx(Text__default["default"].Detail, {
61
59
  tone: props.isDisabled ? 'secondary' : undefined,
62
60
  children: props.children
@@ -65,20 +63,13 @@ const DropdownHead = props => {
65
63
  }), props.chevron]
66
64
  });
67
65
  };
68
- DropdownHead.propTypes = process.env.NODE_ENV !== "production" ? {
69
- iconLeft: _pt__default["default"].element.isRequired,
70
- onClick: _pt__default["default"].func,
71
- children: _pt__default["default"].string.isRequired,
72
- isDisabled: _pt__default["default"].bool.isRequired,
73
- chevron: _pt__default["default"].element.isRequired
74
- } : {};
75
66
  DropdownHead.displayName = 'DropdownHead';
76
67
  var _ref = process.env.NODE_ENV === "production" ? {
77
68
  name: "1jklb6q",
78
69
  styles: "pointer-events:none;margin-top:3px"
79
70
  } : {
80
71
  name: "1kcvcmv-DropdownChevron",
81
- styles: "pointer-events:none;margin-top:3px;label:DropdownChevron;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AAmKgB","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  MouseEvent,\n  KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\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' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAs30}\n  );\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>();\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 = (childrenAsArray.find(\n    (option) => isValidElement(option) && !option.props.isDisabled\n  ) || childrenAsArray[0]) as ReactElement;\n\n  const { onClick } = primaryOption.props;\n\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */",
72
+ styles: "pointer-events:none;margin-top:3px;label:DropdownChevron;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AAmKgB","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  type MouseEvent,\n  type KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement<{ size: string; color: string }>;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\n            display: flex;\n            align-items: center;\n            justify-content: center;\n          `}\n        >\n          {cloneElement(props.iconLeft, {\n            size: '40',\n            color: props.isDisabled ? 'neutral60' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.heightForButtonAs30});\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\n  }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement<TDropdownHead>[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>(null);\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event: Event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target as HTMLElement)\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(\n    props.children\n  ) as ReactElement<TDropdownHead>[];\n  const primaryOption =\n    childrenAsArray.find(\n      (option) => isValidElement(option) && !option.props.isDisabled\n    ) || childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n\n  const handleClickOnHead = useCallback(\n    (\n      event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => {\n      if (isOpen) {\n        toggle(true);\n      } else if (onClick) {\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */",
82
73
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
83
74
  };
84
75
  const DropdownChevron = /*#__PURE__*/react.forwardRef((props, ref) => jsxRuntime.jsx(AccessibleButton__default["default"], {
@@ -86,7 +77,7 @@ const DropdownChevron = /*#__PURE__*/react.forwardRef((props, ref) => jsxRuntime
86
77
  label: "Open Dropdown",
87
78
  onClick: props.onClick,
88
79
  isDisabled: props.isDisabled,
89
- css: [...getButtonStyles(props.isDisabled), /*#__PURE__*/react$1.css("padding:0 ", designSystem.designTokens.spacing20, ";border-radius:0 ", designSystem.designTokens.borderRadius4, " ", designSystem.designTokens.borderRadius4, " 0;border-color:", props.isDisabled ? designSystem.designTokens.colorNeutral : designSystem.designTokens.colorPrimary85, ";border-width:1px 1px 1px 0px;border-style:solid;" + (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.tsx"],"names":[],"mappings":"AA8IW","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  MouseEvent,\n  KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\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' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAs30}\n  );\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>();\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 = (childrenAsArray.find(\n    (option) => isValidElement(option) && !option.props.isDisabled\n  ) || childrenAsArray[0]) as ReactElement;\n\n  const { onClick } = primaryOption.props;\n\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AA4IM","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  MouseEvent,\n  KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\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' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAs30}\n  );\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>();\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 = (childrenAsArray.find(\n    (option) => isValidElement(option) && !option.props.isDisabled\n  ) || childrenAsArray[0]) as ReactElement;\n\n  const { onClick } = primaryOption.props;\n\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"],
80
+ css: [...getButtonStyles(props.isDisabled), /*#__PURE__*/react$1.css("padding:0 ", designSystem.designTokens.spacing20, ";border-radius:0 ", designSystem.designTokens.borderRadius4, " ", designSystem.designTokens.borderRadius4, " 0;border-color:", props.isDisabled ? designSystem.designTokens.colorNeutral : designSystem.designTokens.colorPrimary85, ";border-width:1px 1px 1px 0px;border-style:solid;" + (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.tsx"],"names":[],"mappings":"AA8IW","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  type MouseEvent,\n  type KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement<{ size: string; color: string }>;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\n            display: flex;\n            align-items: center;\n            justify-content: center;\n          `}\n        >\n          {cloneElement(props.iconLeft, {\n            size: '40',\n            color: props.isDisabled ? 'neutral60' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.heightForButtonAs30});\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\n  }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement<TDropdownHead>[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>(null);\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event: Event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target as HTMLElement)\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(\n    props.children\n  ) as ReactElement<TDropdownHead>[];\n  const primaryOption =\n    childrenAsArray.find(\n      (option) => isValidElement(option) && !option.props.isDisabled\n    ) || childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n\n  const handleClickOnHead = useCallback(\n    (\n      event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => {\n      if (isOpen) {\n        toggle(true);\n      } else if (onClick) {\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AA4IM","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  type MouseEvent,\n  type KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement<{ size: string; color: string }>;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\n            display: flex;\n            align-items: center;\n            justify-content: center;\n          `}\n        >\n          {cloneElement(props.iconLeft, {\n            size: '40',\n            color: props.isDisabled ? 'neutral60' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.heightForButtonAs30});\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\n  }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement<TDropdownHead>[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>(null);\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event: Event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target as HTMLElement)\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(\n    props.children\n  ) as ReactElement<TDropdownHead>[];\n  const primaryOption =\n    childrenAsArray.find(\n      (option) => isValidElement(option) && !option.props.isDisabled\n    ) || childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n\n  const handleClickOnHead = useCallback(\n    (\n      event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => {\n      if (isOpen) {\n        toggle(true);\n      } else if (onClick) {\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"],
90
81
  children: jsxRuntime.jsx("div", {
91
82
  // The margin-top is to center the icon as the caret visually looks too high otherwise
92
83
  css: _ref,
@@ -102,7 +93,7 @@ const Options = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE
102
93
  } : {
103
94
  target: "eb24b7r0",
104
95
  label: "Options"
105
- })("position:absolute;z-index:5;width:100%;top:calc(\n ", designSystem.designTokens.spacing20, " + ", designSystem.designTokens.heightForButtonAs30, "\n );border:1px solid ", designSystem.designTokens.colorSurface, ";border-radius:", designSystem.designTokens.borderRadius4, ";box-shadow:0 2px 5px 0px rgba(0, 0, 0, 0.15);margin-top:", designSystem.designTokens.spacing20, ";>button{padding-left:", designSystem.designTokens.spacing30, ";white-space:normal;&:active{background-color:", designSystem.designTokens.colorPrimary95, ";}&:hover{background-color:", designSystem.designTokens.colorPrimary98, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AA0L0B","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  MouseEvent,\n  KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\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' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAs30}\n  );\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>();\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 = (childrenAsArray.find(\n    (option) => isValidElement(option) && !option.props.isDisabled\n  ) || childrenAsArray[0]) as ReactElement;\n\n  const { onClick } = primaryOption.props;\n\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"));
96
+ })("position:absolute;z-index:5;width:100%;top:calc(", designSystem.designTokens.spacing20, " + ", designSystem.designTokens.heightForButtonAs30, ");border:1px solid ", designSystem.designTokens.colorSurface, ";border-radius:", designSystem.designTokens.borderRadius4, ";box-shadow:0 2px 5px 0px rgba(0, 0, 0, 0.15);margin-top:", designSystem.designTokens.spacing20, ";>button{padding-left:", designSystem.designTokens.spacing30, ";white-space:normal;&:active{background-color:", designSystem.designTokens.colorPrimary95, ";}&:hover{background-color:", designSystem.designTokens.colorPrimary98, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AA0L0B","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  type MouseEvent,\n  type KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement<{ size: string; color: string }>;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\n            display: flex;\n            align-items: center;\n            justify-content: center;\n          `}\n        >\n          {cloneElement(props.iconLeft, {\n            size: '40',\n            color: props.isDisabled ? 'neutral60' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.heightForButtonAs30});\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\n  }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement<TDropdownHead>[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>(null);\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event: Event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target as HTMLElement)\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(\n    props.children\n  ) as ReactElement<TDropdownHead>[];\n  const primaryOption =\n    childrenAsArray.find(\n      (option) => isValidElement(option) && !option.props.isDisabled\n    ) || childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n\n  const handleClickOnHead = useCallback(\n    (\n      event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => {\n      if (isOpen) {\n        toggle(true);\n      } else if (onClick) {\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"));
106
97
 
107
98
  /*
108
99
  This component registers a global click event listener to close the dropdown.
@@ -116,7 +107,7 @@ const Options = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE
116
107
  */
117
108
 
118
109
  const PrimaryActionDropdown = props => {
119
- const ref = react.useRef();
110
+ const ref = react.useRef(null);
120
111
  const _useToggleState = hooks.useToggleState(false),
121
112
  _useToggleState2 = _slicedToArray(_useToggleState, 2),
122
113
  isOpen = _useToggleState2[0],
@@ -139,7 +130,7 @@ const PrimaryActionDropdown = props => {
139
130
  const handleClickOnHead = react.useCallback(event => {
140
131
  if (isOpen) {
141
132
  toggle(true);
142
- } else {
133
+ } else if (onClick) {
143
134
  onClick(event);
144
135
  }
145
136
  }, [isOpen, onClick, toggle]);
@@ -148,7 +139,7 @@ const PrimaryActionDropdown = props => {
148
139
  }, [toggle]);
149
140
  process.env.NODE_ENV !== "production" ? utils.warning(childrenAsArray.length > 1, '@commercetools-frontend/ui-kit/dropdowns/primary-action-dropdown: must contain at least two options') : void 0;
150
141
  return jsxRuntime.jsxs("div", {
151
- css: /*#__PURE__*/react$1.css("position:relative;display:inline-flex;align-items:column;>:first-of-type>button{height:", designSystem.designTokens.heightForButtonAs40, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:PrimaryActionDropdown;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AAsRc","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  MouseEvent,\n  KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\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' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAs30}\n  );\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>();\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 = (childrenAsArray.find(\n    (option) => isValidElement(option) && !option.props.isDisabled\n  ) || childrenAsArray[0]) as ReactElement;\n\n  const { onClick } = primaryOption.props;\n\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"),
142
+ css: /*#__PURE__*/react$1.css("position:relative;display:inline-flex;align-items:column;>:first-of-type>button{height:", designSystem.designTokens.heightForButtonAs40, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:PrimaryActionDropdown;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AA0Rc","file":"primary-action-dropdown.tsx","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n  ReactElement,\n  isValidElement,\n  type MouseEvent,\n  type KeyboardEvent,\n  ForwardedRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { designTokens } 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: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.heightForButtonAs30};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.colorNeutral95};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadow0};\n      border: 1px solid ${designTokens.colorPrimary85};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorPrimary90};\n      }\n    `,\n  ];\n};\n\ntype TDropdownHead = {\n  iconLeft: ReactElement<{ size: string; color: string }>;\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  children: string;\n  isDisabled: boolean;\n  chevron: ReactElement;\n};\n\nconst DropdownHead = (props: TDropdownHead) => {\n  return (\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 ${designTokens.spacing30};\n            border-radius: ${designTokens.borderRadius4} 0 0\n              ${designTokens.borderRadius4};\n          `,\n        ]}\n      >\n        <span\n          css={css`\n            margin-right: ${designTokens.spacing20};\n            display: flex;\n            align-items: center;\n            justify-content: center;\n          `}\n        >\n          {cloneElement(props.iconLeft, {\n            size: '40',\n            color: props.isDisabled ? 'neutral60' : 'primary',\n          })}\n        </span>\n        <span\n          css={css`\n            margin: 0 ${designTokens.spacing10} 0 0;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            ${!props.isDisabled &&\n            css`\n              > div {\n                color: ${designTokens.fontColorForButtonAsSecondary} !important;\n              }\n            `}\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};\n\nDropdownHead.displayName = 'DropdownHead';\n\ntype TDropdownChevron = {\n  onClick: () => void;\n  isDisabled: boolean;\n  isOpen: boolean;\n};\n\nconst DropdownChevron = forwardRef<HTMLButtonElement, TDropdownChevron>(\n  (props, ref) => (\n    <AccessibleButton\n      ref={ref}\n      label=\"Open Dropdown\"\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${designTokens.spacing20};\n          border-radius: 0 ${designTokens.borderRadius4}\n            ${designTokens.borderRadius4} 0;\n          border-color: ${props.isDisabled\n            ? designTokens.colorNeutral\n            : designTokens.colorPrimary85};\n          border-width: 1px 1px 1px 0px;\n          border-style: solid;\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 ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.heightForButtonAs30});\n  border: 1px solid ${designTokens.colorSurface};\n  border-radius: ${designTokens.borderRadius4};\n  box-shadow: 0 2px 5px 0px rgba(0, 0, 0, 0.15);\n  margin-top: ${designTokens.spacing20};\n\n  > button {\n    padding-left: ${designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${designTokens.colorPrimary95};\n    }\n    &:hover {\n      background-color: ${designTokens.colorPrimary98};\n    }\n  }\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 */\nexport type TPrimaryActionDropdown = {\n  /**\n   * Any React element.\n   */\n  children: ReactElement<TDropdownHead>[];\n};\n\nconst PrimaryActionDropdown = (props: TPrimaryActionDropdown) => {\n  const ref = useRef<HTMLButtonElement>(null);\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event: Event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target as HTMLElement)\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(\n    props.children\n  ) as ReactElement<TDropdownHead>[];\n  const primaryOption =\n    childrenAsArray.find(\n      (option) => isValidElement(option) && !option.props.isDisabled\n    ) || childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\n\n  const handleClickOnHead = useCallback(\n    (\n      event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => {\n      if (isOpen) {\n        toggle(true);\n      } else if (onClick) {\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        > :first-of-type > button {\n          height: ${designTokens.heightForButtonAs40};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={Boolean(primaryOption.props.isDisabled)}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={Boolean(primaryOption.props.isDisabled)}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !Boolean(primaryOption.props.isDisabled) && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"),
152
143
  children: [jsxRuntime.jsx(DropdownHead, {
153
144
  iconLeft: primaryOption.props.iconLeft,
154
145
  isDisabled: Boolean(primaryOption.props.isDisabled),
@@ -165,9 +156,6 @@ const PrimaryActionDropdown = props => {
165
156
  })]
166
157
  });
167
158
  };
168
- PrimaryActionDropdown.propTypes = process.env.NODE_ENV !== "production" ? {
169
- children: _pt__default["default"].arrayOf(_pt__default["default"].element).isRequired
170
- } : {};
171
159
  PrimaryActionDropdown.displayName = 'PrimaryActionDropdown';
172
160
  var PrimaryActionDropdown$1 = PrimaryActionDropdown;
173
161
 
@@ -184,17 +172,11 @@ const Option = _ref => {
184
172
  children: props.children
185
173
  });
186
174
  };
187
- Option.propTypes = process.env.NODE_ENV !== "production" ? {
188
- onClick: _pt__default["default"].func.isRequired,
189
- isDisabled: _pt__default["default"].bool,
190
- children: _pt__default["default"].string.isRequired,
191
- iconLeft: _pt__default["default"].node
192
- } : {};
193
175
  Option.displayName = 'Option';
194
176
  var Option$1 = Option;
195
177
 
196
178
  // NOTE: This string will be replaced on build time with the package version.
197
- var version = "19.26.0";
179
+ var version = "20.0.0";
198
180
 
199
181
  exports.Option = Option$1;
200
182
  exports["default"] = PrimaryActionDropdown$1;