@topvisor/ui 1.5.4-groupSelector.1 → 1.5.4-preloader.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 (337) hide show
  1. package/.chunks/{api-DuS0Qura.amd.js → api-D-JuUXVn.amd.js} +2 -2
  2. package/.chunks/api-D-JuUXVn.amd.js.map +1 -0
  3. package/.chunks/{api-DuS0Qura.esm.js → api-D-JuUXVn.esm.js} +9 -9
  4. package/.chunks/{api-DuS0Qura.esm.js.map → api-D-JuUXVn.esm.js.map} +1 -1
  5. package/.chunks/app-DeBknp1Q.amd.js +2 -0
  6. package/.chunks/app-DeBknp1Q.amd.js.map +1 -0
  7. package/.chunks/{app-BXCICBAa.esm.js → app-DeBknp1Q.esm.js} +12 -13
  8. package/.chunks/app-DeBknp1Q.esm.js.map +1 -0
  9. package/.chunks/{datepicker-BnBQNlTc.amd.js → datepicker-B2Km72Vg.amd.js} +2 -2
  10. package/.chunks/datepicker-B2Km72Vg.amd.js.map +1 -0
  11. package/.chunks/{datepicker-BnBQNlTc.esm.js → datepicker-B2Km72Vg.esm.js} +2 -2
  12. package/.chunks/{datepicker-BnBQNlTc.esm.js.map → datepicker-B2Km72Vg.esm.js.map} +1 -1
  13. package/.chunks/dialog-DPTJ7VN5.amd.js +2 -0
  14. package/.chunks/dialog-DPTJ7VN5.amd.js.map +1 -0
  15. package/.chunks/{dialog-BPUICFiG.esm.js → dialog-DPTJ7VN5.esm.js} +3 -4
  16. package/.chunks/{dialog-BPUICFiG.esm.js.map → dialog-DPTJ7VN5.esm.js.map} +1 -1
  17. package/.chunks/dialog_regionSelectorRegions-ClRx55RP.amd.js +2 -0
  18. package/.chunks/dialog_regionSelectorRegions-ClRx55RP.amd.js.map +1 -0
  19. package/.chunks/{dialog_regionSelectorRegions-BKvg82IO.esm.js → dialog_regionSelectorRegions-ClRx55RP.esm.js} +14 -15
  20. package/.chunks/{dialog_regionSelectorRegions-BKvg82IO.esm.js.map → dialog_regionSelectorRegions-ClRx55RP.esm.js.map} +1 -1
  21. package/.chunks/{field-CjkpGeA7.amd.js → field-DEusYVqS.amd.js} +2 -2
  22. package/.chunks/field-DEusYVqS.amd.js.map +1 -0
  23. package/.chunks/{field-CjkpGeA7.esm.js → field-DEusYVqS.esm.js} +1 -1
  24. package/.chunks/{field-CjkpGeA7.esm.js.map → field-DEusYVqS.esm.js.map} +1 -1
  25. package/.chunks/forms-DKVIpGnH.amd.js +2 -0
  26. package/.chunks/forms-DKVIpGnH.amd.js.map +1 -0
  27. package/.chunks/{forms-CdCS6WAQ.esm.js → forms-DKVIpGnH.esm.js} +17 -14
  28. package/.chunks/forms-DKVIpGnH.esm.js.map +1 -0
  29. package/.chunks/formsExt-Dy7EHtJS.amd.js +2 -0
  30. package/.chunks/formsExt-Dy7EHtJS.amd.js.map +1 -0
  31. package/.chunks/{formsExt-Ck5q-jXI.esm.js → formsExt-Dy7EHtJS.esm.js} +192 -164
  32. package/.chunks/formsExt-Dy7EHtJS.esm.js.map +1 -0
  33. package/.chunks/lazy-DQU-hLos.amd.js +2 -0
  34. package/.chunks/lazy-DQU-hLos.amd.js.map +1 -0
  35. package/.chunks/lazy-DQU-hLos.esm.js +68 -0
  36. package/.chunks/{lazy-CGswTOPj.esm.js.map → lazy-DQU-hLos.esm.js.map} +1 -1
  37. package/.chunks/{mocker-CwZe-g4N.amd.js → mocker-DOnGwq3y.amd.js} +2 -2
  38. package/.chunks/mocker-DOnGwq3y.amd.js.map +1 -0
  39. package/.chunks/{mocker-CwZe-g4N.esm.js → mocker-DOnGwq3y.esm.js} +1 -1
  40. package/.chunks/{mocker-CwZe-g4N.esm.js.map → mocker-DOnGwq3y.esm.js.map} +1 -1
  41. package/.chunks/{notice-DA4p-RwX.amd.js → notice-C3_mXHCe.amd.js} +2 -2
  42. package/.chunks/notice-C3_mXHCe.amd.js.map +1 -0
  43. package/.chunks/{notice-DA4p-RwX.esm.js → notice-C3_mXHCe.esm.js} +2 -2
  44. package/.chunks/{notice-DA4p-RwX.esm.js.map → notice-C3_mXHCe.esm.js.map} +1 -1
  45. package/.chunks/{popup-CN7-bnQJ.amd.js → popup-B8Us9xZO.amd.js} +2 -2
  46. package/.chunks/popup-B8Us9xZO.amd.js.map +1 -0
  47. package/.chunks/{popup-CN7-bnQJ.esm.js → popup-B8Us9xZO.esm.js} +3 -3
  48. package/.chunks/{popup-CN7-bnQJ.esm.js.map → popup-B8Us9xZO.esm.js.map} +1 -1
  49. package/.chunks/{popup-DHCqvZzI.amd.js → popup-CtiL5V44.amd.js} +2 -2
  50. package/.chunks/popup-CtiL5V44.amd.js.map +1 -0
  51. package/.chunks/{popup-DHCqvZzI.esm.js → popup-CtiL5V44.esm.js} +4 -4
  52. package/.chunks/{popup-DHCqvZzI.esm.js.map → popup-CtiL5V44.esm.js.map} +1 -1
  53. package/.chunks/punycode.es6-BZRFIj88.amd.js +2 -0
  54. package/.chunks/punycode.es6-BZRFIj88.amd.js.map +1 -0
  55. package/.chunks/{punycode.es6-B-5kB2YI.esm.js → punycode.es6-BZRFIj88.esm.js} +5 -5
  56. package/.chunks/{punycode.es6-B-5kB2YI.esm.js.map → punycode.es6-BZRFIj88.esm.js.map} +1 -1
  57. package/.chunks/{store-DuQpSSLL.amd.js → store-DjQAOnrn.amd.js} +2 -2
  58. package/.chunks/store-DjQAOnrn.amd.js.map +1 -0
  59. package/.chunks/{store-DuQpSSLL.esm.js → store-DjQAOnrn.esm.js} +1 -1
  60. package/.chunks/{store-DuQpSSLL.esm.js.map → store-DjQAOnrn.esm.js.map} +1 -1
  61. package/.chunks/utils-C1xkXfK0.amd.js +2 -0
  62. package/.chunks/utils-C1xkXfK0.amd.js.map +1 -0
  63. package/.chunks/{dialogs-CbMNuvfF.esm.js → utils-C1xkXfK0.esm.js} +70 -37
  64. package/.chunks/utils-C1xkXfK0.esm.js.map +1 -0
  65. package/.chunks/utils-Cj8CJ22r.amd.js +2 -0
  66. package/.chunks/utils-Cj8CJ22r.amd.js.map +1 -0
  67. package/.chunks/{utils-lidKtVjF.esm.js → utils-Cj8CJ22r.esm.js} +16 -16
  68. package/.chunks/{utils-lidKtVjF.esm.js.map → utils-Cj8CJ22r.esm.js.map} +1 -1
  69. package/.chunks/{worker-spLieexQ.amd.js → worker-DYTgdzGP.amd.js} +2 -2
  70. package/.chunks/worker-DYTgdzGP.amd.js.map +1 -0
  71. package/.chunks/{worker-spLieexQ.esm.js → worker-DYTgdzGP.esm.js} +3 -3
  72. package/.chunks/{worker-spLieexQ.esm.js.map → worker-DYTgdzGP.esm.js.map} +1 -1
  73. package/api/additional.amd.js +1 -1
  74. package/api/additional.amd.js.map +1 -1
  75. package/api/additional.d.ts +1 -1
  76. package/api/additional.js +1 -1
  77. package/api/additional.js.map +1 -1
  78. package/api/index.amd.js +1 -1
  79. package/api/index.amd.js.map +1 -1
  80. package/api/index.d.ts +1 -1
  81. package/api/index.js +2 -2
  82. package/assets/themes/dark-th.css +1 -1
  83. package/assets/themes/dark.css +1 -1
  84. package/assets/themes/light.css +1 -1
  85. package/autoload-css-manifest.amd.json +4 -4
  86. package/autoload-css-manifest.json +4 -4
  87. package/charts/charts.amd.js +1 -1
  88. package/charts/charts.amd.js.map +1 -1
  89. package/charts/charts.d.ts +1 -1
  90. package/charts/charts.js +3 -3
  91. package/charts/charts.js.map +1 -1
  92. package/core/app.amd.js +1 -1
  93. package/core/app.amd.js.map +1 -1
  94. package/core/app.d.ts +1 -1
  95. package/core/app.js +4 -5
  96. package/dialog/dialog.amd.js +1 -1
  97. package/dialog/dialog.amd.js.map +1 -1
  98. package/dialog/dialog.d.ts +1 -1
  99. package/dialog/dialog.js +3 -4
  100. package/extra/extra.amd.js +1 -1
  101. package/extra/extra.amd.js.map +1 -1
  102. package/extra/extra.d.ts +1 -1
  103. package/extra/extra.js.map +1 -1
  104. package/forms/forms.amd.js +1 -1
  105. package/forms/forms.amd.js.map +1 -1
  106. package/forms/forms.d.ts +1 -1
  107. package/forms/forms.js +1 -1
  108. package/formsExt/formsExt.amd.js +1 -1
  109. package/formsExt/formsExt.amd.js.map +1 -1
  110. package/formsExt/formsExt.d.ts +1 -1
  111. package/formsExt/formsExt.js +1 -1
  112. package/icomoon/demo-files/demo.amd.js.map +1 -1
  113. package/icomoon/demo.amd.js.map +1 -1
  114. package/layout/layout.amd.js +1 -1
  115. package/layout/layout.amd.js.map +1 -1
  116. package/layout/layout.d.ts +1 -1
  117. package/layout/layout.js +3 -3
  118. package/layout/layout.js.map +1 -1
  119. package/package.json +1 -1
  120. package/popup/popup.amd.js +1 -1
  121. package/popup/popup.amd.js.map +1 -1
  122. package/popup/popup.d.ts +1 -1
  123. package/popup/popup.js +1 -1
  124. package/popup/worker.amd.js +1 -1
  125. package/popup/worker.amd.js.map +1 -1
  126. package/popup/worker.d.ts +1 -1
  127. package/popup/worker.js +1 -1
  128. package/project/project.amd.js +1 -1
  129. package/project/project.amd.js.map +1 -1
  130. package/project/project.d.ts +1 -1
  131. package/project/project.js +368 -373
  132. package/project/project.js.map +1 -1
  133. package/src/components/dialog/dialog/composables/utils.d.ts +1 -1
  134. package/src/components/formsExt/selector2/cache.d.ts +22 -4
  135. package/src/components/formsExt/selector2/composables/useMenu.d.ts +1 -1
  136. package/src/components/formsExt/selector2/types.d.ts +9 -0
  137. package/src/components/project/groupSelector/folders/utils.d.ts +1 -0
  138. package/src/components/project/groupSelector/groups/types.d.ts +5 -2
  139. package/src/components/project/groupSelector/stories/mocks/groups.d.ts +4 -0
  140. package/src/components/project/groupSelector/stories/mocks/index.d.ts +2 -1
  141. package/src/components/project/groupSelector/types.d.ts +6 -0
  142. package/src/components/project/projectSelector/cache.d.ts +5 -3
  143. package/src/components/project/projectSelector/stories/mocks/index.d.ts +5 -0
  144. package/src/components/project/projectSelector/stories/mocks/projects.d.ts +3 -0
  145. package/src/components/project/projectSelector/utils.d.ts +1 -1
  146. package/src/components/project/regionSelector/utils/utils.d.ts +2 -5
  147. package/src/core/core/core.d.ts +7 -4
  148. package/src/core/core/options.d.ts +6 -0
  149. package/src/core/core/state.d.ts +3 -0
  150. package/src/core/plugins/core.d.ts +4 -5
  151. package/src/core/utils/composables/useEnteties.d.ts +94 -0
  152. package/tabs/tabs.amd.js +1 -1
  153. package/tabs/tabs.amd.js.map +1 -1
  154. package/tabs/tabs.d.ts +1 -1
  155. package/tabs/tabs.js +1 -1
  156. package/tabs/tabs.js.map +1 -1
  157. package/tabsView/tabsView.amd.js +1 -1
  158. package/tabsView/tabsView.amd.js.map +1 -1
  159. package/tabsView/tabsView.d.ts +1 -1
  160. package/tabsView/tabsView.js +6 -6
  161. package/tabsView/tabsView.js.map +1 -1
  162. package/utils/check.amd.js +1 -1
  163. package/utils/check.amd.js.map +1 -1
  164. package/utils/check.d.ts +1 -1
  165. package/utils/check.js.map +1 -1
  166. package/utils/clipboard.amd.js +1 -1
  167. package/utils/clipboard.amd.js.map +1 -1
  168. package/utils/clipboard.d.ts +1 -1
  169. package/utils/clipboard.js +1 -1
  170. package/utils/clipboard.js.map +1 -1
  171. package/utils/date.amd.js +1 -1
  172. package/utils/date.amd.js.map +1 -1
  173. package/utils/date.d.ts +1 -1
  174. package/utils/date.js +1 -1
  175. package/utils/device.amd.js +1 -1
  176. package/utils/device.amd.js.map +1 -1
  177. package/utils/device.d.ts +1 -1
  178. package/utils/device.js +1 -1
  179. package/utils/dom.amd.js +1 -1
  180. package/utils/dom.amd.js.map +1 -1
  181. package/utils/dom.d.ts +3 -3
  182. package/utils/dom.js.map +1 -1
  183. package/utils/image.amd.js +1 -1
  184. package/utils/image.amd.js.map +1 -1
  185. package/utils/image.d.ts +1 -1
  186. package/utils/image.js +1 -1
  187. package/utils/image.js.map +1 -1
  188. package/utils/keyboard.amd.js +1 -1
  189. package/utils/keyboard.amd.js.map +1 -1
  190. package/utils/keyboard.d.ts +1 -1
  191. package/utils/keyboard.js.map +1 -1
  192. package/utils/lodash.amd.js +1 -1
  193. package/utils/lodash.amd.js.map +1 -1
  194. package/utils/lodash.d.ts +1 -1
  195. package/utils/lodash.js +1 -1
  196. package/utils/number.amd.js +1 -1
  197. package/utils/number.amd.js.map +1 -1
  198. package/utils/number.d.ts +1 -1
  199. package/utils/number.js.map +1 -1
  200. package/utils/price.amd.js +1 -1
  201. package/utils/price.amd.js.map +1 -1
  202. package/utils/price.d.ts +1 -1
  203. package/utils/price.js +1 -1
  204. package/utils/price.js.map +1 -1
  205. package/utils/route.amd.js +1 -1
  206. package/utils/route.amd.js.map +1 -1
  207. package/utils/route.d.ts +1 -1
  208. package/utils/route.js.map +1 -1
  209. package/utils/scroll.amd.js +1 -1
  210. package/utils/scroll.amd.js.map +1 -1
  211. package/utils/scroll.d.ts +1 -1
  212. package/utils/scroll.js.map +1 -1
  213. package/utils/searchers.amd.js +1 -1
  214. package/utils/searchers.amd.js.map +1 -1
  215. package/utils/searchers.d.ts +1 -1
  216. package/utils/searchers.js +1 -1
  217. package/utils/searchers.js.map +1 -1
  218. package/utils/store.amd.js +1 -1
  219. package/utils/store.amd.js.map +1 -1
  220. package/utils/store.d.ts +1 -1
  221. package/utils/store.js +1 -1
  222. package/utils/string.amd.js +1 -1
  223. package/utils/string.amd.js.map +1 -1
  224. package/utils/string.d.ts +1 -1
  225. package/utils/string.js +1 -1
  226. package/utils/string.js.map +1 -1
  227. package/utils/system.amd.js +1 -1
  228. package/utils/system.amd.js.map +1 -1
  229. package/utils/system.d.ts +1 -1
  230. package/utils/system.js.map +1 -1
  231. package/utils/url.amd.js +1 -1
  232. package/utils/url.amd.js.map +1 -1
  233. package/utils/url.d.ts +1 -1
  234. package/utils/url.js +1 -1
  235. package/utils/url.js.map +1 -1
  236. package/.chunks/api-DuS0Qura.amd.js.map +0 -1
  237. package/.chunks/app-BXCICBAa.amd.js +0 -2
  238. package/.chunks/app-BXCICBAa.amd.js.map +0 -1
  239. package/.chunks/app-BXCICBAa.esm.js.map +0 -1
  240. package/.chunks/datepicker-BnBQNlTc.amd.js.map +0 -1
  241. package/.chunks/dialog-BPUICFiG.amd.js +0 -2
  242. package/.chunks/dialog-BPUICFiG.amd.js.map +0 -1
  243. package/.chunks/dialog_regionSelectorRegions-BKvg82IO.amd.js +0 -2
  244. package/.chunks/dialog_regionSelectorRegions-BKvg82IO.amd.js.map +0 -1
  245. package/.chunks/dialogs-CbMNuvfF.amd.js +0 -2
  246. package/.chunks/dialogs-CbMNuvfF.amd.js.map +0 -1
  247. package/.chunks/dialogs-CbMNuvfF.esm.js.map +0 -1
  248. package/.chunks/field-CjkpGeA7.amd.js.map +0 -1
  249. package/.chunks/forms-CdCS6WAQ.amd.js +0 -2
  250. package/.chunks/forms-CdCS6WAQ.amd.js.map +0 -1
  251. package/.chunks/forms-CdCS6WAQ.esm.js.map +0 -1
  252. package/.chunks/formsExt-Ck5q-jXI.amd.js +0 -2
  253. package/.chunks/formsExt-Ck5q-jXI.amd.js.map +0 -1
  254. package/.chunks/formsExt-Ck5q-jXI.esm.js.map +0 -1
  255. package/.chunks/lazy-CGswTOPj.amd.js +0 -2
  256. package/.chunks/lazy-CGswTOPj.amd.js.map +0 -1
  257. package/.chunks/lazy-CGswTOPj.esm.js +0 -68
  258. package/.chunks/mocker-CwZe-g4N.amd.js.map +0 -1
  259. package/.chunks/notice-DA4p-RwX.amd.js.map +0 -1
  260. package/.chunks/popup-CN7-bnQJ.amd.js.map +0 -1
  261. package/.chunks/popup-DHCqvZzI.amd.js.map +0 -1
  262. package/.chunks/punycode.es6-B-5kB2YI.amd.js +0 -2
  263. package/.chunks/punycode.es6-B-5kB2YI.amd.js.map +0 -1
  264. package/.chunks/store-DuQpSSLL.amd.js.map +0 -1
  265. package/.chunks/utils-DrvuXyXl.amd.js +0 -2
  266. package/.chunks/utils-DrvuXyXl.amd.js.map +0 -1
  267. package/.chunks/utils-DrvuXyXl.esm.js +0 -43
  268. package/.chunks/utils-DrvuXyXl.esm.js.map +0 -1
  269. package/.chunks/utils-lidKtVjF.amd.js +0 -2
  270. package/.chunks/utils-lidKtVjF.amd.js.map +0 -1
  271. package/.chunks/worker-spLieexQ.amd.js.map +0 -1
  272. package/src/components/charts/miniChart/miniChart.vue.d.ts +0 -15
  273. package/src/components/charts/miniCharts/miniCharts.vue.d.ts +0 -32
  274. package/src/components/core/notice/item/item.vue.d.ts +0 -10
  275. package/src/components/core/notice/notice.vue.d.ts +0 -5
  276. package/src/components/dialog/dialog/dialog.vue.d.ts +0 -28
  277. package/src/components/dialog/dialog/dialogs/dialogs.vue.d.ts +0 -13
  278. package/src/components/dialog/dialog/page/page.vue.d.ts +0 -19
  279. package/src/components/dialog/dialog/pageComponent/pageComponent.vue.d.ts +0 -6
  280. package/src/components/extra/rive/rive.vue.d.ts +0 -11
  281. package/src/components/forms/avatar/avatar.vue.d.ts +0 -10
  282. package/src/components/forms/button/button.vue.d.ts +0 -21
  283. package/src/components/forms/caption/caption.vue.d.ts +0 -17
  284. package/src/components/forms/checkbox/checkbox.vue.d.ts +0 -27
  285. package/src/components/forms/controlLabel/controlLabel.vue.d.ts +0 -19
  286. package/src/components/forms/hint/hint.vue.d.ts +0 -4
  287. package/src/components/forms/input/input.vue.d.ts +0 -25
  288. package/src/components/forms/inputDate/inputDate.vue.d.ts +0 -12
  289. package/src/components/forms/inputRange/inputRange.vue.d.ts +0 -19
  290. package/src/components/forms/loadbar/loadbar.vue.d.ts +0 -3
  291. package/src/components/forms/preloader/preloader.vue.d.ts +0 -4
  292. package/src/components/forms/radio/radio.vue.d.ts +0 -23
  293. package/src/components/forms/select/select.vue.d.ts +0 -30
  294. package/src/components/forms/switcher/switcher.vue.d.ts +0 -23
  295. package/src/components/forms/textarea/textarea.vue.d.ts +0 -12
  296. package/src/components/formsExt/checkboxGroup/checkboxGroup.vue.d.ts +0 -27
  297. package/src/components/formsExt/editArea/editArea.vue.d.ts +0 -31
  298. package/src/components/formsExt/editInput/editInput.vue.d.ts +0 -23
  299. package/src/components/formsExt/info/info.vue.d.ts +0 -20
  300. package/src/components/formsExt/libs/optionGroup/optionGroup.vue.d.ts +0 -16
  301. package/src/components/formsExt/menu/menu.vue.d.ts +0 -16
  302. package/src/components/formsExt/policy/policy.vue.d.ts +0 -8
  303. package/src/components/formsExt/radioGroup/radioGroup.vue.d.ts +0 -27
  304. package/src/components/formsExt/selector2/itemMulti.vue.d.ts +0 -8
  305. package/src/components/formsExt/selector2/selector2.vue.d.ts +0 -62
  306. package/src/components/layout/islandRows/islandRows.vue.d.ts +0 -17
  307. package/src/components/layout/islandRows/islandRowsRow/islandRowsRow.vue.d.ts +0 -18
  308. package/src/components/layout/islandRows/islandRowsSubTitle/islandRowsSubTitle.vue.d.ts +0 -18
  309. package/src/components/layout/rows/rows.vue.d.ts +0 -21
  310. package/src/components/popup/popup/listItem.vue.d.ts +0 -25
  311. package/src/components/popup/popup/opener/opener.vue.d.ts +0 -17
  312. package/src/components/popup/popup/popup.vue.d.ts +0 -38
  313. package/src/components/popup/popup/widgetInput/widgetInput.vue.d.ts +0 -17
  314. package/src/components/popup/popupAlert/popupAlert.vue.d.ts +0 -25
  315. package/src/components/popup/popupConfirm/popupConfirm.vue.d.ts +0 -26
  316. package/src/components/popup/popupHint/popupHint.vue.d.ts +0 -17
  317. package/src/components/popup/popupPrompt/popupPrompt.vue.d.ts +0 -26
  318. package/src/components/project/competitorSelector/competitorSelector.vue.d.ts +0 -14
  319. package/src/components/project/groupSelector/folders/folders.vue.d.ts +0 -18
  320. package/src/components/project/groupSelector/groupSelector.vue.d.ts +0 -205
  321. package/src/components/project/groupSelector/groups/groups.vue.d.ts +0 -146
  322. package/src/components/project/projectSelector/projectSelector.vue.d.ts +0 -132
  323. package/src/components/project/projectSelector/submenu/submenu.vue.d.ts +0 -4
  324. package/src/components/project/regionSelector/dialog_regionSelectorRegions/dialog_regionSelectorRegions.vue.d.ts +0 -6
  325. package/src/components/project/regionSelector/regionSelector.vue.d.ts +0 -23
  326. package/src/components/project/tagSelector/popupListItem/tagPopupListItem.vue.d.ts +0 -20
  327. package/src/components/project/tagSelector/popupOpener/popupOpener.vue.d.ts +0 -27
  328. package/src/components/project/tagSelector/tagIcon/tagIcon.vue.d.ts +0 -4
  329. package/src/components/project/tagSelector/tagSelector.vue.d.ts +0 -38
  330. package/src/components/tabs/tabs/content.vue.d.ts +0 -19
  331. package/src/components/tabs/tabs/tab.vue.d.ts +0 -19
  332. package/src/components/tabs/tabs/tabs.vue.d.ts +0 -21
  333. package/src/components/tabsView/tabsView/menu.vue.d.ts +0 -28
  334. package/src/components/tabsView/tabsView/menuDelimeter.vue.d.ts +0 -3
  335. package/src/components/tabsView/tabsView/menuItem.vue.d.ts +0 -23
  336. package/src/components/tabsView/tabsView/menuTitle.vue.d.ts +0 -20
  337. package/src/components/tabsView/tabsView/tabsView.vue.d.ts +0 -34
@@ -0,0 +1,2 @@
1
+ define([`require`,`exports`,`./forms-DKVIpGnH.amd`,`./field-DEusYVqS.amd`,`../utils/keyboard.amd`,`./popup-CtiL5V44.amd`,`vue`,`./api-D-JuUXVn.amd`,`../require/css.amd!../assets/formsExt.css`],function(e,t,n,r,i,a,o){"use strict";if(s===void 0)var s=window.Vue;Object.defineProperty(t,"__esModule",{value:!0}),t.u=t.t=t.s=t.r=t.o=t.n=t.l=t.i=t.d=t.c=t.a=void 0;var c={key:0,class:`top-menu_selectAll`},l=(0,o.defineComponent)({__name:`menu`,props:(0,o.mergeModels)({modelValue:{},items:{},isMultiple:{type:Boolean},canBeEmptyMultiple:{type:Boolean},styling:{default:`default`},selectAllItem:{}},{modelValue:{required:!0},modelModifiers:{}}),emits:[`update:modelValue`],setup(e){let t=e,r=(0,o.useModel)(e,`modelValue`),i=(0,o.ref)();!t.isMultiple&&typeof r.value!=`string`&&typeof r.value!=`number`&&console.warn(`Type check failed for prop "modelValue". Expected String: `+typeof r.value),t.isMultiple&&!Array.isArray(r.value)&&console.warn(`Type check failed for prop "modelValue". Expected Array: `+typeof r.value),t.isMultiple&&!t.canBeEmptyMultiple&&Array.isArray(r.value)&&!r.value.length&&t.items[0]&&(r.value=[t.items[0]?.href??t.items[0]?.value]);let a=e=>Array.isArray(r.value)?r.value.includes(e.value):e.value===r.value,s=(e,n=!1)=>{if(Array.isArray(r.value)){let i=r.value.slice();if(n){i.length||(i=t.items.map(e=>e.value));let n=i.indexOf(e.value);n===-1?i.push(e.value):i.splice(n,1)}else i=i.length===1&&i[0]===e.value?[]:[e.value];!t.canBeEmptyMultiple&&!i.length&&(i=[e.value]),r.value=i;return}r.value=e.value},l=e=>{if(i.value.scrollWidth<=i.value.offsetWidth||e.shiftKey||Math.abs(e.deltaY)<50)return;e.preventDefault();let t=e.deltaY>0?30:-30;i.value.scrollLeft=i.value.scrollLeft+t},u=(e=!0)=>{let t=i.value.querySelector(`.top-active`);if(!t)return;let r=t.offsetLeft-i.value.offsetLeft-24,a=t.offsetLeft-i.value.offsetLeft+t.clientWidth+24,o=i.value.scrollLeft,s=i.value.clientWidth+i.value.scrollLeft,c;r<o&&(c=r),a>s&&(c=a-i.value.clientWidth),c!==void 0&&((0,n.G)()?n.O.$?.(i.value).animate({scrollLeft:c},e?200:0):i.value.scrollTo({left:c,behavior:e?`smooth`:`auto`}))},d=()=>{if(Array.isArray(r.value)){if(r.value.length===t.items.length){r.value=[t.items[0].href??t.items[0].value];return}r.value=t.items.map(e=>e.href??e.value)}};return(0,o.onMounted)(()=>u(!1)),(0,o.onUpdated)(()=>u(!0)),(t,u)=>((0,o.openBlock)(),(0,o.createElementBlock)(`div`,{ref_key:`el`,ref:i,class:(0,o.normalizeClass)({"top-menu":!0,[`top-style_`+e.styling]:!0}),onWheel:l},[((0,o.openBlock)(!0),(0,o.createElementBlock)(o.Fragment,null,(0,o.renderList)(e.items,e=>((0,o.openBlock)(),(0,o.createBlock)(n.h,(0,o.mergeProps)({ref_for:!0},e,{class:`top-menu_item`,color:`theme`,onClick:t=>s(e,t.ctrlKey||t.metaKey),isActive:a(e)}),(0,o.createSlots)({_:2},[e.content?{name:`default`,fn:(0,o.withCtx)(()=>[(0,o.createTextVNode)((0,o.toDisplayString)(e.content),1)]),key:`0`}:void 0]),1040,[`onClick`,`isActive`]))),256)),Array.isArray(r.value)&&e.selectAllItem?((0,o.openBlock)(),(0,o.createElementBlock)(`div`,c,[(0,o.createVNode)(n.h,(0,o.mergeProps)(e.selectAllItem,{class:`top-menu_item`,color:`theme`,styling:``,onClick:u[0]||=e=>d(),isActive:r.value.length===e.items.length}),(0,o.createSlots)({_:2},[e.selectAllItem.content?{name:`default`,fn:(0,o.withCtx)(()=>[(0,o.createTextVNode)((0,o.toDisplayString)(e.selectAllItem.content),1)]),key:`0`}:void 0]),1040,[`isActive`])])):(0,o.createCommentVNode)(``,!0)],34))}}),u={class:`top-selector2_itemMulti top-ellipsis`},d=(0,o.defineComponent)({__name:`itemMulti`,props:{id:{},name:{}},emits:[`delete`],setup(e){return(t,n)=>((0,o.openBlock)(),(0,o.createElementBlock)(`div`,u,[(0,o.createTextVNode)((0,o.toDisplayString)(e.name)+` `,1),(0,o.createElementVNode)(`span`,{class:`top-selector2_itemMultiDelete`,"data-top-icon":``,onClick:n[0]||=n=>t.$emit(`delete`,{id:e.id,name:e.name}),onMousedown:n[1]||=(0,o.withModifiers)(()=>{},[`stop`])},null,32)]))}}),f=new Map,p=new Map,m=e=>(p.has(e)||p.set(e,(0,o.ref)(0)),p.get(e)),h=e=>{m(e).value++},g=e=>{f.get(e)?.clear(),h(e)},_=(e,t)=>{let n=f.get(e);if(n)for(let e of n.values())t(e,e.result)},v=e=>{let t=window.mo?.user?.id;return JSON.stringify(e.params)+`:`+e.url+`:`+t},y=(e,t)=>f.get(t)?.get(e),b=(e,t,n)=>{f.has(t)||f.set(t,new Map),f.get(t)?.set(e,n)},x=(e,t,n)=>{_(e,(e,r)=>{let i=r.find(e=>e.id===t);i&&Object.assign(i,n)}),h(e)},S=(e,t)=>{_(e,(e,n)=>{let r=n.findIndex(e=>e.id===t);r!==-1&&(n[r].name=`--`,n.splice(r,1),e.nextOffset&&e.nextOffset--)}),h(e)},C=(e,t,r,i)=>{let a=(0,o.ref)([]),s=(0,o.ref)(!1),c=(0,o.ref)(0),l=``,u;e&&!e.params.limit&&(e.params.limit=100);let d=()=>{if(!e)return;e.params.offset=0;let t=y(v(e),e.path);if(!t){a.value=[],u=void 0;return}a.value=t.result,u=t.nextOffset};e&&i&&(0,o.watch)(m(e.path),()=>{d()});let f=async()=>{if(!e)return;let t=i?v(e):void 0;if(t){let n=y(t,e.path);if(n)return e.abortByFingerprint(),n}let n=await e.call();if(n.errors)return;if(!Array.isArray(n.result)){console.warn("Array expected in `res.result`");return}let r=n.result.findIndex(e=>e.id===void 0||e.name===void 0);if(r!==-1){console.warn(`В result[${r}] нет id или name`);return}return t&&b(t,e.path,n),n},p=async n=>{if(!e)return;if(n){if(!u||s.value)return;e.params.offset=u}else e.params.offset=0;t?.(e,l),s.value=!0;let r=await f();s.value=!1,c.value++,r&&(u=r.nextOffset,n?a.value=a.value.concat(r.result):a.value=r.result)},h=(0,n.P)(()=>p(!1),200);return{apiRequest:e,items:a,isLoading:s,countLoading:c,load:p,setSearchTextAndLoad:(t,n=!0)=>{if(e){if(t.length<r){e.abortByFingerprint(),a.value=[];return}t===l&&a.value.length||(l=t,n?h():p(!1))}}}},w=0,T=null,E=(e,t,n=!0)=>n&&t.id===null?Array.isArray(e)?e.some(e=>e.id===t.id&&e.name===t.name):t.name===e.name:Array.isArray(e)?e.some(e=>e.id===t.id):t.id===e.id,D=(e,t,n)=>{let i=e.params.filters??[];i=i.filter(e=>e.name!==n),t&&i.push((0,r.t)(n,`CONTAINS`,[t])),e.changeParams({filters:i})},O=(e,t,r,a,s,c,l,u,d,f,p,m,h,g)=>{let _=(0,o.ref)(``),v={id:0,name:(0,n.E)().Common.All},y=()=>{_.value=``},b=()=>!(!g.apiRequest||_.value.length>=h),x=(0,o.computed)(()=>{let e=[];return!s&&c.value&&(typeof c.value==`string`&&(v.name=c.value),e.push(v)),r.value?.forEach(t=>e.push({...t})),e}),S=(0,o.ref)([]),C=()=>{S.value=w()},w=()=>{let t=_.value.toLowerCase(),n=(0,i.invertKeyboardLayout)(t),r=[],o,c=[],m=()=>{c.at(-1)?.listItemProps?.type===`delimiter`&&c.pop(),c.length&&=(o&&r.push(o),r.push(...c),0)},h=e=>{let r=p.value?.includes(`id`),i=e.name.toLowerCase(),a=p.value?.filter(e=>e!==`id`).map(t=>typeof e[t]==`string`||typeof e[t]==`number`?e[t]:``).join(`☼`).toLowerCase();(r&&e.id===Number(t)||a?.includes(t)||a?.includes(n))&&(i===t||i===n?c.unshift(e):c.push(e))};for(let e of x.value)switch(e.listItemProps?.type){case`title`:m(),o=e;break;case`delimiter`:if(c.length){let t=c.length;c.at(-1)?.listItemProps?.type===`delimiter`&&t--,c[t]=e}break;default:h(e)}if(m(),r.push(...g.items.value),l.value&&_.value&&(!d.value||d.value(t))&&(u.value||!r.find(e=>e.name.toLowerCase()===t))){let e={id:null,name:_.value};f.value&&(e.listItemProps={closeByClick:!1}),r.push(e)}return s&&(r=r.filter(t=>!E(e.value,t))),a&&(r=a(r)),r},T=n=>{n.listItemProps?.type===`title`||n.listItemProps?.type===`delimiter`||n.id===null&&(t(`appendItem`,n),f.value)||(s&&Array.isArray(e.value)?E(e.value,n)||(e.value=[...e.value,n]):e.value=n,setTimeout(()=>{y()}))};if(g.apiRequest){let t=[r,g.items];s&&t.push(e),(0,o.watch)(t,()=>{C()},{deep:2})}else(0,o.watch)([e,r,_],()=>{C()},{immediate:!0,deep:2});return{searchText:_,resetSearch:y,genIsShort:b,itemsForShow:S,selectItem:T,selectNextItem:()=>{if(Array.isArray(e.value))return;let t=S.value.filter(e=>![`title`,`delimiter`].includes(e.listItemProps?.type??``));e.value={...t[(t.findIndex(t=>t.id===e.value.id)+1)%t.length]}},deleteItemByItem:async t=>{Array.isArray(e.value)&&(e.value=e.value.filter(e=>e.id!==t.id||e.name!==t.name))}}},k={key:0,class:`top-selector2_activeItems`},A={key:1,class:`top-selector2_activeName top-ellipsis`},j={key:2,class:`top-selector2_placeholder top-ellipsis`},M={class:`top-selector2_searchWidget`},N=(0,o.defineComponent)({__name:`selector2`,props:(0,o.mergeModels)({modelValue:{},items:{default:()=>[]},title:{},disabled:{type:Boolean},icon:{},modificator:{},size:{default:`s`},isError:{type:Boolean},openByFocusInput:{type:Boolean,default:void 0},searchType:{default:`popup`},searchFields:{default:()=>[`id`,`name`]},placeholder:{},hasCloserBtn:{type:Boolean},prepareItemsBeforeRender:{},api:{},apiSetSearchParams:{},minLength:{default:0},useCache:{type:Boolean},appendSearchToResult:{type:Boolean},appendSearchAllowDuplicate:{type:Boolean},appendSearchToResultCond:{},appendWithoutSelect:{type:Boolean},multiselect:{type:Boolean},useAllItem:{type:[Boolean,String]},addChanger:{type:Boolean},buttonProps:{},selectedAsPlaceholder:{type:Boolean},openerShortcut:{}},{modelValue:{required:!0},modelModifiers:{}}),emits:(0,o.mergeModels)([`appendItem`,`open`],[`update:modelValue`]),setup(e,{expose:t,emit:r}){let i=e,s=(0,o.useModel)(e,`modelValue`),c=r;t({resetCache:(e=!1)=>{u.apiRequest&&(e&&g(u.apiRequest.path),u.items.value=[],u.countLoading.value=0,u.apiRequest.params.offset=0,requestAnimationFrame(()=>{f.itemsForShow.value=[]}),h()?.elPopup&&u.setSearchTextAndLoad(f.searchText.value))},updateCacheItemById:(e,t)=>{u.apiRequest&&u.apiRequest&&x(u.apiRequest.path,e,t)},deleteCacheItemById:e=>{u.apiRequest&&u.apiRequest&&S(u.apiRequest.path,e)}});let l=(0,o.computed)(()=>i.searchType===`inline`&&i.multiselect||i.searchType===`inline`&&n.O.state.isMobile?`popup`:i.searchType),u=C(i.api,i.apiSetSearchParams,i.minLength,i.useCache),f=O(s,c,(0,o.toRef)(i,`items`),i.prepareItemsBeforeRender,i.multiselect,(0,o.toRef)(i,`useAllItem`),(0,o.toRef)(i,`appendSearchToResult`),(0,o.toRef)(i,`appendSearchAllowDuplicate`),(0,o.toRef)(i,`appendSearchToResultCond`),(0,o.toRef)(i,`appendWithoutSelect`),(0,o.toRef)(i,`searchFields`),l,i.minLength,u),p=(0,o.computed)(()=>i.buttonProps?`TopButton`:l.value===`inline`?`TopInput`:`div`),m=(0,o.ref)(null),h=()=>m.value?.popup;u.apiRequest&&(0,o.watch)(f.searchText,()=>{u.setSearchTextAndLoad(f.searchText.value)});let _=(0,o.computed)(()=>Array.isArray(s.value)||i.multiselect||!i.selectedAsPlaceholder&&l.value!==`inline`?i.placeholder:s.value?.name||i.placeholder),v=e=>{let t=!1;switch(e.key){case`Delete`:case`Backspace`:Array.isArray(s.value)&&(e.preventDefault(),e.stopPropagation(),s.value.pop());break;case`ArrowUp`:case`ArrowRight`:case`ArrowDown`:case`ArrowLeft`:case`Enter`:case` `:t=!0;break;case`Escape`:l.value===`inline`&&f.resetSearch();break}let n=e.key.length===1&&!e.ctrlKey&&!e.metaKey;(l.value===`popup`||l.value===`inline`)&&n&&(t=!0),h()?.elPopup&&(t=!1),t&&(l.value===`popup`&&(e.preventDefault(),e.stopPropagation(),n&&(f.searchText.value||(f.searchText.value=e.key))),e.currentTarget?.click())},y=e=>{e.preventDefault(),f.selectNextItem()},b=()=>{u.apiRequest&&u.setSearchTextAndLoad(f.searchText.value,!1),c(`open`)},w=()=>{l.value===`popup`&&f.searchText.value&&f.resetSearch()},T=e=>{let t=e.target;t.scrollTop/(t.scrollHeight-t.offsetHeight)>.8&&u.load(!0)};return(t,r)=>{let i=(0,o.resolveComponent)(`TopButton`),c=(0,o.resolveComponent)(`TopLoadbar`),h=(0,o.resolveDirective)(`top-focus`),g=(0,o.resolveDirective)(`top-shortcut`);return(0,o.openBlock)(),(0,o.createBlock)((0,o.unref)(a.s),{ref_key:`popupRef`,ref:m,onOpen:r[3]||=e=>b(),onClose:r[4]||=e=>w(),onScrollContentList:r[5]||=e=>(0,o.unref)(u)?T(e):void 0,notch:!1,transitionDuration:0,openByFocusInput:l.value===`inline`&&(e.openByFocusInput??!0),disabled:l.value===`inline`&&(0,o.unref)(f).genIsShort()},(0,o.createSlots)({opener:(0,o.withCtx)(()=>[(0,o.withDirectives)(((0,o.openBlock)(),(0,o.createBlock)((0,o.resolveDynamicComponent)(p.value),(0,o.mergeProps)(e.buttonProps,{class:{"top-selector2":!0,"top-selector2-multiselect":e.multiselect,[`top-selector2-`+e.modificator]:!!e.modificator,"top-as-input":!e.buttonProps&&l.value!==`inline`,"top-as-selector":!0,[`top-size_`+e.size]:!0,"top-disabled":e.disabled,"top-forms-focusable":!e.disabled,"top-error":e.isError},icon:e.icon,tabindex:`0`,onKeydown:v,onBlur:r[0]||=e=>l.value===`inline`&&(0,o.unref)(f).resetSearch(),placeholder:_.value,title:e.title,captionType:l.value===`inline`&&e.title!==void 0?`top`:void 0,modelValue:(0,o.unref)(f).searchText.value,"onUpdate:modelValue":r[1]||=e=>(0,o.unref)(f).searchText.value=e}),{default:(0,o.withCtx)(()=>[e.multiselect?((0,o.openBlock)(),(0,o.createElementBlock)(`div`,k,[((0,o.openBlock)(!0),(0,o.createElementBlock)(o.Fragment,null,(0,o.renderList)(s.value,e=>((0,o.openBlock)(),(0,o.createBlock)(d,{key:e.id??void 0,id:e.id,name:e.name,onDelete:(0,o.unref)(f).deleteItemByItem},null,8,[`id`,`name`,`onDelete`]))),128))])):(0,o.createCommentVNode)(``,!0),l.value!==`inline`&&!e.multiselect?((0,o.openBlock)(),(0,o.createElementBlock)(`span`,A,(0,o.toDisplayString)(Array.isArray(s.value)?``:s.value.name),1)):(0,o.createCommentVNode)(``,!0),e.multiselect&&!s.value.length?((0,o.openBlock)(),(0,o.createElementBlock)(`span`,j,(0,o.toDisplayString)(_.value),1)):(0,o.createCommentVNode)(``,!0),e.addChanger&&!e.buttonProps&&!e.multiselect&&(0,o.unref)(f).itemsForShow.value.length>1&&!e.disabled?((0,o.openBlock)(),(0,o.createElementBlock)(`span`,{key:3,class:`top-changer top-changer-selector`,"data-top-popup-disabled":`true`,onClick:y})):(0,o.createCommentVNode)(``,!0)]),_:1},16,[`class`,`icon`,`placeholder`,`title`,`captionType`,`modelValue`])),[[h,e.isError,void 0,{onupdate:!0}],[g,e.openerShortcut]])]),contentList:(0,o.withCtx)(()=>[((0,o.openBlock)(!0),(0,o.createElementBlock)(o.Fragment,null,(0,o.renderList)((0,o.unref)(f).itemsForShow.value,r=>((0,o.openBlock)(),(0,o.createBlock)((0,o.unref)(a.o),(0,o.mergeProps)({key:r.id??void 0,class:{"top-active":!Array.isArray(s.value)&&!e.multiselect&&s.value.id===r.id&&s.value.name===r.name,"top-selector2_item-all":r.id===(0,o.unref)(0),"top-selector2_item-new":r.id===(0,o.unref)(null)},closeByClick:!e.multiselect||(0,o.unref)(n.O).state.isMobile},{ref_for:!0},r.listItemProps,{onClick:e=>(0,o.unref)(f).selectItem(r)}),(0,o.createSlots)({default:(0,o.withCtx)(()=>[t.$slots.item?(0,o.renderSlot)(t.$slots,`item`,{key:0,item:r}):((0,o.openBlock)(),(0,o.createElementBlock)(o.Fragment,{key:1},[(0,o.createTextVNode)((0,o.toDisplayString)(r.name),1)],64))]),_:2},[t.$slots.actions?{name:`actions`,fn:(0,o.withCtx)(()=>[(0,o.renderSlot)(t.$slots,`actions`,{item:r})]),key:`0`}:void 0]),1040,[`class`,`closeByClick`,`onClick`]))),128)),!(0,o.unref)(f).itemsForShow.value.length&&!(0,o.unref)(f).genIsShort()?((0,o.openBlock)(),(0,o.createBlock)((0,o.unref)(a.o),{key:0,type:`regular`},{default:(0,o.withCtx)(()=>[!(0,o.unref)(u).isLoading.value||(0,o.unref)(u).countLoading.value?((0,o.openBlock)(),(0,o.createElementBlock)(o.Fragment,{key:0},[(0,o.createTextVNode)((0,o.toDisplayString)(t.$i18n.Common.No_results),1)],64)):((0,o.openBlock)(),(0,o.createBlock)((0,o.unref)(n.t),{key:1,type:`circles`}))]),_:1})):(0,o.createCommentVNode)(``,!0),(0,o.unref)(u).countLoading.value&&(0,o.unref)(u).isLoading.value&&l.value===`inline`?((0,o.openBlock)(),(0,o.createBlock)(c,{key:1})):(0,o.createCommentVNode)(``,!0)]),_:2},[l.value===`popup`?{name:`widget`,fn:(0,o.withCtx)(()=>[(0,o.createElementVNode)(`div`,M,[(0,o.withDirectives)((0,o.createVNode)((0,o.unref)(a.a),{title:`Поиск`,icon:``,modelValue:(0,o.unref)(f).searchText.value,"onUpdate:modelValue":r[2]||=e=>(0,o.unref)(f).searchText.value=e,isLoading:!!(0,o.unref)(u).countLoading.value&&(0,o.unref)(u).isLoading.value,placeholder:_.value},null,8,[`modelValue`,`isLoading`,`placeholder`]),[[h,s.value,void 0,{onupdate:!0}]]),e.hasCloserBtn&&!t.$core.state.isMobile?((0,o.openBlock)(),(0,o.createBlock)(i,{key:0,class:`closer`,color:`theme`},{default:(0,o.withCtx)(()=>[(0,o.createTextVNode)((0,o.toDisplayString)(t.$i18n.Common.Cancel),1)]),_:1})):(0,o.createCommentVNode)(``,!0)])]),key:`0`}:void 0]),1032,[`openByFocusInput`,`disabled`])}}}),P={class:`top-editArea_footer`},F=(0,o.defineComponent)({__name:`editArea`,props:{defaultValue:{default:``},title:{},cancelText:{default:`Cancel`},submitText:{default:`Send`},closeText:{default:`Close`},isFocused:{type:Boolean},forceShowCloseBtn:{type:Boolean},attachToKeyboard:{type:Boolean},modelValue:{},name:{},placeholder:{},styling:{},rows:{},minHeight:{},expandable:{type:Boolean,default:!0},disabled:{type:Boolean},readonly:{type:Boolean},isError:{type:Boolean},hint:{},maxLength:{}},emits:[`submit`,`close`,`clickOnTitle`],setup(e,{emit:t}){let r=e,i=t,a=(0,o.ref)(r.defaultValue),s=(0,o.ref)(r.isFocused),c=(0,o.computed)(()=>a.value!==r.defaultValue),l=e=>{i(`submit`,e),a.value=r.defaultValue},u=()=>{if(r.forceShowCloseBtn&&!c.value){i(`close`);return}a.value=r.defaultValue},d=()=>{r.attachToKeyboard&&i(`clickOnTitle`)};return(t,r)=>((0,o.openBlock)(),(0,o.createElementBlock)(`div`,{class:(0,o.normalizeClass)({"top-editArea":!0,"top-editArea-attachedToKeyboard":e.attachToKeyboard})},[e.title||t.$slots.caption?((0,o.openBlock)(),(0,o.createElementBlock)(`div`,{key:0,class:`top-editArea_caption`,onClick:r[0]||=e=>d()},[(0,o.renderSlot)(t.$slots,`caption`,{},()=>[(0,o.createTextVNode)((0,o.toDisplayString)(e.title),1)])])):(0,o.createCommentVNode)(``,!0),(0,o.createElementVNode)(`div`,{class:(0,o.normalizeClass)({"top-editArea_form":!0,"top-forms-focusable":!0,"top-as-input":!0,"top-error":e.isError,"top-focus":s.value})},[(0,o.createVNode)(n.r,{modelValue:a.value,"onUpdate:modelValue":r[1]||=e=>a.value=e,name:e.name,placeholder:e.placeholder,rows:e.rows,minHeight:e.minHeight,expandable:e.expandable,disabled:e.disabled,readonly:e.readonly,isError:e.isError,hint:e.hint,class:`top-editArea_element`,onFocus:r[2]||=()=>s.value=!0,onBlur:r[3]||=()=>s.value=!1,onKeyup:[(0,o.withKeys)(u,[`esc`]),r[4]||=(0,o.withKeys)((0,o.withModifiers)(e=>l(a.value),[`ctrl`]),[`enter`])]},null,8,[`modelValue`,`name`,`placeholder`,`rows`,`minHeight`,`expandable`,`disabled`,`readonly`,`isError`,`hint`]),(0,o.createElementVNode)(`div`,P,[c.value||e.forceShowCloseBtn?((0,o.openBlock)(),(0,o.createBlock)(n.h,{key:0,icon:t.$core.state.isMobile?``:``,class:`top-editArea_button`,color:`theme`,styling:`soft`,onClick:u},(0,o.createSlots)({_:2},[t.$core.state.isMobile?void 0:{name:`default`,fn:(0,o.withCtx)(()=>[(0,o.createTextVNode)((0,o.toDisplayString)(e.cancelText),1)]),key:`0`}]),1032,[`icon`])):(0,o.createCommentVNode)(``,!0),c.value?((0,o.openBlock)(),(0,o.createBlock)(n.h,{key:1,class:`top-editArea_button`,icon:t.$core.state.isMobile?``:``,onClick:r[5]||=e=>l(a.value)},(0,o.createSlots)({_:2},[t.$core.state.isMobile?void 0:{name:`default`,fn:(0,o.withCtx)(()=>[(0,o.createTextVNode)((0,o.toDisplayString)(e.submitText),1)]),key:`0`}]),1032,[`icon`])):(0,o.createCommentVNode)(``,!0)])],2)],2))}}),I={class:`top-editInput`},L=(0,o.defineComponent)({__name:`editInput`,props:{modelValue:{},alwaysShowSubmitBtn:{type:Boolean},input:{},button:{}},emits:[`update:modelValue`],setup(e,{emit:t}){let r=e,i=(0,o.ref)(r.modelValue);(0,o.watch)(()=>r.modelValue,()=>{i.value=r.modelValue});let a=t,s=()=>{a(`update:modelValue`,i.value)};return(t,r)=>((0,o.openBlock)(),(0,o.createElementBlock)(`div`,I,[(0,o.createVNode)(n.c,(0,o.mergeProps)(e.input,{onKeydownCapture:r[0]||=(0,o.withKeys)((0,o.withModifiers)(t=>i.value=e.modelValue,[`stop`]),[`esc`]),onKeydown:(0,o.withKeys)((0,o.withModifiers)(s,[`stop`]),[`enter`]),modelValue:i.value,"onUpdate:modelValue":r[1]||=e=>i.value=e}),(0,o.createSlots)({_:2},[t.$slots.caption?{name:`caption`,fn:(0,o.withCtx)(()=>[(0,o.renderSlot)(t.$slots,`caption`)]),key:`0`}:void 0]),1040,[`onKeydown`,`modelValue`]),i.value!==e.modelValue||e.alwaysShowSubmitBtn?((0,o.openBlock)(),(0,o.createBlock)(n.h,(0,o.mergeProps)({key:0,icon:``,styling:`soft`},e.button,{onClick:s}),null,16)):(0,o.createCommentVNode)(``,!0)]))}}),R=(0,o.defineComponent)({__name:`optionGroup`,props:(0,o.mergeModels)({modelValue:{},items:{},size:{default:`s`},showIndicator:{type:Boolean},isError:{type:Boolean}},{modelValue:{required:!0},modelModifiers:{}}),emits:[`update:modelValue`],setup(e){let t=(0,o.useModel)(e,`modelValue`),r=e,i=(0,o.ref)(null);(0,o.watch)(t,()=>{let e=r.items.map(e=>e.value);Array.isArray(t.value)?t.value.find(t=>!e.includes(t))&&(t.value=t.value.filter(t=>e.includes(t))):e.includes(t.value)||(t.value=e[0]??``),i.value?.querySelector(`.radioGroup_item-selected`)?.scrollIntoView()},{immediate:!0});let a=`optionGroup-`+Math.random();return(r,s)=>((0,o.openBlock)(),(0,o.createElementBlock)(`div`,{ref_key:`elRef`,ref:i,class:(0,o.normalizeClass)({"top-optionGroup":!0,[`top-optionGroup-showIndicator_`+Number(e.showIndicator)]:!0,"top-scrollBarXHidding":!0,[`top-size_`+e.size]:!!e.size,"top-error":e.isError})},[Array.isArray(t.value)?((0,o.openBlock)(!0),(0,o.createElementBlock)(o.Fragment,{key:0},(0,o.renderList)(e.items,r=>((0,o.openBlock)(),(0,o.createBlock)(n.f,{class:(0,o.normalizeClass)({"top-optionGroup_item-selected":t.value.includes(r.value),"top-optionGroup_item":!0}),modelValue:t.value,"onUpdate:modelValue":s[0]||=e=>t.value=e,value:r.value,title:r.title,disabled:r.disabled,isError:e.isError,"data-top-icon":r.icon},(0,o.createSlots)({_:2},[r.label?{name:`default`,fn:(0,o.withCtx)(()=>[(0,o.createTextVNode)((0,o.toDisplayString)(r.label),1)]),key:`0`}:void 0]),1032,[`class`,`modelValue`,`value`,`title`,`disabled`,`isError`,`data-top-icon`]))),256)):((0,o.openBlock)(!0),(0,o.createElementBlock)(o.Fragment,{key:1},(0,o.renderList)(e.items,r=>((0,o.openBlock)(),(0,o.createBlock)(n.a,{class:(0,o.normalizeClass)({"top-optionGroup_item-selected":r.value===t.value,"top-optionGroup_item":!0}),modelValue:t.value,"onUpdate:modelValue":s[1]||=e=>t.value=e,name:a,value:r.value,title:r.title,disabled:r.disabled,isError:e.isError,"data-top-icon":r.icon},(0,o.createSlots)({_:2},[r.label?{name:`default`,fn:(0,o.withCtx)(()=>[(0,o.createTextVNode)((0,o.toDisplayString)(r.label),1)]),key:`0`}:void 0]),1032,[`class`,`modelValue`,`value`,`title`,`disabled`,`isError`,`data-top-icon`]))),256))],2))}}),z=(0,o.defineComponent)({__name:`radioGroup`,props:(0,o.mergeModels)({modelValue:{},items:{},size:{},showIndicator:{type:Boolean},isError:{type:Boolean}},{modelValue:{required:!0},modelModifiers:{}}),emits:[`update:modelValue`],setup(e){let t=(0,o.useModel)(e,`modelValue`);return(e,n)=>((0,o.openBlock)(),(0,o.createBlock)(R,{class:`top-radioGroup`,modelValue:t.value,"onUpdate:modelValue":n[0]||=e=>t.value=e,items:e.$props.items,size:e.$props.size,showIndicator:e.$props.showIndicator,isError:e.$props.isError},{default:(0,o.withCtx)(()=>[(0,o.renderSlot)(e.$slots,`default`)]),_:3},8,[`modelValue`,`items`,`size`,`showIndicator`,`isError`]))}}),B=(0,o.defineComponent)({__name:`checkboxGroup`,props:(0,o.mergeModels)({modelValue:{},items:{},size:{},showIndicator:{type:Boolean},isError:{type:Boolean}},{modelValue:{required:!0},modelModifiers:{}}),emits:[`update:modelValue`],setup(e){let t=(0,o.useModel)(e,`modelValue`);return(e,n)=>((0,o.openBlock)(),(0,o.createBlock)(R,{class:`top-checkboxGroup`,modelValue:t.value,"onUpdate:modelValue":n[0]||=e=>t.value=e,items:e.$props.items,size:e.$props.size,showIndicator:e.$props.showIndicator,isError:e.$props.isError},{default:(0,o.withCtx)(()=>[(0,o.renderSlot)(e.$slots,`default`)]),_:3},8,[`modelValue`,`items`,`size`,`showIndicator`,`isError`]))}}),V=[`data-top-icon`],H={class:`top-info_text`},U={key:0,class:`top-info_value`},W=(0,o.defineComponent)({__name:`info`,props:{icon:{},styling:{default:`default`},size:{default:`default`}},setup(e){return(t,n)=>((0,o.openBlock)(),(0,o.createElementBlock)(`div`,{class:(0,o.normalizeClass)({"top-info":!0,[`top-size_`+e.size]:!0,[`top-info-styling_`+e.styling]:!0}),"data-top-icon":e.icon},[(0,o.createElementVNode)(`div`,H,[(0,o.renderSlot)(t.$slots,`default`)]),t.$slots.additional?((0,o.openBlock)(),(0,o.createElementBlock)(`span`,U,[(0,o.renderSlot)(t.$slots,`additional`)])):(0,o.createCommentVNode)(``,!0)],10,V))}}),G={key:0,class:`top-policy`},K={class:`top-policy_title`},q=[`innerHTML`],J=(0,o.defineComponent)({__name:`policy`,props:{title:{},description:{},acceptText:{}},emits:[`accept`],setup(e,{emit:t}){let r=t,i=(0,o.ref)(!0),a=()=>{i.value=!1,r(`accept`)};return(t,r)=>i.value?((0,o.openBlock)(),(0,o.createElementBlock)(`div`,G,[(0,o.createElementVNode)(`div`,K,(0,o.toDisplayString)(e.title),1),(0,o.createElementVNode)(`div`,{class:`top-policy_description`,innerHTML:e.description},null,8,q),(0,o.createVNode)((0,o.unref)(n.h),{size:`m`,onClick:a},{default:(0,o.withCtx)(()=>[(0,o.createTextVNode)((0,o.toDisplayString)(e.acceptText),1)]),_:1})])):(0,o.createCommentVNode)(``,!0)}});t.d=l,t.c=w,t.l=T,t.u=D,t.s=N,t.o=F,t.a=L,t.i=z,t.r=B,t.n=W,t.t=J});
2
+ //# sourceMappingURL=formsExt-Dy7EHtJS.amd.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[".chunks/formsExt-Dy7EHtJS.esm.js","../../src/components/formsExt/menu/menu.vue","../../src/components/formsExt/selector2/itemMulti.vue","../../src/components/formsExt/selector2/cache.ts","../../src/components/formsExt/selector2/composables/useAPI.ts","../../src/components/formsExt/selector2/utils.ts","../../src/components/formsExt/selector2/composables/useMenu.ts","../../src/components/formsExt/selector2/selector2.vue","../../src/components/formsExt/editArea/editArea.vue","../../src/components/formsExt/editInput/editInput.vue","../../src/components/formsExt/libs/optionGroup/optionGroup.vue","../../src/components/formsExt/radioGroup/radioGroup.vue","../../src/components/formsExt/checkboxGroup/checkboxGroup.vue","../../src/components/formsExt/info/info.vue","../../src/components/formsExt/policy/policy.vue"],"names":["vue","exports","G","te","vue_1","r","i","a","o","c","n","t","s","l","forms_DKVIpGnH_esm_js_1","ne","re","K","q","J","Y","ie","X","Z","Q","ae","oe","se","ce","u","d","f","p","le","ue","$","de","field_DEusYVqS_esm_js_1","fe","h","m","e","keyboard_js_1","g","pe","me","he","ge","_e","T","w","D","O","k","U","W","popup_CtiL5V44_esm_js_1","$slots","$core","ve","ye","be","xe","Se","Ce","$props","we","Te","Ee","De","Oe","ke","Ae","je","Me"],"mappings":"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","sourcesContent":["define([\"require\", \"exports\", \"./forms-DKVIpGnH.esm.js\", \"./field-DEusYVqS.esm.js\", \"../utils/keyboard.js\", \"./popup-CtiL5V44.esm.js\", \"vue\", \"./api-D-JuUXVn.esm.js\"], function (require, exports, forms_DKVIpGnH_esm_js_1, field_DEusYVqS_esm_js_1, keyboard_js_1, popup_CtiL5V44_esm_js_1, vue_1) {\n \"use strict\";\n Object.defineProperty(exports, \"__esModule\", { value: true });\n exports.u = exports.t = exports.s = exports.r = exports.o = exports.n = exports.l = exports.i = exports.d = exports.c = exports.a = void 0;\n //#region src/components/formsExt/menu/menu.vue?vue&type=script&setup=true&lang.ts\n var G = {\n key: 0,\n class: \"top-menu_selectAll\"\n }, te = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"menu\",\n props: /*@__PURE__*/ (0, vue_1.mergeModels)({\n modelValue: {},\n items: {},\n isMultiple: { type: Boolean },\n canBeEmptyMultiple: { type: Boolean },\n styling: { default: \"default\" },\n selectAllItem: {}\n }, {\n modelValue: { required: !0 },\n modelModifiers: {}\n }),\n emits: [\"update:modelValue\"],\n setup(e) {\n let r = e, i = (0, vue_1.useModel)(e, \"modelValue\"), a = (0, vue_1.ref)();\n !r.isMultiple && typeof i.value != \"string\" && typeof i.value != \"number\" && console.warn(\"Type check failed for prop \\\"modelValue\\\". Expected String: \" + typeof i.value), r.isMultiple && !Array.isArray(i.value) && console.warn(\"Type check failed for prop \\\"modelValue\\\". Expected Array: \" + typeof i.value), r.isMultiple && !r.canBeEmptyMultiple && Array.isArray(i.value) && !i.value.length && r.items[0] && (i.value = [r.items[0]?.href ?? r.items[0]?.value]);\n let o = (e) => Array.isArray(i.value) ? i.value.includes(e.value) : e.value === i.value, c = (e, t = !1) => {\n if (Array.isArray(i.value)) {\n let n = i.value.slice();\n if (t) {\n n.length || (n = r.items.map((e) => e.value));\n let t = n.indexOf(e.value);\n t === -1 ? n.push(e.value) : n.splice(t, 1);\n }\n else\n n = n.length === 1 && n[0] === e.value ? [] : [e.value];\n !r.canBeEmptyMultiple && !n.length && (n = [e.value]), i.value = n;\n return;\n }\n i.value = e.value;\n }, l = (e) => {\n if (a.value.scrollWidth <= a.value.offsetWidth || e.shiftKey || Math.abs(e.deltaY) < 50)\n return;\n e.preventDefault();\n let t = e.deltaY > 0 ? 30 : -30;\n a.value.scrollLeft = a.value.scrollLeft + t;\n }, u = (e = !0) => {\n let r = a.value.querySelector(\".top-active\");\n if (!r)\n return;\n let i = r.offsetLeft - a.value.offsetLeft - 24, o = r.offsetLeft - a.value.offsetLeft + r.clientWidth + 24, s = a.value.scrollLeft, c = a.value.clientWidth + a.value.scrollLeft, l;\n i < s && (l = i), o > c && (l = o - a.value.clientWidth), l !== void 0 && ((0, forms_DKVIpGnH_esm_js_1.G)() ? forms_DKVIpGnH_esm_js_1.O.$?.(a.value).animate({ scrollLeft: l }, e ? 200 : 0) : a.value.scrollTo({\n left: l,\n behavior: e ? \"smooth\" : \"auto\"\n }));\n }, d = () => {\n if (Array.isArray(i.value)) {\n if (i.value.length === r.items.length) {\n i.value = [r.items[0].href ?? r.items[0].value];\n return;\n }\n i.value = r.items.map((e) => e.href ?? e.value);\n }\n };\n return (0, vue_1.onMounted)(() => u(!1)), (0, vue_1.onUpdated)(() => u(!0)), (t, n) => ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", {\n ref_key: \"el\",\n ref: a,\n class: (0, vue_1.normalizeClass)({\n \"top-menu\": !0,\n [\"top-style_\" + e.styling]: !0\n }),\n onWheel: l\n }, [((0, vue_1.openBlock)(!0), (0, vue_1.createElementBlock)(vue_1.Fragment, null, (0, vue_1.renderList)(e.items, (e) => ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(forms_DKVIpGnH_esm_js_1.h, (0, vue_1.mergeProps)({ ref_for: !0 }, e, {\n class: \"top-menu_item\",\n color: \"theme\",\n onClick: (t) => c(e, t.ctrlKey || t.metaKey),\n isActive: o(e)\n }), (0, vue_1.createSlots)({ _: 2 }, [e.content ? {\n name: \"default\",\n fn: (0, vue_1.withCtx)(() => [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(e.content), 1)]),\n key: \"0\"\n } : void 0]), 1040, [\"onClick\", \"isActive\"]))), 256)), Array.isArray(i.value) && e.selectAllItem ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", G, [(0, vue_1.createVNode)(forms_DKVIpGnH_esm_js_1.h, (0, vue_1.mergeProps)(e.selectAllItem, {\n class: \"top-menu_item\",\n color: \"theme\",\n styling: \"\",\n onClick: n[0] ||= (e) => d(),\n isActive: i.value.length === e.items.length\n }), (0, vue_1.createSlots)({ _: 2 }, [e.selectAllItem.content ? {\n name: \"default\",\n fn: (0, vue_1.withCtx)(() => [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(e.selectAllItem.content), 1)]),\n key: \"0\"\n } : void 0]), 1040, [\"isActive\"])])) : (0, vue_1.createCommentVNode)(\"\", !0)], 34));\n }\n }), ne = { class: \"top-selector2_itemMulti top-ellipsis\" }, re = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"itemMulti\",\n props: {\n id: {},\n name: {}\n },\n emits: [\"delete\"],\n setup(e) {\n return (t, n) => ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", ne, [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(e.name) + \" \", 1), (0, vue_1.createElementVNode)(\"span\", {\n class: \"top-selector2_itemMultiDelete\",\n \"data-top-icon\": \"\",\n onClick: n[0] ||= (n) => t.$emit(\"delete\", {\n id: e.id,\n name: e.name\n }),\n onMousedown: n[1] ||= (0, vue_1.withModifiers)(() => { }, [\"stop\"])\n }, null, 32)]));\n }\n }), K = /* @__PURE__ */ new Map(), q = /* @__PURE__ */ new Map(), J = (e) => (q.has(e) || q.set(e, (0, vue_1.ref)(0)), q.get(e)), Y = (e) => {\n J(e).value++;\n }, ie = (e) => {\n K.get(e)?.clear(), Y(e);\n }, X = (e, t) => {\n let n = K.get(e);\n if (n)\n for (let e of n.values())\n t(e, e.result);\n }, Z = (e) => {\n let t = window.mo?.user?.id;\n return JSON.stringify(e.params) + \":\" + e.url + \":\" + t;\n }, Q = (e, t) => K.get(t)?.get(e), ae = (e, t, n) => {\n K.has(t) || K.set(t, /* @__PURE__ */ new Map()), K.get(t)?.set(e, n);\n }, oe = (e, t, n) => {\n X(e, (e, r) => {\n let i = r.find((e) => e.id === t);\n i && Object.assign(i, n);\n }), Y(e);\n }, se = (e, t) => {\n X(e, (e, n) => {\n let r = n.findIndex((e) => e.id === t);\n r !== -1 && (n[r].name = \"--\", n.splice(r, 1), e.nextOffset && e.nextOffset--);\n }), Y(e);\n }, ce = (e, t, n, i) => {\n let a = (0, vue_1.ref)([]), o = (0, vue_1.ref)(!1), s = (0, vue_1.ref)(0), c = \"\", l;\n e && !e.params.limit && (e.params.limit = 100);\n let u = () => {\n if (!e)\n return;\n e.params.offset = 0;\n let t = Q(Z(e), e.path);\n if (!t) {\n a.value = [], l = void 0;\n return;\n }\n a.value = t.result, l = t.nextOffset;\n };\n e && i && (0, vue_1.watch)(J(e.path), () => {\n u();\n });\n let d = async () => {\n if (!e)\n return;\n let t = i ? Z(e) : void 0;\n if (t) {\n let n = Q(t, e.path);\n if (n)\n return e.abortByFingerprint(), n;\n }\n let n = await e.call();\n if (n.errors)\n return;\n if (!Array.isArray(n.result)) {\n console.warn(\"Array expected in `res.result`\");\n return;\n }\n let r = n.result.findIndex((e) => e.id === void 0 || e.name === void 0);\n if (r !== -1) {\n console.warn(`В result[${r}] нет id или name`);\n return;\n }\n return t && ae(t, e.path, n), n;\n }, f = async (n) => {\n if (!e)\n return;\n if (n) {\n if (!l || o.value)\n return;\n e.params.offset = l;\n }\n else\n e.params.offset = 0;\n t?.(e, c), o.value = !0;\n let r = await d();\n o.value = !1, s.value++, r && (l = r.nextOffset, n ? a.value = a.value.concat(r.result) : a.value = r.result);\n }, p = (0, forms_DKVIpGnH_esm_js_1.P)(() => f(!1), 200);\n return {\n apiRequest: e,\n items: a,\n isLoading: o,\n countLoading: s,\n load: f,\n setSearchTextAndLoad: (t, r = !0) => {\n if (e) {\n if (t.length < n) {\n e.abortByFingerprint(), a.value = [];\n return;\n }\n t === c && a.value.length || (c = t, r ? p() : f(!1));\n }\n }\n };\n }, le = 0, ue = null, $ = (e, t, n = !0) => n && t.id === null ? Array.isArray(e) ? e.some((e) => e.id === t.id && e.name === t.name) : t.name === e.name : Array.isArray(e) ? e.some((e) => e.id === t.id) : t.id === e.id, de = (e, t, n) => {\n let r = e.params.filters ?? [];\n r = r.filter((e) => e.name !== n), t && r.push((0, field_DEusYVqS_esm_js_1.t)(n, \"CONTAINS\", [t])), e.changeParams({ filters: r });\n }, fe = (t, n, r, i, a, o, s, c, l, u, f, p, m, h) => {\n let _ = (0, vue_1.ref)(\"\"), v = {\n id: 0,\n name: (0, forms_DKVIpGnH_esm_js_1.E)().Common.All\n }, y = () => {\n _.value = \"\";\n }, b = () => !(!h.apiRequest || _.value.length >= m), x = (0, vue_1.computed)(() => {\n let e = [];\n return !a && o.value && (typeof o.value == \"string\" && (v.name = o.value), e.push(v)), r.value?.forEach((t) => e.push({ ...t })), e;\n }), S = (0, vue_1.ref)([]), C = () => {\n S.value = w();\n }, w = () => {\n let e = _.value.toLowerCase(), n = (0, keyboard_js_1.invertKeyboardLayout)(e), r = [], o, p = [], m = () => {\n p.at(-1)?.listItemProps?.type === \"delimiter\" && p.pop(), p.length &&= (o && r.push(o), r.push(...p), 0);\n }, g = (t) => {\n let r = f.value?.includes(\"id\"), i = t.name.toLowerCase(), a = f.value?.filter((e) => e !== \"id\").map((e) => typeof t[e] == \"string\" || typeof t[e] == \"number\" ? t[e] : \"\").join(\"☼\").toLowerCase();\n (r && t.id === Number(e) || a?.includes(e) || a?.includes(n)) && (i === e || i === n ? p.unshift(t) : p.push(t));\n };\n for (let e of x.value)\n switch (e.listItemProps?.type) {\n case \"title\":\n m(), o = e;\n break;\n case \"delimiter\":\n if (p.length) {\n let t = p.length;\n p.at(-1)?.listItemProps?.type === \"delimiter\" && t--, p[t] = e;\n }\n break;\n default: g(e);\n }\n if (m(), r.push(...h.items.value), s.value && _.value && (!l.value || l.value(e)) && (c.value || !r.find((t) => t.name.toLowerCase() === e))) {\n let e = {\n id: null,\n name: _.value\n };\n u.value && (e.listItemProps = { closeByClick: !1 }), r.push(e);\n }\n return a && (r = r.filter((e) => !$(t.value, e))), i && (r = i(r)), r;\n }, T = (e) => {\n e.listItemProps?.type === \"title\" || e.listItemProps?.type === \"delimiter\" || e.id === null && (n(\"appendItem\", e), u.value) || (a && Array.isArray(t.value) ? $(t.value, e) || (t.value = [...t.value, e]) : t.value = e, setTimeout(() => {\n y();\n }));\n };\n if (h.apiRequest) {\n let e = [r, h.items];\n a && e.push(t), (0, vue_1.watch)(e, () => {\n C();\n }, { deep: 2 });\n }\n else\n (0, vue_1.watch)([\n t,\n r,\n _\n ], () => {\n C();\n }, {\n immediate: !0,\n deep: 2\n });\n return {\n searchText: _,\n resetSearch: y,\n genIsShort: b,\n itemsForShow: S,\n selectItem: T,\n selectNextItem: () => {\n if (Array.isArray(t.value))\n return;\n let e = S.value.filter((e) => ![\"title\", \"delimiter\"].includes(e.listItemProps?.type ?? \"\"));\n t.value = { ...e[(e.findIndex((e) => e.id === t.value.id) + 1) % e.length] };\n },\n deleteItemByItem: async (e) => {\n Array.isArray(t.value) && (t.value = t.value.filter((t) => t.id !== e.id || t.name !== e.name));\n }\n };\n }, pe = {\n key: 0,\n class: \"top-selector2_activeItems\"\n }, me = {\n key: 1,\n class: \"top-selector2_activeName top-ellipsis\"\n }, he = {\n key: 2,\n class: \"top-selector2_placeholder top-ellipsis\"\n }, ge = { class: \"top-selector2_searchWidget\" }, _e = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"selector2\",\n props: /*@__PURE__*/ (0, vue_1.mergeModels)({\n modelValue: {},\n items: { default: () => [] },\n title: {},\n disabled: { type: Boolean },\n icon: {},\n modificator: {},\n size: { default: \"s\" },\n isError: { type: Boolean },\n openByFocusInput: {\n type: Boolean,\n default: void 0\n },\n searchType: { default: \"popup\" },\n searchFields: { default: () => [\"id\", \"name\"] },\n placeholder: {},\n hasCloserBtn: { type: Boolean },\n prepareItemsBeforeRender: {},\n api: {},\n apiSetSearchParams: {},\n minLength: { default: 0 },\n useCache: { type: Boolean },\n appendSearchToResult: { type: Boolean },\n appendSearchAllowDuplicate: { type: Boolean },\n appendSearchToResultCond: {},\n appendWithoutSelect: { type: Boolean },\n multiselect: { type: Boolean },\n useAllItem: { type: [Boolean, String] },\n addChanger: { type: Boolean },\n buttonProps: {},\n selectedAsPlaceholder: { type: Boolean },\n openerShortcut: {}\n }, {\n modelValue: { required: !0 },\n modelModifiers: {}\n }),\n emits: /*@__PURE__*/ (0, vue_1.mergeModels)([\"appendItem\", \"open\"], [\"update:modelValue\"]),\n setup(e, { expose: t, emit: r }) {\n let i = e, a = (0, vue_1.useModel)(e, \"modelValue\"), o = r;\n t({\n resetCache: (e = !1) => {\n c.apiRequest && (e && ie(c.apiRequest.path), c.items.value = [], c.countLoading.value = 0, c.apiRequest.params.offset = 0, requestAnimationFrame(() => {\n u.itemsForShow.value = [];\n }), T()?.elPopup && c.setSearchTextAndLoad(u.searchText.value));\n },\n updateCacheItemById: (e, t) => {\n c.apiRequest && c.apiRequest && oe(c.apiRequest.path, e, t);\n },\n deleteCacheItemById: (e) => {\n c.apiRequest && c.apiRequest && se(c.apiRequest.path, e);\n }\n });\n let s = (0, vue_1.computed)(() => i.searchType === \"inline\" && i.multiselect || i.searchType === \"inline\" && forms_DKVIpGnH_esm_js_1.O.state.isMobile ? \"popup\" : i.searchType), c = ce(i.api, i.apiSetSearchParams, i.minLength, i.useCache), u = fe(a, o, (0, vue_1.toRef)(i, \"items\"), i.prepareItemsBeforeRender, i.multiselect, (0, vue_1.toRef)(i, \"useAllItem\"), (0, vue_1.toRef)(i, \"appendSearchToResult\"), (0, vue_1.toRef)(i, \"appendSearchAllowDuplicate\"), (0, vue_1.toRef)(i, \"appendSearchToResultCond\"), (0, vue_1.toRef)(i, \"appendWithoutSelect\"), (0, vue_1.toRef)(i, \"searchFields\"), s, i.minLength, c), d = (0, vue_1.computed)(() => i.buttonProps ? \"TopButton\" : s.value === \"inline\" ? \"TopInput\" : \"div\"), w = (0, vue_1.ref)(null), T = () => w.value?.popup;\n c.apiRequest && (0, vue_1.watch)(u.searchText, () => {\n c.setSearchTextAndLoad(u.searchText.value);\n });\n let D = (0, vue_1.computed)(() => Array.isArray(a.value) || i.multiselect || !i.selectedAsPlaceholder && s.value !== \"inline\" ? i.placeholder : a.value?.name || i.placeholder), O = (e) => {\n let t = !1;\n switch (e.key) {\n case \"Delete\":\n case \"Backspace\":\n Array.isArray(a.value) && (e.preventDefault(), e.stopPropagation(), a.value.pop());\n break;\n case \"ArrowUp\":\n case \"ArrowRight\":\n case \"ArrowDown\":\n case \"ArrowLeft\":\n case \"Enter\":\n case \" \":\n t = !0;\n break;\n case \"Escape\":\n s.value === \"inline\" && u.resetSearch();\n break;\n }\n let n = e.key.length === 1 && !e.ctrlKey && !e.metaKey;\n (s.value === \"popup\" || s.value === \"inline\") && n && (t = !0), T()?.elPopup && (t = !1), t && (s.value === \"popup\" && (e.preventDefault(), e.stopPropagation(), n && (u.searchText.value || (u.searchText.value = e.key))), e.currentTarget?.click());\n }, k = (e) => {\n e.preventDefault(), u.selectNextItem();\n }, U = () => {\n c.apiRequest && c.setSearchTextAndLoad(u.searchText.value, !1), o(\"open\");\n }, W = () => {\n s.value === \"popup\" && u.searchText.value && u.resetSearch();\n }, G = (e) => {\n let t = e.target;\n t.scrollTop / (t.scrollHeight - t.offsetHeight) > .8 && c.load(!0);\n };\n return (t, r) => {\n let i = (0, vue_1.resolveComponent)(\"TopButton\"), o = (0, vue_1.resolveComponent)(\"TopLoadbar\"), g = (0, vue_1.resolveDirective)(\"top-focus\"), T = (0, vue_1.resolveDirective)(\"top-shortcut\");\n return (0, vue_1.openBlock)(), (0, vue_1.createBlock)((0, vue_1.unref)(popup_CtiL5V44_esm_js_1.s), {\n ref_key: \"popupRef\",\n ref: w,\n onOpen: r[3] ||= (e) => U(),\n onClose: r[4] ||= (e) => W(),\n onScrollContentList: r[5] ||= (e) => (0, vue_1.unref)(c) ? G(e) : void 0,\n notch: !1,\n transitionDuration: 0,\n openByFocusInput: s.value === \"inline\" && (e.openByFocusInput ?? !0),\n disabled: s.value === \"inline\" && (0, vue_1.unref)(u).genIsShort()\n }, (0, vue_1.createSlots)({\n opener: (0, vue_1.withCtx)(() => [(0, vue_1.withDirectives)(((0, vue_1.openBlock)(), (0, vue_1.createBlock)((0, vue_1.resolveDynamicComponent)(d.value), (0, vue_1.mergeProps)(e.buttonProps, {\n class: {\n \"top-selector2\": !0,\n \"top-selector2-multiselect\": e.multiselect,\n [\"top-selector2-\" + e.modificator]: !!e.modificator,\n \"top-as-input\": !e.buttonProps && s.value !== \"inline\",\n \"top-as-selector\": !0,\n [\"top-size_\" + e.size]: !0,\n \"top-disabled\": e.disabled,\n \"top-forms-focusable\": !e.disabled,\n \"top-error\": e.isError\n },\n icon: e.icon,\n tabindex: \"0\",\n onKeydown: O,\n onBlur: r[0] ||= (e) => s.value === \"inline\" && (0, vue_1.unref)(u).resetSearch(),\n placeholder: D.value,\n title: e.title,\n captionType: s.value === \"inline\" && e.title !== void 0 ? \"top\" : void 0,\n modelValue: (0, vue_1.unref)(u).searchText.value,\n \"onUpdate:modelValue\": r[1] ||= (e) => (0, vue_1.unref)(u).searchText.value = e\n }), {\n default: (0, vue_1.withCtx)(() => [\n e.multiselect ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", pe, [((0, vue_1.openBlock)(!0), (0, vue_1.createElementBlock)(vue_1.Fragment, null, (0, vue_1.renderList)(a.value, (e) => ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(re, {\n key: e.id ?? void 0,\n id: e.id,\n name: e.name,\n onDelete: (0, vue_1.unref)(u).deleteItemByItem\n }, null, 8, [\n \"id\",\n \"name\",\n \"onDelete\"\n ]))), 128))])) : (0, vue_1.createCommentVNode)(\"\", !0),\n s.value !== \"inline\" && !e.multiselect ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"span\", me, (0, vue_1.toDisplayString)(Array.isArray(a.value) ? \"\" : a.value.name), 1)) : (0, vue_1.createCommentVNode)(\"\", !0),\n e.multiselect && !a.value.length ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"span\", he, (0, vue_1.toDisplayString)(D.value), 1)) : (0, vue_1.createCommentVNode)(\"\", !0),\n e.addChanger && !e.buttonProps && !e.multiselect && (0, vue_1.unref)(u).itemsForShow.value.length > 1 && !e.disabled ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"span\", {\n key: 3,\n class: \"top-changer top-changer-selector\",\n \"data-top-popup-disabled\": \"true\",\n onClick: k\n })) : (0, vue_1.createCommentVNode)(\"\", !0)\n ]),\n _: 1\n }, 16, [\n \"class\",\n \"icon\",\n \"placeholder\",\n \"title\",\n \"captionType\",\n \"modelValue\"\n ])), [[\n g,\n e.isError,\n void 0,\n { onupdate: !0 }\n ], [T, e.openerShortcut]])]),\n contentList: (0, vue_1.withCtx)(() => [\n ((0, vue_1.openBlock)(!0), (0, vue_1.createElementBlock)(vue_1.Fragment, null, (0, vue_1.renderList)((0, vue_1.unref)(u).itemsForShow.value, (r) => ((0, vue_1.openBlock)(), (0, vue_1.createBlock)((0, vue_1.unref)(popup_CtiL5V44_esm_js_1.o), (0, vue_1.mergeProps)({\n key: r.id ?? void 0,\n class: {\n \"top-active\": !Array.isArray(a.value) && !e.multiselect && a.value.id === r.id && a.value.name === r.name,\n \"top-selector2_item-all\": r.id === (0, vue_1.unref)(0),\n \"top-selector2_item-new\": r.id === (0, vue_1.unref)(null)\n },\n closeByClick: !e.multiselect || (0, vue_1.unref)(forms_DKVIpGnH_esm_js_1.O).state.isMobile\n }, { ref_for: !0 }, r.listItemProps, { onClick: (e) => (0, vue_1.unref)(u).selectItem(r) }), (0, vue_1.createSlots)({\n default: (0, vue_1.withCtx)(() => [t.$slots.item ? (0, vue_1.renderSlot)(t.$slots, \"item\", {\n key: 0,\n item: r\n }) : ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(vue_1.Fragment, { key: 1 }, [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(r.name), 1)], 64))]),\n _: 2\n }, [t.$slots.actions ? {\n name: \"actions\",\n fn: (0, vue_1.withCtx)(() => [(0, vue_1.renderSlot)(t.$slots, \"actions\", { item: r })]),\n key: \"0\"\n } : void 0]), 1040, [\n \"class\",\n \"closeByClick\",\n \"onClick\"\n ]))), 128)),\n !(0, vue_1.unref)(u).itemsForShow.value.length && !(0, vue_1.unref)(u).genIsShort() ? ((0, vue_1.openBlock)(), (0, vue_1.createBlock)((0, vue_1.unref)(popup_CtiL5V44_esm_js_1.o), {\n key: 0,\n type: \"regular\"\n }, {\n default: (0, vue_1.withCtx)(() => [!(0, vue_1.unref)(c).isLoading.value || (0, vue_1.unref)(c).countLoading.value ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(vue_1.Fragment, { key: 0 }, [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(t.$i18n.Common.No_results), 1)], 64)) : ((0, vue_1.openBlock)(), (0, vue_1.createBlock)((0, vue_1.unref)(forms_DKVIpGnH_esm_js_1.t), {\n key: 1,\n type: \"circles\"\n }))]),\n _: 1\n })) : (0, vue_1.createCommentVNode)(\"\", !0),\n (0, vue_1.unref)(c).countLoading.value && (0, vue_1.unref)(c).isLoading.value && s.value === \"inline\" ? ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(o, { key: 1 })) : (0, vue_1.createCommentVNode)(\"\", !0)\n ]),\n _: 2\n }, [s.value === \"popup\" ? {\n name: \"widget\",\n fn: (0, vue_1.withCtx)(() => [(0, vue_1.createElementVNode)(\"div\", ge, [(0, vue_1.withDirectives)((0, vue_1.createVNode)((0, vue_1.unref)(popup_CtiL5V44_esm_js_1.a), {\n title: \"Поиск\",\n icon: \"\",\n modelValue: (0, vue_1.unref)(u).searchText.value,\n \"onUpdate:modelValue\": r[2] ||= (e) => (0, vue_1.unref)(u).searchText.value = e,\n isLoading: !!(0, vue_1.unref)(c).countLoading.value && (0, vue_1.unref)(c).isLoading.value,\n placeholder: D.value\n }, null, 8, [\n \"modelValue\",\n \"isLoading\",\n \"placeholder\"\n ]), [[\n g,\n a.value,\n void 0,\n { onupdate: !0 }\n ]]), e.hasCloserBtn && !t.$core.state.isMobile ? ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(i, {\n key: 0,\n class: \"closer\",\n color: \"theme\"\n }, {\n default: (0, vue_1.withCtx)(() => [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(t.$i18n.Common.Cancel), 1)]),\n _: 1\n })) : (0, vue_1.createCommentVNode)(\"\", !0)])]),\n key: \"0\"\n } : void 0]), 1032, [\"openByFocusInput\", \"disabled\"]);\n };\n }\n }), ve = { class: \"top-editArea_footer\" }, ye = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"editArea\",\n props: {\n defaultValue: { default: \"\" },\n title: {},\n cancelText: { default: \"Cancel\" },\n submitText: { default: \"Send\" },\n closeText: { default: \"Close\" },\n isFocused: { type: Boolean },\n forceShowCloseBtn: { type: Boolean },\n attachToKeyboard: { type: Boolean },\n modelValue: {},\n name: {},\n placeholder: {},\n styling: {},\n rows: {},\n minHeight: {},\n expandable: {\n type: Boolean,\n default: !0\n },\n disabled: { type: Boolean },\n readonly: { type: Boolean },\n isError: { type: Boolean },\n hint: {},\n maxLength: {}\n },\n emits: [\n \"submit\",\n \"close\",\n \"clickOnTitle\"\n ],\n setup(e, { emit: t }) {\n let n = e, r = t, i = (0, vue_1.ref)(n.defaultValue), a = (0, vue_1.ref)(n.isFocused), o = (0, vue_1.computed)(() => i.value !== n.defaultValue), l = (e) => {\n r(\"submit\", e), i.value = n.defaultValue;\n }, u = () => {\n if (n.forceShowCloseBtn && !o.value) {\n r(\"close\");\n return;\n }\n i.value = n.defaultValue;\n }, d = () => {\n n.attachToKeyboard && r(\"clickOnTitle\");\n };\n return (t, n) => ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", { class: (0, vue_1.normalizeClass)({\n \"top-editArea\": !0,\n \"top-editArea-attachedToKeyboard\": e.attachToKeyboard\n }) }, [e.title || t.$slots.caption ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", {\n key: 0,\n class: \"top-editArea_caption\",\n onClick: n[0] ||= (e) => d()\n }, [(0, vue_1.renderSlot)(t.$slots, \"caption\", {}, () => [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(e.title), 1)])])) : (0, vue_1.createCommentVNode)(\"\", !0), (0, vue_1.createElementVNode)(\"div\", { class: (0, vue_1.normalizeClass)({\n \"top-editArea_form\": !0,\n \"top-forms-focusable\": !0,\n \"top-as-input\": !0,\n \"top-error\": e.isError,\n \"top-focus\": a.value\n }) }, [(0, vue_1.createVNode)(forms_DKVIpGnH_esm_js_1.r, {\n modelValue: i.value,\n \"onUpdate:modelValue\": n[1] ||= (e) => i.value = e,\n name: e.name,\n placeholder: e.placeholder,\n rows: e.rows,\n minHeight: e.minHeight,\n expandable: e.expandable,\n disabled: e.disabled,\n readonly: e.readonly,\n isError: e.isError,\n hint: e.hint,\n class: \"top-editArea_element\",\n onFocus: n[2] ||= () => a.value = !0,\n onBlur: n[3] ||= () => a.value = !1,\n onKeyup: [(0, vue_1.withKeys)(u, [\"esc\"]), n[4] ||= (0, vue_1.withKeys)((0, vue_1.withModifiers)((e) => l(i.value), [\"ctrl\"]), [\"enter\"])]\n }, null, 8, [\n \"modelValue\",\n \"name\",\n \"placeholder\",\n \"rows\",\n \"minHeight\",\n \"expandable\",\n \"disabled\",\n \"readonly\",\n \"isError\",\n \"hint\"\n ]), (0, vue_1.createElementVNode)(\"div\", ve, [o.value || e.forceShowCloseBtn ? ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(forms_DKVIpGnH_esm_js_1.h, {\n key: 0,\n icon: t.$core.state.isMobile ? \"\" : \"\",\n class: \"top-editArea_button\",\n color: \"theme\",\n styling: \"soft\",\n onClick: u\n }, (0, vue_1.createSlots)({ _: 2 }, [t.$core.state.isMobile ? void 0 : {\n name: \"default\",\n fn: (0, vue_1.withCtx)(() => [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(e.cancelText), 1)]),\n key: \"0\"\n }]), 1032, [\"icon\"])) : (0, vue_1.createCommentVNode)(\"\", !0), o.value ? ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(forms_DKVIpGnH_esm_js_1.h, {\n key: 1,\n class: \"top-editArea_button\",\n icon: t.$core.state.isMobile ? \"\" : \"\",\n onClick: n[5] ||= (e) => l(i.value)\n }, (0, vue_1.createSlots)({ _: 2 }, [t.$core.state.isMobile ? void 0 : {\n name: \"default\",\n fn: (0, vue_1.withCtx)(() => [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(e.submitText), 1)]),\n key: \"0\"\n }]), 1032, [\"icon\"])) : (0, vue_1.createCommentVNode)(\"\", !0)])], 2)], 2));\n }\n }), be = { class: \"top-editInput\" }, xe = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"editInput\",\n props: {\n modelValue: {},\n alwaysShowSubmitBtn: { type: Boolean },\n input: {},\n button: {}\n },\n emits: [\"update:modelValue\"],\n setup(e, { emit: t }) {\n let n = e, r = (0, vue_1.ref)(n.modelValue);\n (0, vue_1.watch)(() => n.modelValue, () => {\n r.value = n.modelValue;\n });\n let i = t, o = () => {\n i(\"update:modelValue\", r.value);\n };\n return (t, n) => ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", be, [(0, vue_1.createVNode)(forms_DKVIpGnH_esm_js_1.c, (0, vue_1.mergeProps)(e.input, {\n onKeydownCapture: n[0] ||= (0, vue_1.withKeys)((0, vue_1.withModifiers)((t) => r.value = e.modelValue, [\"stop\"]), [\"esc\"]),\n onKeydown: (0, vue_1.withKeys)((0, vue_1.withModifiers)(o, [\"stop\"]), [\"enter\"]),\n modelValue: r.value,\n \"onUpdate:modelValue\": n[1] ||= (e) => r.value = e\n }), (0, vue_1.createSlots)({ _: 2 }, [t.$slots.caption ? {\n name: \"caption\",\n fn: (0, vue_1.withCtx)(() => [(0, vue_1.renderSlot)(t.$slots, \"caption\")]),\n key: \"0\"\n } : void 0]), 1040, [\"onKeydown\", \"modelValue\"]), r.value !== e.modelValue || e.alwaysShowSubmitBtn ? ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(forms_DKVIpGnH_esm_js_1.h, (0, vue_1.mergeProps)({\n key: 0,\n icon: \"\",\n styling: \"soft\"\n }, e.button, { onClick: o }), null, 16)) : (0, vue_1.createCommentVNode)(\"\", !0)]));\n }\n }), Se = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"optionGroup\",\n props: /*@__PURE__*/ (0, vue_1.mergeModels)({\n modelValue: {},\n items: {},\n size: { default: \"s\" },\n showIndicator: { type: Boolean },\n isError: { type: Boolean }\n }, {\n modelValue: { required: !0 },\n modelModifiers: {}\n }),\n emits: [\"update:modelValue\"],\n setup(e) {\n let t = (0, vue_1.useModel)(e, \"modelValue\"), n = e, r = (0, vue_1.ref)(null);\n (0, vue_1.watch)(t, () => {\n let e = n.items.map((e) => e.value);\n Array.isArray(t.value) ? t.value.find((t) => !e.includes(t)) && (t.value = t.value.filter((t) => e.includes(t))) : e.includes(t.value) || (t.value = e[0] ?? \"\"), r.value?.querySelector(\".radioGroup_item-selected\")?.scrollIntoView();\n }, { immediate: !0 });\n let a = \"optionGroup-\" + Math.random();\n return (n, s) => ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", {\n ref_key: \"elRef\",\n ref: r,\n class: (0, vue_1.normalizeClass)({\n \"top-optionGroup\": !0,\n [\"top-optionGroup-showIndicator_\" + Number(e.showIndicator)]: !0,\n \"top-scrollBarXHidding\": !0,\n [\"top-size_\" + e.size]: !!e.size,\n \"top-error\": e.isError\n })\n }, [Array.isArray(t.value) ? ((0, vue_1.openBlock)(!0), (0, vue_1.createElementBlock)(vue_1.Fragment, { key: 0 }, (0, vue_1.renderList)(e.items, (n) => ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(forms_DKVIpGnH_esm_js_1.f, {\n class: (0, vue_1.normalizeClass)({\n \"top-optionGroup_item-selected\": t.value.includes(n.value),\n \"top-optionGroup_item\": !0\n }),\n modelValue: t.value,\n \"onUpdate:modelValue\": s[0] ||= (e) => t.value = e,\n value: n.value,\n title: n.title,\n disabled: n.disabled,\n isError: e.isError,\n \"data-top-icon\": n.icon\n }, (0, vue_1.createSlots)({ _: 2 }, [n.label ? {\n name: \"default\",\n fn: (0, vue_1.withCtx)(() => [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(n.label), 1)]),\n key: \"0\"\n } : void 0]), 1032, [\n \"class\",\n \"modelValue\",\n \"value\",\n \"title\",\n \"disabled\",\n \"isError\",\n \"data-top-icon\"\n ]))), 256)) : ((0, vue_1.openBlock)(!0), (0, vue_1.createElementBlock)(vue_1.Fragment, { key: 1 }, (0, vue_1.renderList)(e.items, (n) => ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(forms_DKVIpGnH_esm_js_1.a, {\n class: (0, vue_1.normalizeClass)({\n \"top-optionGroup_item-selected\": n.value === t.value,\n \"top-optionGroup_item\": !0\n }),\n modelValue: t.value,\n \"onUpdate:modelValue\": s[1] ||= (e) => t.value = e,\n name: a,\n value: n.value,\n title: n.title,\n disabled: n.disabled,\n isError: e.isError,\n \"data-top-icon\": n.icon\n }, (0, vue_1.createSlots)({ _: 2 }, [n.label ? {\n name: \"default\",\n fn: (0, vue_1.withCtx)(() => [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(n.label), 1)]),\n key: \"0\"\n } : void 0]), 1032, [\n \"class\",\n \"modelValue\",\n \"value\",\n \"title\",\n \"disabled\",\n \"isError\",\n \"data-top-icon\"\n ]))), 256))], 2));\n }\n }), Ce = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"radioGroup\",\n props: /*@__PURE__*/ (0, vue_1.mergeModels)({\n modelValue: {},\n items: {},\n size: {},\n showIndicator: { type: Boolean },\n isError: { type: Boolean }\n }, {\n modelValue: { required: !0 },\n modelModifiers: {}\n }),\n emits: [\"update:modelValue\"],\n setup(e) {\n let t = (0, vue_1.useModel)(e, \"modelValue\");\n return (e, n) => ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(Se, {\n class: \"top-radioGroup\",\n modelValue: t.value,\n \"onUpdate:modelValue\": n[0] ||= (e) => t.value = e,\n items: e.$props.items,\n size: e.$props.size,\n showIndicator: e.$props.showIndicator,\n isError: e.$props.isError\n }, {\n default: (0, vue_1.withCtx)(() => [(0, vue_1.renderSlot)(e.$slots, \"default\")]),\n _: 3\n }, 8, [\n \"modelValue\",\n \"items\",\n \"size\",\n \"showIndicator\",\n \"isError\"\n ]));\n }\n }), we = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"checkboxGroup\",\n props: /*@__PURE__*/ (0, vue_1.mergeModels)({\n modelValue: {},\n items: {},\n size: {},\n showIndicator: { type: Boolean },\n isError: { type: Boolean }\n }, {\n modelValue: { required: !0 },\n modelModifiers: {}\n }),\n emits: [\"update:modelValue\"],\n setup(e) {\n let t = (0, vue_1.useModel)(e, \"modelValue\");\n return (e, n) => ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(Se, {\n class: \"top-checkboxGroup\",\n modelValue: t.value,\n \"onUpdate:modelValue\": n[0] ||= (e) => t.value = e,\n items: e.$props.items,\n size: e.$props.size,\n showIndicator: e.$props.showIndicator,\n isError: e.$props.isError\n }, {\n default: (0, vue_1.withCtx)(() => [(0, vue_1.renderSlot)(e.$slots, \"default\")]),\n _: 3\n }, 8, [\n \"modelValue\",\n \"items\",\n \"size\",\n \"showIndicator\",\n \"isError\"\n ]));\n }\n }), Te = [\"data-top-icon\"], Ee = { class: \"top-info_text\" }, De = {\n key: 0,\n class: \"top-info_value\"\n }, Oe = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"info\",\n props: {\n icon: {},\n styling: { default: \"default\" },\n size: { default: \"default\" }\n },\n setup(e) {\n return (t, n) => ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", {\n class: (0, vue_1.normalizeClass)({\n \"top-info\": !0,\n [\"top-size_\" + e.size]: !0,\n [\"top-info-styling_\" + e.styling]: !0\n }),\n \"data-top-icon\": e.icon\n }, [(0, vue_1.createElementVNode)(\"div\", Ee, [(0, vue_1.renderSlot)(t.$slots, \"default\")]), t.$slots.additional ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"span\", De, [(0, vue_1.renderSlot)(t.$slots, \"additional\")])) : (0, vue_1.createCommentVNode)(\"\", !0)], 10, Te));\n }\n }), ke = {\n key: 0,\n class: \"top-policy\"\n }, Ae = { class: \"top-policy_title\" }, je = [\"innerHTML\"], Me = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"policy\",\n props: {\n title: {},\n description: {},\n acceptText: {}\n },\n emits: [\"accept\"],\n setup(e, { emit: t }) {\n let n = t, r = (0, vue_1.ref)(!0), i = () => {\n r.value = !1, n(\"accept\");\n };\n return (t, n) => r.value ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", ke, [\n (0, vue_1.createElementVNode)(\"div\", Ae, (0, vue_1.toDisplayString)(e.title), 1),\n (0, vue_1.createElementVNode)(\"div\", {\n class: \"top-policy_description\",\n innerHTML: e.description\n }, null, 8, je),\n (0, vue_1.createVNode)((0, vue_1.unref)(forms_DKVIpGnH_esm_js_1.h), {\n size: \"m\",\n onClick: i\n }, {\n default: (0, vue_1.withCtx)(() => [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(e.acceptText), 1)]),\n _: 1\n })\n ])) : (0, vue_1.createCommentVNode)(\"\", !0);\n }\n });\n exports.d = te;\n exports.c = le;\n exports.l = ue;\n exports.u = de;\n exports.s = _e;\n exports.o = ye;\n exports.a = xe;\n exports.i = Ce;\n exports.r = we;\n exports.n = Oe;\n exports.t = Me;\n});\n//# sourceMappingURL=formsExt-Dy7EHtJS.esm.js.map\n","<script setup lang=\"ts\">\nimport { onMounted, onUpdated, ref } from 'vue';\nimport type { Item, Props } from './types';\nimport Core from '@/core/core/core';\nimport { isSafari } from '@/core/utils/device';\nimport TopButton from '@/components/forms/button/button.vue';\n\nconst props = withDefaults(defineProps<Props>(), {\n\tstyling: 'default',\n});\n\nconst model = defineModel({\n\trequired: true,\n});\n\nconst el = ref();\n\n// валидация типа modelValue без возможности выбора нескольких значений (ожидается строка или число)\nif (!props.isMultiple && typeof (model.value) !== 'string' && typeof (model.value) !== 'number') {\n\tconsole.warn('Type check failed for prop \"modelValue\". Expected String: ' + typeof (model.value));\n}\n\n// валидация типа modelValue с возможностью выбора нескольких значений (ожидается массив)\nif (props.isMultiple && !Array.isArray(model.value)) {\n\tconsole.warn('Type check failed for prop \"modelValue\". Expected Array: ' + typeof (model.value));\n}\n\n/**\n * Для множественного выбора без пустого множества\n *\n * Если ничего не выбрано, присваиваем 1-ое значение\n */\nif (props.isMultiple && !props.canBeEmptyMultiple && Array.isArray(model.value) && !model.value.length && props.items[0]) {\n\tmodel.value = [props.items[0]?.href ?? props.items[0]?.value];\n}\n\nconst itemIsActive = (item: Item) => {\n\tif (!Array.isArray(model.value)) {\n\t\treturn item.value === model.value;\n\t}\n\n\treturn model.value.includes(item.value);\n};\n\n/**\n * Выбрать элемент\n * @param item\n * @param toggle - добавить или исключить элемент, для isMultiple\n */\nconst select = (item: Item, toggle = false) => {\n\tif (Array.isArray(model.value)) {\n\t\tlet modelNew = model.value.slice();\n\n\t\tif (toggle) {\n\t\t\tif (!modelNew.length) modelNew = props.items.map(item => item.value);\n\n\t\t\tconst index = modelNew.indexOf(item.value);\n\t\t\tif (index === -1) {\n\t\t\t\tmodelNew.push(item.value);\n\t\t\t} else {\n\t\t\t\tmodelNew.splice(index, 1);\n\t\t\t}\n\t\t} else {\n\t\t\tif (modelNew.length === 1 && modelNew[0] === item.value) {\n\t\t\t\tmodelNew = [];\n\t\t\t} else {\n\t\t\t\tmodelNew = [item.value];\n\t\t\t}\n\t\t}\n\n\t\tif (!props.canBeEmptyMultiple && !modelNew.length) modelNew = [item.value];\n\n\t\tmodel.value = modelNew;\n\n\t\treturn;\n\t}\n\n\tmodel.value = item.value;\n};\n\n// вертикальный скролл в горизонтальный скролл\nconst onWheel = (event: WheelEvent) => {\n\tif (el.value.scrollWidth <= el.value.offsetWidth) return;\n\tif (event.shiftKey) return;\n\tif (Math.abs(event.deltaY) < 50) return; // устройство с высокой точностью, например тачпад\n\n\tevent.preventDefault();\n\n\tconst delta = event.deltaY > 0 ? 30 : -30;\n\tel.value.scrollLeft = el.value.scrollLeft + delta;\n};\n\n/**\n * Замена стандартному scrollIntoView, который меняет скролл документа\n *\n * Выравнивание по ближнему краю элемента\n *\n * Выравнивается таким образом, чтобы был виден соседний элемент\n */\nconst scrollIntoView = (isSmooth = true) => {\n\tconst elBtn = el.value.querySelector('.top-active');\n\tif (!elBtn) return;\n\n\tconst gap = 24;\n\n\t// левая и правая координаты элемента\n\tconst leftMargin = elBtn.offsetLeft - el.value.offsetLeft - gap;\n\tconst rightMargin = elBtn.offsetLeft - el.value.offsetLeft + elBtn.clientWidth + gap;\n\n\t// левая и правая границы видимой части меню\n\tconst leftMarginParent = el.value.scrollLeft;\n\tconst rightMarginParent = el.value.clientWidth + el.value.scrollLeft;\n\n\tlet scrollLeft: number | undefined = undefined;\n\n\t// левую границу элемента к левой границе меню\n\tif (leftMargin < leftMarginParent) scrollLeft = leftMargin;\n\n\t// правую границу элемента к правой границе меню\n\tif (rightMargin > rightMarginParent) scrollLeft = rightMargin - el.value.clientWidth;\n\n\tif (scrollLeft !== undefined) {\n\t\tif (isSafari()) {\n\t\t\tCore.$?.(el.value).animate({ scrollLeft: scrollLeft }, isSmooth ? 200 : 0);\n\t\t} else {\n\t\t\tel.value.scrollTo({ left: scrollLeft, behavior: isSmooth ? 'smooth' : 'auto' });\n\t\t}\n\t}\n};\n\n/**\n * Выбрать все элементы в меню\n */\nconst selectAll = () => {\n\tif (!Array.isArray(model.value)) return;\n\n\tif (model.value.length === props.items.length) {\n\t\tmodel.value = [props.items[0].href ?? props.items[0].value];\n\t\treturn;\n\t}\n\n\tmodel.value = props.items.map(item => item.href ?? item.value);\n};\n\nonMounted(() => scrollIntoView(false));\nonUpdated(() => scrollIntoView(true));\n\n</script>\n\n<template>\n\t<div\n\t\tref=\"el\"\n\t\t:class=\"{\n\t\t\t'top-menu': true,\n\t\t\t['top-style_' + styling]: true,\n\t\t\t// ['top-unwrap-x']: styling === 'default',\n\t\t}\"\n\t\t@wheel=\"onWheel\"\n\t>\n\t\t<TopButton\n\t\t\tv-for=\"item in items\"\n\t\t\t:=\"item\"\n\t\t\tclass=\"top-menu_item\"\n\t\t\tcolor=\"theme\"\n\t\t\t@click=\"select(item, $event.ctrlKey || $event.metaKey)\"\n\t\t\t:isActive=\"itemIsActive(item)\"\n\t\t>\n\t\t\t<template #default v-if=\"item.content\">\n\t\t\t\t{{ item.content }}\n\t\t\t</template>\n\t\t</TopButton>\n\n\t\t<div\n\t\t\tv-if=\"Array.isArray(model) && selectAllItem\"\n\t\t\tclass=\"top-menu_selectAll\"\n\t\t>\n\t\t\t<TopButton\n\t\t\t\t:=\"selectAllItem\"\n\t\t\t\tclass=\"top-menu_item\"\n\t\t\t\tcolor=\"theme\"\n\t\t\t\tstyling=\"\"\n\t\t\t\t@click=\"selectAll()\"\n\t\t\t\t:isActive=\"model.length === items.length\"\n\t\t\t>\n\t\t\t\t<template #default v-if=\"selectAllItem.content\">\n\t\t\t\t\t{{ selectAllItem.content }}\n\t\t\t\t</template>\n\t\t\t</TopButton>\n\t\t</div>\n\t</div>\n</template>\n\n<style>\n.top-menu {\n\t--scroll-thumb-color: var(--color-line-1);\n\t--scroll-thumb-color-hover: var(--color-line-2);\n\t--scroll-thumb-color-active: var(--color-line-3);\n\n\tmax-width: 100%;\n\tdisplay: flex;\n\talign-items: flex-start;\n\tgap: var(--top-gap-2);\n\toverflow-x: auto;\n\tscrollbar-width: none; /* firefox */\n\n\t/* предотвратить натинвые события браузера (назад / вперед) */\n\toverscroll-behavior-x: contain;\n}\n\n.top-menu::-webkit-scrollbar { display: none; }\n\n.top-menu .top-menu_item {\n\t--top-button-color: var(--color-text-2);\n\n\toutline-offset: -2px !important;\n\tmin-width: 0;\n\tmax-width: 200px;\n\tmargin: 0;\n\tflex-shrink: 0;\n}\n\n.top-menu .top-menu_item[data-top-icon] {\n\t--top-icon-color: var(--color-text-2);\n}\n\n.top-menu_selectAll {\n\tposition: sticky;\n\tright: 0;\n\tbackground: var(--color-layout-front-1);\n\tborder-left: 1px solid var(--color-line-1);\n\tpadding-left: var(--top-padding-1);\n\tbox-shadow: var(--color-layout-front-1) var(--top-padding-2) 0px;\n}\n\n/* style default */\n.top-menu.top-style_default .top-menu_item {\n\t--top-forms-radius: 0;\n\t--top-forms-border-color: transparent;\n\t--top-forms-border-width: 2px;\n\n\tfilter: none;\n\tbox-shadow: none;\n\tborder: none;\n\tborder-bottom: var(--top-forms-border-width) solid var(--top-forms-border-color);\n\tbackground: none;\n}\n\n.top-style_default > .top-menu_item > [data-top-badge] {\n\tmargin-top: 0;\n}\n\n.top-menu.top-style_default .top-menu_item:hover {\n\t--top-icon-color: var(--color-text-1);\n\t--top-button-color: var(--color-text-1);\n\t--top-forms-border-color: var(--color-line-2);\n}\n\n.top-menu.top-style_default .top-menu_item:active,\n.top-menu.top-style_default .top-menu_item.top-active {\n\t--top-icon-color: var(--color-text-primary);\n\t--top-button-color: var(--color-text-1);\n\t--top-forms-border-color: var(--color-line-primary-1);\n}\n\n.top-menu.top-style_default .top-menu_selectAll {\n\tpadding-left: var(--top-padding-2);\n}\n\n/* style bar */\n.top-menu.top-style_bar {\n\tborder-radius: var(--top-radius-3);\n\tborder: 1px solid var(--color-line-2);\n\tpadding: var(--top-padding-1);\n\tgap: 3px;\n}\n.top-menu.top-style_bar .top-menu_item {\n\t--top-button-background-color-hover: var(--color-layer-1);\n\t--top-button-background-color-active: var(--color-layer-2);\n\t--top-button-background-color-selected: var(--color-layer-primary-1);\n\n\tposition: relative;\n}\n\n.top-menu.top-style_bar .top-menu_item:hover {\n\t--top-icon-color: var(--color-text-1);\n\t--top-button-color: var(--color-text-1);\n}\n\n.top-menu.top-style_bar .top-menu_item.top-active {\n\t--top-icon-color: var(--color-text-primary);\n\t--top-button-color: var(--color-text-primary);\n}\n\n/* разделители кнопок в баре */\n.top-menu.top-style_bar .top-menu_item:not(:first-child):not(.top-active):not(:hover):after {\n\tcontent: \"\";\n\tbackground: var(--color-line-1-opacity);\n\twidth: 1px;\n\theight: 60%;\n\tdisplay: block;\n\tposition: absolute;\n\tleft: -2px;\n}\n.top-menu.top-style_bar .top-menu_item.top-active + .top-menu_item:after,\n.top-menu.top-style_bar .top-menu_item:hover + .top-menu_item:after {\n\tcontent: none !important;\n}\n\n/*\n.top-style_bar > .top-menu_item > [data-top-badge] {\n\tmargin-top: -3px;\n}\n*/\n\n/** TODO: .top-unwrap-x надо вынести глобально в UI или добавить в стили для storybook */\n/*\n.top-menu.top-unwrap-x {\n\tpadding-right: var(--top-unwrap-x);\n\tpadding-left: var(--top-unwrap-x);\n\tmargin-right: calc(0px - var(--top-unwrap-x));\n\tmargin-left: calc(0px - var(--top-unwrap-x));\n}\n*/\n</style>\n","<script setup lang=\"ts\">\nimport type { EmitsItemMulti, PropsItemMulti } from './types';\n\ndefineProps<PropsItemMulti>();\ndefineEmits<EmitsItemMulti>();\n</script>\n\n<template>\n\t<div class=\"top-selector2_itemMulti top-ellipsis\">\n\t\t{{ name }}\n\n\t\t<span\n\t\t\tclass=\"top-selector2_itemMultiDelete\"\n\t\t\tdata-top-icon=\"\"\n\t\t\t@click=\"$emit('delete', {id, name})\"\n\t\t\t@mousedown.stop\n\t\t></span>\n\t</div>\n</template>\n\n<style>\n.top-selector2_itemMulti {\n\tbox-sizing: border-box;\n\tpadding-left: var(--top-padding-2);\n\tborder-radius: var(--top-radius-1, 4px);\n\tborder: 1px solid var(--color-line-primary-1);\n\tbackground: var(--color-layer-primary-2);\n\tmin-height: 22px;\n\tmax-width: 100%;\n\tcolor: var(--color-text-1);\n\tflex-grow: 0;\n\tdisplay: inline-flex;\n\talign-items: center;\n\tgap: var(--top-gap-1);\n}\n\n.top-selector2_itemMultiDelete {\n\t--top-icon-size: 14px;\n\t--top-icon-width: 18px;\n\t--top-icon-color: var(--color-text-1);\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\theight: 100%;\n\tcursor: pointer;\n}\n\n.top-selector2_itemMultiDelete:hover {\n\tbackground: var(--color-layer-primary-2);\n}\n\n@media screen and (min-width: 900px) {\n\t.top-selector2.top-active .top-selector2_itemMultiDelete {\n\t\tz-index: calc(var(--top-popup-z-index) + 1);\n\t}\n}\n</style>\n","import { ref, type Ref } from 'vue';\nimport type { Item, Props } from './types';\n\n/**\n * Кеш результата\n */\ntype Cache = Api.ResponseSuccess<Item[], 'get'>;\n\n/**\n * Список кешей для конкретного API метода\n */\nexport const cacheByMethod = new Map<Api.PathAbstract, Map<string, Cache>>();\n\n/**\n * Счетчик изменений кеша для конкретного API метода\n */\nconst cacheVersionByMethod = new Map<Api.PathAbstract, Ref<number>>();\n\n/**\n * Получить счетчик изменений кеша\n */\nexport const getCacheVersion = (apiPath: Api.PathAbstract) => {\n\tif (!cacheVersionByMethod.has(apiPath)) {\n\t\tcacheVersionByMethod.set(apiPath, ref(0));\n\t}\n\n\treturn cacheVersionByMethod.get(apiPath)!;\n};\n\n/**\n * Увеличить счетчик изменений кеша\n */\nconst invalidateCache = (apiPath: Api.PathAbstract) => {\n\tgetCacheVersion(apiPath).value++;\n};\n\n/**\n * Сброс кеша конкретного API метода\n */\nexport const clearCache = (apiPath: Api.PathAbstract) => {\n\tcacheByMethod.get(apiPath)?.clear();\n\n\tinvalidateCache(apiPath);\n};\n\n/**\n * Обойти все кеши конкретного API метода\n */\nconst eachCacheResult = (apiPath: Api.PathAbstract, cb: (resCache: Cache, result: Item[]) => void) => {\n\tconst caches = cacheByMethod.get(apiPath);\n\tif (!caches) return;\n\n\tfor (const res of caches.values()) {\n\t\tcb(res, res.result);\n\t}\n};\n\nexport const genCacheKey = (api: NonNullable<Props['api']>) => {\n\tconst userId = window['mo']?.user?.id;\n\n\tconst cacheKey = JSON.stringify(api.params) + ':' + api.url + ':' + userId;\n\n\treturn cacheKey;\n};\n\nexport const getCache = (cacheKey: string, apiPath: Api.PathAbstract) => {\n\treturn cacheByMethod.get(apiPath)?.get(cacheKey);\n};\n\nexport const setCache = (cacheKey: string, apiPath: Api.PathAbstract, data: Cache) => {\n\tif (!cacheByMethod.has(apiPath)) {\n\t\tcacheByMethod.set(apiPath, new Map());\n\t}\n\n\tcacheByMethod.get(apiPath)?.set(cacheKey, data);\n};\n\n/**\n * Обновить элемент во всех кешах API метода\n */\nexport const updateCacheItemById = (\n\tapiPath: Api.PathAbstract,\n\titemId: Item['id'],\n\tpatch: Partial<Item>,\n) => {\n\teachCacheResult(apiPath, (res, resultI) => {\n\t\tconst item = resultI.find((item) => item.id === itemId);\n\t\tif (!item) return;\n\n\t\tObject.assign(item, patch);\n\t});\n\n\tinvalidateCache(apiPath);\n};\n\n/**\n * Удалить элемент из всех кешей API метода\n */\nexport const deleteCacheItemById = (\n\tapiPath: Api.PathAbstract,\n\titemId: Item['id'],\n) => {\n\teachCacheResult(apiPath, (resCache, resultI) => {\n\t\tconst itemIndex = resultI.findIndex((item) => item.id === itemId);\n\t\tif (itemIndex === -1) return;\n\n\t\t// Model не сбрасываем, только меняем подпись, чтобы не вызывать ненужных загрузок там, где они не нужны\n\t\tresultI[itemIndex].name = '--';\n\n\t\tresultI.splice(itemIndex, 1);\n\n\t\tif (resCache.nextOffset) {\n\t\t\tresCache.nextOffset--;\n\t\t}\n\t});\n\n\tinvalidateCache(apiPath);\n};\n","import { ref, watch } from 'vue';\nimport { debounce } from '../../../../core/utils/lodash';\nimport type { Item, Props } from '../types';\nimport { genCacheKey, getCache, getCacheVersion, setCache } from '../cache';\n\nexport type API = ReturnType<typeof useAPI>;\n\nexport const useAPI = (\n\tapi: Props['api'],\n\tapiSetSearchParams: Props['apiSetSearchParams'],\n\tminLength: number,\n\tuseCache: Props['useCache'],\n) => {\n\t/**\n\t * Список, полученный через API\n\t */\n\tconst items = ref<Item[]>([]);\n\n\t/**\n\t * Флаг - идет загрузка\n\t */\n\tconst isLoading = ref(false);\n\n\tconst countLoading = ref(0);\n\n\tlet searchText = '';\n\tlet nextOffset: number | null | undefined;\n\n\tif (api && !api.params.limit) {\n\t\tapi.params.limit = 100;\n\t}\n\n\t/**\n\t * Синхронизировать данные компонента с данными в кеше\n\t */\n\tconst syncItemsFromCache = () => {\n\t\tif (!api) return;\n\n\t\tapi.params.offset = 0;\n\n\t\tconst cacheKey = genCacheKey(api);\n\t\tconst cache = getCache(cacheKey, api.path);\n\t\tif (!cache) {\n\t\t\titems.value = [];\n\t\t\tnextOffset = undefined;\n\n\t\t\treturn;\n\t\t}\n\n\t\t/**\n\t\t * Общая ссылка позволяет не терять связь между кешем API и выбранным значением, вернее его свойствами\n\t\t *\n\t\t * Пример:\n\t\t * - Выбираем нужный item\n\t\t * - Меняем `item.name` в другом коде и инвалидируем кеш\n\t\t * - Подпись у селектора меняется автоматически\n\t\t */\n\t\titems.value = cache.result;\n\n\t\tnextOffset = cache.nextOffset;\n\t};\n\n\tif (api && useCache) {\n\t\twatch(getCacheVersion(api.path), () => {\n\t\t\tsyncItemsFromCache();\n\t\t});\n\t}\n\n\t/**\n\t * Выполнить обращение к API\n\t *\n\t * При ошибке вернет undefined\n\t */\n\tconst callAPI = async (): Promise<Api.ResponseSuccess<any, 'get'> | undefined> => {\n\t\tif (!api) return;\n\n\t\tconst cacheKey = useCache ? genCacheKey(api) : undefined;\n\n\t\tif (cacheKey) {\n\t\t\tconst cache = getCache(cacheKey, api.path);\n\t\t\tif (cache) {\n\t\t\t\t// остановить запущенные api запросы\n\t\t\t\tapi.abortByFingerprint();\n\n\t\t\t\treturn cache;\n\t\t\t}\n\t\t}\n\n\t\tconst res = await api.call();\n\n\t\tif (res.errors) return;\n\n\t\tif (!Array.isArray(res.result)) {\n\t\t\tconsole.warn('Array expected in `res.result`');\n\n\t\t\treturn;\n\t\t}\n\n\t\tconst indexWithError = (res.result as Array<Item | any>).findIndex(item => item.id === undefined || item.name === undefined);\n\t\tif (indexWithError !== -1) {\n\t\t\tconsole.warn(`В result[${indexWithError}] нет id или name`);\n\n\t\t\treturn;\n\t\t}\n\n\t\tif (cacheKey) {\n\t\t\tsetCache(cacheKey, api.path, res);\n\t\t}\n\n\t\treturn res as Api.ResponseSuccess<any, 'get'>;\n\t};\n\n\t/**\n\t * Загрузить items\n\t */\n\tconst load = async (append: boolean) => {\n\t\tif (!api) return;\n\n\t\tif (append) {\n\t\t\t// данных о следующих страницах не обнаружено\n\t\t\tif (!nextOffset) return;\n\n\t\t\t// дозагружать нельзя, если не завершена предыдущая загрузка\n\t\t\tif (isLoading.value) return;\n\n\t\t\tapi.params.offset = nextOffset;\n\t\t} else {\n\t\t\tapi.params.offset = 0;\n\t\t}\n\n\t\tapiSetSearchParams?.(api, searchText);\n\n\t\tisLoading.value = true;\n\t\tconst res = await callAPI();\n\t\tisLoading.value = false;\n\n\t\tcountLoading.value++;\n\n\t\tif (!res) return;\n\n\t\tnextOffset = res.nextOffset;\n\n\t\tif (append) {\n\t\t\titems.value = items.value.concat(res.result);\n\t\t} else {\n\t\t\titems.value = res.result;\n\t\t}\n\t};\n\n\tconst loadDebounce = debounce(() => load(false), 200);\n\n\t/**\n\t * Выполнить поиск по указанному тексту\n\t *\n\t * Если длина текста меньше minLength, поиск не будет произведен\n\t *\n\t * Если текст не изменился, поиск не будет произведен\n\t *\n\t * @param newSearchText - текст поиска\n\t * @param useDebounce - дедупликация загрузки списка\n\t */\n\tconst setSearchTextAndLoad = (newSearchText: string, useDebounce = true) => {\n\t\tif (!api) return;\n\n\t\t// остановить начатый поиск и сбросить результаты\n\t\tif (newSearchText.length < minLength) {\n\t\t\tapi.abortByFingerprint();\n\n\t\t\titems.value = [];\n\n\t\t\treturn;\n\t\t}\n\n\t\t// условия поиска не поменялись, данные загружены\n\t\tif (newSearchText === searchText && items.value.length) return;\n\n\t\tsearchText = newSearchText;\n\n\t\tif (useDebounce) {\n\t\t\tvoid loadDebounce();\n\t\t} else {\n\t\t\tvoid load(false);\n\t\t}\n\t};\n\n\treturn {\n\t\tapiRequest: api,\n\t\titems,\n\t\tisLoading,\n\t\tcountLoading,\n\t\tload,\n\t\tsetSearchTextAndLoad,\n\t};\n};\n","import type { Item, Props } from './types';\nimport { genFieldFilter } from '@/api/api';\n\n/**\n * Универсальный id для всех элементов \"Все элементы\" / \"Без фильтра\" в `TopSelector`\n */\nexport const ITEM_ID_ALL = 0;\n\n/**\n * Универсальный id для всех добавляемых элементов через `TopSelector`\n */\nexport const ITEM_ID_NEW = null;\n\n/**\n * Выбран ли элемент\n */\nexport const isSelected = (modelValue: Props['modelValue'], item: Item, checkNameForNullId = true) => {\n\tif (checkNameForNullId && item.id === ITEM_ID_NEW) {\n\t\tif (Array.isArray(modelValue)) {\n\t\t\treturn modelValue.some(itemSelected => itemSelected.id === item.id && itemSelected.name === item.name);\n\t\t} else {\n\t\t\treturn item.name === modelValue.name;\n\t\t}\n\t}\n\n\tif (Array.isArray(modelValue)) {\n\t\treturn modelValue.some(itemSelected => itemSelected.id === item.id);\n\t} else {\n\t\treturn item.id === modelValue.id;\n\t}\n};\n\n/**\n * Вспомогательная утилита для создания `callback` функции на добавление фильтра по полю в api запрос\n *\n * Другие фильтры по указанному полю будут удалены\n *\n * @param api - api, которое используется в `TopSelector`\n * @param search - введенная строка поиска\n * @param fieldName - имя поля, по которому надо добавить фильтр на поиск по нестрогому соответствию\n *\n * @todo Объединить с apiSetSearchParamsFilter() из @/components/project/projectSelector/utils.ts\n */\nexport const apiSetSearchParamsFilter = (api: NonNullable<Props['api']>, search: string, fieldName: string) => {\n\tlet filters = api.params.filters ?? [];\n\n\t// удаление других фильтров по этому полю\n\tfilters = filters.filter((filter) => filter.name !== fieldName);\n\n\tif (search) {\n\t\tfilters.push(genFieldFilter(fieldName, 'CONTAINS', [search]));\n\t}\n\n\tapi.changeParams({ filters });\n};\n","import { computed, type ComputedRef, ref, type Ref, watch } from 'vue';\nimport { invertKeyboardLayout } from '@/core/utils/keyboard';\nimport type { Item, Props } from '../types';\nimport { type API } from './useAPI';\nimport { isSelected, ITEM_ID_ALL, ITEM_ID_NEW } from '../utils';\nimport { useI18n } from '@/core/plugins/i18n';\n\n/**\n * Функционал поиска\n */\nexport const useMenu = (\n\tmodel: Ref<Props['modelValue']>,\n\temits: ReturnType<typeof defineEmits>,\n\titems: Ref<Props['items']>,\n\tprepareItemsBeforeRender: Props['prepareItemsBeforeRender'],\n\tmultiselect: Props['multiselect'],\n\tuseAllItem: Ref<Props['useAllItem']>,\n\tappendSearchToResult: Ref<Props['appendSearchToResult']>,\n\tappendSearchAllowDuplicate: Ref<Props['appendSearchAllowDuplicate']>,\n\tappendSearchToResultCond: Ref<Props['appendSearchToResultCond']>,\n\tappendWithoutSelect: Ref<Props['appendWithoutSelect']>,\n\tsearchFields: Ref<Props['searchFields']>,\n\tsearchType: Ref<Props['searchType']>,\n\tminLength: number,\n\tapi: API,\n) => {\n\t/**\n\t * Текст поиска по результатам\n\t */\n\tconst searchText = ref('');\n\n\t/**\n\t * Объект, представляющий опцию \"Все\"\n\t */\n\tconst itemAll = {\n\t\tid: ITEM_ID_ALL,\n\t\tname: useI18n().Common.All as string,\n\t};\n\n\t/**\n\t * Сброс поиска\n\t */\n\tconst resetSearch = () => {\n\t\tsearchText.value = '';\n\t};\n\n\t/**\n\t * Является ли строка поиска достаточной длины для отображения меню\n\t */\n\tconst genIsShort = () => {\n\t\tif (!api.apiRequest) return false;\n\t\tif (searchText.value.length >= minLength) return false;\n\n\t\treturn true;\n\t};\n\n\t/**\n\t * Варианты выбора: props.items + \"Выбрать все\"\n\t */\n\tconst localItems: ComputedRef<Item[]> = computed(() => {\n\t\tconst localItems: Item[] = [];\n\n\t\tif (!multiselect && useAllItem.value) {\n\t\t\tif (typeof useAllItem.value === 'string') {\n\t\t\t\titemAll.name = useAllItem.value;\n\t\t\t}\n\n\t\t\tlocalItems.push(itemAll);\n\t\t}\n\n\t\titems.value?.forEach(item => localItems.push({ ...item }));\n\n\t\treturn localItems;\n\t});\n\n\t/**\n\t * Не используем `computed` в пользу ручного порядка пересчета значения\n\t */\n\tconst itemsForShow = ref<Item[]>([]);\n\n\tconst recalcItemsForShow = () => {\n\t\titemsForShow.value = genItemsForShow();\n\t};\n\n\t/**\n\t * Подготовленный список меню, который содержит в сумме:\n\t * - prop.items: указанный список с учетом фильтра и опций компонента\n\t * - api.items: результаты api запроса, если используется api\n\t *\n\t * @returns Отфильтрованный массив элементов для отображения\n\t */\n\tconst genItemsForShow = () => {\n\t\tconst searchString = searchText.value.toLowerCase();\n\t\tconst searchStringInvertKeyboard = invertKeyboardLayout(searchString);\n\n\t\tlet items: Item[] = [];\n\n\t\t/**\n\t\t * Элемент текущего разделителя в цикле\n\t\t *\n\t\t * Для скрытия / отображения только нужных заголовков и разделителей при поиске\n\t\t *\n\t\t * Логика для `api.items` должна реализовываться в api или api клиенте при генерации элементов\n\t\t */\n\t\tlet itemTitleCategory: Item | undefined;\n\t\tconst itemsCategory: Item[] = [];\n\n\t\t/**\n\t\t * Добавить элементы в результирующий список\n\t\t */\n\t\tconst flushCategory = () => {\n\t\t\t// крайний разделитель не выводить\n\t\t\tif (itemsCategory.at(-1)?.listItemProps?.type === 'delimiter') {\n\t\t\t\titemsCategory.pop();\n\t\t\t}\n\n\t\t\tif (itemsCategory.length) {\n\t\t\t\tif (itemTitleCategory) {\n\t\t\t\t\titems.push(itemTitleCategory);\n\t\t\t\t}\n\n\t\t\t\titems.push(...itemsCategory);\n\n\t\t\t\titemsCategory.length = 0;\n\t\t\t}\n\t\t};\n\n\t\tconst pushMatchedItemToCategory = (item: Item) => {\n\t\t\tconst hasIdSearch = searchFields.value?.includes('id');\n\t\t\tconst name = item.name.toLowerCase();\n\n\t\t\tconst searchFieldsText = searchFields.value\n\t\t\t\t?.filter(field => field !== 'id')\n\t\t\t\t.map(field => typeof item[field] === 'string' || typeof item[field] === 'number' ? item[field] : '')\n\t\t\t\t.join('☼')\n\t\t\t\t.toLowerCase();\n\n\t\t\tif (\n\t\t\t\t(hasIdSearch && item.id === Number(searchString)) ||\n\t\t\t\tsearchFieldsText?.includes(searchString) ||\n\t\t\t\tsearchFieldsText?.includes(searchStringInvertKeyboard)\n\t\t\t) {\n\t\t\t\tif (name === searchString || name === searchStringInvertKeyboard) {\n\t\t\t\t\t// точные совпадения в начало\n\t\t\t\t\titemsCategory.unshift(item);\n\t\t\t\t} else {\n\t\t\t\t\titemsCategory.push(item);\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\n\t\tfor (const item of localItems.value) {\n\t\t\tswitch (item.listItemProps?.type) {\n\t\t\t\tcase 'title':\n\t\t\t\t\tflushCategory();\n\n\t\t\t\t\titemTitleCategory = item;\n\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'delimiter':\n\t\t\t\t\t// вставить разделитель один раз и только если категория не пуста\n\t\t\t\t\tif (itemsCategory.length) {\n\t\t\t\t\t\tlet index = itemsCategory.length;\n\t\t\t\t\t\tif (itemsCategory.at(-1)?.listItemProps?.type === 'delimiter') index--;\n\n\t\t\t\t\t\titemsCategory[index] = item;\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\t\t\t\tdefault:\n\t\t\t\t\tpushMatchedItemToCategory(item);\n\t\t\t}\n\t\t}\n\n\t\tflushCategory();\n\n\t\titems.push(...api.items.value);\n\n\t\t// ввод произвольного значения\n\t\tif (\n\t\t\tappendSearchToResult.value &&\n\t\t\t!!searchText.value &&\n\t\t\t(!appendSearchToResultCond.value || appendSearchToResultCond.value(searchString)) &&\n\n\t\t\t// предложить добавить элемент, если нет точного совпадения или разрешены дубликаты\n\t\t\t(\n\t\t\t\tappendSearchAllowDuplicate.value ||\n\t\t\t\t!items.find((item) => item.name.toLowerCase() === searchString)\n\t\t\t)\n\t\t) {\n\t\t\tconst itemNew: Item = {\n\t\t\t\tid: ITEM_ID_NEW,\n\t\t\t\tname: searchText.value,\n\t\t\t};\n\n\t\t\tif (appendWithoutSelect.value) {\n\t\t\t\titemNew.listItemProps = { closeByClick: false };\n\t\t\t}\n\n\t\t\t// предложение всегда отображается внизу, чтобы не мешать результатам поиска\n\t\t\titems.push(itemNew);\n\t\t}\n\n\t\tif (multiselect) {\n\t\t\titems = items.filter(item => !isSelected(model.value, item));\n\t\t}\n\n\t\tif (prepareItemsBeforeRender) {\n\t\t\titems = prepareItemsBeforeRender(items);\n\t\t}\n\n\t\treturn items;\n\t};\n\n\t/**\n\t * Выбрать элемент\n\t *\n\t * @param item Элемент для выбора\n\t */\n\tconst selectItem = (item: Item) => {\n\t\t// это невыбираемый элемент\n\t\tif (item.listItemProps?.type === 'title' || item.listItemProps?.type === 'delimiter') {\n\t\t\treturn;\n\t\t}\n\n\t\tif (item.id === ITEM_ID_NEW) {\n\t\t\temits('appendItem', item);\n\n\t\t\tif (appendWithoutSelect.value) return;\n\t\t}\n\n\t\tif (multiselect && Array.isArray(model.value)) {\n\t\t\tif (!isSelected(model.value, item)) {\n\t\t\t\tmodel.value = [...model.value, item];\n\t\t\t}\n\t\t} else {\n\t\t\tmodel.value = item;\n\t\t}\n\n\t\t/**\n\t\t * Отложить перерисовку\n\t\t *\n\t\t * fix: Перерисовка меню выполняется раньше, чем срабатывает `click`.\n\t\t * Из-за этого обработчик кликов думает, что клик был вне меню и не закрывает окно\n\t\t *\n\t\t * Файл: @/components/popup/lib/popup.globalEvents.ts\n\t\t *\n\t\t * Функция: onclick()\n\t\t *\n\t\t * ```\n\t\t * const elPopup = e.target.closest<HTMLElement>('.top-popup-wrapper');\n\t\t * ```\n\t\t */\n\t\tsetTimeout(() => {\n\t\t\t/**\n\t\t\t * Завершить поиск после выбора\n\t\t\t */\n\t\t\tresetSearch();\n\t\t});\n\n\t\t// /**\n\t\t// * При изменении значения модели в режиме inline необходимо очистить поле поиска,\n\t\t// * так как поиск больше не актуален после выбора значения\n\t\t// */\n\t\t// if (searchType.value === 'inline') {\n\t\t// \tresetSearch();\n\t\t// }\n\t};\n\n\tif (api.apiRequest) {\n\t\t// загрузка только при открытии popup\n\t\tconst fieldsForWatch: any = [items, api.items];\n\n\t\t// model нужен только для multiselect, без необходимости не использовать для улучшения UX при работе с API\n\t\tif (multiselect) {\n\t\t\tfieldsForWatch.push(model);\n\t\t}\n\n\t\twatch(fieldsForWatch, () => {\n\t\t\trecalcItemsForShow();\n\t\t}, {\n\t\t\tdeep: 2,\n\t\t});\n\t} else {\n\t\twatch([model, items, searchText], () => {\n\t\t\trecalcItemsForShow();\n\t\t}, {\n\t\t\timmediate: true,\n\n\t\t\t// слежение за изменениями `items`\n\t\t\tdeep: 2,\n\t\t});\n\t}\n\n\t/**\n\t * Выбрать следующее значение\n\t */\n\tconst selectNextItem = () => {\n\t\tif (Array.isArray(model.value)) return;\n\n\t\tconst selectableItems = itemsForShow.value.filter((item) => !['title', 'delimiter'].includes(item.listItemProps?.type ?? ''));\n\n\t\tconst currentIndex = selectableItems.findIndex(item => item.id === (model.value as Item).id);\n\t\tconst nextIndex = (currentIndex + 1) % selectableItems.length;\n\t\tmodel.value = { ...selectableItems[nextIndex] };\n\t};\n\n\t/**\n\t * Удалить элемент, `id` и `name` которого равны указанному `item`\n\t */\n\tconst deleteItemByItem = async (item: Item) => {\n\t\tif (Array.isArray(model.value)) {\n\t\t\tmodel.value = model.value.filter((itemI) => itemI.id !== item.id || itemI.name !== item.name);\n\t\t}\n\t};\n\n\treturn {\n\t\tsearchText,\n\t\tresetSearch,\n\t\tgenIsShort,\n\t\titemsForShow,\n\t\tselectItem,\n\t\tselectNextItem,\n\t\tdeleteItemByItem,\n\t};\n};\n","<script setup lang=\"ts\">\nimport { computed, ref, toRef, watch } from 'vue';\nimport Core from '@/core/core/core';\nimport { TopPopup, TopPopupListItem, TopPopupWidgetInput } from '@/components/popup/popup';\nimport { TopPreloader } from '@/components/forms/forms';\nimport type { Emits, Item, Props, Slots } from './types';\nimport Selector2ItemMulti from './itemMulti.vue';\nimport { useAPI } from './composables/useAPI';\nimport { useMenu } from './composables/useMenu';\nimport type { TopLibPopup } from '../../popup/lib/popup';\nimport { clearCache, deleteCacheItemById, updateCacheItemById } from './cache';\nimport { ITEM_ID_ALL, ITEM_ID_NEW } from './utils';\n\nconst props = withDefaults(defineProps<Props>(), {\n\titems: () => [] as Item[],\n\tsize: 's',\n\tminLength: 0,\n\tsearchType: 'popup',\n\topenByFocusInput: undefined,\n\tsearchFields: () => ['id', 'name'],\n});\n\nconst model = defineModel<Props['modelValue']>({ required: true });\n\ndefineSlots<Slots>();\n\nconst emits = defineEmits<Emits>();\n\ndefineExpose({\n\t/**\n\t * Сброс локального кеша и кеша api\n\t *\n\t * @param resetAPICache - Сбросить API кеш, по умолчанию не сбрасывается. Для случаев, когда загруженные данные становятся неактуальными\n\t */\n\tresetCache: (resetAPICache: boolean = false) => {\n\t\tif (!api.apiRequest) return;\n\n\t\t// сброс кеша api\n\t\tif (resetAPICache) {\n\t\t\tclearCache(api.apiRequest.path);\n\t\t}\n\n\t\t// сброс кеша списка\n\t\tapi.items.value = [];\n\n\t\t// сброс флага первичной загрузки\n\t\tapi.countLoading.value = 0;\n\n\t\t// сброс параметров дозагрузки\n\t\tapi.apiRequest.params.offset = 0;\n\n\t\t// сброс кеша локального списка с дополнительными элементами, например `useAllItem`\n\t\trequestAnimationFrame(() => {\n\t\t\tmenu.itemsForShow.value = [];\n\t\t});\n\n\t\t// сразу загрузить данные после сброса, если popup уже открыт\n\t\tif (getPopup()?.elPopup) {\n\t\t\tapi.setSearchTextAndLoad(menu.searchText.value);\n\t\t}\n\t},\n\n\t/**\n\t * Локально обновить элемент списка по `id`, без перезагрузки через API\n\t */\n\tupdateCacheItemById: (id: Item['id'], patch: Partial<Item>) => {\n\t\tif (!api.apiRequest) return;\n\n\t\t// Так как кеш API синхронизирован с api.items, то удалять элемент из `api.items` нет смысла\n\t\t// const item = api.items.value.find((item) => item.id === id);\n\t\t// if (item) {\n\t\t// \tObject.assign(item, patch);\n\t\t// }\n\n\t\tif (api.apiRequest) {\n\t\t\tupdateCacheItemById(api.apiRequest.path, id, patch);\n\t\t}\n\t},\n\n\t/**\n\t * Удалить элемент списка по `id` во всех связанных инстансах без перезагрузки через API\n\t */\n\tdeleteCacheItemById: (id: Item['id']) => {\n\t\tif (!api.apiRequest) return;\n\n\t\t// Так как кеш API синхронизирован с api.items, то удалять элемент из `api.items` нет смысла\n\t\t// const itemIndex = api.items.value.findIndex((item) => item.id === id);\n\t\t//\n\t\t// if (itemIndex !== -1) {\n\t\t// \tapi.items.value.splice(itemIndex, 1);\n\t\t// }\n\n\t\tif (api.apiRequest) {\n\t\t\tdeleteCacheItemById(api.apiRequest.path, id);\n\t\t}\n\t},\n});\n\nconst searchTypeLocal = computed(() => {\n\t// multiselect не поддерживает inline ввода\n\tif (props.searchType === 'inline' && props.multiselect) return 'popup';\n\n\t// В мобильной версии popup работает в полноэкранном режиме\n\tif (props.searchType === 'inline' && Core.state.isMobile) return 'popup';\n\n\treturn props.searchType;\n});\n\n/**\n * Объект для работы с API\n */\nconst api = useAPI(props.api, props.apiSetSearchParams, props.minLength, props.useCache);\n\n/**\n * Объект для работы с меню\n */\nconst menu = useMenu(\n\tmodel,\n\temits,\n\ttoRef(props, 'items'),\n\tprops.prepareItemsBeforeRender,\n\tprops.multiselect,\n\ttoRef(props, 'useAllItem'),\n\ttoRef(props, 'appendSearchToResult'),\n\ttoRef(props, 'appendSearchAllowDuplicate'),\n\ttoRef(props, 'appendSearchToResultCond'),\n\ttoRef(props, 'appendWithoutSelect'),\n\ttoRef(props, 'searchFields'),\n\tsearchTypeLocal,\n\tprops.minLength,\n\tapi,\n);\n\nconst component = computed(() => {\n\tif (props.buttonProps) return 'TopButton';\n\tif (searchTypeLocal.value === 'inline') return 'TopInput';\n\n\treturn 'div';\n});\n\n/**\n * Экземпляр компонента Popup\n */\nconst popupRef = ref<any>(null);\n\n/**\n * Получить доступ к объекту popup\n */\nconst getPopup = (): TopLibPopup | undefined => {\n\treturn popupRef.value?.popup;\n};\n\nif (api.apiRequest) {\n\t// отложенный поиск при вводе текста\n\twatch(menu.searchText, () => {\n\t\tapi.setSearchTextAndLoad(menu.searchText.value);\n\t});\n}\n\nconst placeholder = computed(() => {\n\tif (Array.isArray(model.value) || props.multiselect || !props.selectedAsPlaceholder && searchTypeLocal.value !== 'inline') {\n\t\treturn props.placeholder;\n\t}\n\n\treturn model.value?.name || props.placeholder;\n});\n\n/**\n * Обработчик ввода клавиш на кнопке или поле ввода\n */\nconst onOpenerKeydown = (e: KeyboardEvent) => {\n\tlet needOpen = false;\n\n\tswitch (e.key) {\n\t\tcase 'Delete':\n\t\tcase 'Backspace':\n\t\t\tif (Array.isArray(model.value)) {\n\t\t\t\te.preventDefault();\n\t\t\t\te.stopPropagation();\n\n\t\t\t\tmodel.value.pop();\n\t\t\t}\n\n\t\t\tbreak;\n\t\tcase 'ArrowUp':\n\t\tcase 'ArrowRight':\n\t\tcase 'ArrowDown':\n\t\tcase 'ArrowLeft':\n\t\tcase 'Enter':\n\t\tcase ' ':\n\t\t\tneedOpen = true;\n\n\t\t\tbreak;\n\t\tcase 'Escape':\n\t\t\tif (searchTypeLocal.value === 'inline') {\n\t\t\t\t// очистка введенного текста\n\t\t\t\tmenu.resetSearch();\n\t\t\t}\n\n\t\t\tbreak;\n\t}\n\n\t// введен символ\n\tconst symbolPressed = e.key.length === 1 && !e.ctrlKey && !e.metaKey;\n\n\t// введен символ\n\tif (searchTypeLocal.value === 'popup' || searchTypeLocal.value === 'inline') {\n\t\tif (symbolPressed) {\n\t\t\tneedOpen = true;\n\t\t}\n\t}\n\n\t// popup уже открыт\n\tif (getPopup()?.elPopup) {\n\t\tneedOpen = false;\n\t}\n\n\tif (needOpen) {\n\t\tif (searchTypeLocal.value === 'popup') {\n\t\t\te.preventDefault();\n\t\t\te.stopPropagation();\n\n\t\t\t// введен символ\n\t\t\tif (symbolPressed) {\n\t\t\t\t// начало ввода, сразу ввести первый символ вместе с открытием popup\n\t\t\t\tif (!menu.searchText.value) {\n\t\t\t\t\tmenu.searchText.value = e.key;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t(e.currentTarget as HTMLElement)?.click();\n\t}\n};\n\nconst onClickChanger = (e: MouseEvent) => {\n\te.preventDefault();\n\n\tmenu.selectNextItem();\n};\n\n/**\n * Обработчик открытия попапа\n */\nconst onOpen = () => {\n\tif (api.apiRequest) {\n\t\t// при открытии сразу выполнить поиск\n\t\tapi.setSearchTextAndLoad(menu.searchText.value, false);\n\t}\n\n\temits('open');\n};\n\n/**\n * Обработчик закрытия попапа\n */\nconst onClose = () => {\n\t// очистка введенного текста, в режиме `inline` input вызывается при `blur`\n\tif (searchTypeLocal.value === 'popup') {\n\t\tif (menu.searchText.value) menu.resetSearch();\n\t}\n};\n\n/**\n * Обработчик прокрутки списка контента\n *\n * Для дозагрузки элеменов через api\n *\n * @param {Event} e - Событие прокрутки\n */\nconst onScrollContentList = (e: Event) => {\n\tconst el = e.target as HTMLElement;\n\n\tif (el.scrollTop / (el.scrollHeight - el.offsetHeight) > 0.8) {\n\t\tapi.load(true);\n\t}\n};\n\nif (import.meta.env.STORYBOOK) {\n\twatch(\n\t\t() => props.multiselect,\n\t\t() => {\n\t\t\tif (props.multiselect) {\n\t\t\t\tif (!Array.isArray(model.value)) {\n\t\t\t\t\tmodel.value = [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tid: 1,\n\t\t\t\t\t\t\tname: 'Выбери меня',\n\t\t\t\t\t\t},\n\t\t\t\t\t];\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif (Array.isArray(model.value)) {\n\t\t\t\t\tmodel.value = {\n\t\t\t\t\t\tid: null,\n\t\t\t\t\t\tname: '',\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t\t{ immediate: true },\n\t);\n\n\twatch(\n\t\t() => props.searchType,\n\t\t() => {\n\t\t\t// пауза для установки props в адресной строке\n\t\t\tsetTimeout(() => {\n\t\t\t\tlocation.reload();\n\t\t\t}, 500);\n\t\t},\n\t);\n}\n</script>\n\n<template>\n\t<TopPopup\n\t\tref=\"popupRef\"\n\t\t@open=\"onOpen()\"\n\t\t@close=\"onClose()\"\n\t\t@scrollContentList=\"api ? onScrollContentList($event) : undefined\"\n\t\t:notch=\"false\"\n\t\t:transitionDuration=\"0\"\n\t\t:openByFocusInput=\"searchTypeLocal === 'inline' && (openByFocusInput ?? true)\"\n\t\t:disabled=\"searchTypeLocal === 'inline' && menu.genIsShort()\"\n\t>\n\t\t<template #opener>\n\t\t\t<component\n\t\t\t\t:is=\"component\"\n\n\t\t\t\t:=\"buttonProps\"\n\n\t\t\t\t:class=\"{\n\t\t\t\t\t'top-selector2': true,\n\t\t\t\t\t'top-selector2-multiselect': multiselect,\n\t\t\t\t\t['top-selector2-' + modificator]: !!modificator,\n\t\t\t\t\t'top-as-input': !buttonProps && searchTypeLocal !== 'inline',\n\t\t\t\t\t'top-as-selector': true,\n\t\t\t\t\t['top-size_' + size]: true,\n\t\t\t\t\t['top-disabled']: disabled,\n\t\t\t\t\t['top-forms-focusable']: !disabled,\n\t\t\t\t\t['top-error']: isError,\n\t\t\t\t}\"\n\t\t\t\t:icon\n\t\t\t\ttabindex=\"0\"\n\t\t\t\t@keydown=\"onOpenerKeydown\"\n\t\t\t\t@blur=\"searchTypeLocal === 'inline' && menu.resetSearch()\"\n\t\t\t\tv-top-focus.onupdate=\"isError\"\n\t\t\t\tv-top-shortcut=\"openerShortcut\"\n\n\t\t\t\t:placeholder\n\t\t\t\t:title\n\t\t\t\t:captionType=\"searchTypeLocal === 'inline' && title !== undefined ? 'top' : undefined\"\n\t\t\t\tv-model=\"menu.searchText.value\"\n\t\t\t>\n\t\t\t\t<template v-if=\"multiselect\">\n\t\t\t\t\t<div class=\"top-selector2_activeItems\">\n\t\t\t\t\t\t<Selector2ItemMulti\n\t\t\t\t\t\t\tv-for=\"item of model as Item[]\"\n\t\t\t\t\t\t\t:key=\"item.id ?? undefined\"\n\t\t\t\t\t\t\t:id=\"item.id\"\n\t\t\t\t\t\t\t:name=\"item.name\"\n\t\t\t\t\t\t\t@delete=\"menu.deleteItemByItem\"\n\t\t\t\t\t\t/>\n\t\t\t\t\t</div>\n\t\t\t\t</template>\n\n\t\t\t\t<span v-if=\"searchTypeLocal !== 'inline' && !multiselect\" class=\"top-selector2_activeName top-ellipsis\">\n\t\t\t\t\t{{ !Array.isArray(model) ? model.name : '' }}\n\t\t\t\t</span>\n\n\t\t\t\t<span v-if=\"multiselect && !model.length\" class=\"top-selector2_placeholder top-ellipsis\">\n\t\t\t\t\t{{ placeholder }}\n\t\t\t\t</span>\n\n\t\t\t\t<span\n\t\t\t\t\tv-if=\"addChanger && !buttonProps && !multiselect && menu.itemsForShow.value.length > 1 && !disabled\"\n\t\t\t\t\tclass=\"top-changer top-changer-selector\"\n\t\t\t\t\tdata-top-popup-disabled=\"true\"\n\t\t\t\t\t@click=\"onClickChanger\"\n\t\t\t\t></span>\n\t\t\t</component>\n\t\t</template>\n\n\t\t<template #widget v-if=\"searchTypeLocal === 'popup'\">\n\t\t\t<div class=\"top-selector2_searchWidget\">\n\t\t\t\t<TopPopupWidgetInput\n\t\t\t\t\ttitle=\"Поиск\"\n\t\t\t\t\ticon=\"\"\n\t\t\t\t\tv-model=\"menu.searchText.value\"\n\t\t\t\t\tv-top-focus.onupdate=\"model\"\n\t\t\t\t\t:isLoading=\"!!api.countLoading.value && api.isLoading.value\"\n\t\t\t\t\t:placeholder\n\t\t\t\t/>\n\n\t\t\t\t<TopButton\n\t\t\t\t\tv-if=\"hasCloserBtn && !$core.state.isMobile\"\n\t\t\t\t\tclass=\"closer\"\n\t\t\t\t\tcolor=\"theme\"\n\t\t\t\t>\n\t\t\t\t\t{{ $i18n.Common.Cancel }}\n\t\t\t\t</TopButton>\n\t\t\t</div>\n\t\t</template>\n\n\t\t<template #contentList>\n\t\t\t<TopPopupListItem\n\t\t\t\tv-for=\"item of menu.itemsForShow.value\"\n\t\t\t\t:key=\"item.id ?? undefined\"\n\t\t\t\t:class=\"{\n\t\t\t\t\t'top-active': !Array.isArray(model) && !multiselect && model.id === item.id && model.name === item.name,\n\t\t\t\t\t'top-selector2_item-all':item.id === ITEM_ID_ALL,\n\t\t\t\t\t'top-selector2_item-new':item.id === ITEM_ID_NEW,\n\t\t\t\t}\"\n\t\t\t\t:closeByClick=\"!multiselect || Core.state.isMobile\"\n\t\t\t\t:=\"item.listItemProps\"\n\t\t\t\t@click=\"menu.selectItem(item)\"\n\t\t\t>\n\t\t\t\t<slot\n\t\t\t\t\tv-if=\"$slots.item\"\n\t\t\t\t\tname=\"item\"\n\t\t\t\t\t:item\n\t\t\t\t></slot>\n\n\t\t\t\t<template\n\t\t\t\t\tv-else\n\t\t\t\t>\n\t\t\t\t\t{{ item.name }}\n\t\t\t\t</template>\n\n\t\t\t\t<template v-if=\"$slots.actions\" #actions>\n\t\t\t\t\t<slot name=\"actions\" :item></slot>\n\t\t\t\t</template>\n\t\t\t</TopPopupListItem>\n\n\t\t\t<!-- Элементов для отображения нет -->\n\t\t\t<template v-if=\"!menu.itemsForShow.value.length && !menu.genIsShort()\">\n\t\t\t\t<TopPopupListItem type=\"regular\">\n\t\t\t\t\t<template v-if=\"!api.isLoading.value || api.countLoading.value\">\n\t\t\t\t\t\t{{ $i18n.Common.No_results }}\n\t\t\t\t\t</template>\n\n\t\t\t\t\t<!-- Индикатор первичной загрузки -->\n\t\t\t\t\t<TopPreloader\n\t\t\t\t\t\tv-else\n\t\t\t\t\t\ttype=\"circles\"\n\t\t\t\t\t/>\n\t\t\t\t</TopPopupListItem>\n\t\t\t</template>\n\n\t\t\t<!-- Индикатор повторной загрузки -->\n\t\t\t<TopLoadbar v-if=\"!!api.countLoading.value && api.isLoading.value && searchTypeLocal === 'inline'\"/>\n\t\t</template>\n\t</TopPopup>\n</template>\n\n<style>\n.top-selector2 {\n\twidth: 180px;\n}\n\n.top-selector2::placeholder,\n.top-selector2_placeholder {\n\tcolor: var(--color-text-2);\n}\n\n.top-selector2_placeholder {\n\tpadding-left: var(--top-padding-1);\n}\n\n.top-selector2.top-as-input {\n\tpadding: var(--top-padding-1) var(--top-forms-padding);\n}\n\n.top-selector2.top-selector2-multiselect {\n\twidth: auto;\n\tpadding: var(--top-padding-1);\n\tflex-grow: 1;\n}\n\n.top-selector2.top-active {\n\t--top-forms-border-color: var(--top-forms-border-color-hover);\n}\n\n.top-selector2_searchWidget {\n\tdisplay: flex;\n\tgap: var(--top-gap-2);\n}\n\n.top-selector2_activeItems {\n\tdisplay: flex;\n\tflex-wrap: wrap;\n\tgap: var(--top-padding-1);\n\tmax-width: 100%;\n}\n\n.top-selector2_activeName {\n\tfont-size: var(--top-font-size);\n\twhite-space: nowrap;\n}\n\n.top-changer-selector {\n\twidth: auto;\n\tpadding: var(--top-padding-1);\n\tmargin: calc(0px - var(--top-padding-1));\n\ttransform: translateX(0);\n}\n\n.top-selector2.top-button {\n\tjustify-content: start;\n}\n\n.top-selector2.top-input_input ~ .top-changer-selector {\n\ttransform: translateX(-52px);\n}\n\n.top-selector2.top-as-selector {\n\tpadding-right: calc(var(--top-selector-arrow-width) + var(--top-padding-2));\n}\n</style>\n","<script setup lang=\"ts\">\nimport { computed, ref } from 'vue';\nimport Button from '@/components/forms/button/button.vue';\nimport type { Emits, Props, Slots } from './types';\nimport Textarea from '@/components/forms/textarea/textarea.vue';\n\nconst props = withDefaults(defineProps<Props>(), {\n\tdefaultValue: '',\n\tcancelText: 'Cancel',\n\tsubmitText: 'Send',\n\tcloseText: 'Close',\n\texpandable: true,\n});\n\ndefineSlots<Slots>();\nconst emit = defineEmits<Emits>();\n\nconst localValue = ref(props.defaultValue);\n\nconst isFocused = ref(props.isFocused);\n\nconst isChanged = computed(() => localValue.value !== props.defaultValue);\n\nconst submit = (value: string) => {\n\temit('submit', value);\n\n\tlocalValue.value = props.defaultValue;\n};\n\nconst cancel = () => {\n\tif (props.forceShowCloseBtn && !isChanged.value) {\n\t\temit('close');\n\n\t\treturn;\n\t}\n\n\tlocalValue.value = props.defaultValue;\n};\n\nconst clickOnTitle = () => {\n\tif (props.attachToKeyboard) emit('clickOnTitle');\n};\n</script>\n\n<template>\n\t<div\n\t\t:class=\"{\n\t\t\t'top-editArea': true,\n\t\t\t'top-editArea-attachedToKeyboard': attachToKeyboard,\n\t\t}\"\n\t>\n\t\t<div\n\t\t\tv-if=\"title || $slots.caption\"\n\t\t\tclass=\"top-editArea_caption\"\n\t\t\t@click=\"clickOnTitle()\"\n\t\t>\n\t\t\t<slot name=\"caption\">\n\t\t\t\t{{ title }}\n\t\t\t</slot>\n\t\t</div>\n\n\t\t<div\n\t\t\t:class=\"{\n\t\t\t\t'top-editArea_form': true,\n\t\t\t\t'top-forms-focusable': true,\n\t\t\t\t'top-as-input': true,\n\t\t\t\t'top-error': isError,\n\t\t\t\t'top-focus': isFocused,\n\t\t\t}\"\n\t\t>\n\t\t\t<Textarea\n\t\t\t\tv-model=\"localValue\"\n\t\t\t\t:name=\"name\"\n\t\t\t\t:placeholder=\"placeholder\"\n\t\t\t\t:rows=\"rows\"\n\t\t\t\t:minHeight=\"minHeight\"\n\t\t\t\t:expandable=\"expandable\"\n\t\t\t\t:disabled=\"disabled\"\n\t\t\t\t:readonly=\"readonly\"\n\t\t\t\t:isError=\"isError\"\n\t\t\t\t:hint=\"hint\"\n\t\t\t\tclass=\"top-editArea_element\"\n\t\t\t\t@focus=\"() => isFocused = true\"\n\t\t\t\t@blur=\"() => isFocused = false\"\n\t\t\t\t@keyup.esc=\"cancel\"\n\t\t\t\t@keyup.ctrl.enter=\"submit(localValue)\"\n\t\t\t/>\n\n\t\t\t<div class=\"top-editArea_footer\">\n\t\t\t\t<Button\n\t\t\t\t\tv-if=\"isChanged || forceShowCloseBtn\"\n\t\t\t\t\t:icon=\"$core.state.isMobile ? '': ''\"\n\t\t\t\t\tclass=\"top-editArea_button\"\n\t\t\t\t\tcolor=\"theme\"\n\t\t\t\t\tstyling=\"soft\"\n\t\t\t\t\t@click=\"cancel\"\n\t\t\t\t>\n\t\t\t\t\t<template\n\t\t\t\t\t\t#default\n\t\t\t\t\t\tv-if=\"!$core.state.isMobile\"\n\t\t\t\t\t>\n\t\t\t\t\t\t{{ cancelText }}\n\t\t\t\t\t</template>\n\t\t\t\t</Button>\n\n\t\t\t\t<Button\n\t\t\t\t\tclass=\"top-editArea_button\"\n\t\t\t\t\tv-if=\"isChanged\"\n\t\t\t\t\t:icon=\"$core.state.isMobile ? '': ''\"\n\t\t\t\t\t@click=\"submit(localValue)\"\n\t\t\t\t>\n\t\t\t\t\t<template\n\t\t\t\t\t\t#default\n\t\t\t\t\t\tv-if=\"!$core.state.isMobile\"\n\t\t\t\t\t>\n\t\t\t\t\t\t{{ submitText }}\n\t\t\t\t\t</template>\n\t\t\t\t</Button>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n</template>\n\n<style>\n.top-editArea {\n\t--top-editArea-bottom: env(keyboard-inset-height, 0px);\n\t--top-editArea-offset-bottom: 0px;\n\n\tdisplay: flex;\n\tflex-direction: column;\n\tgap: 6px;\n}\n\n.top-editArea_caption {\n\tfont-size: 12px;\n}\n\n.top-editArea_form {\n\tflex-direction: column;\n}\n\n/* textarea в EditArea */\n.top-textarea {\n\twidth: 100%;\n}\n\n.top-editArea_element.top-textarea_textarea {\n\t--top-forms-border-width: 0px;\n\n\toutline: none;\n\tanimation: none;\n}\n\n/* footer */\n.top-editArea_footer {\n\tpadding: var(--top-forms-padding);\n\tdisplay: flex;\n\tmin-height: 32px;\n\talign-self: flex-end;\n\tjustify-content: flex-end;\n\tgap: var(--top-forms-padding);\n}\n\n/* attachedToKeyboard */\n.top-editArea-attachedToKeyboard {\n\tbackground: var(--top-forms-background-color);\n\tposition: fixed;\n\tbottom: calc(var(--top-editArea-offset-bottom) + var(--top-editArea-bottom));\n\tright: 0;\n\tleft: 0;\n\tz-index: 2;\n\tgap: 0;\n\ttransition: bottom var(--transition-fast);\n}\n\n.top-editArea-attachedToKeyboard .top-editArea_form {\n\tborder-radius: 0;\n\tborder: none;\n\tborder-top: 1px solid var(--top-forms-border-color);\n}\n\n.top-editArea-attachedToKeyboard .top-editArea_title {\n\tcursor: pointer;\n\tborder-top: 1px solid var(--color-line-2-opacity);\n\tpadding: var(--top-forms-padding);\n}\n\n.top-editArea-attachedToKeyboard .top-editArea_footer > [data-top-icon] {\n\tborder-radius: 100%;\n}\n\n@media screen and (max-width: 900px) {\n\t.top-editArea_form {\n\t\tflex-direction: row;\n\t}\n}\n</style>\n","<script setup lang=\"ts\">\nimport { ref, watch } from 'vue';\nimport type { Emits, Props } from './types';\nimport TopInput from '@/components/forms/input/input.vue';\nimport TopButton from '@/components/forms/button/button.vue';\n\nconst props = defineProps<Props>();\n\nconst intermediateValue = ref(props.modelValue);\n\nwatch(() => props.modelValue, () => {\n\tintermediateValue.value = props.modelValue;\n});\n\nconst emit = defineEmits<Emits>();\n\nconst submit = () => {\n\temit('update:modelValue', intermediateValue.value);\n};\n</script>\n\n<template>\n\t<div class=\"top-editInput\">\n\t\t<TopInput\n\t\t\t:=\"input\"\n\t\t\t@keydown.esc.capture.stop=\"intermediateValue = modelValue\"\n\t\t\t@keydown.enter.stop=\"submit\"\n\t\t\tv-model=\"intermediateValue\"\n\t\t>\n\t\t\t<template #caption v-if=\"$slots.caption\">\n\t\t\t\t<slot name=\"caption\"></slot>\n\t\t\t</template>\n\t\t</TopInput>\n\n\t\t<TopButton\n\t\t\tv-if=\"intermediateValue !== modelValue || alwaysShowSubmitBtn\"\n\t\t\ticon=\"\"\n\t\t\tstyling=\"soft\"\n\t\t\t:=\"button\"\n\t\t\t@click=\"submit\"\n\t\t/>\n\t</div>\n</template>\n\n<style>\n.top-editInput {\n\twidth: 220px;\n\tflex-grow: 1;\n\tdisplay: flex;\n\talign-items: flex-end;\n\tgap: var(--top-gap-1);\n}\n\n.top-editInput .top-input {\n\twidth: unset;\n\tflex-grow: 1;\n}\n</style>\n","<script setup lang=\"ts\">\nimport { ref, watch } from 'vue';\nimport type { Props } from './types';\nimport TopCheckbox from '@/components/forms/checkbox/checkbox.vue';\nimport TopRadio from '@/components/forms/radio/radio.vue';\n\nconst model = defineModel<Props['modelValue']>({\n\trequired: true,\n});\n\nconst props = withDefaults(defineProps<Props>(), {\n\tsize: 's',\n});\n\nconst elRef = ref<HTMLElement | null>(null);\n\nwatch(model, () => {\n\tconst valuesAvailable = props.items.map(item => item.value);\n\n\tif (Array.isArray(model.value)) {\n\t\t// есть ли неподдерживаемые значения\n\t\tconst valueIsWrong = model.value.find((value) => {\n\t\t\treturn !valuesAvailable.includes(value);\n\t\t});\n\n\t\tif (valueIsWrong) {\n\t\t\t// оставить только поддерживаемые значения\n\t\t\tmodel.value = model.value.filter((value) => {\n\t\t\t\treturn valuesAvailable.includes(value);\n\t\t\t});\n\t\t}\n\t} else {\n\t\tif (!valuesAvailable.includes(model.value)) {\n\t\t\tmodel.value = valuesAvailable[0] ?? '';\n\t\t}\n\t}\n\n\telRef.value?.querySelector('.radioGroup_item-selected')?.scrollIntoView();\n}, { immediate: true });\n\nconst name = 'optionGroup-' + Math.random();\n</script>\n\n<template>\n\t<div\n\t\tref=\"elRef\"\n\t\t:class=\"{\n\t\t\t['top-optionGroup']: true,\n\t\t\t['top-optionGroup-showIndicator_' + Number(showIndicator)]: true,\n\t\t\t['top-scrollBarXHidding']: true,\n\t\t\t['top-size_' + size]: !!size,\n\t\t\t['top-error']: isError,\n\t\t}\"\n\t>\n\t\t<template v-if=\"Array.isArray(model)\">\n\t\t\t<TopCheckbox\n\t\t\t\t:class=\"{\n\t\t\t\t\t['top-optionGroup_item-selected']: model.includes(item.value),\n\t\t\t\t\t['top-optionGroup_item']: true,\n\t\t\t\t}\"\n\t\t\t\tv-for=\"item of items\"\n\t\t\t\tv-model=\"model\"\n\t\t\t\t:value=\"item.value\"\n\t\t\t\t:title=\"item.title\"\n\t\t\t\t:disabled=\"item.disabled\"\n\t\t\t\t:isError\n\t\t\t\t:data-top-icon=\"item.icon\"\n\t\t\t>\n\t\t\t\t<template #default v-if=\"item.label\">\n\t\t\t\t\t{{ item.label }}\n\t\t\t\t</template>\n\t\t\t</TopCheckbox>\n\t\t</template>\n\n\t\t<template v-else>\n\t\t\t<TopRadio\n\t\t\t\t:class=\"{\n\t\t\t\t\t['top-optionGroup_item-selected']: item.value === model,\n\t\t\t\t\t['top-optionGroup_item']: true,\n\t\t\t\t}\"\n\t\t\t\tv-for=\"item of items\"\n\t\t\t\tv-model=\"model\"\n\t\t\t\t:name\n\t\t\t\t:value=\"item.value\"\n\t\t\t\t:title=\"item.title\"\n\t\t\t\t:disabled=\"item.disabled\"\n\t\t\t\t:isError\n\t\t\t\t:data-top-icon=\"item.icon\"\n\t\t\t>\n\t\t\t\t<template #default v-if=\"item.label\">\n\t\t\t\t\t{{ item.label }}\n\t\t\t\t</template>\n\t\t\t</TopRadio>\n\t\t</template>\n\t</div>\n</template>\n\n<style>\n.top-optionGroup {\n\tuser-select: none;\n\tbox-sizing: border-box;\n\tborder-radius: 8px;\n\tbackground-color: var(--color-layout-middle);\n\theight: var(--top-forms-base-height);\n\tpadding: 2px;\n\tgap: 2px;\n\tdisplay: flex;\n\talign-items: flex-start;\n}\n\n.top-optionGroup_item {\n\tcursor: pointer;\n\tbox-sizing: border-box;\n\tborder-radius: 6px;\n\theight: calc(var(--top-forms-base-height) - 4px);\n\tpadding: 1px var(--top-padding-2);\n\tcolor: var(--color-text-2);\n\tfont-weight: 400;\n\twhite-space: nowrap;\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\tflex-grow: 1;\n\tgap: var(--top-gap-1);\n}\n\n.top-optionGroup_item:hover {\n\tbackground-color: var(--color-layout-front-1);\n\tbox-shadow: 0px 4px 32px 0px rgba(4, 9, 84, 0.10), 0px 0px 4px 0px rgba(4, 9, 84, 0.08);\n}\n\n.top-optionGroup_item-selected {\n\tcolor: var(--color-text-1);\n\tbackground-color: var(--color-bg-lightning-1);\n\tbox-shadow: 0px 4px 32px 0px rgba(4, 9, 84, 0.10), 0px 0px 4px 0px rgba(4, 9, 84, 0.08);\n}\n\n.top-optionGroup_item > .top-forms-optionLabel {\n\tflex-grow: 0;\n}\n\n/* indicator */\n.top-optionGroup-showIndicator_0 > .top-optionGroup_item {\n\tjustify-content: center;\n}\n\n.top-optionGroup-showIndicator_0 > .top-optionGroup_item:has(:focus-visible) {\n\toutline: 2px solid var(--color-bg-primary-2);\n\toutline-offset: -1px;\n}\n\n.top-optionGroup-showIndicator_1 > .top-optionGroup_item {\n\tpadding: 1px 3px;\n\tjustify-content: flex-start;\n}\n\n.top-optionGroup-showIndicator_0 > .top-optionGroup_item > .top-forms-option {\n\topacity: 0;\n\twidth: 0;\n\theight: 0;\n\tposition: absolute;\n}\n\n.top-optionGroup_item > .top-forms-option {\n\torder: -1;\n}\n</style>\n","<script setup lang=\"ts\">\nimport OptionGroup from '../libs/optionGroup/optionGroup.vue';\n\nimport type { Props } from './types';\n\nconst model = defineModel<Props['modelValue']>({\n\trequired: true,\n});\n\ndefineProps<Props>();\n</script>\n\n<template>\n\t<OptionGroup\n\t\tclass=\"top-radioGroup\"\n\t\tv-model=\"model\"\n\t\t:items=\"$props.items\"\n\t\t:size=\"$props.size\"\n\t\t:showIndicator=\"$props.showIndicator\"\n\t\t:isError=\"$props.isError\"\n\t>\n\t\t<slot/>\n\t</OptionGroup>\n</template>\n","<script setup lang=\"ts\">\nimport OptionGroup from '../libs/optionGroup/optionGroup.vue';\n\nimport type { Props } from './types';\n\nconst model = defineModel<Props['modelValue']>({\n\trequired: true,\n});\n\ndefineProps<Props>();\n</script>\n\n<template>\n\t<OptionGroup\n\t\tclass=\"top-checkboxGroup\"\n\t\tv-model=\"model\"\n\t\t:items=\"$props.items\"\n\t\t:size=\"$props.size\"\n\t\t:showIndicator=\"$props.showIndicator\"\n\t\t:isError=\"$props.isError\"\n\t>\n\t\t<slot/>\n\t</OptionGroup>\n</template>\n","<script lang=\"ts\" setup>\nimport type { Props, Slots } from './types';\n\nwithDefaults(defineProps<Props>(), {\n\tstyling: 'default',\n\tsize: 'default',\n});\n\ndefineSlots<Slots>();\n</script>\n\n<template>\n\t<div\n\t\t:class=\"{\n\t\t\t['top-info']: true,\n\t\t\t['top-size_' + size]: true,\n\t\t\t['top-info-styling_' + styling]: true,\n\t\t}\"\n\t\t:data-top-icon=\"icon\"\n\t>\n\t\t<div class=\"top-info_text\">\n\t\t\t<slot></slot>\n\t\t</div>\n\n\t\t<span v-if=\"$slots.additional\" class=\"top-info_value\">\n\t\t\t<slot name=\"additional\"></slot>\n\t\t</span>\n\t</div>\n</template>\n\n<style>\n.top-info {\n\t--top-icon-width: var(--top-icon-size);\n\n\tborder-radius: var(--top-forms-radius);\n\tbox-sizing: border-box;\n\tmin-height: var(--top-forms-base-height);\n\tpadding: var(--top-padding-1) var(--top-padding-2);\n\tflex-grow: 5;\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: space-between;\n\tgap: var(--top-gap-2);\n}\n\n.top-info_text {\n\tflex-grow: 1;\n}\n\n.top-info_value {\n\tfont-weight: bold;\n}\n\n/* size */\n.top-info.top-size_default {\n\tborder-radius: var(--top-radius-3);\n\tpadding: var(--top-padding-4);\n}\n\n/* styling */\n.top-info-styling_default {\n\t--top-icon-color: var(--color-text-2);\n\n\tbackground: var(--color-layer-1);\n}\n\n.top-info-styling_info {\n\t--top-icon-color: var(--color-text-primary);\n\n\tbackground: var(--color-layer-primary-1);\n}\n\n.top-info-styling_warning {\n\t--top-icon-color: var(--color-text-warning);\n\n\tbackground: var(--color-layer-warning-1);\n}\n\n.top-info-styling_negative {\n\t--top-icon-color: var(--color-text-negative);\n\n\tbackground: var(--color-layer-negative-1);\n}\n</style>\n","<script setup lang=\"ts\">\nimport { ref } from 'vue';\nimport { TopButton } from '@/components/forms/forms';\nimport type { Emits, Props } from '@/components/formsExt/policy/types';\n\ndefineProps<Props>();\nconst emits = defineEmits<Emits>();\n\nconst isVisible = ref(true);\n\nconst onAccept = () => {\n\tisVisible.value = false;\n\n\temits('accept');\n};\n</script>\n\n<template>\n\t<div\n\t\tv-if=\"isVisible\"\n\t\tclass=\"top-policy\"\n\t>\n\t\t<div class=\"top-policy_title\">\n\t\t\t{{ title }}\n\t\t</div>\n\n\t\t<div\n\t\t\tclass=\"top-policy_description\"\n\t\t\tv-html=\"description\"\n\t\t></div>\n\n\t\t<TopButton\n\t\t\tsize=\"m\"\n\t\t\t@click=\"onAccept\"\n\t\t>\n\t\t\t{{ acceptText }}\n\t\t</TopButton>\n\t</div>\n</template>\n\n<style>\n.top-policy {\n\tbox-sizing: border-box;\n\tbox-shadow: var(--top-shadow-b);\n\tborder-radius: var(--top-radius-4);\n\tbackground: var(--color-bg-lightning-1);\n\twidth: 600px;\n\tpadding: var(--top-padding-4);\n\tposition: fixed;\n\tright: var(--top-gap-10);\n\tbottom: var(--top-gap-10);\n\tdisplay: flex;\n\tflex-direction: column;\n\tgap: var(--top-gap-4);\n\tz-index: 10000;\n}\n\n.top-policy_title {\n\tfont-size: 24px;\n\tfont-weight: 700;\n}\n\n.top-policy_description {\n\tfont-size: 14px;\n}\n\n@media screen and (max-width: 900px) {\n\t.top-policy {\n\t\twidth: 100%;\n\t\tright: 0;\n\t\tbottom: calc(var(--top-gap-5) + var(--toolbar-height, 0px));\n\t}\n}\n</style>\n"]}