@topvisor/ui 1.1.0-addNativeDialog.12 → 1.1.0-addNativeDialog.14
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.
- package/.chunks/{core-uFZ53eDz.amd.js → core-Bg7lKh4e.amd.js} +2 -2
- package/.chunks/{core-uFZ53eDz.amd.js.map → core-Bg7lKh4e.amd.js.map} +1 -1
- package/.chunks/{core-DwmZJeKo.es.js → core-CPZQHtCX.es.js} +2 -2
- package/.chunks/{core-DwmZJeKo.es.js.map → core-CPZQHtCX.es.js.map} +1 -1
- package/.chunks/{dialog_selectorRegions-DKdrXyjJ.es.js → dialog_selectorRegions-CiOb1xAG.es.js} +3 -3
- package/.chunks/{dialog_selectorRegions-DKdrXyjJ.es.js.map → dialog_selectorRegions-CiOb1xAG.es.js.map} +1 -1
- package/.chunks/{dialog_selectorRegions--uU_HPMU.amd.js → dialog_selectorRegions-DuaLJE6o.amd.js} +2 -2
- package/.chunks/{dialog_selectorRegions--uU_HPMU.amd.js.map → dialog_selectorRegions-DuaLJE6o.amd.js.map} +1 -1
- package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-DzO4WR8t.es.js +622 -0
- package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-DzO4WR8t.es.js.map +1 -0
- package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-R1tL-n2T.amd.js +2 -0
- package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-R1tL-n2T.amd.js.map +1 -0
- package/.chunks/{lazy-gcvTGQlK.es.js → lazy-40pjr8cZ.es.js} +3 -3
- package/.chunks/lazy-40pjr8cZ.es.js.map +1 -0
- package/.chunks/lazy-DSFLxvj4.amd.js +2 -0
- package/.chunks/lazy-DSFLxvj4.amd.js.map +1 -0
- package/.chunks/{page.vue_vue_type_script_setup_true_lang-jdOhWtvA.amd.js → page.vue_vue_type_script_setup_true_lang-BhK7qQ70.amd.js} +2 -2
- package/.chunks/{page.vue_vue_type_script_setup_true_lang-jdOhWtvA.amd.js.map → page.vue_vue_type_script_setup_true_lang-BhK7qQ70.amd.js.map} +1 -1
- package/.chunks/{page.vue_vue_type_script_setup_true_lang-DRvRAOmG.es.js → page.vue_vue_type_script_setup_true_lang-BuzMReWp.es.js} +3 -3
- package/.chunks/{page.vue_vue_type_script_setup_true_lang-DRvRAOmG.es.js.map → page.vue_vue_type_script_setup_true_lang-BuzMReWp.es.js.map} +1 -1
- package/.chunks/{utils-BmI_WbPx.amd.js → utils-Br0ZfM-6.amd.js} +2 -2
- package/.chunks/{utils-BmI_WbPx.amd.js.map → utils-Br0ZfM-6.amd.js.map} +1 -1
- package/.chunks/{utils-CjdLXxom.es.js → utils-CSr6gGno.es.js} +2 -2
- package/.chunks/{utils-CjdLXxom.es.js.map → utils-CSr6gGno.es.js.map} +1 -1
- package/api/index.amd.js +1 -1
- package/api/index.js +6 -6
- package/core/app.amd.js +1 -1
- package/core/app.js +3 -3
- package/dialog/dialog.amd.js +1 -1
- package/dialog/dialog.js +2 -2
- package/package.json +1 -1
- package/project/project.amd.js +1 -1
- package/project/project.js +2 -2
- package/src/components/dialog/lib/types.d.ts +4 -36
- package/src/components/dialog/lib/utils.d.ts +7 -8
- package/src/components/dialog/lib/worker.d.ts +4 -8
- package/utils/searchers.amd.js +1 -1
- package/utils/searchers.js +2 -2
- package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-C7vi1i47.amd.js +0 -2
- package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-C7vi1i47.amd.js.map +0 -1
- package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-xvod3Gmp.es.js +0 -626
- package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-xvod3Gmp.es.js.map +0 -1
- package/.chunks/lazy-BBcejshh.amd.js +0 -2
- package/.chunks/lazy-BBcejshh.amd.js.map +0 -1
- package/.chunks/lazy-gcvTGQlK.es.js.map +0 -1
|
@@ -30,7 +30,7 @@ export declare abstract class TopDialogWorker {
|
|
|
30
30
|
setLoading: (elPages: ElTopDialogPage[] | JQuery<ElTopDialogPage>, isLoading: boolean, duration?: number) => void;
|
|
31
31
|
isLoading: (elPage: ElTopDialogPage | JQuery<ElTopDialogPage>) => boolean;
|
|
32
32
|
inAnimation: (elDialog: ElTopDialog | JQuery<ElTopDialog>) => boolean;
|
|
33
|
-
close: (
|
|
33
|
+
close: (dialogId: string) => void;
|
|
34
34
|
}>;
|
|
35
35
|
static getDialog(el: HTMLElement): ElTopDialog | null;
|
|
36
36
|
/**
|
|
@@ -46,25 +46,21 @@ export declare abstract class TopDialogWorker {
|
|
|
46
46
|
* @deprecated Для обратной совместимости
|
|
47
47
|
*/
|
|
48
48
|
static get$page($el: $el): JQuery<HTMLElement>;
|
|
49
|
-
static getPairPage(el: HTMLElement): ElTopDialogPage[] | undefined;
|
|
50
49
|
/**
|
|
51
50
|
* todo: Переписать на сайте на this.getPairPage()
|
|
52
51
|
*
|
|
53
52
|
* @deprecated Для обратной совместимости
|
|
54
53
|
*/
|
|
55
54
|
static get$pairPage($el: $el): JQuery<HTMLElement>;
|
|
55
|
+
static getPairPage(el: HTMLElement): HTMLElement[] | undefined;
|
|
56
56
|
/**
|
|
57
57
|
* Закрыть диалоговое окно по его id
|
|
58
|
-
* @param id - id элемента ElTopDialog
|
|
59
|
-
* @see ElTopDialog
|
|
60
58
|
*/
|
|
61
|
-
static close(
|
|
59
|
+
static close(dialogId: string): void;
|
|
62
60
|
/**
|
|
63
61
|
* Размонтировать диалоговое окно по его id
|
|
64
|
-
* @param id - id элемента ElTopDialog
|
|
65
|
-
* @see ElTopDialog
|
|
66
62
|
*/
|
|
67
|
-
static destroy(
|
|
63
|
+
static destroy(dialogId: string): void;
|
|
68
64
|
/**
|
|
69
65
|
* Сгенерировать ссылку на страницу в диалоговом окне
|
|
70
66
|
* @param toView - указатель в формате: dialog_{{ dialogId }}={{ pageName }}:{{ args }}
|
package/utils/searchers.amd.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
define(["require","exports","../.chunks/forms-CgtkdwgA.amd","../.chunks/core-
|
|
1
|
+
define(["require","exports","../.chunks/forms-CgtkdwgA.amd","../.chunks/core-Bg7lKh4e.amd","vue","../.chunks/dialogs.vue_vue_type_script_setup_true_lang-R1tL-n2T.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
|
package/utils/searchers.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import "../.chunks/forms-DarRVke_.es.js";
|
|
2
|
-
import "../.chunks/core-
|
|
2
|
+
import "../.chunks/core-CPZQHtCX.es.js";
|
|
3
3
|
import "vue";
|
|
4
|
-
import "../.chunks/dialogs.vue_vue_type_script_setup_true_lang-
|
|
4
|
+
import "../.chunks/dialogs.vue_vue_type_script_setup_true_lang-DzO4WR8t.es.js";
|
|
5
5
|
const k = {
|
|
6
6
|
0: "Yandex",
|
|
7
7
|
20: "Yandex.com",
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
define(["require","exports","vue","../utils/system.amd","./forms-CgtkdwgA.amd","../popup/worker.amd","../utils/route.amd","../utils/scroll.amd","../utils/dom.amd"],(function(we,A,c,q,b,N,v,X,s){"use strict";if(typeof c>"u")var c=window.Vue;$;class p{static state={load:void 0,decoratorOnCreate:void 0,viewPageN:0};static inited=!1;static init(t){if(this.inited)return;this.inited=!0,this.state.load=t==null?void 0:t.load,this.state.decoratorOnCreate=t==null?void 0:t.decoratorOnCreate;const a=(t==null?void 0:t.autoInitDelay)??5e3;window.addEventListener("hashchange",i=>{this.opendDialogsFromChangeUrl(i.oldURL,i.newURL)}),this.opendDialogsFromChangeUrl("",location.href),document.addEventListener("mousedown",async i=>{const o=i.target.closest("a[data-to-view]");if(!o)return;let n="next";o.dataset.action==="top-dialog-close"&&(n="prev"),o.href=p.genViewPageHash(o.dataset.toView,n)}),document.addEventListener("click",async i=>{var h,w;const o=i.target.closest("[data-to-view]");if(!o)return;if(o instanceof HTMLAnchorElement&&o.href==="."){i.preventDefault();const L=new MouseEvent("mousedown",{bubbles:!0,cancelable:!0,view:window});o.dispatchEvent(L),setTimeout(()=>o.click());return}const n=await this.getDialogsUtils(),l=o.dataset.toView,g=l.split("-")[0],u=n.getElDialogById(g);let y="next";if(u){const L=s.querySelectorAllArray(u,".modal-layer"),Y=L.reduce((V,Z)=>{const S=Z.querySelector(":scope > .active");return S&&V.push(S),V},[]);if(Y.length){const V=l.split("-")[1].split(":")[0];(((h=L.reduce((S,I)=>{const G=I==null?void 0:I.querySelector(`:scope > [data-view-page="${V}"]`);return G&&S.push(G),S},[])[0])==null?void 0:h.dataset.order)??0)<(((w=Y[0])==null?void 0:w.dataset.order)??0)&&(y="prev")}}o.dataset.action==="top-dialog-close"&&(y="prev");const d=p.genViewPageHash(l,y);if(o instanceof HTMLAnchorElement){if(!u||!s.isVisible(u))return;if(location.hash.indexOf(l.replace("-","="))!==-1){await n.toViewDirty(l);return}}!!(u!=null&&u.dataset.toViewReplace)?(i.preventDefault(),v.historySetState(!0,d),await n.toViewDirty(l),y=="next"?p.state.viewPageN++:p.state.viewPageN--):o.tagName!=="A"&&(this.compareStates(d,location.hash)?v.historySetState(!1,d):await n.toViewDirty(l))}),setTimeout(()=>this.getDialogsUtils(),a)}static opendDialogsFromChangeUrl(t,a){const i=t.replace(/.*?#/,"#"),r=a.replace(/.*?#/,"#");this.compareStates(i,r)&&this.opendDialogsFromUrl()}static async getDialogsUtils(){const{TopDialogUtils:t}=await Promise.resolve().then(()=>ue);return t}static getDialog(t){return t.closest(".ui-dialog-content")}static get$dialog(t){return t.closest(".ui-dialog-content")}static getPage(t){return t.closest("[data-view-page]")}static get$page(t){return t.closest("[data-view-page]")}static getPairPage(t){const a=p.getDialog(t);if(!a)return;const i=p.getPage(t),r=i==null?void 0:i.dataset.viewPage;return s.querySelectorAllArray(a,`[data-view-page="${r}"]`)}static get$pairPage(t){const a=p.get$dialog(t),r=p.get$page(t).data("view-page");return $('[data-view-page="'+r+'"]',a)}static close(t){const a=document.getElementById(t);if(!a)return;f(a).close()}static destroy(t){const a=document.getElementById(t);if(!a)return;const i=f(a);i.close(),i.remove()}static genViewPageHash(t,a="next"){let i=this.state.viewPageN;a=="prev"?i--:i++;const r=t.split("-"),o=r.shift(),n=r.join("-");let l=v.genHash("vpn",i);return l=v.genHash("view-"+o,n,l),l}static compareStates(t,a){const i=t.match(/[#&]view-[^&]+/g)||[],r=a.match(/[#&]view-[^&]+/g)||[];return!!(i.length!==r.length||i.filter((n,l)=>{const g=r[l]||"";return n!==g}).length)}static opendDialogsFromUrl=async()=>{const t=Number(v.getHash("vpn"))||0;let a;const i=new RegExp("view-((\\w+)=([\\w-]+)(?::([\\w.:-]+))?)","g");for(;a=i.exec(location.hash);){let o="next";return t<this.state.viewPageN&&(o="prev"),(await this.getDialogsUtils()).toViewDirty(a[1],o)}return s.querySelectorAllArray(document,".ui-dialog-content[data-view-page-active]").filter(o=>s.isVisible(o)).forEach(o=>{const n=o.getAttribute("id");if(!n)throw"Диалоговое окно не содержит id";v.getHash("view-"+n)||f(o).close()}),this.state.viewPageN=t,!0}}let j=!1;const D=()=>{j||(j=!0,document.addEventListener("click",e=>{const t=e.target.closest('[data-action="top-dialog-close"]');if(!t)return;e.preventDefault();const a=t.closest(".ui-dialog-content");if(!a)return;const i=t.dataset.toView;if(i=="toPrevPage()"){P.toPrevPage(a);return}if(i){const o=i.split("-"),n=o.shift(),l=o.join("-");if(!n)return;const g=P.getElDialogById(n);if(!g)return;const u=s.querySelectorAllArray(g,`[data-view-page="${l}"]`);if(!u)return;if(!s.isVisible(u[0])){const y=p.genViewPageHash(i,"prev");v.historySetState(!1,y);return}}f(a).close()}),document.addEventListener("submit",e=>{const t=e.target;(t.matches(".modal-body > form")||t.matches(".modal-layer-body > form"))&&e.preventDefault()}),document.addEventListener("keypress",e=>{const t=e.target;if(!(!t.closest(".ui-dialog .modal-body")||!(t.matches("input:not(.searcher), textarea:not(.searcher), select:not(.searcher), button:not(.searcher)")||t.hasAttribute("contenteditable")))&&e.key==="Enter"){if(t.classList.contains("autocomplete")){e.preventDefault();return}if(t.tagName==="TEXTAREA"){if(!e.ctrlKey&&!e.metaKey)return;const r=t.closest("form");if(r){const o=s.querySelectorAllArray(r,'button[type="submit"]').concat(s.querySelectorAllArray(r,'input[type="submit"]')).find(n=>s.isVisible(n));o==null||o.click()}}}}),document.addEventListener("click",e=>{if(!e.target.classList.contains("ui-dialog-overlay"))return;let a,i=0;s.querySelectorAllArray(document,".ui-dialog").filter(o=>s.isVisible(o)&&o.getAttribute("aria-modal")==="false").forEach(o=>{const n=Number(window.getComputedStyle(o).zIndex);n<i||(a=o,i=n)}),a&&a.close()}),window.addEventListener("resize",P.recalcPositions),P.recalcPositions())},ee=':root{--dialog-border-color: var(--color-line-1);--dialog-loading-duration: 10s;--top-dialog-footer-height: var(--top-forms-base-height_s)}html.with_dialog{overflow:hidden!important}a[data-to-view]{cursor:pointer}.ui-dialog{overflow:visible;background:var(--color-layout-front-1);max-height:none;max-width:none;border-radius:8px;border:none;padding:0;color:var(--color-text-1)}.ui-dialog[aria-modal=false]{top:50%;transform:translateY(-50%);z-index:100001}.ui-dialog-overlay,.ui-dialog::backdrop{background:#040404;opacity:.5;filter:Alpha(Opacity=50)}.ui-dialog-overlay{position:fixed;inset:0;z-index:100000;display:none}.ui-dialog[aria-modal=false][open]~.ui-dialog-overlay{display:block}.ui-dialog .ui-dialog-content{padding:0;overflow:visible}.ui-dialog .project_name{word-break:break-all}.ui-dialog-content{--dialog-header-height: 50px;--dialog-layer-pageSelector: 0px}.ui-dialog-content-withPageSelector{--dialog-layer-pageSelector: 42px}.modal-header,.modal-body,.modal-footer{font-size:14px;position:relative}.modal-body{padding:var(--padding-default)}.modal-body:has(>.topTable:first-child){padding-top:calc(var(--padding-default) / 4)}.modal-header{border-bottom:1px solid var(--dialog-border-color);height:var(--dialog-header-height);padding:0 var(--padding-default);display:flex;justify-content:space-between;align-items:center;gap:var(--top-padding-2)}.modal-header>*{padding:10px 0;font-size:16px}.modal-header>.top-title{margin:0;font-weight:400;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-grow:1;order:50;display:flex;align-items:center}.modal-header>.top-title>div[class*=icon]{display:none}.modal-header>div:not(.top-title){order:60}.modal-header>button.close{--top-icon-color: var(--color-text-2);cursor:pointer;background:var(--color-layout-front-1);font-size:16px;order:100;animation-name:none!important}.modal-header>button.close:hover{--top-icon-color: var(--color-text-1)}.modal-header .links_icons{position:absolute;right:50px}.modal-header .links_icons [class*=icon-]{width:auto;height:auto;padding:0 5px;color:#d6dee0}.modal-header .links_icons [class*=icon-].active{color:var(--color-bg-warning-1)}.modal-layer-pageSelector{padding:0 10px!important}.modal-body{max-height:calc(var(--100vh) - var(--dialog-header-height) - 1px - var(--dialog-layer-pageSelector) - var(--top-dialog-footer-height) - 1px);overflow-y:auto;overflow-x:hidden;box-sizing:border-box;flex-grow:1}.modal-body hr{margin:16px -15px}.modal-body h4{padding:0;margin:0 0 10px;line-height:normal}.modal-body .inner{padding:var(--padding-default);margin:0 calc(0px - var(--padding-default));position:relative}.modal-body .inner .bt{border-top:1px dashed var(--color-layout-front-primary-3);position:absolute;top:0;right:0;left:0}.modal-body .inner .bb{border-bottom:1px dashed var(--color-layout-front-primary-3);position:absolute;right:0;bottom:0;left:0}.modal-body .inner.color-1{background:var(--color-layout-front-primary-3);color:var(--color-text-1)}.modal-body .inner strong{color:var(--color-text-1)}.modal-body .comment{line-height:18px}.modal-footer{min-height:var(--top-dialog-footer-height);padding:var(--top-gap-2);display:flex;flex-shrink:0;align-items:center;justify-content:flex-end;gap:var(--top-gap-2)}.modal-footer .modal-footer-btn-left{margin-right:auto}.modal-footer>.btn.full_width,.modal-footer>.top-button.full_width{flex-grow:1;align-self:flex-end}.modal-footer-fullWith{flex-wrap:wrap}.modal-footer-fullWith>*{flex-grow:1}.modal-footer-fullWith>.top-info{flex-grow:5}.modal-footer-fullWith>*:empty{flex-grow:0}.ui-dialog-content>.modal-layer>[data-view-page]>input[type=submit]{position:absolute;visibility:hidden}.help_popup .modal-header{display:none}.help_popup .modal-header a{top:2px;z-index:10}.help_popup .modal-header .top-title{display:none}.modal-layer{overflow:hidden}.modal-layer a[data-top-icon]:empty{color:var(--color-text-4);text-decoration:none}.modal-layer>[data-view-page]>div>div.buttons{display:flex;white-space:nowrap;gap:var(--top-padding-1)}.modal-layer>[data-view-page]>div>div.buttons:empty{display:none}.modal-layer>[data-view-page]>div>div.buttons>div,.modal-layer>[data-view-page]>div>div.buttons>a{cursor:pointer;width:auto;height:auto;min-width:auto;min-height:auto;padding:10px 9px;color:var(--color-text-4)}.modal-layer>[data-view-page]>div>div.buttons>div:hover{color:var(--color-text-2)}.modal-layer>[data-view-page]>div>div.buttons>div.hidden{display:none!important}.ui-dialog-content[data-view-page-active]{display:flex!important;flex-direction:column;justify-items:stretch}.ui-dialog-content>.modal-layer{display:flex!important;align-items:stretch;position:relative}.ui-dialog-content.i-change-page>.modal-layer{overflow:hidden}.ui-dialog-content>.modal-layer>[data-view-page]{width:100%;position:relative;display:none;flex-direction:column;justify-content:space-between;animation:.3s cubic-bezier(.4,0,.2,1) forwards}.ui-dialog-content>.modal-layer>[data-view-page].active{display:flex}.ui-dialog-content>.modal-layer>[data-view-page].reverse{animation-direction:reverse}.ui-dialog-content>.modal-layer>[data-view-page].center-to-left,.ui-dialog-content>.modal-layer>[data-view-page].right-to-center{display:flex;position:absolute;inset:0}.ui-dialog-content>.modal-layer>[data-view-page].center-to-left>div,.ui-dialog-content>.modal-layer>[data-view-page].right-to-center>div{overflow:hidden}.ui-dialog-content>.modal-layer-header{border-bottom:1px solid var(--dialog-border-color);min-height:var(--dialog-header-height)}.ui-dialog-content>.modal-layer-header>[data-view-page]>.modal-header{border:none;background:none}.ui-dialog-content>.modal-layer-header>[data-view-page]>.modal-header>*{animation:.3s cubic-bezier(.4,0,.2,1) forwards}.ui-dialog-content>.modal-layer-header>[data-view-page].reverse>.modal-header>*{animation-direction:reverse}.ui-dialog-content>.modal-layer-header>[data-view-page].center-to-left>.modal-header>.top-title{animation-name:dialog-center-to-left-header-title}.ui-dialog-content>.modal-layer-header>[data-view-page].right-to-center>.modal-header>.top-title{animation-name:dialog-right-to-center-header-title}.ui-dialog-content>.modal-layer-header>[data-view-page].center-to-left>.modal-header>[class*=widget-]{animation-name:dialog-center-to-left-header-title}.ui-dialog-content>.modal-layer-header>[data-view-page].right-to-center>.modal-header>[class*=widget-]{animation-name:dialog-right-to-center-header-title}.ui-dialog-content>.modal-layer-header>[data-view-page].center-to-left>.modal-header>div{animation-name:dialog-center-to-left-header-icons}.ui-dialog-content>.modal-layer-header>[data-view-page].right-to-center>.modal-header>div{animation-name:dialog-right-to-center-header-icons}.ui-dialog-content>.modal-layer-body{border-radius:0 0 8px 8px;max-height:calc(var(--100vh) - var(--dialog-header-height) - var(--dialog-layer-pageSelector) - var(--toolbar-height));flex-grow:2}.ui-dialog-content.i-change-page>.modal-layer-body>[data-view-page]{background:var(--color-layout-front-1)}.ui-dialog-content>.modal-layer-body>[data-view-page].center-to-left{animation-name:dialog-center-to-left}.ui-dialog-content>.modal-layer-body>[data-view-page].right-to-center{animation-name:dialog-right-to-center}.ui-dialog-content .modal-footer .second_level{box-sizing:border-box;background:var(--color-layout-front-1);width:100%;min-height:25px;display:flex;align-items:center;justify-content:center}.ui-dialog-content .modal-footer .second_level input{border-radius:8px;width:100%;height:var(--top-forms-base-height);padding:var(--top-padding-1) var(--top-padding-3);box-sizing:border-box}.ui-dialog-content>.modal-layer-body>[data-view-page].i-load-data{pointer-events:none}.ui-dialog-content>.modal-layer-body>[data-view-page].i-load-data:before{content:" ";background:#378dc6;width:0;height:4px;position:absolute;top:0;left:0;z-index:100;animation:top-loadbar var(--dialog-loading-duration) forwards}.ui-dialog-content.modal-expanded{width:100vw!important;height:calc(var(--100vh) + 10px)!important}.modal-header>[data-widget]{padding:0 8px;position:absolute;inset:0;opacity:0;overflow:hidden;align-items:center;visibility:hidden;transition:opacity .3s;z-index:1}.modal-header>[data-widget=search] div.cancel{opacity:0;transform:translate(100%);transition:transform,opacity;transition-duration:.3s}[data-view-page].i-show-search .modal-header>:not([data-widget=search]){visibility:hidden}[data-view-page].i-show-search [data-widget=search]{visibility:visible;opacity:1}[data-view-page].i-show-search [data-widget=search] .cancel{transform:translate(0);opacity:1}[data-view-page]>.modal-header>*{transition:opacity .3s}[data-view-page].i-show-search>.modal-header>div.buttons{opacity:0}.modal-layer .top-popup-wrapper{height:100%!important}@keyframes dialog-center-to-left-header-title{0%{transform:translate(0);opacity:1}75%{opacity:0}to{transform:translate(-30%);opacity:0}}@keyframes dialog-right-to-center-header-title{0%{transform:translate(100%);opacity:0}25%{opacity:0}to{transform:translate(0);opacity:1}}@keyframes dialog-center-to-left-header-icons{0%{transform:translate(0);opacity:1}35%{transform:translate(-20%);opacity:0}to{transform:translate(-20%);opacity:0}}@keyframes dialog-right-to-center-header-icons{0%{transform:translate(20%);opacity:0}65%{transform:translate(20%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes dialog-center-to-left{0%{transform:translate(0);filter:brightness(1)}to{transform:translate(-30%);filter:brightness(.9)}}@keyframes dialog-right-to-center{0%{transform:translate(100%);box-shadow:#0000001a 0 0 10px}to{transform:translate(0);box-shadow:#0003 0 0 10px}}@media only screen and (max-width: 1480px){.win_side_panel_opener{display:none}}@media only screen and (min-width: 1480px){.ui-dialog-content.with_side_panel{box-shadow:#0003 0 0 6px}.ui-dialog-content.with_side_panel .modal-layer-body{background:var(--color-layout-front-1)}[data-widget=side_panel]{--side_panel_width: calc((100vw - 900px)/2 - 28px) ;box-sizing:border-box;background:var(--color-layout-front-1);max-width:var(--side_panel_width);padding:18px;position:absolute;top:calc(var(--dialog-header-height) + 1px + var(--dialog-layer-pageSelector));bottom:calc(var(--top-dialog-footer-height) + 1px);z-index:-1;display:block;transition:.2s}.win_side_panel_left{border-radius:8px 0 0 8px;right:100%}.win_side_panel_right{border-radius:0 8px 8px 0;left:100%}.win_side_panel_closed.win_side_panel_left{right:calc(100% - var(--side_panel_width))}.win_side_panel_closed.win_side_panel_right{left:calc(100% - var(--side_panel_width))}[data-widget=side_panel] .template{display:block}[data-widget=side_panel] .template>.header,[data-widget=side_panel] .template>.footer{display:flex}.win_side_panel_opener{cursor:pointer;background:var(--color-cyan);color:#fff;padding:4px;position:absolute;top:20px}.win_side_panel_closed .win_side_panel_opener:not(:hover){opacity:.3}.win_side_panel_left .win_side_panel_opener{border-radius:4px 0 0 4px;right:100%}.win_side_panel_right .win_side_panel_opener{border-radius:0 6px 6px 0;left:100%}}@media only screen and (max-height: 900px){html.with_dialog{background:#f1f1f1;overflow:hidden}.ui-dialog.me-tightly{border-radius:0;height:auto!important;position:fixed;top:0!important;bottom:0!important}.ui-dialog.me-tightly .ui-dialog-content{min-height:100%!important}.ui-dialog.me-tightly>div>.modal-body{position:absolute;top:var(--dialog-header-height);right:0;left:0;bottom:var(--dialog-header-height)}.ui-dialog.me-tightly>div>.modal-body:last-child{bottom:0}.ui-dialog.me-tightly>div>.modal-footer{position:absolute;right:0;bottom:0;left:0}.ui-dialog.me-tightly .modal-layer-body{border-radius:0;min-height:0!important}.ui-dialog.me-tightly .modal-layer-body .modal-footer{min-height:unset}}',te="html.with_dialog body{height:var(--100vh);overflow:hidden}.ui-dialog{border-radius:0}.ui-dialog,.ui-dialog::backdrop{height:calc(100% - var(--toolbar-height));width:auto;margin-top:0}.ui-dialog-content{width:100%!important;height:100%!important;min-width:0!important;max-width:100%!important}.modal-header>.top-title{text-align:center;font-size:14px}.modal-header>button.close{font-size:14px;order:1}.modal-body:last-child{bottom:0}.modal-footer{bottom:0}.modal-footer .second_level{padding:10px 8px}.modal-layer-body{min-height:0!important}.ui-dialog-content>.modal-layer-body{border-radius:0}.modal-body,.modal-footer{padding-right:12px;padding-left:12px}.modal-footer .btn:last-child{margin-right:12px}.modal-body .inner{padding:12px;margin:0 -12px;position:relative}",ae=".modal-menu-opener{order:1!important}.modal-menu-opener:before{--top-icon-size: 20px;--top-icon-color: #FFF;--top-icon-width: var(--top-icon-size);border-radius:50%;background:var(--color-bg-primary-1);padding:3px;transition:transform .1s}.modal-menu-opener:hover:before{background:var(--color-bg-primary-2)}.modal-menu-opener.top-active:before{background:var(--color-bg-primary-2);transform:scale(.8)}.modal-layer .top-popup-wrapper{background:transparent;width:auto!important;padding:0!important;margin:0!important;top:0!important;right:0!important;left:0!important;transition:background .3s}.modal-layer .top-popup-wrapper>.top-popup[class],.modal-layer .top-popup-wrapper.with_notch>.top-popup[class]{border-radius:8px;border:none;margin:12px!important;max-width:100%;max-height:calc(100% - 24px);inset:0 0 auto!important;overflow:auto;display:flex;flex-direction:column;opacity:1;transform:translateY(calc(-100% - 24px));transition:transform .3s}.modal-layer .top-popup>.top-popup_header{background:var(--color-theme-50)}.modal-layer .top-theme-lite .top-popup>.top-popup_header .select{border:none}.modal-layer .top-theme-lite .top-popup>.top-popup_header .select .text{color:#fff}.modal-layer .top-theme-lite .top-popup>.top-popup_header .select .arrow{background:none}.modal-layer .top-popup-wrapper-shown:not(.top-popup-wrapper-closed){background:#34495e40}@media only screen and (min-width: 1480px){.ui-dialog-content.with_side_panel{box-shadow:#0003 0 0 6px}.ui-dialog-content.with_side_panel .modal-layer-body{background:var(--color-layout-front-1)}[data-widget=side_panel]{--side_panel_width: calc((100vw - 900px)/2 - 28px) ;box-sizing:border-box;background:var(--color-layout-front-1);max-width:var(--side_panel_width);padding:18px;display:block;position:absolute;top:51px;bottom:51px;z-index:-1;transition:.2s}.win_side_panel_left{border-radius:8px 0 0 8px;right:100%}.win_side_panel_right{border-radius:0 8px 8px 0;left:100%}.win_side_panel_closed.win_side_panel_left{right:calc(100% - var(--side_panel_width))}.win_side_panel_closed.win_side_panel_right{left:calc(100% - var(--side_panel_width))}[data-widget=side_panel] .template{display:block}[data-widget=side_panel] .template>.header,[data-widget=side_panel] .template>.footer{display:flex}.win_side_panel_opener{cursor:pointer;background:var(--color-cyan);color:#fff;padding:4px;position:absolute;top:20px}.win_side_panel_closed .win_side_panel_opener:not(:hover){opacity:.3}.win_side_panel_left .win_side_panel_opener{border-radius:4px 0 0 4px;right:100%}.win_side_panel_right .win_side_panel_opener{border-radius:0 6px 6px 0;left:100%}}",oe="html{--top-dialog-width: auto;--top-dialog-height: auto}.top-dialog{max-width:100vw}.top-dialog .modal-layer-body{height:var(--top-dialog-height)}",ie=".top-dialog{width:var(--top-dialog-width)!important}";b.Core.insertStyleToPage(ee),b.Core.insertStyleToPage(te,"m"),b.Core.insertStyleToPage(ae,"pc"),b.Core.insertStyleToPage(oe),b.Core.insertStyleToPage(ie,"pc");let O;const _=e=>!!e&&typeof e=="object"&&"jquery"in e,C=e=>{const t=R(e),a=re(t);e.setAttribute("closedby",a.closedby),e.setAttribute("aria-modal","false"),e.show()},re=e=>{const t={modal:!1,closedby:"closerequest"},a=e.dataset.closedby;return(a==="closerequest"||a==="none")&&(t.closedby=a),t},z=e=>document.getElementById(e),ne=e=>{e.dialog=t=>{switch(t){case"open":{C(e);break}case"close":{e.close();break}case void 0:{console.warn("Вызвана бесполезная инициализация у нативного диалога");break}default:throw new Error(`Передан неизвестный аргумент: "${t}"`)}return e},e.toggleClass=(t,a)=>{const i=e.querySelector(".ui-dialog-content");if(typeof t=="string"&&(t=t.split(" ")),Array.isArray(t))t.forEach(r=>{i.classList.toggle(r,a)});else throw new Error(`Передан необработанный тип аргумента: ${typeof t}`);return e},e.data=(...t)=>{const a=e.querySelector(".ui-dialog-content");return $(a).data(t),e}},k=async(e,t,a)=>{if(!e.startsWith("dialog_"))return;const i=E(e);if(i&&(i.isOpened.value=!0,t!==void 0&&(i.pageActive.value=t),a!==void 0&&(i.pageActiveNext.value=a),await c.nextTick(),a)){const r=z(e);if(!r)return;r.querySelectorAll(`[data-view-page="${a}"]`).length||await q.waitWhile(()=>!r.querySelectorAll(`[data-view-page="${a}"]`).length)}},de=e=>{var a,i;const t=e.querySelector(".modal-body");t&&(X.connectScrollShadow(t),(i=(a=p.state).decoratorOnCreate)==null||i.call(a,e),le(e))},le=e=>{$(e).on("aftershow.top-menu-popup","[data-top-popup]",(t,a)=>{var o;const i=a[0],r=p.getPairPage(i);(o=r==null?void 0:r[1])==null||o.prepend(i)})},se=async e=>{var n;const t=e.dataset.viewPageActive,a=window.innerWidth;b.Core.state.documentClassModificators.set("top-dialog","with_dialog");const r=window.innerWidth-a;document.documentElement.scrollHeight>window.innerHeight&&(document.querySelector("html").style.marginRight=r+"px"),F();const o=E(e.getAttribute("id"));(n=o==null?void 0:o.emit)==null||n.call(o,"open",t)},ce=async e=>{var n;const t=e.getAttribute("id"),a=e.dataset.viewPageActive;if(a){const l={vpn:p.state.viewPageN,["view-"+t]:null};l["view-"+t]=null,(p.state.viewPageN===0||p.state.viewPageN===1)&&(l.vpn=null),v.setHashs(l,!1)}s.querySelectorAllArray(document,".ui-dialog[open]").find(l=>s.isVisible(l))||(b.Core.state.documentClassModificators.delete("top-dialog"),document.querySelector("html").style.marginRight="");const r=f(e);$(e).trigger("viewAfterClose",[r]);const o=E(t);o&&(o.isOpened.value=!1,(n=o.emit)==null||n.call(o,"close",a),o.onCloseOnce&&(o.onCloseOnce(o.props,a),o.onCloseOnce=void 0)),window.dispatchEvent(new Event("resize"))},F=()=>{s.querySelectorAllArray(document,".ui-dialog").filter(t=>s.isVisible(t)).forEach(t=>{const a=t.querySelector(".modal-body");!a||s.isVisible(a)||(C(t),t.classList.remove("me-tightly"),(t.clientHeight??0)>window.innerHeight&&t.classList.add("me-tightly"))})},M=e=>`${e}Wrapper`,f=e=>e.closest(".ui-dialog"),R=e=>e.querySelector(".ui-dialog-content"),pe=()=>{let e=document.body.querySelector(".ui-dialog-overlay");return e||(e=document.createElement("div"),e.classList.add("ui-dialog-overlay"),document.body.appendChild(e)),e},B=(e,t)=>{const a=pe(),i=document.createElement("dialog");return i.setAttribute("id",M(e)),i.setAttribute("page-active",t),i.setAttribute("class","dialog ui-dialog"),a.insertAdjacentElement("beforebegin",i),i},ge=async(e,t)=>{const i=/(\w+)[=-]([\w-]+)(?::([\w.:-]+))?/g.exec(e);if(i){const r=i[1],o=i[2],n=i[3];let l=[];n&&(l=n.split(":")),await H(r,o,l,t)}},H=async(e,t,a,i,r)=>{let o=null,n=null;if(typeof e=="object"?(_(e)&&(e=e==null?void 0:e[0]),o=e,n=f(o)):(o=document.getElementById(e),o&&(n=document.getElementById(M(e)))),!o&&typeof e=="string"&&p.state.load){await p.state.load(e),await H(e,t,a,i,r);return}o&&(!n&&o.dataset.vueDiaolg!=="true"&&(o.classList.add("top-dialog","ui-dialog-content"),n=B(o.getAttribute("id"),o.dataset.viewPageActive),n.append(o)),n&&(await T(o,t,a,i),n.__isInit||(n.__isInit=!0,de(o),ne(n),n.onclose=()=>ce(o)),C(n),await se(o),r&&r(n)))},T=async(e,t,a,i)=>{var u,y;_(e)&&(e=e==null?void 0:e[0]),t===void 0&&(t=e.dataset.viewPageActive),t!==e.dataset.viewPageActive&&Q(e)&&await q.sleep(100),a===void 0&&(a=[]),await k(e.getAttribute("id"),void 0,t);const r=s.querySelectorAllArray(e,".modal-layer"),o=r.reduce((d,m)=>{const h=m.querySelector(":scope > .active");return h&&d.push(h),d},[]),n=r.reduce((d,m)=>{const h=m.querySelector(`:scope > [data-view-page="${t}"]`);return h&&d.push(h),d},[]),l=a.join(":");if(i===void 0&&(i="next",(((u=n[0])==null?void 0:u.dataset.order)??0)<(((y=o[0])==null?void 0:y.dataset.order)??0)&&(i="prev")),!n.length)return;const g=f(e);if(e.dataset.viewPageActive=t,g.setAttribute("page-active",t),n[0].classList.contains("active")){n[0].dataset.viewPageArgs!==l&&n.forEach(d=>{d.dataset.viewPageArgs=l}),K(e,n,t,a),U(e,n,t,a);return}switch(n.forEach(d=>{d.dataset.viewPageArgs=l}),o.forEach(d=>{d.querySelector(".top-popup-wrapper")&&N.TopPopupWorker.close(d.querySelector(".top-popup-wrapper"))}),g&&!s.isVisible(g)&&(i="none"),o.length||(i="none"),s.isVisible(n[0])&&(i="none"),i){case"prev":{n.forEach(d=>{var h,w;const m=(h=d.parentNode)==null?void 0:h.querySelector(":scope > .active");m&&((w=d.parentNode)==null||w.insertBefore(d,m))}),o.forEach(d=>{d.classList.add("right-to-center","reverse")}),n.forEach(d=>{d.classList.add("center-to-left","reverse")});break}case"next":{n.forEach(d=>{var h,w;const m=(h=d.parentNode)==null?void 0:h.querySelector(":scope > .active");m&&((w=d.parentNode)==null||w.insertBefore(d,m.nextSibling))}),o.forEach(d=>{d==null||d.classList.add("center-to-left")}),n.forEach(d=>{d.classList.add("right-to-center")});break}}if(e.setAttribute("view-page-active",t),o.forEach(d=>{d.classList.remove("active")}),n.forEach(d=>{d.classList.add("active")}),K(e,n,t,a),i){e.classList.add("i-change-page");const d=Number(window.getComputedStyle(n[0]).animationDuration.replace("s",""))*1e3;O=setTimeout(()=>{_(e)&&(e=e==null?void 0:e[0]),k(e.getAttribute("id"),t,""),Q(e),U(e,n,t,a)},d)}else await k(e.getAttribute("id"),t,""),U(e,n,t,a)},he=e=>{var o;const r=(o=s.querySelectorAllArray(e,".modal-layer").reduce((n,l)=>{const g=l.querySelector(":scope > .active");return g&&n.push(g),n},[]).reduce((n,l)=>{let g=l.previousElementSibling;for(;g&&!g.hasAttribute("[data-view-page]");)g=g.previousElementSibling;return g&&n.push(g),n},[])[0])==null?void 0:o.dataset.viewPage;r?T(e,r,void 0,"prev"):f(e).close()},W=new Set,K=(e,t,a,i)=>{const r=e.getAttribute("id")+t[0].dataset.viewPage+a+i.join();W.has(r)||(W.add(r),setTimeout(()=>{W.delete(r);const o=f(e);$(e).trigger("viewBeforeOpen",[o,$(t),a,i])}))},U=(e,t,a,i)=>{const r=f(e);setTimeout(()=>{$(e).trigger("viewAfterOpen",[r,$(t),a,i])})},J=e=>(_(e)&&(e=e==null?void 0:e[0]),e.classList.contains("i-change-page")),Q=e=>{if(!J(e))return!1;clearTimeout(O);const t=s.querySelectorAllArray(e,".modal-layer"),a=e.dataset.viewPageActive;return e.classList.remove("i-change-page"),t.forEach(i=>{i.querySelectorAll(":scope > [data-view-page]").forEach(r=>{r.classList.remove("center-to-left","right-to-center","reverse","active")})}),t.forEach(i=>{var r;(r=i.querySelector(`:scope > [data-view-page="${a}"]`))==null||r.classList.add("active")}),!0},P={getElDialogById:z,updatePageVue:k,recalcPositions:F,toViewDirty:ge,toView:H,toViewPage:T,toPrevPage:he,setLoading:(e,t,a)=>{_(e)&&(e=e.toArray());const i=e.reduce((r,o)=>(o.hasAttribute("[data-view-page]")&&s.isVisible(o)&&r.push(o),r),[]);t?(a!==void 0&&i.forEach(r=>{r.style.setProperty("--dialog-loading-duration",a+"s")}),i.forEach(r=>{r.classList.add("i-load-data")})):(i.forEach(r=>{r.classList.remove("i-load-data")}),i.forEach(r=>{r.style.setProperty("--dialog-loading-duration","10s")}))},isLoading:e=>(_(e)&&(e=e==null?void 0:e[0]),e.classList.contains("i-load-data")),inAnimation:J,close:e=>{const t=z(e);if(!t)return;f(t).close()}};D();const ue=Object.freeze(Object.defineProperty({__proto__:null,TopDialogUtils:P,createAndMountElDialogWrapper:B,getDialogWrapperId:M,getElDialog:R,getElDialogWrapper:f},Symbol.toStringTag,{value:"Module"}));class fe{id;idAttr;Component;isMounted=c.ref(!1);isReady=c.ref(!1);isOpened=c.ref(!1);pageActive=c.ref("");isLoadingPage=c.ref(!1);pageActiveNext=c.ref("");props;emit;onCloseOnce;constructor(t){this.id=t.id,this.idAttr="dialog_"+t.id,this.Component=c.markRaw(t)}onMounted(t,a){this.isMounted.value=!0,this.props=t.props,this.emit=a.emit}async open(t="main",a,i=[],r,o){a&&await this.setProps(a),r&&(this.onCloseOnce=r),await(await p.getDialogsUtils()).toView(this.idAttr,t,i,o)}async openAsLink(t="main",a,i=[],r,o){a&&await this.setProps(a),r&&(this.onCloseOnce=r);const n=this.idAttr+"-"+t,l=p.genViewPageHash(n,o);v.historySetState(!1,l)}async close(){p.close(this.idAttr)}async destroy(){p.destroy(this.idAttr)}async setProps(t={}){this.isMounted||await q.waitWhile(()=>!this.props);for(const a in this.props)this.props[a]=t[a]}needShowPage(t){return this.isOpened.value?this.pageActive.value===t||this.pageActiveNext.value===t:!1}}const me={class:"top-dialogs",style:{display:"none"}},x=c.shallowReactive(new Map),E=e=>(e=e.replace(/^dialog_/,""),x.get(e)),ve=e=>{if(!(e!=null&&e.id))throw console.log({TopDialogComponent:e}),new Error("Expected TopDialogComponent");return x.has(e.id)||x.set(e.id,new fe(e)),x.get(e.id)},ye=c.defineComponent({name:"DialogWrapper",__name:"dialogs",setup(e){return c.onUnmounted(()=>{x.forEach(t=>t.destroy()),x.clear()}),(t,a)=>(c.openBlock(),c.createElementBlock("div",me,[(c.openBlock(!0),c.createElementBlock(c.Fragment,null,c.renderList(c.unref(x),([i,r])=>(c.openBlock(),c.createBlock(c.resolveDynamicComponent(r.Component),{key:i}))),128))]))}});A.TopDialogWorker=p,A._sfc_main=ye,A.addDialogWorker=ve,A.createAndMountElDialogWrapper=B,A.getDialogWorker=E}));
|
|
2
|
-
//# sourceMappingURL=dialogs.vue_vue_type_script_setup_true_lang-C7vi1i47.amd.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"dialogs.vue_vue_type_script_setup_true_lang-C7vi1i47.amd.js","sources":["../../src/components/dialog/lib/worker.ts","../../src/components/dialog/lib/utils.globalEvents.ts","../../src/components/dialog/lib/utils.ts","../../src/components/dialog/dialog/composables/dialogHandle.ts","../../src/components/dialog/dialog/dialogs/dialogs.vue"],"sourcesContent":["import { genHash, getHash, historySetState } from '@/core/utils/route';\nimport type { ElTopDialog, ElTopDialogOpener, ElTopDialogPage, MoveDirection, TopDialogOptions } from './types';\nimport { isVisible, querySelectorAllArray } from '@/core/utils/dom';\nimport type { $el } from '@/components/types';\nimport { getElDialogWrapper } from '@/components/dialog/lib/utils';\n\nexport abstract class TopDialogWorker {\n\tstatic state = {\n\t\tload: undefined as TopDialogOptions['load'] | undefined,\n\t\tdecoratorOnCreate: undefined as TopDialogOptions['decoratorOnCreate'] | undefined,\n\n\t\t/**\n\t\t * Порядковый номер перехода в диалоговых окнах\n\t\t *\n\t\t * Для расчета анимации Вперед / Назад\n\t\t */\n\t\tviewPageN: 0,\n\t};\n\n\tprivate static inited = false;\n\n\t/**\n\t * Инициировать события слежения за парамтерами url\n\t *\n\t * Если в параметрах есть запрос на открытие диалогового окна, TopDialog будет автоматически подключен на страницу\n\t */\n\tstatic init(options?: TopDialogOptions) {\n\t\tif (this.inited) return;\n\t\tthis.inited = true;\n\n\t\tthis.state.load = options?.load;\n\t\tthis.state.decoratorOnCreate = options?.decoratorOnCreate;\n\n\t\tconst autoInitDelay = options?.autoInitDelay ?? 5000;\n\n\t\twindow.addEventListener('hashchange', (e) => {\n\t\t\tthis.opendDialogsFromChangeUrl(e.oldURL, e.newURL);\n\t\t});\n\n\t\tthis.opendDialogsFromChangeUrl('', location.href);\n\n\t\t/**\n\t\t * Сгенерировать ссылку для перехода к странице диалогового окна\n\t\t */\n\t\tdocument.addEventListener('mousedown', async (e) => {\n\t\t\tconst elEventTarget = e.target as HTMLElement;\n\n\t\t\tconst el = elEventTarget.closest<ElTopDialogOpener<HTMLAnchorElement>>('a[data-to-view]');\n\t\t\tif (!el) return;\n\n\t\t\t// const toView = el.dataset.toView;\n\t\t\t// const viewName = toView.split('-')[0];\n\t\t\t// const $toDialog = $('#' + viewName);\n\t\t\t// const $modalLayers = $('> .modal-layer', $toDialog);\n\t\t\t// const $currentPage = $('> .active', $modalLayers);\n\n\t\t\tlet moveDirection: MoveDirection = 'next';\n\n\t\t\t// /**\n\t\t\t// * Данный алгоритм определения направления работает не корректно, так как для чтения свойства order менят состояние через getDialogsUtils()\n\t\t\t// */\n\t\t\t// if ($currentPage.length) {\n\t\t\t// \tconst pageName = toView.split('-')[1].split(':')[0];\n\t\t\t//\n\t\t\t// \tconst TopDialogUtils = await this.getDialogsUtils();\n\t\t\t//\n\t\t\t// \tawait TopDialogUtils.updatePageVue(viewName, undefined, pageName);\n\t\t\t//\n\t\t\t// \tconst $nextPage = $('> [data-view-page=\"' + pageName + '\"]', $modalLayers);\n\t\t\t// \tif ($nextPage.data('order') < $currentPage.data('order')) moveDirection = 'prev';\n\t\t\t// }\n\n\t\t\tif (el.dataset.action === 'top-dialog-close') moveDirection = 'prev';\n\n\t\t\tel.href = TopDialogWorker.genViewPageHash(el.dataset.toView, moveDirection);\n\t\t});\n\n\t\t/**\n\t\t * Осуществить переход по ссылке с учетом historyType\n\t\t */\n\t\tdocument.addEventListener('click', async (e) => {\n\t\t\tconst elEventTarget = e.target as HTMLElement;\n\n\t\t\tconst el = elEventTarget.closest<ElTopDialogOpener>('[data-to-view]');\n\t\t\tif (!el) return;\n\n\t\t\t// Подождать генерацию ссылки\n\t\t\tif (el instanceof HTMLAnchorElement && el.href === '.') {\n\t\t\t\te.preventDefault();\n\n\t\t\t\tconst mouseEvent = new MouseEvent('mousedown', {\n\t\t\t\t\tbubbles: true,\n\t\t\t\t\tcancelable: true,\n\t\t\t\t\tview: window,\n\t\t\t\t});\n\n\t\t\t\tel.dispatchEvent(mouseEvent);\n\n\t\t\t\tsetTimeout(() => el.click());\n\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst TopDialogUtils = await this.getDialogsUtils();\n\n\t\t\tconst toView = el.dataset.toView;\n\t\t\tconst viewName = toView.split('-')[0];\n\n\t\t\tconst elDialog = TopDialogUtils.getElDialogById(viewName);\n\n\t\t\tlet moveDirection: MoveDirection = 'next';\n\n\t\t\tif (elDialog) {\n\t\t\t\tconst elModalLayers = querySelectorAllArray(elDialog, '.modal-layer');\n\t\t\t\tconst elCurrentPages = elModalLayers.reduce<ElTopDialogPage[]>((acc, el) => {\n\t\t\t\t\tconst elCurrentPage = el.querySelector<ElTopDialogPage>(':scope > .active');\n\n\t\t\t\t\tif (elCurrentPage) acc.push(elCurrentPage);\n\n\t\t\t\t\treturn acc;\n\t\t\t\t}, []);\n\n\t\t\t\tif (elCurrentPages.length) {\n\t\t\t\t\tconst pageName = toView.split('-')[1].split(':')[0];\n\t\t\t\t\tconst elNextPages = elModalLayers.reduce<ElTopDialogPage[]>((acc, el) => {\n\t\t\t\t\t\tconst elNextPage = el?.querySelector<ElTopDialogPage>(`:scope > [data-view-page=\"${pageName}\"]`);\n\n\t\t\t\t\t\tif (elNextPage) acc.push(elNextPage);\n\n\t\t\t\t\t\treturn acc;\n\t\t\t\t\t}, []);\n\n\t\t\t\t\tif ((elNextPages[0]?.dataset.order ?? 0) < (elCurrentPages[0]?.dataset.order ?? 0)) moveDirection = 'prev';\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (el.dataset.action === 'top-dialog-close') moveDirection = 'prev';\n\n\t\t\tconst hash = TopDialogWorker.genViewPageHash(toView, moveDirection);\n\n\t\t\tif (el instanceof HTMLAnchorElement) {\n\t\t\t\t// диалоговое окно еще не открыто, произвести переход по ссылке\n\t\t\t\tif (!elDialog || !isVisible(elDialog)) return;\n\n\t\t\t\t// в адресе уже указана эта страница, необходимо явно запросить ее открытие\n\t\t\t\tif (location.hash.indexOf(toView.replace('-', '=')) !== -1) {\n\t\t\t\t\tawait TopDialogUtils.toViewDirty(toView);\n\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tconst replaceHistory = !!elDialog?.dataset.toViewReplace;\n\n\t\t\tif (replaceHistory) {\n\t\t\t\te.preventDefault();\n\n\t\t\t\thistorySetState(true, hash);\n\n\t\t\t\tawait TopDialogUtils.toViewDirty(toView);\n\n\t\t\t\tif (moveDirection == 'next') {\n\t\t\t\t\tTopDialogWorker.state.viewPageN++;\n\t\t\t\t} else {\n\t\t\t\t\tTopDialogWorker.state.viewPageN--;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif (el.tagName !== 'A') {\n\t\t\t\t\tif (this.compareStates(hash, location.hash)) {\n\t\t\t\t\t\thistorySetState(false, hash);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tawait TopDialogUtils.toViewDirty(toView);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\tsetTimeout(() => this.getDialogsUtils(), autoInitDelay);\n\t}\n\n\tprivate static opendDialogsFromChangeUrl(oldUrl: string, newUrl: string) {\n\t\tconst oldHash = oldUrl.replace(/.*?#/, '#');\n\t\tconst newHash = newUrl.replace(/.*?#/, '#');\n\n\t\tconst dialogsStateChanged = this.compareStates(oldHash, newHash);\n\t\tif (dialogsStateChanged) void this.opendDialogsFromUrl();\n\t}\n\n\tstatic async getDialogsUtils() {\n\t\tconst { TopDialogUtils } = await import('./utils');\n\n\t\treturn TopDialogUtils;\n\t}\n\n\tstatic getDialog(el: HTMLElement) {\n\t\treturn el.closest<ElTopDialog>('.ui-dialog-content');\n\t};\n\n\t/**\n\t * todo: Переписать на сайте на this.getDialog()\n\t *\n\t * @deprecated Для обратной совместимости\n\t */\n\tstatic get$dialog($el: $el) {\n\t\treturn $el.closest('.ui-dialog-content');\n\t};\n\n\tstatic getPage(el: HTMLElement) {\n\t\treturn el.closest<ElTopDialogPage>('[data-view-page]');\n\t};\n\n\t/**\n\t * todo: Переписать на сайте на this.getPage()\n\t *\n\t * @deprecated Для обратной совместимости\n\t */\n\tstatic get$page($el: $el) {\n\t\treturn $el.closest('[data-view-page]');\n\t};\n\n\tstatic getPairPage(el: HTMLElement) {\n\t\tconst elDialog = TopDialogWorker.getDialog(el);\n\t\tif (!elDialog) return;\n\n\t\tconst elPage = TopDialogWorker.getPage(el);\n\t\tconst pageName = elPage?.dataset.viewPage;\n\n\t\treturn querySelectorAllArray<ElTopDialogPage>(elDialog, `[data-view-page=\"${pageName}\"]`);\n\t};\n\n\t/**\n\t * todo: Переписать на сайте на this.getPairPage()\n\t *\n\t * @deprecated Для обратной совместимости\n\t */\n\tstatic get$pairPage($el: $el) {\n\t\tconst $dialog = TopDialogWorker.get$dialog($el);\n\n\t\tconst $page = TopDialogWorker.get$page($el);\n\t\tconst pageName = $page.data('view-page');\n\n\t\treturn $('[data-view-page=\"' + pageName + '\"]', $dialog);\n\t};\n\n\t/**\n\t * Закрыть диалоговое окно по его id\n\t * @param id - id элемента ElTopDialog\n\t * @see ElTopDialog\n\t */\n\tstatic close(id: string) {\n\t\tconst elDialog = <ElTopDialog | null>document.getElementById(id);\n\t\tif (!elDialog) return;\n\n\t\tconst elDialogWrapper = getElDialogWrapper(elDialog);\n\n\t\telDialogWrapper.close();\n\t};\n\n\t/**\n\t * Размонтировать диалоговое окно по его id\n\t * @param id - id элемента ElTopDialog\n\t * @see ElTopDialog\n\t */\n\tstatic destroy(id: string) {\n\t\tconst elDialog = <ElTopDialog | null>document.getElementById(id);\n\t\tif (!elDialog) return;\n\n\t\tconst elDialogWrapper = getElDialogWrapper(elDialog);\n\n\t\telDialogWrapper.close();\n\t\telDialogWrapper.remove();\n\t};\n\n\t/**\n\t * Сгенерировать ссылку на страницу в диалоговом окне\n\t * @param toView - указатель в формате: dialog_{{ dialogId }}={{ pageName }}:{{ args }}\n\t * @param moveDirection\n\t */\n\tstatic genViewPageHash(toView: string, moveDirection: MoveDirection = 'next') {\n\t\tlet toViewPageN = this.state.viewPageN;\n\t\tif (moveDirection == 'prev') {\n\t\t\ttoViewPageN--;\n\t\t} else {\n\t\t\ttoViewPageN++;\n\t\t}\n\n\t\tconst viewNameAndPageLink = toView.split('-');\n\t\tconst viewName = viewNameAndPageLink.shift();\n\t\tconst pageLink = viewNameAndPageLink.join('-');\n\n\t\tlet hash = genHash('vpn', toViewPageN);\n\t\thash = genHash('view-' + viewName, pageLink, hash);\n\n\t\treturn hash;\n\t};\n\n\t/**\n\t * Сравнить версию открытых диалоговых окон\n\t * @returns вернет true, если состояния открытых окон изменилось\n\t */\n\tstatic compareStates(hash: string, hash2: string) {\n\t\tconst mathes = hash.match(/[#&]view-[^&]+/g) || [];\n\t\tconst mathes2 = hash2.match(/[#&]view-[^&]+/g) || [];\n\n\t\tif (mathes.length !== mathes2.length) return true;\n\n\t\tconst mathesChanged = mathes.filter((math, n) => {\n\t\t\tconst math2 = mathes2[n] || '';\n\n\t\t\treturn math !== math2;\n\t\t});\n\n\t\tif (mathesChanged.length) return true;\n\n\t\treturn false;\n\t};\n\n\tstatic opendDialogsFromUrl = async () => {\n\t\tconst toViewPageN = Number(getHash('vpn')) || 0;\n\n\t\t// Открыть диалоговое окно\n\t\tlet view: RegExpExecArray | null;\n\t\t// const regexp = new RegExp('view-((\\\\w+)=([\\\\w-]+)(?::([\\\\w.:-]+))?)' + '(' + Math.random() + ')?', 'g'); // fix babel minify regexp\n\t\tconst regexp = new RegExp('view-((\\\\w+)=([\\\\w-]+)(?::([\\\\w.:-]+))?)', 'g');\n\n\t\t// TODO: Цикл делает только одну оперцию и выходит (возможно, оставлен специально с какой-то целью, если нет - заменить на if)\n\t\twhile (view = regexp.exec(location.hash)) {\n\t\t\tlet moveDirection: MoveDirection = 'next';\n\t\t\tif (toViewPageN < this.state.viewPageN) moveDirection = 'prev';\n\n\t\t\tconst TopDialogUtils = await this.getDialogsUtils();\n\n\t\t\treturn TopDialogUtils.toViewDirty(view[1], moveDirection);\n\t\t}\n\n\t\t// Закрыть ненужные view\n\t\tconst elDialogs = querySelectorAllArray<ElTopDialog>(document, '.ui-dialog-content[data-view-page-active]');\n\t\telDialogs.filter((elDialog) => {\n\t\t\treturn isVisible(elDialog);\n\t\t}).forEach((elDialog) => {\n\t\t\tconst viewName = elDialog.getAttribute('id');\n\t\t\tif (!viewName) throw 'Диалоговое окно не содержит id';\n\t\t\tconst pageName = getHash('view-' + viewName);\n\t\t\tif (!pageName) {\n\t\t\t\tconst elDialogWrapper = getElDialogWrapper(elDialog);\n\n\t\t\t\telDialogWrapper.close();\n\t\t\t}\n\t\t});\n\n\t\tthis.state.viewPageN = toViewPageN;\n\n\t\treturn true;\n\t};\n}\n","import { getElDialogWrapper, TopDialogUtils } from './utils';\nimport { TopDialogWorker } from './worker';\nimport { isVisible, querySelectorAllArray } from '@/core/utils/dom';\nimport { historySetState } from '@/core/utils/route';\nimport type { ElTopDialog, ElTopDialogWrapper } from '@/components/dialog/lib/types';\n\nlet inited = false;\n\n/**\n * Инициализация глобальных событий для диалоговых окон\n *\n * Производится один раз при подключении диалогового окна\n *\n * События не размонтируются\n */\nexport const initDialogGlobalEvents = () => {\n\tif (inited) return;\n\tinited = true;\n\n\t/**\n\t * Закрытие диалога по кнопке закрыть\n\t */\n\tdocument.addEventListener('click', (e) => {\n\t\t// // навигация без истории\n\t\t// var $dialog = $(this).closest('.ui-dialog-content');\n\t\t// var viewName = $dialog.attr('id');\n\t\t// var pageName = getHash('view-' + viewName);\n\t\t// if (!pageName) {\n\t\t// \ttoPrevPage($dialog);\n\t\t//\n\t\t// \treturn;\n\t\t// }\n\t\t//\n\t\t// // навигация по истории\n\t\t// if (Core.state.isMobile && history.length > 1 && $(this).closest('.modal-layer').length) {\n\t\t// \tvar href = location.href;\n\t\t//\n\t\t// \thistory.go(-1);\n\t\t//\n\t\t// \tsetTimeout(() => {\n\t\t// \t\t// это первая страница в истории вкладки браузера\n\t\t// \t\tif (href === location.href) $(e.target).closest('.ui-dialog-content').dialog('close');\n\t\t// \t});\n\t\t// } else {\n\t\t// \t$(this).closest('.ui-dialog-content').dialog('close');\n\t\t// }\n\n\t\tconst el = (e.target as HTMLElement).closest('[data-action=\"top-dialog-close\"]') as HTMLElement | null;\n\t\tif (!el) return;\n\n\t\te.preventDefault();\n\n\t\tconst elDialog = el.closest<ElTopDialog>('.ui-dialog-content');\n\t\tif (!elDialog) return;\n\n\t\t// если к кнопке привязана ссылка, диалоговое окно не нужно закрывать\n\t\tconst toView = el.dataset.toView;\n\n\t\tif (toView == 'toPrevPage()') {\n\t\t\tTopDialogUtils.toPrevPage(elDialog);\n\n\t\t\treturn;\n\t\t}\n\n\t\tif (toView) {\n\t\t\tconst viewNameAndPageLink = toView.split('-');\n\t\t\tconst viewName = viewNameAndPageLink.shift();\n\t\t\tconst pageLink = viewNameAndPageLink.join('-');\n\n\t\t\tif (!viewName) return;\n\n\t\t\tconst elDialog = TopDialogUtils.getElDialogById(viewName);\n\t\t\tif (!elDialog) return;\n\n\t\t\tconst elToPages = querySelectorAllArray(elDialog, `[data-view-page=\"${pageLink}\"]`);\n\t\t\tif (!elToPages) return;\n\n\t\t\tif (!isVisible(elToPages[0])) {\n\t\t\t\tconst hash = TopDialogWorker.genViewPageHash(toView, 'prev');\n\n\t\t\t\t// // не убирает кнопку \"Вперед\" в браузере\n\t\t\t\t// history.replaceState(null, '', hash);\n\t\t\t\t// toViewDirty(toView, 'prev');\n\n\t\t\t\t// // добавляет текущую страницу в историю браузера\n\t\t\t\thistorySetState(false, hash);\n\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\n\t\tconst elDialogWrapper = getElDialogWrapper(elDialog);\n\n\t\telDialogWrapper.close();\n\t});\n\n\t/**\n\t * Все submit должны обрабатываться через js\n\t */\n\tdocument.addEventListener('submit', (e) => {\n\t\tconst elForm = e.target as HTMLElement;\n\n\t\tif (elForm.matches('.modal-body > form') || elForm.matches('.modal-layer-body > form')) {\n\t\t\te.preventDefault();\n\t\t}\n\t});\n\n\t/**\n\t * Выполнение действия по нажатию Enter\n\t *\n\t * @todo Убрать `.searcher`\n\t */\n\tdocument.addEventListener('keypress', (e) => {\n\t\tconst eventTarget = e.target as HTMLElement;\n\n\t\tconst elModalBody = eventTarget.closest('.ui-dialog .modal-body');\n\t\tif (!elModalBody) return;\n\n\t\tconst isInput =\n\t\t\teventTarget.matches('input:not(.searcher), textarea:not(.searcher), select:not(.searcher), button:not(.searcher)')\n\t\t\t|| eventTarget.hasAttribute('contenteditable');\n\t\tif (!isInput) return;\n\n\t\t// if (e.keyCode !== 10 && e.key !== 'ENTER') return;\n\t\tif (e.key !== 'Enter') return;\n\n\t\t// не выполнять submit действий при работе с jquery autocomplete\n\t\tif (eventTarget.classList.contains('autocomplete')) {\n\t\t\te.preventDefault();\n\n\t\t\treturn;\n\t\t}\n\n\t\tif (eventTarget.tagName === 'TEXTAREA') {\n\t\t\tif (!e.ctrlKey && !e.metaKey) return;\n\n\t\t\tconst elForm = eventTarget.closest('form');\n\n\t\t\tif (elForm) {\n\t\t\t\t// Find visible submit buttons\n\t\t\t\tconst elSubmitButton = querySelectorAllArray(elForm, 'button[type=\"submit\"]')\n\t\t\t\t\t.concat(querySelectorAllArray(elForm, 'input[type=\"submit\"]'))\n\t\t\t\t\t.find((elSubmitButton) => {\n\t\t\t\t\t\treturn isVisible(elSubmitButton);\n\t\t\t\t\t});\n\n\t\t\t\telSubmitButton?.click();\n\t\t\t}\n\t\t}\n\t});\n\n\t/**\n\t * Закрытие диалога по клику вне окна\n\t */\n\tdocument.addEventListener('click', (event) => {\n\t\tconst eventTarget = event.target as HTMLElement;\n\n\t\tif (!eventTarget.classList.contains('ui-dialog-overlay')) return;\n\n\t\tlet elDialogWrapperWithTopZIndex: ElTopDialogWrapper | undefined;\n\t\tlet topZIndex = 0;\n\n\t\tconst elDialogWrapperVisibles = querySelectorAllArray<ElTopDialogWrapper>(document, '.ui-dialog').filter((elDialogWrapper) => {\n\t\t\treturn isVisible(elDialogWrapper) && elDialogWrapper.getAttribute('aria-modal') === 'false';\n\t\t});\n\n\t\telDialogWrapperVisibles.forEach((elDialogWrapper) => {\n\t\t\tconst zIndex = Number(window.getComputedStyle(elDialogWrapper).zIndex);\n\t\t\tif (zIndex < topZIndex) return;\n\n\t\t\telDialogWrapperWithTopZIndex = elDialogWrapper;\n\t\t\ttopZIndex = zIndex;\n\t\t});\n\n\t\tif (elDialogWrapperWithTopZIndex) {\n\t\t\telDialogWrapperWithTopZIndex.close();\n\t\t}\n\t});\n\n\twindow.addEventListener('resize', TopDialogUtils.recalcPositions);\n\n\tTopDialogUtils.recalcPositions();\n};\n","import 'jquery';\nimport { nextTick } from 'vue';\n\nimport Core from '@/core/core/core';\nimport { TopPopupWorker } from '@/components/popup/worker';\nimport { sleep, waitWhile } from '@/core/utils/system';\nimport { setHashs } from '@/core/utils/route';\nimport { connectScrollShadow } from '@/core/utils/scroll';\n\nimport type {\n\tElTopDialogBody,\n\tElTopDialog,\n\tElTopDialogModalLayer,\n\tElTopDialogPage,\n\tMoveDirection,\n\tElTopDialogWrapper,\n\tElDialogOverlay,\n} from './types';\nimport { TopDialogWorker } from './worker';\nimport { initDialogGlobalEvents } from './utils.globalEvents';\nimport { getDialogWorker } from '../dialog/dialogs/dialogs.vue';\n\nimport css from '../dialog/style/dialog.css?inline';\nimport cssM from '../dialog/style/dialog.m.css?inline';\nimport cssPC from '../dialog/style/dialog.pc.css?inline';\nimport cssModern from '../dialog/style/modern/dialog.css?inline';\nimport cssModernPC from '../dialog/style/modern/dialog.pc.css?inline';\nimport { isVisible, querySelectorAllArray } from '@/core/utils/dom';\n\nCore.insertStyleToPage(css);\nCore.insertStyleToPage(cssM, 'm');\nCore.insertStyleToPage(cssPC, 'pc');\nCore.insertStyleToPage(cssModern);\nCore.insertStyleToPage(cssModernPC, 'pc');\n\nlet timerClearAnimation: NodeJS.Timeout;\n\n/**\n * Является ли элемент JQuery<HTMLElement>\n * @todo Удалить после переписки jquery на сайте\n */\nconst isElJQuery = (el: JQuery<HTMLElement> | HTMLElement | HTMLElement[]) => {\n\treturn !!el && typeof el === 'object' && 'jquery' in el;\n};\n\nconst openElDialog = (elDialogWrapper: ElTopDialogWrapper) => {\n\tconst elDialog = getElDialog(elDialogWrapper);\n\n\tconst options = genVueOptions(elDialog);\n\n\telDialogWrapper.setAttribute('closedby', options.closedby!);\n\n\tif (options.modal) {\n\t\telDialogWrapper.setAttribute('aria-modal', 'true');\n\t\telDialogWrapper.showModal();\n\t} else {\n\t\telDialogWrapper.setAttribute('aria-modal', 'false');\n\t\telDialogWrapper.show();\n\t}\n};\n\n/**\n * Получить настройки диалогового окна из Vue компонента\n */\nconst genVueOptions = (elDialog: ElTopDialog) => {\n\tconst options: {\n\t\tmodal: boolean,\n\t\tclosedby: 'any' | 'closerequest' | 'none',\n\t\tposition?: undefined,\n\t} = {\n\t\tmodal: false,\n\t\tclosedby: 'closerequest',\n\t};\n\n\t// Установить диалоговое окно в режим модального (при использовании нативного элемента \"dialog\" в модльном режиме браузеры помещают его в \"#top-layer\", что делает невозможным расположение других всплывающих элементов поверх него)\n\t// if (elDialog.dataset.modal === 'true') options.modal = true;\n\n\tconst elDialogClosedby = elDialog.dataset.closedby;\n\n\t// Значение \"any\" не используется, так как нативный элемент \"dialog\" будет закрываться при клике даже на элементы, расположенные поверх него\n\tif (elDialogClosedby === 'closerequest' || elDialogClosedby === 'none') options.closedby = elDialogClosedby;\n\n\treturn options;\n};\n\nconst getElDialogById = (id: string) => {\n\treturn <ElTopDialog | null>document.getElementById(id);\n};\n\n/**\n * Добавить методы jquery-диалога для обратной совместимости\n * @todo Удалить после прекрщения использовния jquery-диалога на сайте\n */\nconst addJQueryDialogMethods = (elDialogWrapper: ElTopDialogWrapper) => {\n\telDialogWrapper.dialog = (action) => {\n\t\tswitch (action) {\n\t\t\tcase 'open': {\n\t\t\t\topenElDialog(elDialogWrapper);\n\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tcase 'close': {\n\t\t\t\telDialogWrapper.close();\n\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tcase undefined: {\n\t\t\t\tconsole.warn('Вызвана бесполезная инициализация у нативного диалога');\n\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tdefault: {\n\t\t\t\tthrow new Error(`Передан неизвестный аргумент: \"${action}\"`);\n\t\t\t}\n\t\t}\n\n\t\treturn elDialogWrapper;\n\t};\n\n\telDialogWrapper.toggleClass = (classNames, state) => {\n\t\tconst elDialog = elDialogWrapper.querySelector('.ui-dialog-content');\n\n\t\tif (typeof classNames === 'string') {\n\t\t\tclassNames = classNames.split(' ');\n\t\t}\n\n\t\tif (Array.isArray(classNames)) {\n\t\t\tclassNames.forEach((className) => {\n\t\t\t\telDialog.classList.toggle(className, state);\n\t\t\t});\n\t\t} else {\n\t\t\tthrow new Error(`Передан необработанный тип аргумента: ${typeof classNames}`);\n\t\t}\n\n\t\treturn elDialogWrapper;\n\t};\n\n\telDialogWrapper.data = (...args) => {\n\t\tconst elDialog = elDialogWrapper.querySelector('.ui-dialog-content');\n\n\t\t$(elDialog).data(args);\n\n\t\treturn elDialogWrapper;\n\t};\n};\n\n/**\n * Сменить состояние диалогового окна Vue\n */\nconst updatePageVue = async (dialogId: string, pageName?: string, pageNameNext?: string) => {\n\tif (!dialogId.startsWith('dialog_')) return;\n\n\tconst dialog = getDialogWorker(dialogId);\n\tif (!dialog) return;\n\n\tdialog.isOpened.value = true;\n\tif (pageName !== undefined) dialog.pageActive.value = pageName;\n\tif (pageNameNext !== undefined) dialog.pageActiveNext.value = pageNameNext;\n\n\tawait nextTick();\n\n\tif (pageNameNext) {\n\t\tconst elDialog = getElDialogById(dialogId);\n\t\tif (!elDialog) return;\n\n\t\tconst elNextpages = elDialog.querySelectorAll(`[data-view-page=\"${pageNameNext}\"]`);\n\n\t\tif (!elNextpages.length) {\n\t\t\tawait waitWhile(() => !elDialog.querySelectorAll(`[data-view-page=\"${pageNameNext}\"]`).length);\n\t\t}\n\t}\n};\n\n/**\n * Событие create дилогового окна\n */\nconst onCreate = (elDialog: ElTopDialog) => {\n\tconst elDialogBody = elDialog.querySelector<ElTopDialogBody>('.modal-body');\n\tif (!elDialogBody) return;\n\n\tconnectScrollShadow(elDialogBody);\n\n\tTopDialogWorker.state.decoratorOnCreate?.(elDialog);\n\n\tinitPopup(elDialog);\n};\n\n/**\n * Инициирование событий TopPopup в диалоговом окне\n */\nconst initPopup = (elDialog: ElTopDialog) => {\n\t$(elDialog).on('aftershow.top-menu-popup', '[data-top-popup]', (_e, $popup) => {\n\t\t// перенести popup в корневой элемент страницы диалогового окна\n\t\tconst elPopup = $popup[0];\n\n\t\t// перенести popup в корневой элемент страницы диалогового окна\n\t\tconst elPageContents = TopDialogWorker.getPairPage(elPopup);\n\t\telPageContents?.[1]?.prepend(elPopup);\n\t});\n};\n\n/**\n * Событие open дилогового окна\n */\nconst onOpen = async (elDialog: ElTopDialog) => {\n\tconst pageName = elDialog.dataset.viewPageActive;\n\n\tconst w1 = window.innerWidth;\n\n\tCore.state.documentClassModificators.set('top-dialog', 'with_dialog');\n\n\tconst w2 = window.innerWidth;\n\n\tconst scrollBarWidth = w2 - w1;\n\tif (document.documentElement.scrollHeight > window.innerHeight) document.querySelector('html')!.style.marginRight = scrollBarWidth + 'px';\n\n\trecalcPositions();\n\n\tconst dialog = getDialogWorker(elDialog.getAttribute('id')!);\n\tdialog?.emit?.('open', pageName);\n};\n\n/**\n * Событие close дилогового окна\n */\nconst onClose = async (elDialog: ElTopDialog) => {\n\tconst viewName = elDialog.getAttribute('id');\n\tconst pageName = elDialog.dataset.viewPageActive;\n\n\tif (pageName) {\n\t\tconst hashData = {\n\t\t\tvpn: TopDialogWorker.state.viewPageN as number | null,\n\t\t\t['view-' + viewName]: null,\n\t\t};\n\t\thashData['view-' + viewName] = null;\n\n\t\tif (TopDialogWorker.state.viewPageN === 0 || TopDialogWorker.state.viewPageN === 1) {\n\t\t\thashData.vpn = null;\n\t\t}\n\n\t\tsetHashs(hashData, false);\n\t}\n\n\tconst elDialogOpened = querySelectorAllArray(document, '.ui-dialog[open]').find((el) => {\n\t\treturn isVisible(el);\n\t});\n\n\tif (!elDialogOpened) {\n\t\tCore.state.documentClassModificators.delete('top-dialog');\n\n\t\tdocument.querySelector('html')!.style.marginRight = '';\n\t}\n\n\tconst elDialogWrapper = getElDialogWrapper(elDialog);\n\n\t$(elDialog).trigger('viewAfterClose', [elDialogWrapper]);\n\n\tconst dialog = getDialogWorker(viewName);\n\n\tif (dialog) {\n\t\tdialog.isOpened.value = false;\n\t\tdialog.emit?.('close', pageName);\n\n\t\tif (dialog.onCloseOnce) {\n\t\t\tdialog.onCloseOnce(dialog.props, pageName);\n\t\t\tdialog.onCloseOnce = undefined;\n\t\t}\n\t}\n\n\t// после закрытия диалога может потребоваться пересчет позиций элементов\n\twindow.dispatchEvent(new Event('resize'));\n};\n\n/**\n * Пересчитать положения и размеры открытых диалоговых окон\n */\nconst recalcPositions = () => {\n\tconst elDialogWrapperVisibilityes = querySelectorAllArray<ElTopDialogWrapper>(document, '.ui-dialog').filter((el) => {\n\t\treturn isVisible(el);\n\t});\n\n\telDialogWrapperVisibilityes.forEach((elDialogWrapper) => {\n\t\tconst elDialogBody = elDialogWrapper.querySelector<ElTopDialogBody>('.modal-body');\n\t\tif (!elDialogBody || isVisible(elDialogBody)) return;\n\n\t\topenElDialog(elDialogWrapper);\n\n\t\telDialogWrapper.classList.remove('me-tightly');\n\t\tif ((elDialogWrapper.clientHeight ?? 0) > window.innerHeight) elDialogWrapper.classList.add('me-tightly');\n\t});\n};\n\n/**\n * Получить id внешнего элемента нативного модального окна\n * @param id - id элемента ElTopDialog\n * @see ElTopDialog\n */\nexport const getDialogWrapperId = (id: string) => {\n\treturn `${id}Wrapper`;\n};\n\n/**\n * Получить id внутреннего элемента нативного диалогового окна\n * @param id - id элемента ElTopDialogWrapper\n * @see ElTopDialogWrapper\n */\nexport const getDialogId = (id: string) => {\n\treturn id.replace(/Wrapper$/, '');\n};\n\n/**\n * Получить внешний элемент нативного диалогового окна\n * @param elDialog - элемент ElTopDialog\n * @see ElTopDialog\n */\nexport const getElDialogWrapper = (elDialog: ElTopDialog) => {\n\treturn elDialog.closest('.ui-dialog');\n};\n\n/**\n * Получить внутренний элемент нативного диалогового окна\n * @param elDialogWrapper - элемент ElTopDialogWrapper\n * @see ElTopDialogWrapper\n */\nexport const getElDialog = (elDialogWrapper: ElTopDialogWrapper) => {\n\treturn elDialogWrapper.querySelector('.ui-dialog-content');\n};\n\n/**\n * Создать и монтировать в body задний фон окна\n * @description Создаётся только один для всех диалоговых окон\n * @description Используется только в нативных диалоговых окнах в немодальном режиме вместо \"::backdrop\"\n */\nconst createAndMountElDialogOverlay = () => {\n\tlet elDialogOverlay = document.body.querySelector<ElDialogOverlay>('.ui-dialog-overlay');\n\n\tif (!elDialogOverlay) {\n\t\telDialogOverlay = document.createElement('div');\n\t\telDialogOverlay.classList.add('ui-dialog-overlay');\n\t\tdocument.body.appendChild(elDialogOverlay);\n\t}\n\n\treturn elDialogOverlay;\n};\n\n/**\n * Создать и монтировать в body нативную оболочку окна\n * @description Используется только для нативного диалогового окна\n * @param id - id элемента ElTopDialog\n * @param pageActive - активная страница\n * @see ElTopDialog\n */\nexport const createAndMountElDialogWrapper = (id: string, pageActive: string) => {\n\tconst elDialogOverlay = createAndMountElDialogOverlay();\n\n\tconst elDialogWrapper = document.createElement('dialog');\n\n\telDialogWrapper.setAttribute('id', getDialogWrapperId(id));\n\telDialogWrapper.setAttribute('page-active', pageActive);\n\t// Классы \"ui-<...>\" добавлены для обратной совместимости стилей диалоговых (преимущественно старых) окон\n\telDialogWrapper.setAttribute('class', 'dialog ui-dialog');\n\n\telDialogOverlay.insertAdjacentElement('beforebegin', elDialogWrapper);\n\n\treturn elDialogWrapper as ElTopDialogWrapper;\n};\n\n/**\n * Переход к view page по неразобранной ссылке в формате: {viewName}-{pageName}[:args]\n */\nconst toViewDirty = async (toViewPageName: string, moveDirection?: MoveDirection) => {\n\tconst regexp = /(\\w+)[=-]([\\w-]+)(?::([\\w.:-]+))?/g;\n\tconst toViewParts = regexp.exec(toViewPageName);\n\tif (toViewParts) {\n\t\tconst viewName = toViewParts[1];\n\t\tconst pageName = toViewParts[2];\n\t\tconst argsString = toViewParts[3];\n\n\t\tlet args: string[] = [];\n\t\tif (argsString) args = argsString.split(':');\n\n\t\tawait toView(viewName, pageName, args, moveDirection);\n\t}\n};\n\n/**\n * Открыть диалоговое окно, возможно указать нужную страницу\n * @param viewNameOrElDialog - id страницы окна или элемент окна\n * @param pageName - имя страницы\n * @param args - аргументы, набор проивзольных параметров, которые могут обрабатываться каждым окном по своему\n * @param moveDirection\n * @param callback - функция, которая будет запущена после октытия страницы\n */\nconst toView = async (\n\tviewNameOrElDialog: ElTopDialog | JQuery<ElTopDialog> | string,\n\tpageName?: string,\n\targs?: string[],\n\tmoveDirection?: MoveDirection,\n\tcallback?: Function,\n) => {\n\tlet elDialog: ElTopDialog | null = null;\n\tlet elDialogWrapper: ElTopDialogWrapper | null = null;\n\n\tif (typeof (viewNameOrElDialog) === 'object') {\n\t\tif (isElJQuery(viewNameOrElDialog)) viewNameOrElDialog = viewNameOrElDialog?.[0]; // TODO: Убрать после переписки jquery на сайте\n\n\t\telDialog = viewNameOrElDialog;\n\n\t\telDialogWrapper = getElDialogWrapper(elDialog) as ElTopDialogWrapper | null;\n\t} else {\n\t\telDialog = <ElTopDialog | null>document.getElementById(viewNameOrElDialog);\n\n\t\tif (elDialog) elDialogWrapper = <ElTopDialogWrapper | null>document.getElementById(getDialogWrapperId(viewNameOrElDialog));\n\t}\n\n\t// Диалоговое окно еще не загружено\n\tif (!elDialog && typeof viewNameOrElDialog === 'string' && TopDialogWorker.state.load) {\n\t\tawait TopDialogWorker.state.load(viewNameOrElDialog);\n\n\t\tawait toView(viewNameOrElDialog, pageName, args, moveDirection, callback);\n\n\t\treturn;\n\t}\n\n\tif (!elDialog) return;\n\n\t// Создать нативное модальное окно и поместить в него диалоговое окно (только для окон, созданных НЕ с помощью Vue)\n\tif (!elDialogWrapper && elDialog.dataset.vueDiaolg !== 'true') {\n\t\telDialog.classList.add('top-dialog', 'ui-dialog-content');\n\n\t\telDialogWrapper = createAndMountElDialogWrapper(elDialog.getAttribute('id'), elDialog.dataset.viewPageActive);\n\n\t\telDialogWrapper.append(elDialog);\n\t}\n\n\tif (!elDialogWrapper) return;\n\n\tawait toViewPage(elDialog, pageName, args, moveDirection);\n\n\tif (!elDialogWrapper.__isInit) {\n\t\telDialogWrapper.__isInit = true;\n\n\t\tonCreate(elDialog);\n\n\t\taddJQueryDialogMethods(elDialogWrapper);\n\n\t\telDialogWrapper.onclose = () => onClose(elDialog);\n\t}\n\n\topenElDialog(elDialogWrapper);\n\n\tawait onOpen(elDialog);\n\n\tif (callback) callback(elDialogWrapper);\n};\n\nconst toViewPage = async (elDialog: ElTopDialog | JQuery<ElTopDialog>, pageName?: string, args?: string[], moveDirection?: MoveDirection) => {\n\tif (isElJQuery(elDialog)) elDialog = elDialog?.[0]; // TODO: Убрать после переписки jquery на сайте\n\n\tif (pageName === undefined) pageName = elDialog.dataset.viewPageActive;\n\n\tif (pageName !== elDialog.dataset.viewPageActive) {\n\t\tconst stopped = stopAnimations(elDialog);\n\t\tif (stopped) await sleep(100);\n\t}\n\n\tif (args === undefined) args = [];\n\n\tawait updatePageVue(elDialog.getAttribute('id') as string, undefined, pageName);\n\n\tconst elModalLayers = querySelectorAllArray<ElTopDialogModalLayer>(elDialog, '.modal-layer');\n\tconst elCurrentPages = elModalLayers.reduce<ElTopDialogPage[]>((acc, elModalLayer) => {\n\t\tconst elCurrentPage = elModalLayer.querySelector<ElTopDialogPage>(':scope > .active');\n\t\tif (elCurrentPage) {\n\t\t\tacc.push(elCurrentPage);\n\t\t}\n\n\t\treturn acc;\n\t}, []);\n\n\tconst elNextPages = elModalLayers.reduce<ElTopDialogPage[]>((acc, elModalLayer) => {\n\t\tconst elNextPage = elModalLayer.querySelector<ElTopDialogPage>(`:scope > [data-view-page=\"${pageName}\"]`);\n\t\tif (elNextPage) {\n\t\t\tacc.push(elNextPage);\n\t\t}\n\n\t\treturn acc;\n\t}, []);\n\n\tconst argsString = args.join(':');\n\n\tif (moveDirection === undefined) {\n\t\tmoveDirection = 'next';\n\t\tif ((elNextPages[0]?.dataset.order ?? 0) < (elCurrentPages[0]?.dataset.order ?? 0)) moveDirection = 'prev';\n\t}\n\n\tif (!elNextPages.length) return;\n\n\tconst elDialogWrapper = getElDialogWrapper(elDialog);\n\n\telDialog.dataset.viewPageActive = pageName;\n\t// Элемент HTMLDialogElement должен иметь атрибут 'page-active'\n\telDialogWrapper.setAttribute('page-active', pageName);\n\n\t// запрашиваемая страница уже открыта\n\tif (elNextPages[0].classList.contains('active')) {\n\t\tif (elNextPages[0].dataset.viewPageArgs !== argsString) {\n\t\t\telNextPages.forEach((elNextPage) => {\n\t\t\t\telNextPage.dataset.viewPageArgs = argsString;\n\t\t\t});\n\n\t\t\t// dialogs.beforeOpenViewPage($dialog, $nextPage, pageName, args);\n\t\t\t// dialogs.afterOpenViewPage($dialog, $nextPage, pageName, args);\n\t\t}\n\n\t\tbeforeOpenViewPage(elDialog, elNextPages, pageName, args);\n\t\tafterOpenViewPage(elDialog, elNextPages, pageName, args);\n\n\t\treturn;\n\t}\n\n\telNextPages.forEach((elNextPage) => {\n\t\telNextPage.dataset.viewPageArgs = argsString;\n\t});\n\n\telCurrentPages.forEach((elCurrentPage) => {\n\t\tif (elCurrentPage.querySelector('.top-popup-wrapper')) {\n\t\t\tTopPopupWorker.close(elCurrentPage.querySelector('.top-popup-wrapper')!);\n\t\t}\n\t});\n\n\tif (elDialogWrapper && !isVisible(elDialogWrapper)) moveDirection = 'none';\n\tif (!elCurrentPages.length) moveDirection = 'none';\n\tif (isVisible(elNextPages[0])) moveDirection = 'none';\n\n\tswitch (moveDirection) {\n\t\tcase 'prev': {\n\t\t\telNextPages.forEach((elNextPage) => {\n\t\t\t\tconst elActive = elNextPage.parentNode?.querySelector(':scope > .active');\n\t\t\t\tif (elActive) elNextPage.parentNode?.insertBefore(elNextPage, elActive);\n\t\t\t});\n\n\t\t\telCurrentPages.forEach((elCurrentPage) => {\n\t\t\t\telCurrentPage.classList.add('right-to-center', 'reverse');\n\t\t\t});\n\n\t\t\telNextPages.forEach((elNextPage) => {\n\t\t\t\telNextPage.classList.add('center-to-left', 'reverse');\n\t\t\t});\n\n\t\t\tbreak;\n\t\t}\n\t\tcase 'next': {\n\t\t\telNextPages.forEach((elNextPage) => {\n\t\t\t\tconst elActive = elNextPage.parentNode?.querySelector(':scope > .active');\n\t\t\t\tif (elActive) elNextPage.parentNode?.insertBefore(elNextPage, elActive.nextSibling);\n\t\t\t});\n\n\t\t\telCurrentPages.forEach((elCurrentPage) => {\n\t\t\t\telCurrentPage?.classList.add('center-to-left');\n\t\t\t});\n\n\t\t\telNextPages.forEach((elNextPage) => {\n\t\t\t\telNextPage.classList.add('right-to-center');\n\t\t\t});\n\n\t\t\tbreak;\n\t\t}\n\t}\n\n\telDialog.setAttribute('view-page-active', pageName);\n\n\telCurrentPages.forEach((elCurrentPage) => {\n\t\telCurrentPage.classList.remove('active');\n\t});\n\n\telNextPages.forEach((elNextPage) => {\n\t\telNextPage.classList.add('active');\n\t});\n\n\tbeforeOpenViewPage(elDialog, elNextPages, pageName, args);\n\n\tif (moveDirection) {\n\t\telDialog.classList.add('i-change-page');\n\n\t\tconst delay = Number(window.getComputedStyle(elNextPages[0]).animationDuration.replace('s', '')) * 1000;\n\n\t\ttimerClearAnimation = setTimeout(() => {\n\t\t\tif (isElJQuery(elDialog)) elDialog = elDialog?.[0]; // TODO: Убрать после переписки jquery на сайте\n\n\t\t\tupdatePageVue(elDialog.getAttribute('id'), pageName, '');\n\t\t\tstopAnimations(elDialog);\n\t\t\tafterOpenViewPage(elDialog, elNextPages, pageName, args);\n\t\t}, delay);\n\t} else {\n\t\tawait updatePageVue(elDialog.getAttribute('id'), pageName, '');\n\t\tafterOpenViewPage(elDialog, elNextPages, pageName, args);\n\t}\n};\n\n/**\n * К предыдущему представлению\n */\nconst toPrevPage = (elDialog: ElTopDialog) => {\n\tconst elModalLayers = querySelectorAllArray<ElTopDialogModalLayer>(elDialog, '.modal-layer');\n\tconst elCurrentPages = elModalLayers.reduce<ElTopDialogPage[]>((acc, elModalLayer) => {\n\t\tconst elCurrentPage = elModalLayer.querySelector<ElTopDialogPage>(':scope > .active');\n\n\t\tif (elCurrentPage) {\n\t\t\tacc.push(elCurrentPage);\n\t\t}\n\n\t\treturn acc;\n\t}, []);\n\n\tconst elPrevPages = elCurrentPages.reduce<ElTopDialogPage[]>((acc, elCurrentPage) => {\n\t\tlet elPrevPage = elCurrentPage.previousElementSibling as ElTopDialogPage | null;\n\t\twhile (elPrevPage && !elPrevPage.hasAttribute('[data-view-page]')) {\n\t\t\telPrevPage = elPrevPage.previousElementSibling as ElTopDialogPage | null;\n\t\t}\n\n\t\tif (elPrevPage) acc.push(elPrevPage);\n\n\t\treturn acc;\n\t}, []);\n\n\tconst prevPageName = (elPrevPages[0])?.dataset.viewPage;\n\n\tif (prevPageName) {\n\t\tvoid toViewPage(elDialog, prevPageName, undefined, 'prev');\n\t} else {\n\t\tconst elDialogWrapper = getElDialogWrapper(elDialog);\n\n\t\telDialogWrapper.close();\n\t}\n};\n\n/**\n * Для обработки событий вне vue\n */\nconst beforeOpenViewPageTimers = new Set();\nconst beforeOpenViewPage = (elDialog: ElTopDialog, elPages: ElTopDialogPage[], pageName: string, args: string[]) => {\n\t// группировка цепочки событий\n\t// запрос на открытие страницы может выполняться несколько раз, чаще такое может быть при открытии, загрузке и переходе сразу к нужной странице\n\tconst eventKey = elDialog.getAttribute('id') + elPages[0].dataset.viewPage + pageName + args.join();\n\n\tif (beforeOpenViewPageTimers.has(eventKey)) return;\n\tbeforeOpenViewPageTimers.add(eventKey);\n\n\tsetTimeout(() => {\n\t\tbeforeOpenViewPageTimers.delete(eventKey);\n\n\t\tconst elDialogWrapper = getElDialogWrapper(elDialog)!;\n\n\t\t$(elDialog).trigger('viewBeforeOpen', [elDialogWrapper, $(elPages), pageName, args]);\n\t});\n};\n\n/**\n * Для обработки событий вне vue\n */\nconst afterOpenViewPage = (elDialog: ElTopDialog, elPages: ElTopDialogPage[], pageName?: string, args?: string[]) => {\n\tconst elDialogWrapper = getElDialogWrapper(elDialog);\n\n\tsetTimeout(() => {\n\t\t$(elDialog).trigger('viewAfterOpen', [elDialogWrapper, $(elPages), pageName, args]);\n\t});\n};\n\n/**\n * Получить состояние: Диалоговое окно находится в состоянии смены страницы\n */\nconst inAnimation = (elDialog: ElTopDialog | JQuery<ElTopDialog>) => {\n\tif (isElJQuery(elDialog)) elDialog = elDialog?.[0]; // TODO: Убрать после переписки jquery на сайте\n\n\treturn elDialog.classList.contains('i-change-page');\n};\n\n/**\n * Остановить анимацию смены страницы\n *\n * @returns Вернет true, если анимация производилась и была остановлена\n */\nconst stopAnimations = (elDialog: ElTopDialog) => {\n\tif (!inAnimation(elDialog)) return false;\n\n\tclearTimeout(timerClearAnimation);\n\n\tconst elModalLayers = querySelectorAllArray(elDialog, '.modal-layer');\n\n\tconst pageName = elDialog.dataset.viewPageActive;\n\telDialog.classList.remove('i-change-page');\n\n\telModalLayers.forEach((elModalLayer) => {\n\t\telModalLayer.querySelectorAll(':scope > [data-view-page]').forEach((el) => {\n\t\t\tel.classList.remove('center-to-left', 'right-to-center', 'reverse', 'active');\n\t\t});\n\t});\n\n\telModalLayers.forEach((elModalLayer) => {\n\t\telModalLayer.querySelector(`:scope > [data-view-page=\"${pageName}\"]`)?.classList.add('active');\n\t});\n\n\treturn true;\n};\n\n/**\n * Закрыть диалоговое окно\n */\nconst close = (id: string) => {\n\tconst elDialog = getElDialogById(id);\n\tif (!elDialog) return;\n\n\tconst elDialogWrapper = getElDialogWrapper(elDialog);\n\n\telDialogWrapper.close();\n};\n\n/**\n * Управление props.isLoading\n */\nconst setLoading = (elPages: ElTopDialogPage[] | JQuery<ElTopDialogPage>, isLoading: boolean, duration?: number) => {\n\tif (isElJQuery(elPages)) elPages = elPages.toArray(); // TODO: Убрать после переписки jquery на сайте\n\n\tconst elPagesVisibleds = elPages.reduce<ElTopDialogPage[]>((acc, elPage) => {\n\t\tif (elPage.hasAttribute('[data-view-page]') && isVisible(elPage)) acc.push(elPage);\n\n\t\treturn acc;\n\t}, []);\n\n\tif (isLoading) {\n\t\tif (duration !== undefined) {\n\t\t\telPagesVisibleds.forEach((elPagesVisibled) => {\n\t\t\t\telPagesVisibled.style.setProperty('--dialog-loading-duration', duration + 's');\n\t\t\t});\n\t\t}\n\n\t\telPagesVisibleds.forEach((elPagesVisibled) => {\n\t\t\telPagesVisibled.classList.add('i-load-data');\n\t\t});\n\t} else {\n\t\telPagesVisibleds.forEach((elPagesVisibled) => {\n\t\t\telPagesVisibled.classList.remove('i-load-data');\n\t\t});\n\n\t\telPagesVisibleds.forEach((elPagesVisibled) => {\n\t\t\telPagesVisibled.style.setProperty('--dialog-loading-duration', '10s');\n\t\t});\n\t}\n};\n\nconst isLoading = (elPage: ElTopDialogPage | JQuery<ElTopDialogPage>) => {\n\tif (isElJQuery(elPage)) elPage = elPage?.[0]; // TODO: Убрать после переписки jquery на сайте\n\n\treturn elPage.classList.contains('i-load-data');\n};\n\nexport const TopDialogUtils = {\n\tgetElDialogById,\n\tupdatePageVue,\n\trecalcPositions,\n\ttoViewDirty,\n\ttoView,\n\ttoViewPage,\n\ttoPrevPage,\n\tsetLoading,\n\tisLoading,\n\tinAnimation,\n\tclose,\n};\n\ninitDialogGlobalEvents();\n","import { type ComponentInstance, type ComponentInternalInstance, markRaw, ref } from 'vue';\nimport { waitWhile } from '@/core/utils/system';\nimport TopDialog from '../dialog.vue';\nimport { TopDialogWorker } from '@/components/dialog/lib/worker';\nimport type { MoveDirection } from '@/components/dialog/lib/types';\nimport type { TopDialogComponent } from './types';\nimport { historySetState } from '@/core/utils/route';\n\n/**\n * Объект для работы с диалоговым окном\n *\n * Каждое окно уникально и может быть открыто одновременно только один раз\n *\n * Можно определить много окон, после чего с ними можно вести работу в любой части приложения\n */\nexport class TopDialogHandle<T extends TopDialogComponent> {\n\n\t/**\n\t * Индентификатор, определяется на уровне компонента TopDialogComponent\n\t *\n\t * Может использоваться в навигации для открытия нужных окон с нужными настройками\n\t */\n\tid: string;\n\n\t/**\n\t * ID, используемый в верстке диалогового окна\n\t */\n\tidAttr: string;\n\n\t/**\n\t * Пользовательский компонент диалогового окна\n\t */\n\tComponent: T;\n\n\t/**\n\t * Компонент инициирован\n\t *\n\t * Устанавливается после первого вызова useTopDialog()\n\t */\n\tisMounted = ref(false);\n\n\t/**\n\t * Компонент готов к использованию\n\t *\n\t * Используется для внутренних преобразований после отрисовки\n\t */\n\tisReady = ref(false);\n\n\t/**\n\t * Диалоговое окно открыто\n\t */\n\tisOpened = ref(false);\n\n\t/**\n\t * Имя активной страницы дилогового окна\n\t */\n\tpageActive = ref('');\n\n\t/**\n\t * Диалоговое окно находится в состоянии загрузки своей страницы\n\t */\n\tisLoadingPage = ref(false);\n\n\t/**\n\t * Следующая активная страница\n\t *\n\t * В один момент времени может потребоваться отобразить две страницы, чтобы воспроизвести анимацию\n\t */\n\tpageActiveNext = ref('');\n\n\t/**\n\t * props компонента, доступны после инициализации\n\t */\n\tprops?: ComponentInstance<T>['$props'];\n\n\t/**\n\t * emit базового компонента `TopDialog`\n\t */\n\temit?: ComponentInstance<typeof TopDialog>['$emit'];\n\n\t/**\n\t * Одноразовое событие на закрытие диалогового окна\n\t *\n\t * Используется для привязки окна к сценариям использования\n\t */\n\tonCloseOnce?: (props: typeof this.props, pageName: string) => void;\n\n\tconstructor(TopDialogComponent: T) {\n\t\tthis.id = TopDialogComponent.id!;\n\t\tthis.idAttr = 'dialog_' + TopDialogComponent.id;\n\t\tthis.Component = markRaw(TopDialogComponent);\n\t}\n\n\t/**\n\t * Событие - компонент инициирован\n\t */\n\tonMounted(topDialogComponent: ComponentInternalInstance, topDialogBaseComponent: ComponentInternalInstance) {\n\t\tthis.isMounted.value = true;\n\t\tthis.props = topDialogComponent.props;\n\t\tthis.emit = topDialogBaseComponent.emit;\n\t}\n\n\t/**\n\t * Открыть диалоговое окно\n\t *\n\t * Учтите, что props в диалоговом окне будут доступны не сразу, а только после инициализации vue компонента\n\t */\n\tasync open(pageName: string = 'main', props?: {}, args: [] = [], onCloseOnce?: typeof this.onCloseOnce, moveDirection?: MoveDirection) {\n\t\tif (props) await this.setProps(props);\n\t\tif (onCloseOnce) this.onCloseOnce = onCloseOnce;\n\n\t\tconst TopDialogUtils = await TopDialogWorker.getDialogsUtils();\n\n\t\tawait TopDialogUtils.toView(this.idAttr, pageName, args, moveDirection);\n\t};\n\n\t/**\n\t * Открыть диалоговое окно как ссылку, для хеш-навигации\n\t *\n\t * Диалоговые окна загружаются по имени, см. настройку плагина Core topDialogLoader\n\t */\n\tasync openAsLink(\n\t\tpageName: string = 'main',\n\t\tprops?: {},\n\t\t_args: string[] = [],\n\t\tonCloseOnce?: typeof this.onCloseOnce,\n\t\tmoveDirection?: MoveDirection,\n\t) {\n\t\tif (props) await this.setProps(props);\n\t\tif (onCloseOnce) this.onCloseOnce = onCloseOnce;\n\n\t\tconst viewName = this.idAttr + '-' + pageName;\n\n\t\tconst hash = TopDialogWorker.genViewPageHash(viewName, moveDirection);\n\t\thistorySetState(false, hash);\n\t};\n\n\t/**\n\t * Закрыть диалоговое окно\n\t *\n\t * Не меняет состояние компонента диалогового окна\n\t */\n\tasync close() {\n\t\tTopDialogWorker.close(this.idAttr);\n\t};\n\n\t/**\n\t * Размонтировать $.dialog\n\t */\n\tasync destroy() {\n\t\tTopDialogWorker.destroy(this.idAttr);\n\t}\n\n\t/**\n\t * Устанвоить props\n\t *\n\t * Полностью сбрасывается состояние props\n\t */\n\tasync setProps(props: ComponentInstance<T>['$props'] = {}) {\n\t\t// ожидание инициализации компонента\n\t\tif (!this.isMounted) {\n\t\t\tawait waitWhile(() => !this.props);\n\t\t}\n\n\t\tfor (const name in this.props) {\n\t\t\tthis.props[name] = props[name];\n\t\t}\n\t}\n\n\t/**\n\t * Проверить, есть ли необходимость отрисовки страницы диалогового окна\n\t */\n\tneedShowPage(pageName: string): boolean {\n\t\tif (!this.isOpened.value) return false;\n\n\t\treturn this.pageActive.value === pageName || this.pageActiveNext.value === pageName;\n\t}\n}\n","<script lang=\"ts\">\nimport { shallowReactive } from 'vue';\nimport { TopDialogHandle } from '@/components/dialog/dialog/composables/dialogHandle';\nimport type { TopDialogComponent } from '@/components/dialog/dialog/composables/types';\n\n/**\n * Словарь всех используемых диалоговых окон\n *\n * В других компонентах не использовать\n */\nconst dialogsWorkers = shallowReactive(new Map<string, TopDialogHandle<TopDialogComponent>>());\n\n/**\n * Получить компонент диалогового окна по id\n */\nexport const getDialogWorker = (id: string) => {\n\tid = id.replace(/^dialog_/, '');\n\n\treturn dialogsWorkers.get(id);\n};\n\n/**\n * Добавить компонент диалогового окна для использования\n */\nexport const addDialogWorker = <T extends TopDialogComponent>(TopDialogComponent: T): TopDialogHandle<T> => {\n\tif (!TopDialogComponent?.id) {\n\t\tconsole.log({ TopDialogComponent: TopDialogComponent });\n\n\t\tthrow new Error('Expected TopDialogComponent');\n\t}\n\n\tif (!dialogsWorkers.has(TopDialogComponent.id)) {\n\t\tdialogsWorkers.set(TopDialogComponent.id, new TopDialogHandle(TopDialogComponent));\n\t}\n\n\treturn dialogsWorkers.get(TopDialogComponent.id) as TopDialogHandle<T>;\n};\n</script>\n\n<script setup lang=\"ts\">\nimport { onUnmounted } from 'vue';\n\ndefineOptions({\n\tname: 'DialogWrapper',\n});\n\nonUnmounted(() => {\n\tdialogsWorkers.forEach(dialog => dialog.destroy());\n\tdialogsWorkers.clear();\n});\n</script>\n\n<template>\n\t<div class=\"top-dialogs\" style=\"display: none;\">\n\t\t<component\n\t\t\tv-for=\"[dialogId, dialog] in dialogsWorkers\"\n\t\t\t:is=\"dialog.Component\"\n\t\t\t:key=\"dialogId\"\n\t\t/>\n\t</div>\n</template>\n"],"names":["TopDialogWorker","options","autoInitDelay","e","el","moveDirection","mouseEvent","TopDialogUtils","toView","acc","elCurrentPages","pageName","elNextPage","el2","utils_route","hash","oldUrl","newUrl","utils","$el","elPage","utils_dom","elDialog","id","getElDialogWrapper","elDialogWrapper","toViewPageN","viewName","viewNameAndPageLink","hash2","view","elToPages","elDialog2","pageLink","elForm","eventTarget","elSubmitButton2","event","elDialogWrapperWithTopZIndex","zIndex","topZIndex","Core","timerClearAnimation","isElJQuery","openElDialog","getElDialog","genVueOptions","elDialogClosedby","getElDialogById","addJQueryDialogMethods","action","classNames","className","args","dialog","getDialogWorker","dialogId","pageNameNext","utils_system","onCreate","_b","_a","initPopup","_e","$popup","elPopup","onOpen","w1","scrollBarWidth","recalcPositions","onClose","hashData","getDialogWrapperId","elDialogOverlay","createAndMountElDialogWrapper","pageActive","createAndMountElDialogOverlay","toViewDirty","toViewPageName","toViewParts","argsString","viewNameOrElDialog","callback","stopAnimations","updatePageVue","elCurrentPage","elModalLayer","elNextPages","elActive","toPrevPage","elPrevPage","beforeOpenViewPageTimers","eventKey","inAnimation","elModalLayers","toViewPage","duration","elPagesVisibleds","elPagesVisibled","initDialogGlobalEvents","TopDialogHandle","vue","TopDialogComponent","topDialogComponent","topDialogBaseComponent","props","onCloseOnce","_args","name","dialogsWorkers","addDialogWorker"],"mappings":"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"}
|