@alfalab/core-components-select 19.0.6 → 19.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (306) hide show
  1. package/components/arrow/index.css +4 -4
  2. package/components/arrow/index.module.css.js +1 -1
  3. package/components/base-checkmark/Component.d.ts +2 -2
  4. package/components/base-checkmark/Component.js +14 -7
  5. package/components/base-checkmark/Component.js.map +1 -1
  6. package/components/base-checkmark/index.css +32 -5
  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/Component.js +4 -16
  10. package/components/base-option/Component.js.map +1 -1
  11. package/components/base-option/index.css +14 -20
  12. package/components/base-option/index.module.css.js +1 -1
  13. package/components/base-option/index.module.css.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/mobile.css +11 -11
  17. package/components/base-select/mobile.module.css.js +1 -1
  18. package/components/checkmark/Component.d.ts +1 -1
  19. package/components/checkmark/Component.js +3 -4
  20. package/components/checkmark/Component.js.map +1 -1
  21. package/components/checkmark/index.css +23 -31
  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/Component.d.ts +1 -1
  25. package/components/checkmark-mobile/Component.js +2 -2
  26. package/components/checkmark-mobile/Component.js.map +1 -1
  27. package/components/checkmark-mobile/index.css +14 -7
  28. package/components/checkmark-mobile/index.module.css.js +1 -1
  29. package/components/checkmark-mobile/index.module.css.js.map +1 -1
  30. package/components/clear-button/index.css +4 -4
  31. package/components/clear-button/index.module.css.js +1 -1
  32. package/components/field/Component.js +6 -23
  33. package/components/field/Component.js.map +1 -1
  34. package/components/field/index.css +13 -13
  35. package/components/field/index.module.css.js +1 -1
  36. package/components/footer/index.css +4 -4
  37. package/components/footer/index.module.css.js +1 -1
  38. package/components/optgroup/index.css +4 -4
  39. package/components/optgroup/index.module.css.js +1 -1
  40. package/components/option/Component.js +8 -4
  41. package/components/option/Component.js.map +1 -1
  42. package/components/option/desktop/index.css +19 -19
  43. package/components/option/desktop/index.module.css.js +1 -1
  44. package/components/option/mobile/index.css +16 -16
  45. package/components/option/mobile/index.module.css.js +1 -1
  46. package/components/options-list/index.css +13 -13
  47. package/components/options-list/index.module.css.js +1 -1
  48. package/components/search/index.css +1 -1
  49. package/components/search/index.module.css.js +1 -1
  50. package/components/virtual-options-list/index.css +13 -13
  51. package/components/virtual-options-list/index.module.css.js +1 -1
  52. package/cssm/components/base-checkmark/Component.d.ts +2 -2
  53. package/cssm/components/base-checkmark/Component.js +14 -7
  54. package/cssm/components/base-checkmark/Component.js.map +1 -1
  55. package/cssm/components/base-checkmark/index.module.css +29 -2
  56. package/cssm/components/base-option/Component.js +4 -16
  57. package/cssm/components/base-option/Component.js.map +1 -1
  58. package/cssm/components/base-option/index.module.css +0 -6
  59. package/cssm/components/checkmark/Component.d.ts +1 -1
  60. package/cssm/components/checkmark/Component.js +4 -5
  61. package/cssm/components/checkmark/Component.js.map +1 -1
  62. package/cssm/components/checkmark/index.module.css +16 -24
  63. package/cssm/components/checkmark-mobile/Component.d.ts +1 -1
  64. package/cssm/components/checkmark-mobile/Component.js +2 -2
  65. package/cssm/components/checkmark-mobile/Component.js.map +1 -1
  66. package/cssm/components/checkmark-mobile/index.module.css +10 -3
  67. package/cssm/components/field/Component.js +6 -23
  68. package/cssm/components/field/Component.js.map +1 -1
  69. package/cssm/components/option/Component.js +8 -4
  70. package/cssm/components/option/Component.js.map +1 -1
  71. package/cssm/desktop/Component.desktop.js +0 -2
  72. package/cssm/desktop/Component.desktop.js.map +1 -1
  73. package/cssm/mobile/Component.mobile.js +2 -3
  74. package/cssm/mobile/Component.mobile.js.map +1 -1
  75. package/cssm/presets/useLazyLoading/hook.js +0 -2
  76. package/cssm/presets/useLazyLoading/hook.js.map +1 -1
  77. package/cssm/presets/useSelectWithApply/hook.d.ts +7 -1
  78. package/cssm/presets/useSelectWithApply/hook.js +9 -8
  79. package/cssm/presets/useSelectWithApply/hook.js.map +1 -1
  80. package/cssm/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +1 -0
  81. package/cssm/presets/useSelectWithApply/options-list-with-apply/header/Component.js +3 -3
  82. package/cssm/presets/useSelectWithApply/options-list-with-apply/header/Component.js.map +1 -1
  83. package/cssm/presets/useSelectWithApply/options-list-with-apply/header/index.module.css +5 -1
  84. package/cssm/presets/useSelectWithLoading/hook.js +0 -2
  85. package/cssm/presets/useSelectWithLoading/hook.js.map +1 -1
  86. package/cssm/typings.d.ts +9 -0
  87. package/desktop/Component.desktop.js +0 -2
  88. package/desktop/Component.desktop.js.map +1 -1
  89. package/esm/components/arrow/index.css +4 -4
  90. package/esm/components/arrow/index.module.css.js +1 -1
  91. package/esm/components/base-checkmark/Component.d.ts +2 -2
  92. package/esm/components/base-checkmark/Component.js +14 -7
  93. package/esm/components/base-checkmark/Component.js.map +1 -1
  94. package/esm/components/base-checkmark/index.css +32 -5
  95. package/esm/components/base-checkmark/index.module.css.js +1 -1
  96. package/esm/components/base-checkmark/index.module.css.js.map +1 -1
  97. package/esm/components/base-option/Component.js +4 -16
  98. package/esm/components/base-option/Component.js.map +1 -1
  99. package/esm/components/base-option/index.css +14 -20
  100. package/esm/components/base-option/index.module.css.js +1 -1
  101. package/esm/components/base-option/index.module.css.js.map +1 -1
  102. package/esm/components/base-select/index.css +11 -11
  103. package/esm/components/base-select/index.module.css.js +1 -1
  104. package/esm/components/base-select/mobile.css +11 -11
  105. package/esm/components/base-select/mobile.module.css.js +1 -1
  106. package/esm/components/checkmark/Component.d.ts +1 -1
  107. package/esm/components/checkmark/Component.js +3 -4
  108. package/esm/components/checkmark/Component.js.map +1 -1
  109. package/esm/components/checkmark/index.css +23 -31
  110. package/esm/components/checkmark/index.module.css.js +1 -1
  111. package/esm/components/checkmark/index.module.css.js.map +1 -1
  112. package/esm/components/checkmark-mobile/Component.d.ts +1 -1
  113. package/esm/components/checkmark-mobile/Component.js +2 -2
  114. package/esm/components/checkmark-mobile/Component.js.map +1 -1
  115. package/esm/components/checkmark-mobile/index.css +14 -7
  116. package/esm/components/checkmark-mobile/index.module.css.js +1 -1
  117. package/esm/components/checkmark-mobile/index.module.css.js.map +1 -1
  118. package/esm/components/clear-button/index.css +4 -4
  119. package/esm/components/clear-button/index.module.css.js +1 -1
  120. package/esm/components/field/Component.js +8 -25
  121. package/esm/components/field/Component.js.map +1 -1
  122. package/esm/components/field/index.css +13 -13
  123. package/esm/components/field/index.module.css.js +1 -1
  124. package/esm/components/footer/index.css +4 -4
  125. package/esm/components/footer/index.module.css.js +1 -1
  126. package/esm/components/optgroup/index.css +4 -4
  127. package/esm/components/optgroup/index.module.css.js +1 -1
  128. package/esm/components/option/Component.js +8 -4
  129. package/esm/components/option/Component.js.map +1 -1
  130. package/esm/components/option/desktop/index.css +19 -19
  131. package/esm/components/option/desktop/index.module.css.js +1 -1
  132. package/esm/components/option/mobile/index.css +16 -16
  133. package/esm/components/option/mobile/index.module.css.js +1 -1
  134. package/esm/components/options-list/index.css +13 -13
  135. package/esm/components/options-list/index.module.css.js +1 -1
  136. package/esm/components/search/index.css +1 -1
  137. package/esm/components/search/index.module.css.js +1 -1
  138. package/esm/components/virtual-options-list/index.css +13 -13
  139. package/esm/components/virtual-options-list/index.module.css.js +1 -1
  140. package/esm/desktop/Component.desktop.js +0 -2
  141. package/esm/desktop/Component.desktop.js.map +1 -1
  142. package/esm/mobile/Component.mobile.js +2 -3
  143. package/esm/mobile/Component.mobile.js.map +1 -1
  144. package/esm/presets/useLazyLoading/hook.js +0 -2
  145. package/esm/presets/useLazyLoading/hook.js.map +1 -1
  146. package/esm/presets/useSelectWithApply/hook.d.ts +7 -1
  147. package/esm/presets/useSelectWithApply/hook.js +9 -8
  148. package/esm/presets/useSelectWithApply/hook.js.map +1 -1
  149. package/esm/presets/useSelectWithApply/options-list-with-apply/footer/index.css +3 -3
  150. package/esm/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js +1 -1
  151. package/esm/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +1 -0
  152. package/esm/presets/useSelectWithApply/options-list-with-apply/header/Component.js +3 -3
  153. package/esm/presets/useSelectWithApply/options-list-with-apply/header/Component.js.map +1 -1
  154. package/esm/presets/useSelectWithApply/options-list-with-apply/header/index.css +8 -4
  155. package/esm/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js +1 -1
  156. package/esm/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js.map +1 -1
  157. package/esm/presets/useSelectWithLoading/hook.js +0 -2
  158. package/esm/presets/useSelectWithLoading/hook.js.map +1 -1
  159. package/esm/presets/useSelectWithLoading/index.css +1 -1
  160. package/esm/presets/useSelectWithLoading/index.module.css.js +1 -1
  161. package/esm/typings.d.ts +9 -0
  162. package/mobile/Component.mobile.js +2 -3
  163. package/mobile/Component.mobile.js.map +1 -1
  164. package/modern/components/arrow/index.css +4 -4
  165. package/modern/components/arrow/index.module.css.js +1 -1
  166. package/modern/components/base-checkmark/Component.d.ts +2 -2
  167. package/modern/components/base-checkmark/Component.js +10 -6
  168. package/modern/components/base-checkmark/Component.js.map +1 -1
  169. package/modern/components/base-checkmark/index.css +32 -5
  170. package/modern/components/base-checkmark/index.module.css.js +1 -1
  171. package/modern/components/base-checkmark/index.module.css.js.map +1 -1
  172. package/modern/components/base-option/Component.js +4 -15
  173. package/modern/components/base-option/Component.js.map +1 -1
  174. package/modern/components/base-option/index.css +14 -20
  175. package/modern/components/base-option/index.module.css.js +1 -1
  176. package/modern/components/base-option/index.module.css.js.map +1 -1
  177. package/modern/components/base-select/index.css +11 -11
  178. package/modern/components/base-select/index.module.css.js +1 -1
  179. package/modern/components/base-select/mobile.css +11 -11
  180. package/modern/components/base-select/mobile.module.css.js +1 -1
  181. package/modern/components/checkmark/Component.d.ts +1 -1
  182. package/modern/components/checkmark/Component.js +3 -4
  183. package/modern/components/checkmark/Component.js.map +1 -1
  184. package/modern/components/checkmark/index.css +23 -31
  185. package/modern/components/checkmark/index.module.css.js +1 -1
  186. package/modern/components/checkmark/index.module.css.js.map +1 -1
  187. package/modern/components/checkmark-mobile/Component.d.ts +1 -1
  188. package/modern/components/checkmark-mobile/Component.js +1 -1
  189. package/modern/components/checkmark-mobile/Component.js.map +1 -1
  190. package/modern/components/checkmark-mobile/index.css +14 -7
  191. package/modern/components/checkmark-mobile/index.module.css.js +1 -1
  192. package/modern/components/checkmark-mobile/index.module.css.js.map +1 -1
  193. package/modern/components/clear-button/index.css +4 -4
  194. package/modern/components/clear-button/index.module.css.js +1 -1
  195. package/modern/components/field/Component.js +8 -25
  196. package/modern/components/field/Component.js.map +1 -1
  197. package/modern/components/field/index.css +13 -13
  198. package/modern/components/field/index.module.css.js +1 -1
  199. package/modern/components/footer/index.css +4 -4
  200. package/modern/components/footer/index.module.css.js +1 -1
  201. package/modern/components/optgroup/index.css +4 -4
  202. package/modern/components/optgroup/index.module.css.js +1 -1
  203. package/modern/components/option/Component.js +5 -3
  204. package/modern/components/option/Component.js.map +1 -1
  205. package/modern/components/option/desktop/index.css +19 -19
  206. package/modern/components/option/desktop/index.module.css.js +1 -1
  207. package/modern/components/option/mobile/index.css +16 -16
  208. package/modern/components/option/mobile/index.module.css.js +1 -1
  209. package/modern/components/options-list/index.css +13 -13
  210. package/modern/components/options-list/index.module.css.js +1 -1
  211. package/modern/components/search/index.css +1 -1
  212. package/modern/components/search/index.module.css.js +1 -1
  213. package/modern/components/virtual-options-list/index.css +13 -13
  214. package/modern/components/virtual-options-list/index.module.css.js +1 -1
  215. package/modern/desktop/Component.desktop.js +0 -2
  216. package/modern/desktop/Component.desktop.js.map +1 -1
  217. package/modern/mobile/Component.mobile.js +2 -3
  218. package/modern/mobile/Component.mobile.js.map +1 -1
  219. package/modern/presets/useLazyLoading/hook.js +0 -2
  220. package/modern/presets/useLazyLoading/hook.js.map +1 -1
  221. package/modern/presets/useSelectWithApply/hook.d.ts +7 -1
  222. package/modern/presets/useSelectWithApply/hook.js +3 -1
  223. package/modern/presets/useSelectWithApply/hook.js.map +1 -1
  224. package/modern/presets/useSelectWithApply/options-list-with-apply/footer/index.css +3 -3
  225. package/modern/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js +1 -1
  226. package/modern/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +1 -0
  227. package/modern/presets/useSelectWithApply/options-list-with-apply/header/Component.js +2 -2
  228. package/modern/presets/useSelectWithApply/options-list-with-apply/header/Component.js.map +1 -1
  229. package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.css +8 -4
  230. package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js +1 -1
  231. package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js.map +1 -1
  232. package/modern/presets/useSelectWithLoading/hook.js +0 -2
  233. package/modern/presets/useSelectWithLoading/hook.js.map +1 -1
  234. package/modern/presets/useSelectWithLoading/index.css +1 -1
  235. package/modern/presets/useSelectWithLoading/index.module.css.js +1 -1
  236. package/modern/typings.d.ts +9 -0
  237. package/moderncssm/components/base-checkmark/Component.d.ts +2 -2
  238. package/moderncssm/components/base-checkmark/Component.js +10 -6
  239. package/moderncssm/components/base-checkmark/Component.js.map +1 -1
  240. package/moderncssm/components/base-checkmark/index.module.css +32 -2
  241. package/moderncssm/components/base-option/Component.js +4 -15
  242. package/moderncssm/components/base-option/Component.js.map +1 -1
  243. package/moderncssm/components/base-option/index.module.css +0 -8
  244. package/moderncssm/components/checkmark/Component.d.ts +1 -1
  245. package/moderncssm/components/checkmark/Component.js +3 -4
  246. package/moderncssm/components/checkmark/Component.js.map +1 -1
  247. package/moderncssm/components/checkmark/index.module.css +19 -18
  248. package/moderncssm/components/checkmark-mobile/Component.d.ts +1 -1
  249. package/moderncssm/components/checkmark-mobile/Component.js +1 -1
  250. package/moderncssm/components/checkmark-mobile/Component.js.map +1 -1
  251. package/moderncssm/components/checkmark-mobile/index.module.css +8 -4
  252. package/moderncssm/components/field/Component.js +8 -25
  253. package/moderncssm/components/field/Component.js.map +1 -1
  254. package/moderncssm/components/option/Component.js +5 -3
  255. package/moderncssm/components/option/Component.js.map +1 -1
  256. package/moderncssm/desktop/Component.desktop.js +0 -2
  257. package/moderncssm/desktop/Component.desktop.js.map +1 -1
  258. package/moderncssm/mobile/Component.mobile.js +2 -3
  259. package/moderncssm/mobile/Component.mobile.js.map +1 -1
  260. package/moderncssm/presets/useLazyLoading/hook.js +0 -2
  261. package/moderncssm/presets/useLazyLoading/hook.js.map +1 -1
  262. package/moderncssm/presets/useSelectWithApply/hook.d.ts +7 -1
  263. package/moderncssm/presets/useSelectWithApply/hook.js +3 -1
  264. package/moderncssm/presets/useSelectWithApply/hook.js.map +1 -1
  265. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +1 -0
  266. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/header/Component.js +2 -2
  267. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/header/Component.js.map +1 -1
  268. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/header/index.module.css +6 -1
  269. package/moderncssm/presets/useSelectWithLoading/hook.js +0 -2
  270. package/moderncssm/presets/useSelectWithLoading/hook.js.map +1 -1
  271. package/moderncssm/typings.d.ts +9 -0
  272. package/package.json +8 -9
  273. package/presets/useLazyLoading/hook.js +0 -2
  274. package/presets/useLazyLoading/hook.js.map +1 -1
  275. package/presets/useSelectWithApply/hook.d.ts +7 -1
  276. package/presets/useSelectWithApply/hook.js +9 -8
  277. package/presets/useSelectWithApply/hook.js.map +1 -1
  278. package/presets/useSelectWithApply/options-list-with-apply/footer/index.css +3 -3
  279. package/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js +1 -1
  280. package/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +1 -0
  281. package/presets/useSelectWithApply/options-list-with-apply/header/Component.js +3 -3
  282. package/presets/useSelectWithApply/options-list-with-apply/header/Component.js.map +1 -1
  283. package/presets/useSelectWithApply/options-list-with-apply/header/index.css +8 -4
  284. package/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js +1 -1
  285. package/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js.map +1 -1
  286. package/presets/useSelectWithLoading/hook.js +0 -2
  287. package/presets/useSelectWithLoading/hook.js.map +1 -1
  288. package/presets/useSelectWithLoading/index.css +1 -1
  289. package/presets/useSelectWithLoading/index.module.css.js +1 -1
  290. package/src/components/base-checkmark/Component.tsx +26 -9
  291. package/src/components/base-checkmark/index.module.css +30 -1
  292. package/src/components/base-option/Component.tsx +17 -27
  293. package/src/components/base-option/index.module.css +0 -8
  294. package/src/components/checkmark/Component.tsx +3 -13
  295. package/src/components/checkmark/index.module.css +17 -9
  296. package/src/components/checkmark-mobile/Component.tsx +2 -2
  297. package/src/components/checkmark-mobile/index.module.css +8 -4
  298. package/src/components/field/Component.tsx +12 -26
  299. package/src/components/option/Component.tsx +14 -17
  300. package/src/mobile/Component.mobile.tsx +2 -0
  301. package/src/presets/useSelectWithApply/hook.ts +9 -1
  302. package/src/presets/useSelectWithApply/options-list-with-apply/header/Component.tsx +4 -0
  303. package/src/presets/useSelectWithApply/options-list-with-apply/header/index.module.css +5 -1
  304. package/src/typings.ts +11 -0
  305. package/src/vars.css +3 -3
  306. package/typings.d.ts +9 -0
@@ -83,14 +83,6 @@
83
83
  color: var(--select-option-disabled-color);
84
84
  }
85
85
 
86
- .checkmarkBeforeContent {
87
- margin-right: var(--gap-12);
88
- }
89
-
90
- .checkmarkAfterContent {
91
- margin-left: var(--gap-12);
92
- }
93
-
94
86
  .content {
95
87
  flex: 1;
96
88
  }
@@ -1,3 +1,3 @@
1
1
  import React from 'react';
2
2
  import { type CheckmarkProps } from '../../typings';
3
- export declare const Checkmark: ({ selected, disabled, className, multiple, position, }: CheckmarkProps) => React.JSX.Element;
3
+ export declare const Checkmark: ({ selected, disabled, className, multiple, position, content, }: CheckmarkProps) => React.JSX.Element;
@@ -1,12 +1,10 @@
1
1
  import React, { useCallback } from 'react';
2
2
  import cn from 'classnames';
3
- import { Badge } from '@alfalab/core-components-badge/moderncssm';
4
3
  import { Checkbox } from '@alfalab/core-components-checkbox/moderncssm';
5
- import { CheckmarkCircleMIcon } from '@alfalab/icons-glyph/CheckmarkCircleMIcon';
6
4
  import CheckmarkMIcon from '@alfalab/icons-glyph/CheckmarkMIcon';
7
5
  import styles from './index.module.css';
8
6
 
9
- const Checkmark = ({ selected, disabled = false, className, multiple, position = 'before', }) => {
7
+ const Checkmark = ({ selected, disabled = false, className, multiple, position = 'before', content, }) => {
10
8
  const single = !multiple;
11
9
  const checkmarkClassNames = cn(styles.checkmark, className, styles[position], {
12
10
  [styles.multiple]: !single,
@@ -14,7 +12,8 @@ const Checkmark = ({ selected, disabled = false, className, multiple, position =
14
12
  [styles.selected]: selected,
15
13
  });
16
14
  const handleCheckboxClick = useCallback((event) => event.stopPropagation(), []);
17
- return single ? (React.createElement("div", { className: checkmarkClassNames }, position === 'before' ? (React.createElement(Badge, { className: styles.after, view: 'icon', size: 'm', iconColor: 'positive', content: React.createElement(CheckmarkCircleMIcon, { className: styles.colorIcon }) })) : (React.createElement(CheckmarkMIcon, { className: cn(styles.displayIcon) })))) : (React.createElement(Checkbox, { checked: selected, disabled: disabled, className: checkmarkClassNames, size: 24, onClick: handleCheckboxClick }));
15
+ return single ? (React.createElement("div", { className: checkmarkClassNames },
16
+ React.createElement(CheckmarkMIcon, { className: cn(styles.displayIcon) }))) : (React.createElement(Checkbox, { checked: selected, disabled: disabled, className: checkmarkClassNames, size: 24, label: content, onClick: handleCheckboxClick }));
18
17
  };
19
18
 
20
19
  export { Checkmark };
@@ -1 +1 @@
1
- {"version":3,"file":"Component.js","sources":["../../../src/components/checkmark/Component.tsx"],"sourcesContent":["import React, { useCallback } from 'react';\nimport cn from 'classnames';\n\nimport { Badge } from '@alfalab/core-components-badge';\nimport { Checkbox, type CheckboxProps } from '@alfalab/core-components-checkbox';\nimport { CheckmarkCircleMIcon } from '@alfalab/icons-glyph/CheckmarkCircleMIcon';\nimport CheckmarkMIcon from '@alfalab/icons-glyph/CheckmarkMIcon';\n\nimport { type CheckmarkProps } from '../../typings';\n\nimport styles from './index.module.css';\n\nexport const Checkmark = ({\n selected,\n disabled = false,\n className,\n multiple,\n position = 'before',\n}: CheckmarkProps) => {\n const single = !multiple;\n\n const checkmarkClassNames = cn(styles.checkmark, className, styles[position], {\n [styles.multiple]: !single,\n [styles.single]: single,\n [styles.selected]: selected,\n });\n\n const handleCheckboxClick = useCallback<Required<CheckboxProps>['onClick']>(\n (event) => event.stopPropagation(),\n [],\n );\n\n return single ? (\n <div className={checkmarkClassNames}>\n {position === 'before' ? (\n <Badge\n className={styles.after}\n view='icon'\n size='m'\n iconColor='positive'\n content={<CheckmarkCircleMIcon className={styles.colorIcon} />}\n />\n ) : (\n <CheckmarkMIcon className={cn(styles.displayIcon)} />\n )}\n </div>\n ) : (\n <Checkbox\n checked={selected}\n disabled={disabled}\n className={checkmarkClassNames}\n size={24}\n onClick={handleCheckboxClick}\n />\n );\n};\n"],"names":[],"mappings":";;;;;;;;MAYa,SAAS,GAAG,CAAC,EACtB,QAAQ,EACR,QAAQ,GAAG,KAAK,EAChB,SAAS,EACT,QAAQ,EACR,QAAQ,GAAG,QAAQ,GACN,KAAI;AACjB,IAAA,MAAM,MAAM,GAAG,CAAC,QAAQ;AAExB,IAAA,MAAM,mBAAmB,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE,SAAS,EAAE,MAAM,CAAC,QAAQ,CAAC,EAAE;AAC1E,QAAA,CAAC,MAAM,CAAC,QAAQ,GAAG,CAAC,MAAM;AAC1B,QAAA,CAAC,MAAM,CAAC,MAAM,GAAG,MAAM;AACvB,QAAA,CAAC,MAAM,CAAC,QAAQ,GAAG,QAAQ;AAC9B,KAAA,CAAC;AAEF,IAAA,MAAM,mBAAmB,GAAG,WAAW,CACnC,CAAC,KAAK,KAAK,KAAK,CAAC,eAAe,EAAE,EAClC,EAAE,CACL;IAED,OAAO,MAAM,IACT,KAAK,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,SAAS,EAAE,mBAAmB,EAAA,EAC9B,QAAQ,KAAK,QAAQ,IAClB,KAAC,CAAA,aAAA,CAAA,KAAK,EACF,EAAA,SAAS,EAAE,MAAM,CAAC,KAAK,EACvB,IAAI,EAAC,MAAM,EACX,IAAI,EAAC,GAAG,EACR,SAAS,EAAC,UAAU,EACpB,OAAO,EAAE,KAAC,CAAA,aAAA,CAAA,oBAAoB,IAAC,SAAS,EAAE,MAAM,CAAC,SAAS,EAAA,CAAI,GAChE,KAEF,oBAAC,cAAc,EAAA,EAAC,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,EAAA,CAAI,CACxD,CACC,KAEN,oBAAC,QAAQ,EAAA,EACL,OAAO,EAAE,QAAQ,EACjB,QAAQ,EAAE,QAAQ,EAClB,SAAS,EAAE,mBAAmB,EAC9B,IAAI,EAAE,EAAE,EACR,OAAO,EAAE,mBAAmB,EAC9B,CAAA,CACL;AACL;;;;"}
1
+ {"version":3,"file":"Component.js","sources":["../../../src/components/checkmark/Component.tsx"],"sourcesContent":["import React, { useCallback } from 'react';\nimport cn from 'classnames';\n\nimport { Checkbox, type CheckboxProps } from '@alfalab/core-components-checkbox';\nimport CheckmarkMIcon from '@alfalab/icons-glyph/CheckmarkMIcon';\n\nimport { type CheckmarkProps } from '../../typings';\n\nimport styles from './index.module.css';\n\nexport const Checkmark = ({\n selected,\n disabled = false,\n className,\n multiple,\n position = 'before',\n content,\n}: CheckmarkProps) => {\n const single = !multiple;\n\n const checkmarkClassNames = cn(styles.checkmark, className, styles[position], {\n [styles.multiple]: !single,\n [styles.single]: single,\n [styles.selected]: selected,\n });\n\n const handleCheckboxClick = useCallback<Required<CheckboxProps>['onClick']>(\n (event) => event.stopPropagation(),\n [],\n );\n\n return single ? (\n <div className={checkmarkClassNames}>\n <CheckmarkMIcon className={cn(styles.displayIcon)} />\n </div>\n ) : (\n <Checkbox\n checked={selected}\n disabled={disabled}\n className={checkmarkClassNames}\n size={24}\n label={content}\n onClick={handleCheckboxClick}\n />\n );\n};\n"],"names":[],"mappings":";;;;;;MAUa,SAAS,GAAG,CAAC,EACtB,QAAQ,EACR,QAAQ,GAAG,KAAK,EAChB,SAAS,EACT,QAAQ,EACR,QAAQ,GAAG,QAAQ,EACnB,OAAO,GACM,KAAI;AACjB,IAAA,MAAM,MAAM,GAAG,CAAC,QAAQ;AAExB,IAAA,MAAM,mBAAmB,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE,SAAS,EAAE,MAAM,CAAC,QAAQ,CAAC,EAAE;AAC1E,QAAA,CAAC,MAAM,CAAC,QAAQ,GAAG,CAAC,MAAM;AAC1B,QAAA,CAAC,MAAM,CAAC,MAAM,GAAG,MAAM;AACvB,QAAA,CAAC,MAAM,CAAC,QAAQ,GAAG,QAAQ;AAC9B,KAAA,CAAC;AAEF,IAAA,MAAM,mBAAmB,GAAG,WAAW,CACnC,CAAC,KAAK,KAAK,KAAK,CAAC,eAAe,EAAE,EAClC,EAAE,CACL;IAED,OAAO,MAAM,IACT,KAAK,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,SAAS,EAAE,mBAAmB,EAAA;QAC/B,KAAC,CAAA,aAAA,CAAA,cAAc,IAAC,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,GAAI,CACnD,KAEN,KAAC,CAAA,aAAA,CAAA,QAAQ,IACL,OAAO,EAAE,QAAQ,EACjB,QAAQ,EAAE,QAAQ,EAClB,SAAS,EAAE,mBAAmB,EAC9B,IAAI,EAAE,EAAE,EACR,KAAK,EAAE,OAAO,EACd,OAAO,EAAE,mBAAmB,EAC9B,CAAA,CACL;AACL;;;;"}
@@ -1,24 +1,22 @@
1
1
  :root {
2
-
3
- --select-checkmark-margin: var(--gap-0) var(--gap-8) var(--gap-0) var(--gap-0);
4
- --select-checkmark-margin-after: var(--select-checkmark-margin);
5
- --select-checkmark-size: 4px;
6
- --select-checkmark-before-display: 'flex';
2
+ --select-checkmark-size: 24px;
3
+ --select-checkmark-before-display: flex;
7
4
  --select-checkmark-after-display: none;
8
5
  --select-checkmark-before-display-multiple: block;
9
- --select-checkmark-after-display-single: none;
6
+ --select-checkmark-after-display-single: flex;
10
7
  --select-checkmark-unselected-opacity: 0;
11
- --select-checkmark-background: var(--color-light-neutral-translucent-1300);
12
- --select-checkmark-border-radius: var(--border-radius-circle);
13
8
  }
14
9
 
15
10
  .checkmark {
16
11
  flex-shrink: 0;
17
- margin: var(--select-checkmark-margin);
18
12
  }
19
13
 
14
+ .checkmark.before {
15
+ display: var(--select-checkmark-before-display);
16
+ }
17
+
20
18
  .checkmark.after {
21
- margin: var(--select-checkmark-margin-after);
19
+ display: var(--select-checkmark-after-display);
22
20
  }
23
21
 
24
22
  .single {
@@ -26,9 +24,6 @@
26
24
  align-items: center;
27
25
  justify-content: center;
28
26
  opacity: var(--select-checkmark-unselected-opacity);
29
- background: var(--select-checkmark-background);
30
- background-size: cover;
31
- border-radius: var(--select-checkmark-border-radius);
32
27
  width: var(--select-checkmark-size);
33
28
  height: var(--select-checkmark-size);
34
29
  }
@@ -37,15 +32,15 @@
37
32
  opacity: 1;
38
33
  }
39
34
 
40
- .before {
41
- display: var(--select-checkmark-before-display);
42
- }
43
-
44
- .before.multiple {
35
+ .multiple.before {
45
36
  margin-right: var(--gap-12);
46
37
  display: var(--select-checkmark-before-display-multiple);
47
38
  }
48
39
 
40
+ .multiple.after {
41
+ margin-left: var(--gap-12);
42
+ }
43
+
49
44
  .after.after {
50
45
  display: var(--select-checkmark-after-display);
51
46
  }
@@ -57,3 +52,9 @@
57
52
  .colorIcon {
58
53
  color: var(--color-light-status-positive);
59
54
  }
55
+
56
+ .displayIcon {
57
+ display: block;
58
+ width: 100%;
59
+ height: 100%;
60
+ }
@@ -1,3 +1,3 @@
1
1
  import React from 'react';
2
2
  import { type CheckmarkProps } from '../../typings';
3
- export declare const Checkmark: ({ selected, className }: CheckmarkProps) => React.JSX.Element;
3
+ export declare const Checkmark: ({ selected, className, position }: CheckmarkProps) => React.JSX.Element;
@@ -3,7 +3,7 @@ import cn from 'classnames';
3
3
  import { CheckmarkMIcon } from '@alfalab/icons-glyph/CheckmarkMIcon';
4
4
  import styles from './index.module.css';
5
5
 
6
- const Checkmark = ({ selected, className }) => (React.createElement("div", { className: cn(styles.checkmark, className, {
6
+ const Checkmark = ({ selected, className, position = 'after' }) => (React.createElement("div", { className: cn(styles.checkmark, className, styles[position], {
7
7
  [styles.selected]: selected,
8
8
  }) },
9
9
  React.createElement(CheckmarkMIcon, { className: styles.displayIcon })));
@@ -1 +1 @@
1
- {"version":3,"file":"Component.js","sources":["../../../src/components/checkmark-mobile/Component.tsx"],"sourcesContent":["import React from 'react';\nimport cn from 'classnames';\n\nimport { CheckmarkMIcon } from '@alfalab/icons-glyph/CheckmarkMIcon';\n\nimport { type CheckmarkProps } from '../../typings';\n\nimport styles from './index.module.css';\n\nexport const Checkmark = ({ selected, className }: CheckmarkProps) => (\n <div\n className={cn(styles.checkmark, className, {\n [styles.selected]: selected,\n })}\n >\n <CheckmarkMIcon className={styles.displayIcon} />\n </div>\n);\n"],"names":[],"mappings":";;;;;AASa,MAAA,SAAS,GAAG,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAkB,MAC7D,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EACI,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE,SAAS,EAAE;AACvC,QAAA,CAAC,MAAM,CAAC,QAAQ,GAAG,QAAQ;KAC9B,CAAC,EAAA;IAEF,KAAC,CAAA,aAAA,CAAA,cAAc,EAAC,EAAA,SAAS,EAAE,MAAM,CAAC,WAAW,EAAA,CAAI,CAC/C;;;;"}
1
+ {"version":3,"file":"Component.js","sources":["../../../src/components/checkmark-mobile/Component.tsx"],"sourcesContent":["import React from 'react';\nimport cn from 'classnames';\n\nimport { CheckmarkMIcon } from '@alfalab/icons-glyph/CheckmarkMIcon';\n\nimport { type CheckmarkProps } from '../../typings';\n\nimport styles from './index.module.css';\n\nexport const Checkmark = ({ selected, className, position = 'after' }: CheckmarkProps) => (\n <div\n className={cn(styles.checkmark, className, styles[position], {\n [styles.selected]: selected,\n })}\n >\n <CheckmarkMIcon className={styles.displayIcon} />\n </div>\n);\n"],"names":[],"mappings":";;;;;AASO,MAAM,SAAS,GAAG,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,GAAG,OAAO,EAAkB,MACjF,KACI,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE,SAAS,EAAE,MAAM,CAAC,QAAQ,CAAC,EAAE;AACzD,QAAA,CAAC,MAAM,CAAC,QAAQ,GAAG,QAAQ;KAC9B,CAAC,EAAA;IAEF,KAAC,CAAA,aAAA,CAAA,cAAc,EAAC,EAAA,SAAS,EAAE,MAAM,CAAC,WAAW,EAAA,CAAI,CAC/C;;;;"}
@@ -13,14 +13,18 @@
13
13
  opacity: 0;
14
14
  }
15
15
 
16
- .checkmark:first-child {
17
- display: none;
18
- }
19
-
20
16
  .checkmark.selected {
21
17
  opacity: 1;
22
18
  }
23
19
 
20
+ .checkmark.before {
21
+ margin-right: var(--gap-8);
22
+ }
23
+
24
+ .checkmark.after {
25
+ margin-left: var(--gap-8);
26
+ }
27
+
24
28
  .displayIcon {
25
29
  display: var(--select-mobile-checkmark-display-icon);
26
30
  }
@@ -1,6 +1,6 @@
1
- import React, { useState, useRef, useCallback } from 'react';
1
+ import React, { useState, useRef, useCallback, Fragment } from 'react';
2
2
  import cn from 'classnames';
3
- import { getAddonsByPriority, LockIcon } from '@alfalab/core-components-input/moderncssm/shared';
3
+ import { LockIcon } from '@alfalab/core-components-input/moderncssm/shared';
4
4
  import { getDataTestId } from '@alfalab/core-components-shared/moderncssm';
5
5
  import { useFocus } from '@alfalab/hooks';
6
6
  import { joinOptions } from '../../utils.js';
@@ -27,32 +27,15 @@ const Field = ({ size = 56, open, multiple, error, hint, disabled, label, labelV
27
27
  * [1] - Indicators (eye, calendar, chevron, stepper e.g.)
28
28
  * [0] - Lock
29
29
  */
30
- const rightAddonsMap = getAddonsByPriority([
31
- {
32
- priority: 4,
33
- predicate: clear && filled && !disabled,
34
- render: () => (React.createElement(ClearButton, { onClick: onClear, disabled: disabled, dataTestId: getDataTestId(dataTestId, 'clear-icon'), size: size })),
35
- },
36
- {
37
- priority: 2,
38
- predicate: Boolean(rightAddons),
39
- render: () => rightAddons,
40
- },
41
- {
42
- priority: 1,
43
- predicate: Boolean(Arrow) && !disabled,
44
- render: () => Arrow && React.cloneElement(Arrow, { className: styles.arrow }),
45
- },
46
- {
47
- priority: 0,
48
- predicate: disabled,
49
- render: () => React.createElement(LockIcon, { colors: colors, size: size }),
50
- },
51
- ]);
30
+ const renderRightAddons = () => (React.createElement(Fragment, null,
31
+ clear && filled && !disabled && (React.createElement(ClearButton, { onClick: onClear, disabled: disabled, dataTestId: getDataTestId(dataTestId, 'clear-icon'), size: size })),
32
+ rightAddons,
33
+ !disabled && Arrow && React.cloneElement(Arrow, { className: styles.arrow }),
34
+ disabled && React.createElement(LockIcon, { colors: colors, size: size })));
52
35
  return (React.createElement("div", { className: styles.component, ref: wrapperRef, onFocus: handleFocus, onBlur: handleBlur }, FormControlComponent ? (React.createElement(FormControlComponent, { dataTestId: getDataTestId(dataTestId, 'form-control'), fieldClassName: cn(styles.field, fieldClassName, {
53
36
  [styles.disabled]: disabled,
54
37
  [styles.focusVisible]: focusVisible,
55
- }), block: true, size: size, focused: focused || open, disabled: disabled, filled: filled || (!!placeholder && open), label: showLabel && label, labelView: labelView, error: error, hint: hint, rightAddons: rightAddonsMap, "data-test-id": dataTestId, ...restProps, ...innerProps },
38
+ }), block: true, size: size, focused: focused || open, disabled: disabled, filled: filled || (!!placeholder && open), label: showLabel && label, labelView: labelView, error: error, hint: hint, rightAddons: renderRightAddons(), "data-test-id": dataTestId, ...restProps, ...innerProps },
56
39
  React.createElement("div", { className: cn(styles.contentWrapper, styles[`size-${size}`]) },
57
40
  showPlaceholder && (React.createElement("span", { className: cn(styles.placeholder, {
58
41
  [styles.focused]: focused || open,
@@ -1 +1 @@
1
- {"version":3,"file":"Component.js","sources":["../../../src/components/field/Component.tsx"],"sourcesContent":["import React, { type ElementType, useCallback, useRef, useState } from 'react';\nimport cn from 'classnames';\n\nimport { type FormControlProps } from '@alfalab/core-components-form-control';\nimport { getAddonsByPriority, LockIcon } from '@alfalab/core-components-input/shared';\nimport { getDataTestId } from '@alfalab/core-components-shared';\nimport { useFocus } from '@alfalab/hooks';\n\nimport { type FieldProps as BaseFieldProps } from '../../typings';\nimport { joinOptions } from '../../utils';\nimport { ClearButton } from '../clear-button';\n\nimport styles from './index.module.css';\n\ntype FieldProps = {\n /**\n * Компонент FormControl\n */\n FormControlComponent?: ElementType;\n};\n\n// eslint-disable-next-line complexity\nexport const Field = ({\n size = 56,\n open,\n multiple,\n error,\n hint,\n disabled,\n label,\n labelView = 'inner',\n placeholder,\n selectedMultiple = [],\n selected,\n rightAddons,\n valueRenderer = joinOptions,\n setSelectedItems,\n toggleMenu,\n Arrow,\n innerProps,\n dataTestId,\n fieldClassName,\n FormControlComponent,\n clear,\n onClear,\n valueSeparator,\n ...restProps\n}: BaseFieldProps & FormControlProps & FieldProps) => {\n const { colors = 'default' } = restProps;\n const [focused, setFocused] = useState(false);\n\n const wrapperRef = useRef<HTMLDivElement>(null);\n\n const [focusVisible] = useFocus(wrapperRef, 'keyboard');\n\n const handleFocus = useCallback(() => setFocused(true), []);\n const handleBlur = useCallback(() => setFocused(false), []);\n\n const value = valueRenderer({ selected, selectedMultiple, valueSeparator });\n\n const filled = Boolean(value);\n const showLabel = !!label || labelView === 'outer';\n const showPlaceholder = !!placeholder && !filled && (open || !label || labelView === 'outer');\n\n /**\n * Right addons priority [4] <= [3] <= [2] <= [1] or [0]\n * [4] - Clear\n * [3] - Status (error, success)\n * [2] - Common (info, e.g.)\n * [1] - Indicators (eye, calendar, chevron, stepper e.g.)\n * [0] - Lock\n */\n const rightAddonsMap = getAddonsByPriority([\n {\n priority: 4,\n predicate: clear && filled && !disabled,\n render: () => (\n <ClearButton\n onClick={onClear}\n disabled={disabled}\n dataTestId={getDataTestId(dataTestId, 'clear-icon')}\n size={size}\n />\n ),\n },\n {\n priority: 2,\n predicate: Boolean(rightAddons),\n render: () => rightAddons,\n },\n {\n priority: 1,\n predicate: Boolean(Arrow) && !disabled,\n render: () => Arrow && React.cloneElement(Arrow, { className: styles.arrow }),\n },\n {\n priority: 0,\n predicate: disabled,\n render: () => <LockIcon colors={colors} size={size} />,\n },\n ]);\n\n return (\n <div\n className={styles.component}\n ref={wrapperRef}\n onFocus={handleFocus}\n onBlur={handleBlur}\n >\n {FormControlComponent ? (\n <FormControlComponent\n dataTestId={getDataTestId(dataTestId, 'form-control')}\n fieldClassName={cn(styles.field, fieldClassName, {\n [styles.disabled]: disabled,\n [styles.focusVisible]: focusVisible,\n })}\n block={true}\n size={size}\n focused={focused || open}\n disabled={disabled}\n filled={filled || (!!placeholder && open)}\n label={showLabel && label}\n labelView={labelView}\n error={error}\n hint={hint}\n rightAddons={rightAddonsMap}\n data-test-id={dataTestId}\n {...restProps}\n {...innerProps}\n >\n <div className={cn(styles.contentWrapper, styles[`size-${size}`])}>\n {showPlaceholder && (\n <span\n className={cn(styles.placeholder, {\n [styles.focused]: focused || open,\n })}\n >\n {placeholder}\n </span>\n )}\n {filled && (\n <div className={cn(styles.value, styles[`size-${size}`])}>{value}</div>\n )}\n </div>\n </FormControlComponent>\n ) : null}\n </div>\n );\n};\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"Component.js","sources":["../../../src/components/field/Component.tsx"],"sourcesContent":["import React, { type ElementType, Fragment, useCallback, useRef, useState } from 'react';\nimport cn from 'classnames';\n\nimport { type FormControlProps } from '@alfalab/core-components-form-control';\nimport { LockIcon } from '@alfalab/core-components-input/shared';\nimport { getDataTestId } from '@alfalab/core-components-shared';\nimport { useFocus } from '@alfalab/hooks';\n\nimport { type FieldProps as BaseFieldProps } from '../../typings';\nimport { joinOptions } from '../../utils';\nimport { ClearButton } from '../clear-button';\n\nimport styles from './index.module.css';\n\ntype FieldProps = {\n /**\n * Компонент FormControl\n */\n FormControlComponent?: ElementType;\n};\n\n// eslint-disable-next-line complexity\nexport const Field = ({\n size = 56,\n open,\n multiple,\n error,\n hint,\n disabled,\n label,\n labelView = 'inner',\n placeholder,\n selectedMultiple = [],\n selected,\n rightAddons,\n valueRenderer = joinOptions,\n setSelectedItems,\n toggleMenu,\n Arrow,\n innerProps,\n dataTestId,\n fieldClassName,\n FormControlComponent,\n clear,\n onClear,\n valueSeparator,\n ...restProps\n}: BaseFieldProps & FormControlProps & FieldProps) => {\n const { colors = 'default' } = restProps;\n const [focused, setFocused] = useState(false);\n\n const wrapperRef = useRef<HTMLDivElement>(null);\n\n const [focusVisible] = useFocus(wrapperRef, 'keyboard');\n\n const handleFocus = useCallback(() => setFocused(true), []);\n const handleBlur = useCallback(() => setFocused(false), []);\n\n const value = valueRenderer({ selected, selectedMultiple, valueSeparator });\n\n const filled = Boolean(value);\n const showLabel = !!label || labelView === 'outer';\n const showPlaceholder = !!placeholder && !filled && (open || !label || labelView === 'outer');\n\n /**\n * Right addons priority [4] <= [3] <= [2] <= [1] or [0]\n * [4] - Clear\n * [3] - Status (error, success)\n * [2] - Common (info, e.g.)\n * [1] - Indicators (eye, calendar, chevron, stepper e.g.)\n * [0] - Lock\n */\n const renderRightAddons = () => (\n <Fragment>\n {clear && filled && !disabled && (\n <ClearButton\n onClick={onClear}\n disabled={disabled}\n dataTestId={getDataTestId(dataTestId, 'clear-icon')}\n size={size}\n />\n )}\n {rightAddons}\n {!disabled && Arrow && React.cloneElement(Arrow, { className: styles.arrow })}\n {disabled && <LockIcon colors={colors} size={size} />}\n </Fragment>\n );\n\n return (\n <div\n className={styles.component}\n ref={wrapperRef}\n onFocus={handleFocus}\n onBlur={handleBlur}\n >\n {FormControlComponent ? (\n <FormControlComponent\n dataTestId={getDataTestId(dataTestId, 'form-control')}\n fieldClassName={cn(styles.field, fieldClassName, {\n [styles.disabled]: disabled,\n [styles.focusVisible]: focusVisible,\n })}\n block={true}\n size={size}\n focused={focused || open}\n disabled={disabled}\n filled={filled || (!!placeholder && open)}\n label={showLabel && label}\n labelView={labelView}\n error={error}\n hint={hint}\n rightAddons={renderRightAddons()}\n data-test-id={dataTestId}\n {...restProps}\n {...innerProps}\n >\n <div className={cn(styles.contentWrapper, styles[`size-${size}`])}>\n {showPlaceholder && (\n <span\n className={cn(styles.placeholder, {\n [styles.focused]: focused || open,\n })}\n >\n {placeholder}\n </span>\n )}\n {filled && (\n <div className={cn(styles.value, styles[`size-${size}`])}>{value}</div>\n )}\n </div>\n </FormControlComponent>\n ) : null}\n </div>\n );\n};\n"],"names":[],"mappings":"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"}
@@ -1,19 +1,21 @@
1
1
  import React, { isValidElement } from 'react';
2
2
  import cn from 'classnames';
3
3
 
4
- const OptionBase = ({ size = 48, className, option, children, selected, highlighted, disabled, multiple, mobile, Checkmark, innerProps, dataTestId, styles, }) => {
4
+ const OptionBase = ({ size = 48, className, option, children, selected, highlighted, disabled, multiple, mobile, Checkmark, checkmarkPosition = multiple ? 'before' : 'after', innerProps, dataTestId, styles, }) => {
5
5
  const content = children || option.content || option.key;
6
6
  const { showCheckMark = true } = option;
7
+ const renderCheckmark = (position) => Checkmark &&
8
+ showCheckMark && (React.createElement(Checkmark, { disabled: disabled, selected: selected, multiple: multiple, position: position }));
7
9
  return (React.createElement("div", { ...innerProps, className: cn(styles.option, styles[`size-${size}`], className, {
8
10
  [styles.highlighted]: !mobile && highlighted,
9
11
  [styles.selected]: selected,
10
12
  [styles.disabled]: disabled,
11
13
  }), "data-test-id": dataTestId },
12
- Checkmark && showCheckMark && (React.createElement(Checkmark, { disabled: disabled, selected: selected, multiple: multiple, position: 'before' })),
14
+ checkmarkPosition === 'before' && renderCheckmark('before'),
13
15
  React.createElement("div", { className: cn(styles.content, {
14
16
  [styles.textContent]: !isValidElement(content),
15
17
  }) }, content),
16
- Checkmark && showCheckMark && (React.createElement(Checkmark, { disabled: disabled, selected: selected, multiple: multiple, position: 'after' }))));
18
+ checkmarkPosition === 'after' && renderCheckmark('after')));
17
19
  };
18
20
 
19
21
  export { OptionBase };
@@ -1 +1 @@
1
- {"version":3,"file":"Component.js","sources":["../../../src/components/option/Component.tsx"],"sourcesContent":["import React, { type FC, isValidElement } from 'react';\nimport cn from 'classnames';\n\nimport { type OptionCommonProps } from '../../typings';\n\nimport type stylesDesktop from './desktop/index.module.css';\nimport type stylesMobile from './mobile/index.module.css';\n\ntype OptionPrivateProps = {\n /**\n * Мобильная версия option.\n */\n mobile: boolean;\n /**\n * Стили\n */\n styles: typeof stylesDesktop | typeof stylesMobile;\n};\n\nexport const OptionBase: FC<OptionCommonProps & OptionPrivateProps> = ({\n size = 48,\n className,\n option,\n children,\n selected,\n highlighted,\n disabled,\n multiple,\n mobile,\n Checkmark,\n innerProps,\n dataTestId,\n styles,\n}) => {\n const content = children || option.content || option.key;\n const { showCheckMark = true } = option;\n\n return (\n <div\n {...innerProps}\n className={cn(styles.option, styles[`size-${size}`], className, {\n [styles.highlighted]: !mobile && highlighted,\n [styles.selected]: selected,\n [styles.disabled]: disabled,\n })}\n data-test-id={dataTestId}\n >\n {Checkmark && showCheckMark && (\n <Checkmark\n disabled={disabled}\n selected={selected}\n multiple={multiple}\n position='before'\n />\n )}\n\n <div\n className={cn(styles.content, {\n [styles.textContent]: !isValidElement(content),\n })}\n >\n {content}\n </div>\n\n {/** Workaround чтобы для клика показывать отметку справа и всегда в виде иконки */}\n {Checkmark && showCheckMark && (\n <Checkmark\n disabled={disabled}\n selected={selected}\n multiple={multiple}\n position='after'\n />\n )}\n </div>\n );\n};\n"],"names":[],"mappings":";;;AAmBO,MAAM,UAAU,GAA+C,CAAC,EACnE,IAAI,GAAG,EAAE,EACT,SAAS,EACT,MAAM,EACN,QAAQ,EACR,QAAQ,EACR,WAAW,EACX,QAAQ,EACR,QAAQ,EACR,MAAM,EACN,SAAS,EACT,UAAU,EACV,UAAU,EACV,MAAM,GACT,KAAI;IACD,MAAM,OAAO,GAAG,QAAQ,IAAI,MAAM,CAAC,OAAO,IAAI,MAAM,CAAC,GAAG;AACxD,IAAA,MAAM,EAAE,aAAa,GAAG,IAAI,EAAE,GAAG,MAAM;IAEvC,QACI,gCACQ,UAAU,EACd,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAQ,KAAA,EAAA,IAAI,EAAE,CAAC,EAAE,SAAS,EAAE;YAC5D,CAAC,MAAM,CAAC,WAAW,GAAG,CAAC,MAAM,IAAI,WAAW;AAC5C,YAAA,CAAC,MAAM,CAAC,QAAQ,GAAG,QAAQ;AAC3B,YAAA,CAAC,MAAM,CAAC,QAAQ,GAAG,QAAQ;AAC9B,SAAA,CAAC,kBACY,UAAU,EAAA;QAEvB,SAAS,IAAI,aAAa,KACvB,oBAAC,SAAS,EAAA,EACN,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAC,QAAQ,EAAA,CACnB,CACL;AAED,QAAA,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EACI,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,OAAO,EAAE;gBAC1B,CAAC,MAAM,CAAC,WAAW,GAAG,CAAC,cAAc,CAAC,OAAO,CAAC;aACjD,CAAC,EAAA,EAED,OAAO,CACN;QAGL,SAAS,IAAI,aAAa,KACvB,KAAA,CAAA,aAAA,CAAC,SAAS,EAAA,EACN,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAC,OAAO,EAClB,CAAA,CACL,CACC;AAEd;;;;"}
1
+ {"version":3,"file":"Component.js","sources":["../../../src/components/option/Component.tsx"],"sourcesContent":["import React, { type FC, isValidElement } from 'react';\nimport cn from 'classnames';\n\nimport { type OptionCommonProps } from '../../typings';\n\nimport type stylesDesktop from './desktop/index.module.css';\nimport type stylesMobile from './mobile/index.module.css';\n\ntype OptionPrivateProps = {\n /**\n * Мобильная версия option.\n */\n mobile: boolean;\n /**\n * Стили\n */\n styles: typeof stylesDesktop | typeof stylesMobile;\n};\n\nexport const OptionBase: FC<OptionCommonProps & OptionPrivateProps> = ({\n size = 48,\n className,\n option,\n children,\n selected,\n highlighted,\n disabled,\n multiple,\n mobile,\n Checkmark,\n checkmarkPosition = multiple ? 'before' : 'after',\n innerProps,\n dataTestId,\n styles,\n}) => {\n const content = children || option.content || option.key;\n const { showCheckMark = true } = option;\n\n const renderCheckmark = (position: 'before' | 'after') =>\n Checkmark &&\n showCheckMark && (\n <Checkmark\n disabled={disabled}\n selected={selected}\n multiple={multiple}\n position={position}\n />\n );\n\n return (\n <div\n {...innerProps}\n className={cn(styles.option, styles[`size-${size}`], className, {\n [styles.highlighted]: !mobile && highlighted,\n [styles.selected]: selected,\n [styles.disabled]: disabled,\n })}\n data-test-id={dataTestId}\n >\n {checkmarkPosition === 'before' && renderCheckmark('before')}\n\n <div\n className={cn(styles.content, {\n [styles.textContent]: !isValidElement(content),\n })}\n >\n {content}\n </div>\n\n {checkmarkPosition === 'after' && renderCheckmark('after')}\n </div>\n );\n};\n"],"names":[],"mappings":";;;MAmBa,UAAU,GAA+C,CAAC,EACnE,IAAI,GAAG,EAAE,EACT,SAAS,EACT,MAAM,EACN,QAAQ,EACR,QAAQ,EACR,WAAW,EACX,QAAQ,EACR,QAAQ,EACR,MAAM,EACN,SAAS,EACT,iBAAiB,GAAG,QAAQ,GAAG,QAAQ,GAAG,OAAO,EACjD,UAAU,EACV,UAAU,EACV,MAAM,GACT,KAAI;IACD,MAAM,OAAO,GAAG,QAAQ,IAAI,MAAM,CAAC,OAAO,IAAI,MAAM,CAAC,GAAG;AACxD,IAAA,MAAM,EAAE,aAAa,GAAG,IAAI,EAAE,GAAG,MAAM;AAEvC,IAAA,MAAM,eAAe,GAAG,CAAC,QAA4B,KACjD,SAAS;QACT,aAAa,KACT,KAAC,CAAA,aAAA,CAAA,SAAS,IACN,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EACpB,CAAA,CACL;IAEL,QACI,gCACQ,UAAU,EACd,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAQ,KAAA,EAAA,IAAI,EAAE,CAAC,EAAE,SAAS,EAAE;YAC5D,CAAC,MAAM,CAAC,WAAW,GAAG,CAAC,MAAM,IAAI,WAAW;AAC5C,YAAA,CAAC,MAAM,CAAC,QAAQ,GAAG,QAAQ;AAC3B,YAAA,CAAC,MAAM,CAAC,QAAQ,GAAG,QAAQ;AAC9B,SAAA,CAAC,kBACY,UAAU,EAAA;AAEvB,QAAA,iBAAiB,KAAK,QAAQ,IAAI,eAAe,CAAC,QAAQ,CAAC;AAE5D,QAAA,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EACI,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,OAAO,EAAE;gBAC1B,CAAC,MAAM,CAAC,WAAW,GAAG,CAAC,cAAc,CAAC,OAAO,CAAC;aACjD,CAAC,EAAA,EAED,OAAO,CACN;QAEL,iBAAiB,KAAK,OAAO,IAAI,eAAe,CAAC,OAAO,CAAC,CACxD;AAEd;;;;"}
@@ -6,9 +6,7 @@ import { BaseSelect } from '../components/base-select/Component.js';
6
6
  import { Field } from '../components/field/Component.js';
7
7
  import { Optgroup } from '../components/optgroup/Component.js';
8
8
  import 'classnames';
9
- import '@alfalab/core-components-badge/moderncssm';
10
9
  import '@alfalab/core-components-checkbox/moderncssm';
11
- import '@alfalab/icons-glyph/CheckmarkCircleMIcon';
12
10
  import '@alfalab/icons-glyph/CheckmarkMIcon';
13
11
  import '../components/checkmark/index.module.css';
14
12
  import '../components/option/desktop/index.module.css';
@@ -1 +1 @@
1
- {"version":3,"file":"Component.desktop.js","sources":["../../src/desktop/Component.desktop.tsx"],"sourcesContent":["import React, { forwardRef } from 'react';\n\nimport { FormControlDesktop } from '@alfalab/core-components-form-control/desktop';\nimport { Popover } from '@alfalab/core-components-popover';\n\nimport { Arrow as DefaultArrow } from '../components/arrow';\nimport { BaseSelect } from '../components/base-select';\nimport { Field as DefaultField } from '../components/field';\nimport { Optgroup as DefaultOptgroup } from '../components/optgroup';\nimport { Option as DefaultOption } from '../components/option';\nimport { OptionsList as DefaultOptionsList } from '../components/options-list';\nimport { Search as DefaultSearch } from '../components/search';\nimport { type SelectDesktopProps } from '../typings';\n\nexport const SelectDesktop = forwardRef<HTMLDivElement, SelectDesktopProps>(\n (\n {\n Arrow = DefaultArrow,\n Field = DefaultField,\n OptionsList = DefaultOptionsList,\n Optgroup = DefaultOptgroup,\n Option = DefaultOption,\n Search = DefaultSearch,\n fieldProps = {},\n ...restProps\n },\n ref,\n ) => (\n <BaseSelect\n ref={ref}\n view='desktop'\n Option={Option}\n Field={Field}\n fieldProps={{\n FormControlComponent: FormControlDesktop,\n ...(fieldProps as object),\n }}\n Search={Search}\n Optgroup={Optgroup}\n OptionsList={OptionsList}\n Arrow={Arrow}\n Popover={Popover}\n {...restProps}\n />\n ),\n);\n"],"names":["Arrow","DefaultArrow","Field","DefaultField","OptionsList","DefaultOptionsList","Optgroup","DefaultOptgroup","DefaultOption","Search","DefaultSearch"],"mappings":";;;;;;;;;;;;;;;;;;;;AAcO,MAAM,aAAa,GAAG,UAAU,CACnC,CACI,SACIA,OAAK,GAAGC,KAAY,SACpBC,OAAK,GAAGC,KAAY,eACpBC,aAAW,GAAGC,WAAkB,YAChCC,UAAQ,GAAGC,QAAe,EAC1B,MAAM,GAAGC,gBAAa,UACtBC,QAAM,GAAGC,MAAa,EACtB,UAAU,GAAG,EAAE,EACf,GAAG,SAAS,EACf,EACD,GAAG,MAEH,KAAA,CAAA,aAAA,CAAC,UAAU,EACP,EAAA,GAAG,EAAE,GAAG,EACR,IAAI,EAAC,SAAS,EACd,MAAM,EAAE,MAAM,EACd,KAAK,EAAER,OAAK,EACZ,UAAU,EAAE;AACR,QAAA,oBAAoB,EAAE,kBAAkB;AACxC,QAAA,GAAI,UAAqB;KAC5B,EACD,MAAM,EAAEO,QAAM,EACd,QAAQ,EAAEH,UAAQ,EAClB,WAAW,EAAEF,aAAW,EACxB,KAAK,EAAEJ,OAAK,EACZ,OAAO,EAAE,OAAO,KACZ,SAAS,EAAA,CACf,CACL;;;;"}
1
+ {"version":3,"file":"Component.desktop.js","sources":["../../src/desktop/Component.desktop.tsx"],"sourcesContent":["import React, { forwardRef } from 'react';\n\nimport { FormControlDesktop } from '@alfalab/core-components-form-control/desktop';\nimport { Popover } from '@alfalab/core-components-popover';\n\nimport { Arrow as DefaultArrow } from '../components/arrow';\nimport { BaseSelect } from '../components/base-select';\nimport { Field as DefaultField } from '../components/field';\nimport { Optgroup as DefaultOptgroup } from '../components/optgroup';\nimport { Option as DefaultOption } from '../components/option';\nimport { OptionsList as DefaultOptionsList } from '../components/options-list';\nimport { Search as DefaultSearch } from '../components/search';\nimport { type SelectDesktopProps } from '../typings';\n\nexport const SelectDesktop = forwardRef<HTMLDivElement, SelectDesktopProps>(\n (\n {\n Arrow = DefaultArrow,\n Field = DefaultField,\n OptionsList = DefaultOptionsList,\n Optgroup = DefaultOptgroup,\n Option = DefaultOption,\n Search = DefaultSearch,\n fieldProps = {},\n ...restProps\n },\n ref,\n ) => (\n <BaseSelect\n ref={ref}\n view='desktop'\n Option={Option}\n Field={Field}\n fieldProps={{\n FormControlComponent: FormControlDesktop,\n ...(fieldProps as object),\n }}\n Search={Search}\n Optgroup={Optgroup}\n OptionsList={OptionsList}\n Arrow={Arrow}\n Popover={Popover}\n {...restProps}\n />\n ),\n);\n"],"names":["Arrow","DefaultArrow","Field","DefaultField","OptionsList","DefaultOptionsList","Optgroup","DefaultOptgroup","DefaultOption","Search","DefaultSearch"],"mappings":";;;;;;;;;;;;;;;;;;AAcO,MAAM,aAAa,GAAG,UAAU,CACnC,CACI,SACIA,OAAK,GAAGC,KAAY,SACpBC,OAAK,GAAGC,KAAY,eACpBC,aAAW,GAAGC,WAAkB,YAChCC,UAAQ,GAAGC,QAAe,EAC1B,MAAM,GAAGC,gBAAa,UACtBC,QAAM,GAAGC,MAAa,EACtB,UAAU,GAAG,EAAE,EACf,GAAG,SAAS,EACf,EACD,GAAG,MAEH,KAAA,CAAA,aAAA,CAAC,UAAU,EACP,EAAA,GAAG,EAAE,GAAG,EACR,IAAI,EAAC,SAAS,EACd,MAAM,EAAE,MAAM,EACd,KAAK,EAAER,OAAK,EACZ,UAAU,EAAE;AACR,QAAA,oBAAoB,EAAE,kBAAkB;AACxC,QAAA,GAAI,UAAqB;KAC5B,EACD,MAAM,EAAEO,QAAM,EACd,QAAQ,EAAEH,UAAQ,EAClB,WAAW,EAAEF,aAAW,EACxB,KAAK,EAAEJ,OAAK,EACZ,OAAO,EAAE,OAAO,KACZ,SAAS,EAAA,CACf,CACL;;;;"}
@@ -8,9 +8,7 @@ import { Field } from '../components/field/Component.js';
8
8
  import { Footer } from '../components/footer/Component.js';
9
9
  import { Optgroup } from '../components/optgroup/Component.js';
10
10
  import 'classnames';
11
- import '@alfalab/core-components-badge/moderncssm';
12
11
  import '@alfalab/core-components-checkbox/moderncssm';
13
- import '@alfalab/icons-glyph/CheckmarkCircleMIcon';
14
12
  import '@alfalab/icons-glyph/CheckmarkMIcon';
15
13
  import '../components/checkmark/index.module.css';
16
14
  import '../components/option/desktop/index.module.css';
@@ -26,7 +24,7 @@ import { Header } from '../presets/useSelectWithApply/options-list-with-apply/he
26
24
  const VIRTUAL_OPTIONS_LIST_THRESHOLD = 30;
27
25
  const SelectMobile = forwardRef(({ autocomplete = false, multiple = false, allowUnselect = false, disabled = false, closeOnSelect = !multiple, circularNavigation = false, defaultOpen = false, open: openProp, size = 56, optionsSize = 56, fieldProps = {}, optionProps = {}, optionsListProps = {}, Arrow: Arrow$1 = Arrow, Field: Field$1 = Field, Optgroup: Optgroup$1 = Optgroup, Option = OptionResponsive, Search: Search$1 = Search, selected, options, OptionsList: OptionsList$1 = options.length > VIRTUAL_OPTIONS_LIST_THRESHOLD
28
26
  ? VirtualOptionsList
29
- : OptionsList, onChange, showClear = true, showSelectAll, showHeaderWithSelectAll, useWithApplyHook = multiple, showSearch, searchProps, ...restProps }, ref) => {
27
+ : OptionsList, onChange, showClear = true, showSelectAll, showHeaderWithSelectAll, checkmarkPosition = 'before', useWithApplyHook = multiple, showSearch, searchProps, ...restProps }, ref) => {
30
28
  const applyProps = useSelectWithApply({
31
29
  optionsListProps: {
32
30
  ...optionsListProps,
@@ -40,6 +38,7 @@ const SelectMobile = forwardRef(({ autocomplete = false, multiple = false, allow
40
38
  onChange,
41
39
  showClear,
42
40
  showSelectAll,
41
+ checkmarkPosition,
43
42
  });
44
43
  const bottomAddons = (flatOptions) => flatOptions.length > 0 &&
45
44
  useWithApplyHook &&
@@ -1 +1 @@
1
- {"version":3,"file":"Component.mobile.js","sources":["../../src/mobile/Component.mobile.tsx"],"sourcesContent":["import React, { forwardRef } from 'react';\n\nimport { BottomSheet } from '@alfalab/core-components-bottom-sheet';\nimport { FormControlMobile } from '@alfalab/core-components-form-control/mobile';\nimport { ModalMobile } from '@alfalab/core-components-modal/mobile';\n\nimport { Arrow as DefaultArrow } from '../components/arrow';\nimport { BaseSelect } from '../components/base-select';\nimport { Field as DefaultField } from '../components/field';\nimport { Footer } from '../components/footer';\nimport { Optgroup as DefaultOptgroup } from '../components/optgroup';\nimport { Option as DefaultOption } from '../components/option';\nimport { OptionsList as DefaultOptionsList } from '../components/options-list';\nimport { Search as DefaultSearch } from '../components/search';\nimport { VirtualOptionsList as DefaultVirtualOptionsList } from '../components/virtual-options-list';\nimport { useSelectWithApply } from '../presets/useSelectWithApply/hook';\nimport { Header } from '../presets/useSelectWithApply/options-list-with-apply/header/Component';\nimport { type AnyObject, type OptionShape, type SelectMobileProps } from '../typings';\n\nconst VIRTUAL_OPTIONS_LIST_THRESHOLD = 30;\n\nexport const SelectMobile = forwardRef(\n (\n {\n autocomplete = false,\n multiple = false,\n allowUnselect = false,\n disabled = false,\n closeOnSelect = !multiple,\n circularNavigation = false,\n defaultOpen = false,\n open: openProp,\n size = 56,\n optionsSize = 56,\n fieldProps = {},\n optionProps = {},\n optionsListProps = {},\n Arrow = DefaultArrow,\n Field = DefaultField,\n Optgroup = DefaultOptgroup,\n Option = DefaultOption,\n Search = DefaultSearch,\n selected,\n options,\n OptionsList = options.length > VIRTUAL_OPTIONS_LIST_THRESHOLD\n ? DefaultVirtualOptionsList\n : DefaultOptionsList,\n onChange,\n showClear = true,\n showSelectAll,\n showHeaderWithSelectAll,\n useWithApplyHook = multiple,\n showSearch,\n searchProps,\n ...restProps\n }: SelectMobileProps,\n ref,\n ) => {\n const applyProps = useSelectWithApply({\n optionsListProps: {\n ...(optionsListProps as AnyObject),\n Footer,\n },\n OptionsList,\n showSearch,\n searchProps,\n selected,\n options,\n onChange,\n showClear,\n showSelectAll,\n });\n\n const bottomAddons = (flatOptions: OptionShape[]) =>\n flatOptions.length > 0 &&\n useWithApplyHook &&\n showHeaderWithSelectAll && (\n <Header {...applyProps.optionsListProps.headerProps} mobile={true} />\n );\n\n return (\n <BaseSelect\n ref={ref}\n view='mobile'\n autocomplete={autocomplete}\n multiple={multiple}\n allowUnselect={allowUnselect}\n disabled={disabled}\n closeOnSelect={closeOnSelect}\n circularNavigation={circularNavigation}\n defaultOpen={defaultOpen}\n open={openProp}\n size={size}\n optionsSize={optionsSize}\n fieldProps={{\n FormControlComponent: FormControlMobile,\n ...(fieldProps as object),\n }}\n optionProps={optionProps}\n Arrow={Arrow}\n Field={Field}\n Optgroup={Optgroup}\n Option={Option}\n Search={Search}\n options={options}\n selected={selected}\n onChange={onChange}\n OptionsList={OptionsList}\n showSearch={showSearch}\n searchProps={searchProps}\n BottomSheet={BottomSheet}\n ModalMobile={ModalMobile}\n optionsListProps={optionsListProps}\n {...restProps}\n {...(restProps.isBottomSheet === false\n ? {\n modalHeaderProps: {\n bottomAddons,\n ...restProps.modalHeaderProps,\n },\n }\n : {\n bottomSheetProps: {\n bottomAddons,\n showSwipeMarker: false,\n ...restProps.bottomSheetProps,\n },\n })}\n {...(useWithApplyHook && applyProps)}\n />\n );\n },\n);\n"],"names":["Arrow","DefaultArrow","Field","DefaultField","Optgroup","DefaultOptgroup","DefaultOption","Search","DefaultSearch","OptionsList","DefaultVirtualOptionsList","DefaultOptionsList"],"mappings":"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"}
1
+ {"version":3,"file":"Component.mobile.js","sources":["../../src/mobile/Component.mobile.tsx"],"sourcesContent":["import React, { forwardRef } from 'react';\n\nimport { BottomSheet } from '@alfalab/core-components-bottom-sheet';\nimport { FormControlMobile } from '@alfalab/core-components-form-control/mobile';\nimport { ModalMobile } from '@alfalab/core-components-modal/mobile';\n\nimport { Arrow as DefaultArrow } from '../components/arrow';\nimport { BaseSelect } from '../components/base-select';\nimport { Field as DefaultField } from '../components/field';\nimport { Footer } from '../components/footer';\nimport { Optgroup as DefaultOptgroup } from '../components/optgroup';\nimport { Option as DefaultOption } from '../components/option';\nimport { OptionsList as DefaultOptionsList } from '../components/options-list';\nimport { Search as DefaultSearch } from '../components/search';\nimport { VirtualOptionsList as DefaultVirtualOptionsList } from '../components/virtual-options-list';\nimport { useSelectWithApply } from '../presets/useSelectWithApply/hook';\nimport { Header } from '../presets/useSelectWithApply/options-list-with-apply/header/Component';\nimport { type AnyObject, type OptionShape, type SelectMobileProps } from '../typings';\n\nconst VIRTUAL_OPTIONS_LIST_THRESHOLD = 30;\n\nexport const SelectMobile = forwardRef(\n (\n {\n autocomplete = false,\n multiple = false,\n allowUnselect = false,\n disabled = false,\n closeOnSelect = !multiple,\n circularNavigation = false,\n defaultOpen = false,\n open: openProp,\n size = 56,\n optionsSize = 56,\n fieldProps = {},\n optionProps = {},\n optionsListProps = {},\n Arrow = DefaultArrow,\n Field = DefaultField,\n Optgroup = DefaultOptgroup,\n Option = DefaultOption,\n Search = DefaultSearch,\n selected,\n options,\n OptionsList = options.length > VIRTUAL_OPTIONS_LIST_THRESHOLD\n ? DefaultVirtualOptionsList\n : DefaultOptionsList,\n onChange,\n showClear = true,\n showSelectAll,\n showHeaderWithSelectAll,\n checkmarkPosition = 'before',\n useWithApplyHook = multiple,\n showSearch,\n searchProps,\n ...restProps\n }: SelectMobileProps,\n ref,\n ) => {\n const applyProps = useSelectWithApply({\n optionsListProps: {\n ...(optionsListProps as AnyObject),\n Footer,\n },\n OptionsList,\n showSearch,\n searchProps,\n selected,\n options,\n onChange,\n showClear,\n showSelectAll,\n checkmarkPosition,\n });\n\n const bottomAddons = (flatOptions: OptionShape[]) =>\n flatOptions.length > 0 &&\n useWithApplyHook &&\n showHeaderWithSelectAll && (\n <Header {...applyProps.optionsListProps.headerProps} mobile={true} />\n );\n\n return (\n <BaseSelect\n ref={ref}\n view='mobile'\n autocomplete={autocomplete}\n multiple={multiple}\n allowUnselect={allowUnselect}\n disabled={disabled}\n closeOnSelect={closeOnSelect}\n circularNavigation={circularNavigation}\n defaultOpen={defaultOpen}\n open={openProp}\n size={size}\n optionsSize={optionsSize}\n fieldProps={{\n FormControlComponent: FormControlMobile,\n ...(fieldProps as object),\n }}\n optionProps={optionProps}\n Arrow={Arrow}\n Field={Field}\n Optgroup={Optgroup}\n Option={Option}\n Search={Search}\n options={options}\n selected={selected}\n onChange={onChange}\n OptionsList={OptionsList}\n showSearch={showSearch}\n searchProps={searchProps}\n BottomSheet={BottomSheet}\n ModalMobile={ModalMobile}\n optionsListProps={optionsListProps}\n {...restProps}\n {...(restProps.isBottomSheet === false\n ? {\n modalHeaderProps: {\n bottomAddons,\n ...restProps.modalHeaderProps,\n },\n }\n : {\n bottomSheetProps: {\n bottomAddons,\n showSwipeMarker: false,\n ...restProps.bottomSheetProps,\n },\n })}\n {...(useWithApplyHook && applyProps)}\n />\n );\n },\n);\n"],"names":["Arrow","DefaultArrow","Field","DefaultField","Optgroup","DefaultOptgroup","DefaultOption","Search","DefaultSearch","OptionsList","DefaultVirtualOptionsList","DefaultOptionsList"],"mappings":"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"}
@@ -1,9 +1,7 @@
1
1
  import React, { useReducer, useRef, useCallback, useEffect, useMemo } from 'react';
2
2
  import { Skeleton } from '@alfalab/core-components-skeleton/moderncssm';
3
3
  import 'classnames';
4
- import '@alfalab/core-components-badge/moderncssm';
5
4
  import '@alfalab/core-components-checkbox/moderncssm';
6
- import '@alfalab/icons-glyph/CheckmarkCircleMIcon';
7
5
  import '@alfalab/icons-glyph/CheckmarkMIcon';
8
6
  import '../../components/checkmark/index.module.css';
9
7
  import '../../components/option/desktop/index.module.css';
@@ -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":["DefaultOption"],"mappings":"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"}
1
+ {"version":3,"file":"hook.js","sources":["../../../src/presets/useLazyLoading/hook.tsx"],"sourcesContent":["import React, { type Reducer, useCallback, useEffect, useMemo, useReducer, useRef } from 'react';\n\nimport { type InputProps } from '@alfalab/core-components-input';\nimport { Skeleton } from '@alfalab/core-components-skeleton';\n\nimport { Option as DefaultOption } from '../../components/option';\nimport { type OptionProps, type OptionShape } from '../../typings';\n\nimport 'intersection-observer';\n\nconst DEBOUNCE_TIMEOUT = 300;\n\ntype OptionsFetcherResponse = {\n options: OptionShape[];\n hasMore: boolean;\n};\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\ntype useLazyLoadingProps = {\n /** Количество элементов на \"странице\" */\n limit?: number;\n\n /** Начальный номер \"страницы\" */\n initialOffset?: number;\n\n /** Скелетон загружаемых элементов */\n skeleton?: React.ReactNode;\n\n /** Компонент пункта меню */\n Option?: React.FC<OptionProps>;\n\n /**\n * Функция-загрузчик опций.\n * @param offset - текущая страница\n * @param limit - количество элементов на странице\n * @param queryString - строчные данные, пробрасываемые для поиска из кастомного инпута, расположенного в заголовке OptionsList\n * @returns Promise<{\n * options - список опций следующей \"страницы\". Они аппендятся к предыдущим\n * hasMore - указывает, есть ли еще незагруженные элементы (в случае false перестает загружать \"следующую страницу\")\n * }>\n */\n optionsFetcher(\n offset: number,\n limit: number,\n queryString?: string,\n ): Promise<OptionsFetcherResponse>;\n};\n\nconst actions = {\n fetchOptionsStart() {\n return { type: 'FETCH_OPTIONS_START' } as const;\n },\n fetchOptionsBreak() {\n return { type: 'FETCH_OPTIONS_BREAK' } as const;\n },\n fetchOptionsSuccess(payload: { options: OptionShape[]; hasMore: boolean }) {\n return { type: 'FETCH_OPTIONS_SUCCESS', payload } as const;\n },\n setIsOpened(opened: boolean) {\n return { type: 'SET_IS_OPENED', payload: opened } as const;\n },\n setQueryString(qs: string) {\n return { type: 'SET_QUERY_STRING', payload: qs } as const;\n },\n reset() {\n return { type: 'RESET' } as const;\n },\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype Actions = typeof actions extends { [key: string]: (...args: any) => infer U } ? U : never;\n\nconst skeletonStyle: React.CSSProperties = {\n position: 'absolute',\n top: '50%',\n transform: 'translateY(-50%)',\n height: '16px',\n width: '50%',\n};\n\nexport function useLazyLoading({\n limit = 10,\n initialOffset = 0,\n optionsFetcher,\n skeleton = <Skeleton style={skeletonStyle} visible={true} />,\n Option = DefaultOption,\n}: useLazyLoadingProps) {\n const initialOptions: OptionShape[] = [];\n const initialLoading = false;\n\n const lazyLoadingInitialState = {\n opened: false,\n offset: initialOffset,\n options: initialOptions,\n loading: initialLoading,\n allOptionsLoaded: false,\n queryString: '',\n };\n\n const lazyLoadingReducer: Reducer<typeof lazyLoadingInitialState, Actions> = (\n state,\n action,\n ) => {\n switch (action.type) {\n case 'FETCH_OPTIONS_START': {\n return {\n ...state,\n loading: true,\n };\n }\n case 'FETCH_OPTIONS_BREAK': {\n return {\n ...state,\n loading: false,\n };\n }\n case 'FETCH_OPTIONS_SUCCESS': {\n return {\n ...state,\n options: [...state.options, ...action.payload.options],\n offset: state.offset + (action.payload.options.length ? 1 : 0),\n allOptionsLoaded: !action.payload.hasMore,\n loading: false,\n };\n }\n case 'SET_IS_OPENED': {\n return {\n ...state,\n opened: action.payload,\n };\n }\n case 'SET_QUERY_STRING': {\n return {\n // Изменение queryString подразумевает сброс текущих опций.\n ...lazyLoadingInitialState,\n opened: state.opened,\n loading: true,\n queryString: action.payload,\n };\n }\n case 'RESET': {\n return {\n ...lazyLoadingInitialState,\n };\n }\n default: {\n return state;\n }\n }\n };\n\n const [{ opened, offset, options, loading, allOptionsLoaded, queryString }, dispatch] =\n useReducer(lazyLoadingReducer, lazyLoadingInitialState);\n\n const abortFetchingOptionsRef = useRef<() => void>();\n\n const fetchNextOffsetOptions = useCallback(() => {\n dispatch(actions.fetchOptionsStart());\n\n new Promise<OptionsFetcherResponse>((resolve, reject) => {\n // eslint-disable-next-line no-unused-expressions\n abortFetchingOptionsRef.current?.();\n abortFetchingOptionsRef.current = reject;\n optionsFetcher(offset, limit, queryString).then((res) => {\n resolve(res);\n });\n })\n .then((res) => {\n dispatch(actions.fetchOptionsSuccess(res));\n abortFetchingOptionsRef.current = undefined;\n })\n .catch(\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n () => {},\n );\n }, [optionsFetcher, offset, limit, queryString]);\n\n const listRef = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n let observer: IntersectionObserver;\n\n if (opened && !loading && !allOptionsLoaded) {\n observer = new IntersectionObserver(\n ([entry]) => {\n if (entry.isIntersecting) {\n if (observer) {\n observer.disconnect();\n }\n fetchNextOffsetOptions();\n }\n },\n {\n root: listRef.current,\n },\n );\n\n /*\n * Обсервим пересечение последней опции с контейнером.\n * Таким образом, загрузка следующей \"страницы\" начнется когда юзер доскроллит список\n * до верхнего края последней опции, что обеспечивает плавность\n */\n const optionList = listRef.current?.querySelectorAll('[role=\"option\"]');\n const lastOption = optionList?.[optionList.length - 1];\n\n if (lastOption) {\n observer.observe(lastOption);\n }\n }\n\n return () => {\n if (observer) {\n observer.disconnect();\n }\n };\n }, [offset, fetchNextOffsetOptions, opened, allOptionsLoaded, initialOffset, loading]);\n\n const onOpen = useCallback(\n (payload: { open?: boolean }) => {\n if (payload.open) {\n if (options.length === initialOptions.length) {\n fetchNextOffsetOptions();\n }\n } else {\n // eslint-disable-next-line no-unused-expressions\n abortFetchingOptionsRef.current?.();\n dispatch(actions.fetchOptionsBreak());\n }\n\n dispatch(actions.setIsOpened(payload.open ?? false));\n },\n [initialOptions.length, fetchNextOffsetOptions, options.length],\n );\n\n const fetchNextOptionsRef = useRef<() => void>();\n const fetchNextOptionsTimerRef = useRef<ReturnType<typeof setTimeout>>();\n\n useEffect(() => {\n fetchNextOptionsRef.current = fetchNextOffsetOptions;\n }, [fetchNextOffsetOptions]);\n\n const onQueryStringChange = useCallback<Exclude<InputProps['onChange'], undefined>>(\n (_, payload) => {\n dispatch(actions.setQueryString(payload.value));\n /* eslint-disable no-unused-expressions */\n\n /*\n * Если во время загрузки опций юзер ввел новый текст в инпут,\n * нужно прервать текущую загрузку, чтобы неактуальные опции не попали в выдачу\n */\n abortFetchingOptionsRef.current?.();\n\n listRef.current?.scrollTo({ top: 0 });\n\n /* Дебаунсим ввод текста, чтобы не отправлять запрос к новым опциям на каждый чих */\n if (fetchNextOptionsTimerRef.current) {\n clearTimeout(fetchNextOptionsTimerRef.current);\n }\n fetchNextOptionsTimerRef.current = setTimeout(() => {\n /*\n * После дебаунса необходимо вызвать функцию-загрузчик,\n * содержащую актуальные на данный момент данные оффсета и queryString.\n * Поэтому мы не можем обратиться напрямую к функции fetchNextOptions,\n * так как она будет замкнута на старые значения, актуальные на момент вызова хэндлера,\n * так что берем ее из обновляемого рефа\n */\n fetchNextOptionsRef.current?.();\n }, DEBOUNCE_TIMEOUT);\n /* eslint-enable */\n },\n [],\n );\n\n const renderOption = (props: OptionProps) => (\n <Option {...props} highlighted={loading ? false : props.highlighted} />\n );\n\n const skeletonOptions: OptionShape[] = useMemo(\n () =>\n Array(loading ? limit : 0)\n .fill(0)\n .map((_, key) => ({\n key: `loading-${key}`,\n disabled: true,\n content: skeleton,\n })),\n [loading, limit, skeleton],\n );\n\n const reset = useCallback(() => {\n dispatch(actions.reset());\n }, []);\n\n return {\n optionsProps: {\n Option: renderOption,\n options: [...options, ...skeletonOptions],\n optionsListProps: {\n ref: listRef,\n inputProps: {\n onChange: onQueryStringChange,\n value: queryString,\n },\n },\n onOpen,\n },\n reset,\n };\n}\n"],"names":["DefaultOption"],"mappings":"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"}
@@ -55,8 +55,13 @@ export declare type UseSelectWithApplyProps = {
55
55
  * @default 'reset-footer'
56
56
  */
57
57
  resetName?: string;
58
+ /**
59
+ * Позиция чекбокса "Выбрать все" в Header
60
+ * @default 'before'
61
+ */
62
+ checkmarkPosition?: 'before' | 'after';
58
63
  };
59
- export declare function useSelectWithApply({ options, selected, onChange, onSelectAllClick, OptionsList, optionsListProps, showClear, showSelectAll, showHeaderWithSelectAll, showSearch, searchProps, applyName, resetName, }: UseSelectWithApplyProps): {
64
+ export declare function useSelectWithApply({ options, selected, onChange, onSelectAllClick, OptionsList, optionsListProps, showClear, showSelectAll, showHeaderWithSelectAll, checkmarkPosition, showSearch, searchProps, applyName, resetName, }: UseSelectWithApplyProps): {
60
65
  OptionsList: import("react").ForwardRefExoticComponent<Pick<import("../../typings").SelectProps, "client"> & {
61
66
  className?: string | undefined;
62
67
  optionGroupClassName?: string | undefined;
@@ -237,6 +242,7 @@ export declare function useSelectWithApply({ options, selected, onChange, onSele
237
242
  showClear: boolean;
238
243
  showSelectAll: boolean;
239
244
  showHeaderWithSelectAll: boolean;
245
+ checkmarkPosition: "before" | "after";
240
246
  showSearch: boolean;
241
247
  searchProps: {
242
248
  componentProps?: import("../../typings").SearchProps | undefined;
@@ -5,7 +5,7 @@ import { defaultAccessor, defaultFilterFn, defaultGroupAccessor, processOptions,
5
5
  import { OptionsListWithApply } from './options-list-with-apply/Component.js';
6
6
 
7
7
  const selectAllOption = { key: SELECT_ALL_KEY, content: 'Выбрать все' };
8
- function useSelectWithApply({ options, selected, onChange = () => null, onSelectAllClick = () => null, OptionsList, optionsListProps = {}, showClear = true, showSelectAll = false, showHeaderWithSelectAll = false, showSearch = false, searchProps = {}, applyName = 'apply-footer', resetName = 'reset-footer', }) {
8
+ function useSelectWithApply({ options, selected, onChange = () => null, onSelectAllClick = () => null, OptionsList, optionsListProps = {}, showClear = true, showSelectAll = false, showHeaderWithSelectAll = false, checkmarkPosition = 'before', showSearch = false, searchProps = {}, applyName = 'apply-footer', resetName = 'reset-footer', }) {
9
9
  const [searchState, setSearchState] = useState('');
10
10
  const [search, setSearch] = typeof searchProps?.value === 'string'
11
11
  ? [searchProps.value, searchProps.onChange]
@@ -99,6 +99,7 @@ function useSelectWithApply({ options, selected, onChange = () => null, onSelect
99
99
  checked: selectedDraft.length === flatOptions.length ||
100
100
  flatOptions.every(({ key }) => selectedKeys.includes(key)),
101
101
  onChange: handleToggleAll,
102
+ checkmarkPosition,
102
103
  },
103
104
  },
104
105
  multiple: true,
@@ -123,6 +124,7 @@ function useSelectWithApply({ options, selected, onChange = () => null, onSelect
123
124
  showClear,
124
125
  showSelectAll,
125
126
  showHeaderWithSelectAll,
127
+ checkmarkPosition,
126
128
  showSearch,
127
129
  searchProps,
128
130
  applyName,