@topvisor/ui 1.3.5-popupFromInput.0 → 1.4.0-TopGroupSelector.11

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 (219) hide show
  1. package/.chunks/core-BL-38XF7.es.js +196 -0
  2. package/.chunks/core-BL-38XF7.es.js.map +1 -0
  3. package/.chunks/core-BsPx05H9.amd.js +2 -0
  4. package/.chunks/core-BsPx05H9.amd.js.map +1 -0
  5. package/.chunks/{datepicker-Bq_z2paN.amd.js → datepicker-3coUsFW2.amd.js} +2 -2
  6. package/.chunks/{datepicker-Bq_z2paN.amd.js.map → datepicker-3coUsFW2.amd.js.map} +1 -1
  7. package/.chunks/{datepicker-CGGp0VnN.es.js → datepicker-D1Hw3a3o.es.js} +14 -17
  8. package/.chunks/{datepicker-CGGp0VnN.es.js.map → datepicker-D1Hw3a3o.es.js.map} +1 -1
  9. package/.chunks/dialog_regionSelectorRegions-1UVhgK2f.es.js +180 -0
  10. package/.chunks/dialog_regionSelectorRegions-1UVhgK2f.es.js.map +1 -0
  11. package/.chunks/dialog_regionSelectorRegions-CZ8IX7la.amd.js +2 -0
  12. package/.chunks/dialog_regionSelectorRegions-CZ8IX7la.amd.js.map +1 -0
  13. package/.chunks/{dialogs.vue_vue_type_script_setup_true_lang-DCVIoEeY.es.js → dialogs.vue_vue_type_script_setup_true_lang-DRbTG0vh.es.js} +111 -112
  14. package/.chunks/{dialogs.vue_vue_type_script_setup_true_lang-DCVIoEeY.es.js.map → dialogs.vue_vue_type_script_setup_true_lang-DRbTG0vh.es.js.map} +1 -1
  15. package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-Dq9kWWMg.amd.js +2 -0
  16. package/.chunks/{dialogs.vue_vue_type_script_setup_true_lang-Bf0wXalT.amd.js.map → dialogs.vue_vue_type_script_setup_true_lang-Dq9kWWMg.amd.js.map} +1 -1
  17. package/.chunks/forms-BseC3Ftz.es.js +2035 -0
  18. package/.chunks/{forms-BhbgRJ5I.es.js.map → forms-BseC3Ftz.es.js.map} +1 -1
  19. package/.chunks/forms-CUSCBQu3.amd.js +3 -0
  20. package/.chunks/{forms-CNcrvkYD.amd.js.map → forms-CUSCBQu3.amd.js.map} +1 -1
  21. package/.chunks/index-DLUtoTUg.amd.js +2 -0
  22. package/.chunks/index-DLUtoTUg.amd.js.map +1 -0
  23. package/.chunks/index-DkQWJkMc.es.js +54 -0
  24. package/.chunks/index-DkQWJkMc.es.js.map +1 -0
  25. package/.chunks/notice-Cl3ZgiHm.es.js +191 -0
  26. package/.chunks/{notice-CpPhDTUb.es.js.map → notice-Cl3ZgiHm.es.js.map} +1 -1
  27. package/.chunks/notice-DwjipV21.amd.js +4 -0
  28. package/.chunks/{notice-BpLsm6Zh.amd.js.map → notice-DwjipV21.amd.js.map} +1 -1
  29. package/.chunks/page.vue_vue_type_script_setup_true_lang-CjIiZU-D.amd.js +2 -0
  30. package/.chunks/{page.vue_vue_type_script_setup_true_lang-B-1LEQAz.amd.js.map → page.vue_vue_type_script_setup_true_lang-CjIiZU-D.amd.js.map} +1 -1
  31. package/.chunks/page.vue_vue_type_script_setup_true_lang-CpRJQFD1.es.js +139 -0
  32. package/.chunks/{page.vue_vue_type_script_setup_true_lang-9abPBMpd.es.js.map → page.vue_vue_type_script_setup_true_lang-CpRJQFD1.es.js.map} +1 -1
  33. package/.chunks/policy.vue_vue_type_style_index_0_lang-BBDJEs5Q.es.js +496 -0
  34. package/.chunks/policy.vue_vue_type_style_index_0_lang-BBDJEs5Q.es.js.map +1 -0
  35. package/.chunks/policy.vue_vue_type_style_index_0_lang-DJOaMdBm.amd.js +2 -0
  36. package/.chunks/policy.vue_vue_type_style_index_0_lang-DJOaMdBm.amd.js.map +1 -0
  37. package/.chunks/popup-DRuyYFGB.amd.js +2 -0
  38. package/.chunks/popup-DRuyYFGB.amd.js.map +1 -0
  39. package/.chunks/popup-Jw_Yyg3U.es.js +470 -0
  40. package/.chunks/popup-Jw_Yyg3U.es.js.map +1 -0
  41. package/.chunks/popupHint.vue_vue_type_style_index_0_lang-DD59yF6H.es.js +209 -0
  42. package/.chunks/popupHint.vue_vue_type_style_index_0_lang-DD59yF6H.es.js.map +1 -0
  43. package/.chunks/popupHint.vue_vue_type_style_index_0_lang-DtiT6NE4.amd.js +2 -0
  44. package/.chunks/popupHint.vue_vue_type_style_index_0_lang-DtiT6NE4.amd.js.map +1 -0
  45. package/.chunks/utils-CzHUG_xz.amd.js +2 -0
  46. package/.chunks/{utils-5uxIj2CI.amd.js.map → utils-CzHUG_xz.amd.js.map} +1 -1
  47. package/.chunks/utils-D9nYQabE.amd.js +2 -0
  48. package/.chunks/{utils-Bg_su8b-.amd.js.map → utils-D9nYQabE.amd.js.map} +1 -1
  49. package/.chunks/{utils-D58EUoHa.es.js → utils-Q69SXlnV.es.js} +192 -208
  50. package/.chunks/{utils-D58EUoHa.es.js.map → utils-Q69SXlnV.es.js.map} +1 -1
  51. package/.chunks/{utils-UBgfsQ8v.es.js → utils-YrUExsH7.es.js} +23 -24
  52. package/.chunks/{utils-UBgfsQ8v.es.js.map → utils-YrUExsH7.es.js.map} +1 -1
  53. package/.chunks/{widgetInput.vue_vue_type_script_setup_true_lang-CSD2uMSW.es.js → widgetInput.vue_vue_type_script_setup_true_lang-CDkeKVqY.es.js} +2 -2
  54. package/.chunks/{widgetInput.vue_vue_type_script_setup_true_lang-CSD2uMSW.es.js.map → widgetInput.vue_vue_type_script_setup_true_lang-CDkeKVqY.es.js.map} +1 -1
  55. package/.chunks/{widgetInput.vue_vue_type_script_setup_true_lang-D6SVtg2Q.amd.js → widgetInput.vue_vue_type_script_setup_true_lang-CkE912ll.amd.js} +2 -2
  56. package/.chunks/{widgetInput.vue_vue_type_script_setup_true_lang-D6SVtg2Q.amd.js.map → widgetInput.vue_vue_type_script_setup_true_lang-CkE912ll.amd.js.map} +1 -1
  57. package/api/index.amd.js +1 -1
  58. package/api/index.amd.js.map +1 -1
  59. package/api/index.js +138 -133
  60. package/api/index.js.map +1 -1
  61. package/assets/dialog_regionSelectorRegions.css +1 -0
  62. package/assets/forms.css +1 -1
  63. package/assets/policy.css +1 -0
  64. package/assets/popupHint.css +1 -1
  65. package/assets/project.css +1 -1
  66. package/charts/charts.amd.js +1 -1
  67. package/charts/charts.amd.js.map +1 -1
  68. package/charts/charts.js +80 -80
  69. package/charts/charts.js.map +1 -1
  70. package/core/app.amd.js +1 -1
  71. package/core/app.amd.js.map +1 -1
  72. package/core/app.js +93 -96
  73. package/core/app.js.map +1 -1
  74. package/dialog/dialog.amd.js +1 -1
  75. package/dialog/dialog.amd.js.map +1 -1
  76. package/dialog/dialog.js +13 -13
  77. package/dialog/dialog.js.map +1 -1
  78. package/extra/extra.amd.js +1 -1
  79. package/extra/extra.amd.js.map +1 -1
  80. package/extra/extra.js +20 -23
  81. package/extra/extra.js.map +1 -1
  82. package/forms/forms.amd.js +1 -1
  83. package/forms/forms.js +5 -5
  84. package/formsExt/formsExt.amd.js +1 -1
  85. package/formsExt/formsExt.amd.js.map +1 -1
  86. package/formsExt/formsExt.js +185 -534
  87. package/formsExt/formsExt.js.map +1 -1
  88. package/layout/layout.amd.js +1 -1
  89. package/layout/layout.js +6 -6
  90. package/package.json +1 -1
  91. package/popup/popup.amd.js +1 -1
  92. package/popup/popup.amd.js.map +1 -1
  93. package/popup/popup.js +43 -46
  94. package/popup/popup.js.map +1 -1
  95. package/popup/worker.amd.js +1 -1
  96. package/popup/worker.amd.js.map +1 -1
  97. package/popup/worker.js +11 -9
  98. package/popup/worker.js.map +1 -1
  99. package/project/project.amd.js +1 -1
  100. package/project/project.amd.js.map +1 -1
  101. package/project/project.js +848 -579
  102. package/project/project.js.map +1 -1
  103. package/src/api/api/client/client.d.ts +5 -0
  104. package/src/api/api/mocker/index.d.ts +3 -3
  105. package/src/api/api/types/client/request.d.ts +6 -0
  106. package/src/api/api/types/ext.d.ts +2 -2
  107. package/src/api/api/types/mocker.d.ts +2 -2
  108. package/src/components/forms/button/types.d.ts +6 -0
  109. package/src/components/formsExt/formsExt.d.ts +1 -0
  110. package/src/components/formsExt/libs/optionGroup/types.d.ts +1 -1
  111. package/src/components/formsExt/selector2/cache.d.ts +12 -0
  112. package/src/components/formsExt/selector2/composables/useAPI.d.ts +2036 -2
  113. package/src/components/formsExt/selector2/composables/useMenu.d.ts +2045 -5
  114. package/src/components/formsExt/selector2/itemMulti.vue.d.ts +3 -3
  115. package/src/components/formsExt/selector2/selector2.vue.d.ts +11 -3
  116. package/src/components/formsExt/selector2/types.d.ts +39 -5
  117. package/src/components/formsExt/selector2/utils.d.ts +17 -0
  118. package/src/components/popup/lib/popup.d.ts +1 -2
  119. package/src/components/popup/popup/opener/types.d.ts +6 -2
  120. package/src/components/popup/popup/types.d.ts +3 -2
  121. package/src/components/popup/popup.d.ts +1 -1
  122. package/src/components/project/groupSelector/folders/folders.vue.d.ts +18 -0
  123. package/src/components/project/groupSelector/folders/types.d.ts +63 -0
  124. package/src/components/project/groupSelector/folders/utils.d.ts +63 -0
  125. package/src/components/project/groupSelector/groupSelector.vue.d.ts +33 -0
  126. package/src/components/project/groupSelector/groups/groups.vue.d.ts +126 -0
  127. package/src/components/project/groupSelector/groups/types.d.ts +58 -0
  128. package/src/components/project/groupSelector/groups/utils.d.ts +92 -0
  129. package/src/components/project/groupSelector/stories/mocks/folders.d.ts +4 -0
  130. package/src/components/project/groupSelector/stories/mocks/groups.d.ts +2 -0
  131. package/src/components/project/groupSelector/stories/mocks/index.d.ts +7 -0
  132. package/src/components/project/groupSelector/types.d.ts +133 -0
  133. package/src/components/project/project.d.ts +5 -4
  134. package/src/components/project/{selectorRegion → regionSelector}/utils/utils.d.ts +3 -3
  135. package/src/core/utils/composables/useWatch.d.ts +32 -0
  136. package/tabs/tabs.amd.js +1 -1
  137. package/tabs/tabs.amd.js.map +1 -1
  138. package/tabs/tabs.js +24 -24
  139. package/tabs/tabs.js.map +1 -1
  140. package/tabsView/tabsView.amd.js +1 -1
  141. package/tabsView/tabsView.amd.js.map +1 -1
  142. package/tabsView/tabsView.js +131 -133
  143. package/tabsView/tabsView.js.map +1 -1
  144. package/utils/clipboard.amd.js +1 -1
  145. package/utils/clipboard.js +1 -1
  146. package/utils/date.amd.js +1 -1
  147. package/utils/date.js +1 -1
  148. package/utils/device.amd.js +1 -1
  149. package/utils/device.js +1 -1
  150. package/utils/lodash.amd.js +1 -1
  151. package/utils/lodash.js +1 -1
  152. package/utils/price.amd.js +1 -1
  153. package/utils/price.js +1 -1
  154. package/utils/scroll.amd.js +1 -1
  155. package/utils/scroll.amd.js.map +1 -1
  156. package/utils/scroll.js +14 -14
  157. package/utils/scroll.js.map +1 -1
  158. package/utils/searchers.amd.js +1 -1
  159. package/utils/searchers.js +3 -3
  160. package/utils/string.amd.js +1 -1
  161. package/utils/string.amd.js.map +1 -1
  162. package/utils/string.js +3 -7
  163. package/utils/string.js.map +1 -1
  164. package/.chunks/core-DcLw0dEO.amd.js +0 -2
  165. package/.chunks/core-DcLw0dEO.amd.js.map +0 -1
  166. package/.chunks/core-DpTLGhiK.es.js +0 -197
  167. package/.chunks/core-DpTLGhiK.es.js.map +0 -1
  168. package/.chunks/dialog_selectorRegions-BtAADQHf.es.js +0 -190
  169. package/.chunks/dialog_selectorRegions-BtAADQHf.es.js.map +0 -1
  170. package/.chunks/dialog_selectorRegions-DCrHvHDs.amd.js +0 -2
  171. package/.chunks/dialog_selectorRegions-DCrHvHDs.amd.js.map +0 -1
  172. package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-Bf0wXalT.amd.js +0 -2
  173. package/.chunks/forms-BhbgRJ5I.es.js +0 -2045
  174. package/.chunks/forms-CNcrvkYD.amd.js +0 -3
  175. package/.chunks/index-BEI7XZmU.amd.js +0 -2
  176. package/.chunks/index-BEI7XZmU.amd.js.map +0 -1
  177. package/.chunks/index-igPkes8X.es.js +0 -48
  178. package/.chunks/index-igPkes8X.es.js.map +0 -1
  179. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-QvP1d9jN.amd.js +0 -2
  180. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-QvP1d9jN.amd.js.map +0 -1
  181. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-xvzbyqai.es.js +0 -196
  182. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-xvzbyqai.es.js.map +0 -1
  183. package/.chunks/menu.vue_vue_type_style_index_0_lang-C3Rr6ZyL.amd.js +0 -2
  184. package/.chunks/menu.vue_vue_type_style_index_0_lang-C3Rr6ZyL.amd.js.map +0 -1
  185. package/.chunks/menu.vue_vue_type_style_index_0_lang-dOeZ7an1.es.js +0 -112
  186. package/.chunks/menu.vue_vue_type_style_index_0_lang-dOeZ7an1.es.js.map +0 -1
  187. package/.chunks/notice-BpLsm6Zh.amd.js +0 -4
  188. package/.chunks/notice-CpPhDTUb.es.js +0 -194
  189. package/.chunks/opener.vue_vue_type_script_setup_true_lang-DRzrTv7Q.es.js +0 -36
  190. package/.chunks/opener.vue_vue_type_script_setup_true_lang-DRzrTv7Q.es.js.map +0 -1
  191. package/.chunks/opener.vue_vue_type_script_setup_true_lang-gNZhYkDf.amd.js +0 -2
  192. package/.chunks/opener.vue_vue_type_script_setup_true_lang-gNZhYkDf.amd.js.map +0 -1
  193. package/.chunks/page.vue_vue_type_script_setup_true_lang-9abPBMpd.es.js +0 -143
  194. package/.chunks/page.vue_vue_type_script_setup_true_lang-B-1LEQAz.amd.js +0 -2
  195. package/.chunks/popup-BJj9BJP5.es.js +0 -485
  196. package/.chunks/popup-BJj9BJP5.es.js.map +0 -1
  197. package/.chunks/popup-CfXISjhC.amd.js +0 -2
  198. package/.chunks/popup-CfXISjhC.amd.js.map +0 -1
  199. package/.chunks/popupHint.vue_vue_type_style_index_0_lang-Cce9ZdtW.amd.js +0 -2
  200. package/.chunks/popupHint.vue_vue_type_style_index_0_lang-Cce9ZdtW.amd.js.map +0 -1
  201. package/.chunks/utils-5uxIj2CI.amd.js +0 -2
  202. package/.chunks/utils-Bg_su8b-.amd.js +0 -2
  203. package/assets/dialog_selectorRegions.css +0 -1
  204. package/assets/formsExt.css +0 -1
  205. package/assets/listItem.css +0 -1
  206. package/assets/menu.css +0 -1
  207. package/src/components/popup/popup/opener.vue.d.ts +0 -16
  208. /package/src/components/project/{selectorCompetitors/selectorCompetitors.vue.d.ts → competitorSelector/competitorSelector.vue.d.ts} +0 -0
  209. /package/src/components/project/{selectorCompetitors → competitorSelector}/composables.d.ts +0 -0
  210. /package/src/components/project/{selectorCompetitors → competitorSelector}/types.d.ts +0 -0
  211. /package/src/components/project/{selectorRegion → regionSelector}/composables/compare.d.ts +0 -0
  212. /package/src/components/project/{selectorRegion → regionSelector}/composables/selectRegion.d.ts +0 -0
  213. /package/src/components/project/{selectorRegion → regionSelector}/composables/selectSearcher.d.ts +0 -0
  214. /package/src/components/project/{selectorRegion → regionSelector}/composables/selectorRegion.d.ts +0 -0
  215. /package/src/components/project/{selectorRegion/dialog_selectorRegions/dialog_selectorRegions.vue.d.ts → regionSelector/dialog_regionSelectorRegions/dialog_regionSelectorRegions.vue.d.ts} +0 -0
  216. /package/src/components/project/{selectorRegion/dialog_selectorRegions → regionSelector/dialog_regionSelectorRegions}/types.d.ts +0 -0
  217. /package/src/components/project/{selectorRegion/selectorRegion.vue.d.ts → regionSelector/regionSelector.vue.d.ts} +0 -0
  218. /package/src/components/project/{selectorRegion → regionSelector}/types.d.ts +0 -0
  219. /package/src/components/project/{selectorRegion → regionSelector}/utils/consts.d.ts +0 -0
@@ -0,0 +1,180 @@
1
+
2
+ import { Core as _autoloadCSSCore } from '../core/app.js';
3
+ const fileNames = ['../assets/dialog_regionSelectorRegions.css'].map(fileName => import.meta.resolve(fileName));
4
+ _autoloadCSSCore.insertCSSLinkToPage(fileNames, true);
5
+
6
+ import { defineComponent as E, ref as k, reactive as j, computed as w, watch as D, resolveComponent as b, createBlock as S, openBlock as i, unref as f, withCtx as c, createVNode as d, createTextVNode as C, toDisplayString as p, createElementVNode as m, createElementBlock as _, Fragment as M, renderList as O, createCommentVNode as y } from "vue";
7
+ import { _ as P, a as G } from "./page.vue_vue_type_script_setup_true_lang-CpRJQFD1.es.js";
8
+ import { b as X } from "./utils-YrUExsH7.es.js";
9
+ import { genFlagLinkByCountryCode as Q } from "../utils/string.js";
10
+ import { getSearcherGIcon as q, getLangLabel as z, getDeviceGIcon as H } from "../utils/searchers.js";
11
+ import { C as I } from "./forms-BseC3Ftz.es.js";
12
+ const J = { class: "dialog_regionSelectorRegions_header" }, K = ["data-top-icon"], W = ["src", "alt"], Y = { class: "top-ellipsis" }, Z = { class: "dialog_regionSelectorRegions_regionAreaName" }, F = { key: 1 }, ee = ["data-top-icon"], re = /* @__PURE__ */ E({
13
+ id: "regionSelectorRegions",
14
+ __name: "dialog_regionSelectorRegions",
15
+ props: {
16
+ regions: {},
17
+ regionsIndexes: {},
18
+ "@update:regionsIndexes": { type: Function }
19
+ },
20
+ setup(R) {
21
+ const l = R, h = X(), a = k([]), r = k(null), g = j({
22
+ searcher_key: -1,
23
+ key: -1,
24
+ name: -1
25
+ }), x = w({
26
+ get() {
27
+ return a.value.every((o) => o.selected);
28
+ },
29
+ set(o) {
30
+ a.value = a.value.map((e) => ({ ...e, selected: o }));
31
+ }
32
+ }), v = (o) => {
33
+ g[o] = -g[o], a.value.sort((e, t) => !e[o] || !t[o] ? -1 : e[o] >= t[o] ? g[o] : -g[o]);
34
+ }, V = () => {
35
+ if (!a.value.some((e) => e.selected)) return;
36
+ const o = a.value.filter((e) => e.selected).map((e) => e.index);
37
+ l["@update:regionsIndexes"]?.(o), h.close();
38
+ };
39
+ D([
40
+ () => l.regions,
41
+ () => l.regionsIndexes
42
+ ], () => {
43
+ if (a.value = [], !l.regions || !l.regionsIndexes) return;
44
+ let o = [...l.regions];
45
+ const e = new Map(l.regionsIndexes.map((t, s) => [t, s]));
46
+ o.sort((t, s) => {
47
+ const n = e.get(t.index) ?? Number.MAX_VALUE, u = e.get(s.index) ?? Number.MAX_VALUE;
48
+ return n - u;
49
+ }), o.forEach((t) => {
50
+ let s = t.name;
51
+ t.areaName && (s += ` (${t.areaName})`);
52
+ const n = l.regionsIndexes?.includes(t.index) ?? !1, u = q(t.searcher_key), N = t.lang !== void 0 ? z(t.searcher_key ?? 999, t.lang) : void 0, A = t.device !== void 0 ? H(t.device) : void 0, T = t.countryCode !== void 0 ? Q(t.countryCode) : void 0, U = {
53
+ ...t,
54
+ selected: n,
55
+ title: s,
56
+ searcherIcon: u,
57
+ langLabel: N,
58
+ deviceIcon: A,
59
+ flagLink: T
60
+ };
61
+ a.value.push(U);
62
+ });
63
+ });
64
+ const L = () => {
65
+ if (!I.$?.ui.sortable) {
66
+ console.info("Для работы сортировки требуется глобальная загрузка jQuery UI Sortable");
67
+ return;
68
+ }
69
+ r.value && $(r.value).sortable({
70
+ distance: 10,
71
+ stop: () => {
72
+ const o = [...r.value.children].map((e) => Number(e.getAttribute("data-region-index")));
73
+ a.value.sort((e, t) => o.indexOf(e.index) - o.indexOf(t.index));
74
+ }
75
+ });
76
+ }, B = () => {
77
+ I.$?.ui.sortable && r.value && $(r.value).sortable("destroy");
78
+ };
79
+ return (o, e) => {
80
+ const t = b("TopCheckbox"), s = b("TopButton");
81
+ return i(), S(f(P), {
82
+ id: f(h).id,
83
+ pageActive: "regions",
84
+ class: "dialog_regionSelectorRegions",
85
+ height: "600px",
86
+ width: "600px",
87
+ onOpen: L,
88
+ onClose: B
89
+ }, {
90
+ default: c(() => [
91
+ d(f(G), {
92
+ name: "regions",
93
+ order: 0
94
+ }, {
95
+ header: c(() => [
96
+ m("div", J, [
97
+ d(t, {
98
+ modelValue: x.value,
99
+ "onUpdate:modelValue": e[0] || (e[0] = (n) => x.value = n)
100
+ }, null, 8, ["modelValue"]),
101
+ d(s, {
102
+ class: "dialog_regionSelectorRegions_sortButton",
103
+ color: "theme",
104
+ "data-top-icon": "",
105
+ onClick: e[1] || (e[1] = (n) => v("searcher_key")),
106
+ title: o.$i18n.Projects?.Sort_by_search_engine
107
+ }, null, 8, ["title"]),
108
+ d(s, {
109
+ class: "dialog_regionSelectorRegions_sortButton",
110
+ color: "theme",
111
+ "data-top-icon": "",
112
+ onClick: e[2] || (e[2] = (n) => v("key")),
113
+ title: o.$i18n.Projects?.Sort_by_yande_region_code
114
+ }, null, 8, ["title"]),
115
+ d(s, {
116
+ class: "dialog_regionSelectorRegions_sortButton",
117
+ color: "theme",
118
+ "data-top-icon": "",
119
+ onClick: e[3] || (e[3] = (n) => v("name")),
120
+ title: o.$i18n.Projects?.Sort_by_lphabetically
121
+ }, null, 8, ["title"])
122
+ ])
123
+ ]),
124
+ body: c(() => [
125
+ m("div", {
126
+ ref_key: "elRegions",
127
+ ref: r
128
+ }, [
129
+ (i(!0), _(M, null, O(a.value, (n) => (i(), S(t, {
130
+ key: n.index,
131
+ modelValue: n.selected,
132
+ "onUpdate:modelValue": (u) => n.selected = u,
133
+ class: "dialog_regionSelectorRegions_region",
134
+ "data-region-index": n.index
135
+ }, {
136
+ default: c(() => [
137
+ m("div", {
138
+ class: "dialog_regionSelectorRegions_regionSearcherIcon",
139
+ "data-top-icon": n.searcherIcon
140
+ }, null, 8, K),
141
+ n.flagLink ? (i(), _("img", {
142
+ key: 0,
143
+ class: "top-flag",
144
+ src: "//topvisor.dev" + n.flagLink,
145
+ alt: n.countryCode
146
+ }, null, 8, W)) : y("", !0),
147
+ m("div", Y, [
148
+ C(p(n.name) + " ", 1),
149
+ m("span", Z, p(n.areaName), 1)
150
+ ]),
151
+ n.langLabel ? (i(), _("div", F, " [" + p(n.langLabel) + "] ", 1)) : y("", !0),
152
+ n.deviceIcon ? (i(), _("div", {
153
+ key: 2,
154
+ "data-top-icon": n.deviceIcon
155
+ }, null, 8, ee)) : y("", !0)
156
+ ]),
157
+ _: 2
158
+ }, 1032, ["modelValue", "onUpdate:modelValue", "data-region-index"]))), 128))
159
+ ], 512)
160
+ ]),
161
+ footer: c(() => [
162
+ d(s, { onClick: V }, {
163
+ default: c(() => [
164
+ C(p(o.$i18n.Common?.Apply), 1)
165
+ ]),
166
+ _: 1
167
+ })
168
+ ]),
169
+ _: 1
170
+ })
171
+ ]),
172
+ _: 1
173
+ }, 8, ["id"]);
174
+ };
175
+ }
176
+ });
177
+ export {
178
+ re as default
179
+ };
180
+ //# sourceMappingURL=dialog_regionSelectorRegions-1UVhgK2f.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dialog_regionSelectorRegions-1UVhgK2f.es.js","sources":["../../src/components/project/regionSelector/dialog_regionSelectorRegions/dialog_regionSelectorRegions.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed, reactive, ref, watch } from 'vue';\nimport { TopDialog, TopDialogPage, useTopDialogSelf } from '@/components/dialog/dialog';\nimport { genFlagLinkByCountryCode } from '@/core/utils/string';\nimport type { Props, RegionRich } from './types';\nimport { getDeviceGIcon, getLangLabel, getSearcherGIcon } from '@/core/utils/searchers';\nimport Core from '@/core/core/core';\n\ndefineOptions({ id: 'regionSelectorRegions' });\n\nconst props = defineProps<Partial<Props>>();\n\nconst dialog = useTopDialogSelf();\n\n/**\n * Список расширенных регионов для использования в компоненте\n */\nconst regionsRich = ref<RegionRich[]>([]);\n\n/**\n * Ссылка на элемент с регионами\n */\nconst elRegions = ref<null | HTMLElement>(null);\n\n/**\n * Направление сортировки по полю\n */\nconst sortedVectorByField = reactive({\n\tsearcher_key: -1,\n\tkey: -1,\n\tname: -1,\n});\n\n/**\n * Выбраны все регионы\n */\nconst isAllSelected = computed({\n\tget() {\n\t\treturn regionsRich.value.every(region => region.selected);\n\t},\n\n\tset(value) {\n\t\tregionsRich.value = regionsRich.value.map(region => ({ ...region, selected: value }));\n\t},\n});\n\n/**\n * Сортировать регионы по выбранному полю\n * @param sortedField - Поле для сортировки\n */\nconst sort = (sortedField: keyof typeof sortedVectorByField) => {\n\tsortedVectorByField[sortedField] = -sortedVectorByField[sortedField];\n\n\tregionsRich.value.sort((regionA, regionB) => {\n\t\tif (!regionA[sortedField] || !regionB[sortedField]) return -1;\n\n\t\treturn regionA[sortedField] >= regionB[sortedField] ? sortedVectorByField[sortedField] : -sortedVectorByField[sortedField];\n\t});\n};\n\n/**\n * Применить изменения\n *\n * Вызывает callback `props['@update:regionsIndexes']`\n */\nconst onSubmit = () => {\n\tif (!regionsRich.value.some(region => region.selected)) return;\n\n\tconst regionsIndexes = regionsRich.value\n\t\t.filter(region => region.selected)\n\t\t.map(region => region.index);\n\n\tprops['@update:regionsIndexes']?.(regionsIndexes);\n\n\tdialog.close();\n};\n\n// генерация регионов\nwatch([\n\t() => props.regions,\n\t() => props.regionsIndexes,\n], () => {\n\tregionsRich.value = [];\n\n\tif (!props.regions) return;\n\tif (!props.regionsIndexes) return;\n\n\tlet regions = [...props.regions];\n\n\t// отсортировать регионы по входным данным\n\tconst orderByRegionIndex = new Map(props.regionsIndexes.map((index, order) => [index, order]));\n\n\tregions.sort((regionA, regionB) => {\n\t\tconst orderA = orderByRegionIndex.get(regionA.index) ?? Number.MAX_VALUE;\n\t\tconst orderB = orderByRegionIndex.get(regionB.index) ?? Number.MAX_VALUE;\n\n\t\treturn orderA - orderB;\n\t});\n\n\tregions.forEach(region => {\n\t\tlet title = region.name;\n\t\tif (region.areaName) title += ` (${region.areaName})`;\n\n\t\tconst selected = props.regionsIndexes?.includes(region.index) ?? false;\n\t\tconst searcherIcon = getSearcherGIcon(region.searcher_key);\n\t\tconst langLabel = region.lang !== undefined ? getLangLabel(region.searcher_key ?? 999, region.lang) : undefined;\n\t\tconst deviceIcon = region.device !== undefined ? getDeviceGIcon(region.device) : undefined;\n\t\tconst flagLink = region.countryCode !== undefined ? genFlagLinkByCountryCode(region.countryCode) : undefined;\n\n\t\tconst regionRich = {\n\t\t\t...region,\n\t\t\tselected,\n\t\t\ttitle,\n\t\t\tsearcherIcon,\n\t\t\tlangLabel,\n\t\t\tdeviceIcon,\n\t\t\tflagLink,\n\t\t};\n\n\t\tregionsRich.value.push(regionRich);\n\t});\n});\n\n/**\n * Проверить на существование sortable\n */\nconst onOpen = () => {\n\tif (!Core.$?.ui['sortable']) {\n\t\tconsole.info('Для работы сортировки требуется глобальная загрузка jQuery UI Sortable');\n\n\t\treturn;\n\t}\n\n\tif (!elRegions.value) return;\n\n\t$(elRegions.value).sortable({\n\t\tdistance: 10,\n\n\t\tstop: () => {\n\t\t\t// Обновляем порядок регионов в массиве regionsRich после сортировки\n\t\t\tconst sortedIndexes = [...elRegions.value!.children].map(el => Number(el.getAttribute('data-region-index')));\n\t\t\tregionsRich.value.sort((a, b) => sortedIndexes.indexOf(a.index) - sortedIndexes.indexOf(b.index));\n\t\t},\n\t});\n};\n\n/**\n * Удаление sortable\n */\nconst onClose = () => {\n\tif (!Core.$?.ui['sortable']) return;\n\tif (!elRegions.value) return;\n\n\t$(elRegions.value).sortable('destroy');\n};\n\n</script>\n\n<template>\n\t<TopDialog\n\t\t:id=\"dialog.id\"\n\t\tpageActive=\"regions\"\n\t\tclass=\"dialog_regionSelectorRegions\"\n\t\theight=\"600px\"\n\t\twidth=\"600px\"\n\t\t@open=\"onOpen\"\n\t\t@close=\"onClose\"\n\t>\n\t\t<TopDialogPage name=\"regions\" :order=\"0\">\n\t\t\t<template #header>\n\t\t\t\t<div class=\"dialog_regionSelectorRegions_header\">\n\t\t\t\t\t<TopCheckbox v-model=\"isAllSelected\"></TopCheckbox>\n\n\t\t\t\t\t<TopButton\n\t\t\t\t\t\tclass=\"dialog_regionSelectorRegions_sortButton\"\n\t\t\t\t\t\tcolor=\"theme\"\n\t\t\t\t\t\tdata-top-icon=\"\"\n\t\t\t\t\t\t@click=\"sort('searcher_key')\"\n\t\t\t\t\t\t:title=\"$i18n.Projects?.Sort_by_search_engine\"\n\t\t\t\t\t/>\n\n\t\t\t\t\t<TopButton\n\t\t\t\t\t\tclass=\"dialog_regionSelectorRegions_sortButton\"\n\t\t\t\t\t\tcolor=\"theme\"\n\t\t\t\t\t\tdata-top-icon=\"\"\n\t\t\t\t\t\t@click=\"sort('key')\"\n\t\t\t\t\t\t:title=\"$i18n.Projects?.Sort_by_yande_region_code\"\n\t\t\t\t\t/>\n\n\t\t\t\t\t<TopButton\n\t\t\t\t\t\tclass=\"dialog_regionSelectorRegions_sortButton\"\n\t\t\t\t\t\tcolor=\"theme\"\n\t\t\t\t\t\tdata-top-icon=\"\"\n\t\t\t\t\t\t@click=\"sort('name')\"\n\t\t\t\t\t\t:title=\"$i18n.Projects?.Sort_by_lphabetically\"\n\t\t\t\t\t/>\n\t\t\t\t</div>\n\t\t\t</template>\n\n\t\t\t<template #body>\n\t\t\t\t<div ref=\"elRegions\">\n\t\t\t\t\t<TopCheckbox\n\t\t\t\t\t\tv-for=\"region of regionsRich\"\n\t\t\t\t\t\t:key=\"region.index\"\n\t\t\t\t\t\tv-model=\"region.selected\"\n\t\t\t\t\t\tclass=\"dialog_regionSelectorRegions_region\"\n\t\t\t\t\t\t:data-region-index=\"region.index\"\n\t\t\t\t\t>\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclass=\"dialog_regionSelectorRegions_regionSearcherIcon\"\n\t\t\t\t\t\t\t:data-top-icon=\"region.searcherIcon\"\n\t\t\t\t\t\t></div>\n\n\t\t\t\t\t\t<img\n\t\t\t\t\t\t\tv-if=\"region.flagLink\"\n\t\t\t\t\t\t\tclass=\"top-flag\"\n\t\t\t\t\t\t\t:src=\"'//topvisor.dev' + region.flagLink\"\n\t\t\t\t\t\t\t:alt=\"region.countryCode\"\n\t\t\t\t\t\t>\n\n\t\t\t\t\t\t<div class=\"top-ellipsis\">\n\t\t\t\t\t\t\t{{ region.name }}\n\n\t\t\t\t\t\t\t<span class=\"dialog_regionSelectorRegions_regionAreaName\">\n\t\t\t\t\t\t\t\t{{ region.areaName }}\n\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t<div v-if=\"region.langLabel\">\n\t\t\t\t\t\t\t[{{ region.langLabel }}]\n\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tv-if=\"region.deviceIcon\"\n\t\t\t\t\t\t\t:data-top-icon=\"region.deviceIcon\"\n\t\t\t\t\t\t></div>\n\t\t\t\t\t</TopCheckbox>\n\t\t\t\t</div>\n\t\t\t</template>\n\n\t\t\t<template #footer>\n\t\t\t\t<TopButton @click=\"onSubmit\">\n\t\t\t\t\t{{ $i18n.Common?.Apply }}\n\t\t\t\t</TopButton>\n\t\t\t</template>\n\t\t</TopDialogPage>\n\t</TopDialog>\n</template>\n\n<style>\n@import \"./style.css\";\n</style>\n"],"names":["props","__props","dialog","useTopDialogSelf","regionsRich","ref","elRegions","sortedVectorByField","reactive","isAllSelected","computed","region","value","sort","sortedField","regionA","regionB","onSubmit","regionsIndexes","watch","regions","orderByRegionIndex","index","order","orderA","orderB","title","selected","searcherIcon","getSearcherGIcon","langLabel","getLangLabel","deviceIcon","getDeviceGIcon","flagLink","genFlagLinkByCountryCode","regionRich","onOpen","Core","sortedIndexes","el","a","b","onClose","_createBlock","_unref","TopDialog","_createVNode","TopDialogPage","_createElementVNode","_hoisted_1","_component_TopCheckbox","$event","_component_TopButton","$i18n","_createElementBlock","_Fragment","_renderList","_hoisted_4","_hoisted_5","_toDisplayString","_openBlock"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ define(["require","exports","vue","./page.vue_vue_type_script_setup_true_lang-CjIiZU-D.amd","./utils-CzHUG_xz.amd","../utils/string.amd","../utils/searchers.amd","./forms-CUSCBQu3.amd","../require/css.amd!../assets/dialog_regionSelectorRegions.css"],(function(U,m,e,p,y,k,u,v){"use strict";if(typeof e>"u")var e=window.Vue;const x={class:"dialog_regionSelectorRegions_header"},h=["data-top-icon"],C=["src","alt"],V={class:"top-ellipsis"},S={class:"dialog_regionSelectorRegions_regionAreaName"},b={key:1},N=["data-top-icon"],B=e.defineComponent({id:"regionSelectorRegions",__name:"dialog_regionSelectorRegions",props:{regions:{},regionsIndexes:{},"@update:regionsIndexes":{type:Function}},setup(I){const i=I,_=y.useTopDialogSelf(),r=e.ref([]),s=e.ref(null),d=e.reactive({searcher_key:-1,key:-1,name:-1}),f=e.computed({get(){return r.value.every(t=>t.selected)},set(t){r.value=r.value.map(o=>({...o,selected:t}))}}),g=t=>{d[t]=-d[t],r.value.sort((o,n)=>!o[t]||!n[t]?-1:o[t]>=n[t]?d[t]:-d[t])},R=()=>{if(!r.value.some(o=>o.selected))return;const t=r.value.filter(o=>o.selected).map(o=>o.index);i["@update:regionsIndexes"]?.(t),_.close()};e.watch([()=>i.regions,()=>i.regionsIndexes],()=>{if(r.value=[],!i.regions||!i.regionsIndexes)return;let t=[...i.regions];const o=new Map(i.regionsIndexes.map((n,a)=>[n,a]));t.sort((n,a)=>{const l=o.get(n.index)??Number.MAX_VALUE,c=o.get(a.index)??Number.MAX_VALUE;return l-c}),t.forEach(n=>{let a=n.name;n.areaName&&(a+=` (${n.areaName})`);const l=i.regionsIndexes?.includes(n.index)??!1,c=u.getSearcherGIcon(n.searcher_key),w=n.lang!==void 0?u.getLangLabel(n.searcher_key??999,n.lang):void 0,A=n.device!==void 0?u.getDeviceGIcon(n.device):void 0,T=n.countryCode!==void 0?k.genFlagLinkByCountryCode(n.countryCode):void 0,D={...n,selected:l,title:a,searcherIcon:c,langLabel:w,deviceIcon:A,flagLink:T};r.value.push(D)})});const E=()=>{if(!v.Core.$?.ui.sortable){console.info("Для работы сортировки требуется глобальная загрузка jQuery UI Sortable");return}s.value&&$(s.value).sortable({distance:10,stop:()=>{const t=[...s.value.children].map(o=>Number(o.getAttribute("data-region-index")));r.value.sort((o,n)=>t.indexOf(o.index)-t.indexOf(n.index))}})},L=()=>{v.Core.$?.ui.sortable&&s.value&&$(s.value).sortable("destroy")};return(t,o)=>{const n=e.resolveComponent("TopCheckbox"),a=e.resolveComponent("TopButton");return e.openBlock(),e.createBlock(e.unref(p._sfc_main),{id:e.unref(_).id,pageActive:"regions",class:"dialog_regionSelectorRegions",height:"600px",width:"600px",onOpen:E,onClose:L},{default:e.withCtx(()=>[e.createVNode(e.unref(p._sfc_main$1),{name:"regions",order:0},{header:e.withCtx(()=>[e.createElementVNode("div",x,[e.createVNode(n,{modelValue:f.value,"onUpdate:modelValue":o[0]||(o[0]=l=>f.value=l)},null,8,["modelValue"]),e.createVNode(a,{class:"dialog_regionSelectorRegions_sortButton",color:"theme","data-top-icon":"",onClick:o[1]||(o[1]=l=>g("searcher_key")),title:t.$i18n.Projects?.Sort_by_search_engine},null,8,["title"]),e.createVNode(a,{class:"dialog_regionSelectorRegions_sortButton",color:"theme","data-top-icon":"",onClick:o[2]||(o[2]=l=>g("key")),title:t.$i18n.Projects?.Sort_by_yande_region_code},null,8,["title"]),e.createVNode(a,{class:"dialog_regionSelectorRegions_sortButton",color:"theme","data-top-icon":"",onClick:o[3]||(o[3]=l=>g("name")),title:t.$i18n.Projects?.Sort_by_lphabetically},null,8,["title"])])]),body:e.withCtx(()=>[e.createElementVNode("div",{ref_key:"elRegions",ref:s},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(r.value,l=>(e.openBlock(),e.createBlock(n,{key:l.index,modelValue:l.selected,"onUpdate:modelValue":c=>l.selected=c,class:"dialog_regionSelectorRegions_region","data-region-index":l.index},{default:e.withCtx(()=>[e.createElementVNode("div",{class:"dialog_regionSelectorRegions_regionSearcherIcon","data-top-icon":l.searcherIcon},null,8,h),l.flagLink?(e.openBlock(),e.createElementBlock("img",{key:0,class:"top-flag",src:"//topvisor.dev"+l.flagLink,alt:l.countryCode},null,8,C)):e.createCommentVNode("",!0),e.createElementVNode("div",V,[e.createTextVNode(e.toDisplayString(l.name)+" ",1),e.createElementVNode("span",S,e.toDisplayString(l.areaName),1)]),l.langLabel?(e.openBlock(),e.createElementBlock("div",b," ["+e.toDisplayString(l.langLabel)+"] ",1)):e.createCommentVNode("",!0),l.deviceIcon?(e.openBlock(),e.createElementBlock("div",{key:2,"data-top-icon":l.deviceIcon},null,8,N)):e.createCommentVNode("",!0)]),_:2},1032,["modelValue","onUpdate:modelValue","data-region-index"]))),128))],512)]),footer:e.withCtx(()=>[e.createVNode(a,{onClick:R},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(t.$i18n.Common?.Apply),1)]),_:1})]),_:1})]),_:1},8,["id"])}}});m.default=B,Object.defineProperty(m,Symbol.toStringTag,{value:"Module"})}));
2
+ //# sourceMappingURL=dialog_regionSelectorRegions-CZ8IX7la.amd.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dialog_regionSelectorRegions-CZ8IX7la.amd.js","sources":["../../src/components/project/regionSelector/dialog_regionSelectorRegions/dialog_regionSelectorRegions.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed, reactive, ref, watch } from 'vue';\nimport { TopDialog, TopDialogPage, useTopDialogSelf } from '@/components/dialog/dialog';\nimport { genFlagLinkByCountryCode } from '@/core/utils/string';\nimport type { Props, RegionRich } from './types';\nimport { getDeviceGIcon, getLangLabel, getSearcherGIcon } from '@/core/utils/searchers';\nimport Core from '@/core/core/core';\n\ndefineOptions({ id: 'regionSelectorRegions' });\n\nconst props = defineProps<Partial<Props>>();\n\nconst dialog = useTopDialogSelf();\n\n/**\n * Список расширенных регионов для использования в компоненте\n */\nconst regionsRich = ref<RegionRich[]>([]);\n\n/**\n * Ссылка на элемент с регионами\n */\nconst elRegions = ref<null | HTMLElement>(null);\n\n/**\n * Направление сортировки по полю\n */\nconst sortedVectorByField = reactive({\n\tsearcher_key: -1,\n\tkey: -1,\n\tname: -1,\n});\n\n/**\n * Выбраны все регионы\n */\nconst isAllSelected = computed({\n\tget() {\n\t\treturn regionsRich.value.every(region => region.selected);\n\t},\n\n\tset(value) {\n\t\tregionsRich.value = regionsRich.value.map(region => ({ ...region, selected: value }));\n\t},\n});\n\n/**\n * Сортировать регионы по выбранному полю\n * @param sortedField - Поле для сортировки\n */\nconst sort = (sortedField: keyof typeof sortedVectorByField) => {\n\tsortedVectorByField[sortedField] = -sortedVectorByField[sortedField];\n\n\tregionsRich.value.sort((regionA, regionB) => {\n\t\tif (!regionA[sortedField] || !regionB[sortedField]) return -1;\n\n\t\treturn regionA[sortedField] >= regionB[sortedField] ? sortedVectorByField[sortedField] : -sortedVectorByField[sortedField];\n\t});\n};\n\n/**\n * Применить изменения\n *\n * Вызывает callback `props['@update:regionsIndexes']`\n */\nconst onSubmit = () => {\n\tif (!regionsRich.value.some(region => region.selected)) return;\n\n\tconst regionsIndexes = regionsRich.value\n\t\t.filter(region => region.selected)\n\t\t.map(region => region.index);\n\n\tprops['@update:regionsIndexes']?.(regionsIndexes);\n\n\tdialog.close();\n};\n\n// генерация регионов\nwatch([\n\t() => props.regions,\n\t() => props.regionsIndexes,\n], () => {\n\tregionsRich.value = [];\n\n\tif (!props.regions) return;\n\tif (!props.regionsIndexes) return;\n\n\tlet regions = [...props.regions];\n\n\t// отсортировать регионы по входным данным\n\tconst orderByRegionIndex = new Map(props.regionsIndexes.map((index, order) => [index, order]));\n\n\tregions.sort((regionA, regionB) => {\n\t\tconst orderA = orderByRegionIndex.get(regionA.index) ?? Number.MAX_VALUE;\n\t\tconst orderB = orderByRegionIndex.get(regionB.index) ?? Number.MAX_VALUE;\n\n\t\treturn orderA - orderB;\n\t});\n\n\tregions.forEach(region => {\n\t\tlet title = region.name;\n\t\tif (region.areaName) title += ` (${region.areaName})`;\n\n\t\tconst selected = props.regionsIndexes?.includes(region.index) ?? false;\n\t\tconst searcherIcon = getSearcherGIcon(region.searcher_key);\n\t\tconst langLabel = region.lang !== undefined ? getLangLabel(region.searcher_key ?? 999, region.lang) : undefined;\n\t\tconst deviceIcon = region.device !== undefined ? getDeviceGIcon(region.device) : undefined;\n\t\tconst flagLink = region.countryCode !== undefined ? genFlagLinkByCountryCode(region.countryCode) : undefined;\n\n\t\tconst regionRich = {\n\t\t\t...region,\n\t\t\tselected,\n\t\t\ttitle,\n\t\t\tsearcherIcon,\n\t\t\tlangLabel,\n\t\t\tdeviceIcon,\n\t\t\tflagLink,\n\t\t};\n\n\t\tregionsRich.value.push(regionRich);\n\t});\n});\n\n/**\n * Проверить на существование sortable\n */\nconst onOpen = () => {\n\tif (!Core.$?.ui['sortable']) {\n\t\tconsole.info('Для работы сортировки требуется глобальная загрузка jQuery UI Sortable');\n\n\t\treturn;\n\t}\n\n\tif (!elRegions.value) return;\n\n\t$(elRegions.value).sortable({\n\t\tdistance: 10,\n\n\t\tstop: () => {\n\t\t\t// Обновляем порядок регионов в массиве regionsRich после сортировки\n\t\t\tconst sortedIndexes = [...elRegions.value!.children].map(el => Number(el.getAttribute('data-region-index')));\n\t\t\tregionsRich.value.sort((a, b) => sortedIndexes.indexOf(a.index) - sortedIndexes.indexOf(b.index));\n\t\t},\n\t});\n};\n\n/**\n * Удаление sortable\n */\nconst onClose = () => {\n\tif (!Core.$?.ui['sortable']) return;\n\tif (!elRegions.value) return;\n\n\t$(elRegions.value).sortable('destroy');\n};\n\n</script>\n\n<template>\n\t<TopDialog\n\t\t:id=\"dialog.id\"\n\t\tpageActive=\"regions\"\n\t\tclass=\"dialog_regionSelectorRegions\"\n\t\theight=\"600px\"\n\t\twidth=\"600px\"\n\t\t@open=\"onOpen\"\n\t\t@close=\"onClose\"\n\t>\n\t\t<TopDialogPage name=\"regions\" :order=\"0\">\n\t\t\t<template #header>\n\t\t\t\t<div class=\"dialog_regionSelectorRegions_header\">\n\t\t\t\t\t<TopCheckbox v-model=\"isAllSelected\"></TopCheckbox>\n\n\t\t\t\t\t<TopButton\n\t\t\t\t\t\tclass=\"dialog_regionSelectorRegions_sortButton\"\n\t\t\t\t\t\tcolor=\"theme\"\n\t\t\t\t\t\tdata-top-icon=\"\"\n\t\t\t\t\t\t@click=\"sort('searcher_key')\"\n\t\t\t\t\t\t:title=\"$i18n.Projects?.Sort_by_search_engine\"\n\t\t\t\t\t/>\n\n\t\t\t\t\t<TopButton\n\t\t\t\t\t\tclass=\"dialog_regionSelectorRegions_sortButton\"\n\t\t\t\t\t\tcolor=\"theme\"\n\t\t\t\t\t\tdata-top-icon=\"\"\n\t\t\t\t\t\t@click=\"sort('key')\"\n\t\t\t\t\t\t:title=\"$i18n.Projects?.Sort_by_yande_region_code\"\n\t\t\t\t\t/>\n\n\t\t\t\t\t<TopButton\n\t\t\t\t\t\tclass=\"dialog_regionSelectorRegions_sortButton\"\n\t\t\t\t\t\tcolor=\"theme\"\n\t\t\t\t\t\tdata-top-icon=\"\"\n\t\t\t\t\t\t@click=\"sort('name')\"\n\t\t\t\t\t\t:title=\"$i18n.Projects?.Sort_by_lphabetically\"\n\t\t\t\t\t/>\n\t\t\t\t</div>\n\t\t\t</template>\n\n\t\t\t<template #body>\n\t\t\t\t<div ref=\"elRegions\">\n\t\t\t\t\t<TopCheckbox\n\t\t\t\t\t\tv-for=\"region of regionsRich\"\n\t\t\t\t\t\t:key=\"region.index\"\n\t\t\t\t\t\tv-model=\"region.selected\"\n\t\t\t\t\t\tclass=\"dialog_regionSelectorRegions_region\"\n\t\t\t\t\t\t:data-region-index=\"region.index\"\n\t\t\t\t\t>\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclass=\"dialog_regionSelectorRegions_regionSearcherIcon\"\n\t\t\t\t\t\t\t:data-top-icon=\"region.searcherIcon\"\n\t\t\t\t\t\t></div>\n\n\t\t\t\t\t\t<img\n\t\t\t\t\t\t\tv-if=\"region.flagLink\"\n\t\t\t\t\t\t\tclass=\"top-flag\"\n\t\t\t\t\t\t\t:src=\"'//topvisor.dev' + region.flagLink\"\n\t\t\t\t\t\t\t:alt=\"region.countryCode\"\n\t\t\t\t\t\t>\n\n\t\t\t\t\t\t<div class=\"top-ellipsis\">\n\t\t\t\t\t\t\t{{ region.name }}\n\n\t\t\t\t\t\t\t<span class=\"dialog_regionSelectorRegions_regionAreaName\">\n\t\t\t\t\t\t\t\t{{ region.areaName }}\n\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t<div v-if=\"region.langLabel\">\n\t\t\t\t\t\t\t[{{ region.langLabel }}]\n\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tv-if=\"region.deviceIcon\"\n\t\t\t\t\t\t\t:data-top-icon=\"region.deviceIcon\"\n\t\t\t\t\t\t></div>\n\t\t\t\t\t</TopCheckbox>\n\t\t\t\t</div>\n\t\t\t</template>\n\n\t\t\t<template #footer>\n\t\t\t\t<TopButton @click=\"onSubmit\">\n\t\t\t\t\t{{ $i18n.Common?.Apply }}\n\t\t\t\t</TopButton>\n\t\t\t</template>\n\t\t</TopDialogPage>\n\t</TopDialog>\n</template>\n\n<style>\n@import \"./style.css\";\n</style>\n"],"names":["dialog","utils","regionsRich","vue","elRegions","sortedVectorByField","isAllSelected","region","sort","sortedField","regionA","regionB","props","regionsIndexes","orderA","orderByRegionIndex","orderB","regions","title","selected","deviceIcon","utils_searchers","flagLink","utils_string","searcherIcon","langLabel","regionRich","a","b","sortedIndexes","onOpen","page_vue_vue_type_script_setup_true_lang","_hoisted_1","_cache","$event","_ctx","_hoisted_2","_hoisted_3","_hoisted_5","_hoisted_7"],"mappings":"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"}
@@ -1,8 +1,8 @@
1
- import { ref as d, markRaw as S, shallowReactive as C, defineComponent as b, onUnmounted as O, createElementBlock as H, openBlock as y, Fragment as R, renderList as k, unref as B, createBlock as F, resolveDynamicComponent as _ } from "vue";
2
- import { waitWhile as q } from "../utils/system.js";
3
- import { historySetState as E, genHash as L, getHash as V } from "../utils/route.js";
4
- import { querySelectorAllArray as P, isVisible as M } from "../utils/dom.js";
5
- class c {
1
+ import { ref as g, markRaw as V, shallowReactive as M, defineComponent as C, onUnmounted as S, createElementBlock as U, openBlock as v, Fragment as b, renderList as O, unref as R, createBlock as T, resolveDynamicComponent as k } from "vue";
2
+ import { waitWhile as B } from "../utils/system.js";
3
+ import { historySetState as P, genHash as A, getHash as x } from "../utils/route.js";
4
+ import { querySelectorAllArray as y, isVisible as H } from "../utils/dom.js";
5
+ class r {
6
6
  static state = {
7
7
  load: void 0,
8
8
  decoratorOnCreate: void 0,
@@ -21,64 +21,63 @@ class c {
21
21
  */
22
22
  static init(e) {
23
23
  if (this.inited) return;
24
- this.inited = !0, this.state.load = e == null ? void 0 : e.load, this.state.decoratorOnCreate = e == null ? void 0 : e.decoratorOnCreate;
25
- const a = (e == null ? void 0 : e.autoInitDelay) ?? 5e3;
26
- window.addEventListener("hashchange", (t) => {
27
- this.opendDialogsFromChangeUrl(t.oldURL, t.newURL);
28
- }), this.opendDialogsFromChangeUrl("", location.href), document.addEventListener("mousedown", async (t) => {
29
- if (!(t.target instanceof HTMLElement)) return;
30
- const i = t.target.closest("a[data-to-view]");
24
+ this.inited = !0, this.state.load = e?.load, this.state.decoratorOnCreate = e?.decoratorOnCreate;
25
+ const t = e?.autoInitDelay ?? 5e3;
26
+ window.addEventListener("hashchange", (a) => {
27
+ this.opendDialogsFromChangeUrl(a.oldURL, a.newURL);
28
+ }), this.opendDialogsFromChangeUrl("", location.href), document.addEventListener("mousedown", async (a) => {
29
+ if (!(a.target instanceof HTMLElement)) return;
30
+ const i = a.target.closest("a[data-to-view]");
31
31
  if (!i) return;
32
32
  let n = "next";
33
- i.dataset.action === "top-dialog-close" && (n = "prev"), i.href = c.genViewPageHash(i.dataset.toView, n);
34
- }), document.addEventListener("click", async (t) => {
35
- var N, D;
36
- if (!(t.target instanceof HTMLElement)) return;
37
- const i = t.target.closest("[data-to-view]");
33
+ i.dataset.action === "top-dialog-close" && (n = "prev"), i.href = r.genViewPageHash(i.dataset.toView, n);
34
+ }), document.addEventListener("click", async (a) => {
35
+ if (!(a.target instanceof HTMLElement)) return;
36
+ const i = a.target.closest("[data-to-view]");
38
37
  if (!i) return;
39
38
  if (i instanceof HTMLAnchorElement && i.href === ".") {
40
- t.preventDefault();
41
- const f = new MouseEvent("mousedown", {
39
+ a.preventDefault();
40
+ const w = new MouseEvent("mousedown", {
42
41
  bubbles: !0,
43
42
  cancelable: !0,
44
43
  view: window
45
44
  });
46
- i.dispatchEvent(f), setTimeout(() => i.click());
45
+ i.dispatchEvent(w), setTimeout(() => i.click());
47
46
  return;
48
47
  }
49
- const n = await this.getDialogsUtils(), r = i.dataset.toView, u = r.split("-")[0], l = n.getElDialogById(u);
50
- let w = "next";
51
- if (l) {
52
- const f = P(l, ".modal-layer"), U = f.reduce((m, A) => {
53
- const h = A.querySelector(":scope > .active");
54
- return h && m.push(h), m;
48
+ const n = await this.getDialogsUtils(), o = i.dataset.toView, u = o.split("-")[0], d = n.getElDialogById(u);
49
+ let p = "next";
50
+ if (d) {
51
+ const w = y(d, ".modal-layer"), D = w.reduce((f, E) => {
52
+ const h = E.querySelector(":scope > .active");
53
+ return h && f.push(h), f;
55
54
  }, []);
56
- if (U.length) {
57
- const m = r.split("-")[1].split(":")[0];
58
- (((N = f.reduce((h, p) => {
59
- const x = p == null ? void 0 : p.querySelector(`:scope > [data-view-page="${m}"]`);
60
- return x && h.push(x), h;
61
- }, [])[0]) == null ? void 0 : N.dataset.order) ?? 0) < (((D = U[0]) == null ? void 0 : D.dataset.order) ?? 0) && (w = "prev");
55
+ if (D.length) {
56
+ const f = o.split("-")[1].split(":")[0];
57
+ (w.reduce((h, L) => {
58
+ const N = L?.querySelector(`:scope > [data-view-page="${f}"]`);
59
+ return N && h.push(N), h;
60
+ }, [])[0]?.dataset.order ?? 0) < (D[0]?.dataset.order ?? 0) && (p = "prev");
62
61
  }
63
62
  }
64
- i.dataset.action === "top-dialog-close" && (w = "prev");
65
- const v = c.genViewPageHash(r, w);
63
+ i.dataset.action === "top-dialog-close" && (p = "prev");
64
+ const m = r.genViewPageHash(o, p);
66
65
  if (i instanceof HTMLAnchorElement) {
67
- if (!l || !M(l)) return;
68
- if (location.hash.indexOf(r.replace("-", "=")) !== -1) {
69
- await n.toViewDirty(r);
66
+ if (!d || !H(d)) return;
67
+ if (location.hash.indexOf(o.replace("-", "=")) !== -1) {
68
+ await n.toViewDirty(o);
70
69
  return;
71
70
  }
72
71
  }
73
- !!(l != null && l.dataset.toViewReplace) ? (t.preventDefault(), E(!0, v), await n.toViewDirty(r), w == "next" ? c.state.viewPageN++ : c.state.viewPageN--) : i.tagName !== "A" && (this.compareStates(v, location.hash) ? E(!1, v) : await n.toViewDirty(r));
74
- }), setTimeout(() => this.getDialogsUtils(), a);
72
+ !!d?.dataset.toViewReplace ? (a.preventDefault(), P(!0, m), await n.toViewDirty(o), p == "next" ? r.state.viewPageN++ : r.state.viewPageN--) : i.tagName !== "A" && (this.compareStates(m, location.hash) ? P(!1, m) : await n.toViewDirty(o));
73
+ }), setTimeout(() => this.getDialogsUtils(), t);
75
74
  }
76
- static opendDialogsFromChangeUrl(e, a) {
77
- const t = e.replace(/.*?#/, "#"), s = a.replace(/.*?#/, "#");
78
- this.compareStates(t, s) && this.opendDialogsFromUrl();
75
+ static opendDialogsFromChangeUrl(e, t) {
76
+ const a = e.replace(/.*?#/, "#"), s = t.replace(/.*?#/, "#");
77
+ this.compareStates(a, s) && this.opendDialogsFromUrl();
79
78
  }
80
79
  static async getDialogsUtils() {
81
- const { TopDialogUtils: e } = await import("./utils-D58EUoHa.es.js");
80
+ const { TopDialogUtils: e } = await import("./utils-Q69SXlnV.es.js");
82
81
  return e;
83
82
  }
84
83
  static getDialog(e) {
@@ -109,78 +108,78 @@ class c {
109
108
  * @deprecated Для обратной совместимости
110
109
  */
111
110
  static get$pairPage(e) {
112
- const a = c.get$dialog(e), s = c.get$page(e).data("view-page");
113
- return $('[data-view-page="' + s + '"]', a);
111
+ const t = r.get$dialog(e), s = r.get$page(e).data("view-page");
112
+ return $('[data-view-page="' + s + '"]', t);
114
113
  }
115
114
  static getPairPage(e) {
116
- const a = c.getDialog(e);
117
- if (!a) return;
118
- const t = c.getPage(e), s = t == null ? void 0 : t.dataset.viewPage;
119
- return P(a, `[data-view-page="${s}"]`);
115
+ const t = r.getDialog(e);
116
+ if (!t) return;
117
+ const s = r.getPage(e)?.dataset.viewPage;
118
+ return y(t, `[data-view-page="${s}"]`);
120
119
  }
121
120
  /**
122
121
  * Закрыть диалоговое окно
123
122
  */
124
123
  static close(e) {
125
- const a = $("#" + e);
126
- if (a.dialog("instance")) {
127
- a.dialog("close");
124
+ const t = $("#" + e);
125
+ if (t.dialog("instance")) {
126
+ t.dialog("close");
128
127
  return;
129
128
  }
130
- const t = document.getElementById(e);
131
- t instanceof HTMLDialogElement && t.close();
129
+ const a = document.getElementById(e);
130
+ a instanceof HTMLDialogElement && a.close();
132
131
  }
133
132
  /**
134
133
  * Размонтировать $.dialog
135
134
  */
136
135
  static destroy(e) {
137
- const a = $("#" + e);
138
- if (a.dialog("instance")) {
139
- a.dialog("close"), a.dialog("destroy");
136
+ const t = $("#" + e);
137
+ if (t.dialog("instance")) {
138
+ t.dialog("close"), t.dialog("destroy");
140
139
  return;
141
140
  }
142
- const t = document.getElementById(e);
143
- t instanceof HTMLDialogElement && t.close();
141
+ const a = document.getElementById(e);
142
+ a instanceof HTMLDialogElement && a.close();
144
143
  }
145
144
  /**
146
145
  * Сгенерировать ссылку на страницу в диалоговом окне
147
146
  * @param toView - указатель в формате: dialog_{{ dialogId }}={{ pageName }}:{{ args }}
148
147
  * @param moveDirection
149
148
  */
150
- static genViewPageHash(e, a = "next") {
151
- let t = this.state.viewPageN;
152
- a == "prev" ? t-- : t++;
149
+ static genViewPageHash(e, t = "next") {
150
+ let a = this.state.viewPageN;
151
+ t == "prev" ? a-- : a++;
153
152
  const s = e.split("-"), i = s.shift(), n = s.join("-");
154
- let r = L("vpn", t);
155
- return r = L("view-" + i, n, r), r;
153
+ let o = A("vpn", a);
154
+ return o = A("view-" + i, n, o), o;
156
155
  }
157
156
  /**
158
157
  * Сравнить версию открытых диалоговых окон
159
158
  * @returns вернет true, если состояния открытых окон изменилось
160
159
  */
161
- static compareStates(e, a) {
162
- const t = e.match(/[#&]view-[^&]+/g) || [], s = a.match(/[#&]view-[^&]+/g) || [];
163
- return !!(t.length !== s.length || t.filter((n, r) => {
164
- const u = s[r] || "";
160
+ static compareStates(e, t) {
161
+ const a = e.match(/[#&]view-[^&]+/g) || [], s = t.match(/[#&]view-[^&]+/g) || [];
162
+ return !!(a.length !== s.length || a.filter((n, o) => {
163
+ const u = s[o] || "";
165
164
  return n !== u;
166
165
  }).length);
167
166
  }
168
167
  static opendDialogsFromUrl = async () => {
169
- const e = Number(V("vpn")) || 0;
170
- let a;
171
- const t = new RegExp("view-((\\w+)=([\\w-]+)(?::([\\w.:-]+))?)", "g");
172
- for (; a = t.exec(location.hash); ) {
168
+ const e = Number(x("vpn")) || 0;
169
+ let t;
170
+ const a = new RegExp("view-((\\w+)=([\\w-]+)(?::([\\w.:-]+))?)", "g");
171
+ for (; t = a.exec(location.hash); ) {
173
172
  let i = "next";
174
- return e < this.state.viewPageN && (i = "prev"), (await this.getDialogsUtils()).toViewDirty(a[1], i);
173
+ return e < this.state.viewPageN && (i = "prev"), (await this.getDialogsUtils()).toViewDirty(t[1], i);
175
174
  }
176
- return P(document, ".ui-dialog-content[data-view-page-active]").filter((i) => M(i)).forEach((i) => {
175
+ return y(document, ".ui-dialog-content[data-view-page-active]").filter((i) => H(i)).forEach((i) => {
177
176
  const n = i.getAttribute("id");
178
177
  if (!n) throw "Диалоговое окно не содержит id";
179
- V("view-" + n) || $(i).dialog("close");
178
+ x("view-" + n) || $(i).dialog("close");
180
179
  }), this.state.viewPageN = e, !0;
181
180
  };
182
181
  }
183
- class I {
182
+ class F {
184
183
  /**
185
184
  * Индентификатор, определяется на уровне компонента TopDialogComponent
186
185
  *
@@ -200,31 +199,31 @@ class I {
200
199
  *
201
200
  * Устанавливается после первого вызова useTopDialog()
202
201
  */
203
- isMounted = d(!1);
202
+ isMounted = g(!1);
204
203
  /**
205
204
  * Компонент готов к использованию
206
205
  *
207
206
  * Используется для внутренних преобразований после отрисовки
208
207
  */
209
- isReady = d(!1);
208
+ isReady = g(!1);
210
209
  /**
211
210
  * Диалоговое окно открыто
212
211
  */
213
- isOpened = d(!1);
212
+ isOpened = g(!1);
214
213
  /**
215
214
  * Имя активной страницы дилогового окна
216
215
  */
217
- pageActive = d("");
216
+ pageActive = g("");
218
217
  /**
219
218
  * Диалоговое окно находится в состоянии загрузки своей страницы
220
219
  */
221
- isLoadingPage = d(!1);
220
+ isLoadingPage = g(!1);
222
221
  /**
223
222
  * Следующая активная страница
224
223
  *
225
224
  * В один момент времени может потребоваться отобразить две страницы, чтобы воспроизвести анимацию
226
225
  */
227
- pageActiveNext = d("");
226
+ pageActiveNext = g("");
228
227
  /**
229
228
  * props компонента, доступны после инициализации
230
229
  */
@@ -240,31 +239,31 @@ class I {
240
239
  */
241
240
  onCloseOnce;
242
241
  constructor(e) {
243
- this.id = e.id, this.idAttr = "dialog_" + e.id, this.Component = S(e);
242
+ this.id = e.id, this.idAttr = "dialog_" + e.id, this.Component = V(e);
244
243
  }
245
244
  /**
246
245
  * Событие - компонент инициирован
247
246
  */
248
- onMounted(e, a) {
249
- this.isMounted.value = !0, this.props = e.props, this.emit = a.emit;
247
+ onMounted(e, t) {
248
+ this.isMounted.value = !0, this.props = e.props, this.emit = t.emit;
250
249
  }
251
250
  /**
252
251
  * Открыть диалоговое окно
253
252
  *
254
253
  * Учтите, что props в диалоговом окне будут доступны не сразу, а только после инициализации vue компонента
255
254
  */
256
- async open(e = "main", a, t = [], s, i) {
257
- a && await this.setProps(a), s && (this.onCloseOnce = s), await (await c.getDialogsUtils()).toView(this.idAttr, e, t, i);
255
+ async open(e = "main", t, a = [], s, i) {
256
+ t && await this.setProps(t), s && (this.onCloseOnce = s), await (await r.getDialogsUtils()).toView(this.idAttr, e, a, i);
258
257
  }
259
258
  /**
260
259
  * Открыть диалоговое окно как ссылку, для хеш-навигации
261
260
  *
262
261
  * Диалоговые окна загружаются по имени, см. настройку плагина Core topDialogLoader
263
262
  */
264
- async openAsLink(e = "main", a, t = [], s, i) {
265
- a && await this.setProps(a), s && (this.onCloseOnce = s);
266
- const n = this.idAttr + "-" + e, r = c.genViewPageHash(n, i);
267
- E(!1, r);
263
+ async openAsLink(e = "main", t, a = [], s, i) {
264
+ t && await this.setProps(t), s && (this.onCloseOnce = s);
265
+ const n = this.idAttr + "-" + e, o = r.genViewPageHash(n, i);
266
+ P(!1, o);
268
267
  }
269
268
  /**
270
269
  * Закрыть диалоговое окно
@@ -272,13 +271,13 @@ class I {
272
271
  * Не меняет состояние компонента диалогового окна
273
272
  */
274
273
  async close() {
275
- c.close(this.idAttr);
274
+ r.close(this.idAttr);
276
275
  }
277
276
  /**
278
277
  * Размонтировать $.dialog
279
278
  */
280
279
  async destroy() {
281
- c.destroy(this.idAttr);
280
+ r.destroy(this.idAttr);
282
281
  }
283
282
  /**
284
283
  * Устанвоить props
@@ -286,9 +285,9 @@ class I {
286
285
  * Полностью сбрасывается состояние props
287
286
  */
288
287
  async setProps(e = {}) {
289
- this.isMounted || await q(() => !this.props);
290
- for (const a in this.props)
291
- this.props[a] = e[a];
288
+ this.isMounted || await B(() => !this.props);
289
+ for (const t in this.props)
290
+ this.props[t] = e[t];
292
291
  }
293
292
  /**
294
293
  * Проверить, есть ли необходимость отрисовки страницы диалогового окна
@@ -297,28 +296,28 @@ class I {
297
296
  return this.isOpened.value ? this.pageActive.value === e || this.pageActiveNext.value === e : !1;
298
297
  }
299
298
  }
300
- const T = {
299
+ const _ = {
301
300
  class: "top-dialogs",
302
301
  style: { display: "none" }
303
- }, g = C(/* @__PURE__ */ new Map()), Q = (o) => (o = o.replace(/^dialog_/, ""), g.get(o)), X = (o) => {
304
- if (!(o != null && o.id))
305
- throw console.log({ TopDialogComponent: o }), new Error("Expected TopDialogComponent");
306
- return g.has(o.id) || g.set(o.id, new I(o)), g.get(o.id);
307
- }, Y = /* @__PURE__ */ b({
302
+ }, c = M(/* @__PURE__ */ new Map()), J = (l) => (l = l.replace(/^dialog_/, ""), c.get(l)), K = (l) => {
303
+ if (!l?.id)
304
+ throw console.log({ TopDialogComponent: l }), new Error("Expected TopDialogComponent");
305
+ return c.has(l.id) || c.set(l.id, new F(l)), c.get(l.id);
306
+ }, Q = /* @__PURE__ */ C({
308
307
  name: "DialogWrapper",
309
308
  __name: "dialogs",
310
- setup(o) {
311
- return O(() => {
312
- g.forEach((e) => e.destroy()), g.clear();
313
- }), (e, a) => (y(), H("div", T, [
314
- (y(!0), H(R, null, k(B(g), ([t, s]) => (y(), F(_(s.Component), { key: t }))), 128))
309
+ setup(l) {
310
+ return S(() => {
311
+ c.forEach((e) => e.destroy()), c.clear();
312
+ }), (e, t) => (v(), U("div", _, [
313
+ (v(!0), U(b, null, O(R(c), ([a, s]) => (v(), T(k(s.Component), { key: a }))), 128))
315
314
  ]));
316
315
  }
317
316
  });
318
317
  export {
319
- c as T,
320
- Y as _,
321
- X as a,
322
- Q as g
318
+ r as T,
319
+ Q as _,
320
+ K as a,
321
+ J as g
323
322
  };
324
- //# sourceMappingURL=dialogs.vue_vue_type_script_setup_true_lang-DCVIoEeY.es.js.map
323
+ //# sourceMappingURL=dialogs.vue_vue_type_script_setup_true_lang-DRbTG0vh.es.js.map