@commercetools-uikit/primary-action-dropdown 16.1.0 → 16.2.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.
@@ -25,12 +25,12 @@ var AccessibleButton__default = /*#__PURE__*/_interopDefault(AccessibleButton);
25
25
  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
- const getButtonStyles = (isDisabled, isNewTheme) => {
29
- const baseButtonStyles = /*#__PURE__*/react$1.css("display:flex;align-items:center;height:", designSystem.designTokens.bigButtonHeight, ";" + (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":"AAwB8B","file":"primary-action-dropdown.tsx","sourcesContent":["// TODO: @redesign cleanup\nimport {\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, isNewTheme: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${isNewTheme && designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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  isNewTheme: boolean;\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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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  isNewTheme: 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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\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: props.isDisabled || props.isNewTheme ? 'neutral60' : 'solid',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div<{ isNewTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\n\n  > button {\n    padding-left: ${(props) => props.isNewTheme && designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${(props) =>\n        props.isNewTheme && 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  const { isNewTheme } = useTheme();\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.heightForPrimaryActionDropdown};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        isNewTheme={isNewTheme}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isNewTheme={isNewTheme}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isNewTheme={isNewTheme}>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */");
28
+ const getButtonStyles = isDisabled => {
29
+ const baseButtonStyles = /*#__PURE__*/react$1.css("display:flex;align-items:center;height:", designSystem.designTokens.bigButtonHeight, ";" + (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.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${`1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\n          border-style: solid;\n        `,\n      ]}\n    >\n      {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n      <div\n        // The margin-top is to center the icon as the caret visually looks too high otherwise\n        css={css`\n          pointer-events: none;\n          margin-top: 3px;\n        `}\n      >\n        {cloneElement(\n          props.isOpen && !props.isDisabled ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\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.heightForPrimaryActionDropdown};\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"]} */");
30
30
  if (isDisabled) {
31
- return [baseButtonStyles, /*#__PURE__*/react$1.css("box-shadow:none;background-color:", designSystem.designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled, ";border:", isNewTheme && "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":"AAgCS","file":"primary-action-dropdown.tsx","sourcesContent":["// TODO: @redesign cleanup\nimport {\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, isNewTheme: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${isNewTheme && designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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  isNewTheme: boolean;\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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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  isNewTheme: 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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\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: props.isDisabled || props.isNewTheme ? 'neutral60' : 'solid',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div<{ isNewTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\n\n  > button {\n    padding-left: ${(props) => props.isNewTheme && designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${(props) =>\n        props.isNewTheme && 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  const { isNewTheme } = useTheme();\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.heightForPrimaryActionDropdown};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        isNewTheme={isNewTheme}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isNewTheme={isNewTheme}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isNewTheme={isNewTheme}>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */")];
31
+ return [baseButtonStyles, /*#__PURE__*/react$1.css("box-shadow:none;background-color:", designSystem.designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled, ";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.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${`1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\n          border-style: solid;\n        `,\n      ]}\n    >\n      {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n      <div\n        // The margin-top is to center the icon as the caret visually looks too high otherwise\n        css={css`\n          pointer-events: none;\n          margin-top: 3px;\n        `}\n      >\n        {cloneElement(\n          props.isOpen && !props.isDisabled ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\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.heightForPrimaryActionDropdown};\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"]} */")];
32
32
  }
33
- return [baseButtonStyles, /*#__PURE__*/react$1.css("background-color:", designSystem.designTokens.colorSurface, ";box-shadow:", designSystem.designTokens.shadowForPrimaryActionDropdown, ";border:", isNewTheme && "1px solid ".concat(designSystem.designTokens.colorNeutral), ";&:hover{box-shadow:", designSystem.designTokens.shadowForPrimaryActionDropdownWhenHovered, ";background-color:", isNewTheme && designSystem.designTokens.colorNeutral95, ";}&:active{box-shadow:", designSystem.designTokens.shadowForPrimaryActionDropdownWhenActive, ";background-color:", designSystem.designTokens.backgroundColorForPrimaryActionDropdownWhenActive, ";}" + (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":"AAyCO","file":"primary-action-dropdown.tsx","sourcesContent":["// TODO: @redesign cleanup\nimport {\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, isNewTheme: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${isNewTheme && designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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  isNewTheme: boolean;\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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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  isNewTheme: 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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\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: props.isDisabled || props.isNewTheme ? 'neutral60' : 'solid',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div<{ isNewTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\n\n  > button {\n    padding-left: ${(props) => props.isNewTheme && designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${(props) =>\n        props.isNewTheme && 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  const { isNewTheme } = useTheme();\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.heightForPrimaryActionDropdown};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        isNewTheme={isNewTheme}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isNewTheme={isNewTheme}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isNewTheme={isNewTheme}>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */")];
33
+ return [baseButtonStyles, /*#__PURE__*/react$1.css("background-color:", designSystem.designTokens.colorSurface, ";box-shadow:", designSystem.designTokens.shadowForPrimaryActionDropdown, ";border:", "1px solid ".concat(designSystem.designTokens.colorNeutral), ";&:hover{box-shadow:", designSystem.designTokens.shadowForPrimaryActionDropdownWhenHovered, ";background-color:", designSystem.designTokens.colorNeutral95, ";}&:active{box-shadow:", designSystem.designTokens.shadowForPrimaryActionDropdownWhenActive, ";background-color:", designSystem.designTokens.backgroundColorForPrimaryActionDropdownWhenActive, ";}" + (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.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${`1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\n          border-style: solid;\n        `,\n      ]}\n    >\n      {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n      <div\n        // The margin-top is to center the icon as the caret visually looks too high otherwise\n        css={css`\n          pointer-events: none;\n          margin-top: 3px;\n        `}\n      >\n        {cloneElement(\n          props.isOpen && !props.isDisabled ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\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.heightForPrimaryActionDropdown};\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"]} */")];
34
34
  };
35
35
  var _ref2 = process.env.NODE_ENV === "production" ? {
36
36
  name: "s5xdrg",
@@ -38,7 +38,7 @@ 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":"AAsEY","file":"primary-action-dropdown.tsx","sourcesContent":["// TODO: @redesign cleanup\nimport {\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, isNewTheme: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${isNewTheme && designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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  isNewTheme: boolean;\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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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  isNewTheme: 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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\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: props.isDisabled || props.isNewTheme ? 'neutral60' : 'solid',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div<{ isNewTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\n\n  > button {\n    padding-left: ${(props) => props.isNewTheme && designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${(props) =>\n        props.isNewTheme && 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  const { isNewTheme } = useTheme();\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.heightForPrimaryActionDropdown};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        isNewTheme={isNewTheme}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isNewTheme={isNewTheme}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isNewTheme={isNewTheme}>{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":"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.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${`1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\n          border-style: solid;\n        `,\n      ]}\n    >\n      {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n      <div\n        // The margin-top is to center the icon as the caret visually looks too high otherwise\n        css={css`\n          pointer-events: none;\n          margin-top: 3px;\n        `}\n      >\n        {cloneElement(\n          props.isOpen && !props.isDisabled ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\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.heightForPrimaryActionDropdown};\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"]} */",
42
42
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
43
43
  };
44
44
  const DropdownHead = props => jsxRuntime.jsxs("div", {
@@ -47,15 +47,15 @@ const DropdownHead = props => jsxRuntime.jsxs("div", {
47
47
  label: props.children,
48
48
  onClick: props.onClick,
49
49
  isDisabled: props.isDisabled,
50
- css: [...getButtonStyles(props.isDisabled, props.isNewTheme), /*#__PURE__*/react$1.css("padding:", designSystem.designTokens.paddingForPrimaryActionDropdown, ";border-radius:", designSystem.designTokens.borderRadiusForPrimaryActionDropdown, ";" + (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":"AAiFW","file":"primary-action-dropdown.tsx","sourcesContent":["// TODO: @redesign cleanup\nimport {\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, isNewTheme: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${isNewTheme && designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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  isNewTheme: boolean;\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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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  isNewTheme: 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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\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: props.isDisabled || props.isNewTheme ? 'neutral60' : 'solid',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div<{ isNewTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\n\n  > button {\n    padding-left: ${(props) => props.isNewTheme && designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${(props) =>\n        props.isNewTheme && 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  const { isNewTheme } = useTheme();\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.heightForPrimaryActionDropdown};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        isNewTheme={isNewTheme}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isNewTheme={isNewTheme}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isNewTheme={isNewTheme}>{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":"AA+EM","file":"primary-action-dropdown.tsx","sourcesContent":["// TODO: @redesign cleanup\nimport {\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, isNewTheme: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${isNewTheme && designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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  isNewTheme: boolean;\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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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  isNewTheme: 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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\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: props.isDisabled || props.isNewTheme ? 'neutral60' : 'solid',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div<{ isNewTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\n\n  > button {\n    padding-left: ${(props) => props.isNewTheme && designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${(props) =>\n        props.isNewTheme && 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  const { isNewTheme } = useTheme();\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.heightForPrimaryActionDropdown};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        isNewTheme={isNewTheme}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isNewTheme={isNewTheme}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isNewTheme={isNewTheme}>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"],
50
+ css: [...getButtonStyles(props.isDisabled), /*#__PURE__*/react$1.css("padding:", designSystem.designTokens.paddingForPrimaryActionDropdown, ";border-radius:", designSystem.designTokens.borderRadiusForPrimaryActionDropdown, ";" + (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.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${`1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\n          border-style: solid;\n        `,\n      ]}\n    >\n      {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n      <div\n        // The margin-top is to center the icon as the caret visually looks too high otherwise\n        css={css`\n          pointer-events: none;\n          margin-top: 3px;\n        `}\n      >\n        {cloneElement(\n          props.isOpen && !props.isDisabled ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\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.heightForPrimaryActionDropdown};\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.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${`1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\n          border-style: solid;\n        `,\n      ]}\n    >\n      {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n      <div\n        // The margin-top is to center the icon as the caret visually looks too high otherwise\n        css={css`\n          pointer-events: none;\n          margin-top: 3px;\n        `}\n      >\n        {cloneElement(\n          props.isOpen && !props.isDisabled ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\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.heightForPrimaryActionDropdown};\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
51
  children: [jsxRuntime.jsx("span", {
52
- css: /*#__PURE__*/react$1.css("margin-right:", designSystem.designTokens.marginRightForPrimaryActionDropdown, ";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":"AAwFgB","file":"primary-action-dropdown.tsx","sourcesContent":["// TODO: @redesign cleanup\nimport {\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, isNewTheme: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${isNewTheme && designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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  isNewTheme: boolean;\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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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  isNewTheme: 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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\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: props.isDisabled || props.isNewTheme ? 'neutral60' : 'solid',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div<{ isNewTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\n\n  > button {\n    padding-left: ${(props) => props.isNewTheme && designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${(props) =>\n        props.isNewTheme && 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  const { isNewTheme } = useTheme();\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.heightForPrimaryActionDropdown};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        isNewTheme={isNewTheme}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isNewTheme={isNewTheme}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isNewTheme={isNewTheme}>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"),
52
+ css: /*#__PURE__*/react$1.css("margin-right:", designSystem.designTokens.marginRightForPrimaryActionDropdown, ";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":"AAsFgB","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.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${`1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\n          border-style: solid;\n        `,\n      ]}\n    >\n      {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n      <div\n        // The margin-top is to center the icon as the caret visually looks too high otherwise\n        css={css`\n          pointer-events: none;\n          margin-top: 3px;\n        `}\n      >\n        {cloneElement(\n          props.isOpen && !props.isDisabled ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\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.heightForPrimaryActionDropdown};\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
53
  children: /*#__PURE__*/react.cloneElement(props.iconLeft, {
54
54
  size: 'big',
55
55
  color: props.isDisabled ? 'neutral60' : 'solid'
56
56
  })
57
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":"AAqGgB","file":"primary-action-dropdown.tsx","sourcesContent":["// TODO: @redesign cleanup\nimport {\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, isNewTheme: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${isNewTheme && designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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  isNewTheme: boolean;\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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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  isNewTheme: 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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\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: props.isDisabled || props.isNewTheme ? 'neutral60' : 'solid',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div<{ isNewTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\n\n  > button {\n    padding-left: ${(props) => props.isNewTheme && designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${(props) =>\n        props.isNewTheme && 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  const { isNewTheme } = useTheme();\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.heightForPrimaryActionDropdown};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        isNewTheme={isNewTheme}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isNewTheme={isNewTheme}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isNewTheme={isNewTheme}>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"),
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":"AAmGgB","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.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${`1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\n          border-style: solid;\n        `,\n      ]}\n    >\n      {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n      <div\n        // The margin-top is to center the icon as the caret visually looks too high otherwise\n        css={css`\n          pointer-events: none;\n          margin-top: 3px;\n        `}\n      >\n        {cloneElement(\n          props.isOpen && !props.isDisabled ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\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.heightForPrimaryActionDropdown};\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
59
  children: jsxRuntime.jsx(Text__default["default"].Detail, {
60
60
  tone: props.isDisabled ? 'secondary' : undefined,
61
61
  children: props.children
@@ -68,8 +68,7 @@ DropdownHead.propTypes = process.env.NODE_ENV !== "production" ? {
68
68
  onClick: _pt__default["default"].func,
69
69
  children: _pt__default["default"].string.isRequired,
70
70
  isDisabled: _pt__default["default"].bool.isRequired,
71
- chevron: _pt__default["default"].element.isRequired,
72
- isNewTheme: _pt__default["default"].bool.isRequired
71
+ chevron: _pt__default["default"].element.isRequired
73
72
  } : {};
74
73
  DropdownHead.displayName = 'DropdownHead';
75
74
  var _ref = process.env.NODE_ENV === "production" ? {
@@ -78,7 +77,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
78
77
  } : {
79
78
  name: "1kcvcmv-DropdownChevron",
80
79
  styles: "pointer-events:none;margin-top:3px;label:DropdownChevron;",
81
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AAyJgB","file":"primary-action-dropdown.tsx","sourcesContent":["// TODO: @redesign cleanup\nimport {\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, isNewTheme: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${isNewTheme && designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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  isNewTheme: boolean;\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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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  isNewTheme: 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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\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: props.isDisabled || props.isNewTheme ? 'neutral60' : 'solid',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div<{ isNewTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\n\n  > button {\n    padding-left: ${(props) => props.isNewTheme && designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${(props) =>\n        props.isNewTheme && 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  const { isNewTheme } = useTheme();\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.heightForPrimaryActionDropdown};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        isNewTheme={isNewTheme}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isNewTheme={isNewTheme}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isNewTheme={isNewTheme}>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */",
80
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.tsx"],"names":[],"mappings":"AAsJgB","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.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${`1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\n          border-style: solid;\n        `,\n      ]}\n    >\n      {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n      <div\n        // The margin-top is to center the icon as the caret visually looks too high otherwise\n        css={css`\n          pointer-events: none;\n          margin-top: 3px;\n        `}\n      >\n        {cloneElement(\n          props.isOpen && !props.isDisabled ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\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.heightForPrimaryActionDropdown};\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"]} */",
82
81
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
83
82
  };
84
83
  const DropdownChevron = /*#__PURE__*/react.forwardRef((props, ref) => jsxRuntime.jsx(AccessibleButton__default["default"], {
@@ -86,12 +85,12 @@ const DropdownChevron = /*#__PURE__*/react.forwardRef((props, ref) => jsxRuntime
86
85
  label: "Open Dropdown",
87
86
  onClick: props.onClick,
88
87
  isDisabled: props.isDisabled,
89
- css: [...getButtonStyles(props.isDisabled, props.isNewTheme), /*#__PURE__*/react$1.css("padding:", designSystem.designTokens.paddingForPrimaryActionDropdownIcon, ";border-radius:", designSystem.designTokens.borderRadiusForPrimaryActionDropdownIcon, ";border-color:", designSystem.designTokens.colorNeutral, ";border-width:", designSystem.designTokens.borderForPrimaryActionDropdownIcon, ";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":"AAuIW","file":"primary-action-dropdown.tsx","sourcesContent":["// TODO: @redesign cleanup\nimport {\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, isNewTheme: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${isNewTheme && designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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  isNewTheme: boolean;\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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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  isNewTheme: 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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\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: props.isDisabled || props.isNewTheme ? 'neutral60' : 'solid',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div<{ isNewTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\n\n  > button {\n    padding-left: ${(props) => props.isNewTheme && designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${(props) =>\n        props.isNewTheme && 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  const { isNewTheme } = useTheme();\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.heightForPrimaryActionDropdown};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        isNewTheme={isNewTheme}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isNewTheme={isNewTheme}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isNewTheme={isNewTheme}>{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":"AAqIM","file":"primary-action-dropdown.tsx","sourcesContent":["// TODO: @redesign cleanup\nimport {\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, isNewTheme: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${isNewTheme && designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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  isNewTheme: boolean;\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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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  isNewTheme: 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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\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: props.isDisabled || props.isNewTheme ? 'neutral60' : 'solid',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div<{ isNewTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\n\n  > button {\n    padding-left: ${(props) => props.isNewTheme && designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${(props) =>\n        props.isNewTheme && 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  const { isNewTheme } = useTheme();\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.heightForPrimaryActionDropdown};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        isNewTheme={isNewTheme}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isNewTheme={isNewTheme}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isNewTheme={isNewTheme}>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"],
88
+ css: [...getButtonStyles(props.isDisabled), /*#__PURE__*/react$1.css("padding:", designSystem.designTokens.paddingForPrimaryActionDropdownIcon, ";border-radius:", designSystem.designTokens.borderRadiusForPrimaryActionDropdownIcon, ";border-color:", designSystem.designTokens.colorNeutral, ";border-width:", designSystem.designTokens.borderForPrimaryActionDropdownIcon, ";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":"AAoIW","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.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${`1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\n          border-style: solid;\n        `,\n      ]}\n    >\n      {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n      <div\n        // The margin-top is to center the icon as the caret visually looks too high otherwise\n        css={css`\n          pointer-events: none;\n          margin-top: 3px;\n        `}\n      >\n        {cloneElement(\n          props.isOpen && !props.isDisabled ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\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.heightForPrimaryActionDropdown};\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":"AAkIM","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.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${`1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\n          border-style: solid;\n        `,\n      ]}\n    >\n      {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n      <div\n        // The margin-top is to center the icon as the caret visually looks too high otherwise\n        css={css`\n          pointer-events: none;\n          margin-top: 3px;\n        `}\n      >\n        {cloneElement(\n          props.isOpen && !props.isDisabled ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\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.heightForPrimaryActionDropdown};\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"]} */"],
90
89
  children: jsxRuntime.jsx("div", {
91
90
  // The margin-top is to center the icon as the caret visually looks too high otherwise
92
91
  css: _ref,
93
92
  children: /*#__PURE__*/react.cloneElement(props.isOpen && !props.isDisabled ? jsxRuntime.jsx(icons.CaretUpIcon, {}) : jsxRuntime.jsx(icons.CaretDownIcon, {}), {
94
- color: props.isDisabled || props.isNewTheme ? 'neutral60' : 'solid',
93
+ color: 'neutral60',
95
94
  size: 'small'
96
95
  })
97
96
  })
@@ -102,7 +101,7 @@ const Options = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE
102
101
  } : {
103
102
  target: "eb24b7r0",
104
103
  label: "Options"
105
- })("position:absolute;z-index:5;width:100%;top:calc(", designSystem.designTokens.spacing20, " + ", designSystem.designTokens.bigButtonHeight, ");border:1px solid ", designSystem.designTokens.borderColorForPrimaryActionDropdownMenu, ";border-radius:", designSystem.designTokens.borderRadiusForPrimaryActionDropdownMenu, ";box-shadow:", designSystem.designTokens.shadowForPrimaryActionDropdownMenu, ";margin-top:", designSystem.designTokens.marginTopForPrimaryActionDropdown, ";>button{padding-left:", props => props.isNewTheme && designSystem.designTokens.spacing30, ";white-space:normal;&:active{background-color:", props => props.isNewTheme && 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":"AAgLmD","file":"primary-action-dropdown.tsx","sourcesContent":["// TODO: @redesign cleanup\nimport {\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, isNewTheme: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${isNewTheme && designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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  isNewTheme: boolean;\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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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  isNewTheme: 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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\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: props.isDisabled || props.isNewTheme ? 'neutral60' : 'solid',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div<{ isNewTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\n\n  > button {\n    padding-left: ${(props) => props.isNewTheme && designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${(props) =>\n        props.isNewTheme && 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  const { isNewTheme } = useTheme();\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.heightForPrimaryActionDropdown};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        isNewTheme={isNewTheme}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isNewTheme={isNewTheme}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isNewTheme={isNewTheme}>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"));
104
+ })("position:absolute;z-index:5;width:100%;top:calc(", designSystem.designTokens.spacing20, " + ", designSystem.designTokens.bigButtonHeight, ");border:1px solid ", designSystem.designTokens.borderColorForPrimaryActionDropdownMenu, ";border-radius:", designSystem.designTokens.borderRadiusForPrimaryActionDropdownMenu, ";box-shadow:", designSystem.designTokens.shadowForPrimaryActionDropdownMenu, ";margin-top:", designSystem.designTokens.marginTopForPrimaryActionDropdown, ";>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":"AA6K0B","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.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${`1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\n          border-style: solid;\n        `,\n      ]}\n    >\n      {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n      <div\n        // The margin-top is to center the icon as the caret visually looks too high otherwise\n        css={css`\n          pointer-events: none;\n          margin-top: 3px;\n        `}\n      >\n        {cloneElement(\n          props.isOpen && !props.isDisabled ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\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.heightForPrimaryActionDropdown};\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"]} */"));
106
105
 
107
106
  /*
108
107
  This component registers a global click event listener to close the dropdown.
@@ -121,8 +120,6 @@ const PrimaryActionDropdown = props => {
121
120
  _useToggleState2 = _slicedToArray(_useToggleState, 2),
122
121
  isOpen = _useToggleState2[0],
123
122
  toggle = _useToggleState2[1];
124
- const _useTheme = designSystem.useTheme(),
125
- isNewTheme = _useTheme.isNewTheme;
126
123
  const handleGlobalClick = react.useCallback(event => {
127
124
  const dropdownButton = ref.current;
128
125
  if (dropdownButton && event.target !== dropdownButton && !dropdownButton.contains(event.target)) {
@@ -150,22 +147,19 @@ const PrimaryActionDropdown = props => {
150
147
  }, [toggle]);
151
148
  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;
152
149
  return jsxRuntime.jsxs("div", {
153
- css: /*#__PURE__*/react$1.css("position:relative;display:inline-flex;align-items:column;>:first-of-type>button{height:", designSystem.designTokens.heightForPrimaryActionDropdown, ";}" + (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":"AA0Qc","file":"primary-action-dropdown.tsx","sourcesContent":["// TODO: @redesign cleanup\nimport {\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, isNewTheme: boolean) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${designTokens.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${isNewTheme && `1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${isNewTheme && designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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  isNewTheme: boolean;\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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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  isNewTheme: 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, props.isNewTheme),\n        css`\n          padding: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\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: props.isDisabled || props.isNewTheme ? 'neutral60' : 'solid',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div<{ isNewTheme: boolean }>`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\n\n  > button {\n    padding-left: ${(props) => props.isNewTheme && designTokens.spacing30};\n    white-space: normal;\n    &:active {\n      background-color: ${(props) =>\n        props.isNewTheme && 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  const { isNewTheme } = useTheme();\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.heightForPrimaryActionDropdown};\n        }\n      `}\n    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        isNewTheme={isNewTheme}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref as ForwardedRef<HTMLButtonElement>}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isNewTheme={isNewTheme}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options isNewTheme={isNewTheme}>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nexport default PrimaryActionDropdown;\n"]} */"),
150
+ css: /*#__PURE__*/react$1.css("position:relative;display:inline-flex;align-items:column;>:first-of-type>button{height:", designSystem.designTokens.heightForPrimaryActionDropdown, ";}" + (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":"AAqQc","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.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled};\n        border: ${`1px solid ${designTokens.colorNeutral}`};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${designTokens.colorSurface};\n      box-shadow: ${designTokens.shadowForPrimaryActionDropdown};\n      border: ${`1px solid ${designTokens.colorNeutral}`};\n      &:hover {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenHovered};\n        background-color: ${designTokens.colorNeutral95};\n      }\n      &:active {\n        box-shadow: ${designTokens.shadowForPrimaryActionDropdownWhenActive};\n        background-color: ${designTokens.backgroundColorForPrimaryActionDropdownWhenActive};\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: ${designTokens.paddingForPrimaryActionDropdown};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdown};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin-right: ${designTokens.marginRightForPrimaryActionDropdown};\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: ${designTokens.paddingForPrimaryActionDropdownIcon};\n          border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownIcon};\n          border-color: ${designTokens.colorNeutral};\n          border-width: ${designTokens.borderForPrimaryActionDropdownIcon};\n          border-style: solid;\n        `,\n      ]}\n    >\n      {/*\n    We need to apply pointer-events: none on the icons, so that\n    event.target is always set to the button and never to the icons.\n\n    That way we can use the ref to compare event.target to the\n    AccessibleButton's button in the global click handler.\n  */}\n      <div\n        // The margin-top is to center the icon as the caret visually looks too high otherwise\n        css={css`\n          pointer-events: none;\n          margin-top: 3px;\n        `}\n      >\n        {cloneElement(\n          props.isOpen && !props.isDisabled ? (\n            <CaretUpIcon />\n          ) : (\n            <CaretDownIcon />\n          ),\n          {\n            color: 'neutral60',\n            size: 'small',\n          }\n        )}\n      </div>\n    </AccessibleButton>\n  )\n);\n\nDropdownChevron.displayName = 'DropdownChevron';\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${designTokens.spacing20} + ${designTokens.bigButtonHeight});\n  border: 1px solid ${designTokens.borderColorForPrimaryActionDropdownMenu};\n  border-radius: ${designTokens.borderRadiusForPrimaryActionDropdownMenu};\n  box-shadow: ${designTokens.shadowForPrimaryActionDropdownMenu};\n  margin-top: ${designTokens.marginTopForPrimaryActionDropdown};\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.heightForPrimaryActionDropdown};\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"]} */"),
154
151
  children: [jsxRuntime.jsx(DropdownHead, {
155
152
  iconLeft: primaryOption.props.iconLeft,
156
153
  isDisabled: primaryOption.props.isDisabled,
157
- isNewTheme: isNewTheme,
158
154
  onClick: handleClickOnHead,
159
155
  chevron: jsxRuntime.jsx(DropdownChevron, {
160
156
  ref: ref,
161
157
  onClick: handleClickOnChevron,
162
158
  isDisabled: primaryOption.props.isDisabled,
163
- isNewTheme: isNewTheme,
164
159
  isOpen: isOpen
165
160
  }),
166
161
  children: primaryOption.props.children
167
162
  }), isOpen && !primaryOption.props.isDisabled && jsxRuntime.jsx(Options, {
168
- isNewTheme: isNewTheme,
169
163
  children: childrenAsArray
170
164
  })]
171
165
  });
@@ -196,7 +190,7 @@ Option.defaultProps = {
196
190
  var Option$1 = Option;
197
191
 
198
192
  // NOTE: This string will be replaced on build time with the package version.
199
- var version = "16.1.0";
193
+ var version = "16.2.0";
200
194
 
201
195
  exports.Option = Option$1;
202
196
  exports["default"] = PrimaryActionDropdown$1;