@topvisor/ui 1.4.3-updateVue.0 → 1.5.0-updates.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 (412) hide show
  1. package/.chunks/core-Dgj_YGWh.es.js +268 -0
  2. package/.chunks/core-Dgj_YGWh.es.js.map +1 -0
  3. package/.chunks/core-DzDFXOdI.amd.js +2 -0
  4. package/.chunks/core-DzDFXOdI.amd.js.map +1 -0
  5. package/.chunks/{datepicker-Dhlk31EZ.amd.js → datepicker-oa8ZwRhq.amd.js} +2 -2
  6. package/.chunks/{datepicker-Dhlk31EZ.amd.js.map → datepicker-oa8ZwRhq.amd.js.map} +1 -1
  7. package/.chunks/{datepicker-3ihHfSr7.es.js → datepicker-qToxk2nN.es.js} +2 -2
  8. package/.chunks/{datepicker-3ihHfSr7.es.js.map → datepicker-qToxk2nN.es.js.map} +1 -1
  9. package/.chunks/{dialog_regionSelectorRegions-nk70o5Ht.amd.js → dialog_regionSelectorRegions-CZ0tMVSq.amd.js} +2 -2
  10. package/.chunks/{dialog_regionSelectorRegions-nk70o5Ht.amd.js.map → dialog_regionSelectorRegions-CZ0tMVSq.amd.js.map} +1 -1
  11. package/.chunks/{dialog_regionSelectorRegions-D9ZHTNkd.es.js → dialog_regionSelectorRegions-qDW2Ejsv.es.js} +5 -5
  12. package/.chunks/{dialog_regionSelectorRegions-D9ZHTNkd.es.js.map → dialog_regionSelectorRegions-qDW2Ejsv.es.js.map} +1 -1
  13. package/.chunks/{dialogs.vue_vue_type_script_setup_true_lang-B8xv-moy.amd.js → dialogs.vue_vue_type_script_setup_true_lang-BBix_8WK.amd.js} +2 -2
  14. package/.chunks/{dialogs.vue_vue_type_script_setup_true_lang-B8xv-moy.amd.js.map → dialogs.vue_vue_type_script_setup_true_lang-BBix_8WK.amd.js.map} +1 -1
  15. package/.chunks/{dialogs.vue_vue_type_script_setup_true_lang-BI9rU5DL.es.js → dialogs.vue_vue_type_script_setup_true_lang-CJ97l1ST.es.js} +3 -3
  16. package/.chunks/{dialogs.vue_vue_type_script_setup_true_lang-BI9rU5DL.es.js.map → dialogs.vue_vue_type_script_setup_true_lang-CJ97l1ST.es.js.map} +1 -1
  17. package/.chunks/{forms-D6S85mMQ.amd.js → forms-DDNzqU6o.amd.js} +3 -3
  18. package/.chunks/{forms-D6S85mMQ.amd.js.map → forms-DDNzqU6o.amd.js.map} +1 -1
  19. package/.chunks/{forms-CsPxqywz.es.js → forms-DtC-EKJL.es.js} +217 -213
  20. package/.chunks/{forms-CsPxqywz.es.js.map → forms-DtC-EKJL.es.js.map} +1 -1
  21. package/.chunks/lazy-DDNqYkXn.amd.js +2 -0
  22. package/.chunks/lazy-DDNqYkXn.amd.js.map +1 -0
  23. package/.chunks/{lazy-40pjr8cZ.es.js → lazy-HKSyLh72.es.js} +23 -19
  24. package/.chunks/lazy-HKSyLh72.es.js.map +1 -0
  25. package/.chunks/{notice-IPOLYVCW.es.js → notice-BvQl911b.es.js} +3 -3
  26. package/.chunks/{notice-IPOLYVCW.es.js.map → notice-BvQl911b.es.js.map} +1 -1
  27. package/.chunks/{notice-CNyRUCZZ.amd.js → notice-CJ3WOTCM.amd.js} +2 -2
  28. package/.chunks/{notice-CNyRUCZZ.amd.js.map → notice-CJ3WOTCM.amd.js.map} +1 -1
  29. package/.chunks/{page.vue_vue_type_script_setup_true_lang-CRea7lRi.es.js → page.vue_vue_type_script_setup_true_lang-Dd5-B4Ss.es.js} +9 -9
  30. package/.chunks/{page.vue_vue_type_script_setup_true_lang-CRea7lRi.es.js.map → page.vue_vue_type_script_setup_true_lang-Dd5-B4Ss.es.js.map} +1 -1
  31. package/.chunks/{page.vue_vue_type_script_setup_true_lang-BEpRLx2z.amd.js → page.vue_vue_type_script_setup_true_lang-fl6-Ql4d.amd.js} +2 -2
  32. package/.chunks/{page.vue_vue_type_script_setup_true_lang-BEpRLx2z.amd.js.map → page.vue_vue_type_script_setup_true_lang-fl6-Ql4d.amd.js.map} +1 -1
  33. package/.chunks/policy.vue_vue_type_style_index_0_lang-Bv3LwNDC.es.js +519 -0
  34. package/.chunks/policy.vue_vue_type_style_index_0_lang-Bv3LwNDC.es.js.map +1 -0
  35. package/.chunks/policy.vue_vue_type_style_index_0_lang-Da7rztT5.amd.js +2 -0
  36. package/.chunks/policy.vue_vue_type_style_index_0_lang-Da7rztT5.amd.js.map +1 -0
  37. package/.chunks/{popup-DvXkX-lu.es.js → popup-OuDglAOF.es.js} +4 -4
  38. package/.chunks/popup-OuDglAOF.es.js.map +1 -0
  39. package/.chunks/{popup-BrEWCQkR.amd.js → popup-yXIpyok3.amd.js} +2 -2
  40. package/.chunks/popup-yXIpyok3.amd.js.map +1 -0
  41. package/.chunks/{popupHint.vue_vue_type_style_index_0_lang-KuWtifP4.amd.js → popupHint.vue_vue_type_style_index_0_lang-Bu_HvFoW.amd.js} +2 -2
  42. package/.chunks/{popupHint.vue_vue_type_style_index_0_lang-KuWtifP4.amd.js.map → popupHint.vue_vue_type_style_index_0_lang-Bu_HvFoW.amd.js.map} +1 -1
  43. package/.chunks/{popupHint.vue_vue_type_style_index_0_lang-TWsWJQFN.es.js → popupHint.vue_vue_type_style_index_0_lang-DAQIAxvu.es.js} +5 -5
  44. package/.chunks/{popupHint.vue_vue_type_style_index_0_lang-TWsWJQFN.es.js.map → popupHint.vue_vue_type_style_index_0_lang-DAQIAxvu.es.js.map} +1 -1
  45. package/.chunks/{utils-BywGu5Tr.es.js → utils-BNzP9anP.es.js} +2 -2
  46. package/.chunks/{utils-BywGu5Tr.es.js.map → utils-BNzP9anP.es.js.map} +1 -1
  47. package/.chunks/{utils-B0_n8dlR.amd.js → utils-CWn_G7OO.amd.js} +2 -2
  48. package/.chunks/{utils-B0_n8dlR.amd.js.map → utils-CWn_G7OO.amd.js.map} +1 -1
  49. package/.chunks/utils-DIviuVEw.amd.js +2 -0
  50. package/.chunks/utils-DIviuVEw.amd.js.map +1 -0
  51. package/.chunks/{utils-BlXb8CrZ.es.js → utils-Dma85ehT.es.js} +68 -68
  52. package/.chunks/utils-Dma85ehT.es.js.map +1 -0
  53. package/.chunks/{widgetInput.vue_vue_type_script_setup_true_lang-Pp4anQxP.es.js → widgetInput.vue_vue_type_script_setup_true_lang-CX_BOcVY.es.js} +6 -6
  54. package/.chunks/{widgetInput.vue_vue_type_script_setup_true_lang-Pp4anQxP.es.js.map → widgetInput.vue_vue_type_script_setup_true_lang-CX_BOcVY.es.js.map} +1 -1
  55. package/.chunks/{widgetInput.vue_vue_type_script_setup_true_lang-BUY8yqxb.amd.js → widgetInput.vue_vue_type_script_setup_true_lang-CkOmb3VD.amd.js} +2 -2
  56. package/.chunks/{widgetInput.vue_vue_type_script_setup_true_lang-BUY8yqxb.amd.js.map → widgetInput.vue_vue_type_script_setup_true_lang-CkOmb3VD.amd.js.map} +1 -1
  57. package/api/additional.d.ts +0 -1
  58. package/api/index.amd.js +1 -1
  59. package/api/index.d.ts +0 -1
  60. package/api/index.js +6 -6
  61. package/assets/charts.css +1 -1
  62. package/assets/core.css +1 -1
  63. package/assets/forms.css +1 -1
  64. package/assets/notice.css +1 -1
  65. package/assets/policy.css +1 -1
  66. package/assets/project.css +1 -1
  67. package/assets/tabsView.css +1 -1
  68. package/assets/themes/dark.css +1 -1
  69. package/assets/themes/light.css +1 -1
  70. package/charts/charts.amd.js +1 -1
  71. package/charts/charts.d.ts +0 -1
  72. package/charts/charts.js +14 -14
  73. package/core/app.amd.js +1 -1
  74. package/core/app.d.ts +0 -1
  75. package/core/app.js +15 -15
  76. package/dialog/dialog.amd.js +1 -1
  77. package/dialog/dialog.d.ts +0 -1
  78. package/dialog/dialog.js +6 -6
  79. package/extra/extra.amd.js +1 -1
  80. package/extra/extra.amd.js.map +1 -1
  81. package/extra/extra.d.ts +0 -1
  82. package/extra/extra.js +10 -6
  83. package/extra/extra.js.map +1 -1
  84. package/forms/forms.amd.js +1 -1
  85. package/forms/forms.d.ts +0 -1
  86. package/forms/forms.js +1 -1
  87. package/formsExt/formsExt.amd.js +1 -1
  88. package/formsExt/formsExt.amd.js.map +1 -1
  89. package/formsExt/formsExt.d.ts +0 -1
  90. package/formsExt/formsExt.js +46 -45
  91. package/formsExt/formsExt.js.map +1 -1
  92. package/icomoon/Topvisor icons.json +776 -334
  93. package/icomoon/demo.html +85 -1
  94. package/icomoon/fonts/Topvisor-2.eot +0 -0
  95. package/icomoon/fonts/Topvisor-2.svg +6 -0
  96. package/icomoon/fonts/Topvisor-2.ttf +0 -0
  97. package/icomoon/fonts/Topvisor-2.woff +0 -0
  98. package/icomoon/selection.json +1 -1
  99. package/icomoon/style.css +23 -5
  100. package/layout/layout.amd.js +1 -1
  101. package/layout/layout.d.ts +0 -1
  102. package/layout/layout.js +7 -7
  103. package/package.json +6 -6
  104. package/popup/popup.amd.js +1 -1
  105. package/popup/popup.d.ts +0 -1
  106. package/popup/popup.js +9 -9
  107. package/popup/worker.amd.js +1 -1
  108. package/popup/worker.d.ts +0 -1
  109. package/popup/worker.js +2 -2
  110. package/project/project.amd.js +1 -1
  111. package/project/project.amd.js.map +1 -1
  112. package/project/project.d.ts +0 -1
  113. package/project/project.js +1052 -662
  114. package/project/project.js.map +1 -1
  115. package/src/{components → src/components}/charts/miniCharts/miniCharts.d.ts +1 -1
  116. package/src/{components → src/components}/core/notice/item/types.d.ts +1 -1
  117. package/src/{components → src/components}/core/notice/utils.d.ts +1 -1
  118. package/src/{components → src/components}/dialog/dialog/composables/dialogHandle.d.ts +1 -1
  119. package/src/{components → src/components}/dialog/dialog/dialogs/dialogs.vue.d.ts +2 -2
  120. package/src/{components → src/components}/dialog/dialog/stories/dialog_example/pages/utils.d.ts +1 -1
  121. package/src/src/components/dialog/dialog.d.ts +6 -0
  122. package/src/{components → src/components}/dialog/lib/worker.d.ts +1 -1
  123. package/src/{components → src/components}/forms/button/types.d.ts +1 -1
  124. package/src/{components → src/components}/forms/input/types.d.ts +1 -1
  125. package/src/src/components/forms/inputDate/types.d.ts +1 -0
  126. package/src/{components → src/components}/forms/select/types.d.ts +1 -1
  127. package/src/{components → src/components}/formsExt/editArea/types.d.ts +1 -1
  128. package/src/{components → src/components}/formsExt/editInput/types.d.ts +6 -2
  129. package/src/{components → src/components}/formsExt/libs/optionGroup/types.d.ts +1 -1
  130. package/src/{components → src/components}/formsExt/menu/types.d.ts +1 -1
  131. package/src/{components → src/components}/formsExt/policy/policy.vue.d.ts +1 -1
  132. package/src/{components → src/components}/formsExt/selector2/composables/useAPI.d.ts +210 -124
  133. package/src/{components → src/components}/formsExt/selector2/composables/useMenu.d.ts +211 -125
  134. package/src/{components → src/components}/formsExt/selector2/selector2.vue.d.ts +8 -5
  135. package/src/{components → src/components}/formsExt/selector2/types.d.ts +45 -3
  136. package/src/{components → src/components}/formsExt/selector2/utils.d.ts +2 -0
  137. package/src/{components → src/components}/popup/lib/popup.d.ts +3 -3
  138. package/src/{components → src/components}/popup/lib/worker.d.ts +2 -2
  139. package/src/{components → src/components}/popup/popup/opener/types.d.ts +1 -1
  140. package/src/{components → src/components}/popup/popup/popup.vue.d.ts +1 -1
  141. package/src/{components → src/components}/popup/popup/widgetInput/widgetInput.vue.d.ts +1 -1
  142. package/src/{components → src/components}/popup/popupConfirm/popupConfirm.vue.d.ts +1 -1
  143. package/src/{components → src/components}/project/competitorSelector/composables.d.ts +1 -1
  144. package/src/{components → src/components}/project/competitorSelector/types.d.ts +1 -1
  145. package/src/{components → src/components}/project/groupSelector/folders/types.d.ts +2 -1
  146. package/src/src/components/project/groupSelector/folders/utils.d.ts +422 -0
  147. package/src/{components → src/components}/project/groupSelector/groupSelector.vue.d.ts +2 -1
  148. package/src/{components → src/components}/project/groupSelector/groups/groups.vue.d.ts +20 -10
  149. package/src/{components → src/components}/project/groupSelector/groups/types.d.ts +2 -1
  150. package/src/src/components/project/groupSelector/groups/utils.d.ts +791 -0
  151. package/src/{components → src/components}/project/groupSelector/stories/mocks/index.d.ts +1 -1
  152. package/src/{components → src/components}/project/groupSelector/types.d.ts +6 -0
  153. package/src/src/components/project/groupSelector/utils.d.ts +37 -0
  154. package/src/{components → src/components}/project/project.d.ts +2 -0
  155. package/src/src/components/project/projectSelector/cache.d.ts +29 -0
  156. package/src/src/components/project/projectSelector/projectSelector.vue.d.ts +128 -0
  157. package/src/src/components/project/projectSelector/submenu/submenu.vue.d.ts +4 -0
  158. package/src/src/components/project/projectSelector/submenu/types.d.ts +17 -0
  159. package/src/src/components/project/projectSelector/types.d.ts +48 -0
  160. package/src/src/components/project/projectSelector/utils.d.ts +248 -0
  161. package/src/{components → src/components}/project/regionSelector/composables/selectRegion.d.ts +1 -1
  162. package/src/{components → src/components}/project/regionSelector/composables/selectSearcher.d.ts +1 -1
  163. package/src/{components → src/components}/project/regionSelector/dialog_regionSelectorRegions/types.d.ts +1 -1
  164. package/src/{components → src/components}/project/regionSelector/types.d.ts +9 -4
  165. package/src/{components → src/components}/project/regionSelector/utils/utils.d.ts +5 -5
  166. package/src/{components → src/components}/project/tagSelector/popupOpener/types.d.ts +1 -1
  167. package/src/{components → src/components}/project/tagSelector/types.d.ts +1 -1
  168. package/src/{components → src/components}/project/tagSelector/utils/el.d.ts +1 -1
  169. package/src/{components → src/components}/tabsView/tabsView/menu.vue.d.ts +2 -6
  170. package/src/{components → src/components}/tabsView/tabsView/store.d.ts +1 -1
  171. package/src/{core → src/core}/app.d.ts +2 -2
  172. package/src/{core → src/core}/core/core.d.ts +3 -3
  173. package/src/{core → src/core}/directives/shortcut.d.ts +2 -1
  174. package/src/src/core/directives/tooltip.d.ts +6 -0
  175. package/src/{core → src/core}/plugins/core.d.ts +6 -6
  176. package/src/{core → src/core}/utils/price.d.ts +2 -2
  177. package/src/src/core/utils/store.d.ts +6 -0
  178. package/src/src/core/utils/tests/date/dateFormat.test.d.ts +1 -0
  179. package/tabs/tabs.d.ts +0 -1
  180. package/tabs/tabs.js +5 -5
  181. package/tabsView/tabsView.amd.js +1 -1
  182. package/tabsView/tabsView.amd.js.map +1 -1
  183. package/tabsView/tabsView.d.ts +0 -1
  184. package/tabsView/tabsView.js +93 -104
  185. package/tabsView/tabsView.js.map +1 -1
  186. package/utils/check.d.ts +0 -1
  187. package/utils/clipboard.amd.js +1 -1
  188. package/utils/clipboard.d.ts +0 -1
  189. package/utils/clipboard.js +1 -1
  190. package/utils/date.amd.js +1 -1
  191. package/utils/date.d.ts +0 -1
  192. package/utils/date.js +1 -1
  193. package/utils/device.amd.js +1 -1
  194. package/utils/device.d.ts +0 -1
  195. package/utils/device.js +1 -1
  196. package/utils/dom.d.ts +0 -5
  197. package/utils/image.d.ts +0 -1
  198. package/utils/keyboard.d.ts +0 -1
  199. package/utils/lodash.amd.js +1 -1
  200. package/utils/lodash.d.ts +0 -1
  201. package/utils/lodash.js +1 -1
  202. package/utils/number.d.ts +0 -1
  203. package/utils/price.amd.js +1 -1
  204. package/utils/price.d.ts +0 -1
  205. package/utils/price.js +1 -1
  206. package/utils/route.d.ts +0 -1
  207. package/utils/scroll.d.ts +0 -1
  208. package/utils/searchers.amd.js +1 -1
  209. package/utils/searchers.d.ts +0 -1
  210. package/utils/searchers.js +3 -3
  211. package/utils/store.d.ts +0 -1
  212. package/utils/string.amd.js +1 -1
  213. package/utils/string.d.ts +0 -1
  214. package/utils/string.js +1 -1
  215. package/utils/system.d.ts +0 -1
  216. package/utils/url.d.ts +0 -1
  217. package/.chunks/core-CkdcFIiA.amd.js +0 -2
  218. package/.chunks/core-CkdcFIiA.amd.js.map +0 -1
  219. package/.chunks/core-D8Ou2oPH.es.js +0 -242
  220. package/.chunks/core-D8Ou2oPH.es.js.map +0 -1
  221. package/.chunks/lazy-40pjr8cZ.es.js.map +0 -1
  222. package/.chunks/lazy-DSFLxvj4.amd.js +0 -2
  223. package/.chunks/lazy-DSFLxvj4.amd.js.map +0 -1
  224. package/.chunks/policy.vue_vue_type_style_index_0_lang-CtJ7J9YB.amd.js +0 -2
  225. package/.chunks/policy.vue_vue_type_style_index_0_lang-CtJ7J9YB.amd.js.map +0 -1
  226. package/.chunks/policy.vue_vue_type_style_index_0_lang-D-FVZi-G.es.js +0 -496
  227. package/.chunks/policy.vue_vue_type_style_index_0_lang-D-FVZi-G.es.js.map +0 -1
  228. package/.chunks/popup-BrEWCQkR.amd.js.map +0 -1
  229. package/.chunks/popup-DvXkX-lu.es.js.map +0 -1
  230. package/.chunks/utils-BlXb8CrZ.es.js.map +0 -1
  231. package/.chunks/utils-Daq8EBlT.amd.js +0 -2
  232. package/.chunks/utils-Daq8EBlT.amd.js.map +0 -1
  233. package/src/components/dialog/dialog.d.ts +0 -6
  234. package/src/components/forms/inputDate/types.d.ts +0 -1
  235. package/src/components/project/groupSelector/folders/utils.d.ts +0 -63
  236. package/src/components/project/groupSelector/groups/utils.d.ts +0 -92
  237. package/src/core/directives/tooltip.d.ts +0 -10
  238. package/src/core/utils/store.d.ts +0 -6
  239. /package/src/{api → src/api}/api/additional.d.ts +0 -0
  240. /package/src/{api → src/api}/api/client/client.d.ts +0 -0
  241. /package/src/{api → src/api}/api/client/request-options.d.ts +0 -0
  242. /package/src/{api → src/api}/api/client/request.d.ts +0 -0
  243. /package/src/{api → src/api}/api/index.d.ts +0 -0
  244. /package/src/{api → src/api}/api/mocker/index.d.ts +0 -0
  245. /package/src/{api → src/api}/api/tests/types.test-d.d.ts +0 -0
  246. /package/src/{api → src/api}/api/types/api.d.ts +0 -0
  247. /package/src/{api → src/api}/api/types/client/client.d.ts +0 -0
  248. /package/src/{api → src/api}/api/types/client/middleware.d.ts +0 -0
  249. /package/src/{api → src/api}/api/types/client/options.d.ts +0 -0
  250. /package/src/{api → src/api}/api/types/client/request-context.d.ts +0 -0
  251. /package/src/{api → src/api}/api/types/client/request-options.d.ts +0 -0
  252. /package/src/{api → src/api}/api/types/client/request.d.ts +0 -0
  253. /package/src/{api → src/api}/api/types/ext.d.ts +0 -0
  254. /package/src/{api → src/api}/api/types/field.d.ts +0 -0
  255. /package/src/{api → src/api}/api/types/index.d.ts +0 -0
  256. /package/src/{api → src/api}/api/types/mocker.d.ts +0 -0
  257. /package/src/{api → src/api}/api/types/schema.d.ts +0 -0
  258. /package/src/{api → src/api}/api/types/tv.d.ts +0 -0
  259. /package/src/{api → src/api}/api/types/utils.d.ts +0 -0
  260. /package/src/{api → src/api}/api/utils/common.d.ts +0 -0
  261. /package/src/{api → src/api}/api/utils/field.d.ts +0 -0
  262. /package/src/{api → src/api}/api/utils/filters.d.ts +0 -0
  263. /package/src/{api → src/api}/api/utils/lazy.d.ts +0 -0
  264. /package/src/{components → src/components}/charts/charts.d.ts +0 -0
  265. /package/src/{components → src/components}/charts/miniChart/miniChart.vue.d.ts +0 -0
  266. /package/src/{components → src/components}/charts/miniChart/types.d.ts +0 -0
  267. /package/src/{components → src/components}/charts/miniChart/utils/consts.d.ts +0 -0
  268. /package/src/{components → src/components}/charts/miniCharts/miniCharts.vue.d.ts +0 -0
  269. /package/src/{components → src/components}/core/notice/item/item.vue.d.ts +0 -0
  270. /package/src/{components → src/components}/core/notice/notice.vue.d.ts +0 -0
  271. /package/src/{components → src/components}/core/notice/types.d.ts +0 -0
  272. /package/src/{components → src/components}/dialog/dialog/composables/asyncDialogHandle.d.ts +0 -0
  273. /package/src/{components → src/components}/dialog/dialog/composables/types.d.ts +0 -0
  274. /package/src/{components → src/components}/dialog/dialog/composables/utils.d.ts +0 -0
  275. /package/src/{components → src/components}/dialog/dialog/dialog.vue.d.ts +0 -0
  276. /package/src/{components → src/components}/dialog/dialog/page/page.vue.d.ts +0 -0
  277. /package/src/{components → src/components}/dialog/dialog/page/types.d.ts +0 -0
  278. /package/src/{components → src/components}/dialog/dialog/pageComponent/pageComponent.vue.d.ts +0 -0
  279. /package/src/{components → src/components}/dialog/dialog/pageComponent/types.d.ts +0 -0
  280. /package/src/{components → src/components}/dialog/dialog/types.d.ts +0 -0
  281. /package/src/{components → src/components}/dialog/lib/types.d.ts +0 -0
  282. /package/src/{components → src/components}/dialog/lib/utils.d.ts +0 -0
  283. /package/src/{components → src/components}/dialog/lib/utils.globalEvents.d.ts +0 -0
  284. /package/src/{components → src/components}/extra/extra.d.ts +0 -0
  285. /package/src/{components → src/components}/extra/rive/rive.vue.d.ts +0 -0
  286. /package/src/{components → src/components}/extra/rive/types.d.ts +0 -0
  287. /package/src/{components → src/components}/forms/avatar/avatar.vue.d.ts +0 -0
  288. /package/src/{components → src/components}/forms/avatar/types.d.ts +0 -0
  289. /package/src/{components → src/components}/forms/button/button.vue.d.ts +0 -0
  290. /package/src/{components → src/components}/forms/caption/caption.vue.d.ts +0 -0
  291. /package/src/{components → src/components}/forms/caption/types.d.ts +0 -0
  292. /package/src/{components → src/components}/forms/checkbox/checkbox.vue.d.ts +0 -0
  293. /package/src/{components → src/components}/forms/checkbox/types.d.ts +0 -0
  294. /package/src/{components → src/components}/forms/controlLabel/controlLabel.vue.d.ts +0 -0
  295. /package/src/{components → src/components}/forms/controlLabel/types.d.ts +0 -0
  296. /package/src/{components → src/components}/forms/forms.d.ts +0 -0
  297. /package/src/{components → src/components}/forms/helpers.d.ts +0 -0
  298. /package/src/{components → src/components}/forms/hint/hint.vue.d.ts +0 -0
  299. /package/src/{components → src/components}/forms/hint/types.d.ts +0 -0
  300. /package/src/{components → src/components}/forms/input/input.vue.d.ts +0 -0
  301. /package/src/{components → src/components}/forms/inputDate/datepicker.d.ts +0 -0
  302. /package/src/{components → src/components}/forms/inputDate/inputDate.vue.d.ts +0 -0
  303. /package/src/{components → src/components}/forms/inputRange/inputRange.vue.d.ts +0 -0
  304. /package/src/{components → src/components}/forms/inputRange/types.d.ts +0 -0
  305. /package/src/{components → src/components}/forms/loadbar/loadbar.vue.d.ts +0 -0
  306. /package/src/{components → src/components}/forms/preloader/preloader.vue.d.ts +0 -0
  307. /package/src/{components → src/components}/forms/preloader/types.d.ts +0 -0
  308. /package/src/{components → src/components}/forms/radio/radio.vue.d.ts +0 -0
  309. /package/src/{components → src/components}/forms/radio/types.d.ts +0 -0
  310. /package/src/{components → src/components}/forms/select/select.vue.d.ts +0 -0
  311. /package/src/{components → src/components}/forms/switcher/switcher.vue.d.ts +0 -0
  312. /package/src/{components → src/components}/forms/switcher/types.d.ts +0 -0
  313. /package/src/{components → src/components}/forms/textarea/textarea.vue.d.ts +0 -0
  314. /package/src/{components → src/components}/forms/textarea/types.d.ts +0 -0
  315. /package/src/{components → src/components}/formsExt/checkboxGroup/checkboxGroup.vue.d.ts +0 -0
  316. /package/src/{components → src/components}/formsExt/checkboxGroup/types.d.ts +0 -0
  317. /package/src/{components → src/components}/formsExt/editArea/editArea.vue.d.ts +0 -0
  318. /package/src/{components → src/components}/formsExt/editInput/editInput.vue.d.ts +0 -0
  319. /package/src/{components → src/components}/formsExt/formsExt.d.ts +0 -0
  320. /package/src/{components → src/components}/formsExt/info/info.vue.d.ts +0 -0
  321. /package/src/{components → src/components}/formsExt/info/types.d.ts +0 -0
  322. /package/src/{components → src/components}/formsExt/libs/optionGroup/optionGroup.vue.d.ts +0 -0
  323. /package/src/{components → src/components}/formsExt/menu/menu.vue.d.ts +0 -0
  324. /package/src/{components → src/components}/formsExt/policy/types.d.ts +0 -0
  325. /package/src/{components → src/components}/formsExt/radioGroup/radioGroup.vue.d.ts +0 -0
  326. /package/src/{components → src/components}/formsExt/radioGroup/types.d.ts +0 -0
  327. /package/src/{components → src/components}/formsExt/selector2/cache.d.ts +0 -0
  328. /package/src/{components → src/components}/formsExt/selector2/itemMulti.vue.d.ts +0 -0
  329. /package/src/{components → src/components}/layout/islandRows/islandRows.vue.d.ts +0 -0
  330. /package/src/{components → src/components}/layout/islandRows/islandRowsRow/islandRowsRow.vue.d.ts +0 -0
  331. /package/src/{components → src/components}/layout/islandRows/islandRowsRow/types.d.ts +0 -0
  332. /package/src/{components → src/components}/layout/islandRows/islandRowsSubTitle/islandRowsSubTitle.vue.d.ts +0 -0
  333. /package/src/{components → src/components}/layout/islandRows/types.d.ts +0 -0
  334. /package/src/{components → src/components}/layout/layout.d.ts +0 -0
  335. /package/src/{components → src/components}/layout/rows/rows.vue.d.ts +0 -0
  336. /package/src/{components → src/components}/layout/rows/types.d.ts +0 -0
  337. /package/src/{components → src/components}/popup/lib/popup.globalEvents.d.ts +0 -0
  338. /package/src/{components → src/components}/popup/lib/worker.globalEvents.d.ts +0 -0
  339. /package/src/{components → src/components}/popup/popup/listItem.vue.d.ts +0 -0
  340. /package/src/{components → src/components}/popup/popup/opener/opener.vue.d.ts +0 -0
  341. /package/src/{components → src/components}/popup/popup/types.d.ts +0 -0
  342. /package/src/{components → src/components}/popup/popup.d.ts +0 -0
  343. /package/src/{components → src/components}/popup/popupAlert/popupAlert.vue.d.ts +0 -0
  344. /package/src/{components → src/components}/popup/popupAlert/types.d.ts +0 -0
  345. /package/src/{components → src/components}/popup/popupConfirm/types.d.ts +0 -0
  346. /package/src/{components → src/components}/popup/popupHint/popupHint.vue.d.ts +0 -0
  347. /package/src/{components → src/components}/popup/popupHint/types.d.ts +0 -0
  348. /package/src/{components → src/components}/popup/popupPrompt/popupPrompt.vue.d.ts +0 -0
  349. /package/src/{components → src/components}/popup/popupPrompt/types.d.ts +0 -0
  350. /package/src/{components → src/components}/popup/worker.d.ts +0 -0
  351. /package/src/{components → src/components}/project/competitorSelector/competitorSelector.vue.d.ts +0 -0
  352. /package/src/{components → src/components}/project/groupSelector/folders/folders.vue.d.ts +0 -0
  353. /package/src/{components → src/components}/project/groupSelector/stories/mocks/folders.d.ts +0 -0
  354. /package/src/{components → src/components}/project/groupSelector/stories/mocks/groups.d.ts +0 -0
  355. /package/src/{components → src/components}/project/regionSelector/composables/compare.d.ts +0 -0
  356. /package/src/{components → src/components}/project/regionSelector/composables/selectorRegion.d.ts +0 -0
  357. /package/src/{components → src/components}/project/regionSelector/dialog_regionSelectorRegions/dialog_regionSelectorRegions.vue.d.ts +0 -0
  358. /package/src/{components → src/components}/project/regionSelector/regionSelector.vue.d.ts +0 -0
  359. /package/src/{components → src/components}/project/regionSelector/utils/consts.d.ts +0 -0
  360. /package/src/{components → src/components}/project/tagSelector/popupListItem/tagPopupListItem.vue.d.ts +0 -0
  361. /package/src/{components → src/components}/project/tagSelector/popupListItem/types.d.ts +0 -0
  362. /package/src/{components → src/components}/project/tagSelector/popupOpener/popupOpener.vue.d.ts +0 -0
  363. /package/src/{components → src/components}/project/tagSelector/tagIcon/tagIcon.vue.d.ts +0 -0
  364. /package/src/{components → src/components}/project/tagSelector/tagIcon/types.d.ts +0 -0
  365. /package/src/{components → src/components}/project/tagSelector/tagSelector.vue.d.ts +0 -0
  366. /package/src/{components → src/components}/project/tagSelector/tagsDefaults.d.ts +0 -0
  367. /package/src/{components → src/components}/project/tagSelector/utils/utils.d.ts +0 -0
  368. /package/src/{components → src/components}/tabs/tabs/content.vue.d.ts +0 -0
  369. /package/src/{components → src/components}/tabs/tabs/tab.vue.d.ts +0 -0
  370. /package/src/{components → src/components}/tabs/tabs/tabs.vue.d.ts +0 -0
  371. /package/src/{components → src/components}/tabs/tabs/types.d.ts +0 -0
  372. /package/src/{components → src/components}/tabs/tabs.d.ts +0 -0
  373. /package/src/{components → src/components}/tabsView/tabsView/menuDelimeter.vue.d.ts +0 -0
  374. /package/src/{components → src/components}/tabsView/tabsView/menuItem.vue.d.ts +0 -0
  375. /package/src/{components → src/components}/tabsView/tabsView/menuTitle.vue.d.ts +0 -0
  376. /package/src/{components → src/components}/tabsView/tabsView/tabsView.vue.d.ts +0 -0
  377. /package/src/{components → src/components}/tabsView/tabsView/types.d.ts +0 -0
  378. /package/src/{components → src/components}/tabsView/tabsView/utils.d.ts +0 -0
  379. /package/src/{components → src/components}/tabsView/tabsView.d.ts +0 -0
  380. /package/src/{core → src/core}/core/events/resize.d.ts +0 -0
  381. /package/src/{core → src/core}/core/events.d.ts +0 -0
  382. /package/src/{core → src/core}/core/options.d.ts +0 -0
  383. /package/src/{core → src/core}/core/preloaders.d.ts +0 -0
  384. /package/src/{core → src/core}/core/state.d.ts +0 -0
  385. /package/src/{core → src/core}/directives/data.d.ts +0 -0
  386. /package/src/{core → src/core}/directives/focus.d.ts +0 -0
  387. /package/src/{core → src/core}/directives/preloader.d.ts +0 -0
  388. /package/src/{core → src/core}/directives/scrollIntoView.d.ts +0 -0
  389. /package/src/{core → src/core}/directives/scrollShadow.d.ts +0 -0
  390. /package/src/{core → src/core}/directives/sticky.d.ts +0 -0
  391. /package/src/{core → src/core}/directives/swimUp.d.ts +0 -0
  392. /package/src/{core → src/core}/plugins/i18n.d.ts +0 -0
  393. /package/src/{core → src/core}/plugins/piniaTPA.d.ts +0 -0
  394. /package/src/{core → src/core}/utils/check.d.ts +0 -0
  395. /package/src/{core → src/core}/utils/clipboard.d.ts +0 -0
  396. /package/src/{core → src/core}/utils/composables/useWatch.d.ts +0 -0
  397. /package/src/{core → src/core}/utils/date.d.ts +0 -0
  398. /package/src/{core → src/core}/utils/device.d.ts +0 -0
  399. /package/src/{core → src/core}/utils/dom.d.ts +0 -0
  400. /package/src/{core → src/core}/utils/image.d.ts +0 -0
  401. /package/src/{core → src/core}/utils/keyboard.d.ts +0 -0
  402. /package/src/{core → src/core}/utils/lodash.d.ts +0 -0
  403. /package/src/{core → src/core}/utils/number.d.ts +0 -0
  404. /package/src/{core → src/core}/utils/route.d.ts +0 -0
  405. /package/src/{core → src/core}/utils/scroll.d.ts +0 -0
  406. /package/src/{core → src/core}/utils/searchers.d.ts +0 -0
  407. /package/src/{core → src/core}/utils/store/localStorage.d.ts +0 -0
  408. /package/src/{core → src/core}/utils/store/plugin.d.ts +0 -0
  409. /package/src/{core → src/core}/utils/store/store.d.ts +0 -0
  410. /package/src/{core → src/core}/utils/string.d.ts +0 -0
  411. /package/src/{core → src/core}/utils/system.d.ts +0 -0
  412. /package/src/{core → src/core}/utils/url.d.ts +0 -0
@@ -1,2 +0,0 @@
1
- define(["require","exports","vue","./forms-D6S85mMQ.amd","./popupHint.vue_vue_type_style_index_0_lang-KuWtifP4.amd","./widgetInput.vue_vue_type_script_setup_true_lang-BUY8yqxb.amd","../utils/keyboard.amd","./field-Cvv0SRcJ.amd","../require/css.amd!../assets/policy.css"],(function(te,L,e,w,E,$,R,q){"use strict";if(typeof e>"u")var e=window.Vue;const K={key:0,class:"top-menu_selectAll"},W=e.defineComponent({__name:"menu",props:e.mergeModels({modelValue:{},items:{},isMultiple:{type:Boolean},canBeEmptyMultiple:{type:Boolean},styling:{default:"default"},selectAllItem:{}},{modelValue:{required:!0},modelModifiers:{}}),emits:["update:modelValue"],setup(t){const r=t,n=e.useModel(t,"modelValue"),l=e.ref();!r.isMultiple&&typeof n.value!="string"&&typeof n.value!="number"&&console.warn('Type check failed for prop "modelValue". Expected String: '+typeof n.value),r.isMultiple&&!Array.isArray(n.value)&&console.warn('Type check failed for prop "modelValue". Expected Array: '+typeof n.value),r.isMultiple&&!r.canBeEmptyMultiple&&Array.isArray(n.value)&&!n.value.length&&r.items[0]&&(n.value=[r.items[0]?.href??r.items[0]?.value]);const c=o=>Array.isArray(n.value)?n.value.includes(o.value):o.value===n.value,C=(o,m=!1)=>{if(Array.isArray(n.value)){let u=n.value.slice();if(m){u.length||(u=r.items.map(h=>h.value));const g=u.indexOf(o.value);g===-1?u.push(o.value):u.splice(g,1)}else u.length===1&&u[0]===o.value?u=[]:u=[o.value];!r.canBeEmptyMultiple&&!u.length&&(u=[o.value]),n.value=u;return}n.value=o.value},d=o=>{if(l.value.scrollWidth<=l.value.offsetWidth||o.shiftKey||Math.abs(o.deltaY)<50)return;o.preventDefault();const m=o.deltaY>0?30:-30;l.value.scrollLeft=l.value.scrollLeft+m},f=(o=!0)=>{const m=l.value.querySelector(".top-active");if(!m)return;const u=24,g=m.offsetLeft-l.value.offsetLeft-u,h=m.offsetLeft-l.value.offsetLeft+m.clientWidth+u,y=l.value.scrollLeft,S=l.value.clientWidth+l.value.scrollLeft;let k;g<y&&(k=g),h>S&&(k=h-l.value.clientWidth),k!==void 0&&(w.isSafari()?w.Core.$?.(l.value).animate({scrollLeft:k},o?200:0):l.value.scrollTo({left:k,behavior:o?"smooth":"auto"}))},a=()=>{if(Array.isArray(n.value)){if(n.value.length===r.items.length){n.value=[r.items[0].href??r.items[0].value];return}n.value=r.items.map(o=>o.href??o.value)}};return e.onMounted(()=>f(!1)),e.onUpdated(()=>f(!0)),(o,m)=>(e.openBlock(),e.createElementBlock("div",{ref_key:"el",ref:l,class:e.normalizeClass({"top-menu":!0,["top-style_"+t.styling]:!0}),onWheel:d},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.items,u=>(e.openBlock(),e.createBlock(w._sfc_main$1,e.mergeProps({ref_for:!0},u,{class:"top-menu_item",color:"theme",onClick:g=>C(u,g.ctrlKey||g.metaKey),isActive:c(u)}),e.createSlots({_:2},[u.content?{name:"default",fn:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(u.content),1)]),key:"0"}:void 0]),1040,["onClick","isActive"]))),256)),Array.isArray(n.value)&&t.selectAllItem?(e.openBlock(),e.createElementBlock("div",K,[e.createVNode(w._sfc_main$1,e.mergeProps(t.selectAllItem,{class:"top-menu_item",color:"theme",styling:"",onClick:m[0]||(m[0]=u=>a()),isActive:n.value.length===t.items.length}),e.createSlots({_:2},[t.selectAllItem.content?{name:"default",fn:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(t.selectAllItem.content),1)]),key:"0"}:void 0]),1040,["isActive"])])):e.createCommentVNode("",!0)],34))}}),O={class:"top-selector2_itemMulti top-ellipsis"},z=e.defineComponent({__name:"itemMulti",props:{id:{},name:{}},emits:["delete"],setup(t){return(r,n)=>(e.openBlock(),e.createElementBlock("div",O,[e.createTextVNode(e.toDisplayString(t.name)+" ",1),e.createElementVNode("span",{class:"top-selector2_itemMultiDelete","data-top-icon":"",onClick:n[0]||(n[0]=l=>r.$emit("delete",{id:t.id,name:t.name})),onMousedown:n[1]||(n[1]=e.withModifiers(()=>{},["stop"]))},null,32)]))}}),x=new Map,U=t=>{x.get(t)?.clear()},Y=t=>{const r=window.mo?.user?.id;return JSON.stringify(t.params)+":"+t.url+":"+r},H=(t,r)=>x.get(r)?.get(t),J=(t,r,n)=>{x.has(r)||x.set(r,new Map),x.get(r)?.set(t,n)},j=(t,r,n,l)=>{const c=e.ref([]),C=e.ref(!1),d=e.ref(0);let f="",a;t&&!t.params.limit&&(t.params.limit=100);const o=async()=>{if(!t)return;const h=l?Y(t):void 0;if(h){const k=H(h,t.path);if(k)return t.abortByFingerprint(),k}const y=await t.call();if(y.errors)return;if(!Array.isArray(y.result)){console.warn("Array expected in `res.result`");return}const S=y.result.findIndex(k=>k.id===void 0||k.name===void 0);if(S!==-1){console.warn(`В result[${S}] нет id или name`);return}return h&&J(h,t.path,y),y},m=async h=>{if(!t)return;if(h){if(!a||C.value)return;t.params.offset=a}else t.params.offset=0;r?.(t,f),C.value=!0;const y=await o();C.value=!1,d.value++,y&&(a=y.nextOffset,h?c.value=c.value.concat(y.result):c.value=y.result)},u=w.debounce(()=>m(!1),200);return{apiRequest:t,items:c,isLoading:C,countLoading:d,load:m,setSearchTextAndLoad:(h,y=!0)=>{if(t){if(h.length<n){t.abortByFingerprint(),c.value=[];return}h===f&&c.value.length||(f=h,y?u():m(!1))}}}},P=0,b=null,N=(t,r,n=!0)=>n&&r.id===b?Array.isArray(t)?t.some(l=>l.id===r.id&&l.name===r.name):r.name===t.name:Array.isArray(t)?t.some(l=>l.id===r.id):r.id===t.id,G=(t,r,n)=>{let l=t.params.filters??[];l=l.filter(c=>c.name!==n),r&&l.push(q.genFieldFilter(n,"CONTAINS",[r])),t.changeParams({filters:l})},Q=(t,r,n,l,c,C,d,f,a)=>{const o=e.ref(""),m={id:P,name:w.useI18n().Common.All},u=()=>{o.value=""},g=()=>!(!a.apiRequest||o.value.length>=f),h=e.computed(()=>{const s=[];return!l&&c.value&&(typeof c.value=="string"&&(m.name=c.value),s.push(m)),n.value?.forEach(A=>s.push({...A})),s}),y=e.ref([]),S=()=>{y.value=k()},k=()=>{const s=o.value.toLowerCase(),A=R.invertKeyboardLayout(s);let i=[],T;const I=[],D=()=>{I.at(-1)?.listItemProps?.type==="delimiter"&&I.pop(),I.length&&(T&&i.push(T),i.push(...I),I.length=0)};for(const B of h.value)switch(B.listItemProps?.type){case"title":D(),T=B;break;case"delimiter":if(I.length){let F=I.length;I.at(-1)?.listItemProps?.type==="delimiter"&&F--,I[F]=B}break;default:const M=B.name.toLowerCase();(B.id===Number(s)||M.includes(s)||M.includes(A))&&(M===s||M===A?I.unshift(B):I.push(B))}if(D(),i.push(...a.items.value),C.value&&o.value&&!i.find(B=>B.name.toLowerCase()===s)){const B={id:b,name:o.value};i.push(B)}return l&&(i=i.filter(B=>!N(t.value,B))),i},V=s=>{s.listItemProps?.type==="title"||s.listItemProps?.type==="delimiter"||(l&&Array.isArray(t.value)?N(t.value,s)||(t.value=[...t.value,s]):t.value=s,s.id===b&&r("appendItem",s),setTimeout(()=>{u()}))};if(a.apiRequest){const s=[n,a.items];l&&s.push(t),e.watch(s,()=>{S()})}else e.watch([t,n,o],()=>{S()},{immediate:!0,deep:2});return{searchText:o,resetSearch:u,genIsShort:g,itemsForShow:y,selectItem:V,selectNextItem:()=>{if(Array.isArray(t.value))return;const s=y.value.filter(T=>!["title","delimiter"].includes(T.listItemProps?.type??"")),i=(s.findIndex(T=>T.id===t.value.id)+1)%s.length;t.value={...s[i]}},deleteItemByItem:async s=>{Array.isArray(t.value)&&(t.value=t.value.filter(A=>A.id!==s.id||A.name!==s.name))}}},X={key:0,class:"top-selector2_activeItems"},Z={key:1,class:"top-selector2_activeName top-ellipsis"},_={key:2,class:"top-selector2_placeholder top-ellipsis"},ee=e.defineComponent({__name:"selector2",props:e.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"},placeholder:{},api:{},apiSetSearchParams:{},minLength:{default:0},useCache:{type:Boolean},appendSearchToResult:{type:Boolean},multiselect:{type:Boolean},useAllItem:{type:[Boolean,String]},addChanger:{type:Boolean},buttonProps:{},selectedAsPlaceholder:{type:Boolean}},{modelValue:{required:!0},modelModifiers:{}}),emits:e.mergeModels(["appendItem"],["update:modelValue"]),setup(t,{expose:r,emit:n}){const l=t,c=e.useModel(t,"modelValue"),C=n;r({resetCache:(v=!1)=>{f.apiRequest&&(v&&U(f.apiRequest.path),f.items.value=[],f.countLoading.value=0,f.apiRequest.params.offset=0,requestAnimationFrame(()=>{a.itemsForShow.value=[]}),u()?.elPopup&&f.setSearchTextAndLoad(a.searchText.value))}});const d=e.computed(()=>l.searchType==="inline"&&l.multiselect||l.searchType==="inline"&&w.Core.state.isMobile?"popup":l.searchType),f=j(l.api,l.apiSetSearchParams,l.minLength,l.useCache),a=Q(c,C,e.toRef(l,"items"),l.multiselect,e.toRef(l,"useAllItem"),e.toRef(l,"appendSearchToResult"),d,l.minLength,f),o=e.computed(()=>l.buttonProps?"TopButton":d.value==="inline"?"TopInput":"div"),m=e.ref(null),u=()=>m.value?.popup;f.apiRequest&&e.watch(a.searchText,()=>{f.setSearchTextAndLoad(a.searchText.value)});const g=e.computed(()=>Array.isArray(c.value)||l.multiselect||!l.selectedAsPlaceholder&&d.value!=="inline"?l.placeholder:c.value?.name||l.placeholder),h=v=>{let p=!1;switch(v.key){case"Delete":case"Backspace":Array.isArray(c.value)&&(v.preventDefault(),v.stopPropagation(),c.value.pop());break;case"ArrowUp":case"ArrowRight":case"ArrowDown":case"ArrowLeft":case"Enter":case" ":p=!0;break;case"Escape":d.value==="inline"&&a.resetSearch();break}const s=v.key.length===1&&!v.ctrlKey&&!v.metaKey;(d.value==="popup"||d.value==="inline")&&s&&(p=!0),u()?.elPopup&&(p=!1),p&&(d.value==="popup"&&(v.preventDefault(),v.stopPropagation(),s&&(a.searchText.value||(a.searchText.value=v.key))),v.currentTarget?.click())},y=v=>{v.preventDefault(),a.selectNextItem()},S=()=>{f.apiRequest&&f.setSearchTextAndLoad(a.searchText.value,!1)},k=()=>{d.value==="popup"&&a.searchText.value&&a.resetSearch()},V=v=>{const p=v.target;p.scrollTop/(p.scrollHeight-p.offsetHeight)>.8&&f.load(!0)};return(v,p)=>{const s=e.resolveComponent("TopLoadbar"),A=e.resolveDirective("top-focus");return e.openBlock(),e.createBlock(e.unref(E._sfc_main),{ref_key:"popupRef",ref:m,onOpen:p[3]||(p[3]=i=>S()),onClose:p[4]||(p[4]=i=>k()),onScrollContentList:p[5]||(p[5]=i=>e.unref(f)?V(i):void 0),notch:!1,transitionDuration:0,openByFocusInput:d.value==="inline"&&(t.openByFocusInput??!0),disabled:d.value==="inline"&&e.unref(a).genIsShort()},e.createSlots({opener:e.withCtx(()=>[e.withDirectives((e.openBlock(),e.createBlock(e.resolveDynamicComponent(o.value),e.mergeProps(t.buttonProps,{class:{"top-selector2":!0,"top-selector2-multiselect":t.multiselect,["top-selector2-"+t.modificator]:!!t.modificator,"top-as-input":!t.buttonProps&&d.value!=="inline","top-as-selector":!0,["top-size_"+t.size]:!0,"top-disabled":t.disabled,"top-forms-focusable":!t.disabled,"top-error":t.isError},icon:t.icon,tabindex:"0",onKeydown:h,onBlur:p[0]||(p[0]=i=>d.value==="inline"&&e.unref(a).resetSearch()),placeholder:g.value,title:t.title,captionType:d.value==="inline"&&t.title!==void 0?"top":void 0,modelValue:e.unref(a).searchText.value,"onUpdate:modelValue":p[1]||(p[1]=i=>e.unref(a).searchText.value=i)}),{default:e.withCtx(()=>[t.multiselect?(e.openBlock(),e.createElementBlock("div",X,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(c.value,i=>(e.openBlock(),e.createBlock(z,{id:i.id,name:i.name,onDelete:e.unref(a).deleteItemByItem},null,8,["id","name","onDelete"]))),256))])):e.createCommentVNode("",!0),d.value!=="inline"&&!t.multiselect?(e.openBlock(),e.createElementBlock("span",Z,e.toDisplayString(Array.isArray(c.value)?"":c.value.name),1)):e.createCommentVNode("",!0),t.multiselect&&!c.value.length?(e.openBlock(),e.createElementBlock("span",_,e.toDisplayString(g.value),1)):e.createCommentVNode("",!0),t.addChanger&&!t.buttonProps&&!t.multiselect&&e.unref(a).itemsForShow.value.length>1&&!t.disabled?(e.openBlock(),e.createElementBlock("span",{key:3,class:"top-changer top-changer-selector","data-top-popup-disabled":"true",onClick:y})):e.createCommentVNode("",!0)]),_:1},16,["class","icon","placeholder","title","captionType","modelValue"])),[[A,t.isError,void 0,{onupdate:!0}]])]),contentList:e.withCtx(()=>[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(a).itemsForShow.value,i=>(e.openBlock(),e.createBlock(e.unref(E._sfc_main$2),e.mergeProps({key:i.id??void 0,class:{"top-active":!Array.isArray(c.value)&&!t.multiselect&&c.value.id===i.id&&c.value.name===i.name,"top-selector2_item-all":i.id===e.unref(P),"top-selector2_item-new":i.id===e.unref(b)}},{ref_for:!0},i.listItemProps,{closeByClick:!t.multiselect||e.unref(w.Core).state.isMobile,onClick:T=>e.unref(a).selectItem(i)}),{default:e.withCtx(()=>[v.$slots.item?e.renderSlot(v.$slots,"item",{key:0,item:i}):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(i.name),1)],64))]),_:2},1040,["class","closeByClick","onClick"]))),128)),!e.unref(a).itemsForShow.value.length&&!e.unref(a).genIsShort()?(e.openBlock(),e.createBlock(e.unref(E._sfc_main$2),{key:0,type:"regular"},{default:e.withCtx(()=>[!e.unref(f).isLoading.value||e.unref(f).countLoading.value?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createTextVNode(e.toDisplayString(v.$i18n.Common.No_results),1)],64)):(e.openBlock(),e.createBlock(e.unref(w._sfc_main$12),{key:1,type:"circles"}))]),_:1})):e.createCommentVNode("",!0),e.unref(f).countLoading.value&&e.unref(f).isLoading.value&&d.value==="inline"?(e.openBlock(),e.createBlock(s,{key:1})):e.createCommentVNode("",!0)]),_:2},[d.value==="popup"?{name:"widget",fn:e.withCtx(()=>[e.withDirectives(e.createVNode(e.unref($._sfc_main),{title:"Поиск",icon:"",modelValue:e.unref(a).searchText.value,"onUpdate:modelValue":p[2]||(p[2]=i=>e.unref(a).searchText.value=i),isLoading:!!e.unref(f).countLoading.value&&e.unref(f).isLoading.value,placeholder:g.value},null,8,["modelValue","isLoading","placeholder"]),[[A,c.value,void 0,{onupdate:!0}]])]),key:"0"}:void 0]),1032,["openByFocusInput","disabled"])}}});L.ITEM_ID_ALL=P,L.ITEM_ID_NEW=b,L._sfc_main=ee,L._sfc_main$1=W,L.apiSetSearchParamsFilter=G}));
2
- //# sourceMappingURL=policy.vue_vue_type_style_index_0_lang-CtJ7J9YB.amd.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"policy.vue_vue_type_style_index_0_lang-CtJ7J9YB.amd.js","sources":["../../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"],"sourcesContent":["<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 type { Props } from './types';\n\n/**\n * Список кешей для конкретного API метода\n */\nexport const cacheByMethod = new Map<Api.PathAbstract, Map<string, any>>();\n\n/**\n * Сброс кеша конкретного API метода\n */\nexport const clearCache = (apiPath: Api.PathAbstract) => {\n\tcacheByMethod.get(apiPath)?.clear();\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: any) => {\n\tif (!cacheByMethod.has(apiPath)) {\n\t\tcacheByMethod.set(apiPath, new Map());\n\t}\n\n\tcacheByMethod.get(apiPath)?.set(cacheKey, data);\n};\n","import { ref } from 'vue';\nimport { debounce } from '../../../../core/utils/lodash';\nimport type { Item, Props } from '../types';\nimport { genCacheKey, getCache, 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 * Выполнить обращение к 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 */\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\tmultiselect: Props['multiselect'],\n\tuseAllItem: Ref<Props['useAllItem']>,\n\tappendSearchToResult: Ref<Props['appendSearchToResult']>,\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\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\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\tconst name = item.name.toLowerCase();\n\t\t\t\t\tif (\n\t\t\t\t\t\titem.id === Number(searchString) ||\n\t\t\t\t\t\tname.includes(searchString) ||\n\t\t\t\t\t\tname.includes(searchStringInvertKeyboard)\n\t\t\t\t\t) {\n\t\t\t\t\t\tif (name === searchString || name === searchStringInvertKeyboard) {\n\t\t\t\t\t\t\t// точные совпадения в начало\n\t\t\t\t\t\t\titemsCategory.unshift(item);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\titemsCategory.push(item);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\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\n\t\t\t// результаты могут быть найдены, но не точные, тогда предложить добавить элемент\n\t\t\t!items.find((item) => item.name.toLowerCase() === searchString)\n\t\t) {\n\t\t\tconst itemNew = {\n\t\t\t\tid: ITEM_ID_NEW,\n\t\t\t\tname: searchText.value,\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\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 (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\tif (item.id === ITEM_ID_NEW) {\n\t\t\temits('appendItem', 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} 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 } 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});\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\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.multiselect,\n\ttoRef(props, 'useAllItem'),\n\ttoRef(props, 'appendSearchToResult'),\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\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\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: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<TopPopupWidgetInput\n\t\t\t\ttitle=\"Поиск\"\n\t\t\t\ticon=\"\"\n\t\t\t\tv-model=\"menu.searchText.value\"\n\t\t\t\tv-top-focus.onupdate=\"model\"\n\t\t\t\t:isLoading=\"!!api.countLoading.value && api.isLoading.value\"\n\t\t\t\t:placeholder\n\t\t\t/>\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:=\"item.listItemProps\"\n\t\t\t\t:closeByClick=\"!multiselect || Core.state.isMobile\"\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\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_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\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"],"names":["el","vue","props","model","itemIsActive","item","index","modelNew","onWheel","event","delta","scrollIntoView","isSmooth","leftMargin","elBtn","gap","rightMargin","leftMarginParent","rightMarginParent","scrollLeft","$event","select","_cache","selectAll","__props","_ctx","cacheByMethod","clearCache","apiPath","genCacheKey","api","getCache","cacheKey","data","items","isLoading","countLoading","nextOffset","cache","res","indexWithError","load","append","apiSetSearchParams","searchText","callAPI","loadDebounce","forms","newSearchText","minLength","ITEM_ID_ALL","ITEM_ID_NEW","modelValue","itemSelected","apiSetSearchParamsFilter","search","fieldName","filters","filter","field","localItems","multiselect","useAllItem","itemAll","localItems2","itemsForShow","genItemsForShow","searchStringInvertKeyboard","utils_keyboard","searchString","itemTitleCategory","itemsCategory","items2","flushCategory","itemNew","isSelected","selectItem","emits","resetSearch","fieldsForWatch","recalcItemsForShow","genIsShort","selectableItems","itemI","__expose","resetAPICache","menu","getPopup","searchTypeLocal","component","popupRef","placeholder","onOpenerKeydown","e","symbolPressed","onClickChanger","onScrollContentList","onOpen","onClose","_hoisted_1","popupHint_vue_vue_type_style_index_0_lang"],"mappings":"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"}
@@ -1,496 +0,0 @@
1
-
2
- import { Core as _autoloadCSSCore } from '../core/app.js';
3
- const fileNames = ['../assets/policy.css'].map(fileName => import.meta.resolve(fileName));
4
- _autoloadCSSCore.insertCSSLinkToPage(fileNames, true);
5
-
6
- import { defineComponent as J, mergeModels as W, useModel as ee, ref as $, onMounted as ae, onUpdated as se, createElementBlock as L, openBlock as g, normalizeClass as ne, createCommentVNode as M, Fragment as F, renderList as z, createBlock as S, mergeProps as R, createSlots as U, withCtx as B, createTextVNode as E, toDisplayString as P, createVNode as te, createElementVNode as re, withModifiers as oe, computed as N, watch as H, toRef as O, resolveComponent as ie, resolveDirective as ue, unref as f, renderSlot as ce, withDirectives as Q, resolveDynamicComponent as fe } from "vue";
7
- import { e as X, b as de, C as Y, d as pe, u as ve, s as me } from "./forms-CsPxqywz.es.js";
8
- import { _ as ye, b as Z } from "./popupHint.vue_vue_type_style_index_0_lang-TWsWJQFN.es.js";
9
- import { _ as he } from "./widgetInput.vue_vue_type_script_setup_true_lang-Pp4anQxP.es.js";
10
- import { invertKeyboardLayout as ge } from "../utils/keyboard.js";
11
- import { g as Ae } from "./field-CyyFzM-Y.es.js";
12
- const Ie = {
13
- key: 0,
14
- class: "top-menu_selectAll"
15
- }, Re = /* @__PURE__ */ J({
16
- __name: "menu",
17
- props: /* @__PURE__ */ W({
18
- modelValue: {},
19
- items: {},
20
- isMultiple: { type: Boolean },
21
- canBeEmptyMultiple: { type: Boolean },
22
- styling: { default: "default" },
23
- selectAllItem: {}
24
- }, {
25
- modelValue: {
26
- required: !0
27
- },
28
- modelModifiers: {}
29
- }),
30
- emits: ["update:modelValue"],
31
- setup(e) {
32
- const a = e, l = ee(e, "modelValue"), t = $();
33
- !a.isMultiple && typeof l.value != "string" && typeof l.value != "number" && console.warn('Type check failed for prop "modelValue". Expected String: ' + typeof l.value), a.isMultiple && !Array.isArray(l.value) && console.warn('Type check failed for prop "modelValue". Expected Array: ' + typeof l.value), a.isMultiple && !a.canBeEmptyMultiple && Array.isArray(l.value) && !l.value.length && a.items[0] && (l.value = [a.items[0]?.href ?? a.items[0]?.value]);
34
- const u = (n) => Array.isArray(l.value) ? l.value.includes(n.value) : n.value === l.value, b = (n, v = !1) => {
35
- if (Array.isArray(l.value)) {
36
- let i = l.value.slice();
37
- if (v) {
38
- i.length || (i = a.items.map((y) => y.value));
39
- const A = i.indexOf(n.value);
40
- A === -1 ? i.push(n.value) : i.splice(A, 1);
41
- } else
42
- i.length === 1 && i[0] === n.value ? i = [] : i = [n.value];
43
- !a.canBeEmptyMultiple && !i.length && (i = [n.value]), l.value = i;
44
- return;
45
- }
46
- l.value = n.value;
47
- }, d = (n) => {
48
- if (t.value.scrollWidth <= t.value.offsetWidth || n.shiftKey || Math.abs(n.deltaY) < 50) return;
49
- n.preventDefault();
50
- const v = n.deltaY > 0 ? 30 : -30;
51
- t.value.scrollLeft = t.value.scrollLeft + v;
52
- }, c = (n = !0) => {
53
- const v = t.value.querySelector(".top-active");
54
- if (!v) return;
55
- const i = 24, A = v.offsetLeft - t.value.offsetLeft - i, y = v.offsetLeft - t.value.offsetLeft + v.clientWidth + i, h = t.value.scrollLeft, x = t.value.clientWidth + t.value.scrollLeft;
56
- let I;
57
- A < h && (I = A), y > x && (I = y - t.value.clientWidth), I !== void 0 && (de() ? Y.$?.(t.value).animate({ scrollLeft: I }, n ? 200 : 0) : t.value.scrollTo({ left: I, behavior: n ? "smooth" : "auto" }));
58
- }, s = () => {
59
- if (Array.isArray(l.value)) {
60
- if (l.value.length === a.items.length) {
61
- l.value = [a.items[0].href ?? a.items[0].value];
62
- return;
63
- }
64
- l.value = a.items.map((n) => n.href ?? n.value);
65
- }
66
- };
67
- return ae(() => c(!1)), se(() => c(!0)), (n, v) => (g(), L("div", {
68
- ref_key: "el",
69
- ref: t,
70
- class: ne({
71
- "top-menu": !0,
72
- ["top-style_" + e.styling]: !0
73
- // ['top-unwrap-x']: styling === 'default',
74
- }),
75
- onWheel: d
76
- }, [
77
- (g(!0), L(F, null, z(e.items, (i) => (g(), S(X, R({ ref_for: !0 }, i, {
78
- class: "top-menu_item",
79
- color: "theme",
80
- onClick: (A) => b(i, A.ctrlKey || A.metaKey),
81
- isActive: u(i)
82
- }), U({ _: 2 }, [
83
- i.content ? {
84
- name: "default",
85
- fn: B(() => [
86
- E(P(i.content), 1)
87
- ]),
88
- key: "0"
89
- } : void 0
90
- ]), 1040, ["onClick", "isActive"]))), 256)),
91
- Array.isArray(l.value) && e.selectAllItem ? (g(), L("div", Ie, [
92
- te(X, R(e.selectAllItem, {
93
- class: "top-menu_item",
94
- color: "theme",
95
- styling: "",
96
- onClick: v[0] || (v[0] = (i) => s()),
97
- isActive: l.value.length === e.items.length
98
- }), U({ _: 2 }, [
99
- e.selectAllItem.content ? {
100
- name: "default",
101
- fn: B(() => [
102
- E(P(e.selectAllItem.content), 1)
103
- ]),
104
- key: "0"
105
- } : void 0
106
- ]), 1040, ["isActive"])
107
- ])) : M("", !0)
108
- ], 34));
109
- }
110
- }), ke = { class: "top-selector2_itemMulti top-ellipsis" }, Le = /* @__PURE__ */ J({
111
- __name: "itemMulti",
112
- props: {
113
- id: {},
114
- name: {}
115
- },
116
- emits: ["delete"],
117
- setup(e) {
118
- return (a, l) => (g(), L("div", ke, [
119
- E(P(e.name) + " ", 1),
120
- re("span", {
121
- class: "top-selector2_itemMultiDelete",
122
- "data-top-icon": "",
123
- onClick: l[0] || (l[0] = (t) => a.$emit("delete", { id: e.id, name: e.name })),
124
- onMousedown: l[1] || (l[1] = oe(() => {
125
- }, ["stop"]))
126
- }, null, 32)
127
- ]));
128
- }
129
- }), D = /* @__PURE__ */ new Map(), Ce = (e) => {
130
- D.get(e)?.clear();
131
- }, Te = (e) => {
132
- const a = window.mo?.user?.id;
133
- return JSON.stringify(e.params) + ":" + e.url + ":" + a;
134
- }, be = (e, a) => D.get(a)?.get(e), xe = (e, a, l) => {
135
- D.has(a) || D.set(a, /* @__PURE__ */ new Map()), D.get(a)?.set(e, l);
136
- }, we = (e, a, l, t) => {
137
- const u = $([]), b = $(!1), d = $(0);
138
- let c = "", s;
139
- e && !e.params.limit && (e.params.limit = 100);
140
- const n = async () => {
141
- if (!e) return;
142
- const y = t ? Te(e) : void 0;
143
- if (y) {
144
- const I = be(y, e.path);
145
- if (I)
146
- return e.abortByFingerprint(), I;
147
- }
148
- const h = await e.call();
149
- if (h.errors) return;
150
- if (!Array.isArray(h.result)) {
151
- console.warn("Array expected in `res.result`");
152
- return;
153
- }
154
- const x = h.result.findIndex((I) => I.id === void 0 || I.name === void 0);
155
- if (x !== -1) {
156
- console.warn(`В result[${x}] нет id или name`);
157
- return;
158
- }
159
- return y && xe(y, e.path, h), h;
160
- }, v = async (y) => {
161
- if (!e) return;
162
- if (y) {
163
- if (!s || b.value) return;
164
- e.params.offset = s;
165
- } else
166
- e.params.offset = 0;
167
- a?.(e, c), b.value = !0;
168
- const h = await n();
169
- b.value = !1, d.value++, h && (s = h.nextOffset, y ? u.value = u.value.concat(h.result) : u.value = h.result);
170
- }, i = pe(() => v(!1), 200);
171
- return {
172
- apiRequest: e,
173
- items: u,
174
- isLoading: b,
175
- countLoading: d,
176
- load: v,
177
- setSearchTextAndLoad: (y, h = !0) => {
178
- if (e) {
179
- if (y.length < l) {
180
- e.abortByFingerprint(), u.value = [];
181
- return;
182
- }
183
- y === c && u.value.length || (c = y, h ? i() : v(!1));
184
- }
185
- }
186
- };
187
- }, le = 0, K = null, _ = (e, a, l = !0) => l && a.id === K ? Array.isArray(e) ? e.some((t) => t.id === a.id && t.name === a.name) : a.name === e.name : Array.isArray(e) ? e.some((t) => t.id === a.id) : a.id === e.id, Ke = (e, a, l) => {
188
- let t = e.params.filters ?? [];
189
- t = t.filter((u) => u.name !== l), a && t.push(Ae(l, "CONTAINS", [a])), e.changeParams({ filters: t });
190
- }, Se = (e, a, l, t, u, b, d, c, s) => {
191
- const n = $(""), v = {
192
- id: le,
193
- name: ve().Common.All
194
- }, i = () => {
195
- n.value = "";
196
- }, A = () => !(!s.apiRequest || n.value.length >= c), y = N(() => {
197
- const r = [];
198
- return !t && u.value && (typeof u.value == "string" && (v.name = u.value), r.push(v)), l.value?.forEach((C) => r.push({ ...C })), r;
199
- }), h = $([]), x = () => {
200
- h.value = I();
201
- }, I = () => {
202
- const r = n.value.toLowerCase(), C = ge(r);
203
- let o = [], w;
204
- const T = [], j = () => {
205
- T.at(-1)?.listItemProps?.type === "delimiter" && T.pop(), T.length && (w && o.push(w), o.push(...T), T.length = 0);
206
- };
207
- for (const k of y.value)
208
- switch (k.listItemProps?.type) {
209
- case "title":
210
- j(), w = k;
211
- break;
212
- case "delimiter":
213
- if (T.length) {
214
- let G = T.length;
215
- T.at(-1)?.listItemProps?.type === "delimiter" && G--, T[G] = k;
216
- }
217
- break;
218
- default:
219
- const V = k.name.toLowerCase();
220
- (k.id === Number(r) || V.includes(r) || V.includes(C)) && (V === r || V === C ? T.unshift(k) : T.push(k));
221
- }
222
- if (j(), o.push(...s.items.value), b.value && n.value && // результаты могут быть найдены, но не точные, тогда предложить добавить элемент
223
- !o.find((k) => k.name.toLowerCase() === r)) {
224
- const k = {
225
- id: K,
226
- name: n.value
227
- };
228
- o.push(k);
229
- }
230
- return t && (o = o.filter((k) => !_(e.value, k))), o;
231
- }, q = (r) => {
232
- r.listItemProps?.type === "title" || r.listItemProps?.type === "delimiter" || (t && Array.isArray(e.value) ? _(e.value, r) || (e.value = [...e.value, r]) : e.value = r, r.id === K && a("appendItem", r), setTimeout(() => {
233
- i();
234
- }));
235
- };
236
- if (s.apiRequest) {
237
- const r = [l, s.items];
238
- t && r.push(e), H(r, () => {
239
- x();
240
- });
241
- } else
242
- H([e, l, n], () => {
243
- x();
244
- }, {
245
- immediate: !0,
246
- // слежение за изменениями `items`
247
- deep: 2
248
- });
249
- return {
250
- searchText: n,
251
- resetSearch: i,
252
- genIsShort: A,
253
- itemsForShow: h,
254
- selectItem: q,
255
- selectNextItem: () => {
256
- if (Array.isArray(e.value)) return;
257
- const r = h.value.filter((w) => !["title", "delimiter"].includes(w.listItemProps?.type ?? "")), o = (r.findIndex((w) => w.id === e.value.id) + 1) % r.length;
258
- e.value = { ...r[o] };
259
- },
260
- deleteItemByItem: async (r) => {
261
- Array.isArray(e.value) && (e.value = e.value.filter((C) => C.id !== r.id || C.name !== r.name));
262
- }
263
- };
264
- }, Be = {
265
- key: 0,
266
- class: "top-selector2_activeItems"
267
- }, Me = {
268
- key: 1,
269
- class: "top-selector2_activeName top-ellipsis"
270
- }, Pe = {
271
- key: 2,
272
- class: "top-selector2_placeholder top-ellipsis"
273
- }, qe = /* @__PURE__ */ J({
274
- __name: "selector2",
275
- props: /* @__PURE__ */ W({
276
- modelValue: {},
277
- items: { default: () => [] },
278
- title: {},
279
- disabled: { type: Boolean },
280
- icon: {},
281
- modificator: {},
282
- size: { default: "s" },
283
- isError: { type: Boolean },
284
- openByFocusInput: { type: Boolean, default: void 0 },
285
- searchType: { default: "popup" },
286
- placeholder: {},
287
- api: {},
288
- apiSetSearchParams: {},
289
- minLength: { default: 0 },
290
- useCache: { type: Boolean },
291
- appendSearchToResult: { type: Boolean },
292
- multiselect: { type: Boolean },
293
- useAllItem: { type: [Boolean, String] },
294
- addChanger: { type: Boolean },
295
- buttonProps: {},
296
- selectedAsPlaceholder: { type: Boolean }
297
- }, {
298
- modelValue: { required: !0 },
299
- modelModifiers: {}
300
- }),
301
- emits: /* @__PURE__ */ W(["appendItem"], ["update:modelValue"]),
302
- setup(e, { expose: a, emit: l }) {
303
- const t = e, u = ee(e, "modelValue"), b = l;
304
- a({
305
- /**
306
- * Сброс локального кеша и кеша api
307
- *
308
- * @param resetAPICache - Сбросить API кеш, по умолчанию не сбрасывается. Для случаев, когда загруженные данные становятся неактуальными
309
- */
310
- resetCache: (m = !1) => {
311
- c.apiRequest && (m && Ce(c.apiRequest.path), c.items.value = [], c.countLoading.value = 0, c.apiRequest.params.offset = 0, requestAnimationFrame(() => {
312
- s.itemsForShow.value = [];
313
- }), i()?.elPopup && c.setSearchTextAndLoad(s.searchText.value));
314
- }
315
- });
316
- const d = N(() => t.searchType === "inline" && t.multiselect || t.searchType === "inline" && Y.state.isMobile ? "popup" : t.searchType), c = we(t.api, t.apiSetSearchParams, t.minLength, t.useCache), s = Se(
317
- u,
318
- b,
319
- O(t, "items"),
320
- t.multiselect,
321
- O(t, "useAllItem"),
322
- O(t, "appendSearchToResult"),
323
- d,
324
- t.minLength,
325
- c
326
- ), n = N(() => t.buttonProps ? "TopButton" : d.value === "inline" ? "TopInput" : "div"), v = $(null), i = () => v.value?.popup;
327
- c.apiRequest && H(s.searchText, () => {
328
- c.setSearchTextAndLoad(s.searchText.value);
329
- });
330
- const A = N(() => Array.isArray(u.value) || t.multiselect || !t.selectedAsPlaceholder && d.value !== "inline" ? t.placeholder : u.value?.name || t.placeholder), y = (m) => {
331
- let p = !1;
332
- switch (m.key) {
333
- case "Delete":
334
- case "Backspace":
335
- Array.isArray(u.value) && (m.preventDefault(), m.stopPropagation(), u.value.pop());
336
- break;
337
- case "ArrowUp":
338
- case "ArrowRight":
339
- case "ArrowDown":
340
- case "ArrowLeft":
341
- case "Enter":
342
- case " ":
343
- p = !0;
344
- break;
345
- case "Escape":
346
- d.value === "inline" && s.resetSearch();
347
- break;
348
- }
349
- const r = m.key.length === 1 && !m.ctrlKey && !m.metaKey;
350
- (d.value === "popup" || d.value === "inline") && r && (p = !0), i()?.elPopup && (p = !1), p && (d.value === "popup" && (m.preventDefault(), m.stopPropagation(), r && (s.searchText.value || (s.searchText.value = m.key))), m.currentTarget?.click());
351
- }, h = (m) => {
352
- m.preventDefault(), s.selectNextItem();
353
- }, x = () => {
354
- c.apiRequest && c.setSearchTextAndLoad(s.searchText.value, !1);
355
- }, I = () => {
356
- d.value === "popup" && s.searchText.value && s.resetSearch();
357
- }, q = (m) => {
358
- const p = m.target;
359
- p.scrollTop / (p.scrollHeight - p.offsetHeight) > 0.8 && c.load(!0);
360
- };
361
- return (m, p) => {
362
- const r = ie("TopLoadbar"), C = ue("top-focus");
363
- return g(), S(f(ye), {
364
- ref_key: "popupRef",
365
- ref: v,
366
- onOpen: p[3] || (p[3] = (o) => x()),
367
- onClose: p[4] || (p[4] = (o) => I()),
368
- onScrollContentList: p[5] || (p[5] = (o) => f(c) ? q(o) : void 0),
369
- notch: !1,
370
- transitionDuration: 0,
371
- openByFocusInput: d.value === "inline" && (e.openByFocusInput ?? !0),
372
- disabled: d.value === "inline" && f(s).genIsShort()
373
- }, U({
374
- opener: B(() => [
375
- Q((g(), S(fe(n.value), R(e.buttonProps, {
376
- class: {
377
- "top-selector2": !0,
378
- "top-selector2-multiselect": e.multiselect,
379
- ["top-selector2-" + e.modificator]: !!e.modificator,
380
- "top-as-input": !e.buttonProps && d.value !== "inline",
381
- "top-as-selector": !0,
382
- ["top-size_" + e.size]: !0,
383
- "top-disabled": e.disabled,
384
- "top-forms-focusable": !e.disabled,
385
- "top-error": e.isError
386
- },
387
- icon: e.icon,
388
- tabindex: "0",
389
- onKeydown: y,
390
- onBlur: p[0] || (p[0] = (o) => d.value === "inline" && f(s).resetSearch()),
391
- placeholder: A.value,
392
- title: e.title,
393
- captionType: d.value === "inline" && e.title !== void 0 ? "top" : void 0,
394
- modelValue: f(s).searchText.value,
395
- "onUpdate:modelValue": p[1] || (p[1] = (o) => f(s).searchText.value = o)
396
- }), {
397
- default: B(() => [
398
- e.multiselect ? (g(), L("div", Be, [
399
- (g(!0), L(F, null, z(u.value, (o) => (g(), S(Le, {
400
- id: o.id,
401
- name: o.name,
402
- onDelete: f(s).deleteItemByItem
403
- }, null, 8, ["id", "name", "onDelete"]))), 256))
404
- ])) : M("", !0),
405
- d.value !== "inline" && !e.multiselect ? (g(), L("span", Me, P(Array.isArray(u.value) ? "" : u.value.name), 1)) : M("", !0),
406
- e.multiselect && !u.value.length ? (g(), L("span", Pe, P(A.value), 1)) : M("", !0),
407
- e.addChanger && !e.buttonProps && !e.multiselect && f(s).itemsForShow.value.length > 1 && !e.disabled ? (g(), L("span", {
408
- key: 3,
409
- class: "top-changer top-changer-selector",
410
- "data-top-popup-disabled": "true",
411
- onClick: h
412
- })) : M("", !0)
413
- ]),
414
- _: 1
415
- }, 16, ["class", "icon", "placeholder", "title", "captionType", "modelValue"])), [
416
- [
417
- C,
418
- e.isError,
419
- void 0,
420
- { onupdate: !0 }
421
- ]
422
- ])
423
- ]),
424
- contentList: B(() => [
425
- (g(!0), L(F, null, z(f(s).itemsForShow.value, (o) => (g(), S(f(Z), R({
426
- key: o.id ?? void 0,
427
- class: {
428
- "top-active": !Array.isArray(u.value) && !e.multiselect && u.value.id === o.id && u.value.name === o.name,
429
- "top-selector2_item-all": o.id === f(le),
430
- "top-selector2_item-new": o.id === f(K)
431
- }
432
- }, { ref_for: !0 }, o.listItemProps, {
433
- closeByClick: !e.multiselect || f(Y).state.isMobile,
434
- onClick: (w) => f(s).selectItem(o)
435
- }), {
436
- default: B(() => [
437
- m.$slots.item ? ce(m.$slots, "item", {
438
- key: 0,
439
- item: o
440
- }) : (g(), L(F, { key: 1 }, [
441
- E(P(o.name), 1)
442
- ], 64))
443
- ]),
444
- _: 2
445
- }, 1040, ["class", "closeByClick", "onClick"]))), 128)),
446
- !f(s).itemsForShow.value.length && !f(s).genIsShort() ? (g(), S(f(Z), {
447
- key: 0,
448
- type: "regular"
449
- }, {
450
- default: B(() => [
451
- !f(c).isLoading.value || f(c).countLoading.value ? (g(), L(F, { key: 0 }, [
452
- E(P(m.$i18n.Common.No_results), 1)
453
- ], 64)) : (g(), S(f(me), {
454
- key: 1,
455
- type: "circles"
456
- }))
457
- ]),
458
- _: 1
459
- })) : M("", !0),
460
- f(c).countLoading.value && f(c).isLoading.value && d.value === "inline" ? (g(), S(r, { key: 1 })) : M("", !0)
461
- ]),
462
- _: 2
463
- }, [
464
- d.value === "popup" ? {
465
- name: "widget",
466
- fn: B(() => [
467
- Q(te(f(he), {
468
- title: "Поиск",
469
- icon: "",
470
- modelValue: f(s).searchText.value,
471
- "onUpdate:modelValue": p[2] || (p[2] = (o) => f(s).searchText.value = o),
472
- isLoading: !!f(c).countLoading.value && f(c).isLoading.value,
473
- placeholder: A.value
474
- }, null, 8, ["modelValue", "isLoading", "placeholder"]), [
475
- [
476
- C,
477
- u.value,
478
- void 0,
479
- { onupdate: !0 }
480
- ]
481
- ])
482
- ]),
483
- key: "0"
484
- } : void 0
485
- ]), 1032, ["openByFocusInput", "disabled"]);
486
- };
487
- }
488
- });
489
- export {
490
- K as I,
491
- qe as _,
492
- Re as a,
493
- Ke as b,
494
- le as c
495
- };
496
- //# sourceMappingURL=policy.vue_vue_type_style_index_0_lang-D-FVZi-G.es.js.map