@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.
Files changed (206) hide show
  1. package/components/arrow/index.css +4 -4
  2. package/components/arrow/index.module.css.js +1 -1
  3. package/components/base-checkmark/index.css +5 -5
  4. package/components/base-checkmark/index.module.css.js +1 -1
  5. package/components/base-option/index.css +16 -16
  6. package/components/base-option/index.module.css.js +1 -1
  7. package/components/base-select/Component.d.ts +1 -1
  8. package/components/base-select/Component.js +2 -2
  9. package/components/base-select/Component.js.map +1 -1
  10. package/components/base-select/index.css +11 -11
  11. package/components/base-select/index.module.css.js +1 -1
  12. package/components/base-select/mobile.css +11 -11
  13. package/components/base-select/mobile.module.css.js +1 -1
  14. package/components/checkmark/index.css +9 -9
  15. package/components/checkmark/index.module.css.js +1 -1
  16. package/components/checkmark-mobile/index.css +5 -5
  17. package/components/checkmark-mobile/index.module.css.js +1 -1
  18. package/components/clear-button/index.css +4 -4
  19. package/components/clear-button/index.module.css.js +1 -1
  20. package/components/field/index.css +13 -13
  21. package/components/field/index.module.css.js +1 -1
  22. package/components/footer/index.css +4 -4
  23. package/components/footer/index.module.css.js +1 -1
  24. package/components/optgroup/index.css +4 -4
  25. package/components/optgroup/index.module.css.js +1 -1
  26. package/components/option/desktop/index.css +19 -19
  27. package/components/option/desktop/index.module.css.js +1 -1
  28. package/components/option/mobile/index.css +16 -16
  29. package/components/option/mobile/index.module.css.js +1 -1
  30. package/components/options-list/Component.d.ts +35 -2
  31. package/components/options-list/Component.js +6 -8
  32. package/components/options-list/Component.js.map +1 -1
  33. package/components/options-list/index.css +9 -9
  34. package/components/options-list/index.module.css.js +1 -1
  35. package/components/search/Component.js +15 -1
  36. package/components/search/Component.js.map +1 -1
  37. package/components/search/index.css +1 -1
  38. package/components/search/index.module.css.js +1 -1
  39. package/components/virtual-options-list/Component.d.ts +35 -2
  40. package/components/virtual-options-list/Component.js +6 -9
  41. package/components/virtual-options-list/Component.js.map +1 -1
  42. package/components/virtual-options-list/index.css +13 -13
  43. package/components/virtual-options-list/index.module.css.js +1 -1
  44. package/cssm/components/base-select/Component.d.ts +1 -1
  45. package/cssm/components/base-select/Component.js +2 -2
  46. package/cssm/components/base-select/Component.js.map +1 -1
  47. package/cssm/components/options-list/Component.d.ts +35 -2
  48. package/cssm/components/options-list/Component.js +8 -10
  49. package/cssm/components/options-list/Component.js.map +1 -1
  50. package/cssm/components/search/Component.js +15 -1
  51. package/cssm/components/search/Component.js.map +1 -1
  52. package/cssm/components/virtual-options-list/Component.d.ts +35 -2
  53. package/cssm/components/virtual-options-list/Component.js +8 -11
  54. package/cssm/components/virtual-options-list/Component.js.map +1 -1
  55. package/cssm/hooks/use-native-scrollbar.d.ts +4 -0
  56. package/cssm/hooks/use-native-scrollbar.js +33 -0
  57. package/cssm/hooks/use-native-scrollbar.js.map +1 -0
  58. package/cssm/presets/useSelectWithApply/hook.d.ts +137 -5
  59. package/cssm/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +69 -3
  60. package/cssm/typings.d.ts +1 -1
  61. package/esm/components/arrow/index.css +4 -4
  62. package/esm/components/arrow/index.module.css.js +1 -1
  63. package/esm/components/base-checkmark/index.css +5 -5
  64. package/esm/components/base-checkmark/index.module.css.js +1 -1
  65. package/esm/components/base-option/index.css +16 -16
  66. package/esm/components/base-option/index.module.css.js +1 -1
  67. package/esm/components/base-select/Component.d.ts +1 -1
  68. package/esm/components/base-select/Component.js +2 -2
  69. package/esm/components/base-select/Component.js.map +1 -1
  70. package/esm/components/base-select/index.css +11 -11
  71. package/esm/components/base-select/index.module.css.js +1 -1
  72. package/esm/components/base-select/mobile.css +11 -11
  73. package/esm/components/base-select/mobile.module.css.js +1 -1
  74. package/esm/components/checkmark/index.css +9 -9
  75. package/esm/components/checkmark/index.module.css.js +1 -1
  76. package/esm/components/checkmark-mobile/index.css +5 -5
  77. package/esm/components/checkmark-mobile/index.module.css.js +1 -1
  78. package/esm/components/clear-button/index.css +4 -4
  79. package/esm/components/clear-button/index.module.css.js +1 -1
  80. package/esm/components/field/index.css +13 -13
  81. package/esm/components/field/index.module.css.js +1 -1
  82. package/esm/components/footer/index.css +4 -4
  83. package/esm/components/footer/index.module.css.js +1 -1
  84. package/esm/components/optgroup/index.css +4 -4
  85. package/esm/components/optgroup/index.module.css.js +1 -1
  86. package/esm/components/option/desktop/index.css +19 -19
  87. package/esm/components/option/desktop/index.module.css.js +1 -1
  88. package/esm/components/option/mobile/index.css +16 -16
  89. package/esm/components/option/mobile/index.module.css.js +1 -1
  90. package/esm/components/options-list/Component.d.ts +35 -2
  91. package/esm/components/options-list/Component.js +6 -8
  92. package/esm/components/options-list/Component.js.map +1 -1
  93. package/esm/components/options-list/index.css +9 -9
  94. package/esm/components/options-list/index.module.css.js +1 -1
  95. package/esm/components/search/Component.js +15 -1
  96. package/esm/components/search/Component.js.map +1 -1
  97. package/esm/components/search/index.css +1 -1
  98. package/esm/components/search/index.module.css.js +1 -1
  99. package/esm/components/virtual-options-list/Component.d.ts +35 -2
  100. package/esm/components/virtual-options-list/Component.js +6 -9
  101. package/esm/components/virtual-options-list/Component.js.map +1 -1
  102. package/esm/components/virtual-options-list/index.css +13 -13
  103. package/esm/components/virtual-options-list/index.module.css.js +1 -1
  104. package/esm/hooks/use-native-scrollbar.d.ts +4 -0
  105. package/esm/hooks/use-native-scrollbar.js +29 -0
  106. package/esm/hooks/use-native-scrollbar.js.map +1 -0
  107. package/esm/presets/useSelectWithApply/hook.d.ts +137 -5
  108. package/esm/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +69 -3
  109. package/esm/presets/useSelectWithApply/options-list-with-apply/footer/index.css +3 -3
  110. package/esm/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js +1 -1
  111. package/esm/presets/useSelectWithApply/options-list-with-apply/header/index.css +3 -3
  112. package/esm/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js +1 -1
  113. package/esm/presets/useSelectWithLoading/index.css +1 -1
  114. package/esm/presets/useSelectWithLoading/index.module.css.js +1 -1
  115. package/esm/typings.d.ts +1 -1
  116. package/hooks/use-native-scrollbar.d.ts +4 -0
  117. package/hooks/use-native-scrollbar.js +33 -0
  118. package/hooks/use-native-scrollbar.js.map +1 -0
  119. package/modern/components/arrow/index.css +4 -4
  120. package/modern/components/arrow/index.module.css.js +1 -1
  121. package/modern/components/base-checkmark/index.css +5 -5
  122. package/modern/components/base-checkmark/index.module.css.js +1 -1
  123. package/modern/components/base-option/index.css +16 -16
  124. package/modern/components/base-option/index.module.css.js +1 -1
  125. package/modern/components/base-select/Component.d.ts +1 -1
  126. package/modern/components/base-select/Component.js +2 -2
  127. package/modern/components/base-select/Component.js.map +1 -1
  128. package/modern/components/base-select/index.css +11 -11
  129. package/modern/components/base-select/index.module.css.js +1 -1
  130. package/modern/components/base-select/mobile.css +11 -11
  131. package/modern/components/base-select/mobile.module.css.js +1 -1
  132. package/modern/components/checkmark/index.css +9 -9
  133. package/modern/components/checkmark/index.module.css.js +1 -1
  134. package/modern/components/checkmark-mobile/index.css +5 -5
  135. package/modern/components/checkmark-mobile/index.module.css.js +1 -1
  136. package/modern/components/clear-button/index.css +4 -4
  137. package/modern/components/clear-button/index.module.css.js +1 -1
  138. package/modern/components/field/index.css +13 -13
  139. package/modern/components/field/index.module.css.js +1 -1
  140. package/modern/components/footer/index.css +4 -4
  141. package/modern/components/footer/index.module.css.js +1 -1
  142. package/modern/components/optgroup/index.css +4 -4
  143. package/modern/components/optgroup/index.module.css.js +1 -1
  144. package/modern/components/option/desktop/index.css +19 -19
  145. package/modern/components/option/desktop/index.module.css.js +1 -1
  146. package/modern/components/option/mobile/index.css +16 -16
  147. package/modern/components/option/mobile/index.module.css.js +1 -1
  148. package/modern/components/options-list/Component.d.ts +35 -2
  149. package/modern/components/options-list/Component.js +6 -6
  150. package/modern/components/options-list/Component.js.map +1 -1
  151. package/modern/components/options-list/index.css +9 -9
  152. package/modern/components/options-list/index.module.css.js +1 -1
  153. package/modern/components/search/Component.js +17 -1
  154. package/modern/components/search/Component.js.map +1 -1
  155. package/modern/components/search/index.css +1 -1
  156. package/modern/components/search/index.module.css.js +1 -1
  157. package/modern/components/virtual-options-list/Component.d.ts +35 -2
  158. package/modern/components/virtual-options-list/Component.js +6 -7
  159. package/modern/components/virtual-options-list/Component.js.map +1 -1
  160. package/modern/components/virtual-options-list/index.css +13 -13
  161. package/modern/components/virtual-options-list/index.module.css.js +1 -1
  162. package/modern/hooks/use-native-scrollbar.d.ts +4 -0
  163. package/modern/hooks/use-native-scrollbar.js +27 -0
  164. package/modern/hooks/use-native-scrollbar.js.map +1 -0
  165. package/modern/presets/useSelectWithApply/hook.d.ts +137 -5
  166. package/modern/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +69 -3
  167. package/modern/presets/useSelectWithApply/options-list-with-apply/footer/index.css +3 -3
  168. package/modern/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js +1 -1
  169. package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.css +3 -3
  170. package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js +1 -1
  171. package/modern/presets/useSelectWithLoading/index.css +1 -1
  172. package/modern/presets/useSelectWithLoading/index.module.css.js +1 -1
  173. package/modern/typings.d.ts +1 -1
  174. package/moderncssm/components/base-select/Component.d.ts +1 -1
  175. package/moderncssm/components/base-select/Component.js +2 -2
  176. package/moderncssm/components/base-select/Component.js.map +1 -1
  177. package/moderncssm/components/options-list/Component.d.ts +35 -2
  178. package/moderncssm/components/options-list/Component.js +6 -6
  179. package/moderncssm/components/options-list/Component.js.map +1 -1
  180. package/moderncssm/components/search/Component.js +17 -1
  181. package/moderncssm/components/search/Component.js.map +1 -1
  182. package/moderncssm/components/virtual-options-list/Component.d.ts +35 -2
  183. package/moderncssm/components/virtual-options-list/Component.js +6 -7
  184. package/moderncssm/components/virtual-options-list/Component.js.map +1 -1
  185. package/moderncssm/hooks/use-native-scrollbar.d.ts +4 -0
  186. package/moderncssm/hooks/use-native-scrollbar.js +27 -0
  187. package/moderncssm/hooks/use-native-scrollbar.js.map +1 -0
  188. package/moderncssm/presets/useSelectWithApply/hook.d.ts +137 -5
  189. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +69 -3
  190. package/moderncssm/typings.d.ts +1 -1
  191. package/package.json +4 -4
  192. package/presets/useSelectWithApply/hook.d.ts +137 -5
  193. package/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +69 -3
  194. package/presets/useSelectWithApply/options-list-with-apply/footer/index.css +3 -3
  195. package/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js +1 -1
  196. package/presets/useSelectWithApply/options-list-with-apply/header/index.css +3 -3
  197. package/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js +1 -1
  198. package/presets/useSelectWithLoading/index.css +1 -1
  199. package/presets/useSelectWithLoading/index.module.css.js +1 -1
  200. package/src/components/base-select/Component.tsx +2 -0
  201. package/src/components/options-list/Component.tsx +6 -8
  202. package/src/components/search/Component.tsx +29 -10
  203. package/src/components/virtual-options-list/Component.tsx +6 -9
  204. package/src/hooks/use-native-scrollbar.ts +36 -0
  205. package/src/typings.ts +1 -1
  206. 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":["forwardRef","DefaultOptgroup","DEFAULT_VISIBLE_OPTIONS","useRef","useState","usePrevious","useMatchMedia","isClient","useVirtual","useEffect","lastIndexOf","useVirtualVisibleOptions","useMemo","isGroup","React","cn","styles","__assign","Scrollbar","mergeRefs","SIZE_TO_CLASSNAME_MAP"],"mappings":"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"}
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":["forwardRef","DefaultOptgroup","DEFAULT_VISIBLE_OPTIONS","useRef","useState","usePrevious","useVirtual","useNativeScrollbar","useEffect","lastIndexOf","useVirtualVisibleOptions","useMemo","isGroup","React","cn","styles","__assign","Scrollbar","mergeRefs","SIZE_TO_CLASSNAME_MAP"],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import { type OptionsListProps } from '../typings';
2
+ declare type Params = Pick<OptionsListProps, 'nativeScrollbar' | 'client'>;
3
+ export declare const useNativeScrollbar: (params: Params) => boolean;
4
+ export {};
@@ -0,0 +1,33 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var cssm = require('@alfalab/core-components-mq/cssm');
6
+ var cssm$1 = require('@alfalab/core-components-shared/cssm');
7
+
8
+ var useNativeScrollbar = function (params) {
9
+ var scrollbarByProp = params.nativeScrollbar, client = params.client;
10
+ var query = '(max-width: 1023px)';
11
+ var nativeScrollbar = cssm.useMatchMedia(query, function () {
12
+ return cssm$1.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,kBAAa,CAAC,KAAK,EAAE,YAAA;AAC3C,QAAA,OAAAC,eAAQ,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").OptionsListProps & {
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").OptionsListProps & import("react").RefAttributes<HTMLDivElement>> | undefined;
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").OptionsListProps & import("react").RefAttributes<HTMLDivElement>> | undefined;
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").OptionsListProps & import("react").RefAttributes<HTMLDivElement>> | undefined;
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, type OptionsListProps } from '../../../typings';
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<OptionsListProps & {
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<OptionsListProps & React.RefAttributes<HTMLDivElement>> | undefined;
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;
package/cssm/typings.d.ts CHANGED
@@ -410,7 +410,7 @@ export declare type ArrowProps = {
410
410
  */
411
411
  size?: BaseSelectProps['size'];
412
412
  };
413
- export declare type OptionsListProps = {
413
+ export declare type OptionsListProps = Pick<SelectProps, 'client'> & {
414
414
  /**
415
415
  * Дополнительный класс
416
416
  */
@@ -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
- } .select__arrow_1yce3 {
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
- } .select__arrow_1yce3.select__disabled_1yce3 {
18
+ } .select__arrow_1p3an.select__disabled_1p3an {
19
19
  color: var(--select-arrow-disabled-color);
20
- } .select__arrow_1yce3.select__size-40_1yce3 {
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
- } .select__open_1yce3 {
25
+ } .select__open_1p3an {
26
26
  transform: var(--arrow-transform);
27
27
  }
@@ -1,6 +1,6 @@
1
1
  import './index.css';
2
2
 
3
- var styles = {"arrow":"select__arrow_1yce3","disabled":"select__disabled_1yce3","size-40":"select__size-40_1yce3","open":"select__open_1yce3"};
3
+ var 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
@@ -1,15 +1,15 @@
1
- .select__checkmark_1vgll {
1
+ .select__checkmark_5okzd {
2
2
  flex-shrink: 0;
3
3
  box-sizing: border-box;
4
- } .select__checkmark_1vgll.select__start_1vgll {
4
+ } .select__checkmark_5okzd.select__start_5okzd {
5
5
  align-self: start;
6
- } .select__checkmark_1vgll.select__center_1vgll {
6
+ } .select__checkmark_5okzd.select__center_5okzd {
7
7
  align-self: center;
8
- } .select__single_1vgll {
8
+ } .select__single_5okzd {
9
9
  display: flex;
10
10
  align-items: center;
11
11
  justify-content: center;
12
12
  opacity: 0;
13
- } .select__single_1vgll.select__selected_1vgll {
13
+ } .select__single_5okzd.select__selected_5okzd {
14
14
  opacity: 1;
15
15
  }
@@ -1,6 +1,6 @@
1
1
  import './index.css';
2
2
 
3
- var styles = {"checkmark":"select__checkmark_1vgll","start":"select__start_1vgll","center":"select__center_1vgll","single":"select__single_1vgll","selected":"select__selected_1vgll"};
3
+ var styles = {"checkmark":"select__checkmark_5okzd","start":"select__start_5okzd","center":"select__center_5okzd","single":"select__single_5okzd","selected":"select__selected_5okzd"};
4
4
 
5
5
  export { styles as default };
6
6
  //# sourceMappingURL=index.module.css.js.map
@@ -26,7 +26,7 @@
26
26
  --select-option-hover-color: var(--color-light-text-primary);
27
27
  --select-option-active-color: var(--color-light-text-primary);
28
28
  --select-option-disabled-color: var(--color-light-text-secondary);
29
- } .select__option_y50qw {
29
+ } .select__option_cfbis {
30
30
  font-size: 16px;
31
31
  line-height: 20px;
32
32
  font-weight: 400;
@@ -40,41 +40,41 @@
40
40
  position: relative;
41
41
  cursor: pointer;
42
42
  min-height: var(--size-s-height);
43
- } .select__option_y50qw:not(.select__disabled_y50qw):active {
43
+ } .select__option_cfbis:not(.select__disabled_cfbis):active {
44
44
  background: var(--select-option-active-background);
45
45
  color: var(--select-option-active-color);
46
- } .select__option_y50qw.select__checkmarkBefore_y50qw {
46
+ } .select__option_cfbis.select__checkmarkBefore_cfbis {
47
47
  padding: var(--gap-0) var(--gap-0) var(--gap-0) var(--gap-12);
48
- } .select__option_y50qw.select__checkmarkBefore_y50qw.select__mobile_y50qw {
48
+ } .select__option_cfbis.select__checkmarkBefore_cfbis.select__mobile_cfbis {
49
49
  padding-left: var(--gap-16);
50
- } .select__option_y50qw.select__checkmarkAfter_y50qw.select__checkmarkAfter_y50qw {
50
+ } .select__option_cfbis.select__checkmarkAfter_cfbis.select__checkmarkAfter_cfbis {
51
51
  padding: var(--gap-0) var(--gap-12) var(--gap-0) var(--gap-0);
52
- } .select__option_y50qw.select__checkmarkAfter_y50qw.select__checkmarkAfter_y50qw.select__size-72_y50qw {
52
+ } .select__option_cfbis.select__checkmarkAfter_cfbis.select__checkmarkAfter_cfbis.select__size-72_cfbis {
53
53
  padding-right: var(--gap-16);
54
- } .select__option_y50qw.select__checkmarkAfter_y50qw.select__checkmarkAfter_y50qw.select__mobile_y50qw {
54
+ } .select__option_cfbis.select__checkmarkAfter_cfbis.select__checkmarkAfter_cfbis.select__mobile_cfbis {
55
55
  padding-right: var(--gap-20);
56
- } .select__option_y50qw.select__textContent_y50qw {
56
+ } .select__option_cfbis.select__textContent_cfbis {
57
57
  padding: var(--gap-12);
58
- } .select__option_y50qw.select__textContent_y50qw.select__size-72_y50qw {
58
+ } .select__option_cfbis.select__textContent_cfbis.select__size-72_cfbis {
59
59
  padding-left: var(--gap-16);
60
60
  padding-right: var(--gap-16);
61
- } .select__option_y50qw.select__textContent_y50qw.select__mobile_y50qw {
61
+ } .select__option_cfbis.select__textContent_cfbis.select__mobile_cfbis {
62
62
  padding: var(--gap-16) var(--gap-20) var(--gap-16) var(--gap-16);
63
- } .select__selected_y50qw {
63
+ } .select__selected_cfbis {
64
64
  background: var(--select-option-selected-background);
65
65
  color: var(--select-option-selected-color);
66
66
  cursor: default;
67
- } .select__highlighted_y50qw {
67
+ } .select__highlighted_cfbis {
68
68
  background: var(--select-option-hover-background);
69
69
  color: var(--select-option-hover-color);
70
- } .select__disabled_y50qw {
70
+ } .select__disabled_cfbis {
71
71
  cursor: var(--disabled-cursor);
72
72
  background: var(--select-option-disabled-background);
73
73
  color: var(--select-option-disabled-color);
74
- } .select__checkmarkBeforeContent_y50qw {
74
+ } .select__checkmarkBeforeContent_cfbis {
75
75
  margin-right: var(--gap-12);
76
- } .select__checkmarkAfterContent_y50qw {
76
+ } .select__checkmarkAfterContent_cfbis {
77
77
  margin-left: var(--gap-12);
78
- } .select__content_y50qw {
78
+ } .select__content_cfbis {
79
79
  flex: 1;
80
80
  }
@@ -1,6 +1,6 @@
1
1
  import './index.css';
2
2
 
3
- var styles = {"option":"select__option_y50qw","disabled":"select__disabled_y50qw","checkmarkBefore":"select__checkmarkBefore_y50qw","mobile":"select__mobile_y50qw","checkmarkAfter":"select__checkmarkAfter_y50qw","size-72":"select__size-72_y50qw","textContent":"select__textContent_y50qw","selected":"select__selected_y50qw","highlighted":"select__highlighted_y50qw","checkmarkBeforeContent":"select__checkmarkBeforeContent_y50qw","checkmarkAfterContent":"select__checkmarkAfterContent_y50qw","content":"select__content_y50qw"};
3
+ var styles = {"option":"select__option_cfbis","disabled":"select__disabled_cfbis","checkmarkBefore":"select__checkmarkBefore_cfbis","mobile":"select__mobile_cfbis","checkmarkAfter":"select__checkmarkAfter_cfbis","size-72":"select__size-72_cfbis","textContent":"select__textContent_cfbis","selected":"select__selected_cfbis","highlighted":"select__highlighted_cfbis","checkmarkBeforeContent":"select__checkmarkBeforeContent_cfbis","checkmarkAfterContent":"select__checkmarkAfterContent_cfbis","content":"select__content_cfbis"};
4
4
 
5
5
  export { styles as default };
6
6
  //# sourceMappingURL=index.module.css.js.map
@@ -1,7 +1,7 @@
1
1
  import React from 'react';
2
2
  export declare const BaseSelect: React.ForwardRefExoticComponent<import("../../typings").BaseSelectProps & import("../../typings").AdditionalMobileProps & import("../../typings").BottomSheetSelectMobileProps & import("../../typings").ModalSelectMobileProps & {
3
3
  isBottomSheet?: boolean | undefined;
4
- view: "mobile" | "desktop";
4
+ view: "desktop" | "mobile";
5
5
  Popover?: React.ForwardRefExoticComponent<import("@alfalab/core-components-popover").PopoverProps & React.RefAttributes<HTMLDivElement>> | undefined;
6
6
  BottomSheet?: React.ForwardRefExoticComponent<import("@alfalab/core-components-bottom-sheet").BottomSheetProps & React.RefAttributes<HTMLDivElement>> | undefined;
7
7
  ModalMobile?: (React.ForwardRefExoticComponent<import("@alfalab/core-components-modal/typings").ModalMobileProps & React.RefAttributes<HTMLDivElement>> & {
@@ -363,7 +363,7 @@ function (props, ref) {
363
363
  return (React.createElement(Search, __assign({}, searchProps === null || searchProps === void 0 ? void 0 : searchProps.componentProps, { onBlur: handleBlur, value: search, onChange: handleChange, dataTestId: getDataTestId(dataTestId, 'search'), onClear: handleClear, className: cn((_b = searchProps === null || searchProps === void 0 ? void 0 : searchProps.componentProps) === null || _b === void 0 ? void 0 : _b.className, (_a = {},
364
364
  _a[styles.search] = view === 'desktop',
365
365
  _a[mobileStyles.search] = view === 'mobile',
366
- _a), size && styles[SIZE_TO_CLASSNAME_MAP[size]]), ref: mergeRefs([searchRef, ((_c = searchProps === null || searchProps === void 0 ? void 0 : searchProps.componentProps) === null || _c === void 0 ? void 0 : _c.ref) || null]) })));
366
+ _a), size && styles[SIZE_TO_CLASSNAME_MAP[size]]), ref: mergeRefs([searchRef, ((_c = searchProps === null || searchProps === void 0 ? void 0 : searchProps.componentProps) === null || _c === void 0 ? void 0 : _c.ref) || null]), client: view })));
367
367
  };
368
368
  var _12 = optionsListProps, header = _12.header, emptyPlaceholder = _12.emptyPlaceholder;
369
369
  var renderOptionsListHeader = function () {
@@ -391,7 +391,7 @@ function (props, ref) {
391
391
  return (React.createElement("div", __assign({}, menuProps, { ref: view === 'desktop' ? menuRef : undefined, className: cn(optionsListClassName, view === 'mobile' && mobileStyles.optionsListWrapper, view === 'desktop' && styles.optionsListWrapper) }),
392
392
  React.createElement(OptionsList, __assign({}, listProps, { ref: view === 'desktop' ? listProps.ref : scrollableContainerRef, setHighlightedIndex: view === 'desktop' ? setHighlightedIndex : undefined, className: cn((_a = {}, _a[mobileStyles.optionsList] = view === 'mobile', _a), listProps.className), scrollbarClassName: cn((_b = {}, _b[mobileStyles.scrollbar] = view === 'mobile', _b), listProps.scrollbarClassName), optionsListWidth: optionsListWidth, flatOptions: flatOptions, highlightedIndex: highlightedIndex, open: open, size: size, options: filteredOptions, Optgroup: Optgroup, Option: Option, selectedItems: selectedItems, setSelectedItems: setSelectedItems, toggleMenu: toggleMenu, groupOptionProps: groupOptionProps, getOptionProps: getOptionProps, visibleOptions: view === 'desktop' ? visibleOptions : 0, dataTestId: getDataTestId(dataTestId, 'options-list'), header: renderOptionsListHeader(), optionGroupClassName: cn(optionGroupClassName, (_c = {},
393
393
  _c[mobileStyles.optionGroup] = view === 'mobile',
394
- _c)), emptyPlaceholder: renderEmptyPlaceholder(), onScroll: onScroll, search: search, multiple: multiple, limitDynamicOptionGroupSize: limitDynamicOptionGroupSize })),
394
+ _c)), emptyPlaceholder: renderEmptyPlaceholder(), onScroll: onScroll, search: search, multiple: multiple, limitDynamicOptionGroupSize: limitDynamicOptionGroupSize, client: view })),
395
395
  view === 'desktop' && React.createElement("div", { className: styles.optionsListBorder })));
396
396
  };
397
397
  var renderInPopover = function () {