@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 =
|
|
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:
|
|
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.
|
|
193
|
+
var version = "16.2.0";
|
|
200
194
|
|
|
201
195
|
exports.Option = Option$1;
|
|
202
196
|
exports["default"] = PrimaryActionDropdown$1;
|