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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (314) 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 +19 -23
  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 +22 -18
  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 +8 -7
  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 +24 -22
  43. package/components/option/desktop/index.module.css.js +1 -1
  44. package/components/option/mobile/index.css +21 -19
  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 +5 -9
  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/field/index.module.css +9 -5
  70. package/cssm/components/optgroup/index.module.css +4 -3
  71. package/cssm/components/option/Component.js +8 -4
  72. package/cssm/components/option/Component.js.map +1 -1
  73. package/cssm/components/option/desktop/index.module.css +5 -3
  74. package/cssm/components/option/mobile/index.module.css +5 -3
  75. package/cssm/desktop/Component.desktop.js +0 -2
  76. package/cssm/desktop/Component.desktop.js.map +1 -1
  77. package/cssm/mobile/Component.mobile.js +2 -3
  78. package/cssm/mobile/Component.mobile.js.map +1 -1
  79. package/cssm/presets/useLazyLoading/hook.js +0 -2
  80. package/cssm/presets/useLazyLoading/hook.js.map +1 -1
  81. package/cssm/presets/useSelectWithApply/hook.d.ts +7 -1
  82. package/cssm/presets/useSelectWithApply/hook.js +9 -8
  83. package/cssm/presets/useSelectWithApply/hook.js.map +1 -1
  84. package/cssm/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +1 -0
  85. package/cssm/presets/useSelectWithApply/options-list-with-apply/header/Component.js +3 -3
  86. package/cssm/presets/useSelectWithApply/options-list-with-apply/header/Component.js.map +1 -1
  87. package/cssm/presets/useSelectWithApply/options-list-with-apply/header/index.module.css +5 -1
  88. package/cssm/presets/useSelectWithLoading/hook.js +0 -2
  89. package/cssm/presets/useSelectWithLoading/hook.js.map +1 -1
  90. package/cssm/typings.d.ts +9 -0
  91. package/desktop/Component.desktop.js +0 -2
  92. package/desktop/Component.desktop.js.map +1 -1
  93. package/esm/components/arrow/index.css +4 -4
  94. package/esm/components/arrow/index.module.css.js +1 -1
  95. package/esm/components/base-checkmark/Component.d.ts +2 -2
  96. package/esm/components/base-checkmark/Component.js +14 -7
  97. package/esm/components/base-checkmark/Component.js.map +1 -1
  98. package/esm/components/base-checkmark/index.css +32 -5
  99. package/esm/components/base-checkmark/index.module.css.js +1 -1
  100. package/esm/components/base-checkmark/index.module.css.js.map +1 -1
  101. package/esm/components/base-option/Component.js +4 -16
  102. package/esm/components/base-option/Component.js.map +1 -1
  103. package/esm/components/base-option/index.css +19 -23
  104. package/esm/components/base-option/index.module.css.js +1 -1
  105. package/esm/components/base-option/index.module.css.js.map +1 -1
  106. package/esm/components/base-select/index.css +11 -11
  107. package/esm/components/base-select/index.module.css.js +1 -1
  108. package/esm/components/base-select/mobile.css +11 -11
  109. package/esm/components/base-select/mobile.module.css.js +1 -1
  110. package/esm/components/checkmark/Component.d.ts +1 -1
  111. package/esm/components/checkmark/Component.js +3 -4
  112. package/esm/components/checkmark/Component.js.map +1 -1
  113. package/esm/components/checkmark/index.css +23 -31
  114. package/esm/components/checkmark/index.module.css.js +1 -1
  115. package/esm/components/checkmark/index.module.css.js.map +1 -1
  116. package/esm/components/checkmark-mobile/Component.d.ts +1 -1
  117. package/esm/components/checkmark-mobile/Component.js +2 -2
  118. package/esm/components/checkmark-mobile/Component.js.map +1 -1
  119. package/esm/components/checkmark-mobile/index.css +14 -7
  120. package/esm/components/checkmark-mobile/index.module.css.js +1 -1
  121. package/esm/components/checkmark-mobile/index.module.css.js.map +1 -1
  122. package/esm/components/clear-button/index.css +4 -4
  123. package/esm/components/clear-button/index.module.css.js +1 -1
  124. package/esm/components/field/Component.js +8 -25
  125. package/esm/components/field/Component.js.map +1 -1
  126. package/esm/components/field/index.css +22 -18
  127. package/esm/components/field/index.module.css.js +1 -1
  128. package/esm/components/footer/index.css +4 -4
  129. package/esm/components/footer/index.module.css.js +1 -1
  130. package/esm/components/optgroup/index.css +8 -7
  131. package/esm/components/optgroup/index.module.css.js +1 -1
  132. package/esm/components/option/Component.js +8 -4
  133. package/esm/components/option/Component.js.map +1 -1
  134. package/esm/components/option/desktop/index.css +24 -22
  135. package/esm/components/option/desktop/index.module.css.js +1 -1
  136. package/esm/components/option/mobile/index.css +21 -19
  137. package/esm/components/option/mobile/index.module.css.js +1 -1
  138. package/esm/components/options-list/index.css +13 -13
  139. package/esm/components/options-list/index.module.css.js +1 -1
  140. package/esm/components/search/index.css +1 -1
  141. package/esm/components/search/index.module.css.js +1 -1
  142. package/esm/components/virtual-options-list/index.css +13 -13
  143. package/esm/components/virtual-options-list/index.module.css.js +1 -1
  144. package/esm/desktop/Component.desktop.js +0 -2
  145. package/esm/desktop/Component.desktop.js.map +1 -1
  146. package/esm/mobile/Component.mobile.js +2 -3
  147. package/esm/mobile/Component.mobile.js.map +1 -1
  148. package/esm/presets/useLazyLoading/hook.js +0 -2
  149. package/esm/presets/useLazyLoading/hook.js.map +1 -1
  150. package/esm/presets/useSelectWithApply/hook.d.ts +7 -1
  151. package/esm/presets/useSelectWithApply/hook.js +9 -8
  152. package/esm/presets/useSelectWithApply/hook.js.map +1 -1
  153. package/esm/presets/useSelectWithApply/options-list-with-apply/footer/index.css +3 -3
  154. package/esm/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js +1 -1
  155. package/esm/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +1 -0
  156. package/esm/presets/useSelectWithApply/options-list-with-apply/header/Component.js +3 -3
  157. package/esm/presets/useSelectWithApply/options-list-with-apply/header/Component.js.map +1 -1
  158. package/esm/presets/useSelectWithApply/options-list-with-apply/header/index.css +8 -4
  159. package/esm/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js +1 -1
  160. package/esm/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js.map +1 -1
  161. package/esm/presets/useSelectWithLoading/hook.js +0 -2
  162. package/esm/presets/useSelectWithLoading/hook.js.map +1 -1
  163. package/esm/presets/useSelectWithLoading/index.css +1 -1
  164. package/esm/presets/useSelectWithLoading/index.module.css.js +1 -1
  165. package/esm/typings.d.ts +9 -0
  166. package/mobile/Component.mobile.js +2 -3
  167. package/mobile/Component.mobile.js.map +1 -1
  168. package/modern/components/arrow/index.css +4 -4
  169. package/modern/components/arrow/index.module.css.js +1 -1
  170. package/modern/components/base-checkmark/Component.d.ts +2 -2
  171. package/modern/components/base-checkmark/Component.js +10 -6
  172. package/modern/components/base-checkmark/Component.js.map +1 -1
  173. package/modern/components/base-checkmark/index.css +32 -5
  174. package/modern/components/base-checkmark/index.module.css.js +1 -1
  175. package/modern/components/base-checkmark/index.module.css.js.map +1 -1
  176. package/modern/components/base-option/Component.js +4 -15
  177. package/modern/components/base-option/Component.js.map +1 -1
  178. package/modern/components/base-option/index.css +19 -23
  179. package/modern/components/base-option/index.module.css.js +1 -1
  180. package/modern/components/base-option/index.module.css.js.map +1 -1
  181. package/modern/components/base-select/index.css +11 -11
  182. package/modern/components/base-select/index.module.css.js +1 -1
  183. package/modern/components/base-select/mobile.css +11 -11
  184. package/modern/components/base-select/mobile.module.css.js +1 -1
  185. package/modern/components/checkmark/Component.d.ts +1 -1
  186. package/modern/components/checkmark/Component.js +3 -4
  187. package/modern/components/checkmark/Component.js.map +1 -1
  188. package/modern/components/checkmark/index.css +23 -31
  189. package/modern/components/checkmark/index.module.css.js +1 -1
  190. package/modern/components/checkmark/index.module.css.js.map +1 -1
  191. package/modern/components/checkmark-mobile/Component.d.ts +1 -1
  192. package/modern/components/checkmark-mobile/Component.js +1 -1
  193. package/modern/components/checkmark-mobile/Component.js.map +1 -1
  194. package/modern/components/checkmark-mobile/index.css +14 -7
  195. package/modern/components/checkmark-mobile/index.module.css.js +1 -1
  196. package/modern/components/checkmark-mobile/index.module.css.js.map +1 -1
  197. package/modern/components/clear-button/index.css +4 -4
  198. package/modern/components/clear-button/index.module.css.js +1 -1
  199. package/modern/components/field/Component.js +8 -25
  200. package/modern/components/field/Component.js.map +1 -1
  201. package/modern/components/field/index.css +22 -18
  202. package/modern/components/field/index.module.css.js +1 -1
  203. package/modern/components/footer/index.css +4 -4
  204. package/modern/components/footer/index.module.css.js +1 -1
  205. package/modern/components/optgroup/index.css +8 -7
  206. package/modern/components/optgroup/index.module.css.js +1 -1
  207. package/modern/components/option/Component.js +5 -3
  208. package/modern/components/option/Component.js.map +1 -1
  209. package/modern/components/option/desktop/index.css +24 -22
  210. package/modern/components/option/desktop/index.module.css.js +1 -1
  211. package/modern/components/option/mobile/index.css +21 -19
  212. package/modern/components/option/mobile/index.module.css.js +1 -1
  213. package/modern/components/options-list/index.css +13 -13
  214. package/modern/components/options-list/index.module.css.js +1 -1
  215. package/modern/components/search/index.css +1 -1
  216. package/modern/components/search/index.module.css.js +1 -1
  217. package/modern/components/virtual-options-list/index.css +13 -13
  218. package/modern/components/virtual-options-list/index.module.css.js +1 -1
  219. package/modern/desktop/Component.desktop.js +0 -2
  220. package/modern/desktop/Component.desktop.js.map +1 -1
  221. package/modern/mobile/Component.mobile.js +2 -3
  222. package/modern/mobile/Component.mobile.js.map +1 -1
  223. package/modern/presets/useLazyLoading/hook.js +0 -2
  224. package/modern/presets/useLazyLoading/hook.js.map +1 -1
  225. package/modern/presets/useSelectWithApply/hook.d.ts +7 -1
  226. package/modern/presets/useSelectWithApply/hook.js +3 -1
  227. package/modern/presets/useSelectWithApply/hook.js.map +1 -1
  228. package/modern/presets/useSelectWithApply/options-list-with-apply/footer/index.css +3 -3
  229. package/modern/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js +1 -1
  230. package/modern/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +1 -0
  231. package/modern/presets/useSelectWithApply/options-list-with-apply/header/Component.js +2 -2
  232. package/modern/presets/useSelectWithApply/options-list-with-apply/header/Component.js.map +1 -1
  233. package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.css +8 -4
  234. package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js +1 -1
  235. package/modern/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js.map +1 -1
  236. package/modern/presets/useSelectWithLoading/hook.js +0 -2
  237. package/modern/presets/useSelectWithLoading/hook.js.map +1 -1
  238. package/modern/presets/useSelectWithLoading/index.css +1 -1
  239. package/modern/presets/useSelectWithLoading/index.module.css.js +1 -1
  240. package/modern/typings.d.ts +9 -0
  241. package/moderncssm/components/base-checkmark/Component.d.ts +2 -2
  242. package/moderncssm/components/base-checkmark/Component.js +10 -6
  243. package/moderncssm/components/base-checkmark/Component.js.map +1 -1
  244. package/moderncssm/components/base-checkmark/index.module.css +32 -2
  245. package/moderncssm/components/base-option/Component.js +4 -15
  246. package/moderncssm/components/base-option/Component.js.map +1 -1
  247. package/moderncssm/components/base-option/index.module.css +2 -9
  248. package/moderncssm/components/checkmark/Component.d.ts +1 -1
  249. package/moderncssm/components/checkmark/Component.js +3 -4
  250. package/moderncssm/components/checkmark/Component.js.map +1 -1
  251. package/moderncssm/components/checkmark/index.module.css +19 -18
  252. package/moderncssm/components/checkmark-mobile/Component.d.ts +1 -1
  253. package/moderncssm/components/checkmark-mobile/Component.js +1 -1
  254. package/moderncssm/components/checkmark-mobile/Component.js.map +1 -1
  255. package/moderncssm/components/checkmark-mobile/index.module.css +8 -4
  256. package/moderncssm/components/field/Component.js +8 -25
  257. package/moderncssm/components/field/Component.js.map +1 -1
  258. package/moderncssm/components/field/index.module.css +6 -3
  259. package/moderncssm/components/optgroup/index.module.css +1 -1
  260. package/moderncssm/components/option/Component.js +5 -3
  261. package/moderncssm/components/option/Component.js.map +1 -1
  262. package/moderncssm/components/option/desktop/index.module.css +2 -1
  263. package/moderncssm/components/option/mobile/index.module.css +2 -1
  264. package/moderncssm/desktop/Component.desktop.js +0 -2
  265. package/moderncssm/desktop/Component.desktop.js.map +1 -1
  266. package/moderncssm/mobile/Component.mobile.js +2 -3
  267. package/moderncssm/mobile/Component.mobile.js.map +1 -1
  268. package/moderncssm/presets/useLazyLoading/hook.js +0 -2
  269. package/moderncssm/presets/useLazyLoading/hook.js.map +1 -1
  270. package/moderncssm/presets/useSelectWithApply/hook.d.ts +7 -1
  271. package/moderncssm/presets/useSelectWithApply/hook.js +3 -1
  272. package/moderncssm/presets/useSelectWithApply/hook.js.map +1 -1
  273. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +1 -0
  274. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/header/Component.js +2 -2
  275. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/header/Component.js.map +1 -1
  276. package/moderncssm/presets/useSelectWithApply/options-list-with-apply/header/index.module.css +6 -1
  277. package/moderncssm/presets/useSelectWithLoading/hook.js +0 -2
  278. package/moderncssm/presets/useSelectWithLoading/hook.js.map +1 -1
  279. package/moderncssm/typings.d.ts +9 -0
  280. package/package.json +15 -16
  281. package/presets/useLazyLoading/hook.js +0 -2
  282. package/presets/useLazyLoading/hook.js.map +1 -1
  283. package/presets/useSelectWithApply/hook.d.ts +7 -1
  284. package/presets/useSelectWithApply/hook.js +9 -8
  285. package/presets/useSelectWithApply/hook.js.map +1 -1
  286. package/presets/useSelectWithApply/options-list-with-apply/footer/index.css +3 -3
  287. package/presets/useSelectWithApply/options-list-with-apply/footer/index.module.css.js +1 -1
  288. package/presets/useSelectWithApply/options-list-with-apply/header/Component.d.ts +1 -0
  289. package/presets/useSelectWithApply/options-list-with-apply/header/Component.js +3 -3
  290. package/presets/useSelectWithApply/options-list-with-apply/header/Component.js.map +1 -1
  291. package/presets/useSelectWithApply/options-list-with-apply/header/index.css +8 -4
  292. package/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js +1 -1
  293. package/presets/useSelectWithApply/options-list-with-apply/header/index.module.css.js.map +1 -1
  294. package/presets/useSelectWithLoading/hook.js +0 -2
  295. package/presets/useSelectWithLoading/hook.js.map +1 -1
  296. package/presets/useSelectWithLoading/index.css +1 -1
  297. package/presets/useSelectWithLoading/index.module.css.js +1 -1
  298. package/src/components/base-checkmark/Component.tsx +26 -9
  299. package/src/components/base-checkmark/index.module.css +30 -1
  300. package/src/components/base-option/Component.tsx +17 -27
  301. package/src/components/base-option/index.module.css +0 -8
  302. package/src/components/checkmark/Component.tsx +3 -13
  303. package/src/components/checkmark/index.module.css +17 -9
  304. package/src/components/checkmark-mobile/Component.tsx +2 -2
  305. package/src/components/checkmark-mobile/index.module.css +8 -4
  306. package/src/components/field/Component.tsx +12 -26
  307. package/src/components/option/Component.tsx +14 -17
  308. package/src/mobile/Component.mobile.tsx +2 -0
  309. package/src/presets/useSelectWithApply/hook.ts +9 -1
  310. package/src/presets/useSelectWithApply/options-list-with-apply/header/Component.tsx +4 -0
  311. package/src/presets/useSelectWithApply/options-list-with-apply/header/index.module.css +5 -1
  312. package/src/typings.ts +11 -0
  313. package/src/vars.css +3 -3
  314. package/typings.d.ts +9 -0
@@ -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,
@@ -1 +1 @@
1
- {"version":3,"file":"hook.js","sources":["../../../src/presets/useSelectWithApply/hook.ts"],"sourcesContent":["import { useEffect, useMemo, useRef, useState } from 'react';\nimport reactFastCompare from 'react-fast-compare';\n\nimport { SELECT_ALL_KEY } from '../../consts';\nimport { type AnyObject, type BaseSelectProps, type OptionShape } from '../../typings';\nimport {\n defaultAccessor,\n defaultFilterFn,\n defaultGroupAccessor,\n isGroup,\n processOptions,\n} from '../../utils';\n\nimport { OptionsListWithApply } from './options-list-with-apply';\n\nexport type UseSelectWithApplyProps = {\n /**\n * Список выбранных пунктов\n */\n selected: BaseSelectProps['selected'];\n\n /**\n * Список вариантов выбора\n */\n options: BaseSelectProps['options'];\n\n /**\n * Обработчик выбора\n */\n onChange: BaseSelectProps['onChange'];\n\n /**\n * Дополнительный обработчик клика на чекбокс выбрать все\n */\n onSelectAllClick?: (selectedMultiple: OptionShape[]) => void;\n\n /**\n * Компонент выпадающего меню\n */\n OptionsList?: BaseSelectProps['OptionsList'];\n\n /**\n * Пропсы, которые будут прокинуты в компонент списка\n */\n optionsListProps?: BaseSelectProps['optionsListProps'];\n\n /**\n * Включает отображение поиска\n */\n showSearch?: BaseSelectProps['showSearch'];\n\n /**\n * Настройки поиска\n */\n searchProps?: BaseSelectProps['searchProps'];\n\n /**\n * Показывать кнопку очистки\n */\n showClear?: boolean;\n\n /**\n * Показывать пункт \"Выбрать все\"\n */\n showSelectAll?: boolean;\n\n /**\n * Показывать пункт \"Выбрать все\" в заголовке списка\n */\n showHeaderWithSelectAll?: boolean;\n\n /**\n * Значение name при применении выбора\n * @default 'apply-footer'\n */\n applyName?: string;\n\n /**\n * Значение name при сбросе выбора\n * @default 'reset-footer'\n */\n resetName?: string;\n};\n\nconst selectAllOption = { key: SELECT_ALL_KEY, content: 'Выбрать все' };\n\nexport function useSelectWithApply({\n options,\n selected,\n onChange = () => null,\n onSelectAllClick = () => null,\n OptionsList,\n optionsListProps = {},\n showClear = true,\n showSelectAll = false,\n showHeaderWithSelectAll = false,\n showSearch = false,\n searchProps = {},\n applyName = 'apply-footer',\n resetName = 'reset-footer',\n}: UseSelectWithApplyProps) {\n const [searchState, setSearchState] = useState('');\n\n const [search, setSearch] =\n typeof searchProps?.value === 'string'\n ? [searchProps.value, searchProps.onChange]\n : [searchState, setSearchState];\n\n const accessor = searchProps.accessor || defaultAccessor;\n const filterFn = searchProps.filterFn || defaultFilterFn;\n const groupAccessor = searchProps.groupAccessor ?? defaultGroupAccessor;\n const filterGroup = searchProps.filterGroup ?? false;\n\n const { flatOptions, filteredOptions, selectedOptions } = useMemo(\n () =>\n processOptions(\n options,\n selected,\n showSearch\n ? (option) => {\n if (isGroup(option)) {\n const groupAccessorValue = groupAccessor(option);\n\n return (\n typeof groupAccessorValue === 'string' &&\n filterFn(groupAccessorValue, search)\n );\n }\n\n return filterFn(accessor(option), search);\n }\n : undefined,\n filterGroup,\n ),\n [options, selected, showSearch, filterGroup, filterFn, accessor, search, groupAccessor],\n );\n\n const [selectedDraft, setSelectedDraft] = useState<OptionShape[]>(selectedOptions);\n\n const selectedOptionsRef = useRef<OptionShape[]>(selectedOptions);\n\n const handleApply = () => {\n onChange({\n selected: selectedDraft[0],\n selectedMultiple: selectedDraft,\n initiator: null,\n name: applyName,\n });\n };\n\n const handleClear = () => {\n setSelectedDraft([]);\n onChange({\n selected: null,\n selectedMultiple: [],\n initiator: null,\n name: resetName,\n });\n };\n\n const handleToggleAll = () => {\n const optionsToSet = flatOptions.length === selectedDraft.length ? [] : flatOptions;\n\n onSelectAllClick(optionsToSet);\n setSelectedDraft(optionsToSet);\n };\n\n const selectedKeys = useMemo(() => selectedDraft.map(({ key }) => key), [selectedDraft]);\n\n const handleChange: Required<BaseSelectProps>['onChange'] = ({ initiator, ...restArgs }) => {\n if (!initiator) {\n onChange({\n initiator: null,\n ...restArgs,\n });\n\n return;\n }\n\n const initiatorSelected =\n selectedDraft.some(\n (selectedDraftOption) => selectedDraftOption.key === initiator.key,\n ) ||\n (initiator.key === SELECT_ALL_KEY &&\n (selectedDraft.length === flatOptions.length ||\n flatOptions.every(({ key }) => selectedKeys.includes(key))));\n\n if (initiator.key === SELECT_ALL_KEY) {\n setSelectedDraft(initiatorSelected ? [] : flatOptions);\n } else {\n setSelectedDraft(\n initiatorSelected\n ? selectedDraft.filter((o) => o.key !== initiator.key)\n : selectedDraft.concat(initiator),\n );\n }\n };\n\n const handleClose = () => setSelectedDraft(selectedOptionsRef.current);\n\n useEffect(() => {\n // устанавливать selectedDraft если selectedOptions изменились\n if (!reactFastCompare(selectedOptionsRef.current, selectedOptions)) {\n setSelectedDraft(selectedOptions);\n }\n selectedOptionsRef.current = selectedOptions;\n }, [selectedOptions]);\n\n const memoizedOptions = useMemo(\n () =>\n filteredOptions.length && showSelectAll\n ? [selectAllOption, ...filteredOptions]\n : filteredOptions,\n [filteredOptions, showSelectAll],\n );\n\n return {\n OptionsList: OptionsListWithApply,\n optionsListProps: {\n ...(optionsListProps as AnyObject),\n OptionsList,\n showClear,\n onClear: handleClear,\n onApply: handleApply,\n onClose: handleClose,\n selectedDraft,\n setSelectedDraft,\n showHeaderWithSelectAll,\n headerProps: {\n ...(optionsListProps as AnyObject)?.headerProps,\n indeterminate: selectedDraft.length > 0,\n checked:\n selectedDraft.length === flatOptions.length ||\n flatOptions.every(({ key }) => selectedKeys.includes(key)),\n onChange: handleToggleAll,\n },\n },\n multiple: true,\n options: memoizedOptions,\n onChange: handleChange,\n selected,\n showSearch,\n searchProps: showSearch\n ? {\n ...searchProps,\n value: search,\n onChange: setSearch,\n }\n : undefined,\n /* Костыль для респонсив селекта. В мобильную версию хук уже зашит, и это единственный передать в мобилку оригинальные пропсы */\n originalProps: {\n options,\n selected,\n onChange,\n OptionsList,\n optionsListProps,\n showClear,\n showSelectAll,\n showHeaderWithSelectAll,\n showSearch,\n searchProps,\n applyName,\n resetName,\n },\n };\n}\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"hook.js","sources":["../../../src/presets/useSelectWithApply/hook.ts"],"sourcesContent":["import { useEffect, useMemo, useRef, useState } from 'react';\nimport reactFastCompare from 'react-fast-compare';\n\nimport { SELECT_ALL_KEY } from '../../consts';\nimport { type AnyObject, type BaseSelectProps, type OptionShape } from '../../typings';\nimport {\n defaultAccessor,\n defaultFilterFn,\n defaultGroupAccessor,\n isGroup,\n processOptions,\n} from '../../utils';\n\nimport { OptionsListWithApply } from './options-list-with-apply';\n\nexport type UseSelectWithApplyProps = {\n /**\n * Список выбранных пунктов\n */\n selected: BaseSelectProps['selected'];\n\n /**\n * Список вариантов выбора\n */\n options: BaseSelectProps['options'];\n\n /**\n * Обработчик выбора\n */\n onChange: BaseSelectProps['onChange'];\n\n /**\n * Дополнительный обработчик клика на чекбокс выбрать все\n */\n onSelectAllClick?: (selectedMultiple: OptionShape[]) => void;\n\n /**\n * Компонент выпадающего меню\n */\n OptionsList?: BaseSelectProps['OptionsList'];\n\n /**\n * Пропсы, которые будут прокинуты в компонент списка\n */\n optionsListProps?: BaseSelectProps['optionsListProps'];\n\n /**\n * Включает отображение поиска\n */\n showSearch?: BaseSelectProps['showSearch'];\n\n /**\n * Настройки поиска\n */\n searchProps?: BaseSelectProps['searchProps'];\n\n /**\n * Показывать кнопку очистки\n */\n showClear?: boolean;\n\n /**\n * Показывать пункт \"Выбрать все\"\n */\n showSelectAll?: boolean;\n\n /**\n * Показывать пункт \"Выбрать все\" в заголовке списка\n */\n showHeaderWithSelectAll?: boolean;\n\n /**\n * Значение name при применении выбора\n * @default 'apply-footer'\n */\n applyName?: string;\n\n /**\n * Значение name при сбросе выбора\n * @default 'reset-footer'\n */\n resetName?: string;\n\n /**\n * Позиция чекбокса \"Выбрать все\" в Header\n * @default 'before'\n */\n checkmarkPosition?: 'before' | 'after';\n};\n\nconst selectAllOption = { key: SELECT_ALL_KEY, content: 'Выбрать все' };\n\nexport function useSelectWithApply({\n options,\n selected,\n onChange = () => null,\n onSelectAllClick = () => null,\n OptionsList,\n optionsListProps = {},\n showClear = true,\n showSelectAll = false,\n showHeaderWithSelectAll = false,\n checkmarkPosition = 'before',\n showSearch = false,\n searchProps = {},\n applyName = 'apply-footer',\n resetName = 'reset-footer',\n}: UseSelectWithApplyProps) {\n const [searchState, setSearchState] = useState('');\n\n const [search, setSearch] =\n typeof searchProps?.value === 'string'\n ? [searchProps.value, searchProps.onChange]\n : [searchState, setSearchState];\n\n const accessor = searchProps.accessor || defaultAccessor;\n const filterFn = searchProps.filterFn || defaultFilterFn;\n const groupAccessor = searchProps.groupAccessor ?? defaultGroupAccessor;\n const filterGroup = searchProps.filterGroup ?? false;\n\n const { flatOptions, filteredOptions, selectedOptions } = useMemo(\n () =>\n processOptions(\n options,\n selected,\n showSearch\n ? (option) => {\n if (isGroup(option)) {\n const groupAccessorValue = groupAccessor(option);\n\n return (\n typeof groupAccessorValue === 'string' &&\n filterFn(groupAccessorValue, search)\n );\n }\n\n return filterFn(accessor(option), search);\n }\n : undefined,\n filterGroup,\n ),\n [options, selected, showSearch, filterGroup, filterFn, accessor, search, groupAccessor],\n );\n const [selectedDraft, setSelectedDraft] = useState<OptionShape[]>(selectedOptions);\n\n const selectedOptionsRef = useRef<OptionShape[]>(selectedOptions);\n\n const handleApply = () => {\n onChange({\n selected: selectedDraft[0],\n selectedMultiple: selectedDraft,\n initiator: null,\n name: applyName,\n });\n };\n\n const handleClear = () => {\n setSelectedDraft([]);\n onChange({\n selected: null,\n selectedMultiple: [],\n initiator: null,\n name: resetName,\n });\n };\n\n const handleToggleAll = () => {\n const optionsToSet = flatOptions.length === selectedDraft.length ? [] : flatOptions;\n\n onSelectAllClick(optionsToSet);\n setSelectedDraft(optionsToSet);\n };\n\n const selectedKeys = useMemo(() => selectedDraft.map(({ key }) => key), [selectedDraft]);\n\n const handleChange: Required<BaseSelectProps>['onChange'] = ({ initiator, ...restArgs }) => {\n if (!initiator) {\n onChange({\n initiator: null,\n ...restArgs,\n });\n\n return;\n }\n\n const initiatorSelected =\n selectedDraft.some(\n (selectedDraftOption) => selectedDraftOption.key === initiator.key,\n ) ||\n (initiator.key === SELECT_ALL_KEY &&\n (selectedDraft.length === flatOptions.length ||\n flatOptions.every(({ key }) => selectedKeys.includes(key))));\n\n if (initiator.key === SELECT_ALL_KEY) {\n setSelectedDraft(initiatorSelected ? [] : flatOptions);\n } else {\n setSelectedDraft(\n initiatorSelected\n ? selectedDraft.filter((o) => o.key !== initiator.key)\n : selectedDraft.concat(initiator),\n );\n }\n };\n\n const handleClose = () => setSelectedDraft(selectedOptionsRef.current);\n\n useEffect(() => {\n // устанавливать selectedDraft если selectedOptions изменились\n if (!reactFastCompare(selectedOptionsRef.current, selectedOptions)) {\n setSelectedDraft(selectedOptions);\n }\n selectedOptionsRef.current = selectedOptions;\n }, [selectedOptions]);\n\n const memoizedOptions = useMemo(\n () =>\n filteredOptions.length && showSelectAll\n ? [selectAllOption, ...filteredOptions]\n : filteredOptions,\n [filteredOptions, showSelectAll],\n );\n\n return {\n OptionsList: OptionsListWithApply,\n optionsListProps: {\n ...(optionsListProps as AnyObject),\n OptionsList,\n showClear,\n onClear: handleClear,\n onApply: handleApply,\n onClose: handleClose,\n selectedDraft,\n setSelectedDraft,\n showHeaderWithSelectAll,\n headerProps: {\n ...(optionsListProps as AnyObject)?.headerProps,\n indeterminate: selectedDraft.length > 0,\n checked:\n selectedDraft.length === flatOptions.length ||\n flatOptions.every(({ key }) => selectedKeys.includes(key)),\n onChange: handleToggleAll,\n checkmarkPosition,\n },\n },\n multiple: true,\n options: memoizedOptions,\n onChange: handleChange,\n selected,\n showSearch,\n searchProps: showSearch\n ? {\n ...searchProps,\n value: search,\n onChange: setSearch,\n }\n : undefined,\n /* Костыль для респонсив селекта. В мобильную версию хук уже зашит, и это единственный передать в мобилку оригинальные пропсы */\n originalProps: {\n options,\n selected,\n onChange,\n OptionsList,\n optionsListProps,\n showClear,\n showSelectAll,\n showHeaderWithSelectAll,\n checkmarkPosition,\n showSearch,\n searchProps,\n applyName,\n resetName,\n },\n };\n}\n"],"names":[],"mappings":"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"}
@@ -12,14 +12,14 @@
12
12
  :root {
13
13
  --select-option-list-footer-button-gap: var(--gap-8);
14
14
  }
15
- .select__footer_d6idr {
15
+ .select__footer_kaepn {
16
16
  background-color: var(--color-light-base-bg-primary);
17
17
  padding: var(--gap-12);
18
18
  outline: none;
19
19
  }
20
- .select__footer_d6idr.select__size-72_d6idr {
20
+ .select__footer_kaepn.select__size-72_kaepn {
21
21
  padding: var(--gap-12) var(--gap-16);
22
22
  }
23
- .select__footer_d6idr > .select__button_d6idr + .select__button_d6idr {
23
+ .select__footer_kaepn > .select__button_kaepn + .select__button_kaepn {
24
24
  margin-left: var(--select-option-list-footer-button-gap);
25
25
  }
@@ -1,6 +1,6 @@
1
1
  import './index.css';
2
2
 
3
- const styles = {"footer":"select__footer_d6idr","size-72":"select__size-72_d6idr","button":"select__button_d6idr"};
3
+ const styles = {"footer":"select__footer_kaepn","size-72":"select__size-72_kaepn","button":"select__button_kaepn"};
4
4
 
5
5
  export { styles as default };
6
6
  //# sourceMappingURL=index.module.css.js.map
@@ -7,6 +7,7 @@ export declare type HeaderProps = {
7
7
  onChange?: CheckboxProps['onChange'];
8
8
  mobile?: boolean;
9
9
  dataTestId?: string;
10
+ checkmarkPosition?: 'before' | 'after';
10
11
  size?: OptionsListProps['size'];
11
12
  };
12
13
  export declare const Header: React.FC<HeaderProps>;
@@ -3,11 +3,11 @@ import cn from 'classnames';
3
3
  import { Checkbox } from '@alfalab/core-components-checkbox/modern';
4
4
  import styles from './index.module.css.js';
5
5
 
6
- const Header = ({ onChange, checked, indeterminate, mobile, dataTestId, size, }) => (React.createElement("div", { className: cn(size && styles[`size-${size}`], {
6
+ const Header = ({ onChange, checked, indeterminate, mobile, dataTestId, size, checkmarkPosition = 'before', }) => (React.createElement("div", { className: cn(size && styles[`size-${size}`], {
7
7
  [styles.desktop]: !mobile,
8
8
  [styles.mobile]: mobile,
9
9
  }) },
10
- React.createElement(Checkbox, { block: true, indeterminate: indeterminate, size: 24, onChange: onChange, checked: checked, label: '\u0412\u044B\u0431\u0440\u0430\u0442\u044C \u0432\u0441\u0435', dataTestId: dataTestId })));
10
+ React.createElement(Checkbox, { block: true, indeterminate: indeterminate, size: 24, onChange: onChange, checked: checked, label: '\u0412\u044B\u0431\u0440\u0430\u0442\u044C \u0432\u0441\u0435', dataTestId: dataTestId, position: checkmarkPosition, contentClassName: cn({ [styles.positionAfter]: checkmarkPosition === 'after' }) })));
11
11
 
12
12
  export { Header };
13
13
  //# sourceMappingURL=Component.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Component.js","sources":["../../../../../src/presets/useSelectWithApply/options-list-with-apply/header/Component.tsx"],"sourcesContent":["import React from 'react';\nimport cn from 'classnames';\n\nimport { Checkbox, type CheckboxProps } from '@alfalab/core-components-checkbox';\n\nimport { type OptionsListProps } from '../../../../typings';\n\nimport styles from './index.module.css';\n\nexport type HeaderProps = {\n checked?: boolean;\n indeterminate?: boolean;\n onChange?: CheckboxProps['onChange'];\n mobile?: boolean;\n dataTestId?: string;\n size?: OptionsListProps['size'];\n};\n\nexport const Header: React.FC<HeaderProps> = ({\n onChange,\n checked,\n indeterminate,\n mobile,\n dataTestId,\n size,\n}) => (\n <div\n className={cn(size && styles[`size-${size}`], {\n [styles.desktop]: !mobile,\n [styles.mobile]: mobile,\n })}\n >\n <Checkbox\n block={true}\n indeterminate={indeterminate}\n size={24}\n onChange={onChange}\n checked={checked}\n label='Выбрать все'\n dataTestId={dataTestId}\n />\n </div>\n);\n"],"names":[],"mappings":";;;;;AAkBO,MAAM,MAAM,GAA0B,CAAC,EAC1C,QAAQ,EACR,OAAO,EACP,aAAa,EACb,MAAM,EACN,UAAU,EACV,IAAI,GACP,MACG,KACI,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,SAAS,EAAE,EAAE,CAAC,IAAI,IAAI,MAAM,CAAC,CAAA,KAAA,EAAQ,IAAI,CAAA,CAAE,CAAC,EAAE;AAC1C,QAAA,CAAC,MAAM,CAAC,OAAO,GAAG,CAAC,MAAM;AACzB,QAAA,CAAC,MAAM,CAAC,MAAM,GAAG,MAAM;KAC1B,CAAC,EAAA;AAEF,IAAA,KAAA,CAAA,aAAA,CAAC,QAAQ,EAAA,EACL,KAAK,EAAE,IAAI,EACX,aAAa,EAAE,aAAa,EAC5B,IAAI,EAAE,EAAE,EACR,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,OAAO,EAChB,KAAK,EAAC,+DAAa,EACnB,UAAU,EAAE,UAAU,EACxB,CAAA,CACA;;;;"}
1
+ {"version":3,"file":"Component.js","sources":["../../../../../src/presets/useSelectWithApply/options-list-with-apply/header/Component.tsx"],"sourcesContent":["import React from 'react';\nimport cn from 'classnames';\n\nimport { Checkbox, type CheckboxProps } from '@alfalab/core-components-checkbox';\n\nimport { type OptionsListProps } from '../../../../typings';\n\nimport styles from './index.module.css';\n\nexport type HeaderProps = {\n checked?: boolean;\n indeterminate?: boolean;\n onChange?: CheckboxProps['onChange'];\n mobile?: boolean;\n dataTestId?: string;\n checkmarkPosition?: 'before' | 'after';\n size?: OptionsListProps['size'];\n};\n\nexport const Header: React.FC<HeaderProps> = ({\n onChange,\n checked,\n indeterminate,\n mobile,\n dataTestId,\n size,\n checkmarkPosition = 'before',\n}) => (\n <div\n className={cn(size && styles[`size-${size}`], {\n [styles.desktop]: !mobile,\n [styles.mobile]: mobile,\n })}\n >\n <Checkbox\n block={true}\n indeterminate={indeterminate}\n size={24}\n onChange={onChange}\n checked={checked}\n label='Выбрать все'\n dataTestId={dataTestId}\n position={checkmarkPosition}\n contentClassName={cn({ [styles.positionAfter]: checkmarkPosition === 'after' })}\n />\n </div>\n);\n"],"names":[],"mappings":";;;;;AAmBa,MAAA,MAAM,GAA0B,CAAC,EAC1C,QAAQ,EACR,OAAO,EACP,aAAa,EACb,MAAM,EACN,UAAU,EACV,IAAI,EACJ,iBAAiB,GAAG,QAAQ,GAC/B,MACG,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EACI,SAAS,EAAE,EAAE,CAAC,IAAI,IAAI,MAAM,CAAC,QAAQ,IAAI,CAAA,CAAE,CAAC,EAAE;AAC1C,QAAA,CAAC,MAAM,CAAC,OAAO,GAAG,CAAC,MAAM;AACzB,QAAA,CAAC,MAAM,CAAC,MAAM,GAAG,MAAM;KAC1B,CAAC,EAAA;IAEF,KAAC,CAAA,aAAA,CAAA,QAAQ,EACL,EAAA,KAAK,EAAE,IAAI,EACX,aAAa,EAAE,aAAa,EAC5B,IAAI,EAAE,EAAE,EACR,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,OAAO,EAChB,KAAK,EAAC,+DAAa,EACnB,UAAU,EAAE,UAAU,EACtB,QAAQ,EAAE,iBAAiB,EAC3B,gBAAgB,EAAE,EAAE,CAAC,EAAE,CAAC,MAAM,CAAC,aAAa,GAAG,iBAAiB,KAAK,OAAO,EAAE,CAAC,EAAA,CACjF,CACA;;;;"}
@@ -6,12 +6,16 @@
6
6
  --gap-12: var(--gap-s);
7
7
  --gap-16: var(--gap-m);
8
8
  }
9
- .select__desktop_1h9v5 {
9
+ .select__desktop_1t4z8 {
10
10
  padding: var(--gap-12);
11
11
  }
12
- .select__desktop_1h9v5.select__size-72_1h9v5 {
12
+ .select__desktop_1t4z8.select__size-72_1t4z8 {
13
13
  padding-left: var(--gap-16);
14
14
  }
15
- .select__mobile_1h9v5 {
16
- padding: var(--gap-12) var(--gap-8);
15
+ .select__mobile_1t4z8 {
16
+ padding: var(--gap-12) var(--gap-12) var(--gap-12) var(--gap-8);
17
+ }
18
+ .select__positionAfter_1t4z8 {
19
+ margin-left: 0;
20
+ margin-left: initial;
17
21
  }
@@ -1,6 +1,6 @@
1
1
  import './index.css';
2
2
 
3
- const styles = {"desktop":"select__desktop_1h9v5","size-72":"select__size-72_1h9v5","mobile":"select__mobile_1h9v5"};
3
+ const styles = {"desktop":"select__desktop_1t4z8","size-72":"select__size-72_1t4z8","mobile":"select__mobile_1t4z8","positionAfter":"select__positionAfter_1t4z8"};
4
4
 
5
5
  export { styles as default };
6
6
  //# sourceMappingURL=index.module.css.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.module.css.js","sources":["../../../../src/presets/useSelectWithApply/options-list-with-apply/header/index.module.css"],"sourcesContent":["@import '@alfalab/core-components-vars/src/no-typography-index.css';\n\n.desktop {\n padding: var(--gap-12);\n &.size-72 {\n padding-left: var(--gap-16);\n }\n}\n\n.mobile {\n padding: var(--gap-12) var(--gap-8);\n}\n"],"names":[],"mappings":";;AAEgB,eAAe,CAAC,SAAS,CAAC,uBAAuB,CAAC,SAAS,CAAC,uBAAuB,CAAC,QAAQ,CAAC,sBAAsB,CAAC;;;;"}
1
+ {"version":3,"file":"index.module.css.js","sources":["../../../../src/presets/useSelectWithApply/options-list-with-apply/header/index.module.css"],"sourcesContent":["@import '@alfalab/core-components-vars/src/no-typography-index.css';\n\n.desktop {\n padding: var(--gap-12);\n &.size-72 {\n padding-left: var(--gap-16);\n }\n}\n\n.mobile {\n padding: var(--gap-12) var(--gap-12) var(--gap-12) var(--gap-8);\n}\n\n.positionAfter {\n margin-left: unset;\n}\n"],"names":[],"mappings":";;AAEgB,eAAe,CAAC,SAAS,CAAC,uBAAuB,CAAC,SAAS,CAAC,uBAAuB,CAAC,QAAQ,CAAC,sBAAsB,CAAC,eAAe,CAAC,6BAA6B,CAAC;;;;"}
@@ -1,9 +1,7 @@
1
1
  import React from 'react';
2
2
  import { Skeleton } from '@alfalab/core-components-skeleton/modern';
3
3
  import 'classnames';
4
- import '@alfalab/core-components-badge/modern';
5
4
  import '@alfalab/core-components-checkbox/modern';
6
- import '@alfalab/icons-glyph/CheckmarkCircleMIcon';
7
5
  import '@alfalab/icons-glyph/CheckmarkMIcon';
8
6
  import '../../components/checkmark/index.css';
9
7
  import '../../components/option/desktop/index.css';
@@ -1 +1 @@
1
- {"version":3,"file":"hook.js","sources":["../../../src/presets/useSelectWithLoading/hook.tsx"],"sourcesContent":["import React from 'react';\n\nimport { Skeleton } from '@alfalab/core-components-skeleton';\n\nimport { Option as DefaultOption } from '../../components/option';\nimport { type BaseSelectProps, type OptionProps, type OptionShape } from '../../typings';\n\nimport styles from './index.module.css';\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\ntype useSelectWithLoadingProps = {\n loading?: boolean;\n visibleOptions?: BaseSelectProps['visibleOptions'];\n Option?: React.FC<OptionProps>;\n};\n\nexport function useSelectWithLoading({\n loading = false,\n visibleOptions = 6,\n Option = DefaultOption,\n}: useSelectWithLoadingProps) {\n const renderOption = (props: OptionProps) => (\n <Option {...props} Checkmark={null} highlighted={loading ? false : props.highlighted} />\n );\n\n const options: OptionShape[] = Array(visibleOptions)\n .fill(0)\n .map((_, key) => ({\n key: `loading-${key}`,\n disabled: true,\n content: <Skeleton className={styles.skeleton} visible={true} />,\n }));\n\n if (!loading) return null;\n\n return {\n Option: renderOption,\n options,\n };\n}\n"],"names":["DefaultOption"],"mappings":";;;;;;;;;;;;;;AAgBgB,SAAA,oBAAoB,CAAC,EACjC,OAAO,GAAG,KAAK,EACf,cAAc,GAAG,CAAC,EAClB,MAAM,GAAGA,gBAAa,GACE,EAAA;AACxB,IAAA,MAAM,YAAY,GAAG,CAAC,KAAkB,MACpC,KAAA,CAAA,aAAA,CAAC,MAAM,EAAA,EAAA,GAAK,KAAK,EAAE,SAAS,EAAE,IAAI,EAAE,WAAW,EAAE,OAAO,GAAG,KAAK,GAAG,KAAK,CAAC,WAAW,EAAA,CAAI,CAC3F;AAED,IAAA,MAAM,OAAO,GAAkB,KAAK,CAAC,cAAc;SAC9C,IAAI,CAAC,CAAC;SACN,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,MAAM;QACd,GAAG,EAAE,CAAW,QAAA,EAAA,GAAG,CAAE,CAAA;AACrB,QAAA,QAAQ,EAAE,IAAI;AACd,QAAA,OAAO,EAAE,KAAA,CAAA,aAAA,CAAC,QAAQ,EAAA,EAAC,SAAS,EAAE,MAAM,CAAC,QAAQ,EAAE,OAAO,EAAE,IAAI,EAAI,CAAA;AACnE,KAAA,CAAC,CAAC;AAEP,IAAA,IAAI,CAAC,OAAO;AAAE,QAAA,OAAO,IAAI;IAEzB,OAAO;AACH,QAAA,MAAM,EAAE,YAAY;QACpB,OAAO;KACV;AACL;;;;"}
1
+ {"version":3,"file":"hook.js","sources":["../../../src/presets/useSelectWithLoading/hook.tsx"],"sourcesContent":["import React from 'react';\n\nimport { Skeleton } from '@alfalab/core-components-skeleton';\n\nimport { Option as DefaultOption } from '../../components/option';\nimport { type BaseSelectProps, type OptionProps, type OptionShape } from '../../typings';\n\nimport styles from './index.module.css';\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\ntype useSelectWithLoadingProps = {\n loading?: boolean;\n visibleOptions?: BaseSelectProps['visibleOptions'];\n Option?: React.FC<OptionProps>;\n};\n\nexport function useSelectWithLoading({\n loading = false,\n visibleOptions = 6,\n Option = DefaultOption,\n}: useSelectWithLoadingProps) {\n const renderOption = (props: OptionProps) => (\n <Option {...props} Checkmark={null} highlighted={loading ? false : props.highlighted} />\n );\n\n const options: OptionShape[] = Array(visibleOptions)\n .fill(0)\n .map((_, key) => ({\n key: `loading-${key}`,\n disabled: true,\n content: <Skeleton className={styles.skeleton} visible={true} />,\n }));\n\n if (!loading) return null;\n\n return {\n Option: renderOption,\n options,\n };\n}\n"],"names":["DefaultOption"],"mappings":";;;;;;;;;;;;AAgBgB,SAAA,oBAAoB,CAAC,EACjC,OAAO,GAAG,KAAK,EACf,cAAc,GAAG,CAAC,EAClB,MAAM,GAAGA,gBAAa,GACE,EAAA;AACxB,IAAA,MAAM,YAAY,GAAG,CAAC,KAAkB,MACpC,KAAA,CAAA,aAAA,CAAC,MAAM,EAAA,EAAA,GAAK,KAAK,EAAE,SAAS,EAAE,IAAI,EAAE,WAAW,EAAE,OAAO,GAAG,KAAK,GAAG,KAAK,CAAC,WAAW,EAAA,CAAI,CAC3F;AAED,IAAA,MAAM,OAAO,GAAkB,KAAK,CAAC,cAAc;SAC9C,IAAI,CAAC,CAAC;SACN,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,MAAM;QACd,GAAG,EAAE,CAAW,QAAA,EAAA,GAAG,CAAE,CAAA;AACrB,QAAA,QAAQ,EAAE,IAAI;AACd,QAAA,OAAO,EAAE,KAAA,CAAA,aAAA,CAAC,QAAQ,EAAA,EAAC,SAAS,EAAE,MAAM,CAAC,QAAQ,EAAE,OAAO,EAAE,IAAI,EAAI,CAAA;AACnE,KAAA,CAAC,CAAC;AAEP,IAAA,IAAI,CAAC,OAAO;AAAE,QAAA,OAAO,IAAI;IAEzB,OAAO;AACH,QAAA,MAAM,EAAE,YAAY;QACpB,OAAO;KACV;AACL;;;;"}
@@ -1,4 +1,4 @@
1
- .select__skeleton_1s7nq {
1
+ .select__skeleton_az3hq {
2
2
  position: absolute;
3
3
  top: 50%;
4
4
  transform: translateY(-50%);
@@ -1,6 +1,6 @@
1
1
  import './index.css';
2
2
 
3
- const styles = {"skeleton":"select__skeleton_1s7nq"};
3
+ const styles = {"skeleton":"select__skeleton_az3hq"};
4
4
 
5
5
  export { styles as default };
6
6
  //# sourceMappingURL=index.module.css.js.map
@@ -669,6 +669,10 @@ export declare type CheckmarkProps = {
669
669
  * Расположение отметки
670
670
  */
671
671
  position?: 'before' | 'after';
672
+ /**
673
+ * Дополнительный контент
674
+ */
675
+ content?: ReactNode;
672
676
  /**
673
677
  * Иконка выбранного пункта
674
678
  */
@@ -697,6 +701,11 @@ export declare type AdditionalMobileProps = {
697
701
  * Использовать ли хук useSelectWithApply в мобильном компоненте
698
702
  */
699
703
  useWithApplyHook?: boolean;
704
+ /**
705
+ * Позиция чекбокса "Выбрать все" в Header
706
+ * @default 'before'
707
+ */
708
+ checkmarkPosition?: 'before' | 'after';
700
709
  };
701
710
  export declare type BottomSheetSelectMobileProps = {
702
711
  /**
@@ -1,3 +1,3 @@
1
- import React from 'react';
1
+ import { type FC } from 'react';
2
2
  import { type CheckmarkProps } from '../../typings';
3
- export declare const BaseCheckmark: ({ selected, disabled, className, multiple, align, }: CheckmarkProps) => React.JSX.Element;
3
+ export declare const BaseCheckmark: FC<CheckmarkProps>;
@@ -4,12 +4,16 @@ import { Checkbox } from '@alfalab/core-components-checkbox/moderncssm';
4
4
  import { CheckmarkMIcon } from '@alfalab/icons-glyph/CheckmarkMIcon';
5
5
  import styles from './index.module.css';
6
6
 
7
- const BaseCheckmark = ({ selected, disabled = false, className, multiple, align = 'center', }) => {
8
- const checkmarkClassNames = cn(styles.checkmark, styles[align], className, {
9
- [styles.single]: !multiple,
10
- [styles.selected]: selected,
11
- });
12
- return multiple ? (React.createElement(Checkbox, { checked: selected, disabled: disabled, className: checkmarkClassNames, size: 24, hiddenInput: true })) : (React.createElement(CheckmarkMIcon, { className: checkmarkClassNames }));
7
+ const BaseCheckmark = ({ selected, disabled = false, className, multiple, align = 'center', position = 'before', content, }) => {
8
+ const renderCheckmarkIcon = () => (React.createElement(CheckmarkMIcon, { className: cn(styles.singleIcon, styles[position], {
9
+ [styles.selected]: selected,
10
+ }) }));
11
+ return multiple ? (React.createElement(Checkbox, { block: true, checked: selected, disabled: disabled, contentClassName: cn({ [styles.positionAfter]: position === 'after' }), className: cn(styles.checkmark, styles[align], className, {
12
+ [styles.selected]: selected,
13
+ }), size: 24, position: position, label: content, hiddenInput: true })) : (React.createElement("div", { className: cn(styles.container, styles[align], className) },
14
+ position === 'before' && renderCheckmarkIcon(),
15
+ React.createElement("div", { className: styles.content }, content),
16
+ position === 'after' && renderCheckmarkIcon()));
13
17
  };
14
18
 
15
19
  export { BaseCheckmark };
@@ -1 +1 @@
1
- {"version":3,"file":"Component.js","sources":["../../../src/components/base-checkmark/Component.tsx"],"sourcesContent":["import React from 'react';\nimport cn from 'classnames';\n\nimport { Checkbox } 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 BaseCheckmark = ({\n selected,\n disabled = false,\n className,\n multiple,\n align = 'center',\n}: CheckmarkProps) => {\n const checkmarkClassNames = cn(styles.checkmark, styles[align], className, {\n [styles.single]: !multiple,\n [styles.selected]: selected,\n });\n\n return multiple ? (\n <Checkbox\n checked={selected}\n disabled={disabled}\n className={checkmarkClassNames}\n size={24}\n hiddenInput={true}\n />\n ) : (\n <CheckmarkMIcon className={checkmarkClassNames} />\n );\n};\n"],"names":[],"mappings":";;;;;;MAUa,aAAa,GAAG,CAAC,EAC1B,QAAQ,EACR,QAAQ,GAAG,KAAK,EAChB,SAAS,EACT,QAAQ,EACR,KAAK,GAAG,QAAQ,GACH,KAAI;AACjB,IAAA,MAAM,mBAAmB,GAAG,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE;AACvE,QAAA,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,QAAQ;AAC1B,QAAA,CAAC,MAAM,CAAC,QAAQ,GAAG,QAAQ;AAC9B,KAAA,CAAC;AAEF,IAAA,OAAO,QAAQ,IACX,KAAA,CAAA,aAAA,CAAC,QAAQ,EACL,EAAA,OAAO,EAAE,QAAQ,EACjB,QAAQ,EAAE,QAAQ,EAClB,SAAS,EAAE,mBAAmB,EAC9B,IAAI,EAAE,EAAE,EACR,WAAW,EAAE,IAAI,EAAA,CACnB,KAEF,KAAA,CAAA,aAAA,CAAC,cAAc,EAAC,EAAA,SAAS,EAAE,mBAAmB,EAAA,CAAI,CACrD;AACL;;;;"}
1
+ {"version":3,"file":"Component.js","sources":["../../../src/components/base-checkmark/Component.tsx"],"sourcesContent":["import React, { type FC } from 'react';\nimport cn from 'classnames';\n\nimport { Checkbox } 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 BaseCheckmark: FC<CheckmarkProps> = ({\n selected,\n disabled = false,\n className,\n multiple,\n align = 'center',\n position = 'before',\n content,\n}) => {\n const renderCheckmarkIcon = () => (\n <CheckmarkMIcon\n className={cn(styles.singleIcon, styles[position], {\n [styles.selected]: selected,\n })}\n />\n );\n\n return multiple ? (\n <Checkbox\n block={true}\n checked={selected}\n disabled={disabled}\n contentClassName={cn({ [styles.positionAfter]: position === 'after' })}\n className={cn(styles.checkmark, styles[align], className, {\n [styles.selected]: selected,\n })}\n size={24}\n position={position}\n label={content}\n hiddenInput={true}\n />\n ) : (\n <div className={cn(styles.container, styles[align], className)}>\n {position === 'before' && renderCheckmarkIcon()}\n\n <div className={styles.content}>{content}</div>\n\n {position === 'after' && renderCheckmarkIcon()}\n </div>\n );\n};\n"],"names":[],"mappings":";;;;;;AAUa,MAAA,aAAa,GAAuB,CAAC,EAC9C,QAAQ,EACR,QAAQ,GAAG,KAAK,EAChB,SAAS,EACT,QAAQ,EACR,KAAK,GAAG,QAAQ,EAChB,QAAQ,GAAG,QAAQ,EACnB,OAAO,GACV,KAAI;IACD,MAAM,mBAAmB,GAAG,OACxB,KAAA,CAAA,aAAA,CAAC,cAAc,EACX,EAAA,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,QAAQ,CAAC,EAAE;AAC/C,YAAA,CAAC,MAAM,CAAC,QAAQ,GAAG,QAAQ;SAC9B,CAAC,EAAA,CACJ,CACL;IAED,OAAO,QAAQ,IACX,KAAC,CAAA,aAAA,CAAA,QAAQ,EACL,EAAA,KAAK,EAAE,IAAI,EACX,OAAO,EAAE,QAAQ,EACjB,QAAQ,EAAE,QAAQ,EAClB,gBAAgB,EAAE,EAAE,CAAC,EAAE,CAAC,MAAM,CAAC,aAAa,GAAG,QAAQ,KAAK,OAAO,EAAE,CAAC,EACtE,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE;AACtD,YAAA,CAAC,MAAM,CAAC,QAAQ,GAAG,QAAQ;AAC9B,SAAA,CAAC,EACF,IAAI,EAAE,EAAE,EACR,QAAQ,EAAE,QAAQ,EAClB,KAAK,EAAE,OAAO,EACd,WAAW,EAAE,IAAI,EACnB,CAAA,KAEF,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EAAK,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,KAAK,CAAC,EAAE,SAAS,CAAC,EAAA;AACzD,QAAA,QAAQ,KAAK,QAAQ,IAAI,mBAAmB,EAAE;AAE/C,QAAA,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EAAK,SAAS,EAAE,MAAM,CAAC,OAAO,EAAA,EAAG,OAAO,CAAO;AAE9C,QAAA,QAAQ,KAAK,OAAO,IAAI,mBAAmB,EAAE,CAC5C,CACT;AACL;;;;"}
@@ -11,13 +11,43 @@
11
11
  align-self: center;
12
12
  }
13
13
 
14
- .single {
14
+ .positionAfter {
15
+ margin-left: 0;
16
+ margin-left: initial;
17
+ }
18
+
19
+ .container {
15
20
  display: flex;
16
21
  align-items: center;
17
22
  justify-content: center;
23
+ width: 100%;
24
+ }
25
+
26
+ .container.start {
27
+ align-items: flex-start;
28
+ }
29
+
30
+ .container.center {
31
+ align-items: center;
32
+ }
33
+
34
+ .singleIcon {
35
+ flex-shrink: 0;
18
36
  opacity: 0;
19
37
  }
20
38
 
21
- .single.selected {
39
+ .singleIcon.before {
40
+ margin-right: var(--gap-12);
41
+ }
42
+
43
+ .singleIcon.after {
44
+ margin-left: var(--gap-12);
45
+ }
46
+
47
+ .singleIcon.selected {
22
48
  opacity: 1;
23
49
  }
50
+
51
+ .content {
52
+ flex: 1;
53
+ }
@@ -7,27 +7,16 @@ const BaseOption = ({ className, option, children, selected, highlighted, disabl
7
7
  const content = children || option.content || option.key;
8
8
  const { showCheckMark = true } = option;
9
9
  const isTextContent = !isValidElement(content);
10
- const renderCheckmark = () => {
11
- if (Checkmark && showCheckMark) {
12
- return (React.createElement(Checkmark, { className: cn({
13
- [styles.checkmarkBeforeContent]: checkmarkPosition === 'before',
14
- [styles.checkmarkAfterContent]: checkmarkPosition === 'after',
15
- }), disabled: disabled, selected: selected, multiple: multiple, align: align }));
16
- }
17
- return null;
18
- };
10
+ const showCheckmark = Checkmark && showCheckMark;
19
11
  return (React.createElement("div", { ...innerProps, className: cn(styles.option, size && styles[`size-${size}`], className, {
20
12
  [styles.highlighted]: !mobile && highlighted,
21
13
  [styles.selected]: selected,
22
14
  [styles.disabled]: disabled,
23
15
  [styles.textContent]: isTextContent,
24
16
  [styles.mobile]: mobile,
25
- [styles.checkmarkAfter]: !isTextContent && checkmarkPosition === 'after',
26
- [styles.checkmarkBefore]: !isTextContent && checkmarkPosition === 'before',
27
- }), "data-test-id": dataTestId, "aria-label": option?.value?.name },
28
- checkmarkPosition === 'before' && renderCheckmark(),
29
- React.createElement("div", { className: cn(styles.content) }, content),
30
- checkmarkPosition === 'after' && renderCheckmark()));
17
+ [styles.checkmarkAfter]: showCheckmark && !isTextContent && checkmarkPosition === 'after',
18
+ [styles.checkmarkBefore]: showCheckmark && !isTextContent && checkmarkPosition === 'before',
19
+ }), "data-test-id": dataTestId, "aria-label": option?.value?.name }, showCheckmark ? (React.createElement(Checkmark, { disabled: disabled, selected: selected, multiple: multiple, align: align, position: checkmarkPosition, content: content })) : (React.createElement("div", { className: cn(styles.content) }, content))));
31
20
  };
32
21
 
33
22
  export { BaseOption };
@@ -1 +1 @@
1
- {"version":3,"file":"Component.js","sources":["../../../src/components/base-option/Component.tsx"],"sourcesContent":["import React, { type FC, isValidElement } from 'react';\nimport cn from 'classnames';\n\nimport { type OptionProps } from '../../typings';\nimport { BaseCheckmark } from '../base-checkmark';\n\nimport styles from './index.module.css';\n\nexport const BaseOption: FC<OptionProps> = ({\n className,\n option,\n children,\n selected,\n highlighted,\n disabled,\n multiple,\n Checkmark = BaseCheckmark,\n checkmarkPosition = multiple ? 'before' : 'after',\n align = 'center',\n innerProps,\n dataTestId,\n mobile = false,\n size,\n}) => {\n const content = children || option.content || option.key;\n const { showCheckMark = true } = option;\n\n const isTextContent = !isValidElement(content);\n\n const renderCheckmark = () => {\n if (Checkmark && showCheckMark) {\n return (\n <Checkmark\n className={cn({\n [styles.checkmarkBeforeContent]: checkmarkPosition === 'before',\n [styles.checkmarkAfterContent]: checkmarkPosition === 'after',\n })}\n disabled={disabled}\n selected={selected}\n multiple={multiple}\n align={align}\n />\n );\n }\n\n return null;\n };\n\n return (\n <div\n {...innerProps}\n className={cn(styles.option, size && styles[`size-${size}`], className, {\n [styles.highlighted]: !mobile && highlighted,\n [styles.selected]: selected,\n [styles.disabled]: disabled,\n [styles.textContent]: isTextContent,\n [styles.mobile]: mobile,\n [styles.checkmarkAfter]: !isTextContent && checkmarkPosition === 'after',\n [styles.checkmarkBefore]: !isTextContent && checkmarkPosition === 'before',\n })}\n data-test-id={dataTestId}\n aria-label={option?.value?.name}\n >\n {checkmarkPosition === 'before' && renderCheckmark()}\n\n <div className={cn(styles.content)}>{content}</div>\n\n {checkmarkPosition === 'after' && renderCheckmark()}\n </div>\n );\n};\n"],"names":[],"mappings":";;;;;MAQa,UAAU,GAAoB,CAAC,EACxC,SAAS,EACT,MAAM,EACN,QAAQ,EACR,QAAQ,EACR,WAAW,EACX,QAAQ,EACR,QAAQ,EACR,SAAS,GAAG,aAAa,EACzB,iBAAiB,GAAG,QAAQ,GAAG,QAAQ,GAAG,OAAO,EACjD,KAAK,GAAG,QAAQ,EAChB,UAAU,EACV,UAAU,EACV,MAAM,GAAG,KAAK,EACd,IAAI,GACP,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,aAAa,GAAG,CAAC,cAAc,CAAC,OAAO,CAAC;IAE9C,MAAM,eAAe,GAAG,MAAK;QACzB,IAAI,SAAS,IAAI,aAAa,EAAE;AAC5B,YAAA,QACI,KAAC,CAAA,aAAA,CAAA,SAAS,IACN,SAAS,EAAE,EAAE,CAAC;AACV,oBAAA,CAAC,MAAM,CAAC,sBAAsB,GAAG,iBAAiB,KAAK,QAAQ;AAC/D,oBAAA,CAAC,MAAM,CAAC,qBAAqB,GAAG,iBAAiB,KAAK,OAAO;AAChE,iBAAA,CAAC,EACF,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,KAAK,EAAE,KAAK,EAAA,CACd;AAET;AAED,QAAA,OAAO,IAAI;AACf,KAAC;IAED,QACI,gCACQ,UAAU,EACd,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,IAAI,MAAM,CAAC,CAAA,KAAA,EAAQ,IAAI,CAAE,CAAA,CAAC,EAAE,SAAS,EAAE;YACpE,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;AAC3B,YAAA,CAAC,MAAM,CAAC,WAAW,GAAG,aAAa;AACnC,YAAA,CAAC,MAAM,CAAC,MAAM,GAAG,MAAM;YACvB,CAAC,MAAM,CAAC,cAAc,GAAG,CAAC,aAAa,IAAI,iBAAiB,KAAK,OAAO;YACxE,CAAC,MAAM,CAAC,eAAe,GAAG,CAAC,aAAa,IAAI,iBAAiB,KAAK,QAAQ;AAC7E,SAAA,CAAC,kBACY,UAAU,EAAA,YAAA,EACZ,MAAM,EAAE,KAAK,EAAE,IAAI,EAAA;AAE9B,QAAA,iBAAiB,KAAK,QAAQ,IAAI,eAAe,EAAE;QAEpD,KAAK,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,EAAG,EAAA,OAAO,CAAO;AAElD,QAAA,iBAAiB,KAAK,OAAO,IAAI,eAAe,EAAE,CACjD;AAEd;;;;"}
1
+ {"version":3,"file":"Component.js","sources":["../../../src/components/base-option/Component.tsx"],"sourcesContent":["import React, { type FC, isValidElement } from 'react';\nimport cn from 'classnames';\n\nimport { type OptionProps } from '../../typings';\nimport { BaseCheckmark } from '../base-checkmark';\n\nimport styles from './index.module.css';\n\nexport const BaseOption: FC<OptionProps> = ({\n className,\n option,\n children,\n selected,\n highlighted,\n disabled,\n multiple,\n Checkmark = BaseCheckmark,\n checkmarkPosition = multiple ? 'before' : 'after',\n align = 'center',\n innerProps,\n dataTestId,\n mobile = false,\n size,\n}) => {\n const content = children || option.content || option.key;\n const { showCheckMark = true } = option;\n const isTextContent = !isValidElement(content);\n const showCheckmark = Checkmark && showCheckMark;\n\n return (\n <div\n {...innerProps}\n className={cn(styles.option, size && styles[`size-${size}`], className, {\n [styles.highlighted]: !mobile && highlighted,\n [styles.selected]: selected,\n [styles.disabled]: disabled,\n [styles.textContent]: isTextContent,\n [styles.mobile]: mobile,\n [styles.checkmarkAfter]:\n showCheckmark && !isTextContent && checkmarkPosition === 'after',\n [styles.checkmarkBefore]:\n showCheckmark && !isTextContent && checkmarkPosition === 'before',\n })}\n data-test-id={dataTestId}\n aria-label={option?.value?.name}\n >\n {showCheckmark ? (\n <Checkmark\n disabled={disabled}\n selected={selected}\n multiple={multiple}\n align={align}\n position={checkmarkPosition}\n content={content}\n />\n ) : (\n <div className={cn(styles.content)}>{content}</div>\n )}\n </div>\n );\n};\n"],"names":[],"mappings":";;;;;MAQa,UAAU,GAAoB,CAAC,EACxC,SAAS,EACT,MAAM,EACN,QAAQ,EACR,QAAQ,EACR,WAAW,EACX,QAAQ,EACR,QAAQ,EACR,SAAS,GAAG,aAAa,EACzB,iBAAiB,GAAG,QAAQ,GAAG,QAAQ,GAAG,OAAO,EACjD,KAAK,GAAG,QAAQ,EAChB,UAAU,EACV,UAAU,EACV,MAAM,GAAG,KAAK,EACd,IAAI,GACP,KAAI;IACD,MAAM,OAAO,GAAG,QAAQ,IAAI,MAAM,CAAC,OAAO,IAAI,MAAM,CAAC,GAAG;AACxD,IAAA,MAAM,EAAE,aAAa,GAAG,IAAI,EAAE,GAAG,MAAM;AACvC,IAAA,MAAM,aAAa,GAAG,CAAC,cAAc,CAAC,OAAO,CAAC;AAC9C,IAAA,MAAM,aAAa,GAAG,SAAS,IAAI,aAAa;IAEhD,QACI,gCACQ,UAAU,EACd,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,IAAI,MAAM,CAAC,CAAA,KAAA,EAAQ,IAAI,CAAE,CAAA,CAAC,EAAE,SAAS,EAAE;YACpE,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;AAC3B,YAAA,CAAC,MAAM,CAAC,WAAW,GAAG,aAAa;AACnC,YAAA,CAAC,MAAM,CAAC,MAAM,GAAG,MAAM;AACvB,YAAA,CAAC,MAAM,CAAC,cAAc,GAClB,aAAa,IAAI,CAAC,aAAa,IAAI,iBAAiB,KAAK,OAAO;AACpE,YAAA,CAAC,MAAM,CAAC,eAAe,GACnB,aAAa,IAAI,CAAC,aAAa,IAAI,iBAAiB,KAAK,QAAQ;AACxE,SAAA,CAAC,EACY,cAAA,EAAA,UAAU,EACZ,YAAA,EAAA,MAAM,EAAE,KAAK,EAAE,IAAI,EAE9B,EAAA,aAAa,IACV,KAAC,CAAA,aAAA,CAAA,SAAS,EACN,EAAA,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,iBAAiB,EAC3B,OAAO,EAAE,OAAO,EAClB,CAAA,KAEF,KAAK,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,EAAA,EAAG,OAAO,CAAO,CACtD,CACC;AAEd;;;;"}
@@ -15,7 +15,8 @@
15
15
  font-size: 16px;
16
16
  line-height: 20px;
17
17
  font-weight: 400;
18
- font-family: var(--font-family-system);
18
+ letter-spacing: -0.24px;
19
+ font-family: var(--font-family-alfasans);
19
20
 
20
21
  display: flex;
21
22
  align-items: center;
@@ -83,14 +84,6 @@
83
84
  color: var(--select-option-disabled-color);
84
85
  }
85
86
 
86
- .checkmarkBeforeContent {
87
- margin-right: var(--gap-12);
88
- }
89
-
90
- .checkmarkAfterContent {
91
- margin-left: var(--gap-12);
92
- }
93
-
94
87
  .content {
95
88
  flex: 1;
96
89
  }
@@ -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;;;;"}