@topvisor/ui 1.4.3-fixVTopTooltip.0 → 1.4.3-fixVTopTooltip.1

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.
@@ -1,9 +1,9 @@
1
- import { defineAsyncComponent as D } from "vue";
2
- import { C as s, E as C, l as p, m as R, e as H, h as I, n as M, f as N, _ as K, o as x, p as F, T as B, j as W, q as j, r as Y, g as G } from "./forms-BpbQYyEQ.es.js";
1
+ import { defineAsyncComponent as I } from "vue";
2
+ import { C as s, E as N, l as p, m as K, e as x, h as F, n as B, f as W, _ as j, o as Y, p as G, T as Q, j as q, q as z, r as X, g as J } from "./forms-BpbQYyEQ.es.js";
3
3
  import { TopPopupWorker as a } from "../popup/worker.js";
4
- import { T as q, _ as z } from "./dialogs.vue_vue_type_script_setup_true_lang-D8WYUfXI.es.js";
5
- import { isVisible as U } from "../utils/dom.js";
6
- class Q {
4
+ import { T as Z, _ as tt } from "./dialogs.vue_vue_type_script_setup_true_lang-D8WYUfXI.es.js";
5
+ import { isVisible as l } from "../utils/dom.js";
6
+ class et {
7
7
  static isInited = !1;
8
8
  /**
9
9
  * Добавить глобальные обработчики
@@ -15,7 +15,7 @@ class Q {
15
15
  !(e.target instanceof HTMLElement) || !e.target.dataset?.topPopupOpenByHover || e.target.click();
16
16
  }), document.addEventListener("scroll", () => {
17
17
  s.state.isMobile || s.state.isMobileUA || a.getAll().forEach((e) => a.close(e));
18
- }), C.addOnReize((e) => {
18
+ }), N.addOnReize((e) => {
19
19
  s.state.isMobile && e.topEvent.widthDiff && a.getAll().forEach((o) => a.close(o));
20
20
  }), document.addEventListener("click", this.onclick, { capture: !0 }));
21
21
  }
@@ -49,138 +49,157 @@ class Q {
49
49
  }
50
50
  }
51
51
  }
52
- let v;
53
- const X = {
52
+ let g;
53
+ const ot = {
54
54
  mounted: async (t, e) => {
55
- v || (v = (await import("../utils/dom.js")).storage);
55
+ g || (g = (await import("../utils/dom.js")).storage);
56
56
  const o = e.arg, n = e.value;
57
- v(t, o, n);
57
+ g(t, o, n);
58
58
  }
59
59
  };
60
- let h, u = [], g;
61
- const J = async () => {
60
+ let b, f = [], w;
61
+ const nt = async () => {
62
62
  const { isVisible: t } = await import("../utils/dom.js");
63
- if (u = u.filter(t), !u.length) return;
64
- u[0].focus(), u = [];
65
- }, O = async (t) => {
66
- h || (h = await import("../utils/lodash.js")), g || (g = h.debounce(J, 30)), u.push(t), g();
67
- }, Z = {
63
+ if (f = f.filter(t), !f.length) return;
64
+ f[0].focus(), f = [];
65
+ }, L = async (t) => {
66
+ b || (b = await import("../utils/lodash.js")), w || (w = b.debounce(nt, 30)), f.push(t), w();
67
+ }, it = {
68
68
  mounted: function(t, e) {
69
- t.__TOP_V_FOCUS_VALUE = e.value ?? !0, (e.value ?? !0) && O(t);
69
+ t.__TOP_V_FOCUS_VALUE = e.value ?? !0, (e.value ?? !0) && L(t);
70
70
  },
71
71
  updated: function(t, e) {
72
- e.modifiers.onupdate && t.__TOP_V_FOCUS_VALUE !== (e.value ?? !0) && (t.__TOP_V_FOCUS_VALUE = e.value ?? !0, (e.value ?? !0) && O(t));
72
+ e.modifiers.onupdate && t.__TOP_V_FOCUS_VALUE !== (e.value ?? !0) && (t.__TOP_V_FOCUS_VALUE = e.value ?? !0, (e.value ?? !0) && L(t));
73
73
  }
74
74
  };
75
- let f, T;
76
- const P = (t) => (typeof t == "boolean" || (t ? t = { ...t } : t = {}, t.behavior ??= "smooth", t.block ??= "nearest", t.inline ??= "nearest"), t);
77
- let m, w;
78
- const tt = async () => {
79
- if (!m) return;
80
- const t = await y(m);
81
- t.isVisible && m.scrollIntoView(t.scrollIntoViewOptions);
82
- }, $ = async (t) => {
83
- T || (T = await import("../utils/lodash.js")), w || (w = T.debounce(tt, 30)), m = t, w();
84
- }, y = async (t, e) => {
85
- f || (f = await import("../utils/dom.js"));
86
- let o = f.storage(t, "v-top-scrollIntoView");
75
+ let m, E;
76
+ const C = (t) => (typeof t == "boolean" || (t ? t = { ...t } : t = {}, t.behavior ??= "smooth", t.block ??= "nearest", t.inline ??= "nearest"), t);
77
+ let _, S;
78
+ const st = async () => {
79
+ if (!_) return;
80
+ const t = await O(_);
81
+ t.isVisible && _.scrollIntoView(t.scrollIntoViewOptions);
82
+ }, V = async (t) => {
83
+ E || (E = await import("../utils/lodash.js")), S || (S = E.debounce(st, 30)), _ = t, S();
84
+ }, O = async (t, e) => {
85
+ m || (m = await import("../utils/dom.js"));
86
+ let o = m.storage(t, "v-top-scrollIntoView");
87
87
  return o || (o = {
88
- isVisible: U(t),
89
- scrollIntoViewOptions: P(e)
90
- }, f.storage(t, "v-top-scrollIntoView", o)), o;
91
- }, et = {
88
+ isVisible: l(t),
89
+ scrollIntoViewOptions: C(e)
90
+ }, m.storage(t, "v-top-scrollIntoView", o)), o;
91
+ }, rt = {
92
92
  async mounted(t, e) {
93
- await y(t, e.value), e.modifiers.immediate && $(t);
93
+ await O(t, e.value), e.modifiers.immediate && V(t);
94
94
  },
95
95
  async updated(t, e) {
96
- const o = await y(t, e.value);
97
- o.scrollIntoViewOptions = P(e.value);
98
- const n = U(t);
99
- n && o.isVisible !== n && $(t), o.isVisible = n;
96
+ const o = await O(t, e.value);
97
+ o.scrollIntoViewOptions = C(e.value);
98
+ const n = l(t);
99
+ n && o.isVisible !== n && V(t), o.isVisible = n;
100
100
  }
101
101
  };
102
- let l;
103
- const ot = {
102
+ let u;
103
+ const ct = {
104
104
  async mounted(t) {
105
- l || (l = await import("../utils/scroll.js")), l.connectScrollShadow(t);
105
+ u || (u = await import("../utils/scroll.js")), u.connectScrollShadow(t);
106
106
  },
107
107
  async unmounted(t) {
108
- l || (l = await import("../utils/scroll.js")), l.unconnectScrollShadow(t);
108
+ u || (u = await import("../utils/scroll.js")), u.unconnectScrollShadow(t);
109
109
  }
110
- }, _ = /* @__PURE__ */ new Map();
111
- let L = !1;
112
- const nt = {
110
+ }, v = /* @__PURE__ */ new Map();
111
+ let U;
112
+ const T = /* @__PURE__ */ new Map();
113
+ let $ = !1;
114
+ const at = {
113
115
  ctrl: p() ? "⌘" : "Ctrl",
114
116
  alt: p() ? "⌥" : "Alt",
115
117
  shift: p() ? "⇧" : "Shift"
116
- }, it = (t) => {
118
+ }, lt = (t) => {
117
119
  let e = t;
118
120
  return t.includes("Key") && (e = t.replace("Key", "")), t.includes("Digit") && (e = t.replace("Digit", "")), t === "Escape" && (e = "Esc"), e;
119
- }, V = (t, e) => {
120
- const o = it(t);
121
+ }, R = (t, e) => {
122
+ const o = lt(t);
121
123
  if (!e) return o;
122
- const { ctrl: n, alt: i, shift: r } = nt, c = [];
124
+ const { ctrl: n, alt: i, shift: r } = at, c = [];
123
125
  return e.ctrl && c.push(n), e.alt && c.push(i), e.shift && c.push(r), c.push(o), c.join(p() ? "" : "+");
124
- }, st = (t, e, o) => {
125
- const n = V(e, o);
126
+ }, H = (t, e, o) => {
127
+ const n = R(e, o);
126
128
  if (t.__TOP_V_SHORTCUT_VALUE) {
127
129
  console.warn(`Element already has shortcut "${t.__TOP_V_SHORTCUT_VALUE}"`);
128
130
  return;
129
131
  }
130
- if (_.has(n)) {
132
+ if (T.has(n)) {
131
133
  console.warn(`Shortcut "${n}" is taken`);
132
134
  return;
133
135
  }
134
- _.set(n, t), t.title = t.title ? `${t.title} (${n})` : n, t.__TOP_V_SHORTCUT_VALUE = n;
135
- }, rt = (t) => {
136
+ T.set(n, t), t.title = t.title ? `${t.title} (${n})` : n, t.__TOP_V_SHORTCUT_VALUE = n;
137
+ }, M = (t) => {
136
138
  const e = t.__TOP_V_SHORTCUT_VALUE;
137
- e && _.delete(e);
138
- }, ct = () => {
139
- L || (L = !0, document.addEventListener("keydown", (t) => {
139
+ e && (T.delete(e), delete t.__TOP_V_SHORTCUT_VALUE, t.title === e && t.removeAttribute("title"), t.title.includes(` (${e})`) && (t.title = t.title.replace(` (${e})`, "")));
140
+ }, ut = () => {
141
+ for (const [t] of v)
142
+ !l(t) && t.__TOP_V_SHORTCUT_VALUE && M(t);
143
+ for (const [t, e] of v)
144
+ l(t) && !t.__TOP_V_SHORTCUT_VALUE && H(t, e.value, e.modifiers);
145
+ v.clear();
146
+ }, ft = async (t, e, o) => {
147
+ if (!U) {
148
+ const { debounce: n } = await import("../utils/lodash.js");
149
+ U = n(ut, 30);
150
+ }
151
+ v.set(t, { value: e, modifiers: o }), U();
152
+ }, P = () => {
153
+ $ || ($ = !0, document.addEventListener("keydown", (t) => {
140
154
  if (!(t.target instanceof HTMLElement) || ["INPUT", "TEXTAREA"].includes(t.target.tagName) || t.target.isContentEditable) return;
141
155
  const e = {
142
156
  ctrl: p() ? t.metaKey : t.ctrlKey,
143
157
  alt: t.altKey,
144
158
  shift: t.shiftKey
145
- }, o = V(t.code, e), n = _.get(o);
146
- n && !n.disabled && U(n) && (t.preventDefault(), n.click());
159
+ }, o = R(t.code, e), n = T.get(o);
160
+ n && (n.disabled || !l(n) || (t.preventDefault(), n.click()));
147
161
  }));
148
- }, at = {
162
+ }, pt = {
149
163
  mounted: function(t, e) {
150
164
  const { value: o, modifiers: n } = e;
151
- o && (ct(), st(t, o, n));
165
+ !o || !l(t) || (P(), H(t, o, n));
152
166
  },
153
- unmounted(t) {
154
- rt(t);
167
+ updated: function(t, e) {
168
+ if (!!t.__TOP_V_SHORTCUT_VALUE === l(t)) return;
169
+ const { value: o, modifiers: n } = e;
170
+ o && (P(), ft(t, o, n));
171
+ },
172
+ unmounted: function(t) {
173
+ M(t);
155
174
  }
156
175
  };
157
- let b;
158
- const lt = {
176
+ let y;
177
+ const mt = {
159
178
  mounted(t, e, o) {
160
179
  const n = e.value || "top-sticky";
161
- b = new IntersectionObserver((i) => {
180
+ y = new IntersectionObserver((i) => {
162
181
  let r = i[0].intersectionRatio < 1;
163
182
  r && e.modifiers.bottom && i[0].intersectionRect.y === 0 && (r = !1), t.classList.toggle(n, r);
164
183
  }, {
165
184
  threshold: [1]
166
- }), b.observe(t);
185
+ }), y.observe(t);
167
186
  },
168
187
  unmounted(t, e, o) {
169
- b?.disconnect();
188
+ y?.disconnect();
170
189
  }
171
190
  };
172
- let A = !1, S;
173
- const d = /* @__PURE__ */ new Map(), ut = (t, e) => {
191
+ let k = !1, A;
192
+ const h = /* @__PURE__ */ new Map(), dt = (t, e) => {
174
193
  const { distance: o, percent: n } = t.directiveSwipUpOptions, i = t.getBoundingClientRect().top, r = e * n / 100 / o, c = (e - i) / r;
175
194
  c <= o ? t.style.transform = `translateY(${o - c}px)` : t.style.transform = "translateY(0px)";
176
- }, pt = (t) => {
195
+ }, _t = (t) => {
177
196
  let e = window.innerHeight;
178
197
  window.addEventListener("scroll", () => {
179
- d.forEach((o) => ut(o, e));
180
- }, { passive: !0 }), S = new IntersectionObserver((o) => {
198
+ h.forEach((o) => dt(o, e));
199
+ }, { passive: !0 }), A = new IntersectionObserver((o) => {
181
200
  e = window.innerHeight, o.forEach((n) => {
182
201
  const i = n.target;
183
- if (n.intersectionRatio < 0.1 ? d.delete(i) : d.set(i, i), n.intersectionRatio === 0) {
202
+ if (n.intersectionRatio < 0.1 ? h.delete(i) : h.set(i, i), n.intersectionRatio === 0) {
184
203
  const { distance: r } = i.directiveSwipUpOptions;
185
204
  i.style.transform = `translateY(${r}px)`;
186
205
  }
@@ -188,57 +207,62 @@ const d = /* @__PURE__ */ new Map(), ut = (t, e) => {
188
207
  }, {
189
208
  threshold: 0.1
190
209
  });
191
- }, ft = {
210
+ }, vt = {
192
211
  mounted(t, e, o) {
193
212
  s.state.isMobileUA || (t.directiveSwipUpOptions = {
194
213
  distance: e.value?.distance ?? 100,
195
214
  // количество px на которые блок изначально смещен вниз,
196
215
  percent: e.value?.percent ?? 30
197
216
  // процент высоты экрана поднявшись на который блок закончит подплытие
198
- }, A || (pt(), A = !0), S.observe(t));
217
+ }, k || (_t(), k = !0), A.observe(t));
199
218
  },
200
219
  unmounted(t, e, o) {
201
- d.delete(t), S?.unobserve(t);
220
+ h.delete(t), A?.unobserve(t);
202
221
  }
203
- }, E = (t) => {
222
+ }, d = (t) => {
204
223
  if (!s.$?.ui?.tooltip) {
205
224
  console.info("Для работы v-top-tooltip требуется глобальная загрузка jQuery UI Tooltip");
206
225
  return;
207
226
  }
208
227
  return s.$(t);
209
- }, k = (t, e) => {
210
- const o = t.value ?? {};
211
- return o.content ??= e.getAttribute("title") ?? "", o.content = String(o.content).replace(/([^<>])\r?\n([^<>])/g, "$1<br>$2"), o.position ??= {
228
+ }, D = (t, e) => {
229
+ const o = {
230
+ ...t.value ?? {}
231
+ };
232
+ return o.content ??= e.getAttribute("ui-tooltip-title") ?? e.getAttribute("title") ?? "", o.content = String(o.content).replace(/([^<>])\r?\n([^<>])/g, "$1<br>$2"), o.position ??= {
212
233
  my: "bottom-18px",
213
234
  at: "top center",
214
235
  collision: "flipfit"
215
236
  }, o;
216
- }, mt = {
237
+ }, ht = {
217
238
  mounted(t, e) {
218
- E(t)?.tooltip(k(e, t));
239
+ d(t)?.tooltip(D(e, t));
219
240
  },
220
241
  updated(t, e) {
221
- const o = k(e, t), n = E(t);
222
- if (!n?.tooltip("instance")) {
223
- n?.tooltip(o);
242
+ const o = D(e, t), n = d(t)?.tooltip("instance");
243
+ if (!n) {
244
+ d(t)?.tooltip(o);
224
245
  return;
225
246
  }
226
- n.tooltip("option", o);
247
+ n.options = {
248
+ ...n.options,
249
+ ...o
250
+ };
227
251
  },
228
252
  unmounted(t) {
229
- E(t)?.tooltip("destroy");
253
+ d(t)?.tooltip("destroy");
230
254
  }
231
- }, dt = D(() => import("./notice-Ckc8r96E.es.js"));
255
+ }, Tt = I(() => import("./notice-Ckc8r96E.es.js"));
232
256
  window.vd = console.log;
233
- const wt = {
257
+ const Ut = {
234
258
  install: (t, e) => {
235
259
  t.config.globalProperties.$core = s, t.config.globalProperties.$vd = console.log;
236
260
  for (const o in e)
237
261
  s.state[o] = e[o];
238
- e.widthForMobile && (s.widthForMobile = e.widthForMobile), e.themeName && (s.themeName = e.themeName), s._setState(), e.topPopupOptions && (a.options = e.topPopupOptions), Q.init(), q.init(e.topDialogOptions), t.directive("top-data", X), t.directive("top-focus", Z), t.directive("top-scroll-into-view", et), t.directive("top-scroll-shadow", ot), t.directive("top-shortcut", at), t.directive("top-sticky", lt), t.directive("top-swim-up", ft), t.directive("top-tooltip", mt), t.component("TopAvatar", R), t.component("TopButton", H), t.component("TopCheckbox", I), t.component("TopControlLabel", M), t.component("TopHint", N), t.component("TopInput", K), t.component("TopInputDate", x), t.component("TopInputRange", F), t.component("TopLoadbar", B), t.component("TopRadio", W), t.component("TopSelect", j), t.component("TopSwitcher", Y), t.component("TopTextarea", G), t.component("TopNotice", dt), t.component("TopDialogs", z);
262
+ e.widthForMobile && (s.widthForMobile = e.widthForMobile), e.themeName && (s.themeName = e.themeName), s._setState(), e.topPopupOptions && (a.options = e.topPopupOptions), et.init(), Z.init(e.topDialogOptions), t.directive("top-data", ot), t.directive("top-focus", it), t.directive("top-scroll-into-view", rt), t.directive("top-scroll-shadow", ct), t.directive("top-shortcut", pt), t.directive("top-sticky", mt), t.directive("top-swim-up", vt), t.directive("top-tooltip", ht), t.component("TopAvatar", K), t.component("TopButton", x), t.component("TopCheckbox", F), t.component("TopControlLabel", B), t.component("TopHint", W), t.component("TopInput", j), t.component("TopInputDate", Y), t.component("TopInputRange", G), t.component("TopLoadbar", Q), t.component("TopRadio", q), t.component("TopSelect", z), t.component("TopSwitcher", X), t.component("TopTextarea", J), t.component("TopNotice", Tt), t.component("TopDialogs", tt);
239
263
  }
240
264
  };
241
265
  export {
242
- wt as c
266
+ Ut as c
243
267
  };
244
- //# sourceMappingURL=core-BM3jtOUr.es.js.map
268
+ //# sourceMappingURL=core-DoIr-EAf.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"core-DoIr-EAf.es.js","sources":["../../src/components/popup/lib/worker.globalEvents.ts","../../src/core/directives/data.ts","../../src/core/directives/focus.ts","../../src/core/directives/scrollIntoView.ts","../../src/core/directives/scrollShadow.ts","../../src/core/directives/shortcut.ts","../../src/core/directives/sticky.ts","../../src/core/directives/swimUp.ts","../../src/core/directives/tooltip.ts","../../src/core/plugins/core.ts"],"sourcesContent":["import Core from '@/core/core/core';\nimport Events from '@/core/core/events';\nimport Worker from '@/components/popup/lib/worker';\n\n/**\n * Глобальные события, для реализации Popup\n */\nclass WorkerEvents {\n\n\tprivate static isInited = false;\n\n\t/**\n\t * Добавить глобальные обработчики\n\t *\n\t * Добавляются на страницу один раз и навсегда\n\t */\n\tstatic init(): void {\n\t\tif (this.isInited) return;\n\n\t\tthis.isInited = true;\n\n\t\t// автоматическое открытие при наведении мыши, событие глобальное, так как инициализация popup отложена\n\t\tdocument.addEventListener('mouseover', (e) => {\n\t\t\tif (!(e.target instanceof HTMLElement) || !e.target.dataset?.topPopupOpenByHover) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\te.target.click();\n\t\t});\n\n\t\t// при скролле страницы закрыть Popup\n\t\tdocument.addEventListener('scroll', () => {\n\t\t\tif (Core.state.isMobile || Core.state.isMobileUA) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tWorker.getAll().forEach(elPopup => Worker.close(elPopup));\n\t\t});\n\n\t\tEvents.addOnReize(e => {\n\t\t\t// закрыть popup при повороте экрана телефона\n\t\t\t// если была отображена ПК версия, она будет закрыта\n\t\t\tif (Core.state.isMobile && e.topEvent.widthDiff) {\n\t\t\t\tWorker.getAll().forEach(elPopup => Worker.close(elPopup));\n\t\t\t}\n\t\t});\n\n\t\tdocument.addEventListener('click', this.onclick, { capture: true });\n\t}\n\n\t/**\n\t * Глобальный обработчик кликов\n\t *\n\t * Обрабатывает клики на открытие Popup\n\t */\n\tprivate static async onclick(e: Event): Promise<void> {\n\t\tif (!(e.target instanceof HTMLElement)) return;\n\n\t\tif (e.target.dataset.topPopupDisabled) {\n\t\t\treturn;\n\t\t}\n\n\t\tlet elOpener: HTMLElement | undefined;\n\n\t\tswitch (true) {\n\t\t\tcase !!e.target.dataset?.topPopup:\n\t\t\t\telOpener = e.target;\n\n\t\t\t\tbreak;\n\n\t\t\tcase !!e.target.parentElement?.dataset.topPopup:\n\t\t\t\telOpener = e.target.parentElement;\n\n\t\t\t\tbreak;\n\n\t\t\tcase !!e.target.parentElement?.parentElement?.dataset.topPopup:\n\t\t\t\telOpener = e.target.parentElement?.parentElement;\n\n\t\t\t\tbreak;\n\t\t}\n\n\t\tif (!elOpener) {\n\t\t\treturn;\n\t\t}\n\n\t\tif (elOpener.dataset.topPopupDisabled) {\n\t\t\treturn;\n\t\t}\n\n\t\t// меню уже открыто\n\t\tif (elOpener.dataset.topPopupOpened) {\n\t\t\tconst popup = Worker.getPopupFromOpener(elOpener);\n\t\t\tif (!popup?.openerIsInput) {\n\t\t\t\tpopup?.close();\n\t\t\t}\n\n\t\t\treturn;\n\t\t}\n\n\t\te.preventDefault();\n\n\t\tawait Worker.openByOpener(elOpener);\n\t}\n}\n\nexport default WorkerEvents;\n","import type { DirectiveBinding, ObjectDirective } from 'vue';\n\nlet storage: any;\n\n/**\n * Сохранить данные в элементе\n *\n * Для доступа к данным можно воспользоваться ui/utils/dom storage()\n */\nconst data = {\n\tmounted: async (el: HTMLElement, binding: DirectiveBinding) => {\n\t\tif (!storage) {\n\t\t\tconst UtilsDom = await import('@/core/utils/dom');\n\n\t\t\tstorage = UtilsDom.storage;\n\t\t}\n\n\t\tconst name = binding.arg;\n\t\tconst value = binding.value;\n\n\t\tstorage(el, name, value);\n\t},\n};\n\nexport default data;\n","import type { DirectiveBinding } from 'vue';\n\ntype Binding = DirectiveBinding<boolean, 'onupdate'>;\n\nlet UtilsLodash: typeof import('@/core/utils/lodash');\n\n/**\n * Список элементов, на которых бала запрошена фокусировка, для дедупликации фокусировок\n */\nlet elsActive: HTMLElement[] = [];\n\n/**\n * Функция скролла с дедупликацией\n */\nlet focusOnElActiveDebounce: Function;\n\n/**\n * Выполнить фокусировку на активном элементе\n *\n * Если фокусирока запрошена на несколько элементов, будет выбран первый элемент\n */\nconst focusOnElActive = async () => {\n\tconst { isVisible } = await import('@/core/utils/dom');\n\telsActive = elsActive.filter(isVisible)\n\n\tif (!elsActive.length) return;\n\n\tconst el = elsActive[0];\n\n\tel.focus();\n\n\t// // UX: Если выбрано несколько чекбоксов или радио после выбора фокусировка будет снята, чтобы не делать выбор за пользователя\n\t// if (elsActive.length && el.nodeName === 'INPUT') {\n\t// \tconst type = (el as HTMLInputElement).type;\n\t// \tif (type === 'checkbox' || type === 'radio') el.blur();\n\t// }\n\n\telsActive = [];\n};\n\n/**\n * Выполнить дедуплицированную фокусировку на элементе\n */\nconst focusOnElDebounce = async (el: HTMLElement) => {\n\tif (!UtilsLodash) UtilsLodash = await import('@/core/utils/lodash');\n\tif (!focusOnElActiveDebounce) focusOnElActiveDebounce = UtilsLodash.debounce(focusOnElActive, 30);\n\n\telsActive.push(el);\n\n\tfocusOnElActiveDebounce();\n};\n\n/**\n * Фокусировка на элементе сразу после его отображения\n */\nconst focus = {\n\tmounted: function (el: HTMLElement, binding: Binding) {\n\t\tel['__TOP_V_FOCUS_VALUE'] = binding.value ?? true;\n\n\t\tif (binding.value ?? true) focusOnElDebounce(el);\n\t},\n\n\tupdated: function (el: HTMLElement, binding: Binding) {\n\t\tif (!binding.modifiers.onupdate) return;\n\n\t\tif (el['__TOP_V_FOCUS_VALUE'] === (binding.value ?? true)) return;\n\t\tel['__TOP_V_FOCUS_VALUE'] = binding.value ?? true;\n\n\t\tif (binding.value ?? true) focusOnElDebounce(el);\n\t},\n};\n\nexport default focus;\n","import type { DirectiveBinding, ObjectDirective } from 'vue';\nimport { isVisible } from '@/core/utils/dom';\n\ntype Binding = DirectiveBinding<ScrollIntoViewOptions | boolean | undefined, 'immediate'>;\n\ntype Storage = {\n\t/**\n\t * Сохраненное состояние видимости\n\t */\n\tisVisible: boolean,\n\n\t/**\n\t * Текущие настройки скролла\n\t */\n\tscrollIntoViewOptions: ScrollIntoViewOptions | boolean\n};\n\nlet UtilsDom: typeof import('@/core/utils/dom');\nlet UtilsLodash: typeof import('@/core/utils/lodash');\n\n/**\n * Сгенерировать настройки для скролла\n *\n * @see https://developer.mozilla.org/ru/docs/Web/API/Element/scrollIntoView\n */\nconst genScrollIntoViewOptions = (scrollIntoViewOptions?: ScrollIntoViewOptions | boolean) => {\n\tif (typeof scrollIntoViewOptions === 'boolean') return scrollIntoViewOptions;\n\n\tif (!scrollIntoViewOptions) {\n\t\tscrollIntoViewOptions = {};\n\t} else {\n\t\tscrollIntoViewOptions = { ...scrollIntoViewOptions };\n\t}\n\n\tscrollIntoViewOptions.behavior ??= 'smooth';\n\tscrollIntoViewOptions.block ??= 'nearest';\n\tscrollIntoViewOptions.inline ??= 'nearest';\n\n\treturn scrollIntoViewOptions;\n};\n\n/**\n * Активный элемент, для дедупликации скроллов\n *\n * Только один элемент на странице может считаться активным\n */\nlet elActive: HTMLElement | undefined;\n\n/**\n * Функция скролла с дедупликацией\n */\nlet scrollToElActiveDebounce: Function;\n\n/**\n * Выполнить скролл к текущему активному элементу\n */\nconst scrollToElActive = async () => {\n\tif (!elActive) return;\n\n\tconst storage = await useStorage(elActive);\n\tif (!storage.isVisible) return;\n\n\telActive.scrollIntoView(storage.scrollIntoViewOptions);\n};\n\n/**\n * Выполнить дедуплицированный скролл к элементу\n *\n * Будет выполнен скролл к самому последнему элементу, вызвавшему срабатывание директивы\n */\nconst scrollToElDebounce = async (el: HTMLElement) => {\n\tif (!UtilsLodash) UtilsLodash = await import('@/core/utils/lodash');\n\tif (!scrollToElActiveDebounce) scrollToElActiveDebounce = UtilsLodash.debounce(scrollToElActive, 30);\n\n\telActive = el;\n\n\tscrollToElActiveDebounce();\n};\n\n/**\n * Данные, связанные с элементом и директивой\n */\nconst useStorage = async (el: HTMLElement, scrollIntoViewOptions?: ScrollIntoViewOptions | boolean) => {\n\tif (!UtilsDom) UtilsDom = await import('@/core/utils/dom');\n\n\tlet storage: Storage | undefined = UtilsDom.storage(el, 'v-top-scrollIntoView');\n\n\t// инициализация\n\tif (!storage) {\n\t\tstorage = {\n\t\t\tisVisible: isVisible(el),\n\t\t\tscrollIntoViewOptions: genScrollIntoViewOptions(scrollIntoViewOptions),\n\t\t};\n\n\t\tUtilsDom.storage(el, 'v-top-scrollIntoView', storage);\n\t}\n\n\treturn storage;\n};\n\nconst scrollIntoView: ObjectDirective = {\n\tasync mounted(el: HTMLElement, binding: Binding) {\n\t\tawait useStorage(el, binding.value);\n\n\t\tif (binding.modifiers.immediate) {\n\t\t\tscrollToElDebounce(el);\n\t\t}\n\t},\n\n\tasync updated(el: HTMLElement, binding: Binding) {\n\t\tconst storage = await useStorage(el, binding.value);\n\t\tstorage.scrollIntoViewOptions = genScrollIntoViewOptions(binding.value);\n\n\t\tconst isVisibleNew = isVisible(el);\n\t\tif (isVisibleNew && storage.isVisible !== isVisibleNew) {\n\t\t\tscrollToElDebounce(el);\n\t\t}\n\n\t\tstorage.isVisible = isVisibleNew;\n\t},\n};\n\nexport default scrollIntoView;\n","let UtilsScroll: typeof import('@/core/utils/scroll');\n\n/**\n * Добавить отображение тени при появлении скролла у элемента\n *\n * Будут добавлены события для усатновки модификаторов тени в зависимости от скролла элемента\n *\n * Модификаторы:\n * - top-scrollShadow\n * - top-scrollShadow-started\n * - top-scrollShadow-finished\n */\nconst connectScrollShadow = {\n\tasync mounted(el) {\n\t\tif (!UtilsScroll) UtilsScroll = await import('@/core/utils/scroll');\n\n\t\tUtilsScroll.connectScrollShadow(el);\n\t},\n\n\tasync unmounted(el) {\n\t\tif (!UtilsScroll) UtilsScroll = await import('@/core/utils/scroll');\n\n\t\tUtilsScroll.unconnectScrollShadow(el);\n\t},\n};\n\nexport default connectScrollShadow;\n","import { isVisible } from '@/core/utils/dom';\nimport { isMacOS } from '@/core/utils/device';\nimport type { DirectiveBinding } from 'vue';\nimport type debounce from 'lodash-es/debounce.js';\n\nexport type ShortcutValue = string;\n\n/**\n * Допустимые модификаторы\n */\ntype AllowedModifiers = 'ctrl' | 'shift' | 'alt';\ntype Binding = DirectiveBinding<ShortcutValue, AllowedModifiers>;\n\n/**\n * Очередь элементов, ожидающих синхронизации горячих клавиш.\n * Накапливает изменения для их пакетной обработки\n */\nconst elsShortcutQueue = new Map<HTMLElement, {\n\tvalue: ShortcutValue;\n\tmodifiers: Binding['modifiers'];\n}>;\n\n/**\n * Отложенная версия функции syncShortcuts.\n * Обеспечивает пакетную обработку изменений горячих клавиш\n */\nlet syncShortcutsDebounce: ReturnType<typeof debounce> | undefined;\n\n/**\n * Список горячих клавиш и html элементов, на которые они назначены\n */\nconst elementByShortcut = new Map<string, HTMLElement>();\n\n/**\n * Добавлен ли обработчик события\n */\nlet isListenerAttached = false;\n\n/**\n * Отображение названий клавиш-модификаторов в зависимости от ОС\n *\n * В наших горячих клавишах Ctrl всегда соответствует Cmd в MacOS\n */\nconst modifierKeys = {\n\tctrl: isMacOS() ? '⌘' : 'Ctrl',\n\talt: isMacOS() ? '⌥' : 'Alt',\n\tshift: isMacOS() ? '⇧' : 'Shift',\n};\n\n/**\n * Получить название клавиши из event.code\n */\nconst getKeyLabel = (code: string) => {\n\tlet keyLabel = code;\n\n\tif (code.includes('Key')) keyLabel = code.replace('Key', '');\n\tif (code.includes('Digit')) keyLabel = code.replace('Digit', '');\n\tif (code === 'Escape') keyLabel = 'Esc';\n\n\treturn keyLabel;\n};\n\n/**\n * Сгенерировать строковое представление сочетания клавиш с модификаторами\n *\n * Приводим к виду \"Ctrl+Shift+A\" или \"⌘⇧A\" для MacOS\n */\nconst genShortcutString = (code: string, modifiers: Binding['modifiers']) => {\n\tconst keyLabel = getKeyLabel(code);\n\tif (!modifiers) return keyLabel;\n\n\tconst { ctrl, alt, shift } = modifierKeys;\n\tconst parts: string[] = [];\n\n\tif (modifiers.ctrl) parts.push(ctrl);\n\tif (modifiers.alt) parts.push(alt);\n\tif (modifiers.shift) parts.push(shift);\n\n\t// Основная клавиша\n\tparts.push(keyLabel);\n\n\treturn parts.join(isMacOS() ? '' : '+');\n};\n\nconst registerShortcut = (el: HTMLElement, value: ShortcutValue, modifiers: Binding['modifiers']) => {\n\tconst shortcut = genShortcutString(value, modifiers);\n\n\tif (el['__TOP_V_SHORTCUT_VALUE']) {\n\t\tconsole.warn(`Element already has shortcut \"${el['__TOP_V_SHORTCUT_VALUE']}\"`);\n\n\t\treturn;\n\t}\n\n\tif (elementByShortcut.has(shortcut)) {\n\t\tconsole.warn(`Shortcut \"${shortcut}\" is taken`);\n\n\t\treturn;\n\t}\n\n\telementByShortcut.set(shortcut, el);\n\tel.title = el.title ? `${el.title} (${shortcut})` : shortcut;\n\tel['__TOP_V_SHORTCUT_VALUE'] = shortcut;\n};\n\nconst unregisterShortcut = (el: HTMLElement) => {\n\tconst shortcut: string | undefined = el['__TOP_V_SHORTCUT_VALUE'];\n\tif (!shortcut) return;\n\n\telementByShortcut.delete(shortcut);\n\tdelete el['__TOP_V_SHORTCUT_VALUE'];\n\n\tif (el.title === shortcut) el.removeAttribute('title');\n\tif (el.title.includes(` (${shortcut})`)) {\n\t\tel.title = el.title.replace(` (${shortcut})`, '');\n\t}\n};\n\n/**\n * Обновить регистрацию горячих клавиш для элементов в очереди\n *\n * Отменяет регистрацию для невидимых элементов и регистрирует для видимых.\n * Очищает очередь после обработки\n */\nconst syncShortcuts = () => {\n\tfor (const [el] of elsShortcutQueue) {\n\t\tif (!isVisible(el) && el['__TOP_V_SHORTCUT_VALUE']) {\n\t\t\tunregisterShortcut(el);\n\t\t}\n\t}\n\n\tfor (const [el, data] of elsShortcutQueue) {\n\t\tif (isVisible(el) && !el['__TOP_V_SHORTCUT_VALUE']) {\n\t\t\tregisterShortcut(el, data.value, data.modifiers);\n\t\t}\n\t}\n\n\telsShortcutQueue.clear();\n};\n\n/**\n * Выполняет отложенную регистрацию горячих клавиш на элементе с дедупликацией\n */\nconst registerShortcutDebounce = async (el: HTMLElement, value: ShortcutValue, modifiers: Binding['modifiers']) => {\n\tif (!syncShortcutsDebounce) {\n\t\tconst { debounce } = await import('@/core/utils/lodash');\n\t\tsyncShortcutsDebounce = debounce(syncShortcuts, 30);\n\t}\n\n\telsShortcutQueue.set(el, { value, modifiers });\n\n\tsyncShortcutsDebounce();\n};\n\nconst attachGlobalListener = () => {\n\tif (isListenerAttached) return;\n\tisListenerAttached = true;\n\n\tdocument.addEventListener('keydown', e => {\n\t\tif (!(e.target instanceof HTMLElement)) return;\n\t\tif (['INPUT', 'TEXTAREA'].includes(e.target.tagName) || e.target.isContentEditable) return;\n\n\t\tconst modifiers = {\n\t\t\tctrl: isMacOS() ? e.metaKey : e.ctrlKey,\n\t\t\talt: e.altKey,\n\t\t\tshift: e.shiftKey,\n\t\t};\n\n\t\tconst shortcut = genShortcutString(e.code, modifiers);\n\t\tconst element = elementByShortcut.get(shortcut);\n\n\t\tif (!element) return;\n\t\tif ((element as any).disabled || !isVisible(element)) return;\n\n\t\te.preventDefault();\n\t\telement.click();\n\t});\n};\n\nconst shortcut = {\n\tmounted: function (el: HTMLElement, binding: Binding) {\n\t\tconst { value, modifiers } = binding;\n\t\tif (!value || !isVisible(el)) return;\n\n\t\tattachGlobalListener();\n\t\tregisterShortcut(el, value, modifiers);\n\t},\n\n\tupdated: function (el: HTMLElement, binding: Binding) {\n\t\tif (!!el['__TOP_V_SHORTCUT_VALUE'] === isVisible(el)) return;\n\n\t\tconst { value, modifiers } = binding;\n\t\tif (!value) return;\n\n\t\tattachGlobalListener();\n\t\tvoid registerShortcutDebounce(el, value, modifiers);\n\t},\n\n\tunmounted: function (el: HTMLElement) {\n\t\tunregisterShortcut(el);\n\t},\n};\n\nexport default shortcut;\n","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\n\nlet appStickyObserver: IntersectionObserver;\n\n/**\n * Добавление sticky\n * К элементу добляется класс переданный как значение диррективы либо **'top-sticky'** по умолчанию\n */\nconst sticky = {\n\tmounted(el: HTMLElement, binding: DirectiveBinding, _vnode: VNode) {\n\t\tconst className = binding.value || 'top-sticky';\n\n\t\tappStickyObserver = new IntersectionObserver(entries => {\n\t\t\tlet condition = entries[0].intersectionRatio < 1;\n\t\t\tif (condition) {\n\t\t\t\tif (binding.modifiers.bottom && entries[0].intersectionRect.y === 0) condition = false;\n\t\t\t}\n\n\t\t\tel.classList.toggle(className, condition);\n\t\t}, {\n\t\t\tthreshold: [1],\n\t\t});\n\n\t\tappStickyObserver.observe(el);\n\t},\n\n\tunmounted(_el: HTMLElement, _binding: DirectiveBinding, _vnode: VNode) {\n\t\tappStickyObserver?.disconnect();\n\t},\n};\n\nexport default sticky;\n","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\nimport Core from '@/core/core/core';\n\ninterface HTMLElementWithSwimUpOptions extends HTMLElement {\n\tdirectiveSwipUpOptions: {\n\t\tdistance: number,\n\t\tpercent: number,\n\t};\n}\n\nlet appSwimUpInited = false;\nlet appSwimUpObserver: IntersectionObserver;\nconst appSwimUpEls = new Map();\n\n/**\n * Отодвинуть блок в зависимости от скролла старинцы\n * @param el\n * @param windowHeight\n */\nconst swimUpElTransform = (el: HTMLElementWithSwimUpOptions, windowHeight: number): void => {\n\tconst { distance, percent } = el.directiveSwipUpOptions;\n\n\tconst elTop = el.getBoundingClientRect().top;\n\n\t// во столько раз triggerHeight должен быть меньше, чтобы закончить подплытие к нужной высоте экрана\n\tconst triggerHeightReducer = windowHeight * percent / 100 / distance;\n\tconst triggerHeight = (windowHeight - elTop) / triggerHeightReducer;\n\n\tif (triggerHeight <= distance) {\n\t\tel.style.transform = `translateY(${distance - triggerHeight}px)`;\n\t} else {\n\t\tel.style.transform = 'translateY(0px)';\n\t}\n};\n\nconst swimUpInit = (_el: HTMLElementWithSwimUpOptions): void => {\n\tlet windowHeight = window.innerHeight;\n\n\twindow.addEventListener('scroll', () => {\n\t\tappSwimUpEls.forEach((el) => swimUpElTransform(el, windowHeight));\n\t}, { passive: true });\n\n\t// проверка того, что элемент в зоне видимости\n\tappSwimUpObserver = new IntersectionObserver(entries => {\n\t\twindowHeight = window.innerHeight;\n\n\t\tentries.forEach((entry) => {\n\t\t\tconst el = entry.target as HTMLElementWithSwimUpOptions;\n\n\t\t\tif (entry.intersectionRatio < 0.1) {\n\t\t\t\t// элемент за областью видимости\n\t\t\t\tappSwimUpEls.delete(el);\n\t\t\t} else {\n\t\t\t\t// элемент на экране\n\t\t\t\tappSwimUpEls.set(el, el);\n\t\t\t}\n\n\t\t\tif (entry.intersectionRatio === 0) {\n\t\t\t\tconst { distance } = el.directiveSwipUpOptions;\n\t\t\t\tel.style.transform = `translateY(${distance}px)`;\n\t\t\t}\n\t\t});\n\t}, {\n\t\tthreshold: 0.1,\n\t});\n};\n\n/**\n * Добавление анимации подплытия вверх для блока\n */\nconst swimUp = {\n\tmounted(el: HTMLElementWithSwimUpOptions, binding: DirectiveBinding, _vnode: VNode): void {\n\t\tif (Core.state.isMobileUA) return;\n\n\t\tel.directiveSwipUpOptions = {\n\t\t\tdistance: binding.value?.distance ?? 100, // количество px на которые блок изначально смещен вниз,\n\t\t\tpercent: binding.value?.percent ?? 30, // процент высоты экрана поднявшись на который блок закончит подплытие\n\t\t};\n\n\t\tif (!appSwimUpInited) {\n\t\t\tswimUpInit(el);\n\n\t\t\tappSwimUpInited = true;\n\t\t}\n\n\t\tappSwimUpObserver.observe(el);\n\t},\n\n\tunmounted(el: HTMLElementWithSwimUpOptions, _binding: DirectiveBinding, _vnode: VNode) {\n\t\tappSwimUpEls.delete(el);\n\t\tappSwimUpObserver?.unobserve(el);\n\t},\n};\n\nexport default swimUp;\n","import type { DirectiveBinding, ObjectDirective } from 'vue';\nimport Core from '@/core/core/core';\n\nconst $ = (el: HTMLElement) => {\n\tif (!Core.$?.ui?.tooltip) {\n\t\tconsole.info('Для работы v-top-tooltip требуется глобальная загрузка jQuery UI Tooltip');\n\n\t\treturn;\n\t}\n\n\treturn Core.$(el);\n};\n\nconst tvTooltipGenOptions = (binding: DirectiveBinding, el: HTMLElement): JQueryUI.TooltipOptions => {\n\tconst options = {\n\t\t...(binding.value ?? {}),\n\t} as JQueryUI.TooltipOptions;\n\n\toptions.content ??= el.getAttribute('ui-tooltip-title') ?? el.getAttribute('title') ?? '';\n\toptions.content = String(options.content).replace(/([^<>])\\r?\\n([^<>])/g, '$1<br>$2');\n\n\toptions.position ??= {\n\t\tmy: 'bottom-18px',\n\t\tat: 'top center',\n\t\tcollision: 'flipfit',\n\t};\n\n\treturn options;\n};\n\n/**\n * Добавление всплывающей подсказки к элементу.\n */\nconst tooltip: ObjectDirective<HTMLElement> = {\n\tmounted(el, binding) {\n\t\t$(el)?.tooltip(tvTooltipGenOptions(binding, el));\n\t},\n\n\tupdated(el, binding) {\n\t\t/**\n\t\t * В результате обновления может быть открыто несколько тултипов поэтому изменить опции, без перерисовки тултипа\n\t\t */\n\t\tconst options = tvTooltipGenOptions(binding, el);\n\t\tconst instance = $(el)?.tooltip('instance') as { options: JQueryUI.TooltipOptions } | undefined;\n\n\t\tif (!instance) {\n\t\t\t$(el)?.tooltip(options);\n\t\t\treturn;\n\t\t}\n\n\t\tinstance.options = {\n\t\t\t...instance.options,\n\t\t\t...options,\n\t\t};\n\t},\n\n\tunmounted(el) {\n\t\t$(el)?.tooltip('destroy');\n\t},\n};\n\nexport default tooltip;\n","import { defineAsyncComponent, type Plugin } from 'vue';\nimport type { PartialBy } from '@/components/types';\n\nimport Core from '@/core/core/core';\nimport coreDefaultOptions from '@/core/core/options';\n\nimport * as Forms from '../../components/forms/forms';\n\nconst TopNotice = defineAsyncComponent(() => import('@/components/core/notice/notice.vue'));\n\nimport type { Options as TopPopupOptions } from '@/components/popup/lib/worker';\nimport TopPopupWorker from '@/components/popup/lib/worker';\nimport TopPopupWorkerGlobalEvents from '@/components/popup/lib/worker.globalEvents';\n\nimport TopDialogs from '@/components/dialog/dialog/dialogs/dialogs.vue';\nimport { TopDialogWorker } from '@/components/dialog/lib/worker';\nimport type { TopDialogOptions } from '@/components/dialog/lib/types';\n\nimport directiveData from '@/core/directives/data';\nimport directiveFocus from '@/core/directives/focus';\nimport directiveScrollIntoView from '@/core/directives/scrollIntoView';\nimport directiveScrollShadow from '@/core/directives/scrollShadow';\nimport directiveShortcut from '@/core/directives/shortcut';\nimport directiveSticky from '@/core/directives/sticky';\nimport directiveSwimUp from '@/core/directives/swimUp';\nimport directiveTooltip from '@/core/directives/tooltip';\n\ndeclare global {\n\tconst vd: typeof console.log;\n}\n\nwindow['vd'] = console.log;\n\ndeclare module '@vue/runtime-core' {\n\tinterface ComponentCustomProperties {\n\t\t/**\n\t\t * Статический класс с текущим состоянимем UI\n\t\t */\n\t\t$core: typeof Core;\n\n\t\t$vd: typeof console.log;\n\t}\n\n\t/**\n\t * Обязательные компоненты UI\n\t *\n\t * Они подключаются через плагин и доступны без явного указания импорта\n\t */\n\texport interface GlobalComponents {\n\t\tTopAvatar: typeof Forms.TopAvatar;\n\t\tTopButton: typeof Forms.TopButton;\n\t\tTopCheckbox: typeof Forms.TopCheckbox;\n\t\tTopControlLabel: typeof Forms.TopControlLabel;\n\t\tTopHint: typeof Forms.TopHint;\n\t\tTopInput: typeof Forms.TopInput;\n\t\tTopInputDate: typeof Forms.TopInputDate;\n\t\tTopInputRange: typeof Forms.TopInputRange;\n\t\tTopRadio: typeof Forms.TopRadio;\n\t\tTopSwitcher: typeof Forms.TopSwitcher;\n\t\tTopTextarea: typeof Forms.TopTextarea;\n\t\tTopSelect: typeof Forms.TopSelect;\n\t\tTopLoadbar: typeof Forms.TopLoadbar;\n\n\t\tTopNotice: typeof TopNotice;\n\t\tTopDialogs: typeof TopDialogs;\n\t}\n}\n\ntype CoreOptions = PartialBy<typeof coreDefaultOptions, 'timezoneOffset' | 'documentClassModificators'>;\n\ntype Options = CoreOptions & {\n\ttopPopupOptions?: TopPopupOptions\n\ttopDialogOptions?: TopDialogOptions\n};\n\n/**\n * Плагин для интеграции UI во Vue приложение\n *\n * - В глобальную область видимости шаблонов будет добавлен объект $core\n * - Будут зарегистрирвоаны директивы UI: https://ui.topvisor.com/?path=/docs/core-directives-focus--docs\n * - Будут подключены базовые компоненты UI/Forms: https://ui.topvisor.com/?path=/docs/components-forms-readme--docs\n */\nexport default {\n\n\tinstall: (app, options: Options) => {\n\t\tapp.config.globalProperties.$core = Core;\n\t\tapp.config.globalProperties.$vd = console.log;\n\n\t\t// начальные настройки UI\n\t\tfor (const name in options) {\n\t\t\tCore.state[name] = options[name];\n\t\t}\n\n\t\tif (options.widthForMobile) Core.widthForMobile = options.widthForMobile;\n\t\tif (options.themeName) Core.themeName = options.themeName;\n\n\t\tCore._setState();\n\n\t\tif (options.topPopupOptions) TopPopupWorker.options = options.topPopupOptions;\n\t\tTopPopupWorkerGlobalEvents.init();\n\n\t\tTopDialogWorker.init(options.topDialogOptions);\n\n\t\t// определение директив\n\t\tapp.directive('top-data', directiveData);\n\t\tapp.directive('top-focus', directiveFocus);\n\t\tapp.directive('top-scroll-into-view', directiveScrollIntoView);\n\t\tapp.directive('top-scroll-shadow', directiveScrollShadow);\n\t\tapp.directive('top-shortcut', directiveShortcut);\n\t\tapp.directive('top-sticky', directiveSticky);\n\t\tapp.directive('top-swim-up', directiveSwimUp);\n\t\tapp.directive('top-tooltip', directiveTooltip);\n\n\t\t// определение базовых компонентов\n\t\tapp.component('TopAvatar', Forms.TopAvatar);\n\t\tapp.component('TopButton', Forms.TopButton);\n\t\tapp.component('TopCheckbox', Forms.TopCheckbox);\n\t\tapp.component('TopControlLabel', Forms.TopControlLabel);\n\t\tapp.component('TopHint', Forms.TopHint);\n\t\tapp.component('TopInput', Forms.TopInput);\n\t\tapp.component('TopInputDate', Forms.TopInputDate);\n\t\tapp.component('TopInputRange', Forms.TopInputRange);\n\t\tapp.component('TopLoadbar', Forms.TopLoadbar);\n\t\tapp.component('TopRadio', Forms.TopRadio);\n\t\tapp.component('TopSelect', Forms.TopSelect);\n\t\tapp.component('TopSwitcher', Forms.TopSwitcher);\n\t\tapp.component('TopTextarea', Forms.TopTextarea);\n\n\t\tapp.component('TopNotice', TopNotice);\n\t\tapp.component('TopDialogs', TopDialogs);\n\t},\n\n} satisfies Plugin<Options>;\n"],"names":["WorkerEvents","Core","Worker","elPopup","Events","elOpener","popup","storage","data","el","binding","name","value","UtilsLodash","elsActive","focusOnElActiveDebounce","focusOnElActive","isVisible","focusOnElDebounce","focus","UtilsDom","genScrollIntoViewOptions","scrollIntoViewOptions","elActive","scrollToElActiveDebounce","scrollToElActive","useStorage","scrollToElDebounce","scrollIntoView","isVisibleNew","UtilsScroll","connectScrollShadow","elsShortcutQueue","syncShortcutsDebounce","elementByShortcut","isListenerAttached","modifierKeys","isMacOS","getKeyLabel","code","keyLabel","genShortcutString","modifiers","ctrl","alt","shift","parts","registerShortcut","shortcut","unregisterShortcut","syncShortcuts","registerShortcutDebounce","debounce","attachGlobalListener","e","element","appStickyObserver","sticky","_vnode","className","entries","condition","_el","_binding","appSwimUpInited","appSwimUpObserver","appSwimUpEls","swimUpElTransform","windowHeight","distance","percent","elTop","triggerHeightReducer","triggerHeight","swimUpInit","entry","swimUp","$","tvTooltipGenOptions","options","tooltip","instance","TopNotice","defineAsyncComponent","core","app","TopPopupWorker","TopPopupWorkerGlobalEvents","TopDialogWorker","directiveData","directiveFocus","directiveScrollIntoView","directiveScrollShadow","directiveShortcut","directiveSticky","directiveSwimUp","directiveTooltip","Forms.TopAvatar","Forms.TopButton","Forms.TopCheckbox","Forms.TopControlLabel","Forms.TopHint","Forms.TopInput","Forms.TopInputDate","Forms.TopInputRange","Forms.TopLoadbar","Forms.TopRadio","Forms.TopSelect","Forms.TopSwitcher","Forms.TopTextarea","TopDialogs"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ define(["require","exports","vue","./forms-DDNzqU6o.amd","../popup/worker.amd","./dialogs.vue_vue_type_script_setup_true_lang-BBix_8WK.amd","../utils/dom.amd"],(function(a,W,g,i,l,A,u){"use strict";if(typeof g>"u")var g=window.Vue;class K{static isInited=!1;static init(){this.isInited||(this.isInited=!0,document.addEventListener("mouseover",e=>{!(e.target instanceof HTMLElement)||!e.target.dataset?.topPopupOpenByHover||e.target.click()}),document.addEventListener("scroll",()=>{i.Core.state.isMobile||i.Core.state.isMobileUA||l.TopPopupWorker.getAll().forEach(e=>l.TopPopupWorker.close(e))}),i.Events.addOnReize(e=>{i.Core.state.isMobile&&e.topEvent.widthDiff&&l.TopPopupWorker.getAll().forEach(o=>l.TopPopupWorker.close(o))}),document.addEventListener("click",this.onclick,{capture:!0}))}static async onclick(e){if(!(e.target instanceof HTMLElement)||e.target.dataset.topPopupDisabled)return;let o;switch(!0){case!!e.target.dataset?.topPopup:o=e.target;break;case!!e.target.parentElement?.dataset.topPopup:o=e.target.parentElement;break;case!!e.target.parentElement?.parentElement?.dataset.topPopup:o=e.target.parentElement?.parentElement;break}if(o&&!o.dataset.topPopupDisabled){if(o.dataset.topPopupOpened){const n=l.TopPopupWorker.getPopupFromOpener(o);n?.openerIsInput||n?.close();return}e.preventDefault(),await l.TopPopupWorker.openByOpener(o)}}}let b;const x={mounted:async(t,e)=>{b||(b=(await new Promise((c,r)=>a(["../utils/dom.amd"],c,r))).storage);const o=e.arg,n=e.value;b(t,o,n)}};let w,d=[],S;const F=async()=>{const{isVisible:t}=await new Promise((o,n)=>a(["../utils/dom.amd"],o,n));if(d=d.filter(t),!d.length)return;d[0].focus(),d=[]},L=async t=>{w||(w=await new Promise((e,o)=>a(["../utils/lodash.amd"],e,o))),S||(S=w.debounce(F,30)),d.push(t),S()},B={mounted:function(t,e){t.__TOP_V_FOCUS_VALUE=e.value??!0,(e.value??!0)&&L(t)},updated:function(t,e){e.modifiers.onupdate&&t.__TOP_V_FOCUS_VALUE!==(e.value??!0)&&(t.__TOP_V_FOCUS_VALUE=e.value??!0,(e.value??!0)&&L(t))}};let f,E;const C=t=>(typeof t=="boolean"||(t?t={...t}:t={},t.behavior??="smooth",t.block??="nearest",t.inline??="nearest"),t);let m,O;const Y=async()=>{if(!m)return;const t=await y(m);t.isVisible&&m.scrollIntoView(t.scrollIntoViewOptions)},$=async t=>{E||(E=await new Promise((e,o)=>a(["../utils/lodash.amd"],e,o))),O||(O=E.debounce(Y,30)),m=t,O()},y=async(t,e)=>{f||(f=await new Promise((n,s)=>a(["../utils/dom.amd"],n,s)));let o=f.storage(t,"v-top-scrollIntoView");return o||(o={isVisible:u.isVisible(t),scrollIntoViewOptions:C(e)},f.storage(t,"v-top-scrollIntoView",o)),o},j={async mounted(t,e){await y(t,e.value),e.modifiers.immediate&&$(t)},async updated(t,e){const o=await y(t,e.value);o.scrollIntoViewOptions=C(e.value);const n=u.isVisible(t);n&&o.isVisible!==n&&$(t),o.isVisible=n}};let p;const G={async mounted(t){p||(p=await new Promise((e,o)=>a(["../utils/scroll.amd"],e,o))),p.connectScrollShadow(t)},async unmounted(t){p||(p=await new Promise((e,o)=>a(["../utils/scroll.amd"],e,o))),p.unconnectScrollShadow(t)}},_=new Map;let U;const v=new Map;let k=!1;const Q={ctrl:i.isMacOS()?"⌘":"Ctrl",alt:i.isMacOS()?"⌥":"Alt",shift:i.isMacOS()?"⇧":"Shift"},z=t=>{let e=t;return t.includes("Key")&&(e=t.replace("Key","")),t.includes("Digit")&&(e=t.replace("Digit","")),t==="Escape"&&(e="Esc"),e},D=(t,e)=>{const o=z(t);if(!e)return o;const{ctrl:n,alt:s,shift:c}=Q,r=[];return e.ctrl&&r.push(n),e.alt&&r.push(s),e.shift&&r.push(c),r.push(o),r.join(i.isMacOS()?"":"+")},M=(t,e,o)=>{const n=D(e,o);if(t.__TOP_V_SHORTCUT_VALUE){console.warn(`Element already has shortcut "${t.__TOP_V_SHORTCUT_VALUE}"`);return}if(v.has(n)){console.warn(`Shortcut "${n}" is taken`);return}v.set(n,t),t.title=t.title?`${t.title} (${n})`:n,t.__TOP_V_SHORTCUT_VALUE=n},R=t=>{const e=t.__TOP_V_SHORTCUT_VALUE;e&&(v.delete(e),delete t.__TOP_V_SHORTCUT_VALUE,t.title===e&&t.removeAttribute("title"),t.title.includes(` (${e})`)&&(t.title=t.title.replace(` (${e})`,"")))},X=()=>{for(const[t]of _)!u.isVisible(t)&&t.__TOP_V_SHORTCUT_VALUE&&R(t);for(const[t,e]of _)u.isVisible(t)&&!t.__TOP_V_SHORTCUT_VALUE&&M(t,e.value,e.modifiers);_.clear()},J=async(t,e,o)=>{if(!U){const{debounce:n}=await new Promise((s,c)=>a(["../utils/lodash.amd"],s,c));U=n(X,30)}_.set(t,{value:e,modifiers:o}),U()},H=()=>{k||(k=!0,document.addEventListener("keydown",t=>{if(!(t.target instanceof HTMLElement)||["INPUT","TEXTAREA"].includes(t.target.tagName)||t.target.isContentEditable)return;const e={ctrl:i.isMacOS()?t.metaKey:t.ctrlKey,alt:t.altKey,shift:t.shiftKey},o=D(t.code,e),n=v.get(o);n&&(n.disabled||!u.isVisible(n)||(t.preventDefault(),n.click()))}))},Z={mounted:function(t,e){const{value:o,modifiers:n}=e;!o||!u.isVisible(t)||(H(),M(t,o,n))},updated:function(t,e){if(!!t.__TOP_V_SHORTCUT_VALUE===u.isVisible(t))return;const{value:o,modifiers:n}=e;o&&(H(),J(t,o,n))},unmounted:function(t){R(t)}};let P;const q={mounted(t,e,o){const n=e.value||"top-sticky";P=new IntersectionObserver(s=>{let c=s[0].intersectionRatio<1;c&&e.modifiers.bottom&&s[0].intersectionRect.y===0&&(c=!1),t.classList.toggle(n,c)},{threshold:[1]}),P.observe(t)},unmounted(t,e,o){P?.disconnect()}};let I=!1,V;const h=new Map,tt=(t,e)=>{const{distance:o,percent:n}=t.directiveSwipUpOptions,s=t.getBoundingClientRect().top,c=e*n/100/o,r=(e-s)/c;r<=o?t.style.transform=`translateY(${o-r}px)`:t.style.transform="translateY(0px)"},et=t=>{let e=window.innerHeight;window.addEventListener("scroll",()=>{h.forEach(o=>tt(o,e))},{passive:!0}),V=new IntersectionObserver(o=>{e=window.innerHeight,o.forEach(n=>{const s=n.target;if(n.intersectionRatio<.1?h.delete(s):h.set(s,s),n.intersectionRatio===0){const{distance:c}=s.directiveSwipUpOptions;s.style.transform=`translateY(${c}px)`}})},{threshold:.1})},ot={mounted(t,e,o){i.Core.state.isMobileUA||(t.directiveSwipUpOptions={distance:e.value?.distance??100,percent:e.value?.percent??30},I||(et(),I=!0),V.observe(t))},unmounted(t,e,o){h.delete(t),V?.unobserve(t)}},T=t=>{if(!i.Core.$?.ui?.tooltip){console.info("Для работы v-top-tooltip требуется глобальная загрузка jQuery UI Tooltip");return}return i.Core.$(t)},N=(t,e)=>{const o={...t.value??{}};return o.content??=e.getAttribute("ui-tooltip-title")??e.getAttribute("title")??"",o.content=String(o.content).replace(/([^<>])\r?\n([^<>])/g,"$1<br>$2"),o.position??={my:"bottom-18px",at:"top center",collision:"flipfit"},o},nt={mounted(t,e){T(t)?.tooltip(N(e,t))},updated(t,e){const o=N(e,t),n=T(t)?.tooltip("instance");if(!n){T(t)?.tooltip(o);return}n.options={...n.options,...o}},unmounted(t){T(t)?.tooltip("destroy")}},it=g.defineAsyncComponent(()=>new Promise((t,e)=>a(["./notice-CJ3WOTCM.amd"],t,e)));window.vd=console.log;const st={install:(t,e)=>{t.config.globalProperties.$core=i.Core,t.config.globalProperties.$vd=console.log;for(const o in e)i.Core.state[o]=e[o];e.widthForMobile&&(i.Core.widthForMobile=e.widthForMobile),e.themeName&&(i.Core.themeName=e.themeName),i.Core._setState(),e.topPopupOptions&&(l.TopPopupWorker.options=e.topPopupOptions),K.init(),A.TopDialogWorker.init(e.topDialogOptions),t.directive("top-data",x),t.directive("top-focus",B),t.directive("top-scroll-into-view",j),t.directive("top-scroll-shadow",G),t.directive("top-shortcut",Z),t.directive("top-sticky",q),t.directive("top-swim-up",ot),t.directive("top-tooltip",nt),t.component("TopAvatar",i._sfc_main$6),t.component("TopButton",i._sfc_main$1),t.component("TopCheckbox",i._sfc_main$4),t.component("TopControlLabel",i._sfc_main$7),t.component("TopHint",i._sfc_main$2),t.component("TopInput",i._sfc_main),t.component("TopInputDate",i._sfc_main$8),t.component("TopInputRange",i._sfc_main$9),t.component("TopLoadbar",i.TopLoadbar),t.component("TopRadio",i._sfc_main$5),t.component("TopSelect",i._sfc_main$10),t.component("TopSwitcher",i._sfc_main$11),t.component("TopTextarea",i._sfc_main$3),t.component("TopNotice",it),t.component("TopDialogs",A._sfc_main)}};W.core=st}));
2
+ //# sourceMappingURL=core-DzDFXOdI.amd.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"core-DzDFXOdI.amd.js","sources":["../../src/components/popup/lib/worker.globalEvents.ts","../../src/core/directives/data.ts","../../src/core/directives/focus.ts","../../src/core/directives/scrollIntoView.ts","../../src/core/directives/scrollShadow.ts","../../src/core/directives/shortcut.ts","../../src/core/directives/sticky.ts","../../src/core/directives/swimUp.ts","../../src/core/directives/tooltip.ts","../../src/core/plugins/core.ts"],"sourcesContent":["import Core from '@/core/core/core';\nimport Events from '@/core/core/events';\nimport Worker from '@/components/popup/lib/worker';\n\n/**\n * Глобальные события, для реализации Popup\n */\nclass WorkerEvents {\n\n\tprivate static isInited = false;\n\n\t/**\n\t * Добавить глобальные обработчики\n\t *\n\t * Добавляются на страницу один раз и навсегда\n\t */\n\tstatic init(): void {\n\t\tif (this.isInited) return;\n\n\t\tthis.isInited = true;\n\n\t\t// автоматическое открытие при наведении мыши, событие глобальное, так как инициализация popup отложена\n\t\tdocument.addEventListener('mouseover', (e) => {\n\t\t\tif (!(e.target instanceof HTMLElement) || !e.target.dataset?.topPopupOpenByHover) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\te.target.click();\n\t\t});\n\n\t\t// при скролле страницы закрыть Popup\n\t\tdocument.addEventListener('scroll', () => {\n\t\t\tif (Core.state.isMobile || Core.state.isMobileUA) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tWorker.getAll().forEach(elPopup => Worker.close(elPopup));\n\t\t});\n\n\t\tEvents.addOnReize(e => {\n\t\t\t// закрыть popup при повороте экрана телефона\n\t\t\t// если была отображена ПК версия, она будет закрыта\n\t\t\tif (Core.state.isMobile && e.topEvent.widthDiff) {\n\t\t\t\tWorker.getAll().forEach(elPopup => Worker.close(elPopup));\n\t\t\t}\n\t\t});\n\n\t\tdocument.addEventListener('click', this.onclick, { capture: true });\n\t}\n\n\t/**\n\t * Глобальный обработчик кликов\n\t *\n\t * Обрабатывает клики на открытие Popup\n\t */\n\tprivate static async onclick(e: Event): Promise<void> {\n\t\tif (!(e.target instanceof HTMLElement)) return;\n\n\t\tif (e.target.dataset.topPopupDisabled) {\n\t\t\treturn;\n\t\t}\n\n\t\tlet elOpener: HTMLElement | undefined;\n\n\t\tswitch (true) {\n\t\t\tcase !!e.target.dataset?.topPopup:\n\t\t\t\telOpener = e.target;\n\n\t\t\t\tbreak;\n\n\t\t\tcase !!e.target.parentElement?.dataset.topPopup:\n\t\t\t\telOpener = e.target.parentElement;\n\n\t\t\t\tbreak;\n\n\t\t\tcase !!e.target.parentElement?.parentElement?.dataset.topPopup:\n\t\t\t\telOpener = e.target.parentElement?.parentElement;\n\n\t\t\t\tbreak;\n\t\t}\n\n\t\tif (!elOpener) {\n\t\t\treturn;\n\t\t}\n\n\t\tif (elOpener.dataset.topPopupDisabled) {\n\t\t\treturn;\n\t\t}\n\n\t\t// меню уже открыто\n\t\tif (elOpener.dataset.topPopupOpened) {\n\t\t\tconst popup = Worker.getPopupFromOpener(elOpener);\n\t\t\tif (!popup?.openerIsInput) {\n\t\t\t\tpopup?.close();\n\t\t\t}\n\n\t\t\treturn;\n\t\t}\n\n\t\te.preventDefault();\n\n\t\tawait Worker.openByOpener(elOpener);\n\t}\n}\n\nexport default WorkerEvents;\n","import type { DirectiveBinding, ObjectDirective } from 'vue';\n\nlet storage: any;\n\n/**\n * Сохранить данные в элементе\n *\n * Для доступа к данным можно воспользоваться ui/utils/dom storage()\n */\nconst data = {\n\tmounted: async (el: HTMLElement, binding: DirectiveBinding) => {\n\t\tif (!storage) {\n\t\t\tconst UtilsDom = await import('@/core/utils/dom');\n\n\t\t\tstorage = UtilsDom.storage;\n\t\t}\n\n\t\tconst name = binding.arg;\n\t\tconst value = binding.value;\n\n\t\tstorage(el, name, value);\n\t},\n};\n\nexport default data;\n","import type { DirectiveBinding } from 'vue';\n\ntype Binding = DirectiveBinding<boolean, 'onupdate'>;\n\nlet UtilsLodash: typeof import('@/core/utils/lodash');\n\n/**\n * Список элементов, на которых бала запрошена фокусировка, для дедупликации фокусировок\n */\nlet elsActive: HTMLElement[] = [];\n\n/**\n * Функция скролла с дедупликацией\n */\nlet focusOnElActiveDebounce: Function;\n\n/**\n * Выполнить фокусировку на активном элементе\n *\n * Если фокусирока запрошена на несколько элементов, будет выбран первый элемент\n */\nconst focusOnElActive = async () => {\n\tconst { isVisible } = await import('@/core/utils/dom');\n\telsActive = elsActive.filter(isVisible)\n\n\tif (!elsActive.length) return;\n\n\tconst el = elsActive[0];\n\n\tel.focus();\n\n\t// // UX: Если выбрано несколько чекбоксов или радио после выбора фокусировка будет снята, чтобы не делать выбор за пользователя\n\t// if (elsActive.length && el.nodeName === 'INPUT') {\n\t// \tconst type = (el as HTMLInputElement).type;\n\t// \tif (type === 'checkbox' || type === 'radio') el.blur();\n\t// }\n\n\telsActive = [];\n};\n\n/**\n * Выполнить дедуплицированную фокусировку на элементе\n */\nconst focusOnElDebounce = async (el: HTMLElement) => {\n\tif (!UtilsLodash) UtilsLodash = await import('@/core/utils/lodash');\n\tif (!focusOnElActiveDebounce) focusOnElActiveDebounce = UtilsLodash.debounce(focusOnElActive, 30);\n\n\telsActive.push(el);\n\n\tfocusOnElActiveDebounce();\n};\n\n/**\n * Фокусировка на элементе сразу после его отображения\n */\nconst focus = {\n\tmounted: function (el: HTMLElement, binding: Binding) {\n\t\tel['__TOP_V_FOCUS_VALUE'] = binding.value ?? true;\n\n\t\tif (binding.value ?? true) focusOnElDebounce(el);\n\t},\n\n\tupdated: function (el: HTMLElement, binding: Binding) {\n\t\tif (!binding.modifiers.onupdate) return;\n\n\t\tif (el['__TOP_V_FOCUS_VALUE'] === (binding.value ?? true)) return;\n\t\tel['__TOP_V_FOCUS_VALUE'] = binding.value ?? true;\n\n\t\tif (binding.value ?? true) focusOnElDebounce(el);\n\t},\n};\n\nexport default focus;\n","import type { DirectiveBinding, ObjectDirective } from 'vue';\nimport { isVisible } from '@/core/utils/dom';\n\ntype Binding = DirectiveBinding<ScrollIntoViewOptions | boolean | undefined, 'immediate'>;\n\ntype Storage = {\n\t/**\n\t * Сохраненное состояние видимости\n\t */\n\tisVisible: boolean,\n\n\t/**\n\t * Текущие настройки скролла\n\t */\n\tscrollIntoViewOptions: ScrollIntoViewOptions | boolean\n};\n\nlet UtilsDom: typeof import('@/core/utils/dom');\nlet UtilsLodash: typeof import('@/core/utils/lodash');\n\n/**\n * Сгенерировать настройки для скролла\n *\n * @see https://developer.mozilla.org/ru/docs/Web/API/Element/scrollIntoView\n */\nconst genScrollIntoViewOptions = (scrollIntoViewOptions?: ScrollIntoViewOptions | boolean) => {\n\tif (typeof scrollIntoViewOptions === 'boolean') return scrollIntoViewOptions;\n\n\tif (!scrollIntoViewOptions) {\n\t\tscrollIntoViewOptions = {};\n\t} else {\n\t\tscrollIntoViewOptions = { ...scrollIntoViewOptions };\n\t}\n\n\tscrollIntoViewOptions.behavior ??= 'smooth';\n\tscrollIntoViewOptions.block ??= 'nearest';\n\tscrollIntoViewOptions.inline ??= 'nearest';\n\n\treturn scrollIntoViewOptions;\n};\n\n/**\n * Активный элемент, для дедупликации скроллов\n *\n * Только один элемент на странице может считаться активным\n */\nlet elActive: HTMLElement | undefined;\n\n/**\n * Функция скролла с дедупликацией\n */\nlet scrollToElActiveDebounce: Function;\n\n/**\n * Выполнить скролл к текущему активному элементу\n */\nconst scrollToElActive = async () => {\n\tif (!elActive) return;\n\n\tconst storage = await useStorage(elActive);\n\tif (!storage.isVisible) return;\n\n\telActive.scrollIntoView(storage.scrollIntoViewOptions);\n};\n\n/**\n * Выполнить дедуплицированный скролл к элементу\n *\n * Будет выполнен скролл к самому последнему элементу, вызвавшему срабатывание директивы\n */\nconst scrollToElDebounce = async (el: HTMLElement) => {\n\tif (!UtilsLodash) UtilsLodash = await import('@/core/utils/lodash');\n\tif (!scrollToElActiveDebounce) scrollToElActiveDebounce = UtilsLodash.debounce(scrollToElActive, 30);\n\n\telActive = el;\n\n\tscrollToElActiveDebounce();\n};\n\n/**\n * Данные, связанные с элементом и директивой\n */\nconst useStorage = async (el: HTMLElement, scrollIntoViewOptions?: ScrollIntoViewOptions | boolean) => {\n\tif (!UtilsDom) UtilsDom = await import('@/core/utils/dom');\n\n\tlet storage: Storage | undefined = UtilsDom.storage(el, 'v-top-scrollIntoView');\n\n\t// инициализация\n\tif (!storage) {\n\t\tstorage = {\n\t\t\tisVisible: isVisible(el),\n\t\t\tscrollIntoViewOptions: genScrollIntoViewOptions(scrollIntoViewOptions),\n\t\t};\n\n\t\tUtilsDom.storage(el, 'v-top-scrollIntoView', storage);\n\t}\n\n\treturn storage;\n};\n\nconst scrollIntoView: ObjectDirective = {\n\tasync mounted(el: HTMLElement, binding: Binding) {\n\t\tawait useStorage(el, binding.value);\n\n\t\tif (binding.modifiers.immediate) {\n\t\t\tscrollToElDebounce(el);\n\t\t}\n\t},\n\n\tasync updated(el: HTMLElement, binding: Binding) {\n\t\tconst storage = await useStorage(el, binding.value);\n\t\tstorage.scrollIntoViewOptions = genScrollIntoViewOptions(binding.value);\n\n\t\tconst isVisibleNew = isVisible(el);\n\t\tif (isVisibleNew && storage.isVisible !== isVisibleNew) {\n\t\t\tscrollToElDebounce(el);\n\t\t}\n\n\t\tstorage.isVisible = isVisibleNew;\n\t},\n};\n\nexport default scrollIntoView;\n","let UtilsScroll: typeof import('@/core/utils/scroll');\n\n/**\n * Добавить отображение тени при появлении скролла у элемента\n *\n * Будут добавлены события для усатновки модификаторов тени в зависимости от скролла элемента\n *\n * Модификаторы:\n * - top-scrollShadow\n * - top-scrollShadow-started\n * - top-scrollShadow-finished\n */\nconst connectScrollShadow = {\n\tasync mounted(el) {\n\t\tif (!UtilsScroll) UtilsScroll = await import('@/core/utils/scroll');\n\n\t\tUtilsScroll.connectScrollShadow(el);\n\t},\n\n\tasync unmounted(el) {\n\t\tif (!UtilsScroll) UtilsScroll = await import('@/core/utils/scroll');\n\n\t\tUtilsScroll.unconnectScrollShadow(el);\n\t},\n};\n\nexport default connectScrollShadow;\n","import { isVisible } from '@/core/utils/dom';\nimport { isMacOS } from '@/core/utils/device';\nimport type { DirectiveBinding } from 'vue';\nimport type debounce from 'lodash-es/debounce.js';\n\nexport type ShortcutValue = string;\n\n/**\n * Допустимые модификаторы\n */\ntype AllowedModifiers = 'ctrl' | 'shift' | 'alt';\ntype Binding = DirectiveBinding<ShortcutValue, AllowedModifiers>;\n\n/**\n * Очередь элементов, ожидающих синхронизации горячих клавиш.\n * Накапливает изменения для их пакетной обработки\n */\nconst elsShortcutQueue = new Map<HTMLElement, {\n\tvalue: ShortcutValue;\n\tmodifiers: Binding['modifiers'];\n}>;\n\n/**\n * Отложенная версия функции syncShortcuts.\n * Обеспечивает пакетную обработку изменений горячих клавиш\n */\nlet syncShortcutsDebounce: ReturnType<typeof debounce> | undefined;\n\n/**\n * Список горячих клавиш и html элементов, на которые они назначены\n */\nconst elementByShortcut = new Map<string, HTMLElement>();\n\n/**\n * Добавлен ли обработчик события\n */\nlet isListenerAttached = false;\n\n/**\n * Отображение названий клавиш-модификаторов в зависимости от ОС\n *\n * В наших горячих клавишах Ctrl всегда соответствует Cmd в MacOS\n */\nconst modifierKeys = {\n\tctrl: isMacOS() ? '⌘' : 'Ctrl',\n\talt: isMacOS() ? '⌥' : 'Alt',\n\tshift: isMacOS() ? '⇧' : 'Shift',\n};\n\n/**\n * Получить название клавиши из event.code\n */\nconst getKeyLabel = (code: string) => {\n\tlet keyLabel = code;\n\n\tif (code.includes('Key')) keyLabel = code.replace('Key', '');\n\tif (code.includes('Digit')) keyLabel = code.replace('Digit', '');\n\tif (code === 'Escape') keyLabel = 'Esc';\n\n\treturn keyLabel;\n};\n\n/**\n * Сгенерировать строковое представление сочетания клавиш с модификаторами\n *\n * Приводим к виду \"Ctrl+Shift+A\" или \"⌘⇧A\" для MacOS\n */\nconst genShortcutString = (code: string, modifiers: Binding['modifiers']) => {\n\tconst keyLabel = getKeyLabel(code);\n\tif (!modifiers) return keyLabel;\n\n\tconst { ctrl, alt, shift } = modifierKeys;\n\tconst parts: string[] = [];\n\n\tif (modifiers.ctrl) parts.push(ctrl);\n\tif (modifiers.alt) parts.push(alt);\n\tif (modifiers.shift) parts.push(shift);\n\n\t// Основная клавиша\n\tparts.push(keyLabel);\n\n\treturn parts.join(isMacOS() ? '' : '+');\n};\n\nconst registerShortcut = (el: HTMLElement, value: ShortcutValue, modifiers: Binding['modifiers']) => {\n\tconst shortcut = genShortcutString(value, modifiers);\n\n\tif (el['__TOP_V_SHORTCUT_VALUE']) {\n\t\tconsole.warn(`Element already has shortcut \"${el['__TOP_V_SHORTCUT_VALUE']}\"`);\n\n\t\treturn;\n\t}\n\n\tif (elementByShortcut.has(shortcut)) {\n\t\tconsole.warn(`Shortcut \"${shortcut}\" is taken`);\n\n\t\treturn;\n\t}\n\n\telementByShortcut.set(shortcut, el);\n\tel.title = el.title ? `${el.title} (${shortcut})` : shortcut;\n\tel['__TOP_V_SHORTCUT_VALUE'] = shortcut;\n};\n\nconst unregisterShortcut = (el: HTMLElement) => {\n\tconst shortcut: string | undefined = el['__TOP_V_SHORTCUT_VALUE'];\n\tif (!shortcut) return;\n\n\telementByShortcut.delete(shortcut);\n\tdelete el['__TOP_V_SHORTCUT_VALUE'];\n\n\tif (el.title === shortcut) el.removeAttribute('title');\n\tif (el.title.includes(` (${shortcut})`)) {\n\t\tel.title = el.title.replace(` (${shortcut})`, '');\n\t}\n};\n\n/**\n * Обновить регистрацию горячих клавиш для элементов в очереди\n *\n * Отменяет регистрацию для невидимых элементов и регистрирует для видимых.\n * Очищает очередь после обработки\n */\nconst syncShortcuts = () => {\n\tfor (const [el] of elsShortcutQueue) {\n\t\tif (!isVisible(el) && el['__TOP_V_SHORTCUT_VALUE']) {\n\t\t\tunregisterShortcut(el);\n\t\t}\n\t}\n\n\tfor (const [el, data] of elsShortcutQueue) {\n\t\tif (isVisible(el) && !el['__TOP_V_SHORTCUT_VALUE']) {\n\t\t\tregisterShortcut(el, data.value, data.modifiers);\n\t\t}\n\t}\n\n\telsShortcutQueue.clear();\n};\n\n/**\n * Выполняет отложенную регистрацию горячих клавиш на элементе с дедупликацией\n */\nconst registerShortcutDebounce = async (el: HTMLElement, value: ShortcutValue, modifiers: Binding['modifiers']) => {\n\tif (!syncShortcutsDebounce) {\n\t\tconst { debounce } = await import('@/core/utils/lodash');\n\t\tsyncShortcutsDebounce = debounce(syncShortcuts, 30);\n\t}\n\n\telsShortcutQueue.set(el, { value, modifiers });\n\n\tsyncShortcutsDebounce();\n};\n\nconst attachGlobalListener = () => {\n\tif (isListenerAttached) return;\n\tisListenerAttached = true;\n\n\tdocument.addEventListener('keydown', e => {\n\t\tif (!(e.target instanceof HTMLElement)) return;\n\t\tif (['INPUT', 'TEXTAREA'].includes(e.target.tagName) || e.target.isContentEditable) return;\n\n\t\tconst modifiers = {\n\t\t\tctrl: isMacOS() ? e.metaKey : e.ctrlKey,\n\t\t\talt: e.altKey,\n\t\t\tshift: e.shiftKey,\n\t\t};\n\n\t\tconst shortcut = genShortcutString(e.code, modifiers);\n\t\tconst element = elementByShortcut.get(shortcut);\n\n\t\tif (!element) return;\n\t\tif ((element as any).disabled || !isVisible(element)) return;\n\n\t\te.preventDefault();\n\t\telement.click();\n\t});\n};\n\nconst shortcut = {\n\tmounted: function (el: HTMLElement, binding: Binding) {\n\t\tconst { value, modifiers } = binding;\n\t\tif (!value || !isVisible(el)) return;\n\n\t\tattachGlobalListener();\n\t\tregisterShortcut(el, value, modifiers);\n\t},\n\n\tupdated: function (el: HTMLElement, binding: Binding) {\n\t\tif (!!el['__TOP_V_SHORTCUT_VALUE'] === isVisible(el)) return;\n\n\t\tconst { value, modifiers } = binding;\n\t\tif (!value) return;\n\n\t\tattachGlobalListener();\n\t\tvoid registerShortcutDebounce(el, value, modifiers);\n\t},\n\n\tunmounted: function (el: HTMLElement) {\n\t\tunregisterShortcut(el);\n\t},\n};\n\nexport default shortcut;\n","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\n\nlet appStickyObserver: IntersectionObserver;\n\n/**\n * Добавление sticky\n * К элементу добляется класс переданный как значение диррективы либо **'top-sticky'** по умолчанию\n */\nconst sticky = {\n\tmounted(el: HTMLElement, binding: DirectiveBinding, _vnode: VNode) {\n\t\tconst className = binding.value || 'top-sticky';\n\n\t\tappStickyObserver = new IntersectionObserver(entries => {\n\t\t\tlet condition = entries[0].intersectionRatio < 1;\n\t\t\tif (condition) {\n\t\t\t\tif (binding.modifiers.bottom && entries[0].intersectionRect.y === 0) condition = false;\n\t\t\t}\n\n\t\t\tel.classList.toggle(className, condition);\n\t\t}, {\n\t\t\tthreshold: [1],\n\t\t});\n\n\t\tappStickyObserver.observe(el);\n\t},\n\n\tunmounted(_el: HTMLElement, _binding: DirectiveBinding, _vnode: VNode) {\n\t\tappStickyObserver?.disconnect();\n\t},\n};\n\nexport default sticky;\n","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\nimport Core from '@/core/core/core';\n\ninterface HTMLElementWithSwimUpOptions extends HTMLElement {\n\tdirectiveSwipUpOptions: {\n\t\tdistance: number,\n\t\tpercent: number,\n\t};\n}\n\nlet appSwimUpInited = false;\nlet appSwimUpObserver: IntersectionObserver;\nconst appSwimUpEls = new Map();\n\n/**\n * Отодвинуть блок в зависимости от скролла старинцы\n * @param el\n * @param windowHeight\n */\nconst swimUpElTransform = (el: HTMLElementWithSwimUpOptions, windowHeight: number): void => {\n\tconst { distance, percent } = el.directiveSwipUpOptions;\n\n\tconst elTop = el.getBoundingClientRect().top;\n\n\t// во столько раз triggerHeight должен быть меньше, чтобы закончить подплытие к нужной высоте экрана\n\tconst triggerHeightReducer = windowHeight * percent / 100 / distance;\n\tconst triggerHeight = (windowHeight - elTop) / triggerHeightReducer;\n\n\tif (triggerHeight <= distance) {\n\t\tel.style.transform = `translateY(${distance - triggerHeight}px)`;\n\t} else {\n\t\tel.style.transform = 'translateY(0px)';\n\t}\n};\n\nconst swimUpInit = (_el: HTMLElementWithSwimUpOptions): void => {\n\tlet windowHeight = window.innerHeight;\n\n\twindow.addEventListener('scroll', () => {\n\t\tappSwimUpEls.forEach((el) => swimUpElTransform(el, windowHeight));\n\t}, { passive: true });\n\n\t// проверка того, что элемент в зоне видимости\n\tappSwimUpObserver = new IntersectionObserver(entries => {\n\t\twindowHeight = window.innerHeight;\n\n\t\tentries.forEach((entry) => {\n\t\t\tconst el = entry.target as HTMLElementWithSwimUpOptions;\n\n\t\t\tif (entry.intersectionRatio < 0.1) {\n\t\t\t\t// элемент за областью видимости\n\t\t\t\tappSwimUpEls.delete(el);\n\t\t\t} else {\n\t\t\t\t// элемент на экране\n\t\t\t\tappSwimUpEls.set(el, el);\n\t\t\t}\n\n\t\t\tif (entry.intersectionRatio === 0) {\n\t\t\t\tconst { distance } = el.directiveSwipUpOptions;\n\t\t\t\tel.style.transform = `translateY(${distance}px)`;\n\t\t\t}\n\t\t});\n\t}, {\n\t\tthreshold: 0.1,\n\t});\n};\n\n/**\n * Добавление анимации подплытия вверх для блока\n */\nconst swimUp = {\n\tmounted(el: HTMLElementWithSwimUpOptions, binding: DirectiveBinding, _vnode: VNode): void {\n\t\tif (Core.state.isMobileUA) return;\n\n\t\tel.directiveSwipUpOptions = {\n\t\t\tdistance: binding.value?.distance ?? 100, // количество px на которые блок изначально смещен вниз,\n\t\t\tpercent: binding.value?.percent ?? 30, // процент высоты экрана поднявшись на который блок закончит подплытие\n\t\t};\n\n\t\tif (!appSwimUpInited) {\n\t\t\tswimUpInit(el);\n\n\t\t\tappSwimUpInited = true;\n\t\t}\n\n\t\tappSwimUpObserver.observe(el);\n\t},\n\n\tunmounted(el: HTMLElementWithSwimUpOptions, _binding: DirectiveBinding, _vnode: VNode) {\n\t\tappSwimUpEls.delete(el);\n\t\tappSwimUpObserver?.unobserve(el);\n\t},\n};\n\nexport default swimUp;\n","import type { DirectiveBinding, ObjectDirective } from 'vue';\nimport Core from '@/core/core/core';\n\nconst $ = (el: HTMLElement) => {\n\tif (!Core.$?.ui?.tooltip) {\n\t\tconsole.info('Для работы v-top-tooltip требуется глобальная загрузка jQuery UI Tooltip');\n\n\t\treturn;\n\t}\n\n\treturn Core.$(el);\n};\n\nconst tvTooltipGenOptions = (binding: DirectiveBinding, el: HTMLElement): JQueryUI.TooltipOptions => {\n\tconst options = {\n\t\t...(binding.value ?? {}),\n\t} as JQueryUI.TooltipOptions;\n\n\toptions.content ??= el.getAttribute('ui-tooltip-title') ?? el.getAttribute('title') ?? '';\n\toptions.content = String(options.content).replace(/([^<>])\\r?\\n([^<>])/g, '$1<br>$2');\n\n\toptions.position ??= {\n\t\tmy: 'bottom-18px',\n\t\tat: 'top center',\n\t\tcollision: 'flipfit',\n\t};\n\n\treturn options;\n};\n\n/**\n * Добавление всплывающей подсказки к элементу.\n */\nconst tooltip: ObjectDirective<HTMLElement> = {\n\tmounted(el, binding) {\n\t\t$(el)?.tooltip(tvTooltipGenOptions(binding, el));\n\t},\n\n\tupdated(el, binding) {\n\t\t/**\n\t\t * В результате обновления может быть открыто несколько тултипов поэтому изменить опции, без перерисовки тултипа\n\t\t */\n\t\tconst options = tvTooltipGenOptions(binding, el);\n\t\tconst instance = $(el)?.tooltip('instance') as { options: JQueryUI.TooltipOptions } | undefined;\n\n\t\tif (!instance) {\n\t\t\t$(el)?.tooltip(options);\n\t\t\treturn;\n\t\t}\n\n\t\tinstance.options = {\n\t\t\t...instance.options,\n\t\t\t...options,\n\t\t};\n\t},\n\n\tunmounted(el) {\n\t\t$(el)?.tooltip('destroy');\n\t},\n};\n\nexport default tooltip;\n","import { defineAsyncComponent, type Plugin } from 'vue';\nimport type { PartialBy } from '@/components/types';\n\nimport Core from '@/core/core/core';\nimport coreDefaultOptions from '@/core/core/options';\n\nimport * as Forms from '../../components/forms/forms';\n\nconst TopNotice = defineAsyncComponent(() => import('@/components/core/notice/notice.vue'));\n\nimport type { Options as TopPopupOptions } from '@/components/popup/lib/worker';\nimport TopPopupWorker from '@/components/popup/lib/worker';\nimport TopPopupWorkerGlobalEvents from '@/components/popup/lib/worker.globalEvents';\n\nimport TopDialogs from '@/components/dialog/dialog/dialogs/dialogs.vue';\nimport { TopDialogWorker } from '@/components/dialog/lib/worker';\nimport type { TopDialogOptions } from '@/components/dialog/lib/types';\n\nimport directiveData from '@/core/directives/data';\nimport directiveFocus from '@/core/directives/focus';\nimport directiveScrollIntoView from '@/core/directives/scrollIntoView';\nimport directiveScrollShadow from '@/core/directives/scrollShadow';\nimport directiveShortcut from '@/core/directives/shortcut';\nimport directiveSticky from '@/core/directives/sticky';\nimport directiveSwimUp from '@/core/directives/swimUp';\nimport directiveTooltip from '@/core/directives/tooltip';\n\ndeclare global {\n\tconst vd: typeof console.log;\n}\n\nwindow['vd'] = console.log;\n\ndeclare module '@vue/runtime-core' {\n\tinterface ComponentCustomProperties {\n\t\t/**\n\t\t * Статический класс с текущим состоянимем UI\n\t\t */\n\t\t$core: typeof Core;\n\n\t\t$vd: typeof console.log;\n\t}\n\n\t/**\n\t * Обязательные компоненты UI\n\t *\n\t * Они подключаются через плагин и доступны без явного указания импорта\n\t */\n\texport interface GlobalComponents {\n\t\tTopAvatar: typeof Forms.TopAvatar;\n\t\tTopButton: typeof Forms.TopButton;\n\t\tTopCheckbox: typeof Forms.TopCheckbox;\n\t\tTopControlLabel: typeof Forms.TopControlLabel;\n\t\tTopHint: typeof Forms.TopHint;\n\t\tTopInput: typeof Forms.TopInput;\n\t\tTopInputDate: typeof Forms.TopInputDate;\n\t\tTopInputRange: typeof Forms.TopInputRange;\n\t\tTopRadio: typeof Forms.TopRadio;\n\t\tTopSwitcher: typeof Forms.TopSwitcher;\n\t\tTopTextarea: typeof Forms.TopTextarea;\n\t\tTopSelect: typeof Forms.TopSelect;\n\t\tTopLoadbar: typeof Forms.TopLoadbar;\n\n\t\tTopNotice: typeof TopNotice;\n\t\tTopDialogs: typeof TopDialogs;\n\t}\n}\n\ntype CoreOptions = PartialBy<typeof coreDefaultOptions, 'timezoneOffset' | 'documentClassModificators'>;\n\ntype Options = CoreOptions & {\n\ttopPopupOptions?: TopPopupOptions\n\ttopDialogOptions?: TopDialogOptions\n};\n\n/**\n * Плагин для интеграции UI во Vue приложение\n *\n * - В глобальную область видимости шаблонов будет добавлен объект $core\n * - Будут зарегистрирвоаны директивы UI: https://ui.topvisor.com/?path=/docs/core-directives-focus--docs\n * - Будут подключены базовые компоненты UI/Forms: https://ui.topvisor.com/?path=/docs/components-forms-readme--docs\n */\nexport default {\n\n\tinstall: (app, options: Options) => {\n\t\tapp.config.globalProperties.$core = Core;\n\t\tapp.config.globalProperties.$vd = console.log;\n\n\t\t// начальные настройки UI\n\t\tfor (const name in options) {\n\t\t\tCore.state[name] = options[name];\n\t\t}\n\n\t\tif (options.widthForMobile) Core.widthForMobile = options.widthForMobile;\n\t\tif (options.themeName) Core.themeName = options.themeName;\n\n\t\tCore._setState();\n\n\t\tif (options.topPopupOptions) TopPopupWorker.options = options.topPopupOptions;\n\t\tTopPopupWorkerGlobalEvents.init();\n\n\t\tTopDialogWorker.init(options.topDialogOptions);\n\n\t\t// определение директив\n\t\tapp.directive('top-data', directiveData);\n\t\tapp.directive('top-focus', directiveFocus);\n\t\tapp.directive('top-scroll-into-view', directiveScrollIntoView);\n\t\tapp.directive('top-scroll-shadow', directiveScrollShadow);\n\t\tapp.directive('top-shortcut', directiveShortcut);\n\t\tapp.directive('top-sticky', directiveSticky);\n\t\tapp.directive('top-swim-up', directiveSwimUp);\n\t\tapp.directive('top-tooltip', directiveTooltip);\n\n\t\t// определение базовых компонентов\n\t\tapp.component('TopAvatar', Forms.TopAvatar);\n\t\tapp.component('TopButton', Forms.TopButton);\n\t\tapp.component('TopCheckbox', Forms.TopCheckbox);\n\t\tapp.component('TopControlLabel', Forms.TopControlLabel);\n\t\tapp.component('TopHint', Forms.TopHint);\n\t\tapp.component('TopInput', Forms.TopInput);\n\t\tapp.component('TopInputDate', Forms.TopInputDate);\n\t\tapp.component('TopInputRange', Forms.TopInputRange);\n\t\tapp.component('TopLoadbar', Forms.TopLoadbar);\n\t\tapp.component('TopRadio', Forms.TopRadio);\n\t\tapp.component('TopSelect', Forms.TopSelect);\n\t\tapp.component('TopSwitcher', Forms.TopSwitcher);\n\t\tapp.component('TopTextarea', Forms.TopTextarea);\n\n\t\tapp.component('TopNotice', TopNotice);\n\t\tapp.component('TopDialogs', TopDialogs);\n\t},\n\n} satisfies Plugin<Options>;\n"],"names":["WorkerEvents","forms","popup_worker","elPopup","elOpener","popup","storage","data","el","binding","resolve","reject","require","name","value","UtilsLodash$1","focusOnElActiveDebounce","elsActive","isVisible","focusOnElDebounce","focusOnElActive","focus","UtilsDom","UtilsLodash","genScrollIntoViewOptions","scrollIntoViewOptions","elActive","scrollToElActiveDebounce","useStorage","scrollToElDebounce","scrollToElActive","utils_dom","scrollIntoView","isVisibleNew","UtilsScroll","connectScrollShadow","elsShortcutQueue","syncShortcutsDebounce","elementByShortcut","modifierKeys","getKeyLabel","code","keyLabel","genShortcutString","modifiers","parts","shortcut2","unregisterShortcut","debounce","syncShortcuts","e","shortcut","attachGlobalListener","registerShortcut","appStickyObserver","sticky","_vnode","className","entries","_el","_binding","appSwimUpObserver","appSwimUpEls","swimUpElTransform","windowHeight","triggerHeight","distance","swimUpInit","entry","swimUp","$","tvTooltipGenOptions","options","tooltip","core","app","dialogs_vue_vue_type_script_setup_true_lang","TopNotice"],"mappings":"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"}
package/core/app.amd.js CHANGED
@@ -1,2 +1,2 @@
1
- define(["require","exports","../.chunks/forms-DDNzqU6o.amd","../.chunks/core-B1CmZy7Z.amd","vue","../utils/clipboard.amd","../utils/string.amd","../utils/route.amd","../.chunks/utils-CWn_G7OO.amd","../.chunks/dialogs.vue_vue_type_script_setup_true_lang-BBix_8WK.amd"],(function(E,n,r,g,c,p,f,d,u,m){"use strict";if(typeof c>"u")var c=window.Vue;class S{#s;#t;#e;#a;#c;#i=[];#o=[];#n=[];#r=[];constructor(t){this.#t=t.store,this.#s=this.#t.$id,this.#e=t.options.Page,this.#a=t.options.user,this.#c=t.options.Api,this.#i=t.options.tpaNamesUrlHash||[],this.#o=t.options.tpaNamesStorage||[],this.#n=t.options.tpaNamesStorageLocal||[],this.#r=t.options.tpaNamesGuestLink||[],t.store.genGuestLink=(s,a)=>this.genGuestLink(s,a),this.#a.guest_data?.data||(this.#u(),this.#u(!0),this.#f()),this.#S(),this.#k();const e=r.debounce(()=>{this.#m(),this.#l(),this.#l(!0)});t.store.$subscribe(e)}async genGuestLink(t,e){const s=this.#g();e=Object.assign(e,Object.fromEntries(s));const a=await this.#c.gen(t).setParams(e).call();if(a?.errors)return;const i=a.result;await p.guestLinkToClipboard(i)}#g(){const t=new Map;return this.#r.forEach(e=>{const s=f.camelToSnakeCase(e);t.set(s,this.#t[e])}),t}#h(t){t.forEach((e,s)=>{const a=this.#t[s];if(e!=null&&a!==void 0&&e?.constructor&&e.constructor===a.constructor){if(s.indexOf("date")===0&&!Array.isArray(e)){if(typeof e=="string"&&!/\d\d\d\d-\d\d-\d\d/.test(e))return}this.#t[s]=e}})}#p(t){const e=new Map;return t.forEach((s,a)=>{s!==null&&(s=JSON.stringify(s),e.set(a,s))}),e}#d(t){const e=new Map;return t.forEach((s,a)=>{if(!(s==null||s==="false")){try{if(typeof s=="string"&&!/^\d\d\d\d-\d\d-\d\d$/.test(s)&&(s=JSON.parse(s)),s==null||s==="false")return}catch{}e.set(a,s)}}),e}#f(){let t;try{t=JSON.parse(d.getHash(this.#s))}catch{}if(!t)return;const e=new Map;this.#i.forEach(s=>{const a=t[s];a&&e.set(s,a)}),this.#h(e)}#m(){const t=new Map;this.#i.forEach(a=>{const i=this.#t[a];t.set(a,i)});const e=Object.fromEntries(t),s=JSON.stringify(e);d.setHash(this.#s,s)}#u(t=!1){const e=new Map;let s=this.#o,a="state:"+this.#s;t&&(s=this.#n,a="state:"+this.#s+":"+location.pathname),s.forEach(o=>{const h=localStorage.getItem(a+":"+o);e.set(o,h)});const i=this.#d(e);this.#h(i)}#l(t=!1){const e=new Map;let s=this.#o,a="state:"+this.#s;t&&(s=this.#n,a="state:"+this.#s+":"+location.pathname),s.forEach(o=>{const h=this.#t[o];e.set(o,h)});const i=this.#p(e);s.forEach(o=>{const h=i.get(o);localStorage.setItem(a+":"+o,h)})}#S(){const t=this.#a?.guest_data?.data;if(!t)return;this.#a.id===-1&&(this.#a.positionsReverseDates=t.positionsReverseDates);const e=new Map;this.#r.forEach(i=>{const o=t[i];e.set(i,o)});const s=this.#d(e);this.#h(s);const a=$(".mod_guest_title");if(this.#t.competitorsIds?.length===1&&this.#e.page.data.competitors){let i=this.#e.page.data.competitors.filter(o=>o.id===t.competitorsIds[0]);i.length&&($("a",a).attr("href","http://"+i[0].url),$("a",a).text(i[0].name))}}#k(){this.#t.regionsIndexes&&c.watch(this.#t.regionsIndexes,t=>{if(!t.length)return;t.forEach((a,i)=>t[i]=a);const e=TplProjectSelectorRegion.genSearchersMap(),s=[];e.forEach(a=>{a.regions.forEach(i=>{i.index!==-1&&s.push(i.index)})}),this.#t.regionsIndexes=t.filter(a=>s.includes(a))},{immediate:!0}),this.#t.competitorsIds&&c.watch(this.#t.competitorsIds,t=>{if(!t.length)return;t.forEach((s,a)=>t[a]=s);const e=[this.#e.page.data.project.id];this.#e.page.data.project.competitors.forEach(s=>{s.on>=0&&e.push(s.id)}),this.#t.competitorsIds=t.filter(s=>e.includes(s))},{immediate:!0})}}const k=l=>{const t=l;!t.options.tpaNamesUrlHash?.length&&!t.options.tpaNamesStorage?.length&&!t.options.tpaNamesStorageLocal?.length&&!t.options.tpaNamesGuestLink?.length||new S(t)};n.Core=r.Core,n.i18nPlugin=r.i18n,n.useI18n=r.useI18n,n.useI18nLang=r.useI18nLang,n.corePlugin=g.core,n.useAsyncTopDialog=u.useAsyncTopDialog,n.useTopDialog=u.useTopDialog,n.TopDialogWorker=m.TopDialogWorker,n.piniaTPAPlugin=k,Object.defineProperty(n,Symbol.toStringTag,{value:"Module"})}));
1
+ define(["require","exports","../.chunks/forms-DDNzqU6o.amd","../.chunks/core-DzDFXOdI.amd","vue","../utils/clipboard.amd","../utils/string.amd","../utils/route.amd","../.chunks/utils-CWn_G7OO.amd","../.chunks/dialogs.vue_vue_type_script_setup_true_lang-BBix_8WK.amd"],(function(E,n,r,g,c,p,f,d,u,m){"use strict";if(typeof c>"u")var c=window.Vue;class S{#s;#t;#e;#a;#c;#i=[];#o=[];#n=[];#r=[];constructor(t){this.#t=t.store,this.#s=this.#t.$id,this.#e=t.options.Page,this.#a=t.options.user,this.#c=t.options.Api,this.#i=t.options.tpaNamesUrlHash||[],this.#o=t.options.tpaNamesStorage||[],this.#n=t.options.tpaNamesStorageLocal||[],this.#r=t.options.tpaNamesGuestLink||[],t.store.genGuestLink=(s,a)=>this.genGuestLink(s,a),this.#a.guest_data?.data||(this.#u(),this.#u(!0),this.#f()),this.#S(),this.#k();const e=r.debounce(()=>{this.#m(),this.#l(),this.#l(!0)});t.store.$subscribe(e)}async genGuestLink(t,e){const s=this.#g();e=Object.assign(e,Object.fromEntries(s));const a=await this.#c.gen(t).setParams(e).call();if(a?.errors)return;const i=a.result;await p.guestLinkToClipboard(i)}#g(){const t=new Map;return this.#r.forEach(e=>{const s=f.camelToSnakeCase(e);t.set(s,this.#t[e])}),t}#h(t){t.forEach((e,s)=>{const a=this.#t[s];if(e!=null&&a!==void 0&&e?.constructor&&e.constructor===a.constructor){if(s.indexOf("date")===0&&!Array.isArray(e)){if(typeof e=="string"&&!/\d\d\d\d-\d\d-\d\d/.test(e))return}this.#t[s]=e}})}#p(t){const e=new Map;return t.forEach((s,a)=>{s!==null&&(s=JSON.stringify(s),e.set(a,s))}),e}#d(t){const e=new Map;return t.forEach((s,a)=>{if(!(s==null||s==="false")){try{if(typeof s=="string"&&!/^\d\d\d\d-\d\d-\d\d$/.test(s)&&(s=JSON.parse(s)),s==null||s==="false")return}catch{}e.set(a,s)}}),e}#f(){let t;try{t=JSON.parse(d.getHash(this.#s))}catch{}if(!t)return;const e=new Map;this.#i.forEach(s=>{const a=t[s];a&&e.set(s,a)}),this.#h(e)}#m(){const t=new Map;this.#i.forEach(a=>{const i=this.#t[a];t.set(a,i)});const e=Object.fromEntries(t),s=JSON.stringify(e);d.setHash(this.#s,s)}#u(t=!1){const e=new Map;let s=this.#o,a="state:"+this.#s;t&&(s=this.#n,a="state:"+this.#s+":"+location.pathname),s.forEach(o=>{const h=localStorage.getItem(a+":"+o);e.set(o,h)});const i=this.#d(e);this.#h(i)}#l(t=!1){const e=new Map;let s=this.#o,a="state:"+this.#s;t&&(s=this.#n,a="state:"+this.#s+":"+location.pathname),s.forEach(o=>{const h=this.#t[o];e.set(o,h)});const i=this.#p(e);s.forEach(o=>{const h=i.get(o);localStorage.setItem(a+":"+o,h)})}#S(){const t=this.#a?.guest_data?.data;if(!t)return;this.#a.id===-1&&(this.#a.positionsReverseDates=t.positionsReverseDates);const e=new Map;this.#r.forEach(i=>{const o=t[i];e.set(i,o)});const s=this.#d(e);this.#h(s);const a=$(".mod_guest_title");if(this.#t.competitorsIds?.length===1&&this.#e.page.data.competitors){let i=this.#e.page.data.competitors.filter(o=>o.id===t.competitorsIds[0]);i.length&&($("a",a).attr("href","http://"+i[0].url),$("a",a).text(i[0].name))}}#k(){this.#t.regionsIndexes&&c.watch(this.#t.regionsIndexes,t=>{if(!t.length)return;t.forEach((a,i)=>t[i]=a);const e=TplProjectSelectorRegion.genSearchersMap(),s=[];e.forEach(a=>{a.regions.forEach(i=>{i.index!==-1&&s.push(i.index)})}),this.#t.regionsIndexes=t.filter(a=>s.includes(a))},{immediate:!0}),this.#t.competitorsIds&&c.watch(this.#t.competitorsIds,t=>{if(!t.length)return;t.forEach((s,a)=>t[a]=s);const e=[this.#e.page.data.project.id];this.#e.page.data.project.competitors.forEach(s=>{s.on>=0&&e.push(s.id)}),this.#t.competitorsIds=t.filter(s=>e.includes(s))},{immediate:!0})}}const k=l=>{const t=l;!t.options.tpaNamesUrlHash?.length&&!t.options.tpaNamesStorage?.length&&!t.options.tpaNamesStorageLocal?.length&&!t.options.tpaNamesGuestLink?.length||new S(t)};n.Core=r.Core,n.i18nPlugin=r.i18n,n.useI18n=r.useI18n,n.useI18nLang=r.useI18nLang,n.corePlugin=g.core,n.useAsyncTopDialog=u.useAsyncTopDialog,n.useTopDialog=u.useTopDialog,n.TopDialogWorker=m.TopDialogWorker,n.piniaTPAPlugin=k,Object.defineProperty(n,Symbol.toStringTag,{value:"Module"})}));
2
2
  //# sourceMappingURL=app.amd.js.map
package/core/app.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import { d as c } from "../.chunks/forms-BpbQYyEQ.es.js";
2
2
  import { C as O, i as P, u as I, a as T } from "../.chunks/forms-BpbQYyEQ.es.js";
3
- import { c as y } from "../.chunks/core-BM3jtOUr.es.js";
3
+ import { c as y } from "../.chunks/core-DoIr-EAf.es.js";
4
4
  import { watch as h } from "vue";
5
5
  import { guestLinkToClipboard as p } from "../utils/clipboard.js";
6
6
  import { camelToSnakeCase as d } from "../utils/string.js";
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@topvisor/ui",
3
3
  "private": false,
4
- "version": "1.4.3-fixVTopTooltip.0",
4
+ "version": "1.4.3-fixVTopTooltip.1",
5
5
  "type": "module",
6
6
  "description": "Topvisor UI-kit Vue",
7
7
  "author": "Topvisor",
@@ -1,2 +1,2 @@
1
- define(["require","exports","vue","../.chunks/forms-DDNzqU6o.amd","../.chunks/popupHint.vue_vue_type_style_index_0_lang-CdQostog.amd","../.chunks/policy.vue_vue_type_style_index_0_lang-BDyhjT5Y.amd","../.chunks/utils-CWn_G7OO.amd","../utils/searchers.amd","../.chunks/core-B1CmZy7Z.amd","../.chunks/dialogs.vue_vue_type_script_setup_true_lang-BBix_8WK.amd","../.chunks/field-Cvv0SRcJ.amd","../utils/dom.amd","../popup/worker.amd","../require/css.amd!../assets/project.css"],(function(se,B,e,y,V,C,fe,W,Je,Ye,H,A,ge){"use strict";if(typeof e>"u")var e=window.Vue;const me={class:"top-competitorSelector"},ve={class:"top-ellipsis1"},pe=e.defineComponent({__name:"competitorSelector",props:e.mergeModels({modelValue:{},items:{},showSelectAllItem:{type:Boolean,default:!0}},{modelValue:{},modelModifiers:{}}),emits:["update:modelValue"],setup(t){const a=t,l=e.useModel(t,"modelValue"),o=e.computed(()=>{if(a.showSelectAllItem)return{icon:"",title:y.useI18n().Common.Select_all,value:"all",content:""}});return(i,n)=>(e.openBlock(),e.createElementBlock("div",me,[e.unref(y.Core).state.isMobile?(e.openBlock(),e.createBlock(V._sfc_main,{key:0},{opener:e.withCtx(()=>[e.createVNode(y._sfc_main$1,{class:"top-competitorSelector_opener",color:"theme",icon:"",icon2:""},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(t.items.find(r=>r.value===l.value?.[0])?.content),1)]),_:1})]),contentList:e.withCtx(()=>[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.items,r=>(e.openBlock(),e.createBlock(V._sfc_main$2,{class:e.normalizeClass({"top-active":l.value?.includes(r.value)}),"data-top-icon":r.icon,title:r.title,onClick:()=>l.value=[r.value]},{default:e.withCtx(()=>[e.createElementVNode("span",ve,e.toDisplayString(r.content),1)]),_:2},1032,["class","data-top-icon","title","onClick"]))),256))]),_:1})):(e.openBlock(),e.createBlock(C._sfc_main$1,{key:1,modelValue:l.value,"onUpdate:modelValue":n[0]||(n[0]=r=>l.value=r),items:t.items,isMultiple:!0,styling:"bar",canBeEmptyMultiple:!1,selectAllItem:o.value},null,8,["modelValue","items","selectAllItem"]))]))}}),he=(t,a)=>e.computed(()=>e.toValue(t).filter(i=>i.on>=0||i.id===a).map(i=>({value:i.id,title:i.url+` [${i.id}]`,icon:i.id===e.toValue(a)?"":"",content:i.name}))),w=-1,h=-2,O=-1,ye={0:"Yandex",1:"Google",4:"YouTube",5:"Bing",7:"Seznam",8:"AppStore",9:"GoogleStore",20:"Yandex.com",21:"Yandex.com.tr"},_={key:h,name:"--",index:h},ee={key:h,name:"--",regions:[_],regionByIndex:new Map([[h,_]])},R={key:h,name:"Autoselect",index:h},J={key:h,name:"Autoselect",regions:[R],regionByIndex:new Map([[h,R]])},te={countryCode:"00",depth:1,device:0,key:O,index:O,lang:"ru",name:"Without region"},Ie=()=>(R.name=y.useI18n().Common.Autoselect,R),Se=()=>(Ie(),J.name=y.useI18n().Common.Autoselect,console.log(J),J),ke=()=>(te.name=y.useI18n().Keywords.Without_region,te),Y=(t=!1,a=!1,l=[])=>{let o;return t?o=xe(l):o=oe(l),a&&o.set(h,Se()),o.size||o.set(h,ee),o},oe=(t,a=!0,l=[],o=!1)=>{const i=new Map;return t.forEach(n=>{if(!n.enabled||o&&typeof n.key=="number"&&n.key>1)return;const r={...n};r.regionByIndex=new Map,n.regions&&n.regions.forEach(c=>{if(a&&!c.enabled)return;const m={...c};r.regionByIndex.set(m.index,m)}),!r.regionByIndex.size&&l.length,(!n.regions||r.regionByIndex.size||l.length)&&i.set(r.key,r)}),l.forEach(n=>{if(i.has(n))return;const r={key:n,name:ye[n],regions:[],regionByIndex:new Map};i.set(r.key,r)}),i},xe=t=>{const a=oe(t,!1,[0,1],!0);if(a.has(2)){const l=a.get(2);l&&(l.regionByIndex=new Map)}return a.forEach(l=>{if(!l.regionByIndex)return;const o={...ke()};l.regionByIndex.set(o.index,o)}),a},le=(t,a,l=[])=>{const o=Y(t,!1,l);let i;return o.forEach(n=>{if(!(a.searcher_key!==void 0&&a.searcher_key!=n.key)&&n.regions&&(n.regions.forEach(r=>{if(!i&&!(a.key!==void 0&&a.key!=r.key)&&!(a.index!==void 0&&a.index!=r.index)&&!(!t&&(a.lang!==void 0&&a.lang!=r.lang||a.device!==void 0&&a.device!=r.device)))return r.searcher_key=n.key,i=r,!1}),i))return!1}),i},ne=fe.useAsyncTopDialog(()=>new Promise((t,a)=>se(["../.chunks/dialog_regionSelectorRegions-CZ0tMVSq.amd"],t,a))),Be=(t,a)=>{const l=y.useI18n(),o=e.ref(a.value.keys().next().value??h),i=e.computed(()=>{const n=new Map;if(a.value.forEach(r=>{let c={value:r.key,title:r.name};t.addSearcherIcon&&(c.icon=W.getSearcherGIcon(r.key)),n.set(r.key,c)}),t.addCompare&&!n.has(h)){const r={value:"",title:"--------------------",disabled:!0};n.set(r.value,r);const c={value:w,title:l.Common.Compare};n.set(c.value,c)}return n});return{searcherKey:o,optionBySearcherKey:i}},Ce=(t,a)=>{const l=y.useI18n(),o=e.ref(h);t.modelValue.length===1&&(o.value=t.modelValue[0]),o.value===h&&(t.forFrequency?o.value=a.value?.regionByIndex.values().next().value?.key??h:o.value=a.value?.regionByIndex.keys().next().value??h);const i=e.computed(()=>{const n=new Map;return a.value.regionByIndex?.forEach(r=>{let c=r.name;if(t.forFrequency){const k={value:r.key,title:c};n.has(r.key)||n.set(r.key,k);return}r.device&&(c+=" ("+l.Common["Device_"+r.device]+")");const m=W.getLangLabel(a.value.key||0,r.lang??"");m&&(c+=" / "+m);const f={value:r.index,title:c,icon:r.device?W.getDeviceGIcon(r.device):void 0};n.set(r.index,f)}),n});return e.watch(i,(n,r)=>{if(t.onlySearcher||o.value!==void 0&&n.get(o.value))return;let c=n.keys().next().value;if(o.value===h||c===h){o.value=c;return}let m=r?.get(o.value)?.title||"",f=-1;for(const[k,d]of n.entries()){const v=d.title;if(typeof v!="string"||typeof k=="string")break;if(v===m){c=k;break}const u=new RegExp(` \\((${l.Common.Device_1}|${l.Common.Device_2})\\)`);let s=m,g=3;v.indexOf(s)===-1&&(s=m.replace(/^[^a-zа-я]/i,"").replace(u,""),g--),v.indexOf(s)===-1&&(s=m.replace(/ \/.*/,""),g--),v.indexOf(s)===-1&&(s=m.replace(/ \/.*/,""),s=s.replace(/^[^a-zа-я]/i,"").replace(u,""),g--),v.indexOf(s)!==-1&&(g<=f||(f=g,c=k))}o.value=c}),{regionIndex:o,optionByRegionIndex:i}},Te=(t,a,l)=>{const o=e.ref([]),i=()=>{if(t.onlySearcher&&a.value){o.value=Array.from(a.value.keys());return}let r=[];if(t.modelValue.length>1)r=[...t.modelValue];else try{r=JSON.parse(localStorage.getItem("ui:project:regionSelector"+t.projectId+":regionsIndexes"))??[]}catch{}r.length&&(r=r.filter(c=>l.value.has(c))),r.length||(r=Array.from(l.value)),o.value=[...r]},n=()=>{o.value.length?localStorage.setItem("ui:project:regionSelector:"+t.projectId+":regionsIndexes",JSON.stringify(o.value)):localStorage.removeItem("ui:project:regionSelector:"+t.projectId+":regionsIndexes")};return e.watch(o,()=>{n()}),t.addCompare&&i(),{regionsIndexes:o}},we=t=>{const a=e.computed(()=>Y(t.forFrequency,t.autoRegion,t.searchers)),l=e.computed(()=>a.value.get(i.searcherKey.value)||ee),o=e.computed(()=>{const d=new Set;return a.value.forEach(v=>{v.regionByIndex.forEach(u=>{u.index!==O&&u.index!==h&&d.add(u.index)})}),d}),i=Be(t,a),n=Ce(t,l),r=Te(t,a,o);e.watch(a,()=>{if(t.onlySearcher?r.regionsIndexes.value=Array.from(a.value.keys()):r.regionsIndexes.value=r.regionsIndexes.value.filter(v=>o.value.has(v)),i.searcherKey.value===w)return;let d=a.value.keys().next().value;a.value.forEach(v=>{if(t.onlySearcher&&v.key===i.searcherKey.value){d=i.searcherKey.value;return}if(n.regionIndex.value&&v.regionByIndex?.has(n.regionIndex.value)&&(d=v.key),!t.onlySearcher){let u;d!==void 0&&(u=a.value.get(d)?.regionByIndex);const s=a.value.get(v.key)?.regionByIndex;u?.has(h)&&!s?.has(h)&&(d=v.key)}}),d!==void 0&&(i.searcherKey.value=d),n.regionIndex.value!==void 0&&!l.value?.regionByIndex?.has(n.regionIndex.value)&&(n.regionIndex.value=l.value?.regions?.keys().next().value)},{immediate:!0});const c=()=>{if(!(i.searcherKey.value===w||i.searcherKey.value===h))return i.searcherKey.value},m=()=>{if(t.onlySearcher||n.regionIndex.value===h)return;let d=n.regionIndex.value;if(t.forFrequency){const v=n.regionIndex.value;d=le(t.forFrequency,{searcher_key:c(),key:v},t.searchers)?.index}return d},f=()=>{const d=c();if(d!==void 0)return a.value.get(d)};return{selectSearcher:i,selectRegion:n,compare:r,searcherByKey:a,allRegionsIndexes:o,getSearcher:f,getRegion:()=>{const d=m();if(d!==void 0)return f()?.regionByIndex?.get(d)}}},Me=e.defineComponent({__name:"regionSelector",props:e.mergeModels({projectId:{},searchers:{default:()=>[]},modelValue:{},modelValueSingle:{},addCompare:{type:Boolean},forFrequency:{type:Boolean},autoRegion:{type:Boolean},onlySearcher:{type:Boolean},addChanger:{type:Boolean,default:!0},addSearcherIcon:{type:Boolean,default:!0},addRegionIcon:{type:Boolean,default:!0}},{modelValue:{required:!0},modelModifiers:{},modelValueSingle:{},modelValueSingleModifiers:{}}),emits:["update:modelValue","update:modelValueSingle"],setup(t,{expose:a}){const l=t,o=e.useModel(t,"modelValue"),i=e.useModel(t,"modelValueSingle"),{selectSearcher:n,selectRegion:r,compare:c,searcherByKey:m,allRegionsIndexes:f,getSearcher:k,getRegion:d}=we(l),v=()=>{const u=[];m.value.forEach(s=>{s.enabled&&s.regions.forEach(g=>{g.enabled&&u.push(g)})}),ne.open("regions",{regions:u,regionsIndexes:c.regionsIndexes.value,"@update:regionsIndexes":s=>c.regionsIndexes.value=s})};return e.watch([r.regionIndex,n.searcherKey,c.regionsIndexes],()=>{if(n.searcherKey.value===w&&c.regionsIndexes.value.length){if(JSON.stringify(o.value)===JSON.stringify(c.regionsIndexes.value))return;o.value=[...c.regionsIndexes.value]}else l.onlySearcher?(o.value=[n.searcherKey.value],n.searcherKey.value===h&&!l.autoRegion&&(o.value.length=0)):(o.value=[r.regionIndex.value],r.regionIndex.value===h&&!l.autoRegion&&(o.value.length=0));!l.onlySearcher&&!f.value.size&&(n.searcherKey.value=h)}),i.value&&e.watch(i,()=>{i.value&&(o.value=[i.value])},{immediate:!0}),e.watch(o,()=>{if(o.value[0]&&(i.value=o.value[0]),l.onlySearcher){if(!o.value.length||o.value.length===1&&!m.value.has(o.value[0])||o.value.length===1&&o.value[0]===h&&!l.autoRegion){let u=m.value.keys().next().value;u===h&&!l.autoRegion&&(u=void 0,i.value=h),u!==void 0?o.value=[u]:o.value.length=0;return}if(o.value.length>1&&JSON.stringify(o.value)!==JSON.stringify(c.regionsIndexes.value)){o.value=[...c.regionsIndexes.value];return}}else{let u=[...new Set(o.value)],s=m.value.values().next().value?.regionByIndex?.keys().next().value;if(l.forFrequency&&(s=m.value.values().next().value?.regionByIndex?.values().next().value?.key),s===h&&!l.autoRegion&&(s=void 0,i.value=h),!u.length)s!==void 0&&u.push(s);else if(u.length===1){let g=f.value;l.forFrequency&&(g=new Set,m.value.forEach(U=>{U.regionByIndex.forEach(N=>{N.index!==O&&N.index!==h&&g.add(N.key)})})),g.has(u[0])||(u=[],s!==void 0&&u.push(s))}else u=u.filter(g=>f.value.has(g)),!u.length&&s!==void 0&&u.push(s);if(JSON.stringify(o.value)!==JSON.stringify(u)){o.value=u;return}}if(!(o.value.length===1&&o.value[0]===(l.onlySearcher?n.searcherKey.value:r.regionIndex.value)))if(l.onlySearcher){if(o.value.length===1){n.searcherKey.value=o.value[0];return}n.searcherKey.value=w;return}else{if(!o.value.length)return;if(o.value.length===1&&n.searcherKey.value!==w){r.regionIndex.value=o.value[0];let u;for(const s of m.value.values()){for(const g of s.regionByIndex.values())if((l.forFrequency?g.key:g.index)===r.regionIndex.value){u=s.key;break}if(u!==void 0)break}u!==void 0&&(n.searcherKey.value=u)}else n.searcherKey.value=w,c.regionsIndexes.value=[...o.value]}},{immediate:!0}),a({getSearcher:k,getRegion:d}),(u,s)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass({"top-selectorRegion":!0,"top-selectorRegion-onlySearcher":t.onlySearcher})},[e.createVNode(y._sfc_main$10,{options:e.unref(n).optionBySearcherKey.value,modelValue:e.unref(n).searcherKey.value,"onUpdate:modelValue":s[0]||(s[0]=g=>e.unref(n).searcherKey.value=g),name:"searcher_key",addChanger:t.addChanger},null,8,["options","modelValue","addChanger"]),!t.onlySearcher&&e.unref(n).searcherKey.value!==e.unref(w)?(e.openBlock(),e.createBlock(y._sfc_main$10,{key:0,class:"top-select-region",options:e.unref(r).optionByRegionIndex.value,modelValue:e.unref(r).regionIndex.value,"onUpdate:modelValue":s[1]||(s[1]=g=>e.unref(r).regionIndex.value=g),name:t.forFrequency?"region_key":"region_index",addChanger:t.addChanger,"data-top-icon":t.addRegionIcon?"":void 0},null,8,["options","modelValue","name","addChanger","data-top-icon"])):e.createCommentVNode("",!0),t.addCompare&&!t.onlySearcher&&e.unref(n).searcherKey.value===e.unref(w)?(e.openBlock(),e.createBlock(y._sfc_main$1,{key:1,name:"compare",onClick:v,"data-count-compare-regions-indexes":e.unref(c).regionsIndexes.value.length},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(u.$i18n.Common.Selected_regions),1)]),_:1},8,["data-count-compare-regions-indexes"])):e.createCommentVNode("",!0)],2))}}),M={id:0,name:"/",path:"/"};function Ve(t){return t?y.useI18n()?.Common.All_folders:"/ ("+y.useI18n()?.Keywords.Root_folder+")"}const Q=(t,a,l=new Map,o={id:"root"},i=0)=>(o.childsIds=[],o.id&&(o.countAllGroupsActive=o.count_groups_active),t[o.id]&&t[o.id].forEach(n=>{n={...n},o.childsIds.push(n.id),n.id===0&&(n.name=Ve(a));const r=i>1?"-".repeat(i-1)+" ":"";r&&!n.name.startsWith(r)&&(n.name=r+n.name),l.set(n.id,n),Q(t,a,l,n,i+1),o.childsIds=o.childsIds.concat(n.childsIds),o.id&&n.count_groups_active&&(o.countAllGroupsActive+=n.count_groups_active)}),l),Ae=(t,a)=>t.gen(`/get/${a}/folders/`,["id","parent_id","name","path"]).changeParams({orders:["ord_path"],limit:100});function X(t,a,l){const o=Object.keys(t),i=o.map(n=>t[n]);return e.watch(i,(n,r,c)=>{const m={};n.forEach((f,k)=>{if(!Object.is(f,r[k])){const d=o[k];m[d]={old:r[k],new:f}}}),Object.keys(m).length&&a(m,c)},l)}const Ee=e.defineComponent({__name:"folders",props:e.mergeModels({folderId:{},folder:{},folders:{},projectId:{},canSelectAll:{type:Boolean},addChanger:{type:Boolean},addIcon:{type:Boolean,default:!0},client:{},service:{}},{folderId:{required:!0},folderIdModifiers:{},folder:{default:M},folderModifiers:{}}),emits:["update:folderId","update:folder"],setup(t){const a=t,l=e.useModel(t,"folderId"),o=e.useModel(t,"folder"),i=a.client&&!a.folders?Ae(a.client,a.service):void 0,n=e.ref(null);e.watch(()=>a.projectId,()=>{i?.changeParams({project_id:a.projectId}),i?.setOptions({checkFingerprint:"TopGroupSelectorFolders:"+a.projectId}),n.value?.resetCache()},{immediate:!0});const r=e.computed(()=>Q(a.folders??{root:[M]},a.canSelectAll));return X({modelFolder:o,modelFolderId:l},async c=>{if(l.value===o.value.id)return;if(c.modelFolder&&!c.modelFolderId){l.value=o.value.id;return}let m=r.value.get(a.folderId);m||(m=M),o.value=m,l.value=m.id},{immediate:!0}),(c,m)=>(e.openBlock(),e.createBlock(C._sfc_main,{class:"top-groupSelector_folder",modelValue:o.value,"onUpdate:modelValue":m[0]||(m[0]=f=>o.value=f),items:t.folders?[...r.value.values()]:void 0,"search-type":"inline",icon:t.addIcon?"":void 0,api:t.folders?void 0:e.unref(i),apiSetSearchParams:(...f)=>e.unref(C.apiSetSearchParamsFilter)(...f,"name"),addChanger:t.addChanger,useCache:""},null,8,["modelValue","items","icon","api","apiSetSearchParams","addChanger"]))}}),j={id:-1,name:"--",folder_id:M.id,folder_path:M.path},D={id:C.ITEM_ID_ALL,name:"All groups",folder_id:M.id,folder_path:M.path},E=()=>(D.name=y.useI18n()?.Common.All_groups,D),ae=()=>(D.name=y.useI18n()?.Keywords.Choose_group,D),be=(t,a,l)=>(t=[...t],a!==void 0&&(t=t.filter(o=>o.on==Number(a))),l&&l.id&&l.childsIds&&(t=t.filter(o=>o.folder_id===l.id||l.childsIds.includes(o.folder_id))),t),re=(t,a)=>t.gen(`/get/${a}/groups/`,["id","name","folder_id","folder_path"]).changeParams({folder_id_depth:!0,limit:100}),$e=(t,a)=>t.gen(`/add/${a}/groups/`),Ne={class:"top-groupSelector_groupItem"},Ge={key:0,class:"top-comment"},Ke={key:1,class:"top-groupSelector_groupItemFolderPath"},Le=e.defineComponent({__name:"groups",props:e.mergeModels({groupId:{},group:{},projectId:{},folder:{},groups:{},on:{type:Boolean,default:void 0},canAdd:{type:[String,Boolean]},canSelectAll:{type:[Boolean,String]},autoselect:{default:"first"},addChanger:{type:Boolean,default:!0},showPath:{type:Boolean},addIcon:{type:Boolean,default:!0},client:{},service:{}},{groupId:{required:!0},groupIdModifiers:{},group:{required:!0},groupModifiers:{}}),emits:e.mergeModels(["addGroup"],["update:groupId","update:group"]),setup(t,{emit:a}){const l=t,o=a,i=e.useModel(t,"groupId"),n=e.useModel(t,"group"),r=l.client&&!l.groups?re(l.client,l.service):void 0,c=l.client?$e(l.client,l.service):void 0,m=e.ref(null),f=e.ref(void 0),k=H.genFieldFilter("folder_id","EQUALS",[l.folder?.id??0]);r?.changeParams({project_id:l.projectId,folder_id_depth:!0,filters:[k]}),l.on!==void 0&&r?.params.filters?.push(H.genFieldFilter("on","EQUALS",[Number(l.on)]));const d=u=>{n.value=u,i.value=u.id};X({projectId:()=>l.projectId,folderId:()=>l.folder?.id,canSelectAll:()=>l.canSelectAll},u=>{if(u.projectId&&(r?.changeParams({project_id:l.projectId}),r?.setOptions({checkFingerprint:"TopGroupSelectorGroups:"+l.projectId})),u.folderId&&(k.values=[l.folder?.id??0],l.groups&&(f.value=be(l.groups,l.on,l.folder))),m.value?.resetCache(),(u.folderId?.old!==void 0||u.canSelectAll?.old!==void 0)&&i.value!==C.ITEM_ID_NEW){let s;l.autoselect==="first"&&(s=f.value?.[0],l.canSelectAll&&(s=e.reactive(E()))),(l.autoselect==="placeholder"||!s)&&(s=ae()),d(s)}},{immediate:!0}),X({modelGroup:n,modelGroupId:i},async u=>{if(i.value!==n.value.id){if(u.modelGroup&&!u.modelGroupId){i.value=n.value.id;return}if(!(l.canAdd&&i.value===C.ITEM_ID_NEW)){if(l.groups){let s=f.value?.find(g=>g.id===i.value);if(!s&&l.canSelectAll&&(s=E()),s)d(s);else{const g=f.value?.[0];g&&!i.value?d(g):d(j)}}if(l.client&&!l.groups&&(i.value||i.value===C.ITEM_ID_ALL&&!l.canSelectAll)){const s=re(l.client,l.service).changeParams({project_id:l.projectId,id:i.value,filters:[k]});s?.setOptions({checkFingerprint:"TopGroupSelectorFindGroup:"+l.projectId});const g=await s.call();if(!g.errors?.length&&!g.result)return;!g.errors&&g.result[0]?d(g.result[0]):d(j)}}}},{immediate:!0});const v=async u=>{if(l.canAdd!=="api"||!c)return;const s=n.value,g=await c.changeParams({project_id:l.projectId,names:[u.name],to_id:l.folder?.id??M.id,to_type:"in_folder_last"}).call();g.result?(d(g.result),o("addGroup",g.result)):d(s),m.value?.resetCache(!0)};return(u,s)=>(e.openBlock(),e.createBlock(C._sfc_main,{ref_key:"refSelector",ref:m,class:"top-groupSelector_group",modelValue:n.value,"onUpdate:modelValue":s[0]||(s[0]=g=>n.value=g),items:f.value??t.groups,searchType:"inline",icon:t.addIcon?"":void 0,api:t.groups?void 0:e.unref(r),apiSetSearchParams:(...g)=>e.unref(C.apiSetSearchParamsFilter)(...g,"name"),appendSearchToResult:!!t.canAdd,useAllItem:t.canSelectAll?e.unref(E)().name:!1,addChanger:t.addChanger,useCache:"",onAppendItem:v},{item:e.withCtx(({item:g})=>[e.createElementVNode("div",Ne,[g.id===e.unref(C.ITEM_ID_NEW)?(e.openBlock(),e.createElementBlock("div",Ge,e.toDisplayString(u.$i18n.Common.Add)+": ",1)):e.createCommentVNode("",!0),e.createElementVNode("span",null,e.toDisplayString(g.name),1),g.folder_path&&t.showPath?(e.openBlock(),e.createElementBlock("span",Ke,e.toDisplayString(g.folder_path),1)):e.createCommentVNode("",!0)])]),_:1},8,["modelValue","items","icon","api","apiSetSearchParams","appendSearchToResult","useAllItem","addChanger"]))}}),Oe={class:"top-groupSelector"},Re=e.defineComponent({__name:"groupSelector",props:e.mergeModels({folderId:{},folder:{},groupId:{},group:{},projectId:{},folders:{},groups:{},on:{type:Boolean,default:void 0},canSelectAllGroups:{type:Boolean},canAddGroup:{},autoselect:{default:"first"},addChanger:{type:Boolean,default:!0},showFolders:{type:Boolean,default:!0},showGroups:{type:Boolean,default:!0},addIcon:{type:Boolean,default:!0},client:{},service:{default:"keywords_2"}},{folderId:{required:!0},folderIdModifiers:{},folder:{},folderModifiers:{},groupId:{required:!0},groupIdModifiers:{},group:{default:j},groupModifiers:{}}),emits:e.mergeModels(["update:groups"],["update:folderId","update:folder","update:groupId","update:group"]),setup(t,{emit:a}){const l=t,o=e.useModel(t,"folderId"),i=e.useModel(t,"folder"),n=e.useModel(t,"groupId"),r=e.useModel(t,"group"),c=a,m=Q(l.folders??{root:[M]},l.canSelectAllGroups);i.value=m.get(o.value);let f=l.groups?.find(d=>d.id===n.value);n.value||(f=l.groups?.[0]),l.canSelectAllGroups&&!f&&(f=E()),l.canSelectAllGroups&&!f&&(f=E()),(l.autoselect==="placeholder"||!f)&&(f=ae()),f??=j,r.value=f;const k=d=>{let v;l.groups&&d&&(v=[...l.groups,d]),c("update:groups",v)};return(d,v)=>(e.openBlock(),e.createElementBlock("div",Oe,[t.showFolders?(e.openBlock(),e.createBlock(Ee,{key:0,folderId:o.value,"onUpdate:folderId":v[0]||(v[0]=u=>o.value=u),folder:i.value,"onUpdate:folder":v[1]||(v[1]=u=>i.value=u),projectId:t.projectId,folders:t.folders,canSelectAll:t.canSelectAllGroups,addChanger:t.addChanger,addIcon:t.addIcon,client:t.client,service:t.service},null,8,["folderId","folder","projectId","folders","canSelectAll","addChanger","addIcon","client","service"])):e.createCommentVNode("",!0),t.showGroups?(e.openBlock(),e.createBlock(Le,{key:1,groupId:n.value,"onUpdate:groupId":v[2]||(v[2]=u=>n.value=u),group:r.value,"onUpdate:group":v[3]||(v[3]=u=>r.value=u),projectId:t.projectId,folder:i.value,groups:t.groups,on:t.on,canAdd:t.canAddGroup,canSelectAll:t.canSelectAllGroups,autoselect:t.autoselect,addChanger:t.addChanger,showPath:t.showFolders&&!!t.folders?.[0],addIcon:t.addIcon,client:t.client,service:t.service,onAddGroup:k},null,8,["groupId","group","projectId","folder","groups","on","canAdd","canSelectAll","autoselect","addChanger","showPath","addIcon","client","service"])):e.createCommentVNode("",!0)]))}}),ie=t=>"-"+t,b=t=>t[0]==="-"?t.substring(1):t,P=(t,a)=>{t=b(t);const l=a.find(o=>o.id===t);if(l)return l},je=(t,a,l)=>{a||(a={id:t.id}),a.id=t.id,a.pos??="3",a.notch??=!0,a.posBy??="fixed";const o=ge.TopPopupWorker.genElPopupOpener("div",a);return o.classList.add("top-tagSelector"),t.useTopButton&&o.classList.add("top-tagSelector-useTopButton","top-button","top-color_theme","top-as-selector"),t.useTopButton||o.classList.add("top-tagSelector-custom"),t.mode==="filter"&&o.classList.add("top-tagSelector-filter"),t.mode==="setter"&&!t.filters&&o.classList.add("top-tagSelector-setter_single"),t.mode==="setter"&&t.filters&&o.classList.add("top-tagSelector-setter_several"),o.onclick=i=>{i.preventDefault(),i.stopPropagation(),o.onclick=null;const n=e.ref(t.modelValue),r={model:n,mode:t.mode,targetId:t.targetId,filters:t.filters,payload:t.payload};A.storage(o,"topTagSelectorTarget",r),delete o.dataset.topPopupDisabled,e.isRef(t.modelValue)||e.watch(n,()=>{t.modelValue=n.value,F(o,t,l)}),o.click()},e.isRef(t.modelValue)?e.watch(t.modelValue,()=>F(o,t,l)):A.storage(o,"topTagSelectorRender",i=>{t.modelValue=i;const n=A.storage(o,"topTagSelectorTarget");n&&(n.model.value=i),F(o,t,l)}),F(o,t,l),o},De=(t,a)=>{A.storage(t,"topTagSelectorRender")?.(a)},F=(t,a,l)=>{const o=e.unref(a.modelValue);if(t.classList.toggle("top-tagSelector-selectedOne",!o.length||o.length===1),t.classList.toggle("top-tagSelector-toTwoLine",o.length>5),a.mode==="setter"&&a.filters){t.innerHTML=`<div>${l}</div>`;return}if(t.innerHTML="",!o.length&&a.mode==="filter"){const i=de({id:"all",colorId:"",name:y.useI18n().Common?.All_tags??"",state:""});t.append(i)}o.forEach(i=>{const n=de({id:b(i),colorId:P(i,a.tags)?.color_id??"",name:P(i,a.tags)?.name??"",state:b(i)===i?"selected":"excluded"});t.append(n)})},de=t=>{const a=document.createElement("div");return a.classList.add("top-tagSelector_tagIcon"),a.classList.toggle("top-tagSelector-active",!!t.state),a.classList.toggle("top-tagSelector-excluded",t.state==="excluded"),a.dataset.tag_id=t.id,a.dataset.tag_color_id=t.colorId,a.title=t.name,a},Pe=[{id:"1",name:"Without Tag",color_id:"1"},{id:"2",name:"Red",color_id:"2"},{id:"3",name:"Orange",color_id:"3"},{id:"4",name:"Yellow",color_id:"4"},{id:"5",name:"Blue",color_id:"5"},{id:"6",name:"Purple",color_id:"6"},{id:"7",name:"Green",color_id:"7"},{id:"8",name:"Magenta",color_id:"8"},{id:"9",name:"Dark blue",color_id:"9"},{id:"10",name:"Turquoise",color_id:"10"}],Fe=["data-tag_id","data-tag_color_id","title"],q=e.defineComponent({__name:"tagIcon",props:{id:{},colorId:{},name:{},state:{}},setup(t){return(a,l)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass({"top-tagSelector_tagIcon":!0,"top-tagSelector-active":!!t.state,"top-tagSelector-excluded":t.state==="excluded"}),"data-tag_id":t.id,"data-tag_color_id":t.colorId,title:t.name},null,10,Fe))}}),qe=["contenteditable","onKeydown"],ue=e.defineComponent({__name:"tagPopupListItem",props:e.mergeModels({editable:{type:Boolean},disabled:{type:Boolean},canExclude:{type:Boolean},id:{},colorId:{},name:{},state:{}},{name:{required:!0},nameModifiers:{}}),emits:e.mergeModels(["update:name","unselect","exclude","select"],["update:name"]),setup(t,{emit:a}){const l=t,o=a,i=e.useModel(t,"name"),n=e.ref(null),r=e.computed(()=>navigator.userAgent.indexOf("Firefox")!=-1?{contenteditable:c.value,onpaste:v=>v.preventDefault()}:{}),c=e.ref(!1),m=async()=>{c.value=!0,await e.nextTick(),n.value?.focus()},f=()=>{const v=n.value?.innerText;if(!v)return k();n.value&&(n.value.innerText=v),c.value=!1,o("update:name",v)},k=async()=>{n.value&&(n.value.innerText=l.name),c.value=!1},d=v=>{if(c.value||l.disabled)return;let u="selected";l.canExclude&&(v.ctrlKey||v.metaKey)&&(u="excluded"),l.state==u&&(u=""),u===""&&o("unselect"),u==="selected"&&o("select"),u==="excluded"&&o("exclude")};return(v,u)=>(e.openBlock(),e.createBlock(V._sfc_main$2,{class:e.normalizeClass({"top-tagSelector_tagListItem":!0,"top-tagSelector_tagListItem-inEdit":c.value,"top-tagSelector_tagListItem-disabled":t.disabled,"top-tagSelector_tagListItem-canExclude":t.canExclude,"top-tagSelector-active":!!t.state,"top-tagSelector-excluded":t.state==="excluded"}),onClick:e.withModifiers(d,["stop"])},{default:e.withCtx(()=>[e.createVNode(q,{id:t.id,name:i.value,colorId:t.colorId,state:t.state},null,8,["id","name","colorId","state"]),e.createElementVNode("span",e.mergeProps({ref_key:"elName",ref:n,class:"top-tagSelector_tagListItemName",contenteditable:c.value?"plaintext-only":!1},r.value,{onKeydown:[e.withKeys(e.withModifiers(f,["stop"]),["enter"]),e.withKeys(e.withModifiers(k,["stop"]),["esc"])]}),e.toDisplayString(i.value),17,qe),t.editable?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[c.value?(e.openBlock(),e.createElementBlock("span",{key:1,"data-top-icon":"",class:"top-tagSelector_edit",onClick:e.withModifiers(f,["stop"])})):(e.openBlock(),e.createElementBlock("span",{key:0,"data-top-icon":"",class:"top-tagSelector_edit",onClick:m}))],64)):e.createCommentVNode("",!0)]),_:1},8,["class"]))}}),Ue={key:1},ce=e.defineComponent({inheritAttrs:!1,__name:"popupOpener",props:e.mergeModels({modelValue:{},id:{},tags:{},mode:{},targetId:{},filters:{},useTopButton:{type:Boolean},payload:{},styling:{}},{modelValue:{required:!0},modelModifiers:{}}),emits:["update:modelValue"],setup(t){const a=t,l=e.useModel(t,"modelValue"),o=a.useTopButton?y._sfc_main$1:"div",i=a.useTopButton?"html":"default",n={model:l,mode:a.mode,targetId:a.targetId,filters:a.filters,payload:a.payload};return(r,c)=>{const m=e.resolveDirective("top-data");return e.openBlock(),e.createBlock(V._sfc_main$1,{id:t.id},{default:e.withCtx(()=>[e.withDirectives((e.openBlock(),e.createBlock(e.resolveDynamicComponent(e.unref(o)),e.mergeProps({class:{"top-tagSelector":!0,"top-tagSelector-useTopButton":a.useTopButton,"top-tagSelector-custom":!a.useTopButton,"top-as-selector":a.useTopButton,"top-tagSelector-filter":a.mode==="filter","top-tagSelector-setter_single":a.mode==="setter"&&!t.filters,"top-tagSelector-setter_several":a.mode==="setter"&&t.filters,"top-tagSelector-selectedOne":!l.value.length||l.value.length===1,"top-tagSelector-toTwoLine":l.value.length>5},color:"theme",styling:t.styling},r.$attrs),{[e.unref(i)]:e.withCtx(()=>[!l.value.length&&t.mode==="filter"?(e.openBlock(),e.createBlock(q,{key:0,id:"all",colorId:"",name:r.$i18n.Common.All_tags??"",state:""},null,8,["name"])):e.createCommentVNode("",!0),t.mode==="setter"&&t.filters?(e.openBlock(),e.createElementBlock("div",Ue,[e.renderSlot(r.$slots,"default")])):(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:2},e.renderList(l.value,f=>(e.openBlock(),e.createBlock(q,{id:e.unref(b)(f),colorId:e.unref(P)(f,t.tags)?.color_id??"",name:e.unref(P)(f,t.tags)?.name??"",state:e.unref(b)(f)===f?"selected":"excluded"},null,8,["id","colorId","name","state"]))),256))]),_:2},1040,["class","styling"])),[[m,n,"topTagSelectorTarget"]])]),_:3},8,["id"])}}}),ze=e.defineComponent({__name:"tagSelector",props:e.mergeModels({modelValue:{},tags:{},tagsEditable:{type:Boolean},tagsMax:{default:10},id:{},singleMode:{type:Boolean},requiredForSetter:{type:Boolean,default:!0},maxTagsForSetter:{},emitDelay:{default:500},useTopButton:{type:Boolean,default:!0},styling:{}},{modelValue:{required:!0},modelModifiers:{},tags:{default:e.reactive(Pe)},tagsModifiers:{}}),emits:e.mergeModels(["selector","setter","tagsChanged"],["update:modelValue","update:tags"]),setup(t,{emit:a}){const l=y.useI18n(),o=t,i=e.useModel(t,"modelValue"),n=e.useModel(t,"tags"),r=a,c=y.debounce((p,I)=>{r(p,I)},o.emitDelay);o.singleMode&&!i.value.length&&(i.value=[n.value[0].id]);const m=o.id??"top-popup-id-"+Math.random(),f=e.ref("add"),k=()=>{const p=" "+l.Common.Tags?.toLowerCase(),I=new Map;return I.set("add",{value:"add",title:l.Common.Add+p}),I.set("replace",{value:"replace",title:l.Common.Replace+p}),I.set("delete",{value:"delete",title:l.Common.Delete+p}),I};let d=e.shallowRef({model:i,mode:"filter",targetId:void 0,filters:void 0,payload:void 0});e.watch(i,()=>{c("selector",i.value)});const v=e.computed(()=>{if(d.value.mode==="setter"&&o.maxTagsForSetter&&!d.value.filters)return d.value.model.value.length>=o.maxTagsForSetter}),u=p=>{if(p!=="all"){if(d.value.model.value.includes(p))return"selected";if(d.value.model.value.includes(ie(p)))return"excluded"}return p==="all"&&!d.value.model.value.length?"selected":""},s=(p,I)=>{const S=ie(p);let x=d.value.model.value.filter(T=>T!==p&&T!==S);I==="select"&&x.push(p),I==="exclude"&&x.push(S),d.value.mode==="setter"&&d.value.targetId!==void 0&&o.requiredForSetter&&(x.length||x.push("1"),x.length===2&&d.value.model.value.length===1&&d.value.model.value[0]==="1"&&(x=x.filter(T=>T!=="1"))),o.singleMode&&!d.value.filters&&(x.length||(x=d.value.model.value),x.length>1&&(x=[x[x.length-1]])),x.sort((T,z)=>{if(!o.tags)return 0;const G=o.tags.findIndex(L=>L.id===T),K=o.tags.findIndex(L=>L.id===z);return G-K}),d.value.model.value=x,d.value.mode==="setter"&&d.value.targetId!==void 0&&c("setter",{tagsIds:x,targetId:d.value.targetId,payload:d.value.payload})},g=e.computed(()=>{let p="top-tagSelector_popup";return d.value.mode==="filter"&&(p+=" top-tagSelector_popup-filter"),d.value.mode==="setter"&&(p+=" top-tagSelector_popup-setter"),p}),U=()=>{const p=prompt("","New tag");if(!p||p==="New tag")return;const I=n.value.length+1;n.value.push({id:String(I),name:p,color_id:String((I-1)%10+1)}),r("tagsChanged",n.value)},N=p=>{if(d.value=A.storage(p.elPopupOpener,"topTagSelectorTarget"),!d.value)throw new Error("Open popup TopTagSelector required v-data:topTagSelectorTarget");if(d.value.filters&&(f.value="add",d.value.model.value=[]),!y.Core.$?.ui.sortable){console.info("Для работы сортировки требуется глобальная загрузка jQuery UI Sortable");return}!y.Core.state.isMobile&&!y.Core.state.isMobileUA&&n.value&&$(p.elPopup).sortable({items:'li:has([data-tag_id]:not([data-tag_id="all"]))',cancel:'[contenteditable="plaintext-only"], [contenteditable="true"]',distance:10,stop:function(I,S){if(!n.value)return;const x=$(S.item).parent().find("[data-tag_id]"),T=[];x.each((z,G)=>{if(!n.value)return;const K=$(G).attr("data-tag_id");T.push(K)}),n.value.sort((z,G)=>{const K=T.findIndex(Z=>Z===z.id),L=T.findIndex(Z=>Z===G.id);return K-L}),c("tagsChanged",n.value)}})},We=p=>{y.Core.$?.ui.sortable&&$(p.elPopup).data("ui-sortable")&&$(p.elPopup).sortable("destroy")};return(p,I)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createVNode(ce,{modelValue:i.value,"onUpdate:modelValue":I[0]||(I[0]=S=>i.value=S),id:e.unref(m),tags:n.value,styling:t.styling,mode:"filter",useTopButton:t.useTopButton},null,8,["modelValue","id","tags","styling","useTopButton"]),e.createVNode(V._sfc_main,{id:e.unref(m),class:e.normalizeClass(g.value),onOpen:I[4]||(I[4]=S=>N(S)),onClose:I[5]||(I[5]=S=>We(S)),"transition-duration":50},e.createSlots({contentList:e.withCtx(()=>[e.unref(d).mode==="filter"&&!t.singleMode?(e.openBlock(),e.createBlock(ue,{key:0,id:"all",colorId:"",name:p.$i18n.Common.All_tags??"",state:e.unref(d).model.value.length?"":"selected",onSelect:I[3]||(I[3]=S=>e.unref(d).model.value=[])},null,8,["name","state"])):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(n.value,S=>(e.openBlock(),e.createBlock(ue,{key:S.id,id:S.id,colorId:S.color_id,name:S.name,state:u(S.id),canExclude:e.unref(d).mode==="filter"&&!t.singleMode,editable:t.tagsEditable,disabled:v.value&&u(S.id)==="",onUnselect:x=>s(S.id,"unselect"),onSelect:x=>s(S.id,"select"),onExclude:x=>s(S.id,"exclude"),"onUpdate:name":x=>{S.name=x,e.unref(c)("tagsChanged",n.value)}},null,8,["id","colorId","name","state","canExclude","editable","disabled","onUnselect","onSelect","onExclude","onUpdate:name"]))),128)),t.tagsEditable&&n.value.length<t.tagsMax&&n.value.length<20?(e.openBlock(),e.createBlock(V._sfc_main$2,{key:1,"data-top-icon":"",onClick:e.withModifiers(U,["stop"])},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(p.$i18n.Common.Add),1)]),_:1})):e.createCommentVNode("",!0)]),_:2},[e.unref(d).mode==="setter"&&e.unref(d).filters?{name:"header",fn:e.withCtx(()=>[e.createVNode(y._sfc_main$10,{modelValue:f.value,"onUpdate:modelValue":I[1]||(I[1]=S=>f.value=S),options:k()},null,8,["modelValue","options"])]),key:"0"}:void 0,e.unref(d).mode==="setter"&&e.unref(d).filters?{name:"footer",fn:e.withCtx(()=>[e.createVNode(y._sfc_main$1,{color:"theme"},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(p.$i18n.Common.Cancel),1)]),_:1}),e.createVNode(y._sfc_main$1,{onClick:I[2]||(I[2]=S=>e.unref(c)("setter",{tagsIds:e.unref(d).model.value,filters:e.unref(d).filters,filtersAction:f.value,payload:e.unref(d).payload}))},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(f.value==="add"?p.$i18n.Common.Add:"")+" "+e.toDisplayString(f.value==="replace"?p.$i18n.Common.Replace:"")+" "+e.toDisplayString(f.value==="delete"?p.$i18n.Common.Delete:""),1)]),_:1})]),key:"1"}:void 0]),1032,["id","class"])],64))}});B.TopCompetitorSelector=pe,B.TopGroupSelector=Re,B.TopRegionSelector=Me,B.TopTagSelector=ze,B.TopTagSelectorPopupOpener=ce,B.TopTagSelectorTagIcon=q,B.dialogRegionSelector=ne,B.findRegion=le,B.genElTopTagSelectorPopupOpener=je,B.genSearcherByKey=Y,B.renderElTopTagSelectorPopupOpener=De,B.useItemsFromCompetitors=he,Object.defineProperty(B,Symbol.toStringTag,{value:"Module"})}));
1
+ define(["require","exports","vue","../.chunks/forms-DDNzqU6o.amd","../.chunks/popupHint.vue_vue_type_style_index_0_lang-CdQostog.amd","../.chunks/policy.vue_vue_type_style_index_0_lang-BDyhjT5Y.amd","../.chunks/utils-CWn_G7OO.amd","../utils/searchers.amd","../.chunks/core-DzDFXOdI.amd","../.chunks/dialogs.vue_vue_type_script_setup_true_lang-BBix_8WK.amd","../.chunks/field-Cvv0SRcJ.amd","../utils/dom.amd","../popup/worker.amd","../require/css.amd!../assets/project.css"],(function(se,B,e,y,V,C,fe,W,Je,Ye,H,A,ge){"use strict";if(typeof e>"u")var e=window.Vue;const me={class:"top-competitorSelector"},ve={class:"top-ellipsis1"},pe=e.defineComponent({__name:"competitorSelector",props:e.mergeModels({modelValue:{},items:{},showSelectAllItem:{type:Boolean,default:!0}},{modelValue:{},modelModifiers:{}}),emits:["update:modelValue"],setup(t){const a=t,l=e.useModel(t,"modelValue"),o=e.computed(()=>{if(a.showSelectAllItem)return{icon:"",title:y.useI18n().Common.Select_all,value:"all",content:""}});return(i,n)=>(e.openBlock(),e.createElementBlock("div",me,[e.unref(y.Core).state.isMobile?(e.openBlock(),e.createBlock(V._sfc_main,{key:0},{opener:e.withCtx(()=>[e.createVNode(y._sfc_main$1,{class:"top-competitorSelector_opener",color:"theme",icon:"",icon2:""},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(t.items.find(r=>r.value===l.value?.[0])?.content),1)]),_:1})]),contentList:e.withCtx(()=>[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.items,r=>(e.openBlock(),e.createBlock(V._sfc_main$2,{class:e.normalizeClass({"top-active":l.value?.includes(r.value)}),"data-top-icon":r.icon,title:r.title,onClick:()=>l.value=[r.value]},{default:e.withCtx(()=>[e.createElementVNode("span",ve,e.toDisplayString(r.content),1)]),_:2},1032,["class","data-top-icon","title","onClick"]))),256))]),_:1})):(e.openBlock(),e.createBlock(C._sfc_main$1,{key:1,modelValue:l.value,"onUpdate:modelValue":n[0]||(n[0]=r=>l.value=r),items:t.items,isMultiple:!0,styling:"bar",canBeEmptyMultiple:!1,selectAllItem:o.value},null,8,["modelValue","items","selectAllItem"]))]))}}),he=(t,a)=>e.computed(()=>e.toValue(t).filter(i=>i.on>=0||i.id===a).map(i=>({value:i.id,title:i.url+` [${i.id}]`,icon:i.id===e.toValue(a)?"":"",content:i.name}))),w=-1,h=-2,O=-1,ye={0:"Yandex",1:"Google",4:"YouTube",5:"Bing",7:"Seznam",8:"AppStore",9:"GoogleStore",20:"Yandex.com",21:"Yandex.com.tr"},_={key:h,name:"--",index:h},ee={key:h,name:"--",regions:[_],regionByIndex:new Map([[h,_]])},R={key:h,name:"Autoselect",index:h},J={key:h,name:"Autoselect",regions:[R],regionByIndex:new Map([[h,R]])},te={countryCode:"00",depth:1,device:0,key:O,index:O,lang:"ru",name:"Without region"},Ie=()=>(R.name=y.useI18n().Common.Autoselect,R),Se=()=>(Ie(),J.name=y.useI18n().Common.Autoselect,console.log(J),J),ke=()=>(te.name=y.useI18n().Keywords.Without_region,te),Y=(t=!1,a=!1,l=[])=>{let o;return t?o=xe(l):o=oe(l),a&&o.set(h,Se()),o.size||o.set(h,ee),o},oe=(t,a=!0,l=[],o=!1)=>{const i=new Map;return t.forEach(n=>{if(!n.enabled||o&&typeof n.key=="number"&&n.key>1)return;const r={...n};r.regionByIndex=new Map,n.regions&&n.regions.forEach(c=>{if(a&&!c.enabled)return;const m={...c};r.regionByIndex.set(m.index,m)}),!r.regionByIndex.size&&l.length,(!n.regions||r.regionByIndex.size||l.length)&&i.set(r.key,r)}),l.forEach(n=>{if(i.has(n))return;const r={key:n,name:ye[n],regions:[],regionByIndex:new Map};i.set(r.key,r)}),i},xe=t=>{const a=oe(t,!1,[0,1],!0);if(a.has(2)){const l=a.get(2);l&&(l.regionByIndex=new Map)}return a.forEach(l=>{if(!l.regionByIndex)return;const o={...ke()};l.regionByIndex.set(o.index,o)}),a},le=(t,a,l=[])=>{const o=Y(t,!1,l);let i;return o.forEach(n=>{if(!(a.searcher_key!==void 0&&a.searcher_key!=n.key)&&n.regions&&(n.regions.forEach(r=>{if(!i&&!(a.key!==void 0&&a.key!=r.key)&&!(a.index!==void 0&&a.index!=r.index)&&!(!t&&(a.lang!==void 0&&a.lang!=r.lang||a.device!==void 0&&a.device!=r.device)))return r.searcher_key=n.key,i=r,!1}),i))return!1}),i},ne=fe.useAsyncTopDialog(()=>new Promise((t,a)=>se(["../.chunks/dialog_regionSelectorRegions-CZ0tMVSq.amd"],t,a))),Be=(t,a)=>{const l=y.useI18n(),o=e.ref(a.value.keys().next().value??h),i=e.computed(()=>{const n=new Map;if(a.value.forEach(r=>{let c={value:r.key,title:r.name};t.addSearcherIcon&&(c.icon=W.getSearcherGIcon(r.key)),n.set(r.key,c)}),t.addCompare&&!n.has(h)){const r={value:"",title:"--------------------",disabled:!0};n.set(r.value,r);const c={value:w,title:l.Common.Compare};n.set(c.value,c)}return n});return{searcherKey:o,optionBySearcherKey:i}},Ce=(t,a)=>{const l=y.useI18n(),o=e.ref(h);t.modelValue.length===1&&(o.value=t.modelValue[0]),o.value===h&&(t.forFrequency?o.value=a.value?.regionByIndex.values().next().value?.key??h:o.value=a.value?.regionByIndex.keys().next().value??h);const i=e.computed(()=>{const n=new Map;return a.value.regionByIndex?.forEach(r=>{let c=r.name;if(t.forFrequency){const k={value:r.key,title:c};n.has(r.key)||n.set(r.key,k);return}r.device&&(c+=" ("+l.Common["Device_"+r.device]+")");const m=W.getLangLabel(a.value.key||0,r.lang??"");m&&(c+=" / "+m);const f={value:r.index,title:c,icon:r.device?W.getDeviceGIcon(r.device):void 0};n.set(r.index,f)}),n});return e.watch(i,(n,r)=>{if(t.onlySearcher||o.value!==void 0&&n.get(o.value))return;let c=n.keys().next().value;if(o.value===h||c===h){o.value=c;return}let m=r?.get(o.value)?.title||"",f=-1;for(const[k,d]of n.entries()){const v=d.title;if(typeof v!="string"||typeof k=="string")break;if(v===m){c=k;break}const u=new RegExp(` \\((${l.Common.Device_1}|${l.Common.Device_2})\\)`);let s=m,g=3;v.indexOf(s)===-1&&(s=m.replace(/^[^a-zа-я]/i,"").replace(u,""),g--),v.indexOf(s)===-1&&(s=m.replace(/ \/.*/,""),g--),v.indexOf(s)===-1&&(s=m.replace(/ \/.*/,""),s=s.replace(/^[^a-zа-я]/i,"").replace(u,""),g--),v.indexOf(s)!==-1&&(g<=f||(f=g,c=k))}o.value=c}),{regionIndex:o,optionByRegionIndex:i}},Te=(t,a,l)=>{const o=e.ref([]),i=()=>{if(t.onlySearcher&&a.value){o.value=Array.from(a.value.keys());return}let r=[];if(t.modelValue.length>1)r=[...t.modelValue];else try{r=JSON.parse(localStorage.getItem("ui:project:regionSelector"+t.projectId+":regionsIndexes"))??[]}catch{}r.length&&(r=r.filter(c=>l.value.has(c))),r.length||(r=Array.from(l.value)),o.value=[...r]},n=()=>{o.value.length?localStorage.setItem("ui:project:regionSelector:"+t.projectId+":regionsIndexes",JSON.stringify(o.value)):localStorage.removeItem("ui:project:regionSelector:"+t.projectId+":regionsIndexes")};return e.watch(o,()=>{n()}),t.addCompare&&i(),{regionsIndexes:o}},we=t=>{const a=e.computed(()=>Y(t.forFrequency,t.autoRegion,t.searchers)),l=e.computed(()=>a.value.get(i.searcherKey.value)||ee),o=e.computed(()=>{const d=new Set;return a.value.forEach(v=>{v.regionByIndex.forEach(u=>{u.index!==O&&u.index!==h&&d.add(u.index)})}),d}),i=Be(t,a),n=Ce(t,l),r=Te(t,a,o);e.watch(a,()=>{if(t.onlySearcher?r.regionsIndexes.value=Array.from(a.value.keys()):r.regionsIndexes.value=r.regionsIndexes.value.filter(v=>o.value.has(v)),i.searcherKey.value===w)return;let d=a.value.keys().next().value;a.value.forEach(v=>{if(t.onlySearcher&&v.key===i.searcherKey.value){d=i.searcherKey.value;return}if(n.regionIndex.value&&v.regionByIndex?.has(n.regionIndex.value)&&(d=v.key),!t.onlySearcher){let u;d!==void 0&&(u=a.value.get(d)?.regionByIndex);const s=a.value.get(v.key)?.regionByIndex;u?.has(h)&&!s?.has(h)&&(d=v.key)}}),d!==void 0&&(i.searcherKey.value=d),n.regionIndex.value!==void 0&&!l.value?.regionByIndex?.has(n.regionIndex.value)&&(n.regionIndex.value=l.value?.regions?.keys().next().value)},{immediate:!0});const c=()=>{if(!(i.searcherKey.value===w||i.searcherKey.value===h))return i.searcherKey.value},m=()=>{if(t.onlySearcher||n.regionIndex.value===h)return;let d=n.regionIndex.value;if(t.forFrequency){const v=n.regionIndex.value;d=le(t.forFrequency,{searcher_key:c(),key:v},t.searchers)?.index}return d},f=()=>{const d=c();if(d!==void 0)return a.value.get(d)};return{selectSearcher:i,selectRegion:n,compare:r,searcherByKey:a,allRegionsIndexes:o,getSearcher:f,getRegion:()=>{const d=m();if(d!==void 0)return f()?.regionByIndex?.get(d)}}},Me=e.defineComponent({__name:"regionSelector",props:e.mergeModels({projectId:{},searchers:{default:()=>[]},modelValue:{},modelValueSingle:{},addCompare:{type:Boolean},forFrequency:{type:Boolean},autoRegion:{type:Boolean},onlySearcher:{type:Boolean},addChanger:{type:Boolean,default:!0},addSearcherIcon:{type:Boolean,default:!0},addRegionIcon:{type:Boolean,default:!0}},{modelValue:{required:!0},modelModifiers:{},modelValueSingle:{},modelValueSingleModifiers:{}}),emits:["update:modelValue","update:modelValueSingle"],setup(t,{expose:a}){const l=t,o=e.useModel(t,"modelValue"),i=e.useModel(t,"modelValueSingle"),{selectSearcher:n,selectRegion:r,compare:c,searcherByKey:m,allRegionsIndexes:f,getSearcher:k,getRegion:d}=we(l),v=()=>{const u=[];m.value.forEach(s=>{s.enabled&&s.regions.forEach(g=>{g.enabled&&u.push(g)})}),ne.open("regions",{regions:u,regionsIndexes:c.regionsIndexes.value,"@update:regionsIndexes":s=>c.regionsIndexes.value=s})};return e.watch([r.regionIndex,n.searcherKey,c.regionsIndexes],()=>{if(n.searcherKey.value===w&&c.regionsIndexes.value.length){if(JSON.stringify(o.value)===JSON.stringify(c.regionsIndexes.value))return;o.value=[...c.regionsIndexes.value]}else l.onlySearcher?(o.value=[n.searcherKey.value],n.searcherKey.value===h&&!l.autoRegion&&(o.value.length=0)):(o.value=[r.regionIndex.value],r.regionIndex.value===h&&!l.autoRegion&&(o.value.length=0));!l.onlySearcher&&!f.value.size&&(n.searcherKey.value=h)}),i.value&&e.watch(i,()=>{i.value&&(o.value=[i.value])},{immediate:!0}),e.watch(o,()=>{if(o.value[0]&&(i.value=o.value[0]),l.onlySearcher){if(!o.value.length||o.value.length===1&&!m.value.has(o.value[0])||o.value.length===1&&o.value[0]===h&&!l.autoRegion){let u=m.value.keys().next().value;u===h&&!l.autoRegion&&(u=void 0,i.value=h),u!==void 0?o.value=[u]:o.value.length=0;return}if(o.value.length>1&&JSON.stringify(o.value)!==JSON.stringify(c.regionsIndexes.value)){o.value=[...c.regionsIndexes.value];return}}else{let u=[...new Set(o.value)],s=m.value.values().next().value?.regionByIndex?.keys().next().value;if(l.forFrequency&&(s=m.value.values().next().value?.regionByIndex?.values().next().value?.key),s===h&&!l.autoRegion&&(s=void 0,i.value=h),!u.length)s!==void 0&&u.push(s);else if(u.length===1){let g=f.value;l.forFrequency&&(g=new Set,m.value.forEach(U=>{U.regionByIndex.forEach(N=>{N.index!==O&&N.index!==h&&g.add(N.key)})})),g.has(u[0])||(u=[],s!==void 0&&u.push(s))}else u=u.filter(g=>f.value.has(g)),!u.length&&s!==void 0&&u.push(s);if(JSON.stringify(o.value)!==JSON.stringify(u)){o.value=u;return}}if(!(o.value.length===1&&o.value[0]===(l.onlySearcher?n.searcherKey.value:r.regionIndex.value)))if(l.onlySearcher){if(o.value.length===1){n.searcherKey.value=o.value[0];return}n.searcherKey.value=w;return}else{if(!o.value.length)return;if(o.value.length===1&&n.searcherKey.value!==w){r.regionIndex.value=o.value[0];let u;for(const s of m.value.values()){for(const g of s.regionByIndex.values())if((l.forFrequency?g.key:g.index)===r.regionIndex.value){u=s.key;break}if(u!==void 0)break}u!==void 0&&(n.searcherKey.value=u)}else n.searcherKey.value=w,c.regionsIndexes.value=[...o.value]}},{immediate:!0}),a({getSearcher:k,getRegion:d}),(u,s)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass({"top-selectorRegion":!0,"top-selectorRegion-onlySearcher":t.onlySearcher})},[e.createVNode(y._sfc_main$10,{options:e.unref(n).optionBySearcherKey.value,modelValue:e.unref(n).searcherKey.value,"onUpdate:modelValue":s[0]||(s[0]=g=>e.unref(n).searcherKey.value=g),name:"searcher_key",addChanger:t.addChanger},null,8,["options","modelValue","addChanger"]),!t.onlySearcher&&e.unref(n).searcherKey.value!==e.unref(w)?(e.openBlock(),e.createBlock(y._sfc_main$10,{key:0,class:"top-select-region",options:e.unref(r).optionByRegionIndex.value,modelValue:e.unref(r).regionIndex.value,"onUpdate:modelValue":s[1]||(s[1]=g=>e.unref(r).regionIndex.value=g),name:t.forFrequency?"region_key":"region_index",addChanger:t.addChanger,"data-top-icon":t.addRegionIcon?"":void 0},null,8,["options","modelValue","name","addChanger","data-top-icon"])):e.createCommentVNode("",!0),t.addCompare&&!t.onlySearcher&&e.unref(n).searcherKey.value===e.unref(w)?(e.openBlock(),e.createBlock(y._sfc_main$1,{key:1,name:"compare",onClick:v,"data-count-compare-regions-indexes":e.unref(c).regionsIndexes.value.length},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(u.$i18n.Common.Selected_regions),1)]),_:1},8,["data-count-compare-regions-indexes"])):e.createCommentVNode("",!0)],2))}}),M={id:0,name:"/",path:"/"};function Ve(t){return t?y.useI18n()?.Common.All_folders:"/ ("+y.useI18n()?.Keywords.Root_folder+")"}const Q=(t,a,l=new Map,o={id:"root"},i=0)=>(o.childsIds=[],o.id&&(o.countAllGroupsActive=o.count_groups_active),t[o.id]&&t[o.id].forEach(n=>{n={...n},o.childsIds.push(n.id),n.id===0&&(n.name=Ve(a));const r=i>1?"-".repeat(i-1)+" ":"";r&&!n.name.startsWith(r)&&(n.name=r+n.name),l.set(n.id,n),Q(t,a,l,n,i+1),o.childsIds=o.childsIds.concat(n.childsIds),o.id&&n.count_groups_active&&(o.countAllGroupsActive+=n.count_groups_active)}),l),Ae=(t,a)=>t.gen(`/get/${a}/folders/`,["id","parent_id","name","path"]).changeParams({orders:["ord_path"],limit:100});function X(t,a,l){const o=Object.keys(t),i=o.map(n=>t[n]);return e.watch(i,(n,r,c)=>{const m={};n.forEach((f,k)=>{if(!Object.is(f,r[k])){const d=o[k];m[d]={old:r[k],new:f}}}),Object.keys(m).length&&a(m,c)},l)}const Ee=e.defineComponent({__name:"folders",props:e.mergeModels({folderId:{},folder:{},folders:{},projectId:{},canSelectAll:{type:Boolean},addChanger:{type:Boolean},addIcon:{type:Boolean,default:!0},client:{},service:{}},{folderId:{required:!0},folderIdModifiers:{},folder:{default:M},folderModifiers:{}}),emits:["update:folderId","update:folder"],setup(t){const a=t,l=e.useModel(t,"folderId"),o=e.useModel(t,"folder"),i=a.client&&!a.folders?Ae(a.client,a.service):void 0,n=e.ref(null);e.watch(()=>a.projectId,()=>{i?.changeParams({project_id:a.projectId}),i?.setOptions({checkFingerprint:"TopGroupSelectorFolders:"+a.projectId}),n.value?.resetCache()},{immediate:!0});const r=e.computed(()=>Q(a.folders??{root:[M]},a.canSelectAll));return X({modelFolder:o,modelFolderId:l},async c=>{if(l.value===o.value.id)return;if(c.modelFolder&&!c.modelFolderId){l.value=o.value.id;return}let m=r.value.get(a.folderId);m||(m=M),o.value=m,l.value=m.id},{immediate:!0}),(c,m)=>(e.openBlock(),e.createBlock(C._sfc_main,{class:"top-groupSelector_folder",modelValue:o.value,"onUpdate:modelValue":m[0]||(m[0]=f=>o.value=f),items:t.folders?[...r.value.values()]:void 0,"search-type":"inline",icon:t.addIcon?"":void 0,api:t.folders?void 0:e.unref(i),apiSetSearchParams:(...f)=>e.unref(C.apiSetSearchParamsFilter)(...f,"name"),addChanger:t.addChanger,useCache:""},null,8,["modelValue","items","icon","api","apiSetSearchParams","addChanger"]))}}),j={id:-1,name:"--",folder_id:M.id,folder_path:M.path},D={id:C.ITEM_ID_ALL,name:"All groups",folder_id:M.id,folder_path:M.path},E=()=>(D.name=y.useI18n()?.Common.All_groups,D),ae=()=>(D.name=y.useI18n()?.Keywords.Choose_group,D),be=(t,a,l)=>(t=[...t],a!==void 0&&(t=t.filter(o=>o.on==Number(a))),l&&l.id&&l.childsIds&&(t=t.filter(o=>o.folder_id===l.id||l.childsIds.includes(o.folder_id))),t),re=(t,a)=>t.gen(`/get/${a}/groups/`,["id","name","folder_id","folder_path"]).changeParams({folder_id_depth:!0,limit:100}),$e=(t,a)=>t.gen(`/add/${a}/groups/`),Ne={class:"top-groupSelector_groupItem"},Ge={key:0,class:"top-comment"},Ke={key:1,class:"top-groupSelector_groupItemFolderPath"},Le=e.defineComponent({__name:"groups",props:e.mergeModels({groupId:{},group:{},projectId:{},folder:{},groups:{},on:{type:Boolean,default:void 0},canAdd:{type:[String,Boolean]},canSelectAll:{type:[Boolean,String]},autoselect:{default:"first"},addChanger:{type:Boolean,default:!0},showPath:{type:Boolean},addIcon:{type:Boolean,default:!0},client:{},service:{}},{groupId:{required:!0},groupIdModifiers:{},group:{required:!0},groupModifiers:{}}),emits:e.mergeModels(["addGroup"],["update:groupId","update:group"]),setup(t,{emit:a}){const l=t,o=a,i=e.useModel(t,"groupId"),n=e.useModel(t,"group"),r=l.client&&!l.groups?re(l.client,l.service):void 0,c=l.client?$e(l.client,l.service):void 0,m=e.ref(null),f=e.ref(void 0),k=H.genFieldFilter("folder_id","EQUALS",[l.folder?.id??0]);r?.changeParams({project_id:l.projectId,folder_id_depth:!0,filters:[k]}),l.on!==void 0&&r?.params.filters?.push(H.genFieldFilter("on","EQUALS",[Number(l.on)]));const d=u=>{n.value=u,i.value=u.id};X({projectId:()=>l.projectId,folderId:()=>l.folder?.id,canSelectAll:()=>l.canSelectAll},u=>{if(u.projectId&&(r?.changeParams({project_id:l.projectId}),r?.setOptions({checkFingerprint:"TopGroupSelectorGroups:"+l.projectId})),u.folderId&&(k.values=[l.folder?.id??0],l.groups&&(f.value=be(l.groups,l.on,l.folder))),m.value?.resetCache(),(u.folderId?.old!==void 0||u.canSelectAll?.old!==void 0)&&i.value!==C.ITEM_ID_NEW){let s;l.autoselect==="first"&&(s=f.value?.[0],l.canSelectAll&&(s=e.reactive(E()))),(l.autoselect==="placeholder"||!s)&&(s=ae()),d(s)}},{immediate:!0}),X({modelGroup:n,modelGroupId:i},async u=>{if(i.value!==n.value.id){if(u.modelGroup&&!u.modelGroupId){i.value=n.value.id;return}if(!(l.canAdd&&i.value===C.ITEM_ID_NEW)){if(l.groups){let s=f.value?.find(g=>g.id===i.value);if(!s&&l.canSelectAll&&(s=E()),s)d(s);else{const g=f.value?.[0];g&&!i.value?d(g):d(j)}}if(l.client&&!l.groups&&(i.value||i.value===C.ITEM_ID_ALL&&!l.canSelectAll)){const s=re(l.client,l.service).changeParams({project_id:l.projectId,id:i.value,filters:[k]});s?.setOptions({checkFingerprint:"TopGroupSelectorFindGroup:"+l.projectId});const g=await s.call();if(!g.errors?.length&&!g.result)return;!g.errors&&g.result[0]?d(g.result[0]):d(j)}}}},{immediate:!0});const v=async u=>{if(l.canAdd!=="api"||!c)return;const s=n.value,g=await c.changeParams({project_id:l.projectId,names:[u.name],to_id:l.folder?.id??M.id,to_type:"in_folder_last"}).call();g.result?(d(g.result),o("addGroup",g.result)):d(s),m.value?.resetCache(!0)};return(u,s)=>(e.openBlock(),e.createBlock(C._sfc_main,{ref_key:"refSelector",ref:m,class:"top-groupSelector_group",modelValue:n.value,"onUpdate:modelValue":s[0]||(s[0]=g=>n.value=g),items:f.value??t.groups,searchType:"inline",icon:t.addIcon?"":void 0,api:t.groups?void 0:e.unref(r),apiSetSearchParams:(...g)=>e.unref(C.apiSetSearchParamsFilter)(...g,"name"),appendSearchToResult:!!t.canAdd,useAllItem:t.canSelectAll?e.unref(E)().name:!1,addChanger:t.addChanger,useCache:"",onAppendItem:v},{item:e.withCtx(({item:g})=>[e.createElementVNode("div",Ne,[g.id===e.unref(C.ITEM_ID_NEW)?(e.openBlock(),e.createElementBlock("div",Ge,e.toDisplayString(u.$i18n.Common.Add)+": ",1)):e.createCommentVNode("",!0),e.createElementVNode("span",null,e.toDisplayString(g.name),1),g.folder_path&&t.showPath?(e.openBlock(),e.createElementBlock("span",Ke,e.toDisplayString(g.folder_path),1)):e.createCommentVNode("",!0)])]),_:1},8,["modelValue","items","icon","api","apiSetSearchParams","appendSearchToResult","useAllItem","addChanger"]))}}),Oe={class:"top-groupSelector"},Re=e.defineComponent({__name:"groupSelector",props:e.mergeModels({folderId:{},folder:{},groupId:{},group:{},projectId:{},folders:{},groups:{},on:{type:Boolean,default:void 0},canSelectAllGroups:{type:Boolean},canAddGroup:{},autoselect:{default:"first"},addChanger:{type:Boolean,default:!0},showFolders:{type:Boolean,default:!0},showGroups:{type:Boolean,default:!0},addIcon:{type:Boolean,default:!0},client:{},service:{default:"keywords_2"}},{folderId:{required:!0},folderIdModifiers:{},folder:{},folderModifiers:{},groupId:{required:!0},groupIdModifiers:{},group:{default:j},groupModifiers:{}}),emits:e.mergeModels(["update:groups"],["update:folderId","update:folder","update:groupId","update:group"]),setup(t,{emit:a}){const l=t,o=e.useModel(t,"folderId"),i=e.useModel(t,"folder"),n=e.useModel(t,"groupId"),r=e.useModel(t,"group"),c=a,m=Q(l.folders??{root:[M]},l.canSelectAllGroups);i.value=m.get(o.value);let f=l.groups?.find(d=>d.id===n.value);n.value||(f=l.groups?.[0]),l.canSelectAllGroups&&!f&&(f=E()),l.canSelectAllGroups&&!f&&(f=E()),(l.autoselect==="placeholder"||!f)&&(f=ae()),f??=j,r.value=f;const k=d=>{let v;l.groups&&d&&(v=[...l.groups,d]),c("update:groups",v)};return(d,v)=>(e.openBlock(),e.createElementBlock("div",Oe,[t.showFolders?(e.openBlock(),e.createBlock(Ee,{key:0,folderId:o.value,"onUpdate:folderId":v[0]||(v[0]=u=>o.value=u),folder:i.value,"onUpdate:folder":v[1]||(v[1]=u=>i.value=u),projectId:t.projectId,folders:t.folders,canSelectAll:t.canSelectAllGroups,addChanger:t.addChanger,addIcon:t.addIcon,client:t.client,service:t.service},null,8,["folderId","folder","projectId","folders","canSelectAll","addChanger","addIcon","client","service"])):e.createCommentVNode("",!0),t.showGroups?(e.openBlock(),e.createBlock(Le,{key:1,groupId:n.value,"onUpdate:groupId":v[2]||(v[2]=u=>n.value=u),group:r.value,"onUpdate:group":v[3]||(v[3]=u=>r.value=u),projectId:t.projectId,folder:i.value,groups:t.groups,on:t.on,canAdd:t.canAddGroup,canSelectAll:t.canSelectAllGroups,autoselect:t.autoselect,addChanger:t.addChanger,showPath:t.showFolders&&!!t.folders?.[0],addIcon:t.addIcon,client:t.client,service:t.service,onAddGroup:k},null,8,["groupId","group","projectId","folder","groups","on","canAdd","canSelectAll","autoselect","addChanger","showPath","addIcon","client","service"])):e.createCommentVNode("",!0)]))}}),ie=t=>"-"+t,b=t=>t[0]==="-"?t.substring(1):t,P=(t,a)=>{t=b(t);const l=a.find(o=>o.id===t);if(l)return l},je=(t,a,l)=>{a||(a={id:t.id}),a.id=t.id,a.pos??="3",a.notch??=!0,a.posBy??="fixed";const o=ge.TopPopupWorker.genElPopupOpener("div",a);return o.classList.add("top-tagSelector"),t.useTopButton&&o.classList.add("top-tagSelector-useTopButton","top-button","top-color_theme","top-as-selector"),t.useTopButton||o.classList.add("top-tagSelector-custom"),t.mode==="filter"&&o.classList.add("top-tagSelector-filter"),t.mode==="setter"&&!t.filters&&o.classList.add("top-tagSelector-setter_single"),t.mode==="setter"&&t.filters&&o.classList.add("top-tagSelector-setter_several"),o.onclick=i=>{i.preventDefault(),i.stopPropagation(),o.onclick=null;const n=e.ref(t.modelValue),r={model:n,mode:t.mode,targetId:t.targetId,filters:t.filters,payload:t.payload};A.storage(o,"topTagSelectorTarget",r),delete o.dataset.topPopupDisabled,e.isRef(t.modelValue)||e.watch(n,()=>{t.modelValue=n.value,F(o,t,l)}),o.click()},e.isRef(t.modelValue)?e.watch(t.modelValue,()=>F(o,t,l)):A.storage(o,"topTagSelectorRender",i=>{t.modelValue=i;const n=A.storage(o,"topTagSelectorTarget");n&&(n.model.value=i),F(o,t,l)}),F(o,t,l),o},De=(t,a)=>{A.storage(t,"topTagSelectorRender")?.(a)},F=(t,a,l)=>{const o=e.unref(a.modelValue);if(t.classList.toggle("top-tagSelector-selectedOne",!o.length||o.length===1),t.classList.toggle("top-tagSelector-toTwoLine",o.length>5),a.mode==="setter"&&a.filters){t.innerHTML=`<div>${l}</div>`;return}if(t.innerHTML="",!o.length&&a.mode==="filter"){const i=de({id:"all",colorId:"",name:y.useI18n().Common?.All_tags??"",state:""});t.append(i)}o.forEach(i=>{const n=de({id:b(i),colorId:P(i,a.tags)?.color_id??"",name:P(i,a.tags)?.name??"",state:b(i)===i?"selected":"excluded"});t.append(n)})},de=t=>{const a=document.createElement("div");return a.classList.add("top-tagSelector_tagIcon"),a.classList.toggle("top-tagSelector-active",!!t.state),a.classList.toggle("top-tagSelector-excluded",t.state==="excluded"),a.dataset.tag_id=t.id,a.dataset.tag_color_id=t.colorId,a.title=t.name,a},Pe=[{id:"1",name:"Without Tag",color_id:"1"},{id:"2",name:"Red",color_id:"2"},{id:"3",name:"Orange",color_id:"3"},{id:"4",name:"Yellow",color_id:"4"},{id:"5",name:"Blue",color_id:"5"},{id:"6",name:"Purple",color_id:"6"},{id:"7",name:"Green",color_id:"7"},{id:"8",name:"Magenta",color_id:"8"},{id:"9",name:"Dark blue",color_id:"9"},{id:"10",name:"Turquoise",color_id:"10"}],Fe=["data-tag_id","data-tag_color_id","title"],q=e.defineComponent({__name:"tagIcon",props:{id:{},colorId:{},name:{},state:{}},setup(t){return(a,l)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass({"top-tagSelector_tagIcon":!0,"top-tagSelector-active":!!t.state,"top-tagSelector-excluded":t.state==="excluded"}),"data-tag_id":t.id,"data-tag_color_id":t.colorId,title:t.name},null,10,Fe))}}),qe=["contenteditable","onKeydown"],ue=e.defineComponent({__name:"tagPopupListItem",props:e.mergeModels({editable:{type:Boolean},disabled:{type:Boolean},canExclude:{type:Boolean},id:{},colorId:{},name:{},state:{}},{name:{required:!0},nameModifiers:{}}),emits:e.mergeModels(["update:name","unselect","exclude","select"],["update:name"]),setup(t,{emit:a}){const l=t,o=a,i=e.useModel(t,"name"),n=e.ref(null),r=e.computed(()=>navigator.userAgent.indexOf("Firefox")!=-1?{contenteditable:c.value,onpaste:v=>v.preventDefault()}:{}),c=e.ref(!1),m=async()=>{c.value=!0,await e.nextTick(),n.value?.focus()},f=()=>{const v=n.value?.innerText;if(!v)return k();n.value&&(n.value.innerText=v),c.value=!1,o("update:name",v)},k=async()=>{n.value&&(n.value.innerText=l.name),c.value=!1},d=v=>{if(c.value||l.disabled)return;let u="selected";l.canExclude&&(v.ctrlKey||v.metaKey)&&(u="excluded"),l.state==u&&(u=""),u===""&&o("unselect"),u==="selected"&&o("select"),u==="excluded"&&o("exclude")};return(v,u)=>(e.openBlock(),e.createBlock(V._sfc_main$2,{class:e.normalizeClass({"top-tagSelector_tagListItem":!0,"top-tagSelector_tagListItem-inEdit":c.value,"top-tagSelector_tagListItem-disabled":t.disabled,"top-tagSelector_tagListItem-canExclude":t.canExclude,"top-tagSelector-active":!!t.state,"top-tagSelector-excluded":t.state==="excluded"}),onClick:e.withModifiers(d,["stop"])},{default:e.withCtx(()=>[e.createVNode(q,{id:t.id,name:i.value,colorId:t.colorId,state:t.state},null,8,["id","name","colorId","state"]),e.createElementVNode("span",e.mergeProps({ref_key:"elName",ref:n,class:"top-tagSelector_tagListItemName",contenteditable:c.value?"plaintext-only":!1},r.value,{onKeydown:[e.withKeys(e.withModifiers(f,["stop"]),["enter"]),e.withKeys(e.withModifiers(k,["stop"]),["esc"])]}),e.toDisplayString(i.value),17,qe),t.editable?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[c.value?(e.openBlock(),e.createElementBlock("span",{key:1,"data-top-icon":"",class:"top-tagSelector_edit",onClick:e.withModifiers(f,["stop"])})):(e.openBlock(),e.createElementBlock("span",{key:0,"data-top-icon":"",class:"top-tagSelector_edit",onClick:m}))],64)):e.createCommentVNode("",!0)]),_:1},8,["class"]))}}),Ue={key:1},ce=e.defineComponent({inheritAttrs:!1,__name:"popupOpener",props:e.mergeModels({modelValue:{},id:{},tags:{},mode:{},targetId:{},filters:{},useTopButton:{type:Boolean},payload:{},styling:{}},{modelValue:{required:!0},modelModifiers:{}}),emits:["update:modelValue"],setup(t){const a=t,l=e.useModel(t,"modelValue"),o=a.useTopButton?y._sfc_main$1:"div",i=a.useTopButton?"html":"default",n={model:l,mode:a.mode,targetId:a.targetId,filters:a.filters,payload:a.payload};return(r,c)=>{const m=e.resolveDirective("top-data");return e.openBlock(),e.createBlock(V._sfc_main$1,{id:t.id},{default:e.withCtx(()=>[e.withDirectives((e.openBlock(),e.createBlock(e.resolveDynamicComponent(e.unref(o)),e.mergeProps({class:{"top-tagSelector":!0,"top-tagSelector-useTopButton":a.useTopButton,"top-tagSelector-custom":!a.useTopButton,"top-as-selector":a.useTopButton,"top-tagSelector-filter":a.mode==="filter","top-tagSelector-setter_single":a.mode==="setter"&&!t.filters,"top-tagSelector-setter_several":a.mode==="setter"&&t.filters,"top-tagSelector-selectedOne":!l.value.length||l.value.length===1,"top-tagSelector-toTwoLine":l.value.length>5},color:"theme",styling:t.styling},r.$attrs),{[e.unref(i)]:e.withCtx(()=>[!l.value.length&&t.mode==="filter"?(e.openBlock(),e.createBlock(q,{key:0,id:"all",colorId:"",name:r.$i18n.Common.All_tags??"",state:""},null,8,["name"])):e.createCommentVNode("",!0),t.mode==="setter"&&t.filters?(e.openBlock(),e.createElementBlock("div",Ue,[e.renderSlot(r.$slots,"default")])):(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:2},e.renderList(l.value,f=>(e.openBlock(),e.createBlock(q,{id:e.unref(b)(f),colorId:e.unref(P)(f,t.tags)?.color_id??"",name:e.unref(P)(f,t.tags)?.name??"",state:e.unref(b)(f)===f?"selected":"excluded"},null,8,["id","colorId","name","state"]))),256))]),_:2},1040,["class","styling"])),[[m,n,"topTagSelectorTarget"]])]),_:3},8,["id"])}}}),ze=e.defineComponent({__name:"tagSelector",props:e.mergeModels({modelValue:{},tags:{},tagsEditable:{type:Boolean},tagsMax:{default:10},id:{},singleMode:{type:Boolean},requiredForSetter:{type:Boolean,default:!0},maxTagsForSetter:{},emitDelay:{default:500},useTopButton:{type:Boolean,default:!0},styling:{}},{modelValue:{required:!0},modelModifiers:{},tags:{default:e.reactive(Pe)},tagsModifiers:{}}),emits:e.mergeModels(["selector","setter","tagsChanged"],["update:modelValue","update:tags"]),setup(t,{emit:a}){const l=y.useI18n(),o=t,i=e.useModel(t,"modelValue"),n=e.useModel(t,"tags"),r=a,c=y.debounce((p,I)=>{r(p,I)},o.emitDelay);o.singleMode&&!i.value.length&&(i.value=[n.value[0].id]);const m=o.id??"top-popup-id-"+Math.random(),f=e.ref("add"),k=()=>{const p=" "+l.Common.Tags?.toLowerCase(),I=new Map;return I.set("add",{value:"add",title:l.Common.Add+p}),I.set("replace",{value:"replace",title:l.Common.Replace+p}),I.set("delete",{value:"delete",title:l.Common.Delete+p}),I};let d=e.shallowRef({model:i,mode:"filter",targetId:void 0,filters:void 0,payload:void 0});e.watch(i,()=>{c("selector",i.value)});const v=e.computed(()=>{if(d.value.mode==="setter"&&o.maxTagsForSetter&&!d.value.filters)return d.value.model.value.length>=o.maxTagsForSetter}),u=p=>{if(p!=="all"){if(d.value.model.value.includes(p))return"selected";if(d.value.model.value.includes(ie(p)))return"excluded"}return p==="all"&&!d.value.model.value.length?"selected":""},s=(p,I)=>{const S=ie(p);let x=d.value.model.value.filter(T=>T!==p&&T!==S);I==="select"&&x.push(p),I==="exclude"&&x.push(S),d.value.mode==="setter"&&d.value.targetId!==void 0&&o.requiredForSetter&&(x.length||x.push("1"),x.length===2&&d.value.model.value.length===1&&d.value.model.value[0]==="1"&&(x=x.filter(T=>T!=="1"))),o.singleMode&&!d.value.filters&&(x.length||(x=d.value.model.value),x.length>1&&(x=[x[x.length-1]])),x.sort((T,z)=>{if(!o.tags)return 0;const G=o.tags.findIndex(L=>L.id===T),K=o.tags.findIndex(L=>L.id===z);return G-K}),d.value.model.value=x,d.value.mode==="setter"&&d.value.targetId!==void 0&&c("setter",{tagsIds:x,targetId:d.value.targetId,payload:d.value.payload})},g=e.computed(()=>{let p="top-tagSelector_popup";return d.value.mode==="filter"&&(p+=" top-tagSelector_popup-filter"),d.value.mode==="setter"&&(p+=" top-tagSelector_popup-setter"),p}),U=()=>{const p=prompt("","New tag");if(!p||p==="New tag")return;const I=n.value.length+1;n.value.push({id:String(I),name:p,color_id:String((I-1)%10+1)}),r("tagsChanged",n.value)},N=p=>{if(d.value=A.storage(p.elPopupOpener,"topTagSelectorTarget"),!d.value)throw new Error("Open popup TopTagSelector required v-data:topTagSelectorTarget");if(d.value.filters&&(f.value="add",d.value.model.value=[]),!y.Core.$?.ui.sortable){console.info("Для работы сортировки требуется глобальная загрузка jQuery UI Sortable");return}!y.Core.state.isMobile&&!y.Core.state.isMobileUA&&n.value&&$(p.elPopup).sortable({items:'li:has([data-tag_id]:not([data-tag_id="all"]))',cancel:'[contenteditable="plaintext-only"], [contenteditable="true"]',distance:10,stop:function(I,S){if(!n.value)return;const x=$(S.item).parent().find("[data-tag_id]"),T=[];x.each((z,G)=>{if(!n.value)return;const K=$(G).attr("data-tag_id");T.push(K)}),n.value.sort((z,G)=>{const K=T.findIndex(Z=>Z===z.id),L=T.findIndex(Z=>Z===G.id);return K-L}),c("tagsChanged",n.value)}})},We=p=>{y.Core.$?.ui.sortable&&$(p.elPopup).data("ui-sortable")&&$(p.elPopup).sortable("destroy")};return(p,I)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createVNode(ce,{modelValue:i.value,"onUpdate:modelValue":I[0]||(I[0]=S=>i.value=S),id:e.unref(m),tags:n.value,styling:t.styling,mode:"filter",useTopButton:t.useTopButton},null,8,["modelValue","id","tags","styling","useTopButton"]),e.createVNode(V._sfc_main,{id:e.unref(m),class:e.normalizeClass(g.value),onOpen:I[4]||(I[4]=S=>N(S)),onClose:I[5]||(I[5]=S=>We(S)),"transition-duration":50},e.createSlots({contentList:e.withCtx(()=>[e.unref(d).mode==="filter"&&!t.singleMode?(e.openBlock(),e.createBlock(ue,{key:0,id:"all",colorId:"",name:p.$i18n.Common.All_tags??"",state:e.unref(d).model.value.length?"":"selected",onSelect:I[3]||(I[3]=S=>e.unref(d).model.value=[])},null,8,["name","state"])):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(n.value,S=>(e.openBlock(),e.createBlock(ue,{key:S.id,id:S.id,colorId:S.color_id,name:S.name,state:u(S.id),canExclude:e.unref(d).mode==="filter"&&!t.singleMode,editable:t.tagsEditable,disabled:v.value&&u(S.id)==="",onUnselect:x=>s(S.id,"unselect"),onSelect:x=>s(S.id,"select"),onExclude:x=>s(S.id,"exclude"),"onUpdate:name":x=>{S.name=x,e.unref(c)("tagsChanged",n.value)}},null,8,["id","colorId","name","state","canExclude","editable","disabled","onUnselect","onSelect","onExclude","onUpdate:name"]))),128)),t.tagsEditable&&n.value.length<t.tagsMax&&n.value.length<20?(e.openBlock(),e.createBlock(V._sfc_main$2,{key:1,"data-top-icon":"",onClick:e.withModifiers(U,["stop"])},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(p.$i18n.Common.Add),1)]),_:1})):e.createCommentVNode("",!0)]),_:2},[e.unref(d).mode==="setter"&&e.unref(d).filters?{name:"header",fn:e.withCtx(()=>[e.createVNode(y._sfc_main$10,{modelValue:f.value,"onUpdate:modelValue":I[1]||(I[1]=S=>f.value=S),options:k()},null,8,["modelValue","options"])]),key:"0"}:void 0,e.unref(d).mode==="setter"&&e.unref(d).filters?{name:"footer",fn:e.withCtx(()=>[e.createVNode(y._sfc_main$1,{color:"theme"},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(p.$i18n.Common.Cancel),1)]),_:1}),e.createVNode(y._sfc_main$1,{onClick:I[2]||(I[2]=S=>e.unref(c)("setter",{tagsIds:e.unref(d).model.value,filters:e.unref(d).filters,filtersAction:f.value,payload:e.unref(d).payload}))},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(f.value==="add"?p.$i18n.Common.Add:"")+" "+e.toDisplayString(f.value==="replace"?p.$i18n.Common.Replace:"")+" "+e.toDisplayString(f.value==="delete"?p.$i18n.Common.Delete:""),1)]),_:1})]),key:"1"}:void 0]),1032,["id","class"])],64))}});B.TopCompetitorSelector=pe,B.TopGroupSelector=Re,B.TopRegionSelector=Me,B.TopTagSelector=ze,B.TopTagSelectorPopupOpener=ce,B.TopTagSelectorTagIcon=q,B.dialogRegionSelector=ne,B.findRegion=le,B.genElTopTagSelectorPopupOpener=je,B.genSearcherByKey=Y,B.renderElTopTagSelectorPopupOpener=De,B.useItemsFromCompetitors=he,Object.defineProperty(B,Symbol.toStringTag,{value:"Module"})}));
2
2
  //# sourceMappingURL=project.amd.js.map
@@ -9,7 +9,7 @@ import { _ as we, b as ve, a as Je } from "../.chunks/popupHint.vue_vue_type_sty
9
9
  import { a as We, _ as Me, b as $e, c as Ee, I as ue } from "../.chunks/policy.vue_vue_type_style_index_0_lang-DVl9DBpl.es.js";
10
10
  import { u as Ye } from "../.chunks/utils-MzIaxkRQ.es.js";
11
11
  import { getSearcherGIcon as Qe, getLangLabel as He, getDeviceGIcon as Xe } from "../utils/searchers.js";
12
- import "../.chunks/core-BM3jtOUr.es.js";
12
+ import "../.chunks/core-DoIr-EAf.es.js";
13
13
  import "../.chunks/dialogs.vue_vue_type_script_setup_true_lang-D8WYUfXI.es.js";
14
14
  import { g as Se } from "../.chunks/field-CyyFzM-Y.es.js";
15
15
  import { storage as W } from "../utils/dom.js";
@@ -7,6 +7,7 @@ type AllowedModifiers = 'ctrl' | 'shift' | 'alt';
7
7
  type Binding = DirectiveBinding<ShortcutValue, AllowedModifiers>;
8
8
  declare const shortcut: {
9
9
  mounted: (el: HTMLElement, binding: Binding) => void;
10
- unmounted(el: HTMLElement): void;
10
+ updated: (el: HTMLElement, binding: Binding) => void;
11
+ unmounted: (el: HTMLElement) => void;
11
12
  };
12
13
  export default shortcut;
@@ -1,2 +1,2 @@
1
- define(["require","exports","../.chunks/forms-DDNzqU6o.amd","../.chunks/core-B1CmZy7Z.amd","vue","../.chunks/dialogs.vue_vue_type_script_setup_true_lang-BBix_8WK.amd"],(function(b,c,g,f,r,d){"use strict";if(typeof r>"u")var r=window.Vue;const s={0:"Yandex",20:"Yandex.com",21:"Yandex.com.tr",1:"Google",4:"YouTube",5:"Bing",7:"Seznam",8:"AppStore",9:"GooglePlay",101:"VK",102:"Facebook",103:"Twitter"},t=a=>{let e="";switch(typeof a=="string"&&(a=Number(a)),a){case 0:e="";break;case 20:case 21:e="";break;case 1:e="";break;case 2:e="";break;case 3:e="";break;case 4:e="";break;case 5:e="";break;case 6:e="";break;case 7:e="";break;case 8:e="";break;case 9:e="";break;case null:e="";break}return e},n=a=>{let e="";switch(typeof a=="string"&&(a=Number(a)),a%10){case 0:e="";break;case 1:e="";break;case 2:e="";break}return e},i=(a,e)=>{switch(typeof a=="string"&&(a=Number(a)),a*1){case 1:case 4:case 5:case 6:case 8:case 9:return e}return""},u=(a,e,k)=>{switch(e*1){case 0:switch(k*1){case 2:a=`"${a}"`;break;case 3:a=`"!${a}"`;break;case 5:a=`"[${a}]"`;break;case 6:a=`"[!${a}]"`;break}break;case 1:a=`[${a}]`;break}return a},o=(a,e)=>{switch(e===null&&(e=6),a){case 1:e=3;break;case 2:e=2;break;case 5:e>1&&(e=1);break;default:[1,2,3,5,6].includes(e)||(e=3)}return e};c.genVolumeLabel=u,c.getDeviceGIcon=n,c.getLangLabel=i,c.getSearcherGIcon=t,c.prepareVolumeType=o,c.searchersNames=s,Object.defineProperty(c,Symbol.toStringTag,{value:"Module"})}));
1
+ define(["require","exports","../.chunks/forms-DDNzqU6o.amd","../.chunks/core-DzDFXOdI.amd","vue","../.chunks/dialogs.vue_vue_type_script_setup_true_lang-BBix_8WK.amd"],(function(b,c,g,f,r,d){"use strict";if(typeof r>"u")var r=window.Vue;const s={0:"Yandex",20:"Yandex.com",21:"Yandex.com.tr",1:"Google",4:"YouTube",5:"Bing",7:"Seznam",8:"AppStore",9:"GooglePlay",101:"VK",102:"Facebook",103:"Twitter"},t=a=>{let e="";switch(typeof a=="string"&&(a=Number(a)),a){case 0:e="";break;case 20:case 21:e="";break;case 1:e="";break;case 2:e="";break;case 3:e="";break;case 4:e="";break;case 5:e="";break;case 6:e="";break;case 7:e="";break;case 8:e="";break;case 9:e="";break;case null:e="";break}return e},n=a=>{let e="";switch(typeof a=="string"&&(a=Number(a)),a%10){case 0:e="";break;case 1:e="";break;case 2:e="";break}return e},i=(a,e)=>{switch(typeof a=="string"&&(a=Number(a)),a*1){case 1:case 4:case 5:case 6:case 8:case 9:return e}return""},u=(a,e,k)=>{switch(e*1){case 0:switch(k*1){case 2:a=`"${a}"`;break;case 3:a=`"!${a}"`;break;case 5:a=`"[${a}]"`;break;case 6:a=`"[!${a}]"`;break}break;case 1:a=`[${a}]`;break}return a},o=(a,e)=>{switch(e===null&&(e=6),a){case 1:e=3;break;case 2:e=2;break;case 5:e>1&&(e=1);break;default:[1,2,3,5,6].includes(e)||(e=3)}return e};c.genVolumeLabel=u,c.getDeviceGIcon=n,c.getLangLabel=i,c.getSearcherGIcon=t,c.prepareVolumeType=o,c.searchersNames=s,Object.defineProperty(c,Symbol.toStringTag,{value:"Module"})}));
2
2
  //# sourceMappingURL=searchers.amd.js.map
@@ -1,5 +1,5 @@
1
1
  import "../.chunks/forms-BpbQYyEQ.es.js";
2
- import "../.chunks/core-BM3jtOUr.es.js";
2
+ import "../.chunks/core-DoIr-EAf.es.js";
3
3
  import "vue";
4
4
  import "../.chunks/dialogs.vue_vue_type_script_setup_true_lang-D8WYUfXI.es.js";
5
5
  const k = {
@@ -1,2 +0,0 @@
1
- define(["require","exports","vue","./forms-DDNzqU6o.amd","../popup/worker.amd","./dialogs.vue_vue_type_script_setup_true_lang-BBix_8WK.amd","../utils/dom.amd"],(function(r,M,_,i,l,U,h){"use strict";if(typeof _>"u")var _=window.Vue;class R{static isInited=!1;static init(){this.isInited||(this.isInited=!0,document.addEventListener("mouseover",e=>{!(e.target instanceof HTMLElement)||!e.target.dataset?.topPopupOpenByHover||e.target.click()}),document.addEventListener("scroll",()=>{i.Core.state.isMobile||i.Core.state.isMobileUA||l.TopPopupWorker.getAll().forEach(e=>l.TopPopupWorker.close(e))}),i.Events.addOnReize(e=>{i.Core.state.isMobile&&e.topEvent.widthDiff&&l.TopPopupWorker.getAll().forEach(o=>l.TopPopupWorker.close(o))}),document.addEventListener("click",this.onclick,{capture:!0}))}static async onclick(e){if(!(e.target instanceof HTMLElement)||e.target.dataset.topPopupDisabled)return;let o;switch(!0){case!!e.target.dataset?.topPopup:o=e.target;break;case!!e.target.parentElement?.dataset.topPopup:o=e.target.parentElement;break;case!!e.target.parentElement?.parentElement?.dataset.topPopup:o=e.target.parentElement?.parentElement;break}if(o&&!o.dataset.topPopupDisabled){if(o.dataset.topPopupOpened){const n=l.TopPopupWorker.getPopupFromOpener(o);n?.openerIsInput||n?.close();return}e.preventDefault(),await l.TopPopupWorker.openByOpener(o)}}}let g;const H={mounted:async(t,e)=>{g||(g=(await new Promise((c,a)=>r(["../utils/dom.amd"],c,a))).storage);const o=e.arg,n=e.value;g(t,o,n)}};let T,u=[],w;const I=async()=>{const{isVisible:t}=await new Promise((o,n)=>r(["../utils/dom.amd"],o,n));if(u=u.filter(t),!u.length)return;u[0].focus(),u=[]},L=async t=>{T||(T=await new Promise((e,o)=>r(["../utils/lodash.amd"],e,o))),w||(w=T.debounce(I,30)),u.push(t),w()},N={mounted:function(t,e){t.__TOP_V_FOCUS_VALUE=e.value??!0,(e.value??!0)&&L(t)},updated:function(t,e){e.modifiers.onupdate&&t.__TOP_V_FOCUS_VALUE!==(e.value??!0)&&(t.__TOP_V_FOCUS_VALUE=e.value??!0,(e.value??!0)&&L(t))}};let p,b;const $=t=>(typeof t=="boolean"||(t?t={...t}:t={},t.behavior??="smooth",t.block??="nearest",t.inline??="nearest"),t);let f,E;const W=async()=>{if(!f)return;const t=await S(f);t.isVisible&&f.scrollIntoView(t.scrollIntoViewOptions)},A=async t=>{b||(b=await new Promise((e,o)=>r(["../utils/lodash.amd"],e,o))),E||(E=b.debounce(W,30)),f=t,E()},S=async(t,e)=>{p||(p=await new Promise((n,s)=>r(["../utils/dom.amd"],n,s)));let o=p.storage(t,"v-top-scrollIntoView");return o||(o={isVisible:h.isVisible(t),scrollIntoViewOptions:$(e)},p.storage(t,"v-top-scrollIntoView",o)),o},K={async mounted(t,e){await S(t,e.value),e.modifiers.immediate&&A(t)},async updated(t,e){const o=await S(t,e.value);o.scrollIntoViewOptions=$(e.value);const n=h.isVisible(t);n&&o.isVisible!==n&&A(t),o.isVisible=n}};let d;const x={async mounted(t){d||(d=await new Promise((e,o)=>r(["../utils/scroll.amd"],e,o))),d.connectScrollShadow(t)},async unmounted(t){d||(d=await new Promise((e,o)=>r(["../utils/scroll.amd"],e,o))),d.unconnectScrollShadow(t)}},m=new Map;let C=!1;const F={ctrl:i.isMacOS()?"⌘":"Ctrl",alt:i.isMacOS()?"⌥":"Alt",shift:i.isMacOS()?"⇧":"Shift"},B=t=>{let e=t;return t.includes("Key")&&(e=t.replace("Key","")),t.includes("Digit")&&(e=t.replace("Digit","")),t==="Escape"&&(e="Esc"),e},V=(t,e)=>{const o=B(t);if(!e)return o;const{ctrl:n,alt:s,shift:c}=F,a=[];return e.ctrl&&a.push(n),e.alt&&a.push(s),e.shift&&a.push(c),a.push(o),a.join(i.isMacOS()?"":"+")},Y=(t,e,o)=>{const n=V(e,o);if(t.__TOP_V_SHORTCUT_VALUE){console.warn(`Element already has shortcut "${t.__TOP_V_SHORTCUT_VALUE}"`);return}if(m.has(n)){console.warn(`Shortcut "${n}" is taken`);return}m.set(n,t),t.title=t.title?`${t.title} (${n})`:n,t.__TOP_V_SHORTCUT_VALUE=n},j=t=>{const e=t.__TOP_V_SHORTCUT_VALUE;e&&m.delete(e)},G=()=>{C||(C=!0,document.addEventListener("keydown",t=>{if(!(t.target instanceof HTMLElement)||["INPUT","TEXTAREA"].includes(t.target.tagName)||t.target.isContentEditable)return;const e={ctrl:i.isMacOS()?t.metaKey:t.ctrlKey,alt:t.altKey,shift:t.shiftKey},o=V(t.code,e),n=m.get(o);n&&!n.disabled&&h.isVisible(n)&&(t.preventDefault(),n.click())}))},z={mounted:function(t,e){const{value:o,modifiers:n}=e;o&&(G(),Y(t,o,n))},unmounted(t){j(t)}};let y;const Q={mounted(t,e,o){const n=e.value||"top-sticky";y=new IntersectionObserver(s=>{let c=s[0].intersectionRatio<1;c&&e.modifiers.bottom&&s[0].intersectionRect.y===0&&(c=!1),t.classList.toggle(n,c)},{threshold:[1]}),y.observe(t)},unmounted(t,e,o){y?.disconnect()}};let k=!1,P;const v=new Map,X=(t,e)=>{const{distance:o,percent:n}=t.directiveSwipUpOptions,s=t.getBoundingClientRect().top,c=e*n/100/o,a=(e-s)/c;a<=o?t.style.transform=`translateY(${o-a}px)`:t.style.transform="translateY(0px)"},J=t=>{let e=window.innerHeight;window.addEventListener("scroll",()=>{v.forEach(o=>X(o,e))},{passive:!0}),P=new IntersectionObserver(o=>{e=window.innerHeight,o.forEach(n=>{const s=n.target;if(n.intersectionRatio<.1?v.delete(s):v.set(s,s),n.intersectionRatio===0){const{distance:c}=s.directiveSwipUpOptions;s.style.transform=`translateY(${c}px)`}})},{threshold:.1})},Z={mounted(t,e,o){i.Core.state.isMobileUA||(t.directiveSwipUpOptions={distance:e.value?.distance??100,percent:e.value?.percent??30},k||(J(),k=!0),P.observe(t))},unmounted(t,e,o){v.delete(t),P?.unobserve(t)}},O=t=>{if(!i.Core.$?.ui?.tooltip){console.info("Для работы v-top-tooltip требуется глобальная загрузка jQuery UI Tooltip");return}return i.Core.$(t)},D=(t,e)=>{const o=t.value??{};return o.content??=e.getAttribute("title")??"",o.content=String(o.content).replace(/([^<>])\r?\n([^<>])/g,"$1<br>$2"),o.position??={my:"bottom-18px",at:"top center",collision:"flipfit"},o},q={mounted(t,e){O(t)?.tooltip(D(e,t))},updated(t,e){const o=D(e,t),n=O(t);if(!n?.tooltip("instance")){n?.tooltip(o);return}n.tooltip("option",o)},unmounted(t){O(t)?.tooltip("destroy")}},tt=_.defineAsyncComponent(()=>new Promise((t,e)=>r(["./notice-CJ3WOTCM.amd"],t,e)));window.vd=console.log;const et={install:(t,e)=>{t.config.globalProperties.$core=i.Core,t.config.globalProperties.$vd=console.log;for(const o in e)i.Core.state[o]=e[o];e.widthForMobile&&(i.Core.widthForMobile=e.widthForMobile),e.themeName&&(i.Core.themeName=e.themeName),i.Core._setState(),e.topPopupOptions&&(l.TopPopupWorker.options=e.topPopupOptions),R.init(),U.TopDialogWorker.init(e.topDialogOptions),t.directive("top-data",H),t.directive("top-focus",N),t.directive("top-scroll-into-view",K),t.directive("top-scroll-shadow",x),t.directive("top-shortcut",z),t.directive("top-sticky",Q),t.directive("top-swim-up",Z),t.directive("top-tooltip",q),t.component("TopAvatar",i._sfc_main$6),t.component("TopButton",i._sfc_main$1),t.component("TopCheckbox",i._sfc_main$4),t.component("TopControlLabel",i._sfc_main$7),t.component("TopHint",i._sfc_main$2),t.component("TopInput",i._sfc_main),t.component("TopInputDate",i._sfc_main$8),t.component("TopInputRange",i._sfc_main$9),t.component("TopLoadbar",i.TopLoadbar),t.component("TopRadio",i._sfc_main$5),t.component("TopSelect",i._sfc_main$10),t.component("TopSwitcher",i._sfc_main$11),t.component("TopTextarea",i._sfc_main$3),t.component("TopNotice",tt),t.component("TopDialogs",U._sfc_main)}};M.core=et}));
2
- //# sourceMappingURL=core-B1CmZy7Z.amd.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"core-B1CmZy7Z.amd.js","sources":["../../src/components/popup/lib/worker.globalEvents.ts","../../src/core/directives/data.ts","../../src/core/directives/focus.ts","../../src/core/directives/scrollIntoView.ts","../../src/core/directives/scrollShadow.ts","../../src/core/directives/shortcut.ts","../../src/core/directives/sticky.ts","../../src/core/directives/swimUp.ts","../../src/core/directives/tooltip.ts","../../src/core/plugins/core.ts"],"sourcesContent":["import Core from '@/core/core/core';\nimport Events from '@/core/core/events';\nimport Worker from '@/components/popup/lib/worker';\n\n/**\n * Глобальные события, для реализации Popup\n */\nclass WorkerEvents {\n\n\tprivate static isInited = false;\n\n\t/**\n\t * Добавить глобальные обработчики\n\t *\n\t * Добавляются на страницу один раз и навсегда\n\t */\n\tstatic init(): void {\n\t\tif (this.isInited) return;\n\n\t\tthis.isInited = true;\n\n\t\t// автоматическое открытие при наведении мыши, событие глобальное, так как инициализация popup отложена\n\t\tdocument.addEventListener('mouseover', (e) => {\n\t\t\tif (!(e.target instanceof HTMLElement) || !e.target.dataset?.topPopupOpenByHover) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\te.target.click();\n\t\t});\n\n\t\t// при скролле страницы закрыть Popup\n\t\tdocument.addEventListener('scroll', () => {\n\t\t\tif (Core.state.isMobile || Core.state.isMobileUA) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tWorker.getAll().forEach(elPopup => Worker.close(elPopup));\n\t\t});\n\n\t\tEvents.addOnReize(e => {\n\t\t\t// закрыть popup при повороте экрана телефона\n\t\t\t// если была отображена ПК версия, она будет закрыта\n\t\t\tif (Core.state.isMobile && e.topEvent.widthDiff) {\n\t\t\t\tWorker.getAll().forEach(elPopup => Worker.close(elPopup));\n\t\t\t}\n\t\t});\n\n\t\tdocument.addEventListener('click', this.onclick, { capture: true });\n\t}\n\n\t/**\n\t * Глобальный обработчик кликов\n\t *\n\t * Обрабатывает клики на открытие Popup\n\t */\n\tprivate static async onclick(e: Event): Promise<void> {\n\t\tif (!(e.target instanceof HTMLElement)) return;\n\n\t\tif (e.target.dataset.topPopupDisabled) {\n\t\t\treturn;\n\t\t}\n\n\t\tlet elOpener: HTMLElement | undefined;\n\n\t\tswitch (true) {\n\t\t\tcase !!e.target.dataset?.topPopup:\n\t\t\t\telOpener = e.target;\n\n\t\t\t\tbreak;\n\n\t\t\tcase !!e.target.parentElement?.dataset.topPopup:\n\t\t\t\telOpener = e.target.parentElement;\n\n\t\t\t\tbreak;\n\n\t\t\tcase !!e.target.parentElement?.parentElement?.dataset.topPopup:\n\t\t\t\telOpener = e.target.parentElement?.parentElement;\n\n\t\t\t\tbreak;\n\t\t}\n\n\t\tif (!elOpener) {\n\t\t\treturn;\n\t\t}\n\n\t\tif (elOpener.dataset.topPopupDisabled) {\n\t\t\treturn;\n\t\t}\n\n\t\t// меню уже открыто\n\t\tif (elOpener.dataset.topPopupOpened) {\n\t\t\tconst popup = Worker.getPopupFromOpener(elOpener);\n\t\t\tif (!popup?.openerIsInput) {\n\t\t\t\tpopup?.close();\n\t\t\t}\n\n\t\t\treturn;\n\t\t}\n\n\t\te.preventDefault();\n\n\t\tawait Worker.openByOpener(elOpener);\n\t}\n}\n\nexport default WorkerEvents;\n","import type { DirectiveBinding, ObjectDirective } from 'vue';\n\nlet storage: any;\n\n/**\n * Сохранить данные в элементе\n *\n * Для доступа к данным можно воспользоваться ui/utils/dom storage()\n */\nconst data = {\n\tmounted: async (el: HTMLElement, binding: DirectiveBinding) => {\n\t\tif (!storage) {\n\t\t\tconst UtilsDom = await import('@/core/utils/dom');\n\n\t\t\tstorage = UtilsDom.storage;\n\t\t}\n\n\t\tconst name = binding.arg;\n\t\tconst value = binding.value;\n\n\t\tstorage(el, name, value);\n\t},\n};\n\nexport default data;\n","import type { DirectiveBinding } from 'vue';\n\ntype Binding = DirectiveBinding<boolean, 'onupdate'>;\n\nlet UtilsLodash: typeof import('@/core/utils/lodash');\n\n/**\n * Список элементов, на которых бала запрошена фокусировка, для дедупликации фокусировок\n */\nlet elsActive: HTMLElement[] = [];\n\n/**\n * Функция скролла с дедупликацией\n */\nlet focusOnElActiveDebounce: Function;\n\n/**\n * Выполнить фокусировку на активном элементе\n *\n * Если фокусирока запрошена на несколько элементов, будет выбран первый элемент\n */\nconst focusOnElActive = async () => {\n\tconst { isVisible } = await import('@/core/utils/dom');\n\telsActive = elsActive.filter(isVisible)\n\n\tif (!elsActive.length) return;\n\n\tconst el = elsActive[0];\n\n\tel.focus();\n\n\t// // UX: Если выбрано несколько чекбоксов или радио после выбора фокусировка будет снята, чтобы не делать выбор за пользователя\n\t// if (elsActive.length && el.nodeName === 'INPUT') {\n\t// \tconst type = (el as HTMLInputElement).type;\n\t// \tif (type === 'checkbox' || type === 'radio') el.blur();\n\t// }\n\n\telsActive = [];\n};\n\n/**\n * Выполнить дедуплицированную фокусировку на элементе\n */\nconst focusOnElDebounce = async (el: HTMLElement) => {\n\tif (!UtilsLodash) UtilsLodash = await import('@/core/utils/lodash');\n\tif (!focusOnElActiveDebounce) focusOnElActiveDebounce = UtilsLodash.debounce(focusOnElActive, 30);\n\n\telsActive.push(el);\n\n\tfocusOnElActiveDebounce();\n};\n\n/**\n * Фокусировка на элементе сразу после его отображения\n */\nconst focus = {\n\tmounted: function (el: HTMLElement, binding: Binding) {\n\t\tel['__TOP_V_FOCUS_VALUE'] = binding.value ?? true;\n\n\t\tif (binding.value ?? true) focusOnElDebounce(el);\n\t},\n\n\tupdated: function (el: HTMLElement, binding: Binding) {\n\t\tif (!binding.modifiers.onupdate) return;\n\n\t\tif (el['__TOP_V_FOCUS_VALUE'] === (binding.value ?? true)) return;\n\t\tel['__TOP_V_FOCUS_VALUE'] = binding.value ?? true;\n\n\t\tif (binding.value ?? true) focusOnElDebounce(el);\n\t},\n};\n\nexport default focus;\n","import type { DirectiveBinding, ObjectDirective } from 'vue';\nimport { isVisible } from '@/core/utils/dom';\n\ntype Binding = DirectiveBinding<ScrollIntoViewOptions | boolean | undefined, 'immediate'>;\n\ntype Storage = {\n\t/**\n\t * Сохраненное состояние видимости\n\t */\n\tisVisible: boolean,\n\n\t/**\n\t * Текущие настройки скролла\n\t */\n\tscrollIntoViewOptions: ScrollIntoViewOptions | boolean\n};\n\nlet UtilsDom: typeof import('@/core/utils/dom');\nlet UtilsLodash: typeof import('@/core/utils/lodash');\n\n/**\n * Сгенерировать настройки для скролла\n *\n * @see https://developer.mozilla.org/ru/docs/Web/API/Element/scrollIntoView\n */\nconst genScrollIntoViewOptions = (scrollIntoViewOptions?: ScrollIntoViewOptions | boolean) => {\n\tif (typeof scrollIntoViewOptions === 'boolean') return scrollIntoViewOptions;\n\n\tif (!scrollIntoViewOptions) {\n\t\tscrollIntoViewOptions = {};\n\t} else {\n\t\tscrollIntoViewOptions = { ...scrollIntoViewOptions };\n\t}\n\n\tscrollIntoViewOptions.behavior ??= 'smooth';\n\tscrollIntoViewOptions.block ??= 'nearest';\n\tscrollIntoViewOptions.inline ??= 'nearest';\n\n\treturn scrollIntoViewOptions;\n};\n\n/**\n * Активный элемент, для дедупликации скроллов\n *\n * Только один элемент на странице может считаться активным\n */\nlet elActive: HTMLElement | undefined;\n\n/**\n * Функция скролла с дедупликацией\n */\nlet scrollToElActiveDebounce: Function;\n\n/**\n * Выполнить скролл к текущему активному элементу\n */\nconst scrollToElActive = async () => {\n\tif (!elActive) return;\n\n\tconst storage = await useStorage(elActive);\n\tif (!storage.isVisible) return;\n\n\telActive.scrollIntoView(storage.scrollIntoViewOptions);\n};\n\n/**\n * Выполнить дедуплицированный скролл к элементу\n *\n * Будет выполнен скролл к самому последнему элементу, вызвавшему срабатывание директивы\n */\nconst scrollToElDebounce = async (el: HTMLElement) => {\n\tif (!UtilsLodash) UtilsLodash = await import('@/core/utils/lodash');\n\tif (!scrollToElActiveDebounce) scrollToElActiveDebounce = UtilsLodash.debounce(scrollToElActive, 30);\n\n\telActive = el;\n\n\tscrollToElActiveDebounce();\n};\n\n/**\n * Данные, связанные с элементом и директивой\n */\nconst useStorage = async (el: HTMLElement, scrollIntoViewOptions?: ScrollIntoViewOptions | boolean) => {\n\tif (!UtilsDom) UtilsDom = await import('@/core/utils/dom');\n\n\tlet storage: Storage | undefined = UtilsDom.storage(el, 'v-top-scrollIntoView');\n\n\t// инициализация\n\tif (!storage) {\n\t\tstorage = {\n\t\t\tisVisible: isVisible(el),\n\t\t\tscrollIntoViewOptions: genScrollIntoViewOptions(scrollIntoViewOptions),\n\t\t};\n\n\t\tUtilsDom.storage(el, 'v-top-scrollIntoView', storage);\n\t}\n\n\treturn storage;\n};\n\nconst scrollIntoView: ObjectDirective = {\n\tasync mounted(el: HTMLElement, binding: Binding) {\n\t\tawait useStorage(el, binding.value);\n\n\t\tif (binding.modifiers.immediate) {\n\t\t\tscrollToElDebounce(el);\n\t\t}\n\t},\n\n\tasync updated(el: HTMLElement, binding: Binding) {\n\t\tconst storage = await useStorage(el, binding.value);\n\t\tstorage.scrollIntoViewOptions = genScrollIntoViewOptions(binding.value);\n\n\t\tconst isVisibleNew = isVisible(el);\n\t\tif (isVisibleNew && storage.isVisible !== isVisibleNew) {\n\t\t\tscrollToElDebounce(el);\n\t\t}\n\n\t\tstorage.isVisible = isVisibleNew;\n\t},\n};\n\nexport default scrollIntoView;\n","let UtilsScroll: typeof import('@/core/utils/scroll');\n\n/**\n * Добавить отображение тени при появлении скролла у элемента\n *\n * Будут добавлены события для усатновки модификаторов тени в зависимости от скролла элемента\n *\n * Модификаторы:\n * - top-scrollShadow\n * - top-scrollShadow-started\n * - top-scrollShadow-finished\n */\nconst connectScrollShadow = {\n\tasync mounted(el) {\n\t\tif (!UtilsScroll) UtilsScroll = await import('@/core/utils/scroll');\n\n\t\tUtilsScroll.connectScrollShadow(el);\n\t},\n\n\tasync unmounted(el) {\n\t\tif (!UtilsScroll) UtilsScroll = await import('@/core/utils/scroll');\n\n\t\tUtilsScroll.unconnectScrollShadow(el);\n\t},\n};\n\nexport default connectScrollShadow;\n","import { isVisible } from '@/core/utils/dom';\nimport { isMacOS } from '@/core/utils/device';\nimport type { DirectiveBinding } from 'vue';\n\nexport type ShortcutValue = string;\n\n/**\n * Допустимые модификаторы\n */\ntype AllowedModifiers = 'ctrl' | 'shift' | 'alt';\ntype Binding = DirectiveBinding<ShortcutValue, AllowedModifiers>;\n\n/**\n * Список горячих клавиш и html элементов, на которые они назначены\n */\nconst elementByShortcut = new Map<string, HTMLElement>();\n\n/**\n * Добавлен ли обработчик события\n */\nlet isListenerAttached = false;\n\n/**\n * Отображение названий клавиш-модификаторов в зависимости от ОС\n *\n * В наших горячих клавишах Ctrl всегда соответствует Cmd в MacOS\n */\nconst modifierKeys = {\n\tctrl: isMacOS() ? '⌘' : 'Ctrl',\n\talt: isMacOS() ? '⌥' : 'Alt',\n\tshift: isMacOS() ? '⇧' : 'Shift',\n};\n\n/**\n * Получить название клавиши из event.code\n */\nconst getKeyLabel = (code: string) => {\n\tlet keyLabel = code;\n\n\tif (code.includes('Key')) keyLabel = code.replace('Key', '');\n\tif (code.includes('Digit')) keyLabel = code.replace('Digit', '');\n\tif (code === 'Escape') keyLabel = 'Esc';\n\n\treturn keyLabel;\n};\n\n/**\n * Сгенерировать строковое представление сочетания клавиш с модификаторами\n *\n * Приводим к виду \"Ctrl+Shift+A\" или \"⌘⇧A\" для MacOS\n */\nconst genShortcutString = (code: string, modifiers: Binding['modifiers']) => {\n\tconst keyLabel = getKeyLabel(code);\n\tif (!modifiers) return keyLabel;\n\n\tconst { ctrl, alt, shift } = modifierKeys;\n\tconst parts: string[] = [];\n\n\tif (modifiers.ctrl) parts.push(ctrl);\n\tif (modifiers.alt) parts.push(alt);\n\tif (modifiers.shift) parts.push(shift);\n\n\t// Основная клавиша\n\tparts.push(keyLabel);\n\n\treturn parts.join(isMacOS() ? '' : '+');\n};\n\nconst registerShortcut = (el: HTMLElement, value: ShortcutValue, modifiers: Binding['modifiers']) => {\n\tconst shortcut = genShortcutString(value, modifiers);\n\n\tif (el['__TOP_V_SHORTCUT_VALUE']) {\n\t\tconsole.warn(`Element already has shortcut \"${el['__TOP_V_SHORTCUT_VALUE']}\"`);\n\n\t\treturn;\n\t}\n\n\tif (elementByShortcut.has(shortcut)) {\n\t\tconsole.warn(`Shortcut \"${shortcut}\" is taken`);\n\n\t\treturn;\n\t}\n\n\telementByShortcut.set(shortcut, el);\n\tel.title = el.title ? `${el.title} (${shortcut})` : shortcut;\n\tel['__TOP_V_SHORTCUT_VALUE'] = shortcut;\n};\n\nconst unregisterShortcut = (el: HTMLElement) => {\n\tconst shortcut: string | undefined = el['__TOP_V_SHORTCUT_VALUE'];\n\tif (!shortcut) return;\n\n\telementByShortcut.delete(shortcut);\n};\n\nconst attachGlobalListener = () => {\n\tif (isListenerAttached) return;\n\tisListenerAttached = true;\n\n\tdocument.addEventListener('keydown', e => {\n\t\tif (!(e.target instanceof HTMLElement)) return;\n\t\tif (['INPUT', 'TEXTAREA'].includes(e.target.tagName) || e.target.isContentEditable) return;\n\n\t\tconst modifiers = {\n\t\t\tctrl: isMacOS() ? e.metaKey : e.ctrlKey,\n\t\t\talt: e.altKey,\n\t\t\tshift: e.shiftKey,\n\t\t};\n\n\t\tconst shortcut = genShortcutString(e.code, modifiers);\n\t\tconst element = elementByShortcut.get(shortcut);\n\n\t\tif (!element) return;\n\n\t\tif (!(element as any).disabled && isVisible(element)) {\n\t\t\te.preventDefault();\n\t\t\telement.click();\n\t\t}\n\t});\n};\n\nconst shortcut = {\n\tmounted: function (el: HTMLElement, binding: Binding) {\n\t\tconst { value, modifiers } = binding;\n\t\tif (!value) return;\n\n\t\tattachGlobalListener();\n\t\tregisterShortcut(el, value, modifiers);\n\t},\n\n\tunmounted(el: HTMLElement) {\n\t\tunregisterShortcut(el);\n\t},\n};\n\nexport default shortcut;\n","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\n\nlet appStickyObserver: IntersectionObserver;\n\n/**\n * Добавление sticky\n * К элементу добляется класс переданный как значение диррективы либо **'top-sticky'** по умолчанию\n */\nconst sticky = {\n\tmounted(el: HTMLElement, binding: DirectiveBinding, _vnode: VNode) {\n\t\tconst className = binding.value || 'top-sticky';\n\n\t\tappStickyObserver = new IntersectionObserver(entries => {\n\t\t\tlet condition = entries[0].intersectionRatio < 1;\n\t\t\tif (condition) {\n\t\t\t\tif (binding.modifiers.bottom && entries[0].intersectionRect.y === 0) condition = false;\n\t\t\t}\n\n\t\t\tel.classList.toggle(className, condition);\n\t\t}, {\n\t\t\tthreshold: [1],\n\t\t});\n\n\t\tappStickyObserver.observe(el);\n\t},\n\n\tunmounted(_el: HTMLElement, _binding: DirectiveBinding, _vnode: VNode) {\n\t\tappStickyObserver?.disconnect();\n\t},\n};\n\nexport default sticky;\n","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\nimport Core from '@/core/core/core';\n\ninterface HTMLElementWithSwimUpOptions extends HTMLElement {\n\tdirectiveSwipUpOptions: {\n\t\tdistance: number,\n\t\tpercent: number,\n\t};\n}\n\nlet appSwimUpInited = false;\nlet appSwimUpObserver: IntersectionObserver;\nconst appSwimUpEls = new Map();\n\n/**\n * Отодвинуть блок в зависимости от скролла старинцы\n * @param el\n * @param windowHeight\n */\nconst swimUpElTransform = (el: HTMLElementWithSwimUpOptions, windowHeight: number): void => {\n\tconst { distance, percent } = el.directiveSwipUpOptions;\n\n\tconst elTop = el.getBoundingClientRect().top;\n\n\t// во столько раз triggerHeight должен быть меньше, чтобы закончить подплытие к нужной высоте экрана\n\tconst triggerHeightReducer = windowHeight * percent / 100 / distance;\n\tconst triggerHeight = (windowHeight - elTop) / triggerHeightReducer;\n\n\tif (triggerHeight <= distance) {\n\t\tel.style.transform = `translateY(${distance - triggerHeight}px)`;\n\t} else {\n\t\tel.style.transform = 'translateY(0px)';\n\t}\n};\n\nconst swimUpInit = (_el: HTMLElementWithSwimUpOptions): void => {\n\tlet windowHeight = window.innerHeight;\n\n\twindow.addEventListener('scroll', () => {\n\t\tappSwimUpEls.forEach((el) => swimUpElTransform(el, windowHeight));\n\t}, { passive: true });\n\n\t// проверка того, что элемент в зоне видимости\n\tappSwimUpObserver = new IntersectionObserver(entries => {\n\t\twindowHeight = window.innerHeight;\n\n\t\tentries.forEach((entry) => {\n\t\t\tconst el = entry.target as HTMLElementWithSwimUpOptions;\n\n\t\t\tif (entry.intersectionRatio < 0.1) {\n\t\t\t\t// элемент за областью видимости\n\t\t\t\tappSwimUpEls.delete(el);\n\t\t\t} else {\n\t\t\t\t// элемент на экране\n\t\t\t\tappSwimUpEls.set(el, el);\n\t\t\t}\n\n\t\t\tif (entry.intersectionRatio === 0) {\n\t\t\t\tconst { distance } = el.directiveSwipUpOptions;\n\t\t\t\tel.style.transform = `translateY(${distance}px)`;\n\t\t\t}\n\t\t});\n\t}, {\n\t\tthreshold: 0.1,\n\t});\n};\n\n/**\n * Добавление анимации подплытия вверх для блока\n */\nconst swimUp = {\n\tmounted(el: HTMLElementWithSwimUpOptions, binding: DirectiveBinding, _vnode: VNode): void {\n\t\tif (Core.state.isMobileUA) return;\n\n\t\tel.directiveSwipUpOptions = {\n\t\t\tdistance: binding.value?.distance ?? 100, // количество px на которые блок изначально смещен вниз,\n\t\t\tpercent: binding.value?.percent ?? 30, // процент высоты экрана поднявшись на который блок закончит подплытие\n\t\t};\n\n\t\tif (!appSwimUpInited) {\n\t\t\tswimUpInit(el);\n\n\t\t\tappSwimUpInited = true;\n\t\t}\n\n\t\tappSwimUpObserver.observe(el);\n\t},\n\n\tunmounted(el: HTMLElementWithSwimUpOptions, _binding: DirectiveBinding, _vnode: VNode) {\n\t\tappSwimUpEls.delete(el);\n\t\tappSwimUpObserver?.unobserve(el);\n\t},\n};\n\nexport default swimUp;\n","import type { DirectiveBinding, ObjectDirective } from 'vue';\nimport Core from '@/core/core/core';\n\nconst $ = (el: HTMLElement) => {\n\tif (!Core.$?.ui?.tooltip) {\n\t\tconsole.info('Для работы v-top-tooltip требуется глобальная загрузка jQuery UI Tooltip');\n\n\t\treturn;\n\t}\n\n\treturn Core.$(el);\n};\n\nconst tvTooltipGenOptions = (binding: DirectiveBinding, el: HTMLElement): JQueryUI.TooltipOptions => {\n\tconst options = binding.value ?? {};\n\n\toptions.content ??= el.getAttribute('title') ?? '';\n\toptions.content = String(options.content).replace(/([^<>])\\r?\\n([^<>])/g, '$1<br>$2');\n\n\toptions.position ??= {\n\t\tmy: 'bottom-18px',\n\t\tat: 'top center',\n\t\tcollision: 'flipfit',\n\t};\n\n\treturn options;\n};\n\n/**\n * Добавление всплывающей подсказки к элементу.\n */\nconst tooltip: ObjectDirective<HTMLElement> = {\n\tmounted(el, binding) {\n\t\t$(el)?.tooltip(tvTooltipGenOptions(binding, el));\n\t},\n\n\tupdated(el, binding) {\n\t\t/**\n\t\t * В результате обновления может быть открыто несколько тултипов поэтому изменить опции, без перерисовки тултипа\n\t\t */\n\t\tconst options = tvTooltipGenOptions(binding, el);\n\t\tconst $el = $(el);\n\n\t\tif (!$el?.tooltip('instance')) {\n\t\t\t$el?.tooltip(options);\n\t\t\treturn;\n\t\t}\n\n\t\t$el.tooltip('option', options);\n\t},\n\n\tunmounted(el) {\n\t\t$(el)?.tooltip('destroy');\n\t},\n};\n\nexport default tooltip;\n","import { defineAsyncComponent, type Plugin } from 'vue';\nimport type { PartialBy } from '@/components/types';\n\nimport Core from '@/core/core/core';\nimport coreDefaultOptions from '@/core/core/options';\n\nimport * as Forms from '../../components/forms/forms';\n\nconst TopNotice = defineAsyncComponent(() => import('@/components/core/notice/notice.vue'));\n\nimport type { Options as TopPopupOptions } from '@/components/popup/lib/worker';\nimport TopPopupWorker from '@/components/popup/lib/worker';\nimport TopPopupWorkerGlobalEvents from '@/components/popup/lib/worker.globalEvents';\n\nimport TopDialogs from '@/components/dialog/dialog/dialogs/dialogs.vue';\nimport { TopDialogWorker } from '@/components/dialog/lib/worker';\nimport type { TopDialogOptions } from '@/components/dialog/lib/types';\n\nimport directiveData from '@/core/directives/data';\nimport directiveFocus from '@/core/directives/focus';\nimport directiveScrollIntoView from '@/core/directives/scrollIntoView';\nimport directiveScrollShadow from '@/core/directives/scrollShadow';\nimport directiveShortcut from '@/core/directives/shortcut';\nimport directiveSticky from '@/core/directives/sticky';\nimport directiveSwimUp from '@/core/directives/swimUp';\nimport directiveTooltip from '@/core/directives/tooltip';\n\ndeclare global {\n\tconst vd: typeof console.log;\n}\n\nwindow['vd'] = console.log;\n\ndeclare module '@vue/runtime-core' {\n\tinterface ComponentCustomProperties {\n\t\t/**\n\t\t * Статический класс с текущим состоянимем UI\n\t\t */\n\t\t$core: typeof Core;\n\n\t\t$vd: typeof console.log;\n\t}\n\n\t/**\n\t * Обязательные компоненты UI\n\t *\n\t * Они подключаются через плагин и доступны без явного указания импорта\n\t */\n\texport interface GlobalComponents {\n\t\tTopAvatar: typeof Forms.TopAvatar;\n\t\tTopButton: typeof Forms.TopButton;\n\t\tTopCheckbox: typeof Forms.TopCheckbox;\n\t\tTopControlLabel: typeof Forms.TopControlLabel;\n\t\tTopHint: typeof Forms.TopHint;\n\t\tTopInput: typeof Forms.TopInput;\n\t\tTopInputDate: typeof Forms.TopInputDate;\n\t\tTopInputRange: typeof Forms.TopInputRange;\n\t\tTopRadio: typeof Forms.TopRadio;\n\t\tTopSwitcher: typeof Forms.TopSwitcher;\n\t\tTopTextarea: typeof Forms.TopTextarea;\n\t\tTopSelect: typeof Forms.TopSelect;\n\t\tTopLoadbar: typeof Forms.TopLoadbar;\n\n\t\tTopNotice: typeof TopNotice;\n\t\tTopDialogs: typeof TopDialogs;\n\t}\n}\n\ntype CoreOptions = PartialBy<typeof coreDefaultOptions, 'timezoneOffset' | 'documentClassModificators'>;\n\ntype Options = CoreOptions & {\n\ttopPopupOptions?: TopPopupOptions\n\ttopDialogOptions?: TopDialogOptions\n};\n\n/**\n * Плагин для интеграции UI во Vue приложение\n *\n * - В глобальную область видимости шаблонов будет добавлен объект $core\n * - Будут зарегистрирвоаны директивы UI: https://ui.topvisor.com/?path=/docs/core-directives-focus--docs\n * - Будут подключены базовые компоненты UI/Forms: https://ui.topvisor.com/?path=/docs/components-forms-readme--docs\n */\nexport default {\n\n\tinstall: (app, options: Options) => {\n\t\tapp.config.globalProperties.$core = Core;\n\t\tapp.config.globalProperties.$vd = console.log;\n\n\t\t// начальные настройки UI\n\t\tfor (const name in options) {\n\t\t\tCore.state[name] = options[name];\n\t\t}\n\n\t\tif (options.widthForMobile) Core.widthForMobile = options.widthForMobile;\n\t\tif (options.themeName) Core.themeName = options.themeName;\n\n\t\tCore._setState();\n\n\t\tif (options.topPopupOptions) TopPopupWorker.options = options.topPopupOptions;\n\t\tTopPopupWorkerGlobalEvents.init();\n\n\t\tTopDialogWorker.init(options.topDialogOptions);\n\n\t\t// определение директив\n\t\tapp.directive('top-data', directiveData);\n\t\tapp.directive('top-focus', directiveFocus);\n\t\tapp.directive('top-scroll-into-view', directiveScrollIntoView);\n\t\tapp.directive('top-scroll-shadow', directiveScrollShadow);\n\t\tapp.directive('top-shortcut', directiveShortcut);\n\t\tapp.directive('top-sticky', directiveSticky);\n\t\tapp.directive('top-swim-up', directiveSwimUp);\n\t\tapp.directive('top-tooltip', directiveTooltip);\n\n\t\t// определение базовых компонентов\n\t\tapp.component('TopAvatar', Forms.TopAvatar);\n\t\tapp.component('TopButton', Forms.TopButton);\n\t\tapp.component('TopCheckbox', Forms.TopCheckbox);\n\t\tapp.component('TopControlLabel', Forms.TopControlLabel);\n\t\tapp.component('TopHint', Forms.TopHint);\n\t\tapp.component('TopInput', Forms.TopInput);\n\t\tapp.component('TopInputDate', Forms.TopInputDate);\n\t\tapp.component('TopInputRange', Forms.TopInputRange);\n\t\tapp.component('TopLoadbar', Forms.TopLoadbar);\n\t\tapp.component('TopRadio', Forms.TopRadio);\n\t\tapp.component('TopSelect', Forms.TopSelect);\n\t\tapp.component('TopSwitcher', Forms.TopSwitcher);\n\t\tapp.component('TopTextarea', Forms.TopTextarea);\n\n\t\tapp.component('TopNotice', TopNotice);\n\t\tapp.component('TopDialogs', TopDialogs);\n\t},\n\n} satisfies Plugin<Options>;\n"],"names":["WorkerEvents","forms","popup_worker","elPopup","elOpener","popup","storage","data","el","binding","resolve","reject","require","name","value","UtilsLodash$1","focusOnElActiveDebounce","elsActive","isVisible","focusOnElDebounce","focusOnElActive","focus","UtilsDom","UtilsLodash","genScrollIntoViewOptions","scrollIntoViewOptions","elActive","scrollToElActiveDebounce","useStorage","scrollToElDebounce","scrollToElActive","utils_dom","scrollIntoView","isVisibleNew","UtilsScroll","connectScrollShadow","elementByShortcut","modifierKeys","getKeyLabel","code","keyLabel","genShortcutString","modifiers","parts","shortcut2","unregisterShortcut","e","shortcut","attachGlobalListener","registerShortcut","appStickyObserver","sticky","_vnode","className","entries","_el","_binding","appSwimUpObserver","appSwimUpEls","swimUpElTransform","windowHeight","triggerHeight","distance","swimUpInit","entry","swimUp","$","tvTooltipGenOptions","options","tooltip","$el","core","app","dialogs_vue_vue_type_script_setup_true_lang","TopNotice"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"core-BM3jtOUr.es.js","sources":["../../src/components/popup/lib/worker.globalEvents.ts","../../src/core/directives/data.ts","../../src/core/directives/focus.ts","../../src/core/directives/scrollIntoView.ts","../../src/core/directives/scrollShadow.ts","../../src/core/directives/shortcut.ts","../../src/core/directives/sticky.ts","../../src/core/directives/swimUp.ts","../../src/core/directives/tooltip.ts","../../src/core/plugins/core.ts"],"sourcesContent":["import Core from '@/core/core/core';\nimport Events from '@/core/core/events';\nimport Worker from '@/components/popup/lib/worker';\n\n/**\n * Глобальные события, для реализации Popup\n */\nclass WorkerEvents {\n\n\tprivate static isInited = false;\n\n\t/**\n\t * Добавить глобальные обработчики\n\t *\n\t * Добавляются на страницу один раз и навсегда\n\t */\n\tstatic init(): void {\n\t\tif (this.isInited) return;\n\n\t\tthis.isInited = true;\n\n\t\t// автоматическое открытие при наведении мыши, событие глобальное, так как инициализация popup отложена\n\t\tdocument.addEventListener('mouseover', (e) => {\n\t\t\tif (!(e.target instanceof HTMLElement) || !e.target.dataset?.topPopupOpenByHover) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\te.target.click();\n\t\t});\n\n\t\t// при скролле страницы закрыть Popup\n\t\tdocument.addEventListener('scroll', () => {\n\t\t\tif (Core.state.isMobile || Core.state.isMobileUA) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tWorker.getAll().forEach(elPopup => Worker.close(elPopup));\n\t\t});\n\n\t\tEvents.addOnReize(e => {\n\t\t\t// закрыть popup при повороте экрана телефона\n\t\t\t// если была отображена ПК версия, она будет закрыта\n\t\t\tif (Core.state.isMobile && e.topEvent.widthDiff) {\n\t\t\t\tWorker.getAll().forEach(elPopup => Worker.close(elPopup));\n\t\t\t}\n\t\t});\n\n\t\tdocument.addEventListener('click', this.onclick, { capture: true });\n\t}\n\n\t/**\n\t * Глобальный обработчик кликов\n\t *\n\t * Обрабатывает клики на открытие Popup\n\t */\n\tprivate static async onclick(e: Event): Promise<void> {\n\t\tif (!(e.target instanceof HTMLElement)) return;\n\n\t\tif (e.target.dataset.topPopupDisabled) {\n\t\t\treturn;\n\t\t}\n\n\t\tlet elOpener: HTMLElement | undefined;\n\n\t\tswitch (true) {\n\t\t\tcase !!e.target.dataset?.topPopup:\n\t\t\t\telOpener = e.target;\n\n\t\t\t\tbreak;\n\n\t\t\tcase !!e.target.parentElement?.dataset.topPopup:\n\t\t\t\telOpener = e.target.parentElement;\n\n\t\t\t\tbreak;\n\n\t\t\tcase !!e.target.parentElement?.parentElement?.dataset.topPopup:\n\t\t\t\telOpener = e.target.parentElement?.parentElement;\n\n\t\t\t\tbreak;\n\t\t}\n\n\t\tif (!elOpener) {\n\t\t\treturn;\n\t\t}\n\n\t\tif (elOpener.dataset.topPopupDisabled) {\n\t\t\treturn;\n\t\t}\n\n\t\t// меню уже открыто\n\t\tif (elOpener.dataset.topPopupOpened) {\n\t\t\tconst popup = Worker.getPopupFromOpener(elOpener);\n\t\t\tif (!popup?.openerIsInput) {\n\t\t\t\tpopup?.close();\n\t\t\t}\n\n\t\t\treturn;\n\t\t}\n\n\t\te.preventDefault();\n\n\t\tawait Worker.openByOpener(elOpener);\n\t}\n}\n\nexport default WorkerEvents;\n","import type { DirectiveBinding, ObjectDirective } from 'vue';\n\nlet storage: any;\n\n/**\n * Сохранить данные в элементе\n *\n * Для доступа к данным можно воспользоваться ui/utils/dom storage()\n */\nconst data = {\n\tmounted: async (el: HTMLElement, binding: DirectiveBinding) => {\n\t\tif (!storage) {\n\t\t\tconst UtilsDom = await import('@/core/utils/dom');\n\n\t\t\tstorage = UtilsDom.storage;\n\t\t}\n\n\t\tconst name = binding.arg;\n\t\tconst value = binding.value;\n\n\t\tstorage(el, name, value);\n\t},\n};\n\nexport default data;\n","import type { DirectiveBinding } from 'vue';\n\ntype Binding = DirectiveBinding<boolean, 'onupdate'>;\n\nlet UtilsLodash: typeof import('@/core/utils/lodash');\n\n/**\n * Список элементов, на которых бала запрошена фокусировка, для дедупликации фокусировок\n */\nlet elsActive: HTMLElement[] = [];\n\n/**\n * Функция скролла с дедупликацией\n */\nlet focusOnElActiveDebounce: Function;\n\n/**\n * Выполнить фокусировку на активном элементе\n *\n * Если фокусирока запрошена на несколько элементов, будет выбран первый элемент\n */\nconst focusOnElActive = async () => {\n\tconst { isVisible } = await import('@/core/utils/dom');\n\telsActive = elsActive.filter(isVisible)\n\n\tif (!elsActive.length) return;\n\n\tconst el = elsActive[0];\n\n\tel.focus();\n\n\t// // UX: Если выбрано несколько чекбоксов или радио после выбора фокусировка будет снята, чтобы не делать выбор за пользователя\n\t// if (elsActive.length && el.nodeName === 'INPUT') {\n\t// \tconst type = (el as HTMLInputElement).type;\n\t// \tif (type === 'checkbox' || type === 'radio') el.blur();\n\t// }\n\n\telsActive = [];\n};\n\n/**\n * Выполнить дедуплицированную фокусировку на элементе\n */\nconst focusOnElDebounce = async (el: HTMLElement) => {\n\tif (!UtilsLodash) UtilsLodash = await import('@/core/utils/lodash');\n\tif (!focusOnElActiveDebounce) focusOnElActiveDebounce = UtilsLodash.debounce(focusOnElActive, 30);\n\n\telsActive.push(el);\n\n\tfocusOnElActiveDebounce();\n};\n\n/**\n * Фокусировка на элементе сразу после его отображения\n */\nconst focus = {\n\tmounted: function (el: HTMLElement, binding: Binding) {\n\t\tel['__TOP_V_FOCUS_VALUE'] = binding.value ?? true;\n\n\t\tif (binding.value ?? true) focusOnElDebounce(el);\n\t},\n\n\tupdated: function (el: HTMLElement, binding: Binding) {\n\t\tif (!binding.modifiers.onupdate) return;\n\n\t\tif (el['__TOP_V_FOCUS_VALUE'] === (binding.value ?? true)) return;\n\t\tel['__TOP_V_FOCUS_VALUE'] = binding.value ?? true;\n\n\t\tif (binding.value ?? true) focusOnElDebounce(el);\n\t},\n};\n\nexport default focus;\n","import type { DirectiveBinding, ObjectDirective } from 'vue';\nimport { isVisible } from '@/core/utils/dom';\n\ntype Binding = DirectiveBinding<ScrollIntoViewOptions | boolean | undefined, 'immediate'>;\n\ntype Storage = {\n\t/**\n\t * Сохраненное состояние видимости\n\t */\n\tisVisible: boolean,\n\n\t/**\n\t * Текущие настройки скролла\n\t */\n\tscrollIntoViewOptions: ScrollIntoViewOptions | boolean\n};\n\nlet UtilsDom: typeof import('@/core/utils/dom');\nlet UtilsLodash: typeof import('@/core/utils/lodash');\n\n/**\n * Сгенерировать настройки для скролла\n *\n * @see https://developer.mozilla.org/ru/docs/Web/API/Element/scrollIntoView\n */\nconst genScrollIntoViewOptions = (scrollIntoViewOptions?: ScrollIntoViewOptions | boolean) => {\n\tif (typeof scrollIntoViewOptions === 'boolean') return scrollIntoViewOptions;\n\n\tif (!scrollIntoViewOptions) {\n\t\tscrollIntoViewOptions = {};\n\t} else {\n\t\tscrollIntoViewOptions = { ...scrollIntoViewOptions };\n\t}\n\n\tscrollIntoViewOptions.behavior ??= 'smooth';\n\tscrollIntoViewOptions.block ??= 'nearest';\n\tscrollIntoViewOptions.inline ??= 'nearest';\n\n\treturn scrollIntoViewOptions;\n};\n\n/**\n * Активный элемент, для дедупликации скроллов\n *\n * Только один элемент на странице может считаться активным\n */\nlet elActive: HTMLElement | undefined;\n\n/**\n * Функция скролла с дедупликацией\n */\nlet scrollToElActiveDebounce: Function;\n\n/**\n * Выполнить скролл к текущему активному элементу\n */\nconst scrollToElActive = async () => {\n\tif (!elActive) return;\n\n\tconst storage = await useStorage(elActive);\n\tif (!storage.isVisible) return;\n\n\telActive.scrollIntoView(storage.scrollIntoViewOptions);\n};\n\n/**\n * Выполнить дедуплицированный скролл к элементу\n *\n * Будет выполнен скролл к самому последнему элементу, вызвавшему срабатывание директивы\n */\nconst scrollToElDebounce = async (el: HTMLElement) => {\n\tif (!UtilsLodash) UtilsLodash = await import('@/core/utils/lodash');\n\tif (!scrollToElActiveDebounce) scrollToElActiveDebounce = UtilsLodash.debounce(scrollToElActive, 30);\n\n\telActive = el;\n\n\tscrollToElActiveDebounce();\n};\n\n/**\n * Данные, связанные с элементом и директивой\n */\nconst useStorage = async (el: HTMLElement, scrollIntoViewOptions?: ScrollIntoViewOptions | boolean) => {\n\tif (!UtilsDom) UtilsDom = await import('@/core/utils/dom');\n\n\tlet storage: Storage | undefined = UtilsDom.storage(el, 'v-top-scrollIntoView');\n\n\t// инициализация\n\tif (!storage) {\n\t\tstorage = {\n\t\t\tisVisible: isVisible(el),\n\t\t\tscrollIntoViewOptions: genScrollIntoViewOptions(scrollIntoViewOptions),\n\t\t};\n\n\t\tUtilsDom.storage(el, 'v-top-scrollIntoView', storage);\n\t}\n\n\treturn storage;\n};\n\nconst scrollIntoView: ObjectDirective = {\n\tasync mounted(el: HTMLElement, binding: Binding) {\n\t\tawait useStorage(el, binding.value);\n\n\t\tif (binding.modifiers.immediate) {\n\t\t\tscrollToElDebounce(el);\n\t\t}\n\t},\n\n\tasync updated(el: HTMLElement, binding: Binding) {\n\t\tconst storage = await useStorage(el, binding.value);\n\t\tstorage.scrollIntoViewOptions = genScrollIntoViewOptions(binding.value);\n\n\t\tconst isVisibleNew = isVisible(el);\n\t\tif (isVisibleNew && storage.isVisible !== isVisibleNew) {\n\t\t\tscrollToElDebounce(el);\n\t\t}\n\n\t\tstorage.isVisible = isVisibleNew;\n\t},\n};\n\nexport default scrollIntoView;\n","let UtilsScroll: typeof import('@/core/utils/scroll');\n\n/**\n * Добавить отображение тени при появлении скролла у элемента\n *\n * Будут добавлены события для усатновки модификаторов тени в зависимости от скролла элемента\n *\n * Модификаторы:\n * - top-scrollShadow\n * - top-scrollShadow-started\n * - top-scrollShadow-finished\n */\nconst connectScrollShadow = {\n\tasync mounted(el) {\n\t\tif (!UtilsScroll) UtilsScroll = await import('@/core/utils/scroll');\n\n\t\tUtilsScroll.connectScrollShadow(el);\n\t},\n\n\tasync unmounted(el) {\n\t\tif (!UtilsScroll) UtilsScroll = await import('@/core/utils/scroll');\n\n\t\tUtilsScroll.unconnectScrollShadow(el);\n\t},\n};\n\nexport default connectScrollShadow;\n","import { isVisible } from '@/core/utils/dom';\nimport { isMacOS } from '@/core/utils/device';\nimport type { DirectiveBinding } from 'vue';\n\nexport type ShortcutValue = string;\n\n/**\n * Допустимые модификаторы\n */\ntype AllowedModifiers = 'ctrl' | 'shift' | 'alt';\ntype Binding = DirectiveBinding<ShortcutValue, AllowedModifiers>;\n\n/**\n * Список горячих клавиш и html элементов, на которые они назначены\n */\nconst elementByShortcut = new Map<string, HTMLElement>();\n\n/**\n * Добавлен ли обработчик события\n */\nlet isListenerAttached = false;\n\n/**\n * Отображение названий клавиш-модификаторов в зависимости от ОС\n *\n * В наших горячих клавишах Ctrl всегда соответствует Cmd в MacOS\n */\nconst modifierKeys = {\n\tctrl: isMacOS() ? '⌘' : 'Ctrl',\n\talt: isMacOS() ? '⌥' : 'Alt',\n\tshift: isMacOS() ? '⇧' : 'Shift',\n};\n\n/**\n * Получить название клавиши из event.code\n */\nconst getKeyLabel = (code: string) => {\n\tlet keyLabel = code;\n\n\tif (code.includes('Key')) keyLabel = code.replace('Key', '');\n\tif (code.includes('Digit')) keyLabel = code.replace('Digit', '');\n\tif (code === 'Escape') keyLabel = 'Esc';\n\n\treturn keyLabel;\n};\n\n/**\n * Сгенерировать строковое представление сочетания клавиш с модификаторами\n *\n * Приводим к виду \"Ctrl+Shift+A\" или \"⌘⇧A\" для MacOS\n */\nconst genShortcutString = (code: string, modifiers: Binding['modifiers']) => {\n\tconst keyLabel = getKeyLabel(code);\n\tif (!modifiers) return keyLabel;\n\n\tconst { ctrl, alt, shift } = modifierKeys;\n\tconst parts: string[] = [];\n\n\tif (modifiers.ctrl) parts.push(ctrl);\n\tif (modifiers.alt) parts.push(alt);\n\tif (modifiers.shift) parts.push(shift);\n\n\t// Основная клавиша\n\tparts.push(keyLabel);\n\n\treturn parts.join(isMacOS() ? '' : '+');\n};\n\nconst registerShortcut = (el: HTMLElement, value: ShortcutValue, modifiers: Binding['modifiers']) => {\n\tconst shortcut = genShortcutString(value, modifiers);\n\n\tif (el['__TOP_V_SHORTCUT_VALUE']) {\n\t\tconsole.warn(`Element already has shortcut \"${el['__TOP_V_SHORTCUT_VALUE']}\"`);\n\n\t\treturn;\n\t}\n\n\tif (elementByShortcut.has(shortcut)) {\n\t\tconsole.warn(`Shortcut \"${shortcut}\" is taken`);\n\n\t\treturn;\n\t}\n\n\telementByShortcut.set(shortcut, el);\n\tel.title = el.title ? `${el.title} (${shortcut})` : shortcut;\n\tel['__TOP_V_SHORTCUT_VALUE'] = shortcut;\n};\n\nconst unregisterShortcut = (el: HTMLElement) => {\n\tconst shortcut: string | undefined = el['__TOP_V_SHORTCUT_VALUE'];\n\tif (!shortcut) return;\n\n\telementByShortcut.delete(shortcut);\n};\n\nconst attachGlobalListener = () => {\n\tif (isListenerAttached) return;\n\tisListenerAttached = true;\n\n\tdocument.addEventListener('keydown', e => {\n\t\tif (!(e.target instanceof HTMLElement)) return;\n\t\tif (['INPUT', 'TEXTAREA'].includes(e.target.tagName) || e.target.isContentEditable) return;\n\n\t\tconst modifiers = {\n\t\t\tctrl: isMacOS() ? e.metaKey : e.ctrlKey,\n\t\t\talt: e.altKey,\n\t\t\tshift: e.shiftKey,\n\t\t};\n\n\t\tconst shortcut = genShortcutString(e.code, modifiers);\n\t\tconst element = elementByShortcut.get(shortcut);\n\n\t\tif (!element) return;\n\n\t\tif (!(element as any).disabled && isVisible(element)) {\n\t\t\te.preventDefault();\n\t\t\telement.click();\n\t\t}\n\t});\n};\n\nconst shortcut = {\n\tmounted: function (el: HTMLElement, binding: Binding) {\n\t\tconst { value, modifiers } = binding;\n\t\tif (!value) return;\n\n\t\tattachGlobalListener();\n\t\tregisterShortcut(el, value, modifiers);\n\t},\n\n\tunmounted(el: HTMLElement) {\n\t\tunregisterShortcut(el);\n\t},\n};\n\nexport default shortcut;\n","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\n\nlet appStickyObserver: IntersectionObserver;\n\n/**\n * Добавление sticky\n * К элементу добляется класс переданный как значение диррективы либо **'top-sticky'** по умолчанию\n */\nconst sticky = {\n\tmounted(el: HTMLElement, binding: DirectiveBinding, _vnode: VNode) {\n\t\tconst className = binding.value || 'top-sticky';\n\n\t\tappStickyObserver = new IntersectionObserver(entries => {\n\t\t\tlet condition = entries[0].intersectionRatio < 1;\n\t\t\tif (condition) {\n\t\t\t\tif (binding.modifiers.bottom && entries[0].intersectionRect.y === 0) condition = false;\n\t\t\t}\n\n\t\t\tel.classList.toggle(className, condition);\n\t\t}, {\n\t\t\tthreshold: [1],\n\t\t});\n\n\t\tappStickyObserver.observe(el);\n\t},\n\n\tunmounted(_el: HTMLElement, _binding: DirectiveBinding, _vnode: VNode) {\n\t\tappStickyObserver?.disconnect();\n\t},\n};\n\nexport default sticky;\n","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\nimport Core from '@/core/core/core';\n\ninterface HTMLElementWithSwimUpOptions extends HTMLElement {\n\tdirectiveSwipUpOptions: {\n\t\tdistance: number,\n\t\tpercent: number,\n\t};\n}\n\nlet appSwimUpInited = false;\nlet appSwimUpObserver: IntersectionObserver;\nconst appSwimUpEls = new Map();\n\n/**\n * Отодвинуть блок в зависимости от скролла старинцы\n * @param el\n * @param windowHeight\n */\nconst swimUpElTransform = (el: HTMLElementWithSwimUpOptions, windowHeight: number): void => {\n\tconst { distance, percent } = el.directiveSwipUpOptions;\n\n\tconst elTop = el.getBoundingClientRect().top;\n\n\t// во столько раз triggerHeight должен быть меньше, чтобы закончить подплытие к нужной высоте экрана\n\tconst triggerHeightReducer = windowHeight * percent / 100 / distance;\n\tconst triggerHeight = (windowHeight - elTop) / triggerHeightReducer;\n\n\tif (triggerHeight <= distance) {\n\t\tel.style.transform = `translateY(${distance - triggerHeight}px)`;\n\t} else {\n\t\tel.style.transform = 'translateY(0px)';\n\t}\n};\n\nconst swimUpInit = (_el: HTMLElementWithSwimUpOptions): void => {\n\tlet windowHeight = window.innerHeight;\n\n\twindow.addEventListener('scroll', () => {\n\t\tappSwimUpEls.forEach((el) => swimUpElTransform(el, windowHeight));\n\t}, { passive: true });\n\n\t// проверка того, что элемент в зоне видимости\n\tappSwimUpObserver = new IntersectionObserver(entries => {\n\t\twindowHeight = window.innerHeight;\n\n\t\tentries.forEach((entry) => {\n\t\t\tconst el = entry.target as HTMLElementWithSwimUpOptions;\n\n\t\t\tif (entry.intersectionRatio < 0.1) {\n\t\t\t\t// элемент за областью видимости\n\t\t\t\tappSwimUpEls.delete(el);\n\t\t\t} else {\n\t\t\t\t// элемент на экране\n\t\t\t\tappSwimUpEls.set(el, el);\n\t\t\t}\n\n\t\t\tif (entry.intersectionRatio === 0) {\n\t\t\t\tconst { distance } = el.directiveSwipUpOptions;\n\t\t\t\tel.style.transform = `translateY(${distance}px)`;\n\t\t\t}\n\t\t});\n\t}, {\n\t\tthreshold: 0.1,\n\t});\n};\n\n/**\n * Добавление анимации подплытия вверх для блока\n */\nconst swimUp = {\n\tmounted(el: HTMLElementWithSwimUpOptions, binding: DirectiveBinding, _vnode: VNode): void {\n\t\tif (Core.state.isMobileUA) return;\n\n\t\tel.directiveSwipUpOptions = {\n\t\t\tdistance: binding.value?.distance ?? 100, // количество px на которые блок изначально смещен вниз,\n\t\t\tpercent: binding.value?.percent ?? 30, // процент высоты экрана поднявшись на который блок закончит подплытие\n\t\t};\n\n\t\tif (!appSwimUpInited) {\n\t\t\tswimUpInit(el);\n\n\t\t\tappSwimUpInited = true;\n\t\t}\n\n\t\tappSwimUpObserver.observe(el);\n\t},\n\n\tunmounted(el: HTMLElementWithSwimUpOptions, _binding: DirectiveBinding, _vnode: VNode) {\n\t\tappSwimUpEls.delete(el);\n\t\tappSwimUpObserver?.unobserve(el);\n\t},\n};\n\nexport default swimUp;\n","import type { DirectiveBinding, ObjectDirective } from 'vue';\nimport Core from '@/core/core/core';\n\nconst $ = (el: HTMLElement) => {\n\tif (!Core.$?.ui?.tooltip) {\n\t\tconsole.info('Для работы v-top-tooltip требуется глобальная загрузка jQuery UI Tooltip');\n\n\t\treturn;\n\t}\n\n\treturn Core.$(el);\n};\n\nconst tvTooltipGenOptions = (binding: DirectiveBinding, el: HTMLElement): JQueryUI.TooltipOptions => {\n\tconst options = binding.value ?? {};\n\n\toptions.content ??= el.getAttribute('title') ?? '';\n\toptions.content = String(options.content).replace(/([^<>])\\r?\\n([^<>])/g, '$1<br>$2');\n\n\toptions.position ??= {\n\t\tmy: 'bottom-18px',\n\t\tat: 'top center',\n\t\tcollision: 'flipfit',\n\t};\n\n\treturn options;\n};\n\n/**\n * Добавление всплывающей подсказки к элементу.\n */\nconst tooltip: ObjectDirective<HTMLElement> = {\n\tmounted(el, binding) {\n\t\t$(el)?.tooltip(tvTooltipGenOptions(binding, el));\n\t},\n\n\tupdated(el, binding) {\n\t\t/**\n\t\t * В результате обновления может быть открыто несколько тултипов поэтому изменить опции, без перерисовки тултипа\n\t\t */\n\t\tconst options = tvTooltipGenOptions(binding, el);\n\t\tconst $el = $(el);\n\n\t\tif (!$el?.tooltip('instance')) {\n\t\t\t$el?.tooltip(options);\n\t\t\treturn;\n\t\t}\n\n\t\t$el.tooltip('option', options);\n\t},\n\n\tunmounted(el) {\n\t\t$(el)?.tooltip('destroy');\n\t},\n};\n\nexport default tooltip;\n","import { defineAsyncComponent, type Plugin } from 'vue';\nimport type { PartialBy } from '@/components/types';\n\nimport Core from '@/core/core/core';\nimport coreDefaultOptions from '@/core/core/options';\n\nimport * as Forms from '../../components/forms/forms';\n\nconst TopNotice = defineAsyncComponent(() => import('@/components/core/notice/notice.vue'));\n\nimport type { Options as TopPopupOptions } from '@/components/popup/lib/worker';\nimport TopPopupWorker from '@/components/popup/lib/worker';\nimport TopPopupWorkerGlobalEvents from '@/components/popup/lib/worker.globalEvents';\n\nimport TopDialogs from '@/components/dialog/dialog/dialogs/dialogs.vue';\nimport { TopDialogWorker } from '@/components/dialog/lib/worker';\nimport type { TopDialogOptions } from '@/components/dialog/lib/types';\n\nimport directiveData from '@/core/directives/data';\nimport directiveFocus from '@/core/directives/focus';\nimport directiveScrollIntoView from '@/core/directives/scrollIntoView';\nimport directiveScrollShadow from '@/core/directives/scrollShadow';\nimport directiveShortcut from '@/core/directives/shortcut';\nimport directiveSticky from '@/core/directives/sticky';\nimport directiveSwimUp from '@/core/directives/swimUp';\nimport directiveTooltip from '@/core/directives/tooltip';\n\ndeclare global {\n\tconst vd: typeof console.log;\n}\n\nwindow['vd'] = console.log;\n\ndeclare module '@vue/runtime-core' {\n\tinterface ComponentCustomProperties {\n\t\t/**\n\t\t * Статический класс с текущим состоянимем UI\n\t\t */\n\t\t$core: typeof Core;\n\n\t\t$vd: typeof console.log;\n\t}\n\n\t/**\n\t * Обязательные компоненты UI\n\t *\n\t * Они подключаются через плагин и доступны без явного указания импорта\n\t */\n\texport interface GlobalComponents {\n\t\tTopAvatar: typeof Forms.TopAvatar;\n\t\tTopButton: typeof Forms.TopButton;\n\t\tTopCheckbox: typeof Forms.TopCheckbox;\n\t\tTopControlLabel: typeof Forms.TopControlLabel;\n\t\tTopHint: typeof Forms.TopHint;\n\t\tTopInput: typeof Forms.TopInput;\n\t\tTopInputDate: typeof Forms.TopInputDate;\n\t\tTopInputRange: typeof Forms.TopInputRange;\n\t\tTopRadio: typeof Forms.TopRadio;\n\t\tTopSwitcher: typeof Forms.TopSwitcher;\n\t\tTopTextarea: typeof Forms.TopTextarea;\n\t\tTopSelect: typeof Forms.TopSelect;\n\t\tTopLoadbar: typeof Forms.TopLoadbar;\n\n\t\tTopNotice: typeof TopNotice;\n\t\tTopDialogs: typeof TopDialogs;\n\t}\n}\n\ntype CoreOptions = PartialBy<typeof coreDefaultOptions, 'timezoneOffset' | 'documentClassModificators'>;\n\ntype Options = CoreOptions & {\n\ttopPopupOptions?: TopPopupOptions\n\ttopDialogOptions?: TopDialogOptions\n};\n\n/**\n * Плагин для интеграции UI во Vue приложение\n *\n * - В глобальную область видимости шаблонов будет добавлен объект $core\n * - Будут зарегистрирвоаны директивы UI: https://ui.topvisor.com/?path=/docs/core-directives-focus--docs\n * - Будут подключены базовые компоненты UI/Forms: https://ui.topvisor.com/?path=/docs/components-forms-readme--docs\n */\nexport default {\n\n\tinstall: (app, options: Options) => {\n\t\tapp.config.globalProperties.$core = Core;\n\t\tapp.config.globalProperties.$vd = console.log;\n\n\t\t// начальные настройки UI\n\t\tfor (const name in options) {\n\t\t\tCore.state[name] = options[name];\n\t\t}\n\n\t\tif (options.widthForMobile) Core.widthForMobile = options.widthForMobile;\n\t\tif (options.themeName) Core.themeName = options.themeName;\n\n\t\tCore._setState();\n\n\t\tif (options.topPopupOptions) TopPopupWorker.options = options.topPopupOptions;\n\t\tTopPopupWorkerGlobalEvents.init();\n\n\t\tTopDialogWorker.init(options.topDialogOptions);\n\n\t\t// определение директив\n\t\tapp.directive('top-data', directiveData);\n\t\tapp.directive('top-focus', directiveFocus);\n\t\tapp.directive('top-scroll-into-view', directiveScrollIntoView);\n\t\tapp.directive('top-scroll-shadow', directiveScrollShadow);\n\t\tapp.directive('top-shortcut', directiveShortcut);\n\t\tapp.directive('top-sticky', directiveSticky);\n\t\tapp.directive('top-swim-up', directiveSwimUp);\n\t\tapp.directive('top-tooltip', directiveTooltip);\n\n\t\t// определение базовых компонентов\n\t\tapp.component('TopAvatar', Forms.TopAvatar);\n\t\tapp.component('TopButton', Forms.TopButton);\n\t\tapp.component('TopCheckbox', Forms.TopCheckbox);\n\t\tapp.component('TopControlLabel', Forms.TopControlLabel);\n\t\tapp.component('TopHint', Forms.TopHint);\n\t\tapp.component('TopInput', Forms.TopInput);\n\t\tapp.component('TopInputDate', Forms.TopInputDate);\n\t\tapp.component('TopInputRange', Forms.TopInputRange);\n\t\tapp.component('TopLoadbar', Forms.TopLoadbar);\n\t\tapp.component('TopRadio', Forms.TopRadio);\n\t\tapp.component('TopSelect', Forms.TopSelect);\n\t\tapp.component('TopSwitcher', Forms.TopSwitcher);\n\t\tapp.component('TopTextarea', Forms.TopTextarea);\n\n\t\tapp.component('TopNotice', TopNotice);\n\t\tapp.component('TopDialogs', TopDialogs);\n\t},\n\n} satisfies Plugin<Options>;\n"],"names":["WorkerEvents","Core","Worker","elPopup","Events","elOpener","popup","storage","data","el","binding","name","value","UtilsLodash","elsActive","focusOnElActiveDebounce","focusOnElActive","isVisible","focusOnElDebounce","focus","UtilsDom","genScrollIntoViewOptions","scrollIntoViewOptions","elActive","scrollToElActiveDebounce","scrollToElActive","useStorage","scrollToElDebounce","scrollIntoView","isVisibleNew","UtilsScroll","connectScrollShadow","elementByShortcut","isListenerAttached","modifierKeys","isMacOS","getKeyLabel","code","keyLabel","genShortcutString","modifiers","ctrl","alt","shift","parts","registerShortcut","shortcut","unregisterShortcut","attachGlobalListener","e","element","appStickyObserver","sticky","_vnode","className","entries","condition","_el","_binding","appSwimUpInited","appSwimUpObserver","appSwimUpEls","swimUpElTransform","windowHeight","distance","percent","elTop","triggerHeightReducer","triggerHeight","swimUpInit","entry","swimUp","$","tvTooltipGenOptions","options","tooltip","$el","TopNotice","defineAsyncComponent","core","app","TopPopupWorker","TopPopupWorkerGlobalEvents","TopDialogWorker","directiveData","directiveFocus","directiveScrollIntoView","directiveScrollShadow","directiveShortcut","directiveSticky","directiveSwimUp","directiveTooltip","Forms.TopAvatar","Forms.TopButton","Forms.TopCheckbox","Forms.TopControlLabel","Forms.TopHint","Forms.TopInput","Forms.TopInputDate","Forms.TopInputRange","Forms.TopLoadbar","Forms.TopRadio","Forms.TopSelect","Forms.TopSwitcher","Forms.TopTextarea","TopDialogs"],"mappings":"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"}