@flodesk/grain 11.22.6 → 11.23.1
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.
- package/es/components/arrange/index.js +34 -47
- package/es/components/autocomplete.js +94 -149
- package/es/components/autocomplete2.js +131 -170
- package/es/components/badge.js +12 -17
- package/es/components/box.js +115 -126
- package/es/components/breakpoints-provider.js +6 -4
- package/es/components/button.js +27 -40
- package/es/components/checkbox.js +31 -28
- package/es/components/dropdown.js +52 -50
- package/es/components/flex/index.js +31 -46
- package/es/components/icon-button.js +17 -25
- package/es/components/icon-toggle.js +30 -34
- package/es/components/icon.js +10 -20
- package/es/components/link.js +18 -18
- package/es/components/modal.js +75 -69
- package/es/components/nav/index.js +36 -43
- package/es/components/pagination.js +45 -63
- package/es/components/popover.js +47 -48
- package/es/components/progress.js +12 -15
- package/es/components/provider.js +7 -6
- package/es/components/radio.js +25 -24
- package/es/components/select.js +92 -100
- package/es/components/slider.js +25 -29
- package/es/components/spinner.js +11 -26
- package/es/components/stack.js +10 -19
- package/es/components/switch.js +21 -21
- package/es/components/tab.js +18 -25
- package/es/components/text/index.js +38 -48
- package/es/components/text-button.js +28 -41
- package/es/components/text-input.js +53 -75
- package/es/components/text-toggle.js +20 -31
- package/es/components/textarea.js +38 -33
- package/es/components/toast.js +29 -28
- package/es/components/tooltip.js +43 -77
- package/es/foundational/field.js +39 -34
- package/es/foundational/menu.js +112 -98
- package/es/foundational/styles.js +23 -23
- package/es/hooks/useKeyPress.js +10 -31
- package/es/hooks/useMedia.js +8 -45
- package/es/hooks/useOnClickOutside.js +4 -7
- package/es/hooks/usePrev.js +3 -3
- package/es/hooks/useWidth.js +3 -29
- package/es/hooks/useWindowSize.js +4 -32
- package/es/icons/icon-align-center.js +28 -32
- package/es/icons/icon-align-left.js +35 -39
- package/es/icons/icon-align-right.js +35 -39
- package/es/icons/icon-archive.js +21 -25
- package/es/icons/icon-arrow-down.js +21 -25
- package/es/icons/icon-arrow-left.js +21 -25
- package/es/icons/icon-arrow-right.js +21 -25
- package/es/icons/icon-arrow-up.js +21 -25
- package/es/icons/icon-at.js +21 -25
- package/es/icons/icon-bold.js +28 -32
- package/es/icons/icon-bolt-filled.js +21 -25
- package/es/icons/icon-bolt.js +21 -25
- package/es/icons/icon-browser.js +21 -25
- package/es/icons/icon-brush.js +20 -24
- package/es/icons/icon-bullet-list.js +21 -25
- package/es/icons/icon-chart.js +29 -33
- package/es/icons/icon-check.js +21 -25
- package/es/icons/icon-chevron-down.js +21 -25
- package/es/icons/icon-chevron-horizontal.js +21 -25
- package/es/icons/icon-chevron-left.js +21 -25
- package/es/icons/icon-chevron-right.js +21 -25
- package/es/icons/icon-chevron-up.js +28 -32
- package/es/icons/icon-chevron-vertical.js +28 -32
- package/es/icons/icon-clip.js +37 -41
- package/es/icons/icon-clock.js +21 -25
- package/es/icons/icon-column-and-rows.js +25 -29
- package/es/icons/icon-column-one.js +21 -25
- package/es/icons/icon-column-two.js +21 -25
- package/es/icons/icon-columns-and-row.js +25 -29
- package/es/icons/icon-columns.js +21 -25
- package/es/icons/icon-content-align-bottom.js +21 -25
- package/es/icons/icon-content-align-center.js +21 -25
- package/es/icons/icon-content-align-top.js +21 -25
- package/es/icons/icon-crop.js +21 -25
- package/es/icons/icon-cross.js +23 -27
- package/es/icons/icon-download.js +28 -32
- package/es/icons/icon-drag.js +21 -25
- package/es/icons/icon-duplicate.js +21 -25
- package/es/icons/icon-ellipsis.js +21 -25
- package/es/icons/icon-file.js +28 -32
- package/es/icons/icon-folder-add.js +21 -25
- package/es/icons/icon-folder-move.js +21 -25
- package/es/icons/icon-folder-remove.js +21 -25
- package/es/icons/icon-folder.js +21 -25
- package/es/icons/icon-gear.js +35 -39
- package/es/icons/icon-globe.js +28 -32
- package/es/icons/icon-heart.js +21 -25
- package/es/icons/icon-hide.js +21 -25
- package/es/icons/icon-image.js +21 -25
- package/es/icons/icon-info.js +21 -25
- package/es/icons/icon-italic.js +28 -32
- package/es/icons/icon-layout-text-bottom.js +28 -32
- package/es/icons/icon-layout-text-left.js +21 -25
- package/es/icons/icon-layout-text-right.js +28 -32
- package/es/icons/icon-layout-text-top.js +21 -25
- package/es/icons/icon-link.js +21 -25
- package/es/icons/icon-location.js +21 -25
- package/es/icons/icon-mail.js +21 -25
- package/es/icons/icon-minus.js +19 -23
- package/es/icons/icon-monitor.js +21 -25
- package/es/icons/icon-number-list.js +29 -33
- package/es/icons/icon-pencil.js +28 -32
- package/es/icons/icon-phone.js +21 -25
- package/es/icons/icon-play.js +21 -25
- package/es/icons/icon-plus.js +21 -25
- package/es/icons/icon-question.js +21 -25
- package/es/icons/icon-redo.js +21 -25
- package/es/icons/icon-reset.js +22 -26
- package/es/icons/icon-row-and-columns.js +25 -29
- package/es/icons/icon-rows-and-column.js +25 -29
- package/es/icons/icon-rows.js +21 -25
- package/es/icons/icon-search.js +21 -25
- package/es/icons/icon-send.js +21 -25
- package/es/icons/icon-share.js +21 -25
- package/es/icons/icon-show.js +21 -25
- package/es/icons/icon-smile.js +28 -32
- package/es/icons/icon-square.js +21 -25
- package/es/icons/icon-strike.js +28 -32
- package/es/icons/icon-switch.js +21 -25
- package/es/icons/icon-tablet.js +21 -25
- package/es/icons/icon-text-align-center.js +21 -25
- package/es/icons/icon-text-align-left.js +21 -25
- package/es/icons/icon-text-align-right.js +21 -25
- package/es/icons/icon-text-justify.js +21 -25
- package/es/icons/icon-trash.js +28 -32
- package/es/icons/icon-type.js +28 -32
- package/es/icons/icon-underline.js +28 -32
- package/es/icons/icon-undo.js +28 -32
- package/es/icons/icon-upload.js +28 -32
- package/es/styles/base.js +1 -1
- package/es/styles/card.js +4 -8
- package/es/styles/colors/core.js +1 -1
- package/es/styles/colors/theme.js +1 -1
- package/es/styles/foundational-variables.js +5 -0
- package/es/styles/index.js +2 -2
- package/es/styles/shadows.js +1 -1
- package/es/styles/utilities.js +65 -90
- package/es/styles/variables.js +1 -1
- package/es/types.js +28 -29
- package/es/utilities/attributes.js +46 -49
- package/es/utilities/helpers.js +13 -36
- package/es/utilities/responsive.js +16 -43
- package/es/utilities/style-config.js +32 -76
- package/es/utilities/styles.js +17 -29
- package/es/variables/breakpoints.js +1 -1
- package/es/variables/colors.js +1 -1
- package/es/variables/vars.js +3 -13
- package/package.json +5 -5
- package/es/styles/component-variables.js +0 -2
package/es/components/select.js
CHANGED
|
@@ -1,16 +1,7 @@
|
|
|
1
|
-
import "core-js/modules/es.object.keys.js";
|
|
2
|
-
import "core-js/modules/es.array.index-of.js";
|
|
3
|
-
import "core-js/modules/es.symbol.js";
|
|
4
|
-
import "core-js/modules/es.object.assign.js";
|
|
5
1
|
import _styled from "@emotion/styled/base";
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
import "core-js/modules/es.array.map.js";
|
|
10
|
-
import "core-js/modules/es.object.to-string.js";
|
|
11
|
-
import "core-js/modules/es.array.iterator.js";
|
|
12
|
-
import "core-js/modules/es.map.js";
|
|
13
|
-
import "core-js/modules/es.string.iterator.js";
|
|
2
|
+
const _excluded = ["children", "variant"],
|
|
3
|
+
_excluded2 = ["option", "isSelected", "menuItemsHaveEllipsis", "allowMultiple"],
|
|
4
|
+
_excluded3 = ["children", "floating", "hasPortal", "isOpen"];
|
|
14
5
|
import "core-js/modules/web.dom-collections.iterator.js";
|
|
15
6
|
|
|
16
7
|
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
@@ -33,17 +24,18 @@ import { MenuItemDivider, useMenuPosition } from '../foundational/menu';
|
|
|
33
24
|
import { FloatingPortal } from '@floating-ui/react-dom-interactions';
|
|
34
25
|
import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
35
26
|
|
|
36
|
-
|
|
27
|
+
const TriggerButton = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "production" ? {
|
|
37
28
|
target: "e17qd7kh1"
|
|
38
29
|
} : {
|
|
39
30
|
target: "e17qd7kh1",
|
|
40
31
|
label: "TriggerButton"
|
|
41
|
-
})(styles.buttonReset, ";", styles.transitions, ";color:inherit;display:flex;align-items:center;gap:8px;border:none;background:transparent;padding:0 ", getSpace('fieldPaddingX'), ";border:1px solid ", getColor('fieldBorder'), ";font-weight:", getWeight('normal'), ";min-height:var(--grn-textBoxHeight);border-radius:", getRadius('s'), ";width:100%;text-align:left;&:hover{border-color:", getColor('fieldBorderHover'), ";}&[disabled]{", fieldDisabledStyles, ";cursor:default;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/select.jsx"],"names":[],"mappings":"AAoBmC","file":"../../src/components/select.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo } from 'react';\nimport styled from '@emotion/styled';\nimport { Box, Icon, Text, TextButton } from '.';\nimport { IconChevronDown } from '../icons';\nimport { Listbox } from '@headlessui/react';\nimport { getColor, getRadius, getSpace, getWeight } from '../utilities';\nimport { defaultProps, types } from '../types';\nimport {\n  fieldDisabledStyles,\n  FieldHint,\n  FieldLabel,\n  MenuCard,\n  MenuCardTransition,\n  MenuItem,\n  styles,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\n\nconst TriggerButton = styled.button`\n  ${styles.buttonReset};\n  ${styles.transitions};\n\n  color: inherit;\n  display: flex;\n  align-items: center;\n  gap: 8px;\n  border: none;\n  background: transparent;\n  padding: 0 ${getSpace('fieldPaddingX')};\n  border: 1px solid ${getColor('fieldBorder')};\n  font-weight: ${getWeight('normal')};\n  min-height: var(--grn-textBoxHeight);\n  border-radius: ${getRadius('s')};\n  width: 100%;\n  text-align: left;\n\n  &:hover {\n    border-color: ${getColor('fieldBorderHover')};\n  }\n\n  &[disabled] {\n    ${fieldDisabledStyles};\n    cursor: default;\n  }\n`;\n\nconst Trigger = forwardRef(({ children, variant = 'box', ...props }, ref) => (\n  <>\n    {variant === 'box' && (\n      <TriggerButton ref={ref} type=\"button\" {...props}>\n        <Text hasEllipsis>{children}</Text>\n        <Box marginLeft=\"auto\">\n          <Icon icon={<IconChevronDown />} />\n        </Box>\n      </TriggerButton>\n    )}\n    {variant === 'text' && (\n      <TextButton ref={ref} icon={<IconChevronDown />} iconPosition=\"right\" {...props}>\n        {children}\n      </TextButton>\n    )}\n  </>\n));\n\nconst getTriggerContent = (isMultiple, selected, placeholder) => {\n  if (!selected) {\n    if (placeholder) return <Text color=\"shade7\">{placeholder}</Text>;\n    return null;\n  }\n  if (isMultiple) {\n    return selected.map(option => option.content).join(', ');\n  }\n  return selected.content;\n};\n\nconst SelectButton = ({ customTrigger, variant, isMultiple, selected, placeholder }) => {\n  const props = {\n    variant,\n    children: getTriggerContent(isMultiple, selected, placeholder),\n  };\n  return (\n    <Listbox.Button as={Fragment}>\n      {customTrigger ? customTrigger({ props }) : <Trigger {...props} />}\n    </Listbox.Button>\n  );\n};\n\nconst Root = styled.div`\n  min-width: 0px;\n`;\n\nconst SelectMenuOption = ({\n  option,\n  isSelected,\n  menuItemsHaveEllipsis,\n  allowMultiple,\n  ...props\n}) => (\n  <Listbox.Option value={option} as={Fragment} disabled={option.isDisabled} {...props}>\n    {({ active }) => {\n      return (\n        <MenuItem\n          isSelected={isSelected}\n          isActive={active}\n          isDisabled={option.isDisabled}\n          hasEllipsis={menuItemsHaveEllipsis}\n        >\n          {option.content}\n        </MenuItem>\n      );\n    }}\n  </Listbox.Option>\n);\n\nconst SelectInfo = ({ label, hint }) => (\n  <>\n    {(label || hint) && (\n      <Box marginBottom=\"betweenFormControlAndLabel\">\n        {label && <Listbox.Label as={FieldLabel}>{label}</Listbox.Label>}\n        {hint && <FieldHint>{hint}</FieldHint>}\n      </Box>\n    )}\n  </>\n);\n\nconst SelectMenu = ({ children, floating, hasPortal, isOpen, ...props }) => {\n  const Root = hasPortal ? FloatingPortal : Fragment;\n  return (\n    <Root>\n      <MenuCardTransition>\n        <Listbox.Options\n          static\n          className=\"grn-context\"\n          ref={floating}\n          as={MenuCard}\n          isDisabled={!isOpen}\n          {...props}\n        >\n          {children}\n        </Listbox.Options>\n      </MenuCardTransition>\n    </Root>\n  );\n};\n\nconst getIsSelected = (isMultiple, option, selected) => {\n  if (!selected) return null;\n  if (isMultiple) {\n    return selected.some(selectedOption => selectedOption.content === option.content);\n  }\n\n  return option.value === selected.value;\n};\n\nexport const Select = ({\n  options,\n  value,\n  onChange,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  trigger: customTrigger,\n  triggerVariant = 'box',\n  label,\n  hint,\n  menuZIndex,\n  menuItemsHaveEllipsis = true,\n  allowMultiple,\n  hasPortal = true,\n  placeholder,\n  isDisabled,\n}) => {\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n  const rootWidth = triggerVariant === 'text' ? 'fit-content' : undefined;\n\n  const optionMap = useMemo(() => {\n    return new Map(options.map(option => [option.value, option]));\n  }, [options]);\n\n  const selected = useMemo(() => {\n    const valueIsValid = value !== null && value !== undefined;\n\n    if (allowMultiple) {\n      return valueIsValid ? value.map(v => optionMap.get(v)) : [];\n    }\n\n    return valueIsValid ? optionMap.get(value) : null;\n  }, [allowMultiple, optionMap, value]);\n\n  const listboxValue = useMemo(() => {\n    const valueIsValid = selected !== undefined && selected !== null;\n\n    if (!valueIsValid) {\n      if (allowMultiple) return [];\n      else return null;\n    }\n\n    return selected;\n  }, [allowMultiple, selected]);\n\n  return (\n    <Listbox\n      as={Root}\n      value={listboxValue}\n      onChange={onChange}\n      width={rootWidth}\n      multiple={allowMultiple}\n      disabled={isDisabled}\n    >\n      {({ open }) => (\n        <>\n          <SelectInfo label={label} hint={hint} />\n\n          <Box position=\"relative\" ref={reference}>\n            <SelectButton\n              customTrigger={customTrigger}\n              variant={triggerVariant}\n              isMultiple={allowMultiple}\n              selected={selected}\n              placeholder={placeholder}\n            />\n\n            <SelectMenu\n              placement={menuPlacement}\n              maxHeight={menuMaxHeight}\n              zIndex={menuZIndex}\n              floating={floating}\n              style={floatingStyles}\n              hasPortal={hasPortal}\n              isOpen={open}\n            >\n              {options.map((option, index) => {\n                const isSelected = getIsSelected(allowMultiple, option, selected);\n\n                if (option.type === 'divider') return <MenuItemDivider key={index} />;\n\n                return (\n                  <SelectMenuOption\n                    isSelected={isSelected}\n                    key={index}\n                    option={option}\n                    hasEllipsis={menuItemsHaveEllipsis}\n                    allowMultiple={allowMultiple}\n                  />\n                );\n              })}\n            </SelectMenu>\n          </Box>\n        </>\n      )}\n    </Listbox>\n  );\n};\n\nSelect.Label = FieldLabel;\nSelect.Hint = FieldHint;\nSelect.Trigger = Trigger;\n\nSelect.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.oneOfType([PropTypes.string, PropTypes.number, PropTypes.array]),\n  onChange: PropTypes.func.isRequired,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuZIndex: types.zIndex,\n  menuMaxHeight: types.dimension,\n  trigger: PropTypes.func,\n  triggerVariant: PropTypes.oneOf(['box', 'text']),\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  allowMultiple: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  placeholder: PropTypes.string,\n  isDisabled: PropTypes.bool,\n};\n"]} */"));
|
|
32
|
+
})(styles.buttonReset, ";", styles.transitions, ";color:inherit;display:flex;align-items:center;gap:8px;border:none;background:transparent;padding:0 ", getSpace('fieldPaddingX'), ";border:1px solid ", getColor('fieldBorder'), ";font-weight:", getWeight('normal'), ";min-height:var(--grn-textbox-height-m);border-radius:", getRadius('s'), ";width:100%;text-align:left;&:hover{border-color:", getColor('fieldBorderHover'), ";}&[disabled]{", fieldDisabledStyles, ";cursor:default;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/select.jsx"],"names":[],"mappings":"AAoBmC","file":"../../src/components/select.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo } from 'react';\nimport styled from '@emotion/styled';\nimport { Box, Icon, Text, TextButton } from '.';\nimport { IconChevronDown } from '../icons';\nimport { Listbox } from '@headlessui/react';\nimport { getColor, getRadius, getSpace, getWeight } from '../utilities';\nimport { defaultProps, types } from '../types';\nimport {\n  fieldDisabledStyles,\n  FieldHint,\n  FieldLabel,\n  MenuCard,\n  MenuCardTransition,\n  MenuItem,\n  styles,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\n\nconst TriggerButton = styled.button`\n  ${styles.buttonReset};\n  ${styles.transitions};\n\n  color: inherit;\n  display: flex;\n  align-items: center;\n  gap: 8px;\n  border: none;\n  background: transparent;\n  padding: 0 ${getSpace('fieldPaddingX')};\n  border: 1px solid ${getColor('fieldBorder')};\n  font-weight: ${getWeight('normal')};\n  min-height: var(--grn-textbox-height-m);\n  border-radius: ${getRadius('s')};\n  width: 100%;\n  text-align: left;\n\n  &:hover {\n    border-color: ${getColor('fieldBorderHover')};\n  }\n\n  &[disabled] {\n    ${fieldDisabledStyles};\n    cursor: default;\n  }\n`;\n\nconst Trigger = forwardRef(({ children, variant = 'box', ...props }, ref) => (\n  <>\n    {variant === 'box' && (\n      <TriggerButton ref={ref} type=\"button\" {...props}>\n        <Text hasEllipsis>{children}</Text>\n        <Box marginLeft=\"auto\">\n          <Icon icon={<IconChevronDown />} />\n        </Box>\n      </TriggerButton>\n    )}\n    {variant === 'text' && (\n      <TextButton ref={ref} icon={<IconChevronDown />} iconPosition=\"right\" {...props}>\n        {children}\n      </TextButton>\n    )}\n  </>\n));\n\nconst getTriggerContent = (isMultiple, selected, placeholder) => {\n  if (!selected) {\n    if (placeholder) return <Text color=\"shade7\">{placeholder}</Text>;\n    return null;\n  }\n  if (isMultiple) {\n    return selected.map(option => option.content).join(', ');\n  }\n  return selected.content;\n};\n\nconst SelectButton = ({ customTrigger, variant, isMultiple, selected, placeholder }) => {\n  const props = {\n    variant,\n    children: getTriggerContent(isMultiple, selected, placeholder),\n  };\n  return (\n    <Listbox.Button as={Fragment}>\n      {customTrigger ? customTrigger({ props }) : <Trigger {...props} />}\n    </Listbox.Button>\n  );\n};\n\nconst Root = styled.div`\n  min-width: 0px;\n`;\n\nconst SelectMenuOption = ({\n  option,\n  isSelected,\n  menuItemsHaveEllipsis,\n  allowMultiple,\n  ...props\n}) => (\n  <Listbox.Option value={option} as={Fragment} disabled={option.isDisabled} {...props}>\n    {({ active }) => {\n      return (\n        <MenuItem\n          isSelected={isSelected}\n          isActive={active}\n          isDisabled={option.isDisabled}\n          hasEllipsis={menuItemsHaveEllipsis}\n        >\n          {option.content}\n        </MenuItem>\n      );\n    }}\n  </Listbox.Option>\n);\n\nconst SelectInfo = ({ label, hint }) => (\n  <>\n    {(label || hint) && (\n      <Box marginBottom=\"betweenFormControlAndLabel\">\n        {label && <Listbox.Label as={FieldLabel}>{label}</Listbox.Label>}\n        {hint && <FieldHint>{hint}</FieldHint>}\n      </Box>\n    )}\n  </>\n);\n\nconst SelectMenu = ({ children, floating, hasPortal, isOpen, ...props }) => {\n  const Root = hasPortal ? FloatingPortal : Fragment;\n  return (\n    <Root>\n      <MenuCardTransition>\n        <Listbox.Options\n          static\n          className=\"grn-context\"\n          ref={floating}\n          as={MenuCard}\n          isDisabled={!isOpen}\n          {...props}\n        >\n          {children}\n        </Listbox.Options>\n      </MenuCardTransition>\n    </Root>\n  );\n};\n\nconst getIsSelected = (isMultiple, option, selected) => {\n  if (!selected) return null;\n  if (isMultiple) {\n    return selected.some(selectedOption => selectedOption.content === option.content);\n  }\n\n  return option.value === selected.value;\n};\n\nexport const Select = ({\n  options,\n  value,\n  onChange,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  trigger: customTrigger,\n  triggerVariant = 'box',\n  label,\n  hint,\n  menuZIndex,\n  menuItemsHaveEllipsis = true,\n  allowMultiple,\n  hasPortal = true,\n  placeholder,\n  isDisabled,\n}) => {\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n  const rootWidth = triggerVariant === 'text' ? 'fit-content' : undefined;\n\n  const optionMap = useMemo(() => {\n    return new Map(options.map(option => [option.value, option]));\n  }, [options]);\n\n  const selected = useMemo(() => {\n    const valueIsValid = value !== null && value !== undefined;\n\n    if (allowMultiple) {\n      return valueIsValid ? value.map(v => optionMap.get(v)) : [];\n    }\n\n    return valueIsValid ? optionMap.get(value) : null;\n  }, [allowMultiple, optionMap, value]);\n\n  const listboxValue = useMemo(() => {\n    const valueIsValid = selected !== undefined && selected !== null;\n\n    if (!valueIsValid) {\n      if (allowMultiple) return [];\n      else return null;\n    }\n\n    return selected;\n  }, [allowMultiple, selected]);\n\n  return (\n    <Listbox\n      as={Root}\n      value={listboxValue}\n      onChange={onChange}\n      width={rootWidth}\n      multiple={allowMultiple}\n      disabled={isDisabled}\n    >\n      {({ open }) => (\n        <>\n          <SelectInfo label={label} hint={hint} />\n\n          <Box position=\"relative\" ref={reference}>\n            <SelectButton\n              customTrigger={customTrigger}\n              variant={triggerVariant}\n              isMultiple={allowMultiple}\n              selected={selected}\n              placeholder={placeholder}\n            />\n\n            <SelectMenu\n              placement={menuPlacement}\n              maxHeight={menuMaxHeight}\n              zIndex={menuZIndex}\n              floating={floating}\n              style={floatingStyles}\n              hasPortal={hasPortal}\n              isOpen={open}\n            >\n              {options.map((option, index) => {\n                const isSelected = getIsSelected(allowMultiple, option, selected);\n\n                if (option.type === 'divider') return <MenuItemDivider key={index} />;\n\n                return (\n                  <SelectMenuOption\n                    isSelected={isSelected}\n                    key={index}\n                    option={option}\n                    hasEllipsis={menuItemsHaveEllipsis}\n                    allowMultiple={allowMultiple}\n                  />\n                );\n              })}\n            </SelectMenu>\n          </Box>\n        </>\n      )}\n    </Listbox>\n  );\n};\n\nSelect.Label = FieldLabel;\nSelect.Hint = FieldHint;\nSelect.Trigger = Trigger;\n\nSelect.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.oneOfType([PropTypes.string, PropTypes.number, PropTypes.array]),\n  onChange: PropTypes.func.isRequired,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuZIndex: types.zIndex,\n  menuMaxHeight: types.dimension,\n  trigger: PropTypes.func,\n  triggerVariant: PropTypes.oneOf(['box', 'text']),\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  allowMultiple: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  placeholder: PropTypes.string,\n  isDisabled: PropTypes.bool,\n};\n"]} */"));
|
|
42
33
|
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
34
|
+
const Trigger = /*#__PURE__*/forwardRef((_ref, ref) => {
|
|
35
|
+
let {
|
|
36
|
+
children,
|
|
37
|
+
variant = 'box'
|
|
38
|
+
} = _ref,
|
|
47
39
|
props = _objectWithoutProperties(_ref, _excluded);
|
|
48
40
|
|
|
49
41
|
return ___EmotionJSX(React.Fragment, null, variant === 'box' && ___EmotionJSX(TriggerButton, _extends({
|
|
@@ -62,7 +54,7 @@ var Trigger = /*#__PURE__*/forwardRef(function (_ref, ref) {
|
|
|
62
54
|
}, props), children));
|
|
63
55
|
});
|
|
64
56
|
|
|
65
|
-
|
|
57
|
+
const getTriggerContent = (isMultiple, selected, placeholder) => {
|
|
66
58
|
if (!selected) {
|
|
67
59
|
if (placeholder) return ___EmotionJSX(Text, {
|
|
68
60
|
color: "shade7"
|
|
@@ -71,32 +63,32 @@ var getTriggerContent = function getTriggerContent(isMultiple, selected, placeho
|
|
|
71
63
|
}
|
|
72
64
|
|
|
73
65
|
if (isMultiple) {
|
|
74
|
-
return selected.map(
|
|
75
|
-
return option.content;
|
|
76
|
-
}).join(', ');
|
|
66
|
+
return selected.map(option => option.content).join(', ');
|
|
77
67
|
}
|
|
78
68
|
|
|
79
69
|
return selected.content;
|
|
80
70
|
};
|
|
81
71
|
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
72
|
+
const SelectButton = _ref2 => {
|
|
73
|
+
let {
|
|
74
|
+
customTrigger,
|
|
75
|
+
variant,
|
|
76
|
+
isMultiple,
|
|
77
|
+
selected,
|
|
78
|
+
placeholder
|
|
79
|
+
} = _ref2;
|
|
80
|
+
const props = {
|
|
81
|
+
variant,
|
|
90
82
|
children: getTriggerContent(isMultiple, selected, placeholder)
|
|
91
83
|
};
|
|
92
84
|
return ___EmotionJSX(Listbox.Button, {
|
|
93
85
|
as: Fragment
|
|
94
86
|
}, customTrigger ? customTrigger({
|
|
95
|
-
props
|
|
87
|
+
props
|
|
96
88
|
}) : ___EmotionJSX(Trigger, props));
|
|
97
89
|
};
|
|
98
90
|
|
|
99
|
-
|
|
91
|
+
const Root = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
100
92
|
target: "e17qd7kh0"
|
|
101
93
|
} : {
|
|
102
94
|
target: "e17qd7kh0",
|
|
@@ -107,23 +99,27 @@ var Root = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
|
107
99
|
} : {
|
|
108
100
|
name: "wowqs1",
|
|
109
101
|
styles: "min-width:0px",
|
|
110
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/select.jsx"],"names":[],"mappings":"AAyFuB","file":"../../src/components/select.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo } from 'react';\nimport styled from '@emotion/styled';\nimport { Box, Icon, Text, TextButton } from '.';\nimport { IconChevronDown } from '../icons';\nimport { Listbox } from '@headlessui/react';\nimport { getColor, getRadius, getSpace, getWeight } from '../utilities';\nimport { defaultProps, types } from '../types';\nimport {\n  fieldDisabledStyles,\n  FieldHint,\n  FieldLabel,\n  MenuCard,\n  MenuCardTransition,\n  MenuItem,\n  styles,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\n\nconst TriggerButton = styled.button`\n  ${styles.buttonReset};\n  ${styles.transitions};\n\n  color: inherit;\n  display: flex;\n  align-items: center;\n  gap: 8px;\n  border: none;\n  background: transparent;\n  padding: 0 ${getSpace('fieldPaddingX')};\n  border: 1px solid ${getColor('fieldBorder')};\n  font-weight: ${getWeight('normal')};\n  min-height: var(--grn-textBoxHeight);\n  border-radius: ${getRadius('s')};\n  width: 100%;\n  text-align: left;\n\n  &:hover {\n    border-color: ${getColor('fieldBorderHover')};\n  }\n\n  &[disabled] {\n    ${fieldDisabledStyles};\n    cursor: default;\n  }\n`;\n\nconst Trigger = forwardRef(({ children, variant = 'box', ...props }, ref) => (\n  <>\n    {variant === 'box' && (\n      <TriggerButton ref={ref} type=\"button\" {...props}>\n        <Text hasEllipsis>{children}</Text>\n        <Box marginLeft=\"auto\">\n          <Icon icon={<IconChevronDown />} />\n        </Box>\n      </TriggerButton>\n    )}\n    {variant === 'text' && (\n      <TextButton ref={ref} icon={<IconChevronDown />} iconPosition=\"right\" {...props}>\n        {children}\n      </TextButton>\n    )}\n  </>\n));\n\nconst getTriggerContent = (isMultiple, selected, placeholder) => {\n  if (!selected) {\n    if (placeholder) return <Text color=\"shade7\">{placeholder}</Text>;\n    return null;\n  }\n  if (isMultiple) {\n    return selected.map(option => option.content).join(', ');\n  }\n  return selected.content;\n};\n\nconst SelectButton = ({ customTrigger, variant, isMultiple, selected, placeholder }) => {\n  const props = {\n    variant,\n    children: getTriggerContent(isMultiple, selected, placeholder),\n  };\n  return (\n    <Listbox.Button as={Fragment}>\n      {customTrigger ? customTrigger({ props }) : <Trigger {...props} />}\n    </Listbox.Button>\n  );\n};\n\nconst Root = styled.div`\n  min-width: 0px;\n`;\n\nconst SelectMenuOption = ({\n  option,\n  isSelected,\n  menuItemsHaveEllipsis,\n  allowMultiple,\n  ...props\n}) => (\n  <Listbox.Option value={option} as={Fragment} disabled={option.isDisabled} {...props}>\n    {({ active }) => {\n      return (\n        <MenuItem\n          isSelected={isSelected}\n          isActive={active}\n          isDisabled={option.isDisabled}\n          hasEllipsis={menuItemsHaveEllipsis}\n        >\n          {option.content}\n        </MenuItem>\n      );\n    }}\n  </Listbox.Option>\n);\n\nconst SelectInfo = ({ label, hint }) => (\n  <>\n    {(label || hint) && (\n      <Box marginBottom=\"betweenFormControlAndLabel\">\n        {label && <Listbox.Label as={FieldLabel}>{label}</Listbox.Label>}\n        {hint && <FieldHint>{hint}</FieldHint>}\n      </Box>\n    )}\n  </>\n);\n\nconst SelectMenu = ({ children, floating, hasPortal, isOpen, ...props }) => {\n  const Root = hasPortal ? FloatingPortal : Fragment;\n  return (\n    <Root>\n      <MenuCardTransition>\n        <Listbox.Options\n          static\n          className=\"grn-context\"\n          ref={floating}\n          as={MenuCard}\n          isDisabled={!isOpen}\n          {...props}\n        >\n          {children}\n        </Listbox.Options>\n      </MenuCardTransition>\n    </Root>\n  );\n};\n\nconst getIsSelected = (isMultiple, option, selected) => {\n  if (!selected) return null;\n  if (isMultiple) {\n    return selected.some(selectedOption => selectedOption.content === option.content);\n  }\n\n  return option.value === selected.value;\n};\n\nexport const Select = ({\n  options,\n  value,\n  onChange,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  trigger: customTrigger,\n  triggerVariant = 'box',\n  label,\n  hint,\n  menuZIndex,\n  menuItemsHaveEllipsis = true,\n  allowMultiple,\n  hasPortal = true,\n  placeholder,\n  isDisabled,\n}) => {\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n  const rootWidth = triggerVariant === 'text' ? 'fit-content' : undefined;\n\n  const optionMap = useMemo(() => {\n    return new Map(options.map(option => [option.value, option]));\n  }, [options]);\n\n  const selected = useMemo(() => {\n    const valueIsValid = value !== null && value !== undefined;\n\n    if (allowMultiple) {\n      return valueIsValid ? value.map(v => optionMap.get(v)) : [];\n    }\n\n    return valueIsValid ? optionMap.get(value) : null;\n  }, [allowMultiple, optionMap, value]);\n\n  const listboxValue = useMemo(() => {\n    const valueIsValid = selected !== undefined && selected !== null;\n\n    if (!valueIsValid) {\n      if (allowMultiple) return [];\n      else return null;\n    }\n\n    return selected;\n  }, [allowMultiple, selected]);\n\n  return (\n    <Listbox\n      as={Root}\n      value={listboxValue}\n      onChange={onChange}\n      width={rootWidth}\n      multiple={allowMultiple}\n      disabled={isDisabled}\n    >\n      {({ open }) => (\n        <>\n          <SelectInfo label={label} hint={hint} />\n\n          <Box position=\"relative\" ref={reference}>\n            <SelectButton\n              customTrigger={customTrigger}\n              variant={triggerVariant}\n              isMultiple={allowMultiple}\n              selected={selected}\n              placeholder={placeholder}\n            />\n\n            <SelectMenu\n              placement={menuPlacement}\n              maxHeight={menuMaxHeight}\n              zIndex={menuZIndex}\n              floating={floating}\n              style={floatingStyles}\n              hasPortal={hasPortal}\n              isOpen={open}\n            >\n              {options.map((option, index) => {\n                const isSelected = getIsSelected(allowMultiple, option, selected);\n\n                if (option.type === 'divider') return <MenuItemDivider key={index} />;\n\n                return (\n                  <SelectMenuOption\n                    isSelected={isSelected}\n                    key={index}\n                    option={option}\n                    hasEllipsis={menuItemsHaveEllipsis}\n                    allowMultiple={allowMultiple}\n                  />\n                );\n              })}\n            </SelectMenu>\n          </Box>\n        </>\n      )}\n    </Listbox>\n  );\n};\n\nSelect.Label = FieldLabel;\nSelect.Hint = FieldHint;\nSelect.Trigger = Trigger;\n\nSelect.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.oneOfType([PropTypes.string, PropTypes.number, PropTypes.array]),\n  onChange: PropTypes.func.isRequired,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuZIndex: types.zIndex,\n  menuMaxHeight: types.dimension,\n  trigger: PropTypes.func,\n  triggerVariant: PropTypes.oneOf(['box', 'text']),\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  allowMultiple: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  placeholder: PropTypes.string,\n  isDisabled: PropTypes.bool,\n};\n"]} */",
|
|
102
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/select.jsx"],"names":[],"mappings":"AAyFuB","file":"../../src/components/select.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo } from 'react';\nimport styled from '@emotion/styled';\nimport { Box, Icon, Text, TextButton } from '.';\nimport { IconChevronDown } from '../icons';\nimport { Listbox } from '@headlessui/react';\nimport { getColor, getRadius, getSpace, getWeight } from '../utilities';\nimport { defaultProps, types } from '../types';\nimport {\n  fieldDisabledStyles,\n  FieldHint,\n  FieldLabel,\n  MenuCard,\n  MenuCardTransition,\n  MenuItem,\n  styles,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\n\nconst TriggerButton = styled.button`\n  ${styles.buttonReset};\n  ${styles.transitions};\n\n  color: inherit;\n  display: flex;\n  align-items: center;\n  gap: 8px;\n  border: none;\n  background: transparent;\n  padding: 0 ${getSpace('fieldPaddingX')};\n  border: 1px solid ${getColor('fieldBorder')};\n  font-weight: ${getWeight('normal')};\n  min-height: var(--grn-textbox-height-m);\n  border-radius: ${getRadius('s')};\n  width: 100%;\n  text-align: left;\n\n  &:hover {\n    border-color: ${getColor('fieldBorderHover')};\n  }\n\n  &[disabled] {\n    ${fieldDisabledStyles};\n    cursor: default;\n  }\n`;\n\nconst Trigger = forwardRef(({ children, variant = 'box', ...props }, ref) => (\n  <>\n    {variant === 'box' && (\n      <TriggerButton ref={ref} type=\"button\" {...props}>\n        <Text hasEllipsis>{children}</Text>\n        <Box marginLeft=\"auto\">\n          <Icon icon={<IconChevronDown />} />\n        </Box>\n      </TriggerButton>\n    )}\n    {variant === 'text' && (\n      <TextButton ref={ref} icon={<IconChevronDown />} iconPosition=\"right\" {...props}>\n        {children}\n      </TextButton>\n    )}\n  </>\n));\n\nconst getTriggerContent = (isMultiple, selected, placeholder) => {\n  if (!selected) {\n    if (placeholder) return <Text color=\"shade7\">{placeholder}</Text>;\n    return null;\n  }\n  if (isMultiple) {\n    return selected.map(option => option.content).join(', ');\n  }\n  return selected.content;\n};\n\nconst SelectButton = ({ customTrigger, variant, isMultiple, selected, placeholder }) => {\n  const props = {\n    variant,\n    children: getTriggerContent(isMultiple, selected, placeholder),\n  };\n  return (\n    <Listbox.Button as={Fragment}>\n      {customTrigger ? customTrigger({ props }) : <Trigger {...props} />}\n    </Listbox.Button>\n  );\n};\n\nconst Root = styled.div`\n  min-width: 0px;\n`;\n\nconst SelectMenuOption = ({\n  option,\n  isSelected,\n  menuItemsHaveEllipsis,\n  allowMultiple,\n  ...props\n}) => (\n  <Listbox.Option value={option} as={Fragment} disabled={option.isDisabled} {...props}>\n    {({ active }) => {\n      return (\n        <MenuItem\n          isSelected={isSelected}\n          isActive={active}\n          isDisabled={option.isDisabled}\n          hasEllipsis={menuItemsHaveEllipsis}\n        >\n          {option.content}\n        </MenuItem>\n      );\n    }}\n  </Listbox.Option>\n);\n\nconst SelectInfo = ({ label, hint }) => (\n  <>\n    {(label || hint) && (\n      <Box marginBottom=\"betweenFormControlAndLabel\">\n        {label && <Listbox.Label as={FieldLabel}>{label}</Listbox.Label>}\n        {hint && <FieldHint>{hint}</FieldHint>}\n      </Box>\n    )}\n  </>\n);\n\nconst SelectMenu = ({ children, floating, hasPortal, isOpen, ...props }) => {\n  const Root = hasPortal ? FloatingPortal : Fragment;\n  return (\n    <Root>\n      <MenuCardTransition>\n        <Listbox.Options\n          static\n          className=\"grn-context\"\n          ref={floating}\n          as={MenuCard}\n          isDisabled={!isOpen}\n          {...props}\n        >\n          {children}\n        </Listbox.Options>\n      </MenuCardTransition>\n    </Root>\n  );\n};\n\nconst getIsSelected = (isMultiple, option, selected) => {\n  if (!selected) return null;\n  if (isMultiple) {\n    return selected.some(selectedOption => selectedOption.content === option.content);\n  }\n\n  return option.value === selected.value;\n};\n\nexport const Select = ({\n  options,\n  value,\n  onChange,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  trigger: customTrigger,\n  triggerVariant = 'box',\n  label,\n  hint,\n  menuZIndex,\n  menuItemsHaveEllipsis = true,\n  allowMultiple,\n  hasPortal = true,\n  placeholder,\n  isDisabled,\n}) => {\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n  const rootWidth = triggerVariant === 'text' ? 'fit-content' : undefined;\n\n  const optionMap = useMemo(() => {\n    return new Map(options.map(option => [option.value, option]));\n  }, [options]);\n\n  const selected = useMemo(() => {\n    const valueIsValid = value !== null && value !== undefined;\n\n    if (allowMultiple) {\n      return valueIsValid ? value.map(v => optionMap.get(v)) : [];\n    }\n\n    return valueIsValid ? optionMap.get(value) : null;\n  }, [allowMultiple, optionMap, value]);\n\n  const listboxValue = useMemo(() => {\n    const valueIsValid = selected !== undefined && selected !== null;\n\n    if (!valueIsValid) {\n      if (allowMultiple) return [];\n      else return null;\n    }\n\n    return selected;\n  }, [allowMultiple, selected]);\n\n  return (\n    <Listbox\n      as={Root}\n      value={listboxValue}\n      onChange={onChange}\n      width={rootWidth}\n      multiple={allowMultiple}\n      disabled={isDisabled}\n    >\n      {({ open }) => (\n        <>\n          <SelectInfo label={label} hint={hint} />\n\n          <Box position=\"relative\" ref={reference}>\n            <SelectButton\n              customTrigger={customTrigger}\n              variant={triggerVariant}\n              isMultiple={allowMultiple}\n              selected={selected}\n              placeholder={placeholder}\n            />\n\n            <SelectMenu\n              placement={menuPlacement}\n              maxHeight={menuMaxHeight}\n              zIndex={menuZIndex}\n              floating={floating}\n              style={floatingStyles}\n              hasPortal={hasPortal}\n              isOpen={open}\n            >\n              {options.map((option, index) => {\n                const isSelected = getIsSelected(allowMultiple, option, selected);\n\n                if (option.type === 'divider') return <MenuItemDivider key={index} />;\n\n                return (\n                  <SelectMenuOption\n                    isSelected={isSelected}\n                    key={index}\n                    option={option}\n                    hasEllipsis={menuItemsHaveEllipsis}\n                    allowMultiple={allowMultiple}\n                  />\n                );\n              })}\n            </SelectMenu>\n          </Box>\n        </>\n      )}\n    </Listbox>\n  );\n};\n\nSelect.Label = FieldLabel;\nSelect.Hint = FieldHint;\nSelect.Trigger = Trigger;\n\nSelect.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.oneOfType([PropTypes.string, PropTypes.number, PropTypes.array]),\n  onChange: PropTypes.func.isRequired,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuZIndex: types.zIndex,\n  menuMaxHeight: types.dimension,\n  trigger: PropTypes.func,\n  triggerVariant: PropTypes.oneOf(['box', 'text']),\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  allowMultiple: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  placeholder: PropTypes.string,\n  isDisabled: PropTypes.bool,\n};\n"]} */",
|
|
111
103
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
112
104
|
});
|
|
113
105
|
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
106
|
+
const SelectMenuOption = _ref3 => {
|
|
107
|
+
let {
|
|
108
|
+
option,
|
|
109
|
+
isSelected,
|
|
110
|
+
menuItemsHaveEllipsis,
|
|
111
|
+
allowMultiple
|
|
112
|
+
} = _ref3,
|
|
119
113
|
props = _objectWithoutProperties(_ref3, _excluded2);
|
|
120
114
|
|
|
121
115
|
return ___EmotionJSX(Listbox.Option, _extends({
|
|
122
116
|
value: option,
|
|
123
117
|
as: Fragment,
|
|
124
118
|
disabled: option.isDisabled
|
|
125
|
-
}, props),
|
|
126
|
-
|
|
119
|
+
}, props), _ref4 => {
|
|
120
|
+
let {
|
|
121
|
+
active
|
|
122
|
+
} = _ref4;
|
|
127
123
|
return ___EmotionJSX(MenuItem, {
|
|
128
124
|
isSelected: isSelected,
|
|
129
125
|
isActive: active,
|
|
@@ -133,9 +129,11 @@ var SelectMenuOption = function SelectMenuOption(_ref3) {
|
|
|
133
129
|
});
|
|
134
130
|
};
|
|
135
131
|
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
132
|
+
const SelectInfo = _ref5 => {
|
|
133
|
+
let {
|
|
134
|
+
label,
|
|
135
|
+
hint
|
|
136
|
+
} = _ref5;
|
|
139
137
|
return ___EmotionJSX(React.Fragment, null, (label || hint) && ___EmotionJSX(Box, {
|
|
140
138
|
marginBottom: "betweenFormControlAndLabel"
|
|
141
139
|
}, label && ___EmotionJSX(Listbox.Label, {
|
|
@@ -143,14 +141,16 @@ var SelectInfo = function SelectInfo(_ref5) {
|
|
|
143
141
|
}, label), hint && ___EmotionJSX(FieldHint, null, hint)));
|
|
144
142
|
};
|
|
145
143
|
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
144
|
+
const SelectMenu = _ref6 => {
|
|
145
|
+
let {
|
|
146
|
+
children,
|
|
147
|
+
floating,
|
|
148
|
+
hasPortal,
|
|
149
|
+
isOpen
|
|
150
|
+
} = _ref6,
|
|
151
151
|
props = _objectWithoutProperties(_ref6, _excluded3);
|
|
152
152
|
|
|
153
|
-
|
|
153
|
+
const Root = hasPortal ? FloatingPortal : Fragment;
|
|
154
154
|
return ___EmotionJSX(Root, null, ___EmotionJSX(MenuCardTransition, null, ___EmotionJSX(Listbox.Options, _extends({
|
|
155
155
|
static: true,
|
|
156
156
|
className: "grn-context",
|
|
@@ -160,68 +160,58 @@ var SelectMenu = function SelectMenu(_ref6) {
|
|
|
160
160
|
}, props), children)));
|
|
161
161
|
};
|
|
162
162
|
|
|
163
|
-
|
|
163
|
+
const getIsSelected = (isMultiple, option, selected) => {
|
|
164
164
|
if (!selected) return null;
|
|
165
165
|
|
|
166
166
|
if (isMultiple) {
|
|
167
|
-
return selected.some(
|
|
168
|
-
return selectedOption.content === option.content;
|
|
169
|
-
});
|
|
167
|
+
return selected.some(selectedOption => selectedOption.content === option.content);
|
|
170
168
|
}
|
|
171
169
|
|
|
172
170
|
return option.value === selected.value;
|
|
173
171
|
};
|
|
174
172
|
|
|
175
|
-
export
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
menuWidth
|
|
200
|
-
menuPlacement
|
|
201
|
-
})
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
var rootWidth = triggerVariant === 'text' ? 'fit-content' : undefined;
|
|
207
|
-
var optionMap = useMemo(function () {
|
|
208
|
-
return new Map(options.map(function (option) {
|
|
209
|
-
return [option.value, option];
|
|
210
|
-
}));
|
|
173
|
+
export const Select = _ref7 => {
|
|
174
|
+
let {
|
|
175
|
+
options,
|
|
176
|
+
value,
|
|
177
|
+
onChange,
|
|
178
|
+
menuPlacement = defaultProps.menuPlacement,
|
|
179
|
+
menuWidth,
|
|
180
|
+
menuMaxHeight = defaultProps.menuMaxHeight,
|
|
181
|
+
trigger: customTrigger,
|
|
182
|
+
triggerVariant = 'box',
|
|
183
|
+
label,
|
|
184
|
+
hint,
|
|
185
|
+
menuZIndex,
|
|
186
|
+
menuItemsHaveEllipsis = true,
|
|
187
|
+
allowMultiple,
|
|
188
|
+
hasPortal = true,
|
|
189
|
+
placeholder,
|
|
190
|
+
isDisabled
|
|
191
|
+
} = _ref7;
|
|
192
|
+
const {
|
|
193
|
+
reference,
|
|
194
|
+
floating,
|
|
195
|
+
floatingStyles
|
|
196
|
+
} = useMenuPosition({
|
|
197
|
+
menuWidth,
|
|
198
|
+
menuPlacement
|
|
199
|
+
});
|
|
200
|
+
const rootWidth = triggerVariant === 'text' ? 'fit-content' : undefined;
|
|
201
|
+
const optionMap = useMemo(() => {
|
|
202
|
+
return new Map(options.map(option => [option.value, option]));
|
|
211
203
|
}, [options]);
|
|
212
|
-
|
|
213
|
-
|
|
204
|
+
const selected = useMemo(() => {
|
|
205
|
+
const valueIsValid = value !== null && value !== undefined;
|
|
214
206
|
|
|
215
207
|
if (allowMultiple) {
|
|
216
|
-
return valueIsValid ? value.map(
|
|
217
|
-
return optionMap.get(v);
|
|
218
|
-
}) : [];
|
|
208
|
+
return valueIsValid ? value.map(v => optionMap.get(v)) : [];
|
|
219
209
|
}
|
|
220
210
|
|
|
221
211
|
return valueIsValid ? optionMap.get(value) : null;
|
|
222
212
|
}, [allowMultiple, optionMap, value]);
|
|
223
|
-
|
|
224
|
-
|
|
213
|
+
const listboxValue = useMemo(() => {
|
|
214
|
+
const valueIsValid = selected !== undefined && selected !== null;
|
|
225
215
|
|
|
226
216
|
if (!valueIsValid) {
|
|
227
217
|
if (allowMultiple) return [];else return null;
|
|
@@ -236,8 +226,10 @@ export var Select = function Select(_ref7) {
|
|
|
236
226
|
width: rootWidth,
|
|
237
227
|
multiple: allowMultiple,
|
|
238
228
|
disabled: isDisabled
|
|
239
|
-
},
|
|
240
|
-
|
|
229
|
+
}, _ref8 => {
|
|
230
|
+
let {
|
|
231
|
+
open
|
|
232
|
+
} = _ref8;
|
|
241
233
|
return ___EmotionJSX(React.Fragment, null, ___EmotionJSX(SelectInfo, {
|
|
242
234
|
label: label,
|
|
243
235
|
hint: hint
|
|
@@ -258,8 +250,8 @@ export var Select = function Select(_ref7) {
|
|
|
258
250
|
style: floatingStyles,
|
|
259
251
|
hasPortal: hasPortal,
|
|
260
252
|
isOpen: open
|
|
261
|
-
}, options.map(
|
|
262
|
-
|
|
253
|
+
}, options.map((option, index) => {
|
|
254
|
+
const isSelected = getIsSelected(allowMultiple, option, selected);
|
|
263
255
|
if (option.type === 'divider') return ___EmotionJSX(MenuItemDivider, {
|
|
264
256
|
key: index
|
|
265
257
|
});
|
package/es/components/slider.js
CHANGED
|
@@ -1,9 +1,5 @@
|
|
|
1
|
-
import "core-js/modules/es.object.keys.js";
|
|
2
|
-
import "core-js/modules/es.array.index-of.js";
|
|
3
|
-
import "core-js/modules/es.symbol.js";
|
|
4
|
-
import "core-js/modules/es.object.assign.js";
|
|
5
1
|
import _styled from "@emotion/styled/base";
|
|
6
|
-
|
|
2
|
+
const _excluded = ["min", "max", "value", "step", "onChange", "id", "label", "hint"];
|
|
7
3
|
|
|
8
4
|
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
9
5
|
|
|
@@ -18,53 +14,53 @@ import { FieldHint, FieldLabel, transitionStyles } from '../foundational';
|
|
|
18
14
|
import { getColor, getSpace } from '../utilities';
|
|
19
15
|
import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
20
16
|
|
|
21
|
-
|
|
17
|
+
const InputWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
22
18
|
target: "el2kgbu2"
|
|
23
19
|
} : {
|
|
24
20
|
target: "el2kgbu2",
|
|
25
21
|
label: "InputWrapper"
|
|
26
|
-
})("--trackHeight:2px;--sliderHeight:16px;--thumbSize:var(--sliderHeight);--thumbBorder:1px ", getColor('shade6'), ";--trackColor:", getColor('fade2'), ";--trackFilledColor:", getColor('selection'), ";@media (hover: hover){&:hover{--trackColor:", getColor('fade4'), ";}}position:relative;",
|
|
27
|
-
|
|
22
|
+
})("--trackHeight:2px;--sliderHeight:16px;--thumbSize:var(--sliderHeight);--thumbBorder:1px ", getColor('shade6'), ";--trackColor:", getColor('fade2'), ";--trackFilledColor:", getColor('selection'), ";@media (hover: hover){&:hover{--trackColor:", getColor('fade4'), ";}}position:relative;", _ref => {
|
|
23
|
+
let {
|
|
24
|
+
marginTop
|
|
25
|
+
} = _ref;
|
|
28
26
|
return marginTop && "margin-top: ".concat(marginTop);
|
|
29
27
|
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3NsaWRlci5qc3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTytCIiwiZmlsZSI6Ii4uLy4uL3NyYy9jb21wb25lbnRzL3NsaWRlci5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQcm9wVHlwZXMgfSBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCBSZWFjdCwgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgdHlwZXMgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyBGaWVsZEhpbnQsIEZpZWxkTGFiZWwsIHRyYW5zaXRpb25TdHlsZXMgfSBmcm9tICcuLi9mb3VuZGF0aW9uYWwnO1xuaW1wb3J0IHsgZ2V0Q29sb3IsIGdldFNwYWNlIH0gZnJvbSAnLi4vdXRpbGl0aWVzJztcblxuY29uc3QgSW5wdXRXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgLS10cmFja0hlaWdodDogMnB4O1xuICAtLXNsaWRlckhlaWdodDogMTZweDtcbiAgLS10aHVtYlNpemU6IHZhcigtLXNsaWRlckhlaWdodCk7XG4gIC0tdGh1bWJCb3JkZXI6IDFweCAke2dldENvbG9yKCdzaGFkZTYnKX07XG4gIC0tdHJhY2tDb2xvcjogJHtnZXRDb2xvcignZmFkZTInKX07XG4gIC0tdHJhY2tGaWxsZWRDb2xvcjogJHtnZXRDb2xvcignc2VsZWN0aW9uJyl9O1xuXG4gIEBtZWRpYSAoaG92ZXI6IGhvdmVyKSB7XG4gICAgJjpob3ZlciB7XG4gICAgICAtLXRyYWNrQ29sb3I6ICR7Z2V0Q29sb3IoJ2ZhZGU0Jyl9O1xuICAgIH1cbiAgfVxuXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgJHsoeyBtYXJnaW5Ub3AgfSkgPT4gbWFyZ2luVG9wICYmIGBtYXJnaW4tdG9wOiAke21hcmdpblRvcH1gfTtcbmA7XG5cbmNvbnN0IFRyYWNrID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB0b3A6IDA7XG4gIGJvdHRvbTogMDtcbiAgbWFyZ2luOiBhdXRvO1xuICBoZWlnaHQ6IHZhcigtLXRyYWNrSGVpZ2h0KTtcbiAgd2lkdGg6IDEwMCU7XG4gIGJhY2tncm91bmQ6IHZhcigtLXRyYWNrQ29sb3IpO1xuICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgJHt0cmFuc2l0aW9uU3R5bGVzfTtcblxuICAmOjpiZWZvcmUge1xuICAgIGNvbnRlbnQ6ICcnO1xuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICB0b3A6IDA7XG4gICAgYm90dG9tOiAwO1xuICAgIG1hcmdpbjogYXV0bztcbiAgICBoZWlnaHQ6IHZhcigtLXRyYWNrSGVpZ2h0KTtcbiAgICBiYWNrZ3JvdW5kOiB2YXIoLS10cmFja0ZpbGxlZENvbG9yKTtcbiAgICB3aWR0aDogdmFyKC0tdmFsdWUpO1xuICAgIGRpc3BsYXk6IGJsb2NrO1xuICAgIGJvcmRlci1yYWRpdXM6IHZhcigtLXRyYWNrSGVpZ2h0KSAwIDAgdmFyKC0tdHJhY2tIZWlnaHQpO1xuICB9XG5gO1xuXG5jb25zdCB0cmFja1N0eWxlcyA9IGBcbiAgd2lkdGg6IDEwMCU7XG4gIGhlaWdodDogdmFyKC0tc2xpZGVySGVpZ2h0KTtcbiAgY3Vyc29yOiBwb2ludGVyO1xuICBiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcbiAgei1pbmRleDogMTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuYDtcblxuY29uc3QgdGh1bWJTdHlsZXMgPSBgXG4gIGFwcGVhcmFuY2U6IG5vbmU7XG4gIGhlaWdodDogdmFyKC0tdGh1bWJTaXplKTtcbiAgd2lkdGg6IHZhcigtLXRodW1iU2l6ZSk7XG4gIGJvcmRlci1yYWRpdXM6IDEwMHB4O1xuICBiYWNrZ3JvdW5kOiAke2dldENvbG9yKCdzaGFkZTEnKX07XG4gIGJveC1zaGFkb3c6IGluc2V0IDAgMCAwIHZhcigtLXRodW1iQm9yZGVyKTtcbiAgY3Vyc29yOiBwb2ludGVyO1xuICBib3JkZXI6IG5vbmU7XG5gO1xuXG5jb25zdCB0aHVtYkZvY3VzU3R5bGVzID0gYFxuICAtLXRodW1iQm9yZGVyOiAycHggJHtnZXRDb2xvcignc2VsZWN0aW9uJyl9O1xuYDtcblxuY29uc3QgSW5wdXRGaWVsZCA9IHN0eWxlZC5pbnB1dGBcbiAgYXBwZWFyYW5jZTogbm9uZTtcbiAgd2lkdGg6IDEwMCU7XG4gIG1hcmdpbjogMDtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG5cbiAgJjo6LXdlYmtpdC1zbGlkZXItcnVubmFibGUtdHJhY2sge1xuICAgICR7dHJhY2tTdHlsZXN9XG4gIH1cblxuICAmOjotbW96LXJhbmdlLXRyYWNrIHtcbiAgICAke3RyYWNrU3R5bGVzfVxuICB9XG5cbiAgJjo6LXdlYmtpdC1zbGlkZXItdGh1bWIge1xuICAgICR7dGh1bWJTdHlsZXN9XG4gIH1cblxuICAmOjotbW96LXJhbmdlLXRodW1iIHtcbiAgICAke3RodW1iU3R5bGVzfVxuICB9XG5cbiAgJjpmb2N1cy12aXNpYmxlOjotd2Via2l0LXNsaWRlci10aHVtYiB7XG4gICAgJHt0aHVtYkZvY3VzU3R5bGVzfVxuICB9XG5cbiAgJjpmb2N1cy12aXNpYmxlOjotbW96LXJhbmdlLXRodW1iIHtcbiAgICAke3RodW1iRm9jdXNTdHlsZXN9XG4gIH1cblxuICAmOmZvY3VzIHtcbiAgICBvdXRsaW5lOiBub25lO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgU2xpZGVyID0gZm9yd2FyZFJlZihcbiAgKHsgbWluID0gMCwgbWF4ID0gMTAwLCB2YWx1ZSwgc3RlcCwgb25DaGFuZ2UsIGlkLCBsYWJlbCwgaGludCwgLi4ucHJvcHMgfSwgcmVmKSA9PiB7XG4gICAgY29uc3QgZ2V0UGVyY2VudGFnZSA9ICgpID0+ICgodmFsdWUgLSBtaW4pIC8gKG1heCAtIG1pbikpICogMTAwO1xuICAgIGNvbnN0IGZpZWxkTWFyZ2luVG9wID0gbGFiZWwgfHwgaGludCA/IGdldFNwYWNlKCdiZXR3ZWVuRm9ybUNvbnRyb2xBbmRMYWJlbCcpIDogdW5kZWZpbmVkO1xuICAgIGNvbnN0IHZhbHVlU3R5bGUgPSB7ICctLXZhbHVlJzogYCR7Z2V0UGVyY2VudGFnZSgpfSVgIH07XG5cbiAgICByZXR1cm4gKFxuICAgICAgPGRpdj5cbiAgICAgICAge2xhYmVsICYmIDxGaWVsZExhYmVsIGh0bWxGb3I9e2lkfT57bGFiZWx9PC9GaWVsZExhYmVsPn1cbiAgICAgICAge2hpbnQgJiYgPEZpZWxkSGludD57aGludH08L0ZpZWxkSGludD59XG4gICAgICAgIDxJbnB1dFdyYXBwZXIgc3R5bGU9e3ZhbHVlU3R5bGV9IG1hcmdpblRvcD17ZmllbGRNYXJnaW5Ub3B9PlxuICAgICAgICAgIDxUcmFjayAvPlxuICAgICAgICAgIDxJbnB1dEZpZWxkXG4gICAgICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgICAgIGlkPXtpZH1cbiAgICAgICAgICAgIHR5cGU9XCJyYW5nZVwiXG4gICAgICAgICAgICBtaW49e21pbn1cbiAgICAgICAgICAgIG1heD17bWF4fVxuICAgICAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICAgICAgc3RlcD17c3RlcH1cbiAgICAgICAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgICAgICAgIHsuLi5wcm9wc31cbiAgICAgICAgICAvPlxuICAgICAgICA8L0lucHV0V3JhcHBlcj5cbiAgICAgIDwvZGl2PlxuICAgICk7XG4gIH0sXG4pO1xuXG5TbGlkZXIuTGFiZWwgPSBGaWVsZExhYmVsO1xuU2xpZGVyLkhpbnQgPSBGaWVsZEhpbnQ7XG5cblNsaWRlci5wcm9wVHlwZXMgPSB7XG4gIG1pbjogUHJvcFR5cGVzLm51bWJlcixcbiAgbWF4OiBQcm9wVHlwZXMubnVtYmVyLFxuICB2YWx1ZTogUHJvcFR5cGVzLm51bWJlcixcbiAgc3RlcDogUHJvcFR5cGVzLm51bWJlcixcbiAgb25DaGFuZ2U6IFByb3BUeXBlcy5mdW5jLFxuICBsYWJlbDogdHlwZXMubGFiZWwsXG4gIGhpbnQ6IHR5cGVzLmhpbnQsXG4gIGlkOiBQcm9wVHlwZXMuc3RyaW5nLFxufTtcbiJdfQ== */"));
|
|
30
28
|
|
|
31
|
-
|
|
29
|
+
const Track = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
32
30
|
target: "el2kgbu1"
|
|
33
31
|
} : {
|
|
34
32
|
target: "el2kgbu1",
|
|
35
33
|
label: "Track"
|
|
36
34
|
})("position:absolute;top:0;bottom:0;margin:auto;height:var(--trackHeight);width:100%;background:var(--trackColor);pointer-events:none;", transitionStyles, ";&::before{content:'';position:absolute;top:0;bottom:0;margin:auto;height:var(--trackHeight);background:var(--trackFilledColor);width:var(--value);display:block;border-radius:var(--trackHeight) 0 0 var(--trackHeight);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3NsaWRlci5qc3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUJ3QiIsImZpbGUiOiIuLi8uLi9zcmMvY29tcG9uZW50cy9zbGlkZXIuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUHJvcFR5cGVzIH0gZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgUmVhY3QsIHsgZm9yd2FyZFJlZiB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IHR5cGVzIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgRmllbGRIaW50LCBGaWVsZExhYmVsLCB0cmFuc2l0aW9uU3R5bGVzIH0gZnJvbSAnLi4vZm91bmRhdGlvbmFsJztcbmltcG9ydCB7IGdldENvbG9yLCBnZXRTcGFjZSB9IGZyb20gJy4uL3V0aWxpdGllcyc7XG5cbmNvbnN0IElucHV0V3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIC0tdHJhY2tIZWlnaHQ6IDJweDtcbiAgLS1zbGlkZXJIZWlnaHQ6IDE2cHg7XG4gIC0tdGh1bWJTaXplOiB2YXIoLS1zbGlkZXJIZWlnaHQpO1xuICAtLXRodW1iQm9yZGVyOiAxcHggJHtnZXRDb2xvcignc2hhZGU2Jyl9O1xuICAtLXRyYWNrQ29sb3I6ICR7Z2V0Q29sb3IoJ2ZhZGUyJyl9O1xuICAtLXRyYWNrRmlsbGVkQ29sb3I6ICR7Z2V0Q29sb3IoJ3NlbGVjdGlvbicpfTtcblxuICBAbWVkaWEgKGhvdmVyOiBob3Zlcikge1xuICAgICY6aG92ZXIge1xuICAgICAgLS10cmFja0NvbG9yOiAke2dldENvbG9yKCdmYWRlNCcpfTtcbiAgICB9XG4gIH1cblxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gICR7KHsgbWFyZ2luVG9wIH0pID0+IG1hcmdpblRvcCAmJiBgbWFyZ2luLXRvcDogJHttYXJnaW5Ub3B9YH07XG5gO1xuXG5jb25zdCBUcmFjayA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgdG9wOiAwO1xuICBib3R0b206IDA7XG4gIG1hcmdpbjogYXV0bztcbiAgaGVpZ2h0OiB2YXIoLS10cmFja0hlaWdodCk7XG4gIHdpZHRoOiAxMDAlO1xuICBiYWNrZ3JvdW5kOiB2YXIoLS10cmFja0NvbG9yKTtcbiAgcG9pbnRlci1ldmVudHM6IG5vbmU7XG4gICR7dHJhbnNpdGlvblN0eWxlc307XG5cbiAgJjo6YmVmb3JlIHtcbiAgICBjb250ZW50OiAnJztcbiAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgdG9wOiAwO1xuICAgIGJvdHRvbTogMDtcbiAgICBtYXJnaW46IGF1dG87XG4gICAgaGVpZ2h0OiB2YXIoLS10cmFja0hlaWdodCk7XG4gICAgYmFja2dyb3VuZDogdmFyKC0tdHJhY2tGaWxsZWRDb2xvcik7XG4gICAgd2lkdGg6IHZhcigtLXZhbHVlKTtcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICBib3JkZXItcmFkaXVzOiB2YXIoLS10cmFja0hlaWdodCkgMCAwIHZhcigtLXRyYWNrSGVpZ2h0KTtcbiAgfVxuYDtcblxuY29uc3QgdHJhY2tTdHlsZXMgPSBgXG4gIHdpZHRoOiAxMDAlO1xuICBoZWlnaHQ6IHZhcigtLXNsaWRlckhlaWdodCk7XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gIHotaW5kZXg6IDE7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbmA7XG5cbmNvbnN0IHRodW1iU3R5bGVzID0gYFxuICBhcHBlYXJhbmNlOiBub25lO1xuICBoZWlnaHQ6IHZhcigtLXRodW1iU2l6ZSk7XG4gIHdpZHRoOiB2YXIoLS10aHVtYlNpemUpO1xuICBib3JkZXItcmFkaXVzOiAxMDBweDtcbiAgYmFja2dyb3VuZDogJHtnZXRDb2xvcignc2hhZGUxJyl9O1xuICBib3gtc2hhZG93OiBpbnNldCAwIDAgMCB2YXIoLS10aHVtYkJvcmRlcik7XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgYm9yZGVyOiBub25lO1xuYDtcblxuY29uc3QgdGh1bWJGb2N1c1N0eWxlcyA9IGBcbiAgLS10aHVtYkJvcmRlcjogMnB4ICR7Z2V0Q29sb3IoJ3NlbGVjdGlvbicpfTtcbmA7XG5cbmNvbnN0IElucHV0RmllbGQgPSBzdHlsZWQuaW5wdXRgXG4gIGFwcGVhcmFuY2U6IG5vbmU7XG4gIHdpZHRoOiAxMDAlO1xuICBtYXJnaW46IDA7XG4gIGRpc3BsYXk6IGJsb2NrO1xuICBiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuXG4gICY6Oi13ZWJraXQtc2xpZGVyLXJ1bm5hYmxlLXRyYWNrIHtcbiAgICAke3RyYWNrU3R5bGVzfVxuICB9XG5cbiAgJjo6LW1vei1yYW5nZS10cmFjayB7XG4gICAgJHt0cmFja1N0eWxlc31cbiAgfVxuXG4gICY6Oi13ZWJraXQtc2xpZGVyLXRodW1iIHtcbiAgICAke3RodW1iU3R5bGVzfVxuICB9XG5cbiAgJjo6LW1vei1yYW5nZS10aHVtYiB7XG4gICAgJHt0aHVtYlN0eWxlc31cbiAgfVxuXG4gICY6Zm9jdXMtdmlzaWJsZTo6LXdlYmtpdC1zbGlkZXItdGh1bWIge1xuICAgICR7dGh1bWJGb2N1c1N0eWxlc31cbiAgfVxuXG4gICY6Zm9jdXMtdmlzaWJsZTo6LW1vei1yYW5nZS10aHVtYiB7XG4gICAgJHt0aHVtYkZvY3VzU3R5bGVzfVxuICB9XG5cbiAgJjpmb2N1cyB7XG4gICAgb3V0bGluZTogbm9uZTtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFNsaWRlciA9IGZvcndhcmRSZWYoXG4gICh7IG1pbiA9IDAsIG1heCA9IDEwMCwgdmFsdWUsIHN0ZXAsIG9uQ2hhbmdlLCBpZCwgbGFiZWwsIGhpbnQsIC4uLnByb3BzIH0sIHJlZikgPT4ge1xuICAgIGNvbnN0IGdldFBlcmNlbnRhZ2UgPSAoKSA9PiAoKHZhbHVlIC0gbWluKSAvIChtYXggLSBtaW4pKSAqIDEwMDtcbiAgICBjb25zdCBmaWVsZE1hcmdpblRvcCA9IGxhYmVsIHx8IGhpbnQgPyBnZXRTcGFjZSgnYmV0d2VlbkZvcm1Db250cm9sQW5kTGFiZWwnKSA6IHVuZGVmaW5lZDtcbiAgICBjb25zdCB2YWx1ZVN0eWxlID0geyAnLS12YWx1ZSc6IGAke2dldFBlcmNlbnRhZ2UoKX0lYCB9O1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxkaXY+XG4gICAgICAgIHtsYWJlbCAmJiA8RmllbGRMYWJlbCBodG1sRm9yPXtpZH0+e2xhYmVsfTwvRmllbGRMYWJlbD59XG4gICAgICAgIHtoaW50ICYmIDxGaWVsZEhpbnQ+e2hpbnR9PC9GaWVsZEhpbnQ+fVxuICAgICAgICA8SW5wdXRXcmFwcGVyIHN0eWxlPXt2YWx1ZVN0eWxlfSBtYXJnaW5Ub3A9e2ZpZWxkTWFyZ2luVG9wfT5cbiAgICAgICAgICA8VHJhY2sgLz5cbiAgICAgICAgICA8SW5wdXRGaWVsZFxuICAgICAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgICAgICBpZD17aWR9XG4gICAgICAgICAgICB0eXBlPVwicmFuZ2VcIlxuICAgICAgICAgICAgbWluPXttaW59XG4gICAgICAgICAgICBtYXg9e21heH1cbiAgICAgICAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgICAgICAgIHN0ZXA9e3N0ZXB9XG4gICAgICAgICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICAgICAgICB7Li4ucHJvcHN9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9JbnB1dFdyYXBwZXI+XG4gICAgICA8L2Rpdj5cbiAgICApO1xuICB9LFxuKTtcblxuU2xpZGVyLkxhYmVsID0gRmllbGRMYWJlbDtcblNsaWRlci5IaW50ID0gRmllbGRIaW50O1xuXG5TbGlkZXIucHJvcFR5cGVzID0ge1xuICBtaW46IFByb3BUeXBlcy5udW1iZXIsXG4gIG1heDogUHJvcFR5cGVzLm51bWJlcixcbiAgdmFsdWU6IFByb3BUeXBlcy5udW1iZXIsXG4gIHN0ZXA6IFByb3BUeXBlcy5udW1iZXIsXG4gIG9uQ2hhbmdlOiBQcm9wVHlwZXMuZnVuYyxcbiAgbGFiZWw6IHR5cGVzLmxhYmVsLFxuICBoaW50OiB0eXBlcy5oaW50LFxuICBpZDogUHJvcFR5cGVzLnN0cmluZyxcbn07XG4iXX0= */"));
|
|
37
35
|
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
36
|
+
const trackStyles = "\n width: 100%;\n height: var(--sliderHeight);\n cursor: pointer;\n background: transparent;\n z-index: 1;\n position: relative;\n";
|
|
37
|
+
const thumbStyles = "\n appearance: none;\n height: var(--thumbSize);\n width: var(--thumbSize);\n border-radius: 100px;\n background: ".concat(getColor('shade1'), ";\n box-shadow: inset 0 0 0 var(--thumbBorder);\n cursor: pointer;\n border: none;\n");
|
|
38
|
+
const thumbFocusStyles = "\n --thumbBorder: 2px ".concat(getColor('selection'), ";\n");
|
|
41
39
|
|
|
42
|
-
|
|
40
|
+
const InputField = /*#__PURE__*/_styled("input", process.env.NODE_ENV === "production" ? {
|
|
43
41
|
target: "el2kgbu0"
|
|
44
42
|
} : {
|
|
45
43
|
target: "el2kgbu0",
|
|
46
44
|
label: "InputField"
|
|
47
45
|
})("appearance:none;width:100%;margin:0;display:block;background:transparent;position:relative;&::-webkit-slider-runnable-track{", trackStyles, ";}&::-moz-range-track{", trackStyles, ";}&::-webkit-slider-thumb{", thumbStyles, ";}&::-moz-range-thumb{", thumbStyles, ";}&:focus-visible::-webkit-slider-thumb{", thumbFocusStyles, ";}&:focus-visible::-moz-range-thumb{", thumbFocusStyles, ";}&:focus{outline:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3NsaWRlci5qc3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEUrQiIsImZpbGUiOiIuLi8uLi9zcmMvY29tcG9uZW50cy9zbGlkZXIuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUHJvcFR5cGVzIH0gZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgUmVhY3QsIHsgZm9yd2FyZFJlZiB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IHR5cGVzIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgRmllbGRIaW50LCBGaWVsZExhYmVsLCB0cmFuc2l0aW9uU3R5bGVzIH0gZnJvbSAnLi4vZm91bmRhdGlvbmFsJztcbmltcG9ydCB7IGdldENvbG9yLCBnZXRTcGFjZSB9IGZyb20gJy4uL3V0aWxpdGllcyc7XG5cbmNvbnN0IElucHV0V3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIC0tdHJhY2tIZWlnaHQ6IDJweDtcbiAgLS1zbGlkZXJIZWlnaHQ6IDE2cHg7XG4gIC0tdGh1bWJTaXplOiB2YXIoLS1zbGlkZXJIZWlnaHQpO1xuICAtLXRodW1iQm9yZGVyOiAxcHggJHtnZXRDb2xvcignc2hhZGU2Jyl9O1xuICAtLXRyYWNrQ29sb3I6ICR7Z2V0Q29sb3IoJ2ZhZGUyJyl9O1xuICAtLXRyYWNrRmlsbGVkQ29sb3I6ICR7Z2V0Q29sb3IoJ3NlbGVjdGlvbicpfTtcblxuICBAbWVkaWEgKGhvdmVyOiBob3Zlcikge1xuICAgICY6aG92ZXIge1xuICAgICAgLS10cmFja0NvbG9yOiAke2dldENvbG9yKCdmYWRlNCcpfTtcbiAgICB9XG4gIH1cblxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gICR7KHsgbWFyZ2luVG9wIH0pID0+IG1hcmdpblRvcCAmJiBgbWFyZ2luLXRvcDogJHttYXJnaW5Ub3B9YH07XG5gO1xuXG5jb25zdCBUcmFjayA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgdG9wOiAwO1xuICBib3R0b206IDA7XG4gIG1hcmdpbjogYXV0bztcbiAgaGVpZ2h0OiB2YXIoLS10cmFja0hlaWdodCk7XG4gIHdpZHRoOiAxMDAlO1xuICBiYWNrZ3JvdW5kOiB2YXIoLS10cmFja0NvbG9yKTtcbiAgcG9pbnRlci1ldmVudHM6IG5vbmU7XG4gICR7dHJhbnNpdGlvblN0eWxlc307XG5cbiAgJjo6YmVmb3JlIHtcbiAgICBjb250ZW50OiAnJztcbiAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgdG9wOiAwO1xuICAgIGJvdHRvbTogMDtcbiAgICBtYXJnaW46IGF1dG87XG4gICAgaGVpZ2h0OiB2YXIoLS10cmFja0hlaWdodCk7XG4gICAgYmFja2dyb3VuZDogdmFyKC0tdHJhY2tGaWxsZWRDb2xvcik7XG4gICAgd2lkdGg6IHZhcigtLXZhbHVlKTtcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICBib3JkZXItcmFkaXVzOiB2YXIoLS10cmFja0hlaWdodCkgMCAwIHZhcigtLXRyYWNrSGVpZ2h0KTtcbiAgfVxuYDtcblxuY29uc3QgdHJhY2tTdHlsZXMgPSBgXG4gIHdpZHRoOiAxMDAlO1xuICBoZWlnaHQ6IHZhcigtLXNsaWRlckhlaWdodCk7XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gIHotaW5kZXg6IDE7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbmA7XG5cbmNvbnN0IHRodW1iU3R5bGVzID0gYFxuICBhcHBlYXJhbmNlOiBub25lO1xuICBoZWlnaHQ6IHZhcigtLXRodW1iU2l6ZSk7XG4gIHdpZHRoOiB2YXIoLS10aHVtYlNpemUpO1xuICBib3JkZXItcmFkaXVzOiAxMDBweDtcbiAgYmFja2dyb3VuZDogJHtnZXRDb2xvcignc2hhZGUxJyl9O1xuICBib3gtc2hhZG93OiBpbnNldCAwIDAgMCB2YXIoLS10aHVtYkJvcmRlcik7XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgYm9yZGVyOiBub25lO1xuYDtcblxuY29uc3QgdGh1bWJGb2N1c1N0eWxlcyA9IGBcbiAgLS10aHVtYkJvcmRlcjogMnB4ICR7Z2V0Q29sb3IoJ3NlbGVjdGlvbicpfTtcbmA7XG5cbmNvbnN0IElucHV0RmllbGQgPSBzdHlsZWQuaW5wdXRgXG4gIGFwcGVhcmFuY2U6IG5vbmU7XG4gIHdpZHRoOiAxMDAlO1xuICBtYXJnaW46IDA7XG4gIGRpc3BsYXk6IGJsb2NrO1xuICBiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuXG4gICY6Oi13ZWJraXQtc2xpZGVyLXJ1bm5hYmxlLXRyYWNrIHtcbiAgICAke3RyYWNrU3R5bGVzfVxuICB9XG5cbiAgJjo6LW1vei1yYW5nZS10cmFjayB7XG4gICAgJHt0cmFja1N0eWxlc31cbiAgfVxuXG4gICY6Oi13ZWJraXQtc2xpZGVyLXRodW1iIHtcbiAgICAke3RodW1iU3R5bGVzfVxuICB9XG5cbiAgJjo6LW1vei1yYW5nZS10aHVtYiB7XG4gICAgJHt0aHVtYlN0eWxlc31cbiAgfVxuXG4gICY6Zm9jdXMtdmlzaWJsZTo6LXdlYmtpdC1zbGlkZXItdGh1bWIge1xuICAgICR7dGh1bWJGb2N1c1N0eWxlc31cbiAgfVxuXG4gICY6Zm9jdXMtdmlzaWJsZTo6LW1vei1yYW5nZS10aHVtYiB7XG4gICAgJHt0aHVtYkZvY3VzU3R5bGVzfVxuICB9XG5cbiAgJjpmb2N1cyB7XG4gICAgb3V0bGluZTogbm9uZTtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFNsaWRlciA9IGZvcndhcmRSZWYoXG4gICh7IG1pbiA9IDAsIG1heCA9IDEwMCwgdmFsdWUsIHN0ZXAsIG9uQ2hhbmdlLCBpZCwgbGFiZWwsIGhpbnQsIC4uLnByb3BzIH0sIHJlZikgPT4ge1xuICAgIGNvbnN0IGdldFBlcmNlbnRhZ2UgPSAoKSA9PiAoKHZhbHVlIC0gbWluKSAvIChtYXggLSBtaW4pKSAqIDEwMDtcbiAgICBjb25zdCBmaWVsZE1hcmdpblRvcCA9IGxhYmVsIHx8IGhpbnQgPyBnZXRTcGFjZSgnYmV0d2VlbkZvcm1Db250cm9sQW5kTGFiZWwnKSA6IHVuZGVmaW5lZDtcbiAgICBjb25zdCB2YWx1ZVN0eWxlID0geyAnLS12YWx1ZSc6IGAke2dldFBlcmNlbnRhZ2UoKX0lYCB9O1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxkaXY+XG4gICAgICAgIHtsYWJlbCAmJiA8RmllbGRMYWJlbCBodG1sRm9yPXtpZH0+e2xhYmVsfTwvRmllbGRMYWJlbD59XG4gICAgICAgIHtoaW50ICYmIDxGaWVsZEhpbnQ+e2hpbnR9PC9GaWVsZEhpbnQ+fVxuICAgICAgICA8SW5wdXRXcmFwcGVyIHN0eWxlPXt2YWx1ZVN0eWxlfSBtYXJnaW5Ub3A9e2ZpZWxkTWFyZ2luVG9wfT5cbiAgICAgICAgICA8VHJhY2sgLz5cbiAgICAgICAgICA8SW5wdXRGaWVsZFxuICAgICAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgICAgICBpZD17aWR9XG4gICAgICAgICAgICB0eXBlPVwicmFuZ2VcIlxuICAgICAgICAgICAgbWluPXttaW59XG4gICAgICAgICAgICBtYXg9e21heH1cbiAgICAgICAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgICAgICAgIHN0ZXA9e3N0ZXB9XG4gICAgICAgICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICAgICAgICB7Li4ucHJvcHN9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9JbnB1dFdyYXBwZXI+XG4gICAgICA8L2Rpdj5cbiAgICApO1xuICB9LFxuKTtcblxuU2xpZGVyLkxhYmVsID0gRmllbGRMYWJlbDtcblNsaWRlci5IaW50ID0gRmllbGRIaW50O1xuXG5TbGlkZXIucHJvcFR5cGVzID0ge1xuICBtaW46IFByb3BUeXBlcy5udW1iZXIsXG4gIG1heDogUHJvcFR5cGVzLm51bWJlcixcbiAgdmFsdWU6IFByb3BUeXBlcy5udW1iZXIsXG4gIHN0ZXA6IFByb3BUeXBlcy5udW1iZXIsXG4gIG9uQ2hhbmdlOiBQcm9wVHlwZXMuZnVuYyxcbiAgbGFiZWw6IHR5cGVzLmxhYmVsLFxuICBoaW50OiB0eXBlcy5oaW50LFxuICBpZDogUHJvcFR5cGVzLnN0cmluZyxcbn07XG4iXX0= */"));
|
|
48
46
|
|
|
49
|
-
export
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
47
|
+
export const Slider = /*#__PURE__*/forwardRef((_ref2, ref) => {
|
|
48
|
+
let {
|
|
49
|
+
min = 0,
|
|
50
|
+
max = 100,
|
|
51
|
+
value,
|
|
52
|
+
step,
|
|
53
|
+
onChange,
|
|
54
|
+
id,
|
|
55
|
+
label,
|
|
56
|
+
hint
|
|
57
|
+
} = _ref2,
|
|
60
58
|
props = _objectWithoutProperties(_ref2, _excluded);
|
|
61
59
|
|
|
62
|
-
|
|
63
|
-
return (value - min) / (max - min) * 100;
|
|
64
|
-
};
|
|
60
|
+
const getPercentage = () => (value - min) / (max - min) * 100;
|
|
65
61
|
|
|
66
|
-
|
|
67
|
-
|
|
62
|
+
const fieldMarginTop = label || hint ? getSpace('betweenFormControlAndLabel') : undefined;
|
|
63
|
+
const valueStyle = {
|
|
68
64
|
'--value': "".concat(getPercentage(), "%")
|
|
69
65
|
};
|
|
70
66
|
return ___EmotionJSX("div", null, label && ___EmotionJSX(FieldLabel, {
|
package/es/components/spinner.js
CHANGED
|
@@ -1,12 +1,5 @@
|
|
|
1
|
-
import "core-js/modules/es.array.slice.js";
|
|
2
|
-
import "core-js/modules/es.object.freeze.js";
|
|
3
|
-
import "core-js/modules/es.object.define-properties.js";
|
|
4
|
-
import "core-js/modules/es.object.keys.js";
|
|
5
|
-
import "core-js/modules/es.array.index-of.js";
|
|
6
|
-
import "core-js/modules/es.symbol.js";
|
|
7
|
-
import "core-js/modules/es.object.assign.js";
|
|
8
1
|
import _styled from "@emotion/styled/base";
|
|
9
|
-
|
|
2
|
+
const _excluded = ["size", "color"];
|
|
10
3
|
|
|
11
4
|
var _templateObject;
|
|
12
5
|
|
|
@@ -24,29 +17,21 @@ import PropTypes from 'prop-types';
|
|
|
24
17
|
import { keyframes } from '@emotion/react';
|
|
25
18
|
import { types } from '../types';
|
|
26
19
|
import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
27
|
-
|
|
28
|
-
|
|
20
|
+
const spin = keyframes(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n to {\n transform: rotate(360deg);\n }\n"])));
|
|
21
|
+
const circleStyles = "\n content: '';\n position: absolute;\n left: 0;\n top: 0;\n width: 100%;\n height: 100%;\n";
|
|
29
22
|
|
|
30
|
-
|
|
23
|
+
const Wrapper = /*#__PURE__*/_styled("span", process.env.NODE_ENV === "production" ? {
|
|
31
24
|
target: "e1m87sp0"
|
|
32
25
|
} : {
|
|
33
26
|
target: "e1m87sp0",
|
|
34
27
|
label: "Wrapper"
|
|
35
|
-
})("--stroke:2px;height:",
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
}
|
|
42
|
-
return getColor(props.color);
|
|
43
|
-
}, ";border-radius:100%;animation:", spin, " 1s linear infinite;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3NwaW5uZXIuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNCMkIiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvc3Bpbm5lci5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXRDb2xvciwgZ2V0RGltZW5zaW9uIH0gZnJvbSAnLi4vdXRpbGl0aWVzJztcbmltcG9ydCBSZWFjdCwgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCB7IGtleWZyYW1lcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IHR5cGVzIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5jb25zdCBzcGluID0ga2V5ZnJhbWVzYFxuICB0byB7XG4gICAgdHJhbnNmb3JtOiByb3RhdGUoMzYwZGVnKTtcbiAgfVxuYDtcblxuY29uc3QgY2lyY2xlU3R5bGVzID0gYFxuICBjb250ZW50OiAnJztcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBsZWZ0OiAwO1xuICB0b3A6IDA7XG4gIHdpZHRoOiAxMDAlO1xuICBoZWlnaHQ6IDEwMCU7XG5gO1xuXG5jb25zdCBXcmFwcGVyID0gc3R5bGVkLnNwYW5gXG4gIC0tc3Ryb2tlOiAycHg7XG5cbiAgaGVpZ2h0OiAke3Byb3BzID0+IGdldERpbWVuc2lvbihwcm9wcy5zaXplKX07XG4gIHdpZHRoOiAke3Byb3BzID0+IGdldERpbWVuc2lvbihwcm9wcy5zaXplKX07XG4gIGRpc3BsYXk6IGJsb2NrO1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG5cbiAgJjpiZWZvcmUge1xuICAgICR7Y2lyY2xlU3R5bGVzfTtcbiAgICBib3JkZXI6IHZhcigtLXN0cm9rZSkgc29saWQgJHtwcm9wcyA9PiBnZXRDb2xvcihwcm9wcy5jb2xvcil9O1xuICAgIGJvcmRlci1yYWRpdXM6IDEwMCU7XG4gICAgb3BhY2l0eTogdmFyKC0tZmFkZTMtYSk7XG4gIH1cblxuICAmOmFmdGVyIHtcbiAgICAke2NpcmNsZVN0eWxlc307XG4gICAgYm9yZGVyOiB2YXIoLS1zdHJva2UpIHNvbGlkIHRyYW5zcGFyZW50O1xuICAgIGJvcmRlci1sZWZ0LWNvbG9yOiAke3Byb3BzID0+IGdldENvbG9yKHByb3BzLmNvbG9yKX07XG4gICAgYm9yZGVyLXJhZGl1czogMTAwJTtcbiAgICBhbmltYXRpb246ICR7c3Bpbn0gMXMgbGluZWFyIGluZmluaXRlO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgU3Bpbm5lciA9IGZvcndhcmRSZWYoKHsgc2l6ZSA9IDMsIGNvbG9yID0gJ2NvbnRlbnQnLCAuLi5wcm9wcyB9LCByZWYpID0+IChcbiAgPFdyYXBwZXIgY29sb3I9e2NvbG9yfSBzaXplPXtzaXplfSByZWY9e3JlZn0gey4uLnByb3BzfSAvPlxuKSk7XG5cblNwaW5uZXIucHJvcFR5cGVzID0ge1xuICBzaXplOiBQcm9wVHlwZXMubnVtYmVyLFxuICBjb2xvcjogdHlwZXMuY29sb3IsXG59O1xuIl19 */"));
|
|
44
|
-
|
|
45
|
-
export var Spinner = /*#__PURE__*/forwardRef(function (_ref, ref) {
|
|
46
|
-
var _ref$size = _ref.size,
|
|
47
|
-
size = _ref$size === void 0 ? 3 : _ref$size,
|
|
48
|
-
_ref$color = _ref.color,
|
|
49
|
-
color = _ref$color === void 0 ? 'content' : _ref$color,
|
|
28
|
+
})("--stroke:2px;height:", props => getDimension(props.size), ";width:", props => getDimension(props.size), ";display:block;position:relative;&:before{", circleStyles, ";border:var(--stroke) solid ", props => getColor(props.color), ";border-radius:100%;opacity:var(--fade3-a);}&:after{", circleStyles, ";border:var(--stroke) solid transparent;border-left-color:", props => getColor(props.color), ";border-radius:100%;animation:", spin, " 1s linear infinite;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3NwaW5uZXIuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNCMkIiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvc3Bpbm5lci5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXRDb2xvciwgZ2V0RGltZW5zaW9uIH0gZnJvbSAnLi4vdXRpbGl0aWVzJztcbmltcG9ydCBSZWFjdCwgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCB7IGtleWZyYW1lcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IHR5cGVzIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5jb25zdCBzcGluID0ga2V5ZnJhbWVzYFxuICB0byB7XG4gICAgdHJhbnNmb3JtOiByb3RhdGUoMzYwZGVnKTtcbiAgfVxuYDtcblxuY29uc3QgY2lyY2xlU3R5bGVzID0gYFxuICBjb250ZW50OiAnJztcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBsZWZ0OiAwO1xuICB0b3A6IDA7XG4gIHdpZHRoOiAxMDAlO1xuICBoZWlnaHQ6IDEwMCU7XG5gO1xuXG5jb25zdCBXcmFwcGVyID0gc3R5bGVkLnNwYW5gXG4gIC0tc3Ryb2tlOiAycHg7XG5cbiAgaGVpZ2h0OiAke3Byb3BzID0+IGdldERpbWVuc2lvbihwcm9wcy5zaXplKX07XG4gIHdpZHRoOiAke3Byb3BzID0+IGdldERpbWVuc2lvbihwcm9wcy5zaXplKX07XG4gIGRpc3BsYXk6IGJsb2NrO1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG5cbiAgJjpiZWZvcmUge1xuICAgICR7Y2lyY2xlU3R5bGVzfTtcbiAgICBib3JkZXI6IHZhcigtLXN0cm9rZSkgc29saWQgJHtwcm9wcyA9PiBnZXRDb2xvcihwcm9wcy5jb2xvcil9O1xuICAgIGJvcmRlci1yYWRpdXM6IDEwMCU7XG4gICAgb3BhY2l0eTogdmFyKC0tZmFkZTMtYSk7XG4gIH1cblxuICAmOmFmdGVyIHtcbiAgICAke2NpcmNsZVN0eWxlc307XG4gICAgYm9yZGVyOiB2YXIoLS1zdHJva2UpIHNvbGlkIHRyYW5zcGFyZW50O1xuICAgIGJvcmRlci1sZWZ0LWNvbG9yOiAke3Byb3BzID0+IGdldENvbG9yKHByb3BzLmNvbG9yKX07XG4gICAgYm9yZGVyLXJhZGl1czogMTAwJTtcbiAgICBhbmltYXRpb246ICR7c3Bpbn0gMXMgbGluZWFyIGluZmluaXRlO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgU3Bpbm5lciA9IGZvcndhcmRSZWYoKHsgc2l6ZSA9IDMsIGNvbG9yID0gJ2NvbnRlbnQnLCAuLi5wcm9wcyB9LCByZWYpID0+IChcbiAgPFdyYXBwZXIgY29sb3I9e2NvbG9yfSBzaXplPXtzaXplfSByZWY9e3JlZn0gey4uLnByb3BzfSAvPlxuKSk7XG5cblNwaW5uZXIucHJvcFR5cGVzID0ge1xuICBzaXplOiBQcm9wVHlwZXMubnVtYmVyLFxuICBjb2xvcjogdHlwZXMuY29sb3IsXG59O1xuIl19 */"));
|
|
29
|
+
|
|
30
|
+
export const Spinner = /*#__PURE__*/forwardRef((_ref, ref) => {
|
|
31
|
+
let {
|
|
32
|
+
size = 3,
|
|
33
|
+
color = 'content'
|
|
34
|
+
} = _ref,
|
|
50
35
|
props = _objectWithoutProperties(_ref, _excluded);
|
|
51
36
|
|
|
52
37
|
return ___EmotionJSX(Wrapper, _extends({
|