@amboss/design-system 1.9.5 → 1.9.7
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/build/cjs/src/components/Button/Button.js +11 -8
- package/build/cjs/src/components/Column/Columns.js +2 -2
- package/build/cjs/src/components/Form/Select/Select.js +5 -5
- package/build/cjs/src/components/PictogramButton/PictogramButton.js +5 -4
- package/build/cjs/src/components/RoundButton/RoundButton.js +5 -4
- package/build/esm/src/components/Button/Button.js +11 -8
- package/build/esm/src/components/Button/Button.js.map +1 -1
- package/build/esm/src/components/Column/Columns.js +2 -2
- package/build/esm/src/components/Column/Columns.js.map +1 -1
- package/build/esm/src/components/Form/Select/Select.js +5 -5
- package/build/esm/src/components/Form/Select/Select.js.map +1 -1
- package/build/esm/src/components/PictogramButton/PictogramButton.js +5 -4
- package/build/esm/src/components/PictogramButton/PictogramButton.js.map +1 -1
- package/build/esm/src/components/RoundButton/RoundButton.js +5 -4
- package/build/esm/src/components/RoundButton/RoundButton.js.map +1 -1
- package/build/esm/src/shared/mediaQueries.js.map +1 -1
- package/package.json +21 -17
|
@@ -22,7 +22,7 @@ const StyledContainer = /*#__PURE__*/_styled__default.default("div", process.env
|
|
|
22
22
|
label: "StyledContainer"
|
|
23
23
|
})(() => ({
|
|
24
24
|
position: "relative"
|
|
25
|
-
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Select.tsx"],"names":[],"mappings":"AAqBwB","file":"Select.tsx","sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, {\n  useState,\n  useRef,\n  useMemo,\n  useEffect,\n  useCallback,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { useKeyboard } from \"../../../shared/useKeyboard\";\nimport {\n  useAutoPosition,\n  VerticalPosition,\n} from \"../../../shared/useAutoPosition\";\nimport { FormField, FormFieldProps } from \"../FormField/FormField\";\nimport { VirtualScrollList } from \"../../VirtualScrollList/VirtualScrollList\";\nimport { Input, InputRaw } from \"../Input/Input\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Box } from \"../../Box/Box\";\n\nconst StyledContainer = styled.div(() => ({\n  position: \"relative\",\n}));\n\nconst StyledInputWrap = styled.div(() => ({\n  zIndex: 0,\n  position: \"absolute\",\n  pointerEvents: \"none\",\n  width: \"100%\",\n  bottom: 0,\n  left: 0,\n}));\n\nconst StyledDropdown = styled.div<{ dropdownPosition: VerticalPosition }>(\n  ({ theme, dropdownPosition }) => ({\n    backgroundColor: theme.values.color.background.layer_2,\n    position: \"absolute\",\n    fontSize: theme.variables.size.font.text.s,\n    zIndex: 2,\n    width: \"100%\",\n    margin: `${theme.variables.size.spacing.xs} 0`,\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.dropdown.m,\n    overflow: \"hidden\",\n    boxShadow: theme.variables.shadow.card.b,\n    boxSizing: \"border-box\",\n    ...(dropdownPosition === \"down\" && {\n      top: \"100%\",\n    }),\n    ...(dropdownPosition === \"up\" && {\n      bottom: \"100%\",\n    }),\n  })\n);\n\nconst StyledDropdownItem = styled.div<{ active: boolean }>(\n  ({ theme, active }) => ({\n    padding: theme.variables.size.spacing.xs,\n    borderRadius: theme.variables.size.borderRadius.dropdown.s,\n    ...(active && {\n      backgroundColor: theme.values.color.background.dropdown.active,\n      borderRadius: 0,\n    }),\n    \"&:hover\": {\n      backgroundColor: theme.values.color.background.dropdown.active,\n      borderRadius: 0,\n    },\n  })\n);\n\nconst HiddenSelectInput = styled.select(() => ({\n  display: \"none\",\n}));\n\ntype SelectOption = {\n  value: string;\n  label: string;\n} & Record<string, unknown>;\n\nexport type SelectProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  emptyStateMessage?: string;\n  hasError?: boolean;\n  disabled?: boolean;\n  options?: SelectOption[];\n  filterMethod?: (options: SelectOption, value: string) => boolean;\n  onChange?: (e: React.FormEvent<HTMLSelectElement>) => void;\n  onBlur?: () => void;\n  onFocus?: () => void;\n  maxHeight?: number;\n  autoComplete?: string;\n} & FormFieldProps;\n\nconst defaultFilterMethod = (option: SelectOption, value: string): boolean =>\n  option.label.toLowerCase().indexOf(value.toLowerCase()) > -1;\n\nexport function Select({\n  options = [],\n  name,\n  value,\n  placeholder,\n  emptyStateMessage,\n  hasError,\n  filterMethod = defaultFilterMethod,\n  onChange = () => null,\n  onBlur = () => null,\n  onFocus = () => null,\n  maxHeight = 230,\n  autoComplete = \"on\",\n  ...rest\n}: SelectProps): React.ReactElement {\n  const { disabled } = rest;\n  const [isOpen, setIsOpen] = useState(false);\n  const [innerValue, setInnerValue] = useState(\"\");\n  const [preselectedIndex, setPreselectedIndex] = useState(-1);\n  const initialValueOption = useMemo(\n    () =>\n      options.find((option) => option.value === value) || {\n        value: \"\",\n        label: \"\",\n      },\n    [options, value]\n  );\n  const [fakeSelectedOption, setFakeSelectedOption] = useState(\n    initialValueOption\n  );\n  const fakeSelectRef = useRef(null);\n\n  const dropDownRef = useRef(null);\n  const innerInputRef = useRef(null);\n\n  const currentValueRef = useRef(value);\n  currentValueRef.current = value;\n\n  const forceChangeFakeSelect = useCallback(\n    (selectedOption: SelectOption) => {\n      if (fakeSelectedOption.value !== selectedOption.value) {\n        setFakeSelectedOption(selectedOption);\n      }\n    },\n    [fakeSelectedOption]\n  );\n\n  const [verticalPosition] = useAutoPosition(\n    fakeSelectRef,\n    dropDownRef,\n    isOpen\n  );\n\n  const closeDropdown = useCallback(\n    (noSelect = false) => {\n      setIsOpen(false);\n      if (!noSelect) {\n        const selectedOption = options.find(\n          (option) =>\n            option.label.toLowerCase().trim() ===\n            innerValue.toLowerCase().trim()\n        );\n        if (selectedOption) {\n          forceChangeFakeSelect(selectedOption);\n        }\n      }\n      setInnerValue(\"\");\n      setPreselectedIndex(-1);\n      onBlur();\n    },\n    [onBlur, forceChangeFakeSelect, innerValue, options]\n  );\n\n  useEffect(() => {\n    if (\n      fakeSelectRef.current &&\n      currentValueRef.current !== fakeSelectedOption.value\n    ) {\n      fakeSelectRef.current.dispatchEvent(\n        new Event(\"change\", { bubbles: true })\n      );\n    }\n  }, [fakeSelectedOption, fakeSelectRef, currentValueRef]);\n\n  // force updating the hidden select if a new initial value gets passed down\n  // without it, there would be a mismatch of selected value and the hidden select,\n  // which would cause the first value to not be selectable\n  useEffect(() => {\n    forceChangeFakeSelect(initialValueOption);\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [initialValueOption]);\n\n  const filteredOptions = useMemo(() => {\n    if (!innerValue) {\n      return options;\n    }\n\n    return options.filter((option) => filterMethod(option, innerValue));\n  }, [options, filterMethod, innerValue]);\n\n  const displayValue = useMemo(\n    () =>\n      options.some((option) => option.value === value)\n        ? options.find((option) => option.value === value).label\n        : \"\",\n    [value, options]\n  );\n\n  useEffect(() => {\n    setPreselectedIndex(-1);\n  }, [filteredOptions]);\n\n  useKeyboard(\n    {\n      Escape: () => closeDropdown(true),\n      Enter: () => {\n        if (filteredOptions[preselectedIndex]) {\n          forceChangeFakeSelect(filteredOptions[preselectedIndex]);\n          closeDropdown(true);\n          return;\n        }\n        closeDropdown();\n      },\n      ArrowUp: () => {\n        setPreselectedIndex(Math.max(preselectedIndex - 1, 0));\n      },\n      ArrowDown: () => {\n        setPreselectedIndex(\n          Math.min(preselectedIndex + 1, filteredOptions.length - 1)\n        );\n      },\n    },\n    innerInputRef,\n    isOpen && !disabled\n  );\n\n  useKeyboard(\n    {\n      \"ArrowUp ArrowDown\": () => {\n        setIsOpen(true);\n      },\n    },\n    innerInputRef,\n    !isOpen && !disabled\n  );\n\n  return (\n    <FormField {...(rest as FormFieldProps)}>\n      <StyledContainer\n        onBlur={() => {\n          closeDropdown(true);\n        }}\n      >\n        <div style={{ zIndex: 1 }}>\n          <InputRaw\n            areaLabel={rest.label}\n            name={`${name}-innerInput`}\n            value={innerValue}\n            privateProps={{ isTransparent: !(isOpen && innerValue) }}\n            icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n            hasError={hasError}\n            disabled={disabled}\n            onFocus={() => {\n              setIsOpen(true);\n              onFocus();\n            }}\n            onClick={() => {\n              setIsOpen(true);\n            }}\n            onChange={(e) => {\n              if (e.currentTarget.value) {\n                setIsOpen(true);\n              }\n              setInnerValue(e.currentTarget.value);\n            }}\n            ref={innerInputRef}\n            autoComplete={autoComplete}\n          />\n        </div>\n\n        <StyledInputWrap>\n          <Input\n            name={name}\n            value={displayValue}\n            onChange={() => null}\n            icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n            placeholder={placeholder}\n            tabIndex={-1}\n            autoComplete=\"off\"\n          />\n        </StyledInputWrap>\n\n        {isOpen && (\n          // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n          <StyledDropdown\n            dropdownPosition={verticalPosition}\n            ref={dropDownRef}\n            // this is to prevent known bug of Chrome when element\n            // loses focus on click on the scrollbar\n            onMouseDown={(e) => e.preventDefault()}\n          >\n            <VirtualScrollList\n              maxHeight={maxHeight}\n              itemHeight={36}\n              itemAmount={filteredOptions.length}\n              emptyState={() => (\n                <Box space=\"xs\">\n                  <Text>{emptyStateMessage || \"🤷🏻‍♀️\"}</Text>\n                </Box>\n              )}\n              itemInView={preselectedIndex}\n              itemTemplate={(index: number) => {\n                const option: SelectOption = filteredOptions[index];\n                return (\n                  // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n                  <StyledDropdownItem\n                    key={option.value}\n                    active={\n                      preselectedIndex === index || value === option.value\n                    }\n                    onMouseDown={() => {\n                      forceChangeFakeSelect(option);\n                      closeDropdown(true);\n                    }}\n                  >\n                    <Text weight=\"bold\" variant=\"secondary\" size=\"s\">\n                      {option.label}\n                    </Text>\n                  </StyledDropdownItem>\n                );\n              }}\n            />\n          </StyledDropdown>\n        )}\n\n        <HiddenSelectInput\n          onChange={onChange}\n          value={fakeSelectedOption.value}\n          ref={fakeSelectRef}\n          autoComplete=\"off\"\n        >\n          <option value={fakeSelectedOption.value}>\n            {fakeSelectedOption.label}\n          </option>\n        </HiddenSelectInput>\n      </StyledContainer>\n    </FormField>\n  );\n}\n"]} */");
|
|
25
|
+
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Select.tsx"],"names":[],"mappings":"AAqBwB","file":"Select.tsx","sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, {\n  useState,\n  useRef,\n  useMemo,\n  useEffect,\n  useCallback,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { useKeyboard } from \"../../../shared/useKeyboard\";\nimport {\n  useAutoPosition,\n  VerticalPosition,\n} from \"../../../shared/useAutoPosition\";\nimport { FormField, FormFieldProps } from \"../FormField/FormField\";\nimport { VirtualScrollList } from \"../../VirtualScrollList/VirtualScrollList\";\nimport { Input, InputRaw } from \"../Input/Input\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Box } from \"../../Box/Box\";\n\nconst StyledContainer = styled.div(() => ({\n  position: \"relative\",\n}));\n\nconst StyledInputWrap = styled.div(() => ({\n  zIndex: 0,\n  position: \"absolute\",\n  pointerEvents: \"none\",\n  width: \"100%\",\n  bottom: 0,\n  left: 0,\n}));\n\nconst StyledDropdown = styled.div<{ dropdownPosition: VerticalPosition }>(\n  ({ theme, dropdownPosition }) => ({\n    backgroundColor: theme.values.color.background.layer_2,\n    position: \"absolute\",\n    fontSize: theme.variables.size.font.text.s,\n    zIndex: 2,\n    width: \"100%\",\n    margin: `${theme.variables.size.spacing.xs} 0`,\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.dropdown.m,\n    overflow: \"hidden\",\n    boxShadow: theme.variables.shadow.card.b,\n    boxSizing: \"border-box\",\n    ...(dropdownPosition === \"down\" && {\n      top: \"100%\",\n    }),\n    ...(dropdownPosition === \"up\" && {\n      bottom: \"100%\",\n    }),\n  })\n);\n\nconst StyledDropdownItem = styled.div<{ active: boolean }>(\n  ({ theme, active }) => ({\n    padding: theme.variables.size.spacing.xs,\n    borderRadius: theme.variables.size.borderRadius.dropdown.s,\n    ...(active && {\n      backgroundColor: theme.values.color.background.dropdown.active,\n      borderRadius: 0,\n    }),\n    \"&:hover\": {\n      backgroundColor: theme.values.color.background.dropdown.active,\n      borderRadius: 0,\n    },\n  })\n);\n\nconst HiddenSelectInput = styled.select(() => ({\n  display: \"none\",\n}));\n\ntype SelectOption = {\n  value: string;\n  label: string;\n} & Record<string, unknown>;\n\nexport type SelectProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  emptyStateMessage?: string;\n  hasError?: boolean;\n  disabled?: boolean;\n  options?: SelectOption[];\n  filterMethod?: (options: SelectOption, value: string) => boolean;\n  onChange?: (e: React.FormEvent<HTMLSelectElement>) => void;\n  onBlur?: () => void;\n  onFocus?: () => void;\n  maxHeight?: number;\n  autoComplete?: string;\n} & FormFieldProps;\n\nconst defaultFilterMethod = (option: SelectOption, value: string): boolean =>\n  option.label.toLowerCase().indexOf(value.toLowerCase()) > -1;\n\nexport function Select({\n  options = [],\n  name,\n  value,\n  placeholder,\n  emptyStateMessage,\n  hasError,\n  filterMethod = defaultFilterMethod,\n  onChange = () => null,\n  onBlur = () => null,\n  onFocus = () => null,\n  maxHeight = 230,\n  autoComplete = \"on\",\n  ...rest\n}: SelectProps): React.ReactElement {\n  const { disabled } = rest;\n  const [isOpen, setIsOpen] = useState(false);\n  const [innerValue, setInnerValue] = useState(\"\");\n  const [preselectedIndex, setPreselectedIndex] = useState(-1);\n  const initialValueOption = useMemo(\n    () =>\n      options.find((option) => option.value === value) || {\n        value: \"\",\n        label: \"\",\n      },\n    [options, value]\n  );\n  const [fakeSelectedOption, setFakeSelectedOption] =\n    useState(initialValueOption);\n  const fakeSelectRef = useRef(null);\n\n  const dropDownRef = useRef(null);\n  const innerInputRef = useRef(null);\n\n  const currentValueRef = useRef(value);\n  currentValueRef.current = value;\n\n  const forceChangeFakeSelect = useCallback(\n    (selectedOption: SelectOption) => {\n      if (fakeSelectedOption.value !== selectedOption.value) {\n        setFakeSelectedOption(selectedOption);\n      }\n    },\n    [fakeSelectedOption]\n  );\n\n  const [verticalPosition] = useAutoPosition(\n    fakeSelectRef,\n    dropDownRef,\n    isOpen\n  );\n\n  const closeDropdown = useCallback(\n    (noSelect = false) => {\n      setIsOpen(false);\n      if (!noSelect) {\n        const selectedOption = options.find(\n          (option) =>\n            option.label.toLowerCase().trim() ===\n            innerValue.toLowerCase().trim()\n        );\n        if (selectedOption) {\n          forceChangeFakeSelect(selectedOption);\n        }\n      }\n      setInnerValue(\"\");\n      setPreselectedIndex(-1);\n      onBlur();\n    },\n    [onBlur, forceChangeFakeSelect, innerValue, options]\n  );\n\n  useEffect(() => {\n    if (\n      fakeSelectRef.current &&\n      currentValueRef.current !== fakeSelectedOption.value\n    ) {\n      fakeSelectRef.current.dispatchEvent(\n        new Event(\"change\", { bubbles: true })\n      );\n    }\n  }, [fakeSelectedOption, fakeSelectRef, currentValueRef]);\n\n  // force updating the hidden select if a new initial value gets passed down\n  // without it, there would be a mismatch of selected value and the hidden select,\n  // which would cause the first value to not be selectable\n  useEffect(() => {\n    forceChangeFakeSelect(initialValueOption);\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [initialValueOption]);\n\n  const filteredOptions = useMemo(() => {\n    if (!innerValue) {\n      return options;\n    }\n\n    return options.filter((option) => filterMethod(option, innerValue));\n  }, [options, filterMethod, innerValue]);\n\n  const displayValue = useMemo(\n    () =>\n      options.some((option) => option.value === value)\n        ? options.find((option) => option.value === value).label\n        : \"\",\n    [value, options]\n  );\n\n  useEffect(() => {\n    setPreselectedIndex(-1);\n  }, [filteredOptions]);\n\n  useKeyboard(\n    {\n      Escape: () => closeDropdown(true),\n      Enter: () => {\n        if (filteredOptions[preselectedIndex]) {\n          forceChangeFakeSelect(filteredOptions[preselectedIndex]);\n          closeDropdown(true);\n          return;\n        }\n        closeDropdown();\n      },\n      ArrowUp: () => {\n        setPreselectedIndex(Math.max(preselectedIndex - 1, 0));\n      },\n      ArrowDown: () => {\n        setPreselectedIndex(\n          Math.min(preselectedIndex + 1, filteredOptions.length - 1)\n        );\n      },\n    },\n    innerInputRef,\n    isOpen && !disabled\n  );\n\n  useKeyboard(\n    {\n      \"ArrowUp ArrowDown\": () => {\n        setIsOpen(true);\n      },\n    },\n    innerInputRef,\n    !isOpen && !disabled\n  );\n\n  return (\n    <FormField {...(rest as FormFieldProps)}>\n      <StyledContainer\n        onBlur={() => {\n          closeDropdown(true);\n        }}\n      >\n        <div style={{ zIndex: 1 }}>\n          <InputRaw\n            areaLabel={rest.label}\n            name={`${name}-innerInput`}\n            value={innerValue}\n            privateProps={{ isTransparent: !(isOpen && innerValue) }}\n            icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n            hasError={hasError}\n            disabled={disabled}\n            onFocus={() => {\n              setIsOpen(true);\n              onFocus();\n            }}\n            onClick={() => {\n              setIsOpen(true);\n            }}\n            onChange={(e) => {\n              if (e.currentTarget.value) {\n                setIsOpen(true);\n              }\n              setInnerValue(e.currentTarget.value);\n            }}\n            ref={innerInputRef}\n            autoComplete={autoComplete}\n          />\n        </div>\n\n        <StyledInputWrap>\n          <Input\n            name={name}\n            value={displayValue}\n            onChange={() => null}\n            icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n            placeholder={placeholder}\n            tabIndex={-1}\n            autoComplete=\"off\"\n          />\n        </StyledInputWrap>\n\n        {isOpen && (\n          // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n          <StyledDropdown\n            dropdownPosition={verticalPosition}\n            ref={dropDownRef}\n            // this is to prevent known bug of Chrome when element\n            // loses focus on click on the scrollbar\n            onMouseDown={(e) => e.preventDefault()}\n          >\n            <VirtualScrollList\n              maxHeight={maxHeight}\n              itemHeight={36}\n              itemAmount={filteredOptions.length}\n              emptyState={() => (\n                <Box space=\"xs\">\n                  <Text>{emptyStateMessage || \"🤷🏻‍♀️\"}</Text>\n                </Box>\n              )}\n              itemInView={preselectedIndex}\n              itemTemplate={(index: number) => {\n                const option: SelectOption = filteredOptions[index];\n                return (\n                  // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n                  <StyledDropdownItem\n                    key={option.value}\n                    active={\n                      preselectedIndex === index || value === option.value\n                    }\n                    onMouseDown={() => {\n                      forceChangeFakeSelect(option);\n                      closeDropdown(true);\n                    }}\n                  >\n                    <Text weight=\"bold\" variant=\"secondary\" size=\"s\">\n                      {option.label}\n                    </Text>\n                  </StyledDropdownItem>\n                );\n              }}\n            />\n          </StyledDropdown>\n        )}\n\n        <HiddenSelectInput\n          onChange={onChange}\n          value={fakeSelectedOption.value}\n          ref={fakeSelectRef}\n          autoComplete=\"off\"\n        >\n          <option value={fakeSelectedOption.value}>\n            {fakeSelectedOption.label}\n          </option>\n        </HiddenSelectInput>\n      </StyledContainer>\n    </FormField>\n  );\n}\n"]} */");
|
|
26
26
|
const StyledInputWrap = /*#__PURE__*/_styled__default.default("div", process.env.NODE_ENV === "production" ? {
|
|
27
27
|
target: "el6d4lv3"
|
|
28
28
|
} : {
|
|
@@ -35,7 +35,7 @@ const StyledInputWrap = /*#__PURE__*/_styled__default.default("div", process.env
|
|
|
35
35
|
width: "100%",
|
|
36
36
|
bottom: 0,
|
|
37
37
|
left: 0
|
|
38
|
-
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Select.tsx"],"names":[],"mappings":"AAyBwB","file":"Select.tsx","sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, {\n  useState,\n  useRef,\n  useMemo,\n  useEffect,\n  useCallback,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { useKeyboard } from \"../../../shared/useKeyboard\";\nimport {\n  useAutoPosition,\n  VerticalPosition,\n} from \"../../../shared/useAutoPosition\";\nimport { FormField, FormFieldProps } from \"../FormField/FormField\";\nimport { VirtualScrollList } from \"../../VirtualScrollList/VirtualScrollList\";\nimport { Input, InputRaw } from \"../Input/Input\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Box } from \"../../Box/Box\";\n\nconst StyledContainer = styled.div(() => ({\n  position: \"relative\",\n}));\n\nconst StyledInputWrap = styled.div(() => ({\n  zIndex: 0,\n  position: \"absolute\",\n  pointerEvents: \"none\",\n  width: \"100%\",\n  bottom: 0,\n  left: 0,\n}));\n\nconst StyledDropdown = styled.div<{ dropdownPosition: VerticalPosition }>(\n  ({ theme, dropdownPosition }) => ({\n    backgroundColor: theme.values.color.background.layer_2,\n    position: \"absolute\",\n    fontSize: theme.variables.size.font.text.s,\n    zIndex: 2,\n    width: \"100%\",\n    margin: `${theme.variables.size.spacing.xs} 0`,\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.dropdown.m,\n    overflow: \"hidden\",\n    boxShadow: theme.variables.shadow.card.b,\n    boxSizing: \"border-box\",\n    ...(dropdownPosition === \"down\" && {\n      top: \"100%\",\n    }),\n    ...(dropdownPosition === \"up\" && {\n      bottom: \"100%\",\n    }),\n  })\n);\n\nconst StyledDropdownItem = styled.div<{ active: boolean }>(\n  ({ theme, active }) => ({\n    padding: theme.variables.size.spacing.xs,\n    borderRadius: theme.variables.size.borderRadius.dropdown.s,\n    ...(active && {\n      backgroundColor: theme.values.color.background.dropdown.active,\n      borderRadius: 0,\n    }),\n    \"&:hover\": {\n      backgroundColor: theme.values.color.background.dropdown.active,\n      borderRadius: 0,\n    },\n  })\n);\n\nconst HiddenSelectInput = styled.select(() => ({\n  display: \"none\",\n}));\n\ntype SelectOption = {\n  value: string;\n  label: string;\n} & Record<string, unknown>;\n\nexport type SelectProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  emptyStateMessage?: string;\n  hasError?: boolean;\n  disabled?: boolean;\n  options?: SelectOption[];\n  filterMethod?: (options: SelectOption, value: string) => boolean;\n  onChange?: (e: React.FormEvent<HTMLSelectElement>) => void;\n  onBlur?: () => void;\n  onFocus?: () => void;\n  maxHeight?: number;\n  autoComplete?: string;\n} & FormFieldProps;\n\nconst defaultFilterMethod = (option: SelectOption, value: string): boolean =>\n  option.label.toLowerCase().indexOf(value.toLowerCase()) > -1;\n\nexport function Select({\n  options = [],\n  name,\n  value,\n  placeholder,\n  emptyStateMessage,\n  hasError,\n  filterMethod = defaultFilterMethod,\n  onChange = () => null,\n  onBlur = () => null,\n  onFocus = () => null,\n  maxHeight = 230,\n  autoComplete = \"on\",\n  ...rest\n}: SelectProps): React.ReactElement {\n  const { disabled } = rest;\n  const [isOpen, setIsOpen] = useState(false);\n  const [innerValue, setInnerValue] = useState(\"\");\n  const [preselectedIndex, setPreselectedIndex] = useState(-1);\n  const initialValueOption = useMemo(\n    () =>\n      options.find((option) => option.value === value) || {\n        value: \"\",\n        label: \"\",\n      },\n    [options, value]\n  );\n  const [fakeSelectedOption, setFakeSelectedOption] = useState(\n    initialValueOption\n  );\n  const fakeSelectRef = useRef(null);\n\n  const dropDownRef = useRef(null);\n  const innerInputRef = useRef(null);\n\n  const currentValueRef = useRef(value);\n  currentValueRef.current = value;\n\n  const forceChangeFakeSelect = useCallback(\n    (selectedOption: SelectOption) => {\n      if (fakeSelectedOption.value !== selectedOption.value) {\n        setFakeSelectedOption(selectedOption);\n      }\n    },\n    [fakeSelectedOption]\n  );\n\n  const [verticalPosition] = useAutoPosition(\n    fakeSelectRef,\n    dropDownRef,\n    isOpen\n  );\n\n  const closeDropdown = useCallback(\n    (noSelect = false) => {\n      setIsOpen(false);\n      if (!noSelect) {\n        const selectedOption = options.find(\n          (option) =>\n            option.label.toLowerCase().trim() ===\n            innerValue.toLowerCase().trim()\n        );\n        if (selectedOption) {\n          forceChangeFakeSelect(selectedOption);\n        }\n      }\n      setInnerValue(\"\");\n      setPreselectedIndex(-1);\n      onBlur();\n    },\n    [onBlur, forceChangeFakeSelect, innerValue, options]\n  );\n\n  useEffect(() => {\n    if (\n      fakeSelectRef.current &&\n      currentValueRef.current !== fakeSelectedOption.value\n    ) {\n      fakeSelectRef.current.dispatchEvent(\n        new Event(\"change\", { bubbles: true })\n      );\n    }\n  }, [fakeSelectedOption, fakeSelectRef, currentValueRef]);\n\n  // force updating the hidden select if a new initial value gets passed down\n  // without it, there would be a mismatch of selected value and the hidden select,\n  // which would cause the first value to not be selectable\n  useEffect(() => {\n    forceChangeFakeSelect(initialValueOption);\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [initialValueOption]);\n\n  const filteredOptions = useMemo(() => {\n    if (!innerValue) {\n      return options;\n    }\n\n    return options.filter((option) => filterMethod(option, innerValue));\n  }, [options, filterMethod, innerValue]);\n\n  const displayValue = useMemo(\n    () =>\n      options.some((option) => option.value === value)\n        ? options.find((option) => option.value === value).label\n        : \"\",\n    [value, options]\n  );\n\n  useEffect(() => {\n    setPreselectedIndex(-1);\n  }, [filteredOptions]);\n\n  useKeyboard(\n    {\n      Escape: () => closeDropdown(true),\n      Enter: () => {\n        if (filteredOptions[preselectedIndex]) {\n          forceChangeFakeSelect(filteredOptions[preselectedIndex]);\n          closeDropdown(true);\n          return;\n        }\n        closeDropdown();\n      },\n      ArrowUp: () => {\n        setPreselectedIndex(Math.max(preselectedIndex - 1, 0));\n      },\n      ArrowDown: () => {\n        setPreselectedIndex(\n          Math.min(preselectedIndex + 1, filteredOptions.length - 1)\n        );\n      },\n    },\n    innerInputRef,\n    isOpen && !disabled\n  );\n\n  useKeyboard(\n    {\n      \"ArrowUp ArrowDown\": () => {\n        setIsOpen(true);\n      },\n    },\n    innerInputRef,\n    !isOpen && !disabled\n  );\n\n  return (\n    <FormField {...(rest as FormFieldProps)}>\n      <StyledContainer\n        onBlur={() => {\n          closeDropdown(true);\n        }}\n      >\n        <div style={{ zIndex: 1 }}>\n          <InputRaw\n            areaLabel={rest.label}\n            name={`${name}-innerInput`}\n            value={innerValue}\n            privateProps={{ isTransparent: !(isOpen && innerValue) }}\n            icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n            hasError={hasError}\n            disabled={disabled}\n            onFocus={() => {\n              setIsOpen(true);\n              onFocus();\n            }}\n            onClick={() => {\n              setIsOpen(true);\n            }}\n            onChange={(e) => {\n              if (e.currentTarget.value) {\n                setIsOpen(true);\n              }\n              setInnerValue(e.currentTarget.value);\n            }}\n            ref={innerInputRef}\n            autoComplete={autoComplete}\n          />\n        </div>\n\n        <StyledInputWrap>\n          <Input\n            name={name}\n            value={displayValue}\n            onChange={() => null}\n            icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n            placeholder={placeholder}\n            tabIndex={-1}\n            autoComplete=\"off\"\n          />\n        </StyledInputWrap>\n\n        {isOpen && (\n          // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n          <StyledDropdown\n            dropdownPosition={verticalPosition}\n            ref={dropDownRef}\n            // this is to prevent known bug of Chrome when element\n            // loses focus on click on the scrollbar\n            onMouseDown={(e) => e.preventDefault()}\n          >\n            <VirtualScrollList\n              maxHeight={maxHeight}\n              itemHeight={36}\n              itemAmount={filteredOptions.length}\n              emptyState={() => (\n                <Box space=\"xs\">\n                  <Text>{emptyStateMessage || \"🤷🏻‍♀️\"}</Text>\n                </Box>\n              )}\n              itemInView={preselectedIndex}\n              itemTemplate={(index: number) => {\n                const option: SelectOption = filteredOptions[index];\n                return (\n                  // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n                  <StyledDropdownItem\n                    key={option.value}\n                    active={\n                      preselectedIndex === index || value === option.value\n                    }\n                    onMouseDown={() => {\n                      forceChangeFakeSelect(option);\n                      closeDropdown(true);\n                    }}\n                  >\n                    <Text weight=\"bold\" variant=\"secondary\" size=\"s\">\n                      {option.label}\n                    </Text>\n                  </StyledDropdownItem>\n                );\n              }}\n            />\n          </StyledDropdown>\n        )}\n\n        <HiddenSelectInput\n          onChange={onChange}\n          value={fakeSelectedOption.value}\n          ref={fakeSelectRef}\n          autoComplete=\"off\"\n        >\n          <option value={fakeSelectedOption.value}>\n            {fakeSelectedOption.label}\n          </option>\n        </HiddenSelectInput>\n      </StyledContainer>\n    </FormField>\n  );\n}\n"]} */");
|
|
38
|
+
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Select.tsx"],"names":[],"mappings":"AAyBwB","file":"Select.tsx","sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, {\n  useState,\n  useRef,\n  useMemo,\n  useEffect,\n  useCallback,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { useKeyboard } from \"../../../shared/useKeyboard\";\nimport {\n  useAutoPosition,\n  VerticalPosition,\n} from \"../../../shared/useAutoPosition\";\nimport { FormField, FormFieldProps } from \"../FormField/FormField\";\nimport { VirtualScrollList } from \"../../VirtualScrollList/VirtualScrollList\";\nimport { Input, InputRaw } from \"../Input/Input\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Box } from \"../../Box/Box\";\n\nconst StyledContainer = styled.div(() => ({\n  position: \"relative\",\n}));\n\nconst StyledInputWrap = styled.div(() => ({\n  zIndex: 0,\n  position: \"absolute\",\n  pointerEvents: \"none\",\n  width: \"100%\",\n  bottom: 0,\n  left: 0,\n}));\n\nconst StyledDropdown = styled.div<{ dropdownPosition: VerticalPosition }>(\n  ({ theme, dropdownPosition }) => ({\n    backgroundColor: theme.values.color.background.layer_2,\n    position: \"absolute\",\n    fontSize: theme.variables.size.font.text.s,\n    zIndex: 2,\n    width: \"100%\",\n    margin: `${theme.variables.size.spacing.xs} 0`,\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.dropdown.m,\n    overflow: \"hidden\",\n    boxShadow: theme.variables.shadow.card.b,\n    boxSizing: \"border-box\",\n    ...(dropdownPosition === \"down\" && {\n      top: \"100%\",\n    }),\n    ...(dropdownPosition === \"up\" && {\n      bottom: \"100%\",\n    }),\n  })\n);\n\nconst StyledDropdownItem = styled.div<{ active: boolean }>(\n  ({ theme, active }) => ({\n    padding: theme.variables.size.spacing.xs,\n    borderRadius: theme.variables.size.borderRadius.dropdown.s,\n    ...(active && {\n      backgroundColor: theme.values.color.background.dropdown.active,\n      borderRadius: 0,\n    }),\n    \"&:hover\": {\n      backgroundColor: theme.values.color.background.dropdown.active,\n      borderRadius: 0,\n    },\n  })\n);\n\nconst HiddenSelectInput = styled.select(() => ({\n  display: \"none\",\n}));\n\ntype SelectOption = {\n  value: string;\n  label: string;\n} & Record<string, unknown>;\n\nexport type SelectProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  emptyStateMessage?: string;\n  hasError?: boolean;\n  disabled?: boolean;\n  options?: SelectOption[];\n  filterMethod?: (options: SelectOption, value: string) => boolean;\n  onChange?: (e: React.FormEvent<HTMLSelectElement>) => void;\n  onBlur?: () => void;\n  onFocus?: () => void;\n  maxHeight?: number;\n  autoComplete?: string;\n} & FormFieldProps;\n\nconst defaultFilterMethod = (option: SelectOption, value: string): boolean =>\n  option.label.toLowerCase().indexOf(value.toLowerCase()) > -1;\n\nexport function Select({\n  options = [],\n  name,\n  value,\n  placeholder,\n  emptyStateMessage,\n  hasError,\n  filterMethod = defaultFilterMethod,\n  onChange = () => null,\n  onBlur = () => null,\n  onFocus = () => null,\n  maxHeight = 230,\n  autoComplete = \"on\",\n  ...rest\n}: SelectProps): React.ReactElement {\n  const { disabled } = rest;\n  const [isOpen, setIsOpen] = useState(false);\n  const [innerValue, setInnerValue] = useState(\"\");\n  const [preselectedIndex, setPreselectedIndex] = useState(-1);\n  const initialValueOption = useMemo(\n    () =>\n      options.find((option) => option.value === value) || {\n        value: \"\",\n        label: \"\",\n      },\n    [options, value]\n  );\n  const [fakeSelectedOption, setFakeSelectedOption] =\n    useState(initialValueOption);\n  const fakeSelectRef = useRef(null);\n\n  const dropDownRef = useRef(null);\n  const innerInputRef = useRef(null);\n\n  const currentValueRef = useRef(value);\n  currentValueRef.current = value;\n\n  const forceChangeFakeSelect = useCallback(\n    (selectedOption: SelectOption) => {\n      if (fakeSelectedOption.value !== selectedOption.value) {\n        setFakeSelectedOption(selectedOption);\n      }\n    },\n    [fakeSelectedOption]\n  );\n\n  const [verticalPosition] = useAutoPosition(\n    fakeSelectRef,\n    dropDownRef,\n    isOpen\n  );\n\n  const closeDropdown = useCallback(\n    (noSelect = false) => {\n      setIsOpen(false);\n      if (!noSelect) {\n        const selectedOption = options.find(\n          (option) =>\n            option.label.toLowerCase().trim() ===\n            innerValue.toLowerCase().trim()\n        );\n        if (selectedOption) {\n          forceChangeFakeSelect(selectedOption);\n        }\n      }\n      setInnerValue(\"\");\n      setPreselectedIndex(-1);\n      onBlur();\n    },\n    [onBlur, forceChangeFakeSelect, innerValue, options]\n  );\n\n  useEffect(() => {\n    if (\n      fakeSelectRef.current &&\n      currentValueRef.current !== fakeSelectedOption.value\n    ) {\n      fakeSelectRef.current.dispatchEvent(\n        new Event(\"change\", { bubbles: true })\n      );\n    }\n  }, [fakeSelectedOption, fakeSelectRef, currentValueRef]);\n\n  // force updating the hidden select if a new initial value gets passed down\n  // without it, there would be a mismatch of selected value and the hidden select,\n  // which would cause the first value to not be selectable\n  useEffect(() => {\n    forceChangeFakeSelect(initialValueOption);\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [initialValueOption]);\n\n  const filteredOptions = useMemo(() => {\n    if (!innerValue) {\n      return options;\n    }\n\n    return options.filter((option) => filterMethod(option, innerValue));\n  }, [options, filterMethod, innerValue]);\n\n  const displayValue = useMemo(\n    () =>\n      options.some((option) => option.value === value)\n        ? options.find((option) => option.value === value).label\n        : \"\",\n    [value, options]\n  );\n\n  useEffect(() => {\n    setPreselectedIndex(-1);\n  }, [filteredOptions]);\n\n  useKeyboard(\n    {\n      Escape: () => closeDropdown(true),\n      Enter: () => {\n        if (filteredOptions[preselectedIndex]) {\n          forceChangeFakeSelect(filteredOptions[preselectedIndex]);\n          closeDropdown(true);\n          return;\n        }\n        closeDropdown();\n      },\n      ArrowUp: () => {\n        setPreselectedIndex(Math.max(preselectedIndex - 1, 0));\n      },\n      ArrowDown: () => {\n        setPreselectedIndex(\n          Math.min(preselectedIndex + 1, filteredOptions.length - 1)\n        );\n      },\n    },\n    innerInputRef,\n    isOpen && !disabled\n  );\n\n  useKeyboard(\n    {\n      \"ArrowUp ArrowDown\": () => {\n        setIsOpen(true);\n      },\n    },\n    innerInputRef,\n    !isOpen && !disabled\n  );\n\n  return (\n    <FormField {...(rest as FormFieldProps)}>\n      <StyledContainer\n        onBlur={() => {\n          closeDropdown(true);\n        }}\n      >\n        <div style={{ zIndex: 1 }}>\n          <InputRaw\n            areaLabel={rest.label}\n            name={`${name}-innerInput`}\n            value={innerValue}\n            privateProps={{ isTransparent: !(isOpen && innerValue) }}\n            icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n            hasError={hasError}\n            disabled={disabled}\n            onFocus={() => {\n              setIsOpen(true);\n              onFocus();\n            }}\n            onClick={() => {\n              setIsOpen(true);\n            }}\n            onChange={(e) => {\n              if (e.currentTarget.value) {\n                setIsOpen(true);\n              }\n              setInnerValue(e.currentTarget.value);\n            }}\n            ref={innerInputRef}\n            autoComplete={autoComplete}\n          />\n        </div>\n\n        <StyledInputWrap>\n          <Input\n            name={name}\n            value={displayValue}\n            onChange={() => null}\n            icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n            placeholder={placeholder}\n            tabIndex={-1}\n            autoComplete=\"off\"\n          />\n        </StyledInputWrap>\n\n        {isOpen && (\n          // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n          <StyledDropdown\n            dropdownPosition={verticalPosition}\n            ref={dropDownRef}\n            // this is to prevent known bug of Chrome when element\n            // loses focus on click on the scrollbar\n            onMouseDown={(e) => e.preventDefault()}\n          >\n            <VirtualScrollList\n              maxHeight={maxHeight}\n              itemHeight={36}\n              itemAmount={filteredOptions.length}\n              emptyState={() => (\n                <Box space=\"xs\">\n                  <Text>{emptyStateMessage || \"🤷🏻‍♀️\"}</Text>\n                </Box>\n              )}\n              itemInView={preselectedIndex}\n              itemTemplate={(index: number) => {\n                const option: SelectOption = filteredOptions[index];\n                return (\n                  // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n                  <StyledDropdownItem\n                    key={option.value}\n                    active={\n                      preselectedIndex === index || value === option.value\n                    }\n                    onMouseDown={() => {\n                      forceChangeFakeSelect(option);\n                      closeDropdown(true);\n                    }}\n                  >\n                    <Text weight=\"bold\" variant=\"secondary\" size=\"s\">\n                      {option.label}\n                    </Text>\n                  </StyledDropdownItem>\n                );\n              }}\n            />\n          </StyledDropdown>\n        )}\n\n        <HiddenSelectInput\n          onChange={onChange}\n          value={fakeSelectedOption.value}\n          ref={fakeSelectRef}\n          autoComplete=\"off\"\n        >\n          <option value={fakeSelectedOption.value}>\n            {fakeSelectedOption.label}\n          </option>\n        </HiddenSelectInput>\n      </StyledContainer>\n    </FormField>\n  );\n}\n"]} */");
|
|
39
39
|
const StyledDropdown = /*#__PURE__*/_styled__default.default("div", process.env.NODE_ENV === "production" ? {
|
|
40
40
|
target: "el6d4lv2"
|
|
41
41
|
} : {
|
|
@@ -65,7 +65,7 @@ const StyledDropdown = /*#__PURE__*/_styled__default.default("div", process.env.
|
|
|
65
65
|
bottom: "100%"
|
|
66
66
|
})
|
|
67
67
|
};
|
|
68
|
-
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Select.tsx"],"names":[],"mappings":"AAkCuB","file":"Select.tsx","sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, {\n  useState,\n  useRef,\n  useMemo,\n  useEffect,\n  useCallback,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { useKeyboard } from \"../../../shared/useKeyboard\";\nimport {\n  useAutoPosition,\n  VerticalPosition,\n} from \"../../../shared/useAutoPosition\";\nimport { FormField, FormFieldProps } from \"../FormField/FormField\";\nimport { VirtualScrollList } from \"../../VirtualScrollList/VirtualScrollList\";\nimport { Input, InputRaw } from \"../Input/Input\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Box } from \"../../Box/Box\";\n\nconst StyledContainer = styled.div(() => ({\n  position: \"relative\",\n}));\n\nconst StyledInputWrap = styled.div(() => ({\n  zIndex: 0,\n  position: \"absolute\",\n  pointerEvents: \"none\",\n  width: \"100%\",\n  bottom: 0,\n  left: 0,\n}));\n\nconst StyledDropdown = styled.div<{ dropdownPosition: VerticalPosition }>(\n  ({ theme, dropdownPosition }) => ({\n    backgroundColor: theme.values.color.background.layer_2,\n    position: \"absolute\",\n    fontSize: theme.variables.size.font.text.s,\n    zIndex: 2,\n    width: \"100%\",\n    margin: `${theme.variables.size.spacing.xs} 0`,\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.dropdown.m,\n    overflow: \"hidden\",\n    boxShadow: theme.variables.shadow.card.b,\n    boxSizing: \"border-box\",\n    ...(dropdownPosition === \"down\" && {\n      top: \"100%\",\n    }),\n    ...(dropdownPosition === \"up\" && {\n      bottom: \"100%\",\n    }),\n  })\n);\n\nconst StyledDropdownItem = styled.div<{ active: boolean }>(\n  ({ theme, active }) => ({\n    padding: theme.variables.size.spacing.xs,\n    borderRadius: theme.variables.size.borderRadius.dropdown.s,\n    ...(active && {\n      backgroundColor: theme.values.color.background.dropdown.active,\n      borderRadius: 0,\n    }),\n    \"&:hover\": {\n      backgroundColor: theme.values.color.background.dropdown.active,\n      borderRadius: 0,\n    },\n  })\n);\n\nconst HiddenSelectInput = styled.select(() => ({\n  display: \"none\",\n}));\n\ntype SelectOption = {\n  value: string;\n  label: string;\n} & Record<string, unknown>;\n\nexport type SelectProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  emptyStateMessage?: string;\n  hasError?: boolean;\n  disabled?: boolean;\n  options?: SelectOption[];\n  filterMethod?: (options: SelectOption, value: string) => boolean;\n  onChange?: (e: React.FormEvent<HTMLSelectElement>) => void;\n  onBlur?: () => void;\n  onFocus?: () => void;\n  maxHeight?: number;\n  autoComplete?: string;\n} & FormFieldProps;\n\nconst defaultFilterMethod = (option: SelectOption, value: string): boolean =>\n  option.label.toLowerCase().indexOf(value.toLowerCase()) > -1;\n\nexport function Select({\n  options = [],\n  name,\n  value,\n  placeholder,\n  emptyStateMessage,\n  hasError,\n  filterMethod = defaultFilterMethod,\n  onChange = () => null,\n  onBlur = () => null,\n  onFocus = () => null,\n  maxHeight = 230,\n  autoComplete = \"on\",\n  ...rest\n}: SelectProps): React.ReactElement {\n  const { disabled } = rest;\n  const [isOpen, setIsOpen] = useState(false);\n  const [innerValue, setInnerValue] = useState(\"\");\n  const [preselectedIndex, setPreselectedIndex] = useState(-1);\n  const initialValueOption = useMemo(\n    () =>\n      options.find((option) => option.value === value) || {\n        value: \"\",\n        label: \"\",\n      },\n    [options, value]\n  );\n  const [fakeSelectedOption, setFakeSelectedOption] = useState(\n    initialValueOption\n  );\n  const fakeSelectRef = useRef(null);\n\n  const dropDownRef = useRef(null);\n  const innerInputRef = useRef(null);\n\n  const currentValueRef = useRef(value);\n  currentValueRef.current = value;\n\n  const forceChangeFakeSelect = useCallback(\n    (selectedOption: SelectOption) => {\n      if (fakeSelectedOption.value !== selectedOption.value) {\n        setFakeSelectedOption(selectedOption);\n      }\n    },\n    [fakeSelectedOption]\n  );\n\n  const [verticalPosition] = useAutoPosition(\n    fakeSelectRef,\n    dropDownRef,\n    isOpen\n  );\n\n  const closeDropdown = useCallback(\n    (noSelect = false) => {\n      setIsOpen(false);\n      if (!noSelect) {\n        const selectedOption = options.find(\n          (option) =>\n            option.label.toLowerCase().trim() ===\n            innerValue.toLowerCase().trim()\n        );\n        if (selectedOption) {\n          forceChangeFakeSelect(selectedOption);\n        }\n      }\n      setInnerValue(\"\");\n      setPreselectedIndex(-1);\n      onBlur();\n    },\n    [onBlur, forceChangeFakeSelect, innerValue, options]\n  );\n\n  useEffect(() => {\n    if (\n      fakeSelectRef.current &&\n      currentValueRef.current !== fakeSelectedOption.value\n    ) {\n      fakeSelectRef.current.dispatchEvent(\n        new Event(\"change\", { bubbles: true })\n      );\n    }\n  }, [fakeSelectedOption, fakeSelectRef, currentValueRef]);\n\n  // force updating the hidden select if a new initial value gets passed down\n  // without it, there would be a mismatch of selected value and the hidden select,\n  // which would cause the first value to not be selectable\n  useEffect(() => {\n    forceChangeFakeSelect(initialValueOption);\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [initialValueOption]);\n\n  const filteredOptions = useMemo(() => {\n    if (!innerValue) {\n      return options;\n    }\n\n    return options.filter((option) => filterMethod(option, innerValue));\n  }, [options, filterMethod, innerValue]);\n\n  const displayValue = useMemo(\n    () =>\n      options.some((option) => option.value === value)\n        ? options.find((option) => option.value === value).label\n        : \"\",\n    [value, options]\n  );\n\n  useEffect(() => {\n    setPreselectedIndex(-1);\n  }, [filteredOptions]);\n\n  useKeyboard(\n    {\n      Escape: () => closeDropdown(true),\n      Enter: () => {\n        if (filteredOptions[preselectedIndex]) {\n          forceChangeFakeSelect(filteredOptions[preselectedIndex]);\n          closeDropdown(true);\n          return;\n        }\n        closeDropdown();\n      },\n      ArrowUp: () => {\n        setPreselectedIndex(Math.max(preselectedIndex - 1, 0));\n      },\n      ArrowDown: () => {\n        setPreselectedIndex(\n          Math.min(preselectedIndex + 1, filteredOptions.length - 1)\n        );\n      },\n    },\n    innerInputRef,\n    isOpen && !disabled\n  );\n\n  useKeyboard(\n    {\n      \"ArrowUp ArrowDown\": () => {\n        setIsOpen(true);\n      },\n    },\n    innerInputRef,\n    !isOpen && !disabled\n  );\n\n  return (\n    <FormField {...(rest as FormFieldProps)}>\n      <StyledContainer\n        onBlur={() => {\n          closeDropdown(true);\n        }}\n      >\n        <div style={{ zIndex: 1 }}>\n          <InputRaw\n            areaLabel={rest.label}\n            name={`${name}-innerInput`}\n            value={innerValue}\n            privateProps={{ isTransparent: !(isOpen && innerValue) }}\n            icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n            hasError={hasError}\n            disabled={disabled}\n            onFocus={() => {\n              setIsOpen(true);\n              onFocus();\n            }}\n            onClick={() => {\n              setIsOpen(true);\n            }}\n            onChange={(e) => {\n              if (e.currentTarget.value) {\n                setIsOpen(true);\n              }\n              setInnerValue(e.currentTarget.value);\n            }}\n            ref={innerInputRef}\n            autoComplete={autoComplete}\n          />\n        </div>\n\n        <StyledInputWrap>\n          <Input\n            name={name}\n            value={displayValue}\n            onChange={() => null}\n            icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n            placeholder={placeholder}\n            tabIndex={-1}\n            autoComplete=\"off\"\n          />\n        </StyledInputWrap>\n\n        {isOpen && (\n          // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n          <StyledDropdown\n            dropdownPosition={verticalPosition}\n            ref={dropDownRef}\n            // this is to prevent known bug of Chrome when element\n            // loses focus on click on the scrollbar\n            onMouseDown={(e) => e.preventDefault()}\n          >\n            <VirtualScrollList\n              maxHeight={maxHeight}\n              itemHeight={36}\n              itemAmount={filteredOptions.length}\n              emptyState={() => (\n                <Box space=\"xs\">\n                  <Text>{emptyStateMessage || \"🤷🏻‍♀️\"}</Text>\n                </Box>\n              )}\n              itemInView={preselectedIndex}\n              itemTemplate={(index: number) => {\n                const option: SelectOption = filteredOptions[index];\n                return (\n                  // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n                  <StyledDropdownItem\n                    key={option.value}\n                    active={\n                      preselectedIndex === index || value === option.value\n                    }\n                    onMouseDown={() => {\n                      forceChangeFakeSelect(option);\n                      closeDropdown(true);\n                    }}\n                  >\n                    <Text weight=\"bold\" variant=\"secondary\" size=\"s\">\n                      {option.label}\n                    </Text>\n                  </StyledDropdownItem>\n                );\n              }}\n            />\n          </StyledDropdown>\n        )}\n\n        <HiddenSelectInput\n          onChange={onChange}\n          value={fakeSelectedOption.value}\n          ref={fakeSelectRef}\n          autoComplete=\"off\"\n        >\n          <option value={fakeSelectedOption.value}>\n            {fakeSelectedOption.label}\n          </option>\n        </HiddenSelectInput>\n      </StyledContainer>\n    </FormField>\n  );\n}\n"]} */");
|
|
68
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Select.tsx"],"names":[],"mappings":"AAkCuB","file":"Select.tsx","sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, {\n  useState,\n  useRef,\n  useMemo,\n  useEffect,\n  useCallback,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { useKeyboard } from \"../../../shared/useKeyboard\";\nimport {\n  useAutoPosition,\n  VerticalPosition,\n} from \"../../../shared/useAutoPosition\";\nimport { FormField, FormFieldProps } from \"../FormField/FormField\";\nimport { VirtualScrollList } from \"../../VirtualScrollList/VirtualScrollList\";\nimport { Input, InputRaw } from \"../Input/Input\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Box } from \"../../Box/Box\";\n\nconst StyledContainer = styled.div(() => ({\n  position: \"relative\",\n}));\n\nconst StyledInputWrap = styled.div(() => ({\n  zIndex: 0,\n  position: \"absolute\",\n  pointerEvents: \"none\",\n  width: \"100%\",\n  bottom: 0,\n  left: 0,\n}));\n\nconst StyledDropdown = styled.div<{ dropdownPosition: VerticalPosition }>(\n  ({ theme, dropdownPosition }) => ({\n    backgroundColor: theme.values.color.background.layer_2,\n    position: \"absolute\",\n    fontSize: theme.variables.size.font.text.s,\n    zIndex: 2,\n    width: \"100%\",\n    margin: `${theme.variables.size.spacing.xs} 0`,\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.dropdown.m,\n    overflow: \"hidden\",\n    boxShadow: theme.variables.shadow.card.b,\n    boxSizing: \"border-box\",\n    ...(dropdownPosition === \"down\" && {\n      top: \"100%\",\n    }),\n    ...(dropdownPosition === \"up\" && {\n      bottom: \"100%\",\n    }),\n  })\n);\n\nconst StyledDropdownItem = styled.div<{ active: boolean }>(\n  ({ theme, active }) => ({\n    padding: theme.variables.size.spacing.xs,\n    borderRadius: theme.variables.size.borderRadius.dropdown.s,\n    ...(active && {\n      backgroundColor: theme.values.color.background.dropdown.active,\n      borderRadius: 0,\n    }),\n    \"&:hover\": {\n      backgroundColor: theme.values.color.background.dropdown.active,\n      borderRadius: 0,\n    },\n  })\n);\n\nconst HiddenSelectInput = styled.select(() => ({\n  display: \"none\",\n}));\n\ntype SelectOption = {\n  value: string;\n  label: string;\n} & Record<string, unknown>;\n\nexport type SelectProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  emptyStateMessage?: string;\n  hasError?: boolean;\n  disabled?: boolean;\n  options?: SelectOption[];\n  filterMethod?: (options: SelectOption, value: string) => boolean;\n  onChange?: (e: React.FormEvent<HTMLSelectElement>) => void;\n  onBlur?: () => void;\n  onFocus?: () => void;\n  maxHeight?: number;\n  autoComplete?: string;\n} & FormFieldProps;\n\nconst defaultFilterMethod = (option: SelectOption, value: string): boolean =>\n  option.label.toLowerCase().indexOf(value.toLowerCase()) > -1;\n\nexport function Select({\n  options = [],\n  name,\n  value,\n  placeholder,\n  emptyStateMessage,\n  hasError,\n  filterMethod = defaultFilterMethod,\n  onChange = () => null,\n  onBlur = () => null,\n  onFocus = () => null,\n  maxHeight = 230,\n  autoComplete = \"on\",\n  ...rest\n}: SelectProps): React.ReactElement {\n  const { disabled } = rest;\n  const [isOpen, setIsOpen] = useState(false);\n  const [innerValue, setInnerValue] = useState(\"\");\n  const [preselectedIndex, setPreselectedIndex] = useState(-1);\n  const initialValueOption = useMemo(\n    () =>\n      options.find((option) => option.value === value) || {\n        value: \"\",\n        label: \"\",\n      },\n    [options, value]\n  );\n  const [fakeSelectedOption, setFakeSelectedOption] =\n    useState(initialValueOption);\n  const fakeSelectRef = useRef(null);\n\n  const dropDownRef = useRef(null);\n  const innerInputRef = useRef(null);\n\n  const currentValueRef = useRef(value);\n  currentValueRef.current = value;\n\n  const forceChangeFakeSelect = useCallback(\n    (selectedOption: SelectOption) => {\n      if (fakeSelectedOption.value !== selectedOption.value) {\n        setFakeSelectedOption(selectedOption);\n      }\n    },\n    [fakeSelectedOption]\n  );\n\n  const [verticalPosition] = useAutoPosition(\n    fakeSelectRef,\n    dropDownRef,\n    isOpen\n  );\n\n  const closeDropdown = useCallback(\n    (noSelect = false) => {\n      setIsOpen(false);\n      if (!noSelect) {\n        const selectedOption = options.find(\n          (option) =>\n            option.label.toLowerCase().trim() ===\n            innerValue.toLowerCase().trim()\n        );\n        if (selectedOption) {\n          forceChangeFakeSelect(selectedOption);\n        }\n      }\n      setInnerValue(\"\");\n      setPreselectedIndex(-1);\n      onBlur();\n    },\n    [onBlur, forceChangeFakeSelect, innerValue, options]\n  );\n\n  useEffect(() => {\n    if (\n      fakeSelectRef.current &&\n      currentValueRef.current !== fakeSelectedOption.value\n    ) {\n      fakeSelectRef.current.dispatchEvent(\n        new Event(\"change\", { bubbles: true })\n      );\n    }\n  }, [fakeSelectedOption, fakeSelectRef, currentValueRef]);\n\n  // force updating the hidden select if a new initial value gets passed down\n  // without it, there would be a mismatch of selected value and the hidden select,\n  // which would cause the first value to not be selectable\n  useEffect(() => {\n    forceChangeFakeSelect(initialValueOption);\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [initialValueOption]);\n\n  const filteredOptions = useMemo(() => {\n    if (!innerValue) {\n      return options;\n    }\n\n    return options.filter((option) => filterMethod(option, innerValue));\n  }, [options, filterMethod, innerValue]);\n\n  const displayValue = useMemo(\n    () =>\n      options.some((option) => option.value === value)\n        ? options.find((option) => option.value === value).label\n        : \"\",\n    [value, options]\n  );\n\n  useEffect(() => {\n    setPreselectedIndex(-1);\n  }, [filteredOptions]);\n\n  useKeyboard(\n    {\n      Escape: () => closeDropdown(true),\n      Enter: () => {\n        if (filteredOptions[preselectedIndex]) {\n          forceChangeFakeSelect(filteredOptions[preselectedIndex]);\n          closeDropdown(true);\n          return;\n        }\n        closeDropdown();\n      },\n      ArrowUp: () => {\n        setPreselectedIndex(Math.max(preselectedIndex - 1, 0));\n      },\n      ArrowDown: () => {\n        setPreselectedIndex(\n          Math.min(preselectedIndex + 1, filteredOptions.length - 1)\n        );\n      },\n    },\n    innerInputRef,\n    isOpen && !disabled\n  );\n\n  useKeyboard(\n    {\n      \"ArrowUp ArrowDown\": () => {\n        setIsOpen(true);\n      },\n    },\n    innerInputRef,\n    !isOpen && !disabled\n  );\n\n  return (\n    <FormField {...(rest as FormFieldProps)}>\n      <StyledContainer\n        onBlur={() => {\n          closeDropdown(true);\n        }}\n      >\n        <div style={{ zIndex: 1 }}>\n          <InputRaw\n            areaLabel={rest.label}\n            name={`${name}-innerInput`}\n            value={innerValue}\n            privateProps={{ isTransparent: !(isOpen && innerValue) }}\n            icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n            hasError={hasError}\n            disabled={disabled}\n            onFocus={() => {\n              setIsOpen(true);\n              onFocus();\n            }}\n            onClick={() => {\n              setIsOpen(true);\n            }}\n            onChange={(e) => {\n              if (e.currentTarget.value) {\n                setIsOpen(true);\n              }\n              setInnerValue(e.currentTarget.value);\n            }}\n            ref={innerInputRef}\n            autoComplete={autoComplete}\n          />\n        </div>\n\n        <StyledInputWrap>\n          <Input\n            name={name}\n            value={displayValue}\n            onChange={() => null}\n            icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n            placeholder={placeholder}\n            tabIndex={-1}\n            autoComplete=\"off\"\n          />\n        </StyledInputWrap>\n\n        {isOpen && (\n          // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n          <StyledDropdown\n            dropdownPosition={verticalPosition}\n            ref={dropDownRef}\n            // this is to prevent known bug of Chrome when element\n            // loses focus on click on the scrollbar\n            onMouseDown={(e) => e.preventDefault()}\n          >\n            <VirtualScrollList\n              maxHeight={maxHeight}\n              itemHeight={36}\n              itemAmount={filteredOptions.length}\n              emptyState={() => (\n                <Box space=\"xs\">\n                  <Text>{emptyStateMessage || \"🤷🏻‍♀️\"}</Text>\n                </Box>\n              )}\n              itemInView={preselectedIndex}\n              itemTemplate={(index: number) => {\n                const option: SelectOption = filteredOptions[index];\n                return (\n                  // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n                  <StyledDropdownItem\n                    key={option.value}\n                    active={\n                      preselectedIndex === index || value === option.value\n                    }\n                    onMouseDown={() => {\n                      forceChangeFakeSelect(option);\n                      closeDropdown(true);\n                    }}\n                  >\n                    <Text weight=\"bold\" variant=\"secondary\" size=\"s\">\n                      {option.label}\n                    </Text>\n                  </StyledDropdownItem>\n                );\n              }}\n            />\n          </StyledDropdown>\n        )}\n\n        <HiddenSelectInput\n          onChange={onChange}\n          value={fakeSelectedOption.value}\n          ref={fakeSelectRef}\n          autoComplete=\"off\"\n        >\n          <option value={fakeSelectedOption.value}>\n            {fakeSelectedOption.label}\n          </option>\n        </HiddenSelectInput>\n      </StyledContainer>\n    </FormField>\n  );\n}\n"]} */");
|
|
69
69
|
const StyledDropdownItem = /*#__PURE__*/_styled__default.default("div", process.env.NODE_ENV === "production" ? {
|
|
70
70
|
target: "el6d4lv1"
|
|
71
71
|
} : {
|
|
@@ -88,7 +88,7 @@ const StyledDropdownItem = /*#__PURE__*/_styled__default.default("div", process.
|
|
|
88
88
|
borderRadius: 0
|
|
89
89
|
}
|
|
90
90
|
};
|
|
91
|
-
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Select.tsx"],"names":[],"mappings":"AAwD2B","file":"Select.tsx","sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, {\n  useState,\n  useRef,\n  useMemo,\n  useEffect,\n  useCallback,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { useKeyboard } from \"../../../shared/useKeyboard\";\nimport {\n  useAutoPosition,\n  VerticalPosition,\n} from \"../../../shared/useAutoPosition\";\nimport { FormField, FormFieldProps } from \"../FormField/FormField\";\nimport { VirtualScrollList } from \"../../VirtualScrollList/VirtualScrollList\";\nimport { Input, InputRaw } from \"../Input/Input\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Box } from \"../../Box/Box\";\n\nconst StyledContainer = styled.div(() => ({\n  position: \"relative\",\n}));\n\nconst StyledInputWrap = styled.div(() => ({\n  zIndex: 0,\n  position: \"absolute\",\n  pointerEvents: \"none\",\n  width: \"100%\",\n  bottom: 0,\n  left: 0,\n}));\n\nconst StyledDropdown = styled.div<{ dropdownPosition: VerticalPosition }>(\n  ({ theme, dropdownPosition }) => ({\n    backgroundColor: theme.values.color.background.layer_2,\n    position: \"absolute\",\n    fontSize: theme.variables.size.font.text.s,\n    zIndex: 2,\n    width: \"100%\",\n    margin: `${theme.variables.size.spacing.xs} 0`,\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.dropdown.m,\n    overflow: \"hidden\",\n    boxShadow: theme.variables.shadow.card.b,\n    boxSizing: \"border-box\",\n    ...(dropdownPosition === \"down\" && {\n      top: \"100%\",\n    }),\n    ...(dropdownPosition === \"up\" && {\n      bottom: \"100%\",\n    }),\n  })\n);\n\nconst StyledDropdownItem = styled.div<{ active: boolean }>(\n  ({ theme, active }) => ({\n    padding: theme.variables.size.spacing.xs,\n    borderRadius: theme.variables.size.borderRadius.dropdown.s,\n    ...(active && {\n      backgroundColor: theme.values.color.background.dropdown.active,\n      borderRadius: 0,\n    }),\n    \"&:hover\": {\n      backgroundColor: theme.values.color.background.dropdown.active,\n      borderRadius: 0,\n    },\n  })\n);\n\nconst HiddenSelectInput = styled.select(() => ({\n  display: \"none\",\n}));\n\ntype SelectOption = {\n  value: string;\n  label: string;\n} & Record<string, unknown>;\n\nexport type SelectProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  emptyStateMessage?: string;\n  hasError?: boolean;\n  disabled?: boolean;\n  options?: SelectOption[];\n  filterMethod?: (options: SelectOption, value: string) => boolean;\n  onChange?: (e: React.FormEvent<HTMLSelectElement>) => void;\n  onBlur?: () => void;\n  onFocus?: () => void;\n  maxHeight?: number;\n  autoComplete?: string;\n} & FormFieldProps;\n\nconst defaultFilterMethod = (option: SelectOption, value: string): boolean =>\n  option.label.toLowerCase().indexOf(value.toLowerCase()) > -1;\n\nexport function Select({\n  options = [],\n  name,\n  value,\n  placeholder,\n  emptyStateMessage,\n  hasError,\n  filterMethod = defaultFilterMethod,\n  onChange = () => null,\n  onBlur = () => null,\n  onFocus = () => null,\n  maxHeight = 230,\n  autoComplete = \"on\",\n  ...rest\n}: SelectProps): React.ReactElement {\n  const { disabled } = rest;\n  const [isOpen, setIsOpen] = useState(false);\n  const [innerValue, setInnerValue] = useState(\"\");\n  const [preselectedIndex, setPreselectedIndex] = useState(-1);\n  const initialValueOption = useMemo(\n    () =>\n      options.find((option) => option.value === value) || {\n        value: \"\",\n        label: \"\",\n      },\n    [options, value]\n  );\n  const [fakeSelectedOption, setFakeSelectedOption] = useState(\n    initialValueOption\n  );\n  const fakeSelectRef = useRef(null);\n\n  const dropDownRef = useRef(null);\n  const innerInputRef = useRef(null);\n\n  const currentValueRef = useRef(value);\n  currentValueRef.current = value;\n\n  const forceChangeFakeSelect = useCallback(\n    (selectedOption: SelectOption) => {\n      if (fakeSelectedOption.value !== selectedOption.value) {\n        setFakeSelectedOption(selectedOption);\n      }\n    },\n    [fakeSelectedOption]\n  );\n\n  const [verticalPosition] = useAutoPosition(\n    fakeSelectRef,\n    dropDownRef,\n    isOpen\n  );\n\n  const closeDropdown = useCallback(\n    (noSelect = false) => {\n      setIsOpen(false);\n      if (!noSelect) {\n        const selectedOption = options.find(\n          (option) =>\n            option.label.toLowerCase().trim() ===\n            innerValue.toLowerCase().trim()\n        );\n        if (selectedOption) {\n          forceChangeFakeSelect(selectedOption);\n        }\n      }\n      setInnerValue(\"\");\n      setPreselectedIndex(-1);\n      onBlur();\n    },\n    [onBlur, forceChangeFakeSelect, innerValue, options]\n  );\n\n  useEffect(() => {\n    if (\n      fakeSelectRef.current &&\n      currentValueRef.current !== fakeSelectedOption.value\n    ) {\n      fakeSelectRef.current.dispatchEvent(\n        new Event(\"change\", { bubbles: true })\n      );\n    }\n  }, [fakeSelectedOption, fakeSelectRef, currentValueRef]);\n\n  // force updating the hidden select if a new initial value gets passed down\n  // without it, there would be a mismatch of selected value and the hidden select,\n  // which would cause the first value to not be selectable\n  useEffect(() => {\n    forceChangeFakeSelect(initialValueOption);\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [initialValueOption]);\n\n  const filteredOptions = useMemo(() => {\n    if (!innerValue) {\n      return options;\n    }\n\n    return options.filter((option) => filterMethod(option, innerValue));\n  }, [options, filterMethod, innerValue]);\n\n  const displayValue = useMemo(\n    () =>\n      options.some((option) => option.value === value)\n        ? options.find((option) => option.value === value).label\n        : \"\",\n    [value, options]\n  );\n\n  useEffect(() => {\n    setPreselectedIndex(-1);\n  }, [filteredOptions]);\n\n  useKeyboard(\n    {\n      Escape: () => closeDropdown(true),\n      Enter: () => {\n        if (filteredOptions[preselectedIndex]) {\n          forceChangeFakeSelect(filteredOptions[preselectedIndex]);\n          closeDropdown(true);\n          return;\n        }\n        closeDropdown();\n      },\n      ArrowUp: () => {\n        setPreselectedIndex(Math.max(preselectedIndex - 1, 0));\n      },\n      ArrowDown: () => {\n        setPreselectedIndex(\n          Math.min(preselectedIndex + 1, filteredOptions.length - 1)\n        );\n      },\n    },\n    innerInputRef,\n    isOpen && !disabled\n  );\n\n  useKeyboard(\n    {\n      \"ArrowUp ArrowDown\": () => {\n        setIsOpen(true);\n      },\n    },\n    innerInputRef,\n    !isOpen && !disabled\n  );\n\n  return (\n    <FormField {...(rest as FormFieldProps)}>\n      <StyledContainer\n        onBlur={() => {\n          closeDropdown(true);\n        }}\n      >\n        <div style={{ zIndex: 1 }}>\n          <InputRaw\n            areaLabel={rest.label}\n            name={`${name}-innerInput`}\n            value={innerValue}\n            privateProps={{ isTransparent: !(isOpen && innerValue) }}\n            icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n            hasError={hasError}\n            disabled={disabled}\n            onFocus={() => {\n              setIsOpen(true);\n              onFocus();\n            }}\n            onClick={() => {\n              setIsOpen(true);\n            }}\n            onChange={(e) => {\n              if (e.currentTarget.value) {\n                setIsOpen(true);\n              }\n              setInnerValue(e.currentTarget.value);\n            }}\n            ref={innerInputRef}\n            autoComplete={autoComplete}\n          />\n        </div>\n\n        <StyledInputWrap>\n          <Input\n            name={name}\n            value={displayValue}\n            onChange={() => null}\n            icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n            placeholder={placeholder}\n            tabIndex={-1}\n            autoComplete=\"off\"\n          />\n        </StyledInputWrap>\n\n        {isOpen && (\n          // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n          <StyledDropdown\n            dropdownPosition={verticalPosition}\n            ref={dropDownRef}\n            // this is to prevent known bug of Chrome when element\n            // loses focus on click on the scrollbar\n            onMouseDown={(e) => e.preventDefault()}\n          >\n            <VirtualScrollList\n              maxHeight={maxHeight}\n              itemHeight={36}\n              itemAmount={filteredOptions.length}\n              emptyState={() => (\n                <Box space=\"xs\">\n                  <Text>{emptyStateMessage || \"🤷🏻‍♀️\"}</Text>\n                </Box>\n              )}\n              itemInView={preselectedIndex}\n              itemTemplate={(index: number) => {\n                const option: SelectOption = filteredOptions[index];\n                return (\n                  // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n                  <StyledDropdownItem\n                    key={option.value}\n                    active={\n                      preselectedIndex === index || value === option.value\n                    }\n                    onMouseDown={() => {\n                      forceChangeFakeSelect(option);\n                      closeDropdown(true);\n                    }}\n                  >\n                    <Text weight=\"bold\" variant=\"secondary\" size=\"s\">\n                      {option.label}\n                    </Text>\n                  </StyledDropdownItem>\n                );\n              }}\n            />\n          </StyledDropdown>\n        )}\n\n        <HiddenSelectInput\n          onChange={onChange}\n          value={fakeSelectedOption.value}\n          ref={fakeSelectRef}\n          autoComplete=\"off\"\n        >\n          <option value={fakeSelectedOption.value}>\n            {fakeSelectedOption.label}\n          </option>\n        </HiddenSelectInput>\n      </StyledContainer>\n    </FormField>\n  );\n}\n"]} */");
|
|
91
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Select.tsx"],"names":[],"mappings":"AAwD2B","file":"Select.tsx","sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, {\n  useState,\n  useRef,\n  useMemo,\n  useEffect,\n  useCallback,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { useKeyboard } from \"../../../shared/useKeyboard\";\nimport {\n  useAutoPosition,\n  VerticalPosition,\n} from \"../../../shared/useAutoPosition\";\nimport { FormField, FormFieldProps } from \"../FormField/FormField\";\nimport { VirtualScrollList } from \"../../VirtualScrollList/VirtualScrollList\";\nimport { Input, InputRaw } from \"../Input/Input\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Box } from \"../../Box/Box\";\n\nconst StyledContainer = styled.div(() => ({\n  position: \"relative\",\n}));\n\nconst StyledInputWrap = styled.div(() => ({\n  zIndex: 0,\n  position: \"absolute\",\n  pointerEvents: \"none\",\n  width: \"100%\",\n  bottom: 0,\n  left: 0,\n}));\n\nconst StyledDropdown = styled.div<{ dropdownPosition: VerticalPosition }>(\n  ({ theme, dropdownPosition }) => ({\n    backgroundColor: theme.values.color.background.layer_2,\n    position: \"absolute\",\n    fontSize: theme.variables.size.font.text.s,\n    zIndex: 2,\n    width: \"100%\",\n    margin: `${theme.variables.size.spacing.xs} 0`,\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.dropdown.m,\n    overflow: \"hidden\",\n    boxShadow: theme.variables.shadow.card.b,\n    boxSizing: \"border-box\",\n    ...(dropdownPosition === \"down\" && {\n      top: \"100%\",\n    }),\n    ...(dropdownPosition === \"up\" && {\n      bottom: \"100%\",\n    }),\n  })\n);\n\nconst StyledDropdownItem = styled.div<{ active: boolean }>(\n  ({ theme, active }) => ({\n    padding: theme.variables.size.spacing.xs,\n    borderRadius: theme.variables.size.borderRadius.dropdown.s,\n    ...(active && {\n      backgroundColor: theme.values.color.background.dropdown.active,\n      borderRadius: 0,\n    }),\n    \"&:hover\": {\n      backgroundColor: theme.values.color.background.dropdown.active,\n      borderRadius: 0,\n    },\n  })\n);\n\nconst HiddenSelectInput = styled.select(() => ({\n  display: \"none\",\n}));\n\ntype SelectOption = {\n  value: string;\n  label: string;\n} & Record<string, unknown>;\n\nexport type SelectProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  emptyStateMessage?: string;\n  hasError?: boolean;\n  disabled?: boolean;\n  options?: SelectOption[];\n  filterMethod?: (options: SelectOption, value: string) => boolean;\n  onChange?: (e: React.FormEvent<HTMLSelectElement>) => void;\n  onBlur?: () => void;\n  onFocus?: () => void;\n  maxHeight?: number;\n  autoComplete?: string;\n} & FormFieldProps;\n\nconst defaultFilterMethod = (option: SelectOption, value: string): boolean =>\n  option.label.toLowerCase().indexOf(value.toLowerCase()) > -1;\n\nexport function Select({\n  options = [],\n  name,\n  value,\n  placeholder,\n  emptyStateMessage,\n  hasError,\n  filterMethod = defaultFilterMethod,\n  onChange = () => null,\n  onBlur = () => null,\n  onFocus = () => null,\n  maxHeight = 230,\n  autoComplete = \"on\",\n  ...rest\n}: SelectProps): React.ReactElement {\n  const { disabled } = rest;\n  const [isOpen, setIsOpen] = useState(false);\n  const [innerValue, setInnerValue] = useState(\"\");\n  const [preselectedIndex, setPreselectedIndex] = useState(-1);\n  const initialValueOption = useMemo(\n    () =>\n      options.find((option) => option.value === value) || {\n        value: \"\",\n        label: \"\",\n      },\n    [options, value]\n  );\n  const [fakeSelectedOption, setFakeSelectedOption] =\n    useState(initialValueOption);\n  const fakeSelectRef = useRef(null);\n\n  const dropDownRef = useRef(null);\n  const innerInputRef = useRef(null);\n\n  const currentValueRef = useRef(value);\n  currentValueRef.current = value;\n\n  const forceChangeFakeSelect = useCallback(\n    (selectedOption: SelectOption) => {\n      if (fakeSelectedOption.value !== selectedOption.value) {\n        setFakeSelectedOption(selectedOption);\n      }\n    },\n    [fakeSelectedOption]\n  );\n\n  const [verticalPosition] = useAutoPosition(\n    fakeSelectRef,\n    dropDownRef,\n    isOpen\n  );\n\n  const closeDropdown = useCallback(\n    (noSelect = false) => {\n      setIsOpen(false);\n      if (!noSelect) {\n        const selectedOption = options.find(\n          (option) =>\n            option.label.toLowerCase().trim() ===\n            innerValue.toLowerCase().trim()\n        );\n        if (selectedOption) {\n          forceChangeFakeSelect(selectedOption);\n        }\n      }\n      setInnerValue(\"\");\n      setPreselectedIndex(-1);\n      onBlur();\n    },\n    [onBlur, forceChangeFakeSelect, innerValue, options]\n  );\n\n  useEffect(() => {\n    if (\n      fakeSelectRef.current &&\n      currentValueRef.current !== fakeSelectedOption.value\n    ) {\n      fakeSelectRef.current.dispatchEvent(\n        new Event(\"change\", { bubbles: true })\n      );\n    }\n  }, [fakeSelectedOption, fakeSelectRef, currentValueRef]);\n\n  // force updating the hidden select if a new initial value gets passed down\n  // without it, there would be a mismatch of selected value and the hidden select,\n  // which would cause the first value to not be selectable\n  useEffect(() => {\n    forceChangeFakeSelect(initialValueOption);\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [initialValueOption]);\n\n  const filteredOptions = useMemo(() => {\n    if (!innerValue) {\n      return options;\n    }\n\n    return options.filter((option) => filterMethod(option, innerValue));\n  }, [options, filterMethod, innerValue]);\n\n  const displayValue = useMemo(\n    () =>\n      options.some((option) => option.value === value)\n        ? options.find((option) => option.value === value).label\n        : \"\",\n    [value, options]\n  );\n\n  useEffect(() => {\n    setPreselectedIndex(-1);\n  }, [filteredOptions]);\n\n  useKeyboard(\n    {\n      Escape: () => closeDropdown(true),\n      Enter: () => {\n        if (filteredOptions[preselectedIndex]) {\n          forceChangeFakeSelect(filteredOptions[preselectedIndex]);\n          closeDropdown(true);\n          return;\n        }\n        closeDropdown();\n      },\n      ArrowUp: () => {\n        setPreselectedIndex(Math.max(preselectedIndex - 1, 0));\n      },\n      ArrowDown: () => {\n        setPreselectedIndex(\n          Math.min(preselectedIndex + 1, filteredOptions.length - 1)\n        );\n      },\n    },\n    innerInputRef,\n    isOpen && !disabled\n  );\n\n  useKeyboard(\n    {\n      \"ArrowUp ArrowDown\": () => {\n        setIsOpen(true);\n      },\n    },\n    innerInputRef,\n    !isOpen && !disabled\n  );\n\n  return (\n    <FormField {...(rest as FormFieldProps)}>\n      <StyledContainer\n        onBlur={() => {\n          closeDropdown(true);\n        }}\n      >\n        <div style={{ zIndex: 1 }}>\n          <InputRaw\n            areaLabel={rest.label}\n            name={`${name}-innerInput`}\n            value={innerValue}\n            privateProps={{ isTransparent: !(isOpen && innerValue) }}\n            icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n            hasError={hasError}\n            disabled={disabled}\n            onFocus={() => {\n              setIsOpen(true);\n              onFocus();\n            }}\n            onClick={() => {\n              setIsOpen(true);\n            }}\n            onChange={(e) => {\n              if (e.currentTarget.value) {\n                setIsOpen(true);\n              }\n              setInnerValue(e.currentTarget.value);\n            }}\n            ref={innerInputRef}\n            autoComplete={autoComplete}\n          />\n        </div>\n\n        <StyledInputWrap>\n          <Input\n            name={name}\n            value={displayValue}\n            onChange={() => null}\n            icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n            placeholder={placeholder}\n            tabIndex={-1}\n            autoComplete=\"off\"\n          />\n        </StyledInputWrap>\n\n        {isOpen && (\n          // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n          <StyledDropdown\n            dropdownPosition={verticalPosition}\n            ref={dropDownRef}\n            // this is to prevent known bug of Chrome when element\n            // loses focus on click on the scrollbar\n            onMouseDown={(e) => e.preventDefault()}\n          >\n            <VirtualScrollList\n              maxHeight={maxHeight}\n              itemHeight={36}\n              itemAmount={filteredOptions.length}\n              emptyState={() => (\n                <Box space=\"xs\">\n                  <Text>{emptyStateMessage || \"🤷🏻‍♀️\"}</Text>\n                </Box>\n              )}\n              itemInView={preselectedIndex}\n              itemTemplate={(index: number) => {\n                const option: SelectOption = filteredOptions[index];\n                return (\n                  // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n                  <StyledDropdownItem\n                    key={option.value}\n                    active={\n                      preselectedIndex === index || value === option.value\n                    }\n                    onMouseDown={() => {\n                      forceChangeFakeSelect(option);\n                      closeDropdown(true);\n                    }}\n                  >\n                    <Text weight=\"bold\" variant=\"secondary\" size=\"s\">\n                      {option.label}\n                    </Text>\n                  </StyledDropdownItem>\n                );\n              }}\n            />\n          </StyledDropdown>\n        )}\n\n        <HiddenSelectInput\n          onChange={onChange}\n          value={fakeSelectedOption.value}\n          ref={fakeSelectRef}\n          autoComplete=\"off\"\n        >\n          <option value={fakeSelectedOption.value}>\n            {fakeSelectedOption.label}\n          </option>\n        </HiddenSelectInput>\n      </StyledContainer>\n    </FormField>\n  );\n}\n"]} */");
|
|
92
92
|
const HiddenSelectInput = /*#__PURE__*/_styled__default.default("select", process.env.NODE_ENV === "production" ? {
|
|
93
93
|
target: "el6d4lv0"
|
|
94
94
|
} : {
|
|
@@ -96,7 +96,7 @@ const HiddenSelectInput = /*#__PURE__*/_styled__default.default("select", proces
|
|
|
96
96
|
label: "HiddenSelectInput"
|
|
97
97
|
})(() => ({
|
|
98
98
|
display: "none"
|
|
99
|
-
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Select.tsx"],"names":[],"mappings":"AAuE0B","file":"Select.tsx","sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, {\n  useState,\n  useRef,\n  useMemo,\n  useEffect,\n  useCallback,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { useKeyboard } from \"../../../shared/useKeyboard\";\nimport {\n  useAutoPosition,\n  VerticalPosition,\n} from \"../../../shared/useAutoPosition\";\nimport { FormField, FormFieldProps } from \"../FormField/FormField\";\nimport { VirtualScrollList } from \"../../VirtualScrollList/VirtualScrollList\";\nimport { Input, InputRaw } from \"../Input/Input\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Box } from \"../../Box/Box\";\n\nconst StyledContainer = styled.div(() => ({\n  position: \"relative\",\n}));\n\nconst StyledInputWrap = styled.div(() => ({\n  zIndex: 0,\n  position: \"absolute\",\n  pointerEvents: \"none\",\n  width: \"100%\",\n  bottom: 0,\n  left: 0,\n}));\n\nconst StyledDropdown = styled.div<{ dropdownPosition: VerticalPosition }>(\n  ({ theme, dropdownPosition }) => ({\n    backgroundColor: theme.values.color.background.layer_2,\n    position: \"absolute\",\n    fontSize: theme.variables.size.font.text.s,\n    zIndex: 2,\n    width: \"100%\",\n    margin: `${theme.variables.size.spacing.xs} 0`,\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.dropdown.m,\n    overflow: \"hidden\",\n    boxShadow: theme.variables.shadow.card.b,\n    boxSizing: \"border-box\",\n    ...(dropdownPosition === \"down\" && {\n      top: \"100%\",\n    }),\n    ...(dropdownPosition === \"up\" && {\n      bottom: \"100%\",\n    }),\n  })\n);\n\nconst StyledDropdownItem = styled.div<{ active: boolean }>(\n  ({ theme, active }) => ({\n    padding: theme.variables.size.spacing.xs,\n    borderRadius: theme.variables.size.borderRadius.dropdown.s,\n    ...(active && {\n      backgroundColor: theme.values.color.background.dropdown.active,\n      borderRadius: 0,\n    }),\n    \"&:hover\": {\n      backgroundColor: theme.values.color.background.dropdown.active,\n      borderRadius: 0,\n    },\n  })\n);\n\nconst HiddenSelectInput = styled.select(() => ({\n  display: \"none\",\n}));\n\ntype SelectOption = {\n  value: string;\n  label: string;\n} & Record<string, unknown>;\n\nexport type SelectProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  emptyStateMessage?: string;\n  hasError?: boolean;\n  disabled?: boolean;\n  options?: SelectOption[];\n  filterMethod?: (options: SelectOption, value: string) => boolean;\n  onChange?: (e: React.FormEvent<HTMLSelectElement>) => void;\n  onBlur?: () => void;\n  onFocus?: () => void;\n  maxHeight?: number;\n  autoComplete?: string;\n} & FormFieldProps;\n\nconst defaultFilterMethod = (option: SelectOption, value: string): boolean =>\n  option.label.toLowerCase().indexOf(value.toLowerCase()) > -1;\n\nexport function Select({\n  options = [],\n  name,\n  value,\n  placeholder,\n  emptyStateMessage,\n  hasError,\n  filterMethod = defaultFilterMethod,\n  onChange = () => null,\n  onBlur = () => null,\n  onFocus = () => null,\n  maxHeight = 230,\n  autoComplete = \"on\",\n  ...rest\n}: SelectProps): React.ReactElement {\n  const { disabled } = rest;\n  const [isOpen, setIsOpen] = useState(false);\n  const [innerValue, setInnerValue] = useState(\"\");\n  const [preselectedIndex, setPreselectedIndex] = useState(-1);\n  const initialValueOption = useMemo(\n    () =>\n      options.find((option) => option.value === value) || {\n        value: \"\",\n        label: \"\",\n      },\n    [options, value]\n  );\n  const [fakeSelectedOption, setFakeSelectedOption] = useState(\n    initialValueOption\n  );\n  const fakeSelectRef = useRef(null);\n\n  const dropDownRef = useRef(null);\n  const innerInputRef = useRef(null);\n\n  const currentValueRef = useRef(value);\n  currentValueRef.current = value;\n\n  const forceChangeFakeSelect = useCallback(\n    (selectedOption: SelectOption) => {\n      if (fakeSelectedOption.value !== selectedOption.value) {\n        setFakeSelectedOption(selectedOption);\n      }\n    },\n    [fakeSelectedOption]\n  );\n\n  const [verticalPosition] = useAutoPosition(\n    fakeSelectRef,\n    dropDownRef,\n    isOpen\n  );\n\n  const closeDropdown = useCallback(\n    (noSelect = false) => {\n      setIsOpen(false);\n      if (!noSelect) {\n        const selectedOption = options.find(\n          (option) =>\n            option.label.toLowerCase().trim() ===\n            innerValue.toLowerCase().trim()\n        );\n        if (selectedOption) {\n          forceChangeFakeSelect(selectedOption);\n        }\n      }\n      setInnerValue(\"\");\n      setPreselectedIndex(-1);\n      onBlur();\n    },\n    [onBlur, forceChangeFakeSelect, innerValue, options]\n  );\n\n  useEffect(() => {\n    if (\n      fakeSelectRef.current &&\n      currentValueRef.current !== fakeSelectedOption.value\n    ) {\n      fakeSelectRef.current.dispatchEvent(\n        new Event(\"change\", { bubbles: true })\n      );\n    }\n  }, [fakeSelectedOption, fakeSelectRef, currentValueRef]);\n\n  // force updating the hidden select if a new initial value gets passed down\n  // without it, there would be a mismatch of selected value and the hidden select,\n  // which would cause the first value to not be selectable\n  useEffect(() => {\n    forceChangeFakeSelect(initialValueOption);\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [initialValueOption]);\n\n  const filteredOptions = useMemo(() => {\n    if (!innerValue) {\n      return options;\n    }\n\n    return options.filter((option) => filterMethod(option, innerValue));\n  }, [options, filterMethod, innerValue]);\n\n  const displayValue = useMemo(\n    () =>\n      options.some((option) => option.value === value)\n        ? options.find((option) => option.value === value).label\n        : \"\",\n    [value, options]\n  );\n\n  useEffect(() => {\n    setPreselectedIndex(-1);\n  }, [filteredOptions]);\n\n  useKeyboard(\n    {\n      Escape: () => closeDropdown(true),\n      Enter: () => {\n        if (filteredOptions[preselectedIndex]) {\n          forceChangeFakeSelect(filteredOptions[preselectedIndex]);\n          closeDropdown(true);\n          return;\n        }\n        closeDropdown();\n      },\n      ArrowUp: () => {\n        setPreselectedIndex(Math.max(preselectedIndex - 1, 0));\n      },\n      ArrowDown: () => {\n        setPreselectedIndex(\n          Math.min(preselectedIndex + 1, filteredOptions.length - 1)\n        );\n      },\n    },\n    innerInputRef,\n    isOpen && !disabled\n  );\n\n  useKeyboard(\n    {\n      \"ArrowUp ArrowDown\": () => {\n        setIsOpen(true);\n      },\n    },\n    innerInputRef,\n    !isOpen && !disabled\n  );\n\n  return (\n    <FormField {...(rest as FormFieldProps)}>\n      <StyledContainer\n        onBlur={() => {\n          closeDropdown(true);\n        }}\n      >\n        <div style={{ zIndex: 1 }}>\n          <InputRaw\n            areaLabel={rest.label}\n            name={`${name}-innerInput`}\n            value={innerValue}\n            privateProps={{ isTransparent: !(isOpen && innerValue) }}\n            icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n            hasError={hasError}\n            disabled={disabled}\n            onFocus={() => {\n              setIsOpen(true);\n              onFocus();\n            }}\n            onClick={() => {\n              setIsOpen(true);\n            }}\n            onChange={(e) => {\n              if (e.currentTarget.value) {\n                setIsOpen(true);\n              }\n              setInnerValue(e.currentTarget.value);\n            }}\n            ref={innerInputRef}\n            autoComplete={autoComplete}\n          />\n        </div>\n\n        <StyledInputWrap>\n          <Input\n            name={name}\n            value={displayValue}\n            onChange={() => null}\n            icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n            placeholder={placeholder}\n            tabIndex={-1}\n            autoComplete=\"off\"\n          />\n        </StyledInputWrap>\n\n        {isOpen && (\n          // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n          <StyledDropdown\n            dropdownPosition={verticalPosition}\n            ref={dropDownRef}\n            // this is to prevent known bug of Chrome when element\n            // loses focus on click on the scrollbar\n            onMouseDown={(e) => e.preventDefault()}\n          >\n            <VirtualScrollList\n              maxHeight={maxHeight}\n              itemHeight={36}\n              itemAmount={filteredOptions.length}\n              emptyState={() => (\n                <Box space=\"xs\">\n                  <Text>{emptyStateMessage || \"🤷🏻‍♀️\"}</Text>\n                </Box>\n              )}\n              itemInView={preselectedIndex}\n              itemTemplate={(index: number) => {\n                const option: SelectOption = filteredOptions[index];\n                return (\n                  // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n                  <StyledDropdownItem\n                    key={option.value}\n                    active={\n                      preselectedIndex === index || value === option.value\n                    }\n                    onMouseDown={() => {\n                      forceChangeFakeSelect(option);\n                      closeDropdown(true);\n                    }}\n                  >\n                    <Text weight=\"bold\" variant=\"secondary\" size=\"s\">\n                      {option.label}\n                    </Text>\n                  </StyledDropdownItem>\n                );\n              }}\n            />\n          </StyledDropdown>\n        )}\n\n        <HiddenSelectInput\n          onChange={onChange}\n          value={fakeSelectedOption.value}\n          ref={fakeSelectRef}\n          autoComplete=\"off\"\n        >\n          <option value={fakeSelectedOption.value}>\n            {fakeSelectedOption.label}\n          </option>\n        </HiddenSelectInput>\n      </StyledContainer>\n    </FormField>\n  );\n}\n"]} */");
|
|
99
|
+
}), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Select.tsx"],"names":[],"mappings":"AAuE0B","file":"Select.tsx","sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, {\n  useState,\n  useRef,\n  useMemo,\n  useEffect,\n  useCallback,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { useKeyboard } from \"../../../shared/useKeyboard\";\nimport {\n  useAutoPosition,\n  VerticalPosition,\n} from \"../../../shared/useAutoPosition\";\nimport { FormField, FormFieldProps } from \"../FormField/FormField\";\nimport { VirtualScrollList } from \"../../VirtualScrollList/VirtualScrollList\";\nimport { Input, InputRaw } from \"../Input/Input\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Box } from \"../../Box/Box\";\n\nconst StyledContainer = styled.div(() => ({\n  position: \"relative\",\n}));\n\nconst StyledInputWrap = styled.div(() => ({\n  zIndex: 0,\n  position: \"absolute\",\n  pointerEvents: \"none\",\n  width: \"100%\",\n  bottom: 0,\n  left: 0,\n}));\n\nconst StyledDropdown = styled.div<{ dropdownPosition: VerticalPosition }>(\n  ({ theme, dropdownPosition }) => ({\n    backgroundColor: theme.values.color.background.layer_2,\n    position: \"absolute\",\n    fontSize: theme.variables.size.font.text.s,\n    zIndex: 2,\n    width: \"100%\",\n    margin: `${theme.variables.size.spacing.xs} 0`,\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.dropdown.m,\n    overflow: \"hidden\",\n    boxShadow: theme.variables.shadow.card.b,\n    boxSizing: \"border-box\",\n    ...(dropdownPosition === \"down\" && {\n      top: \"100%\",\n    }),\n    ...(dropdownPosition === \"up\" && {\n      bottom: \"100%\",\n    }),\n  })\n);\n\nconst StyledDropdownItem = styled.div<{ active: boolean }>(\n  ({ theme, active }) => ({\n    padding: theme.variables.size.spacing.xs,\n    borderRadius: theme.variables.size.borderRadius.dropdown.s,\n    ...(active && {\n      backgroundColor: theme.values.color.background.dropdown.active,\n      borderRadius: 0,\n    }),\n    \"&:hover\": {\n      backgroundColor: theme.values.color.background.dropdown.active,\n      borderRadius: 0,\n    },\n  })\n);\n\nconst HiddenSelectInput = styled.select(() => ({\n  display: \"none\",\n}));\n\ntype SelectOption = {\n  value: string;\n  label: string;\n} & Record<string, unknown>;\n\nexport type SelectProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  emptyStateMessage?: string;\n  hasError?: boolean;\n  disabled?: boolean;\n  options?: SelectOption[];\n  filterMethod?: (options: SelectOption, value: string) => boolean;\n  onChange?: (e: React.FormEvent<HTMLSelectElement>) => void;\n  onBlur?: () => void;\n  onFocus?: () => void;\n  maxHeight?: number;\n  autoComplete?: string;\n} & FormFieldProps;\n\nconst defaultFilterMethod = (option: SelectOption, value: string): boolean =>\n  option.label.toLowerCase().indexOf(value.toLowerCase()) > -1;\n\nexport function Select({\n  options = [],\n  name,\n  value,\n  placeholder,\n  emptyStateMessage,\n  hasError,\n  filterMethod = defaultFilterMethod,\n  onChange = () => null,\n  onBlur = () => null,\n  onFocus = () => null,\n  maxHeight = 230,\n  autoComplete = \"on\",\n  ...rest\n}: SelectProps): React.ReactElement {\n  const { disabled } = rest;\n  const [isOpen, setIsOpen] = useState(false);\n  const [innerValue, setInnerValue] = useState(\"\");\n  const [preselectedIndex, setPreselectedIndex] = useState(-1);\n  const initialValueOption = useMemo(\n    () =>\n      options.find((option) => option.value === value) || {\n        value: \"\",\n        label: \"\",\n      },\n    [options, value]\n  );\n  const [fakeSelectedOption, setFakeSelectedOption] =\n    useState(initialValueOption);\n  const fakeSelectRef = useRef(null);\n\n  const dropDownRef = useRef(null);\n  const innerInputRef = useRef(null);\n\n  const currentValueRef = useRef(value);\n  currentValueRef.current = value;\n\n  const forceChangeFakeSelect = useCallback(\n    (selectedOption: SelectOption) => {\n      if (fakeSelectedOption.value !== selectedOption.value) {\n        setFakeSelectedOption(selectedOption);\n      }\n    },\n    [fakeSelectedOption]\n  );\n\n  const [verticalPosition] = useAutoPosition(\n    fakeSelectRef,\n    dropDownRef,\n    isOpen\n  );\n\n  const closeDropdown = useCallback(\n    (noSelect = false) => {\n      setIsOpen(false);\n      if (!noSelect) {\n        const selectedOption = options.find(\n          (option) =>\n            option.label.toLowerCase().trim() ===\n            innerValue.toLowerCase().trim()\n        );\n        if (selectedOption) {\n          forceChangeFakeSelect(selectedOption);\n        }\n      }\n      setInnerValue(\"\");\n      setPreselectedIndex(-1);\n      onBlur();\n    },\n    [onBlur, forceChangeFakeSelect, innerValue, options]\n  );\n\n  useEffect(() => {\n    if (\n      fakeSelectRef.current &&\n      currentValueRef.current !== fakeSelectedOption.value\n    ) {\n      fakeSelectRef.current.dispatchEvent(\n        new Event(\"change\", { bubbles: true })\n      );\n    }\n  }, [fakeSelectedOption, fakeSelectRef, currentValueRef]);\n\n  // force updating the hidden select if a new initial value gets passed down\n  // without it, there would be a mismatch of selected value and the hidden select,\n  // which would cause the first value to not be selectable\n  useEffect(() => {\n    forceChangeFakeSelect(initialValueOption);\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [initialValueOption]);\n\n  const filteredOptions = useMemo(() => {\n    if (!innerValue) {\n      return options;\n    }\n\n    return options.filter((option) => filterMethod(option, innerValue));\n  }, [options, filterMethod, innerValue]);\n\n  const displayValue = useMemo(\n    () =>\n      options.some((option) => option.value === value)\n        ? options.find((option) => option.value === value).label\n        : \"\",\n    [value, options]\n  );\n\n  useEffect(() => {\n    setPreselectedIndex(-1);\n  }, [filteredOptions]);\n\n  useKeyboard(\n    {\n      Escape: () => closeDropdown(true),\n      Enter: () => {\n        if (filteredOptions[preselectedIndex]) {\n          forceChangeFakeSelect(filteredOptions[preselectedIndex]);\n          closeDropdown(true);\n          return;\n        }\n        closeDropdown();\n      },\n      ArrowUp: () => {\n        setPreselectedIndex(Math.max(preselectedIndex - 1, 0));\n      },\n      ArrowDown: () => {\n        setPreselectedIndex(\n          Math.min(preselectedIndex + 1, filteredOptions.length - 1)\n        );\n      },\n    },\n    innerInputRef,\n    isOpen && !disabled\n  );\n\n  useKeyboard(\n    {\n      \"ArrowUp ArrowDown\": () => {\n        setIsOpen(true);\n      },\n    },\n    innerInputRef,\n    !isOpen && !disabled\n  );\n\n  return (\n    <FormField {...(rest as FormFieldProps)}>\n      <StyledContainer\n        onBlur={() => {\n          closeDropdown(true);\n        }}\n      >\n        <div style={{ zIndex: 1 }}>\n          <InputRaw\n            areaLabel={rest.label}\n            name={`${name}-innerInput`}\n            value={innerValue}\n            privateProps={{ isTransparent: !(isOpen && innerValue) }}\n            icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n            hasError={hasError}\n            disabled={disabled}\n            onFocus={() => {\n              setIsOpen(true);\n              onFocus();\n            }}\n            onClick={() => {\n              setIsOpen(true);\n            }}\n            onChange={(e) => {\n              if (e.currentTarget.value) {\n                setIsOpen(true);\n              }\n              setInnerValue(e.currentTarget.value);\n            }}\n            ref={innerInputRef}\n            autoComplete={autoComplete}\n          />\n        </div>\n\n        <StyledInputWrap>\n          <Input\n            name={name}\n            value={displayValue}\n            onChange={() => null}\n            icon={isOpen ? \"chevron-up\" : \"chevron-down\"}\n            placeholder={placeholder}\n            tabIndex={-1}\n            autoComplete=\"off\"\n          />\n        </StyledInputWrap>\n\n        {isOpen && (\n          // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n          <StyledDropdown\n            dropdownPosition={verticalPosition}\n            ref={dropDownRef}\n            // this is to prevent known bug of Chrome when element\n            // loses focus on click on the scrollbar\n            onMouseDown={(e) => e.preventDefault()}\n          >\n            <VirtualScrollList\n              maxHeight={maxHeight}\n              itemHeight={36}\n              itemAmount={filteredOptions.length}\n              emptyState={() => (\n                <Box space=\"xs\">\n                  <Text>{emptyStateMessage || \"🤷🏻‍♀️\"}</Text>\n                </Box>\n              )}\n              itemInView={preselectedIndex}\n              itemTemplate={(index: number) => {\n                const option: SelectOption = filteredOptions[index];\n                return (\n                  // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n                  <StyledDropdownItem\n                    key={option.value}\n                    active={\n                      preselectedIndex === index || value === option.value\n                    }\n                    onMouseDown={() => {\n                      forceChangeFakeSelect(option);\n                      closeDropdown(true);\n                    }}\n                  >\n                    <Text weight=\"bold\" variant=\"secondary\" size=\"s\">\n                      {option.label}\n                    </Text>\n                  </StyledDropdownItem>\n                );\n              }}\n            />\n          </StyledDropdown>\n        )}\n\n        <HiddenSelectInput\n          onChange={onChange}\n          value={fakeSelectedOption.value}\n          ref={fakeSelectRef}\n          autoComplete=\"off\"\n        >\n          <option value={fakeSelectedOption.value}>\n            {fakeSelectedOption.label}\n          </option>\n        </HiddenSelectInput>\n      </StyledContainer>\n    </FormField>\n  );\n}\n"]} */");
|
|
100
100
|
const defaultFilterMethod = (option, value) => option.label.toLowerCase().indexOf(value.toLowerCase()) > -1;
|
|
101
101
|
function Select(_ref3) {
|
|
102
102
|
let {
|
|
@@ -69,7 +69,7 @@ const StyledPictogramButton = /*#__PURE__*/_styled__default.default("button", pr
|
|
|
69
69
|
borderRadius: "0"
|
|
70
70
|
})
|
|
71
71
|
};
|
|
72
|
-
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBpY3RvZ3JhbUJ1dHRvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUThCIiwiZmlsZSI6IlBpY3RvZ3JhbUJ1dHRvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSByZWFjdC9qc3gtcHJvcHMtbm8tc3ByZWFkaW5nICovXG5pbXBvcnQgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IEljb25OYW1lLCBJY29uIH0gZnJvbSBcIi4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uL0lubGluZS9JbmxpbmVcIjtcbmltcG9ydCB7IEJ1dHRvblByb3BzIH0gZnJvbSBcIi4uL0J1dHRvbi9CdXR0b25cIjtcbmltcG9ydCB7IFBvbHltb3JwaGljQ29tcG9uZW50UHJvcHNXaXRoUmVmLCBQb2x5bW9ycGhpY1JlZiB9IGZyb20gXCIuLi8uLi90eXBlc1wiO1xuXG5jb25zdCBTdHlsZWRQaWN0b2dyYW1CdXR0b24gPSBzdHlsZWQuYnV0dG9uPFBhcnRpYWw8UGljdG9ncmFtQnV0dG9uUHJvcHM+PihcbiAgKHsgdGhlbWUsIHZhcmlhbnQsIHNxdWFyZUNvcm5lcnMgfSkgPT4gKHtcbiAgICBcIiZbdHlwZT0nYnV0dG9uJ11cIjoge1xuICAgICAgYXBwZWFyYW5jZTogXCJub25lXCIsXG4gICAgICBcIi1tb3otYXBwZWFyYW5jZVwiOiBcIm5vbmVcIixcbiAgICAgIFwiLXdlYmtpdC1hcHBlYXJhbmNlXCI6IFwibm9uZVwiLFxuICAgIH0sXG4gICAgYm9yZGVyOiAwLFxuICAgIGRpc3BsYXk6IFwiaW5saW5lLWJsb2NrXCIsXG4gICAgdGV4dFRyYW5zZm9ybTogXCJub25lXCIsXG4gICAgdGV4dERlY29yYXRpb246IFwibm9uZVwiLFxuICAgIGJvcmRlclJhZGl1czogdGhlbWUudmFyaWFibGVzLnNpemUuYm9yZGVyUmFkaXVzLmJ1dHRvbi5tLFxuICAgIGZvbnRGYW1pbHk6IHRoZW1lLnZhcmlhYmxlcy5mb250RmFtaWx5LmxhdG8sXG4gICAgZm9udFNpemU6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmZvbnQuYnV0dG9uLm0sXG4gICAgbGluZUhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUubGluZUhlaWdodC5idXR0b24ubSxcbiAgICBmb250V2VpZ2h0OiB0aGVtZS52YXJpYWJsZXMud2VpZ2h0LmJvbGQsXG4gICAgcGFkZGluZzogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gICAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgICBcIiZbZGlzYWJsZWRdLCAmOmRpc2FibGVkXCI6IHtcbiAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmJ1dHRvbi5kaXNhYmxlZCxcbiAgICAgIHBvaW50ZXJFdmVudHM6IFwibm9uZVwiLFxuICAgIH0sXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5idXR0b25bdmFyaWFudF0uYmFzZSxcbiAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnRleHQuYnV0dG9uW3ZhcmlhbnRdLmJhc2UsXG4gICAgXCImOmhvdmVyXCI6IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQuYnV0dG9uW3ZhcmlhbnRdLmhvdmVyLFxuICAgICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LmJ1dHRvblt2YXJpYW50XS5ob3ZlcixcbiAgICB9LFxuICAgIFwiJjphY3RpdmVcIjoge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5idXR0b25bdmFyaWFudF0uYWN0aXZlLFxuICAgICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LmJ1dHRvblt2YXJpYW50XS5hY3RpdmUsXG4gICAgfSxcbiAgICAuLi4odmFyaWFudCA9PT0gXCJzZWNvbmRhcnlcIiAmJiB7XG4gICAgICBib3JkZXI6IFwiMXB4IHNvbGlkXCIsXG4gICAgICBib3JkZXJDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5idXR0b25bdmFyaWFudF0uYmFzZSxcbiAgICAgIHBhZGRpbmc6IHBhcnNlSW50KHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzLCAxMCkgLSAxLFxuICAgICAgXCImOmhvdmVyXCI6IHtcbiAgICAgICAgYm9yZGVyQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuYnV0dG9uW3ZhcmlhbnRdLmhvdmVyLFxuICAgICAgfSxcbiAgICAgIFwiJjphY3RpdmVcIjoge1xuICAgICAgICBib3JkZXJDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5idXR0b25bdmFyaWFudF0uYWN0aXZlLFxuICAgICAgfSxcbiAgICB9KSxcbiAgICAuLi4oc3F1YXJlQ29ybmVycyAmJiB7XG4gICAgICBib3JkZXJSYWRpdXM6IFwiMFwiLFxuICAgIH0pLFxuICB9KVxuKTtcblxuZXhwb3J0IHR5cGUgUGljdG9ncmFtQnV0dG9uUHJvcHMgPSBQaWNrPFxuICBCdXR0b25Qcm9wcyxcbiAgfCBcInZhcmlhbnRcIlxuICB8IFwidHlwZVwiXG4gIHwgXCJkaXNhYmxlZFwiXG4gIHwgXCJvbkNsaWNrXCJcbiAgfCBcIm9uRm9jdXNcIlxuICB8IFwib25CbHVyXCJcbiAgfCBcImRhdGEtZTJlLXRlc3QtaWRcIlxuPiAmIHtcbiAgLyoqIFRoZSBjZW50ZXJlZCBpY29uIHRvIGJlIGRpc3BsYXllZC4gKi9cbiAgaWNvbjogSWNvbk5hbWU7XG4gIC8qKiBJZiB0cnVlLCB0aGUgYnV0dG9uIGhhcyBzcXVhcmUgY29ybmVycy4gKi9cbiAgc3F1YXJlQ29ybmVycz86IGJvb2xlYW47XG59O1xuXG50eXBlIFBpY3RvZ3JhbUJ1dHRvbkNvbXBvbmVudCA9IDxDIGV4dGVuZHMgUmVhY3QuRWxlbWVudFR5cGUgPSBcImJ1dHRvblwiPihcbiAgcHJvcHM6IFBvbHltb3JwaGljQ29tcG9uZW50UHJvcHNXaXRoUmVmPEMsIFBpY3RvZ3JhbUJ1dHRvblByb3BzPlxuKSA9PiBSZWFjdC5SZWFjdEVsZW1lbnQgfCBudWxsO1xuXG5leHBvcnQgY29uc3QgUGljdG9ncmFtQnV0dG9uOiBQaWN0b2dyYW1CdXR0b25Db21wb25lbnQgPSBSZWFjdC5mb3J3YXJkUmVmKFxuICA8QyBleHRlbmRzIFJlYWN0LkVsZW1lbnRUeXBlID0gXCJidXR0b25cIj4oXG4gICAge1xuICAgICAgdHlwZSA9IFwiYnV0dG9uXCIsXG4gICAgICB2YXJpYW50ID0gXCJ0ZXJ0aWFyeVwiLFxuICAgICAgZGlzYWJsZWQgPSBmYWxzZSxcbiAgICAgIG9uQ2xpY2ssXG4gICAgICBvbkZvY3VzLFxuICAgICAgb25CbHVyLFxuICAgICAgXCJkYXRhLWUyZS10ZXN0LWlkXCI6IGRhdGFFMmVUZXN0SWQsXG4gICAgICBhcyxcbiAgICAgIGljb24sXG4gICAgICBzcXVhcmVDb3JuZXJzID0gZmFsc2UsXG4gICAgICAuLi5yZXN0XG4gICAgfTogUG9seW1vcnBoaWNDb21wb25lbnRQcm9wc1dpdGhSZWY8QywgUGljdG9ncmFtQnV0dG9uUHJvcHM+LFxuICAgIHJlZj86IFBvbHltb3JwaGljUmVmPEM+
|
|
72
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBpY3RvZ3JhbUJ1dHRvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUThCIiwiZmlsZSI6IlBpY3RvZ3JhbUJ1dHRvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSByZWFjdC9qc3gtcHJvcHMtbm8tc3ByZWFkaW5nICovXG5pbXBvcnQgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IEljb25OYW1lLCBJY29uIH0gZnJvbSBcIi4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uL0lubGluZS9JbmxpbmVcIjtcbmltcG9ydCB7IEJ1dHRvblByb3BzIH0gZnJvbSBcIi4uL0J1dHRvbi9CdXR0b25cIjtcbmltcG9ydCB7IFBvbHltb3JwaGljQ29tcG9uZW50UHJvcHNXaXRoUmVmLCBQb2x5bW9ycGhpY1JlZiB9IGZyb20gXCIuLi8uLi90eXBlc1wiO1xuXG5jb25zdCBTdHlsZWRQaWN0b2dyYW1CdXR0b24gPSBzdHlsZWQuYnV0dG9uPFBhcnRpYWw8UGljdG9ncmFtQnV0dG9uUHJvcHM+PihcbiAgKHsgdGhlbWUsIHZhcmlhbnQsIHNxdWFyZUNvcm5lcnMgfSkgPT4gKHtcbiAgICBcIiZbdHlwZT0nYnV0dG9uJ11cIjoge1xuICAgICAgYXBwZWFyYW5jZTogXCJub25lXCIsXG4gICAgICBcIi1tb3otYXBwZWFyYW5jZVwiOiBcIm5vbmVcIixcbiAgICAgIFwiLXdlYmtpdC1hcHBlYXJhbmNlXCI6IFwibm9uZVwiLFxuICAgIH0sXG4gICAgYm9yZGVyOiAwLFxuICAgIGRpc3BsYXk6IFwiaW5saW5lLWJsb2NrXCIsXG4gICAgdGV4dFRyYW5zZm9ybTogXCJub25lXCIsXG4gICAgdGV4dERlY29yYXRpb246IFwibm9uZVwiLFxuICAgIGJvcmRlclJhZGl1czogdGhlbWUudmFyaWFibGVzLnNpemUuYm9yZGVyUmFkaXVzLmJ1dHRvbi5tLFxuICAgIGZvbnRGYW1pbHk6IHRoZW1lLnZhcmlhYmxlcy5mb250RmFtaWx5LmxhdG8sXG4gICAgZm9udFNpemU6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmZvbnQuYnV0dG9uLm0sXG4gICAgbGluZUhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUubGluZUhlaWdodC5idXR0b24ubSxcbiAgICBmb250V2VpZ2h0OiB0aGVtZS52YXJpYWJsZXMud2VpZ2h0LmJvbGQsXG4gICAgcGFkZGluZzogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gICAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgICBcIiZbZGlzYWJsZWRdLCAmOmRpc2FibGVkXCI6IHtcbiAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmJ1dHRvbi5kaXNhYmxlZCxcbiAgICAgIHBvaW50ZXJFdmVudHM6IFwibm9uZVwiLFxuICAgIH0sXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5idXR0b25bdmFyaWFudF0uYmFzZSxcbiAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnRleHQuYnV0dG9uW3ZhcmlhbnRdLmJhc2UsXG4gICAgXCImOmhvdmVyXCI6IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQuYnV0dG9uW3ZhcmlhbnRdLmhvdmVyLFxuICAgICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LmJ1dHRvblt2YXJpYW50XS5ob3ZlcixcbiAgICB9LFxuICAgIFwiJjphY3RpdmVcIjoge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5idXR0b25bdmFyaWFudF0uYWN0aXZlLFxuICAgICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LmJ1dHRvblt2YXJpYW50XS5hY3RpdmUsXG4gICAgfSxcbiAgICAuLi4odmFyaWFudCA9PT0gXCJzZWNvbmRhcnlcIiAmJiB7XG4gICAgICBib3JkZXI6IFwiMXB4IHNvbGlkXCIsXG4gICAgICBib3JkZXJDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5idXR0b25bdmFyaWFudF0uYmFzZSxcbiAgICAgIHBhZGRpbmc6IHBhcnNlSW50KHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzLCAxMCkgLSAxLFxuICAgICAgXCImOmhvdmVyXCI6IHtcbiAgICAgICAgYm9yZGVyQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuYnV0dG9uW3ZhcmlhbnRdLmhvdmVyLFxuICAgICAgfSxcbiAgICAgIFwiJjphY3RpdmVcIjoge1xuICAgICAgICBib3JkZXJDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5idXR0b25bdmFyaWFudF0uYWN0aXZlLFxuICAgICAgfSxcbiAgICB9KSxcbiAgICAuLi4oc3F1YXJlQ29ybmVycyAmJiB7XG4gICAgICBib3JkZXJSYWRpdXM6IFwiMFwiLFxuICAgIH0pLFxuICB9KVxuKTtcblxuZXhwb3J0IHR5cGUgUGljdG9ncmFtQnV0dG9uUHJvcHMgPSBQaWNrPFxuICBCdXR0b25Qcm9wcyxcbiAgfCBcInZhcmlhbnRcIlxuICB8IFwidHlwZVwiXG4gIHwgXCJkaXNhYmxlZFwiXG4gIHwgXCJvbkNsaWNrXCJcbiAgfCBcIm9uRm9jdXNcIlxuICB8IFwib25CbHVyXCJcbiAgfCBcImRhdGEtZTJlLXRlc3QtaWRcIlxuPiAmIHtcbiAgLyoqIFRoZSBjZW50ZXJlZCBpY29uIHRvIGJlIGRpc3BsYXllZC4gKi9cbiAgaWNvbjogSWNvbk5hbWU7XG4gIC8qKiBJZiB0cnVlLCB0aGUgYnV0dG9uIGhhcyBzcXVhcmUgY29ybmVycy4gKi9cbiAgc3F1YXJlQ29ybmVycz86IGJvb2xlYW47XG59O1xuXG50eXBlIFBpY3RvZ3JhbUJ1dHRvbkNvbXBvbmVudCA9IDxDIGV4dGVuZHMgUmVhY3QuRWxlbWVudFR5cGUgPSBcImJ1dHRvblwiPihcbiAgcHJvcHM6IFBvbHltb3JwaGljQ29tcG9uZW50UHJvcHNXaXRoUmVmPEMsIFBpY3RvZ3JhbUJ1dHRvblByb3BzPlxuKSA9PiBSZWFjdC5SZWFjdEVsZW1lbnQgfCBudWxsO1xuXG5leHBvcnQgY29uc3QgUGljdG9ncmFtQnV0dG9uOiBQaWN0b2dyYW1CdXR0b25Db21wb25lbnQgPSBSZWFjdC5mb3J3YXJkUmVmKFxuICA8QyBleHRlbmRzIFJlYWN0LkVsZW1lbnRUeXBlID0gXCJidXR0b25cIj4oXG4gICAge1xuICAgICAgdHlwZSA9IFwiYnV0dG9uXCIsXG4gICAgICB2YXJpYW50ID0gXCJ0ZXJ0aWFyeVwiLFxuICAgICAgZGlzYWJsZWQgPSBmYWxzZSxcbiAgICAgIG9uQ2xpY2ssXG4gICAgICBvbkZvY3VzLFxuICAgICAgb25CbHVyLFxuICAgICAgXCJkYXRhLWUyZS10ZXN0LWlkXCI6IGRhdGFFMmVUZXN0SWQsXG4gICAgICBhcyxcbiAgICAgIGljb24sXG4gICAgICBzcXVhcmVDb3JuZXJzID0gZmFsc2UsXG4gICAgICAuLi5yZXN0XG4gICAgfTogUG9seW1vcnBoaWNDb21wb25lbnRQcm9wc1dpdGhSZWY8QywgUGljdG9ncmFtQnV0dG9uUHJvcHM+LFxuICAgIHJlZj86IFBvbHltb3JwaGljUmVmPEM+XG4gICkgPT4ge1xuICAgIGZ1bmN0aW9uIGhhbmRsZUNsaWNrKGU6IFJlYWN0Lk1vdXNlRXZlbnQpIHtcbiAgICAgIGlmIChkaXNhYmxlZCkge1xuICAgICAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgICB9XG4gICAgICBpZiAob25DbGljaykge1xuICAgICAgICBvbkNsaWNrKGUpO1xuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiAoXG4gICAgICA8U3R5bGVkUGljdG9ncmFtQnV0dG9uXG4gICAgICAgIHJlZj17cmVmfVxuICAgICAgICBkYXRhLWUyZS10ZXN0LWlkPXtkYXRhRTJlVGVzdElkfVxuICAgICAgICBhcz17YXN9XG4gICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgdHlwZT17YXMgJiYgYXMgIT09IFwiYnV0dG9uXCIgPyB1bmRlZmluZWQgOiB0eXBlfVxuICAgICAgICB2YXJpYW50PXt2YXJpYW50fVxuICAgICAgICBzcXVhcmVDb3JuZXJzPXtzcXVhcmVDb3JuZXJzfVxuICAgICAgICBvbkNsaWNrPXtoYW5kbGVDbGlja31cbiAgICAgICAgb25Gb2N1cz17b25Gb2N1c31cbiAgICAgICAgb25CbHVyPXtvbkJsdXJ9XG4gICAgICAgIHsuLi5yZXN0fVxuICAgICAgPlxuICAgICAgICA8SW5saW5lIHZBbGlnbkl0ZW1zPVwiY2VudGVyXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiIHNwYWNlPVwieHhzXCIgbm9XcmFwPlxuICAgICAgICAgIDxJY29uXG4gICAgICAgICAgICBzaXplPVwic1wiXG4gICAgICAgICAgICBuYW1lPXtpY29ufVxuICAgICAgICAgICAgZGF0YS10ZXN0aWQ9e2ljb259XG4gICAgICAgICAgICBkYXRhLWUyZS10ZXN0LWlkPXtpY29ufVxuICAgICAgICAgIC8+XG4gICAgICAgIDwvSW5saW5lPlxuICAgICAgPC9TdHlsZWRQaWN0b2dyYW1CdXR0b24+XG4gICAgKTtcbiAgfVxuKTtcbiJdfQ== */");
|
|
73
73
|
const PictogramButton = /*#__PURE__*/React__default.default.forwardRef((_ref2, ref) => {
|
|
74
74
|
let {
|
|
75
75
|
type = "button",
|
|
@@ -102,8 +102,7 @@ const PictogramButton = /*#__PURE__*/React__default.default.forwardRef((_ref2, r
|
|
|
102
102
|
squareCorners: squareCorners,
|
|
103
103
|
onClick: handleClick,
|
|
104
104
|
onFocus: onFocus,
|
|
105
|
-
onBlur: onBlur
|
|
106
|
-
"aria-label": icon
|
|
105
|
+
onBlur: onBlur
|
|
107
106
|
}, rest), /*#__PURE__*/React__default.default.createElement(Inline.Inline, {
|
|
108
107
|
vAlignItems: "center",
|
|
109
108
|
alignItems: "center",
|
|
@@ -111,7 +110,9 @@ const PictogramButton = /*#__PURE__*/React__default.default.forwardRef((_ref2, r
|
|
|
111
110
|
noWrap: true
|
|
112
111
|
}, /*#__PURE__*/React__default.default.createElement(Icon.Icon, {
|
|
113
112
|
size: "s",
|
|
114
|
-
name: icon
|
|
113
|
+
name: icon,
|
|
114
|
+
"data-testid": icon,
|
|
115
|
+
"data-e2e-test-id": icon
|
|
115
116
|
})));
|
|
116
117
|
});
|
|
117
118
|
|
|
@@ -65,7 +65,7 @@ const StyledRoundButton = /*#__PURE__*/_styled__default.default("button", proces
|
|
|
65
65
|
}
|
|
66
66
|
})
|
|
67
67
|
};
|
|
68
|
-
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlJvdW5kQnV0dG9uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRMEIiLCJmaWxlIjoiUm91bmRCdXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBJY29uTmFtZSwgSWNvbiB9IGZyb20gXCIuLi9JY29uL0ljb25cIjtcbmltcG9ydCB7IElubGluZSB9IGZyb20gXCIuLi9JbmxpbmUvSW5saW5lXCI7XG5pbXBvcnQgeyBCdXR0b25Qcm9wcyB9IGZyb20gXCIuLi9CdXR0b24vQnV0dG9uXCI7XG5pbXBvcnQgeyBBc1Byb3AgfSBmcm9tIFwiLi4vLi4vdHlwZXNcIjtcblxuY29uc3QgU3R5bGVkUm91bmRCdXR0b24gPSBzdHlsZWQuYnV0dG9uPFBhcnRpYWw8Um91bmRCdXR0b25Qcm9wcz4+
|
|
68
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlJvdW5kQnV0dG9uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRMEIiLCJmaWxlIjoiUm91bmRCdXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBJY29uTmFtZSwgSWNvbiB9IGZyb20gXCIuLi9JY29uL0ljb25cIjtcbmltcG9ydCB7IElubGluZSB9IGZyb20gXCIuLi9JbmxpbmUvSW5saW5lXCI7XG5pbXBvcnQgeyBCdXR0b25Qcm9wcyB9IGZyb20gXCIuLi9CdXR0b24vQnV0dG9uXCI7XG5pbXBvcnQgeyBBc1Byb3AgfSBmcm9tIFwiLi4vLi4vdHlwZXNcIjtcblxuY29uc3QgU3R5bGVkUm91bmRCdXR0b24gPSBzdHlsZWQuYnV0dG9uPFBhcnRpYWw8Um91bmRCdXR0b25Qcm9wcz4+KFxuICAoeyB0aGVtZSwgdmFyaWFudCB9KSA9PiAoe1xuICAgIFwiJlt0eXBlPSdidXR0b24nXVwiOiB7XG4gICAgICBhcHBlYXJhbmNlOiBcIm5vbmVcIixcbiAgICAgIFwiLW1vei1hcHBlYXJhbmNlXCI6IFwibm9uZVwiLFxuICAgICAgXCItd2Via2l0LWFwcGVhcmFuY2VcIjogXCJub25lXCIsXG4gICAgfSxcbiAgICBib3JkZXI6IDAsXG4gICAgZGlzcGxheTogXCJpbmxpbmUtYmxvY2tcIixcbiAgICB0ZXh0VHJhbnNmb3JtOiBcIm5vbmVcIixcbiAgICB0ZXh0RGVjb3JhdGlvbjogXCJub25lXCIsXG4gICAgYm9yZGVyUmFkaXVzOiBcIjEwMCVcIixcbiAgICBmb250RmFtaWx5OiB0aGVtZS52YXJpYWJsZXMuZm9udEZhbWlseS5sYXRvLFxuICAgIGZvbnRTaXplOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5mb250LmJ1dHRvbi5tLFxuICAgIGxpbmVIZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmxpbmVIZWlnaHQuYnV0dG9uLm0sXG4gICAgZm9udFdlaWdodDogdGhlbWUudmFyaWFibGVzLndlaWdodC5ib2xkLFxuICAgIHBhZGRpbmc6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG4gICAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgICBcIiZbZGlzYWJsZWRdLCAmOmRpc2FibGVkXCI6IHtcbiAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmJ1dHRvbi5kaXNhYmxlZCxcbiAgICAgIHBvaW50ZXJFdmVudHM6IFwibm9uZVwiLFxuICAgIH0sXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5idXR0b25bdmFyaWFudF0uYmFzZSxcbiAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnRleHQuYnV0dG9uW3ZhcmlhbnRdLmJhc2UsXG4gICAgXCImOmhvdmVyXCI6IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQuYnV0dG9uW3ZhcmlhbnRdLmhvdmVyLFxuICAgICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LmJ1dHRvblt2YXJpYW50XS5ob3ZlcixcbiAgICB9LFxuICAgIFwiJjphY3RpdmVcIjoge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5idXR0b25bdmFyaWFudF0uYWN0aXZlLFxuICAgICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LmJ1dHRvblt2YXJpYW50XS5hY3RpdmUsXG4gICAgfSxcbiAgICAuLi4odmFyaWFudCA9PT0gXCJzZWNvbmRhcnlcIiAmJiB7XG4gICAgICBib3JkZXI6IFwiMnB4IHNvbGlkXCIsXG4gICAgICBib3JkZXJDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci50b2dnbGVCdXR0b24uZGVmYXVsdCxcbiAgICAgIHBhZGRpbmc6IHBhcnNlSW50KHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsIDEwKSAtIDIsXG4gICAgICBcIiY6aG92ZXJcIjoge1xuICAgICAgICBib3JkZXJDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci50b2dnbGVCdXR0b24uZGVmYXVsdEhvdmVyLFxuICAgICAgfSxcbiAgICAgIFwiJjphY3RpdmVcIjoge1xuICAgICAgICBib3JkZXJDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci50b2dnbGVCdXR0b24uZGVmYXVsdEhvdmVyLFxuICAgICAgfSxcbiAgICB9KSxcbiAgfSlcbik7XG5cbmV4cG9ydCB0eXBlIFJvdW5kQnV0dG9uUHJvcHMgPSBQaWNrPFxuICBCdXR0b25Qcm9wcyxcbiAgfCBcInZhcmlhbnRcIlxuICB8IFwidHlwZVwiXG4gIHwgXCJkaXNhYmxlZFwiXG4gIHwgXCJvbkNsaWNrXCJcbiAgfCBcIm9uRm9jdXNcIlxuICB8IFwib25CbHVyXCJcbiAgfCBcImRhdGEtZTJlLXRlc3QtaWRcIlxuPiAmIHtcbiAgLyoqIFRoZSBjZW50ZXJlZCBpY29uIHRvIGJlIGRpc3BsYXllZC4gKi9cbiAgaWNvbjogSWNvbk5hbWU7XG59O1xuXG5jb25zdCBkZWZhdWx0UHJvcHM6IFBhcnRpYWw8Um91bmRCdXR0b25Qcm9wcz4gJiBBc1Byb3A8XCJidXR0b25cIj4gPSB7XG4gIHR5cGU6IFwiYnV0dG9uXCIsXG4gIHZhcmlhbnQ6IFwidGVydGlhcnlcIixcbiAgZGlzYWJsZWQ6IGZhbHNlLFxuICBhczogXCJidXR0b25cIixcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI6IHVuZGVmaW5lZCxcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBSb3VuZEJ1dHRvbjxDIGV4dGVuZHMgUmVhY3QuRWxlbWVudFR5cGUgPSBcImJ1dHRvblwiPih7XG4gIG9uQ2xpY2ssXG4gIG9uRm9jdXMsXG4gIG9uQmx1cixcbiAgdHlwZSxcbiAgZGlzYWJsZWQsXG4gIGFzLFxuICBpY29uLFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgLi4ucmVzdFxufTogUm91bmRCdXR0b25Qcm9wcyAmIEFzUHJvcDxDPik6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFJvdW5kQnV0dG9uXG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPXtkYXRhRTJlVGVzdElkfVxuICAgICAgYXM9e2FzfVxuICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgdHlwZT17YXMgPT09IFwiYVwiID8gdW5kZWZpbmVkIDogdHlwZX1cbiAgICAgIG9uQ2xpY2s9eyhlOiBSZWFjdC5Nb3VzZUV2ZW50KSA9PiB7XG4gICAgICAgIGlmIChkaXNhYmxlZCkge1xuICAgICAgICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgfVxuICAgICAgICBpZiAob25DbGljaykge1xuICAgICAgICAgIG9uQ2xpY2soZSk7XG4gICAgICAgIH1cbiAgICAgIH19XG4gICAgICBvbkZvY3VzPXtvbkZvY3VzfVxuICAgICAgb25CbHVyPXtvbkJsdXJ9XG4gICAgICB7Li4ucmVzdH1cbiAgICA+XG4gICAgICA8SW5saW5lIHZBbGlnbkl0ZW1zPVwiY2VudGVyXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiIHNwYWNlPVwieHhzXCIgbm9XcmFwPlxuICAgICAgICB7aWNvbiAmJiAoXG4gICAgICAgICAgPEljb25cbiAgICAgICAgICAgIHNpemU9XCJzXCJcbiAgICAgICAgICAgIG5hbWU9e2ljb259XG4gICAgICAgICAgICBkYXRhLXRlc3RpZD17aWNvbn1cbiAgICAgICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2ljb259XG4gICAgICAgICAgLz5cbiAgICAgICAgKX1cbiAgICAgIDwvSW5saW5lPlxuICAgIDwvU3R5bGVkUm91bmRCdXR0b24+XG4gICk7XG59XG5Sb3VuZEJ1dHRvbi5kZWZhdWx0UHJvcHMgPSBkZWZhdWx0UHJvcHM7XG4iXX0= */");
|
|
69
69
|
const defaultProps = {
|
|
70
70
|
type: "button",
|
|
71
71
|
variant: "tertiary",
|
|
@@ -99,8 +99,7 @@ function RoundButton(_ref2) {
|
|
|
99
99
|
}
|
|
100
100
|
},
|
|
101
101
|
onFocus: onFocus,
|
|
102
|
-
onBlur: onBlur
|
|
103
|
-
"aria-label": icon
|
|
102
|
+
onBlur: onBlur
|
|
104
103
|
}, rest), /*#__PURE__*/React__default.default.createElement(Inline.Inline, {
|
|
105
104
|
vAlignItems: "center",
|
|
106
105
|
alignItems: "center",
|
|
@@ -108,7 +107,9 @@ function RoundButton(_ref2) {
|
|
|
108
107
|
noWrap: true
|
|
109
108
|
}, icon && /*#__PURE__*/React__default.default.createElement(Icon.Icon, {
|
|
110
109
|
size: "s",
|
|
111
|
-
name: icon
|
|
110
|
+
name: icon,
|
|
111
|
+
"data-testid": icon,
|
|
112
|
+
"data-e2e-test-id": icon
|
|
112
113
|
})));
|
|
113
114
|
}
|
|
114
115
|
RoundButton.defaultProps = defaultProps;
|