@commercetools-uikit/primary-action-dropdown 18.4.0 → 18.5.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.
@@ -6,8 +6,8 @@ var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
6
6
  var _styled = require('@emotion/styled/base');
7
7
  var _pt = require('prop-types');
8
8
  var _findInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/find');
9
- var react = require('react');
10
- var react$1 = require('@emotion/react');
9
+ var react$1 = require('react');
10
+ var react = require('@emotion/react');
11
11
  var AccessibleButton = require('@commercetools-uikit/accessible-button');
12
12
  var designSystem = require('@commercetools-uikit/design-system');
13
13
  var Text = require('@commercetools-uikit/text');
@@ -26,11 +26,11 @@ var Text__default = /*#__PURE__*/_interopDefault(Text);
26
26
 
27
27
  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)."; }
28
28
  const getButtonStyles = isDisabled => {
29
- const baseButtonStyles = /*#__PURE__*/react$1.css("display:flex;align-items:center;height:", designSystem.designTokens.heightForButtonAsMedium, ";" + (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.heightForButtonAsMedium};\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.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral90};\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  <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' : 'solid',\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      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\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: ${designTokens.colorNeutral};\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.heightForButtonAsMedium}\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.colorInfo95};\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[];\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */");
29
+ const baseButtonStyles = /*#__PURE__*/react.css("display:flex;align-items:center;height:", designSystem.designTokens.heightForButtonAsMedium, ";" + (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, useTheme } 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.heightForButtonAsMedium};\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.borderColorForDropdown};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenHovered};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenActive};\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  const { themedValue } = useTheme();\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\n              ? 'neutral60'\n              : themedValue('solid', '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.borderColorForDropdown};\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<{ isRecolouringTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAsMedium}\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.backgroundColorForDropdownOptionWhenActive};\n    }\n    ${(props) =>\n      props.isRecolouringTheme &&\n      css`\n        &:hover {\n          background-color: ${designTokens.colorPrimary98};\n        }\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[];\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  const { isRecolouringTheme } = useTheme();\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isRecolouringTheme={isRecolouringTheme}>\n          {childrenAsArray}\n        </Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */");
30
30
  if (isDisabled) {
31
- return [baseButtonStyles, /*#__PURE__*/react$1.css("box-shadow:none;background-color:", designSystem.designTokens.colorNeutral95, ";border:", "1px solid ".concat(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.heightForButtonAsMedium};\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.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral90};\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  <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' : 'solid',\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      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\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: ${designTokens.colorNeutral};\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.heightForButtonAsMedium}\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.colorInfo95};\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[];\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */")];
31
+ return [baseButtonStyles, /*#__PURE__*/react.css("box-shadow:none;background-color:", designSystem.designTokens.colorNeutral95, ";border:", "1px solid ".concat(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, useTheme } 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.heightForButtonAsMedium};\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.borderColorForDropdown};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenHovered};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenActive};\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  const { themedValue } = useTheme();\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\n              ? 'neutral60'\n              : themedValue('solid', '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.borderColorForDropdown};\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<{ isRecolouringTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAsMedium}\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.backgroundColorForDropdownOptionWhenActive};\n    }\n    ${(props) =>\n      props.isRecolouringTheme &&\n      css`\n        &:hover {\n          background-color: ${designTokens.colorPrimary98};\n        }\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[];\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  const { isRecolouringTheme } = useTheme();\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isRecolouringTheme={isRecolouringTheme}>\n          {childrenAsArray}\n        </Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */")];
32
32
  }
33
- return [baseButtonStyles, /*#__PURE__*/react$1.css("background-color:", designSystem.designTokens.colorSurface, ";box-shadow:", designSystem.designTokens.shadow0, ";border:", "1px solid ".concat(designSystem.designTokens.colorNeutral), ";&:hover{box-shadow:", designSystem.designTokens.shadow0, ";background-color:", designSystem.designTokens.colorNeutral95, ";}&:active{box-shadow:", designSystem.designTokens.shadow0, ";background-color:", designSystem.designTokens.colorNeutral90, ";}" + (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.heightForButtonAsMedium};\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.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral90};\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  <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' : 'solid',\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      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\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: ${designTokens.colorNeutral};\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.heightForButtonAsMedium}\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.colorInfo95};\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[];\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */")];
33
+ return [baseButtonStyles, /*#__PURE__*/react.css("background-color:", designSystem.designTokens.colorSurface, ";box-shadow:", designSystem.designTokens.shadow0, ";border:1px solid ", designSystem.designTokens.borderColorForDropdown, ";&:hover{box-shadow:", designSystem.designTokens.shadow0, ";background-color:", designSystem.designTokens.backgroundColorForDropdownWhenHovered, ";}&:active{box-shadow:", designSystem.designTokens.shadow0, ";background-color:", designSystem.designTokens.backgroundColorForDropdownWhenActive, ";}" + (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, useTheme } 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.heightForButtonAsMedium};\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.borderColorForDropdown};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenHovered};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenActive};\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  const { themedValue } = useTheme();\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\n              ? 'neutral60'\n              : themedValue('solid', '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.borderColorForDropdown};\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<{ isRecolouringTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAsMedium}\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.backgroundColorForDropdownOptionWhenActive};\n    }\n    ${(props) =>\n      props.isRecolouringTheme &&\n      css`\n        &:hover {\n          background-color: ${designTokens.colorPrimary98};\n        }\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[];\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  const { isRecolouringTheme } = useTheme();\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isRecolouringTheme={isRecolouringTheme}>\n          {childrenAsArray}\n        </Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */")];
34
34
  };
35
35
  var _ref2 = process.env.NODE_ENV === "production" ? {
36
36
  name: "s5xdrg",
@@ -38,31 +38,35 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
38
38
  } : {
39
39
  name: "2jmmma-DropdownHead",
40
40
  styles: "display:flex;align-items:center;label:DropdownHead;",
41
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AAoEY","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.heightForButtonAsMedium};\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.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral90};\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  <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' : 'solid',\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      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\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: ${designTokens.colorNeutral};\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.heightForButtonAsMedium}\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.colorInfo95};\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[];\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */",
41
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AAsEc","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, useTheme } 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.heightForButtonAsMedium};\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.borderColorForDropdown};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenHovered};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenActive};\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  const { themedValue } = useTheme();\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\n              ? 'neutral60'\n              : themedValue('solid', '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.borderColorForDropdown};\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<{ isRecolouringTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAsMedium}\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.backgroundColorForDropdownOptionWhenActive};\n    }\n    ${(props) =>\n      props.isRecolouringTheme &&\n      css`\n        &:hover {\n          background-color: ${designTokens.colorPrimary98};\n        }\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[];\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  const { isRecolouringTheme } = useTheme();\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isRecolouringTheme={isRecolouringTheme}>\n          {childrenAsArray}\n        </Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */",
42
42
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
43
43
  };
44
- const DropdownHead = props => jsxRuntime.jsxs("div", {
45
- css: _ref2,
46
- children: [jsxRuntime.jsxs(AccessibleButton__default["default"], {
47
- label: props.children,
48
- onClick: props.onClick,
49
- isDisabled: props.isDisabled,
50
- 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":"AA+EW","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.heightForButtonAsMedium};\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.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral90};\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  <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' : 'solid',\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      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\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: ${designTokens.colorNeutral};\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.heightForButtonAsMedium}\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.colorInfo95};\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[];\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\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":"AA6EM","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.heightForButtonAsMedium};\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.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral90};\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  <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' : 'solid',\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      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\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: ${designTokens.colorNeutral};\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.heightForButtonAsMedium}\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.colorInfo95};\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[];\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"],
51
- children: [jsxRuntime.jsx("span", {
52
- 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":"AAuFgB","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.heightForButtonAsMedium};\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.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral90};\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  <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' : 'solid',\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      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\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: ${designTokens.colorNeutral};\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.heightForButtonAsMedium}\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.colorInfo95};\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[];\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"),
53
- children: /*#__PURE__*/react.cloneElement(props.iconLeft, {
54
- size: 'big',
55
- color: props.isDisabled ? 'neutral60' : 'solid'
56
- })
57
- }), jsxRuntime.jsx("span", {
58
- css: /*#__PURE__*/react$1.css("margin:0 ", designSystem.designTokens.spacing10, " 0 0;display:flex;align-items:center;justify-content:center;" + (process.env.NODE_ENV === "production" ? "" : ";label:DropdownHead;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AAoGgB","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.heightForButtonAsMedium};\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.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral90};\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  <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' : 'solid',\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      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\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: ${designTokens.colorNeutral};\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.heightForButtonAsMedium}\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.colorInfo95};\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[];\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"),
59
- children: jsxRuntime.jsx(Text__default["default"].Detail, {
60
- tone: props.isDisabled ? 'secondary' : undefined,
61
- children: props.children
62
- })
63
- })]
64
- }), props.chevron]
65
- });
44
+ const DropdownHead = props => {
45
+ const _useTheme = designSystem.useTheme(),
46
+ themedValue = _useTheme.themedValue;
47
+ return jsxRuntime.jsxs("div", {
48
+ css: _ref2,
49
+ children: [jsxRuntime.jsxs(AccessibleButton__default["default"], {
50
+ label: props.children,
51
+ onClick: props.onClick,
52
+ isDisabled: props.isDisabled,
53
+ css: [...getButtonStyles(props.isDisabled), /*#__PURE__*/react.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":"AAiFa","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, useTheme } 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.heightForButtonAsMedium};\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.borderColorForDropdown};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenHovered};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenActive};\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  const { themedValue } = useTheme();\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\n              ? 'neutral60'\n              : themedValue('solid', '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.borderColorForDropdown};\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<{ isRecolouringTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAsMedium}\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.backgroundColorForDropdownOptionWhenActive};\n    }\n    ${(props) =>\n      props.isRecolouringTheme &&\n      css`\n        &:hover {\n          background-color: ${designTokens.colorPrimary98};\n        }\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[];\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  const { isRecolouringTheme } = useTheme();\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isRecolouringTheme={isRecolouringTheme}>\n          {childrenAsArray}\n        </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":"AA+EQ","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, useTheme } 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.heightForButtonAsMedium};\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.borderColorForDropdown};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenHovered};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenActive};\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  const { themedValue } = useTheme();\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\n              ? 'neutral60'\n              : themedValue('solid', '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.borderColorForDropdown};\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<{ isRecolouringTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAsMedium}\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.backgroundColorForDropdownOptionWhenActive};\n    }\n    ${(props) =>\n      props.isRecolouringTheme &&\n      css`\n        &:hover {\n          background-color: ${designTokens.colorPrimary98};\n        }\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[];\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  const { isRecolouringTheme } = useTheme();\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isRecolouringTheme={isRecolouringTheme}>\n          {childrenAsArray}\n        </Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"],
54
+ children: [jsxRuntime.jsx("span", {
55
+ css: /*#__PURE__*/react.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":"AAyFkB","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, useTheme } 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.heightForButtonAsMedium};\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.borderColorForDropdown};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenHovered};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenActive};\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  const { themedValue } = useTheme();\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\n              ? 'neutral60'\n              : themedValue('solid', '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.borderColorForDropdown};\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<{ isRecolouringTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAsMedium}\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.backgroundColorForDropdownOptionWhenActive};\n    }\n    ${(props) =>\n      props.isRecolouringTheme &&\n      css`\n        &:hover {\n          background-color: ${designTokens.colorPrimary98};\n        }\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[];\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  const { isRecolouringTheme } = useTheme();\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isRecolouringTheme={isRecolouringTheme}>\n          {childrenAsArray}\n        </Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"),
56
+ children: /*#__PURE__*/react$1.cloneElement(props.iconLeft, {
57
+ size: 'big',
58
+ color: props.isDisabled ? 'neutral60' : themedValue('solid', 'primary')
59
+ })
60
+ }), jsxRuntime.jsx("span", {
61
+ css: /*#__PURE__*/react.css("margin:0 ", designSystem.designTokens.spacing10, " 0 0;display:flex;align-items:center;justify-content:center;", !props.isDisabled && /*#__PURE__*/react.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":"AA+Ge","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, useTheme } 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.heightForButtonAsMedium};\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.borderColorForDropdown};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenHovered};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenActive};\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  const { themedValue } = useTheme();\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\n              ? 'neutral60'\n              : themedValue('solid', '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.borderColorForDropdown};\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<{ isRecolouringTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAsMedium}\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.backgroundColorForDropdownOptionWhenActive};\n    }\n    ${(props) =>\n      props.isRecolouringTheme &&\n      css`\n        &:hover {\n          background-color: ${designTokens.colorPrimary98};\n        }\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[];\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  const { isRecolouringTheme } = useTheme();\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isRecolouringTheme={isRecolouringTheme}>\n          {childrenAsArray}\n        </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":"AAwGkB","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, useTheme } 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.heightForButtonAsMedium};\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.borderColorForDropdown};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenHovered};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenActive};\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  const { themedValue } = useTheme();\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\n              ? 'neutral60'\n              : themedValue('solid', '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.borderColorForDropdown};\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<{ isRecolouringTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAsMedium}\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.backgroundColorForDropdownOptionWhenActive};\n    }\n    ${(props) =>\n      props.isRecolouringTheme &&\n      css`\n        &:hover {\n          background-color: ${designTokens.colorPrimary98};\n        }\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[];\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  const { isRecolouringTheme } = useTheme();\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isRecolouringTheme={isRecolouringTheme}>\n          {childrenAsArray}\n        </Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"),
62
+ children: jsxRuntime.jsx(Text__default["default"].Detail, {
63
+ tone: props.isDisabled ? 'secondary' : undefined,
64
+ children: props.children
65
+ })
66
+ })]
67
+ }), props.chevron]
68
+ });
69
+ };
66
70
  DropdownHead.propTypes = process.env.NODE_ENV !== "production" ? {
67
71
  iconLeft: _pt__default["default"].element.isRequired,
68
72
  onClick: _pt__default["default"].func,
@@ -77,19 +81,19 @@ var _ref = process.env.NODE_ENV === "production" ? {
77
81
  } : {
78
82
  name: "1kcvcmv-DropdownChevron",
79
83
  styles: "pointer-events:none;margin-top:3px;label:DropdownChevron;",
80
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AAwJgB","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.heightForButtonAsMedium};\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.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral90};\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  <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' : 'solid',\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      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\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: ${designTokens.colorNeutral};\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.heightForButtonAsMedium}\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.colorInfo95};\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[];\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */",
84
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AAsKgB","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, useTheme } 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.heightForButtonAsMedium};\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.borderColorForDropdown};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenHovered};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenActive};\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  const { themedValue } = useTheme();\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\n              ? 'neutral60'\n              : themedValue('solid', '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.borderColorForDropdown};\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<{ isRecolouringTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAsMedium}\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.backgroundColorForDropdownOptionWhenActive};\n    }\n    ${(props) =>\n      props.isRecolouringTheme &&\n      css`\n        &:hover {\n          background-color: ${designTokens.colorPrimary98};\n        }\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[];\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  const { isRecolouringTheme } = useTheme();\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isRecolouringTheme={isRecolouringTheme}>\n          {childrenAsArray}\n        </Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */",
81
85
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
82
86
  };
83
- const DropdownChevron = /*#__PURE__*/react.forwardRef((props, ref) => jsxRuntime.jsx(AccessibleButton__default["default"], {
87
+ const DropdownChevron = /*#__PURE__*/react$1.forwardRef((props, ref) => jsxRuntime.jsx(AccessibleButton__default["default"], {
84
88
  ref: ref,
85
89
  label: "Open Dropdown",
86
90
  onClick: props.onClick,
87
91
  isDisabled: props.isDisabled,
88
- 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:", designSystem.designTokens.colorNeutral, ";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":"AAqIW","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.heightForButtonAsMedium};\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.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral90};\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  <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' : 'solid',\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      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\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: ${designTokens.colorNeutral};\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.heightForButtonAsMedium}\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.colorInfo95};\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[];\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\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":"AAmIM","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.heightForButtonAsMedium};\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.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral90};\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  <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' : 'solid',\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      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\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: ${designTokens.colorNeutral};\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.heightForButtonAsMedium}\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.colorInfo95};\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[];\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"],
92
+ css: [...getButtonStyles(props.isDisabled), /*#__PURE__*/react.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.borderColorForDropdown, ";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":"AAiJW","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, useTheme } 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.heightForButtonAsMedium};\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.borderColorForDropdown};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenHovered};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenActive};\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  const { themedValue } = useTheme();\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\n              ? 'neutral60'\n              : themedValue('solid', '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.borderColorForDropdown};\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<{ isRecolouringTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAsMedium}\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.backgroundColorForDropdownOptionWhenActive};\n    }\n    ${(props) =>\n      props.isRecolouringTheme &&\n      css`\n        &:hover {\n          background-color: ${designTokens.colorPrimary98};\n        }\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[];\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  const { isRecolouringTheme } = useTheme();\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isRecolouringTheme={isRecolouringTheme}>\n          {childrenAsArray}\n        </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":"AA+IM","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, useTheme } 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.heightForButtonAsMedium};\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.borderColorForDropdown};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenHovered};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenActive};\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  const { themedValue } = useTheme();\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\n              ? 'neutral60'\n              : themedValue('solid', '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.borderColorForDropdown};\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<{ isRecolouringTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAsMedium}\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.backgroundColorForDropdownOptionWhenActive};\n    }\n    ${(props) =>\n      props.isRecolouringTheme &&\n      css`\n        &:hover {\n          background-color: ${designTokens.colorPrimary98};\n        }\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[];\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  const { isRecolouringTheme } = useTheme();\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isRecolouringTheme={isRecolouringTheme}>\n          {childrenAsArray}\n        </Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"],
89
93
  children: jsxRuntime.jsx("div", {
90
94
  // The margin-top is to center the icon as the caret visually looks too high otherwise
91
95
  css: _ref,
92
- children: /*#__PURE__*/react.cloneElement(props.isOpen && !props.isDisabled ? jsxRuntime.jsx(icons.CaretUpIcon, {}) : jsxRuntime.jsx(icons.CaretDownIcon, {}), {
96
+ children: /*#__PURE__*/react$1.cloneElement(props.isOpen && !props.isDisabled ? jsxRuntime.jsx(icons.CaretUpIcon, {}) : jsxRuntime.jsx(icons.CaretDownIcon, {}), {
93
97
  color: 'neutral60',
94
98
  size: 'small'
95
99
  })
@@ -101,7 +105,7 @@ const Options = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE
101
105
  } : {
102
106
  target: "eb24b7r0",
103
107
  label: "Options"
104
- })("position:absolute;z-index:5;width:100%;top:calc(\n ", designSystem.designTokens.spacing20, " + ", designSystem.designTokens.heightForButtonAsMedium, "\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.colorInfo95, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AA+K0B","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.heightForButtonAsMedium};\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.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral90};\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  <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' : 'solid',\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      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\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: ${designTokens.colorNeutral};\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.heightForButtonAsMedium}\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.colorInfo95};\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[];\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"));
108
+ })("position:absolute;z-index:5;width:100%;top:calc(\n ", designSystem.designTokens.spacing20, " + ", designSystem.designTokens.heightForButtonAsMedium, "\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;", props => props.isRecolouringTheme && /*#__PURE__*/react.css("&:hover{background-color:", designSystem.designTokens.colorPrimary98, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:Options;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AAiNS","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, useTheme } 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.heightForButtonAsMedium};\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.borderColorForDropdown};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenHovered};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenActive};\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  const { themedValue } = useTheme();\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\n              ? 'neutral60'\n              : themedValue('solid', '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.borderColorForDropdown};\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<{ isRecolouringTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAsMedium}\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.backgroundColorForDropdownOptionWhenActive};\n    }\n    ${(props) =>\n      props.isRecolouringTheme &&\n      css`\n        &:hover {\n          background-color: ${designTokens.colorPrimary98};\n        }\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[];\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  const { isRecolouringTheme } = useTheme();\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isRecolouringTheme={isRecolouringTheme}>\n          {childrenAsArray}\n        </Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"), ";&:active{background-color:", designSystem.designTokens.backgroundColorForDropdownOptionWhenActive, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AA6L2D","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, useTheme } 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.heightForButtonAsMedium};\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.borderColorForDropdown};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenHovered};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenActive};\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  const { themedValue } = useTheme();\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\n              ? 'neutral60'\n              : themedValue('solid', '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.borderColorForDropdown};\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<{ isRecolouringTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAsMedium}\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.backgroundColorForDropdownOptionWhenActive};\n    }\n    ${(props) =>\n      props.isRecolouringTheme &&\n      css`\n        &:hover {\n          background-color: ${designTokens.colorPrimary98};\n        }\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[];\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  const { isRecolouringTheme } = useTheme();\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isRecolouringTheme={isRecolouringTheme}>\n          {childrenAsArray}\n        </Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"));
105
109
 
106
110
  /*
107
111
  This component registers a global click event listener to close the dropdown.
@@ -115,39 +119,41 @@ const Options = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE
115
119
  */
116
120
 
117
121
  const PrimaryActionDropdown = props => {
118
- const ref = react.useRef();
122
+ const ref = react$1.useRef();
119
123
  const _useToggleState = hooks.useToggleState(false),
120
124
  _useToggleState2 = _slicedToArray(_useToggleState, 2),
121
125
  isOpen = _useToggleState2[0],
122
126
  toggle = _useToggleState2[1];
123
- const handleGlobalClick = react.useCallback(event => {
127
+ const handleGlobalClick = react$1.useCallback(event => {
124
128
  const dropdownButton = ref.current;
125
129
  if (dropdownButton && event.target !== dropdownButton && !dropdownButton.contains(event.target)) {
126
130
  toggle(false);
127
131
  }
128
132
  }, [ref, toggle]);
129
- react.useEffect(() => {
133
+ const _useTheme2 = designSystem.useTheme(),
134
+ isRecolouringTheme = _useTheme2.isRecolouringTheme;
135
+ react$1.useEffect(() => {
130
136
  window.addEventListener('click', handleGlobalClick);
131
137
  return () => {
132
138
  window.removeEventListener('click', handleGlobalClick);
133
139
  };
134
140
  }, [handleGlobalClick]);
135
- const childrenAsArray = react.Children.toArray(props.children);
136
- const primaryOption = _findInstanceProperty__default["default"](childrenAsArray).call(childrenAsArray, option => /*#__PURE__*/react.isValidElement(option) && !option.props.isDisabled) || childrenAsArray[0];
141
+ const childrenAsArray = react$1.Children.toArray(props.children);
142
+ const primaryOption = _findInstanceProperty__default["default"](childrenAsArray).call(childrenAsArray, option => /*#__PURE__*/react$1.isValidElement(option) && !option.props.isDisabled) || childrenAsArray[0];
137
143
  const onClick = primaryOption.props.onClick;
138
- const handleClickOnHead = react.useCallback(event => {
144
+ const handleClickOnHead = react$1.useCallback(event => {
139
145
  if (isOpen) {
140
146
  toggle(true);
141
147
  } else {
142
148
  onClick(event);
143
149
  }
144
150
  }, [isOpen, onClick, toggle]);
145
- const handleClickOnChevron = react.useCallback(() => {
151
+ const handleClickOnChevron = react$1.useCallback(() => {
146
152
  toggle();
147
153
  }, [toggle]);
148
154
  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;
149
155
  return jsxRuntime.jsxs("div", {
150
- css: /*#__PURE__*/react$1.css("position:relative;display:inline-flex;align-items:column;>:first-of-type>button{height:", designSystem.designTokens.heightForButtonAsBig, ";}" + (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":"AAyQc","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.heightForButtonAsMedium};\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.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.colorNeutral90};\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  <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' : 'solid',\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      >\n        <Text.Detail tone={props.isDisabled ? 'secondary' : undefined}>\n          {props.children}\n        </Text.Detail>\n      </span>\n    </AccessibleButton>\n    {props.chevron}\n  </div>\n);\n\nDropdownHead.displayName = 'DropdownHead';\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: ${designTokens.colorNeutral};\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.heightForButtonAsMedium}\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.colorInfo95};\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[];\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"),
156
+ css: /*#__PURE__*/react.css("position:relative;display:inline-flex;align-items:column;>:first-of-type>button{height:", designSystem.designTokens.heightForButtonAsBig, ";}" + (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":"AA+Rc","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, useTheme } 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.heightForButtonAsMedium};\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.borderColorForDropdown};\n      &:hover {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenHovered};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadow0};\n        background-color: ${designTokens.backgroundColorForDropdownWhenActive};\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  const { themedValue } = useTheme();\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\n              ? 'neutral60'\n              : themedValue('solid', '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.borderColorForDropdown};\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<{ isRecolouringTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(\n    ${designTokens.spacing20} + ${designTokens.heightForButtonAsMedium}\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.backgroundColorForDropdownOptionWhenActive};\n    }\n    ${(props) =>\n      props.isRecolouringTheme &&\n      css`\n        &:hover {\n          background-color: ${designTokens.colorPrimary98};\n        }\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[];\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  const { isRecolouringTheme } = useTheme();\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.heightForButtonAsBig};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isRecolouringTheme={isRecolouringTheme}>\n          {childrenAsArray}\n        </Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"),
151
157
  children: [jsxRuntime.jsx(DropdownHead, {
152
158
  iconLeft: primaryOption.props.iconLeft,
153
159
  isDisabled: primaryOption.props.isDisabled,
@@ -160,6 +166,7 @@ const PrimaryActionDropdown = props => {
160
166
  }),
161
167
  children: primaryOption.props.children
162
168
  }), isOpen && !primaryOption.props.isDisabled && jsxRuntime.jsx(Options, {
169
+ isRecolouringTheme: isRecolouringTheme,
163
170
  children: childrenAsArray
164
171
  })]
165
172
  });
@@ -174,7 +181,7 @@ const Option = props => jsxRuntime.jsx(AccessibleButton__default["default"], {
174
181
  label: props.children,
175
182
  onClick: props.onClick,
176
183
  isDisabled: props.isDisabled,
177
- css: [/*#__PURE__*/react$1.css("display:block;text-align:left;width:100%;padding:", designSystem.designTokens.spacing20, ";background-color:", designSystem.designTokens.colorSurface, ";&:first-of-type{border-radius:", designSystem.designTokens.borderRadius6, " ", designSystem.designTokens.borderRadius6, " 0 0;}&:last-of-type{border-radius:0 0 ", designSystem.designTokens.borderRadius6, " ", designSystem.designTokens.borderRadius6, ";}&:hover{background-color:", designSystem.designTokens.colorNeutral95, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:Option;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm9wdGlvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJTIiwiZmlsZSI6Im9wdGlvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgQWNjZXNzaWJsZUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9hY2Nlc3NpYmxlLWJ1dHRvbic7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxudHlwZSBUT3B0aW9uID0ge1xuICAvKipcbiAgICogRXZlbnQgaGFuZGxlciB0cmlnZ2VycyB3aGVuZXZlciB0aGUgb3B0aW9uIGlzIGNsaWNrZWQuXG4gICAqL1xuICBvbkNsaWNrOiAoKSA9PiB2b2lkO1xuICAvKipcbiAgICogRGlzYWJsZXMgdGhlIG9wdGlvbiB3aXRoaW4gdGhlIGRyb3Bkb3duLiBJZiBhbGwgb3B0aW9ucyBhcmUgZGlzYWJsZWQgdGhlIGRyb3Bkb3duIHdpbGwgYmUgZGlzYWJsZWQuXG4gICAqL1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEFueSBzdHJpbmcgd2hpY2ggc2VydmVzIGFzIHRoZSBsYWJlbC5cbiAgICovXG4gIGNoaWxkcmVuOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBBbnkgUmVhY3Qgbm9kZS5cbiAgICovXG4gIGljb25MZWZ0OiBSZWFjdE5vZGU7XG59O1xuXG5jb25zdCBPcHRpb24gPSAocHJvcHM6IFRPcHRpb24pID0+IChcbiAgPEFjY2Vzc2libGVCdXR0b25cbiAgICBsYWJlbD17cHJvcHMuY2hpbGRyZW59XG4gICAgb25DbGljaz17cHJvcHMub25DbGlja31cbiAgICBpc0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgIGNzcz17W1xuICAgICAgY3NzYFxuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgdGV4dC1hbGlnbjogbGVmdDtcbiAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyMH07XG4gICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gICAgICAgICY6Zmlyc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzNn1cbiAgICAgICAgICAgICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9IDAgMDtcbiAgICAgICAgfVxuICAgICAgICAmOmxhc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogMCAwICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9XG4gICAgICAgICAgICAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM2fTtcbiAgICAgICAgfVxuICAgICAgICAmOmhvdmVyIHtcbiAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX07XG4gICAgICAgIH1cbiAgICAgIGAsXG4gICAgICBwcm9wcy5pc0Rpc2FibGVkICYmXG4gICAgICAgIGNzc2BcbiAgICAgICAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsfTtcbiAgICAgICAgYCxcbiAgICBdfVxuICA+XG4gICAge3Byb3BzLmNoaWxkcmVufVxuICA8L0FjY2Vzc2libGVCdXR0b24+XG4pO1xuT3B0aW9uLmRpc3BsYXlOYW1lID0gJ09wdGlvbic7XG5PcHRpb24uZGVmYXVsdFByb3BzID0ge1xuICBpc0Rpc2FibGVkOiBmYWxzZSxcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE9wdGlvbjtcbiJdfQ== */"), props.isDisabled && /*#__PURE__*/react$1.css("color:", designSystem.designTokens.colorNeutral, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:Option;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm9wdGlvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaURXIiwiZmlsZSI6Im9wdGlvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgQWNjZXNzaWJsZUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9hY2Nlc3NpYmxlLWJ1dHRvbic7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxudHlwZSBUT3B0aW9uID0ge1xuICAvKipcbiAgICogRXZlbnQgaGFuZGxlciB0cmlnZ2VycyB3aGVuZXZlciB0aGUgb3B0aW9uIGlzIGNsaWNrZWQuXG4gICAqL1xuICBvbkNsaWNrOiAoKSA9PiB2b2lkO1xuICAvKipcbiAgICogRGlzYWJsZXMgdGhlIG9wdGlvbiB3aXRoaW4gdGhlIGRyb3Bkb3duLiBJZiBhbGwgb3B0aW9ucyBhcmUgZGlzYWJsZWQgdGhlIGRyb3Bkb3duIHdpbGwgYmUgZGlzYWJsZWQuXG4gICAqL1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEFueSBzdHJpbmcgd2hpY2ggc2VydmVzIGFzIHRoZSBsYWJlbC5cbiAgICovXG4gIGNoaWxkcmVuOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBBbnkgUmVhY3Qgbm9kZS5cbiAgICovXG4gIGljb25MZWZ0OiBSZWFjdE5vZGU7XG59O1xuXG5jb25zdCBPcHRpb24gPSAocHJvcHM6IFRPcHRpb24pID0+IChcbiAgPEFjY2Vzc2libGVCdXR0b25cbiAgICBsYWJlbD17cHJvcHMuY2hpbGRyZW59XG4gICAgb25DbGljaz17cHJvcHMub25DbGlja31cbiAgICBpc0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgIGNzcz17W1xuICAgICAgY3NzYFxuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgdGV4dC1hbGlnbjogbGVmdDtcbiAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyMH07XG4gICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gICAgICAgICY6Zmlyc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzNn1cbiAgICAgICAgICAgICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9IDAgMDtcbiAgICAgICAgfVxuICAgICAgICAmOmxhc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogMCAwICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9XG4gICAgICAgICAgICAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM2fTtcbiAgICAgICAgfVxuICAgICAgICAmOmhvdmVyIHtcbiAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX07XG4gICAgICAgIH1cbiAgICAgIGAsXG4gICAgICBwcm9wcy5pc0Rpc2FibGVkICYmXG4gICAgICAgIGNzc2BcbiAgICAgICAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsfTtcbiAgICAgICAgYCxcbiAgICBdfVxuICA+XG4gICAge3Byb3BzLmNoaWxkcmVufVxuICA8L0FjY2Vzc2libGVCdXR0b24+XG4pO1xuT3B0aW9uLmRpc3BsYXlOYW1lID0gJ09wdGlvbic7XG5PcHRpb24uZGVmYXVsdFByb3BzID0ge1xuICBpc0Rpc2FibGVkOiBmYWxzZSxcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE9wdGlvbjtcbiJdfQ== */"), process.env.NODE_ENV === "production" ? "" : ";label:Option;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm9wdGlvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkJJIiwiZmlsZSI6Im9wdGlvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgQWNjZXNzaWJsZUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9hY2Nlc3NpYmxlLWJ1dHRvbic7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxudHlwZSBUT3B0aW9uID0ge1xuICAvKipcbiAgICogRXZlbnQgaGFuZGxlciB0cmlnZ2VycyB3aGVuZXZlciB0aGUgb3B0aW9uIGlzIGNsaWNrZWQuXG4gICAqL1xuICBvbkNsaWNrOiAoKSA9PiB2b2lkO1xuICAvKipcbiAgICogRGlzYWJsZXMgdGhlIG9wdGlvbiB3aXRoaW4gdGhlIGRyb3Bkb3duLiBJZiBhbGwgb3B0aW9ucyBhcmUgZGlzYWJsZWQgdGhlIGRyb3Bkb3duIHdpbGwgYmUgZGlzYWJsZWQuXG4gICAqL1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEFueSBzdHJpbmcgd2hpY2ggc2VydmVzIGFzIHRoZSBsYWJlbC5cbiAgICovXG4gIGNoaWxkcmVuOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBBbnkgUmVhY3Qgbm9kZS5cbiAgICovXG4gIGljb25MZWZ0OiBSZWFjdE5vZGU7XG59O1xuXG5jb25zdCBPcHRpb24gPSAocHJvcHM6IFRPcHRpb24pID0+IChcbiAgPEFjY2Vzc2libGVCdXR0b25cbiAgICBsYWJlbD17cHJvcHMuY2hpbGRyZW59XG4gICAgb25DbGljaz17cHJvcHMub25DbGlja31cbiAgICBpc0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgIGNzcz17W1xuICAgICAgY3NzYFxuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgdGV4dC1hbGlnbjogbGVmdDtcbiAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyMH07XG4gICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gICAgICAgICY6Zmlyc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzNn1cbiAgICAgICAgICAgICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9IDAgMDtcbiAgICAgICAgfVxuICAgICAgICAmOmxhc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogMCAwICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9XG4gICAgICAgICAgICAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM2fTtcbiAgICAgICAgfVxuICAgICAgICAmOmhvdmVyIHtcbiAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX07XG4gICAgICAgIH1cbiAgICAgIGAsXG4gICAgICBwcm9wcy5pc0Rpc2FibGVkICYmXG4gICAgICAgIGNzc2BcbiAgICAgICAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsfTtcbiAgICAgICAgYCxcbiAgICBdfVxuICA+XG4gICAge3Byb3BzLmNoaWxkcmVufVxuICA8L0FjY2Vzc2libGVCdXR0b24+XG4pO1xuT3B0aW9uLmRpc3BsYXlOYW1lID0gJ09wdGlvbic7XG5PcHRpb24uZGVmYXVsdFByb3BzID0ge1xuICBpc0Rpc2FibGVkOiBmYWxzZSxcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE9wdGlvbjtcbiJdfQ== */"],
184
+ css: [/*#__PURE__*/react.css("display:block;text-align:left;width:100%;padding:", designSystem.designTokens.spacing20, ";background-color:", designSystem.designTokens.colorSurface, ";&:first-of-type{border-radius:", designSystem.designTokens.borderRadius6, " ", designSystem.designTokens.borderRadius6, " 0 0;}&:last-of-type{border-radius:0 0 ", designSystem.designTokens.borderRadius6, " ", designSystem.designTokens.borderRadius6, ";}&:hover{background-color:", designSystem.designTokens.colorNeutral95, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:Option;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm9wdGlvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJTIiwiZmlsZSI6Im9wdGlvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgQWNjZXNzaWJsZUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9hY2Nlc3NpYmxlLWJ1dHRvbic7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxudHlwZSBUT3B0aW9uID0ge1xuICAvKipcbiAgICogRXZlbnQgaGFuZGxlciB0cmlnZ2VycyB3aGVuZXZlciB0aGUgb3B0aW9uIGlzIGNsaWNrZWQuXG4gICAqL1xuICBvbkNsaWNrOiAoKSA9PiB2b2lkO1xuICAvKipcbiAgICogRGlzYWJsZXMgdGhlIG9wdGlvbiB3aXRoaW4gdGhlIGRyb3Bkb3duLiBJZiBhbGwgb3B0aW9ucyBhcmUgZGlzYWJsZWQgdGhlIGRyb3Bkb3duIHdpbGwgYmUgZGlzYWJsZWQuXG4gICAqL1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEFueSBzdHJpbmcgd2hpY2ggc2VydmVzIGFzIHRoZSBsYWJlbC5cbiAgICovXG4gIGNoaWxkcmVuOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBBbnkgUmVhY3Qgbm9kZS5cbiAgICovXG4gIGljb25MZWZ0OiBSZWFjdE5vZGU7XG59O1xuXG5jb25zdCBPcHRpb24gPSAocHJvcHM6IFRPcHRpb24pID0+IChcbiAgPEFjY2Vzc2libGVCdXR0b25cbiAgICBsYWJlbD17cHJvcHMuY2hpbGRyZW59XG4gICAgb25DbGljaz17cHJvcHMub25DbGlja31cbiAgICBpc0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgIGNzcz17W1xuICAgICAgY3NzYFxuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgdGV4dC1hbGlnbjogbGVmdDtcbiAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyMH07XG4gICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gICAgICAgICY6Zmlyc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzNn1cbiAgICAgICAgICAgICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9IDAgMDtcbiAgICAgICAgfVxuICAgICAgICAmOmxhc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogMCAwICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9XG4gICAgICAgICAgICAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM2fTtcbiAgICAgICAgfVxuICAgICAgICAmOmhvdmVyIHtcbiAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX07XG4gICAgICAgIH1cbiAgICAgIGAsXG4gICAgICBwcm9wcy5pc0Rpc2FibGVkICYmXG4gICAgICAgIGNzc2BcbiAgICAgICAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsfTtcbiAgICAgICAgYCxcbiAgICBdfVxuICA+XG4gICAge3Byb3BzLmNoaWxkcmVufVxuICA8L0FjY2Vzc2libGVCdXR0b24+XG4pO1xuT3B0aW9uLmRpc3BsYXlOYW1lID0gJ09wdGlvbic7XG5PcHRpb24uZGVmYXVsdFByb3BzID0ge1xuICBpc0Rpc2FibGVkOiBmYWxzZSxcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE9wdGlvbjtcbiJdfQ== */"), props.isDisabled && /*#__PURE__*/react.css("color:", designSystem.designTokens.colorNeutral, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:Option;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm9wdGlvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaURXIiwiZmlsZSI6Im9wdGlvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgQWNjZXNzaWJsZUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9hY2Nlc3NpYmxlLWJ1dHRvbic7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxudHlwZSBUT3B0aW9uID0ge1xuICAvKipcbiAgICogRXZlbnQgaGFuZGxlciB0cmlnZ2VycyB3aGVuZXZlciB0aGUgb3B0aW9uIGlzIGNsaWNrZWQuXG4gICAqL1xuICBvbkNsaWNrOiAoKSA9PiB2b2lkO1xuICAvKipcbiAgICogRGlzYWJsZXMgdGhlIG9wdGlvbiB3aXRoaW4gdGhlIGRyb3Bkb3duLiBJZiBhbGwgb3B0aW9ucyBhcmUgZGlzYWJsZWQgdGhlIGRyb3Bkb3duIHdpbGwgYmUgZGlzYWJsZWQuXG4gICAqL1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEFueSBzdHJpbmcgd2hpY2ggc2VydmVzIGFzIHRoZSBsYWJlbC5cbiAgICovXG4gIGNoaWxkcmVuOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBBbnkgUmVhY3Qgbm9kZS5cbiAgICovXG4gIGljb25MZWZ0OiBSZWFjdE5vZGU7XG59O1xuXG5jb25zdCBPcHRpb24gPSAocHJvcHM6IFRPcHRpb24pID0+IChcbiAgPEFjY2Vzc2libGVCdXR0b25cbiAgICBsYWJlbD17cHJvcHMuY2hpbGRyZW59XG4gICAgb25DbGljaz17cHJvcHMub25DbGlja31cbiAgICBpc0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgIGNzcz17W1xuICAgICAgY3NzYFxuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgdGV4dC1hbGlnbjogbGVmdDtcbiAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyMH07XG4gICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gICAgICAgICY6Zmlyc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzNn1cbiAgICAgICAgICAgICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9IDAgMDtcbiAgICAgICAgfVxuICAgICAgICAmOmxhc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogMCAwICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9XG4gICAgICAgICAgICAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM2fTtcbiAgICAgICAgfVxuICAgICAgICAmOmhvdmVyIHtcbiAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX07XG4gICAgICAgIH1cbiAgICAgIGAsXG4gICAgICBwcm9wcy5pc0Rpc2FibGVkICYmXG4gICAgICAgIGNzc2BcbiAgICAgICAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsfTtcbiAgICAgICAgYCxcbiAgICBdfVxuICA+XG4gICAge3Byb3BzLmNoaWxkcmVufVxuICA8L0FjY2Vzc2libGVCdXR0b24+XG4pO1xuT3B0aW9uLmRpc3BsYXlOYW1lID0gJ09wdGlvbic7XG5PcHRpb24uZGVmYXVsdFByb3BzID0ge1xuICBpc0Rpc2FibGVkOiBmYWxzZSxcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE9wdGlvbjtcbiJdfQ== */"), process.env.NODE_ENV === "production" ? "" : ";label:Option;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm9wdGlvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkJJIiwiZmlsZSI6Im9wdGlvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgQWNjZXNzaWJsZUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9hY2Nlc3NpYmxlLWJ1dHRvbic7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxudHlwZSBUT3B0aW9uID0ge1xuICAvKipcbiAgICogRXZlbnQgaGFuZGxlciB0cmlnZ2VycyB3aGVuZXZlciB0aGUgb3B0aW9uIGlzIGNsaWNrZWQuXG4gICAqL1xuICBvbkNsaWNrOiAoKSA9PiB2b2lkO1xuICAvKipcbiAgICogRGlzYWJsZXMgdGhlIG9wdGlvbiB3aXRoaW4gdGhlIGRyb3Bkb3duLiBJZiBhbGwgb3B0aW9ucyBhcmUgZGlzYWJsZWQgdGhlIGRyb3Bkb3duIHdpbGwgYmUgZGlzYWJsZWQuXG4gICAqL1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEFueSBzdHJpbmcgd2hpY2ggc2VydmVzIGFzIHRoZSBsYWJlbC5cbiAgICovXG4gIGNoaWxkcmVuOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBBbnkgUmVhY3Qgbm9kZS5cbiAgICovXG4gIGljb25MZWZ0OiBSZWFjdE5vZGU7XG59O1xuXG5jb25zdCBPcHRpb24gPSAocHJvcHM6IFRPcHRpb24pID0+IChcbiAgPEFjY2Vzc2libGVCdXR0b25cbiAgICBsYWJlbD17cHJvcHMuY2hpbGRyZW59XG4gICAgb25DbGljaz17cHJvcHMub25DbGlja31cbiAgICBpc0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgIGNzcz17W1xuICAgICAgY3NzYFxuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgdGV4dC1hbGlnbjogbGVmdDtcbiAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyMH07XG4gICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gICAgICAgICY6Zmlyc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzNn1cbiAgICAgICAgICAgICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9IDAgMDtcbiAgICAgICAgfVxuICAgICAgICAmOmxhc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogMCAwICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9XG4gICAgICAgICAgICAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM2fTtcbiAgICAgICAgfVxuICAgICAgICAmOmhvdmVyIHtcbiAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX07XG4gICAgICAgIH1cbiAgICAgIGAsXG4gICAgICBwcm9wcy5pc0Rpc2FibGVkICYmXG4gICAgICAgIGNzc2BcbiAgICAgICAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsfTtcbiAgICAgICAgYCxcbiAgICBdfVxuICA+XG4gICAge3Byb3BzLmNoaWxkcmVufVxuICA8L0FjY2Vzc2libGVCdXR0b24+XG4pO1xuT3B0aW9uLmRpc3BsYXlOYW1lID0gJ09wdGlvbic7XG5PcHRpb24uZGVmYXVsdFByb3BzID0ge1xuICBpc0Rpc2FibGVkOiBmYWxzZSxcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE9wdGlvbjtcbiJdfQ== */"],
178
185
  children: props.children
179
186
  });
180
187
  Option.propTypes = process.env.NODE_ENV !== "production" ? {
@@ -190,7 +197,7 @@ Option.defaultProps = {
190
197
  var Option$1 = Option;
191
198
 
192
199
  // NOTE: This string will be replaced on build time with the package version.
193
- var version = "18.4.0";
200
+ var version = "18.5.0";
194
201
 
195
202
  exports.Option = Option$1;
196
203
  exports["default"] = PrimaryActionDropdown$1;