@alfalab/core-components-select 19.1.0 → 19.1.1-alfasans

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 (345) hide show
  1. package/Component.responsive.d.ts +1 -1
  2. package/Component.responsive.js.map +1 -1
  3. package/components/arrow/index.css +4 -4
  4. package/components/arrow/index.module.css.js +1 -1
  5. package/components/arrow/index.module.css.js.map +1 -1
  6. package/components/base-checkmark/index.css +12 -12
  7. package/components/base-checkmark/index.module.css.js +1 -1
  8. package/components/base-checkmark/index.module.css.js.map +1 -1
  9. package/components/base-option/index.css +19 -17
  10. package/components/base-option/index.module.css.js +1 -1
  11. package/components/base-option/index.module.css.js.map +1 -1
  12. package/components/base-select/Component.d.ts +5 -5
  13. package/components/base-select/Component.js.map +1 -1
  14. package/components/base-select/index.css +11 -11
  15. package/components/base-select/index.module.css.js +1 -1
  16. package/components/base-select/index.module.css.js.map +1 -1
  17. package/components/base-select/mobile.css +11 -11
  18. package/components/base-select/mobile.module.css.js +1 -1
  19. package/components/base-select/mobile.module.css.js.map +1 -1
  20. package/components/base-select/types/component-types.d.ts +4 -4
  21. package/components/checkmark/index.css +11 -11
  22. package/components/checkmark/index.module.css.js +1 -1
  23. package/components/checkmark/index.module.css.js.map +1 -1
  24. package/components/checkmark-mobile/index.css +6 -6
  25. package/components/checkmark-mobile/index.module.css.js +1 -1
  26. package/components/checkmark-mobile/index.module.css.js.map +1 -1
  27. package/components/clear-button/index.css +4 -4
  28. package/components/clear-button/index.module.css.js +1 -1
  29. package/components/field/Component.d.ts +1 -1
  30. package/components/field/index.css +22 -18
  31. package/components/field/index.module.css.js +1 -1
  32. package/components/field/index.module.css.js.map +1 -1
  33. package/components/footer/Component.d.ts +1 -1
  34. package/components/footer/index.css +4 -4
  35. package/components/footer/index.module.css.js +1 -1
  36. package/components/footer/index.module.css.js.map +1 -1
  37. package/components/native-select/Component.d.ts +1 -1
  38. package/components/optgroup/index.css +8 -7
  39. package/components/optgroup/index.module.css.js +1 -1
  40. package/components/optgroup/index.module.css.js.map +1 -1
  41. package/components/option/Component.d.ts +1 -2
  42. package/components/option/desktop/index.css +24 -22
  43. package/components/option/desktop/index.module.css.js +1 -1
  44. package/components/option/desktop/index.module.css.js.map +1 -1
  45. package/components/option/mobile/index.css +21 -19
  46. package/components/option/mobile/index.module.css.js +1 -1
  47. package/components/option/mobile/index.module.css.js.map +1 -1
  48. package/components/options-list/Component.d.ts +25 -25
  49. package/components/options-list/Component.js +3 -3
  50. package/components/options-list/Component.js.map +1 -1
  51. package/components/options-list/index.css +13 -13
  52. package/components/options-list/index.module.css.js +1 -1
  53. package/components/options-list/index.module.css.js.map +1 -1
  54. package/components/search/Component.js.map +1 -1
  55. package/components/search/index.css +1 -1
  56. package/components/search/index.module.css.js +1 -1
  57. package/components/search/index.module.css.js.map +1 -1
  58. package/components/virtual-options-list/Component.d.ts +25 -25
  59. package/components/virtual-options-list/Component.js.map +1 -1
  60. package/components/virtual-options-list/index.css +13 -13
  61. package/components/virtual-options-list/index.module.css.js +1 -1
  62. package/components/virtual-options-list/index.module.css.js.map +1 -1
  63. package/cssm/Component.responsive.d.ts +1 -1
  64. package/cssm/Component.responsive.js.map +1 -1
  65. package/cssm/components/base-option/index.module.css +5 -3
  66. package/cssm/components/base-select/Component.d.ts +5 -5
  67. package/cssm/components/base-select/Component.js.map +1 -1
  68. package/cssm/components/base-select/types/component-types.d.ts +4 -4
  69. package/cssm/components/field/Component.d.ts +1 -1
  70. package/cssm/components/field/index.module.css +9 -5
  71. package/cssm/components/footer/Component.d.ts +1 -1
  72. package/cssm/components/native-select/Component.d.ts +1 -1
  73. package/cssm/components/optgroup/index.module.css +4 -3
  74. package/cssm/components/option/Component.d.ts +1 -2
  75. package/cssm/components/option/desktop/index.module.css +5 -3
  76. package/cssm/components/option/mobile/index.module.css +5 -3
  77. package/cssm/components/options-list/Component.d.ts +25 -25
  78. package/cssm/components/options-list/Component.js +3 -3
  79. package/cssm/components/options-list/Component.js.map +1 -1
  80. package/cssm/components/search/Component.js.map +1 -1
  81. package/cssm/components/virtual-options-list/Component.d.ts +25 -25
  82. package/cssm/components/virtual-options-list/Component.js.map +1 -1
  83. package/cssm/desktop/Component.desktop.d.ts +1 -1
  84. package/cssm/hooks/use-native-scrollbar.d.ts +1 -1
  85. package/cssm/hooks/use-native-scrollbar.js.map +1 -1
  86. package/cssm/presets/useLazyLoading/hook.d.ts +2 -2
  87. package/cssm/presets/useLazyLoading/hook.js.map +1 -1
  88. package/cssm/presets/useSelectWithApply/hook.d.ts +97 -131
  89. package/cssm/presets/useSelectWithApply/hook.js.map +1 -1
  90. package/cssm/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +36 -69
  91. package/cssm/presets/useSelectWithApply/options-list-with-apply/Component.js.map +1 -1
  92. package/cssm/presets/useSelectWithApply/options-list-with-apply/footer/Component.d.ts +1 -1
  93. package/cssm/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +1 -1
  94. package/cssm/presets/useSelectWithLoading/hook.d.ts +1 -1
  95. package/cssm/typings.d.ts +21 -21
  96. package/cssm/utils.d.ts +4 -4
  97. package/cssm/utils.js.map +1 -1
  98. package/desktop/Component.desktop.d.ts +1 -1
  99. package/esm/Component.responsive.d.ts +1 -1
  100. package/esm/Component.responsive.js.map +1 -1
  101. package/esm/components/arrow/index.css +4 -4
  102. package/esm/components/arrow/index.module.css.js +1 -1
  103. package/esm/components/arrow/index.module.css.js.map +1 -1
  104. package/esm/components/base-checkmark/index.css +12 -12
  105. package/esm/components/base-checkmark/index.module.css.js +1 -1
  106. package/esm/components/base-checkmark/index.module.css.js.map +1 -1
  107. package/esm/components/base-option/index.css +19 -17
  108. package/esm/components/base-option/index.module.css.js +1 -1
  109. package/esm/components/base-option/index.module.css.js.map +1 -1
  110. package/esm/components/base-select/Component.d.ts +5 -5
  111. package/esm/components/base-select/Component.js.map +1 -1
  112. package/esm/components/base-select/index.css +11 -11
  113. package/esm/components/base-select/index.module.css.js +1 -1
  114. package/esm/components/base-select/index.module.css.js.map +1 -1
  115. package/esm/components/base-select/mobile.css +11 -11
  116. package/esm/components/base-select/mobile.module.css.js +1 -1
  117. package/esm/components/base-select/mobile.module.css.js.map +1 -1
  118. package/esm/components/base-select/types/component-types.d.ts +4 -4
  119. package/esm/components/checkmark/index.css +11 -11
  120. package/esm/components/checkmark/index.module.css.js +1 -1
  121. package/esm/components/checkmark/index.module.css.js.map +1 -1
  122. package/esm/components/checkmark-mobile/index.css +6 -6
  123. package/esm/components/checkmark-mobile/index.module.css.js +1 -1
  124. package/esm/components/checkmark-mobile/index.module.css.js.map +1 -1
  125. package/esm/components/clear-button/index.css +4 -4
  126. package/esm/components/clear-button/index.module.css.js +1 -1
  127. package/esm/components/field/Component.d.ts +1 -1
  128. package/esm/components/field/index.css +22 -18
  129. package/esm/components/field/index.module.css.js +1 -1
  130. package/esm/components/field/index.module.css.js.map +1 -1
  131. package/esm/components/footer/Component.d.ts +1 -1
  132. package/esm/components/footer/index.css +4 -4
  133. package/esm/components/footer/index.module.css.js +1 -1
  134. package/esm/components/footer/index.module.css.js.map +1 -1
  135. package/esm/components/native-select/Component.d.ts +1 -1
  136. package/esm/components/optgroup/index.css +8 -7
  137. package/esm/components/optgroup/index.module.css.js +1 -1
  138. package/esm/components/optgroup/index.module.css.js.map +1 -1
  139. package/esm/components/option/Component.d.ts +1 -2
  140. package/esm/components/option/desktop/index.css +24 -22
  141. package/esm/components/option/desktop/index.module.css.js +1 -1
  142. package/esm/components/option/desktop/index.module.css.js.map +1 -1
  143. package/esm/components/option/mobile/index.css +21 -19
  144. package/esm/components/option/mobile/index.module.css.js +1 -1
  145. package/esm/components/option/mobile/index.module.css.js.map +1 -1
  146. package/esm/components/options-list/Component.d.ts +25 -25
  147. package/esm/components/options-list/Component.js +3 -3
  148. package/esm/components/options-list/Component.js.map +1 -1
  149. package/esm/components/options-list/index.css +13 -13
  150. package/esm/components/options-list/index.module.css.js +1 -1
  151. package/esm/components/options-list/index.module.css.js.map +1 -1
  152. package/esm/components/search/Component.js.map +1 -1
  153. package/esm/components/search/index.css +1 -1
  154. package/esm/components/search/index.module.css.js +1 -1
  155. package/esm/components/search/index.module.css.js.map +1 -1
  156. package/esm/components/virtual-options-list/Component.d.ts +25 -25
  157. package/esm/components/virtual-options-list/Component.js.map +1 -1
  158. package/esm/components/virtual-options-list/index.css +13 -13
  159. package/esm/components/virtual-options-list/index.module.css.js +1 -1
  160. package/esm/components/virtual-options-list/index.module.css.js.map +1 -1
  161. package/esm/desktop/Component.desktop.d.ts +1 -1
  162. package/esm/hooks/use-native-scrollbar.d.ts +1 -1
  163. package/esm/hooks/use-native-scrollbar.js.map +1 -1
  164. package/esm/presets/useLazyLoading/hook.d.ts +2 -2
  165. package/esm/presets/useLazyLoading/hook.js.map +1 -1
  166. package/esm/presets/useSelectWithApply/hook.d.ts +97 -131
  167. package/esm/presets/useSelectWithApply/hook.js.map +1 -1
  168. package/esm/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +36 -69
  169. package/esm/presets/useSelectWithApply/options-list-with-apply/Component.js.map +1 -1
  170. package/esm/presets/useSelectWithApply/options-list-with-apply/footer/Component.d.ts +1 -1
  171. package/esm/presets/useSelectWithApply/options-list-with-apply/footer/index.css +3 -3
  172. package/esm/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js +1 -1
  173. package/esm/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js.map +1 -1
  174. package/esm/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +1 -1
  175. package/esm/presets/useSelectWithApply/options-list-with-apply/header/index.css +4 -4
  176. package/esm/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js +1 -1
  177. package/esm/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js.map +1 -1
  178. package/esm/presets/useSelectWithLoading/hook.d.ts +1 -1
  179. package/esm/presets/useSelectWithLoading/index.css +1 -1
  180. package/esm/presets/useSelectWithLoading/index.module.css.js +1 -1
  181. package/esm/typings.d.ts +21 -21
  182. package/esm/utils.d.ts +4 -4
  183. package/esm/utils.js.map +1 -1
  184. package/hooks/use-native-scrollbar.d.ts +1 -1
  185. package/hooks/use-native-scrollbar.js.map +1 -1
  186. package/modern/Component.responsive.d.ts +1 -1
  187. package/modern/Component.responsive.js.map +1 -1
  188. package/modern/components/arrow/index.css +4 -4
  189. package/modern/components/arrow/index.module.css.js +1 -1
  190. package/modern/components/arrow/index.module.css.js.map +1 -1
  191. package/modern/components/base-checkmark/index.css +12 -12
  192. package/modern/components/base-checkmark/index.module.css.js +1 -1
  193. package/modern/components/base-checkmark/index.module.css.js.map +1 -1
  194. package/modern/components/base-option/index.css +19 -17
  195. package/modern/components/base-option/index.module.css.js +1 -1
  196. package/modern/components/base-option/index.module.css.js.map +1 -1
  197. package/modern/components/base-select/Component.d.ts +5 -5
  198. package/modern/components/base-select/Component.js.map +1 -1
  199. package/modern/components/base-select/index.css +11 -11
  200. package/modern/components/base-select/index.module.css.js +1 -1
  201. package/modern/components/base-select/index.module.css.js.map +1 -1
  202. package/modern/components/base-select/mobile.css +11 -11
  203. package/modern/components/base-select/mobile.module.css.js +1 -1
  204. package/modern/components/base-select/mobile.module.css.js.map +1 -1
  205. package/modern/components/base-select/types/component-types.d.ts +4 -4
  206. package/modern/components/checkmark/index.css +11 -11
  207. package/modern/components/checkmark/index.module.css.js +1 -1
  208. package/modern/components/checkmark/index.module.css.js.map +1 -1
  209. package/modern/components/checkmark-mobile/index.css +6 -6
  210. package/modern/components/checkmark-mobile/index.module.css.js +1 -1
  211. package/modern/components/checkmark-mobile/index.module.css.js.map +1 -1
  212. package/modern/components/clear-button/index.css +4 -4
  213. package/modern/components/clear-button/index.module.css.js +1 -1
  214. package/modern/components/field/Component.d.ts +1 -1
  215. package/modern/components/field/index.css +22 -18
  216. package/modern/components/field/index.module.css.js +1 -1
  217. package/modern/components/field/index.module.css.js.map +1 -1
  218. package/modern/components/footer/Component.d.ts +1 -1
  219. package/modern/components/footer/index.css +4 -4
  220. package/modern/components/footer/index.module.css.js +1 -1
  221. package/modern/components/footer/index.module.css.js.map +1 -1
  222. package/modern/components/native-select/Component.d.ts +1 -1
  223. package/modern/components/optgroup/index.css +8 -7
  224. package/modern/components/optgroup/index.module.css.js +1 -1
  225. package/modern/components/optgroup/index.module.css.js.map +1 -1
  226. package/modern/components/option/Component.d.ts +1 -2
  227. package/modern/components/option/desktop/index.css +24 -22
  228. package/modern/components/option/desktop/index.module.css.js +1 -1
  229. package/modern/components/option/desktop/index.module.css.js.map +1 -1
  230. package/modern/components/option/mobile/index.css +21 -19
  231. package/modern/components/option/mobile/index.module.css.js +1 -1
  232. package/modern/components/option/mobile/index.module.css.js.map +1 -1
  233. package/modern/components/options-list/Component.d.ts +25 -25
  234. package/modern/components/options-list/Component.js +3 -3
  235. package/modern/components/options-list/Component.js.map +1 -1
  236. package/modern/components/options-list/index.css +13 -13
  237. package/modern/components/options-list/index.module.css.js +1 -1
  238. package/modern/components/options-list/index.module.css.js.map +1 -1
  239. package/modern/components/search/Component.js.map +1 -1
  240. package/modern/components/search/index.css +1 -1
  241. package/modern/components/search/index.module.css.js +1 -1
  242. package/modern/components/search/index.module.css.js.map +1 -1
  243. package/modern/components/virtual-options-list/Component.d.ts +25 -25
  244. package/modern/components/virtual-options-list/Component.js.map +1 -1
  245. package/modern/components/virtual-options-list/index.css +13 -13
  246. package/modern/components/virtual-options-list/index.module.css.js +1 -1
  247. package/modern/components/virtual-options-list/index.module.css.js.map +1 -1
  248. package/modern/desktop/Component.desktop.d.ts +1 -1
  249. package/modern/hooks/use-native-scrollbar.d.ts +1 -1
  250. package/modern/hooks/use-native-scrollbar.js.map +1 -1
  251. package/modern/presets/useLazyLoading/hook.d.ts +2 -2
  252. package/modern/presets/useLazyLoading/hook.js.map +1 -1
  253. package/modern/presets/useSelectWithApply/hook.d.ts +97 -131
  254. package/modern/presets/useSelectWithApply/hook.js.map +1 -1
  255. package/modern/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +36 -69
  256. package/modern/presets/useSelectWithApply/options-list-with-apply/Component.js.map +1 -1
  257. package/modern/presets/useSelectWithApply/options-list-with-apply/footer/Component.d.ts +1 -1
  258. package/modern/presets/useSelectWithApply/options-list-with-apply/footer/index.css +3 -3
  259. package/modern/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js +1 -1
  260. package/modern/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js.map +1 -1
  261. package/modern/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +1 -1
  262. package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.css +4 -4
  263. package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js +1 -1
  264. package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js.map +1 -1
  265. package/modern/presets/useSelectWithLoading/hook.d.ts +1 -1
  266. package/modern/presets/useSelectWithLoading/index.css +1 -1
  267. package/modern/presets/useSelectWithLoading/index.module.css.js +1 -1
  268. package/modern/typings.d.ts +21 -21
  269. package/modern/utils.d.ts +4 -4
  270. package/modern/utils.js.map +1 -1
  271. package/moderncssm/Component.responsive.d.ts +1 -1
  272. package/moderncssm/Component.responsive.js.map +1 -1
  273. package/moderncssm/components/base-option/index.module.css +2 -1
  274. package/moderncssm/components/base-select/Component.d.ts +5 -5
  275. package/moderncssm/components/base-select/Component.js.map +1 -1
  276. package/moderncssm/components/base-select/types/component-types.d.ts +4 -4
  277. package/moderncssm/components/field/Component.d.ts +1 -1
  278. package/moderncssm/components/field/index.module.css +6 -3
  279. package/moderncssm/components/footer/Component.d.ts +1 -1
  280. package/moderncssm/components/native-select/Component.d.ts +1 -1
  281. package/moderncssm/components/optgroup/index.module.css +1 -1
  282. package/moderncssm/components/option/Component.d.ts +1 -2
  283. package/moderncssm/components/option/desktop/index.module.css +2 -1
  284. package/moderncssm/components/option/mobile/index.module.css +2 -1
  285. package/moderncssm/components/options-list/Component.d.ts +25 -25
  286. package/moderncssm/components/options-list/Component.js +3 -3
  287. package/moderncssm/components/options-list/Component.js.map +1 -1
  288. package/moderncssm/components/search/Component.js.map +1 -1
  289. package/moderncssm/components/virtual-options-list/Component.d.ts +25 -25
  290. package/moderncssm/components/virtual-options-list/Component.js.map +1 -1
  291. package/moderncssm/desktop/Component.desktop.d.ts +1 -1
  292. package/moderncssm/hooks/use-native-scrollbar.d.ts +1 -1
  293. package/moderncssm/hooks/use-native-scrollbar.js.map +1 -1
  294. package/moderncssm/presets/useLazyLoading/hook.d.ts +2 -2
  295. package/moderncssm/presets/useLazyLoading/hook.js.map +1 -1
  296. package/moderncssm/presets/useSelectWithApply/hook.d.ts +97 -131
  297. package/moderncssm/presets/useSelectWithApply/hook.js.map +1 -1
  298. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +36 -69
  299. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/Component.js.map +1 -1
  300. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/footer/Component.d.ts +1 -1
  301. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +1 -1
  302. package/moderncssm/presets/useSelectWithLoading/hook.d.ts +1 -1
  303. package/moderncssm/typings.d.ts +21 -21
  304. package/moderncssm/utils.d.ts +4 -4
  305. package/moderncssm/utils.js.map +1 -1
  306. package/package.json +15 -15
  307. package/presets/useLazyLoading/hook.d.ts +2 -2
  308. package/presets/useLazyLoading/hook.js.map +1 -1
  309. package/presets/useSelectWithApply/hook.d.ts +97 -130
  310. package/presets/useSelectWithApply/hook.js.map +1 -1
  311. package/presets/useSelectWithApply/options-list-with-apply/Component.d.ts +36 -69
  312. package/presets/useSelectWithApply/options-list-with-apply/Component.js.map +1 -1
  313. package/presets/useSelectWithApply/options-list-with-apply/footer/Component.d.ts +1 -1
  314. package/presets/useSelectWithApply/options-list-with-apply/footer/index.css +3 -3
  315. package/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js +1 -1
  316. package/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js.map +1 -1
  317. package/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +1 -1
  318. package/presets/useSelectWithApply/options-list-with-apply/header/index.css +4 -4
  319. package/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js +1 -1
  320. package/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js.map +1 -1
  321. package/presets/useSelectWithLoading/hook.d.ts +1 -1
  322. package/presets/useSelectWithLoading/index.css +1 -1
  323. package/presets/useSelectWithLoading/index.module.css.js +1 -1
  324. package/src/components/arrow/index.module.css +1 -1
  325. package/src/components/base-checkmark/index.module.css +1 -1
  326. package/src/components/base-option/index.module.css +1 -1
  327. package/src/components/base-select/index.module.css +1 -1
  328. package/src/components/base-select/mobile.module.css +1 -1
  329. package/src/components/checkmark/index.module.css +1 -1
  330. package/src/components/checkmark-mobile/index.module.css +1 -1
  331. package/src/components/field/index.module.css +1 -1
  332. package/src/components/footer/index.module.css +1 -1
  333. package/src/components/optgroup/index.module.css +1 -1
  334. package/src/components/option/desktop/index.module.css +1 -1
  335. package/src/components/option/index.module.css +1 -1
  336. package/src/components/option/mobile/index.module.css +1 -1
  337. package/src/components/options-list/Component.tsx +3 -3
  338. package/src/components/options-list/index.module.css +1 -1
  339. package/src/components/search/index.module.css +1 -1
  340. package/src/components/virtual-options-list/index.module.css +1 -1
  341. package/src/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css +1 -1
  342. package/src/presets/useSelectWithApply/options-list-with-apply/header/index.module.css +1 -1
  343. package/typings.d.ts +21 -21
  344. package/utils.d.ts +4 -4
  345. package/utils.js.map +1 -1
@@ -1 +1 @@
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":["React","Skeleton","DefaultOption","__assign","__spreadArray","useReducer","useRef","useCallback","useEffect","useMemo"],"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":["React","Skeleton","DefaultOption","__assign","__spreadArray","useReducer","useRef","useCallback","useEffect","useMemo"],"mappings":"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"}
@@ -1,6 +1,5 @@
1
- /// <reference types="react" />
2
1
  import { type AnyObject, type BaseSelectProps, type OptionShape } from '../../typings';
3
- export declare type UseSelectWithApplyProps = {
2
+ export type UseSelectWithApplyProps = {
4
3
  /**
5
4
  * Список выбранных пунктов
6
5
  */
@@ -63,116 +62,83 @@ export declare type UseSelectWithApplyProps = {
63
62
  };
64
63
  export declare function useSelectWithApply({ options, selected, onChange, onSelectAllClick, OptionsList, optionsListProps, showClear, showSelectAll, showHeaderWithSelectAll, checkmarkPosition, showSearch, searchProps, applyName, resetName, }: UseSelectWithApplyProps): {
65
64
  OptionsList: import("react").ForwardRefExoticComponent<Pick<import("../../typings").SelectProps, "client"> & {
66
- className?: string | undefined;
67
- optionGroupClassName?: string | undefined;
68
- scrollbarClassName?: string | undefined;
69
- footerClassName?: string | undefined;
70
- size?: 40 | 48 | 56 | 64 | 72 | undefined;
65
+ className?: string;
66
+ optionGroupClassName?: string;
67
+ scrollbarClassName?: string;
68
+ footerClassName?: string;
69
+ size?: 40 | 48 | 56 | 64 | 72;
71
70
  Option: import("react").ComponentType<import("../../typings").OptionProps>;
72
71
  getOptionProps: (option: OptionShape, index: number) => import("../../typings").OptionProps;
73
- groupOptionProps?: AnyObject | undefined;
74
- selectedItems?: OptionShape[] | undefined;
72
+ groupOptionProps?: AnyObject;
73
+ selectedItems?: OptionShape[];
75
74
  setSelectedItems: (selected: OptionShape[]) => void;
76
75
  toggleMenu: () => void;
77
76
  header?: import("react").ReactNode;
78
77
  footer?: import("react").ReactNode;
79
- options?: (OptionShape | import("../../typings").GroupShape)[] | undefined;
80
- flatOptions?: OptionShape[] | undefined;
81
- highlightedIndex?: number | undefined;
82
- open?: boolean | undefined;
83
- Optgroup?: import("react").ComponentType<import("../../typings").OptgroupProps> | undefined;
78
+ options?: Array<OptionShape | import("../../typings").GroupShape>;
79
+ flatOptions?: OptionShape[];
80
+ highlightedIndex?: number;
81
+ open?: boolean;
82
+ Optgroup?: BaseSelectProps["Optgroup"];
84
83
  emptyPlaceholder?: import("react").ReactNode;
85
- visibleOptions?: number | undefined;
86
- onScroll?: ((event: import("react").MouseEvent<HTMLDivElement, MouseEvent>) => void) | undefined;
87
- dataTestId?: string | undefined;
88
- inputProps?: import("@alfalab/core-components-input").InputProps | undefined;
89
- showFooter?: boolean | undefined;
90
- nativeScrollbar?: boolean | undefined;
91
- optionsListWidth?: "field" | "content" | undefined;
92
- onApply?: (() => void) | undefined;
93
- onClear?: (() => void) | undefined;
94
- setHighlightedIndex?: ((index: number) => void) | undefined;
95
- search?: string | undefined;
96
- multiple?: boolean | undefined;
97
- limitDynamicOptionGroupSize?: boolean | undefined;
84
+ visibleOptions?: number;
85
+ onScroll?: (event: import("react").MouseEvent<HTMLDivElement>) => void;
86
+ dataTestId?: string;
87
+ inputProps?: import("@alfalab/core-components-input").InputProps;
88
+ showFooter?: boolean;
89
+ nativeScrollbar?: boolean;
90
+ optionsListWidth?: BaseSelectProps["optionsListWidth"];
91
+ onApply?: () => void;
92
+ onClear?: () => void;
93
+ setHighlightedIndex?: (index: number) => void;
94
+ search?: string;
95
+ multiple?: boolean;
96
+ limitDynamicOptionGroupSize?: BaseSelectProps["limitDynamicOptionGroupSize"];
98
97
  } & {
99
- showClear?: boolean | undefined;
100
- onClose?: (() => void) | undefined;
101
- selectedDraft?: OptionShape[] | undefined;
102
- OptionsList?: import("react").FC<Pick<import("../../typings").SelectProps, "client"> & {
103
- className?: string | undefined;
104
- optionGroupClassName?: string | undefined;
105
- scrollbarClassName?: string | undefined;
106
- footerClassName?: string | undefined;
107
- size?: 40 | 48 | 56 | 64 | 72 | undefined;
108
- Option: import("react").ComponentType<import("../../typings").OptionProps>;
109
- getOptionProps: (option: OptionShape, index: number) => import("../../typings").OptionProps;
110
- groupOptionProps?: AnyObject | undefined;
111
- selectedItems?: OptionShape[] | undefined;
112
- setSelectedItems: (selected: OptionShape[]) => void;
113
- toggleMenu: () => void;
114
- header?: import("react").ReactNode;
115
- footer?: import("react").ReactNode;
116
- options?: (OptionShape | import("../../typings").GroupShape)[] | undefined;
117
- flatOptions?: OptionShape[] | undefined;
118
- highlightedIndex?: number | undefined;
119
- open?: boolean | undefined;
120
- Optgroup?: import("react").ComponentType<import("../../typings").OptgroupProps> | undefined;
121
- emptyPlaceholder?: import("react").ReactNode;
122
- visibleOptions?: number | undefined;
123
- onScroll?: ((event: import("react").MouseEvent<HTMLDivElement, MouseEvent>) => void) | undefined;
124
- dataTestId?: string | undefined;
125
- inputProps?: import("@alfalab/core-components-input").InputProps | undefined;
126
- showFooter?: boolean | undefined;
127
- nativeScrollbar?: boolean | undefined;
128
- optionsListWidth?: "field" | "content" | undefined;
129
- onApply?: (() => void) | undefined;
130
- onClear?: (() => void) | undefined;
131
- setHighlightedIndex?: ((index: number) => void) | undefined;
132
- search?: string | undefined;
133
- multiple?: boolean | undefined;
134
- limitDynamicOptionGroupSize?: boolean | undefined;
135
- } & import("react").RefAttributes<HTMLDivElement>> | undefined;
136
- Footer?: import("react").FC<import("./options-list-with-apply/footer/Component").FooterProps> | undefined;
137
- Header?: import("react").FC<import("./options-list-with-apply/header/Component").HeaderProps> | undefined;
138
- headerProps?: import("./options-list-with-apply/header/Component").HeaderProps | undefined;
139
- showHeaderWithSelectAll?: boolean | undefined;
140
- setSelectedDraft?: ((selectedDraft: OptionShape[]) => void) | undefined;
98
+ showClear?: boolean;
99
+ onClose?: () => void;
100
+ selectedDraft?: OptionShape[];
101
+ OptionsList?: import("react").FC<import("../../typings").OptionsListProps & import("react").RefAttributes<HTMLDivElement>>;
102
+ Footer?: import("react").FC<import("./options-list-with-apply/footer/Component").FooterProps>;
103
+ Header?: import("react").FC<import("./options-list-with-apply/header/Component").HeaderProps>;
104
+ headerProps?: import("./options-list-with-apply/header/Component").HeaderProps;
105
+ showHeaderWithSelectAll?: boolean;
106
+ setSelectedDraft?: (selectedDraft: OptionShape[]) => void;
141
107
  } & import("react").RefAttributes<HTMLDivElement>>;
142
108
  optionsListProps: {
143
109
  OptionsList: import("react").ComponentType<Pick<import("../../typings").SelectProps, "client"> & {
144
- className?: string | undefined;
145
- optionGroupClassName?: string | undefined;
146
- scrollbarClassName?: string | undefined;
147
- footerClassName?: string | undefined;
148
- size?: 40 | 48 | 56 | 64 | 72 | undefined;
110
+ className?: string;
111
+ optionGroupClassName?: string;
112
+ scrollbarClassName?: string;
113
+ footerClassName?: string;
114
+ size?: 40 | 48 | 56 | 64 | 72;
149
115
  Option: import("react").ComponentType<import("../../typings").OptionProps>;
150
116
  getOptionProps: (option: OptionShape, index: number) => import("../../typings").OptionProps;
151
- groupOptionProps?: AnyObject | undefined;
152
- selectedItems?: OptionShape[] | undefined;
117
+ groupOptionProps?: AnyObject;
118
+ selectedItems?: OptionShape[];
153
119
  setSelectedItems: (selected: OptionShape[]) => void;
154
120
  toggleMenu: () => void;
155
121
  header?: import("react").ReactNode;
156
122
  footer?: import("react").ReactNode;
157
- options?: (OptionShape | import("../../typings").GroupShape)[] | undefined;
158
- flatOptions?: OptionShape[] | undefined;
159
- highlightedIndex?: number | undefined;
160
- open?: boolean | undefined;
161
- Optgroup?: import("react").ComponentType<import("../../typings").OptgroupProps> | undefined;
123
+ options?: Array<OptionShape | import("../../typings").GroupShape>;
124
+ flatOptions?: OptionShape[];
125
+ highlightedIndex?: number;
126
+ open?: boolean;
127
+ Optgroup?: BaseSelectProps["Optgroup"];
162
128
  emptyPlaceholder?: import("react").ReactNode;
163
- visibleOptions?: number | undefined;
164
- onScroll?: ((event: import("react").MouseEvent<HTMLDivElement, MouseEvent>) => void) | undefined;
165
- dataTestId?: string | undefined;
166
- inputProps?: import("@alfalab/core-components-input").InputProps | undefined;
167
- showFooter?: boolean | undefined;
168
- nativeScrollbar?: boolean | undefined;
169
- optionsListWidth?: "field" | "content" | undefined;
170
- onApply?: (() => void) | undefined;
171
- onClear?: (() => void) | undefined;
172
- setHighlightedIndex?: ((index: number) => void) | undefined;
173
- search?: string | undefined;
174
- multiple?: boolean | undefined;
175
- limitDynamicOptionGroupSize?: boolean | undefined;
129
+ visibleOptions?: number;
130
+ onScroll?: (event: import("react").MouseEvent<HTMLDivElement>) => void;
131
+ dataTestId?: string;
132
+ inputProps?: import("@alfalab/core-components-input").InputProps;
133
+ showFooter?: boolean;
134
+ nativeScrollbar?: boolean;
135
+ optionsListWidth?: BaseSelectProps["optionsListWidth"];
136
+ onApply?: () => void;
137
+ onClear?: () => void;
138
+ setHighlightedIndex?: (index: number) => void;
139
+ search?: string;
140
+ multiple?: boolean;
141
+ limitDynamicOptionGroupSize?: BaseSelectProps["limitDynamicOptionGroupSize"];
176
142
  } & import("react").RefAttributes<HTMLDivElement>> | undefined;
177
143
  showClear: boolean;
178
144
  onClear: () => void;
@@ -194,49 +160,49 @@ export declare function useSelectWithApply({ options, selected, onChange, onSele
194
160
  searchProps: {
195
161
  value: string;
196
162
  onChange: ((value: string) => void) | undefined;
197
- componentProps?: import("../../typings").SearchProps | undefined;
198
- accessor?: ((option: OptionShape) => string) | undefined;
199
- filterFn?: ((optionText: string, search: string) => boolean) | undefined;
200
- filterGroup?: boolean | undefined;
201
- groupAccessor?: ((group: import("../../typings").GroupShape) => string | undefined) | undefined;
163
+ componentProps?: import("../../typings").SearchProps;
164
+ accessor?: (option: OptionShape) => string;
165
+ filterFn?: (optionText: string, search: string) => boolean;
166
+ filterGroup?: boolean;
167
+ groupAccessor?: (group: import("../../typings").GroupShape) => string | undefined;
202
168
  } | undefined;
203
169
  originalProps: {
204
170
  options: (OptionShape | import("../../typings").GroupShape)[];
205
171
  selected: string | OptionShape | (string | OptionShape)[] | null | undefined;
206
172
  onChange: (payload: import("../../typings").BaseSelectChangePayload) => void;
207
173
  OptionsList: import("react").ComponentType<Pick<import("../../typings").SelectProps, "client"> & {
208
- className?: string | undefined;
209
- optionGroupClassName?: string | undefined;
210
- scrollbarClassName?: string | undefined;
211
- footerClassName?: string | undefined;
212
- size?: 40 | 48 | 56 | 64 | 72 | undefined;
174
+ className?: string;
175
+ optionGroupClassName?: string;
176
+ scrollbarClassName?: string;
177
+ footerClassName?: string;
178
+ size?: 40 | 48 | 56 | 64 | 72;
213
179
  Option: import("react").ComponentType<import("../../typings").OptionProps>;
214
180
  getOptionProps: (option: OptionShape, index: number) => import("../../typings").OptionProps;
215
- groupOptionProps?: AnyObject | undefined;
216
- selectedItems?: OptionShape[] | undefined;
181
+ groupOptionProps?: AnyObject;
182
+ selectedItems?: OptionShape[];
217
183
  setSelectedItems: (selected: OptionShape[]) => void;
218
184
  toggleMenu: () => void;
219
185
  header?: import("react").ReactNode;
220
186
  footer?: import("react").ReactNode;
221
- options?: (OptionShape | import("../../typings").GroupShape)[] | undefined;
222
- flatOptions?: OptionShape[] | undefined;
223
- highlightedIndex?: number | undefined;
224
- open?: boolean | undefined;
225
- Optgroup?: import("react").ComponentType<import("../../typings").OptgroupProps> | undefined;
187
+ options?: Array<OptionShape | import("../../typings").GroupShape>;
188
+ flatOptions?: OptionShape[];
189
+ highlightedIndex?: number;
190
+ open?: boolean;
191
+ Optgroup?: BaseSelectProps["Optgroup"];
226
192
  emptyPlaceholder?: import("react").ReactNode;
227
- visibleOptions?: number | undefined;
228
- onScroll?: ((event: import("react").MouseEvent<HTMLDivElement, MouseEvent>) => void) | undefined;
229
- dataTestId?: string | undefined;
230
- inputProps?: import("@alfalab/core-components-input").InputProps | undefined;
231
- showFooter?: boolean | undefined;
232
- nativeScrollbar?: boolean | undefined;
233
- optionsListWidth?: "field" | "content" | undefined;
234
- onApply?: (() => void) | undefined;
235
- onClear?: (() => void) | undefined;
236
- setHighlightedIndex?: ((index: number) => void) | undefined;
237
- search?: string | undefined;
238
- multiple?: boolean | undefined;
239
- limitDynamicOptionGroupSize?: boolean | undefined;
193
+ visibleOptions?: number;
194
+ onScroll?: (event: import("react").MouseEvent<HTMLDivElement>) => void;
195
+ dataTestId?: string;
196
+ inputProps?: import("@alfalab/core-components-input").InputProps;
197
+ showFooter?: boolean;
198
+ nativeScrollbar?: boolean;
199
+ optionsListWidth?: BaseSelectProps["optionsListWidth"];
200
+ onApply?: () => void;
201
+ onClear?: () => void;
202
+ setHighlightedIndex?: (index: number) => void;
203
+ search?: string;
204
+ multiple?: boolean;
205
+ limitDynamicOptionGroupSize?: BaseSelectProps["limitDynamicOptionGroupSize"];
240
206
  } & import("react").RefAttributes<HTMLDivElement>> | undefined;
241
207
  optionsListProps: unknown;
242
208
  showClear: boolean;
@@ -245,13 +211,13 @@ export declare function useSelectWithApply({ options, selected, onChange, onSele
245
211
  checkmarkPosition: "before" | "after";
246
212
  showSearch: boolean;
247
213
  searchProps: {
248
- componentProps?: import("../../typings").SearchProps | undefined;
249
- accessor?: ((option: OptionShape) => string) | undefined;
250
- filterFn?: ((optionText: string, search: string) => boolean) | undefined;
251
- value?: string | undefined;
252
- onChange?: ((value: string) => void) | undefined;
253
- filterGroup?: boolean | undefined;
254
- groupAccessor?: ((group: import("../../typings").GroupShape) => string | undefined) | undefined;
214
+ componentProps?: import("../../typings").SearchProps;
215
+ accessor?: (option: OptionShape) => string;
216
+ filterFn?: (optionText: string, search: string) => boolean;
217
+ value?: string;
218
+ onChange?: (value: string) => void;
219
+ filterGroup?: boolean;
220
+ groupAccessor?: (group: import("../../typings").GroupShape) => string | undefined;
255
221
  };
256
222
  applyName: string;
257
223
  resetName: string;
@@ -1 +1 @@
1
- {"version":3,"file":"hook.js","sources":["../../../src/presets/useSelectWithApply/hook.ts"],"sourcesContent":["import { useEffect, useMemo, useRef, useState } from 'react';\nimport reactFastCompare from 'react-fast-compare';\n\nimport { SELECT_ALL_KEY } from '../../consts';\nimport { type AnyObject, type BaseSelectProps, type OptionShape } from '../../typings';\nimport {\n defaultAccessor,\n defaultFilterFn,\n defaultGroupAccessor,\n isGroup,\n processOptions,\n} from '../../utils';\n\nimport { OptionsListWithApply } from './options-list-with-apply';\n\nexport type UseSelectWithApplyProps = {\n /**\n * Список выбранных пунктов\n */\n selected: BaseSelectProps['selected'];\n\n /**\n * Список вариантов выбора\n */\n options: BaseSelectProps['options'];\n\n /**\n * Обработчик выбора\n */\n onChange: BaseSelectProps['onChange'];\n\n /**\n * Дополнительный обработчик клика на чекбокс выбрать все\n */\n onSelectAllClick?: (selectedMultiple: OptionShape[]) => void;\n\n /**\n * Компонент выпадающего меню\n */\n OptionsList?: BaseSelectProps['OptionsList'];\n\n /**\n * Пропсы, которые будут прокинуты в компонент списка\n */\n optionsListProps?: BaseSelectProps['optionsListProps'];\n\n /**\n * Включает отображение поиска\n */\n showSearch?: BaseSelectProps['showSearch'];\n\n /**\n * Настройки поиска\n */\n searchProps?: BaseSelectProps['searchProps'];\n\n /**\n * Показывать кнопку очистки\n */\n showClear?: boolean;\n\n /**\n * Показывать пункт \"Выбрать все\"\n */\n showSelectAll?: boolean;\n\n /**\n * Показывать пункт \"Выбрать все\" в заголовке списка\n */\n showHeaderWithSelectAll?: boolean;\n\n /**\n * Значение name при применении выбора\n * @default 'apply-footer'\n */\n applyName?: string;\n\n /**\n * Значение name при сбросе выбора\n * @default 'reset-footer'\n */\n resetName?: string;\n\n /**\n * Позиция чекбокса \"Выбрать все\" в Header\n * @default 'before'\n */\n checkmarkPosition?: 'before' | 'after';\n};\n\nconst selectAllOption = { key: SELECT_ALL_KEY, content: 'Выбрать все' };\n\nexport function useSelectWithApply({\n options,\n selected,\n onChange = () => null,\n onSelectAllClick = () => null,\n OptionsList,\n optionsListProps = {},\n showClear = true,\n showSelectAll = false,\n showHeaderWithSelectAll = false,\n checkmarkPosition = 'before',\n showSearch = false,\n searchProps = {},\n applyName = 'apply-footer',\n resetName = 'reset-footer',\n}: UseSelectWithApplyProps) {\n const [searchState, setSearchState] = useState('');\n\n const [search, setSearch] =\n typeof searchProps?.value === 'string'\n ? [searchProps.value, searchProps.onChange]\n : [searchState, setSearchState];\n\n const accessor = searchProps.accessor || defaultAccessor;\n const filterFn = searchProps.filterFn || defaultFilterFn;\n const groupAccessor = searchProps.groupAccessor ?? defaultGroupAccessor;\n const filterGroup = searchProps.filterGroup ?? false;\n\n const { flatOptions, filteredOptions, selectedOptions } = useMemo(\n () =>\n processOptions(\n options,\n selected,\n showSearch\n ? (option) => {\n if (isGroup(option)) {\n const groupAccessorValue = groupAccessor(option);\n\n return (\n typeof groupAccessorValue === 'string' &&\n filterFn(groupAccessorValue, search)\n );\n }\n\n return filterFn(accessor(option), search);\n }\n : undefined,\n filterGroup,\n ),\n [options, selected, showSearch, filterGroup, filterFn, accessor, search, groupAccessor],\n );\n const [selectedDraft, setSelectedDraft] = useState<OptionShape[]>(selectedOptions);\n\n const selectedOptionsRef = useRef<OptionShape[]>(selectedOptions);\n\n const handleApply = () => {\n onChange({\n selected: selectedDraft[0],\n selectedMultiple: selectedDraft,\n initiator: null,\n name: applyName,\n });\n };\n\n const handleClear = () => {\n setSelectedDraft([]);\n onChange({\n selected: null,\n selectedMultiple: [],\n initiator: null,\n name: resetName,\n });\n };\n\n const handleToggleAll = () => {\n const optionsToSet = flatOptions.length === selectedDraft.length ? [] : flatOptions;\n\n onSelectAllClick(optionsToSet);\n setSelectedDraft(optionsToSet);\n };\n\n const selectedKeys = useMemo(() => selectedDraft.map(({ key }) => key), [selectedDraft]);\n\n const handleChange: Required<BaseSelectProps>['onChange'] = ({ initiator, ...restArgs }) => {\n if (!initiator) {\n onChange({\n initiator: null,\n ...restArgs,\n });\n\n return;\n }\n\n const initiatorSelected =\n selectedDraft.some(\n (selectedDraftOption) => selectedDraftOption.key === initiator.key,\n ) ||\n (initiator.key === SELECT_ALL_KEY &&\n (selectedDraft.length === flatOptions.length ||\n flatOptions.every(({ key }) => selectedKeys.includes(key))));\n\n if (initiator.key === SELECT_ALL_KEY) {\n setSelectedDraft(initiatorSelected ? [] : flatOptions);\n } else {\n setSelectedDraft(\n initiatorSelected\n ? selectedDraft.filter((o) => o.key !== initiator.key)\n : selectedDraft.concat(initiator),\n );\n }\n };\n\n const handleClose = () => setSelectedDraft(selectedOptionsRef.current);\n\n useEffect(() => {\n // устанавливать selectedDraft если selectedOptions изменились\n if (!reactFastCompare(selectedOptionsRef.current, selectedOptions)) {\n setSelectedDraft(selectedOptions);\n }\n selectedOptionsRef.current = selectedOptions;\n }, [selectedOptions]);\n\n const memoizedOptions = useMemo(\n () =>\n filteredOptions.length && showSelectAll\n ? [selectAllOption, ...filteredOptions]\n : filteredOptions,\n [filteredOptions, showSelectAll],\n );\n\n return {\n OptionsList: OptionsListWithApply,\n optionsListProps: {\n ...(optionsListProps as AnyObject),\n OptionsList,\n showClear,\n onClear: handleClear,\n onApply: handleApply,\n onClose: handleClose,\n selectedDraft,\n setSelectedDraft,\n showHeaderWithSelectAll,\n headerProps: {\n ...(optionsListProps as AnyObject)?.headerProps,\n indeterminate: selectedDraft.length > 0,\n checked:\n selectedDraft.length === flatOptions.length ||\n flatOptions.every(({ key }) => selectedKeys.includes(key)),\n onChange: handleToggleAll,\n checkmarkPosition,\n },\n },\n multiple: true,\n options: memoizedOptions,\n onChange: handleChange,\n selected,\n showSearch,\n searchProps: showSearch\n ? {\n ...searchProps,\n value: search,\n onChange: setSearch,\n }\n : undefined,\n /* Костыль для респонсив селекта. В мобильную версию хук уже зашит, и это единственный передать в мобилку оригинальные пропсы */\n originalProps: {\n options,\n selected,\n onChange,\n OptionsList,\n optionsListProps,\n showClear,\n showSelectAll,\n showHeaderWithSelectAll,\n checkmarkPosition,\n showSearch,\n searchProps,\n applyName,\n resetName,\n },\n };\n}\n"],"names":["SELECT_ALL_KEY","useState","defaultAccessor","defaultFilterFn","defaultGroupAccessor","useMemo","processOptions","isGroup","useRef","__rest","useEffect","reactFastCompare","OptionsListWithApply","__assign"],"mappings":"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"}
1
+ {"version":3,"file":"hook.js","sources":["../../../src/presets/useSelectWithApply/hook.ts"],"sourcesContent":["import { useEffect, useMemo, useRef, useState } from 'react';\nimport reactFastCompare from 'react-fast-compare';\n\nimport { SELECT_ALL_KEY } from '../../consts';\nimport { type AnyObject, type BaseSelectProps, type OptionShape } from '../../typings';\nimport {\n defaultAccessor,\n defaultFilterFn,\n defaultGroupAccessor,\n isGroup,\n processOptions,\n} from '../../utils';\n\nimport { OptionsListWithApply } from './options-list-with-apply';\n\nexport type UseSelectWithApplyProps = {\n /**\n * Список выбранных пунктов\n */\n selected: BaseSelectProps['selected'];\n\n /**\n * Список вариантов выбора\n */\n options: BaseSelectProps['options'];\n\n /**\n * Обработчик выбора\n */\n onChange: BaseSelectProps['onChange'];\n\n /**\n * Дополнительный обработчик клика на чекбокс выбрать все\n */\n onSelectAllClick?: (selectedMultiple: OptionShape[]) => void;\n\n /**\n * Компонент выпадающего меню\n */\n OptionsList?: BaseSelectProps['OptionsList'];\n\n /**\n * Пропсы, которые будут прокинуты в компонент списка\n */\n optionsListProps?: BaseSelectProps['optionsListProps'];\n\n /**\n * Включает отображение поиска\n */\n showSearch?: BaseSelectProps['showSearch'];\n\n /**\n * Настройки поиска\n */\n searchProps?: BaseSelectProps['searchProps'];\n\n /**\n * Показывать кнопку очистки\n */\n showClear?: boolean;\n\n /**\n * Показывать пункт \"Выбрать все\"\n */\n showSelectAll?: boolean;\n\n /**\n * Показывать пункт \"Выбрать все\" в заголовке списка\n */\n showHeaderWithSelectAll?: boolean;\n\n /**\n * Значение name при применении выбора\n * @default 'apply-footer'\n */\n applyName?: string;\n\n /**\n * Значение name при сбросе выбора\n * @default 'reset-footer'\n */\n resetName?: string;\n\n /**\n * Позиция чекбокса \"Выбрать все\" в Header\n * @default 'before'\n */\n checkmarkPosition?: 'before' | 'after';\n};\n\nconst selectAllOption = { key: SELECT_ALL_KEY, content: 'Выбрать все' };\n\nexport function useSelectWithApply({\n options,\n selected,\n onChange = () => null,\n onSelectAllClick = () => null,\n OptionsList,\n optionsListProps = {},\n showClear = true,\n showSelectAll = false,\n showHeaderWithSelectAll = false,\n checkmarkPosition = 'before',\n showSearch = false,\n searchProps = {},\n applyName = 'apply-footer',\n resetName = 'reset-footer',\n}: UseSelectWithApplyProps) {\n const [searchState, setSearchState] = useState('');\n\n const [search, setSearch] =\n typeof searchProps?.value === 'string'\n ? [searchProps.value, searchProps.onChange]\n : [searchState, setSearchState];\n\n const accessor = searchProps.accessor || defaultAccessor;\n const filterFn = searchProps.filterFn || defaultFilterFn;\n const groupAccessor = searchProps.groupAccessor ?? defaultGroupAccessor;\n const filterGroup = searchProps.filterGroup ?? false;\n\n const { flatOptions, filteredOptions, selectedOptions } = useMemo(\n () =>\n processOptions(\n options,\n selected,\n showSearch\n ? (option) => {\n if (isGroup(option)) {\n const groupAccessorValue = groupAccessor(option);\n\n return (\n typeof groupAccessorValue === 'string' &&\n filterFn(groupAccessorValue, search)\n );\n }\n\n return filterFn(accessor(option), search);\n }\n : undefined,\n filterGroup,\n ),\n [options, selected, showSearch, filterGroup, filterFn, accessor, search, groupAccessor],\n );\n const [selectedDraft, setSelectedDraft] = useState<OptionShape[]>(selectedOptions);\n\n const selectedOptionsRef = useRef<OptionShape[]>(selectedOptions);\n\n const handleApply = () => {\n onChange({\n selected: selectedDraft[0],\n selectedMultiple: selectedDraft,\n initiator: null,\n name: applyName,\n });\n };\n\n const handleClear = () => {\n setSelectedDraft([]);\n onChange({\n selected: null,\n selectedMultiple: [],\n initiator: null,\n name: resetName,\n });\n };\n\n const handleToggleAll = () => {\n const optionsToSet = flatOptions.length === selectedDraft.length ? [] : flatOptions;\n\n onSelectAllClick(optionsToSet);\n setSelectedDraft(optionsToSet);\n };\n\n const selectedKeys = useMemo(() => selectedDraft.map(({ key }) => key), [selectedDraft]);\n\n const handleChange: Required<BaseSelectProps>['onChange'] = ({ initiator, ...restArgs }) => {\n if (!initiator) {\n onChange({\n initiator: null,\n ...restArgs,\n });\n\n return;\n }\n\n const initiatorSelected =\n selectedDraft.some(\n (selectedDraftOption) => selectedDraftOption.key === initiator.key,\n ) ||\n (initiator.key === SELECT_ALL_KEY &&\n (selectedDraft.length === flatOptions.length ||\n flatOptions.every(({ key }) => selectedKeys.includes(key))));\n\n if (initiator.key === SELECT_ALL_KEY) {\n setSelectedDraft(initiatorSelected ? [] : flatOptions);\n } else {\n setSelectedDraft(\n initiatorSelected\n ? selectedDraft.filter((o) => o.key !== initiator.key)\n : selectedDraft.concat(initiator),\n );\n }\n };\n\n const handleClose = () => setSelectedDraft(selectedOptionsRef.current);\n\n useEffect(() => {\n // устанавливать selectedDraft если selectedOptions изменились\n if (!reactFastCompare(selectedOptionsRef.current, selectedOptions)) {\n setSelectedDraft(selectedOptions);\n }\n selectedOptionsRef.current = selectedOptions;\n }, [selectedOptions]);\n\n const memoizedOptions = useMemo(\n () =>\n filteredOptions.length && showSelectAll\n ? [selectAllOption, ...filteredOptions]\n : filteredOptions,\n [filteredOptions, showSelectAll],\n );\n\n return {\n OptionsList: OptionsListWithApply,\n optionsListProps: {\n ...(optionsListProps as AnyObject),\n OptionsList,\n showClear,\n onClear: handleClear,\n onApply: handleApply,\n onClose: handleClose,\n selectedDraft,\n setSelectedDraft,\n showHeaderWithSelectAll,\n headerProps: {\n ...(optionsListProps as AnyObject)?.headerProps,\n indeterminate: selectedDraft.length > 0,\n checked:\n selectedDraft.length === flatOptions.length ||\n flatOptions.every(({ key }) => selectedKeys.includes(key)),\n onChange: handleToggleAll,\n checkmarkPosition,\n },\n },\n multiple: true,\n options: memoizedOptions,\n onChange: handleChange,\n selected,\n showSearch,\n searchProps: showSearch\n ? {\n ...searchProps,\n value: search,\n onChange: setSearch,\n }\n : undefined,\n /* Костыль для респонсив селекта. В мобильную версию хук уже зашит, и это единственный передать в мобилку оригинальные пропсы */\n originalProps: {\n options,\n selected,\n onChange,\n OptionsList,\n optionsListProps,\n showClear,\n showSelectAll,\n showHeaderWithSelectAll,\n checkmarkPosition,\n showSearch,\n searchProps,\n applyName,\n resetName,\n },\n };\n}\n"],"names":["SELECT_ALL_KEY","useState","defaultAccessor","defaultFilterFn","defaultGroupAccessor","useMemo","processOptions","isGroup","useRef","__rest","useEffect","reactFastCompare","OptionsListWithApply","__assign"],"mappings":"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"}
@@ -1,81 +1,48 @@
1
- import React from 'react';
2
- import { type OptionShape } from '../../../typings';
1
+ import React, { type FC, type RefAttributes } from 'react';
2
+ import { type OptionShape, type OptionsListProps } from '../../../typings';
3
3
  import { type FooterProps } from './footer/Component';
4
4
  import { type HeaderProps } from './header/Component';
5
5
  export declare const OptionsListWithApply: React.ForwardRefExoticComponent<Pick<import("../../../typings").SelectProps, "client"> & {
6
- className?: string | undefined;
7
- optionGroupClassName?: string | undefined;
8
- scrollbarClassName?: string | undefined;
9
- footerClassName?: string | undefined;
10
- size?: 40 | 48 | 56 | 64 | 72 | undefined;
6
+ className?: string;
7
+ optionGroupClassName?: string;
8
+ scrollbarClassName?: string;
9
+ footerClassName?: string;
10
+ size?: 40 | 48 | 56 | 64 | 72;
11
11
  Option: React.ComponentType<import("../../../typings").OptionProps>;
12
12
  getOptionProps: (option: OptionShape, index: number) => import("../../../typings").OptionProps;
13
- groupOptionProps?: import("../../../typings").AnyObject | undefined;
14
- selectedItems?: OptionShape[] | undefined;
13
+ groupOptionProps?: import("../../../typings").AnyObject;
14
+ selectedItems?: OptionShape[];
15
15
  setSelectedItems: (selected: OptionShape[]) => void;
16
16
  toggleMenu: () => void;
17
17
  header?: React.ReactNode;
18
18
  footer?: React.ReactNode;
19
- options?: (OptionShape | import("../../../typings").GroupShape)[] | undefined;
20
- flatOptions?: OptionShape[] | undefined;
21
- highlightedIndex?: number | undefined;
22
- open?: boolean | undefined;
23
- Optgroup?: React.ComponentType<import("../../../typings").OptgroupProps> | undefined;
19
+ options?: Array<OptionShape | import("../../../typings").GroupShape>;
20
+ flatOptions?: OptionShape[];
21
+ highlightedIndex?: number;
22
+ open?: boolean;
23
+ Optgroup?: import("../../../typings").BaseSelectProps["Optgroup"];
24
24
  emptyPlaceholder?: React.ReactNode;
25
- visibleOptions?: number | undefined;
26
- onScroll?: ((event: React.MouseEvent<HTMLDivElement, MouseEvent>) => void) | undefined;
27
- dataTestId?: string | undefined;
28
- inputProps?: import("@alfalab/core-components-input").InputProps | undefined;
29
- showFooter?: boolean | undefined;
30
- nativeScrollbar?: boolean | undefined;
31
- optionsListWidth?: "field" | "content" | undefined;
32
- onApply?: (() => void) | undefined;
33
- onClear?: (() => void) | undefined;
34
- setHighlightedIndex?: ((index: number) => void) | undefined;
35
- search?: string | undefined;
36
- multiple?: boolean | undefined;
37
- limitDynamicOptionGroupSize?: boolean | undefined;
25
+ visibleOptions?: number;
26
+ onScroll?: (event: React.MouseEvent<HTMLDivElement>) => void;
27
+ dataTestId?: string;
28
+ inputProps?: import("@alfalab/core-components-input").InputProps;
29
+ showFooter?: boolean;
30
+ nativeScrollbar?: boolean;
31
+ optionsListWidth?: import("../../../typings").BaseSelectProps["optionsListWidth"];
32
+ onApply?: () => void;
33
+ onClear?: () => void;
34
+ setHighlightedIndex?: (index: number) => void;
35
+ search?: string;
36
+ multiple?: boolean;
37
+ limitDynamicOptionGroupSize?: import("../../../typings").BaseSelectProps["limitDynamicOptionGroupSize"];
38
38
  } & {
39
- showClear?: boolean | undefined;
40
- onClose?: (() => void) | undefined;
41
- selectedDraft?: OptionShape[] | undefined;
42
- OptionsList?: React.FC<Pick<import("../../../typings").SelectProps, "client"> & {
43
- className?: string | undefined;
44
- optionGroupClassName?: string | undefined;
45
- scrollbarClassName?: string | undefined;
46
- footerClassName?: string | undefined;
47
- size?: 40 | 48 | 56 | 64 | 72 | undefined;
48
- Option: React.ComponentType<import("../../../typings").OptionProps>;
49
- getOptionProps: (option: OptionShape, index: number) => import("../../../typings").OptionProps;
50
- groupOptionProps?: import("../../../typings").AnyObject | undefined;
51
- selectedItems?: OptionShape[] | undefined;
52
- setSelectedItems: (selected: OptionShape[]) => void;
53
- toggleMenu: () => void;
54
- header?: React.ReactNode;
55
- footer?: React.ReactNode;
56
- options?: (OptionShape | import("../../../typings").GroupShape)[] | undefined;
57
- flatOptions?: OptionShape[] | undefined;
58
- highlightedIndex?: number | undefined;
59
- open?: boolean | undefined;
60
- Optgroup?: React.ComponentType<import("../../../typings").OptgroupProps> | undefined;
61
- emptyPlaceholder?: React.ReactNode;
62
- visibleOptions?: number | undefined;
63
- onScroll?: ((event: React.MouseEvent<HTMLDivElement, MouseEvent>) => void) | undefined;
64
- dataTestId?: string | undefined;
65
- inputProps?: import("@alfalab/core-components-input").InputProps | undefined;
66
- showFooter?: boolean | undefined;
67
- nativeScrollbar?: boolean | undefined;
68
- optionsListWidth?: "field" | "content" | undefined;
69
- onApply?: (() => void) | undefined;
70
- onClear?: (() => void) | undefined;
71
- setHighlightedIndex?: ((index: number) => void) | undefined;
72
- search?: string | undefined;
73
- multiple?: boolean | undefined;
74
- limitDynamicOptionGroupSize?: boolean | undefined;
75
- } & React.RefAttributes<HTMLDivElement>> | undefined;
76
- Footer?: React.FC<FooterProps> | undefined;
77
- Header?: React.FC<HeaderProps> | undefined;
78
- headerProps?: HeaderProps | undefined;
79
- showHeaderWithSelectAll?: boolean | undefined;
80
- setSelectedDraft?: ((selectedDraft: OptionShape[]) => void) | undefined;
39
+ showClear?: boolean;
40
+ onClose?: () => void;
41
+ selectedDraft?: OptionShape[];
42
+ OptionsList?: React.FC<OptionsListProps & RefAttributes<HTMLDivElement>>;
43
+ Footer?: FC<FooterProps>;
44
+ Header?: FC<HeaderProps>;
45
+ headerProps?: HeaderProps;
46
+ showHeaderWithSelectAll?: boolean;
47
+ setSelectedDraft?: (selectedDraft: OptionShape[]) => void;
81
48
  } & React.RefAttributes<HTMLDivElement>>;
@@ -1 +1 @@
1
- {"version":3,"file":"Component.js","sources":["../../../../src/presets/useSelectWithApply/options-list-with-apply/Component.tsx"],"sourcesContent":["import React, { type FC, forwardRef, type RefAttributes, useCallback, useEffect } from 'react';\n\nimport { OptionsList as DefaultOptionsList } from '../../../components/options-list';\nimport { DEFAULT_VISIBLE_OPTIONS, SELECT_ALL_KEY } from '../../../consts';\nimport { type OptionShape, type OptionsListProps } from '../../../typings';\n\nimport { Footer as DefaultFooter, type FooterProps } from './footer/Component';\nimport { Header as DefaultHeader, type HeaderProps } from './header/Component';\n\ntype OptionsListWithApplyProps = OptionsListProps & {\n showClear?: boolean;\n onClose?: () => void;\n selectedDraft?: OptionShape[];\n OptionsList?: React.FC<OptionsListProps & RefAttributes<HTMLDivElement>>;\n Footer?: FC<FooterProps>;\n Header?: FC<HeaderProps>;\n headerProps?: HeaderProps;\n showHeaderWithSelectAll?: boolean;\n setSelectedDraft?: (selectedDraft: OptionShape[]) => void;\n};\n\nexport const OptionsListWithApply = forwardRef<HTMLDivElement, OptionsListWithApplyProps>(\n (\n {\n toggleMenu,\n getOptionProps: defaultGetOptionProps,\n showClear = true,\n showHeaderWithSelectAll,\n selectedDraft = [],\n flatOptions = [],\n OptionsList = DefaultOptionsList,\n onApply = () => null,\n onClear = () => null,\n onClose = () => null,\n visibleOptions = DEFAULT_VISIBLE_OPTIONS,\n Footer = DefaultFooter,\n Header = DefaultHeader,\n header,\n headerProps,\n setSelectedDraft,\n size,\n ...restProps\n }: OptionsListWithApplyProps,\n ref,\n ) => {\n const getOptionProps = useCallback(\n (option: OptionShape, index: number) => {\n const optionProps = defaultGetOptionProps(option, index);\n\n const selected =\n option.key === SELECT_ALL_KEY\n ? selectedDraft.length === flatOptions.length - 1\n : selectedDraft.some(({ key }) => key === option.key);\n\n return {\n ...optionProps,\n selected,\n };\n },\n [defaultGetOptionProps, flatOptions.length, selectedDraft],\n );\n\n const handleApply = useCallback(() => {\n onApply();\n\n toggleMenu();\n }, [onApply, toggleMenu]);\n\n const handleClear = useCallback(() => {\n onClear();\n\n toggleMenu();\n }, [onClear, toggleMenu]);\n\n const handleSelectedItems = useCallback(\n (items: OptionShape[]) => {\n setSelectedDraft?.(items);\n },\n [setSelectedDraft],\n );\n\n useEffect(() => {\n const activeElement = document.activeElement as HTMLElement;\n\n return () => {\n onClose();\n if (activeElement) {\n activeElement.focus();\n }\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n const renderHeader = () => {\n if (!showHeaderWithSelectAll && !header) return undefined;\n\n return (\n <React.Fragment>\n {header}\n {showHeaderWithSelectAll && flatOptions.length > 0 && (\n <Header {...headerProps} size={size} />\n )}\n </React.Fragment>\n );\n };\n\n return (\n <OptionsList\n {...restProps}\n size={size}\n ref={ref}\n visibleOptions={visibleOptions}\n toggleMenu={toggleMenu}\n flatOptions={flatOptions}\n getOptionProps={getOptionProps}\n onApply={handleApply}\n onClear={handleClear}\n header={renderHeader()}\n selectedItems={selectedDraft}\n setSelectedItems={handleSelectedItems}\n footer={\n <Footer\n handleApply={handleApply}\n handleClear={handleClear}\n showClear={showClear}\n selectedDraft={selectedDraft}\n dataTestId={restProps?.dataTestId}\n size={size}\n />\n }\n />\n );\n },\n);\n"],"names":["forwardRef","DefaultOptionsList","DEFAULT_VISIBLE_OPTIONS","DefaultFooter","DefaultHeader","__rest","useCallback","SELECT_ALL_KEY","__assign","useEffect","React"],"mappings":";;;;;;;;;;;;;;;IAqBa,oBAAoB,GAAGA,gBAAU,CAC1C,UACI,EAmB4B,EAC5B,GAAG,EAAA;IAnBC,IAAA,UAAU,gBAAA,EACM,qBAAqB,oBAAA,EACrC,EAAA,GAAA,EAAA,CAAA,SAAgB,EAAhB,SAAS,GAAG,EAAA,KAAA,MAAA,GAAA,IAAI,KAAA,EAChB,uBAAuB,GAAA,EAAA,CAAA,uBAAA,EACvB,EAAkB,GAAA,EAAA,CAAA,aAAA,EAAlB,aAAa,GAAG,EAAA,KAAA,MAAA,GAAA,EAAE,GAAA,EAAA,EAClB,EAAgB,GAAA,EAAA,CAAA,WAAA,EAAhB,WAAW,GAAG,EAAA,KAAA,MAAA,GAAA,EAAE,GAAA,EAAA,EAChB,EAAgC,GAAA,EAAA,CAAA,WAAA,EAAhC,WAAW,GAAG,EAAA,KAAA,MAAA,GAAAC,qBAAkB,GAAA,EAAA,EAChC,EAAoB,GAAA,EAAA,CAAA,OAAA,EAApB,OAAO,GAAG,EAAA,KAAA,MAAA,GAAA,YAAA,EAAM,OAAA,IAAI,CAAJ,EAAI,KAAA,EACpB,EAAA,GAAA,EAAA,CAAA,OAAoB,EAApB,OAAO,GAAG,EAAA,KAAA,MAAA,GAAA,YAAA,EAAM,OAAA,IAAI,CAAA,EAAA,GAAA,EAAA,EACpB,eAAoB,EAApB,OAAO,GAAG,EAAA,KAAA,MAAA,GAAA,YAAA,EAAM,OAAA,IAAI,GAAA,GAAA,EAAA,EACpB,EAAA,GAAA,EAAA,CAAA,cAAwC,EAAxC,cAAc,mBAAGC,8BAAuB,GAAA,EAAA,EACxC,EAAA,GAAA,EAAA,CAAA,MAAsB,EAAtB,MAAM,mBAAGC,kBAAa,GAAA,EAAA,EACtB,EAAA,GAAA,EAAA,CAAA,MAAsB,EAAtB,MAAM,mBAAGC,kBAAa,GAAA,EAAA,EACtB,MAAM,GAAA,EAAA,CAAA,MAAA,EACN,WAAW,GAAA,EAAA,CAAA,WAAA,EACX,gBAAgB,GAAA,EAAA,CAAA,gBAAA,EAChB,IAAI,UAAA,EACD,SAAS,GAlBhBC,YAAA,CAAA,EAAA,EAAA,CAAA,YAAA,EAAA,gBAAA,EAAA,WAAA,EAAA,yBAAA,EAAA,eAAA,EAAA,aAAA,EAAA,aAAA,EAAA,SAAA,EAAA,SAAA,EAAA,SAAA,EAAA,gBAAA,EAAA,QAAA,EAAA,QAAA,EAAA,QAAA,EAAA,aAAA,EAAA,kBAAA,EAAA,MAAA,CAmBC,CADe;AAIhB,IAAA,IAAM,cAAc,GAAGC,iBAAW,CAC9B,UAAC,MAAmB,EAAE,KAAa,EAAA;QAC/B,IAAM,WAAW,GAAG,qBAAqB,CAAC,MAAM,EAAE,KAAK,CAAC;AAExD,QAAA,IAAM,QAAQ,GACV,MAAM,CAAC,GAAG,KAAKC;cACT,aAAa,CAAC,MAAM,KAAK,WAAW,CAAC,MAAM,GAAG;AAChD,cAAE,aAAa,CAAC,IAAI,CAAC,UAAC,EAAO,EAAA;AAAL,gBAAA,IAAA,GAAG,GAAA,EAAA,CAAA,GAAA;AAAO,gBAAA,OAAA,GAAG,KAAK,MAAM,CAAC,GAAG;AAAlB,aAAkB,CAAC;AAE7D,QAAA,OAAAC,cAAA,CAAAA,cAAA,CAAA,EAAA,EACO,WAAW,CAAA,EAAA,EACd,QAAQ,EAAA,QAAA,EACV,CAAA;KACL,EACD,CAAC,qBAAqB,EAAE,WAAW,CAAC,MAAM,EAAE,aAAa,CAAC,CAC7D;IAED,IAAM,WAAW,GAAGF,iBAAW,CAAC,YAAA;AAC5B,QAAA,OAAO,EAAE;AAET,QAAA,UAAU,EAAE;AAChB,KAAC,EAAE,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;IAEzB,IAAM,WAAW,GAAGA,iBAAW,CAAC,YAAA;AAC5B,QAAA,OAAO,EAAE;AAET,QAAA,UAAU,EAAE;AAChB,KAAC,EAAE,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;AAEzB,IAAA,IAAM,mBAAmB,GAAGA,iBAAW,CACnC,UAAC,KAAoB,EAAA;AACjB,QAAA,gBAAgB,aAAhB,gBAAgB,KAAA,MAAA,GAAA,MAAA,GAAhB,gBAAgB,CAAG,KAAK,CAAC;AAC7B,KAAC,EACD,CAAC,gBAAgB,CAAC,CACrB;AAED,IAAAG,eAAS,CAAC,YAAA;AACN,QAAA,IAAM,aAAa,GAAG,QAAQ,CAAC,aAA4B;QAE3D,OAAO,YAAA;AACH,YAAA,OAAO,EAAE;AACT,YAAA,IAAI,aAAa,EAAE;gBACf,aAAa,CAAC,KAAK,EAAE;AACxB;AACL,SAAC;;KAEJ,EAAE,EAAE,CAAC;AAEN,IAAA,IAAM,YAAY,GAAG,YAAA;AACjB,QAAA,IAAI,CAAC,uBAAuB,IAAI,CAAC,MAAM;AAAE,YAAA,OAAO,SAAS;AAEzD,QAAA,QACIC,sBAAA,CAAA,aAAA,CAACA,sBAAK,CAAC,QAAQ,EAAA,IAAA;YACV,MAAM;YACN,uBAAuB,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,KAC9CA,sBAAC,CAAA,aAAA,CAAA,MAAM,qBAAK,WAAW,EAAA,EAAE,IAAI,EAAE,IAAI,IAAI,CAC1C,CACY;AAEzB,KAAC;AAED,IAAA,QACIA,sBAAC,CAAA,aAAA,CAAA,WAAW,qBACJ,SAAS,EAAA,EACb,IAAI,EAAE,IAAI,EACV,GAAG,EAAE,GAAG,EACR,cAAc,EAAE,cAAc,EAC9B,UAAU,EAAE,UAAU,EACtB,WAAW,EAAE,WAAW,EACxB,cAAc,EAAE,cAAc,EAC9B,OAAO,EAAE,WAAW,EACpB,OAAO,EAAE,WAAW,EACpB,MAAM,EAAE,YAAY,EAAE,EACtB,aAAa,EAAE,aAAa,EAC5B,gBAAgB,EAAE,mBAAmB,EACrC,MAAM,EACFA,sBAAC,CAAA,aAAA,CAAA,MAAM,IACH,WAAW,EAAE,WAAW,EACxB,WAAW,EAAE,WAAW,EACxB,SAAS,EAAE,SAAS,EACpB,aAAa,EAAE,aAAa,EAC5B,UAAU,EAAE,SAAS,aAAT,SAAS,KAAA,MAAA,GAAA,MAAA,GAAT,SAAS,CAAE,UAAU,EACjC,IAAI,EAAE,IAAI,EACZ,CAAA,EAAA,CAAA,CAER;AAEV,CAAC;;;;"}
1
+ {"version":3,"file":"Component.js","sources":["../../../../src/presets/useSelectWithApply/options-list-with-apply/Component.tsx"],"sourcesContent":["import React, { type FC, forwardRef, type RefAttributes, useCallback, useEffect } from 'react';\n\nimport { OptionsList as DefaultOptionsList } from '../../../components/options-list';\nimport { DEFAULT_VISIBLE_OPTIONS, SELECT_ALL_KEY } from '../../../consts';\nimport { type OptionShape, type OptionsListProps } from '../../../typings';\n\nimport { Footer as DefaultFooter, type FooterProps } from './footer/Component';\nimport { Header as DefaultHeader, type HeaderProps } from './header/Component';\n\ntype OptionsListWithApplyProps = OptionsListProps & {\n showClear?: boolean;\n onClose?: () => void;\n selectedDraft?: OptionShape[];\n OptionsList?: React.FC<OptionsListProps & RefAttributes<HTMLDivElement>>;\n Footer?: FC<FooterProps>;\n Header?: FC<HeaderProps>;\n headerProps?: HeaderProps;\n showHeaderWithSelectAll?: boolean;\n setSelectedDraft?: (selectedDraft: OptionShape[]) => void;\n};\n\nexport const OptionsListWithApply = forwardRef<HTMLDivElement, OptionsListWithApplyProps>(\n (\n {\n toggleMenu,\n getOptionProps: defaultGetOptionProps,\n showClear = true,\n showHeaderWithSelectAll,\n selectedDraft = [],\n flatOptions = [],\n OptionsList = DefaultOptionsList,\n onApply = () => null,\n onClear = () => null,\n onClose = () => null,\n visibleOptions = DEFAULT_VISIBLE_OPTIONS,\n Footer = DefaultFooter,\n Header = DefaultHeader,\n header,\n headerProps,\n setSelectedDraft,\n size,\n ...restProps\n }: OptionsListWithApplyProps,\n ref,\n ) => {\n const getOptionProps = useCallback(\n (option: OptionShape, index: number) => {\n const optionProps = defaultGetOptionProps(option, index);\n\n const selected =\n option.key === SELECT_ALL_KEY\n ? selectedDraft.length === flatOptions.length - 1\n : selectedDraft.some(({ key }) => key === option.key);\n\n return {\n ...optionProps,\n selected,\n };\n },\n [defaultGetOptionProps, flatOptions.length, selectedDraft],\n );\n\n const handleApply = useCallback(() => {\n onApply();\n\n toggleMenu();\n }, [onApply, toggleMenu]);\n\n const handleClear = useCallback(() => {\n onClear();\n\n toggleMenu();\n }, [onClear, toggleMenu]);\n\n const handleSelectedItems = useCallback(\n (items: OptionShape[]) => {\n setSelectedDraft?.(items);\n },\n [setSelectedDraft],\n );\n\n useEffect(() => {\n const activeElement = document.activeElement as HTMLElement;\n\n return () => {\n onClose();\n if (activeElement) {\n activeElement.focus();\n }\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n const renderHeader = () => {\n if (!showHeaderWithSelectAll && !header) return undefined;\n\n return (\n <React.Fragment>\n {header}\n {showHeaderWithSelectAll && flatOptions.length > 0 && (\n <Header {...headerProps} size={size} />\n )}\n </React.Fragment>\n );\n };\n\n return (\n <OptionsList\n {...restProps}\n size={size}\n ref={ref}\n visibleOptions={visibleOptions}\n toggleMenu={toggleMenu}\n flatOptions={flatOptions}\n getOptionProps={getOptionProps}\n onApply={handleApply}\n onClear={handleClear}\n header={renderHeader()}\n selectedItems={selectedDraft}\n setSelectedItems={handleSelectedItems}\n footer={\n <Footer\n handleApply={handleApply}\n handleClear={handleClear}\n showClear={showClear}\n selectedDraft={selectedDraft}\n dataTestId={restProps?.dataTestId}\n size={size}\n />\n }\n />\n );\n },\n);\n"],"names":["forwardRef","DefaultOptionsList","DEFAULT_VISIBLE_OPTIONS","DefaultFooter","DefaultHeader","__rest","useCallback","SELECT_ALL_KEY","__assign","useEffect","React"],"mappings":"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"}