@alfalab/core-components-select 14.3.5 → 15.0.1

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 (416) hide show
  1. package/Component.desktop.d.ts +19 -0
  2. package/{Component.js → Component.desktop.js} +6 -6
  3. package/Component.mobile-ebda875c.d.ts +6 -0
  4. package/Component.mobile-f1f15074.d.ts +387 -0
  5. package/Component.mobile.d.ts +41 -0
  6. package/Component.mobile.js +62 -0
  7. package/Component.modal.mobile.d.ts +60 -0
  8. package/Component.modal.mobile.js +62 -0
  9. package/Component.responsive.d.ts +1 -1
  10. package/Component.responsive.js +26 -25
  11. package/components/arrow/Component.js +1 -1
  12. package/components/arrow/index.css +3 -3
  13. package/components/base-checkmark/Component.js +1 -1
  14. package/components/base-checkmark/index.css +4 -4
  15. package/components/base-option/Component.js +1 -1
  16. package/components/base-option/index.css +13 -13
  17. package/components/base-select/Component.js +6 -6
  18. package/components/base-select/index.css +8 -8
  19. package/components/base-select/index.js +1 -1
  20. package/components/base-select-mobile/Component.d.ts +3 -3
  21. package/components/base-select-mobile/Component.js +13 -9
  22. package/components/base-select-mobile/footer/Component.js +4 -4
  23. package/components/base-select-mobile/footer/index.css +5 -5
  24. package/components/base-select-mobile/footer/index.js +1 -1
  25. package/components/base-select-mobile/index.css +13 -11
  26. package/components/base-select-mobile/index.js +1 -2
  27. package/components/checkmark/Component.js +1 -1
  28. package/components/checkmark/index.css +10 -10
  29. package/components/checkmark-mobile/Component.js +1 -1
  30. package/components/checkmark-mobile/index.css +6 -6
  31. package/components/field/Component.d.ts +8 -1
  32. package/components/field/Component.js +19 -16
  33. package/components/field/index.css +38 -11
  34. package/components/field/index.js +0 -1
  35. package/components/index.d.ts +0 -2
  36. package/components/index.js +4 -19
  37. package/components/optgroup/Component.js +1 -1
  38. package/components/optgroup/index.css +6 -6
  39. package/components/option/Component.js +1 -1
  40. package/components/option/index.css +20 -20
  41. package/components/options-list/Component.js +1 -1
  42. package/components/options-list/index.css +9 -9
  43. package/components/virtual-options-list/Component.js +1 -1
  44. package/components/virtual-options-list/index.css +15 -15
  45. package/cssm/Component.desktop.d.ts +19 -0
  46. package/cssm/{Component.js → Component.desktop.js} +6 -6
  47. package/cssm/Component.mobile-ebda875c.d.ts +6 -0
  48. package/cssm/Component.mobile-f1f15074.d.ts +387 -0
  49. package/cssm/Component.mobile.d.ts +41 -0
  50. package/cssm/Component.mobile.js +74 -0
  51. package/cssm/Component.modal.mobile.d.ts +60 -0
  52. package/cssm/Component.modal.mobile.js +74 -0
  53. package/cssm/Component.responsive.d.ts +1 -1
  54. package/cssm/Component.responsive.js +30 -33
  55. package/cssm/components/base-select/Component.js +5 -5
  56. package/cssm/components/base-select/index.js +1 -1
  57. package/cssm/components/base-select-mobile/Component.d.ts +3 -3
  58. package/cssm/components/base-select-mobile/Component.js +12 -8
  59. package/cssm/components/base-select-mobile/footer/Component.js +3 -3
  60. package/cssm/components/base-select-mobile/footer/index.js +1 -1
  61. package/cssm/components/base-select-mobile/index.js +1 -2
  62. package/cssm/components/base-select-mobile/index.module.css +4 -2
  63. package/cssm/components/field/Component.d.ts +8 -1
  64. package/cssm/components/field/Component.js +18 -15
  65. package/cssm/components/field/index.js +0 -1
  66. package/cssm/components/field/index.module.css +31 -4
  67. package/cssm/components/index.d.ts +0 -2
  68. package/cssm/components/index.js +7 -28
  69. package/cssm/desktop-63dec22f.d.ts +6 -0
  70. package/cssm/desktop.d.ts +2 -0
  71. package/cssm/desktop.js +44 -0
  72. package/cssm/hook-97e6e688.d.ts +16 -0
  73. package/cssm/hook-97e6e688.js +110 -0
  74. package/{esm/hook-b4e70cb0.d.ts → cssm/hook-9ea9e32c.d.ts} +9 -7
  75. package/cssm/index-ebda875c.d.ts +20 -60
  76. package/cssm/index.d.ts +2 -5
  77. package/cssm/index.js +34 -61
  78. package/cssm/mobile-96988a65.d.ts +2 -0
  79. package/cssm/mobile.d.ts +5 -4
  80. package/cssm/mobile.js +15 -24
  81. package/cssm/presets/index.d.ts +1 -1
  82. package/cssm/presets/index.js +9 -36
  83. package/cssm/presets/useLazyLoading/hook.js +9 -4
  84. package/cssm/presets/useSelectWithApply/hook.js +9 -48
  85. package/cssm/presets/useSelectWithApply/options-list-with-apply/Component.js +3 -42
  86. package/cssm/presets/useSelectWithApply/options-list-with-apply/footer/Component.js +3 -3
  87. package/cssm/presets/useSelectWithApply/options-list-with-apply/index.d.ts +1 -1
  88. package/cssm/presets/useSelectWithApply/options-list-with-apply/index.js +10 -49
  89. package/cssm/shared.d.ts +5 -0
  90. package/cssm/shared.js +78 -0
  91. package/cssm/typings-9211a437.d.ts +95 -0
  92. package/cssm/typings-baf4875b.d.ts +52 -0
  93. package/desktop-63dec22f.d.ts +6 -0
  94. package/desktop.d.ts +2 -0
  95. package/{responsive.js → desktop.js} +5 -19
  96. package/esm/Component.desktop.d.ts +19 -0
  97. package/esm/{Component.js → Component.desktop.js} +6 -6
  98. package/esm/Component.mobile-ebda875c.d.ts +6 -0
  99. package/esm/Component.mobile-f1f15074.d.ts +387 -0
  100. package/esm/Component.mobile.d.ts +41 -0
  101. package/esm/Component.mobile.js +54 -0
  102. package/esm/Component.modal.mobile.d.ts +60 -0
  103. package/esm/Component.modal.mobile.js +54 -0
  104. package/esm/Component.responsive.d.ts +1 -1
  105. package/esm/Component.responsive.js +26 -25
  106. package/esm/components/arrow/Component.js +1 -1
  107. package/esm/components/arrow/index.css +3 -3
  108. package/esm/components/base-checkmark/Component.js +1 -1
  109. package/esm/components/base-checkmark/index.css +4 -4
  110. package/esm/components/base-option/Component.js +1 -1
  111. package/esm/components/base-option/index.css +13 -13
  112. package/esm/components/base-select/Component.js +2 -2
  113. package/esm/components/base-select/index.css +8 -8
  114. package/esm/components/base-select/index.js +1 -1
  115. package/esm/components/base-select-mobile/Component.d.ts +3 -3
  116. package/esm/components/base-select-mobile/Component.js +9 -5
  117. package/esm/components/base-select-mobile/footer/Component.js +4 -4
  118. package/esm/components/base-select-mobile/footer/index.css +5 -5
  119. package/esm/components/base-select-mobile/footer/index.js +1 -1
  120. package/esm/components/base-select-mobile/index.css +13 -11
  121. package/esm/components/base-select-mobile/index.js +1 -2
  122. package/esm/components/checkmark/Component.js +1 -1
  123. package/esm/components/checkmark/index.css +10 -10
  124. package/esm/components/checkmark-mobile/Component.js +1 -1
  125. package/esm/components/checkmark-mobile/index.css +6 -6
  126. package/esm/components/field/Component.d.ts +8 -1
  127. package/esm/components/field/Component.js +19 -16
  128. package/esm/components/field/index.css +38 -11
  129. package/esm/components/field/index.js +0 -1
  130. package/esm/components/index.d.ts +0 -2
  131. package/esm/components/index.js +4 -17
  132. package/esm/components/optgroup/Component.js +1 -1
  133. package/esm/components/optgroup/index.css +6 -6
  134. package/esm/components/option/Component.js +1 -1
  135. package/esm/components/option/index.css +20 -20
  136. package/esm/components/options-list/Component.js +1 -1
  137. package/esm/components/options-list/index.css +9 -9
  138. package/esm/components/virtual-options-list/Component.js +1 -1
  139. package/esm/components/virtual-options-list/index.css +15 -15
  140. package/esm/desktop-63dec22f.d.ts +6 -0
  141. package/esm/desktop.d.ts +2 -0
  142. package/esm/{responsive.js → desktop.js} +4 -18
  143. package/{cssm/hook-b4e70cb0.d.ts → esm/hook-9ea9e32c.d.ts} +9 -7
  144. package/esm/hook-cb30fc23.d.ts +16 -0
  145. package/esm/hook-cb30fc23.js +102 -0
  146. package/esm/index-ebda875c.d.ts +20 -60
  147. package/esm/index.d.ts +2 -5
  148. package/esm/index.js +27 -29
  149. package/esm/mobile-96988a65.d.ts +2 -0
  150. package/esm/mobile.d.ts +5 -4
  151. package/esm/mobile.js +12 -16
  152. package/esm/presets/index.d.ts +1 -1
  153. package/esm/presets/index.js +7 -25
  154. package/esm/presets/useLazyLoading/hook.js +9 -5
  155. package/esm/presets/useSelectWithApply/hook.js +7 -33
  156. package/esm/presets/useSelectWithApply/options-list-with-apply/Component.js +2 -28
  157. package/esm/presets/useSelectWithApply/options-list-with-apply/footer/Component.js +4 -4
  158. package/esm/presets/useSelectWithApply/options-list-with-apply/footer/index.css +3 -3
  159. package/esm/presets/useSelectWithApply/options-list-with-apply/header/Component.js +1 -1
  160. package/esm/presets/useSelectWithApply/options-list-with-apply/header/index.css +3 -3
  161. package/esm/presets/useSelectWithApply/options-list-with-apply/index.d.ts +1 -1
  162. package/esm/presets/useSelectWithApply/options-list-with-apply/index.js +8 -34
  163. package/esm/presets/useSelectWithLoading/hook.js +1 -1
  164. package/esm/presets/useSelectWithLoading/index.css +2 -2
  165. package/esm/shared.d.ts +5 -0
  166. package/esm/shared.js +38 -0
  167. package/esm/typings-9211a437.d.ts +95 -0
  168. package/esm/typings-baf4875b.d.ts +52 -0
  169. package/hook-3e654f56.d.ts +16 -0
  170. package/hook-3e654f56.js +110 -0
  171. package/{hook-b4e70cb0.d.ts → hook-9ea9e32c.d.ts} +9 -7
  172. package/index-ebda875c.d.ts +20 -60
  173. package/index.d.ts +2 -5
  174. package/index.js +28 -51
  175. package/mobile-96988a65.d.ts +2 -0
  176. package/mobile.d.ts +5 -4
  177. package/mobile.js +14 -18
  178. package/modern/Component.desktop.d.ts +19 -0
  179. package/modern/{Component.js → Component.desktop.js} +7 -4
  180. package/modern/Component.mobile-ebda875c.d.ts +6 -0
  181. package/modern/Component.mobile-f1f15074.d.ts +387 -0
  182. package/modern/Component.mobile.d.ts +41 -0
  183. package/modern/Component.mobile.js +61 -0
  184. package/modern/Component.modal.mobile.d.ts +60 -0
  185. package/modern/Component.modal.mobile.js +61 -0
  186. package/modern/Component.responsive.d.ts +1 -1
  187. package/modern/Component.responsive.js +26 -25
  188. package/modern/components/arrow/Component.js +1 -1
  189. package/modern/components/arrow/index.css +3 -3
  190. package/modern/components/base-checkmark/Component.js +1 -1
  191. package/modern/components/base-checkmark/index.css +4 -4
  192. package/modern/components/base-option/Component.js +1 -1
  193. package/modern/components/base-option/index.css +13 -13
  194. package/modern/components/base-select/Component.js +2 -2
  195. package/modern/components/base-select/index.css +8 -8
  196. package/modern/components/base-select/index.js +1 -1
  197. package/modern/components/base-select-mobile/Component.d.ts +3 -3
  198. package/modern/components/base-select-mobile/Component.js +9 -5
  199. package/modern/components/base-select-mobile/footer/Component.js +4 -4
  200. package/modern/components/base-select-mobile/footer/index.css +5 -5
  201. package/modern/components/base-select-mobile/footer/index.js +1 -1
  202. package/modern/components/base-select-mobile/index.css +13 -11
  203. package/modern/components/base-select-mobile/index.js +1 -2
  204. package/modern/components/checkmark/Component.js +1 -1
  205. package/modern/components/checkmark/index.css +10 -10
  206. package/modern/components/checkmark-mobile/Component.js +1 -1
  207. package/modern/components/checkmark-mobile/index.css +6 -6
  208. package/modern/components/field/Component.d.ts +8 -1
  209. package/modern/components/field/Component.js +17 -14
  210. package/modern/components/field/index.css +38 -11
  211. package/modern/components/field/index.js +0 -1
  212. package/modern/components/index.d.ts +0 -2
  213. package/modern/components/index.js +4 -17
  214. package/modern/components/optgroup/Component.js +1 -1
  215. package/modern/components/optgroup/index.css +6 -6
  216. package/modern/components/option/Component.js +1 -1
  217. package/modern/components/option/index.css +20 -20
  218. package/modern/components/options-list/Component.js +1 -1
  219. package/modern/components/options-list/index.css +9 -9
  220. package/modern/components/virtual-options-list/Component.js +1 -1
  221. package/modern/components/virtual-options-list/index.css +15 -15
  222. package/modern/desktop-63dec22f.d.ts +6 -0
  223. package/modern/desktop.d.ts +2 -0
  224. package/modern/{responsive.js → desktop.js} +4 -18
  225. package/modern/hook-467b4d42.d.ts +16 -0
  226. package/modern/{Component-5c16a908.js → hook-467b4d42.js} +3 -66
  227. package/modern/{hook-b4e70cb0.d.ts → hook-9ea9e32c.d.ts} +9 -7
  228. package/modern/index-ebda875c.d.ts +20 -60
  229. package/modern/index.d.ts +2 -5
  230. package/modern/index.js +27 -29
  231. package/modern/mobile-96988a65.d.ts +2 -0
  232. package/modern/mobile.d.ts +5 -4
  233. package/modern/mobile.js +12 -16
  234. package/modern/presets/index.d.ts +1 -1
  235. package/modern/presets/index.js +7 -25
  236. package/modern/presets/useLazyLoading/hook.js +9 -5
  237. package/modern/presets/useSelectWithApply/hook.js +7 -33
  238. package/modern/presets/useSelectWithApply/options-list-with-apply/Component.js +2 -28
  239. package/modern/presets/useSelectWithApply/options-list-with-apply/footer/Component.js +4 -4
  240. package/modern/presets/useSelectWithApply/options-list-with-apply/footer/index.css +3 -3
  241. package/modern/presets/useSelectWithApply/options-list-with-apply/header/Component.js +1 -1
  242. package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.css +3 -3
  243. package/modern/presets/useSelectWithApply/options-list-with-apply/index.d.ts +1 -1
  244. package/modern/presets/useSelectWithApply/options-list-with-apply/index.js +8 -34
  245. package/modern/presets/useSelectWithLoading/hook.js +1 -1
  246. package/modern/presets/useSelectWithLoading/index.css +2 -2
  247. package/modern/shared.d.ts +5 -0
  248. package/modern/shared.js +37 -0
  249. package/modern/typings-9211a437.d.ts +95 -0
  250. package/modern/typings-baf4875b.d.ts +52 -0
  251. package/package.json +38 -12
  252. package/presets/index.d.ts +1 -1
  253. package/presets/index.js +7 -25
  254. package/presets/useLazyLoading/hook.js +9 -5
  255. package/presets/useSelectWithApply/hook.js +7 -33
  256. package/presets/useSelectWithApply/options-list-with-apply/Component.js +2 -28
  257. package/presets/useSelectWithApply/options-list-with-apply/footer/Component.js +4 -4
  258. package/presets/useSelectWithApply/options-list-with-apply/footer/index.css +3 -3
  259. package/presets/useSelectWithApply/options-list-with-apply/header/Component.js +1 -1
  260. package/presets/useSelectWithApply/options-list-with-apply/header/index.css +3 -3
  261. package/presets/useSelectWithApply/options-list-with-apply/index.d.ts +1 -1
  262. package/presets/useSelectWithApply/options-list-with-apply/index.js +8 -34
  263. package/presets/useSelectWithLoading/hook.js +1 -1
  264. package/presets/useSelectWithLoading/index.css +2 -2
  265. package/shared.d.ts +5 -0
  266. package/shared.js +64 -0
  267. package/src/Component.desktop.tsx +52 -0
  268. package/src/Component.mobile.tsx +149 -0
  269. package/src/Component.modal.mobile.tsx +144 -0
  270. package/src/Component.responsive.tsx +59 -0
  271. package/src/components/arrow/Component.tsx +12 -0
  272. package/src/components/arrow/index.module.css +15 -0
  273. package/src/components/arrow/index.ts +1 -0
  274. package/src/components/base-checkmark/Component.tsx +33 -0
  275. package/src/components/base-checkmark/index.module.css +18 -0
  276. package/src/components/base-checkmark/index.ts +1 -0
  277. package/src/components/base-option/Component.tsx +57 -0
  278. package/src/components/base-option/index.module.css +67 -0
  279. package/src/components/base-option/index.ts +1 -0
  280. package/src/components/base-select/Component.tsx +478 -0
  281. package/src/components/base-select/index.module.css +68 -0
  282. package/src/components/base-select/index.ts +1 -0
  283. package/src/components/base-select-mobile/Component.tsx +486 -0
  284. package/src/components/base-select-mobile/footer/Component.tsx +46 -0
  285. package/src/components/base-select-mobile/footer/index.module.css +23 -0
  286. package/src/components/base-select-mobile/footer/index.ts +1 -0
  287. package/src/components/base-select-mobile/index.module.css +48 -0
  288. package/src/components/base-select-mobile/index.ts +1 -0
  289. package/src/components/checkmark/Component.tsx +56 -0
  290. package/src/components/checkmark/index.module.css +48 -0
  291. package/src/components/checkmark/index.ts +1 -0
  292. package/src/components/checkmark-mobile/Component.tsx +18 -0
  293. package/src/components/checkmark-mobile/index.module.css +28 -0
  294. package/src/components/checkmark-mobile/index.ts +1 -0
  295. package/src/components/field/Component.tsx +110 -0
  296. package/src/components/field/index.module.css +60 -0
  297. package/src/components/field/index.ts +1 -0
  298. package/src/components/index.ts +8 -0
  299. package/src/components/native-select/Component.tsx +60 -0
  300. package/src/components/native-select/index.ts +1 -0
  301. package/src/components/optgroup/Component.tsx +15 -0
  302. package/src/components/optgroup/index.module.css +30 -0
  303. package/src/components/optgroup/index.ts +1 -0
  304. package/src/components/option/Component.tsx +65 -0
  305. package/src/components/option/index.module.css +108 -0
  306. package/src/components/option/index.ts +1 -0
  307. package/src/components/options-list/Component.tsx +140 -0
  308. package/src/components/options-list/index.module.css +40 -0
  309. package/src/components/options-list/index.ts +1 -0
  310. package/src/components/virtual-options-list/Component.tsx +217 -0
  311. package/src/components/virtual-options-list/index.module.css +76 -0
  312. package/src/components/virtual-options-list/index.ts +1 -0
  313. package/src/consts.ts +1 -0
  314. package/src/desktop.ts +1 -0
  315. package/src/index.ts +4 -0
  316. package/src/mobile.ts +5 -0
  317. package/src/presets/index.ts +3 -0
  318. package/src/presets/useLazyLoading/hook.tsx +309 -0
  319. package/src/presets/useSelectWithApply/hook.tsx +154 -0
  320. package/src/presets/useSelectWithApply/options-list-with-apply/Component.tsx +106 -0
  321. package/src/presets/useSelectWithApply/options-list-with-apply/footer/Component.tsx +37 -0
  322. package/src/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css +11 -0
  323. package/src/presets/useSelectWithApply/options-list-with-apply/header/Component.tsx +26 -0
  324. package/src/presets/useSelectWithApply/options-list-with-apply/header/index.module.css +9 -0
  325. package/src/presets/useSelectWithApply/options-list-with-apply/index.ts +1 -0
  326. package/src/presets/useSelectWithLoading/hook.tsx +40 -0
  327. package/src/shared.ts +5 -0
  328. package/src/typings.ts +691 -0
  329. package/src/utils.ts +154 -0
  330. package/src/vars.css +57 -0
  331. package/typings-9211a437.d.ts +95 -0
  332. package/typings-baf4875b.d.ts +52 -0
  333. package/Component-1e06de61.d.ts +0 -108
  334. package/Component-1e06de61.js +0 -165
  335. package/Component-3885b0d7.d.ts +0 -169
  336. package/Component.d.ts +0 -104
  337. package/Component.mobile-b2c0420d.d.ts +0 -93
  338. package/components/select-mobile/Component.d.ts +0 -0
  339. package/components/select-mobile/Component.js +0 -49
  340. package/components/select-mobile/index.d.ts +0 -1
  341. package/components/select-mobile/index.js +0 -49
  342. package/components/select-modal-mobile/Component.d.ts +0 -0
  343. package/components/select-modal-mobile/Component.js +0 -49
  344. package/components/select-modal-mobile/index.d.ts +0 -1
  345. package/components/select-modal-mobile/index.js +0 -49
  346. package/cssm/Component-3885b0d7.d.ts +0 -169
  347. package/cssm/Component-4727d474.d.ts +0 -108
  348. package/cssm/Component-4727d474.js +0 -175
  349. package/cssm/Component.d.ts +0 -104
  350. package/cssm/Component.mobile-b2c0420d.d.ts +0 -93
  351. package/cssm/components/select-mobile/Component.d.ts +0 -0
  352. package/cssm/components/select-mobile/Component.js +0 -66
  353. package/cssm/components/select-mobile/index.d.ts +0 -1
  354. package/cssm/components/select-mobile/index.js +0 -66
  355. package/cssm/components/select-modal-mobile/Component.d.ts +0 -0
  356. package/cssm/components/select-modal-mobile/Component.js +0 -66
  357. package/cssm/components/select-modal-mobile/index.d.ts +0 -1
  358. package/cssm/components/select-modal-mobile/index.js +0 -66
  359. package/cssm/getDataTestId-5c876d98.d.ts +0 -2
  360. package/cssm/getDataTestId-5c876d98.js +0 -8
  361. package/cssm/index-3885b0d7.d.ts +0 -3
  362. package/cssm/intersection-observer-9ec5cf59.d.ts +0 -1
  363. package/cssm/intersection-observer-9ec5cf59.js +0 -893
  364. package/cssm/responsive.d.ts +0 -2
  365. package/cssm/responsive.js +0 -67
  366. package/cssm/types-ebda875c.d.ts +0 -113
  367. package/esm/Component-16af9d1e.d.ts +0 -108
  368. package/esm/Component-16af9d1e.js +0 -155
  369. package/esm/Component-3885b0d7.d.ts +0 -169
  370. package/esm/Component.d.ts +0 -104
  371. package/esm/Component.mobile-b2c0420d.d.ts +0 -93
  372. package/esm/components/select-mobile/Component.d.ts +0 -0
  373. package/esm/components/select-mobile/Component.js +0 -41
  374. package/esm/components/select-mobile/index.d.ts +0 -1
  375. package/esm/components/select-mobile/index.js +0 -41
  376. package/esm/components/select-modal-mobile/Component.d.ts +0 -0
  377. package/esm/components/select-modal-mobile/Component.js +0 -41
  378. package/esm/components/select-modal-mobile/index.d.ts +0 -1
  379. package/esm/components/select-modal-mobile/index.js +0 -41
  380. package/esm/getDataTestId-1a678b16.d.ts +0 -2
  381. package/esm/getDataTestId-1a678b16.js +0 -6
  382. package/esm/index-3885b0d7.d.ts +0 -3
  383. package/esm/intersection-observer-4e5bb99c.d.ts +0 -1
  384. package/esm/intersection-observer-4e5bb99c.js +0 -891
  385. package/esm/presets/useLazyLoading/index.css +0 -8
  386. package/esm/responsive.d.ts +0 -2
  387. package/esm/types-ebda875c.d.ts +0 -113
  388. package/getDataTestId-3f974970.d.ts +0 -2
  389. package/getDataTestId-3f974970.js +0 -8
  390. package/index-3885b0d7.d.ts +0 -3
  391. package/intersection-observer-411362a8.d.ts +0 -1
  392. package/intersection-observer-411362a8.js +0 -893
  393. package/modern/Component-3885b0d7.d.ts +0 -169
  394. package/modern/Component-5c16a908.d.ts +0 -108
  395. package/modern/Component.d.ts +0 -104
  396. package/modern/Component.mobile-b2c0420d.d.ts +0 -93
  397. package/modern/components/select-mobile/Component.d.ts +0 -0
  398. package/modern/components/select-mobile/Component.js +0 -40
  399. package/modern/components/select-mobile/index.d.ts +0 -1
  400. package/modern/components/select-mobile/index.js +0 -40
  401. package/modern/components/select-modal-mobile/Component.d.ts +0 -0
  402. package/modern/components/select-modal-mobile/Component.js +0 -40
  403. package/modern/components/select-modal-mobile/index.d.ts +0 -1
  404. package/modern/components/select-modal-mobile/index.js +0 -40
  405. package/modern/getDataTestId-c17bfb0c.d.ts +0 -2
  406. package/modern/getDataTestId-c17bfb0c.js +0 -6
  407. package/modern/index-3885b0d7.d.ts +0 -3
  408. package/modern/intersection-observer-4e5bb99c.d.ts +0 -1
  409. package/modern/intersection-observer-4e5bb99c.js +0 -891
  410. package/modern/presets/useLazyLoading/index.css +0 -8
  411. package/modern/responsive.d.ts +0 -2
  412. package/modern/types-ebda875c.d.ts +0 -113
  413. package/presets/useLazyLoading/index.css +0 -8
  414. package/responsive.d.ts +0 -2
  415. package/types-ebda875c.d.ts +0 -113
  416. /package/{cssm/presets/useLazyLoading → src/presets/useSelectWithLoading}/index.module.css +0 -0
@@ -0,0 +1,48 @@
1
+ @import '@alfalab/core-components-themes/src/default.css';
2
+ @import '../../vars.css';
3
+
4
+ .checkmark {
5
+ flex-shrink: 0;
6
+ margin: var(--select-checkmark-margin);
7
+
8
+ &.after {
9
+ margin: var(--select-checkmark-margin-after);
10
+ }
11
+ }
12
+
13
+ .single {
14
+ display: flex;
15
+ align-items: center;
16
+ justify-content: center;
17
+ opacity: var(--select-checkmark-unselected-opacity);
18
+ background: var(--select-checkmark-background);
19
+ background-size: cover;
20
+ border-radius: var(--select-checkmark-border-radius);
21
+ width: var(--select-checkmark-size);
22
+ height: var(--select-checkmark-size);
23
+
24
+ &.selected {
25
+ opacity: 1;
26
+ }
27
+ }
28
+
29
+ .before {
30
+ display: var(--select-checkmark-before-display);
31
+
32
+ &.multiple {
33
+ margin-right: var(--gap-s);
34
+ display: var(--select-checkmark-before-display-multiple);
35
+ }
36
+ }
37
+
38
+ .after {
39
+ display: var(--select-checkmark-after-display);
40
+
41
+ &.single {
42
+ display: var(--select-checkmark-after-display-single);
43
+ }
44
+ }
45
+
46
+ .colorIcon {
47
+ color: var(--color-light-graphic-positive);
48
+ }
@@ -0,0 +1 @@
1
+ export * from './Component';
@@ -0,0 +1,18 @@
1
+ import React from 'react';
2
+ import cn from 'classnames';
3
+
4
+ import { CheckmarkMIcon } from '@alfalab/icons-glyph/CheckmarkMIcon';
5
+
6
+ import { CheckmarkProps } from '../../typings';
7
+
8
+ import styles from './index.module.css';
9
+
10
+ export const Checkmark = ({ selected, className }: CheckmarkProps) => (
11
+ <div
12
+ className={cn(styles.checkmark, className, {
13
+ [styles.selected]: selected,
14
+ })}
15
+ >
16
+ <CheckmarkMIcon className={styles.displayIcon} />
17
+ </div>
18
+ );
@@ -0,0 +1,28 @@
1
+ @import '@alfalab/core-components-themes/src/default.css';
2
+ @import '../../vars.css';
3
+
4
+ .checkmark {
5
+ flex-shrink: 0;
6
+ display: flex;
7
+ align-items: center;
8
+ justify-content: center;
9
+ width: 24px;
10
+ height: 24px;
11
+ opacity: 0;
12
+
13
+ &:first-child {
14
+ display: none;
15
+ }
16
+
17
+ &.selected {
18
+ opacity: 1;
19
+ }
20
+ }
21
+
22
+ .displayIcon {
23
+ display: var(--select-mobile-checkmark-display-icon);
24
+ }
25
+
26
+ .displayBadge {
27
+ display: var(--select-mobile-checkmark-display-badge);
28
+ }
@@ -0,0 +1 @@
1
+ export * from './Component';
@@ -0,0 +1,110 @@
1
+ import React, { ElementType, useCallback, useRef, useState } from 'react';
2
+ import cn from 'classnames';
3
+
4
+ import type { FormControlProps } from '@alfalab/core-components-form-control';
5
+ import { useFocus } from '@alfalab/hooks';
6
+
7
+ import { FieldProps as BaseFieldProps } from '../../typings';
8
+ import { joinOptions } from '../../utils';
9
+
10
+ import styles from './index.module.css';
11
+
12
+ type FieldProps = {
13
+ /**
14
+ * Компонент FormControl
15
+ */
16
+ FormControlComponent?: ElementType;
17
+ };
18
+
19
+ export const Field = ({
20
+ size = 'm',
21
+ open,
22
+ multiple,
23
+ error,
24
+ hint,
25
+ disabled,
26
+ label,
27
+ labelView = 'inner',
28
+ placeholder,
29
+ selectedMultiple = [],
30
+ selected,
31
+ rightAddons,
32
+ valueRenderer = joinOptions,
33
+ setSelectedItems,
34
+ toggleMenu,
35
+ Arrow,
36
+ innerProps,
37
+ dataTestId,
38
+ fieldClassName,
39
+ FormControlComponent,
40
+ ...restProps
41
+ }: BaseFieldProps & FormControlProps & FieldProps) => {
42
+ const [focused, setFocused] = useState(false);
43
+
44
+ const wrapperRef = useRef<HTMLDivElement>(null);
45
+
46
+ const [focusVisible] = useFocus(wrapperRef, 'keyboard');
47
+
48
+ const handleFocus = useCallback(() => setFocused(true), []);
49
+ const handleBlur = useCallback(() => setFocused(false), []);
50
+
51
+ const value = valueRenderer({ selected, selectedMultiple });
52
+
53
+ const filled = Boolean(value);
54
+ const showLabel = !!label || labelView === 'outer';
55
+ const showPlaceholder = !!placeholder && !filled && (open || !label || labelView === 'outer');
56
+
57
+ return (
58
+ <div
59
+ className={styles.component}
60
+ ref={wrapperRef}
61
+ onFocus={handleFocus}
62
+ onBlur={handleBlur}
63
+ >
64
+ {FormControlComponent ? (
65
+ <FormControlComponent
66
+ fieldClassName={cn(styles.field, fieldClassName, {
67
+ [styles.disabled]: disabled,
68
+ [styles.focusVisible]: focusVisible,
69
+ })}
70
+ block={true}
71
+ size={size}
72
+ focused={focused || open}
73
+ disabled={disabled}
74
+ filled={filled || (!!placeholder && open)}
75
+ label={showLabel && label}
76
+ labelView={labelView}
77
+ error={error}
78
+ hint={hint}
79
+ rightAddons={
80
+ (Arrow || rightAddons) && (
81
+ <React.Fragment>
82
+ {rightAddons}
83
+ {/* TODO: стоит переделать, но это будет мажорка */}
84
+ {Arrow
85
+ ? React.cloneElement(Arrow, { className: styles.arrow })
86
+ : null}
87
+ </React.Fragment>
88
+ )
89
+ }
90
+ data-test-id={dataTestId}
91
+ {...restProps}
92
+ {...innerProps}
93
+ >
94
+ <div className={styles.contentWrapper}>
95
+ {showPlaceholder && (
96
+ <span
97
+ className={cn(styles.placeholder, {
98
+ [styles.focused]: focused || open,
99
+ })}
100
+ >
101
+ {placeholder}
102
+ </span>
103
+ )}
104
+ {filled && <div className={styles.value}>{value}</div>}
105
+ </div>
106
+ </FormControlComponent>
107
+ ) : null}
108
+ </div>
109
+ );
110
+ };
@@ -0,0 +1,60 @@
1
+ @import '@alfalab/core-components-themes/src/default.css';
2
+ @import '@alfalab/core-components-input/src/vars.css';
3
+ @import '../../vars.css';
4
+
5
+ .component {
6
+ width: 100%;
7
+ outline: none;
8
+ }
9
+
10
+ .field:not(.disabled) {
11
+ cursor: pointer;
12
+
13
+ &:hover {
14
+ & .arrow {
15
+ opacity: var(--select-arrow-hover-opacity);
16
+ }
17
+ }
18
+ }
19
+
20
+ .disabled {
21
+ cursor: var(--disabled-cursor);
22
+ }
23
+
24
+ .placeholder {
25
+ color: var(--input-placeholder-color);
26
+ transition: color 0.2s ease;
27
+ animation: show-placeholder 0.2s ease;
28
+
29
+ &.focused {
30
+ color: var(--input-focus-placeholder-color);
31
+ }
32
+ }
33
+
34
+ .contentWrapper {
35
+ @mixin paragraph_component;
36
+
37
+ white-space: nowrap;
38
+ text-overflow: ellipsis;
39
+ overflow: hidden;
40
+ width: 100%;
41
+ }
42
+
43
+ .value {
44
+ overflow: hidden;
45
+ text-overflow: ellipsis;
46
+ text-align: left;
47
+ }
48
+
49
+ .focusVisible {
50
+ @mixin focus-outline;
51
+ }
52
+
53
+ @keyframes show-placeholder {
54
+ from {
55
+ opacity: 0;
56
+ }
57
+ to {
58
+ opacity: 1;
59
+ }
60
+ }
@@ -0,0 +1 @@
1
+ export * from './Component';
@@ -0,0 +1,8 @@
1
+ export * from './arrow';
2
+ export * from './base-select';
3
+ export * from './field';
4
+ export * from './optgroup';
5
+ export * from './option';
6
+ export * from './options-list';
7
+ export * from './virtual-options-list';
8
+ export * from './base-option';
@@ -0,0 +1,60 @@
1
+ import React, { forwardRef, SelectHTMLAttributes, useCallback } from 'react';
2
+
3
+ import { GroupShape, OptionShape } from '../../typings';
4
+ import { isGroup } from '../../utils';
5
+
6
+ export type NativeSelectProps = SelectHTMLAttributes<HTMLSelectElement> & {
7
+ /**
8
+ * Список вариантов выбора
9
+ */
10
+ options: Array<OptionShape | GroupShape>;
11
+
12
+ /**
13
+ * Значение селекта
14
+ */
15
+ value: string | string[];
16
+ };
17
+
18
+ const Option = ({ option }: { option: OptionShape }) => (
19
+ <option value={option.key} disabled={option.disabled}>
20
+ {typeof option.content === 'string' ? option.content : option.key}
21
+ </option>
22
+ );
23
+
24
+ const Group = ({ label, options }: GroupShape) => (
25
+ <optgroup label={label}>
26
+ {options.map((option) => (
27
+ <Option option={option} key={option.key} />
28
+ ))}
29
+ </optgroup>
30
+ );
31
+
32
+ export const NativeSelect = forwardRef<HTMLSelectElement, NativeSelectProps>(
33
+ ({ className, disabled, multiple, value, name, options, onChange, ...restProps }, ref) => {
34
+ const handleClick = useCallback((event: React.MouseEvent<HTMLSelectElement>) => {
35
+ event.stopPropagation();
36
+ }, []);
37
+
38
+ return (
39
+ <select
40
+ className={className}
41
+ disabled={disabled}
42
+ multiple={multiple}
43
+ name={name}
44
+ value={value}
45
+ onChange={onChange}
46
+ onClick={handleClick}
47
+ ref={ref}
48
+ {...restProps}
49
+ >
50
+ {options.map((option) =>
51
+ isGroup(option) ? (
52
+ <Group {...option} key={option.label} />
53
+ ) : (
54
+ <Option option={option} key={option.key} />
55
+ ),
56
+ )}
57
+ </select>
58
+ );
59
+ },
60
+ );
@@ -0,0 +1 @@
1
+ export * from './Component';
@@ -0,0 +1,15 @@
1
+ import React from 'react';
2
+ import cn from 'classnames';
3
+
4
+ import { OptgroupProps } from '../../typings';
5
+
6
+ import styles from './index.module.css';
7
+
8
+ export const Optgroup = ({ children, className, label, size = 's' }: OptgroupProps) => (
9
+ <React.Fragment>
10
+ <div className={cn(styles.optgroup, className, styles[size])}>
11
+ <span className={styles.label}>{label}</span>
12
+ </div>
13
+ {children}
14
+ </React.Fragment>
15
+ );
@@ -0,0 +1,30 @@
1
+ @import '@alfalab/core-components-themes/src/default.css';
2
+ @import '../../vars.css';
3
+
4
+ .optgroup {
5
+ position: relative;
6
+ display: flex;
7
+ align-items: center;
8
+ padding: var(--gap-s) var(--select-optgroup-right-padding) var(--gap-2xs)
9
+ var(--select-optgroup-left-padding);
10
+ box-sizing: border-box;
11
+ background: var(--select-optgroup-background);
12
+ min-height: 40px;
13
+
14
+ & + *[role='option']:before {
15
+ display: none;
16
+ }
17
+ }
18
+
19
+ .label {
20
+ @mixin paragraph_caps;
21
+
22
+ display: block;
23
+ color: var(--select-optgroup-color);
24
+ }
25
+
26
+ .l,
27
+ .xl {
28
+ padding-left: var(--select-optgroup-l-left-padding);
29
+ padding-right: var(--select-optgroup-l-right-padding);
30
+ }
@@ -0,0 +1 @@
1
+ export * from './Component';
@@ -0,0 +1,65 @@
1
+ import React, { FC, isValidElement } from 'react';
2
+ import cn from 'classnames';
3
+
4
+ import { OptionProps } from '../../typings';
5
+ import { Checkmark as DefaultCheckMark } from '../checkmark';
6
+ import { Checkmark as DefaultMobileCheckmark } from '../checkmark-mobile';
7
+
8
+ import styles from './index.module.css';
9
+
10
+ export const Option: FC<OptionProps> = ({
11
+ size = 's',
12
+ className,
13
+ option,
14
+ children,
15
+ selected,
16
+ highlighted,
17
+ disabled,
18
+ multiple,
19
+ mobile,
20
+ Checkmark = mobile ? DefaultMobileCheckmark : DefaultCheckMark,
21
+ innerProps,
22
+ dataTestId,
23
+ }) => {
24
+ const content = children || option.content || option.key;
25
+ const { showCheckMark = true } = option;
26
+
27
+ return (
28
+ <div
29
+ {...innerProps}
30
+ className={cn(styles.option, styles[size], className, {
31
+ [styles.highlighted]: !mobile && highlighted,
32
+ [styles.selected]: selected,
33
+ [styles.disabled]: disabled,
34
+ })}
35
+ data-test-id={dataTestId}
36
+ >
37
+ {Checkmark && showCheckMark && (
38
+ <Checkmark
39
+ disabled={disabled}
40
+ selected={selected}
41
+ multiple={multiple}
42
+ position='before'
43
+ />
44
+ )}
45
+
46
+ <div
47
+ className={cn(styles.content, {
48
+ [styles.textContent]: !isValidElement(content),
49
+ })}
50
+ >
51
+ {content}
52
+ </div>
53
+
54
+ {/** Workaround чтобы для клика показывать отметку справа и всегда в виде иконки */}
55
+ {Checkmark && showCheckMark && (
56
+ <Checkmark
57
+ disabled={disabled}
58
+ selected={selected}
59
+ multiple={multiple}
60
+ position='after'
61
+ />
62
+ )}
63
+ </div>
64
+ );
65
+ };
@@ -0,0 +1,108 @@
1
+ @import '@alfalab/core-components-themes/src/default.css';
2
+ @import '../../vars.css';
3
+
4
+ .option {
5
+ @mixin paragraph_component;
6
+
7
+ display: flex;
8
+ align-items: center;
9
+ padding-left: var(--select-option-left-padding);
10
+ padding-right: var(--select-option-right-padding);
11
+ transition: background-color 0.2s ease;
12
+ background: var(--select-option-background);
13
+ color: var(--select-option-color);
14
+ box-sizing: border-box;
15
+ position: relative;
16
+ cursor: pointer;
17
+
18
+ &:not(.disabled):active {
19
+ background: var(--select-option-active-background);
20
+ color: var(--select-option-active-color);
21
+ }
22
+
23
+ &:before {
24
+ content: '';
25
+ position: absolute;
26
+ left: var(--select-option-left-padding);
27
+ right: var(--select-option-right-padding);
28
+ top: 0;
29
+ height: 1px;
30
+ background: var(--select-option-divider-background);
31
+ display: var(--select-option-divider-display);
32
+ transition: opacity 0.2s ease;
33
+ }
34
+
35
+ &:first-child:before {
36
+ display: none;
37
+ }
38
+ }
39
+
40
+ .s {
41
+ min-height: var(--size-s-height);
42
+ }
43
+
44
+ .m {
45
+ min-height: var(--size-m-height);
46
+ }
47
+
48
+ .l {
49
+ min-height: var(--size-l-height);
50
+ }
51
+
52
+ .xl {
53
+ min-height: var(--size-xl-height);
54
+ }
55
+
56
+ .l,
57
+ .xl {
58
+ padding-left: var(--select-option-l-left-padding);
59
+ padding-right: var(--select-option-l-right-padding);
60
+
61
+ &:before {
62
+ left: var(--select-option-l-left-padding);
63
+ right: var(--select-option-l-right-padding);
64
+ }
65
+ }
66
+
67
+ .selected {
68
+ background: var(--select-option-selected-background);
69
+ color: var(--select-option-selected-color);
70
+ cursor: default;
71
+ }
72
+
73
+ .highlighted {
74
+ background: var(--select-option-hover-background);
75
+ color: var(--select-option-hover-color);
76
+
77
+ &:before,
78
+ & + .option:before {
79
+ opacity: 0;
80
+ }
81
+ }
82
+
83
+ .disabled {
84
+ cursor: var(--disabled-cursor);
85
+ background: var(--select-option-disabled-background);
86
+ color: var(--select-option-disabled-color);
87
+ }
88
+
89
+ .content {
90
+ overflow: hidden;
91
+ flex: 1;
92
+ text-overflow: ellipsis;
93
+ }
94
+
95
+ .textContent {
96
+ padding-top: var(--gap-s);
97
+ padding-bottom: var(--gap-s);
98
+ }
99
+
100
+ /* IE min-height fix */
101
+
102
+ @media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
103
+ .option:after {
104
+ min-height: inherit;
105
+ font-size: 0;
106
+ content: '';
107
+ }
108
+ }
@@ -0,0 +1 @@
1
+ export * from './Component';