@alfalab/core-components-select 18.2.5 → 18.2.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/arrow/index.css +4 -4
- package/components/arrow/index.module.css.js +1 -1
- package/components/base-checkmark/index.css +5 -5
- package/components/base-checkmark/index.module.css.js +1 -1
- package/components/base-option/index.css +16 -16
- package/components/base-option/index.module.css.js +1 -1
- package/components/base-select/Component.d.ts +1 -1
- package/components/base-select/Component.js +2 -2
- package/components/base-select/Component.js.map +1 -1
- package/components/base-select/index.css +11 -11
- package/components/base-select/index.module.css.js +1 -1
- package/components/base-select/mobile.css +11 -11
- package/components/base-select/mobile.module.css.js +1 -1
- package/components/checkmark/index.css +9 -9
- package/components/checkmark/index.module.css.js +1 -1
- package/components/checkmark-mobile/index.css +5 -5
- package/components/checkmark-mobile/index.module.css.js +1 -1
- package/components/clear-button/index.css +4 -4
- package/components/clear-button/index.module.css.js +1 -1
- package/components/field/index.css +13 -13
- package/components/field/index.module.css.js +1 -1
- package/components/footer/index.css +4 -4
- package/components/footer/index.module.css.js +1 -1
- package/components/optgroup/index.css +4 -4
- package/components/optgroup/index.module.css.js +1 -1
- package/components/option/desktop/index.css +19 -19
- package/components/option/desktop/index.module.css.js +1 -1
- package/components/option/mobile/index.css +16 -16
- package/components/option/mobile/index.module.css.js +1 -1
- package/components/options-list/Component.d.ts +35 -2
- package/components/options-list/Component.js +6 -8
- package/components/options-list/Component.js.map +1 -1
- package/components/options-list/index.css +9 -9
- package/components/options-list/index.module.css.js +1 -1
- package/components/search/Component.js +15 -1
- package/components/search/Component.js.map +1 -1
- package/components/search/index.css +1 -1
- package/components/search/index.module.css.js +1 -1
- package/components/virtual-options-list/Component.d.ts +35 -2
- package/components/virtual-options-list/Component.js +6 -9
- package/components/virtual-options-list/Component.js.map +1 -1
- package/components/virtual-options-list/index.css +13 -13
- package/components/virtual-options-list/index.module.css.js +1 -1
- package/cssm/components/base-select/Component.d.ts +1 -1
- package/cssm/components/base-select/Component.js +2 -2
- package/cssm/components/base-select/Component.js.map +1 -1
- package/cssm/components/options-list/Component.d.ts +35 -2
- package/cssm/components/options-list/Component.js +8 -10
- package/cssm/components/options-list/Component.js.map +1 -1
- package/cssm/components/search/Component.js +15 -1
- package/cssm/components/search/Component.js.map +1 -1
- package/cssm/components/virtual-options-list/Component.d.ts +35 -2
- package/cssm/components/virtual-options-list/Component.js +8 -11
- package/cssm/components/virtual-options-list/Component.js.map +1 -1
- package/cssm/hooks/use-native-scrollbar.d.ts +4 -0
- package/cssm/hooks/use-native-scrollbar.js +33 -0
- package/cssm/hooks/use-native-scrollbar.js.map +1 -0
- package/cssm/presets/useSelectWithApply/hook.d.ts +137 -5
- package/cssm/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +69 -3
- package/cssm/typings.d.ts +1 -1
- package/esm/components/arrow/index.css +4 -4
- package/esm/components/arrow/index.module.css.js +1 -1
- package/esm/components/base-checkmark/index.css +5 -5
- package/esm/components/base-checkmark/index.module.css.js +1 -1
- package/esm/components/base-option/index.css +16 -16
- package/esm/components/base-option/index.module.css.js +1 -1
- package/esm/components/base-select/Component.d.ts +1 -1
- package/esm/components/base-select/Component.js +2 -2
- package/esm/components/base-select/Component.js.map +1 -1
- package/esm/components/base-select/index.css +11 -11
- package/esm/components/base-select/index.module.css.js +1 -1
- package/esm/components/base-select/mobile.css +11 -11
- package/esm/components/base-select/mobile.module.css.js +1 -1
- package/esm/components/checkmark/index.css +9 -9
- package/esm/components/checkmark/index.module.css.js +1 -1
- package/esm/components/checkmark-mobile/index.css +5 -5
- package/esm/components/checkmark-mobile/index.module.css.js +1 -1
- package/esm/components/clear-button/index.css +4 -4
- package/esm/components/clear-button/index.module.css.js +1 -1
- package/esm/components/field/index.css +13 -13
- package/esm/components/field/index.module.css.js +1 -1
- package/esm/components/footer/index.css +4 -4
- package/esm/components/footer/index.module.css.js +1 -1
- package/esm/components/optgroup/index.css +4 -4
- package/esm/components/optgroup/index.module.css.js +1 -1
- package/esm/components/option/desktop/index.css +19 -19
- package/esm/components/option/desktop/index.module.css.js +1 -1
- package/esm/components/option/mobile/index.css +16 -16
- package/esm/components/option/mobile/index.module.css.js +1 -1
- package/esm/components/options-list/Component.d.ts +35 -2
- package/esm/components/options-list/Component.js +6 -8
- package/esm/components/options-list/Component.js.map +1 -1
- package/esm/components/options-list/index.css +9 -9
- package/esm/components/options-list/index.module.css.js +1 -1
- package/esm/components/search/Component.js +15 -1
- package/esm/components/search/Component.js.map +1 -1
- package/esm/components/search/index.css +1 -1
- package/esm/components/search/index.module.css.js +1 -1
- package/esm/components/virtual-options-list/Component.d.ts +35 -2
- package/esm/components/virtual-options-list/Component.js +6 -9
- package/esm/components/virtual-options-list/Component.js.map +1 -1
- package/esm/components/virtual-options-list/index.css +13 -13
- package/esm/components/virtual-options-list/index.module.css.js +1 -1
- package/esm/hooks/use-native-scrollbar.d.ts +4 -0
- package/esm/hooks/use-native-scrollbar.js +29 -0
- package/esm/hooks/use-native-scrollbar.js.map +1 -0
- package/esm/presets/useSelectWithApply/hook.d.ts +137 -5
- package/esm/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +69 -3
- package/esm/presets/useSelectWithApply/options-list-with-apply/footer/index.css +3 -3
- package/esm/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js +1 -1
- package/esm/presets/useSelectWithApply/options-list-with-apply/header/index.css +3 -3
- package/esm/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js +1 -1
- package/esm/presets/useSelectWithLoading/index.css +1 -1
- package/esm/presets/useSelectWithLoading/index.module.css.js +1 -1
- package/esm/typings.d.ts +1 -1
- package/hooks/use-native-scrollbar.d.ts +4 -0
- package/hooks/use-native-scrollbar.js +33 -0
- package/hooks/use-native-scrollbar.js.map +1 -0
- package/modern/components/arrow/index.css +4 -4
- package/modern/components/arrow/index.module.css.js +1 -1
- package/modern/components/base-checkmark/index.css +5 -5
- package/modern/components/base-checkmark/index.module.css.js +1 -1
- package/modern/components/base-option/index.css +16 -16
- package/modern/components/base-option/index.module.css.js +1 -1
- package/modern/components/base-select/Component.d.ts +1 -1
- package/modern/components/base-select/Component.js +2 -2
- package/modern/components/base-select/Component.js.map +1 -1
- package/modern/components/base-select/index.css +11 -11
- package/modern/components/base-select/index.module.css.js +1 -1
- package/modern/components/base-select/mobile.css +11 -11
- package/modern/components/base-select/mobile.module.css.js +1 -1
- package/modern/components/checkmark/index.css +9 -9
- package/modern/components/checkmark/index.module.css.js +1 -1
- package/modern/components/checkmark-mobile/index.css +5 -5
- package/modern/components/checkmark-mobile/index.module.css.js +1 -1
- package/modern/components/clear-button/index.css +4 -4
- package/modern/components/clear-button/index.module.css.js +1 -1
- package/modern/components/field/index.css +13 -13
- package/modern/components/field/index.module.css.js +1 -1
- package/modern/components/footer/index.css +4 -4
- package/modern/components/footer/index.module.css.js +1 -1
- package/modern/components/optgroup/index.css +4 -4
- package/modern/components/optgroup/index.module.css.js +1 -1
- package/modern/components/option/desktop/index.css +19 -19
- package/modern/components/option/desktop/index.module.css.js +1 -1
- package/modern/components/option/mobile/index.css +16 -16
- package/modern/components/option/mobile/index.module.css.js +1 -1
- package/modern/components/options-list/Component.d.ts +35 -2
- package/modern/components/options-list/Component.js +6 -6
- package/modern/components/options-list/Component.js.map +1 -1
- package/modern/components/options-list/index.css +9 -9
- package/modern/components/options-list/index.module.css.js +1 -1
- package/modern/components/search/Component.js +17 -1
- package/modern/components/search/Component.js.map +1 -1
- package/modern/components/search/index.css +1 -1
- package/modern/components/search/index.module.css.js +1 -1
- package/modern/components/virtual-options-list/Component.d.ts +35 -2
- package/modern/components/virtual-options-list/Component.js +6 -7
- package/modern/components/virtual-options-list/Component.js.map +1 -1
- package/modern/components/virtual-options-list/index.css +13 -13
- package/modern/components/virtual-options-list/index.module.css.js +1 -1
- package/modern/hooks/use-native-scrollbar.d.ts +4 -0
- package/modern/hooks/use-native-scrollbar.js +27 -0
- package/modern/hooks/use-native-scrollbar.js.map +1 -0
- package/modern/presets/useSelectWithApply/hook.d.ts +137 -5
- package/modern/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +69 -3
- package/modern/presets/useSelectWithApply/options-list-with-apply/footer/index.css +3 -3
- package/modern/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js +1 -1
- package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.css +3 -3
- package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js +1 -1
- package/modern/presets/useSelectWithLoading/index.css +1 -1
- package/modern/presets/useSelectWithLoading/index.module.css.js +1 -1
- package/modern/typings.d.ts +1 -1
- package/moderncssm/components/base-select/Component.d.ts +1 -1
- package/moderncssm/components/base-select/Component.js +2 -2
- package/moderncssm/components/base-select/Component.js.map +1 -1
- package/moderncssm/components/options-list/Component.d.ts +35 -2
- package/moderncssm/components/options-list/Component.js +6 -6
- package/moderncssm/components/options-list/Component.js.map +1 -1
- package/moderncssm/components/search/Component.js +17 -1
- package/moderncssm/components/search/Component.js.map +1 -1
- package/moderncssm/components/virtual-options-list/Component.d.ts +35 -2
- package/moderncssm/components/virtual-options-list/Component.js +6 -7
- package/moderncssm/components/virtual-options-list/Component.js.map +1 -1
- package/moderncssm/hooks/use-native-scrollbar.d.ts +4 -0
- package/moderncssm/hooks/use-native-scrollbar.js +27 -0
- package/moderncssm/hooks/use-native-scrollbar.js.map +1 -0
- package/moderncssm/presets/useSelectWithApply/hook.d.ts +137 -5
- package/moderncssm/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +69 -3
- package/moderncssm/typings.d.ts +1 -1
- package/package.json +4 -4
- package/presets/useSelectWithApply/hook.d.ts +137 -5
- package/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +69 -3
- package/presets/useSelectWithApply/options-list-with-apply/footer/index.css +3 -3
- package/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js +1 -1
- package/presets/useSelectWithApply/options-list-with-apply/header/index.css +3 -3
- package/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js +1 -1
- package/presets/useSelectWithLoading/index.css +1 -1
- package/presets/useSelectWithLoading/index.module.css.js +1 -1
- package/src/components/base-select/Component.tsx +2 -0
- package/src/components/options-list/Component.tsx +6 -8
- package/src/components/search/Component.tsx +29 -10
- package/src/components/virtual-options-list/Component.tsx +6 -9
- package/src/hooks/use-native-scrollbar.ts +36 -0
- package/src/typings.ts +1 -1
- package/typings.d.ts +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Component.js","sources":["../../../src/components/virtual-options-list/Component.tsx"],"sourcesContent":["import React, { forwardRef, useEffect, useMemo, useRef, useState } from 'react';\nimport mergeRefs from 'react-merge-refs';\nimport { useVirtual } from 'react-virtual';\nimport cn from 'classnames';\n\nimport { useMatchMedia } from '@alfalab/core-components-mq';\nimport { Scrollbar } from '@alfalab/core-components-scrollbar';\nimport { isClient } from '@alfalab/core-components-shared';\n\nimport { DEFAULT_VISIBLE_OPTIONS, SIZE_TO_CLASSNAME_MAP } from '../../consts';\nimport { type GroupShape, type OptionShape, type OptionsListProps } from '../../typings';\nimport { isGroup, lastIndexOf, usePrevious, useVirtualVisibleOptions } from '../../utils';\nimport { Optgroup as DefaultOptgroup } from '../optgroup';\n\nimport styles from './index.module.css';\n\nexport const VirtualOptionsList = forwardRef<HTMLDivElement, OptionsListProps>(\n (\n {\n size = 48,\n flatOptions = [],\n highlightedIndex = -1,\n optionGroupClassName,\n className,\n getOptionProps,\n groupOptionProps = {},\n Option,\n open,\n options = [],\n Optgroup = DefaultOptgroup,\n dataTestId,\n emptyPlaceholder,\n visibleOptions = DEFAULT_VISIBLE_OPTIONS,\n header,\n footer,\n showFooter = true,\n optionsListWidth,\n onScroll,\n nativeScrollbar: nativeScrollbarProp,\n setHighlightedIndex,\n selectedItems,\n setSelectedItems,\n search,\n multiple,\n scrollbarClassName,\n },\n ref,\n ) => {\n const listRef = useRef<HTMLDivElement>(null);\n const parentRef = useRef<HTMLDivElement>(null);\n const scrollbarRef = useRef<HTMLDivElement>(null);\n const [visibleOptionsInvalidateKey, setVisibleOptionsInvalidateKey] = useState('');\n const prevHighlightedIndex = usePrevious(highlightedIndex) || -1;\n\n const query = '(max-width: 1023px)';\n let [nativeScrollbar] = useMatchMedia(query, () =>\n isClient() ? window.matchMedia(query).matches : true,\n );\n\n const rowVirtualizer = useVirtual({\n size: flatOptions.length,\n parentRef: (ref || parentRef) as React.RefObject<HTMLDivElement>,\n overscan: 15,\n });\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n nativeScrollbar = Boolean(nativeScrollbarProp ?? nativeScrollbar);\n\n // Сколл к выбранному пункту при открытии меню\n useEffect(() => {\n if (open) {\n rowVirtualizer.scrollToIndex(highlightedIndex, { align: 'end' });\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [open]);\n\n // Скролл к пункту, которого нет на экране\n useEffect(() => {\n if (highlightedIndex === -1) return;\n\n if (!rowVirtualizer.virtualItems.some((option) => option.index === highlightedIndex)) {\n rowVirtualizer.scrollToIndex(highlightedIndex, { align: 'end' });\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [highlightedIndex]);\n\n // Циклическая навигация\n useEffect(() => {\n const notDisabled = (option: OptionShape) => !option.disabled;\n const firstNonDisabled = flatOptions.findIndex(notDisabled);\n const lastNonDisabled = lastIndexOf(flatOptions, notDisabled);\n\n if (\n prevHighlightedIndex <= firstNonDisabled &&\n highlightedIndex === flatOptions.length - 1\n ) {\n rowVirtualizer.scrollToIndex(lastNonDisabled);\n }\n\n if (prevHighlightedIndex >= lastNonDisabled && highlightedIndex === 0) {\n rowVirtualizer.scrollToIndex(0);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [prevHighlightedIndex, highlightedIndex]);\n\n useEffect(() => {\n setVisibleOptionsInvalidateKey(\n /**\n * react-virtual может несколько раз отрендерить список с одним элементом,\n * поэтому нужно еще раз пересчитать высоту, когда список ВИДИМЫХ пунктов будет отрендерен полностью\n * Также, высоту нужно пересчитывать при изменении пунктов меню\n */\n rowVirtualizer.virtualItems\n .slice(0, Math.min(rowVirtualizer.virtualItems.length, visibleOptions + 1))\n .map((item) => flatOptions[item.index].key)\n .join('_'),\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [rowVirtualizer.virtualItems.length, flatOptions]);\n\n useVirtualVisibleOptions({\n visibleOptions,\n invalidate: visibleOptionsInvalidateKey,\n listRef,\n styleTargetRef: nativeScrollbar ? parentRef : scrollbarRef,\n open,\n });\n\n // Т.к. рендерится плоский список, необходимо знать индекс, когда начинается новая группа\n const groupStartIndexes = useMemo(() => {\n let currentIndex = 0;\n\n return options.reduce((acc: { [key: number]: number }, option, index) => {\n if (isGroup(option)) {\n acc[currentIndex] = index;\n currentIndex += option.options.length;\n } else {\n currentIndex += 1;\n }\n\n return acc;\n }, {});\n }, [options]);\n\n const renderList = () =>\n rowVirtualizer.virtualItems.map((virtualRow) => {\n const option = flatOptions[virtualRow.index];\n const renderGroup = () => {\n const group = options[groupStartIndexes[virtualRow.index]] as GroupShape;\n\n if (!group) return null;\n\n const groupSelectedItems = selectedItems?.filter(({ key: selectedItemKey }) =>\n group.options.some((opt) => opt.key === selectedItemKey),\n );\n const handleSelectedItems = (items: OptionShape[]) => {\n setSelectedItems(\n (\n selectedItems?.filter(\n ({ key: selectedItemKey }) =>\n !group.options.some((opt) => opt.key === selectedItemKey),\n ) ?? []\n ).concat(items),\n );\n };\n\n return (\n <Optgroup\n label={group.label}\n size={size}\n className={optionGroupClassName}\n options={group.options}\n selectedItems={groupSelectedItems}\n setSelectedItems={handleSelectedItems}\n search={search}\n multiple={multiple}\n {...groupOptionProps}\n />\n );\n };\n\n return (\n <div\n key={virtualRow.index}\n ref={virtualRow.measureRef}\n className={cn(styles.virtualRow, {\n [styles.highlighted]: highlightedIndex === virtualRow.index,\n })}\n style={{\n transform: `translateY(${virtualRow.start}px)`,\n }}\n >\n {renderGroup()}\n {!isGroup(option) && (\n <Option {...getOptionProps(option, virtualRow.index)} />\n )}\n </div>\n );\n });\n\n const contentNodeProps = {\n className: styles.inner,\n style: { height: `${rowVirtualizer.totalSize}px` },\n ref: listRef,\n };\n\n const renderWithCustomScrollbar = () => (\n <Scrollbar\n className={cn(styles.scrollable, scrollbarClassName)}\n ref={scrollbarRef}\n horizontalAutoStretch={optionsListWidth === 'content'}\n scrollableNodeProps={{ onScroll, ref: parentRef }}\n contentNodeProps={contentNodeProps}\n >\n {renderList()}\n </Scrollbar>\n );\n\n const renderWithNativeScrollbar = () => {\n if (visibleOptions) {\n return (\n <div\n className={cn(styles.scrollable, scrollbarClassName)}\n ref={mergeRefs([parentRef, ref])}\n onScroll={onScroll}\n >\n <div {...contentNodeProps}>{renderList()}</div>\n </div>\n );\n }\n\n return <div {...contentNodeProps}>{renderList()}</div>;\n };\n\n const resetHighlightedIndex = () => setHighlightedIndex?.(-1);\n\n if (options.length === 0 && !emptyPlaceholder) {\n return null;\n }\n\n return (\n <div\n className={cn(\n styles.virtualOptionsList,\n styles[SIZE_TO_CLASSNAME_MAP[size]],\n className,\n )}\n data-test-id={dataTestId}\n >\n {header && (\n <div\n className={styles.virtualOptionsListHeader}\n onMouseEnter={resetHighlightedIndex}\n >\n {header}\n </div>\n )}\n\n {nativeScrollbar ? renderWithNativeScrollbar() : renderWithCustomScrollbar()}\n\n {emptyPlaceholder && options.length === 0 && (\n <div className={styles.emptyPlaceholder}>{emptyPlaceholder}</div>\n )}\n\n {showFooter && footer && (\n <div\n onMouseEnter={resetHighlightedIndex}\n className={cn(styles.virtualOptionsListFooter, {\n [styles.withBorder]:\n visibleOptions && flatOptions.length > visibleOptions,\n })}\n >\n {footer}\n </div>\n )}\n </div>\n );\n },\n);\n"],"names":["Optgroup","DefaultOptgroup"],"mappings":";;;;;;;;;;;;;IAgBa,kBAAkB,GAAG,UAAU,CACxC,UACI,EA2BC,EACD,GAAG,EAAA;;QA3BC,EAAS,GAAA,EAAA,CAAA,IAAA,EAAT,IAAI,GAAA,EAAA,KAAA,MAAA,GAAG,EAAE,GAAA,EAAA,EACT,EAAgB,GAAA,EAAA,CAAA,WAAA,EAAhB,WAAW,GAAA,EAAA,KAAA,MAAA,GAAG,EAAE,GAAA,EAAA,EAChB,EAAqB,GAAA,EAAA,CAAA,gBAAA,EAArB,gBAAgB,GAAA,EAAA,KAAA,MAAA,GAAG,EAAE,KAAA,EACrB,oBAAoB,GAAA,EAAA,CAAA,oBAAA,EACpB,SAAS,GAAA,EAAA,CAAA,SAAA,EACT,cAAc,GAAA,EAAA,CAAA,cAAA,EACd,EAAA,GAAA,EAAA,CAAA,gBAAqB,EAArB,gBAAgB,mBAAG,EAAE,GAAA,EAAA,EACrB,MAAM,GAAA,EAAA,CAAA,MAAA,EACN,IAAI,GAAA,EAAA,CAAA,IAAA,EACJ,EAAY,GAAA,EAAA,CAAA,OAAA,EAAZ,OAAO,GAAA,EAAA,KAAA,MAAA,GAAG,EAAE,GAAA,EAAA,EACZ,EAA0B,GAAA,EAAA,CAAA,QAAA,EAA1BA,UAAQ,GAAA,EAAA,KAAA,MAAA,GAAGC,QAAe,GAAA,EAAA,EAC1B,UAAU,GAAA,EAAA,CAAA,UAAA,EACV,gBAAgB,sBAAA,EAChB,EAAA,GAAA,EAAA,CAAA,cAAwC,EAAxC,cAAc,GAAG,EAAA,KAAA,MAAA,GAAA,uBAAuB,KAAA,EACxC,MAAM,GAAA,EAAA,CAAA,MAAA,EACN,MAAM,GAAA,EAAA,CAAA,MAAA,EACN,EAAiB,GAAA,EAAA,CAAA,UAAA,EAAjB,UAAU,GAAA,EAAA,KAAA,MAAA,GAAG,IAAI,GAAA,EAAA,EACjB,gBAAgB,GAAA,EAAA,CAAA,gBAAA,EAChB,QAAQ,GAAA,EAAA,CAAA,QAAA,EACS,mBAAmB,GAAA,EAAA,CAAA,eAAA,EACpC,mBAAmB,GAAA,EAAA,CAAA,mBAAA,EACnB,aAAa,mBAAA,EACb,gBAAgB,GAAA,EAAA,CAAA,gBAAA,EAChB,MAAM,GAAA,EAAA,CAAA,MAAA,EACN,QAAQ,GAAA,EAAA,CAAA,QAAA,EACR,kBAAkB,GAAA,EAAA,CAAA,kBAAA;AAItB,IAAA,IAAM,OAAO,GAAG,MAAM,CAAiB,IAAI,CAAC;AAC5C,IAAA,IAAM,SAAS,GAAG,MAAM,CAAiB,IAAI,CAAC;AAC9C,IAAA,IAAM,YAAY,GAAG,MAAM,CAAiB,IAAI,CAAC;IAC3C,IAAA,EAAA,GAAgE,QAAQ,CAAC,EAAE,CAAC,EAA3E,2BAA2B,GAAA,EAAA,CAAA,CAAA,CAAA,EAAE,8BAA8B,GAAA,EAAA,CAAA,CAAA,CAAgB;IAClF,IAAM,oBAAoB,GAAG,WAAW,CAAC,gBAAgB,CAAC,IAAI,EAAE;IAEhE,IAAM,KAAK,GAAG,qBAAqB;AAC9B,IAAA,IAAA,eAAe,GAAI,aAAa,CAAC,KAAK,EAAE,YAAA;AACzC,QAAA,OAAA,QAAQ,EAAE,GAAG,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,OAAO,GAAG,IAAI;KAAA,CACvD,GAFmB;IAIpB,IAAM,cAAc,GAAG,UAAU,CAAC;QAC9B,IAAI,EAAE,WAAW,CAAC,MAAM;AACxB,QAAA,SAAS,GAAG,GAAG,IAAI,SAAS,CAAoC;AAChE,QAAA,QAAQ,EAAE,EAAE;AACf,KAAA,CAAC;;IAGF,eAAe,GAAG,OAAO,CAAC,mBAAmB,KAAA,IAAA,IAAnB,mBAAmB,KAAA,MAAA,GAAnB,mBAAmB,GAAI,eAAe,CAAC;;AAGjE,IAAA,SAAS,CAAC,YAAA;AACN,QAAA,IAAI,IAAI,EAAE;YACN,cAAc,CAAC,aAAa,CAAC,gBAAgB,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;AACnE;;AAEL,KAAC,EAAE,CAAC,IAAI,CAAC,CAAC;;AAGV,IAAA,SAAS,CAAC,YAAA;QACN,IAAI,gBAAgB,KAAK,EAAE;YAAE;AAE7B,QAAA,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,IAAI,CAAC,UAAC,MAAM,IAAK,OAAA,MAAM,CAAC,KAAK,KAAK,gBAAgB,CAAjC,EAAiC,CAAC,EAAE;YAClF,cAAc,CAAC,aAAa,CAAC,gBAAgB,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;AACnE;;AAEL,KAAC,EAAE,CAAC,gBAAgB,CAAC,CAAC;;AAGtB,IAAA,SAAS,CAAC,YAAA;AACN,QAAA,IAAM,WAAW,GAAG,UAAC,MAAmB,EAAK,EAAA,OAAA,CAAC,MAAM,CAAC,QAAQ,CAAhB,EAAgB;QAC7D,IAAM,gBAAgB,GAAG,WAAW,CAAC,SAAS,CAAC,WAAW,CAAC;QAC3D,IAAM,eAAe,GAAG,WAAW,CAAC,WAAW,EAAE,WAAW,CAAC;QAE7D,IACI,oBAAoB,IAAI,gBAAgB;AACxC,YAAA,gBAAgB,KAAK,WAAW,CAAC,MAAM,GAAG,CAAC,EAC7C;AACE,YAAA,cAAc,CAAC,aAAa,CAAC,eAAe,CAAC;AAChD;AAED,QAAA,IAAI,oBAAoB,IAAI,eAAe,IAAI,gBAAgB,KAAK,CAAC,EAAE;AACnE,YAAA,cAAc,CAAC,aAAa,CAAC,CAAC,CAAC;AAClC;;AAEL,KAAC,EAAE,CAAC,oBAAoB,EAAE,gBAAgB,CAAC,CAAC;AAE5C,IAAA,SAAS,CAAC,YAAA;QACN,8BAA8B;AAC1B;;;;AAIG;AACH,QAAA,cAAc,CAAC;AACV,aAAA,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,cAAc,CAAC,YAAY,CAAC,MAAM,EAAE,cAAc,GAAG,CAAC,CAAC;AACzE,aAAA,GAAG,CAAC,UAAC,IAAI,EAAA,EAAK,OAAA,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,CAAA,EAAA;AACzC,aAAA,IAAI,CAAC,GAAG,CAAC,CACjB;;KAEJ,EAAE,CAAC,cAAc,CAAC,YAAY,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;AAErD,IAAA,wBAAwB,CAAC;AACrB,QAAA,cAAc,EAAA,cAAA;AACd,QAAA,UAAU,EAAE,2BAA2B;AACvC,QAAA,OAAO,EAAA,OAAA;QACP,cAAc,EAAE,eAAe,GAAG,SAAS,GAAG,YAAY;AAC1D,QAAA,IAAI,EAAA,IAAA;AACP,KAAA,CAAC;;IAGF,IAAM,iBAAiB,GAAG,OAAO,CAAC,YAAA;QAC9B,IAAI,YAAY,GAAG,CAAC;QAEpB,OAAO,OAAO,CAAC,MAAM,CAAC,UAAC,GAA8B,EAAE,MAAM,EAAE,KAAK,EAAA;AAChE,YAAA,IAAI,OAAO,CAAC,MAAM,CAAC,EAAE;AACjB,gBAAA,GAAG,CAAC,YAAY,CAAC,GAAG,KAAK;AACzB,gBAAA,YAAY,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM;AACxC;AAAM,iBAAA;gBACH,YAAY,IAAI,CAAC;AACpB;AAED,YAAA,OAAO,GAAG;SACb,EAAE,EAAE,CAAC;AACV,KAAC,EAAE,CAAC,OAAO,CAAC,CAAC;AAEb,IAAA,IAAM,UAAU,GAAG,YAAA;AACf,QAAA,OAAA,cAAc,CAAC,YAAY,CAAC,GAAG,CAAC,UAAC,UAAU,EAAA;;YACvC,IAAM,MAAM,GAAG,WAAW,CAAC,UAAU,CAAC,KAAK,CAAC;AAC5C,YAAA,IAAM,WAAW,GAAG,YAAA;gBAChB,IAAM,KAAK,GAAG,OAAO,CAAC,iBAAiB,CAAC,UAAU,CAAC,KAAK,CAAC,CAAe;AAExE,gBAAA,IAAI,CAAC,KAAK;AAAE,oBAAA,OAAO,IAAI;gBAEvB,IAAM,kBAAkB,GAAG,aAAa,KAAb,IAAA,IAAA,aAAa,KAAb,MAAA,GAAA,MAAA,GAAA,aAAa,CAAE,MAAM,CAAC,UAAC,EAAwB,EAAA;AAAjB,oBAAA,IAAA,eAAe,GAAA,EAAA,CAAA,GAAA;AACpE,oBAAA,OAAA,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,UAAC,GAAG,EAAK,EAAA,OAAA,GAAG,CAAC,GAAG,KAAK,eAAe,CAAA,EAAA,CAAC;AAAxD,iBAAwD,CAC3D;gBACD,IAAM,mBAAmB,GAAG,UAAC,KAAoB,EAAA;;AAC7C,oBAAA,gBAAgB,CACZ,CACI,CAAA,EAAA,GAAA,aAAa,KAAb,IAAA,IAAA,aAAa,KAAb,MAAA,GAAA,MAAA,GAAA,aAAa,CAAE,MAAM,CACjB,UAAC,EAAwB,EAAA;AAAjB,wBAAA,IAAA,eAAe,GAAA,EAAA,CAAA,GAAA;AACnB,wBAAA,OAAA,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,UAAC,GAAG,EAAK,EAAA,OAAA,GAAG,CAAC,GAAG,KAAK,eAAe,CAAA,EAAA,CAAC;qBAAA,CAChE,MAAI,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAA,EAAE,EACT,MAAM,CAAC,KAAK,CAAC,CAClB;AACL,iBAAC;AAED,gBAAA,QACI,KAAC,CAAA,aAAA,CAAAD,UAAQ,aACL,KAAK,EAAE,KAAK,CAAC,KAAK,EAClB,IAAI,EAAE,IAAI,EACV,SAAS,EAAE,oBAAoB,EAC/B,OAAO,EAAE,KAAK,CAAC,OAAO,EACtB,aAAa,EAAE,kBAAkB,EACjC,gBAAgB,EAAE,mBAAmB,EACrC,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,QAAQ,IACd,gBAAgB,CAAA,CACtB;AAEV,aAAC;YAED,QACI,6BACI,GAAG,EAAE,UAAU,CAAC,KAAK,EACrB,GAAG,EAAE,UAAU,CAAC,UAAU,EAC1B,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,UAAU,GAAA,EAAA,GAAA,EAAA;oBAC3B,EAAC,CAAA,MAAM,CAAC,WAAW,CAAA,GAAG,gBAAgB,KAAK,UAAU,CAAC,KAAK;AAC7D,oBAAA,EAAA,EAAA,EACF,KAAK,EAAE;AACH,oBAAA,SAAS,EAAE,aAAA,CAAA,MAAA,CAAc,UAAU,CAAC,KAAK,EAAK,KAAA,CAAA;AACjD,iBAAA,EAAA;AAEA,gBAAA,WAAW,EAAE;gBACb,CAAC,OAAO,CAAC,MAAM,CAAC,KACb,KAAA,CAAA,aAAA,CAAC,MAAM,EAAK,QAAA,CAAA,EAAA,EAAA,cAAc,CAAC,MAAM,EAAE,UAAU,CAAC,KAAK,CAAC,CAAI,CAAA,CAC3D,CACC;AAEd,SAAC,CAAC;AArDF,KAqDE;AAEN,IAAA,IAAM,gBAAgB,GAAG;QACrB,SAAS,EAAE,MAAM,CAAC,KAAK;QACvB,KAAK,EAAE,EAAE,MAAM,EAAE,UAAG,cAAc,CAAC,SAAS,EAAA,IAAA,CAAI,EAAE;AAClD,QAAA,GAAG,EAAE,OAAO;KACf;IAED,IAAM,yBAAyB,GAAG,YAAM,EAAA,QACpC,KAAC,CAAA,aAAA,CAAA,SAAS,EACN,EAAA,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,UAAU,EAAE,kBAAkB,CAAC,EACpD,GAAG,EAAE,YAAY,EACjB,qBAAqB,EAAE,gBAAgB,KAAK,SAAS,EACrD,mBAAmB,EAAE,EAAE,QAAQ,EAAA,QAAA,EAAE,GAAG,EAAE,SAAS,EAAE,EACjD,gBAAgB,EAAE,gBAAgB,EAEjC,EAAA,UAAU,EAAE,CACL,EATwB,EAUvC;AAED,IAAA,IAAM,yBAAyB,GAAG,YAAA;AAC9B,QAAA,IAAI,cAAc,EAAE;YAChB,QACI,KACI,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,UAAU,EAAE,kBAAkB,CAAC,EACpD,GAAG,EAAE,SAAS,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,EAChC,QAAQ,EAAE,QAAQ,EAAA;AAElB,gBAAA,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,QAAA,CAAA,EAAA,EAAS,gBAAgB,CAAG,EAAA,UAAU,EAAE,CAAO,CAC7C;AAEb;AAED,QAAA,OAAO,wCAAS,gBAAgB,CAAA,EAAG,UAAU,EAAE,CAAO;AAC1D,KAAC;AAED,IAAA,IAAM,qBAAqB,GAAG,YAAM,EAAA,OAAA,mBAAmB,KAAnB,IAAA,IAAA,mBAAmB,KAAnB,MAAA,GAAA,MAAA,GAAA,mBAAmB,CAAG,EAAE,CAAC,CAAA,EAAA;IAE7D,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,IAAI,CAAC,gBAAgB,EAAE;AAC3C,QAAA,OAAO,IAAI;AACd;IAED,QACI,6BACI,SAAS,EAAE,EAAE,CACT,MAAM,CAAC,kBAAkB,EACzB,MAAM,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC,EACnC,SAAS,CACZ,EAAA,cAAA,EACa,UAAU,EAAA;AAEvB,QAAA,MAAM,KACH,KACI,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,SAAS,EAAE,MAAM,CAAC,wBAAwB,EAC1C,YAAY,EAAE,qBAAqB,EAElC,EAAA,MAAM,CACL,CACT;QAEA,eAAe,GAAG,yBAAyB,EAAE,GAAG,yBAAyB,EAAE;AAE3E,QAAA,gBAAgB,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,KACrC,KAAK,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,SAAS,EAAE,MAAM,CAAC,gBAAgB,EAAG,EAAA,gBAAgB,CAAO,CACpE;AAEA,QAAA,UAAU,IAAI,MAAM,KACjB,6BACI,YAAY,EAAE,qBAAqB,EACnC,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,wBAAwB,GAAA,EAAA,GAAA,EAAA;gBACzC,EAAC,CAAA,MAAM,CAAC,UAAU,CACd,GAAA,cAAc,IAAI,WAAW,CAAC,MAAM,GAAG,cAAc;AAC3D,gBAAA,EAAA,EAAA,EAAA,EAED,MAAM,CACL,CACT,CACC;AAEd,CAAC;;;;"}
|
|
1
|
+
{"version":3,"file":"Component.js","sources":["../../../src/components/virtual-options-list/Component.tsx"],"sourcesContent":["import React, { forwardRef, useEffect, useMemo, useRef, useState } from 'react';\nimport mergeRefs from 'react-merge-refs';\nimport { useVirtual } from 'react-virtual';\nimport cn from 'classnames';\n\nimport { Scrollbar } from '@alfalab/core-components-scrollbar';\n\nimport { DEFAULT_VISIBLE_OPTIONS, SIZE_TO_CLASSNAME_MAP } from '../../consts';\nimport { useNativeScrollbar } from '../../hooks/use-native-scrollbar';\nimport { type GroupShape, type OptionShape, type OptionsListProps } from '../../typings';\nimport { isGroup, lastIndexOf, usePrevious, useVirtualVisibleOptions } from '../../utils';\nimport { Optgroup as DefaultOptgroup } from '../optgroup';\n\nimport styles from './index.module.css';\n\nexport const VirtualOptionsList = forwardRef<HTMLDivElement, OptionsListProps>(\n (\n {\n size = 48,\n flatOptions = [],\n highlightedIndex = -1,\n optionGroupClassName,\n className,\n getOptionProps,\n groupOptionProps = {},\n Option,\n open,\n options = [],\n Optgroup = DefaultOptgroup,\n dataTestId,\n emptyPlaceholder,\n visibleOptions = DEFAULT_VISIBLE_OPTIONS,\n header,\n footer,\n showFooter = true,\n optionsListWidth,\n onScroll,\n nativeScrollbar: nativeScrollbarProp,\n setHighlightedIndex,\n selectedItems,\n setSelectedItems,\n search,\n multiple,\n scrollbarClassName,\n client,\n },\n ref,\n ) => {\n const listRef = useRef<HTMLDivElement>(null);\n const parentRef = useRef<HTMLDivElement>(null);\n const scrollbarRef = useRef<HTMLDivElement>(null);\n const [visibleOptionsInvalidateKey, setVisibleOptionsInvalidateKey] = useState('');\n const prevHighlightedIndex = usePrevious(highlightedIndex) || -1;\n\n const rowVirtualizer = useVirtual({\n size: flatOptions.length,\n parentRef: (ref || parentRef) as React.RefObject<HTMLDivElement>,\n overscan: 15,\n });\n\n const nativeScrollbar = useNativeScrollbar({\n nativeScrollbar: nativeScrollbarProp,\n client,\n });\n\n // Сколл к выбранному пункту при открытии меню\n useEffect(() => {\n if (open) {\n rowVirtualizer.scrollToIndex(highlightedIndex, { align: 'end' });\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [open]);\n\n // Скролл к пункту, которого нет на экране\n useEffect(() => {\n if (highlightedIndex === -1) return;\n\n if (!rowVirtualizer.virtualItems.some((option) => option.index === highlightedIndex)) {\n rowVirtualizer.scrollToIndex(highlightedIndex, { align: 'end' });\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [highlightedIndex]);\n\n // Циклическая навигация\n useEffect(() => {\n const notDisabled = (option: OptionShape) => !option.disabled;\n const firstNonDisabled = flatOptions.findIndex(notDisabled);\n const lastNonDisabled = lastIndexOf(flatOptions, notDisabled);\n\n if (\n prevHighlightedIndex <= firstNonDisabled &&\n highlightedIndex === flatOptions.length - 1\n ) {\n rowVirtualizer.scrollToIndex(lastNonDisabled);\n }\n\n if (prevHighlightedIndex >= lastNonDisabled && highlightedIndex === 0) {\n rowVirtualizer.scrollToIndex(0);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [prevHighlightedIndex, highlightedIndex]);\n\n useEffect(() => {\n setVisibleOptionsInvalidateKey(\n /**\n * react-virtual может несколько раз отрендерить список с одним элементом,\n * поэтому нужно еще раз пересчитать высоту, когда список ВИДИМЫХ пунктов будет отрендерен полностью\n * Также, высоту нужно пересчитывать при изменении пунктов меню\n */\n rowVirtualizer.virtualItems\n .slice(0, Math.min(rowVirtualizer.virtualItems.length, visibleOptions + 1))\n .map((item) => flatOptions[item.index].key)\n .join('_'),\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [rowVirtualizer.virtualItems.length, flatOptions]);\n\n useVirtualVisibleOptions({\n visibleOptions,\n invalidate: visibleOptionsInvalidateKey,\n listRef,\n styleTargetRef: nativeScrollbar ? parentRef : scrollbarRef,\n open,\n });\n\n // Т.к. рендерится плоский список, необходимо знать индекс, когда начинается новая группа\n const groupStartIndexes = useMemo(() => {\n let currentIndex = 0;\n\n return options.reduce((acc: { [key: number]: number }, option, index) => {\n if (isGroup(option)) {\n acc[currentIndex] = index;\n currentIndex += option.options.length;\n } else {\n currentIndex += 1;\n }\n\n return acc;\n }, {});\n }, [options]);\n\n const renderList = () =>\n rowVirtualizer.virtualItems.map((virtualRow) => {\n const option = flatOptions[virtualRow.index];\n const renderGroup = () => {\n const group = options[groupStartIndexes[virtualRow.index]] as GroupShape;\n\n if (!group) return null;\n\n const groupSelectedItems = selectedItems?.filter(({ key: selectedItemKey }) =>\n group.options.some((opt) => opt.key === selectedItemKey),\n );\n const handleSelectedItems = (items: OptionShape[]) => {\n setSelectedItems(\n (\n selectedItems?.filter(\n ({ key: selectedItemKey }) =>\n !group.options.some((opt) => opt.key === selectedItemKey),\n ) ?? []\n ).concat(items),\n );\n };\n\n return (\n <Optgroup\n label={group.label}\n size={size}\n className={optionGroupClassName}\n options={group.options}\n selectedItems={groupSelectedItems}\n setSelectedItems={handleSelectedItems}\n search={search}\n multiple={multiple}\n {...groupOptionProps}\n />\n );\n };\n\n return (\n <div\n key={virtualRow.index}\n ref={virtualRow.measureRef}\n className={cn(styles.virtualRow, {\n [styles.highlighted]: highlightedIndex === virtualRow.index,\n })}\n style={{\n transform: `translateY(${virtualRow.start}px)`,\n }}\n >\n {renderGroup()}\n {!isGroup(option) && (\n <Option {...getOptionProps(option, virtualRow.index)} />\n )}\n </div>\n );\n });\n\n const contentNodeProps = {\n className: styles.inner,\n style: { height: `${rowVirtualizer.totalSize}px` },\n ref: listRef,\n };\n\n const renderWithCustomScrollbar = () => (\n <Scrollbar\n className={cn(styles.scrollable, scrollbarClassName)}\n ref={scrollbarRef}\n horizontalAutoStretch={optionsListWidth === 'content'}\n scrollableNodeProps={{ onScroll, ref: parentRef }}\n contentNodeProps={contentNodeProps}\n >\n {renderList()}\n </Scrollbar>\n );\n\n const renderWithNativeScrollbar = () => {\n if (visibleOptions) {\n return (\n <div\n className={cn(styles.scrollable, scrollbarClassName)}\n ref={mergeRefs([parentRef, ref])}\n onScroll={onScroll}\n >\n <div {...contentNodeProps}>{renderList()}</div>\n </div>\n );\n }\n\n return <div {...contentNodeProps}>{renderList()}</div>;\n };\n\n const resetHighlightedIndex = () => setHighlightedIndex?.(-1);\n\n if (options.length === 0 && !emptyPlaceholder) {\n return null;\n }\n\n return (\n <div\n className={cn(\n styles.virtualOptionsList,\n styles[SIZE_TO_CLASSNAME_MAP[size]],\n className,\n )}\n data-test-id={dataTestId}\n >\n {header && (\n <div\n className={styles.virtualOptionsListHeader}\n onMouseEnter={resetHighlightedIndex}\n >\n {header}\n </div>\n )}\n\n {nativeScrollbar ? renderWithNativeScrollbar() : renderWithCustomScrollbar()}\n\n {emptyPlaceholder && options.length === 0 && (\n <div className={styles.emptyPlaceholder}>{emptyPlaceholder}</div>\n )}\n\n {showFooter && footer && (\n <div\n onMouseEnter={resetHighlightedIndex}\n className={cn(styles.virtualOptionsListFooter, {\n [styles.withBorder]:\n visibleOptions && flatOptions.length > visibleOptions,\n })}\n >\n {footer}\n </div>\n )}\n </div>\n );\n },\n);\n"],"names":["Optgroup","DefaultOptgroup"],"mappings":"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"}
|
|
@@ -17,35 +17,35 @@
|
|
|
17
17
|
|
|
18
18
|
--select-option-left-padding: var(--gap-12);
|
|
19
19
|
--select-option-right-padding: var(--gap-12);
|
|
20
|
-
} .
|
|
20
|
+
} .select__virtualOptionsList_yyfv8 {
|
|
21
21
|
width: 100%;
|
|
22
22
|
outline: none;
|
|
23
23
|
box-sizing: border-box;
|
|
24
24
|
position: sticky;
|
|
25
25
|
justify-content: space-between;
|
|
26
|
-
} .
|
|
26
|
+
} .select__virtualOptionsListHeader_yyfv8 {
|
|
27
27
|
box-sizing: border-box;
|
|
28
28
|
border-bottom: 1px solid var(--color-light-neutral-300);
|
|
29
|
-
} .
|
|
29
|
+
} .select__virtualOptionsListFooter_yyfv8 {
|
|
30
30
|
position: sticky;
|
|
31
31
|
bottom: var(--gap-0);
|
|
32
32
|
box-sizing: border-box;
|
|
33
33
|
border-top: 1px solid transparent;
|
|
34
|
-
} .
|
|
34
|
+
} .select__virtualOptionsListFooter_yyfv8.select__withBorder_yyfv8 {
|
|
35
35
|
border-top: 1px solid var(--color-light-neutral-300);
|
|
36
|
-
} .
|
|
36
|
+
} .select__scrollable_yyfv8 {
|
|
37
37
|
position: relative;
|
|
38
38
|
overflow: auto;
|
|
39
39
|
width: 100%;
|
|
40
|
-
} .
|
|
40
|
+
} .select__inner_yyfv8 {
|
|
41
41
|
position: relative;
|
|
42
42
|
width: 100%;
|
|
43
|
-
} .
|
|
43
|
+
} .select__virtualRow_yyfv8 {
|
|
44
44
|
position: absolute;
|
|
45
45
|
top: var(--gap-0);
|
|
46
46
|
left: var(--gap-0);
|
|
47
47
|
width: 100%;
|
|
48
|
-
} .
|
|
48
|
+
} .select__virtualRow_yyfv8:before {
|
|
49
49
|
content: '';
|
|
50
50
|
position: absolute;
|
|
51
51
|
z-index: 1;
|
|
@@ -55,15 +55,15 @@
|
|
|
55
55
|
height: 1px;
|
|
56
56
|
background: var(--select-option-divider-background);
|
|
57
57
|
display: var(--select-option-divider-display);
|
|
58
|
-
} .
|
|
58
|
+
} .select__virtualRow_yyfv8:first-child:before {
|
|
59
59
|
display: none;
|
|
60
|
-
} .
|
|
61
|
-
.
|
|
60
|
+
} .select__highlighted_yyfv8:before,
|
|
61
|
+
.select__highlighted_yyfv8 + .select__virtualRow_yyfv8:before {
|
|
62
62
|
display: none;
|
|
63
|
-
} .
|
|
63
|
+
} .select__emptyPlaceholder_yyfv8 {
|
|
64
64
|
padding: var(--gap-16) var(--gap-12);
|
|
65
65
|
color: var(--select-options-list-empty-placeholder-color);
|
|
66
66
|
flex: 1;
|
|
67
|
-
} .select__size-
|
|
67
|
+
} .select__size-72_yyfv8 .select__emptyPlaceholder_yyfv8 {
|
|
68
68
|
padding: var(--gap-24) var(--gap-16);
|
|
69
69
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import './index.css';
|
|
2
2
|
|
|
3
|
-
var styles = {"virtualOptionsList":"
|
|
3
|
+
var styles = {"virtualOptionsList":"select__virtualOptionsList_yyfv8","virtualOptionsListHeader":"select__virtualOptionsListHeader_yyfv8","virtualOptionsListFooter":"select__virtualOptionsListFooter_yyfv8","withBorder":"select__withBorder_yyfv8","scrollable":"select__scrollable_yyfv8","inner":"select__inner_yyfv8","virtualRow":"select__virtualRow_yyfv8","highlighted":"select__highlighted_yyfv8","emptyPlaceholder":"select__emptyPlaceholder_yyfv8","size-72":"select__size-72_yyfv8"};
|
|
4
4
|
|
|
5
5
|
export { styles as default };
|
|
6
6
|
//# sourceMappingURL=index.module.css.js.map
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { useMatchMedia } from '@alfalab/core-components-mq/esm';
|
|
2
|
+
import { isClient } from '@alfalab/core-components-shared/esm';
|
|
3
|
+
|
|
4
|
+
var useNativeScrollbar = function (params) {
|
|
5
|
+
var scrollbarByProp = params.nativeScrollbar, client = params.client;
|
|
6
|
+
var query = '(max-width: 1023px)';
|
|
7
|
+
var nativeScrollbar = useMatchMedia(query, function () {
|
|
8
|
+
return isClient() ? window.matchMedia(query).matches : true;
|
|
9
|
+
})[0];
|
|
10
|
+
/**
|
|
11
|
+
* Условия отображения custom/native scrollbar
|
|
12
|
+
* 1. Принудительное управление через пропс
|
|
13
|
+
* 2. Для desktop/mobile выключаем и включаем соответственно
|
|
14
|
+
* 3. Иначе ориентируемся на медиа-запрос
|
|
15
|
+
*/
|
|
16
|
+
if (scrollbarByProp) {
|
|
17
|
+
return scrollbarByProp;
|
|
18
|
+
}
|
|
19
|
+
if (client === 'desktop') {
|
|
20
|
+
return false;
|
|
21
|
+
}
|
|
22
|
+
if (client === 'mobile') {
|
|
23
|
+
return true;
|
|
24
|
+
}
|
|
25
|
+
return nativeScrollbar;
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
export { useNativeScrollbar };
|
|
29
|
+
//# sourceMappingURL=use-native-scrollbar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-native-scrollbar.js","sources":["../../src/hooks/use-native-scrollbar.ts"],"sourcesContent":["import { useMatchMedia } from '@alfalab/core-components-mq';\nimport { isClient } from '@alfalab/core-components-shared';\n\nimport { type OptionsListProps } from '../typings';\n\ntype Params = Pick<OptionsListProps, 'nativeScrollbar' | 'client'>;\n\nexport const useNativeScrollbar = (params: Params) => {\n const { nativeScrollbar: scrollbarByProp, client } = params;\n\n const query = '(max-width: 1023px)';\n\n const [nativeScrollbar] = useMatchMedia(query, () =>\n isClient() ? window.matchMedia(query).matches : true,\n );\n\n /**\n * Условия отображения custom/native scrollbar\n * 1. Принудительное управление через пропс\n * 2. Для desktop/mobile выключаем и включаем соответственно\n * 3. Иначе ориентируемся на медиа-запрос\n */\n if (scrollbarByProp) {\n return scrollbarByProp;\n }\n\n if (client === 'desktop') {\n return false;\n }\n\n if (client === 'mobile') {\n return true;\n }\n\n return nativeScrollbar;\n};\n"],"names":[],"mappings":";;;AAOO,IAAM,kBAAkB,GAAG,UAAC,MAAc,EAAA;IACrC,IAAiB,eAAe,GAAa,MAAM,CAAA,eAAnB,EAAE,MAAM,GAAK,MAAM,CAAA,MAAX;IAEhD,IAAM,KAAK,GAAG,qBAAqB;AAE5B,IAAA,IAAA,eAAe,GAAI,aAAa,CAAC,KAAK,EAAE,YAAA;AAC3C,QAAA,OAAA,QAAQ,EAAE,GAAG,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,OAAO,GAAG,IAAI;KAAA,CACvD,GAFqB;AAItB;;;;;AAKG;AACH,IAAA,IAAI,eAAe,EAAE;AACjB,QAAA,OAAO,eAAe;AACzB;IAED,IAAI,MAAM,KAAK,SAAS,EAAE;AACtB,QAAA,OAAO,KAAK;AACf;IAED,IAAI,MAAM,KAAK,QAAQ,EAAE;AACrB,QAAA,OAAO,IAAI;AACd;AAED,IAAA,OAAO,eAAe;AAC1B;;;;"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
|
-
import { type BaseSelectProps, type OptionShape } from '../../typings';
|
|
2
|
+
import { type AnyObject, type BaseSelectProps, type OptionShape } from '../../typings';
|
|
3
3
|
export declare type UseSelectWithApplyProps = {
|
|
4
4
|
/**
|
|
5
5
|
* Список выбранных пунктов
|
|
@@ -57,11 +57,77 @@ export declare type UseSelectWithApplyProps = {
|
|
|
57
57
|
resetName?: string;
|
|
58
58
|
};
|
|
59
59
|
export declare function useSelectWithApply({ options, selected, onChange, onSelectAllClick, OptionsList, optionsListProps, showClear, showSelectAll, showHeaderWithSelectAll, showSearch, searchProps, applyName, resetName, }: UseSelectWithApplyProps): {
|
|
60
|
-
OptionsList: import("react").ForwardRefExoticComponent<import("../../typings").
|
|
60
|
+
OptionsList: import("react").ForwardRefExoticComponent<Pick<import("../../typings").SelectProps, "client"> & {
|
|
61
|
+
className?: string | undefined;
|
|
62
|
+
optionGroupClassName?: string | undefined;
|
|
63
|
+
scrollbarClassName?: string | undefined;
|
|
64
|
+
footerClassName?: string | undefined;
|
|
65
|
+
size?: "s" | "m" | "l" | "xl" | 40 | 48 | 56 | 64 | 72 | undefined;
|
|
66
|
+
Option: import("react").ComponentType<import("../../typings").OptionProps>;
|
|
67
|
+
getOptionProps: (option: OptionShape, index: number) => import("../../typings").OptionProps;
|
|
68
|
+
groupOptionProps?: AnyObject | undefined;
|
|
69
|
+
selectedItems?: OptionShape[] | undefined;
|
|
70
|
+
setSelectedItems: (selected: OptionShape[]) => void;
|
|
71
|
+
toggleMenu: () => void;
|
|
72
|
+
header?: import("react").ReactNode;
|
|
73
|
+
footer?: import("react").ReactNode;
|
|
74
|
+
options?: (OptionShape | import("../../typings").GroupShape)[] | undefined;
|
|
75
|
+
flatOptions?: OptionShape[] | undefined;
|
|
76
|
+
highlightedIndex?: number | undefined;
|
|
77
|
+
open?: boolean | undefined;
|
|
78
|
+
Optgroup?: import("react").ComponentType<import("../../typings").OptgroupProps> | undefined;
|
|
79
|
+
emptyPlaceholder?: import("react").ReactNode;
|
|
80
|
+
visibleOptions?: number | undefined;
|
|
81
|
+
onScroll?: ((event: import("react").MouseEvent<HTMLDivElement, MouseEvent>) => void) | undefined;
|
|
82
|
+
dataTestId?: string | undefined;
|
|
83
|
+
inputProps?: import("@alfalab/core-components-input").InputProps | undefined;
|
|
84
|
+
showFooter?: boolean | undefined;
|
|
85
|
+
nativeScrollbar?: boolean | undefined;
|
|
86
|
+
optionsListWidth?: "field" | "content" | undefined;
|
|
87
|
+
onApply?: (() => void) | undefined;
|
|
88
|
+
onClear?: (() => void) | undefined;
|
|
89
|
+
setHighlightedIndex?: ((index: number) => void) | undefined;
|
|
90
|
+
search?: string | undefined;
|
|
91
|
+
multiple?: boolean | undefined;
|
|
92
|
+
limitDynamicOptionGroupSize?: boolean | undefined;
|
|
93
|
+
} & {
|
|
61
94
|
showClear?: boolean | undefined;
|
|
62
95
|
onClose?: (() => void) | undefined;
|
|
63
96
|
selectedDraft?: OptionShape[] | undefined;
|
|
64
|
-
OptionsList?: import("react").FC<import("../../typings").
|
|
97
|
+
OptionsList?: import("react").FC<Pick<import("../../typings").SelectProps, "client"> & {
|
|
98
|
+
className?: string | undefined;
|
|
99
|
+
optionGroupClassName?: string | undefined;
|
|
100
|
+
scrollbarClassName?: string | undefined;
|
|
101
|
+
footerClassName?: string | undefined;
|
|
102
|
+
size?: "s" | "m" | "l" | "xl" | 40 | 48 | 56 | 64 | 72 | undefined;
|
|
103
|
+
Option: import("react").ComponentType<import("../../typings").OptionProps>;
|
|
104
|
+
getOptionProps: (option: OptionShape, index: number) => import("../../typings").OptionProps;
|
|
105
|
+
groupOptionProps?: AnyObject | undefined;
|
|
106
|
+
selectedItems?: OptionShape[] | undefined;
|
|
107
|
+
setSelectedItems: (selected: OptionShape[]) => void;
|
|
108
|
+
toggleMenu: () => void;
|
|
109
|
+
header?: import("react").ReactNode;
|
|
110
|
+
footer?: import("react").ReactNode;
|
|
111
|
+
options?: (OptionShape | import("../../typings").GroupShape)[] | undefined;
|
|
112
|
+
flatOptions?: OptionShape[] | undefined;
|
|
113
|
+
highlightedIndex?: number | undefined;
|
|
114
|
+
open?: boolean | undefined;
|
|
115
|
+
Optgroup?: import("react").ComponentType<import("../../typings").OptgroupProps> | undefined;
|
|
116
|
+
emptyPlaceholder?: import("react").ReactNode;
|
|
117
|
+
visibleOptions?: number | undefined;
|
|
118
|
+
onScroll?: ((event: import("react").MouseEvent<HTMLDivElement, MouseEvent>) => void) | undefined;
|
|
119
|
+
dataTestId?: string | undefined;
|
|
120
|
+
inputProps?: import("@alfalab/core-components-input").InputProps | undefined;
|
|
121
|
+
showFooter?: boolean | undefined;
|
|
122
|
+
nativeScrollbar?: boolean | undefined;
|
|
123
|
+
optionsListWidth?: "field" | "content" | undefined;
|
|
124
|
+
onApply?: (() => void) | undefined;
|
|
125
|
+
onClear?: (() => void) | undefined;
|
|
126
|
+
setHighlightedIndex?: ((index: number) => void) | undefined;
|
|
127
|
+
search?: string | undefined;
|
|
128
|
+
multiple?: boolean | undefined;
|
|
129
|
+
limitDynamicOptionGroupSize?: boolean | undefined;
|
|
130
|
+
} & import("react").RefAttributes<HTMLDivElement>> | undefined;
|
|
65
131
|
Footer?: import("react").FC<import("./options-list-with-apply/footer/Component").FooterProps> | undefined;
|
|
66
132
|
Header?: import("react").FC<import("./options-list-with-apply/header/Component").HeaderProps> | undefined;
|
|
67
133
|
headerProps?: import("./options-list-with-apply/header/Component").HeaderProps | undefined;
|
|
@@ -69,7 +135,40 @@ export declare function useSelectWithApply({ options, selected, onChange, onSele
|
|
|
69
135
|
setSelectedDraft?: ((selectedDraft: OptionShape[]) => void) | undefined;
|
|
70
136
|
} & import("react").RefAttributes<HTMLDivElement>>;
|
|
71
137
|
optionsListProps: {
|
|
72
|
-
OptionsList: import("react").ComponentType<import("../../typings").
|
|
138
|
+
OptionsList: import("react").ComponentType<Pick<import("../../typings").SelectProps, "client"> & {
|
|
139
|
+
className?: string | undefined;
|
|
140
|
+
optionGroupClassName?: string | undefined;
|
|
141
|
+
scrollbarClassName?: string | undefined;
|
|
142
|
+
footerClassName?: string | undefined;
|
|
143
|
+
size?: "s" | "m" | "l" | "xl" | 40 | 48 | 56 | 64 | 72 | undefined;
|
|
144
|
+
Option: import("react").ComponentType<import("../../typings").OptionProps>;
|
|
145
|
+
getOptionProps: (option: OptionShape, index: number) => import("../../typings").OptionProps;
|
|
146
|
+
groupOptionProps?: AnyObject | undefined;
|
|
147
|
+
selectedItems?: OptionShape[] | undefined;
|
|
148
|
+
setSelectedItems: (selected: OptionShape[]) => void;
|
|
149
|
+
toggleMenu: () => void;
|
|
150
|
+
header?: import("react").ReactNode;
|
|
151
|
+
footer?: import("react").ReactNode;
|
|
152
|
+
options?: (OptionShape | import("../../typings").GroupShape)[] | undefined;
|
|
153
|
+
flatOptions?: OptionShape[] | undefined;
|
|
154
|
+
highlightedIndex?: number | undefined;
|
|
155
|
+
open?: boolean | undefined;
|
|
156
|
+
Optgroup?: import("react").ComponentType<import("../../typings").OptgroupProps> | undefined;
|
|
157
|
+
emptyPlaceholder?: import("react").ReactNode;
|
|
158
|
+
visibleOptions?: number | undefined;
|
|
159
|
+
onScroll?: ((event: import("react").MouseEvent<HTMLDivElement, MouseEvent>) => void) | undefined;
|
|
160
|
+
dataTestId?: string | undefined;
|
|
161
|
+
inputProps?: import("@alfalab/core-components-input").InputProps | undefined;
|
|
162
|
+
showFooter?: boolean | undefined;
|
|
163
|
+
nativeScrollbar?: boolean | undefined;
|
|
164
|
+
optionsListWidth?: "field" | "content" | undefined;
|
|
165
|
+
onApply?: (() => void) | undefined;
|
|
166
|
+
onClear?: (() => void) | undefined;
|
|
167
|
+
setHighlightedIndex?: ((index: number) => void) | undefined;
|
|
168
|
+
search?: string | undefined;
|
|
169
|
+
multiple?: boolean | undefined;
|
|
170
|
+
limitDynamicOptionGroupSize?: boolean | undefined;
|
|
171
|
+
} & import("react").RefAttributes<HTMLDivElement>> | undefined;
|
|
73
172
|
showClear: boolean;
|
|
74
173
|
onClear: () => void;
|
|
75
174
|
onApply: () => void;
|
|
@@ -100,7 +199,40 @@ export declare function useSelectWithApply({ options, selected, onChange, onSele
|
|
|
100
199
|
options: (OptionShape | import("../../typings").GroupShape)[];
|
|
101
200
|
selected: string | OptionShape | (string | OptionShape)[] | null | undefined;
|
|
102
201
|
onChange: (payload: import("../../typings").BaseSelectChangePayload) => void;
|
|
103
|
-
OptionsList: import("react").ComponentType<import("../../typings").
|
|
202
|
+
OptionsList: import("react").ComponentType<Pick<import("../../typings").SelectProps, "client"> & {
|
|
203
|
+
className?: string | undefined;
|
|
204
|
+
optionGroupClassName?: string | undefined;
|
|
205
|
+
scrollbarClassName?: string | undefined;
|
|
206
|
+
footerClassName?: string | undefined;
|
|
207
|
+
size?: "s" | "m" | "l" | "xl" | 40 | 48 | 56 | 64 | 72 | undefined;
|
|
208
|
+
Option: import("react").ComponentType<import("../../typings").OptionProps>;
|
|
209
|
+
getOptionProps: (option: OptionShape, index: number) => import("../../typings").OptionProps;
|
|
210
|
+
groupOptionProps?: AnyObject | undefined;
|
|
211
|
+
selectedItems?: OptionShape[] | undefined;
|
|
212
|
+
setSelectedItems: (selected: OptionShape[]) => void;
|
|
213
|
+
toggleMenu: () => void;
|
|
214
|
+
header?: import("react").ReactNode;
|
|
215
|
+
footer?: import("react").ReactNode;
|
|
216
|
+
options?: (OptionShape | import("../../typings").GroupShape)[] | undefined;
|
|
217
|
+
flatOptions?: OptionShape[] | undefined;
|
|
218
|
+
highlightedIndex?: number | undefined;
|
|
219
|
+
open?: boolean | undefined;
|
|
220
|
+
Optgroup?: import("react").ComponentType<import("../../typings").OptgroupProps> | undefined;
|
|
221
|
+
emptyPlaceholder?: import("react").ReactNode;
|
|
222
|
+
visibleOptions?: number | undefined;
|
|
223
|
+
onScroll?: ((event: import("react").MouseEvent<HTMLDivElement, MouseEvent>) => void) | undefined;
|
|
224
|
+
dataTestId?: string | undefined;
|
|
225
|
+
inputProps?: import("@alfalab/core-components-input").InputProps | undefined;
|
|
226
|
+
showFooter?: boolean | undefined;
|
|
227
|
+
nativeScrollbar?: boolean | undefined;
|
|
228
|
+
optionsListWidth?: "field" | "content" | undefined;
|
|
229
|
+
onApply?: (() => void) | undefined;
|
|
230
|
+
onClear?: (() => void) | undefined;
|
|
231
|
+
setHighlightedIndex?: ((index: number) => void) | undefined;
|
|
232
|
+
search?: string | undefined;
|
|
233
|
+
multiple?: boolean | undefined;
|
|
234
|
+
limitDynamicOptionGroupSize?: boolean | undefined;
|
|
235
|
+
} & import("react").RefAttributes<HTMLDivElement>> | undefined;
|
|
104
236
|
optionsListProps: unknown;
|
|
105
237
|
showClear: boolean;
|
|
106
238
|
showSelectAll: boolean;
|
|
@@ -1,12 +1,78 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import { type OptionShape
|
|
2
|
+
import { type OptionShape } from '../../../typings';
|
|
3
3
|
import { type FooterProps } from './footer/Component';
|
|
4
4
|
import { type HeaderProps } from './header/Component';
|
|
5
|
-
export declare const OptionsListWithApply: React.ForwardRefExoticComponent<
|
|
5
|
+
export declare const OptionsListWithApply: React.ForwardRefExoticComponent<Pick<import("../../../typings").SelectProps, "client"> & {
|
|
6
|
+
className?: string | undefined;
|
|
7
|
+
optionGroupClassName?: string | undefined;
|
|
8
|
+
scrollbarClassName?: string | undefined;
|
|
9
|
+
footerClassName?: string | undefined;
|
|
10
|
+
size?: "s" | "m" | "l" | "xl" | 40 | 48 | 56 | 64 | 72 | undefined;
|
|
11
|
+
Option: React.ComponentType<import("../../../typings").OptionProps>;
|
|
12
|
+
getOptionProps: (option: OptionShape, index: number) => import("../../../typings").OptionProps;
|
|
13
|
+
groupOptionProps?: import("../../../typings").AnyObject | undefined;
|
|
14
|
+
selectedItems?: OptionShape[] | undefined;
|
|
15
|
+
setSelectedItems: (selected: OptionShape[]) => void;
|
|
16
|
+
toggleMenu: () => void;
|
|
17
|
+
header?: React.ReactNode;
|
|
18
|
+
footer?: React.ReactNode;
|
|
19
|
+
options?: (OptionShape | import("../../../typings").GroupShape)[] | undefined;
|
|
20
|
+
flatOptions?: OptionShape[] | undefined;
|
|
21
|
+
highlightedIndex?: number | undefined;
|
|
22
|
+
open?: boolean | undefined;
|
|
23
|
+
Optgroup?: React.ComponentType<import("../../../typings").OptgroupProps> | undefined;
|
|
24
|
+
emptyPlaceholder?: React.ReactNode;
|
|
25
|
+
visibleOptions?: number | undefined;
|
|
26
|
+
onScroll?: ((event: React.MouseEvent<HTMLDivElement, MouseEvent>) => void) | undefined;
|
|
27
|
+
dataTestId?: string | undefined;
|
|
28
|
+
inputProps?: import("@alfalab/core-components-input").InputProps | undefined;
|
|
29
|
+
showFooter?: boolean | undefined;
|
|
30
|
+
nativeScrollbar?: boolean | undefined;
|
|
31
|
+
optionsListWidth?: "field" | "content" | undefined;
|
|
32
|
+
onApply?: (() => void) | undefined;
|
|
33
|
+
onClear?: (() => void) | undefined;
|
|
34
|
+
setHighlightedIndex?: ((index: number) => void) | undefined;
|
|
35
|
+
search?: string | undefined;
|
|
36
|
+
multiple?: boolean | undefined;
|
|
37
|
+
limitDynamicOptionGroupSize?: boolean | undefined;
|
|
38
|
+
} & {
|
|
6
39
|
showClear?: boolean | undefined;
|
|
7
40
|
onClose?: (() => void) | undefined;
|
|
8
41
|
selectedDraft?: OptionShape[] | undefined;
|
|
9
|
-
OptionsList?: React.FC<
|
|
42
|
+
OptionsList?: React.FC<Pick<import("../../../typings").SelectProps, "client"> & {
|
|
43
|
+
className?: string | undefined;
|
|
44
|
+
optionGroupClassName?: string | undefined;
|
|
45
|
+
scrollbarClassName?: string | undefined;
|
|
46
|
+
footerClassName?: string | undefined;
|
|
47
|
+
size?: "s" | "m" | "l" | "xl" | 40 | 48 | 56 | 64 | 72 | undefined;
|
|
48
|
+
Option: React.ComponentType<import("../../../typings").OptionProps>;
|
|
49
|
+
getOptionProps: (option: OptionShape, index: number) => import("../../../typings").OptionProps;
|
|
50
|
+
groupOptionProps?: import("../../../typings").AnyObject | undefined;
|
|
51
|
+
selectedItems?: OptionShape[] | undefined;
|
|
52
|
+
setSelectedItems: (selected: OptionShape[]) => void;
|
|
53
|
+
toggleMenu: () => void;
|
|
54
|
+
header?: React.ReactNode;
|
|
55
|
+
footer?: React.ReactNode;
|
|
56
|
+
options?: (OptionShape | import("../../../typings").GroupShape)[] | undefined;
|
|
57
|
+
flatOptions?: OptionShape[] | undefined;
|
|
58
|
+
highlightedIndex?: number | undefined;
|
|
59
|
+
open?: boolean | undefined;
|
|
60
|
+
Optgroup?: React.ComponentType<import("../../../typings").OptgroupProps> | undefined;
|
|
61
|
+
emptyPlaceholder?: React.ReactNode;
|
|
62
|
+
visibleOptions?: number | undefined;
|
|
63
|
+
onScroll?: ((event: React.MouseEvent<HTMLDivElement, MouseEvent>) => void) | undefined;
|
|
64
|
+
dataTestId?: string | undefined;
|
|
65
|
+
inputProps?: import("@alfalab/core-components-input").InputProps | undefined;
|
|
66
|
+
showFooter?: boolean | undefined;
|
|
67
|
+
nativeScrollbar?: boolean | undefined;
|
|
68
|
+
optionsListWidth?: "field" | "content" | undefined;
|
|
69
|
+
onApply?: (() => void) | undefined;
|
|
70
|
+
onClear?: (() => void) | undefined;
|
|
71
|
+
setHighlightedIndex?: ((index: number) => void) | undefined;
|
|
72
|
+
search?: string | undefined;
|
|
73
|
+
multiple?: boolean | undefined;
|
|
74
|
+
limitDynamicOptionGroupSize?: boolean | undefined;
|
|
75
|
+
} & React.RefAttributes<HTMLDivElement>> | undefined;
|
|
10
76
|
Footer?: React.FC<FooterProps> | undefined;
|
|
11
77
|
Header?: React.FC<HeaderProps> | undefined;
|
|
12
78
|
headerProps?: HeaderProps | undefined;
|
|
@@ -9,12 +9,12 @@
|
|
|
9
9
|
--gap-16: var(--gap-m);
|
|
10
10
|
} :root {
|
|
11
11
|
--select-option-list-footer-button-gap: var(--gap-8);
|
|
12
|
-
} .
|
|
12
|
+
} .select__footer_knau3 {
|
|
13
13
|
background-color: var(--color-light-base-bg-primary);
|
|
14
14
|
padding: var(--gap-12);
|
|
15
15
|
outline: none;
|
|
16
|
-
} .
|
|
16
|
+
} .select__footer_knau3.select__size-72_knau3 {
|
|
17
17
|
padding: var(--gap-12) var(--gap-16);
|
|
18
|
-
} .
|
|
18
|
+
} .select__footer_knau3 > .select__button_knau3 + .select__button_knau3 {
|
|
19
19
|
margin-left: var(--select-option-list-footer-button-gap);
|
|
20
20
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import './index.css';
|
|
2
2
|
|
|
3
|
-
var styles = {"footer":"
|
|
3
|
+
var styles = {"footer":"select__footer_knau3","size-72":"select__size-72_knau3","button":"select__button_knau3"};
|
|
4
4
|
|
|
5
5
|
export { styles as default };
|
|
6
6
|
//# sourceMappingURL=index.module.css.js.map
|
|
@@ -5,10 +5,10 @@
|
|
|
5
5
|
--gap-8: var(--gap-xs);
|
|
6
6
|
--gap-12: var(--gap-s);
|
|
7
7
|
--gap-16: var(--gap-m);
|
|
8
|
-
} .
|
|
8
|
+
} .select__desktop_156uq {
|
|
9
9
|
padding: var(--gap-12);
|
|
10
|
-
} .
|
|
10
|
+
} .select__desktop_156uq.select__size-72_156uq {
|
|
11
11
|
padding-left: var(--gap-16);
|
|
12
|
-
} .
|
|
12
|
+
} .select__mobile_156uq {
|
|
13
13
|
padding: var(--gap-12) var(--gap-8);
|
|
14
14
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import './index.css';
|
|
2
2
|
|
|
3
|
-
var styles = {"desktop":"
|
|
3
|
+
var styles = {"desktop":"select__desktop_156uq","size-72":"select__size-72_156uq","mobile":"select__mobile_156uq"};
|
|
4
4
|
|
|
5
5
|
export { styles as default };
|
|
6
6
|
//# sourceMappingURL=index.module.css.js.map
|
package/esm/typings.d.ts
CHANGED
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var coreComponentsMq = require('@alfalab/core-components-mq');
|
|
6
|
+
var coreComponentsShared = require('@alfalab/core-components-shared');
|
|
7
|
+
|
|
8
|
+
var useNativeScrollbar = function (params) {
|
|
9
|
+
var scrollbarByProp = params.nativeScrollbar, client = params.client;
|
|
10
|
+
var query = '(max-width: 1023px)';
|
|
11
|
+
var nativeScrollbar = coreComponentsMq.useMatchMedia(query, function () {
|
|
12
|
+
return coreComponentsShared.isClient() ? window.matchMedia(query).matches : true;
|
|
13
|
+
})[0];
|
|
14
|
+
/**
|
|
15
|
+
* Условия отображения custom/native scrollbar
|
|
16
|
+
* 1. Принудительное управление через пропс
|
|
17
|
+
* 2. Для desktop/mobile выключаем и включаем соответственно
|
|
18
|
+
* 3. Иначе ориентируемся на медиа-запрос
|
|
19
|
+
*/
|
|
20
|
+
if (scrollbarByProp) {
|
|
21
|
+
return scrollbarByProp;
|
|
22
|
+
}
|
|
23
|
+
if (client === 'desktop') {
|
|
24
|
+
return false;
|
|
25
|
+
}
|
|
26
|
+
if (client === 'mobile') {
|
|
27
|
+
return true;
|
|
28
|
+
}
|
|
29
|
+
return nativeScrollbar;
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
exports.useNativeScrollbar = useNativeScrollbar;
|
|
33
|
+
//# sourceMappingURL=use-native-scrollbar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-native-scrollbar.js","sources":["../src/hooks/use-native-scrollbar.ts"],"sourcesContent":["import { useMatchMedia } from '@alfalab/core-components-mq';\nimport { isClient } from '@alfalab/core-components-shared';\n\nimport { type OptionsListProps } from '../typings';\n\ntype Params = Pick<OptionsListProps, 'nativeScrollbar' | 'client'>;\n\nexport const useNativeScrollbar = (params: Params) => {\n const { nativeScrollbar: scrollbarByProp, client } = params;\n\n const query = '(max-width: 1023px)';\n\n const [nativeScrollbar] = useMatchMedia(query, () =>\n isClient() ? window.matchMedia(query).matches : true,\n );\n\n /**\n * Условия отображения custom/native scrollbar\n * 1. Принудительное управление через пропс\n * 2. Для desktop/mobile выключаем и включаем соответственно\n * 3. Иначе ориентируемся на медиа-запрос\n */\n if (scrollbarByProp) {\n return scrollbarByProp;\n }\n\n if (client === 'desktop') {\n return false;\n }\n\n if (client === 'mobile') {\n return true;\n }\n\n return nativeScrollbar;\n};\n"],"names":["useMatchMedia","isClient"],"mappings":";;;;;;;AAOO,IAAM,kBAAkB,GAAG,UAAC,MAAc,EAAA;IACrC,IAAiB,eAAe,GAAa,MAAM,CAAA,eAAnB,EAAE,MAAM,GAAK,MAAM,CAAA,MAAX;IAEhD,IAAM,KAAK,GAAG,qBAAqB;AAE5B,IAAA,IAAA,eAAe,GAAIA,8BAAa,CAAC,KAAK,EAAE,YAAA;AAC3C,QAAA,OAAAC,6BAAQ,EAAE,GAAG,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,OAAO,GAAG,IAAI;KAAA,CACvD,GAFqB;AAItB;;;;;AAKG;AACH,IAAA,IAAI,eAAe,EAAE;AACjB,QAAA,OAAO,eAAe;AACzB;IAED,IAAI,MAAM,KAAK,SAAS,EAAE;AACtB,QAAA,OAAO,KAAK;AACf;IAED,IAAI,MAAM,KAAK,QAAQ,EAAE;AACrB,QAAA,OAAO,IAAI;AACd;AAED,IAAA,OAAO,eAAe;AAC1B;;;;"}
|
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
} :root {
|
|
7
7
|
--select-arrow-color: var(--color-light-neutral-translucent-700);
|
|
8
8
|
--select-arrow-disabled-color: var(--color-light-neutral-translucent-500);
|
|
9
|
-
} .
|
|
9
|
+
} .select__arrow_1p3an {
|
|
10
10
|
display: block;
|
|
11
11
|
width: 24px;
|
|
12
12
|
height: 24px;
|
|
@@ -15,13 +15,13 @@
|
|
|
15
15
|
transition:
|
|
16
16
|
transform 0.15s ease-in-out,
|
|
17
17
|
opacity 0.2s ease;
|
|
18
|
-
} .
|
|
18
|
+
} .select__arrow_1p3an.select__disabled_1p3an {
|
|
19
19
|
color: var(--select-arrow-disabled-color);
|
|
20
|
-
} .
|
|
20
|
+
} .select__arrow_1p3an.select__size-40_1p3an {
|
|
21
21
|
width: auto;
|
|
22
22
|
width: initial;
|
|
23
23
|
height: auto;
|
|
24
24
|
height: initial;
|
|
25
|
-
} .
|
|
25
|
+
} .select__open_1p3an {
|
|
26
26
|
transform: var(--arrow-transform);
|
|
27
27
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import './index.css';
|
|
2
2
|
|
|
3
|
-
const styles = {"arrow":"
|
|
3
|
+
const styles = {"arrow":"select__arrow_1p3an","disabled":"select__disabled_1p3an","size-40":"select__size-40_1p3an","open":"select__open_1p3an"};
|
|
4
4
|
|
|
5
5
|
export { styles as default };
|
|
6
6
|
//# sourceMappingURL=index.module.css.js.map
|