@foxford/ui 2.109.0 → 2.110.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (34) hide show
  1. package/components/Avatar/Avatar.js +1 -1
  2. package/components/Avatar/Avatar.js.map +1 -1
  3. package/components/Avatar/Avatar.mjs +1 -1
  4. package/components/Avatar/Avatar.mjs.map +1 -1
  5. package/components/Avatar/sizes.js +1 -1
  6. package/components/Avatar/sizes.js.map +1 -1
  7. package/components/Avatar/sizes.mjs +1 -1
  8. package/components/Avatar/sizes.mjs.map +1 -1
  9. package/components/Chip/Chip.js +1 -1
  10. package/components/Chip/Chip.js.map +1 -1
  11. package/components/Chip/Chip.mjs +1 -1
  12. package/components/Chip/Chip.mjs.map +1 -1
  13. package/components/Chip/sizes.js +2 -0
  14. package/components/Chip/sizes.js.map +1 -0
  15. package/components/Chip/sizes.mjs +2 -0
  16. package/components/Chip/sizes.mjs.map +1 -0
  17. package/components/Chip/style.js +1 -1
  18. package/components/Chip/style.js.map +1 -1
  19. package/components/Chip/style.mjs +1 -1
  20. package/components/Chip/style.mjs.map +1 -1
  21. package/components/Dropdown/Dropdown.js +1 -1
  22. package/components/Dropdown/Dropdown.js.map +1 -1
  23. package/components/Dropdown/Dropdown.mjs +1 -1
  24. package/components/Dropdown/Dropdown.mjs.map +1 -1
  25. package/components/Indicator/constants.js +1 -1
  26. package/components/Indicator/constants.js.map +1 -1
  27. package/components/Indicator/constants.mjs +1 -1
  28. package/components/Indicator/constants.mjs.map +1 -1
  29. package/dts/index.d.ts +383 -233
  30. package/package.json +2 -2
  31. package/components/Chip/constants.js +0 -2
  32. package/components/Chip/constants.js.map +0 -1
  33. package/components/Chip/constants.mjs +0 -2
  34. package/components/Chip/constants.mjs.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"Dropdown.js","sources":["../../../../src/components/Dropdown/Dropdown.tsx"],"sourcesContent":["import { forwardRef, useState, useRef, useEffect, useLayoutEffect, useMemo, useCallback } from 'react'\nimport { nanoid } from 'nanoid'\nimport { ChevronDown, Close } from '@foxford/icon-pack'\nimport { withMergedProps } from 'hocs/withMergedProps'\nimport type { MergedProps } from 'hocs/withMergedProps'\nimport { useScrollMonitor } from 'hooks/useScrollMonitor'\nimport { focusFirstFocusable, focusLastFocusable } from 'shared/utils/dom'\nimport { createDebouncedCallback } from 'shared/utils/misc'\nimport { keyboardKeys } from 'shared/constants'\nimport type { Nullable } from 'shared/types'\nimport { FormInput } from 'components/FormInput'\nimport { FormInputLabel } from 'components/FormInputLabel'\nimport { Chip } from 'components/Chip'\nimport { IconButton } from 'components/IconButton'\nimport { Icon } from 'components/Icon'\nimport { DropdownMenu } from './DropdownMenu'\nimport { useFilteredOptions, useLoadedOptions } from './hooks'\nimport { SIZES } from './sizes'\nimport { getDropdownInputText, getDropdownSelectedOption } from './utils'\nimport * as Styled from './style'\nimport type { DropdownProps, DropdownOption, DropdownOptionGroup } from './types'\nimport { DropdownMenuMultiple } from './DropdownMenuMultiple'\nimport { DropdownMenuSingle } from './DropdownMenuSingle'\n\nconst COMPONENT_NAME = 'Dropdown'\n\n/**\n *\n * Компонент для выбора одной или нескольких опций из числа доступных.\n *\n * Поддерживается \"ref\" и все нативные атрибуты \\<div\\> элемента.\n */\nconst Dropdown: React.ForwardRefExoticComponent<DropdownProps> = withMergedProps<DropdownProps, HTMLDivElement>(\n forwardRef<HTMLDivElement, MergedProps<DropdownProps>>((props, ref) => {\n const {\n size = 'm',\n name = 'fox-dropdown',\n labelPosition = 'dynamic',\n searchable = true,\n primary = true,\n optionsMultiToggle = true,\n iconProps = {},\n menuProps = {},\n loadingIconProps = {},\n optionsEmptyIconProps = {},\n loading,\n autoFocus,\n disableAutoScrollToSelectedOption,\n closeMenuOnScroll,\n scrollMonitorTarget,\n contrast,\n selectedOption,\n defaultSelectedOption,\n icon,\n addonLeft,\n inputMode,\n loadingMessage,\n loadingIcon,\n maxLength,\n multiple,\n clearable,\n onChangeInput,\n onCloseMenu,\n onOpenMenu,\n onSelectOption,\n options,\n loadOptions,\n renderOption,\n groupSelectedOptions,\n optionsMultiToggleCaption,\n optionsEmptyMessage,\n optionsEmptyIcon,\n palette,\n placeholder,\n readOnly,\n required,\n status,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n form,\n label,\n ...rootProps\n } = props\n\n const sizeProps = {\n size,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n }\n\n const formInputLabelId = useMemo(() => rootProps.id ?? `${name}-${nanoid()}`, [name, rootProps.id])\n const inputLabelId = useMemo(() => nanoid(), [])\n const menuListId = useMemo(() => nanoid(), [])\n\n const [filteredOptions, getFilteredOptions] = useFilteredOptions({\n options,\n })\n\n const [loadedOptions, optionsLoading, getLoadedOptions] = useLoadedOptions({\n loadOptions,\n options,\n })\n\n const [dropdownSelectedOption, setDropdownSelectedOption] = useState<DropdownOption[]>(() =>\n getDropdownSelectedOption(selectedOption !== undefined ? selectedOption : defaultSelectedOption, multiple)\n )\n\n const [inputText, setInputText] = useState<string>(() => getDropdownInputText(dropdownSelectedOption, multiple))\n\n const [focusWithin, setFocusWithin] = useState<boolean>(false)\n\n const [menuOpenRequest, setMenuOpenRequest] = useState<boolean>(false)\n\n const menuOptions: (DropdownOption | DropdownOptionGroup)[] = loadOptions ? loadedOptions : filteredOptions\n const menuOptionsLoading = loadOptions ? (loading ?? optionsLoading) : loading\n\n const menuOpen = menuOpenRequest && !rootProps.disabled\n\n const inputRequired = required && dropdownSelectedOption.length === 0\n const inputActive = Boolean(menuOpen || inputText || focusWithin)\n\n const inputRef = useRef<HTMLInputElement>(null)\n const [menuRef, setMenuRef] = useState<Nullable<HTMLElement>>(null)\n const menuListRef = useRef<HTMLUListElement>(null)\n const selectedOptionRef = useRef<HTMLElement>(null)\n const menuOpenPrevRef = useRef<boolean>(menuOpen)\n\n const updateInputText = useCallback(\n (inputTextValue: string) => {\n setInputText(inputTextValue)\n\n if (onChangeInput) {\n onChangeInput(inputTextValue)\n }\n },\n [onChangeInput]\n )\n\n const updateOptions = useCallback(\n (inputTextValue: string) => {\n if (loadOptions) {\n getLoadedOptions(inputTextValue)\n } else {\n getFilteredOptions(inputTextValue)\n }\n },\n [loadOptions, getLoadedOptions, getFilteredOptions]\n )\n\n const updateOptionsDebounced = useMemo(() => {\n return createDebouncedCallback(updateOptions, 150)\n }, [updateOptions])\n\n const preventBlur = (evt: React.PointerEvent<HTMLDivElement> | React.MouseEvent<HTMLDivElement, MouseEvent>) => {\n if (\n evt.target !== inputRef.current &&\n evt.target instanceof Node &&\n (evt.currentTarget.contains(evt.target) ||\n (menuProps.renderInPortal && menuOpen && menuRef && menuRef.contains(evt.target)))\n ) {\n evt.preventDefault()\n }\n }\n\n useScrollMonitor({\n target: scrollMonitorTarget,\n onScrollStart: () => {\n if (closeMenuOnScroll && menuOpen) {\n inputRef.current?.focus()\n setMenuOpenRequest(false)\n }\n },\n })\n\n useLayoutEffect(() => {\n if (selectedOption === undefined) return\n\n if (!multiple && !menuOpen) {\n updateInputText(getDropdownInputText(selectedOption))\n }\n setDropdownSelectedOption(getDropdownSelectedOption(selectedOption, multiple))\n }, [multiple, selectedOption, menuOpen, updateInputText])\n\n useEffect(() => {\n if (menuOpen === menuOpenPrevRef.current) return\n\n if (menuOpen && onOpenMenu) onOpenMenu()\n if (!menuOpen && onCloseMenu) onCloseMenu()\n\n menuOpenPrevRef.current = menuOpen\n }, [menuOpen, onCloseMenu, onOpenMenu])\n\n useEffect(() => {\n if (\n !multiple &&\n !disableAutoScrollToSelectedOption &&\n menuOpen &&\n !menuOptionsLoading &&\n inputText.length === 0 &&\n menuRef &&\n selectedOptionRef.current\n ) {\n const menuRect = menuRef.getBoundingClientRect()\n const selectedOptionRect = selectedOptionRef.current.getBoundingClientRect()\n\n if (selectedOptionRect.top < menuRect.top || selectedOptionRect.bottom > menuRect.bottom) {\n setTimeout(() => {\n if (menuRef && selectedOptionRef.current) {\n menuRef.scrollTo(0, selectedOptionRef.current.offsetTop)\n }\n }, 0)\n }\n }\n }, [multiple, disableAutoScrollToSelectedOption, menuOpen, menuOptionsLoading, inputText, menuRef])\n\n useEffect(() => {\n if (rootProps.disabled) {\n setFocusWithin(false)\n }\n }, [rootProps.disabled])\n\n return (\n <FormInputLabel\n {...rootProps}\n {...sizeProps}\n ref={ref}\n id={formInputLabelId}\n onColored={contrast}\n primary={primary}\n error={status === 'error'}\n success={status === 'success'}\n focus={focusWithin}\n palette={{\n color: rootProps.disabled ? palette.labelColorDisabled : palette.labelColor,\n backgroundColor: rootProps.disabled ? palette.backgroundColorDisabled : palette.backgroundColor,\n backgroundColorHover: rootProps.disabled ? palette.backgroundColorDisabled : palette.backgroundColorHover,\n borderColor: rootProps.disabled ? palette.borderColorDisabled : palette.borderColor,\n }}\n onClick={(evt) => {\n if (rootProps.onClick) rootProps.onClick(evt)\n\n if (rootProps.disabled) return\n\n inputRef.current?.focus()\n\n if (!menuOpen) {\n setMenuOpenRequest(true)\n\n updateOptions('')\n if (searchable) {\n updateInputText('')\n }\n } else if (menuRef && evt.target instanceof Node && !menuRef.contains(evt.target)) {\n setMenuOpenRequest(false)\n updateInputText(getDropdownInputText(dropdownSelectedOption, multiple))\n }\n }}\n onPointerDown={(evt) => {\n if (rootProps.onPointerDown) rootProps.onPointerDown(evt)\n\n preventBlur(evt)\n }}\n onMouseDown={(evt) => {\n if (rootProps.onMouseDown) rootProps.onMouseDown(evt)\n\n if (!window.PointerEvent) preventBlur(evt)\n }}\n onFocus={(evt) => {\n if (rootProps.onFocus) rootProps.onFocus(evt)\n\n setFocusWithin(true)\n\n if (inputRef.current && evt.target === inputRef.current && searchable && !multiple && !menuOpen) {\n updateInputText('')\n }\n }}\n onBlur={(evt) => {\n if (rootProps.onBlur) rootProps.onBlur(evt)\n\n if (\n evt.currentTarget.contains(evt.relatedTarget) ||\n (menuProps.renderInPortal && menuOpen && menuRef && menuRef.contains(evt.relatedTarget))\n ) {\n return\n }\n\n setFocusWithin(false)\n updateInputText(getDropdownInputText(dropdownSelectedOption, multiple))\n setMenuOpenRequest(false)\n }}\n input={\n <>\n {inputRequired && !searchable && !readOnly ? (\n <Styled.InputMimic\n required\n type='text'\n inputMode='none'\n form={form}\n tabIndex={-1}\n onFocus={() => {\n inputRef.current?.focus()\n }}\n />\n ) : null}\n <FormInput\n {...sizeProps}\n ref={inputRef}\n role='combobox'\n aria-controls={menuListId}\n aria-expanded={menuOpen}\n type='text'\n autoComplete='off'\n autoCapitalize='off'\n autoCorrect='off'\n spellCheck='false'\n active={inputActive}\n label={label}\n labelId={inputLabelId}\n labelPosition={labelPosition}\n form={form}\n autoFocus={autoFocus}\n inputMode={searchable ? inputMode : 'none'}\n maxLength={maxLength}\n placeholder={placeholder}\n readOnly={readOnly || !searchable}\n required={inputRequired}\n disabled={rootProps.disabled}\n value={inputText}\n palette={{\n color: palette.color,\n colorDisabled: palette.colorDisabled,\n placeholderColor: palette.placeholderColor,\n placeholderColorDisabled: palette.placeholderColorDisabled,\n }}\n onClick={(evt) => {\n if (menuOpen && evt.currentTarget.selectionStart !== evt.currentTarget.selectionEnd) {\n evt.stopPropagation()\n }\n }}\n onChange={(evt) => {\n const inputValue = evt.currentTarget.value\n\n updateInputText(inputValue)\n updateOptionsDebounced(inputValue)\n setMenuOpenRequest(true)\n }}\n onKeyDown={(evt) => {\n if (keyboardKeys.Enter.validate(evt.key)) {\n updateInputText(getDropdownInputText(dropdownSelectedOption, multiple))\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.Space.validate(evt.key) && (!menuOpen || evt.currentTarget.selectionStart === 0)) {\n evt.preventDefault()\n\n if (!menuOpen) {\n updateOptions('')\n if (searchable) {\n updateInputText('')\n }\n }\n\n setMenuOpenRequest((prev) => !prev)\n }\n\n if (keyboardKeys.Esc.validate(evt.key)) {\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.Tab.validate(evt.key) && menuOpen) {\n evt.preventDefault()\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.ArrowDown.validate(evt.key) && menuOpen && menuListRef.current) {\n evt.preventDefault()\n\n if (!multiple && selectedOptionRef.current) {\n const menuItems = [...menuListRef.current.children]\n\n const idx = menuItems.findIndex((item) => item.contains(selectedOptionRef.current as Node))\n\n const focusTarget = menuItems[idx + 1] ?? menuItems[0]\n\n if (focusTarget instanceof HTMLElement) {\n focusFirstFocusable(focusTarget)\n }\n } else {\n focusFirstFocusable(menuListRef.current)\n }\n }\n\n if (keyboardKeys.ArrowUp.validate(evt.key) && menuOpen && menuListRef.current) {\n evt.preventDefault()\n\n if (!multiple && selectedOptionRef.current) {\n const menuItems = [...menuListRef.current.children]\n\n const idx = menuItems.findIndex((item) => item.contains(selectedOptionRef.current as Node))\n\n const focusTarget = menuItems[idx - 1] ?? menuItems[menuItems.length - 1]\n\n if (focusTarget instanceof HTMLElement) {\n focusFirstFocusable(focusTarget)\n }\n } else {\n focusLastFocusable(menuListRef.current)\n }\n }\n }}\n />\n {dropdownSelectedOption.map((option) => (\n <input\n key={option.value}\n type='hidden'\n name={name}\n value={option.value}\n form={form}\n disabled={rootProps.disabled || option.disabled}\n />\n ))}\n </>\n }\n addonLeft={\n addonLeft ??\n (icon\n ? (addonLeftProps) => (\n <Icon\n {...addonLeftProps.iconProps}\n {...iconProps}\n name={typeof icon === 'string' ? icon : undefined}\n icon={typeof icon !== 'string' ? icon : undefined}\n />\n )\n : undefined)\n }\n addonRight={(addonRightProps) => (\n <>\n {multiple && dropdownSelectedOption.length > 0 ? (\n <Chip\n size='xs'\n active\n black\n disabled={rootProps.disabled}\n cursor={rootProps.disabled ? 'not-allowed' : undefined}\n text={dropdownSelectedOption.length}\n textProps={{\n appearance: 'caption',\n size: 'xs',\n }}\n palette={\n rootProps.disabled\n ? {\n color: 'content-disabled',\n colorHover: 'content-disabled',\n backgroundColor: 'bg-disabled-small',\n backgroundColorHover: 'bg-disabled-small',\n }\n : undefined\n }\n onPointerDown={(evt) => {\n evt.preventDefault()\n }}\n onMouseDown={(evt) => {\n if (!window.PointerEvent) evt.preventDefault()\n }}\n discardButtonProps={{\n square: true,\n contrast: !rootProps.disabled,\n onClick: (evt) => {\n evt.stopPropagation()\n\n if (!readOnly) {\n if (selectedOption === undefined) {\n setDropdownSelectedOption([])\n }\n\n if (onSelectOption) onSelectOption([])\n\n inputRef.current?.focus()\n updateInputText('')\n updateOptions('')\n setMenuOpenRequest(true)\n }\n },\n }}\n />\n ) : null}\n {!multiple && clearable && dropdownSelectedOption.length > 0 ? (\n <IconButton\n icon={<Close />}\n size='l'\n square\n disabled={rootProps.disabled}\n onClick={(evt) => {\n evt.stopPropagation()\n\n if (!readOnly) {\n if (selectedOption === undefined) {\n setDropdownSelectedOption([])\n }\n\n if (onSelectOption) onSelectOption(null)\n\n inputRef.current?.focus()\n updateInputText('')\n updateOptions('')\n setMenuOpenRequest(true)\n }\n }}\n />\n ) : null}\n <Styled.IconAnimated {...addonRightProps.iconProps} {...iconProps} icon={<ChevronDown />} up={menuOpen} />\n </>\n )}\n dropdown={(dropdownProps) => (\n <DropdownMenu\n {...menuProps}\n setRef={setMenuRef}\n open={menuOpen}\n popperReferenceId={formInputLabelId}\n secondary={!contrast}\n elevated={contrast}\n disableAutoFocus\n palette={{\n backgroundColor: palette.menuBackgroundColor,\n borderColor: palette.menuBorderColor,\n }}\n empty={menuOptions.length === 0}\n loading={menuOptionsLoading}\n loadingMessage={loadingMessage}\n loadingIcon={loadingIcon}\n loadingIconProps={{\n ...dropdownProps.iconProps,\n ...loadingIconProps,\n }}\n emptyMessage={optionsEmptyMessage}\n emptyIcon={optionsEmptyIcon}\n emptyIconProps={{\n ...dropdownProps.iconProps,\n ...optionsEmptyIconProps,\n }}\n onKeyDown={(evt) => {\n if (keyboardKeys.Tab.validate(evt.key)) {\n evt.preventDefault()\n inputRef.current?.focus()\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.Enter.validate(evt.key)) {\n inputRef.current?.focus()\n updateInputText(getDropdownInputText(dropdownSelectedOption, multiple))\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.Esc.validate(evt.key)) {\n inputRef.current?.focus()\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.Backspace.validate(evt.key) && !readOnly && (multiple || (!multiple && clearable))) {\n if (selectedOption === undefined) {\n setDropdownSelectedOption([])\n }\n\n if (onSelectOption) onSelectOption(multiple ? [] : null)\n\n updateInputText('')\n updateOptions('')\n }\n }}\n >\n {multiple ? (\n <DropdownMenuMultiple\n {...sizeProps}\n ref={menuListRef}\n inputRef={inputRef}\n label={label}\n name={name}\n disabled={rootProps.disabled}\n readOnly={readOnly}\n menuListId={menuListId}\n inputLabelId={inputLabelId}\n menuOptions={menuOptions}\n dropdownSelectedOption={dropdownSelectedOption}\n inputText={inputText}\n optionsMultiToggle={optionsMultiToggle}\n groupSelectedOptions={groupSelectedOptions}\n optionsMultiToggleCaption={optionsMultiToggleCaption}\n renderOption={renderOption}\n onChange={(update) => {\n if (selectedOption === undefined) {\n setDropdownSelectedOption(update)\n }\n\n if (onSelectOption) onSelectOption(update)\n }}\n />\n ) : (\n <DropdownMenuSingle\n {...sizeProps}\n ref={menuListRef}\n label={label}\n readOnly={readOnly}\n multiple={multiple}\n disabled={rootProps.disabled}\n status={status}\n menuListId={menuListId}\n inputLabelId={inputLabelId}\n menuOptions={menuOptions}\n dropdownSelectedOption={dropdownSelectedOption}\n selectedOptionRef={selectedOptionRef}\n renderOption={renderOption}\n onChange={(option) => {\n const update = { ...option }\n\n if (selectedOption === undefined) {\n updateInputText(getDropdownInputText(update))\n setDropdownSelectedOption(getDropdownSelectedOption(update))\n }\n\n if (onSelectOption) onSelectOption(update)\n\n inputRef.current?.focus()\n setMenuOpenRequest(false)\n }}\n />\n )}\n </DropdownMenu>\n )}\n />\n )\n }),\n {\n sizes: SIZES,\n displayName: COMPONENT_NAME,\n }\n)\n\nexport { Dropdown, COMPONENT_NAME }\n"],"names":["Dropdown","withMergedProps","forwardRef","props","ref","size","name","labelPosition","searchable","primary","optionsMultiToggle","iconProps","menuProps","loadingIconProps","optionsEmptyIconProps","loading","autoFocus","disableAutoScrollToSelectedOption","closeMenuOnScroll","scrollMonitorTarget","contrast","selectedOption","defaultSelectedOption","icon","addonLeft","inputMode","loadingMessage","loadingIcon","maxLength","multiple","clearable","onChangeInput","onCloseMenu","onOpenMenu","onSelectOption","options","loadOptions","renderOption","groupSelectedOptions","optionsMultiToggleCaption","optionsEmptyMessage","optionsEmptyIcon","palette","placeholder","readOnly","required","status","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","form","label","rootProps","sizeProps","formInputLabelId","useMemo","id","nanoid","inputLabelId","menuListId","filteredOptions","getFilteredOptions","useFilteredOptions","loadedOptions","optionsLoading","getLoadedOptions","useLoadedOptions","dropdownSelectedOption","setDropdownSelectedOption","useState","getDropdownSelectedOption","undefined","inputText","setInputText","getDropdownInputText","focusWithin","setFocusWithin","menuOpenRequest","setMenuOpenRequest","menuOptions","menuOptionsLoading","menuOpen","disabled","inputRequired","length","inputActive","Boolean","inputRef","useRef","menuRef","setMenuRef","menuListRef","selectedOptionRef","menuOpenPrevRef","updateInputText","useCallback","inputTextValue","updateOptions","updateOptionsDebounced","createDebouncedCallback","preventBlur","evt","target","current","Node","currentTarget","contains","renderInPortal","preventDefault","useScrollMonitor","onScrollStart","focus","useLayoutEffect","useEffect","menuRect","getBoundingClientRect","selectedOptionRect","top","bottom","setTimeout","scrollTo","offsetTop","_jsx","FormInputLabel","onColored","error","success","color","labelColorDisabled","labelColor","backgroundColor","backgroundColorDisabled","backgroundColorHover","borderColor","borderColorDisabled","onClick","onPointerDown","onMouseDown","window","PointerEvent","onFocus","onBlur","relatedTarget","input","_jsxs","_Fragment","children","Styled","type","tabIndex","FormInput","role","autoComplete","autoCapitalize","autoCorrect","spellCheck","active","labelId","value","colorDisabled","placeholderColor","placeholderColorDisabled","selectionStart","selectionEnd","stopPropagation","onChange","inputValue","onKeyDown","keyboardKeys","Enter","validate","key","Space","prev","Esc","Tab","ArrowDown","menuItems","idx","findIndex","item","focusTarget","HTMLElement","focusFirstFocusable","ArrowUp","focusLastFocusable","map","option","addonLeftProps","Icon","addonRight","addonRightProps","Chip","black","cursor","text","textProps","appearance","colorHover","discardButtonProps","square","IconButton","Close","ChevronDown","up","dropdown","dropdownProps","DropdownMenu","setRef","open","popperReferenceId","secondary","elevated","disableAutoFocus","menuBackgroundColor","menuBorderColor","empty","emptyMessage","emptyIcon","emptyIconProps","Backspace","DropdownMenuMultiple","update","DropdownMenuSingle","sizes","SIZES","displayName"],"mappings":"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"}
1
+ {"version":3,"file":"Dropdown.js","sources":["../../../../src/components/Dropdown/Dropdown.tsx"],"sourcesContent":["import { forwardRef, useState, useRef, useEffect, useLayoutEffect, useMemo, useCallback } from 'react'\nimport { nanoid } from 'nanoid'\nimport { ChevronDown, Close } from '@foxford/icon-pack'\nimport { withMergedProps } from 'hocs/withMergedProps'\nimport type { MergedProps } from 'hocs/withMergedProps'\nimport { useScrollMonitor } from 'hooks/useScrollMonitor'\nimport { focusFirstFocusable, focusLastFocusable } from 'shared/utils/dom'\nimport { createDebouncedCallback } from 'shared/utils/misc'\nimport { keyboardKeys } from 'shared/constants'\nimport type { Nullable } from 'shared/types'\nimport { FormInput } from 'components/FormInput'\nimport { FormInputLabel } from 'components/FormInputLabel'\nimport { Chip } from 'components/Chip'\nimport { IconButton } from 'components/IconButton'\nimport { Icon } from 'components/Icon'\nimport { DropdownMenu } from './DropdownMenu'\nimport { useFilteredOptions, useLoadedOptions } from './hooks'\nimport { SIZES } from './sizes'\nimport { getDropdownInputText, getDropdownSelectedOption } from './utils'\nimport * as Styled from './style'\nimport type { DropdownProps, DropdownOption, DropdownOptionGroup } from './types'\nimport { DropdownMenuMultiple } from './DropdownMenuMultiple'\nimport { DropdownMenuSingle } from './DropdownMenuSingle'\n\nconst COMPONENT_NAME = 'Dropdown'\n\n/**\n *\n * Компонент для выбора одной или нескольких опций из числа доступных.\n *\n * Поддерживается \"ref\" и все нативные атрибуты \\<div\\> элемента.\n */\nconst Dropdown: React.ForwardRefExoticComponent<DropdownProps> = withMergedProps<DropdownProps, HTMLDivElement>(\n forwardRef<HTMLDivElement, MergedProps<DropdownProps>>((props, ref) => {\n const {\n size = 'm',\n name = 'fox-dropdown',\n labelPosition = 'dynamic',\n searchable = true,\n primary = true,\n optionsMultiToggle = true,\n iconProps = {},\n menuProps = {},\n loadingIconProps = {},\n optionsEmptyIconProps = {},\n loading,\n autoFocus,\n disableAutoScrollToSelectedOption,\n closeMenuOnScroll,\n scrollMonitorTarget,\n contrast,\n selectedOption,\n defaultSelectedOption,\n icon,\n addonLeft,\n inputMode,\n loadingMessage,\n loadingIcon,\n maxLength,\n multiple,\n clearable,\n onChangeInput,\n onCloseMenu,\n onOpenMenu,\n onSelectOption,\n options,\n loadOptions,\n renderOption,\n groupSelectedOptions,\n optionsMultiToggleCaption,\n optionsEmptyMessage,\n optionsEmptyIcon,\n palette,\n placeholder,\n readOnly,\n required,\n status,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n form,\n label,\n ...rootProps\n } = props\n\n const sizeProps = {\n size,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n }\n\n const formInputLabelId = useMemo(() => rootProps.id ?? `${name}-${nanoid()}`, [name, rootProps.id])\n const inputLabelId = useMemo(() => nanoid(), [])\n const menuListId = useMemo(() => nanoid(), [])\n\n const [filteredOptions, getFilteredOptions] = useFilteredOptions({\n options,\n })\n\n const [loadedOptions, optionsLoading, getLoadedOptions] = useLoadedOptions({\n loadOptions,\n options,\n })\n\n const [dropdownSelectedOption, setDropdownSelectedOption] = useState<DropdownOption[]>(() =>\n getDropdownSelectedOption(selectedOption !== undefined ? selectedOption : defaultSelectedOption, multiple)\n )\n\n const [inputText, setInputText] = useState<string>(() => getDropdownInputText(dropdownSelectedOption, multiple))\n\n const [focusWithin, setFocusWithin] = useState<boolean>(false)\n\n const [menuOpenRequest, setMenuOpenRequest] = useState<boolean>(false)\n\n const menuOptions: (DropdownOption | DropdownOptionGroup)[] = loadOptions ? loadedOptions : filteredOptions\n const menuOptionsLoading = loadOptions ? (loading ?? optionsLoading) : loading\n\n const menuOpen = menuOpenRequest && !rootProps.disabled\n\n const inputRequired = required && dropdownSelectedOption.length === 0\n const inputActive = Boolean(menuOpen || inputText || focusWithin)\n\n const inputRef = useRef<HTMLInputElement>(null)\n const [menuRef, setMenuRef] = useState<Nullable<HTMLElement>>(null)\n const menuListRef = useRef<HTMLUListElement>(null)\n const selectedOptionRef = useRef<HTMLElement>(null)\n const menuOpenPrevRef = useRef<boolean>(menuOpen)\n\n const updateInputText = useCallback(\n (inputTextValue: string) => {\n setInputText(inputTextValue)\n\n if (onChangeInput) {\n onChangeInput(inputTextValue)\n }\n },\n [onChangeInput]\n )\n\n const updateOptions = useCallback(\n (inputTextValue: string) => {\n if (loadOptions) {\n getLoadedOptions(inputTextValue)\n } else {\n getFilteredOptions(inputTextValue)\n }\n },\n [loadOptions, getLoadedOptions, getFilteredOptions]\n )\n\n const updateOptionsDebounced = useMemo(() => {\n return createDebouncedCallback(updateOptions, 150)\n }, [updateOptions])\n\n const preventBlur = (evt: React.PointerEvent<HTMLDivElement> | React.MouseEvent<HTMLDivElement, MouseEvent>) => {\n if (\n evt.target !== inputRef.current &&\n evt.target instanceof Node &&\n (evt.currentTarget.contains(evt.target) ||\n (menuProps.renderInPortal && menuOpen && menuRef && menuRef.contains(evt.target)))\n ) {\n evt.preventDefault()\n }\n }\n\n useScrollMonitor({\n target: scrollMonitorTarget,\n onScrollStart: () => {\n if (closeMenuOnScroll && menuOpen) {\n inputRef.current?.focus()\n setMenuOpenRequest(false)\n }\n },\n })\n\n useLayoutEffect(() => {\n if (selectedOption === undefined) return\n\n if (!multiple && !menuOpen) {\n updateInputText(getDropdownInputText(selectedOption))\n }\n setDropdownSelectedOption(getDropdownSelectedOption(selectedOption, multiple))\n }, [multiple, selectedOption, menuOpen, updateInputText])\n\n useEffect(() => {\n if (menuOpen === menuOpenPrevRef.current) return\n\n if (menuOpen && onOpenMenu) onOpenMenu()\n if (!menuOpen && onCloseMenu) onCloseMenu()\n\n menuOpenPrevRef.current = menuOpen\n }, [menuOpen, onCloseMenu, onOpenMenu])\n\n useEffect(() => {\n if (\n !multiple &&\n !disableAutoScrollToSelectedOption &&\n menuOpen &&\n !menuOptionsLoading &&\n inputText.length === 0 &&\n menuRef &&\n selectedOptionRef.current\n ) {\n const menuRect = menuRef.getBoundingClientRect()\n const selectedOptionRect = selectedOptionRef.current.getBoundingClientRect()\n\n if (selectedOptionRect.top < menuRect.top || selectedOptionRect.bottom > menuRect.bottom) {\n setTimeout(() => {\n if (menuRef && selectedOptionRef.current) {\n menuRef.scrollTo(0, selectedOptionRef.current.offsetTop)\n }\n }, 0)\n }\n }\n }, [multiple, disableAutoScrollToSelectedOption, menuOpen, menuOptionsLoading, inputText, menuRef])\n\n useEffect(() => {\n if (rootProps.disabled) {\n setFocusWithin(false)\n }\n }, [rootProps.disabled])\n\n return (\n <FormInputLabel\n {...rootProps}\n {...sizeProps}\n ref={ref}\n id={formInputLabelId}\n onColored={contrast}\n primary={primary}\n error={status === 'error'}\n success={status === 'success'}\n focus={focusWithin}\n palette={{\n color: rootProps.disabled ? palette.labelColorDisabled : palette.labelColor,\n backgroundColor: rootProps.disabled ? palette.backgroundColorDisabled : palette.backgroundColor,\n backgroundColorHover: rootProps.disabled ? palette.backgroundColorDisabled : palette.backgroundColorHover,\n borderColor: rootProps.disabled ? palette.borderColorDisabled : palette.borderColor,\n }}\n onClick={(evt) => {\n if (rootProps.onClick) rootProps.onClick(evt)\n\n if (rootProps.disabled) return\n\n inputRef.current?.focus()\n\n if (!menuOpen) {\n setMenuOpenRequest(true)\n\n updateOptions('')\n if (searchable) {\n updateInputText('')\n }\n } else if (menuRef && evt.target instanceof Node && !menuRef.contains(evt.target)) {\n setMenuOpenRequest(false)\n updateInputText(getDropdownInputText(dropdownSelectedOption, multiple))\n }\n }}\n onPointerDown={(evt) => {\n if (rootProps.onPointerDown) rootProps.onPointerDown(evt)\n\n preventBlur(evt)\n }}\n onMouseDown={(evt) => {\n if (rootProps.onMouseDown) rootProps.onMouseDown(evt)\n\n if (!window.PointerEvent) preventBlur(evt)\n }}\n onFocus={(evt) => {\n if (rootProps.onFocus) rootProps.onFocus(evt)\n\n setFocusWithin(true)\n\n if (inputRef.current && evt.target === inputRef.current && searchable && !multiple && !menuOpen) {\n updateInputText('')\n }\n }}\n onBlur={(evt) => {\n if (rootProps.onBlur) rootProps.onBlur(evt)\n\n if (\n evt.currentTarget.contains(evt.relatedTarget) ||\n (menuProps.renderInPortal && menuOpen && menuRef && menuRef.contains(evt.relatedTarget))\n ) {\n return\n }\n\n setFocusWithin(false)\n updateInputText(getDropdownInputText(dropdownSelectedOption, multiple))\n setMenuOpenRequest(false)\n }}\n input={\n <>\n {inputRequired && !searchable && !readOnly ? (\n <Styled.InputMimic\n required\n type='text'\n inputMode='none'\n form={form}\n tabIndex={-1}\n onFocus={() => {\n inputRef.current?.focus()\n }}\n />\n ) : null}\n <FormInput\n {...sizeProps}\n ref={inputRef}\n role='combobox'\n aria-controls={menuListId}\n aria-expanded={menuOpen}\n type='text'\n autoComplete='off'\n autoCapitalize='off'\n autoCorrect='off'\n spellCheck='false'\n active={inputActive}\n label={label}\n labelId={inputLabelId}\n labelPosition={labelPosition}\n form={form}\n autoFocus={autoFocus}\n inputMode={searchable ? inputMode : 'none'}\n maxLength={maxLength}\n placeholder={placeholder}\n readOnly={readOnly || !searchable}\n required={inputRequired}\n disabled={rootProps.disabled}\n value={inputText}\n palette={{\n color: palette.color,\n colorDisabled: palette.colorDisabled,\n placeholderColor: palette.placeholderColor,\n placeholderColorDisabled: palette.placeholderColorDisabled,\n }}\n onClick={(evt) => {\n if (menuOpen && evt.currentTarget.selectionStart !== evt.currentTarget.selectionEnd) {\n evt.stopPropagation()\n }\n }}\n onChange={(evt) => {\n const inputValue = evt.currentTarget.value\n\n updateInputText(inputValue)\n updateOptionsDebounced(inputValue)\n setMenuOpenRequest(true)\n }}\n onKeyDown={(evt) => {\n if (keyboardKeys.Enter.validate(evt.key)) {\n updateInputText(getDropdownInputText(dropdownSelectedOption, multiple))\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.Space.validate(evt.key) && (!menuOpen || evt.currentTarget.selectionStart === 0)) {\n evt.preventDefault()\n\n if (!menuOpen) {\n updateOptions('')\n if (searchable) {\n updateInputText('')\n }\n }\n\n setMenuOpenRequest((prev) => !prev)\n }\n\n if (keyboardKeys.Esc.validate(evt.key)) {\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.Tab.validate(evt.key) && menuOpen) {\n evt.preventDefault()\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.ArrowDown.validate(evt.key) && menuOpen && menuListRef.current) {\n evt.preventDefault()\n\n if (!multiple && selectedOptionRef.current) {\n const menuItems = [...menuListRef.current.children]\n\n const idx = menuItems.findIndex((item) => item.contains(selectedOptionRef.current as Node))\n\n const focusTarget = menuItems[idx + 1] ?? menuItems[0]\n\n if (focusTarget instanceof HTMLElement) {\n focusFirstFocusable(focusTarget)\n }\n } else {\n focusFirstFocusable(menuListRef.current)\n }\n }\n\n if (keyboardKeys.ArrowUp.validate(evt.key) && menuOpen && menuListRef.current) {\n evt.preventDefault()\n\n if (!multiple && selectedOptionRef.current) {\n const menuItems = [...menuListRef.current.children]\n\n const idx = menuItems.findIndex((item) => item.contains(selectedOptionRef.current as Node))\n\n const focusTarget = menuItems[idx - 1] ?? menuItems[menuItems.length - 1]\n\n if (focusTarget instanceof HTMLElement) {\n focusFirstFocusable(focusTarget)\n }\n } else {\n focusLastFocusable(menuListRef.current)\n }\n }\n }}\n />\n {dropdownSelectedOption.map((option) => (\n <input\n key={option.value}\n type='hidden'\n name={name}\n value={option.value}\n form={form}\n disabled={rootProps.disabled || option.disabled}\n />\n ))}\n </>\n }\n addonLeft={\n addonLeft ??\n (icon\n ? (addonLeftProps) => (\n <Icon\n {...addonLeftProps.iconProps}\n {...iconProps}\n name={typeof icon === 'string' ? icon : undefined}\n icon={typeof icon !== 'string' ? icon : undefined}\n />\n )\n : undefined)\n }\n addonRight={(addonRightProps) => (\n <>\n {multiple && dropdownSelectedOption.length > 0 ? (\n <Chip\n size='xs'\n active\n black\n disabled={rootProps.disabled}\n cursor={rootProps.disabled ? 'not-allowed' : undefined}\n title={dropdownSelectedOption.length}\n palette={\n rootProps.disabled\n ? {\n color: 'content-disabled',\n colorHover: 'content-disabled',\n backgroundColor: 'bg-disabled-small',\n backgroundColorHover: 'bg-disabled-small',\n }\n : undefined\n }\n onPointerDown={(evt) => {\n evt.preventDefault()\n }}\n onMouseDown={(evt) => {\n if (!window.PointerEvent) evt.preventDefault()\n }}\n addonRight={(chipAddonRightProps) => (\n <IconButton\n {...chipAddonRightProps.iconButtonProps}\n contrast={!rootProps.disabled}\n onClick={(evt) => {\n evt.stopPropagation()\n\n if (!readOnly) {\n if (selectedOption === undefined) {\n setDropdownSelectedOption([])\n }\n\n if (onSelectOption) onSelectOption([])\n\n inputRef.current?.focus()\n updateInputText('')\n updateOptions('')\n setMenuOpenRequest(true)\n }\n }}\n />\n )}\n />\n ) : null}\n {!multiple && clearable && dropdownSelectedOption.length > 0 ? (\n <IconButton\n icon={<Close />}\n size='l'\n square\n disabled={rootProps.disabled}\n onClick={(evt) => {\n evt.stopPropagation()\n\n if (!readOnly) {\n if (selectedOption === undefined) {\n setDropdownSelectedOption([])\n }\n\n if (onSelectOption) onSelectOption(null)\n\n inputRef.current?.focus()\n updateInputText('')\n updateOptions('')\n setMenuOpenRequest(true)\n }\n }}\n />\n ) : null}\n <Styled.IconAnimated {...addonRightProps.iconProps} {...iconProps} icon={<ChevronDown />} up={menuOpen} />\n </>\n )}\n dropdown={(dropdownProps) => (\n <DropdownMenu\n {...menuProps}\n setRef={setMenuRef}\n open={menuOpen}\n popperReferenceId={formInputLabelId}\n secondary={!contrast}\n elevated={contrast}\n disableAutoFocus\n palette={{\n backgroundColor: palette.menuBackgroundColor,\n borderColor: palette.menuBorderColor,\n }}\n empty={menuOptions.length === 0}\n loading={menuOptionsLoading}\n loadingMessage={loadingMessage}\n loadingIcon={loadingIcon}\n loadingIconProps={{\n ...dropdownProps.iconProps,\n ...loadingIconProps,\n }}\n emptyMessage={optionsEmptyMessage}\n emptyIcon={optionsEmptyIcon}\n emptyIconProps={{\n ...dropdownProps.iconProps,\n ...optionsEmptyIconProps,\n }}\n onKeyDown={(evt) => {\n if (keyboardKeys.Tab.validate(evt.key)) {\n evt.preventDefault()\n inputRef.current?.focus()\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.Enter.validate(evt.key)) {\n inputRef.current?.focus()\n updateInputText(getDropdownInputText(dropdownSelectedOption, multiple))\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.Esc.validate(evt.key)) {\n inputRef.current?.focus()\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.Backspace.validate(evt.key) && !readOnly && (multiple || (!multiple && clearable))) {\n if (selectedOption === undefined) {\n setDropdownSelectedOption([])\n }\n\n if (onSelectOption) onSelectOption(multiple ? [] : null)\n\n updateInputText('')\n updateOptions('')\n }\n }}\n >\n {multiple ? (\n <DropdownMenuMultiple\n {...sizeProps}\n ref={menuListRef}\n inputRef={inputRef}\n label={label}\n name={name}\n disabled={rootProps.disabled}\n readOnly={readOnly}\n menuListId={menuListId}\n inputLabelId={inputLabelId}\n menuOptions={menuOptions}\n dropdownSelectedOption={dropdownSelectedOption}\n inputText={inputText}\n optionsMultiToggle={optionsMultiToggle}\n groupSelectedOptions={groupSelectedOptions}\n optionsMultiToggleCaption={optionsMultiToggleCaption}\n renderOption={renderOption}\n onChange={(update) => {\n if (selectedOption === undefined) {\n setDropdownSelectedOption(update)\n }\n\n if (onSelectOption) onSelectOption(update)\n }}\n />\n ) : (\n <DropdownMenuSingle\n {...sizeProps}\n ref={menuListRef}\n label={label}\n readOnly={readOnly}\n multiple={multiple}\n disabled={rootProps.disabled}\n status={status}\n menuListId={menuListId}\n inputLabelId={inputLabelId}\n menuOptions={menuOptions}\n dropdownSelectedOption={dropdownSelectedOption}\n selectedOptionRef={selectedOptionRef}\n renderOption={renderOption}\n onChange={(option) => {\n const update = { ...option }\n\n if (selectedOption === undefined) {\n updateInputText(getDropdownInputText(update))\n setDropdownSelectedOption(getDropdownSelectedOption(update))\n }\n\n if (onSelectOption) onSelectOption(update)\n\n inputRef.current?.focus()\n setMenuOpenRequest(false)\n }}\n />\n )}\n </DropdownMenu>\n )}\n />\n )\n }),\n {\n sizes: SIZES,\n displayName: COMPONENT_NAME,\n }\n)\n\nexport { Dropdown, COMPONENT_NAME }\n"],"names":["Dropdown","withMergedProps","forwardRef","props","ref","size","name","labelPosition","searchable","primary","optionsMultiToggle","iconProps","menuProps","loadingIconProps","optionsEmptyIconProps","loading","autoFocus","disableAutoScrollToSelectedOption","closeMenuOnScroll","scrollMonitorTarget","contrast","selectedOption","defaultSelectedOption","icon","addonLeft","inputMode","loadingMessage","loadingIcon","maxLength","multiple","clearable","onChangeInput","onCloseMenu","onOpenMenu","onSelectOption","options","loadOptions","renderOption","groupSelectedOptions","optionsMultiToggleCaption","optionsEmptyMessage","optionsEmptyIcon","palette","placeholder","readOnly","required","status","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","form","label","rootProps","sizeProps","formInputLabelId","useMemo","id","nanoid","inputLabelId","menuListId","filteredOptions","getFilteredOptions","useFilteredOptions","loadedOptions","optionsLoading","getLoadedOptions","useLoadedOptions","dropdownSelectedOption","setDropdownSelectedOption","useState","getDropdownSelectedOption","undefined","inputText","setInputText","getDropdownInputText","focusWithin","setFocusWithin","menuOpenRequest","setMenuOpenRequest","menuOptions","menuOptionsLoading","menuOpen","disabled","inputRequired","length","inputActive","Boolean","inputRef","useRef","menuRef","setMenuRef","menuListRef","selectedOptionRef","menuOpenPrevRef","updateInputText","useCallback","inputTextValue","updateOptions","updateOptionsDebounced","createDebouncedCallback","preventBlur","evt","target","current","Node","currentTarget","contains","renderInPortal","preventDefault","useScrollMonitor","onScrollStart","focus","useLayoutEffect","useEffect","menuRect","getBoundingClientRect","selectedOptionRect","top","bottom","setTimeout","scrollTo","offsetTop","_jsx","FormInputLabel","onColored","error","success","color","labelColorDisabled","labelColor","backgroundColor","backgroundColorDisabled","backgroundColorHover","borderColor","borderColorDisabled","onClick","onPointerDown","onMouseDown","window","PointerEvent","onFocus","onBlur","relatedTarget","input","_jsxs","_Fragment","children","Styled","type","tabIndex","FormInput","role","autoComplete","autoCapitalize","autoCorrect","spellCheck","active","labelId","value","colorDisabled","placeholderColor","placeholderColorDisabled","selectionStart","selectionEnd","stopPropagation","onChange","inputValue","onKeyDown","keyboardKeys","Enter","validate","key","Space","prev","Esc","Tab","ArrowDown","menuItems","idx","findIndex","item","focusTarget","HTMLElement","focusFirstFocusable","ArrowUp","focusLastFocusable","map","option","addonLeftProps","Icon","addonRight","addonRightProps","Chip","black","cursor","title","colorHover","chipAddonRightProps","IconButton","iconButtonProps","Close","square","ChevronDown","up","dropdown","dropdownProps","DropdownMenu","setRef","open","popperReferenceId","secondary","elevated","disableAutoFocus","menuBackgroundColor","menuBorderColor","empty","emptyMessage","emptyIcon","emptyIconProps","Backspace","DropdownMenuMultiple","update","DropdownMenuSingle","sizes","SIZES","displayName"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- import{forwardRef,useMemo,useState,useRef,useCallback,useLayoutEffect,useEffect}from'react';import{nanoid}from'nanoid';import{withMergedProps}from'../../hocs/withMergedProps.mjs';import{useScrollMonitor}from'../../hooks/useScrollMonitor.mjs';import{focusFirstFocusable,focusLastFocusable}from'../../shared/utils/dom.mjs';import{createDebouncedCallback}from'../../shared/utils/misc.mjs';import{keyboardKeys}from'../../shared/constants.mjs';import{DropdownMenu}from'./DropdownMenu.mjs';import{useFilteredOptions,useLoadedOptions}from'./hooks.mjs';import{SIZES}from'./sizes.mjs';import{getDropdownSelectedOption,getDropdownInputText}from'./utils.mjs';import{IconAnimated,InputMimic}from'./style.mjs';import{DropdownMenuMultiple}from'./DropdownMenuMultiple.mjs';import{DropdownMenuSingle}from'./DropdownMenuSingle.mjs';import{jsx,jsxs,Fragment}from'react/jsx-runtime';import{FormInputLabel}from'../FormInputLabel/FormInputLabel.mjs';import{Chip}from'../Chip/Chip.mjs';import{IconButton}from'../IconButton/IconButton.mjs';import{Close}from'../../icon-pack/src/icons/Close/index.mjs';import{ChevronDown}from'../../icon-pack/src/icons/ChevronDown/index.mjs';import{Icon}from'../Icon/Icon.mjs';import{FormInput}from'../FormInput/FormInput.mjs';const COMPONENT_NAME='Dropdown';const Dropdown=withMergedProps(forwardRef((o,e)=>{const{size:n="m",name:t="fox-dropdown",labelPosition:r="dynamic",searchable:s=!0,primary:l=!0,optionsMultiToggle:a=!0,iconProps:i={},menuProps:d={},loadingIconProps:c={},optionsEmptyIconProps:u={},loading:p,autoFocus:m,disableAutoScrollToSelectedOption:f,closeMenuOnScroll:b,scrollMonitorTarget:g,contrast:y,selectedOption:C,defaultSelectedOption:D,icon:w,addonLeft:M,inputMode:I,loadingMessage:k,loadingIcon:v,maxLength:h,multiple:x,clearable:S,onChangeInput:j,onCloseMenu:O,onOpenMenu:T,onSelectOption:F,options:P,loadOptions:E,renderOption:L,groupSelectedOptions:z,optionsMultiToggleCaption:B,optionsEmptyMessage:R,optionsEmptyIcon:K,palette:N,placeholder:A,readOnly:X,required:H,status:q,sizeXXS:Z,sizeXS:$,sizeS:_,sizeM:U,sizeL:G,sizeXL:J,form:Q,label:V,...W}=o;const Y={size:n,sizeXXS:Z,sizeXS:$,sizeS:_,sizeM:U,sizeL:G,sizeXL:J};const oo=useMemo(()=>W.id??`${t}-${nanoid()}`,[t,W.id]);const eo=useMemo(()=>nanoid(),[]);const no=useMemo(()=>nanoid(),[]);const[to,ro]=useFilteredOptions({options:P});const[so,lo,ao]=useLoadedOptions({loadOptions:E,options:P});const[io,co]=useState(()=>getDropdownSelectedOption(C!==void 0?C:D,x));const[uo,po]=useState(()=>getDropdownInputText(io,x));const[mo,fo]=useState(!1);const[bo,go]=useState(!1);const yo=E?so:to;const Co=E?p??lo:p;const Do=bo&&!W.disabled;const wo=H&&io.length===0;const Mo=Boolean(Do||uo||mo);const Io=useRef(null);const[ko,vo]=useState(null);const ho=useRef(null);const xo=useRef(null);const So=useRef(Do);const jo=useCallback(o=>{po(o),j&&j(o)},[j]);const Oo=useCallback(o=>{E?ao(o):ro(o)},[E,ao,ro]);const To=useMemo(()=>createDebouncedCallback(Oo,150),[Oo]);const preventBlur=o=>{o.target!==Io.current&&o.target instanceof Node&&(o.currentTarget.contains(o.target)||d.renderInPortal&&Do&&ko&&ko.contains(o.target))&&o.preventDefault()};return useScrollMonitor({target:g,onScrollStart:()=>{b&&Do&&(Io.current?.focus(),go(!1))}}),useLayoutEffect(()=>{C!==void 0&&(x||Do||jo(getDropdownInputText(C)),co(getDropdownSelectedOption(C,x)))},[x,C,Do,jo]),useEffect(()=>{Do!==So.current&&(Do&&T&&T(),!Do&&O&&O(),So.current=Do)},[Do,O,T]),useEffect(()=>{if(!x&&!f&&Do&&!Co&&uo.length===0&&ko&&xo.current){const o=ko.getBoundingClientRect();const e=xo.current.getBoundingClientRect();(e.top<o.top||e.bottom>o.bottom)&&setTimeout(()=>{ko&&xo.current&&ko.scrollTo(0,xo.current.offsetTop)},0)}},[x,f,Do,Co,uo,ko]),useEffect(()=>{W.disabled&&fo(!1)},[W.disabled]),jsx(FormInputLabel,{...W,...Y,ref:e,id:oo,onColored:y,primary:l,error:q==='error',success:q==='success',focus:mo,palette:{color:W.disabled?N.labelColorDisabled:N.labelColor,backgroundColor:W.disabled?N.backgroundColorDisabled:N.backgroundColor,backgroundColorHover:W.disabled?N.backgroundColorDisabled:N.backgroundColorHover,borderColor:W.disabled?N.borderColorDisabled:N.borderColor},onClick:o=>{W.onClick&&W.onClick(o),W.disabled||(Io.current?.focus(),Do?ko&&o.target instanceof Node&&!ko.contains(o.target)&&(go(!1),jo(getDropdownInputText(io,x))):(go(!0),Oo(''),s&&jo('')))},onPointerDown:o=>{W.onPointerDown&&W.onPointerDown(o),preventBlur(o)},onMouseDown:o=>{W.onMouseDown&&W.onMouseDown(o),window.PointerEvent||preventBlur(o)},onFocus:o=>{W.onFocus&&W.onFocus(o),fo(!0),Io.current&&o.target===Io.current&&s&&!x&&!Do&&jo('')},onBlur:o=>{W.onBlur&&W.onBlur(o),o.currentTarget.contains(o.relatedTarget)||d.renderInPortal&&Do&&ko&&ko.contains(o.relatedTarget)||(fo(!1),jo(getDropdownInputText(io,x)),go(!1))},input:jsxs(Fragment,{children:[!wo||s||X?null:jsx(InputMimic,{required:!0,type:"text",inputMode:"none",form:Q,tabIndex:-1,onFocus:()=>{Io.current?.focus()}}),jsx(FormInput,{...Y,ref:Io,role:"combobox","aria-controls":no,"aria-expanded":Do,type:"text",autoComplete:"off",autoCapitalize:"off",autoCorrect:"off",spellCheck:"false",active:Mo,label:V,labelId:eo,labelPosition:r,form:Q,autoFocus:m,inputMode:s?I:'none',maxLength:h,placeholder:A,readOnly:X||!s,required:wo,disabled:W.disabled,value:uo,palette:{color:N.color,colorDisabled:N.colorDisabled,placeholderColor:N.placeholderColor,placeholderColorDisabled:N.placeholderColorDisabled},onClick:o=>{Do&&o.currentTarget.selectionStart!==o.currentTarget.selectionEnd&&o.stopPropagation()},onChange:o=>{const e=o.currentTarget.value;jo(e),To(e),go(!0)},onKeyDown:o=>{if(keyboardKeys.Enter.validate(o.key)&&(jo(getDropdownInputText(io,x)),go(!1)),!keyboardKeys.Space.validate(o.key)||Do&&o.currentTarget.selectionStart!==0||(o.preventDefault(),Do||(Oo(''),s&&jo('')),go(o=>!o)),keyboardKeys.Esc.validate(o.key)&&go(!1),keyboardKeys.Tab.validate(o.key)&&Do&&(o.preventDefault(),go(!1)),keyboardKeys.ArrowDown.validate(o.key)&&Do&&ho.current)if(o.preventDefault(),!x&&xo.current){const o=[...ho.current.children];const e=o.findIndex(o=>o.contains(xo.current));const n=o[e+1]??o[0];n instanceof HTMLElement&&focusFirstFocusable(n)}else focusFirstFocusable(ho.current);if(keyboardKeys.ArrowUp.validate(o.key)&&Do&&ho.current)if(o.preventDefault(),!x&&xo.current){const o=[...ho.current.children];const e=o.findIndex(o=>o.contains(xo.current));const n=o[e-1]??o[o.length-1];n instanceof HTMLElement&&focusFirstFocusable(n)}else focusLastFocusable(ho.current)}}),io.map(o=>jsx("input",{type:"hidden",name:t,value:o.value,form:Q,disabled:W.disabled||o.disabled},o.value))]}),addonLeft:M??(w?o=>jsx(Icon,{...o.iconProps,...i,name:typeof w=='string'?w:void 0,icon:typeof w!='string'?w:void 0}):void 0),addonRight:o=>jsxs(Fragment,{children:[x&&io.length>0?jsx(Chip,{size:"xs",active:!0,black:!0,disabled:W.disabled,cursor:W.disabled?'not-allowed':void 0,text:io.length,textProps:{appearance:'caption',size:'xs'},palette:W.disabled?{color:'content-disabled',colorHover:'content-disabled',backgroundColor:'bg-disabled-small',backgroundColorHover:'bg-disabled-small'}:void 0,onPointerDown:o=>{o.preventDefault()},onMouseDown:o=>{window.PointerEvent||o.preventDefault()},discardButtonProps:{square:!0,contrast:!W.disabled,onClick:o=>{o.stopPropagation(),X||(C===void 0&&co([]),F&&F([]),Io.current?.focus(),jo(''),Oo(''),go(!0))}}}):null,!x&&S&&io.length>0?jsx(IconButton,{icon:jsx(Close,{}),size:"l",square:!0,disabled:W.disabled,onClick:o=>{o.stopPropagation(),X||(C===void 0&&co([]),F&&F(null),Io.current?.focus(),jo(''),Oo(''),go(!0))}}):null,jsx(IconAnimated,{...o.iconProps,...i,icon:jsx(ChevronDown,{}),up:Do})]}),dropdown:o=>jsx(DropdownMenu,{...d,setRef:vo,open:Do,popperReferenceId:oo,secondary:!y,elevated:y,disableAutoFocus:!0,palette:{backgroundColor:N.menuBackgroundColor,borderColor:N.menuBorderColor},empty:yo.length===0,loading:Co,loadingMessage:k,loadingIcon:v,loadingIconProps:{...o.iconProps,...c},emptyMessage:R,emptyIcon:K,emptyIconProps:{...o.iconProps,...u},onKeyDown:o=>{keyboardKeys.Tab.validate(o.key)&&(o.preventDefault(),Io.current?.focus(),go(!1)),keyboardKeys.Enter.validate(o.key)&&(Io.current?.focus(),jo(getDropdownInputText(io,x)),go(!1)),keyboardKeys.Esc.validate(o.key)&&(Io.current?.focus(),go(!1)),keyboardKeys.Backspace.validate(o.key)&&!X&&(x||!x&&S)&&(C===void 0&&co([]),F&&F(x?[]:null),jo(''),Oo(''))},children:x?jsx(DropdownMenuMultiple,{...Y,ref:ho,inputRef:Io,label:V,name:t,disabled:W.disabled,readOnly:X,menuListId:no,inputLabelId:eo,menuOptions:yo,dropdownSelectedOption:io,inputText:uo,optionsMultiToggle:a,groupSelectedOptions:z,optionsMultiToggleCaption:B,renderOption:L,onChange:o=>{C===void 0&&co(o),F&&F(o)}}):jsx(DropdownMenuSingle,{...Y,ref:ho,label:V,readOnly:X,multiple:x,disabled:W.disabled,status:q,menuListId:no,inputLabelId:eo,menuOptions:yo,dropdownSelectedOption:io,selectedOptionRef:xo,renderOption:L,onChange:o=>{const e={...o};C===void 0&&(jo(getDropdownInputText(e)),co(getDropdownSelectedOption(e))),F&&F(e),Io.current?.focus(),go(!1)}})})})}),{sizes:SIZES,displayName:"Dropdown"});export{COMPONENT_NAME,Dropdown};
1
+ import{forwardRef,useMemo,useState,useRef,useCallback,useLayoutEffect,useEffect}from'react';import{nanoid}from'nanoid';import{withMergedProps}from'../../hocs/withMergedProps.mjs';import{useScrollMonitor}from'../../hooks/useScrollMonitor.mjs';import{focusFirstFocusable,focusLastFocusable}from'../../shared/utils/dom.mjs';import{createDebouncedCallback}from'../../shared/utils/misc.mjs';import{keyboardKeys}from'../../shared/constants.mjs';import{DropdownMenu}from'./DropdownMenu.mjs';import{useFilteredOptions,useLoadedOptions}from'./hooks.mjs';import{SIZES}from'./sizes.mjs';import{getDropdownSelectedOption,getDropdownInputText}from'./utils.mjs';import{IconAnimated,InputMimic}from'./style.mjs';import{DropdownMenuMultiple}from'./DropdownMenuMultiple.mjs';import{DropdownMenuSingle}from'./DropdownMenuSingle.mjs';import{jsx,jsxs,Fragment}from'react/jsx-runtime';import{FormInputLabel}from'../FormInputLabel/FormInputLabel.mjs';import{Chip}from'../Chip/Chip.mjs';import{IconButton}from'../IconButton/IconButton.mjs';import{Close}from'../../icon-pack/src/icons/Close/index.mjs';import{ChevronDown}from'../../icon-pack/src/icons/ChevronDown/index.mjs';import{Icon}from'../Icon/Icon.mjs';import{FormInput}from'../FormInput/FormInput.mjs';const COMPONENT_NAME='Dropdown';const Dropdown=withMergedProps(forwardRef((o,e)=>{const{size:n="m",name:t="fox-dropdown",labelPosition:r="dynamic",searchable:s=!0,primary:l=!0,optionsMultiToggle:i=!0,iconProps:a={},menuProps:d={},loadingIconProps:c={},optionsEmptyIconProps:u={},loading:p,autoFocus:m,disableAutoScrollToSelectedOption:f,closeMenuOnScroll:b,scrollMonitorTarget:g,contrast:y,selectedOption:C,defaultSelectedOption:D,icon:w,addonLeft:M,inputMode:I,loadingMessage:k,loadingIcon:v,maxLength:h,multiple:x,clearable:S,onChangeInput:j,onCloseMenu:O,onOpenMenu:T,onSelectOption:F,options:P,loadOptions:E,renderOption:L,groupSelectedOptions:z,optionsMultiToggleCaption:B,optionsEmptyMessage:R,optionsEmptyIcon:K,palette:N,placeholder:A,readOnly:X,required:H,status:q,sizeXXS:Z,sizeXS:$,sizeS:_,sizeM:U,sizeL:G,sizeXL:J,form:Q,label:V,...W}=o;const Y={size:n,sizeXXS:Z,sizeXS:$,sizeS:_,sizeM:U,sizeL:G,sizeXL:J};const oo=useMemo(()=>W.id??`${t}-${nanoid()}`,[t,W.id]);const eo=useMemo(()=>nanoid(),[]);const no=useMemo(()=>nanoid(),[]);const[to,ro]=useFilteredOptions({options:P});const[so,lo,io]=useLoadedOptions({loadOptions:E,options:P});const[ao,co]=useState(()=>getDropdownSelectedOption(C!==void 0?C:D,x));const[uo,po]=useState(()=>getDropdownInputText(ao,x));const[mo,fo]=useState(!1);const[bo,go]=useState(!1);const yo=E?so:to;const Co=E?p??lo:p;const Do=bo&&!W.disabled;const wo=H&&ao.length===0;const Mo=Boolean(Do||uo||mo);const Io=useRef(null);const[ko,vo]=useState(null);const ho=useRef(null);const xo=useRef(null);const So=useRef(Do);const jo=useCallback(o=>{po(o),j&&j(o)},[j]);const Oo=useCallback(o=>{E?io(o):ro(o)},[E,io,ro]);const To=useMemo(()=>createDebouncedCallback(Oo,150),[Oo]);const preventBlur=o=>{o.target!==Io.current&&o.target instanceof Node&&(o.currentTarget.contains(o.target)||d.renderInPortal&&Do&&ko&&ko.contains(o.target))&&o.preventDefault()};return useScrollMonitor({target:g,onScrollStart:()=>{b&&Do&&(Io.current?.focus(),go(!1))}}),useLayoutEffect(()=>{C!==void 0&&(x||Do||jo(getDropdownInputText(C)),co(getDropdownSelectedOption(C,x)))},[x,C,Do,jo]),useEffect(()=>{Do!==So.current&&(Do&&T&&T(),!Do&&O&&O(),So.current=Do)},[Do,O,T]),useEffect(()=>{if(!x&&!f&&Do&&!Co&&uo.length===0&&ko&&xo.current){const o=ko.getBoundingClientRect();const e=xo.current.getBoundingClientRect();(e.top<o.top||e.bottom>o.bottom)&&setTimeout(()=>{ko&&xo.current&&ko.scrollTo(0,xo.current.offsetTop)},0)}},[x,f,Do,Co,uo,ko]),useEffect(()=>{W.disabled&&fo(!1)},[W.disabled]),jsx(FormInputLabel,{...W,...Y,ref:e,id:oo,onColored:y,primary:l,error:q==='error',success:q==='success',focus:mo,palette:{color:W.disabled?N.labelColorDisabled:N.labelColor,backgroundColor:W.disabled?N.backgroundColorDisabled:N.backgroundColor,backgroundColorHover:W.disabled?N.backgroundColorDisabled:N.backgroundColorHover,borderColor:W.disabled?N.borderColorDisabled:N.borderColor},onClick:o=>{W.onClick&&W.onClick(o),W.disabled||(Io.current?.focus(),Do?ko&&o.target instanceof Node&&!ko.contains(o.target)&&(go(!1),jo(getDropdownInputText(ao,x))):(go(!0),Oo(''),s&&jo('')))},onPointerDown:o=>{W.onPointerDown&&W.onPointerDown(o),preventBlur(o)},onMouseDown:o=>{W.onMouseDown&&W.onMouseDown(o),window.PointerEvent||preventBlur(o)},onFocus:o=>{W.onFocus&&W.onFocus(o),fo(!0),Io.current&&o.target===Io.current&&s&&!x&&!Do&&jo('')},onBlur:o=>{W.onBlur&&W.onBlur(o),o.currentTarget.contains(o.relatedTarget)||d.renderInPortal&&Do&&ko&&ko.contains(o.relatedTarget)||(fo(!1),jo(getDropdownInputText(ao,x)),go(!1))},input:jsxs(Fragment,{children:[!wo||s||X?null:jsx(InputMimic,{required:!0,type:"text",inputMode:"none",form:Q,tabIndex:-1,onFocus:()=>{Io.current?.focus()}}),jsx(FormInput,{...Y,ref:Io,role:"combobox","aria-controls":no,"aria-expanded":Do,type:"text",autoComplete:"off",autoCapitalize:"off",autoCorrect:"off",spellCheck:"false",active:Mo,label:V,labelId:eo,labelPosition:r,form:Q,autoFocus:m,inputMode:s?I:'none',maxLength:h,placeholder:A,readOnly:X||!s,required:wo,disabled:W.disabled,value:uo,palette:{color:N.color,colorDisabled:N.colorDisabled,placeholderColor:N.placeholderColor,placeholderColorDisabled:N.placeholderColorDisabled},onClick:o=>{Do&&o.currentTarget.selectionStart!==o.currentTarget.selectionEnd&&o.stopPropagation()},onChange:o=>{const e=o.currentTarget.value;jo(e),To(e),go(!0)},onKeyDown:o=>{if(keyboardKeys.Enter.validate(o.key)&&(jo(getDropdownInputText(ao,x)),go(!1)),!keyboardKeys.Space.validate(o.key)||Do&&o.currentTarget.selectionStart!==0||(o.preventDefault(),Do||(Oo(''),s&&jo('')),go(o=>!o)),keyboardKeys.Esc.validate(o.key)&&go(!1),keyboardKeys.Tab.validate(o.key)&&Do&&(o.preventDefault(),go(!1)),keyboardKeys.ArrowDown.validate(o.key)&&Do&&ho.current)if(o.preventDefault(),!x&&xo.current){const o=[...ho.current.children];const e=o.findIndex(o=>o.contains(xo.current));const n=o[e+1]??o[0];n instanceof HTMLElement&&focusFirstFocusable(n)}else focusFirstFocusable(ho.current);if(keyboardKeys.ArrowUp.validate(o.key)&&Do&&ho.current)if(o.preventDefault(),!x&&xo.current){const o=[...ho.current.children];const e=o.findIndex(o=>o.contains(xo.current));const n=o[e-1]??o[o.length-1];n instanceof HTMLElement&&focusFirstFocusable(n)}else focusLastFocusable(ho.current)}}),ao.map(o=>jsx("input",{type:"hidden",name:t,value:o.value,form:Q,disabled:W.disabled||o.disabled},o.value))]}),addonLeft:M??(w?o=>jsx(Icon,{...o.iconProps,...a,name:typeof w=='string'?w:void 0,icon:typeof w!='string'?w:void 0}):void 0),addonRight:o=>jsxs(Fragment,{children:[x&&ao.length>0?jsx(Chip,{size:"xs",active:!0,black:!0,disabled:W.disabled,cursor:W.disabled?'not-allowed':void 0,title:ao.length,palette:W.disabled?{color:'content-disabled',colorHover:'content-disabled',backgroundColor:'bg-disabled-small',backgroundColorHover:'bg-disabled-small'}:void 0,onPointerDown:o=>{o.preventDefault()},onMouseDown:o=>{window.PointerEvent||o.preventDefault()},addonRight:o=>jsx(IconButton,{...o.iconButtonProps,contrast:!W.disabled,onClick:o=>{o.stopPropagation(),X||(C===void 0&&co([]),F&&F([]),Io.current?.focus(),jo(''),Oo(''),go(!0))}})}):null,!x&&S&&ao.length>0?jsx(IconButton,{icon:jsx(Close,{}),size:"l",square:!0,disabled:W.disabled,onClick:o=>{o.stopPropagation(),X||(C===void 0&&co([]),F&&F(null),Io.current?.focus(),jo(''),Oo(''),go(!0))}}):null,jsx(IconAnimated,{...o.iconProps,...a,icon:jsx(ChevronDown,{}),up:Do})]}),dropdown:o=>jsx(DropdownMenu,{...d,setRef:vo,open:Do,popperReferenceId:oo,secondary:!y,elevated:y,disableAutoFocus:!0,palette:{backgroundColor:N.menuBackgroundColor,borderColor:N.menuBorderColor},empty:yo.length===0,loading:Co,loadingMessage:k,loadingIcon:v,loadingIconProps:{...o.iconProps,...c},emptyMessage:R,emptyIcon:K,emptyIconProps:{...o.iconProps,...u},onKeyDown:o=>{keyboardKeys.Tab.validate(o.key)&&(o.preventDefault(),Io.current?.focus(),go(!1)),keyboardKeys.Enter.validate(o.key)&&(Io.current?.focus(),jo(getDropdownInputText(ao,x)),go(!1)),keyboardKeys.Esc.validate(o.key)&&(Io.current?.focus(),go(!1)),keyboardKeys.Backspace.validate(o.key)&&!X&&(x||!x&&S)&&(C===void 0&&co([]),F&&F(x?[]:null),jo(''),Oo(''))},children:x?jsx(DropdownMenuMultiple,{...Y,ref:ho,inputRef:Io,label:V,name:t,disabled:W.disabled,readOnly:X,menuListId:no,inputLabelId:eo,menuOptions:yo,dropdownSelectedOption:ao,inputText:uo,optionsMultiToggle:i,groupSelectedOptions:z,optionsMultiToggleCaption:B,renderOption:L,onChange:o=>{C===void 0&&co(o),F&&F(o)}}):jsx(DropdownMenuSingle,{...Y,ref:ho,label:V,readOnly:X,multiple:x,disabled:W.disabled,status:q,menuListId:no,inputLabelId:eo,menuOptions:yo,dropdownSelectedOption:ao,selectedOptionRef:xo,renderOption:L,onChange:o=>{const e={...o};C===void 0&&(jo(getDropdownInputText(e)),co(getDropdownSelectedOption(e))),F&&F(e),Io.current?.focus(),go(!1)}})})})}),{sizes:SIZES,displayName:"Dropdown"});export{COMPONENT_NAME,Dropdown};
2
2
  //# sourceMappingURL=Dropdown.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"Dropdown.mjs","sources":["../../../../src/components/Dropdown/Dropdown.tsx"],"sourcesContent":["import { forwardRef, useState, useRef, useEffect, useLayoutEffect, useMemo, useCallback } from 'react'\nimport { nanoid } from 'nanoid'\nimport { ChevronDown, Close } from '@foxford/icon-pack'\nimport { withMergedProps } from 'hocs/withMergedProps'\nimport type { MergedProps } from 'hocs/withMergedProps'\nimport { useScrollMonitor } from 'hooks/useScrollMonitor'\nimport { focusFirstFocusable, focusLastFocusable } from 'shared/utils/dom'\nimport { createDebouncedCallback } from 'shared/utils/misc'\nimport { keyboardKeys } from 'shared/constants'\nimport type { Nullable } from 'shared/types'\nimport { FormInput } from 'components/FormInput'\nimport { FormInputLabel } from 'components/FormInputLabel'\nimport { Chip } from 'components/Chip'\nimport { IconButton } from 'components/IconButton'\nimport { Icon } from 'components/Icon'\nimport { DropdownMenu } from './DropdownMenu'\nimport { useFilteredOptions, useLoadedOptions } from './hooks'\nimport { SIZES } from './sizes'\nimport { getDropdownInputText, getDropdownSelectedOption } from './utils'\nimport * as Styled from './style'\nimport type { DropdownProps, DropdownOption, DropdownOptionGroup } from './types'\nimport { DropdownMenuMultiple } from './DropdownMenuMultiple'\nimport { DropdownMenuSingle } from './DropdownMenuSingle'\n\nconst COMPONENT_NAME = 'Dropdown'\n\n/**\n *\n * Компонент для выбора одной или нескольких опций из числа доступных.\n *\n * Поддерживается \"ref\" и все нативные атрибуты \\<div\\> элемента.\n */\nconst Dropdown: React.ForwardRefExoticComponent<DropdownProps> = withMergedProps<DropdownProps, HTMLDivElement>(\n forwardRef<HTMLDivElement, MergedProps<DropdownProps>>((props, ref) => {\n const {\n size = 'm',\n name = 'fox-dropdown',\n labelPosition = 'dynamic',\n searchable = true,\n primary = true,\n optionsMultiToggle = true,\n iconProps = {},\n menuProps = {},\n loadingIconProps = {},\n optionsEmptyIconProps = {},\n loading,\n autoFocus,\n disableAutoScrollToSelectedOption,\n closeMenuOnScroll,\n scrollMonitorTarget,\n contrast,\n selectedOption,\n defaultSelectedOption,\n icon,\n addonLeft,\n inputMode,\n loadingMessage,\n loadingIcon,\n maxLength,\n multiple,\n clearable,\n onChangeInput,\n onCloseMenu,\n onOpenMenu,\n onSelectOption,\n options,\n loadOptions,\n renderOption,\n groupSelectedOptions,\n optionsMultiToggleCaption,\n optionsEmptyMessage,\n optionsEmptyIcon,\n palette,\n placeholder,\n readOnly,\n required,\n status,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n form,\n label,\n ...rootProps\n } = props\n\n const sizeProps = {\n size,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n }\n\n const formInputLabelId = useMemo(() => rootProps.id ?? `${name}-${nanoid()}`, [name, rootProps.id])\n const inputLabelId = useMemo(() => nanoid(), [])\n const menuListId = useMemo(() => nanoid(), [])\n\n const [filteredOptions, getFilteredOptions] = useFilteredOptions({\n options,\n })\n\n const [loadedOptions, optionsLoading, getLoadedOptions] = useLoadedOptions({\n loadOptions,\n options,\n })\n\n const [dropdownSelectedOption, setDropdownSelectedOption] = useState<DropdownOption[]>(() =>\n getDropdownSelectedOption(selectedOption !== undefined ? selectedOption : defaultSelectedOption, multiple)\n )\n\n const [inputText, setInputText] = useState<string>(() => getDropdownInputText(dropdownSelectedOption, multiple))\n\n const [focusWithin, setFocusWithin] = useState<boolean>(false)\n\n const [menuOpenRequest, setMenuOpenRequest] = useState<boolean>(false)\n\n const menuOptions: (DropdownOption | DropdownOptionGroup)[] = loadOptions ? loadedOptions : filteredOptions\n const menuOptionsLoading = loadOptions ? (loading ?? optionsLoading) : loading\n\n const menuOpen = menuOpenRequest && !rootProps.disabled\n\n const inputRequired = required && dropdownSelectedOption.length === 0\n const inputActive = Boolean(menuOpen || inputText || focusWithin)\n\n const inputRef = useRef<HTMLInputElement>(null)\n const [menuRef, setMenuRef] = useState<Nullable<HTMLElement>>(null)\n const menuListRef = useRef<HTMLUListElement>(null)\n const selectedOptionRef = useRef<HTMLElement>(null)\n const menuOpenPrevRef = useRef<boolean>(menuOpen)\n\n const updateInputText = useCallback(\n (inputTextValue: string) => {\n setInputText(inputTextValue)\n\n if (onChangeInput) {\n onChangeInput(inputTextValue)\n }\n },\n [onChangeInput]\n )\n\n const updateOptions = useCallback(\n (inputTextValue: string) => {\n if (loadOptions) {\n getLoadedOptions(inputTextValue)\n } else {\n getFilteredOptions(inputTextValue)\n }\n },\n [loadOptions, getLoadedOptions, getFilteredOptions]\n )\n\n const updateOptionsDebounced = useMemo(() => {\n return createDebouncedCallback(updateOptions, 150)\n }, [updateOptions])\n\n const preventBlur = (evt: React.PointerEvent<HTMLDivElement> | React.MouseEvent<HTMLDivElement, MouseEvent>) => {\n if (\n evt.target !== inputRef.current &&\n evt.target instanceof Node &&\n (evt.currentTarget.contains(evt.target) ||\n (menuProps.renderInPortal && menuOpen && menuRef && menuRef.contains(evt.target)))\n ) {\n evt.preventDefault()\n }\n }\n\n useScrollMonitor({\n target: scrollMonitorTarget,\n onScrollStart: () => {\n if (closeMenuOnScroll && menuOpen) {\n inputRef.current?.focus()\n setMenuOpenRequest(false)\n }\n },\n })\n\n useLayoutEffect(() => {\n if (selectedOption === undefined) return\n\n if (!multiple && !menuOpen) {\n updateInputText(getDropdownInputText(selectedOption))\n }\n setDropdownSelectedOption(getDropdownSelectedOption(selectedOption, multiple))\n }, [multiple, selectedOption, menuOpen, updateInputText])\n\n useEffect(() => {\n if (menuOpen === menuOpenPrevRef.current) return\n\n if (menuOpen && onOpenMenu) onOpenMenu()\n if (!menuOpen && onCloseMenu) onCloseMenu()\n\n menuOpenPrevRef.current = menuOpen\n }, [menuOpen, onCloseMenu, onOpenMenu])\n\n useEffect(() => {\n if (\n !multiple &&\n !disableAutoScrollToSelectedOption &&\n menuOpen &&\n !menuOptionsLoading &&\n inputText.length === 0 &&\n menuRef &&\n selectedOptionRef.current\n ) {\n const menuRect = menuRef.getBoundingClientRect()\n const selectedOptionRect = selectedOptionRef.current.getBoundingClientRect()\n\n if (selectedOptionRect.top < menuRect.top || selectedOptionRect.bottom > menuRect.bottom) {\n setTimeout(() => {\n if (menuRef && selectedOptionRef.current) {\n menuRef.scrollTo(0, selectedOptionRef.current.offsetTop)\n }\n }, 0)\n }\n }\n }, [multiple, disableAutoScrollToSelectedOption, menuOpen, menuOptionsLoading, inputText, menuRef])\n\n useEffect(() => {\n if (rootProps.disabled) {\n setFocusWithin(false)\n }\n }, [rootProps.disabled])\n\n return (\n <FormInputLabel\n {...rootProps}\n {...sizeProps}\n ref={ref}\n id={formInputLabelId}\n onColored={contrast}\n primary={primary}\n error={status === 'error'}\n success={status === 'success'}\n focus={focusWithin}\n palette={{\n color: rootProps.disabled ? palette.labelColorDisabled : palette.labelColor,\n backgroundColor: rootProps.disabled ? palette.backgroundColorDisabled : palette.backgroundColor,\n backgroundColorHover: rootProps.disabled ? palette.backgroundColorDisabled : palette.backgroundColorHover,\n borderColor: rootProps.disabled ? palette.borderColorDisabled : palette.borderColor,\n }}\n onClick={(evt) => {\n if (rootProps.onClick) rootProps.onClick(evt)\n\n if (rootProps.disabled) return\n\n inputRef.current?.focus()\n\n if (!menuOpen) {\n setMenuOpenRequest(true)\n\n updateOptions('')\n if (searchable) {\n updateInputText('')\n }\n } else if (menuRef && evt.target instanceof Node && !menuRef.contains(evt.target)) {\n setMenuOpenRequest(false)\n updateInputText(getDropdownInputText(dropdownSelectedOption, multiple))\n }\n }}\n onPointerDown={(evt) => {\n if (rootProps.onPointerDown) rootProps.onPointerDown(evt)\n\n preventBlur(evt)\n }}\n onMouseDown={(evt) => {\n if (rootProps.onMouseDown) rootProps.onMouseDown(evt)\n\n if (!window.PointerEvent) preventBlur(evt)\n }}\n onFocus={(evt) => {\n if (rootProps.onFocus) rootProps.onFocus(evt)\n\n setFocusWithin(true)\n\n if (inputRef.current && evt.target === inputRef.current && searchable && !multiple && !menuOpen) {\n updateInputText('')\n }\n }}\n onBlur={(evt) => {\n if (rootProps.onBlur) rootProps.onBlur(evt)\n\n if (\n evt.currentTarget.contains(evt.relatedTarget) ||\n (menuProps.renderInPortal && menuOpen && menuRef && menuRef.contains(evt.relatedTarget))\n ) {\n return\n }\n\n setFocusWithin(false)\n updateInputText(getDropdownInputText(dropdownSelectedOption, multiple))\n setMenuOpenRequest(false)\n }}\n input={\n <>\n {inputRequired && !searchable && !readOnly ? (\n <Styled.InputMimic\n required\n type='text'\n inputMode='none'\n form={form}\n tabIndex={-1}\n onFocus={() => {\n inputRef.current?.focus()\n }}\n />\n ) : null}\n <FormInput\n {...sizeProps}\n ref={inputRef}\n role='combobox'\n aria-controls={menuListId}\n aria-expanded={menuOpen}\n type='text'\n autoComplete='off'\n autoCapitalize='off'\n autoCorrect='off'\n spellCheck='false'\n active={inputActive}\n label={label}\n labelId={inputLabelId}\n labelPosition={labelPosition}\n form={form}\n autoFocus={autoFocus}\n inputMode={searchable ? inputMode : 'none'}\n maxLength={maxLength}\n placeholder={placeholder}\n readOnly={readOnly || !searchable}\n required={inputRequired}\n disabled={rootProps.disabled}\n value={inputText}\n palette={{\n color: palette.color,\n colorDisabled: palette.colorDisabled,\n placeholderColor: palette.placeholderColor,\n placeholderColorDisabled: palette.placeholderColorDisabled,\n }}\n onClick={(evt) => {\n if (menuOpen && evt.currentTarget.selectionStart !== evt.currentTarget.selectionEnd) {\n evt.stopPropagation()\n }\n }}\n onChange={(evt) => {\n const inputValue = evt.currentTarget.value\n\n updateInputText(inputValue)\n updateOptionsDebounced(inputValue)\n setMenuOpenRequest(true)\n }}\n onKeyDown={(evt) => {\n if (keyboardKeys.Enter.validate(evt.key)) {\n updateInputText(getDropdownInputText(dropdownSelectedOption, multiple))\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.Space.validate(evt.key) && (!menuOpen || evt.currentTarget.selectionStart === 0)) {\n evt.preventDefault()\n\n if (!menuOpen) {\n updateOptions('')\n if (searchable) {\n updateInputText('')\n }\n }\n\n setMenuOpenRequest((prev) => !prev)\n }\n\n if (keyboardKeys.Esc.validate(evt.key)) {\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.Tab.validate(evt.key) && menuOpen) {\n evt.preventDefault()\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.ArrowDown.validate(evt.key) && menuOpen && menuListRef.current) {\n evt.preventDefault()\n\n if (!multiple && selectedOptionRef.current) {\n const menuItems = [...menuListRef.current.children]\n\n const idx = menuItems.findIndex((item) => item.contains(selectedOptionRef.current as Node))\n\n const focusTarget = menuItems[idx + 1] ?? menuItems[0]\n\n if (focusTarget instanceof HTMLElement) {\n focusFirstFocusable(focusTarget)\n }\n } else {\n focusFirstFocusable(menuListRef.current)\n }\n }\n\n if (keyboardKeys.ArrowUp.validate(evt.key) && menuOpen && menuListRef.current) {\n evt.preventDefault()\n\n if (!multiple && selectedOptionRef.current) {\n const menuItems = [...menuListRef.current.children]\n\n const idx = menuItems.findIndex((item) => item.contains(selectedOptionRef.current as Node))\n\n const focusTarget = menuItems[idx - 1] ?? menuItems[menuItems.length - 1]\n\n if (focusTarget instanceof HTMLElement) {\n focusFirstFocusable(focusTarget)\n }\n } else {\n focusLastFocusable(menuListRef.current)\n }\n }\n }}\n />\n {dropdownSelectedOption.map((option) => (\n <input\n key={option.value}\n type='hidden'\n name={name}\n value={option.value}\n form={form}\n disabled={rootProps.disabled || option.disabled}\n />\n ))}\n </>\n }\n addonLeft={\n addonLeft ??\n (icon\n ? (addonLeftProps) => (\n <Icon\n {...addonLeftProps.iconProps}\n {...iconProps}\n name={typeof icon === 'string' ? icon : undefined}\n icon={typeof icon !== 'string' ? icon : undefined}\n />\n )\n : undefined)\n }\n addonRight={(addonRightProps) => (\n <>\n {multiple && dropdownSelectedOption.length > 0 ? (\n <Chip\n size='xs'\n active\n black\n disabled={rootProps.disabled}\n cursor={rootProps.disabled ? 'not-allowed' : undefined}\n text={dropdownSelectedOption.length}\n textProps={{\n appearance: 'caption',\n size: 'xs',\n }}\n palette={\n rootProps.disabled\n ? {\n color: 'content-disabled',\n colorHover: 'content-disabled',\n backgroundColor: 'bg-disabled-small',\n backgroundColorHover: 'bg-disabled-small',\n }\n : undefined\n }\n onPointerDown={(evt) => {\n evt.preventDefault()\n }}\n onMouseDown={(evt) => {\n if (!window.PointerEvent) evt.preventDefault()\n }}\n discardButtonProps={{\n square: true,\n contrast: !rootProps.disabled,\n onClick: (evt) => {\n evt.stopPropagation()\n\n if (!readOnly) {\n if (selectedOption === undefined) {\n setDropdownSelectedOption([])\n }\n\n if (onSelectOption) onSelectOption([])\n\n inputRef.current?.focus()\n updateInputText('')\n updateOptions('')\n setMenuOpenRequest(true)\n }\n },\n }}\n />\n ) : null}\n {!multiple && clearable && dropdownSelectedOption.length > 0 ? (\n <IconButton\n icon={<Close />}\n size='l'\n square\n disabled={rootProps.disabled}\n onClick={(evt) => {\n evt.stopPropagation()\n\n if (!readOnly) {\n if (selectedOption === undefined) {\n setDropdownSelectedOption([])\n }\n\n if (onSelectOption) onSelectOption(null)\n\n inputRef.current?.focus()\n updateInputText('')\n updateOptions('')\n setMenuOpenRequest(true)\n }\n }}\n />\n ) : null}\n <Styled.IconAnimated {...addonRightProps.iconProps} {...iconProps} icon={<ChevronDown />} up={menuOpen} />\n </>\n )}\n dropdown={(dropdownProps) => (\n <DropdownMenu\n {...menuProps}\n setRef={setMenuRef}\n open={menuOpen}\n popperReferenceId={formInputLabelId}\n secondary={!contrast}\n elevated={contrast}\n disableAutoFocus\n palette={{\n backgroundColor: palette.menuBackgroundColor,\n borderColor: palette.menuBorderColor,\n }}\n empty={menuOptions.length === 0}\n loading={menuOptionsLoading}\n loadingMessage={loadingMessage}\n loadingIcon={loadingIcon}\n loadingIconProps={{\n ...dropdownProps.iconProps,\n ...loadingIconProps,\n }}\n emptyMessage={optionsEmptyMessage}\n emptyIcon={optionsEmptyIcon}\n emptyIconProps={{\n ...dropdownProps.iconProps,\n ...optionsEmptyIconProps,\n }}\n onKeyDown={(evt) => {\n if (keyboardKeys.Tab.validate(evt.key)) {\n evt.preventDefault()\n inputRef.current?.focus()\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.Enter.validate(evt.key)) {\n inputRef.current?.focus()\n updateInputText(getDropdownInputText(dropdownSelectedOption, multiple))\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.Esc.validate(evt.key)) {\n inputRef.current?.focus()\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.Backspace.validate(evt.key) && !readOnly && (multiple || (!multiple && clearable))) {\n if (selectedOption === undefined) {\n setDropdownSelectedOption([])\n }\n\n if (onSelectOption) onSelectOption(multiple ? [] : null)\n\n updateInputText('')\n updateOptions('')\n }\n }}\n >\n {multiple ? (\n <DropdownMenuMultiple\n {...sizeProps}\n ref={menuListRef}\n inputRef={inputRef}\n label={label}\n name={name}\n disabled={rootProps.disabled}\n readOnly={readOnly}\n menuListId={menuListId}\n inputLabelId={inputLabelId}\n menuOptions={menuOptions}\n dropdownSelectedOption={dropdownSelectedOption}\n inputText={inputText}\n optionsMultiToggle={optionsMultiToggle}\n groupSelectedOptions={groupSelectedOptions}\n optionsMultiToggleCaption={optionsMultiToggleCaption}\n renderOption={renderOption}\n onChange={(update) => {\n if (selectedOption === undefined) {\n setDropdownSelectedOption(update)\n }\n\n if (onSelectOption) onSelectOption(update)\n }}\n />\n ) : (\n <DropdownMenuSingle\n {...sizeProps}\n ref={menuListRef}\n label={label}\n readOnly={readOnly}\n multiple={multiple}\n disabled={rootProps.disabled}\n status={status}\n menuListId={menuListId}\n inputLabelId={inputLabelId}\n menuOptions={menuOptions}\n dropdownSelectedOption={dropdownSelectedOption}\n selectedOptionRef={selectedOptionRef}\n renderOption={renderOption}\n onChange={(option) => {\n const update = { ...option }\n\n if (selectedOption === undefined) {\n updateInputText(getDropdownInputText(update))\n setDropdownSelectedOption(getDropdownSelectedOption(update))\n }\n\n if (onSelectOption) onSelectOption(update)\n\n inputRef.current?.focus()\n setMenuOpenRequest(false)\n }}\n />\n )}\n </DropdownMenu>\n )}\n />\n )\n }),\n {\n sizes: SIZES,\n displayName: COMPONENT_NAME,\n }\n)\n\nexport { Dropdown, COMPONENT_NAME }\n"],"names":["COMPONENT_NAME","Dropdown","withMergedProps","forwardRef","props","ref","size","name","labelPosition","searchable","primary","optionsMultiToggle","iconProps","menuProps","loadingIconProps","optionsEmptyIconProps","loading","autoFocus","disableAutoScrollToSelectedOption","closeMenuOnScroll","scrollMonitorTarget","contrast","selectedOption","defaultSelectedOption","icon","addonLeft","inputMode","loadingMessage","loadingIcon","maxLength","multiple","clearable","onChangeInput","onCloseMenu","onOpenMenu","onSelectOption","options","loadOptions","renderOption","groupSelectedOptions","optionsMultiToggleCaption","optionsEmptyMessage","optionsEmptyIcon","palette","placeholder","readOnly","required","status","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","form","label","rootProps","sizeProps","formInputLabelId","useMemo","id","nanoid","inputLabelId","menuListId","filteredOptions","getFilteredOptions","useFilteredOptions","loadedOptions","optionsLoading","getLoadedOptions","useLoadedOptions","dropdownSelectedOption","setDropdownSelectedOption","useState","getDropdownSelectedOption","undefined","inputText","setInputText","getDropdownInputText","focusWithin","setFocusWithin","menuOpenRequest","setMenuOpenRequest","menuOptions","menuOptionsLoading","menuOpen","disabled","inputRequired","length","inputActive","Boolean","inputRef","useRef","menuRef","setMenuRef","menuListRef","selectedOptionRef","menuOpenPrevRef","updateInputText","useCallback","inputTextValue","updateOptions","updateOptionsDebounced","createDebouncedCallback","preventBlur","evt","target","current","Node","currentTarget","contains","renderInPortal","preventDefault","useScrollMonitor","onScrollStart","focus","useLayoutEffect","useEffect","menuRect","getBoundingClientRect","selectedOptionRect","top","bottom","setTimeout","scrollTo","offsetTop","_jsx","FormInputLabel","onColored","error","success","color","labelColorDisabled","labelColor","backgroundColor","backgroundColorDisabled","backgroundColorHover","borderColor","borderColorDisabled","onClick","onPointerDown","onMouseDown","window","PointerEvent","onFocus","onBlur","relatedTarget","input","_jsxs","_Fragment","children","Styled","type","tabIndex","FormInput","role","autoComplete","autoCapitalize","autoCorrect","spellCheck","active","labelId","value","colorDisabled","placeholderColor","placeholderColorDisabled","selectionStart","selectionEnd","stopPropagation","onChange","inputValue","onKeyDown","keyboardKeys","Enter","validate","key","Space","prev","Esc","Tab","ArrowDown","menuItems","idx","findIndex","item","focusTarget","HTMLElement","focusFirstFocusable","ArrowUp","focusLastFocusable","map","option","addonLeftProps","Icon","addonRight","addonRightProps","Chip","black","cursor","text","textProps","appearance","colorHover","discardButtonProps","square","IconButton","Close","ChevronDown","up","dropdown","dropdownProps","DropdownMenu","setRef","open","popperReferenceId","secondary","elevated","disableAutoFocus","menuBackgroundColor","menuBorderColor","empty","emptyMessage","emptyIcon","emptyIconProps","Backspace","DropdownMenuMultiple","update","DropdownMenuSingle","sizes","SIZES","displayName"],"mappings":"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"}
1
+ {"version":3,"file":"Dropdown.mjs","sources":["../../../../src/components/Dropdown/Dropdown.tsx"],"sourcesContent":["import { forwardRef, useState, useRef, useEffect, useLayoutEffect, useMemo, useCallback } from 'react'\nimport { nanoid } from 'nanoid'\nimport { ChevronDown, Close } from '@foxford/icon-pack'\nimport { withMergedProps } from 'hocs/withMergedProps'\nimport type { MergedProps } from 'hocs/withMergedProps'\nimport { useScrollMonitor } from 'hooks/useScrollMonitor'\nimport { focusFirstFocusable, focusLastFocusable } from 'shared/utils/dom'\nimport { createDebouncedCallback } from 'shared/utils/misc'\nimport { keyboardKeys } from 'shared/constants'\nimport type { Nullable } from 'shared/types'\nimport { FormInput } from 'components/FormInput'\nimport { FormInputLabel } from 'components/FormInputLabel'\nimport { Chip } from 'components/Chip'\nimport { IconButton } from 'components/IconButton'\nimport { Icon } from 'components/Icon'\nimport { DropdownMenu } from './DropdownMenu'\nimport { useFilteredOptions, useLoadedOptions } from './hooks'\nimport { SIZES } from './sizes'\nimport { getDropdownInputText, getDropdownSelectedOption } from './utils'\nimport * as Styled from './style'\nimport type { DropdownProps, DropdownOption, DropdownOptionGroup } from './types'\nimport { DropdownMenuMultiple } from './DropdownMenuMultiple'\nimport { DropdownMenuSingle } from './DropdownMenuSingle'\n\nconst COMPONENT_NAME = 'Dropdown'\n\n/**\n *\n * Компонент для выбора одной или нескольких опций из числа доступных.\n *\n * Поддерживается \"ref\" и все нативные атрибуты \\<div\\> элемента.\n */\nconst Dropdown: React.ForwardRefExoticComponent<DropdownProps> = withMergedProps<DropdownProps, HTMLDivElement>(\n forwardRef<HTMLDivElement, MergedProps<DropdownProps>>((props, ref) => {\n const {\n size = 'm',\n name = 'fox-dropdown',\n labelPosition = 'dynamic',\n searchable = true,\n primary = true,\n optionsMultiToggle = true,\n iconProps = {},\n menuProps = {},\n loadingIconProps = {},\n optionsEmptyIconProps = {},\n loading,\n autoFocus,\n disableAutoScrollToSelectedOption,\n closeMenuOnScroll,\n scrollMonitorTarget,\n contrast,\n selectedOption,\n defaultSelectedOption,\n icon,\n addonLeft,\n inputMode,\n loadingMessage,\n loadingIcon,\n maxLength,\n multiple,\n clearable,\n onChangeInput,\n onCloseMenu,\n onOpenMenu,\n onSelectOption,\n options,\n loadOptions,\n renderOption,\n groupSelectedOptions,\n optionsMultiToggleCaption,\n optionsEmptyMessage,\n optionsEmptyIcon,\n palette,\n placeholder,\n readOnly,\n required,\n status,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n form,\n label,\n ...rootProps\n } = props\n\n const sizeProps = {\n size,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n }\n\n const formInputLabelId = useMemo(() => rootProps.id ?? `${name}-${nanoid()}`, [name, rootProps.id])\n const inputLabelId = useMemo(() => nanoid(), [])\n const menuListId = useMemo(() => nanoid(), [])\n\n const [filteredOptions, getFilteredOptions] = useFilteredOptions({\n options,\n })\n\n const [loadedOptions, optionsLoading, getLoadedOptions] = useLoadedOptions({\n loadOptions,\n options,\n })\n\n const [dropdownSelectedOption, setDropdownSelectedOption] = useState<DropdownOption[]>(() =>\n getDropdownSelectedOption(selectedOption !== undefined ? selectedOption : defaultSelectedOption, multiple)\n )\n\n const [inputText, setInputText] = useState<string>(() => getDropdownInputText(dropdownSelectedOption, multiple))\n\n const [focusWithin, setFocusWithin] = useState<boolean>(false)\n\n const [menuOpenRequest, setMenuOpenRequest] = useState<boolean>(false)\n\n const menuOptions: (DropdownOption | DropdownOptionGroup)[] = loadOptions ? loadedOptions : filteredOptions\n const menuOptionsLoading = loadOptions ? (loading ?? optionsLoading) : loading\n\n const menuOpen = menuOpenRequest && !rootProps.disabled\n\n const inputRequired = required && dropdownSelectedOption.length === 0\n const inputActive = Boolean(menuOpen || inputText || focusWithin)\n\n const inputRef = useRef<HTMLInputElement>(null)\n const [menuRef, setMenuRef] = useState<Nullable<HTMLElement>>(null)\n const menuListRef = useRef<HTMLUListElement>(null)\n const selectedOptionRef = useRef<HTMLElement>(null)\n const menuOpenPrevRef = useRef<boolean>(menuOpen)\n\n const updateInputText = useCallback(\n (inputTextValue: string) => {\n setInputText(inputTextValue)\n\n if (onChangeInput) {\n onChangeInput(inputTextValue)\n }\n },\n [onChangeInput]\n )\n\n const updateOptions = useCallback(\n (inputTextValue: string) => {\n if (loadOptions) {\n getLoadedOptions(inputTextValue)\n } else {\n getFilteredOptions(inputTextValue)\n }\n },\n [loadOptions, getLoadedOptions, getFilteredOptions]\n )\n\n const updateOptionsDebounced = useMemo(() => {\n return createDebouncedCallback(updateOptions, 150)\n }, [updateOptions])\n\n const preventBlur = (evt: React.PointerEvent<HTMLDivElement> | React.MouseEvent<HTMLDivElement, MouseEvent>) => {\n if (\n evt.target !== inputRef.current &&\n evt.target instanceof Node &&\n (evt.currentTarget.contains(evt.target) ||\n (menuProps.renderInPortal && menuOpen && menuRef && menuRef.contains(evt.target)))\n ) {\n evt.preventDefault()\n }\n }\n\n useScrollMonitor({\n target: scrollMonitorTarget,\n onScrollStart: () => {\n if (closeMenuOnScroll && menuOpen) {\n inputRef.current?.focus()\n setMenuOpenRequest(false)\n }\n },\n })\n\n useLayoutEffect(() => {\n if (selectedOption === undefined) return\n\n if (!multiple && !menuOpen) {\n updateInputText(getDropdownInputText(selectedOption))\n }\n setDropdownSelectedOption(getDropdownSelectedOption(selectedOption, multiple))\n }, [multiple, selectedOption, menuOpen, updateInputText])\n\n useEffect(() => {\n if (menuOpen === menuOpenPrevRef.current) return\n\n if (menuOpen && onOpenMenu) onOpenMenu()\n if (!menuOpen && onCloseMenu) onCloseMenu()\n\n menuOpenPrevRef.current = menuOpen\n }, [menuOpen, onCloseMenu, onOpenMenu])\n\n useEffect(() => {\n if (\n !multiple &&\n !disableAutoScrollToSelectedOption &&\n menuOpen &&\n !menuOptionsLoading &&\n inputText.length === 0 &&\n menuRef &&\n selectedOptionRef.current\n ) {\n const menuRect = menuRef.getBoundingClientRect()\n const selectedOptionRect = selectedOptionRef.current.getBoundingClientRect()\n\n if (selectedOptionRect.top < menuRect.top || selectedOptionRect.bottom > menuRect.bottom) {\n setTimeout(() => {\n if (menuRef && selectedOptionRef.current) {\n menuRef.scrollTo(0, selectedOptionRef.current.offsetTop)\n }\n }, 0)\n }\n }\n }, [multiple, disableAutoScrollToSelectedOption, menuOpen, menuOptionsLoading, inputText, menuRef])\n\n useEffect(() => {\n if (rootProps.disabled) {\n setFocusWithin(false)\n }\n }, [rootProps.disabled])\n\n return (\n <FormInputLabel\n {...rootProps}\n {...sizeProps}\n ref={ref}\n id={formInputLabelId}\n onColored={contrast}\n primary={primary}\n error={status === 'error'}\n success={status === 'success'}\n focus={focusWithin}\n palette={{\n color: rootProps.disabled ? palette.labelColorDisabled : palette.labelColor,\n backgroundColor: rootProps.disabled ? palette.backgroundColorDisabled : palette.backgroundColor,\n backgroundColorHover: rootProps.disabled ? palette.backgroundColorDisabled : palette.backgroundColorHover,\n borderColor: rootProps.disabled ? palette.borderColorDisabled : palette.borderColor,\n }}\n onClick={(evt) => {\n if (rootProps.onClick) rootProps.onClick(evt)\n\n if (rootProps.disabled) return\n\n inputRef.current?.focus()\n\n if (!menuOpen) {\n setMenuOpenRequest(true)\n\n updateOptions('')\n if (searchable) {\n updateInputText('')\n }\n } else if (menuRef && evt.target instanceof Node && !menuRef.contains(evt.target)) {\n setMenuOpenRequest(false)\n updateInputText(getDropdownInputText(dropdownSelectedOption, multiple))\n }\n }}\n onPointerDown={(evt) => {\n if (rootProps.onPointerDown) rootProps.onPointerDown(evt)\n\n preventBlur(evt)\n }}\n onMouseDown={(evt) => {\n if (rootProps.onMouseDown) rootProps.onMouseDown(evt)\n\n if (!window.PointerEvent) preventBlur(evt)\n }}\n onFocus={(evt) => {\n if (rootProps.onFocus) rootProps.onFocus(evt)\n\n setFocusWithin(true)\n\n if (inputRef.current && evt.target === inputRef.current && searchable && !multiple && !menuOpen) {\n updateInputText('')\n }\n }}\n onBlur={(evt) => {\n if (rootProps.onBlur) rootProps.onBlur(evt)\n\n if (\n evt.currentTarget.contains(evt.relatedTarget) ||\n (menuProps.renderInPortal && menuOpen && menuRef && menuRef.contains(evt.relatedTarget))\n ) {\n return\n }\n\n setFocusWithin(false)\n updateInputText(getDropdownInputText(dropdownSelectedOption, multiple))\n setMenuOpenRequest(false)\n }}\n input={\n <>\n {inputRequired && !searchable && !readOnly ? (\n <Styled.InputMimic\n required\n type='text'\n inputMode='none'\n form={form}\n tabIndex={-1}\n onFocus={() => {\n inputRef.current?.focus()\n }}\n />\n ) : null}\n <FormInput\n {...sizeProps}\n ref={inputRef}\n role='combobox'\n aria-controls={menuListId}\n aria-expanded={menuOpen}\n type='text'\n autoComplete='off'\n autoCapitalize='off'\n autoCorrect='off'\n spellCheck='false'\n active={inputActive}\n label={label}\n labelId={inputLabelId}\n labelPosition={labelPosition}\n form={form}\n autoFocus={autoFocus}\n inputMode={searchable ? inputMode : 'none'}\n maxLength={maxLength}\n placeholder={placeholder}\n readOnly={readOnly || !searchable}\n required={inputRequired}\n disabled={rootProps.disabled}\n value={inputText}\n palette={{\n color: palette.color,\n colorDisabled: palette.colorDisabled,\n placeholderColor: palette.placeholderColor,\n placeholderColorDisabled: palette.placeholderColorDisabled,\n }}\n onClick={(evt) => {\n if (menuOpen && evt.currentTarget.selectionStart !== evt.currentTarget.selectionEnd) {\n evt.stopPropagation()\n }\n }}\n onChange={(evt) => {\n const inputValue = evt.currentTarget.value\n\n updateInputText(inputValue)\n updateOptionsDebounced(inputValue)\n setMenuOpenRequest(true)\n }}\n onKeyDown={(evt) => {\n if (keyboardKeys.Enter.validate(evt.key)) {\n updateInputText(getDropdownInputText(dropdownSelectedOption, multiple))\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.Space.validate(evt.key) && (!menuOpen || evt.currentTarget.selectionStart === 0)) {\n evt.preventDefault()\n\n if (!menuOpen) {\n updateOptions('')\n if (searchable) {\n updateInputText('')\n }\n }\n\n setMenuOpenRequest((prev) => !prev)\n }\n\n if (keyboardKeys.Esc.validate(evt.key)) {\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.Tab.validate(evt.key) && menuOpen) {\n evt.preventDefault()\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.ArrowDown.validate(evt.key) && menuOpen && menuListRef.current) {\n evt.preventDefault()\n\n if (!multiple && selectedOptionRef.current) {\n const menuItems = [...menuListRef.current.children]\n\n const idx = menuItems.findIndex((item) => item.contains(selectedOptionRef.current as Node))\n\n const focusTarget = menuItems[idx + 1] ?? menuItems[0]\n\n if (focusTarget instanceof HTMLElement) {\n focusFirstFocusable(focusTarget)\n }\n } else {\n focusFirstFocusable(menuListRef.current)\n }\n }\n\n if (keyboardKeys.ArrowUp.validate(evt.key) && menuOpen && menuListRef.current) {\n evt.preventDefault()\n\n if (!multiple && selectedOptionRef.current) {\n const menuItems = [...menuListRef.current.children]\n\n const idx = menuItems.findIndex((item) => item.contains(selectedOptionRef.current as Node))\n\n const focusTarget = menuItems[idx - 1] ?? menuItems[menuItems.length - 1]\n\n if (focusTarget instanceof HTMLElement) {\n focusFirstFocusable(focusTarget)\n }\n } else {\n focusLastFocusable(menuListRef.current)\n }\n }\n }}\n />\n {dropdownSelectedOption.map((option) => (\n <input\n key={option.value}\n type='hidden'\n name={name}\n value={option.value}\n form={form}\n disabled={rootProps.disabled || option.disabled}\n />\n ))}\n </>\n }\n addonLeft={\n addonLeft ??\n (icon\n ? (addonLeftProps) => (\n <Icon\n {...addonLeftProps.iconProps}\n {...iconProps}\n name={typeof icon === 'string' ? icon : undefined}\n icon={typeof icon !== 'string' ? icon : undefined}\n />\n )\n : undefined)\n }\n addonRight={(addonRightProps) => (\n <>\n {multiple && dropdownSelectedOption.length > 0 ? (\n <Chip\n size='xs'\n active\n black\n disabled={rootProps.disabled}\n cursor={rootProps.disabled ? 'not-allowed' : undefined}\n title={dropdownSelectedOption.length}\n palette={\n rootProps.disabled\n ? {\n color: 'content-disabled',\n colorHover: 'content-disabled',\n backgroundColor: 'bg-disabled-small',\n backgroundColorHover: 'bg-disabled-small',\n }\n : undefined\n }\n onPointerDown={(evt) => {\n evt.preventDefault()\n }}\n onMouseDown={(evt) => {\n if (!window.PointerEvent) evt.preventDefault()\n }}\n addonRight={(chipAddonRightProps) => (\n <IconButton\n {...chipAddonRightProps.iconButtonProps}\n contrast={!rootProps.disabled}\n onClick={(evt) => {\n evt.stopPropagation()\n\n if (!readOnly) {\n if (selectedOption === undefined) {\n setDropdownSelectedOption([])\n }\n\n if (onSelectOption) onSelectOption([])\n\n inputRef.current?.focus()\n updateInputText('')\n updateOptions('')\n setMenuOpenRequest(true)\n }\n }}\n />\n )}\n />\n ) : null}\n {!multiple && clearable && dropdownSelectedOption.length > 0 ? (\n <IconButton\n icon={<Close />}\n size='l'\n square\n disabled={rootProps.disabled}\n onClick={(evt) => {\n evt.stopPropagation()\n\n if (!readOnly) {\n if (selectedOption === undefined) {\n setDropdownSelectedOption([])\n }\n\n if (onSelectOption) onSelectOption(null)\n\n inputRef.current?.focus()\n updateInputText('')\n updateOptions('')\n setMenuOpenRequest(true)\n }\n }}\n />\n ) : null}\n <Styled.IconAnimated {...addonRightProps.iconProps} {...iconProps} icon={<ChevronDown />} up={menuOpen} />\n </>\n )}\n dropdown={(dropdownProps) => (\n <DropdownMenu\n {...menuProps}\n setRef={setMenuRef}\n open={menuOpen}\n popperReferenceId={formInputLabelId}\n secondary={!contrast}\n elevated={contrast}\n disableAutoFocus\n palette={{\n backgroundColor: palette.menuBackgroundColor,\n borderColor: palette.menuBorderColor,\n }}\n empty={menuOptions.length === 0}\n loading={menuOptionsLoading}\n loadingMessage={loadingMessage}\n loadingIcon={loadingIcon}\n loadingIconProps={{\n ...dropdownProps.iconProps,\n ...loadingIconProps,\n }}\n emptyMessage={optionsEmptyMessage}\n emptyIcon={optionsEmptyIcon}\n emptyIconProps={{\n ...dropdownProps.iconProps,\n ...optionsEmptyIconProps,\n }}\n onKeyDown={(evt) => {\n if (keyboardKeys.Tab.validate(evt.key)) {\n evt.preventDefault()\n inputRef.current?.focus()\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.Enter.validate(evt.key)) {\n inputRef.current?.focus()\n updateInputText(getDropdownInputText(dropdownSelectedOption, multiple))\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.Esc.validate(evt.key)) {\n inputRef.current?.focus()\n setMenuOpenRequest(false)\n }\n\n if (keyboardKeys.Backspace.validate(evt.key) && !readOnly && (multiple || (!multiple && clearable))) {\n if (selectedOption === undefined) {\n setDropdownSelectedOption([])\n }\n\n if (onSelectOption) onSelectOption(multiple ? [] : null)\n\n updateInputText('')\n updateOptions('')\n }\n }}\n >\n {multiple ? (\n <DropdownMenuMultiple\n {...sizeProps}\n ref={menuListRef}\n inputRef={inputRef}\n label={label}\n name={name}\n disabled={rootProps.disabled}\n readOnly={readOnly}\n menuListId={menuListId}\n inputLabelId={inputLabelId}\n menuOptions={menuOptions}\n dropdownSelectedOption={dropdownSelectedOption}\n inputText={inputText}\n optionsMultiToggle={optionsMultiToggle}\n groupSelectedOptions={groupSelectedOptions}\n optionsMultiToggleCaption={optionsMultiToggleCaption}\n renderOption={renderOption}\n onChange={(update) => {\n if (selectedOption === undefined) {\n setDropdownSelectedOption(update)\n }\n\n if (onSelectOption) onSelectOption(update)\n }}\n />\n ) : (\n <DropdownMenuSingle\n {...sizeProps}\n ref={menuListRef}\n label={label}\n readOnly={readOnly}\n multiple={multiple}\n disabled={rootProps.disabled}\n status={status}\n menuListId={menuListId}\n inputLabelId={inputLabelId}\n menuOptions={menuOptions}\n dropdownSelectedOption={dropdownSelectedOption}\n selectedOptionRef={selectedOptionRef}\n renderOption={renderOption}\n onChange={(option) => {\n const update = { ...option }\n\n if (selectedOption === undefined) {\n updateInputText(getDropdownInputText(update))\n setDropdownSelectedOption(getDropdownSelectedOption(update))\n }\n\n if (onSelectOption) onSelectOption(update)\n\n inputRef.current?.focus()\n setMenuOpenRequest(false)\n }}\n />\n )}\n </DropdownMenu>\n )}\n />\n )\n }),\n {\n sizes: SIZES,\n displayName: COMPONENT_NAME,\n }\n)\n\nexport { Dropdown, COMPONENT_NAME }\n"],"names":["COMPONENT_NAME","Dropdown","withMergedProps","forwardRef","props","ref","size","name","labelPosition","searchable","primary","optionsMultiToggle","iconProps","menuProps","loadingIconProps","optionsEmptyIconProps","loading","autoFocus","disableAutoScrollToSelectedOption","closeMenuOnScroll","scrollMonitorTarget","contrast","selectedOption","defaultSelectedOption","icon","addonLeft","inputMode","loadingMessage","loadingIcon","maxLength","multiple","clearable","onChangeInput","onCloseMenu","onOpenMenu","onSelectOption","options","loadOptions","renderOption","groupSelectedOptions","optionsMultiToggleCaption","optionsEmptyMessage","optionsEmptyIcon","palette","placeholder","readOnly","required","status","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","form","label","rootProps","sizeProps","formInputLabelId","useMemo","id","nanoid","inputLabelId","menuListId","filteredOptions","getFilteredOptions","useFilteredOptions","loadedOptions","optionsLoading","getLoadedOptions","useLoadedOptions","dropdownSelectedOption","setDropdownSelectedOption","useState","getDropdownSelectedOption","undefined","inputText","setInputText","getDropdownInputText","focusWithin","setFocusWithin","menuOpenRequest","setMenuOpenRequest","menuOptions","menuOptionsLoading","menuOpen","disabled","inputRequired","length","inputActive","Boolean","inputRef","useRef","menuRef","setMenuRef","menuListRef","selectedOptionRef","menuOpenPrevRef","updateInputText","useCallback","inputTextValue","updateOptions","updateOptionsDebounced","createDebouncedCallback","preventBlur","evt","target","current","Node","currentTarget","contains","renderInPortal","preventDefault","useScrollMonitor","onScrollStart","focus","useLayoutEffect","useEffect","menuRect","getBoundingClientRect","selectedOptionRect","top","bottom","setTimeout","scrollTo","offsetTop","_jsx","FormInputLabel","onColored","error","success","color","labelColorDisabled","labelColor","backgroundColor","backgroundColorDisabled","backgroundColorHover","borderColor","borderColorDisabled","onClick","onPointerDown","onMouseDown","window","PointerEvent","onFocus","onBlur","relatedTarget","input","_jsxs","_Fragment","children","Styled","type","tabIndex","FormInput","role","autoComplete","autoCapitalize","autoCorrect","spellCheck","active","labelId","value","colorDisabled","placeholderColor","placeholderColorDisabled","selectionStart","selectionEnd","stopPropagation","onChange","inputValue","onKeyDown","keyboardKeys","Enter","validate","key","Space","prev","Esc","Tab","ArrowDown","menuItems","idx","findIndex","item","focusTarget","HTMLElement","focusFirstFocusable","ArrowUp","focusLastFocusable","map","option","addonLeftProps","Icon","addonRight","addonRightProps","Chip","black","cursor","title","colorHover","chipAddonRightProps","IconButton","iconButtonProps","Close","square","ChevronDown","up","dropdown","dropdownProps","DropdownMenu","setRef","open","popperReferenceId","secondary","elevated","disableAutoFocus","menuBackgroundColor","menuBorderColor","empty","emptyMessage","emptyIcon","emptyIconProps","Backspace","DropdownMenuMultiple","update","DropdownMenuSingle","sizes","SIZES","displayName"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- 'use strict';exports.SIZES={xxxl:{width:10,height:10,borderRadius:'50%'},xxl:{width:10,height:10,borderRadius:'50%'},xl:{width:10,height:10,borderRadius:'50%'},l:{width:10,height:10,borderRadius:'50%'},m:{width:6,height:6,borderRadius:'50%'},s:{width:4,height:4,borderRadius:'50%'},xs:{width:4,height:4,borderRadius:'50%'},xxs:{width:4,height:4,borderRadius:'50%'},xxxs:{width:4,height:4,borderRadius:'50%'}},exports.SIZES_SQUARE={xxxl:{width:'min-content',minWidth:22,height:22,borderRadius:5,fontSize:14},xxl:{width:'min-content',minWidth:22,height:22,borderRadius:5,fontSize:14},xl:{width:'min-content',minWidth:22,height:22,borderRadius:5,fontSize:14},l:{width:'min-content',minWidth:22,height:22,borderRadius:5,fontSize:14},m:{width:'min-content',minWidth:18,height:18,borderRadius:4,fontSize:12},s:{width:'min-content',minWidth:16,height:16,borderRadius:4,fontSize:10},xs:{width:'min-content',minWidth:16,height:16,borderRadius:4,fontSize:10},xxs:{width:'min-content',minWidth:16,height:16,borderRadius:4,fontSize:10},xxxs:{width:'min-content',minWidth:16,height:16,borderRadius:4,fontSize:10}};
1
+ 'use strict';exports.SIZES={xxxl:{width:10,minWidth:'auto',height:10,borderRadius:'50%',fontSize:14},xxl:{width:10,minWidth:'auto',height:10,borderRadius:'50%',fontSize:14},xl:{width:10,minWidth:'auto',height:10,borderRadius:'50%',fontSize:14},l:{width:10,minWidth:'auto',height:10,borderRadius:'50%',fontSize:14},m:{width:6,minWidth:'auto',height:6,borderRadius:'50%',fontSize:12},s:{width:4,minWidth:'auto',height:4,borderRadius:'50%',fontSize:10},xs:{width:4,minWidth:'auto',height:4,borderRadius:'50%',fontSize:10},xxs:{width:4,minWidth:'auto',height:4,borderRadius:'50%',fontSize:10},xxxs:{width:4,minWidth:'auto',height:4,borderRadius:'50%',fontSize:10}},exports.SIZES_SQUARE={xxxl:{'--indicator-size':'22px',width:'min-content',minWidth:'var(--indicator-size)',height:'var(--indicator-size)',borderRadius:"calc(var(--indicator-size) * 0.2)",fontSize:14},xxl:{'--indicator-size':'22px',width:'min-content',minWidth:'var(--indicator-size)',height:'var(--indicator-size)',borderRadius:"calc(var(--indicator-size) * 0.2)",fontSize:14},xl:{'--indicator-size':'22px',width:'min-content',minWidth:'var(--indicator-size)',height:'var(--indicator-size)',borderRadius:"calc(var(--indicator-size) * 0.2)",fontSize:14},l:{'--indicator-size':'22px',width:'min-content',minWidth:'var(--indicator-size)',height:'var(--indicator-size)',borderRadius:"calc(var(--indicator-size) * 0.2)",fontSize:14},m:{'--indicator-size':'18px',width:'min-content',minWidth:'var(--indicator-size)',height:'var(--indicator-size)',borderRadius:"calc(var(--indicator-size) * 0.2)",fontSize:12},s:{'--indicator-size':'16px',width:'min-content',minWidth:'var(--indicator-size)',height:'var(--indicator-size)',borderRadius:"calc(var(--indicator-size) * 0.2)",fontSize:10},xs:{'--indicator-size':'16px',width:'min-content',minWidth:'var(--indicator-size)',height:'var(--indicator-size)',borderRadius:"calc(var(--indicator-size) * 0.2)",fontSize:10},xxs:{'--indicator-size':'16px',width:'min-content',minWidth:'var(--indicator-size)',height:'var(--indicator-size)',borderRadius:"calc(var(--indicator-size) * 0.2)",fontSize:10},xxxs:{'--indicator-size':'16px',width:'min-content',minWidth:'var(--indicator-size)',height:'var(--indicator-size)',borderRadius:"calc(var(--indicator-size) * 0.2)",fontSize:10}};
2
2
  //# sourceMappingURL=constants.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"constants.js","sources":["../../../../src/components/Indicator/constants.ts"],"sourcesContent":["import type { CSSProperties } from 'react'\nimport type { Size } from 'shared/types'\n\nexport const SIZES: Record<Size, CSSProperties> = {\n xxxl: {\n width: 10,\n height: 10,\n borderRadius: '50%',\n },\n xxl: {\n width: 10,\n height: 10,\n borderRadius: '50%',\n },\n xl: {\n width: 10,\n height: 10,\n borderRadius: '50%',\n },\n l: {\n width: 10,\n height: 10,\n borderRadius: '50%',\n },\n m: {\n width: 6,\n height: 6,\n borderRadius: '50%',\n },\n s: {\n width: 4,\n height: 4,\n borderRadius: '50%',\n },\n xs: {\n width: 4,\n height: 4,\n borderRadius: '50%',\n },\n xxs: {\n width: 4,\n height: 4,\n borderRadius: '50%',\n },\n xxxs: {\n width: 4,\n height: 4,\n borderRadius: '50%',\n },\n}\n\nexport const SIZES_SQUARE: Record<Size, CSSProperties> = {\n xxxl: {\n width: 'min-content',\n minWidth: 22,\n height: 22,\n borderRadius: 5,\n fontSize: 14,\n },\n xxl: {\n width: 'min-content',\n minWidth: 22,\n height: 22,\n borderRadius: 5,\n fontSize: 14,\n },\n xl: {\n width: 'min-content',\n minWidth: 22,\n height: 22,\n borderRadius: 5,\n fontSize: 14,\n },\n l: {\n width: 'min-content',\n minWidth: 22,\n height: 22,\n borderRadius: 5,\n fontSize: 14,\n },\n m: {\n width: 'min-content',\n minWidth: 18,\n height: 18,\n borderRadius: 4,\n fontSize: 12,\n },\n s: {\n width: 'min-content',\n minWidth: 16,\n height: 16,\n borderRadius: 4,\n fontSize: 10,\n },\n xs: {\n width: 'min-content',\n minWidth: 16,\n height: 16,\n borderRadius: 4,\n fontSize: 10,\n },\n xxs: {\n width: 'min-content',\n minWidth: 16,\n height: 16,\n borderRadius: 4,\n fontSize: 10,\n },\n xxxs: {\n width: 'min-content',\n minWidth: 16,\n height: 16,\n borderRadius: 4,\n fontSize: 10,\n },\n}\n"],"names":["xxxl","width","height","borderRadius","xxl","xl","l","m","s","xs","xxs","xxxs","minWidth","fontSize"],"mappings":"2BAGkD,CAChDA,KAAM,CACJC,MAAO,GACPC,OAAQ,GACRC,aAAc,OAEhBC,IAAK,CACHH,MAAO,GACPC,OAAQ,GACRC,aAAc,OAEhBE,GAAI,CACFJ,MAAO,GACPC,OAAQ,GACRC,aAAc,OAEhBG,EAAG,CACDL,MAAO,GACPC,OAAQ,GACRC,aAAc,OAEhBI,EAAG,CACDN,MAAO,EACPC,OAAQ,EACRC,aAAc,OAEhBK,EAAG,CACDP,MAAO,EACPC,OAAQ,EACRC,aAAc,OAEhBM,GAAI,CACFR,MAAO,EACPC,OAAQ,EACRC,aAAc,OAEhBO,IAAK,CACHT,MAAO,EACPC,OAAQ,EACRC,aAAc,OAEhBQ,KAAM,CACJV,MAAO,EACPC,OAAQ,EACRC,aAAc,6BAIuC,CACvDH,KAAM,CACJC,MAAO,cACPW,SAAU,GACVV,OAAQ,GACRC,aAAc,EACdU,SAAU,IAEZT,IAAK,CACHH,MAAO,cACPW,SAAU,GACVV,OAAQ,GACRC,aAAc,EACdU,SAAU,IAEZR,GAAI,CACFJ,MAAO,cACPW,SAAU,GACVV,OAAQ,GACRC,aAAc,EACdU,SAAU,IAEZP,EAAG,CACDL,MAAO,cACPW,SAAU,GACVV,OAAQ,GACRC,aAAc,EACdU,SAAU,IAEZN,EAAG,CACDN,MAAO,cACPW,SAAU,GACVV,OAAQ,GACRC,aAAc,EACdU,SAAU,IAEZL,EAAG,CACDP,MAAO,cACPW,SAAU,GACVV,OAAQ,GACRC,aAAc,EACdU,SAAU,IAEZJ,GAAI,CACFR,MAAO,cACPW,SAAU,GACVV,OAAQ,GACRC,aAAc,EACdU,SAAU,IAEZH,IAAK,CACHT,MAAO,cACPW,SAAU,GACVV,OAAQ,GACRC,aAAc,EACdU,SAAU,IAEZF,KAAM,CACJV,MAAO,cACPW,SAAU,GACVV,OAAQ,GACRC,aAAc,EACdU,SAAU"}
1
+ {"version":3,"file":"constants.js","sources":["../../../../src/components/Indicator/constants.ts"],"sourcesContent":["import type { CSSProperties } from 'react'\nimport type { Size } from 'shared/types'\n\nexport const SIZES: Record<Size, CSSProperties> = {\n xxxl: {\n width: 10,\n minWidth: 'auto',\n height: 10,\n borderRadius: '50%',\n fontSize: 14,\n },\n xxl: {\n width: 10,\n minWidth: 'auto',\n height: 10,\n borderRadius: '50%',\n fontSize: 14,\n },\n xl: {\n width: 10,\n minWidth: 'auto',\n height: 10,\n borderRadius: '50%',\n fontSize: 14,\n },\n l: {\n width: 10,\n minWidth: 'auto',\n height: 10,\n borderRadius: '50%',\n fontSize: 14,\n },\n m: {\n width: 6,\n minWidth: 'auto',\n height: 6,\n borderRadius: '50%',\n fontSize: 12,\n },\n s: {\n width: 4,\n minWidth: 'auto',\n height: 4,\n borderRadius: '50%',\n fontSize: 10,\n },\n xs: {\n width: 4,\n minWidth: 'auto',\n height: 4,\n borderRadius: '50%',\n fontSize: 10,\n },\n xxs: {\n width: 4,\n minWidth: 'auto',\n height: 4,\n borderRadius: '50%',\n fontSize: 10,\n },\n xxxs: {\n width: 4,\n minWidth: 'auto',\n height: 4,\n borderRadius: '50%',\n fontSize: 10,\n },\n}\n\nexport const SIZES_SQUARE: Record<Size, CSSProperties> = {\n xxxl: {\n '--indicator-size': '22px',\n width: 'min-content',\n minWidth: 'var(--indicator-size)',\n height: 'var(--indicator-size)',\n borderRadius: `calc(var(--indicator-size) * 0.2)`,\n fontSize: 14,\n },\n xxl: {\n '--indicator-size': '22px',\n width: 'min-content',\n minWidth: 'var(--indicator-size)',\n height: 'var(--indicator-size)',\n borderRadius: `calc(var(--indicator-size) * 0.2)`,\n fontSize: 14,\n },\n xl: {\n '--indicator-size': '22px',\n width: 'min-content',\n minWidth: 'var(--indicator-size)',\n height: 'var(--indicator-size)',\n borderRadius: `calc(var(--indicator-size) * 0.2)`,\n fontSize: 14,\n },\n l: {\n '--indicator-size': '22px',\n width: 'min-content',\n minWidth: 'var(--indicator-size)',\n height: 'var(--indicator-size)',\n borderRadius: `calc(var(--indicator-size) * 0.2)`,\n fontSize: 14,\n },\n m: {\n '--indicator-size': '18px',\n width: 'min-content',\n minWidth: 'var(--indicator-size)',\n height: 'var(--indicator-size)',\n borderRadius: `calc(var(--indicator-size) * 0.2)`,\n fontSize: 12,\n },\n s: {\n '--indicator-size': '16px',\n width: 'min-content',\n minWidth: 'var(--indicator-size)',\n height: 'var(--indicator-size)',\n borderRadius: `calc(var(--indicator-size) * 0.2)`,\n fontSize: 10,\n },\n xs: {\n '--indicator-size': '16px',\n width: 'min-content',\n minWidth: 'var(--indicator-size)',\n height: 'var(--indicator-size)',\n borderRadius: `calc(var(--indicator-size) * 0.2)`,\n fontSize: 10,\n },\n xxs: {\n '--indicator-size': '16px',\n width: 'min-content',\n minWidth: 'var(--indicator-size)',\n height: 'var(--indicator-size)',\n borderRadius: `calc(var(--indicator-size) * 0.2)`,\n fontSize: 10,\n },\n xxxs: {\n '--indicator-size': '16px',\n width: 'min-content',\n minWidth: 'var(--indicator-size)',\n height: 'var(--indicator-size)',\n borderRadius: `calc(var(--indicator-size) * 0.2)`,\n fontSize: 10,\n },\n}\n"],"names":["xxxl","width","minWidth","height","borderRadius","fontSize","xxl","xl","l","m","s","xs","xxs","xxxs"],"mappings":"2BAGkD,CAChDA,KAAM,CACJC,MAAO,GACPC,SAAU,OACVC,OAAQ,GACRC,aAAc,MACdC,SAAU,IAEZC,IAAK,CACHL,MAAO,GACPC,SAAU,OACVC,OAAQ,GACRC,aAAc,MACdC,SAAU,IAEZE,GAAI,CACFN,MAAO,GACPC,SAAU,OACVC,OAAQ,GACRC,aAAc,MACdC,SAAU,IAEZG,EAAG,CACDP,MAAO,GACPC,SAAU,OACVC,OAAQ,GACRC,aAAc,MACdC,SAAU,IAEZI,EAAG,CACDR,MAAO,EACPC,SAAU,OACVC,OAAQ,EACRC,aAAc,MACdC,SAAU,IAEZK,EAAG,CACDT,MAAO,EACPC,SAAU,OACVC,OAAQ,EACRC,aAAc,MACdC,SAAU,IAEZM,GAAI,CACFV,MAAO,EACPC,SAAU,OACVC,OAAQ,EACRC,aAAc,MACdC,SAAU,IAEZO,IAAK,CACHX,MAAO,EACPC,SAAU,OACVC,OAAQ,EACRC,aAAc,MACdC,SAAU,IAEZQ,KAAM,CACJZ,MAAO,EACPC,SAAU,OACVC,OAAQ,EACRC,aAAc,MACdC,SAAU,0BAI2C,CACvDL,KAAM,CACJ,mBAAoB,OACpBC,MAAO,cACPC,SAAU,wBACVC,OAAQ,wBACRC,aAAc,oCACdC,SAAU,IAEZC,IAAK,CACH,mBAAoB,OACpBL,MAAO,cACPC,SAAU,wBACVC,OAAQ,wBACRC,aAAc,oCACdC,SAAU,IAEZE,GAAI,CACF,mBAAoB,OACpBN,MAAO,cACPC,SAAU,wBACVC,OAAQ,wBACRC,aAAc,oCACdC,SAAU,IAEZG,EAAG,CACD,mBAAoB,OACpBP,MAAO,cACPC,SAAU,wBACVC,OAAQ,wBACRC,aAAc,oCACdC,SAAU,IAEZI,EAAG,CACD,mBAAoB,OACpBR,MAAO,cACPC,SAAU,wBACVC,OAAQ,wBACRC,aAAc,oCACdC,SAAU,IAEZK,EAAG,CACD,mBAAoB,OACpBT,MAAO,cACPC,SAAU,wBACVC,OAAQ,wBACRC,aAAc,oCACdC,SAAU,IAEZM,GAAI,CACF,mBAAoB,OACpBV,MAAO,cACPC,SAAU,wBACVC,OAAQ,wBACRC,aAAc,oCACdC,SAAU,IAEZO,IAAK,CACH,mBAAoB,OACpBX,MAAO,cACPC,SAAU,wBACVC,OAAQ,wBACRC,aAAc,oCACdC,SAAU,IAEZQ,KAAM,CACJ,mBAAoB,OACpBZ,MAAO,cACPC,SAAU,wBACVC,OAAQ,wBACRC,aAAc,oCACdC,SAAU"}
@@ -1,2 +1,2 @@
1
- const SIZES={xxxl:{width:10,height:10,borderRadius:'50%'},xxl:{width:10,height:10,borderRadius:'50%'},xl:{width:10,height:10,borderRadius:'50%'},l:{width:10,height:10,borderRadius:'50%'},m:{width:6,height:6,borderRadius:'50%'},s:{width:4,height:4,borderRadius:'50%'},xs:{width:4,height:4,borderRadius:'50%'},xxs:{width:4,height:4,borderRadius:'50%'},xxxs:{width:4,height:4,borderRadius:'50%'}};const SIZES_SQUARE={xxxl:{width:'min-content',minWidth:22,height:22,borderRadius:5,fontSize:14},xxl:{width:'min-content',minWidth:22,height:22,borderRadius:5,fontSize:14},xl:{width:'min-content',minWidth:22,height:22,borderRadius:5,fontSize:14},l:{width:'min-content',minWidth:22,height:22,borderRadius:5,fontSize:14},m:{width:'min-content',minWidth:18,height:18,borderRadius:4,fontSize:12},s:{width:'min-content',minWidth:16,height:16,borderRadius:4,fontSize:10},xs:{width:'min-content',minWidth:16,height:16,borderRadius:4,fontSize:10},xxs:{width:'min-content',minWidth:16,height:16,borderRadius:4,fontSize:10},xxxs:{width:'min-content',minWidth:16,height:16,borderRadius:4,fontSize:10}};export{SIZES,SIZES_SQUARE};
1
+ const SIZES={xxxl:{width:10,minWidth:'auto',height:10,borderRadius:'50%',fontSize:14},xxl:{width:10,minWidth:'auto',height:10,borderRadius:'50%',fontSize:14},xl:{width:10,minWidth:'auto',height:10,borderRadius:'50%',fontSize:14},l:{width:10,minWidth:'auto',height:10,borderRadius:'50%',fontSize:14},m:{width:6,minWidth:'auto',height:6,borderRadius:'50%',fontSize:12},s:{width:4,minWidth:'auto',height:4,borderRadius:'50%',fontSize:10},xs:{width:4,minWidth:'auto',height:4,borderRadius:'50%',fontSize:10},xxs:{width:4,minWidth:'auto',height:4,borderRadius:'50%',fontSize:10},xxxs:{width:4,minWidth:'auto',height:4,borderRadius:'50%',fontSize:10}};const SIZES_SQUARE={xxxl:{'--indicator-size':'22px',width:'min-content',minWidth:'var(--indicator-size)',height:'var(--indicator-size)',borderRadius:"calc(var(--indicator-size) * 0.2)",fontSize:14},xxl:{'--indicator-size':'22px',width:'min-content',minWidth:'var(--indicator-size)',height:'var(--indicator-size)',borderRadius:"calc(var(--indicator-size) * 0.2)",fontSize:14},xl:{'--indicator-size':'22px',width:'min-content',minWidth:'var(--indicator-size)',height:'var(--indicator-size)',borderRadius:"calc(var(--indicator-size) * 0.2)",fontSize:14},l:{'--indicator-size':'22px',width:'min-content',minWidth:'var(--indicator-size)',height:'var(--indicator-size)',borderRadius:"calc(var(--indicator-size) * 0.2)",fontSize:14},m:{'--indicator-size':'18px',width:'min-content',minWidth:'var(--indicator-size)',height:'var(--indicator-size)',borderRadius:"calc(var(--indicator-size) * 0.2)",fontSize:12},s:{'--indicator-size':'16px',width:'min-content',minWidth:'var(--indicator-size)',height:'var(--indicator-size)',borderRadius:"calc(var(--indicator-size) * 0.2)",fontSize:10},xs:{'--indicator-size':'16px',width:'min-content',minWidth:'var(--indicator-size)',height:'var(--indicator-size)',borderRadius:"calc(var(--indicator-size) * 0.2)",fontSize:10},xxs:{'--indicator-size':'16px',width:'min-content',minWidth:'var(--indicator-size)',height:'var(--indicator-size)',borderRadius:"calc(var(--indicator-size) * 0.2)",fontSize:10},xxxs:{'--indicator-size':'16px',width:'min-content',minWidth:'var(--indicator-size)',height:'var(--indicator-size)',borderRadius:"calc(var(--indicator-size) * 0.2)",fontSize:10}};export{SIZES,SIZES_SQUARE};
2
2
  //# sourceMappingURL=constants.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"constants.mjs","sources":["../../../../src/components/Indicator/constants.ts"],"sourcesContent":["import type { CSSProperties } from 'react'\nimport type { Size } from 'shared/types'\n\nexport const SIZES: Record<Size, CSSProperties> = {\n xxxl: {\n width: 10,\n height: 10,\n borderRadius: '50%',\n },\n xxl: {\n width: 10,\n height: 10,\n borderRadius: '50%',\n },\n xl: {\n width: 10,\n height: 10,\n borderRadius: '50%',\n },\n l: {\n width: 10,\n height: 10,\n borderRadius: '50%',\n },\n m: {\n width: 6,\n height: 6,\n borderRadius: '50%',\n },\n s: {\n width: 4,\n height: 4,\n borderRadius: '50%',\n },\n xs: {\n width: 4,\n height: 4,\n borderRadius: '50%',\n },\n xxs: {\n width: 4,\n height: 4,\n borderRadius: '50%',\n },\n xxxs: {\n width: 4,\n height: 4,\n borderRadius: '50%',\n },\n}\n\nexport const SIZES_SQUARE: Record<Size, CSSProperties> = {\n xxxl: {\n width: 'min-content',\n minWidth: 22,\n height: 22,\n borderRadius: 5,\n fontSize: 14,\n },\n xxl: {\n width: 'min-content',\n minWidth: 22,\n height: 22,\n borderRadius: 5,\n fontSize: 14,\n },\n xl: {\n width: 'min-content',\n minWidth: 22,\n height: 22,\n borderRadius: 5,\n fontSize: 14,\n },\n l: {\n width: 'min-content',\n minWidth: 22,\n height: 22,\n borderRadius: 5,\n fontSize: 14,\n },\n m: {\n width: 'min-content',\n minWidth: 18,\n height: 18,\n borderRadius: 4,\n fontSize: 12,\n },\n s: {\n width: 'min-content',\n minWidth: 16,\n height: 16,\n borderRadius: 4,\n fontSize: 10,\n },\n xs: {\n width: 'min-content',\n minWidth: 16,\n height: 16,\n borderRadius: 4,\n fontSize: 10,\n },\n xxs: {\n width: 'min-content',\n minWidth: 16,\n height: 16,\n borderRadius: 4,\n fontSize: 10,\n },\n xxxs: {\n width: 'min-content',\n minWidth: 16,\n height: 16,\n borderRadius: 4,\n fontSize: 10,\n },\n}\n"],"names":["SIZES","xxxl","width","height","borderRadius","xxl","xl","l","m","s","xs","xxs","xxxs","SIZES_SQUARE","minWidth","fontSize"],"mappings":"AAGO,MAAMA,MAAqC,CAChDC,KAAM,CACJC,MAAO,GACPC,OAAQ,GACRC,aAAc,OAEhBC,IAAK,CACHH,MAAO,GACPC,OAAQ,GACRC,aAAc,OAEhBE,GAAI,CACFJ,MAAO,GACPC,OAAQ,GACRC,aAAc,OAEhBG,EAAG,CACDL,MAAO,GACPC,OAAQ,GACRC,aAAc,OAEhBI,EAAG,CACDN,MAAO,EACPC,OAAQ,EACRC,aAAc,OAEhBK,EAAG,CACDP,MAAO,EACPC,OAAQ,EACRC,aAAc,OAEhBM,GAAI,CACFR,MAAO,EACPC,OAAQ,EACRC,aAAc,OAEhBO,IAAK,CACHT,MAAO,EACPC,OAAQ,EACRC,aAAc,OAEhBQ,KAAM,CACJV,MAAO,EACPC,OAAQ,EACRC,aAAc,QAIX,MAAMS,aAA4C,CACvDZ,KAAM,CACJC,MAAO,cACPY,SAAU,GACVX,OAAQ,GACRC,aAAc,EACdW,SAAU,IAEZV,IAAK,CACHH,MAAO,cACPY,SAAU,GACVX,OAAQ,GACRC,aAAc,EACdW,SAAU,IAEZT,GAAI,CACFJ,MAAO,cACPY,SAAU,GACVX,OAAQ,GACRC,aAAc,EACdW,SAAU,IAEZR,EAAG,CACDL,MAAO,cACPY,SAAU,GACVX,OAAQ,GACRC,aAAc,EACdW,SAAU,IAEZP,EAAG,CACDN,MAAO,cACPY,SAAU,GACVX,OAAQ,GACRC,aAAc,EACdW,SAAU,IAEZN,EAAG,CACDP,MAAO,cACPY,SAAU,GACVX,OAAQ,GACRC,aAAc,EACdW,SAAU,IAEZL,GAAI,CACFR,MAAO,cACPY,SAAU,GACVX,OAAQ,GACRC,aAAc,EACdW,SAAU,IAEZJ,IAAK,CACHT,MAAO,cACPY,SAAU,GACVX,OAAQ,GACRC,aAAc,EACdW,SAAU,IAEZH,KAAM,CACJV,MAAO,cACPY,SAAU,GACVX,OAAQ,GACRC,aAAc,EACdW,SAAU"}
1
+ {"version":3,"file":"constants.mjs","sources":["../../../../src/components/Indicator/constants.ts"],"sourcesContent":["import type { CSSProperties } from 'react'\nimport type { Size } from 'shared/types'\n\nexport const SIZES: Record<Size, CSSProperties> = {\n xxxl: {\n width: 10,\n minWidth: 'auto',\n height: 10,\n borderRadius: '50%',\n fontSize: 14,\n },\n xxl: {\n width: 10,\n minWidth: 'auto',\n height: 10,\n borderRadius: '50%',\n fontSize: 14,\n },\n xl: {\n width: 10,\n minWidth: 'auto',\n height: 10,\n borderRadius: '50%',\n fontSize: 14,\n },\n l: {\n width: 10,\n minWidth: 'auto',\n height: 10,\n borderRadius: '50%',\n fontSize: 14,\n },\n m: {\n width: 6,\n minWidth: 'auto',\n height: 6,\n borderRadius: '50%',\n fontSize: 12,\n },\n s: {\n width: 4,\n minWidth: 'auto',\n height: 4,\n borderRadius: '50%',\n fontSize: 10,\n },\n xs: {\n width: 4,\n minWidth: 'auto',\n height: 4,\n borderRadius: '50%',\n fontSize: 10,\n },\n xxs: {\n width: 4,\n minWidth: 'auto',\n height: 4,\n borderRadius: '50%',\n fontSize: 10,\n },\n xxxs: {\n width: 4,\n minWidth: 'auto',\n height: 4,\n borderRadius: '50%',\n fontSize: 10,\n },\n}\n\nexport const SIZES_SQUARE: Record<Size, CSSProperties> = {\n xxxl: {\n '--indicator-size': '22px',\n width: 'min-content',\n minWidth: 'var(--indicator-size)',\n height: 'var(--indicator-size)',\n borderRadius: `calc(var(--indicator-size) * 0.2)`,\n fontSize: 14,\n },\n xxl: {\n '--indicator-size': '22px',\n width: 'min-content',\n minWidth: 'var(--indicator-size)',\n height: 'var(--indicator-size)',\n borderRadius: `calc(var(--indicator-size) * 0.2)`,\n fontSize: 14,\n },\n xl: {\n '--indicator-size': '22px',\n width: 'min-content',\n minWidth: 'var(--indicator-size)',\n height: 'var(--indicator-size)',\n borderRadius: `calc(var(--indicator-size) * 0.2)`,\n fontSize: 14,\n },\n l: {\n '--indicator-size': '22px',\n width: 'min-content',\n minWidth: 'var(--indicator-size)',\n height: 'var(--indicator-size)',\n borderRadius: `calc(var(--indicator-size) * 0.2)`,\n fontSize: 14,\n },\n m: {\n '--indicator-size': '18px',\n width: 'min-content',\n minWidth: 'var(--indicator-size)',\n height: 'var(--indicator-size)',\n borderRadius: `calc(var(--indicator-size) * 0.2)`,\n fontSize: 12,\n },\n s: {\n '--indicator-size': '16px',\n width: 'min-content',\n minWidth: 'var(--indicator-size)',\n height: 'var(--indicator-size)',\n borderRadius: `calc(var(--indicator-size) * 0.2)`,\n fontSize: 10,\n },\n xs: {\n '--indicator-size': '16px',\n width: 'min-content',\n minWidth: 'var(--indicator-size)',\n height: 'var(--indicator-size)',\n borderRadius: `calc(var(--indicator-size) * 0.2)`,\n fontSize: 10,\n },\n xxs: {\n '--indicator-size': '16px',\n width: 'min-content',\n minWidth: 'var(--indicator-size)',\n height: 'var(--indicator-size)',\n borderRadius: `calc(var(--indicator-size) * 0.2)`,\n fontSize: 10,\n },\n xxxs: {\n '--indicator-size': '16px',\n width: 'min-content',\n minWidth: 'var(--indicator-size)',\n height: 'var(--indicator-size)',\n borderRadius: `calc(var(--indicator-size) * 0.2)`,\n fontSize: 10,\n },\n}\n"],"names":["SIZES","xxxl","width","minWidth","height","borderRadius","fontSize","xxl","xl","l","m","s","xs","xxs","xxxs","SIZES_SQUARE"],"mappings":"AAGO,MAAMA,MAAqC,CAChDC,KAAM,CACJC,MAAO,GACPC,SAAU,OACVC,OAAQ,GACRC,aAAc,MACdC,SAAU,IAEZC,IAAK,CACHL,MAAO,GACPC,SAAU,OACVC,OAAQ,GACRC,aAAc,MACdC,SAAU,IAEZE,GAAI,CACFN,MAAO,GACPC,SAAU,OACVC,OAAQ,GACRC,aAAc,MACdC,SAAU,IAEZG,EAAG,CACDP,MAAO,GACPC,SAAU,OACVC,OAAQ,GACRC,aAAc,MACdC,SAAU,IAEZI,EAAG,CACDR,MAAO,EACPC,SAAU,OACVC,OAAQ,EACRC,aAAc,MACdC,SAAU,IAEZK,EAAG,CACDT,MAAO,EACPC,SAAU,OACVC,OAAQ,EACRC,aAAc,MACdC,SAAU,IAEZM,GAAI,CACFV,MAAO,EACPC,SAAU,OACVC,OAAQ,EACRC,aAAc,MACdC,SAAU,IAEZO,IAAK,CACHX,MAAO,EACPC,SAAU,OACVC,OAAQ,EACRC,aAAc,MACdC,SAAU,IAEZQ,KAAM,CACJZ,MAAO,EACPC,SAAU,OACVC,OAAQ,EACRC,aAAc,MACdC,SAAU,KAIP,MAAMS,aAA4C,CACvDd,KAAM,CACJ,mBAAoB,OACpBC,MAAO,cACPC,SAAU,wBACVC,OAAQ,wBACRC,aAAc,oCACdC,SAAU,IAEZC,IAAK,CACH,mBAAoB,OACpBL,MAAO,cACPC,SAAU,wBACVC,OAAQ,wBACRC,aAAc,oCACdC,SAAU,IAEZE,GAAI,CACF,mBAAoB,OACpBN,MAAO,cACPC,SAAU,wBACVC,OAAQ,wBACRC,aAAc,oCACdC,SAAU,IAEZG,EAAG,CACD,mBAAoB,OACpBP,MAAO,cACPC,SAAU,wBACVC,OAAQ,wBACRC,aAAc,oCACdC,SAAU,IAEZI,EAAG,CACD,mBAAoB,OACpBR,MAAO,cACPC,SAAU,wBACVC,OAAQ,wBACRC,aAAc,oCACdC,SAAU,IAEZK,EAAG,CACD,mBAAoB,OACpBT,MAAO,cACPC,SAAU,wBACVC,OAAQ,wBACRC,aAAc,oCACdC,SAAU,IAEZM,GAAI,CACF,mBAAoB,OACpBV,MAAO,cACPC,SAAU,wBACVC,OAAQ,wBACRC,aAAc,oCACdC,SAAU,IAEZO,IAAK,CACH,mBAAoB,OACpBX,MAAO,cACPC,SAAU,wBACVC,OAAQ,wBACRC,aAAc,oCACdC,SAAU,IAEZQ,KAAM,CACJ,mBAAoB,OACpBZ,MAAO,cACPC,SAAU,wBACVC,OAAQ,wBACRC,aAAc,oCACdC,SAAU"}