@alfalab/core-components-select 18.0.1 → 18.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (573) hide show
  1. package/Component.responsive.d.ts +1 -1
  2. package/Component.responsive.js.map +1 -1
  3. package/components/arrow/Component.d.ts +1 -1
  4. package/components/arrow/Component.js.map +1 -1
  5. package/components/arrow/index.css +11 -7
  6. package/components/arrow/index.module.css.js +1 -1
  7. package/components/arrow/index.module.css.js.map +1 -1
  8. package/components/base-checkmark/Component.d.ts +1 -1
  9. package/components/base-checkmark/Component.js.map +1 -1
  10. package/components/base-checkmark/index.css +7 -7
  11. package/components/base-checkmark/index.module.css.js +1 -1
  12. package/components/base-checkmark/index.module.css.js.map +1 -1
  13. package/components/base-option/Component.d.ts +2 -2
  14. package/components/base-option/Component.js.map +1 -1
  15. package/components/base-option/index.css +20 -20
  16. package/components/base-option/index.module.css.js +1 -1
  17. package/components/base-option/index.module.css.js.map +1 -1
  18. package/components/base-select/Component.js +18 -14
  19. package/components/base-select/Component.js.map +1 -1
  20. package/components/base-select/index.css +16 -14
  21. package/components/base-select/index.module.css.js +1 -1
  22. package/components/base-select/index.module.css.js.map +1 -1
  23. package/components/base-select/mobile.css +13 -13
  24. package/components/base-select/mobile.module.css.js +1 -1
  25. package/components/base-select/mobile.module.css.js.map +1 -1
  26. package/components/base-select/types/component-types.d.ts +7 -7
  27. package/components/checkmark/Component.d.ts +1 -1
  28. package/components/checkmark/Component.js.map +1 -1
  29. package/components/checkmark/index.css +13 -13
  30. package/components/checkmark/index.module.css.js +1 -1
  31. package/components/checkmark/index.module.css.js.map +1 -1
  32. package/components/checkmark-mobile/Component.d.ts +1 -1
  33. package/components/checkmark-mobile/Component.js.map +1 -1
  34. package/components/checkmark-mobile/index.css +6 -6
  35. package/components/checkmark-mobile/index.module.css.js +1 -1
  36. package/components/checkmark-mobile/index.module.css.js.map +1 -1
  37. package/components/clear-button/Component.d.ts +1 -1
  38. package/components/clear-button/Component.js.map +1 -1
  39. package/components/clear-button/index.css +5 -5
  40. package/components/clear-button/index.module.css.js +1 -1
  41. package/components/field/Component.d.ts +3 -3
  42. package/components/field/Component.js +12 -5
  43. package/components/field/Component.js.map +1 -1
  44. package/components/field/index.css +16 -16
  45. package/components/field/index.module.css.js +1 -1
  46. package/components/field/index.module.css.js.map +1 -1
  47. package/components/footer/index.css +5 -5
  48. package/components/footer/index.module.css.js +1 -1
  49. package/components/footer/index.module.css.js.map +1 -1
  50. package/components/native-select/Component.d.ts +2 -2
  51. package/components/native-select/Component.js.map +1 -1
  52. package/components/optgroup/Component.d.ts +1 -1
  53. package/components/optgroup/Component.js.map +1 -1
  54. package/components/optgroup/index.css +5 -5
  55. package/components/optgroup/index.module.css.js +1 -1
  56. package/components/optgroup/index.module.css.js.map +1 -1
  57. package/components/option/Component.d.ts +2 -2
  58. package/components/option/Component.js.map +1 -1
  59. package/components/option/Component.responsive.d.ts +1 -1
  60. package/components/option/Component.responsive.js.map +1 -1
  61. package/components/option/desktop/Component.d.ts +1 -1
  62. package/components/option/desktop/Component.js.map +1 -1
  63. package/components/option/desktop/index.css +23 -24
  64. package/components/option/desktop/index.module.css.js +1 -1
  65. package/components/option/desktop/index.module.css.js.map +1 -1
  66. package/components/option/mobile/Component.d.ts +1 -1
  67. package/components/option/mobile/Component.js.map +1 -1
  68. package/components/option/mobile/index.css +19 -20
  69. package/components/option/mobile/index.module.css.js +1 -1
  70. package/components/option/mobile/index.module.css.js.map +1 -1
  71. package/components/options-list/Component.d.ts +1 -1
  72. package/components/options-list/Component.js.map +1 -1
  73. package/components/options-list/index.css +11 -11
  74. package/components/options-list/index.module.css.js +1 -1
  75. package/components/options-list/index.module.css.js.map +1 -1
  76. package/components/search/Component.d.ts +1 -1
  77. package/components/search/Component.js.map +1 -1
  78. package/components/search/index.css +1 -1
  79. package/components/search/index.module.css.js +1 -1
  80. package/components/search/index.module.css.js.map +1 -1
  81. package/components/virtual-options-list/Component.d.ts +1 -1
  82. package/components/virtual-options-list/Component.js.map +1 -1
  83. package/components/virtual-options-list/index.css +15 -15
  84. package/components/virtual-options-list/index.module.css.js +1 -1
  85. package/components/virtual-options-list/index.module.css.js.map +1 -1
  86. package/consts.d.ts +1 -0
  87. package/consts.js +2 -0
  88. package/consts.js.map +1 -1
  89. package/cssm/Component.responsive.d.ts +1 -1
  90. package/cssm/Component.responsive.js.map +1 -1
  91. package/cssm/components/arrow/Component.d.ts +1 -1
  92. package/cssm/components/arrow/Component.js.map +1 -1
  93. package/cssm/components/arrow/index.module.css +7 -3
  94. package/cssm/components/base-checkmark/Component.d.ts +1 -1
  95. package/cssm/components/base-checkmark/Component.js.map +1 -1
  96. package/cssm/components/base-checkmark/index.module.css +2 -2
  97. package/cssm/components/base-option/Component.d.ts +2 -2
  98. package/cssm/components/base-option/Component.js.map +1 -1
  99. package/cssm/components/base-option/index.module.css +4 -4
  100. package/cssm/components/base-select/Component.js +18 -14
  101. package/cssm/components/base-select/Component.js.map +1 -1
  102. package/cssm/components/base-select/index.module.css +5 -3
  103. package/cssm/components/base-select/mobile.module.css +2 -2
  104. package/cssm/components/base-select/types/component-types.d.ts +7 -7
  105. package/cssm/components/checkmark/Component.d.ts +1 -1
  106. package/cssm/components/checkmark/Component.js.map +1 -1
  107. package/cssm/components/checkmark/index.module.css +4 -4
  108. package/cssm/components/checkmark-mobile/Component.d.ts +1 -1
  109. package/cssm/components/checkmark-mobile/Component.js.map +1 -1
  110. package/cssm/components/checkmark-mobile/index.module.css +1 -1
  111. package/cssm/components/clear-button/Component.d.ts +1 -1
  112. package/cssm/components/clear-button/Component.js.map +1 -1
  113. package/cssm/components/clear-button/index.module.css +1 -1
  114. package/cssm/components/field/Component.d.ts +3 -3
  115. package/cssm/components/field/Component.js +12 -5
  116. package/cssm/components/field/Component.js.map +1 -1
  117. package/cssm/components/field/index.module.css +4 -4
  118. package/cssm/components/footer/index.module.css +1 -1
  119. package/cssm/components/native-select/Component.d.ts +2 -2
  120. package/cssm/components/native-select/Component.js.map +1 -1
  121. package/cssm/components/optgroup/Component.d.ts +1 -1
  122. package/cssm/components/optgroup/Component.js.map +1 -1
  123. package/cssm/components/optgroup/index.module.css +1 -1
  124. package/cssm/components/option/Component.d.ts +2 -2
  125. package/cssm/components/option/Component.js.map +1 -1
  126. package/cssm/components/option/Component.responsive.d.ts +1 -1
  127. package/cssm/components/option/Component.responsive.js.map +1 -1
  128. package/cssm/components/option/desktop/Component.d.ts +1 -1
  129. package/cssm/components/option/desktop/Component.js.map +1 -1
  130. package/cssm/components/option/desktop/index.module.css +4 -5
  131. package/cssm/components/option/mobile/Component.d.ts +1 -1
  132. package/cssm/components/option/mobile/Component.js.map +1 -1
  133. package/cssm/components/option/mobile/index.module.css +3 -4
  134. package/cssm/components/options-list/Component.d.ts +1 -1
  135. package/cssm/components/options-list/Component.js.map +1 -1
  136. package/cssm/components/options-list/index.module.css +2 -2
  137. package/cssm/components/search/Component.d.ts +1 -1
  138. package/cssm/components/search/Component.js.map +1 -1
  139. package/cssm/components/virtual-options-list/Component.d.ts +1 -1
  140. package/cssm/components/virtual-options-list/Component.js.map +1 -1
  141. package/cssm/components/virtual-options-list/index.module.css +2 -2
  142. package/cssm/consts.d.ts +1 -0
  143. package/cssm/consts.js +2 -0
  144. package/cssm/consts.js.map +1 -1
  145. package/cssm/desktop/Component.desktop.js.map +1 -1
  146. package/cssm/mobile/Component.mobile.d.ts +1 -1
  147. package/cssm/mobile/Component.mobile.js.map +1 -1
  148. package/cssm/mobile/Component.modal.mobile.js.map +1 -1
  149. package/cssm/presets/index.js +0 -1
  150. package/cssm/presets/index.js.map +1 -1
  151. package/cssm/presets/useLazyLoading/hook.d.ts +1 -1
  152. package/cssm/presets/useLazyLoading/hook.js.map +1 -1
  153. package/cssm/presets/useSelectWithApply/hook.d.ts +1 -2
  154. package/cssm/presets/useSelectWithApply/hook.js +4 -5
  155. package/cssm/presets/useSelectWithApply/hook.js.map +1 -1
  156. package/cssm/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +3 -3
  157. package/cssm/presets/useSelectWithApply/options-list-with-apply/Component.js +1 -2
  158. package/cssm/presets/useSelectWithApply/options-list-with-apply/Component.js.map +1 -1
  159. package/cssm/presets/useSelectWithApply/options-list-with-apply/footer/Component.d.ts +1 -1
  160. package/cssm/presets/useSelectWithApply/options-list-with-apply/footer/Component.js.map +1 -1
  161. package/cssm/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css +1 -1
  162. package/cssm/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +2 -2
  163. package/cssm/presets/useSelectWithApply/options-list-with-apply/header/Component.js.map +1 -1
  164. package/cssm/presets/useSelectWithApply/options-list-with-apply/header/index.module.css +1 -1
  165. package/cssm/presets/useSelectWithLoading/hook.d.ts +1 -1
  166. package/cssm/presets/useSelectWithLoading/hook.js.map +1 -1
  167. package/cssm/shared/index.js +0 -1
  168. package/cssm/shared/index.js.map +1 -1
  169. package/cssm/typings.d.ts +14 -8
  170. package/cssm/utils.d.ts +2 -2
  171. package/cssm/utils.js.map +1 -1
  172. package/desktop/Component.desktop.js.map +1 -1
  173. package/esm/Component.responsive.d.ts +1 -1
  174. package/esm/Component.responsive.js.map +1 -1
  175. package/esm/components/arrow/Component.d.ts +1 -1
  176. package/esm/components/arrow/Component.js.map +1 -1
  177. package/esm/components/arrow/index.css +11 -7
  178. package/esm/components/arrow/index.module.css.js +1 -1
  179. package/esm/components/arrow/index.module.css.js.map +1 -1
  180. package/esm/components/base-checkmark/Component.d.ts +1 -1
  181. package/esm/components/base-checkmark/Component.js.map +1 -1
  182. package/esm/components/base-checkmark/index.css +7 -7
  183. package/esm/components/base-checkmark/index.module.css.js +1 -1
  184. package/esm/components/base-checkmark/index.module.css.js.map +1 -1
  185. package/esm/components/base-option/Component.d.ts +2 -2
  186. package/esm/components/base-option/Component.js.map +1 -1
  187. package/esm/components/base-option/index.css +20 -20
  188. package/esm/components/base-option/index.module.css.js +1 -1
  189. package/esm/components/base-option/index.module.css.js.map +1 -1
  190. package/esm/components/base-select/Component.js +19 -15
  191. package/esm/components/base-select/Component.js.map +1 -1
  192. package/esm/components/base-select/index.css +16 -14
  193. package/esm/components/base-select/index.module.css.js +1 -1
  194. package/esm/components/base-select/index.module.css.js.map +1 -1
  195. package/esm/components/base-select/mobile.css +13 -13
  196. package/esm/components/base-select/mobile.module.css.js +1 -1
  197. package/esm/components/base-select/mobile.module.css.js.map +1 -1
  198. package/esm/components/base-select/types/component-types.d.ts +7 -7
  199. package/esm/components/checkmark/Component.d.ts +1 -1
  200. package/esm/components/checkmark/Component.js.map +1 -1
  201. package/esm/components/checkmark/index.css +13 -13
  202. package/esm/components/checkmark/index.module.css.js +1 -1
  203. package/esm/components/checkmark/index.module.css.js.map +1 -1
  204. package/esm/components/checkmark-mobile/Component.d.ts +1 -1
  205. package/esm/components/checkmark-mobile/Component.js.map +1 -1
  206. package/esm/components/checkmark-mobile/index.css +6 -6
  207. package/esm/components/checkmark-mobile/index.module.css.js +1 -1
  208. package/esm/components/checkmark-mobile/index.module.css.js.map +1 -1
  209. package/esm/components/clear-button/Component.d.ts +1 -1
  210. package/esm/components/clear-button/Component.js.map +1 -1
  211. package/esm/components/clear-button/index.css +5 -5
  212. package/esm/components/clear-button/index.module.css.js +1 -1
  213. package/esm/components/field/Component.d.ts +3 -3
  214. package/esm/components/field/Component.js +13 -6
  215. package/esm/components/field/Component.js.map +1 -1
  216. package/esm/components/field/index.css +16 -16
  217. package/esm/components/field/index.module.css.js +1 -1
  218. package/esm/components/field/index.module.css.js.map +1 -1
  219. package/esm/components/footer/index.css +5 -5
  220. package/esm/components/footer/index.module.css.js +1 -1
  221. package/esm/components/footer/index.module.css.js.map +1 -1
  222. package/esm/components/native-select/Component.d.ts +2 -2
  223. package/esm/components/native-select/Component.js.map +1 -1
  224. package/esm/components/optgroup/Component.d.ts +1 -1
  225. package/esm/components/optgroup/Component.js.map +1 -1
  226. package/esm/components/optgroup/index.css +5 -5
  227. package/esm/components/optgroup/index.module.css.js +1 -1
  228. package/esm/components/optgroup/index.module.css.js.map +1 -1
  229. package/esm/components/option/Component.d.ts +2 -2
  230. package/esm/components/option/Component.js.map +1 -1
  231. package/esm/components/option/Component.responsive.d.ts +1 -1
  232. package/esm/components/option/Component.responsive.js.map +1 -1
  233. package/esm/components/option/desktop/Component.d.ts +1 -1
  234. package/esm/components/option/desktop/Component.js.map +1 -1
  235. package/esm/components/option/desktop/index.css +23 -24
  236. package/esm/components/option/desktop/index.module.css.js +1 -1
  237. package/esm/components/option/desktop/index.module.css.js.map +1 -1
  238. package/esm/components/option/mobile/Component.d.ts +1 -1
  239. package/esm/components/option/mobile/Component.js.map +1 -1
  240. package/esm/components/option/mobile/index.css +19 -20
  241. package/esm/components/option/mobile/index.module.css.js +1 -1
  242. package/esm/components/option/mobile/index.module.css.js.map +1 -1
  243. package/esm/components/options-list/Component.d.ts +1 -1
  244. package/esm/components/options-list/Component.js.map +1 -1
  245. package/esm/components/options-list/index.css +11 -11
  246. package/esm/components/options-list/index.module.css.js +1 -1
  247. package/esm/components/options-list/index.module.css.js.map +1 -1
  248. package/esm/components/search/Component.d.ts +1 -1
  249. package/esm/components/search/Component.js.map +1 -1
  250. package/esm/components/search/index.css +1 -1
  251. package/esm/components/search/index.module.css.js +1 -1
  252. package/esm/components/search/index.module.css.js.map +1 -1
  253. package/esm/components/virtual-options-list/Component.d.ts +1 -1
  254. package/esm/components/virtual-options-list/Component.js.map +1 -1
  255. package/esm/components/virtual-options-list/index.css +15 -15
  256. package/esm/components/virtual-options-list/index.module.css.js +1 -1
  257. package/esm/components/virtual-options-list/index.module.css.js.map +1 -1
  258. package/esm/consts.d.ts +1 -0
  259. package/esm/consts.js +2 -1
  260. package/esm/consts.js.map +1 -1
  261. package/esm/desktop/Component.desktop.js.map +1 -1
  262. package/esm/mobile/Component.mobile.d.ts +1 -1
  263. package/esm/mobile/Component.mobile.js.map +1 -1
  264. package/esm/mobile/Component.modal.mobile.js.map +1 -1
  265. package/esm/presets/index.js +1 -1
  266. package/esm/presets/useLazyLoading/hook.d.ts +1 -1
  267. package/esm/presets/useLazyLoading/hook.js.map +1 -1
  268. package/esm/presets/useSelectWithApply/hook.d.ts +1 -2
  269. package/esm/presets/useSelectWithApply/hook.js +2 -2
  270. package/esm/presets/useSelectWithApply/hook.js.map +1 -1
  271. package/esm/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +3 -3
  272. package/esm/presets/useSelectWithApply/options-list-with-apply/Component.js +1 -2
  273. package/esm/presets/useSelectWithApply/options-list-with-apply/Component.js.map +1 -1
  274. package/esm/presets/useSelectWithApply/options-list-with-apply/footer/Component.d.ts +1 -1
  275. package/esm/presets/useSelectWithApply/options-list-with-apply/footer/Component.js.map +1 -1
  276. package/esm/presets/useSelectWithApply/options-list-with-apply/footer/index.css +4 -4
  277. package/esm/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js +1 -1
  278. package/esm/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js.map +1 -1
  279. package/esm/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +2 -2
  280. package/esm/presets/useSelectWithApply/options-list-with-apply/header/Component.js.map +1 -1
  281. package/esm/presets/useSelectWithApply/options-list-with-apply/header/index.css +4 -4
  282. package/esm/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js +1 -1
  283. package/esm/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js.map +1 -1
  284. package/esm/presets/useSelectWithLoading/hook.d.ts +1 -1
  285. package/esm/presets/useSelectWithLoading/hook.js.map +1 -1
  286. package/esm/presets/useSelectWithLoading/index.css +1 -1
  287. package/esm/presets/useSelectWithLoading/index.module.css.js +1 -1
  288. package/esm/shared/index.js +1 -1
  289. package/esm/typings.d.ts +14 -8
  290. package/esm/utils.d.ts +2 -2
  291. package/esm/utils.js.map +1 -1
  292. package/mobile/Component.mobile.d.ts +1 -1
  293. package/mobile/Component.mobile.js.map +1 -1
  294. package/mobile/Component.modal.mobile.js.map +1 -1
  295. package/modern/Component.responsive.d.ts +1 -1
  296. package/modern/Component.responsive.js.map +1 -1
  297. package/modern/components/arrow/Component.d.ts +1 -1
  298. package/modern/components/arrow/Component.js.map +1 -1
  299. package/modern/components/arrow/index.css +11 -7
  300. package/modern/components/arrow/index.module.css.js +1 -1
  301. package/modern/components/arrow/index.module.css.js.map +1 -1
  302. package/modern/components/base-checkmark/Component.d.ts +1 -1
  303. package/modern/components/base-checkmark/Component.js.map +1 -1
  304. package/modern/components/base-checkmark/index.css +7 -7
  305. package/modern/components/base-checkmark/index.module.css.js +1 -1
  306. package/modern/components/base-checkmark/index.module.css.js.map +1 -1
  307. package/modern/components/base-option/Component.d.ts +2 -2
  308. package/modern/components/base-option/Component.js.map +1 -1
  309. package/modern/components/base-option/index.css +20 -20
  310. package/modern/components/base-option/index.module.css.js +1 -1
  311. package/modern/components/base-option/index.module.css.js.map +1 -1
  312. package/modern/components/base-select/Component.js +7 -5
  313. package/modern/components/base-select/Component.js.map +1 -1
  314. package/modern/components/base-select/index.css +16 -14
  315. package/modern/components/base-select/index.module.css.js +1 -1
  316. package/modern/components/base-select/index.module.css.js.map +1 -1
  317. package/modern/components/base-select/mobile.css +13 -13
  318. package/modern/components/base-select/mobile.module.css.js +1 -1
  319. package/modern/components/base-select/mobile.module.css.js.map +1 -1
  320. package/modern/components/base-select/types/component-types.d.ts +7 -7
  321. package/modern/components/checkmark/Component.d.ts +1 -1
  322. package/modern/components/checkmark/Component.js.map +1 -1
  323. package/modern/components/checkmark/index.css +13 -13
  324. package/modern/components/checkmark/index.module.css.js +1 -1
  325. package/modern/components/checkmark/index.module.css.js.map +1 -1
  326. package/modern/components/checkmark-mobile/Component.d.ts +1 -1
  327. package/modern/components/checkmark-mobile/Component.js.map +1 -1
  328. package/modern/components/checkmark-mobile/index.css +6 -6
  329. package/modern/components/checkmark-mobile/index.module.css.js +1 -1
  330. package/modern/components/checkmark-mobile/index.module.css.js.map +1 -1
  331. package/modern/components/clear-button/Component.d.ts +1 -1
  332. package/modern/components/clear-button/Component.js.map +1 -1
  333. package/modern/components/clear-button/index.css +5 -5
  334. package/modern/components/clear-button/index.module.css.js +1 -1
  335. package/modern/components/field/Component.d.ts +3 -3
  336. package/modern/components/field/Component.js +13 -6
  337. package/modern/components/field/Component.js.map +1 -1
  338. package/modern/components/field/index.css +16 -16
  339. package/modern/components/field/index.module.css.js +1 -1
  340. package/modern/components/field/index.module.css.js.map +1 -1
  341. package/modern/components/footer/index.css +5 -5
  342. package/modern/components/footer/index.module.css.js +1 -1
  343. package/modern/components/footer/index.module.css.js.map +1 -1
  344. package/modern/components/native-select/Component.d.ts +2 -2
  345. package/modern/components/native-select/Component.js.map +1 -1
  346. package/modern/components/optgroup/Component.d.ts +1 -1
  347. package/modern/components/optgroup/Component.js.map +1 -1
  348. package/modern/components/optgroup/index.css +5 -5
  349. package/modern/components/optgroup/index.module.css.js +1 -1
  350. package/modern/components/optgroup/index.module.css.js.map +1 -1
  351. package/modern/components/option/Component.d.ts +2 -2
  352. package/modern/components/option/Component.js.map +1 -1
  353. package/modern/components/option/Component.responsive.d.ts +1 -1
  354. package/modern/components/option/Component.responsive.js.map +1 -1
  355. package/modern/components/option/desktop/Component.d.ts +1 -1
  356. package/modern/components/option/desktop/Component.js.map +1 -1
  357. package/modern/components/option/desktop/index.css +23 -24
  358. package/modern/components/option/desktop/index.module.css.js +1 -1
  359. package/modern/components/option/desktop/index.module.css.js.map +1 -1
  360. package/modern/components/option/mobile/Component.d.ts +1 -1
  361. package/modern/components/option/mobile/Component.js.map +1 -1
  362. package/modern/components/option/mobile/index.css +19 -20
  363. package/modern/components/option/mobile/index.module.css.js +1 -1
  364. package/modern/components/option/mobile/index.module.css.js.map +1 -1
  365. package/modern/components/options-list/Component.d.ts +1 -1
  366. package/modern/components/options-list/Component.js.map +1 -1
  367. package/modern/components/options-list/index.css +11 -11
  368. package/modern/components/options-list/index.module.css.js +1 -1
  369. package/modern/components/options-list/index.module.css.js.map +1 -1
  370. package/modern/components/search/Component.d.ts +1 -1
  371. package/modern/components/search/Component.js.map +1 -1
  372. package/modern/components/search/index.css +1 -1
  373. package/modern/components/search/index.module.css.js +1 -1
  374. package/modern/components/search/index.module.css.js.map +1 -1
  375. package/modern/components/virtual-options-list/Component.d.ts +1 -1
  376. package/modern/components/virtual-options-list/Component.js.map +1 -1
  377. package/modern/components/virtual-options-list/index.css +15 -15
  378. package/modern/components/virtual-options-list/index.module.css.js +1 -1
  379. package/modern/components/virtual-options-list/index.module.css.js.map +1 -1
  380. package/modern/consts.d.ts +1 -0
  381. package/modern/consts.js +2 -1
  382. package/modern/consts.js.map +1 -1
  383. package/modern/desktop/Component.desktop.js.map +1 -1
  384. package/modern/mobile/Component.mobile.d.ts +1 -1
  385. package/modern/mobile/Component.mobile.js.map +1 -1
  386. package/modern/mobile/Component.modal.mobile.js.map +1 -1
  387. package/modern/presets/index.js +1 -1
  388. package/modern/presets/useLazyLoading/hook.d.ts +1 -1
  389. package/modern/presets/useLazyLoading/hook.js.map +1 -1
  390. package/modern/presets/useSelectWithApply/hook.d.ts +1 -2
  391. package/modern/presets/useSelectWithApply/hook.js +2 -2
  392. package/modern/presets/useSelectWithApply/hook.js.map +1 -1
  393. package/modern/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +3 -3
  394. package/modern/presets/useSelectWithApply/options-list-with-apply/Component.js +1 -2
  395. package/modern/presets/useSelectWithApply/options-list-with-apply/Component.js.map +1 -1
  396. package/modern/presets/useSelectWithApply/options-list-with-apply/footer/Component.d.ts +1 -1
  397. package/modern/presets/useSelectWithApply/options-list-with-apply/footer/Component.js.map +1 -1
  398. package/modern/presets/useSelectWithApply/options-list-with-apply/footer/index.css +4 -4
  399. package/modern/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js +1 -1
  400. package/modern/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js.map +1 -1
  401. package/modern/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +2 -2
  402. package/modern/presets/useSelectWithApply/options-list-with-apply/header/Component.js.map +1 -1
  403. package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.css +4 -4
  404. package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js +1 -1
  405. package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js.map +1 -1
  406. package/modern/presets/useSelectWithLoading/hook.d.ts +1 -1
  407. package/modern/presets/useSelectWithLoading/hook.js.map +1 -1
  408. package/modern/presets/useSelectWithLoading/index.css +1 -1
  409. package/modern/presets/useSelectWithLoading/index.module.css.js +1 -1
  410. package/modern/shared/index.js +1 -1
  411. package/modern/typings.d.ts +14 -8
  412. package/modern/utils.d.ts +2 -2
  413. package/modern/utils.js.map +1 -1
  414. package/moderncssm/Component.responsive.d.ts +1 -1
  415. package/moderncssm/Component.responsive.js.map +1 -1
  416. package/moderncssm/components/arrow/Component.d.ts +1 -1
  417. package/moderncssm/components/arrow/Component.js.map +1 -1
  418. package/moderncssm/components/arrow/index.module.css +11 -3
  419. package/moderncssm/components/base-checkmark/Component.d.ts +1 -1
  420. package/moderncssm/components/base-checkmark/Component.js.map +1 -1
  421. package/moderncssm/components/base-checkmark/index.module.css +6 -2
  422. package/moderncssm/components/base-option/Component.d.ts +2 -2
  423. package/moderncssm/components/base-option/Component.js.map +1 -1
  424. package/moderncssm/components/base-option/index.module.css +20 -4
  425. package/moderncssm/components/base-select/Component.js +7 -5
  426. package/moderncssm/components/base-select/Component.js.map +1 -1
  427. package/moderncssm/components/base-select/index.module.css +13 -2
  428. package/moderncssm/components/base-select/mobile.module.css +12 -2
  429. package/moderncssm/components/base-select/types/component-types.d.ts +7 -7
  430. package/moderncssm/components/checkmark/Component.d.ts +1 -1
  431. package/moderncssm/components/checkmark/Component.js.map +1 -1
  432. package/moderncssm/components/checkmark/index.module.css +13 -4
  433. package/moderncssm/components/checkmark-mobile/Component.d.ts +1 -1
  434. package/moderncssm/components/checkmark-mobile/Component.js.map +1 -1
  435. package/moderncssm/components/checkmark-mobile/index.module.css +6 -1
  436. package/moderncssm/components/clear-button/Component.d.ts +1 -1
  437. package/moderncssm/components/clear-button/Component.js.map +1 -1
  438. package/moderncssm/components/clear-button/index.module.css +3 -5
  439. package/moderncssm/components/field/Component.d.ts +3 -3
  440. package/moderncssm/components/field/Component.js +13 -6
  441. package/moderncssm/components/field/Component.js.map +1 -1
  442. package/moderncssm/components/field/index.module.css +6 -4
  443. package/moderncssm/components/footer/index.module.css +4 -1
  444. package/moderncssm/components/native-select/Component.d.ts +2 -2
  445. package/moderncssm/components/native-select/Component.js.map +1 -1
  446. package/moderncssm/components/optgroup/Component.d.ts +1 -1
  447. package/moderncssm/components/optgroup/Component.js.map +1 -1
  448. package/moderncssm/components/optgroup/index.module.css +5 -1
  449. package/moderncssm/components/option/Component.d.ts +2 -2
  450. package/moderncssm/components/option/Component.js.map +1 -1
  451. package/moderncssm/components/option/Component.responsive.d.ts +1 -1
  452. package/moderncssm/components/option/Component.responsive.js.map +1 -1
  453. package/moderncssm/components/option/desktop/Component.d.ts +1 -1
  454. package/moderncssm/components/option/desktop/Component.js.map +1 -1
  455. package/moderncssm/components/option/desktop/index.module.css +4 -6
  456. package/moderncssm/components/option/mobile/Component.d.ts +1 -1
  457. package/moderncssm/components/option/mobile/Component.js.map +1 -1
  458. package/moderncssm/components/option/mobile/index.module.css +3 -5
  459. package/moderncssm/components/options-list/Component.d.ts +1 -1
  460. package/moderncssm/components/options-list/Component.js.map +1 -1
  461. package/moderncssm/components/options-list/index.module.css +11 -2
  462. package/moderncssm/components/search/Component.d.ts +1 -1
  463. package/moderncssm/components/search/Component.js.map +1 -1
  464. package/moderncssm/components/virtual-options-list/Component.d.ts +1 -1
  465. package/moderncssm/components/virtual-options-list/Component.js.map +1 -1
  466. package/moderncssm/components/virtual-options-list/index.module.css +14 -2
  467. package/moderncssm/consts.d.ts +1 -0
  468. package/moderncssm/consts.js +2 -1
  469. package/moderncssm/consts.js.map +1 -1
  470. package/moderncssm/desktop/Component.desktop.js.map +1 -1
  471. package/moderncssm/mobile/Component.mobile.d.ts +1 -1
  472. package/moderncssm/mobile/Component.mobile.js.map +1 -1
  473. package/moderncssm/mobile/Component.modal.mobile.js.map +1 -1
  474. package/moderncssm/presets/index.js +1 -1
  475. package/moderncssm/presets/useLazyLoading/hook.d.ts +1 -1
  476. package/moderncssm/presets/useLazyLoading/hook.js.map +1 -1
  477. package/moderncssm/presets/useSelectWithApply/hook.d.ts +1 -2
  478. package/moderncssm/presets/useSelectWithApply/hook.js +2 -2
  479. package/moderncssm/presets/useSelectWithApply/hook.js.map +1 -1
  480. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +3 -3
  481. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/Component.js +1 -2
  482. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/Component.js.map +1 -1
  483. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/footer/Component.d.ts +1 -1
  484. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/footer/Component.js.map +1 -1
  485. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css +4 -1
  486. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +2 -2
  487. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/header/Component.js.map +1 -1
  488. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/header/index.module.css +3 -1
  489. package/moderncssm/presets/useSelectWithLoading/hook.d.ts +1 -1
  490. package/moderncssm/presets/useSelectWithLoading/hook.js.map +1 -1
  491. package/moderncssm/shared/index.js +1 -1
  492. package/moderncssm/typings.d.ts +14 -8
  493. package/moderncssm/utils.d.ts +2 -2
  494. package/moderncssm/utils.js.map +1 -1
  495. package/package.json +3 -3
  496. package/presets/index.js +0 -1
  497. package/presets/index.js.map +1 -1
  498. package/presets/useLazyLoading/hook.d.ts +1 -1
  499. package/presets/useLazyLoading/hook.js.map +1 -1
  500. package/presets/useSelectWithApply/hook.d.ts +1 -2
  501. package/presets/useSelectWithApply/hook.js +4 -5
  502. package/presets/useSelectWithApply/hook.js.map +1 -1
  503. package/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +3 -3
  504. package/presets/useSelectWithApply/options-list-with-apply/Component.js +1 -2
  505. package/presets/useSelectWithApply/options-list-with-apply/Component.js.map +1 -1
  506. package/presets/useSelectWithApply/options-list-with-apply/footer/Component.d.ts +1 -1
  507. package/presets/useSelectWithApply/options-list-with-apply/footer/Component.js.map +1 -1
  508. package/presets/useSelectWithApply/options-list-with-apply/footer/index.css +4 -4
  509. package/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js +1 -1
  510. package/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js.map +1 -1
  511. package/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +2 -2
  512. package/presets/useSelectWithApply/options-list-with-apply/header/Component.js.map +1 -1
  513. package/presets/useSelectWithApply/options-list-with-apply/header/index.css +4 -4
  514. package/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js +1 -1
  515. package/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js.map +1 -1
  516. package/presets/useSelectWithLoading/hook.d.ts +1 -1
  517. package/presets/useSelectWithLoading/hook.js.map +1 -1
  518. package/presets/useSelectWithLoading/index.css +1 -1
  519. package/presets/useSelectWithLoading/index.module.css.js +1 -1
  520. package/shared/index.js +0 -1
  521. package/shared/index.js.map +1 -1
  522. package/src/Component.responsive.tsx +1 -1
  523. package/src/components/arrow/Component.tsx +1 -1
  524. package/src/components/arrow/index.module.css +4 -2
  525. package/src/components/base-checkmark/Component.tsx +1 -1
  526. package/src/components/base-checkmark/index.module.css +1 -1
  527. package/src/components/base-option/Component.tsx +2 -2
  528. package/src/components/base-option/index.module.css +1 -1
  529. package/src/components/base-select/Component.tsx +20 -12
  530. package/src/components/base-select/index.module.css +2 -2
  531. package/src/components/base-select/mobile.module.css +1 -1
  532. package/src/components/base-select/types/component-types.ts +14 -16
  533. package/src/components/checkmark/Component.tsx +2 -2
  534. package/src/components/checkmark/index.module.css +1 -1
  535. package/src/components/checkmark-mobile/Component.tsx +1 -1
  536. package/src/components/checkmark-mobile/index.module.css +1 -1
  537. package/src/components/clear-button/Component.tsx +1 -1
  538. package/src/components/field/Component.tsx +18 -11
  539. package/src/components/field/index.module.css +1 -1
  540. package/src/components/footer/index.module.css +1 -1
  541. package/src/components/native-select/Component.tsx +2 -2
  542. package/src/components/optgroup/Component.tsx +1 -1
  543. package/src/components/optgroup/index.module.css +1 -1
  544. package/src/components/option/Component.responsive.tsx +1 -1
  545. package/src/components/option/Component.tsx +2 -2
  546. package/src/components/option/desktop/Component.tsx +1 -1
  547. package/src/components/option/desktop/index.module.css +1 -1
  548. package/src/components/option/index.module.css +1 -4
  549. package/src/components/option/mobile/Component.tsx +1 -1
  550. package/src/components/option/mobile/index.module.css +1 -1
  551. package/src/components/options-list/Component.tsx +1 -1
  552. package/src/components/options-list/index.module.css +1 -1
  553. package/src/components/search/Component.tsx +1 -1
  554. package/src/components/search/index.module.css +1 -1
  555. package/src/components/virtual-options-list/Component.tsx +1 -1
  556. package/src/components/virtual-options-list/index.module.css +1 -1
  557. package/src/consts.ts +2 -0
  558. package/src/desktop/Component.desktop.tsx +1 -1
  559. package/src/mobile/Component.mobile.tsx +1 -1
  560. package/src/mobile/Component.modal.mobile.tsx +1 -1
  561. package/src/presets/useLazyLoading/hook.tsx +3 -3
  562. package/src/presets/useSelectWithApply/{hook.tsx → hook.ts} +2 -3
  563. package/src/presets/useSelectWithApply/options-list-with-apply/Component.tsx +5 -6
  564. package/src/presets/useSelectWithApply/options-list-with-apply/footer/Component.tsx +1 -1
  565. package/src/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css +1 -1
  566. package/src/presets/useSelectWithApply/options-list-with-apply/header/Component.tsx +2 -2
  567. package/src/presets/useSelectWithApply/options-list-with-apply/header/index.module.css +1 -1
  568. package/src/presets/useSelectWithLoading/hook.tsx +1 -1
  569. package/src/typings.ts +27 -17
  570. package/src/utils.ts +8 -3
  571. package/typings.d.ts +14 -8
  572. package/utils.d.ts +2 -2
  573. package/utils.js.map +1 -1
@@ -1,6 +1,6 @@
1
1
  import './index.css';
2
2
 
3
- const styles = {"option":"select__option_vvvze","disabled":"select__disabled_vvvze","size-48":"select__size-48_vvvze","size-56":"select__size-56_vvvze","size-64":"select__size-64_vvvze","size-72":"select__size-72_vvvze","selected":"select__selected_vvvze","highlighted":"select__highlighted_vvvze","content":"select__content_vvvze","textContent":"select__textContent_vvvze"};
3
+ const styles = {"option":"select__option_1v17g","disabled":"select__disabled_1v17g","size-48":"select__size-48_1v17g","size-56":"select__size-56_1v17g","size-64":"select__size-64_1v17g","size-72":"select__size-72_1v17g","selected":"select__selected_1v17g","highlighted":"select__highlighted_1v17g","content":"select__content_1v17g","textContent":"select__textContent_1v17g"};
4
4
 
5
5
  export { styles as default };
6
6
  //# sourceMappingURL=index.module.css.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.module.css.js","sources":["../../../src/components/option/mobile/index.module.css"],"sourcesContent":["@import '@alfalab/core-components-vars/src/index.css';\n@import '../../../vars.css';\n@import '../index.module.css';\n"],"names":[],"mappings":";;AAEgB,eAAe,CAAC,QAAQ,CAAC,sBAAsB,CAAC,UAAU,CAAC,wBAAwB,CAAC,SAAS,CAAC,uBAAuB,CAAC,SAAS,CAAC,uBAAuB,CAAC,SAAS,CAAC,uBAAuB,CAAC,SAAS,CAAC,uBAAuB,CAAC,UAAU,CAAC,wBAAwB,CAAC,aAAa,CAAC,2BAA2B,CAAC,SAAS,CAAC,uBAAuB,CAAC,aAAa,CAAC,2BAA2B,CAAC;;;;"}
1
+ {"version":3,"file":"index.module.css.js","sources":["../../../src/components/option/mobile/index.module.css"],"sourcesContent":["@import '@alfalab/core-components-vars/src/no-typography-index.css';\n@import '../../../vars.css';\n@import '../index.module.css';\n"],"names":[],"mappings":";;AAEgB,eAAe,CAAC,QAAQ,CAAC,sBAAsB,CAAC,UAAU,CAAC,wBAAwB,CAAC,SAAS,CAAC,uBAAuB,CAAC,SAAS,CAAC,uBAAuB,CAAC,SAAS,CAAC,uBAAuB,CAAC,SAAS,CAAC,uBAAuB,CAAC,UAAU,CAAC,wBAAwB,CAAC,aAAa,CAAC,2BAA2B,CAAC,SAAS,CAAC,uBAAuB,CAAC,aAAa,CAAC,2BAA2B,CAAC;;;;"}
@@ -1,3 +1,3 @@
1
1
  import React from 'react';
2
- import { OptionsListProps } from '../../typings';
2
+ import { type OptionsListProps } from '../../typings';
3
3
  export declare const OptionsList: React.ForwardRefExoticComponent<OptionsListProps & React.RefAttributes<HTMLDivElement>>;
@@ -1 +1 @@
1
- {"version":3,"file":"Component.js","sources":["../../../src/components/options-list/Component.tsx"],"sourcesContent":["import React, { forwardRef, useCallback, useRef, useState } from 'react';\nimport mergeRefs from 'react-merge-refs';\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 { GroupShape, OptionShape, OptionsListProps } from '../../typings';\nimport { isGroup, useVisibleOptions } from '../../utils';\nimport { Optgroup as DefaultOptgroup } from '../optgroup';\n\nimport styles from './index.module.css';\n\nconst createCounter = () => {\n let count = 0;\n\n // eslint-disable-next-line no-plusplus\n return () => count++;\n};\n\nexport const OptionsList = forwardRef<HTMLDivElement, OptionsListProps>(\n (\n {\n size = 48,\n className,\n optionGroupClassName,\n footerClassName,\n scrollbarClassName,\n Option,\n getOptionProps,\n groupOptionProps = {},\n options = [],\n Optgroup = DefaultOptgroup,\n dataTestId,\n emptyPlaceholder,\n visibleOptions = DEFAULT_VISIBLE_OPTIONS,\n onScroll,\n open,\n header,\n footer,\n showFooter = true,\n optionsListWidth,\n nativeScrollbar: nativeScrollbarProp,\n flatOptions = [],\n setHighlightedIndex,\n selectedItems,\n search,\n setSelectedItems,\n multiple,\n limitDynamicOptionGroupSize = false,\n },\n ref,\n ) => {\n const [scrollTop, setScrollTop] = useState(true);\n const [scrollBottom, setScrollBottom] = useState(false);\n\n const query = '(max-width: 1023px)';\n let [nativeScrollbar] = useMatchMedia(query, () =>\n isClient() ? window.matchMedia(query).matches : true,\n );\n\n nativeScrollbar = Boolean(nativeScrollbarProp ?? nativeScrollbar);\n\n const handleScroll = useCallback(\n (event: React.MouseEvent<HTMLDivElement, MouseEvent>) => {\n const scrolledToHeader = event.currentTarget.scrollTop <= 0;\n const scrolledToFooter =\n event.currentTarget.scrollHeight - event.currentTarget.offsetHeight <=\n event.currentTarget.scrollTop;\n\n setScrollTop(scrolledToHeader);\n setScrollBottom(scrolledToFooter);\n\n onScroll?.(event);\n },\n [onScroll],\n );\n\n const renderOption = (option: OptionShape, index: number) => (\n <Option key={option.key} {...getOptionProps(option, index)} />\n );\n\n const listRef = useRef<HTMLDivElement>(null);\n const scrollbarRef = useRef<HTMLDivElement>(null);\n const counter = createCounter();\n const renderGroup = (group: GroupShape) => {\n const groupSelectedItems = selectedItems?.filter(({ key: selectedItemKey }) =>\n group.options.some((option) => option.key === selectedItemKey),\n );\n const handleSelectedItems = (items: OptionShape[]) => {\n setSelectedItems(\n (\n selectedItems?.filter(\n ({ key: selectedItemKey }) =>\n !group.options.some((option) => option.key === selectedItemKey),\n ) ?? []\n ).concat(items),\n );\n };\n\n return (\n <Optgroup\n className={optionGroupClassName}\n label={group.label}\n key={group.label}\n size={size}\n options={group.options}\n selectedItems={groupSelectedItems}\n setSelectedItems={handleSelectedItems}\n search={search}\n multiple={multiple}\n {...groupOptionProps}\n >\n {group.options.map((option) => renderOption(option, counter()))}\n </Optgroup>\n );\n };\n\n const actualOptionsCount = limitDynamicOptionGroupSize && options.length > 0;\n\n const [measured, height] = useVisibleOptions({\n visibleOptions,\n listRef,\n open,\n options,\n actualOptionsCount,\n size: actualOptionsCount\n ? (() => {\n switch (typeof size) {\n case 'string':\n throw new Error(\n 'OptionsList with `limitDynamicOptionGroupSize` enabled needs a `size` with number type',\n );\n default:\n return size;\n }\n })()\n : undefined,\n });\n\n if (options.length === 0 && !emptyPlaceholder && !header && !footer) {\n return null;\n }\n\n const renderListItems = () => (\n <React.Fragment>\n {options.map((option) =>\n isGroup(option) ? renderGroup(option) : renderOption(option, counter()),\n )}\n\n {emptyPlaceholder && options.length === 0 && (\n <div className={styles.emptyPlaceholder}>{emptyPlaceholder}</div>\n )}\n </React.Fragment>\n );\n\n const renderWithCustomScrollbar = () => {\n const scrollableNodeProps = {\n onScroll: handleScroll,\n 'data-test-id': dataTestId,\n ref: ref as React.RefObject<HTMLDivElement>,\n };\n\n return (\n <Scrollbar\n className={cn(styles.scrollable, scrollbarClassName)}\n ref={scrollbarRef}\n style={{ height }}\n horizontalAutoStretch={optionsListWidth === 'content'}\n scrollableNodeProps={scrollableNodeProps}\n contentNodeProps={{ ref: listRef }}\n maskProps={{\n /*\n * Для корректного подсчета высоты опций(иначе для optionsListWidth: 'field'\n * высота опции всегда будет равна высоте одной строчки)\n */\n className: cn({\n [styles.mask]: optionsListWidth === 'content' && !measured,\n }),\n }}\n >\n {renderListItems()}\n </Scrollbar>\n );\n };\n\n const renderWithNativeScrollbar = () => (\n <div\n className={cn(styles.scrollable, scrollbarClassName)}\n ref={mergeRefs([listRef, ref])}\n onScroll={handleScroll}\n style={{ height }}\n >\n {renderListItems()}\n </div>\n );\n\n const resetHighlightedIndex = () => setHighlightedIndex?.(-1);\n\n return (\n <div\n {...(nativeScrollbar && { 'data-test-id': dataTestId })}\n className={cn(styles.optionsList, styles[SIZE_TO_CLASSNAME_MAP[size]], className)}\n >\n {header && (\n <div\n className={cn(styles.optionsListHeader, {\n [styles.headerHighlighted]: !scrollTop,\n })}\n onMouseEnter={resetHighlightedIndex}\n >\n {header}\n </div>\n )}\n\n {nativeScrollbar ? renderWithNativeScrollbar() : renderWithCustomScrollbar()}\n\n {showFooter && footer && (\n <div\n onMouseEnter={resetHighlightedIndex}\n className={cn(styles.optionsListFooter, footerClassName, {\n [styles.withBorder]:\n visibleOptions &&\n flatOptions.length > visibleOptions &&\n !scrollBottom,\n })}\n >\n {footer}\n </div>\n )}\n </div>\n );\n },\n);\n"],"names":["Optgroup","DefaultOptgroup"],"mappings":"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"}
1
+ {"version":3,"file":"Component.js","sources":["../../../src/components/options-list/Component.tsx"],"sourcesContent":["import React, { forwardRef, useCallback, useRef, useState } from 'react';\nimport mergeRefs from 'react-merge-refs';\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, useVisibleOptions } from '../../utils';\nimport { Optgroup as DefaultOptgroup } from '../optgroup';\n\nimport styles from './index.module.css';\n\nconst createCounter = () => {\n let count = 0;\n\n // eslint-disable-next-line no-plusplus\n return () => count++;\n};\n\nexport const OptionsList = forwardRef<HTMLDivElement, OptionsListProps>(\n (\n {\n size = 48,\n className,\n optionGroupClassName,\n footerClassName,\n scrollbarClassName,\n Option,\n getOptionProps,\n groupOptionProps = {},\n options = [],\n Optgroup = DefaultOptgroup,\n dataTestId,\n emptyPlaceholder,\n visibleOptions = DEFAULT_VISIBLE_OPTIONS,\n onScroll,\n open,\n header,\n footer,\n showFooter = true,\n optionsListWidth,\n nativeScrollbar: nativeScrollbarProp,\n flatOptions = [],\n setHighlightedIndex,\n selectedItems,\n search,\n setSelectedItems,\n multiple,\n limitDynamicOptionGroupSize = false,\n },\n ref,\n ) => {\n const [scrollTop, setScrollTop] = useState(true);\n const [scrollBottom, setScrollBottom] = useState(false);\n\n const query = '(max-width: 1023px)';\n let [nativeScrollbar] = useMatchMedia(query, () =>\n isClient() ? window.matchMedia(query).matches : true,\n );\n\n nativeScrollbar = Boolean(nativeScrollbarProp ?? nativeScrollbar);\n\n const handleScroll = useCallback(\n (event: React.MouseEvent<HTMLDivElement, MouseEvent>) => {\n const scrolledToHeader = event.currentTarget.scrollTop <= 0;\n const scrolledToFooter =\n event.currentTarget.scrollHeight - event.currentTarget.offsetHeight <=\n event.currentTarget.scrollTop;\n\n setScrollTop(scrolledToHeader);\n setScrollBottom(scrolledToFooter);\n\n onScroll?.(event);\n },\n [onScroll],\n );\n\n const renderOption = (option: OptionShape, index: number) => (\n <Option key={option.key} {...getOptionProps(option, index)} />\n );\n\n const listRef = useRef<HTMLDivElement>(null);\n const scrollbarRef = useRef<HTMLDivElement>(null);\n const counter = createCounter();\n const renderGroup = (group: GroupShape) => {\n const groupSelectedItems = selectedItems?.filter(({ key: selectedItemKey }) =>\n group.options.some((option) => option.key === selectedItemKey),\n );\n const handleSelectedItems = (items: OptionShape[]) => {\n setSelectedItems(\n (\n selectedItems?.filter(\n ({ key: selectedItemKey }) =>\n !group.options.some((option) => option.key === selectedItemKey),\n ) ?? []\n ).concat(items),\n );\n };\n\n return (\n <Optgroup\n className={optionGroupClassName}\n label={group.label}\n key={group.label}\n size={size}\n options={group.options}\n selectedItems={groupSelectedItems}\n setSelectedItems={handleSelectedItems}\n search={search}\n multiple={multiple}\n {...groupOptionProps}\n >\n {group.options.map((option) => renderOption(option, counter()))}\n </Optgroup>\n );\n };\n\n const actualOptionsCount = limitDynamicOptionGroupSize && options.length > 0;\n\n const [measured, height] = useVisibleOptions({\n visibleOptions,\n listRef,\n open,\n options,\n actualOptionsCount,\n size: actualOptionsCount\n ? (() => {\n switch (typeof size) {\n case 'string':\n throw new Error(\n 'OptionsList with `limitDynamicOptionGroupSize` enabled needs a `size` with number type',\n );\n default:\n return size;\n }\n })()\n : undefined,\n });\n\n if (options.length === 0 && !emptyPlaceholder && !header && !footer) {\n return null;\n }\n\n const renderListItems = () => (\n <React.Fragment>\n {options.map((option) =>\n isGroup(option) ? renderGroup(option) : renderOption(option, counter()),\n )}\n\n {emptyPlaceholder && options.length === 0 && (\n <div className={styles.emptyPlaceholder}>{emptyPlaceholder}</div>\n )}\n </React.Fragment>\n );\n\n const renderWithCustomScrollbar = () => {\n const scrollableNodeProps = {\n onScroll: handleScroll,\n 'data-test-id': dataTestId,\n ref: ref as React.RefObject<HTMLDivElement>,\n };\n\n return (\n <Scrollbar\n className={cn(styles.scrollable, scrollbarClassName)}\n ref={scrollbarRef}\n style={{ height }}\n horizontalAutoStretch={optionsListWidth === 'content'}\n scrollableNodeProps={scrollableNodeProps}\n contentNodeProps={{ ref: listRef }}\n maskProps={{\n /*\n * Для корректного подсчета высоты опций(иначе для optionsListWidth: 'field'\n * высота опции всегда будет равна высоте одной строчки)\n */\n className: cn({\n [styles.mask]: optionsListWidth === 'content' && !measured,\n }),\n }}\n >\n {renderListItems()}\n </Scrollbar>\n );\n };\n\n const renderWithNativeScrollbar = () => (\n <div\n className={cn(styles.scrollable, scrollbarClassName)}\n ref={mergeRefs([listRef, ref])}\n onScroll={handleScroll}\n style={{ height }}\n >\n {renderListItems()}\n </div>\n );\n\n const resetHighlightedIndex = () => setHighlightedIndex?.(-1);\n\n return (\n <div\n {...(nativeScrollbar && { 'data-test-id': dataTestId })}\n className={cn(styles.optionsList, styles[SIZE_TO_CLASSNAME_MAP[size]], className)}\n >\n {header && (\n <div\n className={cn(styles.optionsListHeader, {\n [styles.headerHighlighted]: !scrollTop,\n })}\n onMouseEnter={resetHighlightedIndex}\n >\n {header}\n </div>\n )}\n\n {nativeScrollbar ? renderWithNativeScrollbar() : renderWithCustomScrollbar()}\n\n {showFooter && footer && (\n <div\n onMouseEnter={resetHighlightedIndex}\n className={cn(styles.optionsListFooter, footerClassName, {\n [styles.withBorder]:\n visibleOptions &&\n flatOptions.length > visibleOptions &&\n !scrollBottom,\n })}\n >\n {footer}\n </div>\n )}\n </div>\n );\n },\n);\n"],"names":["Optgroup","DefaultOptgroup"],"mappings":"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"}
@@ -11,33 +11,33 @@
11
11
  --gap-24: var(--gap-xl);
12
12
  } :root {
13
13
  --select-options-list-empty-placeholder-color: var(--color-light-text-secondary);
14
- } .select__optionsList_9b7bg {
14
+ } .select__optionsList_196zw {
15
15
  width: 100%;
16
16
  outline: none;
17
17
  box-sizing: border-box;
18
18
  position: relative;
19
- } .select__optionsListHeader_9b7bg {
19
+ } .select__optionsListHeader_196zw {
20
20
  box-sizing: border-box;
21
21
  border-bottom: 1px solid transparent;
22
- transition: border-color 0.2s ease
23
- } .select__optionsListHeader_9b7bg.select__headerHighlighted_9b7bg {
22
+ transition: border-color 0.2s ease;
23
+ } .select__optionsListHeader_196zw.select__headerHighlighted_196zw {
24
24
  border-bottom-color: var(--color-light-neutral-300);
25
- } .select__optionsListFooter_9b7bg {
25
+ } .select__optionsListFooter_196zw {
26
26
  position: sticky;
27
27
  bottom: var(--gap-0);
28
28
  box-sizing: border-box;
29
29
  border-top: 1px solid transparent;
30
- transition: border-color 0.2s ease
31
- } .select__optionsListFooter_9b7bg.select__withBorder_9b7bg {
30
+ transition: border-color 0.2s ease;
31
+ } .select__optionsListFooter_196zw.select__withBorder_196zw {
32
32
  border-top-color: var(--color-light-neutral-300);
33
- } .select__scrollable_9b7bg {
33
+ } .select__scrollable_196zw {
34
34
  overflow: auto;
35
35
  width: 100%;
36
- } .select__mask_9b7bg {
36
+ } .select__mask_196zw {
37
37
  min-width: 4000px;
38
- } .select__emptyPlaceholder_9b7bg {
38
+ } .select__emptyPlaceholder_196zw {
39
39
  padding: var(--gap-16) var(--gap-12);
40
40
  color: var(--select-options-list-empty-placeholder-color);
41
- } .select__size-72_9b7bg .select__emptyPlaceholder_9b7bg {
41
+ } .select__size-72_196zw .select__emptyPlaceholder_196zw {
42
42
  padding: var(--gap-24) var(--gap-16);
43
43
  }
@@ -1,6 +1,6 @@
1
1
  import './index.css';
2
2
 
3
- const styles = {"optionsList":"select__optionsList_9b7bg","optionsListHeader":"select__optionsListHeader_9b7bg","headerHighlighted":"select__headerHighlighted_9b7bg","optionsListFooter":"select__optionsListFooter_9b7bg","withBorder":"select__withBorder_9b7bg","scrollable":"select__scrollable_9b7bg","mask":"select__mask_9b7bg","emptyPlaceholder":"select__emptyPlaceholder_9b7bg","size-72":"select__size-72_9b7bg"};
3
+ const styles = {"optionsList":"select__optionsList_196zw","optionsListHeader":"select__optionsListHeader_196zw","headerHighlighted":"select__headerHighlighted_196zw","optionsListFooter":"select__optionsListFooter_196zw","withBorder":"select__withBorder_196zw","scrollable":"select__scrollable_196zw","mask":"select__mask_196zw","emptyPlaceholder":"select__emptyPlaceholder_196zw","size-72":"select__size-72_196zw"};
4
4
 
5
5
  export { styles as default };
6
6
  //# sourceMappingURL=index.module.css.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.module.css.js","sources":["../../src/components/options-list/index.module.css"],"sourcesContent":["@import '@alfalab/core-components-vars/src/index.css';\n@import '../../vars.css';\n\n.optionsList {\n width: 100%;\n outline: none;\n box-sizing: border-box;\n position: relative;\n}\n\n.optionsListHeader {\n box-sizing: border-box;\n border-bottom: 1px solid transparent;\n transition: border-color 0.2s ease;\n\n &.headerHighlighted {\n border-bottom-color: var(--color-light-neutral-300);\n }\n}\n\n.optionsListFooter {\n position: sticky;\n bottom: var(--gap-0);\n box-sizing: border-box;\n border-top: 1px solid transparent;\n transition: border-color 0.2s ease;\n\n &.withBorder {\n border-top-color: var(--color-light-neutral-300);\n }\n}\n\n.scrollable {\n overflow: auto;\n width: 100%;\n}\n\n.mask {\n min-width: 4000px;\n}\n\n.emptyPlaceholder {\n padding: var(--gap-16) var(--gap-12);\n color: var(--select-options-list-empty-placeholder-color);\n}\n\n.size-72 .emptyPlaceholder {\n padding: var(--gap-24) var(--gap-16);\n}\n"],"names":[],"mappings":";;AAEgB,eAAe,CAAC,aAAa,CAAC,2BAA2B,CAAC,mBAAmB,CAAC,iCAAiC,CAAC,mBAAmB,CAAC,iCAAiC,CAAC,mBAAmB,CAAC,iCAAiC,CAAC,YAAY,CAAC,0BAA0B,CAAC,YAAY,CAAC,0BAA0B,CAAC,MAAM,CAAC,oBAAoB,CAAC,kBAAkB,CAAC,gCAAgC,CAAC,SAAS,CAAC,uBAAuB,CAAC;;;;"}
1
+ {"version":3,"file":"index.module.css.js","sources":["../../src/components/options-list/index.module.css"],"sourcesContent":["@import '@alfalab/core-components-vars/src/no-typography-index.css';\n@import '../../vars.css';\n\n.optionsList {\n width: 100%;\n outline: none;\n box-sizing: border-box;\n position: relative;\n}\n\n.optionsListHeader {\n box-sizing: border-box;\n border-bottom: 1px solid transparent;\n transition: border-color 0.2s ease;\n\n &.headerHighlighted {\n border-bottom-color: var(--color-light-neutral-300);\n }\n}\n\n.optionsListFooter {\n position: sticky;\n bottom: var(--gap-0);\n box-sizing: border-box;\n border-top: 1px solid transparent;\n transition: border-color 0.2s ease;\n\n &.withBorder {\n border-top-color: var(--color-light-neutral-300);\n }\n}\n\n.scrollable {\n overflow: auto;\n width: 100%;\n}\n\n.mask {\n min-width: 4000px;\n}\n\n.emptyPlaceholder {\n padding: var(--gap-16) var(--gap-12);\n color: var(--select-options-list-empty-placeholder-color);\n}\n\n.size-72 .emptyPlaceholder {\n padding: var(--gap-24) var(--gap-16);\n}\n"],"names":[],"mappings":";;AAEgB,eAAe,CAAC,aAAa,CAAC,2BAA2B,CAAC,mBAAmB,CAAC,iCAAiC,CAAC,mBAAmB,CAAC,iCAAiC,CAAC,mBAAmB,CAAC,iCAAiC,CAAC,YAAY,CAAC,0BAA0B,CAAC,YAAY,CAAC,0BAA0B,CAAC,MAAM,CAAC,oBAAoB,CAAC,kBAAkB,CAAC,gCAAgC,CAAC,SAAS,CAAC,uBAAuB,CAAC;;;;"}
@@ -1,3 +1,3 @@
1
1
  import React from 'react';
2
- import { SearchProps } from '../../typings';
2
+ import { type SearchProps } from '../../typings';
3
3
  export declare const Search: React.ForwardRefExoticComponent<Omit<SearchProps, "ref"> & React.RefAttributes<HTMLInputElement>>;
@@ -1 +1 @@
1
- {"version":3,"file":"Component.js","sources":["../../../src/components/search/Component.tsx"],"sourcesContent":["import React, { forwardRef } from 'react';\nimport cn from 'classnames';\n\nimport { Input } from '@alfalab/core-components-input';\nimport { MagnifierMIcon } from '@alfalab/icons-glyph/MagnifierMIcon';\n\nimport { SearchProps } from '../../typings';\n\nimport styles from './index.module.css';\n\nexport const Search = forwardRef<HTMLInputElement, SearchProps>(\n (\n {\n clear = true,\n placeholder = 'Поиск',\n className,\n leftAddons = <MagnifierMIcon color='#86868A' />,\n ...restProps\n },\n ref,\n ) => (\n <Input\n ref={ref}\n className={cn(styles.component, className)}\n placeholder={placeholder}\n leftAddons={leftAddons}\n clear={clear}\n {...restProps}\n />\n ),\n);\n"],"names":[],"mappings":";;;;;;AAUO,MAAM,MAAM,GAAG,UAAU,CAC5B,CACI,EACI,KAAK,GAAG,IAAI,EACZ,WAAW,GAAG,OAAO,EACrB,SAAS,EACT,UAAU,GAAG,KAAC,CAAA,aAAA,CAAA,cAAc,IAAC,KAAK,EAAC,SAAS,EAAA,CAAG,EAC/C,GAAG,SAAS,EACf,EACD,GAAG,MAEH,KAAC,CAAA,aAAA,CAAA,KAAK,EACF,EAAA,GAAG,EAAE,GAAG,EACR,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE,SAAS,CAAC,EAC1C,WAAW,EAAE,WAAW,EACxB,UAAU,EAAE,UAAU,EACtB,KAAK,EAAE,KAAK,EACR,GAAA,SAAS,EACf,CAAA,CACL;;;;"}
1
+ {"version":3,"file":"Component.js","sources":["../../../src/components/search/Component.tsx"],"sourcesContent":["import React, { forwardRef } from 'react';\nimport cn from 'classnames';\n\nimport { Input } from '@alfalab/core-components-input';\nimport { MagnifierMIcon } from '@alfalab/icons-glyph/MagnifierMIcon';\n\nimport { type SearchProps } from '../../typings';\n\nimport styles from './index.module.css';\n\nexport const Search = forwardRef<HTMLInputElement, SearchProps>(\n (\n {\n clear = true,\n placeholder = 'Поиск',\n className,\n leftAddons = <MagnifierMIcon color='#86868A' />,\n ...restProps\n },\n ref,\n ) => (\n <Input\n ref={ref}\n className={cn(styles.component, className)}\n placeholder={placeholder}\n leftAddons={leftAddons}\n clear={clear}\n {...restProps}\n />\n ),\n);\n"],"names":[],"mappings":";;;;;;AAUO,MAAM,MAAM,GAAG,UAAU,CAC5B,CACI,EACI,KAAK,GAAG,IAAI,EACZ,WAAW,GAAG,OAAO,EACrB,SAAS,EACT,UAAU,GAAG,KAAC,CAAA,aAAA,CAAA,cAAc,IAAC,KAAK,EAAC,SAAS,EAAA,CAAG,EAC/C,GAAG,SAAS,EACf,EACD,GAAG,MAEH,KAAC,CAAA,aAAA,CAAA,KAAK,EACF,EAAA,GAAG,EAAE,GAAG,EACR,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE,SAAS,CAAC,EAC1C,WAAW,EAAE,WAAW,EACxB,UAAU,EAAE,UAAU,EACtB,KAAK,EAAE,KAAK,EACR,GAAA,SAAS,EACf,CAAA,CACL;;;;"}
@@ -1,3 +1,3 @@
1
- .select__component_18lur.select__component_18lur {
1
+ .select__component_ou3k9.select__component_ou3k9 {
2
2
  width: auto;
3
3
  }
@@ -1,6 +1,6 @@
1
1
  import './index.css';
2
2
 
3
- const styles = {"component":"select__component_18lur"};
3
+ const styles = {"component":"select__component_ou3k9"};
4
4
 
5
5
  export { styles as default };
6
6
  //# sourceMappingURL=index.module.css.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.module.css.js","sources":["../../src/components/search/index.module.css"],"sourcesContent":["@import '@alfalab/core-components-vars/src/index.css';\n@import '../../vars.css';\n\n.component.component {\n width: auto;\n}\n"],"names":[],"mappings":";;AAEgB,eAAe,CAAC,WAAW,CAAC,yBAAyB,CAAC;;;;"}
1
+ {"version":3,"file":"index.module.css.js","sources":["../../src/components/search/index.module.css"],"sourcesContent":["@import '@alfalab/core-components-vars/src/no-typography-index.css';\n@import '../../vars.css';\n\n.component.component {\n width: auto;\n}\n"],"names":[],"mappings":";;AAEgB,eAAe,CAAC,WAAW,CAAC,yBAAyB,CAAC;;;;"}
@@ -1,3 +1,3 @@
1
1
  import React from 'react';
2
- import { OptionsListProps } from '../../typings';
2
+ import { type OptionsListProps } from '../../typings';
3
3
  export declare const VirtualOptionsList: React.ForwardRefExoticComponent<OptionsListProps & React.RefAttributes<HTMLDivElement>>;
@@ -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 { GroupShape, OptionShape, 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":"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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 { 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":"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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
- } .select__virtualOptionsList_ol8k1 {
20
+ } .select__virtualOptionsList_18czr {
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
- } .select__virtualOptionsListHeader_ol8k1 {
26
+ } .select__virtualOptionsListHeader_18czr {
27
27
  box-sizing: border-box;
28
28
  border-bottom: 1px solid var(--color-light-neutral-300);
29
- } .select__virtualOptionsListFooter_ol8k1 {
29
+ } .select__virtualOptionsListFooter_18czr {
30
30
  position: sticky;
31
31
  bottom: var(--gap-0);
32
32
  box-sizing: border-box;
33
- border-top: 1px solid transparent
34
- } .select__virtualOptionsListFooter_ol8k1.select__withBorder_ol8k1 {
33
+ border-top: 1px solid transparent;
34
+ } .select__virtualOptionsListFooter_18czr.select__withBorder_18czr {
35
35
  border-top: 1px solid var(--color-light-neutral-300);
36
- } .select__scrollable_ol8k1 {
36
+ } .select__scrollable_18czr {
37
37
  position: relative;
38
38
  overflow: auto;
39
39
  width: 100%;
40
- } .select__inner_ol8k1 {
40
+ } .select__inner_18czr {
41
41
  position: relative;
42
42
  width: 100%;
43
- } .select__virtualRow_ol8k1 {
43
+ } .select__virtualRow_18czr {
44
44
  position: absolute;
45
45
  top: var(--gap-0);
46
46
  left: var(--gap-0);
47
- width: 100%
48
- } .select__virtualRow_ol8k1:before {
47
+ width: 100%;
48
+ } .select__virtualRow_18czr: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
- } .select__virtualRow_ol8k1:first-child:before {
58
+ } .select__virtualRow_18czr:first-child:before {
59
59
  display: none;
60
- } .select__highlighted_ol8k1:before,
61
- .select__highlighted_ol8k1 + .select__virtualRow_ol8k1:before {
60
+ } .select__highlighted_18czr:before,
61
+ .select__highlighted_18czr + .select__virtualRow_18czr:before {
62
62
  display: none;
63
- } .select__emptyPlaceholder_ol8k1 {
63
+ } .select__emptyPlaceholder_18czr {
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-72_ol8k1 .select__emptyPlaceholder_ol8k1 {
67
+ } .select__size-72_18czr .select__emptyPlaceholder_18czr {
68
68
  padding: var(--gap-24) var(--gap-16);
69
69
  }
@@ -1,6 +1,6 @@
1
1
  import './index.css';
2
2
 
3
- const styles = {"virtualOptionsList":"select__virtualOptionsList_ol8k1","virtualOptionsListHeader":"select__virtualOptionsListHeader_ol8k1","virtualOptionsListFooter":"select__virtualOptionsListFooter_ol8k1","withBorder":"select__withBorder_ol8k1","scrollable":"select__scrollable_ol8k1","inner":"select__inner_ol8k1","virtualRow":"select__virtualRow_ol8k1","highlighted":"select__highlighted_ol8k1","emptyPlaceholder":"select__emptyPlaceholder_ol8k1","size-72":"select__size-72_ol8k1"};
3
+ const styles = {"virtualOptionsList":"select__virtualOptionsList_18czr","virtualOptionsListHeader":"select__virtualOptionsListHeader_18czr","virtualOptionsListFooter":"select__virtualOptionsListFooter_18czr","withBorder":"select__withBorder_18czr","scrollable":"select__scrollable_18czr","inner":"select__inner_18czr","virtualRow":"select__virtualRow_18czr","highlighted":"select__highlighted_18czr","emptyPlaceholder":"select__emptyPlaceholder_18czr","size-72":"select__size-72_18czr"};
4
4
 
5
5
  export { styles as default };
6
6
  //# sourceMappingURL=index.module.css.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.module.css.js","sources":["../../src/components/virtual-options-list/index.module.css"],"sourcesContent":["@import '@alfalab/core-components-vars/src/index.css';\n@import '../../vars.css';\n\n.virtualOptionsList {\n width: 100%;\n outline: none;\n box-sizing: border-box;\n position: sticky;\n justify-content: space-between;\n}\n\n.virtualOptionsListHeader {\n box-sizing: border-box;\n border-bottom: 1px solid var(--color-light-neutral-300);\n}\n\n.virtualOptionsListFooter {\n position: sticky;\n bottom: var(--gap-0);\n box-sizing: border-box;\n border-top: 1px solid transparent;\n\n &.withBorder {\n border-top: 1px solid var(--color-light-neutral-300);\n }\n}\n\n.scrollable {\n position: relative;\n overflow: auto;\n width: 100%;\n}\n\n.inner {\n position: relative;\n width: 100%;\n}\n\n.virtualRow {\n position: absolute;\n top: var(--gap-0);\n left: var(--gap-0);\n width: 100%;\n\n &:before {\n content: '';\n position: absolute;\n z-index: 1;\n left: var(--select-option-left-padding);\n right: var(--select-option-right-padding);\n top: var(--gap-0);\n height: 1px;\n background: var(--select-option-divider-background);\n display: var(--select-option-divider-display);\n }\n\n &:first-child:before {\n display: none;\n }\n}\n\n.highlighted {\n &:before,\n & + .virtualRow:before {\n display: none;\n }\n}\n\n.emptyPlaceholder {\n padding: var(--gap-16) var(--gap-12);\n color: var(--select-options-list-empty-placeholder-color);\n flex: 1;\n}\n\n.size-72 .emptyPlaceholder {\n padding: var(--gap-24) var(--gap-16);\n}\n"],"names":[],"mappings":";;AAEgB,eAAe,CAAC,oBAAoB,CAAC,kCAAkC,CAAC,0BAA0B,CAAC,wCAAwC,CAAC,0BAA0B,CAAC,wCAAwC,CAAC,YAAY,CAAC,0BAA0B,CAAC,YAAY,CAAC,0BAA0B,CAAC,OAAO,CAAC,qBAAqB,CAAC,YAAY,CAAC,0BAA0B,CAAC,aAAa,CAAC,2BAA2B,CAAC,kBAAkB,CAAC,gCAAgC,CAAC,SAAS,CAAC,uBAAuB,CAAC;;;;"}
1
+ {"version":3,"file":"index.module.css.js","sources":["../../src/components/virtual-options-list/index.module.css"],"sourcesContent":["@import '@alfalab/core-components-vars/src/no-typography-index.css';\n@import '../../vars.css';\n\n.virtualOptionsList {\n width: 100%;\n outline: none;\n box-sizing: border-box;\n position: sticky;\n justify-content: space-between;\n}\n\n.virtualOptionsListHeader {\n box-sizing: border-box;\n border-bottom: 1px solid var(--color-light-neutral-300);\n}\n\n.virtualOptionsListFooter {\n position: sticky;\n bottom: var(--gap-0);\n box-sizing: border-box;\n border-top: 1px solid transparent;\n\n &.withBorder {\n border-top: 1px solid var(--color-light-neutral-300);\n }\n}\n\n.scrollable {\n position: relative;\n overflow: auto;\n width: 100%;\n}\n\n.inner {\n position: relative;\n width: 100%;\n}\n\n.virtualRow {\n position: absolute;\n top: var(--gap-0);\n left: var(--gap-0);\n width: 100%;\n\n &:before {\n content: '';\n position: absolute;\n z-index: 1;\n left: var(--select-option-left-padding);\n right: var(--select-option-right-padding);\n top: var(--gap-0);\n height: 1px;\n background: var(--select-option-divider-background);\n display: var(--select-option-divider-display);\n }\n\n &:first-child:before {\n display: none;\n }\n}\n\n.highlighted {\n &:before,\n & + .virtualRow:before {\n display: none;\n }\n}\n\n.emptyPlaceholder {\n padding: var(--gap-16) var(--gap-12);\n color: var(--select-options-list-empty-placeholder-color);\n flex: 1;\n}\n\n.size-72 .emptyPlaceholder {\n padding: var(--gap-24) var(--gap-16);\n}\n"],"names":[],"mappings":";;AAEgB,eAAe,CAAC,oBAAoB,CAAC,kCAAkC,CAAC,0BAA0B,CAAC,wCAAwC,CAAC,0BAA0B,CAAC,wCAAwC,CAAC,YAAY,CAAC,0BAA0B,CAAC,YAAY,CAAC,0BAA0B,CAAC,OAAO,CAAC,qBAAqB,CAAC,YAAY,CAAC,0BAA0B,CAAC,aAAa,CAAC,2BAA2B,CAAC,kBAAkB,CAAC,gCAAgC,CAAC,SAAS,CAAC,uBAAuB,CAAC;;;;"}
@@ -11,3 +11,4 @@ export declare const SIZE_TO_CLASSNAME_MAP: {
11
11
  72: string;
12
12
  };
13
13
  export declare const DEFAULT_SEPARATOR = ", ";
14
+ export declare const SELECT_ALL_KEY = "select_all";
package/modern/consts.js CHANGED
@@ -11,6 +11,7 @@ const SIZE_TO_CLASSNAME_MAP = {
11
11
  72: 'size-72',
12
12
  };
13
13
  const DEFAULT_SEPARATOR = ', ';
14
+ const SELECT_ALL_KEY = 'select_all';
14
15
 
15
- export { DEFAULT_SEPARATOR, DEFAULT_VISIBLE_OPTIONS, SIZE_TO_CLASSNAME_MAP };
16
+ export { DEFAULT_SEPARATOR, DEFAULT_VISIBLE_OPTIONS, SELECT_ALL_KEY, SIZE_TO_CLASSNAME_MAP };
16
17
  //# sourceMappingURL=consts.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"consts.js","sources":["../src/consts.ts"],"sourcesContent":["export const DEFAULT_VISIBLE_OPTIONS = 5;\n\nexport const SIZE_TO_CLASSNAME_MAP = {\n s: 'size-48',\n m: 'size-56',\n l: 'size-64',\n xl: 'size-72',\n 40: 'size-40',\n 48: 'size-48',\n 56: 'size-56',\n 64: 'size-64',\n 72: 'size-72',\n};\n\nexport const DEFAULT_SEPARATOR = ', ';\n"],"names":[],"mappings":"AAAO,MAAM,uBAAuB,GAAG;AAE1B,MAAA,qBAAqB,GAAG;AACjC,IAAA,CAAC,EAAE,SAAS;AACZ,IAAA,CAAC,EAAE,SAAS;AACZ,IAAA,CAAC,EAAE,SAAS;AACZ,IAAA,EAAE,EAAE,SAAS;AACb,IAAA,EAAE,EAAE,SAAS;AACb,IAAA,EAAE,EAAE,SAAS;AACb,IAAA,EAAE,EAAE,SAAS;AACb,IAAA,EAAE,EAAE,SAAS;AACb,IAAA,EAAE,EAAE,SAAS;;AAGV,MAAM,iBAAiB,GAAG;;;;"}
1
+ {"version":3,"file":"consts.js","sources":["../src/consts.ts"],"sourcesContent":["export const DEFAULT_VISIBLE_OPTIONS = 5;\n\nexport const SIZE_TO_CLASSNAME_MAP = {\n s: 'size-48',\n m: 'size-56',\n l: 'size-64',\n xl: 'size-72',\n 40: 'size-40',\n 48: 'size-48',\n 56: 'size-56',\n 64: 'size-64',\n 72: 'size-72',\n};\n\nexport const DEFAULT_SEPARATOR = ', ';\n\nexport const SELECT_ALL_KEY = 'select_all';\n"],"names":[],"mappings":"AAAO,MAAM,uBAAuB,GAAG;AAE1B,MAAA,qBAAqB,GAAG;AACjC,IAAA,CAAC,EAAE,SAAS;AACZ,IAAA,CAAC,EAAE,SAAS;AACZ,IAAA,CAAC,EAAE,SAAS;AACZ,IAAA,EAAE,EAAE,SAAS;AACb,IAAA,EAAE,EAAE,SAAS;AACb,IAAA,EAAE,EAAE,SAAS;AACb,IAAA,EAAE,EAAE,SAAS;AACb,IAAA,EAAE,EAAE,SAAS;AACb,IAAA,EAAE,EAAE,SAAS;;AAGV,MAAM,iBAAiB,GAAG;AAE1B,MAAM,cAAc,GAAG;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"Component.desktop.js","sources":["../../src/desktop/Component.desktop.tsx"],"sourcesContent":["import React, { forwardRef } from 'react';\n\nimport { FormControlDesktop } from '@alfalab/core-components-form-control/desktop';\nimport { Popover } from '@alfalab/core-components-popover';\n\nimport { Arrow as DefaultArrow } from '../components/arrow';\nimport { BaseSelect } from '../components/base-select';\nimport { Field as DefaultField } from '../components/field';\nimport { Optgroup as DefaultOptgroup } from '../components/optgroup';\nimport { Option as DefaultOption } from '../components/option';\nimport { OptionsList as DefaultOptionsList } from '../components/options-list';\nimport { Search as DefaultSearch } from '../components/search';\nimport { SelectDesktopProps } from '../typings';\n\nexport const SelectDesktop = forwardRef<HTMLDivElement, SelectDesktopProps>(\n (\n {\n Arrow = DefaultArrow,\n Field = DefaultField,\n OptionsList = DefaultOptionsList,\n Optgroup = DefaultOptgroup,\n Option = DefaultOption,\n Search = DefaultSearch,\n fieldProps = {},\n ...restProps\n },\n ref,\n ) => (\n <BaseSelect\n ref={ref}\n view='desktop'\n Option={Option}\n Field={Field}\n fieldProps={{\n FormControlComponent: FormControlDesktop,\n ...(fieldProps as object),\n }}\n Search={Search}\n Optgroup={Optgroup}\n OptionsList={OptionsList}\n Arrow={Arrow}\n Popover={Popover}\n {...restProps}\n />\n ),\n);\n"],"names":["Arrow","DefaultArrow","Field","DefaultField","OptionsList","DefaultOptionsList","Optgroup","DefaultOptgroup","DefaultOption","Search","DefaultSearch"],"mappings":";;;;;;;;;;;;;;;;;;;;AAcO,MAAM,aAAa,GAAG,UAAU,CACnC,CACI,SACIA,OAAK,GAAGC,KAAY,SACpBC,OAAK,GAAGC,KAAY,eACpBC,aAAW,GAAGC,WAAkB,YAChCC,UAAQ,GAAGC,QAAe,EAC1B,MAAM,GAAGC,gBAAa,UACtBC,QAAM,GAAGC,MAAa,EACtB,UAAU,GAAG,EAAE,EACf,GAAG,SAAS,EACf,EACD,GAAG,MAEH,KAAA,CAAA,aAAA,CAAC,UAAU,EACP,EAAA,GAAG,EAAE,GAAG,EACR,IAAI,EAAC,SAAS,EACd,MAAM,EAAE,MAAM,EACd,KAAK,EAAER,OAAK,EACZ,UAAU,EAAE;AACR,QAAA,oBAAoB,EAAE,kBAAkB;AACxC,QAAA,GAAI,UAAqB;KAC5B,EACD,MAAM,EAAEO,QAAM,EACd,QAAQ,EAAEH,UAAQ,EAClB,WAAW,EAAEF,aAAW,EACxB,KAAK,EAAEJ,OAAK,EACZ,OAAO,EAAE,OAAO,KACZ,SAAS,EAAA,CACf,CACL;;;;"}
1
+ {"version":3,"file":"Component.desktop.js","sources":["../../src/desktop/Component.desktop.tsx"],"sourcesContent":["import React, { forwardRef } from 'react';\n\nimport { FormControlDesktop } from '@alfalab/core-components-form-control/desktop';\nimport { Popover } from '@alfalab/core-components-popover';\n\nimport { Arrow as DefaultArrow } from '../components/arrow';\nimport { BaseSelect } from '../components/base-select';\nimport { Field as DefaultField } from '../components/field';\nimport { Optgroup as DefaultOptgroup } from '../components/optgroup';\nimport { Option as DefaultOption } from '../components/option';\nimport { OptionsList as DefaultOptionsList } from '../components/options-list';\nimport { Search as DefaultSearch } from '../components/search';\nimport { type SelectDesktopProps } from '../typings';\n\nexport const SelectDesktop = forwardRef<HTMLDivElement, SelectDesktopProps>(\n (\n {\n Arrow = DefaultArrow,\n Field = DefaultField,\n OptionsList = DefaultOptionsList,\n Optgroup = DefaultOptgroup,\n Option = DefaultOption,\n Search = DefaultSearch,\n fieldProps = {},\n ...restProps\n },\n ref,\n ) => (\n <BaseSelect\n ref={ref}\n view='desktop'\n Option={Option}\n Field={Field}\n fieldProps={{\n FormControlComponent: FormControlDesktop,\n ...(fieldProps as object),\n }}\n Search={Search}\n Optgroup={Optgroup}\n OptionsList={OptionsList}\n Arrow={Arrow}\n Popover={Popover}\n {...restProps}\n />\n ),\n);\n"],"names":["Arrow","DefaultArrow","Field","DefaultField","OptionsList","DefaultOptionsList","Optgroup","DefaultOptgroup","DefaultOption","Search","DefaultSearch"],"mappings":";;;;;;;;;;;;;;;;;;;;AAcO,MAAM,aAAa,GAAG,UAAU,CACnC,CACI,SACIA,OAAK,GAAGC,KAAY,SACpBC,OAAK,GAAGC,KAAY,eACpBC,aAAW,GAAGC,WAAkB,YAChCC,UAAQ,GAAGC,QAAe,EAC1B,MAAM,GAAGC,gBAAa,UACtBC,QAAM,GAAGC,MAAa,EACtB,UAAU,GAAG,EAAE,EACf,GAAG,SAAS,EACf,EACD,GAAG,MAEH,KAAA,CAAA,aAAA,CAAC,UAAU,EACP,EAAA,GAAG,EAAE,GAAG,EACR,IAAI,EAAC,SAAS,EACd,MAAM,EAAE,MAAM,EACd,KAAK,EAAER,OAAK,EACZ,UAAU,EAAE;AACR,QAAA,oBAAoB,EAAE,kBAAkB;AACxC,QAAA,GAAI,UAAqB;KAC5B,EACD,MAAM,EAAEO,QAAM,EACd,QAAQ,EAAEH,UAAQ,EAClB,WAAW,EAAEF,aAAW,EACxB,KAAK,EAAEJ,OAAK,EACZ,OAAO,EAAE,OAAO,KACZ,SAAS,EAAA,CACf,CACL;;;;"}
@@ -1,3 +1,3 @@
1
1
  import React from 'react';
2
- import { SelectMobileProps } from '../typings';
2
+ import { type SelectMobileProps } from '../typings';
3
3
  export declare const SelectMobile: React.ForwardRefExoticComponent<SelectMobileProps & React.RefAttributes<unknown>>;
@@ -1 +1 @@
1
- {"version":3,"file":"Component.mobile.js","sources":["../../src/mobile/Component.mobile.tsx"],"sourcesContent":["import React, { forwardRef } from 'react';\n\nimport { BottomSheet } from '@alfalab/core-components-bottom-sheet';\nimport { FormControlMobile } from '@alfalab/core-components-form-control/mobile';\nimport { ModalMobile } from '@alfalab/core-components-modal/mobile';\n\nimport { Arrow as DefaultArrow } from '../components/arrow';\nimport { BaseSelect } from '../components/base-select';\nimport { Field as DefaultField } from '../components/field';\nimport { Footer } from '../components/footer';\nimport { Optgroup as DefaultOptgroup } from '../components/optgroup';\nimport { Option as DefaultOption } from '../components/option';\nimport { OptionsList as DefaultOptionsList } from '../components/options-list';\nimport { Search as DefaultSearch } from '../components/search';\nimport { VirtualOptionsList as DefaultVirtualOptionsList } from '../components/virtual-options-list';\nimport { useSelectWithApply } from '../presets/useSelectWithApply/hook';\nimport { Header } from '../presets/useSelectWithApply/options-list-with-apply/header/Component';\nimport { AnyObject, OptionShape, SelectMobileProps } from '../typings';\n\nconst VIRTUAL_OPTIONS_LIST_THRESHOLD = 30;\n\nexport const SelectMobile = forwardRef(\n (\n {\n autocomplete = false,\n multiple = false,\n allowUnselect = false,\n disabled = false,\n closeOnSelect = !multiple,\n circularNavigation = false,\n defaultOpen = false,\n open: openProp,\n size = 56,\n optionsSize = 56,\n fieldProps = {},\n optionProps = {},\n optionsListProps = {},\n Arrow = DefaultArrow,\n Field = DefaultField,\n Optgroup = DefaultOptgroup,\n Option = DefaultOption,\n Search = DefaultSearch,\n selected,\n options,\n OptionsList = options.length > VIRTUAL_OPTIONS_LIST_THRESHOLD\n ? DefaultVirtualOptionsList\n : DefaultOptionsList,\n onChange,\n showClear = true,\n showSelectAll,\n showHeaderWithSelectAll,\n useWithApplyHook = multiple,\n showSearch,\n searchProps,\n ...restProps\n }: SelectMobileProps,\n ref,\n ) => {\n const applyProps = useSelectWithApply({\n optionsListProps: {\n ...(optionsListProps as AnyObject),\n Footer,\n },\n OptionsList,\n showSearch,\n searchProps,\n selected,\n options,\n onChange,\n showClear,\n showSelectAll,\n });\n\n const bottomAddons = (flatOptions: OptionShape[]) =>\n flatOptions.length > 0 &&\n useWithApplyHook &&\n showHeaderWithSelectAll && (\n <Header {...applyProps.optionsListProps.headerProps} mobile={true} />\n );\n\n return (\n <BaseSelect\n ref={ref}\n view='mobile'\n autocomplete={autocomplete}\n multiple={multiple}\n allowUnselect={allowUnselect}\n disabled={disabled}\n closeOnSelect={closeOnSelect}\n circularNavigation={circularNavigation}\n defaultOpen={defaultOpen}\n open={openProp}\n size={size}\n optionsSize={optionsSize}\n fieldProps={{\n FormControlComponent: FormControlMobile,\n ...(fieldProps as object),\n }}\n optionProps={optionProps}\n Arrow={Arrow}\n Field={Field}\n Optgroup={Optgroup}\n Option={Option}\n Search={Search}\n options={options}\n selected={selected}\n onChange={onChange}\n OptionsList={OptionsList}\n showSearch={showSearch}\n searchProps={searchProps}\n BottomSheet={BottomSheet}\n ModalMobile={ModalMobile}\n optionsListProps={optionsListProps}\n {...restProps}\n {...(restProps.isBottomSheet === false\n ? {\n modalHeaderProps: {\n bottomAddons,\n ...restProps.modalHeaderProps,\n },\n }\n : {\n bottomSheetProps: {\n bottomAddons,\n showSwipeMarker: false,\n ...restProps.bottomSheetProps,\n },\n })}\n {...(useWithApplyHook && applyProps)}\n />\n );\n },\n);\n"],"names":["Arrow","DefaultArrow","Field","DefaultField","Optgroup","DefaultOptgroup","DefaultOption","Search","DefaultSearch","OptionsList","DefaultVirtualOptionsList","DefaultOptionsList"],"mappings":"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"}
1
+ {"version":3,"file":"Component.mobile.js","sources":["../../src/mobile/Component.mobile.tsx"],"sourcesContent":["import React, { forwardRef } from 'react';\n\nimport { BottomSheet } from '@alfalab/core-components-bottom-sheet';\nimport { FormControlMobile } from '@alfalab/core-components-form-control/mobile';\nimport { ModalMobile } from '@alfalab/core-components-modal/mobile';\n\nimport { Arrow as DefaultArrow } from '../components/arrow';\nimport { BaseSelect } from '../components/base-select';\nimport { Field as DefaultField } from '../components/field';\nimport { Footer } from '../components/footer';\nimport { Optgroup as DefaultOptgroup } from '../components/optgroup';\nimport { Option as DefaultOption } from '../components/option';\nimport { OptionsList as DefaultOptionsList } from '../components/options-list';\nimport { Search as DefaultSearch } from '../components/search';\nimport { VirtualOptionsList as DefaultVirtualOptionsList } from '../components/virtual-options-list';\nimport { useSelectWithApply } from '../presets/useSelectWithApply/hook';\nimport { Header } from '../presets/useSelectWithApply/options-list-with-apply/header/Component';\nimport { type AnyObject, type OptionShape, type SelectMobileProps } from '../typings';\n\nconst VIRTUAL_OPTIONS_LIST_THRESHOLD = 30;\n\nexport const SelectMobile = forwardRef(\n (\n {\n autocomplete = false,\n multiple = false,\n allowUnselect = false,\n disabled = false,\n closeOnSelect = !multiple,\n circularNavigation = false,\n defaultOpen = false,\n open: openProp,\n size = 56,\n optionsSize = 56,\n fieldProps = {},\n optionProps = {},\n optionsListProps = {},\n Arrow = DefaultArrow,\n Field = DefaultField,\n Optgroup = DefaultOptgroup,\n Option = DefaultOption,\n Search = DefaultSearch,\n selected,\n options,\n OptionsList = options.length > VIRTUAL_OPTIONS_LIST_THRESHOLD\n ? DefaultVirtualOptionsList\n : DefaultOptionsList,\n onChange,\n showClear = true,\n showSelectAll,\n showHeaderWithSelectAll,\n useWithApplyHook = multiple,\n showSearch,\n searchProps,\n ...restProps\n }: SelectMobileProps,\n ref,\n ) => {\n const applyProps = useSelectWithApply({\n optionsListProps: {\n ...(optionsListProps as AnyObject),\n Footer,\n },\n OptionsList,\n showSearch,\n searchProps,\n selected,\n options,\n onChange,\n showClear,\n showSelectAll,\n });\n\n const bottomAddons = (flatOptions: OptionShape[]) =>\n flatOptions.length > 0 &&\n useWithApplyHook &&\n showHeaderWithSelectAll && (\n <Header {...applyProps.optionsListProps.headerProps} mobile={true} />\n );\n\n return (\n <BaseSelect\n ref={ref}\n view='mobile'\n autocomplete={autocomplete}\n multiple={multiple}\n allowUnselect={allowUnselect}\n disabled={disabled}\n closeOnSelect={closeOnSelect}\n circularNavigation={circularNavigation}\n defaultOpen={defaultOpen}\n open={openProp}\n size={size}\n optionsSize={optionsSize}\n fieldProps={{\n FormControlComponent: FormControlMobile,\n ...(fieldProps as object),\n }}\n optionProps={optionProps}\n Arrow={Arrow}\n Field={Field}\n Optgroup={Optgroup}\n Option={Option}\n Search={Search}\n options={options}\n selected={selected}\n onChange={onChange}\n OptionsList={OptionsList}\n showSearch={showSearch}\n searchProps={searchProps}\n BottomSheet={BottomSheet}\n ModalMobile={ModalMobile}\n optionsListProps={optionsListProps}\n {...restProps}\n {...(restProps.isBottomSheet === false\n ? {\n modalHeaderProps: {\n bottomAddons,\n ...restProps.modalHeaderProps,\n },\n }\n : {\n bottomSheetProps: {\n bottomAddons,\n showSwipeMarker: false,\n ...restProps.bottomSheetProps,\n },\n })}\n {...(useWithApplyHook && applyProps)}\n />\n );\n },\n);\n"],"names":["Arrow","DefaultArrow","Field","DefaultField","Optgroup","DefaultOptgroup","DefaultOption","Search","DefaultSearch","OptionsList","DefaultVirtualOptionsList","DefaultOptionsList"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"Component.modal.mobile.js","sources":["../../src/mobile/Component.modal.mobile.tsx"],"sourcesContent":["import React, { forwardRef } from 'react';\n\nimport { SelectModalMobileProps } from '../typings';\n\nimport { SelectMobile } from './Component.mobile';\n\nexport const SelectModalMobile = forwardRef((props: SelectModalMobileProps, ref) => (\n <SelectMobile {...props} isBottomSheet={false} ref={ref} />\n));\n"],"names":[],"mappings":";;;AAMO,MAAM,iBAAiB,GAAG,UAAU,CAAC,CAAC,KAA6B,EAAE,GAAG,MAC3E,KAAC,CAAA,aAAA,CAAA,YAAY,EAAK,EAAA,GAAA,KAAK,EAAE,aAAa,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,EAAI,CAAA,CAC9D;;;;"}
1
+ {"version":3,"file":"Component.modal.mobile.js","sources":["../../src/mobile/Component.modal.mobile.tsx"],"sourcesContent":["import React, { forwardRef } from 'react';\n\nimport { type SelectModalMobileProps } from '../typings';\n\nimport { SelectMobile } from './Component.mobile';\n\nexport const SelectModalMobile = forwardRef((props: SelectModalMobileProps, ref) => (\n <SelectMobile {...props} isBottomSheet={false} ref={ref} />\n));\n"],"names":[],"mappings":";;;AAMO,MAAM,iBAAiB,GAAG,UAAU,CAAC,CAAC,KAA6B,EAAE,GAAG,MAC3E,KAAC,CAAA,aAAA,CAAA,YAAY,EAAK,EAAA,GAAA,KAAK,EAAE,aAAa,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,EAAI,CAAA,CAC9D;;;;"}
@@ -1,4 +1,4 @@
1
1
  export { useSelectWithLoading } from './useSelectWithLoading/hook.js';
2
2
  export { useLazyLoading } from './useLazyLoading/hook.js';
3
- export { SELECT_ALL_KEY, useSelectWithApply } from './useSelectWithApply/hook.js';
3
+ export { useSelectWithApply } from './useSelectWithApply/hook.js';
4
4
  //# sourceMappingURL=index.js.map
@@ -1,5 +1,5 @@
1
1
  import React from 'react';
2
- import { OptionProps, OptionShape } from '../../typings';
2
+ import { type OptionProps, type OptionShape } from '../../typings';
3
3
  import 'intersection-observer';
4
4
  declare type OptionsFetcherResponse = {
5
5
  options: OptionShape[];
@@ -1 +1 @@
1
- {"version":3,"file":"hook.js","sources":["../../../src/presets/useLazyLoading/hook.tsx"],"sourcesContent":["import React, { Reducer, useCallback, useEffect, useMemo, useReducer, useRef } from 'react';\n\nimport { InputProps } from '@alfalab/core-components-input';\nimport { Skeleton } from '@alfalab/core-components-skeleton';\n\nimport { Option as DefaultOption } from '../../components/option';\nimport { OptionProps, OptionShape } from '../../typings';\n\nimport 'intersection-observer';\n\nconst DEBOUNCE_TIMEOUT = 300;\n\ntype OptionsFetcherResponse = {\n options: OptionShape[];\n hasMore: boolean;\n};\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\ntype useLazyLoadingProps = {\n /** Количество элементов на \"странице\" */\n limit?: number;\n\n /** Начальный номер \"страницы\" */\n initialOffset?: number;\n\n /** Скелетон загружаемых элементов */\n skeleton?: React.ReactNode;\n\n /** Компонент пункта меню */\n Option?: React.FC<OptionProps>;\n\n /**\n * Функция-загрузчик опций.\n * @param offset - текущая страница\n * @param limit - количество элементов на странице\n * @param queryString - строчные данные, пробрасываемые для поиска из кастомного инпута, расположенного в заголовке OptionsList\n * @returns Promise<{\n * options - список опций следующей \"страницы\". Они аппендятся к предыдущим\n * hasMore - указывает, есть ли еще незагруженные элементы (в случае false перестает загружать \"следующую страницу\")\n * }>\n */\n optionsFetcher(\n offset: number,\n limit: number,\n queryString?: string,\n ): Promise<OptionsFetcherResponse>;\n};\n\nconst actions = {\n fetchOptionsStart() {\n return { type: 'FETCH_OPTIONS_START' } as const;\n },\n fetchOptionsBreak() {\n return { type: 'FETCH_OPTIONS_BREAK' } as const;\n },\n fetchOptionsSuccess(payload: { options: OptionShape[]; hasMore: boolean }) {\n return { type: 'FETCH_OPTIONS_SUCCESS', payload } as const;\n },\n setIsOpened(opened: boolean) {\n return { type: 'SET_IS_OPENED', payload: opened } as const;\n },\n setQueryString(qs: string) {\n return { type: 'SET_QUERY_STRING', payload: qs } as const;\n },\n reset() {\n return { type: 'RESET' } as const;\n },\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype Actions = typeof actions extends { [key: string]: (...args: any) => infer U } ? U : never;\n\nconst skeletonStyle: React.CSSProperties = {\n position: 'absolute',\n top: '50%',\n transform: 'translateY(-50%)',\n height: '16px',\n width: '50%',\n};\n\nexport function useLazyLoading({\n limit = 10,\n initialOffset = 0,\n optionsFetcher,\n skeleton = <Skeleton style={skeletonStyle} visible={true} />,\n Option = DefaultOption,\n}: useLazyLoadingProps) {\n const initialOptions: OptionShape[] = [];\n const initialLoading = false;\n\n const lazyLoadingInitialState = {\n opened: false,\n offset: initialOffset,\n options: initialOptions,\n loading: initialLoading,\n allOptionsLoaded: false,\n queryString: '',\n };\n\n const lazyLoadingReducer: Reducer<typeof lazyLoadingInitialState, Actions> = (\n state,\n action,\n ) => {\n switch (action.type) {\n case 'FETCH_OPTIONS_START': {\n return {\n ...state,\n loading: true,\n };\n }\n case 'FETCH_OPTIONS_BREAK': {\n return {\n ...state,\n loading: false,\n };\n }\n case 'FETCH_OPTIONS_SUCCESS': {\n return {\n ...state,\n options: [...state.options, ...action.payload.options],\n offset: state.offset + (action.payload.options.length ? 1 : 0),\n allOptionsLoaded: !action.payload.hasMore,\n loading: false,\n };\n }\n case 'SET_IS_OPENED': {\n return {\n ...state,\n opened: action.payload,\n };\n }\n case 'SET_QUERY_STRING': {\n return {\n // Изменение queryString подразумевает сброс текущих опций.\n ...lazyLoadingInitialState,\n opened: state.opened,\n loading: true,\n queryString: action.payload,\n };\n }\n case 'RESET': {\n return {\n ...lazyLoadingInitialState,\n };\n }\n default: {\n return state;\n }\n }\n };\n\n const [{ opened, offset, options, loading, allOptionsLoaded, queryString }, dispatch] =\n useReducer(lazyLoadingReducer, lazyLoadingInitialState);\n\n const abortFetchingOptionsRef = useRef<() => void>();\n\n const fetchNextOffsetOptions = useCallback(() => {\n dispatch(actions.fetchOptionsStart());\n\n new Promise<OptionsFetcherResponse>((resolve, reject) => {\n // eslint-disable-next-line no-unused-expressions\n abortFetchingOptionsRef.current?.();\n abortFetchingOptionsRef.current = reject;\n optionsFetcher(offset, limit, queryString).then((res) => {\n resolve(res);\n });\n })\n .then((res) => {\n dispatch(actions.fetchOptionsSuccess(res));\n abortFetchingOptionsRef.current = undefined;\n })\n .catch(\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n () => {},\n );\n }, [optionsFetcher, offset, limit, queryString]);\n\n const listRef = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n let observer: IntersectionObserver;\n\n if (opened && !loading && !allOptionsLoaded) {\n observer = new IntersectionObserver(\n ([entry]) => {\n if (entry.isIntersecting) {\n if (observer) {\n observer.disconnect();\n }\n fetchNextOffsetOptions();\n }\n },\n {\n root: listRef.current,\n },\n );\n\n /*\n * Обсервим пересечение последней опции с контейнером.\n * Таким образом, загрузка следующей \"страницы\" начнется когда юзер доскроллит список\n * до верхнего края последней опции, что обеспечивает плавность\n */\n const optionList = listRef.current?.querySelectorAll('[role=\"option\"]');\n const lastOption = optionList?.[optionList.length - 1];\n\n if (lastOption) {\n observer.observe(lastOption);\n }\n }\n\n return () => {\n if (observer) {\n observer.disconnect();\n }\n };\n }, [offset, fetchNextOffsetOptions, opened, allOptionsLoaded, initialOffset, loading]);\n\n const onOpen = useCallback(\n (payload: { open?: boolean }) => {\n if (payload.open) {\n if (options.length === initialOptions.length) {\n fetchNextOffsetOptions();\n }\n } else {\n // eslint-disable-next-line no-unused-expressions\n abortFetchingOptionsRef.current?.();\n dispatch(actions.fetchOptionsBreak());\n }\n\n dispatch(actions.setIsOpened(payload.open ?? false));\n },\n [initialOptions.length, fetchNextOffsetOptions, options.length],\n );\n\n const fetchNextOptionsRef = useRef<() => void>();\n const fetchNextOptionsTimerRef = useRef<ReturnType<typeof setTimeout>>();\n\n useEffect(() => {\n fetchNextOptionsRef.current = fetchNextOffsetOptions;\n }, [fetchNextOffsetOptions]);\n\n const onQueryStringChange = useCallback<Exclude<InputProps['onChange'], undefined>>(\n (_, payload) => {\n dispatch(actions.setQueryString(payload.value));\n /* eslint-disable no-unused-expressions */\n\n /*\n * Если во время загрузки опций юзер ввел новый текст в инпут,\n * нужно прервать текущую загрузку, чтобы неактуальные опции не попали в выдачу\n */\n abortFetchingOptionsRef.current?.();\n\n listRef.current?.scrollTo({ top: 0 });\n\n /* Дебаунсим ввод текста, чтобы не отправлять запрос к новым опциям на каждый чих */\n if (fetchNextOptionsTimerRef.current) {\n clearTimeout(fetchNextOptionsTimerRef.current);\n }\n fetchNextOptionsTimerRef.current = setTimeout(() => {\n /*\n * После дебаунса необходимо вызвать функцию-загрузчик,\n * содержащую актуальные на данный момент данные оффсета и queryString.\n * Поэтому мы не можем обратиться напрямую к функции fetchNextOptions,\n * так как она будет замкнута на старые значения, актуальные на момент вызова хэндлера,\n * так что берем ее из обновляемого рефа\n */\n fetchNextOptionsRef.current?.();\n }, DEBOUNCE_TIMEOUT);\n /* eslint-enable */\n },\n [],\n );\n\n const renderOption = (props: OptionProps) => (\n <Option {...props} highlighted={loading ? false : props.highlighted} />\n );\n\n const skeletonOptions: OptionShape[] = useMemo(\n () =>\n Array(loading ? limit : 0)\n .fill(0)\n .map((_, key) => ({\n key: `loading-${key}`,\n disabled: true,\n content: skeleton,\n })),\n [loading, limit, skeleton],\n );\n\n const reset = useCallback(() => {\n dispatch(actions.reset());\n }, []);\n\n return {\n optionsProps: {\n Option: renderOption,\n options: [...options, ...skeletonOptions],\n optionsListProps: {\n ref: listRef,\n inputProps: {\n onChange: onQueryStringChange,\n value: queryString,\n },\n },\n onOpen,\n },\n reset,\n };\n}\n"],"names":["DefaultOption"],"mappings":"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"}
1
+ {"version":3,"file":"hook.js","sources":["../../../src/presets/useLazyLoading/hook.tsx"],"sourcesContent":["import React, { type Reducer, useCallback, useEffect, useMemo, useReducer, useRef } from 'react';\n\nimport { type InputProps } from '@alfalab/core-components-input';\nimport { Skeleton } from '@alfalab/core-components-skeleton';\n\nimport { Option as DefaultOption } from '../../components/option';\nimport { type OptionProps, type OptionShape } from '../../typings';\n\nimport 'intersection-observer';\n\nconst DEBOUNCE_TIMEOUT = 300;\n\ntype OptionsFetcherResponse = {\n options: OptionShape[];\n hasMore: boolean;\n};\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\ntype useLazyLoadingProps = {\n /** Количество элементов на \"странице\" */\n limit?: number;\n\n /** Начальный номер \"страницы\" */\n initialOffset?: number;\n\n /** Скелетон загружаемых элементов */\n skeleton?: React.ReactNode;\n\n /** Компонент пункта меню */\n Option?: React.FC<OptionProps>;\n\n /**\n * Функция-загрузчик опций.\n * @param offset - текущая страница\n * @param limit - количество элементов на странице\n * @param queryString - строчные данные, пробрасываемые для поиска из кастомного инпута, расположенного в заголовке OptionsList\n * @returns Promise<{\n * options - список опций следующей \"страницы\". Они аппендятся к предыдущим\n * hasMore - указывает, есть ли еще незагруженные элементы (в случае false перестает загружать \"следующую страницу\")\n * }>\n */\n optionsFetcher(\n offset: number,\n limit: number,\n queryString?: string,\n ): Promise<OptionsFetcherResponse>;\n};\n\nconst actions = {\n fetchOptionsStart() {\n return { type: 'FETCH_OPTIONS_START' } as const;\n },\n fetchOptionsBreak() {\n return { type: 'FETCH_OPTIONS_BREAK' } as const;\n },\n fetchOptionsSuccess(payload: { options: OptionShape[]; hasMore: boolean }) {\n return { type: 'FETCH_OPTIONS_SUCCESS', payload } as const;\n },\n setIsOpened(opened: boolean) {\n return { type: 'SET_IS_OPENED', payload: opened } as const;\n },\n setQueryString(qs: string) {\n return { type: 'SET_QUERY_STRING', payload: qs } as const;\n },\n reset() {\n return { type: 'RESET' } as const;\n },\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype Actions = typeof actions extends { [key: string]: (...args: any) => infer U } ? U : never;\n\nconst skeletonStyle: React.CSSProperties = {\n position: 'absolute',\n top: '50%',\n transform: 'translateY(-50%)',\n height: '16px',\n width: '50%',\n};\n\nexport function useLazyLoading({\n limit = 10,\n initialOffset = 0,\n optionsFetcher,\n skeleton = <Skeleton style={skeletonStyle} visible={true} />,\n Option = DefaultOption,\n}: useLazyLoadingProps) {\n const initialOptions: OptionShape[] = [];\n const initialLoading = false;\n\n const lazyLoadingInitialState = {\n opened: false,\n offset: initialOffset,\n options: initialOptions,\n loading: initialLoading,\n allOptionsLoaded: false,\n queryString: '',\n };\n\n const lazyLoadingReducer: Reducer<typeof lazyLoadingInitialState, Actions> = (\n state,\n action,\n ) => {\n switch (action.type) {\n case 'FETCH_OPTIONS_START': {\n return {\n ...state,\n loading: true,\n };\n }\n case 'FETCH_OPTIONS_BREAK': {\n return {\n ...state,\n loading: false,\n };\n }\n case 'FETCH_OPTIONS_SUCCESS': {\n return {\n ...state,\n options: [...state.options, ...action.payload.options],\n offset: state.offset + (action.payload.options.length ? 1 : 0),\n allOptionsLoaded: !action.payload.hasMore,\n loading: false,\n };\n }\n case 'SET_IS_OPENED': {\n return {\n ...state,\n opened: action.payload,\n };\n }\n case 'SET_QUERY_STRING': {\n return {\n // Изменение queryString подразумевает сброс текущих опций.\n ...lazyLoadingInitialState,\n opened: state.opened,\n loading: true,\n queryString: action.payload,\n };\n }\n case 'RESET': {\n return {\n ...lazyLoadingInitialState,\n };\n }\n default: {\n return state;\n }\n }\n };\n\n const [{ opened, offset, options, loading, allOptionsLoaded, queryString }, dispatch] =\n useReducer(lazyLoadingReducer, lazyLoadingInitialState);\n\n const abortFetchingOptionsRef = useRef<() => void>();\n\n const fetchNextOffsetOptions = useCallback(() => {\n dispatch(actions.fetchOptionsStart());\n\n new Promise<OptionsFetcherResponse>((resolve, reject) => {\n // eslint-disable-next-line no-unused-expressions\n abortFetchingOptionsRef.current?.();\n abortFetchingOptionsRef.current = reject;\n optionsFetcher(offset, limit, queryString).then((res) => {\n resolve(res);\n });\n })\n .then((res) => {\n dispatch(actions.fetchOptionsSuccess(res));\n abortFetchingOptionsRef.current = undefined;\n })\n .catch(\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n () => {},\n );\n }, [optionsFetcher, offset, limit, queryString]);\n\n const listRef = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n let observer: IntersectionObserver;\n\n if (opened && !loading && !allOptionsLoaded) {\n observer = new IntersectionObserver(\n ([entry]) => {\n if (entry.isIntersecting) {\n if (observer) {\n observer.disconnect();\n }\n fetchNextOffsetOptions();\n }\n },\n {\n root: listRef.current,\n },\n );\n\n /*\n * Обсервим пересечение последней опции с контейнером.\n * Таким образом, загрузка следующей \"страницы\" начнется когда юзер доскроллит список\n * до верхнего края последней опции, что обеспечивает плавность\n */\n const optionList = listRef.current?.querySelectorAll('[role=\"option\"]');\n const lastOption = optionList?.[optionList.length - 1];\n\n if (lastOption) {\n observer.observe(lastOption);\n }\n }\n\n return () => {\n if (observer) {\n observer.disconnect();\n }\n };\n }, [offset, fetchNextOffsetOptions, opened, allOptionsLoaded, initialOffset, loading]);\n\n const onOpen = useCallback(\n (payload: { open?: boolean }) => {\n if (payload.open) {\n if (options.length === initialOptions.length) {\n fetchNextOffsetOptions();\n }\n } else {\n // eslint-disable-next-line no-unused-expressions\n abortFetchingOptionsRef.current?.();\n dispatch(actions.fetchOptionsBreak());\n }\n\n dispatch(actions.setIsOpened(payload.open ?? false));\n },\n [initialOptions.length, fetchNextOffsetOptions, options.length],\n );\n\n const fetchNextOptionsRef = useRef<() => void>();\n const fetchNextOptionsTimerRef = useRef<ReturnType<typeof setTimeout>>();\n\n useEffect(() => {\n fetchNextOptionsRef.current = fetchNextOffsetOptions;\n }, [fetchNextOffsetOptions]);\n\n const onQueryStringChange = useCallback<Exclude<InputProps['onChange'], undefined>>(\n (_, payload) => {\n dispatch(actions.setQueryString(payload.value));\n /* eslint-disable no-unused-expressions */\n\n /*\n * Если во время загрузки опций юзер ввел новый текст в инпут,\n * нужно прервать текущую загрузку, чтобы неактуальные опции не попали в выдачу\n */\n abortFetchingOptionsRef.current?.();\n\n listRef.current?.scrollTo({ top: 0 });\n\n /* Дебаунсим ввод текста, чтобы не отправлять запрос к новым опциям на каждый чих */\n if (fetchNextOptionsTimerRef.current) {\n clearTimeout(fetchNextOptionsTimerRef.current);\n }\n fetchNextOptionsTimerRef.current = setTimeout(() => {\n /*\n * После дебаунса необходимо вызвать функцию-загрузчик,\n * содержащую актуальные на данный момент данные оффсета и queryString.\n * Поэтому мы не можем обратиться напрямую к функции fetchNextOptions,\n * так как она будет замкнута на старые значения, актуальные на момент вызова хэндлера,\n * так что берем ее из обновляемого рефа\n */\n fetchNextOptionsRef.current?.();\n }, DEBOUNCE_TIMEOUT);\n /* eslint-enable */\n },\n [],\n );\n\n const renderOption = (props: OptionProps) => (\n <Option {...props} highlighted={loading ? false : props.highlighted} />\n );\n\n const skeletonOptions: OptionShape[] = useMemo(\n () =>\n Array(loading ? limit : 0)\n .fill(0)\n .map((_, key) => ({\n key: `loading-${key}`,\n disabled: true,\n content: skeleton,\n })),\n [loading, limit, skeleton],\n );\n\n const reset = useCallback(() => {\n dispatch(actions.reset());\n }, []);\n\n return {\n optionsProps: {\n Option: renderOption,\n options: [...options, ...skeletonOptions],\n optionsListProps: {\n ref: listRef,\n inputProps: {\n onChange: onQueryStringChange,\n value: queryString,\n },\n },\n onOpen,\n },\n reset,\n };\n}\n"],"names":["DefaultOption"],"mappings":"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"}
@@ -1,5 +1,5 @@
1
1
  /// <reference types="react" />
2
- import type { BaseSelectProps, OptionShape } from '../../typings';
2
+ import { type BaseSelectProps, type OptionShape } from '../../typings';
3
3
  export declare type UseSelectWithApplyProps = {
4
4
  /**
5
5
  * Список выбранных пунктов
@@ -56,7 +56,6 @@ export declare type UseSelectWithApplyProps = {
56
56
  */
57
57
  resetName?: string;
58
58
  };
59
- export declare const SELECT_ALL_KEY = "select_all";
60
59
  export declare function useSelectWithApply({ options, selected, onChange, onSelectAllClick, OptionsList, optionsListProps, showClear, showSelectAll, showHeaderWithSelectAll, showSearch, searchProps, applyName, resetName, }: UseSelectWithApplyProps): {
61
60
  OptionsList: import("react").ForwardRefExoticComponent<import("../../typings").OptionsListProps & {
62
61
  showClear?: boolean | undefined;