@commercetools-uikit/primary-action-dropdown 12.2.3 → 12.2.4
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.
|
@@ -54,11 +54,11 @@ var DropdownHead = function DropdownHead(props) {
|
|
|
54
54
|
|
|
55
55
|
return jsxRuntime.jsxs("div", {
|
|
56
56
|
css: _ref3,
|
|
57
|
-
children: [jsxRuntime.jsxs(AccessibleButton__default[
|
|
57
|
+
children: [jsxRuntime.jsxs(AccessibleButton__default["default"], {
|
|
58
58
|
label: props.children,
|
|
59
59
|
onClick: props.onClick,
|
|
60
60
|
isDisabled: props.isDisabled,
|
|
61
|
-
css: _concatInstanceProperty__default['default'](_context = []).call(_context, _toConsumableArray(getButtonStyles(props.isDisabled)), [/*#__PURE__*/react.css("padding:0 ", designSystem.customProperties.spacingS, ";border-radius:", designSystem.customProperties.borderRadius6, " 0 0 ", designSystem.customProperties.borderRadius6, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:DropdownHead;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AA8DW","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } 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) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\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 ${vars.spacingXs} 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';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\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 ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\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 */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\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    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AA4DM","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } 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) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\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 ${vars.spacingXs} 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';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\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 ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\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 */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\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    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"]),
|
|
61
|
+
css: _concatInstanceProperty__default["default"](_context = []).call(_context, _toConsumableArray(getButtonStyles(props.isDisabled)), [/*#__PURE__*/react.css("padding:0 ", designSystem.customProperties.spacingS, ";border-radius:", designSystem.customProperties.borderRadius6, " 0 0 ", designSystem.customProperties.borderRadius6, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:DropdownHead;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AA8DW","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } 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) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\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 ${vars.spacingXs} 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';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\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 ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\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 */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\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    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AA4DM","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } 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) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\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 ${vars.spacingXs} 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';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\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 ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\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 */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\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    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"]),
|
|
62
62
|
children: [jsxRuntime.jsx("span", {
|
|
63
63
|
css: /*#__PURE__*/react.css("margin:0 ", designSystem.customProperties.spacingXs, " 0 0;display:flex;align-items:center;justify-content:center;" + (process.env.NODE_ENV === "production" ? "" : ";label:DropdownHead;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AAqEgB","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } 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) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\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 ${vars.spacingXs} 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';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\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 ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\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 */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\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    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"),
|
|
64
64
|
children: /*#__PURE__*/react$1.cloneElement(props.iconLeft, {
|
|
@@ -67,7 +67,7 @@ var DropdownHead = function DropdownHead(props) {
|
|
|
67
67
|
})
|
|
68
68
|
}), jsxRuntime.jsx("span", {
|
|
69
69
|
css: /*#__PURE__*/react.css("margin:0 ", designSystem.customProperties.spacingXs, " 0 0;display:flex;align-items:center;justify-content:center;" + (process.env.NODE_ENV === "production" ? "" : ";label:DropdownHead;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AAkFgB","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } 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) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\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 ${vars.spacingXs} 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';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\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 ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\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 */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\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    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"),
|
|
70
|
-
children: jsxRuntime.jsx(Text__default[
|
|
70
|
+
children: jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
71
71
|
tone: props.isDisabled ? 'secondary' : undefined,
|
|
72
72
|
children: props.children
|
|
73
73
|
})
|
|
@@ -78,11 +78,11 @@ var DropdownHead = function DropdownHead(props) {
|
|
|
78
78
|
|
|
79
79
|
DropdownHead.displayName = 'DropdownHead';
|
|
80
80
|
DropdownHead.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
81
|
-
iconLeft: PropTypes__default[
|
|
82
|
-
onClick: PropTypes__default[
|
|
83
|
-
children: PropTypes__default[
|
|
84
|
-
isDisabled: PropTypes__default[
|
|
85
|
-
chevron: PropTypes__default[
|
|
81
|
+
iconLeft: PropTypes__default["default"].element.isRequired,
|
|
82
|
+
onClick: PropTypes__default["default"].func,
|
|
83
|
+
children: PropTypes__default["default"].node.isRequired,
|
|
84
|
+
isDisabled: PropTypes__default["default"].bool.isRequired,
|
|
85
|
+
chevron: PropTypes__default["default"].element.isRequired
|
|
86
86
|
} : {};
|
|
87
87
|
|
|
88
88
|
var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
@@ -98,13 +98,13 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
|
98
98
|
var DropdownChevron = /*#__PURE__*/react$1.forwardRef(function (props, ref) {
|
|
99
99
|
var _context2;
|
|
100
100
|
|
|
101
|
-
return jsxRuntime.jsx(AccessibleButton__default[
|
|
101
|
+
return jsxRuntime.jsx(AccessibleButton__default["default"], {
|
|
102
102
|
ref: ref,
|
|
103
103
|
label: "Open Dropdown",
|
|
104
104
|
onClick: props.onClick,
|
|
105
105
|
isDisabled: props.isDisabled,
|
|
106
106
|
isOpen: props.isOpen,
|
|
107
|
-
css: _concatInstanceProperty__default['default'](_context2 = []).call(_context2, _toConsumableArray(getButtonStyles(props.isDisabled)), [/*#__PURE__*/react.css("padding:0 ", designSystem.customProperties.spacingXs, ";border-left:1px solid ", designSystem.customProperties.colorNeutral, ";border-radius:0 ", designSystem.customProperties.borderRadius6, " ", designSystem.customProperties.borderRadius6, " 0;" + (process.env.NODE_ENV === "production" ? "" : ";label:DropdownChevron;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AAoHS","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } 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) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\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 ${vars.spacingXs} 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';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\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 ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\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 */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\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    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AAkHI","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } 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) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\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 ${vars.spacingXs} 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';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\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 ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\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 */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\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    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"]),
|
|
107
|
+
css: _concatInstanceProperty__default["default"](_context2 = []).call(_context2, _toConsumableArray(getButtonStyles(props.isDisabled)), [/*#__PURE__*/react.css("padding:0 ", designSystem.customProperties.spacingXs, ";border-left:1px solid ", designSystem.customProperties.colorNeutral, ";border-radius:0 ", designSystem.customProperties.borderRadius6, " ", designSystem.customProperties.borderRadius6, " 0;" + (process.env.NODE_ENV === "production" ? "" : ";label:DropdownChevron;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AAoHS","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } 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) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\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 ${vars.spacingXs} 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';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\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 ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\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 */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\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    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AAkHI","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } 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) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\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 ${vars.spacingXs} 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';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\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 ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\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 */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\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    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"]),
|
|
108
108
|
children: jsxRuntime.jsx("div", {
|
|
109
109
|
// The margin-top is to center the icon as the caret visually looks too high otherwise
|
|
110
110
|
css: _ref2,
|
|
@@ -117,12 +117,12 @@ var DropdownChevron = /*#__PURE__*/react$1.forwardRef(function (props, ref) {
|
|
|
117
117
|
});
|
|
118
118
|
DropdownChevron.displayName = 'DropdownChevron';
|
|
119
119
|
DropdownChevron.propTypes = {
|
|
120
|
-
onClick: PropTypes__default[
|
|
121
|
-
isDisabled: PropTypes__default[
|
|
122
|
-
isOpen: PropTypes__default[
|
|
120
|
+
onClick: PropTypes__default["default"].func.isRequired,
|
|
121
|
+
isDisabled: PropTypes__default["default"].bool.isRequired,
|
|
122
|
+
isOpen: PropTypes__default["default"].bool.isRequired
|
|
123
123
|
};
|
|
124
124
|
|
|
125
|
-
var Options = _styled__default[
|
|
125
|
+
var Options = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
126
126
|
target: "e102bf7i0"
|
|
127
127
|
} : {
|
|
128
128
|
target: "e102bf7i0",
|
|
@@ -130,7 +130,7 @@ var Options = _styled__default['default']("div", process.env.NODE_ENV === "produ
|
|
|
130
130
|
})("position:absolute;z-index:5;width:100%;top:calc(", designSystem.customProperties.spacingS, " + ", designSystem.customProperties.bigButtonHeight, ");left:0;border:1px solid ", designSystem.customProperties.colorNeutral, ";border-radius:", designSystem.customProperties.borderRadius6, ";box-shadow:", designSystem.customProperties.shadow1, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["primary-action-dropdown.js"],"names":[],"mappings":"AA2J0B","file":"primary-action-dropdown.js","sourcesContent":["import {\n  cloneElement,\n  forwardRef,\n  useRef,\n  useCallback,\n  useEffect,\n  Children,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport { customProperties as vars } 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) => {\n  const baseButtonStyles = css`\n    display: flex;\n    align-items: center;\n    height: ${vars.bigButtonHeight};\n  `;\n  if (isDisabled) {\n    return [\n      baseButtonStyles,\n      css`\n        box-shadow: none;\n        background-color: ${vars.colorAccent98};\n      `,\n    ];\n  }\n  return [\n    baseButtonStyles,\n    css`\n      background-color: ${vars.colorSurface};\n      box-shadow: ${vars.shadow7};\n      &:hover {\n        box-shadow: ${vars.shadow8};\n      }\n      &:active {\n        box-shadow: ${vars.shadow9};\n        background-color: ${vars.colorNeutral95};\n      }\n    `,\n  ];\n};\n\nconst DropdownHead = (props) => (\n  <div\n    css={css`\n      display: flex;\n      align-items: center;\n    `}\n  >\n    <AccessibleButton\n      label={props.children}\n      onClick={props.onClick}\n      isDisabled={props.isDisabled}\n      css={[\n        ...getButtonStyles(props.isDisabled),\n        css`\n          padding: 0 ${vars.spacingS};\n          border-radius: ${vars.borderRadius6} 0 0 ${vars.borderRadius6};\n        `,\n      ]}\n    >\n      <span\n        css={css`\n          margin: 0 ${vars.spacingXs} 0 0;\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 ${vars.spacingXs} 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';\nDropdownHead.propTypes = {\n  iconLeft: PropTypes.element.isRequired,\n  onClick: PropTypes.func,\n  children: PropTypes.node.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  chevron: PropTypes.element.isRequired,\n};\n\nconst DropdownChevron = forwardRef((props, ref) => (\n  <AccessibleButton\n    ref={ref}\n    label=\"Open Dropdown\"\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    isOpen={props.isOpen}\n    css={[\n      ...getButtonStyles(props.isDisabled),\n      css`\n        padding: 0 ${vars.spacingXs};\n        border-left: 1px solid ${vars.colorNeutral};\n        border-radius: 0 ${vars.borderRadius6} ${vars.borderRadius6} 0;\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 ? <CaretUpIcon /> : <CaretDownIcon />,\n        {\n          color: props.isDisabled ? 'neutral60' : 'solid',\n          size: 'small',\n        }\n      )}\n    </div>\n  </AccessibleButton>\n));\n\nDropdownChevron.displayName = 'DropdownChevron';\nDropdownChevron.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool.isRequired,\n  isOpen: PropTypes.bool.isRequired,\n};\n\nconst Options = styled.div`\n  position: absolute;\n  z-index: 5;\n  width: 100%;\n  top: calc(${vars.spacingS} + ${vars.bigButtonHeight});\n  left: 0;\n  border: 1px solid ${vars.colorNeutral};\n  border-radius: ${vars.borderRadius6};\n  box-shadow: ${vars.shadow1};\n`;\n\nexport const Option = (props) => (\n  <AccessibleButton\n    label={props.children}\n    onClick={props.onClick}\n    isDisabled={props.isDisabled}\n    css={[\n      css`\n        display: block;\n        text-align: left;\n        width: 100%;\n        padding: ${vars.spacingS};\n        background-color: ${vars.colorSurface};\n        &:first-of-type {\n          border-radius: ${vars.borderRadius6} ${vars.borderRadius6} 0 0;\n        }\n        &:last-of-type {\n          border-radius: 0 0 ${vars.borderRadius6} ${vars.borderRadius6};\n        }\n        &:hover {\n          background-color: ${vars.colorNeutral95};\n        }\n      `,\n      props.isDisabled &&\n        css`\n          color: ${vars.colorNeutral};\n        `,\n    ]}\n  >\n    {props.children}\n  </AccessibleButton>\n);\nOption.displayName = 'Option';\nOption.propTypes = {\n  onClick: PropTypes.func.isRequired,\n  isDisabled: PropTypes.bool,\n  children: PropTypes.string.isRequired,\n  // eslint-disable-next-line react/no-unused-prop-types\n  iconLeft: PropTypes.node.isRequired,\n};\nOption.defaultProps = {\n  isDisabled: false,\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 */\nconst PrimaryActionDropdown = (props) => {\n  const ref = useRef();\n  const [isOpen, toggle] = useToggleState(false);\n\n  const handleGlobalClick = useCallback(\n    (event) => {\n      const dropdownButton = ref.current;\n      if (\n        dropdownButton &&\n        event.target !== dropdownButton &&\n        !dropdownButton.contains(event.target)\n      ) {\n        toggle(false);\n      }\n    },\n    [ref, toggle]\n  );\n  useEffect(() => {\n    window.addEventListener('click', handleGlobalClick);\n    return () => {\n      window.removeEventListener('click', handleGlobalClick);\n    };\n  }, [handleGlobalClick]);\n\n  const childrenAsArray = Children.toArray(props.children);\n  const primaryOption =\n    childrenAsArray.find((option) => !option.props.isDisabled) ||\n    childrenAsArray[0];\n\n  const { onClick } = primaryOption.props;\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    >\n      <DropdownHead\n        iconLeft={primaryOption.props.iconLeft}\n        isDisabled={primaryOption.props.isDisabled}\n        onClick={handleClickOnHead}\n        chevron={\n          <DropdownChevron\n            ref={ref}\n            onClick={handleClickOnChevron}\n            isDisabled={primaryOption.props.isDisabled}\n            isOpen={isOpen}\n          />\n        }\n      >\n        {primaryOption.props.children}\n      </DropdownHead>\n      {isOpen && !primaryOption.props.isDisabled && (\n        <Options>{childrenAsArray}</Options>\n      )}\n    </div>\n  );\n};\n\nPrimaryActionDropdown.displayName = 'PrimaryActionDropdown';\n\nPrimaryActionDropdown.propTypes = {\n  children: PropTypes.node.isRequired,\n};\n\nexport default PrimaryActionDropdown;\n"]} */"));
|
|
131
131
|
|
|
132
132
|
var Option = function Option(props) {
|
|
133
|
-
return jsxRuntime.jsx(AccessibleButton__default[
|
|
133
|
+
return jsxRuntime.jsx(AccessibleButton__default["default"], {
|
|
134
134
|
label: props.children,
|
|
135
135
|
onClick: props.onClick,
|
|
136
136
|
isDisabled: props.isDisabled,
|
|
@@ -140,11 +140,11 @@ var Option = function Option(props) {
|
|
|
140
140
|
};
|
|
141
141
|
Option.displayName = 'Option';
|
|
142
142
|
Option.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
143
|
-
onClick: PropTypes__default[
|
|
144
|
-
isDisabled: PropTypes__default[
|
|
145
|
-
children: PropTypes__default[
|
|
143
|
+
onClick: PropTypes__default["default"].func.isRequired,
|
|
144
|
+
isDisabled: PropTypes__default["default"].bool,
|
|
145
|
+
children: PropTypes__default["default"].string.isRequired,
|
|
146
146
|
// eslint-disable-next-line react/no-unused-prop-types
|
|
147
|
-
iconLeft: PropTypes__default[
|
|
147
|
+
iconLeft: PropTypes__default["default"].node.isRequired
|
|
148
148
|
} : {};
|
|
149
149
|
Option.defaultProps = {
|
|
150
150
|
isDisabled: false
|
|
@@ -192,7 +192,7 @@ var PrimaryActionDropdown = function PrimaryActionDropdown(props) {
|
|
|
192
192
|
};
|
|
193
193
|
}, [handleGlobalClick]);
|
|
194
194
|
var childrenAsArray = react$1.Children.toArray(props.children);
|
|
195
|
-
var primaryOption = _findInstanceProperty__default[
|
|
195
|
+
var primaryOption = _findInstanceProperty__default["default"](childrenAsArray).call(childrenAsArray, function (option) {
|
|
196
196
|
return !option.props.isDisabled;
|
|
197
197
|
}) || childrenAsArray[0];
|
|
198
198
|
var onClick = primaryOption.props.onClick;
|
|
@@ -228,13 +228,13 @@ var PrimaryActionDropdown = function PrimaryActionDropdown(props) {
|
|
|
228
228
|
|
|
229
229
|
PrimaryActionDropdown.displayName = 'PrimaryActionDropdown';
|
|
230
230
|
PrimaryActionDropdown.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
231
|
-
children: PropTypes__default[
|
|
231
|
+
children: PropTypes__default["default"].node.isRequired
|
|
232
232
|
} : {};
|
|
233
233
|
var PrimaryActionDropdown$1 = PrimaryActionDropdown;
|
|
234
234
|
|
|
235
235
|
// NOTE: This string will be replaced in the `prepare` script by the `scripts/version.js` file.
|
|
236
|
-
var version = '12.2.
|
|
236
|
+
var version = '12.2.4';
|
|
237
237
|
|
|
238
238
|
exports.Option = Option;
|
|
239
|
-
exports[
|
|
239
|
+
exports["default"] = PrimaryActionDropdown$1;
|
|
240
240
|
exports.version = version;
|
|
@@ -47,11 +47,11 @@ var DropdownHead = function DropdownHead(props) {
|
|
|
47
47
|
|
|
48
48
|
return jsxRuntime.jsxs("div", {
|
|
49
49
|
css: _ref3,
|
|
50
|
-
children: [jsxRuntime.jsxs(AccessibleButton__default[
|
|
50
|
+
children: [jsxRuntime.jsxs(AccessibleButton__default["default"], {
|
|
51
51
|
label: props.children,
|
|
52
52
|
onClick: props.onClick,
|
|
53
53
|
isDisabled: props.isDisabled,
|
|
54
|
-
css: _concatInstanceProperty__default[
|
|
54
|
+
css: _concatInstanceProperty__default["default"](_context = []).call(_context, _toConsumableArray(getButtonStyles(props.isDisabled)), [/*#__PURE__*/react.css("padding:0 ", designSystem.customProperties.spacingS, ";border-radius:", designSystem.customProperties.borderRadius6, " 0 0 ", designSystem.customProperties.borderRadius6, ";" + ("" ), "" ), "" ]),
|
|
55
55
|
children: [jsxRuntime.jsx("span", {
|
|
56
56
|
css: /*#__PURE__*/react.css("margin:0 ", designSystem.customProperties.spacingXs, " 0 0;display:flex;align-items:center;justify-content:center;" + ("" ), "" ),
|
|
57
57
|
children: /*#__PURE__*/react$1.cloneElement(props.iconLeft, {
|
|
@@ -60,7 +60,7 @@ var DropdownHead = function DropdownHead(props) {
|
|
|
60
60
|
})
|
|
61
61
|
}), jsxRuntime.jsx("span", {
|
|
62
62
|
css: /*#__PURE__*/react.css("margin:0 ", designSystem.customProperties.spacingXs, " 0 0;display:flex;align-items:center;justify-content:center;" + ("" ), "" ),
|
|
63
|
-
children: jsxRuntime.jsx(Text__default[
|
|
63
|
+
children: jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
64
64
|
tone: props.isDisabled ? 'secondary' : undefined,
|
|
65
65
|
children: props.children
|
|
66
66
|
})
|
|
@@ -80,13 +80,13 @@ var _ref2 = {
|
|
|
80
80
|
var DropdownChevron = /*#__PURE__*/react$1.forwardRef(function (props, ref) {
|
|
81
81
|
var _context2;
|
|
82
82
|
|
|
83
|
-
return jsxRuntime.jsx(AccessibleButton__default[
|
|
83
|
+
return jsxRuntime.jsx(AccessibleButton__default["default"], {
|
|
84
84
|
ref: ref,
|
|
85
85
|
label: "Open Dropdown",
|
|
86
86
|
onClick: props.onClick,
|
|
87
87
|
isDisabled: props.isDisabled,
|
|
88
88
|
isOpen: props.isOpen,
|
|
89
|
-
css: _concatInstanceProperty__default[
|
|
89
|
+
css: _concatInstanceProperty__default["default"](_context2 = []).call(_context2, _toConsumableArray(getButtonStyles(props.isDisabled)), [/*#__PURE__*/react.css("padding:0 ", designSystem.customProperties.spacingXs, ";border-left:1px solid ", designSystem.customProperties.colorNeutral, ";border-radius:0 ", designSystem.customProperties.borderRadius6, " ", designSystem.customProperties.borderRadius6, " 0;" + ("" ), "" ), "" ]),
|
|
90
90
|
children: jsxRuntime.jsx("div", {
|
|
91
91
|
// The margin-top is to center the icon as the caret visually looks too high otherwise
|
|
92
92
|
css: _ref2,
|
|
@@ -99,17 +99,17 @@ var DropdownChevron = /*#__PURE__*/react$1.forwardRef(function (props, ref) {
|
|
|
99
99
|
});
|
|
100
100
|
DropdownChevron.displayName = 'DropdownChevron';
|
|
101
101
|
DropdownChevron.propTypes = {
|
|
102
|
-
onClick: PropTypes__default[
|
|
103
|
-
isDisabled: PropTypes__default[
|
|
104
|
-
isOpen: PropTypes__default[
|
|
102
|
+
onClick: PropTypes__default["default"].func.isRequired,
|
|
103
|
+
isDisabled: PropTypes__default["default"].bool.isRequired,
|
|
104
|
+
isOpen: PropTypes__default["default"].bool.isRequired
|
|
105
105
|
};
|
|
106
106
|
|
|
107
|
-
var Options = _styled__default[
|
|
107
|
+
var Options = _styled__default["default"]("div", {
|
|
108
108
|
target: "e102bf7i0"
|
|
109
109
|
} )("position:absolute;z-index:5;width:100%;top:calc(", designSystem.customProperties.spacingS, " + ", designSystem.customProperties.bigButtonHeight, ");left:0;border:1px solid ", designSystem.customProperties.colorNeutral, ";border-radius:", designSystem.customProperties.borderRadius6, ";box-shadow:", designSystem.customProperties.shadow1, ";" + ("" ));
|
|
110
110
|
|
|
111
111
|
var Option = function Option(props) {
|
|
112
|
-
return jsxRuntime.jsx(AccessibleButton__default[
|
|
112
|
+
return jsxRuntime.jsx(AccessibleButton__default["default"], {
|
|
113
113
|
label: props.children,
|
|
114
114
|
onClick: props.onClick,
|
|
115
115
|
isDisabled: props.isDisabled,
|
|
@@ -160,7 +160,7 @@ var PrimaryActionDropdown = function PrimaryActionDropdown(props) {
|
|
|
160
160
|
};
|
|
161
161
|
}, [handleGlobalClick]);
|
|
162
162
|
var childrenAsArray = react$1.Children.toArray(props.children);
|
|
163
|
-
var primaryOption = _findInstanceProperty__default[
|
|
163
|
+
var primaryOption = _findInstanceProperty__default["default"](childrenAsArray).call(childrenAsArray, function (option) {
|
|
164
164
|
return !option.props.isDisabled;
|
|
165
165
|
}) || childrenAsArray[0];
|
|
166
166
|
var onClick = primaryOption.props.onClick;
|
|
@@ -198,8 +198,8 @@ PrimaryActionDropdown.propTypes = {};
|
|
|
198
198
|
var PrimaryActionDropdown$1 = PrimaryActionDropdown;
|
|
199
199
|
|
|
200
200
|
// NOTE: This string will be replaced in the `prepare` script by the `scripts/version.js` file.
|
|
201
|
-
var version = '12.2.
|
|
201
|
+
var version = '12.2.4';
|
|
202
202
|
|
|
203
203
|
exports.Option = Option;
|
|
204
|
-
exports[
|
|
204
|
+
exports["default"] = PrimaryActionDropdown$1;
|
|
205
205
|
exports.version = version;
|
|
@@ -220,6 +220,6 @@ PrimaryActionDropdown.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
220
220
|
var PrimaryActionDropdown$1 = PrimaryActionDropdown;
|
|
221
221
|
|
|
222
222
|
// NOTE: This string will be replaced in the `prepare` script by the `scripts/version.js` file.
|
|
223
|
-
var version = '12.2.
|
|
223
|
+
var version = '12.2.4';
|
|
224
224
|
|
|
225
225
|
export { 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": "12.2.
|
|
4
|
+
"version": "12.2.4",
|
|
5
5
|
"bugs": "https://github.com/commercetools/ui-kit/issues",
|
|
6
6
|
"repository": {
|
|
7
7
|
"type": "git",
|
|
@@ -23,14 +23,14 @@
|
|
|
23
23
|
"prepare": "../../../scripts/version.js replace"
|
|
24
24
|
},
|
|
25
25
|
"dependencies": {
|
|
26
|
-
"@babel/runtime": "7.
|
|
27
|
-
"@babel/runtime-corejs3": "7.
|
|
28
|
-
"@commercetools-uikit/accessible-button": "12.2.
|
|
29
|
-
"@commercetools-uikit/buttons": "12.2.
|
|
30
|
-
"@commercetools-uikit/design-system": "12.2.
|
|
26
|
+
"@babel/runtime": "7.15.4",
|
|
27
|
+
"@babel/runtime-corejs3": "7.15.4",
|
|
28
|
+
"@commercetools-uikit/accessible-button": "12.2.4",
|
|
29
|
+
"@commercetools-uikit/buttons": "12.2.4",
|
|
30
|
+
"@commercetools-uikit/design-system": "12.2.4",
|
|
31
31
|
"@commercetools-uikit/hooks": "12.2.3",
|
|
32
|
-
"@commercetools-uikit/icons": "12.2.
|
|
33
|
-
"@commercetools-uikit/text": "12.2.
|
|
32
|
+
"@commercetools-uikit/icons": "12.2.4",
|
|
33
|
+
"@commercetools-uikit/text": "12.2.4",
|
|
34
34
|
"@commercetools-uikit/utils": "12.2.0",
|
|
35
35
|
"@emotion/react": "^11.4.0",
|
|
36
36
|
"@emotion/styled": "^11.3.0",
|