@topvisor/ui 1.0.20 → 1.0.21-pinia-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.
Files changed (163) hide show
  1. package/.chunks/{datepicker-BwpUPRh5.es.js → datepicker-BC31NE5M.es.js} +2 -2
  2. package/.chunks/datepicker-BC31NE5M.es.js.map +1 -0
  3. package/.chunks/{datepicker-BpcIQBQx.amd.js → datepicker-CVoT5EME.amd.js} +2 -2
  4. package/.chunks/datepicker-CVoT5EME.amd.js.map +1 -0
  5. package/.chunks/forms-CipZtprq.es.js +1999 -0
  6. package/.chunks/forms-CipZtprq.es.js.map +1 -0
  7. package/.chunks/forms-CxYSHZLL.amd.js +3 -0
  8. package/.chunks/forms-CxYSHZLL.amd.js.map +1 -0
  9. package/.chunks/{listItem.vue_vue_type_script_setup_true_lang-BbSoFbg2.amd.js → listItem.vue_vue_type_script_setup_true_lang-CT6O_7Qy.amd.js} +2 -2
  10. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-CT6O_7Qy.amd.js.map +1 -0
  11. package/.chunks/{listItem.vue_vue_type_script_setup_true_lang-B0jhkmeG.es.js → listItem.vue_vue_type_script_setup_true_lang-uNNJJ4S0.es.js} +12 -12
  12. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-uNNJJ4S0.es.js.map +1 -0
  13. package/.chunks/{menu.vue_vue_type_style_index_0_lang-CPtzi4v1.amd.js → menu.vue_vue_type_style_index_0_lang-DAI_WcXI.amd.js} +2 -2
  14. package/.chunks/menu.vue_vue_type_style_index_0_lang-DAI_WcXI.amd.js.map +1 -0
  15. package/.chunks/{menu.vue_vue_type_style_index_0_lang-CF3aS3nJ.es.js → menu.vue_vue_type_style_index_0_lang-fU3LbpR7.es.js} +25 -25
  16. package/.chunks/menu.vue_vue_type_style_index_0_lang-fU3LbpR7.es.js.map +1 -0
  17. package/.chunks/{notice-Dj71_6Fi.es.js → notice-cCZZtLLu.es.js} +3 -3
  18. package/.chunks/notice-cCZZtLLu.es.js.map +1 -0
  19. package/.chunks/{notice-CiJb1Cdk.amd.js → notice-uzdQ-t3s.amd.js} +2 -2
  20. package/.chunks/notice-uzdQ-t3s.amd.js.map +1 -0
  21. package/.chunks/{popup-DbEAZSBK.es.js → popup-BvhY5oAD.es.js} +3 -2
  22. package/.chunks/popup-BvhY5oAD.es.js.map +1 -0
  23. package/.chunks/{popup-Cw2abdjh.amd.js → popup-Bwknq6xI.amd.js} +2 -2
  24. package/.chunks/popup-Bwknq6xI.amd.js.map +1 -0
  25. package/.chunks/store-CX_6ZXhO.es.js.map +1 -1
  26. package/.chunks/store-esTid5oI.amd.js.map +1 -1
  27. package/.chunks/{utils-DSzOIsFV.amd.js → utils-BfdO2xlC.amd.js} +2 -2
  28. package/.chunks/utils-BfdO2xlC.amd.js.map +1 -0
  29. package/.chunks/{utils-3FaaPSyL.es.js → utils-C2OmmJkw.es.js} +64 -64
  30. package/.chunks/utils-C2OmmJkw.es.js.map +1 -0
  31. package/.chunks/{utils-DF6k2YnU.amd.js → utils-C3dsXIj9.amd.js} +2 -2
  32. package/.chunks/utils-C3dsXIj9.amd.js.map +1 -0
  33. package/.chunks/{utils-zcyFDsBL.es.js → utils-C5sf4bZh.es.js} +78 -78
  34. package/.chunks/utils-C5sf4bZh.es.js.map +1 -0
  35. package/README.md +82 -82
  36. package/assets/core.css +1 -1
  37. package/assets/forms.css +1 -1
  38. package/assets/layout.css +1 -1
  39. package/charts/charts.amd.js +1 -1
  40. package/charts/charts.amd.js.map +1 -1
  41. package/charts/charts.js +8 -8
  42. package/charts/charts.js.map +1 -1
  43. package/components/forms/checkbox/checkbox.d.ts +5 -3
  44. package/components/forms/checkbox/checkbox.vue.d.ts +2 -2
  45. package/components/forms/input/input.d.ts +8 -0
  46. package/components/forms/input/input.vue.d.ts +2 -1
  47. package/components/forms/radio/radio.d.ts +1 -1
  48. package/components/forms/radio/radio.vue.d.ts +2 -2
  49. package/components/forms/select/select.d.ts +7 -0
  50. package/components/forms/select/select.vue.d.ts +2 -1
  51. package/components/forms/textarea/textarea.d.ts +7 -0
  52. package/components/forms/textarea/textarea.vue.d.ts +2 -1
  53. package/core/app.amd.js +1 -1
  54. package/core/app.amd.js.map +1 -1
  55. package/core/app.js +22 -21
  56. package/core/app.js.map +1 -1
  57. package/dialog/dialog.amd.js +1 -1
  58. package/dialog/dialog.amd.js.map +1 -1
  59. package/dialog/dialog.js +20 -20
  60. package/dialog/dialog.js.map +1 -1
  61. package/forms/forms.amd.js +1 -1
  62. package/forms/forms.js +1 -1
  63. package/forms/helpers.amd.js.map +1 -1
  64. package/forms/helpers.js.map +1 -1
  65. package/formsExt/formsExt.amd.js +1 -1
  66. package/formsExt/formsExt.amd.js.map +1 -1
  67. package/formsExt/formsExt.js +213 -210
  68. package/formsExt/formsExt.js.map +1 -1
  69. package/icomoon/Read Me.txt +7 -7
  70. package/icomoon/Topvisor icons.json +6259 -6259
  71. package/icomoon/demo-files/demo.css +158 -158
  72. package/icomoon/demo-files/demo.js +30 -30
  73. package/icomoon/demo.html +3558 -3558
  74. package/icomoon/fonts/Topvisor-2.svg +276 -276
  75. package/icomoon/style.css +780 -780
  76. package/jquery-ui.min.css +5 -5
  77. package/layout/layout.amd.js +1 -1
  78. package/layout/layout.amd.js.map +1 -1
  79. package/layout/layout.js +7 -7
  80. package/layout/layout.js.map +1 -1
  81. package/package.json +33 -33
  82. package/popup/popup.amd.js +1 -1
  83. package/popup/popup.amd.js.map +1 -1
  84. package/popup/popup.js +18 -17
  85. package/popup/popup.js.map +1 -1
  86. package/popup/worker.amd.js +1 -1
  87. package/popup/worker.amd.js.map +1 -1
  88. package/popup/worker.js +2 -2
  89. package/popup/worker.js.map +1 -1
  90. package/project/project.amd.js +1 -1
  91. package/project/project.amd.js.map +1 -1
  92. package/project/project.js +311 -311
  93. package/project/project.js.map +1 -1
  94. package/require/css.amd.js +12 -12
  95. package/tabs/tabs.amd.js.map +1 -1
  96. package/tabs/tabs.js +5 -5
  97. package/tabs/tabs.js.map +1 -1
  98. package/tabsView/tabsView.amd.js +1 -1
  99. package/tabsView/tabsView.amd.js.map +1 -1
  100. package/tabsView/tabsView.js +26 -26
  101. package/tabsView/tabsView.js.map +1 -1
  102. package/utils/check.amd.js.map +1 -1
  103. package/utils/check.js.map +1 -1
  104. package/utils/clipboard.amd.js +1 -1
  105. package/utils/clipboard.amd.js.map +1 -1
  106. package/utils/clipboard.js +1 -1
  107. package/utils/clipboard.js.map +1 -1
  108. package/utils/date.amd.js +1 -1
  109. package/utils/date.js +1 -1
  110. package/utils/device.amd.js +1 -1
  111. package/utils/device.js +1 -1
  112. package/utils/dom.amd.js +1 -1
  113. package/utils/dom.amd.js.map +1 -1
  114. package/utils/dom.js +30 -30
  115. package/utils/dom.js.map +1 -1
  116. package/utils/image.amd.js.map +1 -1
  117. package/utils/image.js.map +1 -1
  118. package/utils/keyboard.amd.js.map +1 -1
  119. package/utils/keyboard.js.map +1 -1
  120. package/utils/lodash.amd.js +1 -1
  121. package/utils/lodash.js +1 -1
  122. package/utils/number.amd.js.map +1 -1
  123. package/utils/number.js.map +1 -1
  124. package/utils/price.amd.js +1 -1
  125. package/utils/price.amd.js.map +1 -1
  126. package/utils/price.js +3 -3
  127. package/utils/price.js.map +1 -1
  128. package/utils/route.amd.js +1 -1
  129. package/utils/route.amd.js.map +1 -1
  130. package/utils/route.js +5 -5
  131. package/utils/route.js.map +1 -1
  132. package/utils/scroll.amd.js.map +1 -1
  133. package/utils/scroll.js.map +1 -1
  134. package/utils/searchers.amd.js.map +1 -1
  135. package/utils/searchers.js +2 -0
  136. package/utils/searchers.js.map +1 -1
  137. package/utils/string.amd.js +1 -1
  138. package/utils/string.amd.js.map +1 -1
  139. package/utils/string.js +29 -29
  140. package/utils/string.js.map +1 -1
  141. package/utils/system.amd.js.map +1 -1
  142. package/utils/system.js.map +1 -1
  143. package/utils/url.amd.js.map +1 -1
  144. package/utils/url.js.map +1 -1
  145. package/web-types.json +130 -130
  146. package/.chunks/datepicker-BpcIQBQx.amd.js.map +0 -1
  147. package/.chunks/datepicker-BwpUPRh5.es.js.map +0 -1
  148. package/.chunks/forms-CqYQQ4oo.amd.js +0 -3
  149. package/.chunks/forms-CqYQQ4oo.amd.js.map +0 -1
  150. package/.chunks/forms-UBLh4e8-.es.js +0 -2010
  151. package/.chunks/forms-UBLh4e8-.es.js.map +0 -1
  152. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-B0jhkmeG.es.js.map +0 -1
  153. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-BbSoFbg2.amd.js.map +0 -1
  154. package/.chunks/menu.vue_vue_type_style_index_0_lang-CF3aS3nJ.es.js.map +0 -1
  155. package/.chunks/menu.vue_vue_type_style_index_0_lang-CPtzi4v1.amd.js.map +0 -1
  156. package/.chunks/notice-CiJb1Cdk.amd.js.map +0 -1
  157. package/.chunks/notice-Dj71_6Fi.es.js.map +0 -1
  158. package/.chunks/popup-Cw2abdjh.amd.js.map +0 -1
  159. package/.chunks/popup-DbEAZSBK.es.js.map +0 -1
  160. package/.chunks/utils-3FaaPSyL.es.js.map +0 -1
  161. package/.chunks/utils-DF6k2YnU.amd.js.map +0 -1
  162. package/.chunks/utils-DSzOIsFV.amd.js.map +0 -1
  163. package/.chunks/utils-zcyFDsBL.es.js.map +0 -1
@@ -1,4 +1,4 @@
1
- import { ref as d, markRaw as A, shallowReactive as D, defineComponent as x, onUnmounted as V, openBlock as v, createElementBlock as p, Fragment as U, renderList as H, unref as S, createBlock as _, resolveDynamicComponent as L, getCurrentInstance as O, inject as M } from "vue";
1
+ import { ref as g, markRaw as A, shallowReactive as D, defineComponent as x, onUnmounted as V, createElementBlock as f, openBlock as v, Fragment as U, renderList as H, unref as S, createBlock as _, resolveDynamicComponent as L, getCurrentInstance as O, inject as M } from "vue";
2
2
  import { waitWhile as k } from "../utils/system.js";
3
3
  import { historySetState as E, genHash as m, getHash as y } from "../utils/route.js";
4
4
  class c {
@@ -19,10 +19,10 @@ class c {
19
19
  *
20
20
  * Если в параметрах есть запрос на открытие диалогового окна, TopDialog будет автоматически подключен на страницу
21
21
  */
22
- static init(e) {
22
+ static init(t) {
23
23
  if (this.inited) return;
24
- this.inited = !0, this.state.load = e == null ? void 0 : e.load, this.state.decoratorOnCreate = e == null ? void 0 : e.decoratorOnCreate;
25
- const t = (e == null ? void 0 : e.autoInitDelay) ?? 5e3;
24
+ this.inited = !0, this.state.load = t == null ? void 0 : t.load, this.state.decoratorOnCreate = t == null ? void 0 : t.decoratorOnCreate;
25
+ const e = (t == null ? void 0 : t.autoInitDelay) ?? 5e3;
26
26
  $(window).on("hashchange.dialogs", () => {
27
27
  this.compareStates(location.hash, this.state.locationHashPrev) && this.opendDialogsFromUrl();
28
28
  }), $(window).trigger("hashchange.dialogs"), $(document).on("mousedown", "a[data-to-view]", async (s) => {
@@ -36,11 +36,11 @@ class c {
36
36
  s.preventDefault(), a.mousedown(), setTimeout(() => a.click());
37
37
  return;
38
38
  }
39
- const r = await this.getDialogsUtils(), o = a.dataset.toView, n = o.split("-")[0], l = $("#" + n), h = $("> .modal-layer", l), f = $("> .active", h), P = !!l.data("data-to-view-replace");
39
+ const r = await this.getDialogsUtils(), o = a.dataset.toView, n = o.split("-")[0], l = $("#" + n), h = $("> .modal-layer", l), p = $("> .active", h), P = !!l.data("data-to-view-replace");
40
40
  let w = "next";
41
- if (f.length) {
41
+ if (p.length) {
42
42
  const N = o.split("-")[1].split(":")[0];
43
- $('> [data-view-page="' + N + '"]', h).data("order") < f.data("order") && (w = "prev");
43
+ $('> [data-view-page="' + N + '"]', h).data("order") < p.data("order") && (w = "prev");
44
44
  }
45
45
  a.dataset.action === "top-dialog-close" && (w = "prev");
46
46
  const u = c.genViewPageHash(o, w);
@@ -52,74 +52,74 @@ class c {
52
52
  }
53
53
  }
54
54
  P ? (s.preventDefault(), E(!0, u), await r.toViewDirty(o), w == "next" ? c.state.viewPageN++ : c.state.viewPageN--) : a.tagName !== "A" && (this.compareStates(u, location.hash) ? location.hash = u : await r.toViewDirty(o));
55
- }), setTimeout(() => this.getDialogsUtils(), t);
55
+ }), setTimeout(() => this.getDialogsUtils(), e);
56
56
  }
57
57
  static async getDialogsUtils() {
58
- const { TopDialogUtils: e } = await import("./utils-3FaaPSyL.es.js");
59
- return e;
58
+ const { TopDialogUtils: t } = await import("./utils-C2OmmJkw.es.js");
59
+ return t;
60
60
  }
61
- static get$dialog(e) {
62
- return e.closest(".ui-dialog-content");
61
+ static get$dialog(t) {
62
+ return t.closest(".ui-dialog-content");
63
63
  }
64
- static get$page(e) {
65
- return e.closest("[data-view-page]");
64
+ static get$page(t) {
65
+ return t.closest("[data-view-page]");
66
66
  }
67
67
  /**
68
68
  * Получить элементы страницы в шапке и в контенте
69
69
  */
70
- static get$pairPage(e) {
71
- const t = c.get$dialog(e), a = c.get$page(e).data("view-page");
72
- return $('[data-view-page="' + a + '"]', t);
70
+ static get$pairPage(t) {
71
+ const e = c.get$dialog(t), a = c.get$page(t).data("view-page");
72
+ return $('[data-view-page="' + a + '"]', e);
73
73
  }
74
74
  /**
75
75
  * Закрыть диалоговое окно
76
76
  */
77
- static close(e) {
78
- const t = $("#" + e);
79
- t.dialog("instance") && t.dialog("close");
77
+ static close(t) {
78
+ const e = $("#" + t);
79
+ e.dialog("instance") && e.dialog("close");
80
80
  }
81
81
  /**
82
82
  * Размонтировать $.dialog
83
83
  */
84
- static destroy(e) {
85
- const t = $("#" + e);
86
- t.dialog("instance") && (t.dialog("close"), t.dialog("destroy"));
84
+ static destroy(t) {
85
+ const e = $("#" + t);
86
+ e.dialog("instance") && (e.dialog("close"), e.dialog("destroy"));
87
87
  }
88
88
  /**
89
89
  * Сгенерировать ссылку на страницу в диалоговом окне
90
90
  * @param toView - указатель в формате: dialog_{{ dialogId }}={{ pageName }}:{{ args }}
91
91
  * @param moveDirection
92
92
  */
93
- static genViewPageHash(e, t = "next") {
93
+ static genViewPageHash(t, e = "next") {
94
94
  var s = this.state.viewPageN;
95
- t == "prev" ? s-- : s++;
96
- var a = e.split("-"), r = a.shift(), o = a.join("-"), n = m("vpn", s), n = m("view-" + r, o, n);
95
+ e == "prev" ? s-- : s++;
96
+ var a = t.split("-"), r = a.shift(), o = a.join("-"), n = m("vpn", s), n = m("view-" + r, o, n);
97
97
  return n;
98
98
  }
99
99
  /**
100
100
  * Сравнить версию открытых диалоговых окон
101
101
  * @returns вернет true, если состояния открытых окон изменилось
102
102
  */
103
- static compareStates(e, t) {
104
- const s = e.match(/[#&]view-[^&]+/g) || [], a = t.match(/[#&]view-[^&]+/g) || [];
103
+ static compareStates(t, e) {
104
+ const s = t.match(/[#&]view-[^&]+/g) || [], a = e.match(/[#&]view-[^&]+/g) || [];
105
105
  return !!(s.length !== a.length || s.filter((o, n) => {
106
106
  const l = a[n] || "";
107
107
  return o !== l;
108
108
  }).length);
109
109
  }
110
110
  static opendDialogsFromUrl = async () => {
111
- const e = Number(y("vpn")) || 0;
111
+ const t = Number(y("vpn")) || 0;
112
112
  this.state.locationHashPrev = location.hash;
113
- let t;
113
+ let e;
114
114
  const s = new RegExp("view-((\\w+)=([\\w-]+)(?::([\\w.:-]+))?)", "g");
115
- for (; t = s.exec(location.hash); ) {
115
+ for (; e = s.exec(location.hash); ) {
116
116
  var a = "next";
117
- return e < this.state.viewPageN && (a = "prev"), (await this.getDialogsUtils()).toViewDirty(t[1], a);
117
+ return t < this.state.viewPageN && (a = "prev"), (await this.getDialogsUtils()).toViewDirty(e[1], a);
118
118
  }
119
119
  return $(".ui-dialog-content[data-view-page-active]:visible").each((r, o) => {
120
120
  var n = $(o), l = n.attr("id"), h = y("view-" + l);
121
121
  h || n.dialog("close");
122
- }), this.state.viewPageN = e, !0;
122
+ }), this.state.viewPageN = t, !0;
123
123
  };
124
124
  }
125
125
  class b {
@@ -142,31 +142,31 @@ class b {
142
142
  *
143
143
  * Устанавливается после первого вызова useTopDialog()
144
144
  */
145
- isMounted = d(!1);
145
+ isMounted = g(!1);
146
146
  /**
147
147
  * Компонент готов к использованию
148
148
  *
149
149
  * Используется для внутренних преобразований после отрисовки
150
150
  */
151
- isReady = d(!1);
151
+ isReady = g(!1);
152
152
  /**
153
153
  * Диалоговое окно открыто
154
154
  */
155
- isOpened = d(!1);
155
+ isOpened = g(!1);
156
156
  /**
157
157
  * Имя активной страницы дилогового окна
158
158
  */
159
- pageActive = d("");
159
+ pageActive = g("");
160
160
  /**
161
161
  * Диалоговое окно находится в состоянии загрузки своей страницы
162
162
  */
163
- isLoadingPage = d(!1);
163
+ isLoadingPage = g(!1);
164
164
  /**
165
165
  * Следующая активная страница
166
166
  *
167
167
  * В один момент времени может потребоваться отобразить две страницы, чтобы воспроизвести анимацию
168
168
  */
169
- pageActiveNext = d("");
169
+ pageActiveNext = g("");
170
170
  /**
171
171
  * props компонента, доступны после инициализации
172
172
  */
@@ -181,31 +181,31 @@ class b {
181
181
  * Используется для привязки окна к сценариям использования
182
182
  */
183
183
  onCloseOnce;
184
- constructor(e) {
185
- this.id = e.id, this.idAttr = "dialog_" + e.id, this.Component = A(e);
184
+ constructor(t) {
185
+ this.id = t.id, this.idAttr = "dialog_" + t.id, this.Component = A(t);
186
186
  }
187
187
  /**
188
188
  * Событие - компонент инициирован
189
189
  */
190
- onMounted(e, t) {
191
- this.isMounted.value = !0, this.props = e.props, this.emit = t.emit;
190
+ onMounted(t, e) {
191
+ this.isMounted.value = !0, this.props = t.props, this.emit = e.emit;
192
192
  }
193
193
  /**
194
194
  * Открыть диалоговое окно
195
195
  *
196
196
  * Учтите, что props в диалоговом окне будут доступны не сразу, а только после инициализации vue компонента
197
197
  */
198
- async open(e = "main", t, s = [], a, r) {
199
- t && await this.setProps(t), a && (this.onCloseOnce = a), await (await c.getDialogsUtils()).toView(this.idAttr, e, s, r);
198
+ async open(t = "main", e, s = [], a, r) {
199
+ e && await this.setProps(e), a && (this.onCloseOnce = a), await (await c.getDialogsUtils()).toView(this.idAttr, t, s, r);
200
200
  }
201
201
  /**
202
202
  * Открыть диалоговое окно как ссылку, для хеш-навигации
203
203
  *
204
204
  * Диалоговые окна загружаются по имени, см. настройку плагина Core topDialogLoader
205
205
  */
206
- async openAsLink(e = "main", t, s = [], a, r) {
207
- t && await this.setProps(t), a && (this.onCloseOnce = a);
208
- const o = this.idAttr + "-" + e;
206
+ async openAsLink(t = "main", e, s = [], a, r) {
207
+ e && await this.setProps(e), a && (this.onCloseOnce = a);
208
+ const o = this.idAttr + "-" + t;
209
209
  location.hash = c.genViewPageHash(o, r);
210
210
  }
211
211
  /**
@@ -227,33 +227,33 @@ class b {
227
227
  *
228
228
  * Полностью сбрасывается состояние props
229
229
  */
230
- async setProps(e = {}) {
230
+ async setProps(t = {}) {
231
231
  this.isMounted || await k(() => !this.props);
232
- for (const t in this.props)
233
- this.props[t] = e[t];
232
+ for (const e in this.props)
233
+ this.props[e] = t[e];
234
234
  }
235
235
  /**
236
236
  * Проверить, есть ли необходимость отрисовки страницы диалогового окна
237
237
  */
238
- needShowPage(e) {
239
- return this.isOpened.value ? this.pageActive.value === e || this.pageActiveNext.value === e : !1;
238
+ needShowPage(t) {
239
+ return this.isOpened.value ? this.pageActive.value === t || this.pageActiveNext.value === t : !1;
240
240
  }
241
241
  }
242
242
  const C = {
243
243
  class: "top-dialogs",
244
244
  style: { display: "none" }
245
- }, g = D(/* @__PURE__ */ new Map()), R = (i) => (i = i.replace(/^dialog_/, ""), g.get(i)), B = (i) => {
245
+ }, d = D(/* @__PURE__ */ new Map()), R = (i) => (i = i.replace(/^dialog_/, ""), d.get(i)), B = (i) => {
246
246
  if (!(i != null && i.id))
247
247
  throw console.log({ TopDialogComponent: i }), new Error("Expected TopDialogComponent");
248
- return g.has(i.id) || g.set(i.id, new b(i)), g.get(i.id);
248
+ return d.has(i.id) || d.set(i.id, new b(i)), d.get(i.id);
249
249
  }, G = /* @__PURE__ */ x({
250
250
  name: "DialogWrapper",
251
251
  __name: "dialogs",
252
252
  setup(i) {
253
253
  return V(() => {
254
- g.forEach((e) => e.destroy()), g.clear();
255
- }), (e, t) => (v(), p("div", C, [
256
- (v(!0), p(U, null, H(S(g), ([s, a]) => (v(), _(L(a.Component), { key: s }))), 128))
254
+ d.forEach((t) => t.destroy()), d.clear();
255
+ }), (t, e) => (v(), f("div", C, [
256
+ (v(!0), f(U, null, H(S(d), ([s, a]) => (v(), _(L(a.Component), { key: s }))), 128))
257
257
  ]));
258
258
  }
259
259
  });
@@ -267,63 +267,63 @@ class F {
267
267
  *
268
268
  * Ссылка не будет указывать на объект, если диалоговое окно еще не загружено
269
269
  */
270
- worker = d(null);
271
- constructor(e) {
272
- this.resolve = e;
270
+ worker = g(null);
271
+ constructor(t) {
272
+ this.resolve = t;
273
273
  }
274
274
  /**
275
275
  * Получить доступ к TopDialogHandle
276
276
  */
277
277
  async get() {
278
278
  if (this.worker.value) return this.worker.value;
279
- const t = (await this.resolve()).default;
280
- this.worker.value = I(t);
279
+ const e = (await this.resolve()).default;
280
+ this.worker.value = I(e);
281
281
  const s = this.worker.value;
282
282
  return await k(() => !s.isMounted), s;
283
283
  }
284
284
  /**
285
285
  * Открыть диалоговое окно
286
286
  */
287
- async open(...e) {
288
- await (await this.get()).open(...e);
287
+ async open(...t) {
288
+ await (await this.get()).open(...t);
289
289
  }
290
290
  /**
291
291
  * Открыть диалоговое окно как ссылку, для хеш-навигации
292
292
  *
293
293
  * Только общедоступные диалоговые окна, расположенные в @/dialogs
294
294
  */
295
- async openAsLink(...e) {
296
- (await this.get()).openAsLink(...e);
295
+ async openAsLink(...t) {
296
+ (await this.get()).openAsLink(...t);
297
297
  }
298
298
  /**
299
299
  * Закрыть диалоговое окно
300
300
  *
301
301
  * Не меняет состояние компонента диалогового окна
302
302
  */
303
- async close(...e) {
304
- (await this.get()).close(...e);
303
+ async close(...t) {
304
+ (await this.get()).close(...t);
305
305
  }
306
306
  /**
307
307
  * Размонтировать виджет диалогового окна
308
308
  */
309
- async destroy(...e) {
310
- (await this.get()).destroy(...e);
309
+ async destroy(...t) {
310
+ (await this.get()).destroy(...t);
311
311
  }
312
312
  /**
313
313
  * Устанвоить props
314
314
  *
315
315
  * Полностью сбрасывается состояние props
316
316
  */
317
- async setProps(...e) {
318
- await (await this.get()).setProps(...e);
317
+ async setProps(...t) {
318
+ await (await this.get()).setProps(...t);
319
319
  }
320
320
  }
321
321
  const J = () => {
322
- var e;
322
+ var t;
323
323
  const i = O();
324
- if ((e = i == null ? void 0 : i.type) != null && e.id) {
325
- const t = R(i.type.id);
326
- if (t) return t;
324
+ if ((t = i == null ? void 0 : i.type) != null && t.id) {
325
+ const e = R(i.type.id);
326
+ if (e) return e;
327
327
  }
328
328
  return M("dialogWorker");
329
329
  }, I = (i) => B(i), K = (i) => new F(i);
@@ -335,4 +335,4 @@ export {
335
335
  R as g,
336
336
  J as u
337
337
  };
338
- //# sourceMappingURL=utils-zcyFDsBL.es.js.map
338
+ //# sourceMappingURL=utils-C5sf4bZh.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils-C5sf4bZh.es.js","sources":["../../src/components/dialog/lib/worker.ts","../../src/components/dialog/dialog/composables/dialogHandle.ts","../../src/components/dialog/dialog/dialogs/dialogs.vue","../../src/components/dialog/dialog/composables/asyncDialogHandle.ts","../../src/components/dialog/dialog/composables/utils.ts"],"sourcesContent":["import { genHash, getHash, historySetState } from '@/core/utils/route';\r\nimport type { MoveDirection, TopDialogOptions } from './types';\r\nimport type { $el } from '@/components/types';\r\n\r\nexport abstract class TopDialogWorker {\r\n\tstatic state = {\r\n\t\tload: undefined as TopDialogOptions['load'] | undefined,\r\n\t\tdecoratorOnCreate: undefined as TopDialogOptions['decoratorOnCreate'] | undefined,\r\n\r\n\t\t/**\r\n\t\t * Порядковай номер перехода в диалоговых окнах\r\n\t\t *\r\n\t\t * Для расчета направления Вперед / Назад\r\n\t\t */\r\n\t\tviewPageN: 0,\r\n\t\tlocationHashPrev: '',\r\n\t};\r\n\r\n\tprivate static inited = false;\r\n\r\n\t/**\r\n\t * Инициировать события слежения за парамтерами url\r\n\t *\r\n\t * Если в параметрах есть запрос на открытие диалогового окна, TopDialog будет автоматически подключен на страницу\r\n\t */\r\n\tstatic init(options?: TopDialogOptions) {\r\n\t\tif (this.inited) return;\r\n\t\tthis.inited = true;\r\n\r\n\t\tthis.state.load = options?.load;\r\n\t\tthis.state.decoratorOnCreate = options?.decoratorOnCreate;\r\n\r\n\t\tconst autoInitDelay = options?.autoInitDelay ?? 5000;\r\n\r\n\t\t$(window).on('hashchange.dialogs', () => {\r\n\t\t\tconst dialogsStateChanged = this.compareStates(location.hash, this.state.locationHashPrev);\r\n\t\t\tif (dialogsStateChanged) this.opendDialogsFromUrl();\r\n\t\t});\r\n\r\n\t\t$(window).trigger('hashchange.dialogs');\r\n\r\n\t\t/**\r\n\t\t * Сгенерировать ссылку для перехода к странице диалогового окна\r\n\t\t */\r\n\t\t$(document).on('mousedown', 'a[data-to-view]', async (e) => {\r\n\t\t\tconst el = e.target.closest('[data-to-view]');\r\n\r\n\t\t\tconst toView = el.dataset.toView;\r\n\t\t\tconst viewName = toView.split('-')[0];\r\n\t\t\tconst $toDialog = $('#' + viewName);\r\n\t\t\tconst $modalLayers = $('> .modal-layer', $toDialog);\r\n\t\t\t// const $currentPage = $('> .active', $modalLayers);\r\n\r\n\t\t\tlet moveDirection: MoveDirection = 'next';\r\n\r\n\t\t\t// /**\r\n\t\t\t// * Данный алгоритм определения направления работает не корректно, так как для чтения свойства order менят состояние через getDialogsUtils()\r\n\t\t\t// */\r\n\t\t\t// if ($currentPage.length) {\r\n\t\t\t// \tconst pageName = toView.split('-')[1].split(':')[0];\r\n\t\t\t//\r\n\t\t\t// \tconst TopDialogUtils = await this.getDialogsUtils();\r\n\t\t\t//\r\n\t\t\t// \tawait TopDialogUtils.updatePageVue(viewName, undefined, pageName);\r\n\t\t\t//\r\n\t\t\t// \tconst $nextPage = $('> [data-view-page=\"' + pageName + '\"]', $modalLayers);\r\n\t\t\t// \tif ($nextPage.data('order') < $currentPage.data('order')) moveDirection = 'prev';\r\n\t\t\t// }\r\n\r\n\t\t\tif (el.dataset.action === 'top-dialog-close') moveDirection = 'prev';\r\n\r\n\t\t\tel.href = TopDialogWorker.genViewPageHash(el.dataset.toView, moveDirection);\r\n\t\t});\r\n\r\n\t\t/**\r\n\t\t * Осуществить переход по ссылке с учетом historyType\r\n\t\t */\r\n\t\t$(document).on('click', '[data-to-view]', async (e) => {\r\n\t\t\tconst el = e.target.closest('[data-to-view]');\r\n\r\n\t\t\t// Подождать генерацию ссылки\r\n\t\t\tif (el.href === '.') {\r\n\t\t\t\te.preventDefault();\r\n\r\n\t\t\t\tel.mousedown();\r\n\r\n\t\t\t\tsetTimeout(() => el.click());\r\n\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\r\n\t\t\tconst TopDialogUtils = await this.getDialogsUtils();\r\n\r\n\t\t\tconst toView = el.dataset.toView;\r\n\t\t\tconst viewName = toView.split('-')[0];\r\n\t\t\tconst $toDialog = $('#' + viewName);\r\n\t\t\tconst $modalLayers = $('> .modal-layer', $toDialog);\r\n\t\t\tconst $currentPage = $('> .active', $modalLayers);\r\n\r\n\t\t\tconst replaceHistory = !!$toDialog.data('data-to-view-replace');\r\n\r\n\t\t\tlet moveDirection: MoveDirection = 'next';\r\n\t\t\tif ($currentPage.length) {\r\n\t\t\t\tconst pageName = toView.split('-')[1].split(':')[0];\r\n\t\t\t\tconst $nextPage = $('> [data-view-page=\"' + pageName + '\"]', $modalLayers);\r\n\t\t\t\tif ($nextPage.data('order') < $currentPage.data('order')) moveDirection = 'prev';\r\n\t\t\t}\r\n\t\t\tif (el.dataset.action === 'top-dialog-close') moveDirection = 'prev';\r\n\r\n\t\t\tconst hash = TopDialogWorker.genViewPageHash(toView, moveDirection);\r\n\r\n\t\t\tif (el.tagName === 'A') {\r\n\t\t\t\t// диалоговое окно еще не открыто, произвести переход по ссылке\r\n\t\t\t\tif (!$toDialog.is(':visible')) return;\r\n\r\n\t\t\t\t// в адресе уже указана эта страница, необходимсо явно запросить ее открытие\r\n\t\t\t\tif (location.hash.indexOf(toView.replace('-', '=')) !== -1) {\r\n\t\t\t\t\tawait TopDialogUtils.toViewDirty(toView);\r\n\r\n\t\t\t\t\treturn;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t\tif (replaceHistory) {\r\n\t\t\t\te.preventDefault();\r\n\r\n\t\t\t\thistorySetState(true, hash);\r\n\r\n\t\t\t\tawait TopDialogUtils.toViewDirty(toView);\r\n\r\n\t\t\t\tif (moveDirection == 'next') {\r\n\t\t\t\t\tTopDialogWorker.state.viewPageN++;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tTopDialogWorker.state.viewPageN--;\r\n\t\t\t\t}\r\n\t\t\t} else {\r\n\t\t\t\tif (el.tagName !== 'A') {\r\n\t\t\t\t\tif (this.compareStates(hash, location.hash)) {\r\n\t\t\t\t\t\tlocation.hash = hash;\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tawait TopDialogUtils.toViewDirty(toView);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\tsetTimeout(() => this.getDialogsUtils(), autoInitDelay);\r\n\t}\r\n\r\n\tstatic async getDialogsUtils() {\r\n\t\tconst { TopDialogUtils } = await import('./utils');\r\n\r\n\t\treturn TopDialogUtils;\r\n\t}\r\n\r\n\tstatic get$dialog($el: $el) {\r\n\t\treturn $el.closest('.ui-dialog-content');\r\n\t};\r\n\r\n\tstatic get$page($el: $el) {\r\n\t\treturn $el.closest('[data-view-page]');\r\n\t};\r\n\r\n\t/**\r\n\t * Получить элементы страницы в шапке и в контенте\r\n\t */\r\n\tstatic get$pairPage($el: $el) {\r\n\t\tconst $dialog = TopDialogWorker.get$dialog($el);\r\n\r\n\t\tconst $page = TopDialogWorker.get$page($el);\r\n\t\tconst pageName = $page.data('view-page');\r\n\r\n\t\treturn $('[data-view-page=\"' + pageName + '\"]', $dialog);\r\n\t};\r\n\r\n\t/**\r\n\t * Закрыть диалоговое окно\r\n\t */\r\n\tstatic close(dialogId: string) {\r\n\t\tconst $dialog = $('#' + dialogId);\r\n\r\n\t\tif (!$dialog.dialog('instance')) return;\r\n\r\n\t\t$dialog.dialog('close');\r\n\t};\r\n\r\n\t/**\r\n\t * Размонтировать $.dialog\r\n\t */\r\n\tstatic destroy(dialogId: string) {\r\n\t\tconst $dialog = $('#' + dialogId);\r\n\r\n\t\tif (!$dialog.dialog('instance')) return;\r\n\r\n\t\t$dialog.dialog('close');\r\n\t\t$dialog.dialog('destroy');\r\n\t};\r\n\r\n\t/**\r\n\t * Сгенерировать ссылку на страницу в диалоговом окне\r\n\t * @param toView - указатель в формате: dialog_{{ dialogId }}={{ pageName }}:{{ args }}\r\n\t * @param moveDirection\r\n\t */\r\n\tstatic genViewPageHash(toView: string, moveDirection: MoveDirection = 'next') {\r\n\t\tvar toViewPageN = this.state.viewPageN;\r\n\t\tif (moveDirection == 'prev') {\r\n\t\t\ttoViewPageN--;\r\n\t\t} else {\r\n\t\t\ttoViewPageN++;\r\n\t\t}\r\n\r\n\t\tvar viewNameAndPageLink = toView.split('-');\r\n\t\tvar viewName = viewNameAndPageLink.shift();\r\n\t\tvar pageLink = viewNameAndPageLink.join('-');\r\n\t\tvar hash = genHash('vpn', toViewPageN);\r\n\t\tvar hash = genHash('view-' + viewName, pageLink, hash);\r\n\r\n\t\treturn hash;\r\n\t};\r\n\r\n\t/**\r\n\t * Сравнить версию открытых диалоговых окон\r\n\t * @returns вернет true, если состояния открытых окон изменилось\r\n\t */\r\n\tstatic compareStates(hash: string, hash2: string) {\r\n\t\tconst mathes = hash.match(/[#&]view-[^&]+/g) || [];\r\n\t\tconst mathes2 = hash2.match(/[#&]view-[^&]+/g) || [];\r\n\r\n\t\tif (mathes.length !== mathes2.length) return true;\r\n\r\n\t\tconst mathesChanged = mathes.filter((math, n) => {\r\n\t\t\tconst math2 = mathes2[n] || '';\r\n\r\n\t\t\treturn math !== math2;\r\n\t\t});\r\n\r\n\t\tif (mathesChanged.length) return true;\r\n\r\n\t\treturn false;\r\n\t};\r\n\r\n\tstatic opendDialogsFromUrl = async () => {\r\n\t\tconst toViewPageN = Number(getHash('vpn')) || 0;\r\n\r\n\t\tthis.state.locationHashPrev = location.hash;\r\n\r\n\t\t// Открыть диалоговое окно\r\n\t\tlet view: RegExpExecArray | null;\r\n\t\t// const regexp = new RegExp('view-((\\\\w+)=([\\\\w-]+)(?::([\\\\w.:-]+))?)' + '(' + Math.random() + ')?', 'g'); // fix babel minify regexp\r\n\t\tconst regexp = new RegExp('view-((\\\\w+)=([\\\\w-]+)(?::([\\\\w.:-]+))?)', 'g');\r\n\t\twhile (view = regexp.exec(location.hash)) {\r\n\t\t\tvar moveDirection: MoveDirection = 'next';\r\n\t\t\tif (toViewPageN < this.state.viewPageN) moveDirection = 'prev';\r\n\r\n\t\t\tconst TopDialogUtils = await this.getDialogsUtils();\r\n\r\n\t\t\treturn TopDialogUtils.toViewDirty(view[1], moveDirection);\r\n\t\t}\r\n\r\n\t\t// Закрыть ненужные view\r\n\t\t$('.ui-dialog-content[data-view-page-active]:visible').each((_index: number, dialog: HTMLElement) => {\r\n\t\t\tvar $dialog = $(dialog);\r\n\r\n\t\t\tvar viewName = $dialog.attr('id');\r\n\t\t\tvar pageName = getHash('view-' + viewName);\r\n\t\t\tif (!pageName) $dialog.dialog('close');\r\n\t\t});\r\n\r\n\t\tthis.state.viewPageN = toViewPageN;\r\n\r\n\t\treturn true;\r\n\t};\r\n}\r\n","import { type ComponentInstance, type ComponentInternalInstance, markRaw, ref } from 'vue';\r\nimport { waitWhile } from '@/core/utils/system';\r\nimport TopDialog from '../dialog.vue';\r\nimport { TopDialogWorker } from '@/components/dialog/lib/worker';\r\nimport type { MoveDirection } from '@/components/dialog/lib/types';\r\nimport type { TopDialogComponent } from './types';\r\n\r\n/**\r\n * Объект для работы с диалоговым окном\r\n *\r\n * Каждое окно уникально и может быть открыто одновременно только один раз\r\n *\r\n * Можно определить много окон, после чего с ними можно вести работу в любой части приложения\r\n */\r\nexport class TopDialogHandle<T extends TopDialogComponent> {\r\n\r\n\t/**\r\n\t * Индентификатор, определяется на уровне компонента TopDialogComponent\r\n\t *\r\n\t * Может использоваться в навигации для открытия нужных окон с нужными настройками\r\n\t */\r\n\tid: string;\r\n\r\n\t/**\r\n\t * ID, используемый в верстке диалогового окна\r\n\t */\r\n\tidAttr: string;\r\n\r\n\t/**\r\n\t * Пользовательский компонент диалогового окна\r\n\t */\r\n\tComponent: T;\r\n\r\n\t/**\r\n\t * Компонент инициирован\r\n\t *\r\n\t * Устанавливается после первого вызова useTopDialog()\r\n\t */\r\n\tisMounted = ref(false);\r\n\r\n\t/**\r\n\t * Компонент готов к использованию\r\n\t *\r\n\t * Используется для внутренних преобразований после отрисовки\r\n\t */\r\n\tisReady = ref(false);\r\n\r\n\t/**\r\n\t * Диалоговое окно открыто\r\n\t */\r\n\tisOpened = ref(false);\r\n\r\n\t/**\r\n\t * Имя активной страницы дилогового окна\r\n\t */\r\n\tpageActive = ref('');\r\n\r\n\t/**\r\n\t * Диалоговое окно находится в состоянии загрузки своей страницы\r\n\t */\r\n\tisLoadingPage = ref(false);\r\n\r\n\t/**\r\n\t * Следующая активная страница\r\n\t *\r\n\t * В один момент времени может потребоваться отобразить две страницы, чтобы воспроизвести анимацию\r\n\t */\r\n\tpageActiveNext = ref('');\r\n\r\n\t/**\r\n\t * props компонента, доступны после инициализации\r\n\t */\r\n\tprops?: ComponentInstance<T>['$props'];\r\n\r\n\t/**\r\n\t * emit базового компонента `TopDialog`\r\n\t */\r\n\temit?: ComponentInstance<typeof TopDialog>['$emit'];\r\n\r\n\t/**\r\n\t * Одноразовое событие на закрытие диалогового окна\r\n\t *\r\n\t * Используется для привязки окна к сценариям использования\r\n\t */\r\n\tonCloseOnce?: (props: typeof this.props, pageName: string) => void;\r\n\r\n\tconstructor(TopDialogComponent: T) {\r\n\t\tthis.id = TopDialogComponent.id!;\r\n\t\tthis.idAttr = 'dialog_' + TopDialogComponent.id;\r\n\t\tthis.Component = markRaw(TopDialogComponent);\r\n\t}\r\n\r\n\t/**\r\n\t * Событие - компонент инициирован\r\n\t */\r\n\tonMounted(topDialogComponent: ComponentInternalInstance, topDialogBaseComponent: ComponentInternalInstance) {\r\n\t\tthis.isMounted.value = true;\r\n\t\tthis.props = topDialogComponent.props;\r\n\t\tthis.emit = topDialogBaseComponent.emit;\r\n\t}\r\n\r\n\t/**\r\n\t * Открыть диалоговое окно\r\n\t *\r\n\t * Учтите, что props в диалоговом окне будут доступны не сразу, а только после инициализации vue компонента\r\n\t */\r\n\tasync open(pageName: string = 'main', props?: {}, args: [] = [], onCloseOnce?: typeof this.onCloseOnce, moveDirection?: MoveDirection) {\r\n\t\tif (props) await this.setProps(props);\r\n\t\tif (onCloseOnce) this.onCloseOnce = onCloseOnce;\r\n\r\n\t\tconst TopDialogUtils = await TopDialogWorker.getDialogsUtils();\r\n\r\n\t\tawait TopDialogUtils.toView(this.idAttr, pageName, args, moveDirection);\r\n\t};\r\n\r\n\t/**\r\n\t * Открыть диалоговое окно как ссылку, для хеш-навигации\r\n\t *\r\n\t * Диалоговые окна загружаются по имени, см. настройку плагина Core topDialogLoader\r\n\t */\r\n\tasync openAsLink(\r\n\t\tpageName: string = 'main',\r\n\t\tprops?: {},\r\n\t\t_args: string[] = [],\r\n\t\tonCloseOnce?: typeof this.onCloseOnce,\r\n\t\tmoveDirection?: MoveDirection,\r\n\t) {\r\n\t\tif (props) await this.setProps(props);\r\n\t\tif (onCloseOnce) this.onCloseOnce = onCloseOnce;\r\n\r\n\t\tconst viewName = this.idAttr + '-' + pageName;\r\n\r\n\t\tlocation.hash = TopDialogWorker.genViewPageHash(viewName, moveDirection);\r\n\t};\r\n\r\n\t/**\r\n\t * Закрыть диалоговое окно\r\n\t *\r\n\t * Не меняет состояние компонента диалогового окна\r\n\t */\r\n\tasync close() {\r\n\t\tTopDialogWorker.close(this.idAttr);\r\n\t};\r\n\r\n\t/**\r\n\t * Размонтировать $.dialog\r\n\t */\r\n\tasync destroy() {\r\n\t\tTopDialogWorker.destroy(this.idAttr);\r\n\t}\r\n\r\n\t/**\r\n\t * Устанвоить props\r\n\t *\r\n\t * Полностью сбрасывается состояние props\r\n\t */\r\n\tasync setProps(props: ComponentInstance<T>['$props'] = {}) {\r\n\t\t// ожидание инициализации компонента\r\n\t\tif (!this.isMounted) {\r\n\t\t\tawait waitWhile(() => !this.props);\r\n\t\t}\r\n\r\n\t\tfor (const name in this.props) {\r\n\t\t\tthis.props[name] = props[name];\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t * Проверить, есть ли необходимость отрисовки страницы диалогового окна\r\n\t */\r\n\tneedShowPage(pageName: string): boolean {\r\n\t\tif (!this.isOpened.value) return false;\r\n\r\n\t\treturn this.pageActive.value === pageName || this.pageActiveNext.value === pageName;\r\n\t}\r\n}\r\n","<script lang=\"ts\">\r\nimport { shallowReactive } from 'vue';\r\nimport { TopDialogHandle } from '@/components/dialog/dialog/composables/dialogHandle';\r\nimport type { TopDialogComponent } from '@/components/dialog/dialog/composables/types';\r\n\r\n/**\r\n * Словарь всех используемых диалоговых окон\r\n *\r\n * В других компонентах не использовать\r\n */\r\nconst dialogsWorkers = shallowReactive(new Map<string, TopDialogHandle<TopDialogComponent>>());\r\n\r\nexport const getDialogWorker = (id: string) => {\r\n\tid = id.replace(/^dialog_/, '');\r\n\r\n\treturn dialogsWorkers.get(id);\r\n};\r\n\r\n/**\r\n * Добавить компонент диалогового окна для использования\r\n */\r\nexport const addDialogWorker = <T extends TopDialogComponent>(TopDialogComponent: T): TopDialogHandle<T> => {\r\n\tif (!TopDialogComponent?.id) {\r\n\t\tconsole.log({ TopDialogComponent: TopDialogComponent });\r\n\r\n\t\tthrow new Error('Expected TopDialogComponent');\r\n\t}\r\n\r\n\tif (!dialogsWorkers.has(TopDialogComponent.id)) {\r\n\t\tdialogsWorkers.set(TopDialogComponent.id, new TopDialogHandle(TopDialogComponent));\r\n\t}\r\n\r\n\treturn dialogsWorkers.get(TopDialogComponent.id) as TopDialogHandle<T>;\r\n};\r\n</script>\r\n\r\n<script setup lang=\"ts\">\r\nimport { onUnmounted } from 'vue';\r\n\r\ndefineOptions({\r\n\tname: 'DialogWrapper',\r\n});\r\n\r\nonUnmounted(() => {\r\n\tdialogsWorkers.forEach(dialog => dialog.destroy());\r\n\tdialogsWorkers.clear();\r\n});\r\n</script>\r\n\r\n<template>\r\n\t<div class=\"top-dialogs\" style=\"display: none;\">\r\n\t\t<component\r\n\t\t\tv-for=\"[dialogId, dialog] in dialogsWorkers\"\r\n\t\t\t:is=\"dialog.Component\"\r\n\t\t\t:key=\"dialogId\"\r\n\t\t/>\r\n\t</div>\r\n</template>\r\n","import type { Ref } from 'vue';\r\nimport { ref } from 'vue';\r\nimport { useTopDialog } from './utils';\r\nimport { waitWhile } from '@/core/utils/system';\r\nimport type { AsyncTopDialogComponentLoader, TopDialogComponent } from './types';\r\nimport { TopDialogHandle } from './dialogHandle';\r\n\r\n/**\r\n * Объект для работы с асинхронным диалоговым окном\r\n *\r\n * Является прослойкой для доступа к TopDialogHandle\r\n */\r\nexport class AsyncTopDialogHandle<T extends TopDialogComponent> {\r\n\r\n\t/**\r\n\t * Функция, определяющая компонент TopDialogComponent\r\n\t */\r\n\treadonly resolve: AsyncTopDialogComponentLoader<T>;\r\n\r\n\t/**\r\n\t * Реактивная Сссылка на объект worker,\r\n\t *\r\n\t * Ссылка не будет указывать на объект, если диалоговое окно еще не загружено\r\n\t */\r\n\treadonly worker: Ref<TopDialogHandle<T> | null> = ref(null);\r\n\r\n\tconstructor(resolve: AsyncTopDialogComponentLoader<T>) {\r\n\t\tthis.resolve = resolve;\r\n\t}\r\n\r\n\t/**\r\n\t * Получить доступ к TopDialogHandle\r\n\t */\r\n\tasync get() {\r\n\t\tif (this.worker.value) return this.worker.value;\r\n\r\n\t\tconst result = await this.resolve();\r\n\t\tconst TopDialogComponent = result.default;\r\n\r\n\t\tthis.worker.value = useTopDialog(TopDialogComponent);\r\n\r\n\t\tconst worker = this.worker.value;\r\n\r\n\t\tawait waitWhile(() => !worker.isMounted);\r\n\r\n\t\treturn worker;\r\n\t}\r\n\r\n\t/**\r\n\t * Открыть диалоговое окно\r\n\t */\r\n\tasync open(...args: Parameters<TopDialogHandle<T>['open']>) {\r\n\t\tconst worker = await this.get();\r\n\r\n\t\tawait worker.open(...args);\r\n\t}\r\n\r\n\t/**\r\n\t * Открыть диалоговое окно как ссылку, для хеш-навигации\r\n\t *\r\n\t * Только общедоступные диалоговые окна, расположенные в @/dialogs\r\n\t */\r\n\tasync openAsLink(...args: Parameters<TopDialogHandle<T>['open']>) {\r\n\t\tconst worker = await this.get();\r\n\r\n\t\tvoid worker.openAsLink(...args);\r\n\t}\r\n\r\n\t/**\r\n\t * Закрыть диалоговое окно\r\n\t *\r\n\t * Не меняет состояние компонента диалогового окна\r\n\t */\r\n\tasync close(...args: Parameters<TopDialogHandle<T>['close']>) {\r\n\t\tconst worker = await this.get();\r\n\r\n\t\tworker.close(...args);\r\n\t}\r\n\r\n\t/**\r\n\t * Размонтировать виджет диалогового окна\r\n\t */\r\n\tasync destroy(...args: Parameters<TopDialogHandle<T>['close']>) {\r\n\t\tconst worker = await this.get();\r\n\r\n\t\tworker.destroy(...args);\r\n\t}\r\n\r\n\t/**\r\n\t * Устанвоить props\r\n\t *\r\n\t * Полностью сбрасывается состояние props\r\n\t */\r\n\tasync setProps(...args: Parameters<TopDialogHandle<T>['setProps']>) {\r\n\t\tconst worker = await this.get();\r\n\r\n\t\tawait worker.setProps(...args);\r\n\t}\r\n}\r\n","import { getCurrentInstance, inject } from 'vue';\r\nimport { TopDialogHandle } from './dialogHandle';\r\nimport { AsyncTopDialogHandle } from './asyncDialogHandle';\r\nimport type { AsyncTopDialogComponentLoader, TopDialogComponent } from './types';\r\nimport { addDialogWorker, getDialogWorker } from '../dialogs/dialogs.vue';\r\n\r\n/**\r\n * Получить объект управленя текущим диалоговым окном\r\n */\r\nexport const useTopDialogSelf = () => {\r\n\t// вызов из пользовтаельского компонента диалога\r\n\tconst topDialogComponent = getCurrentInstance() as any;\r\n\tif (topDialogComponent?.type?.id) {\r\n\t\tconst dialogWorker = getDialogWorker(topDialogComponent.type.id);\r\n\t\tif (dialogWorker) return dialogWorker;\r\n\t}\r\n\r\n\treturn inject('dialogWorker') as TopDialogHandle<TopDialogComponent>;\r\n};\r\n\r\n/**\r\n * Получить объект управленя диалоговым окном\r\n *\r\n * При первом вызове компонент диалогового окна будет внедрен в компонент DialogWrapper\r\n */\r\nexport const useTopDialog = <T extends TopDialogComponent>(DialogComponent: T): TopDialogHandle<T> => {\r\n\treturn addDialogWorker(DialogComponent);\r\n};\r\n\r\n/**\r\n * Получить объект управленя асинхронным диалоговым окном\r\n *\r\n * Компонент диалогового окна будет загружен и инициирован при первом взаимодействии с объектом\r\n *\r\n * Использует useTopDialog()\r\n */\r\nexport const useAsyncTopDialog = <T extends TopDialogComponent>(resolve: AsyncTopDialogComponentLoader<T>): AsyncTopDialogHandle<T> => {\r\n\treturn new AsyncTopDialogHandle(resolve);\r\n};\r\n"],"names":["TopDialogWorker","options","autoInitDelay","e","el","viewName","$toDialog","moveDirection","TopDialogUtils","toView","$modalLayers","$currentPage","replaceHistory","pageName","hash","historySetState","$el","$dialog","dialogId","toViewPageN","viewNameAndPageLink","pageLink","genHash","hash2","mathes","mathes2","math","math2","getHash","view","regexp","_index","dialog","TopDialogHandle","ref","TopDialogComponent","markRaw","topDialogComponent","topDialogBaseComponent","props","args","onCloseOnce","_args","waitWhile","name","dialogsWorkers","shallowReactive","getDialogWorker","id","addDialogWorker","onUnmounted","AsyncTopDialogHandle","resolve","useTopDialog","worker","useTopDialogSelf","getCurrentInstance","_a","dialogWorker","inject","DialogComponent","useAsyncTopDialog"],"mappings":"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"}
package/README.md CHANGED
@@ -1,82 +1,82 @@
1
- # UI kit Topvisor Vue
2
-
3
- ## Vue компоненты
4
-
5
- Компоненты поставляются в двух форматах:
6
-
7
- - amd (requirejs)
8
- - es
9
-
10
- Компоненты делятся на разные библиотеки и доступны через импорт этих библиотек.
11
-
12
- Каждая библиотека находится в отдельной папке, соответствующей имени библиотеки.
13
-
14
- Все стили модулей находятся в папке /assets/ в файлах соответствующих имени библиотеки.
15
- В этой же папке располагаются стили для асинхронно загружаемых компонентов.
16
- Все стили грузятся автоматически вместе с загрузкой компонента.
17
-
18
- Документация и описание всех компонентов: https://ui.topvisor.com/
19
-
20
- ## Общие стили UI
21
-
22
- - /assets/core.css - основная палитра цветов и общие стили и модификаторы компонентов
23
- - /assets/themes/* - стили тем оформления
24
-
25
- ## Подключение стилей
26
-
27
- Стили компонентов подгружаются автоматически.
28
-
29
- Стили UI core.css необходимо подгрузить на страницу вручную.
30
-
31
- ```js
32
- import '@topvisor/ui/assets/core.css';
33
- ```
34
-
35
- ```html
36
- <link href="https://cdn.jsdelivr.net/npm/@topvisor/ui/assets/core.css" rel="stylesheet">
37
- ```
38
-
39
- ## Подключение стилей темы
40
-
41
- Стили темы необходимо подгрузить на страницу вручную.
42
-
43
- Для смены темы необходимо подгрузить файл стилей необходимой темы и отключить стили предыдущей темы.
44
-
45
- ```js
46
- import '@topvisor/ui/assets/themes/light.css';
47
- ```
48
-
49
- ```html
50
-
51
- <link href="https://cdn.jsdelivr.net/npm/@topvisor/ui/assets/themes/light.css" rel="stylesheet">
52
- ```
53
-
54
- ## Внешние зависимсоти
55
-
56
- Стили icomoon добавлены в пакет и их необходимо подгрузить на страницу вручную.
57
-
58
- ```js
59
- import '@topvisor/ui/icomoon/style.css';
60
- ```
61
-
62
- ```html
63
-
64
- <link href="https://cdn.jsdelivr.net/npm/@topvisor/ui/icomoon/style.css" rel="stylesheet">
65
- ```
66
-
67
- ## Подключение компонентов
68
-
69
- Пример подключения библиотеки Forms и компонента Button:
70
-
71
- ```javascript
72
- require(['@topvisor/ui/forms/forms.amd'], ({ Button }) => {
73
- console.log(Button);
74
- });
75
-
76
- require(['@topvisor/ui/forms/forms.amd'], Forms => {
77
- const { Button } = Forms;
78
-
79
- console.log(Forms);
80
- console.log(Button);
81
- });
82
- ```
1
+ # UI kit Topvisor Vue
2
+
3
+ ## Vue компоненты
4
+
5
+ Компоненты поставляются в двух форматах:
6
+
7
+ - amd (requirejs)
8
+ - es
9
+
10
+ Компоненты делятся на разные библиотеки и доступны через импорт этих библиотек.
11
+
12
+ Каждая библиотека находится в отдельной папке, соответствующей имени библиотеки.
13
+
14
+ Все стили модулей находятся в папке /assets/ в файлах соответствующих имени библиотеки.
15
+ В этой же папке располагаются стили для асинхронно загружаемых компонентов.
16
+ Все стили грузятся автоматически вместе с загрузкой компонента.
17
+
18
+ Документация и описание всех компонентов: https://ui.topvisor.com/
19
+
20
+ ## Общие стили UI
21
+
22
+ - /assets/core.css - основная палитра цветов и общие стили и модификаторы компонентов
23
+ - /assets/themes/* - стили тем оформления
24
+
25
+ ## Подключение стилей
26
+
27
+ Стили компонентов подгружаются автоматически.
28
+
29
+ Стили UI core.css необходимо подгрузить на страницу вручную.
30
+
31
+ ```js
32
+ import '@topvisor/ui/assets/core.css';
33
+ ```
34
+
35
+ ```html
36
+ <link href="https://cdn.jsdelivr.net/npm/@topvisor/ui/assets/core.css" rel="stylesheet">
37
+ ```
38
+
39
+ ## Подключение стилей темы
40
+
41
+ Стили темы необходимо подгрузить на страницу вручную.
42
+
43
+ Для смены темы необходимо подгрузить файл стилей необходимой темы и отключить стили предыдущей темы.
44
+
45
+ ```js
46
+ import '@topvisor/ui/assets/themes/light.css';
47
+ ```
48
+
49
+ ```html
50
+
51
+ <link href="https://cdn.jsdelivr.net/npm/@topvisor/ui/assets/themes/light.css" rel="stylesheet">
52
+ ```
53
+
54
+ ## Внешние зависимсоти
55
+
56
+ Стили icomoon добавлены в пакет и их необходимо подгрузить на страницу вручную.
57
+
58
+ ```js
59
+ import '@topvisor/ui/icomoon/style.css';
60
+ ```
61
+
62
+ ```html
63
+
64
+ <link href="https://cdn.jsdelivr.net/npm/@topvisor/ui/icomoon/style.css" rel="stylesheet">
65
+ ```
66
+
67
+ ## Подключение компонентов
68
+
69
+ Пример подключения библиотеки Forms и компонента Button:
70
+
71
+ ```javascript
72
+ require(['@topvisor/ui/forms/forms.amd'], ({ Button }) => {
73
+ console.log(Button);
74
+ });
75
+
76
+ require(['@topvisor/ui/forms/forms.amd'], Forms => {
77
+ const { Button } = Forms;
78
+
79
+ console.log(Forms);
80
+ console.log(Button);
81
+ });
82
+ ```