@commercetools-uikit/primary-action-dropdown 16.0.0 → 16.1.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,17 +25,13 @@ 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
|
-
|
|
29
28
|
const getButtonStyles = (isDisabled, isNewTheme) => {
|
|
30
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"]} */");
|
|
31
|
-
|
|
32
30
|
if (isDisabled) {
|
|
33
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"]} */")];
|
|
34
32
|
}
|
|
35
|
-
|
|
36
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"]} */")];
|
|
37
34
|
};
|
|
38
|
-
|
|
39
35
|
var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
40
36
|
name: "s5xdrg",
|
|
41
37
|
styles: "display:flex;align-items:center"
|
|
@@ -45,7 +41,6 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
|
45
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"]} */",
|
|
46
42
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
47
43
|
};
|
|
48
|
-
|
|
49
44
|
const DropdownHead = props => jsxRuntime.jsxs("div", {
|
|
50
45
|
css: _ref2,
|
|
51
46
|
children: [jsxRuntime.jsxs(AccessibleButton__default["default"], {
|
|
@@ -68,7 +63,6 @@ const DropdownHead = props => jsxRuntime.jsxs("div", {
|
|
|
68
63
|
})]
|
|
69
64
|
}), props.chevron]
|
|
70
65
|
});
|
|
71
|
-
|
|
72
66
|
DropdownHead.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
73
67
|
iconLeft: _pt__default["default"].element.isRequired,
|
|
74
68
|
onClick: _pt__default["default"].func,
|
|
@@ -78,7 +72,6 @@ DropdownHead.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
78
72
|
isNewTheme: _pt__default["default"].bool.isRequired
|
|
79
73
|
} : {};
|
|
80
74
|
DropdownHead.displayName = 'DropdownHead';
|
|
81
|
-
|
|
82
75
|
var _ref = process.env.NODE_ENV === "production" ? {
|
|
83
76
|
name: "1jklb6q",
|
|
84
77
|
styles: "pointer-events:none;margin-top:3px"
|
|
@@ -88,7 +81,6 @@ var _ref = process.env.NODE_ENV === "production" ? {
|
|
|
88
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"]} */",
|
|
89
82
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
90
83
|
};
|
|
91
|
-
|
|
92
84
|
const DropdownChevron = /*#__PURE__*/react.forwardRef((props, ref) => jsxRuntime.jsx(AccessibleButton__default["default"], {
|
|
93
85
|
ref: ref,
|
|
94
86
|
label: "Open Dropdown",
|
|
@@ -105,13 +97,13 @@ const DropdownChevron = /*#__PURE__*/react.forwardRef((props, ref) => jsxRuntime
|
|
|
105
97
|
})
|
|
106
98
|
}));
|
|
107
99
|
DropdownChevron.displayName = 'DropdownChevron';
|
|
108
|
-
|
|
109
100
|
const Options = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
110
101
|
target: "eb24b7r0"
|
|
111
102
|
} : {
|
|
112
103
|
target: "eb24b7r0",
|
|
113
104
|
label: "Options"
|
|
114
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"]} */"));
|
|
106
|
+
|
|
115
107
|
/*
|
|
116
108
|
This component registers a global click event listener to close the dropdown.
|
|
117
109
|
It uses this global listener to close when:
|
|
@@ -123,21 +115,16 @@ const Options = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE
|
|
|
123
115
|
immediately.
|
|
124
116
|
*/
|
|
125
117
|
|
|
126
|
-
|
|
127
118
|
const PrimaryActionDropdown = props => {
|
|
128
119
|
const ref = react.useRef();
|
|
129
|
-
|
|
130
120
|
const _useToggleState = hooks.useToggleState(false),
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
121
|
+
_useToggleState2 = _slicedToArray(_useToggleState, 2),
|
|
122
|
+
isOpen = _useToggleState2[0],
|
|
123
|
+
toggle = _useToggleState2[1];
|
|
135
124
|
const _useTheme = designSystem.useTheme(),
|
|
136
|
-
|
|
137
|
-
|
|
125
|
+
isNewTheme = _useTheme.isNewTheme;
|
|
138
126
|
const handleGlobalClick = react.useCallback(event => {
|
|
139
127
|
const dropdownButton = ref.current;
|
|
140
|
-
|
|
141
128
|
if (dropdownButton && event.target !== dropdownButton && !dropdownButton.contains(event.target)) {
|
|
142
129
|
toggle(false);
|
|
143
130
|
}
|
|
@@ -183,7 +170,6 @@ const PrimaryActionDropdown = props => {
|
|
|
183
170
|
})]
|
|
184
171
|
});
|
|
185
172
|
};
|
|
186
|
-
|
|
187
173
|
PrimaryActionDropdown.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
188
174
|
children: _pt__default["default"].arrayOf(_pt__default["default"].element).isRequired
|
|
189
175
|
} : {};
|
|
@@ -197,7 +183,6 @@ const Option = props => jsxRuntime.jsx(AccessibleButton__default["default"], {
|
|
|
197
183
|
css: [/*#__PURE__*/react$1.css("display:block;text-align:left;width:100%;padding:", designSystem.designTokens.spacing20, ";background-color:", designSystem.designTokens.colorSurface, ";&:first-of-type{border-radius:", designSystem.designTokens.borderRadius6, " ", designSystem.designTokens.borderRadius6, " 0 0;}&:last-of-type{border-radius:0 0 ", designSystem.designTokens.borderRadius6, " ", designSystem.designTokens.borderRadius6, ";}&:hover{background-color:", designSystem.designTokens.colorNeutral95, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:Option;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm9wdGlvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJTIiwiZmlsZSI6Im9wdGlvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgQWNjZXNzaWJsZUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9hY2Nlc3NpYmxlLWJ1dHRvbic7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxudHlwZSBUT3B0aW9uID0ge1xuICAvKipcbiAgICogRXZlbnQgaGFuZGxlciB0cmlnZ2VycyB3aGVuZXZlciB0aGUgb3B0aW9uIGlzIGNsaWNrZWQuXG4gICAqL1xuICBvbkNsaWNrOiAoKSA9PiB2b2lkO1xuICAvKipcbiAgICogRGlzYWJsZXMgdGhlIG9wdGlvbiB3aXRoaW4gdGhlIGRyb3Bkb3duLiBJZiBhbGwgb3B0aW9ucyBhcmUgZGlzYWJsZWQgdGhlIGRyb3Bkb3duIHdpbGwgYmUgZGlzYWJsZWQuXG4gICAqL1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEFueSBzdHJpbmcgd2hpY2ggc2VydmVzIGFzIHRoZSBsYWJlbC5cbiAgICovXG4gIGNoaWxkcmVuOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBBbnkgUmVhY3Qgbm9kZS5cbiAgICovXG4gIGljb25MZWZ0OiBSZWFjdE5vZGU7XG59O1xuXG5jb25zdCBPcHRpb24gPSAocHJvcHM6IFRPcHRpb24pID0+IChcbiAgPEFjY2Vzc2libGVCdXR0b25cbiAgICBsYWJlbD17cHJvcHMuY2hpbGRyZW59XG4gICAgb25DbGljaz17cHJvcHMub25DbGlja31cbiAgICBpc0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgIGNzcz17W1xuICAgICAgY3NzYFxuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgdGV4dC1hbGlnbjogbGVmdDtcbiAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyMH07XG4gICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gICAgICAgICY6Zmlyc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzNn1cbiAgICAgICAgICAgICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9IDAgMDtcbiAgICAgICAgfVxuICAgICAgICAmOmxhc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogMCAwICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9XG4gICAgICAgICAgICAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM2fTtcbiAgICAgICAgfVxuICAgICAgICAmOmhvdmVyIHtcbiAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX07XG4gICAgICAgIH1cbiAgICAgIGAsXG4gICAgICBwcm9wcy5pc0Rpc2FibGVkICYmXG4gICAgICAgIGNzc2BcbiAgICAgICAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsfTtcbiAgICAgICAgYCxcbiAgICBdfVxuICA+XG4gICAge3Byb3BzLmNoaWxkcmVufVxuICA8L0FjY2Vzc2libGVCdXR0b24+XG4pO1xuT3B0aW9uLmRpc3BsYXlOYW1lID0gJ09wdGlvbic7XG5PcHRpb24uZGVmYXVsdFByb3BzID0ge1xuICBpc0Rpc2FibGVkOiBmYWxzZSxcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE9wdGlvbjtcbiJdfQ== */"), props.isDisabled && /*#__PURE__*/react$1.css("color:", designSystem.designTokens.colorNeutral, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:Option;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm9wdGlvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaURXIiwiZmlsZSI6Im9wdGlvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgQWNjZXNzaWJsZUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9hY2Nlc3NpYmxlLWJ1dHRvbic7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxudHlwZSBUT3B0aW9uID0ge1xuICAvKipcbiAgICogRXZlbnQgaGFuZGxlciB0cmlnZ2VycyB3aGVuZXZlciB0aGUgb3B0aW9uIGlzIGNsaWNrZWQuXG4gICAqL1xuICBvbkNsaWNrOiAoKSA9PiB2b2lkO1xuICAvKipcbiAgICogRGlzYWJsZXMgdGhlIG9wdGlvbiB3aXRoaW4gdGhlIGRyb3Bkb3duLiBJZiBhbGwgb3B0aW9ucyBhcmUgZGlzYWJsZWQgdGhlIGRyb3Bkb3duIHdpbGwgYmUgZGlzYWJsZWQuXG4gICAqL1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEFueSBzdHJpbmcgd2hpY2ggc2VydmVzIGFzIHRoZSBsYWJlbC5cbiAgICovXG4gIGNoaWxkcmVuOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBBbnkgUmVhY3Qgbm9kZS5cbiAgICovXG4gIGljb25MZWZ0OiBSZWFjdE5vZGU7XG59O1xuXG5jb25zdCBPcHRpb24gPSAocHJvcHM6IFRPcHRpb24pID0+IChcbiAgPEFjY2Vzc2libGVCdXR0b25cbiAgICBsYWJlbD17cHJvcHMuY2hpbGRyZW59XG4gICAgb25DbGljaz17cHJvcHMub25DbGlja31cbiAgICBpc0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgIGNzcz17W1xuICAgICAgY3NzYFxuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgdGV4dC1hbGlnbjogbGVmdDtcbiAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyMH07XG4gICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gICAgICAgICY6Zmlyc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzNn1cbiAgICAgICAgICAgICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9IDAgMDtcbiAgICAgICAgfVxuICAgICAgICAmOmxhc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogMCAwICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9XG4gICAgICAgICAgICAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM2fTtcbiAgICAgICAgfVxuICAgICAgICAmOmhvdmVyIHtcbiAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX07XG4gICAgICAgIH1cbiAgICAgIGAsXG4gICAgICBwcm9wcy5pc0Rpc2FibGVkICYmXG4gICAgICAgIGNzc2BcbiAgICAgICAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsfTtcbiAgICAgICAgYCxcbiAgICBdfVxuICA+XG4gICAge3Byb3BzLmNoaWxkcmVufVxuICA8L0FjY2Vzc2libGVCdXR0b24+XG4pO1xuT3B0aW9uLmRpc3BsYXlOYW1lID0gJ09wdGlvbic7XG5PcHRpb24uZGVmYXVsdFByb3BzID0ge1xuICBpc0Rpc2FibGVkOiBmYWxzZSxcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE9wdGlvbjtcbiJdfQ== */"), process.env.NODE_ENV === "production" ? "" : ";label:Option;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm9wdGlvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkJJIiwiZmlsZSI6Im9wdGlvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgQWNjZXNzaWJsZUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9hY2Nlc3NpYmxlLWJ1dHRvbic7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxudHlwZSBUT3B0aW9uID0ge1xuICAvKipcbiAgICogRXZlbnQgaGFuZGxlciB0cmlnZ2VycyB3aGVuZXZlciB0aGUgb3B0aW9uIGlzIGNsaWNrZWQuXG4gICAqL1xuICBvbkNsaWNrOiAoKSA9PiB2b2lkO1xuICAvKipcbiAgICogRGlzYWJsZXMgdGhlIG9wdGlvbiB3aXRoaW4gdGhlIGRyb3Bkb3duLiBJZiBhbGwgb3B0aW9ucyBhcmUgZGlzYWJsZWQgdGhlIGRyb3Bkb3duIHdpbGwgYmUgZGlzYWJsZWQuXG4gICAqL1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEFueSBzdHJpbmcgd2hpY2ggc2VydmVzIGFzIHRoZSBsYWJlbC5cbiAgICovXG4gIGNoaWxkcmVuOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBBbnkgUmVhY3Qgbm9kZS5cbiAgICovXG4gIGljb25MZWZ0OiBSZWFjdE5vZGU7XG59O1xuXG5jb25zdCBPcHRpb24gPSAocHJvcHM6IFRPcHRpb24pID0+IChcbiAgPEFjY2Vzc2libGVCdXR0b25cbiAgICBsYWJlbD17cHJvcHMuY2hpbGRyZW59XG4gICAgb25DbGljaz17cHJvcHMub25DbGlja31cbiAgICBpc0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgIGNzcz17W1xuICAgICAgY3NzYFxuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgdGV4dC1hbGlnbjogbGVmdDtcbiAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyMH07XG4gICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gICAgICAgICY6Zmlyc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzNn1cbiAgICAgICAgICAgICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9IDAgMDtcbiAgICAgICAgfVxuICAgICAgICAmOmxhc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogMCAwICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9XG4gICAgICAgICAgICAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM2fTtcbiAgICAgICAgfVxuICAgICAgICAmOmhvdmVyIHtcbiAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX07XG4gICAgICAgIH1cbiAgICAgIGAsXG4gICAgICBwcm9wcy5pc0Rpc2FibGVkICYmXG4gICAgICAgIGNzc2BcbiAgICAgICAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsfTtcbiAgICAgICAgYCxcbiAgICBdfVxuICA+XG4gICAge3Byb3BzLmNoaWxkcmVufVxuICA8L0FjY2Vzc2libGVCdXR0b24+XG4pO1xuT3B0aW9uLmRpc3BsYXlOYW1lID0gJ09wdGlvbic7XG5PcHRpb24uZGVmYXVsdFByb3BzID0ge1xuICBpc0Rpc2FibGVkOiBmYWxzZSxcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE9wdGlvbjtcbiJdfQ== */"],
|
|
198
184
|
children: props.children
|
|
199
185
|
});
|
|
200
|
-
|
|
201
186
|
Option.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
202
187
|
onClick: _pt__default["default"].func.isRequired,
|
|
203
188
|
isDisabled: _pt__default["default"].bool,
|
|
@@ -211,7 +196,7 @@ Option.defaultProps = {
|
|
|
211
196
|
var Option$1 = Option;
|
|
212
197
|
|
|
213
198
|
// NOTE: This string will be replaced on build time with the package version.
|
|
214
|
-
var version = "16.
|
|
199
|
+
var version = "16.1.0";
|
|
215
200
|
|
|
216
201
|
exports.Option = Option$1;
|
|
217
202
|
exports["default"] = PrimaryActionDropdown$1;
|
|
@@ -25,19 +25,15 @@ var Text__default = /*#__PURE__*/_interopDefault(Text);
|
|
|
25
25
|
|
|
26
26
|
const getButtonStyles = (isDisabled, isNewTheme) => {
|
|
27
27
|
const baseButtonStyles = /*#__PURE__*/react$1.css("display:flex;align-items:center;height:", designSystem.designTokens.bigButtonHeight, ";" + ("" ), "" );
|
|
28
|
-
|
|
29
28
|
if (isDisabled) {
|
|
30
29
|
return [baseButtonStyles, /*#__PURE__*/react$1.css("box-shadow:none;background-color:", designSystem.designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled, ";border:", isNewTheme && "1px solid ".concat(designSystem.designTokens.colorNeutral), ";" + ("" ), "" )];
|
|
31
30
|
}
|
|
32
|
-
|
|
33
31
|
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, ";}" + ("" ), "" )];
|
|
34
32
|
};
|
|
35
|
-
|
|
36
33
|
var _ref2 = {
|
|
37
34
|
name: "s5xdrg",
|
|
38
35
|
styles: "display:flex;align-items:center"
|
|
39
36
|
} ;
|
|
40
|
-
|
|
41
37
|
const DropdownHead = props => jsxRuntime.jsxs("div", {
|
|
42
38
|
css: _ref2,
|
|
43
39
|
children: [jsxRuntime.jsxs(AccessibleButton__default["default"], {
|
|
@@ -60,15 +56,12 @@ const DropdownHead = props => jsxRuntime.jsxs("div", {
|
|
|
60
56
|
})]
|
|
61
57
|
}), props.chevron]
|
|
62
58
|
});
|
|
63
|
-
|
|
64
59
|
DropdownHead.propTypes = {};
|
|
65
60
|
DropdownHead.displayName = 'DropdownHead';
|
|
66
|
-
|
|
67
61
|
var _ref = {
|
|
68
62
|
name: "1jklb6q",
|
|
69
63
|
styles: "pointer-events:none;margin-top:3px"
|
|
70
64
|
} ;
|
|
71
|
-
|
|
72
65
|
const DropdownChevron = /*#__PURE__*/react.forwardRef((props, ref) => jsxRuntime.jsx(AccessibleButton__default["default"], {
|
|
73
66
|
ref: ref,
|
|
74
67
|
label: "Open Dropdown",
|
|
@@ -85,10 +78,10 @@ const DropdownChevron = /*#__PURE__*/react.forwardRef((props, ref) => jsxRuntime
|
|
|
85
78
|
})
|
|
86
79
|
}));
|
|
87
80
|
DropdownChevron.displayName = 'DropdownChevron';
|
|
88
|
-
|
|
89
81
|
const Options = /*#__PURE__*/_styled__default["default"]("div", {
|
|
90
82
|
target: "eb24b7r0"
|
|
91
83
|
} )("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, ";}}" + ("" ));
|
|
84
|
+
|
|
92
85
|
/*
|
|
93
86
|
This component registers a global click event listener to close the dropdown.
|
|
94
87
|
It uses this global listener to close when:
|
|
@@ -100,21 +93,16 @@ const Options = /*#__PURE__*/_styled__default["default"]("div", {
|
|
|
100
93
|
immediately.
|
|
101
94
|
*/
|
|
102
95
|
|
|
103
|
-
|
|
104
96
|
const PrimaryActionDropdown = props => {
|
|
105
97
|
const ref = react.useRef();
|
|
106
|
-
|
|
107
98
|
const _useToggleState = hooks.useToggleState(false),
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
99
|
+
_useToggleState2 = _slicedToArray(_useToggleState, 2),
|
|
100
|
+
isOpen = _useToggleState2[0],
|
|
101
|
+
toggle = _useToggleState2[1];
|
|
112
102
|
const _useTheme = designSystem.useTheme(),
|
|
113
|
-
|
|
114
|
-
|
|
103
|
+
isNewTheme = _useTheme.isNewTheme;
|
|
115
104
|
const handleGlobalClick = react.useCallback(event => {
|
|
116
105
|
const dropdownButton = ref.current;
|
|
117
|
-
|
|
118
106
|
if (dropdownButton && event.target !== dropdownButton && !dropdownButton.contains(event.target)) {
|
|
119
107
|
toggle(false);
|
|
120
108
|
}
|
|
@@ -159,7 +147,6 @@ const PrimaryActionDropdown = props => {
|
|
|
159
147
|
})]
|
|
160
148
|
});
|
|
161
149
|
};
|
|
162
|
-
|
|
163
150
|
PrimaryActionDropdown.propTypes = {};
|
|
164
151
|
PrimaryActionDropdown.displayName = 'PrimaryActionDropdown';
|
|
165
152
|
var PrimaryActionDropdown$1 = PrimaryActionDropdown;
|
|
@@ -171,7 +158,6 @@ const Option = props => jsxRuntime.jsx(AccessibleButton__default["default"], {
|
|
|
171
158
|
css: [/*#__PURE__*/react$1.css("display:block;text-align:left;width:100%;padding:", designSystem.designTokens.spacing20, ";background-color:", designSystem.designTokens.colorSurface, ";&:first-of-type{border-radius:", designSystem.designTokens.borderRadius6, " ", designSystem.designTokens.borderRadius6, " 0 0;}&:last-of-type{border-radius:0 0 ", designSystem.designTokens.borderRadius6, " ", designSystem.designTokens.borderRadius6, ";}&:hover{background-color:", designSystem.designTokens.colorNeutral95, ";}" + ("" ), "" ), props.isDisabled && /*#__PURE__*/react$1.css("color:", designSystem.designTokens.colorNeutral, ";" + ("" ), "" ), "" , "" ],
|
|
172
159
|
children: props.children
|
|
173
160
|
});
|
|
174
|
-
|
|
175
161
|
Option.propTypes = {};
|
|
176
162
|
Option.displayName = 'Option';
|
|
177
163
|
Option.defaultProps = {
|
|
@@ -180,7 +166,7 @@ Option.defaultProps = {
|
|
|
180
166
|
var Option$1 = Option;
|
|
181
167
|
|
|
182
168
|
// NOTE: This string will be replaced on build time with the package version.
|
|
183
|
-
var version = "16.
|
|
169
|
+
var version = "16.1.0";
|
|
184
170
|
|
|
185
171
|
exports.Option = Option$1;
|
|
186
172
|
exports["default"] = PrimaryActionDropdown$1;
|
|
@@ -13,17 +13,13 @@ import { useToggleState } from '@commercetools-uikit/hooks';
|
|
|
13
13
|
import { jsxs, jsx } from '@emotion/react/jsx-runtime';
|
|
14
14
|
|
|
15
15
|
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)."; }
|
|
16
|
-
|
|
17
16
|
const getButtonStyles = (isDisabled, isNewTheme) => {
|
|
18
17
|
const baseButtonStyles = /*#__PURE__*/css("display:flex;align-items:center;height:", 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"]} */");
|
|
19
|
-
|
|
20
18
|
if (isDisabled) {
|
|
21
19
|
return [baseButtonStyles, /*#__PURE__*/css("box-shadow:none;background-color:", designTokens.backgroundColorForPrimaryActionDropdownWhenDisabled, ";border:", isNewTheme && "1px solid ".concat(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"]} */")];
|
|
22
20
|
}
|
|
23
|
-
|
|
24
21
|
return [baseButtonStyles, /*#__PURE__*/css("background-color:", designTokens.colorSurface, ";box-shadow:", designTokens.shadowForPrimaryActionDropdown, ";border:", isNewTheme && "1px solid ".concat(designTokens.colorNeutral), ";&:hover{box-shadow:", designTokens.shadowForPrimaryActionDropdownWhenHovered, ";background-color:", isNewTheme && designTokens.colorNeutral95, ";}&:active{box-shadow:", designTokens.shadowForPrimaryActionDropdownWhenActive, ";background-color:", 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"]} */")];
|
|
25
22
|
};
|
|
26
|
-
|
|
27
23
|
var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
28
24
|
name: "s5xdrg",
|
|
29
25
|
styles: "display:flex;align-items:center"
|
|
@@ -33,7 +29,6 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
|
33
29
|
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"]} */",
|
|
34
30
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
35
31
|
};
|
|
36
|
-
|
|
37
32
|
const DropdownHead = props => jsxs("div", {
|
|
38
33
|
css: _ref2,
|
|
39
34
|
children: [jsxs(AccessibleButton, {
|
|
@@ -56,7 +51,6 @@ const DropdownHead = props => jsxs("div", {
|
|
|
56
51
|
})]
|
|
57
52
|
}), props.chevron]
|
|
58
53
|
});
|
|
59
|
-
|
|
60
54
|
DropdownHead.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
61
55
|
iconLeft: _pt.element.isRequired,
|
|
62
56
|
onClick: _pt.func,
|
|
@@ -66,7 +60,6 @@ DropdownHead.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
66
60
|
isNewTheme: _pt.bool.isRequired
|
|
67
61
|
} : {};
|
|
68
62
|
DropdownHead.displayName = 'DropdownHead';
|
|
69
|
-
|
|
70
63
|
var _ref = process.env.NODE_ENV === "production" ? {
|
|
71
64
|
name: "1jklb6q",
|
|
72
65
|
styles: "pointer-events:none;margin-top:3px"
|
|
@@ -76,7 +69,6 @@ var _ref = process.env.NODE_ENV === "production" ? {
|
|
|
76
69
|
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"]} */",
|
|
77
70
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
78
71
|
};
|
|
79
|
-
|
|
80
72
|
const DropdownChevron = /*#__PURE__*/forwardRef((props, ref) => jsx(AccessibleButton, {
|
|
81
73
|
ref: ref,
|
|
82
74
|
label: "Open Dropdown",
|
|
@@ -93,13 +85,13 @@ const DropdownChevron = /*#__PURE__*/forwardRef((props, ref) => jsx(AccessibleBu
|
|
|
93
85
|
})
|
|
94
86
|
}));
|
|
95
87
|
DropdownChevron.displayName = 'DropdownChevron';
|
|
96
|
-
|
|
97
88
|
const Options = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
98
89
|
target: "eb24b7r0"
|
|
99
90
|
} : {
|
|
100
91
|
target: "eb24b7r0",
|
|
101
92
|
label: "Options"
|
|
102
93
|
})("position:absolute;z-index:5;width:100%;top:calc(", designTokens.spacing20, " + ", designTokens.bigButtonHeight, ");border:1px solid ", designTokens.borderColorForPrimaryActionDropdownMenu, ";border-radius:", designTokens.borderRadiusForPrimaryActionDropdownMenu, ";box-shadow:", designTokens.shadowForPrimaryActionDropdownMenu, ";margin-top:", designTokens.marginTopForPrimaryActionDropdown, ";>button{padding-left:", props => props.isNewTheme && designTokens.spacing30, ";white-space:normal;&:active{background-color:", props => props.isNewTheme && 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"]} */"));
|
|
94
|
+
|
|
103
95
|
/*
|
|
104
96
|
This component registers a global click event listener to close the dropdown.
|
|
105
97
|
It uses this global listener to close when:
|
|
@@ -111,21 +103,16 @@ const Options = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production
|
|
|
111
103
|
immediately.
|
|
112
104
|
*/
|
|
113
105
|
|
|
114
|
-
|
|
115
106
|
const PrimaryActionDropdown = props => {
|
|
116
107
|
const ref = useRef();
|
|
117
|
-
|
|
118
108
|
const _useToggleState = useToggleState(false),
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
109
|
+
_useToggleState2 = _slicedToArray(_useToggleState, 2),
|
|
110
|
+
isOpen = _useToggleState2[0],
|
|
111
|
+
toggle = _useToggleState2[1];
|
|
123
112
|
const _useTheme = useTheme(),
|
|
124
|
-
|
|
125
|
-
|
|
113
|
+
isNewTheme = _useTheme.isNewTheme;
|
|
126
114
|
const handleGlobalClick = useCallback(event => {
|
|
127
115
|
const dropdownButton = ref.current;
|
|
128
|
-
|
|
129
116
|
if (dropdownButton && event.target !== dropdownButton && !dropdownButton.contains(event.target)) {
|
|
130
117
|
toggle(false);
|
|
131
118
|
}
|
|
@@ -171,7 +158,6 @@ const PrimaryActionDropdown = props => {
|
|
|
171
158
|
})]
|
|
172
159
|
});
|
|
173
160
|
};
|
|
174
|
-
|
|
175
161
|
PrimaryActionDropdown.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
176
162
|
children: _pt.arrayOf(_pt.element).isRequired
|
|
177
163
|
} : {};
|
|
@@ -185,7 +171,6 @@ const Option = props => jsx(AccessibleButton, {
|
|
|
185
171
|
css: [/*#__PURE__*/css("display:block;text-align:left;width:100%;padding:", designTokens.spacing20, ";background-color:", designTokens.colorSurface, ";&:first-of-type{border-radius:", designTokens.borderRadius6, " ", designTokens.borderRadius6, " 0 0;}&:last-of-type{border-radius:0 0 ", designTokens.borderRadius6, " ", designTokens.borderRadius6, ";}&:hover{background-color:", designTokens.colorNeutral95, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:Option;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm9wdGlvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJTIiwiZmlsZSI6Im9wdGlvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgQWNjZXNzaWJsZUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9hY2Nlc3NpYmxlLWJ1dHRvbic7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxudHlwZSBUT3B0aW9uID0ge1xuICAvKipcbiAgICogRXZlbnQgaGFuZGxlciB0cmlnZ2VycyB3aGVuZXZlciB0aGUgb3B0aW9uIGlzIGNsaWNrZWQuXG4gICAqL1xuICBvbkNsaWNrOiAoKSA9PiB2b2lkO1xuICAvKipcbiAgICogRGlzYWJsZXMgdGhlIG9wdGlvbiB3aXRoaW4gdGhlIGRyb3Bkb3duLiBJZiBhbGwgb3B0aW9ucyBhcmUgZGlzYWJsZWQgdGhlIGRyb3Bkb3duIHdpbGwgYmUgZGlzYWJsZWQuXG4gICAqL1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEFueSBzdHJpbmcgd2hpY2ggc2VydmVzIGFzIHRoZSBsYWJlbC5cbiAgICovXG4gIGNoaWxkcmVuOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBBbnkgUmVhY3Qgbm9kZS5cbiAgICovXG4gIGljb25MZWZ0OiBSZWFjdE5vZGU7XG59O1xuXG5jb25zdCBPcHRpb24gPSAocHJvcHM6IFRPcHRpb24pID0+IChcbiAgPEFjY2Vzc2libGVCdXR0b25cbiAgICBsYWJlbD17cHJvcHMuY2hpbGRyZW59XG4gICAgb25DbGljaz17cHJvcHMub25DbGlja31cbiAgICBpc0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgIGNzcz17W1xuICAgICAgY3NzYFxuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgdGV4dC1hbGlnbjogbGVmdDtcbiAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyMH07XG4gICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gICAgICAgICY6Zmlyc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzNn1cbiAgICAgICAgICAgICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9IDAgMDtcbiAgICAgICAgfVxuICAgICAgICAmOmxhc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogMCAwICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9XG4gICAgICAgICAgICAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM2fTtcbiAgICAgICAgfVxuICAgICAgICAmOmhvdmVyIHtcbiAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX07XG4gICAgICAgIH1cbiAgICAgIGAsXG4gICAgICBwcm9wcy5pc0Rpc2FibGVkICYmXG4gICAgICAgIGNzc2BcbiAgICAgICAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsfTtcbiAgICAgICAgYCxcbiAgICBdfVxuICA+XG4gICAge3Byb3BzLmNoaWxkcmVufVxuICA8L0FjY2Vzc2libGVCdXR0b24+XG4pO1xuT3B0aW9uLmRpc3BsYXlOYW1lID0gJ09wdGlvbic7XG5PcHRpb24uZGVmYXVsdFByb3BzID0ge1xuICBpc0Rpc2FibGVkOiBmYWxzZSxcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE9wdGlvbjtcbiJdfQ== */"), props.isDisabled && /*#__PURE__*/css("color:", designTokens.colorNeutral, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:Option;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm9wdGlvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaURXIiwiZmlsZSI6Im9wdGlvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgQWNjZXNzaWJsZUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9hY2Nlc3NpYmxlLWJ1dHRvbic7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxudHlwZSBUT3B0aW9uID0ge1xuICAvKipcbiAgICogRXZlbnQgaGFuZGxlciB0cmlnZ2VycyB3aGVuZXZlciB0aGUgb3B0aW9uIGlzIGNsaWNrZWQuXG4gICAqL1xuICBvbkNsaWNrOiAoKSA9PiB2b2lkO1xuICAvKipcbiAgICogRGlzYWJsZXMgdGhlIG9wdGlvbiB3aXRoaW4gdGhlIGRyb3Bkb3duLiBJZiBhbGwgb3B0aW9ucyBhcmUgZGlzYWJsZWQgdGhlIGRyb3Bkb3duIHdpbGwgYmUgZGlzYWJsZWQuXG4gICAqL1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEFueSBzdHJpbmcgd2hpY2ggc2VydmVzIGFzIHRoZSBsYWJlbC5cbiAgICovXG4gIGNoaWxkcmVuOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBBbnkgUmVhY3Qgbm9kZS5cbiAgICovXG4gIGljb25MZWZ0OiBSZWFjdE5vZGU7XG59O1xuXG5jb25zdCBPcHRpb24gPSAocHJvcHM6IFRPcHRpb24pID0+IChcbiAgPEFjY2Vzc2libGVCdXR0b25cbiAgICBsYWJlbD17cHJvcHMuY2hpbGRyZW59XG4gICAgb25DbGljaz17cHJvcHMub25DbGlja31cbiAgICBpc0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgIGNzcz17W1xuICAgICAgY3NzYFxuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgdGV4dC1hbGlnbjogbGVmdDtcbiAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyMH07XG4gICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gICAgICAgICY6Zmlyc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzNn1cbiAgICAgICAgICAgICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9IDAgMDtcbiAgICAgICAgfVxuICAgICAgICAmOmxhc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogMCAwICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9XG4gICAgICAgICAgICAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM2fTtcbiAgICAgICAgfVxuICAgICAgICAmOmhvdmVyIHtcbiAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX07XG4gICAgICAgIH1cbiAgICAgIGAsXG4gICAgICBwcm9wcy5pc0Rpc2FibGVkICYmXG4gICAgICAgIGNzc2BcbiAgICAgICAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsfTtcbiAgICAgICAgYCxcbiAgICBdfVxuICA+XG4gICAge3Byb3BzLmNoaWxkcmVufVxuICA8L0FjY2Vzc2libGVCdXR0b24+XG4pO1xuT3B0aW9uLmRpc3BsYXlOYW1lID0gJ09wdGlvbic7XG5PcHRpb24uZGVmYXVsdFByb3BzID0ge1xuICBpc0Rpc2FibGVkOiBmYWxzZSxcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE9wdGlvbjtcbiJdfQ== */"), process.env.NODE_ENV === "production" ? "" : ";label:Option;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm9wdGlvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkJJIiwiZmlsZSI6Im9wdGlvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgQWNjZXNzaWJsZUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9hY2Nlc3NpYmxlLWJ1dHRvbic7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxudHlwZSBUT3B0aW9uID0ge1xuICAvKipcbiAgICogRXZlbnQgaGFuZGxlciB0cmlnZ2VycyB3aGVuZXZlciB0aGUgb3B0aW9uIGlzIGNsaWNrZWQuXG4gICAqL1xuICBvbkNsaWNrOiAoKSA9PiB2b2lkO1xuICAvKipcbiAgICogRGlzYWJsZXMgdGhlIG9wdGlvbiB3aXRoaW4gdGhlIGRyb3Bkb3duLiBJZiBhbGwgb3B0aW9ucyBhcmUgZGlzYWJsZWQgdGhlIGRyb3Bkb3duIHdpbGwgYmUgZGlzYWJsZWQuXG4gICAqL1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEFueSBzdHJpbmcgd2hpY2ggc2VydmVzIGFzIHRoZSBsYWJlbC5cbiAgICovXG4gIGNoaWxkcmVuOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBBbnkgUmVhY3Qgbm9kZS5cbiAgICovXG4gIGljb25MZWZ0OiBSZWFjdE5vZGU7XG59O1xuXG5jb25zdCBPcHRpb24gPSAocHJvcHM6IFRPcHRpb24pID0+IChcbiAgPEFjY2Vzc2libGVCdXR0b25cbiAgICBsYWJlbD17cHJvcHMuY2hpbGRyZW59XG4gICAgb25DbGljaz17cHJvcHMub25DbGlja31cbiAgICBpc0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgIGNzcz17W1xuICAgICAgY3NzYFxuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgdGV4dC1hbGlnbjogbGVmdDtcbiAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyMH07XG4gICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gICAgICAgICY6Zmlyc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzNn1cbiAgICAgICAgICAgICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9IDAgMDtcbiAgICAgICAgfVxuICAgICAgICAmOmxhc3Qtb2YtdHlwZSB7XG4gICAgICAgICAgYm9yZGVyLXJhZGl1czogMCAwICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9XG4gICAgICAgICAgICAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM2fTtcbiAgICAgICAgfVxuICAgICAgICAmOmhvdmVyIHtcbiAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX07XG4gICAgICAgIH1cbiAgICAgIGAsXG4gICAgICBwcm9wcy5pc0Rpc2FibGVkICYmXG4gICAgICAgIGNzc2BcbiAgICAgICAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsfTtcbiAgICAgICAgYCxcbiAgICBdfVxuICA+XG4gICAge3Byb3BzLmNoaWxkcmVufVxuICA8L0FjY2Vzc2libGVCdXR0b24+XG4pO1xuT3B0aW9uLmRpc3BsYXlOYW1lID0gJ09wdGlvbic7XG5PcHRpb24uZGVmYXVsdFByb3BzID0ge1xuICBpc0Rpc2FibGVkOiBmYWxzZSxcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE9wdGlvbjtcbiJdfQ== */"],
|
|
186
172
|
children: props.children
|
|
187
173
|
});
|
|
188
|
-
|
|
189
174
|
Option.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
190
175
|
onClick: _pt.func.isRequired,
|
|
191
176
|
isDisabled: _pt.bool,
|
|
@@ -199,6 +184,6 @@ Option.defaultProps = {
|
|
|
199
184
|
var Option$1 = Option;
|
|
200
185
|
|
|
201
186
|
// NOTE: This string will be replaced on build time with the package version.
|
|
202
|
-
var version = "16.
|
|
187
|
+
var version = "16.1.0";
|
|
203
188
|
|
|
204
189
|
export { Option$1 as Option, PrimaryActionDropdown$1 as default, version };
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@commercetools-uikit/primary-action-dropdown",
|
|
3
3
|
"description": "A dropdown component with any number of action, where the first action of the dropdown can be triggered without opening the dropdown itself.",
|
|
4
|
-
"version": "16.
|
|
4
|
+
"version": "16.1.0",
|
|
5
5
|
"bugs": "https://github.com/commercetools/ui-kit/issues",
|
|
6
6
|
"repository": {
|
|
7
7
|
"type": "git",
|
|
@@ -21,13 +21,13 @@
|
|
|
21
21
|
"dependencies": {
|
|
22
22
|
"@babel/runtime": "^7.20.13",
|
|
23
23
|
"@babel/runtime-corejs3": "^7.20.13",
|
|
24
|
-
"@commercetools-uikit/accessible-button": "16.
|
|
25
|
-
"@commercetools-uikit/buttons": "16.
|
|
26
|
-
"@commercetools-uikit/design-system": "16.
|
|
27
|
-
"@commercetools-uikit/hooks": "16.
|
|
28
|
-
"@commercetools-uikit/icons": "16.
|
|
29
|
-
"@commercetools-uikit/text": "16.
|
|
30
|
-
"@commercetools-uikit/utils": "16.
|
|
24
|
+
"@commercetools-uikit/accessible-button": "16.1.0",
|
|
25
|
+
"@commercetools-uikit/buttons": "16.1.0",
|
|
26
|
+
"@commercetools-uikit/design-system": "16.1.0",
|
|
27
|
+
"@commercetools-uikit/hooks": "16.1.0",
|
|
28
|
+
"@commercetools-uikit/icons": "16.1.0",
|
|
29
|
+
"@commercetools-uikit/text": "16.1.0",
|
|
30
|
+
"@commercetools-uikit/utils": "16.1.0",
|
|
31
31
|
"@emotion/react": "^11.10.5",
|
|
32
32
|
"@emotion/styled": "^11.10.5",
|
|
33
33
|
"lodash": "4.17.21",
|