@topvisor/ui 1.5.0-updates.0 → 1.5.0-updates.5
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/api-CawzY1Cw.amd.js +2 -0
- package/.chunks/api-CawzY1Cw.amd.js.map +1 -0
- package/.chunks/api-CawzY1Cw.esm.js +208 -0
- package/.chunks/api-CawzY1Cw.esm.js.map +1 -0
- package/.chunks/app-CCX-gNqz.amd.js +2 -0
- package/.chunks/app-CCX-gNqz.amd.js.map +1 -0
- package/.chunks/app-CCX-gNqz.esm.js +396 -0
- package/.chunks/app-CCX-gNqz.esm.js.map +1 -0
- package/.chunks/datepicker-BTkZOq7d.amd.js +2 -0
- package/.chunks/datepicker-BTkZOq7d.amd.js.map +1 -0
- package/.chunks/datepicker-BTkZOq7d.esm.js +38 -0
- package/.chunks/datepicker-BTkZOq7d.esm.js.map +1 -0
- package/.chunks/dialog-DeM4SApg.amd.js +2 -0
- package/.chunks/dialog-DeM4SApg.amd.js.map +1 -0
- package/.chunks/dialog-DeM4SApg.esm.js +117 -0
- package/.chunks/dialog-DeM4SApg.esm.js.map +1 -0
- package/.chunks/dialog_regionSelectorRegions-CYrmaDt3.amd.js +2 -0
- package/.chunks/dialog_regionSelectorRegions-CYrmaDt3.amd.js.map +1 -0
- package/.chunks/dialog_regionSelectorRegions-CYrmaDt3.esm.js +169 -0
- package/.chunks/dialog_regionSelectorRegions-CYrmaDt3.esm.js.map +1 -0
- package/.chunks/dialogs-CMrERMI7.amd.js +2 -0
- package/.chunks/dialogs-CMrERMI7.amd.js.map +1 -0
- package/.chunks/dialogs-CMrERMI7.esm.js +237 -0
- package/.chunks/dialogs-CMrERMI7.esm.js.map +1 -0
- package/.chunks/field-CjkpGeA7.amd.js +2 -0
- package/.chunks/field-CjkpGeA7.amd.js.map +1 -0
- package/.chunks/field-CjkpGeA7.esm.js +16 -0
- package/.chunks/field-CjkpGeA7.esm.js.map +1 -0
- package/.chunks/forms-CbUt-6Ff.amd.js +2 -0
- package/.chunks/forms-CbUt-6Ff.amd.js.map +1 -0
- package/.chunks/forms-CbUt-6Ff.esm.js +1991 -0
- package/.chunks/forms-CbUt-6Ff.esm.js.map +1 -0
- package/.chunks/formsExt-CrTmBhja.amd.js +2 -0
- package/.chunks/formsExt-CrTmBhja.amd.js.map +1 -0
- package/.chunks/formsExt-CrTmBhja.esm.js +807 -0
- package/.chunks/formsExt-CrTmBhja.esm.js.map +1 -0
- package/.chunks/lazy-CGswTOPj.amd.js +2 -0
- package/.chunks/lazy-CGswTOPj.amd.js.map +1 -0
- package/.chunks/lazy-CGswTOPj.esm.js +68 -0
- package/.chunks/lazy-CGswTOPj.esm.js.map +1 -0
- package/.chunks/mocker-CwZe-g4N.amd.js +2 -0
- package/.chunks/mocker-CwZe-g4N.amd.js.map +1 -0
- package/.chunks/mocker-CwZe-g4N.esm.js +45 -0
- package/.chunks/mocker-CwZe-g4N.esm.js.map +1 -0
- package/.chunks/notice-CslVdVNm.amd.js +4 -0
- package/.chunks/notice-CslVdVNm.amd.js.map +1 -0
- package/.chunks/notice-CslVdVNm.esm.js +191 -0
- package/.chunks/notice-CslVdVNm.esm.js.map +1 -0
- package/.chunks/popup-DrByVU-k.amd.js +2 -0
- package/.chunks/popup-DrByVU-k.amd.js.map +1 -0
- package/.chunks/popup-DrByVU-k.esm.js +444 -0
- package/.chunks/popup-DrByVU-k.esm.js.map +1 -0
- package/.chunks/popup-dNrN-eKi.amd.js +2 -0
- package/.chunks/popup-dNrN-eKi.amd.js.map +1 -0
- package/.chunks/popup-dNrN-eKi.esm.js +323 -0
- package/.chunks/popup-dNrN-eKi.esm.js.map +1 -0
- package/.chunks/punycode.es6-B-5kB2YI.amd.js +2 -0
- package/.chunks/{punycode.es6-CgGegfA_.es.js.map → punycode.es6-B-5kB2YI.amd.js.map} +1 -1
- package/.chunks/punycode.es6-B-5kB2YI.esm.js +105 -0
- package/.chunks/punycode.es6-B-5kB2YI.esm.js.map +1 -0
- package/.chunks/store-DuQpSSLL.amd.js +2 -0
- package/.chunks/{store-CX_6ZXhO.es.js.map → store-DuQpSSLL.amd.js.map} +1 -1
- package/.chunks/store-DuQpSSLL.esm.js +27 -0
- package/.chunks/store-DuQpSSLL.esm.js.map +1 -0
- package/.chunks/utils-BwiXsV0S.amd.js +2 -0
- package/.chunks/utils-BwiXsV0S.amd.js.map +1 -0
- package/.chunks/utils-BwiXsV0S.esm.js +43 -0
- package/.chunks/utils-BwiXsV0S.esm.js.map +1 -0
- package/.chunks/utils-Dd0MZgyw.amd.js +2 -0
- package/.chunks/utils-Dd0MZgyw.amd.js.map +1 -0
- package/.chunks/utils-Dd0MZgyw.esm.js +287 -0
- package/.chunks/utils-Dd0MZgyw.esm.js.map +1 -0
- package/.chunks/worker-Db8YrEHo.amd.js +2 -0
- package/.chunks/worker-Db8YrEHo.amd.js.map +1 -0
- package/.chunks/worker-Db8YrEHo.esm.js +100 -0
- package/.chunks/worker-Db8YrEHo.esm.js.map +1 -0
- package/api/additional.amd.js +2 -2
- package/api/additional.amd.js.map +1 -1
- package/api/additional.js +70 -66
- package/api/additional.js.map +1 -1
- package/api/index.amd.js +2 -2
- package/api/index.amd.js.map +1 -1
- package/api/index.js +3 -285
- package/assets/charts.css +1 -1
- package/assets/core.css +1 -1
- package/assets/dialog_regionSelectorRegions.css +1 -1
- package/assets/extra.css +1 -1
- package/assets/forms.css +1 -1
- package/assets/formsExt.css +1 -0
- package/assets/layout.css +1 -1
- package/assets/notice.css +1 -1
- package/assets/popup.css +1 -0
- package/assets/project.css +1 -1
- package/assets/tabs.css +1 -1
- package/assets/tabsView.css +1 -1
- package/assets/themes/dark-th.css +1 -1
- package/assets/themes/dark.css +1 -1
- package/assets/themes/light.css +1 -1
- package/autoload-css-manifest.amd.json +79 -0
- package/autoload-css-manifest.json +90 -0
- package/charts/charts.amd.js +2 -2
- package/charts/charts.amd.js.map +1 -1
- package/charts/charts.js +146 -174
- package/charts/charts.js.map +1 -1
- package/core/app.amd.js +2 -2
- package/core/app.amd.js.map +1 -1
- package/core/app.js +5 -213
- package/dialog/dialog.amd.js +2 -2
- package/dialog/dialog.amd.js.map +1 -1
- package/dialog/dialog.js +4 -60
- package/extra/extra.amd.js +2 -2
- package/extra/extra.amd.js.map +1 -1
- package/extra/extra.js +73 -69
- package/extra/extra.js.map +1 -1
- package/forms/forms.amd.js +2 -2
- package/forms/forms.amd.js.map +1 -1
- package/forms/forms.js +2 -19
- package/forms/helpers.amd.js +2 -2
- package/forms/helpers.amd.js.map +1 -1
- package/forms/helpers.js +0 -2
- package/formsExt/formsExt.amd.js +2 -2
- package/formsExt/formsExt.amd.js.map +1 -1
- package/formsExt/formsExt.js +2 -373
- package/icomoon/demo-files/demo.amd.js +2 -0
- package/icomoon/demo-files/demo.amd.js.map +1 -0
- package/icomoon/demo.amd.js +2 -0
- package/icomoon/demo.amd.js.map +1 -0
- package/layout/layout.amd.js +2 -2
- package/layout/layout.amd.js.map +1 -1
- package/layout/layout.js +41 -57
- package/layout/layout.js.map +1 -1
- package/package.json +1 -1
- package/popup/popup.amd.js +2 -2
- package/popup/popup.amd.js.map +1 -1
- package/popup/popup.js +2 -282
- package/popup/worker.amd.js +2 -2
- package/popup/worker.amd.js.map +1 -1
- package/popup/worker.js +2 -144
- package/project/project.amd.js +2 -2
- package/project/project.amd.js.map +1 -1
- package/project/project.js +1666 -1643
- package/project/project.js.map +1 -1
- package/src/src/components/project/groupSelector/folders/types.d.ts +1 -1
- package/src/src/components/project/groupSelector/folders/utils.d.ts +35 -400
- package/src/src/components/project/groupSelector/groupSelector.vue.d.ts +1 -1
- package/src/src/components/project/groupSelector/groups/types.d.ts +1 -1
- package/src/src/components/project/groupSelector/groups/utils.d.ts +44 -757
- package/src/src/components/project/projectSelector/utils.d.ts +40 -39
- package/tabs/tabs.amd.js +2 -2
- package/tabs/tabs.amd.js.map +1 -1
- package/tabs/tabs.js +63 -77
- package/tabs/tabs.js.map +1 -1
- package/tabsView/tabsView.amd.js +2 -2
- package/tabsView/tabsView.amd.js.map +1 -1
- package/tabsView/tabsView.js +245 -288
- package/tabsView/tabsView.js.map +1 -1
- package/utils/check.amd.js +2 -2
- package/utils/check.amd.js.map +1 -1
- package/utils/check.js +15 -19
- package/utils/check.js.map +1 -1
- package/utils/clipboard.amd.js +6 -6
- package/utils/clipboard.amd.js.map +1 -1
- package/utils/clipboard.js +26 -31
- package/utils/clipboard.js.map +1 -1
- package/utils/date.amd.js +2 -2
- package/utils/date.amd.js.map +1 -1
- package/utils/date.js +2 -12
- package/utils/device.amd.js +2 -2
- package/utils/device.amd.js.map +1 -1
- package/utils/device.js +2 -15
- package/utils/dom.amd.js +2 -2
- package/utils/dom.amd.js.map +1 -1
- package/utils/dom.js +53 -67
- package/utils/dom.js.map +1 -1
- package/utils/image.amd.js +3 -3
- package/utils/image.amd.js.map +1 -1
- package/utils/image.js +12 -22
- package/utils/image.js.map +1 -1
- package/utils/keyboard.amd.js +2 -2
- package/utils/keyboard.amd.js.map +1 -1
- package/utils/keyboard.js +10 -11
- package/utils/keyboard.js.map +1 -1
- package/utils/lodash.amd.js +2 -2
- package/utils/lodash.amd.js.map +1 -1
- package/utils/lodash.js +2 -9
- package/utils/number.amd.js +2 -2
- package/utils/number.amd.js.map +1 -1
- package/utils/number.js +12 -12
- package/utils/number.js.map +1 -1
- package/utils/price.amd.js +2 -2
- package/utils/price.amd.js.map +1 -1
- package/utils/price.js +14 -9
- package/utils/price.js.map +1 -1
- package/utils/route.amd.js +2 -2
- package/utils/route.amd.js.map +1 -1
- package/utils/route.js +33 -37
- package/utils/route.js.map +1 -1
- package/utils/scroll.amd.js +2 -2
- package/utils/scroll.amd.js.map +1 -1
- package/utils/scroll.js +39 -43
- package/utils/scroll.js.map +1 -1
- package/utils/searchers.amd.js +2 -2
- package/utils/searchers.amd.js.map +1 -1
- package/utils/searchers.js +128 -133
- package/utils/searchers.js.map +1 -1
- package/utils/store.amd.js +2 -2
- package/utils/store.amd.js.map +1 -1
- package/utils/store.js +2 -7
- package/utils/string.amd.js +2 -2
- package/utils/string.amd.js.map +1 -1
- package/utils/string.js +120 -147
- package/utils/string.js.map +1 -1
- package/utils/system.amd.js +2 -2
- package/utils/system.amd.js.map +1 -1
- package/utils/system.js +25 -28
- package/utils/system.js.map +1 -1
- package/utils/url.amd.js +3 -3
- package/utils/url.amd.js.map +1 -1
- package/utils/url.js +36 -47
- package/utils/url.js.map +1 -1
- package/.chunks/core-Dgj_YGWh.es.js +0 -268
- package/.chunks/core-Dgj_YGWh.es.js.map +0 -1
- package/.chunks/core-DzDFXOdI.amd.js +0 -2
- package/.chunks/core-DzDFXOdI.amd.js.map +0 -1
- package/.chunks/datepicker-oa8ZwRhq.amd.js +0 -2
- package/.chunks/datepicker-oa8ZwRhq.amd.js.map +0 -1
- package/.chunks/datepicker-qToxk2nN.es.js +0 -41
- package/.chunks/datepicker-qToxk2nN.es.js.map +0 -1
- package/.chunks/dialog_regionSelectorRegions-CZ0tMVSq.amd.js +0 -2
- package/.chunks/dialog_regionSelectorRegions-CZ0tMVSq.amd.js.map +0 -1
- package/.chunks/dialog_regionSelectorRegions-qDW2Ejsv.es.js +0 -180
- package/.chunks/dialog_regionSelectorRegions-qDW2Ejsv.es.js.map +0 -1
- package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-BBix_8WK.amd.js +0 -2
- package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-BBix_8WK.amd.js.map +0 -1
- package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-CJ97l1ST.es.js +0 -323
- package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-CJ97l1ST.es.js.map +0 -1
- package/.chunks/field-Cvv0SRcJ.amd.js +0 -2
- package/.chunks/field-Cvv0SRcJ.amd.js.map +0 -1
- package/.chunks/field-CyyFzM-Y.es.js +0 -16
- package/.chunks/field-CyyFzM-Y.es.js.map +0 -1
- package/.chunks/forms-DDNzqU6o.amd.js +0 -3
- package/.chunks/forms-DDNzqU6o.amd.js.map +0 -1
- package/.chunks/forms-DtC-EKJL.es.js +0 -2053
- package/.chunks/forms-DtC-EKJL.es.js.map +0 -1
- package/.chunks/index-DLUtoTUg.amd.js +0 -2
- package/.chunks/index-DLUtoTUg.amd.js.map +0 -1
- package/.chunks/index-DkQWJkMc.es.js +0 -54
- package/.chunks/index-DkQWJkMc.es.js.map +0 -1
- package/.chunks/lazy-DDNqYkXn.amd.js +0 -2
- package/.chunks/lazy-DDNqYkXn.amd.js.map +0 -1
- package/.chunks/lazy-HKSyLh72.es.js +0 -75
- package/.chunks/lazy-HKSyLh72.es.js.map +0 -1
- package/.chunks/notice-BvQl911b.es.js +0 -191
- package/.chunks/notice-BvQl911b.es.js.map +0 -1
- package/.chunks/notice-CJ3WOTCM.amd.js +0 -4
- package/.chunks/notice-CJ3WOTCM.amd.js.map +0 -1
- package/.chunks/page.vue_vue_type_script_setup_true_lang-Dd5-B4Ss.es.js +0 -139
- package/.chunks/page.vue_vue_type_script_setup_true_lang-Dd5-B4Ss.es.js.map +0 -1
- package/.chunks/page.vue_vue_type_script_setup_true_lang-fl6-Ql4d.amd.js +0 -2
- package/.chunks/page.vue_vue_type_script_setup_true_lang-fl6-Ql4d.amd.js.map +0 -1
- package/.chunks/policy.vue_vue_type_style_index_0_lang-Bv3LwNDC.es.js +0 -519
- package/.chunks/policy.vue_vue_type_style_index_0_lang-Bv3LwNDC.es.js.map +0 -1
- package/.chunks/policy.vue_vue_type_style_index_0_lang-Da7rztT5.amd.js +0 -2
- package/.chunks/policy.vue_vue_type_style_index_0_lang-Da7rztT5.amd.js.map +0 -1
- package/.chunks/popup-OuDglAOF.es.js +0 -470
- package/.chunks/popup-OuDglAOF.es.js.map +0 -1
- package/.chunks/popup-yXIpyok3.amd.js +0 -2
- package/.chunks/popup-yXIpyok3.amd.js.map +0 -1
- package/.chunks/popupHint.vue_vue_type_style_index_0_lang-Bu_HvFoW.amd.js +0 -2
- package/.chunks/popupHint.vue_vue_type_style_index_0_lang-Bu_HvFoW.amd.js.map +0 -1
- package/.chunks/popupHint.vue_vue_type_style_index_0_lang-DAQIAxvu.es.js +0 -209
- package/.chunks/popupHint.vue_vue_type_style_index_0_lang-DAQIAxvu.es.js.map +0 -1
- package/.chunks/punycode.es6-CNOnFR2-.amd.js +0 -2
- package/.chunks/punycode.es6-CNOnFR2-.amd.js.map +0 -1
- package/.chunks/punycode.es6-CgGegfA_.es.js +0 -134
- package/.chunks/store-CX_6ZXhO.es.js +0 -29
- package/.chunks/store-YRW59xEF.amd.js +0 -2
- package/.chunks/store-YRW59xEF.amd.js.map +0 -1
- package/.chunks/utils-BNzP9anP.es.js +0 -78
- package/.chunks/utils-BNzP9anP.es.js.map +0 -1
- package/.chunks/utils-CWn_G7OO.amd.js +0 -2
- package/.chunks/utils-CWn_G7OO.amd.js.map +0 -1
- package/.chunks/utils-DIviuVEw.amd.js +0 -2
- package/.chunks/utils-DIviuVEw.amd.js.map +0 -1
- package/.chunks/utils-Dma85ehT.es.js +0 -288
- package/.chunks/utils-Dma85ehT.es.js.map +0 -1
- package/.chunks/widgetInput.vue_vue_type_script_setup_true_lang-CX_BOcVY.es.js +0 -39
- package/.chunks/widgetInput.vue_vue_type_script_setup_true_lang-CX_BOcVY.es.js.map +0 -1
- package/.chunks/widgetInput.vue_vue_type_script_setup_true_lang-CkOmb3VD.amd.js +0 -2
- package/.chunks/widgetInput.vue_vue_type_script_setup_true_lang-CkOmb3VD.amd.js.map +0 -1
- package/api/index.js.map +0 -1
- package/assets/policy.css +0 -1
- package/assets/popupHint.css +0 -1
- package/core/app.js.map +0 -1
- package/dialog/dialog.js.map +0 -1
- package/forms/forms.js.map +0 -1
- package/forms/helpers.js.map +0 -1
- package/formsExt/formsExt.js.map +0 -1
- package/popup/popup.js.map +0 -1
- package/popup/worker.js.map +0 -1
- package/src/src/components/project/groupSelector/utils.d.ts +0 -37
- package/utils/date.js.map +0 -1
- package/utils/device.js.map +0 -1
- package/utils/lodash.js.map +0 -1
- package/utils/store.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"app-CCX-gNqz.esm.js","names":["#storeId","#store","#Page","#user","#Api","#namesUrlHash","#namesStorage","#namesStorageLocal","#namesGuestLink","#loadFromStorage","#loadFromHash","#loadFromGuestLink","#prepareParams","#saveInHash","#saveInStorage","#genOptionsForGuestLink","#setOptions","#genDataUnFormat","#genDataFormat"],"sources":["../../src/components/popup/lib/worker.globalEvents.ts","../../src/core/directives/data.ts","../../src/core/directives/focus.ts","../../src/core/directives/scrollIntoView.ts","../../src/core/directives/scrollShadow.ts","../../src/core/directives/shortcut.ts","../../src/core/directives/sticky.ts","../../src/core/directives/swimUp.ts","../../src/core/directives/tooltip.ts","../../src/core/plugins/core.ts","../../src/core/plugins/piniaTPA.ts"],"sourcesContent":["import Core from '@/core/core/core';\nimport Events from '@/core/core/events';\nimport Worker from '@/components/popup/lib/worker';\n\n/**\n * Глобальные события, для реализации Popup\n */\nclass WorkerEvents {\n\n\tprivate static isInited = false;\n\n\t/**\n\t * Добавить глобальные обработчики\n\t *\n\t * Добавляются на страницу один раз и навсегда\n\t */\n\tstatic init(): void {\n\t\tif (this.isInited) return;\n\n\t\tthis.isInited = true;\n\n\t\t// автоматическое открытие при наведении мыши, событие глобальное, так как инициализация popup отложена\n\t\tdocument.addEventListener('mouseover', (e) => {\n\t\t\tif (!(e.target instanceof HTMLElement) || !e.target.dataset?.topPopupOpenByHover) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\te.target.click();\n\t\t});\n\n\t\t// при скролле страницы закрыть Popup\n\t\tdocument.addEventListener('scroll', () => {\n\t\t\tif (Core.state.isMobile || Core.state.isMobileUA) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tWorker.getAll().forEach(elPopup => Worker.close(elPopup));\n\t\t});\n\n\t\tEvents.addOnReize(e => {\n\t\t\t// закрыть popup при повороте экрана телефона\n\t\t\t// если была отображена ПК версия, она будет закрыта\n\t\t\tif (Core.state.isMobile && e.topEvent.widthDiff) {\n\t\t\t\tWorker.getAll().forEach(elPopup => Worker.close(elPopup));\n\t\t\t}\n\t\t});\n\n\t\tdocument.addEventListener('click', this.onclick, { capture: true });\n\t}\n\n\t/**\n\t * Глобальный обработчик кликов\n\t *\n\t * Обрабатывает клики на открытие Popup\n\t */\n\tprivate static async onclick(e: Event): Promise<void> {\n\t\tif (!(e.target instanceof HTMLElement)) return;\n\n\t\tif (e.target.dataset.topPopupDisabled) {\n\t\t\treturn;\n\t\t}\n\n\t\tlet elOpener: HTMLElement | undefined;\n\n\t\tswitch (true) {\n\t\t\tcase !!e.target.dataset?.topPopup:\n\t\t\t\telOpener = e.target;\n\n\t\t\t\tbreak;\n\n\t\t\tcase !!e.target.parentElement?.dataset.topPopup:\n\t\t\t\telOpener = e.target.parentElement;\n\n\t\t\t\tbreak;\n\n\t\t\tcase !!e.target.parentElement?.parentElement?.dataset.topPopup:\n\t\t\t\telOpener = e.target.parentElement?.parentElement;\n\n\t\t\t\tbreak;\n\t\t}\n\n\t\tif (!elOpener) {\n\t\t\treturn;\n\t\t}\n\n\t\tif (elOpener.dataset.topPopupDisabled) {\n\t\t\treturn;\n\t\t}\n\n\t\t// меню уже открыто\n\t\tif (elOpener.dataset.topPopupOpened) {\n\t\t\tconst popup = Worker.getPopupFromOpener(elOpener);\n\t\t\tif (!popup?.openerIsInput) {\n\t\t\t\tpopup?.close();\n\t\t\t}\n\n\t\t\treturn;\n\t\t}\n\n\t\te.preventDefault();\n\n\t\tawait Worker.openByOpener(elOpener);\n\t}\n}\n\nexport default WorkerEvents;\n","import type { DirectiveBinding, ObjectDirective } from 'vue';\n\nlet storage: any;\n\n/**\n * Сохранить данные в элементе\n *\n * Для доступа к данным можно воспользоваться ui/utils/dom storage()\n */\nconst data = {\n\tmounted: async (el: HTMLElement, binding: DirectiveBinding) => {\n\t\tif (!storage) {\n\t\t\tconst UtilsDom = await import('@/core/utils/dom');\n\n\t\t\tstorage = UtilsDom.storage;\n\t\t}\n\n\t\tconst name = binding.arg;\n\t\tconst value = binding.value;\n\n\t\tstorage(el, name, value);\n\t},\n};\n\nexport default data;\n","import type { DirectiveBinding } from 'vue';\n\ntype Binding = DirectiveBinding<boolean, 'onupdate'>;\n\nlet UtilsLodash: typeof import('@/core/utils/lodash');\n\n/**\n * Список элементов, на которых бала запрошена фокусировка, для дедупликации фокусировок\n */\nlet elsActive: HTMLElement[] = [];\n\n/**\n * Функция скролла с дедупликацией\n */\nlet focusOnElActiveDebounce: Function;\n\n/**\n * Выполнить фокусировку на активном элементе\n *\n * Если фокусирока запрошена на несколько элементов, будет выбран первый элемент\n */\nconst focusOnElActive = async () => {\n\tconst { isVisible } = await import('@/core/utils/dom');\n\telsActive = elsActive.filter(isVisible)\n\n\tif (!elsActive.length) return;\n\n\tconst el = elsActive[0];\n\n\tel.focus();\n\n\t// // UX: Если выбрано несколько чекбоксов или радио после выбора фокусировка будет снята, чтобы не делать выбор за пользователя\n\t// if (elsActive.length && el.nodeName === 'INPUT') {\n\t// \tconst type = (el as HTMLInputElement).type;\n\t// \tif (type === 'checkbox' || type === 'radio') el.blur();\n\t// }\n\n\telsActive = [];\n};\n\n/**\n * Выполнить дедуплицированную фокусировку на элементе\n */\nconst focusOnElDebounce = async (el: HTMLElement) => {\n\tif (!UtilsLodash) UtilsLodash = await import('@/core/utils/lodash');\n\tif (!focusOnElActiveDebounce) focusOnElActiveDebounce = UtilsLodash.debounce(focusOnElActive, 30);\n\n\telsActive.push(el);\n\n\tfocusOnElActiveDebounce();\n};\n\n/**\n * Фокусировка на элементе сразу после его отображения\n */\nconst focus = {\n\tmounted: function (el: HTMLElement, binding: Binding) {\n\t\tel['__TOP_V_FOCUS_VALUE'] = binding.value ?? true;\n\n\t\tif (binding.value ?? true) focusOnElDebounce(el);\n\t},\n\n\tupdated: function (el: HTMLElement, binding: Binding) {\n\t\tif (!binding.modifiers.onupdate) return;\n\n\t\tif (el['__TOP_V_FOCUS_VALUE'] === (binding.value ?? true)) return;\n\t\tel['__TOP_V_FOCUS_VALUE'] = binding.value ?? true;\n\n\t\tif (binding.value ?? true) focusOnElDebounce(el);\n\t},\n};\n\nexport default focus;\n","import type { DirectiveBinding, ObjectDirective } from 'vue';\nimport { isVisible } from '@/core/utils/dom';\n\ntype Binding = DirectiveBinding<ScrollIntoViewOptions | boolean | undefined, 'immediate'>;\n\ntype Storage = {\n\t/**\n\t * Сохраненное состояние видимости\n\t */\n\tisVisible: boolean,\n\n\t/**\n\t * Текущие настройки скролла\n\t */\n\tscrollIntoViewOptions: ScrollIntoViewOptions | boolean\n};\n\nlet UtilsDom: typeof import('@/core/utils/dom');\nlet UtilsLodash: typeof import('@/core/utils/lodash');\n\n/**\n * Сгенерировать настройки для скролла\n *\n * @see https://developer.mozilla.org/ru/docs/Web/API/Element/scrollIntoView\n */\nconst genScrollIntoViewOptions = (scrollIntoViewOptions?: ScrollIntoViewOptions | boolean) => {\n\tif (typeof scrollIntoViewOptions === 'boolean') return scrollIntoViewOptions;\n\n\tif (!scrollIntoViewOptions) {\n\t\tscrollIntoViewOptions = {};\n\t} else {\n\t\tscrollIntoViewOptions = { ...scrollIntoViewOptions };\n\t}\n\n\tscrollIntoViewOptions.behavior ??= 'smooth';\n\tscrollIntoViewOptions.block ??= 'nearest';\n\tscrollIntoViewOptions.inline ??= 'nearest';\n\n\treturn scrollIntoViewOptions;\n};\n\n/**\n * Активный элемент, для дедупликации скроллов\n *\n * Только один элемент на странице может считаться активным\n */\nlet elActive: HTMLElement | undefined;\n\n/**\n * Функция скролла с дедупликацией\n */\nlet scrollToElActiveDebounce: Function;\n\n/**\n * Выполнить скролл к текущему активному элементу\n */\nconst scrollToElActive = async () => {\n\tif (!elActive) return;\n\n\tconst storage = await useStorage(elActive);\n\tif (!storage.isVisible) return;\n\n\telActive.scrollIntoView(storage.scrollIntoViewOptions);\n};\n\n/**\n * Выполнить дедуплицированный скролл к элементу\n *\n * Будет выполнен скролл к самому последнему элементу, вызвавшему срабатывание директивы\n */\nconst scrollToElDebounce = async (el: HTMLElement) => {\n\tif (!UtilsLodash) UtilsLodash = await import('@/core/utils/lodash');\n\tif (!scrollToElActiveDebounce) scrollToElActiveDebounce = UtilsLodash.debounce(scrollToElActive, 30);\n\n\telActive = el;\n\n\tscrollToElActiveDebounce();\n};\n\n/**\n * Данные, связанные с элементом и директивой\n */\nconst useStorage = async (el: HTMLElement, scrollIntoViewOptions?: ScrollIntoViewOptions | boolean) => {\n\tif (!UtilsDom) UtilsDom = await import('@/core/utils/dom');\n\n\tlet storage: Storage | undefined = UtilsDom.storage(el, 'v-top-scrollIntoView');\n\n\t// инициализация\n\tif (!storage) {\n\t\tstorage = {\n\t\t\tisVisible: isVisible(el),\n\t\t\tscrollIntoViewOptions: genScrollIntoViewOptions(scrollIntoViewOptions),\n\t\t};\n\n\t\tUtilsDom.storage(el, 'v-top-scrollIntoView', storage);\n\t}\n\n\treturn storage;\n};\n\nconst scrollIntoView: ObjectDirective = {\n\tasync mounted(el: HTMLElement, binding: Binding) {\n\t\tawait useStorage(el, binding.value);\n\n\t\tif (binding.modifiers.immediate) {\n\t\t\tscrollToElDebounce(el);\n\t\t}\n\t},\n\n\tasync updated(el: HTMLElement, binding: Binding) {\n\t\tconst storage = await useStorage(el, binding.value);\n\t\tstorage.scrollIntoViewOptions = genScrollIntoViewOptions(binding.value);\n\n\t\tconst isVisibleNew = isVisible(el);\n\t\tif (isVisibleNew && storage.isVisible !== isVisibleNew) {\n\t\t\tscrollToElDebounce(el);\n\t\t}\n\n\t\tstorage.isVisible = isVisibleNew;\n\t},\n};\n\nexport default scrollIntoView;\n","let UtilsScroll: typeof import('@/core/utils/scroll');\n\n/**\n * Добавить отображение тени при появлении скролла у элемента\n *\n * Будут добавлены события для усатновки модификаторов тени в зависимости от скролла элемента\n *\n * Модификаторы:\n * - top-scrollShadow\n * - top-scrollShadow-started\n * - top-scrollShadow-finished\n */\nconst connectScrollShadow = {\n\tasync mounted(el) {\n\t\tif (!UtilsScroll) UtilsScroll = await import('@/core/utils/scroll');\n\n\t\tUtilsScroll.connectScrollShadow(el);\n\t},\n\n\tasync unmounted(el) {\n\t\tif (!UtilsScroll) UtilsScroll = await import('@/core/utils/scroll');\n\n\t\tUtilsScroll.unconnectScrollShadow(el);\n\t},\n};\n\nexport default connectScrollShadow;\n","import { isVisible } from '@/core/utils/dom';\nimport { isMacOS } from '@/core/utils/device';\nimport type { DirectiveBinding } from 'vue';\nimport type debounce from 'lodash-es/debounce.js';\n\nexport type ShortcutValue = string;\n\n/**\n * Допустимые модификаторы\n */\ntype AllowedModifiers = 'ctrl' | 'shift' | 'alt';\ntype Binding = DirectiveBinding<ShortcutValue, AllowedModifiers>;\n\n/**\n * Очередь элементов, ожидающих синхронизации горячих клавиш.\n * Накапливает изменения для их пакетной обработки\n */\nconst elsShortcutQueue = new Map<HTMLElement, {\n\tvalue: ShortcutValue;\n\tmodifiers: Binding['modifiers'];\n}>;\n\n/**\n * Отложенная версия функции syncShortcuts.\n * Обеспечивает пакетную обработку изменений горячих клавиш\n */\nlet syncShortcutsDebounce: ReturnType<typeof debounce> | undefined;\n\n/**\n * Список горячих клавиш и html элементов, на которые они назначены\n */\nconst elementByShortcut = new Map<string, HTMLElement>();\n\n/**\n * Добавлен ли обработчик события\n */\nlet isListenerAttached = false;\n\n/**\n * Отображение названий клавиш-модификаторов в зависимости от ОС\n *\n * В наших горячих клавишах Ctrl всегда соответствует Cmd в MacOS\n */\nconst modifierKeys = {\n\tctrl: isMacOS() ? '⌘' : 'Ctrl',\n\talt: isMacOS() ? '⌥' : 'Alt',\n\tshift: isMacOS() ? '⇧' : 'Shift',\n};\n\n/**\n * Получить название клавиши из event.code\n */\nconst getKeyLabel = (code: string) => {\n\tlet keyLabel = code;\n\n\tif (code.includes('Key')) keyLabel = code.replace('Key', '');\n\tif (code.includes('Digit')) keyLabel = code.replace('Digit', '');\n\tif (code === 'Escape') keyLabel = 'Esc';\n\n\treturn keyLabel;\n};\n\n/**\n * Сгенерировать строковое представление сочетания клавиш с модификаторами\n *\n * Приводим к виду \"Ctrl+Shift+A\" или \"⌘⇧A\" для MacOS\n */\nconst genShortcutString = (code: string, modifiers: Binding['modifiers']) => {\n\tconst keyLabel = getKeyLabel(code);\n\tif (!modifiers) return keyLabel;\n\n\tconst { ctrl, alt, shift } = modifierKeys;\n\tconst parts: string[] = [];\n\n\tif (modifiers.ctrl) parts.push(ctrl);\n\tif (modifiers.alt) parts.push(alt);\n\tif (modifiers.shift) parts.push(shift);\n\n\t// Основная клавиша\n\tparts.push(keyLabel);\n\n\treturn parts.join(isMacOS() ? '' : '+');\n};\n\nconst registerShortcut = (el: HTMLElement, value: ShortcutValue, modifiers: Binding['modifiers']) => {\n\tconst shortcut = genShortcutString(value, modifiers);\n\n\tif (el['__TOP_V_SHORTCUT_VALUE']) {\n\t\tconsole.warn(`Element already has shortcut \"${el['__TOP_V_SHORTCUT_VALUE']}\"`);\n\n\t\treturn;\n\t}\n\n\tif (elementByShortcut.has(shortcut)) {\n\t\tconsole.warn(`Shortcut \"${shortcut}\" is taken`);\n\n\t\treturn;\n\t}\n\n\telementByShortcut.set(shortcut, el);\n\tel.title = el.title ? `${el.title} (${shortcut})` : shortcut;\n\tel['__TOP_V_SHORTCUT_VALUE'] = shortcut;\n};\n\nconst unregisterShortcut = (el: HTMLElement) => {\n\tconst shortcut: string | undefined = el['__TOP_V_SHORTCUT_VALUE'];\n\tif (!shortcut) return;\n\n\telementByShortcut.delete(shortcut);\n\tdelete el['__TOP_V_SHORTCUT_VALUE'];\n\n\tif (el.title === shortcut) el.removeAttribute('title');\n\tif (el.title.includes(` (${shortcut})`)) {\n\t\tel.title = el.title.replace(` (${shortcut})`, '');\n\t}\n};\n\n/**\n * Обновить регистрацию горячих клавиш для элементов в очереди\n *\n * Отменяет регистрацию для невидимых элементов и регистрирует для видимых.\n * Очищает очередь после обработки\n */\nconst syncShortcuts = () => {\n\tfor (const [el] of elsShortcutQueue) {\n\t\tif (!isVisible(el) && el['__TOP_V_SHORTCUT_VALUE']) {\n\t\t\tunregisterShortcut(el);\n\t\t}\n\t}\n\n\tfor (const [el, data] of elsShortcutQueue) {\n\t\tif (isVisible(el) && !el['__TOP_V_SHORTCUT_VALUE']) {\n\t\t\tregisterShortcut(el, data.value, data.modifiers);\n\t\t}\n\t}\n\n\telsShortcutQueue.clear();\n};\n\n/**\n * Выполняет отложенную регистрацию горячих клавиш на элементе с дедупликацией\n */\nconst registerShortcutDebounce = async (el: HTMLElement, value: ShortcutValue, modifiers: Binding['modifiers']) => {\n\tif (!syncShortcutsDebounce) {\n\t\tconst { debounce } = await import('@/core/utils/lodash');\n\t\tsyncShortcutsDebounce = debounce(syncShortcuts, 30);\n\t}\n\n\telsShortcutQueue.set(el, { value, modifiers });\n\n\tsyncShortcutsDebounce();\n};\n\nconst attachGlobalListener = () => {\n\tif (isListenerAttached) return;\n\tisListenerAttached = true;\n\n\tdocument.addEventListener('keydown', e => {\n\t\tif (!(e.target instanceof HTMLElement)) return;\n\t\tif (['INPUT', 'TEXTAREA'].includes(e.target.tagName) || e.target.isContentEditable) return;\n\n\t\tconst modifiers = {\n\t\t\tctrl: isMacOS() ? e.metaKey : e.ctrlKey,\n\t\t\talt: e.altKey,\n\t\t\tshift: e.shiftKey,\n\t\t};\n\n\t\tconst shortcut = genShortcutString(e.code, modifiers);\n\t\tconst element = elementByShortcut.get(shortcut);\n\n\t\tif (!element) return;\n\t\tif ((element as any).disabled || !isVisible(element)) return;\n\n\t\te.preventDefault();\n\t\telement.click();\n\t});\n};\n\nconst shortcut = {\n\tmounted: function (el: HTMLElement, binding: Binding) {\n\t\tconst { value, modifiers } = binding;\n\t\tif (!value || !isVisible(el)) return;\n\n\t\tattachGlobalListener();\n\t\tregisterShortcut(el, value, modifiers);\n\t},\n\n\tupdated: function (el: HTMLElement, binding: Binding) {\n\t\tif (!!el['__TOP_V_SHORTCUT_VALUE'] === isVisible(el)) return;\n\n\t\tconst { value, modifiers } = binding;\n\t\tif (!value) return;\n\n\t\tattachGlobalListener();\n\t\tvoid registerShortcutDebounce(el, value, modifiers);\n\t},\n\n\tunmounted: function (el: HTMLElement) {\n\t\tunregisterShortcut(el);\n\t},\n};\n\nexport default shortcut;\n","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\n\nlet appStickyObserver: IntersectionObserver;\n\n/**\n * Добавление sticky\n * К элементу добляется класс переданный как значение диррективы либо **'top-sticky'** по умолчанию\n */\nconst sticky = {\n\tmounted(el: HTMLElement, binding: DirectiveBinding, _vnode: VNode) {\n\t\tconst className = binding.value || 'top-sticky';\n\n\t\tappStickyObserver = new IntersectionObserver(entries => {\n\t\t\tlet condition = entries[0].intersectionRatio < 1;\n\t\t\tif (condition) {\n\t\t\t\tif (binding.modifiers.bottom && entries[0].intersectionRect.y === 0) condition = false;\n\t\t\t}\n\n\t\t\tel.classList.toggle(className, condition);\n\t\t}, {\n\t\t\tthreshold: [1],\n\t\t});\n\n\t\tappStickyObserver.observe(el);\n\t},\n\n\tunmounted(_el: HTMLElement, _binding: DirectiveBinding, _vnode: VNode) {\n\t\tappStickyObserver?.disconnect();\n\t},\n};\n\nexport default sticky;\n","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\nimport Core from '@/core/core/core';\n\ninterface HTMLElementWithSwimUpOptions extends HTMLElement {\n\tdirectiveSwipUpOptions: {\n\t\tdistance: number,\n\t\tpercent: number,\n\t};\n}\n\nlet appSwimUpInited = false;\nlet appSwimUpObserver: IntersectionObserver;\nconst appSwimUpEls = new Map();\n\n/**\n * Отодвинуть блок в зависимости от скролла старинцы\n * @param el\n * @param windowHeight\n */\nconst swimUpElTransform = (el: HTMLElementWithSwimUpOptions, windowHeight: number): void => {\n\tconst { distance, percent } = el.directiveSwipUpOptions;\n\n\tconst elTop = el.getBoundingClientRect().top;\n\n\t// во столько раз triggerHeight должен быть меньше, чтобы закончить подплытие к нужной высоте экрана\n\tconst triggerHeightReducer = windowHeight * percent / 100 / distance;\n\tconst triggerHeight = (windowHeight - elTop) / triggerHeightReducer;\n\n\tif (triggerHeight <= distance) {\n\t\tel.style.transform = `translateY(${distance - triggerHeight}px)`;\n\t} else {\n\t\tel.style.transform = 'translateY(0px)';\n\t}\n};\n\nconst swimUpInit = (_el: HTMLElementWithSwimUpOptions): void => {\n\tlet windowHeight = window.innerHeight;\n\n\twindow.addEventListener('scroll', () => {\n\t\tappSwimUpEls.forEach((el) => swimUpElTransform(el, windowHeight));\n\t}, { passive: true });\n\n\t// проверка того, что элемент в зоне видимости\n\tappSwimUpObserver = new IntersectionObserver(entries => {\n\t\twindowHeight = window.innerHeight;\n\n\t\tentries.forEach((entry) => {\n\t\t\tconst el = entry.target as HTMLElementWithSwimUpOptions;\n\n\t\t\tif (entry.intersectionRatio < 0.1) {\n\t\t\t\t// элемент за областью видимости\n\t\t\t\tappSwimUpEls.delete(el);\n\t\t\t} else {\n\t\t\t\t// элемент на экране\n\t\t\t\tappSwimUpEls.set(el, el);\n\t\t\t}\n\n\t\t\tif (entry.intersectionRatio === 0) {\n\t\t\t\tconst { distance } = el.directiveSwipUpOptions;\n\t\t\t\tel.style.transform = `translateY(${distance}px)`;\n\t\t\t}\n\t\t});\n\t}, {\n\t\tthreshold: 0.1,\n\t});\n};\n\n/**\n * Добавление анимации подплытия вверх для блока\n */\nconst swimUp = {\n\tmounted(el: HTMLElementWithSwimUpOptions, binding: DirectiveBinding, _vnode: VNode): void {\n\t\tif (Core.state.isMobileUA) return;\n\n\t\tel.directiveSwipUpOptions = {\n\t\t\tdistance: binding.value?.distance ?? 100, // количество px на которые блок изначально смещен вниз,\n\t\t\tpercent: binding.value?.percent ?? 30, // процент высоты экрана поднявшись на который блок закончит подплытие\n\t\t};\n\n\t\tif (!appSwimUpInited) {\n\t\t\tswimUpInit(el);\n\n\t\t\tappSwimUpInited = true;\n\t\t}\n\n\t\tappSwimUpObserver.observe(el);\n\t},\n\n\tunmounted(el: HTMLElementWithSwimUpOptions, _binding: DirectiveBinding, _vnode: VNode) {\n\t\tappSwimUpEls.delete(el);\n\t\tappSwimUpObserver?.unobserve(el);\n\t},\n};\n\nexport default swimUp;\n","import type { DirectiveBinding, ObjectDirective } from 'vue';\nimport Core from '@/core/core/core';\n\nconst $ = (el: HTMLElement) => {\n\tif (!Core.$?.ui?.tooltip) {\n\t\tconsole.info('Для работы v-top-tooltip требуется глобальная загрузка jQuery UI Tooltip');\n\n\t\treturn;\n\t}\n\n\treturn Core.$(el);\n};\n\nconst tvTooltipGenOptions = (binding: DirectiveBinding, el: HTMLElement): JQueryUI.TooltipOptions => {\n\tconst options = {\n\t\t...(binding.value ?? {}),\n\t} as JQueryUI.TooltipOptions;\n\n\toptions.content ??= el.getAttribute('ui-tooltip-title') ?? el.getAttribute('title') ?? '';\n\toptions.content = String(options.content).replace(/([^<>])\\r?\\n([^<>])/g, '$1<br>$2');\n\n\toptions.position ??= {\n\t\tmy: 'bottom-18px',\n\t\tat: 'top center',\n\t\tcollision: 'flipfit',\n\t};\n\n\treturn options;\n};\n\n/**\n * Добавление всплывающей подсказки к элементу.\n */\nconst tooltip: ObjectDirective<HTMLElement> = {\n\tmounted(el, binding) {\n\t\t$(el)?.tooltip(tvTooltipGenOptions(binding, el));\n\t},\n\n\tupdated(el, binding) {\n\t\t/**\n\t\t * В результате обновления может быть открыто несколько тултипов поэтому изменить опции, без перерисовки тултипа\n\t\t */\n\t\tconst options = tvTooltipGenOptions(binding, el);\n\t\tconst instance = $(el)?.tooltip('instance') as { options: JQueryUI.TooltipOptions } | undefined;\n\n\t\tif (!instance) {\n\t\t\t$(el)?.tooltip(options);\n\t\t\treturn;\n\t\t}\n\n\t\tinstance.options = {\n\t\t\t...instance.options,\n\t\t\t...options,\n\t\t};\n\t},\n\n\tunmounted(el) {\n\t\t$(el)?.tooltip('destroy');\n\t},\n};\n\nexport default tooltip;\n","import { defineAsyncComponent, type Plugin } from 'vue';\nimport type { PartialBy } from '@/components/types';\n\nimport Core from '@/core/core/core';\nimport coreDefaultOptions from '@/core/core/options';\n\nimport * as Forms from '../../components/forms/forms';\n\nconst TopNotice = defineAsyncComponent(() => import('@/components/core/notice/notice.vue'));\n\nimport type { Options as TopPopupOptions } from '@/components/popup/lib/worker';\nimport TopPopupWorker from '@/components/popup/lib/worker';\nimport TopPopupWorkerGlobalEvents from '@/components/popup/lib/worker.globalEvents';\n\nimport TopDialogs from '@/components/dialog/dialog/dialogs/dialogs.vue';\nimport { TopDialogWorker } from '@/components/dialog/lib/worker';\nimport type { TopDialogOptions } from '@/components/dialog/lib/types';\n\nimport directiveData from '@/core/directives/data';\nimport directiveFocus from '@/core/directives/focus';\nimport directiveScrollIntoView from '@/core/directives/scrollIntoView';\nimport directiveScrollShadow from '@/core/directives/scrollShadow';\nimport directiveShortcut from '@/core/directives/shortcut';\nimport directiveSticky from '@/core/directives/sticky';\nimport directiveSwimUp from '@/core/directives/swimUp';\nimport directiveTooltip from '@/core/directives/tooltip';\n\ndeclare global {\n\tconst vd: typeof console.log;\n}\n\nwindow['vd'] = console.log;\n\ndeclare module '@vue/runtime-core' {\n\tinterface ComponentCustomProperties {\n\t\t/**\n\t\t * Статический класс с текущим состоянимем UI\n\t\t */\n\t\t$core: typeof Core;\n\n\t\t$vd: typeof console.log;\n\t}\n\n\t/**\n\t * Обязательные компоненты UI\n\t *\n\t * Они подключаются через плагин и доступны без явного указания импорта\n\t */\n\texport interface GlobalComponents {\n\t\tTopAvatar: typeof Forms.TopAvatar;\n\t\tTopButton: typeof Forms.TopButton;\n\t\tTopCheckbox: typeof Forms.TopCheckbox;\n\t\tTopControlLabel: typeof Forms.TopControlLabel;\n\t\tTopHint: typeof Forms.TopHint;\n\t\tTopInput: typeof Forms.TopInput;\n\t\tTopInputDate: typeof Forms.TopInputDate;\n\t\tTopInputRange: typeof Forms.TopInputRange;\n\t\tTopRadio: typeof Forms.TopRadio;\n\t\tTopSwitcher: typeof Forms.TopSwitcher;\n\t\tTopTextarea: typeof Forms.TopTextarea;\n\t\tTopSelect: typeof Forms.TopSelect;\n\t\tTopLoadbar: typeof Forms.TopLoadbar;\n\n\t\tTopNotice: typeof TopNotice;\n\t\tTopDialogs: typeof TopDialogs;\n\t}\n}\n\ntype CoreOptions = PartialBy<typeof coreDefaultOptions, 'timezoneOffset' | 'documentClassModificators'>;\n\ntype Options = CoreOptions & {\n\ttopPopupOptions?: TopPopupOptions\n\ttopDialogOptions?: TopDialogOptions\n};\n\n/**\n * Плагин для интеграции UI во Vue приложение\n *\n * - В глобальную область видимости шаблонов будет добавлен объект $core\n * - Будут зарегистрирвоаны директивы UI: https://ui.topvisor.com/?path=/docs/core-directives-focus--docs\n * - Будут подключены базовые компоненты UI/Forms: https://ui.topvisor.com/?path=/docs/components-forms-readme--docs\n */\nexport default {\n\n\tinstall: (app, options: Options) => {\n\t\tapp.config.globalProperties.$core = Core;\n\t\tapp.config.globalProperties.$vd = console.log;\n\n\t\t// начальные настройки UI\n\t\tfor (const name in options) {\n\t\t\tCore.state[name] = options[name];\n\t\t}\n\n\t\tif (options.widthForMobile) Core.widthForMobile = options.widthForMobile;\n\t\tif (options.themeName) Core.themeName = options.themeName;\n\n\t\tCore._setState();\n\n\t\tif (options.topPopupOptions) TopPopupWorker.options = options.topPopupOptions;\n\t\tTopPopupWorkerGlobalEvents.init();\n\n\t\tTopDialogWorker.init(options.topDialogOptions);\n\n\t\t// определение директив\n\t\tapp.directive('top-data', directiveData);\n\t\tapp.directive('top-focus', directiveFocus);\n\t\tapp.directive('top-scroll-into-view', directiveScrollIntoView);\n\t\tapp.directive('top-scroll-shadow', directiveScrollShadow);\n\t\tapp.directive('top-shortcut', directiveShortcut);\n\t\tapp.directive('top-sticky', directiveSticky);\n\t\tapp.directive('top-swim-up', directiveSwimUp);\n\t\tapp.directive('top-tooltip', directiveTooltip);\n\n\t\t// определение базовых компонентов\n\t\tapp.component('TopAvatar', Forms.TopAvatar);\n\t\tapp.component('TopButton', Forms.TopButton);\n\t\tapp.component('TopCheckbox', Forms.TopCheckbox);\n\t\tapp.component('TopControlLabel', Forms.TopControlLabel);\n\t\tapp.component('TopHint', Forms.TopHint);\n\t\tapp.component('TopInput', Forms.TopInput);\n\t\tapp.component('TopInputDate', Forms.TopInputDate);\n\t\tapp.component('TopInputRange', Forms.TopInputRange);\n\t\tapp.component('TopLoadbar', Forms.TopLoadbar);\n\t\tapp.component('TopRadio', Forms.TopRadio);\n\t\tapp.component('TopSelect', Forms.TopSelect);\n\t\tapp.component('TopSwitcher', Forms.TopSwitcher);\n\t\tapp.component('TopTextarea', Forms.TopTextarea);\n\n\t\tapp.component('TopNotice', TopNotice);\n\t\tapp.component('TopDialogs', TopDialogs);\n\t},\n\n} satisfies Plugin<Options>;\n","import type { PiniaPluginContext, Store } from 'pinia';\nimport { watch } from 'vue';\nimport { debounce } from '@/core/utils/lodash';\nimport { guestLinkToClipboard } from '@/core/utils/clipboard';\nimport { camelToSnakeCase } from '@/core/utils/string.js';\nimport { getHash, setHash } from '@/core/utils/route';\n\nclass PiniaTPA {\n\n\treadonly #storeId: string;\n\treadonly #store: Store<string, any>;\n\n\t/**\n\t * @deprecated\n\t */\n\treadonly #Page: any;\n\n\treadonly #user: any;\n\treadonly #Api: Api.Client<Api.TV.Paths, true>;\n\n\treadonly #namesUrlHash: string[] = [];\n\treadonly #namesStorage: string[] = [];\n\treadonly #namesStorageLocal: string[] = [];\n\treadonly #namesGuestLink: string[] = [];\n\n\tconstructor(context: Context) {\n\t\tthis.#store = context.store;\n\t\tthis.#storeId = this.#store.$id;\n\n\t\tthis.#Page = context.options.Page;\n\n\t\tthis.#user = context.options.user;\n\t\tthis.#Api = context.options.Api;\n\n\t\tthis.#namesUrlHash = context.options.tpaNamesUrlHash || [];\n\t\tthis.#namesStorage = context.options.tpaNamesStorage || [];\n\t\tthis.#namesStorageLocal = context.options.tpaNamesStorageLocal || [];\n\t\tthis.#namesGuestLink = context.options.tpaNamesGuestLink || [];\n\n\t\tcontext.store.genGuestLink = <Path extends Api.TV.Path>(path: Path, params: Api.TV.Params<Path>) => this.genGuestLink(path, params);\n\n\t\tif (!this.#user.guest_data?.data) {\n\t\t\tthis.#loadFromStorage();\n\t\t\tthis.#loadFromStorage(true);\n\n\t\t\t// настройки URL hash имеют приоритет\n\t\t\tthis.#loadFromHash();\n\t\t}\n\n\t\t// настройки гостевой ссылки имеют приоритет\n\t\tthis.#loadFromGuestLink();\n\n\t\tthis.#prepareParams();\n\n\t\tconst save = debounce(() => {\n\t\t\tthis.#saveInHash();\n\t\t\tthis.#saveInStorage();\n\t\t\tthis.#saveInStorage(true);\n\t\t});\n\n\t\tcontext.store.$subscribe(save);\n\t}\n\n\t/**\n\t * Сгенерировать гостевую ссылку\n\t *\n\t * Метод, путь к которому указан в path, должен возвращать сгенерированную ссылку\n\t */\n\tasync genGuestLink<Path extends Api.TV.Path>(path: Path, params: Api.TV.Params<Path>) {\n\t\tconst dataGuestLink = this.#genOptionsForGuestLink();\n\t\tparams = Object.assign(params, Object.fromEntries(dataGuestLink));\n\n\t\tconst res = await this.#Api.gen(path).setParams(params).call();\n\t\tif (res?.errors) return;\n\n\t\tconst link = res.result as string;\n\n\t\tawait guestLinkToClipboard(link);\n\t}\n\n\t/**\n\t * Сгенерировать опции для гостевой ссылки\n\t */\n\t#genOptionsForGuestLink() {\n\t\tconst data = new Map();\n\n\t\tthis.#namesGuestLink.forEach(name => {\n\t\t\t// формат параметров API: snake_case\n\t\t\tconst nameSnakeCase = camelToSnakeCase(name);\n\t\t\tdata.set(nameSnakeCase, this.#store[name]);\n\t\t});\n\n\t\treturn data;\n\t}\n\n\t/**\n\t * Установить опции из объекта без фиксации состояния\n\t */\n\t#setOptions(data: Map<string, any>) {\n\t\tdata.forEach((value, name) => {\n\t\t\tconst currentValue = this.#store[name];\n\n\t\t\tif (value === null || value === undefined) return;\n\t\t\tif (currentValue === undefined) return;\n\t\t\tif (!value?.constructor) return;\n\t\t\tif (value.constructor !== currentValue.constructor) return;\n\n\t\t\t// дополнительная проверка на формат даты\n\t\t\tif (name.indexOf('date') === 0) {\n\t\t\t\tif (Array.isArray(value)) {\n\t\t\t\t\t// value.forEach((valueI) => {\n\t\t\t\t\t// \tif (!/\\d\\d\\d\\d-\\d\\d-\\d\\d/.test(valueI)) return;\n\t\t\t\t\t// });\n\t\t\t\t} else {\n\t\t\t\t\tif (typeof (value) === 'string') {\n\t\t\t\t\t\tif (!/\\d\\d\\d\\d-\\d\\d-\\d\\d/.test(value)) return;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis.#store[name] = value;\n\t\t});\n\t}\n\n\t/**\n\t * Сгенерировать Map объект с опциями со значениями в виде json строк\n\t */\n\t#genDataFormat(data: Map<string, any>) {\n\t\tconst dataFormatted = new Map();\n\n\t\tdata.forEach((value, name) => {\n\t\t\tif (value === null) return;\n\n\t\t\tvalue = JSON.stringify(value);\n\n\t\t\tdataFormatted.set(name, value);\n\t\t});\n\n\t\treturn dataFormatted;\n\t}\n\n\t/**\n\t * Сгенерировать Map объект с опциями со значениями в оригинальном виде\n\t */\n\t#genDataUnFormat(dataFormatted: Map<string, string>) {\n\t\tconst data: Map<string, any> = new Map();\n\n\t\tdataFormatted.forEach((value, name) => {\n\t\t\tif (value === null || value === undefined || value === 'false') return;\n\n\t\t\ttry {\n\t\t\t\tif (typeof (value) === 'string' && !/^\\d\\d\\d\\d-\\d\\d-\\d\\d$/.test(value)) value = JSON.parse(value);\n\n\t\t\t\tif (value === null || value === undefined || value === 'false') return;\n\t\t\t} catch (e) {\n\t\t\t\t// не json строка\n\t\t\t}\n\n\t\t\tdata.set(name, value);\n\t\t});\n\n\t\treturn data;\n\t}\n\n\t/**\n\t * Установить опции из хеша адреса страницы\n\t */\n\t#loadFromHash() {\n\t\tlet dataHash: any;\n\t\ttry {\n\t\t\tdataHash = JSON.parse(getHash(this.#storeId));\n\t\t} catch (e) {\n\n\t\t}\n\t\tif (!dataHash) return;\n\n\t\tconst data: Map<string, any> = new Map();\n\n\t\tthis.#namesUrlHash.forEach((name) => {\n\t\t\tconst value = dataHash[name];\n\t\t\tif (!value) return;\n\n\t\t\tdata.set(name, value);\n\t\t});\n\n\t\tthis.#setOptions(data);\n\t}\n\n\t/**\n\t * Сохранить опции в хеш адреса страницы\n\t */\n\t#saveInHash() {\n\t\tconst data = new Map();\n\n\t\tthis.#namesUrlHash.forEach((name) => {\n\t\t\tconst value = this.#store[name];\n\n\t\t\tdata.set(name, value);\n\t\t});\n\n\t\tconst dataObject = Object.fromEntries(data);\n\t\tconst dataJSON = JSON.stringify(dataObject);\n\n\t\tsetHash(this.#storeId, dataJSON);\n\t};\n\n\t/**\n\t * Установить опции из localStorage\n\t * @param isLocal - сохранить с учетом адреса страницы\n\t */\n\t#loadFromStorage(isLocal = false) {\n\t\tconst dataFormatted = new Map();\n\n\t\tlet names = this.#namesStorage;\n\t\tlet storageNamespace = 'state:' + this.#storeId;\n\n\t\tif (isLocal) {\n\t\t\tnames = this.#namesStorageLocal;\n\t\t\tstorageNamespace = 'state:' + this.#storeId + ':' + location.pathname;\n\t\t}\n\n\t\tnames.forEach((name) => {\n\t\t\tconst value = localStorage.getItem(storageNamespace + ':' + name);\n\t\t\tdataFormatted.set(name, value);\n\t\t});\n\n\t\tconst data = this.#genDataUnFormat(dataFormatted);\n\n\t\tthis.#setOptions(data);\n\t}\n\n\t/**\n\t * Сохранить опции в localStorage\n\t * @param isLocal - сохранить с учетом адреса страницы\n\t */\n\t#saveInStorage(isLocal = false) {\n\t\tconst data = new Map();\n\n\t\tlet names = this.#namesStorage;\n\t\tlet storageNamespace = 'state:' + this.#storeId;\n\n\t\tif (isLocal) {\n\t\t\tnames = this.#namesStorageLocal;\n\t\t\tstorageNamespace = 'state:' + this.#storeId + ':' + location.pathname;\n\t\t}\n\n\t\tnames.forEach((name) => {\n\t\t\tconst value = this.#store[name];\n\n\t\t\tdata.set(name, value);\n\t\t});\n\n\t\tconst dataFormatted = this.#genDataFormat(data);\n\n\t\tnames.forEach((name) => {\n\t\t\tconst value = dataFormatted.get(name);\n\n\t\t\tlocalStorage.setItem(storageNamespace + ':' + name, value);\n\t\t});\n\t}\n\n\t/**\n\t * Установить опции из гостевой ссылки\n\t */\n\t#loadFromGuestLink() {\n\t\tconst guestData = this.#user?.guest_data?.data;\n\t\tif (!guestData) return;\n\n\t\t// общие правила для гостевых сессий\n\t\tif (this.#user.id === -1) this.#user.positionsReverseDates = guestData.positionsReverseDates;\n\n\t\tconst dataFormatted = new Map();\n\n\t\tthis.#namesGuestLink.forEach((name) => {\n\t\t\tconst value = guestData[name];\n\t\t\tdataFormatted.set(name, value);\n\t\t});\n\n\t\tconst data = this.#genDataUnFormat(dataFormatted);\n\n\t\tthis.#setOptions(data);\n\n\t\tconst $guestTitle = $('.mod_guest_title');\n\n\t\t// TODO: вынести в опции плагина\n\t\tif (this.#store.competitorsIds?.length === 1 && this.#Page.page.data.competitors) {\n\t\t\tlet competitors = this.#Page.page.data.competitors.filter((competitor: any) => competitor.id === guestData.competitorsIds[0]);\n\t\t\tif (competitors.length) {\n\t\t\t\t$('a', $guestTitle).attr('href', 'http://' + competitors[0].url);\n\t\t\t\t$('a', $guestTitle).text(competitors[0].name);\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Подготовить входные параметры перед инициализацией основного функционала\n\t *\n\t * Входные параметры устанавливаются при открытии страницы\n\t *\n\t * Входные параметры могут меняться пользоваталем и устаревать\n\t */\n\t#prepareParams() {\n\t\t// контролль за вводом регионов\n\t\t// TODO: вынести в опции плагина\n\t\tif (this.#store.regionsIndexes) {\n\t\t\twatch(this.#store.regionsIndexes, (regionsIndexes) => {\n\t\t\t\tif (!regionsIndexes.length) return;\n\n\t\t\t\t// приведение типа\n\t\t\t\tregionsIndexes.forEach((regionIndex: number, index: number) => regionsIndexes[index] = regionIndex);\n\n\t\t\t\t// оставить только включенные регионы\n\t\t\t\t// @ts-ignore\n\t\t\t\tconst mapSearchers = TplProjectSelectorRegion.genSearchersMap();\n\n\t\t\t\tconst availableRegionsIndexes: number[] = [];\n\t\t\t\tmapSearchers.forEach((searcher: any) => {\n\t\t\t\t\tsearcher.regions.forEach((region: any) => {\n\t\t\t\t\t\tif (region.index === -1) return;\n\n\t\t\t\t\t\tavailableRegionsIndexes.push(region.index);\n\t\t\t\t\t});\n\t\t\t\t});\n\n\t\t\t\tthis.#store.regionsIndexes = regionsIndexes.filter((regionIndex: number) => availableRegionsIndexes.includes(regionIndex));\n\t\t\t}, { immediate: true });\n\t\t}\n\n\t\t// контролль за вводом конкурентов\n\t\t// TODO: вынести в опции плагина\n\t\tif (this.#store.competitorsIds) {\n\t\t\twatch(this.#store.competitorsIds, (competitorsIds) => {\n\t\t\t\tif (!competitorsIds.length) return;\n\n\t\t\t\t// приведение типа\n\t\t\t\tcompetitorsIds.forEach((competitorId: number, index: number) => competitorsIds[index] = competitorId);\n\n\t\t\t\t// оставить только включенных конкурентов\n\t\t\t\tconst availableCompetitorsIds = [this.#Page.page.data.project.id];\n\t\t\t\tthis.#Page.page.data.project.competitors.forEach((competitor: any) => {\n\t\t\t\t\tif (competitor.on >= 0) availableCompetitorsIds.push(competitor.id);\n\t\t\t\t});\n\n\t\t\t\tthis.#store.competitorsIds = competitorsIds.filter((competitorId: number) => availableCompetitorsIds.includes(competitorId));\n\t\t\t}, { immediate: true });\n\t\t}\n\t}\n\n}\n\ntype Options = {\n\t/**\n\t * TODO: Убрать из плагина\n\t */\n\tPage: any,\n\n\t/**\n\t * Объект с настройками пользователя\n\t */\n\tuser: any,\n\n\t/**\n\t * Объект для работы с API\n\t *\n\t * См. на сайте: @/component/api/core/api.ts\n\t */\n\tApi: Api.Client<Api.TV.Paths, true>;\n\n\t/**\n\t * Имена свойств для сохранения в URL\n\t */\n\ttpaNamesUrlHash?: string[],\n\n\t/**\n\t * Имена свойств для сохранения в localStorage\n\t */\n\ttpaNamesStorage?: string[],\n\n\t/**\n\t * Имена свойств для сохранения в localStorage с учетом пути URL\n\t *\n\t * Каждый URL будет работать со своим состоянием\n\t */\n\ttpaNamesStorageLocal?: string[],\n\n\t/**\n\t * Имена свойств для работы с гостевой ссылкой\n\t *\n\t * Для генерации гостевой ссылки используйте store.genGuestLink(data, url)\n\t */\n\ttpaNamesGuestLink?: string[],\n};\n\ntype Context = PiniaPluginContext & {\n\toptions: Options\n};\n\n/**\n * Плагин tpa (Third-party access) для pinia\n *\n * Добавляет возможность сохранять и загружать данные в/из:\n * \t- URL hash в адресе страницы\n * \t- localStorage\n * \t- гостевая ссылка\n *\n * Для подключения плагина нужно указань одну или несколько опций при определении defineStore():\n * - tpaNamesUrlHash\n * - tpaNamesStorage\n * - tpaNamesStorageLocal\n * - tpaNamesGuestLink\n */\nexport default (contextPinia: PiniaPluginContext) => {\n\tconst context = contextPinia as Context;\n\n\t// плагин подключать не нужно\n\tif (\n\t\t!context.options.tpaNamesUrlHash?.length &&\n\t\t!context.options.tpaNamesStorage?.length &&\n\t\t!context.options.tpaNamesStorageLocal?.length &&\n\t\t!context.options.tpaNamesGuestLink?.length\n\t) {\n\t\treturn;\n\t}\n\n\tnew PiniaTPA(context);\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
define([`require`,`exports`,`./forms-CbUt-6Ff.amd.js`,`vue`],function(e,t,n,r){"use strict";Object.defineProperty(t,`__esModule`,{value:!0}),t.connectDatepicker=a,t.oninput=u,n.O.insertStyleToPage(`.ui-datepicker{--datepicker-day-color:var(--color-layout-front-1);--datepicker-day-color-hover:var(--color-layer-1);--datepicker-selected-color:var(--color-bg-primary-1);--datepicker-selected-color-hover:var(--color-bg-primary-2);--datepicker-range-color:var(--color-layer-primary-1);--datepicker-range-color-hover:var(--color-layer-primary-2);-webkit-user-select:none;user-select:none;width:auto;padding:0}.ui-datepicker:before,.ui-datepicker:after{display:none}.ui-datepicker-inline{display:inline-block!important}.ui-datepicker:not(.ui-datepicker-inline){background:var(--color-layout-front-1);box-shadow:var(--top-shadow);border-radius:8px;padding:8px;z-index:10000000!important}.ui-datepicker a{text-decoration:none!important}.ui-datepicker option{color:var(--color-text-1);font-size:14px}.ui-datepicker-header{align-items:center;margin:0 0 18px;display:flex;padding:0!important}.ui-datepicker-header>*{justify-content:center;align-items:center;display:flex}.ui-datepicker-title{height:24px;width:100%!important;margin:0!important}.ui-datepicker-month,.ui-datepicker-year{text-align:center;border:none;padding:0;outline:none!important;width:auto!important;margin:0 6px!important;font-size:16px!important}.ui-datepicker-month{color:var(--color-text-1)}.ui-datepicker-year{color:var(--color-text-2)}select.ui-datepicker-month,select.ui-datepicker-year{cursor:pointer}.ui-datepicker-prev,.ui-datepicker-next{cursor:pointer;font-family:Topvisor-2;font-size:24px;width:24px!important;height:24px!important;position:static!important}.ui-datepicker-prev:before{color:var(--color-text-3);content:""}.ui-datepicker-prev-hover:before{color:var(--color-text-1);content:""}.ui-datepicker-next{color:var(--color-text-3);order:1}.ui-datepicker-next-hover{color:var(--color-text-1);order:1}.ui-datepicker-next:before{content:""}.ui-datepicker-prev>*,.ui-datepicker-next>*{display:none!important}.ui-datepicker thead th{color:var(--color-text-3);font-size:14px;width:auto!important;padding:0!important;font-weight:400!important}.ui-datepicker table{font-size:14px;margin:0!important}.ui-datepicker td{color:var(--color-text-1);background:0 0;padding:0!important}.ui-datepicker td span,.ui-datepicker td a{text-align:center;border:none;border-radius:8px;min-width:32px;height:32px;margin:1px;padding:0;line-height:32px;display:block;position:relative;color:var(--color-text-1)!important}.ui-datepicker td a{background:var(--datepicker-day-color)}.ui-datepicker td a:hover{background:var(--datepicker-day-color-hover)}td.ui-datepicker-today span,td.ui-datepicker-today a{background:0 0;position:relative}.ui-datepicker td.selected a{background:var(--datepicker-range-color);margin-left:0;margin-right:1px;padding-left:1px;padding-right:0}.ui-datepicker td.selected a:hover{background:var(--datepicker-range-color-hover)}.ui-datepicker td.selected:not(.selected-start):not(:first-child):not(.first-of-month) a{border-top-left-radius:0;border-bottom-left-radius:0;margin-left:0;padding-left:1px}.ui-datepicker td.selected:not(.selected-end):not(:last-child):not(.last-of-month) a{border-top-right-radius:0;border-bottom-right-radius:0;margin-right:0;padding-right:1px}.ui-datepicker td.selected-start a,.ui-datepicker td.selected-end a,.ui-datepicker td.ui-datepicker-current-day a{background:var(--datepicker-selected-color);color:#fff!important}.ui-datepicker td.selected-start a:hover,.ui-datepicker td.selected-end a:hover,.ui-datepicker td.ui-datepicker-current-day a:hover{background:var(--datepicker-selected-color-hover)}.ui-datepicker-day-marks{justify-content:center;align-items:center;line-height:normal;display:flex;position:absolute;bottom:3px;left:0;right:0}.ui-datepicker-day-marks>i{border:1px solid #fff;border-radius:50%;width:4px;height:4px;margin:0 2px}.ui-datepicker-day-marks-exists{background:var(--color-text-primary)}.ui-datepicker-day-marks-update{background:var(--color-text-negative)}.ui-datepicker-row-break{display:none}`);var i=e=>{if(!n.O.$?.ui?.datepicker){console.info(`Для работы datepicker требуется глобальная загрузка jQuery UI Datepicker`);return}return n.O.$.datepicker.setDefaults({dateFormat:n.O.state.dateFormat.toLowerCase().replace(`m`,`mm`).replace(`y`,`yy`).replace(`d`,`dd`)}),n.O.$(e)};function a(e,t){return i(e)?.datepicker(t)}var o,s,c,l;(0,r.watch)((0,r.toRef)(n.O.state.dateFormat),()=>{o=(0,n._)(`2000-01-01`),s=o.match(/\D/)?.[0]??`-`,c=o.replace(/\D+/g,``).length,l=[];for(let e=0;e<o.length;e++)o[e]===s&&l.push(e)},{immediate:!0});function u(e){let t=e.target.selectionEnd,n=e.target.value,r=n.substring(0,t).replace(/\D+/g,``),i=n.substring(t).replace(/\D+/g,``),a=r.length+i.length-c;if(a>0){r=r.substring(0,c);let e=c-r.length;i=i.substring(i.length-e)}else a<0&&(e.inputType===`deleteContentForward`?r+=`0`.repeat(-a):i=`0`.repeat(-a)+i);t=r.length,n=r+i;for(let e=0;e<l.length;e++){let r=l[e];n=n.substring(0,r)+s+n.substring(r),t>=r&&t++}e.inputType===`deleteContentBackward`&&n[t-1]===s&&t--,n!==e.target.value&&(e.target.value=n,e.target.selectionStart=t,e.target.selectionEnd=t)}});
|
|
2
|
+
//# sourceMappingURL=datepicker-BTkZOq7d.amd.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[".chunks/datepicker-BTkZOq7d.esm.js","../../src/components/forms/inputDate/datepicker.ts"],"names":["exports","forms_CbUt_6Ff_esm_js_1","t","vue_1"],"mappings":"AAAA,OAAO,CAAC,UAAW,UAAW,0BAA2B,MAAM,CAAE,SAAU,EAAS,EAAS,EAAyB,EAAO,CACzH,aACA,OAAO,eAAeA,EAAS,aAAc,CAAE,MAAO,GAAM,CAAC,CAC7D,EAAQ,kBAAoB,ECG3B,EAAA,QAAA,EAIHC,EAAa,EAAA,kBAAA,q2HAA2E,CAExF,IAAA,EAAA,GAAA,CDHM,GAAI,CAACA,EAAwB,EAAE,GAAG,IAAI,WAAY,CCMlD,QAAA,KAAW,2EACiD,CDLxD,OCYJ,OAAOA,EAAmB,EAAA,EAAA,WAAA,YAAA,CAAA,WAAAA,EAAA,EAAA,MAAA,WAAA,aAAA,CAAA,QAAA,IAAA,KAAA,CAAA,QAAA,IAAA,KAAA,CAAA,QAAA,IAAA,KAAA,CAAA,CAAA,CAAAA,EAAA,EAAA,EAAAC,EAAA,EAG9B,SAGA,EAAA,EAAA,EAAA,CAEa,OAAM,EAAA,EAAA,EAAA,WAAmB,EAAA,CAOzC,IAAK,EAAI,EAAI,EAAG,GAKZ,EAAAC,EAAA,QAAkB,EAAAA,EAAA,OAAAF,EAAA,EAAA,MAAA,WAAA,KAAA,CAKvB,GAAwB,EAAQA,EAAA,GAAA,aAAA,CAAA,EAAA,EAAA,MAAA,KAAA,GAAA,IAAA,IAAA,EAAA,EAAA,QAAA,OAAA,GAAA,CAAA,OAAA,EAAA,EAAA,CAC3B,IAAiB,IAAA,EAAO,EAAA,EAAA,EAAA,OACd,IAQa,EAAA,KAAA,GAAA,EAAA,KAAA,EAAA,EAET,CAAe,UAAU,CAAG,EAAiB,CAAA,CAE9D,SAAiC,EAAmB,EAAe,CACjC,IAAA,EAAA,EAAU,OAAgB,aAAkC,EAAA,EAAA,OAAA,MAAA,EAAA,EAAA,UAAA,EAAA,EAAA,CAAA,QAAA,OAAA,GAAA,CAAA,EAAA,EAAA,UAAA,EAAA,CAAA,QAAA,OAAA,GAAA,CAAA,EAAA,EAAA,OAAA,EAAA,OAAA,EACpF,GAAoB,EAAA,EAE1B,CAQyB,EAC9B,EAAA,UAAyB,EAAA,EAAA,CAGhB,IAAI,EAAG,EAAsB,EAAA,OACI,EAAA,EAAA,UAAA,EAAA,OAAA,EAAA,MAWpC,EAAA,IAAc,EAAA,YAAA,uBACnB,GAIG,IAAA,OAAY,CAAA,EAAO,CAAA,EAAA,IACtB,OAAE,CAAO,EAAA,CAAA,GD/DH,EAAI,EAAE,OAAQ,EAAI,EAAI,EACtB,IAAK,IAAI,EAAI,EAAG,EAAI,EAAE,OAAQ,IAAK,CAC/B,IAAI,EAAI,EAAE,GACV,EAAI,EAAE,UAAU,EAAG,EAAE,CAAG,EAAI,EAAE,UAAU,EAAE,CAAE,GAAK,GAAK,IAE1D,EAAE,YAAc,yBAA2B,EAAE,EAAI,KAAO,GAAK,IAAK,IAAM,EAAE,OAAO,QAAU,EAAE,OAAO,MAAQ,EAAG,EAAE,OAAO,eAAiB,EAAG,EAAE,OAAO,aAAe,KAE1K","sourcesContent":["define([\"require\", \"exports\", \"./forms-CbUt-6Ff.esm.js\", \"vue\"], function (require, exports, forms_CbUt_6Ff_esm_js_1, vue_1) {\n \"use strict\";\n Object.defineProperty(exports, \"__esModule\", { value: true });\n exports.connectDatepicker = a;\n exports.oninput = u;\n //#endregion\n //#region src/components/forms/inputDate/datepicker.ts\n forms_CbUt_6Ff_esm_js_1.O.insertStyleToPage(\".ui-datepicker{--datepicker-day-color:var(--color-layout-front-1);--datepicker-day-color-hover:var(--color-layer-1);--datepicker-selected-color:var(--color-bg-primary-1);--datepicker-selected-color-hover:var(--color-bg-primary-2);--datepicker-range-color:var(--color-layer-primary-1);--datepicker-range-color-hover:var(--color-layer-primary-2);-webkit-user-select:none;user-select:none;width:auto;padding:0}.ui-datepicker:before,.ui-datepicker:after{display:none}.ui-datepicker-inline{display:inline-block!important}.ui-datepicker:not(.ui-datepicker-inline){background:var(--color-layout-front-1);box-shadow:var(--top-shadow);border-radius:8px;padding:8px;z-index:10000000!important}.ui-datepicker a{text-decoration:none!important}.ui-datepicker option{color:var(--color-text-1);font-size:14px}.ui-datepicker-header{align-items:center;margin:0 0 18px;display:flex;padding:0!important}.ui-datepicker-header>*{justify-content:center;align-items:center;display:flex}.ui-datepicker-title{height:24px;width:100%!important;margin:0!important}.ui-datepicker-month,.ui-datepicker-year{text-align:center;border:none;padding:0;outline:none!important;width:auto!important;margin:0 6px!important;font-size:16px!important}.ui-datepicker-month{color:var(--color-text-1)}.ui-datepicker-year{color:var(--color-text-2)}select.ui-datepicker-month,select.ui-datepicker-year{cursor:pointer}.ui-datepicker-prev,.ui-datepicker-next{cursor:pointer;font-family:Topvisor-2;font-size:24px;width:24px!important;height:24px!important;position:static!important}.ui-datepicker-prev:before{color:var(--color-text-3);content:\\\"\\\"}.ui-datepicker-prev-hover:before{color:var(--color-text-1);content:\\\"\\\"}.ui-datepicker-next{color:var(--color-text-3);order:1}.ui-datepicker-next-hover{color:var(--color-text-1);order:1}.ui-datepicker-next:before{content:\\\"\\\"}.ui-datepicker-prev>*,.ui-datepicker-next>*{display:none!important}.ui-datepicker thead th{color:var(--color-text-3);font-size:14px;width:auto!important;padding:0!important;font-weight:400!important}.ui-datepicker table{font-size:14px;margin:0!important}.ui-datepicker td{color:var(--color-text-1);background:0 0;padding:0!important}.ui-datepicker td span,.ui-datepicker td a{text-align:center;border:none;border-radius:8px;min-width:32px;height:32px;margin:1px;padding:0;line-height:32px;display:block;position:relative;color:var(--color-text-1)!important}.ui-datepicker td a{background:var(--datepicker-day-color)}.ui-datepicker td a:hover{background:var(--datepicker-day-color-hover)}td.ui-datepicker-today span,td.ui-datepicker-today a{background:0 0;position:relative}.ui-datepicker td.selected a{background:var(--datepicker-range-color);margin-left:0;margin-right:1px;padding-left:1px;padding-right:0}.ui-datepicker td.selected a:hover{background:var(--datepicker-range-color-hover)}.ui-datepicker td.selected:not(.selected-start):not(:first-child):not(.first-of-month) a{border-top-left-radius:0;border-bottom-left-radius:0;margin-left:0;padding-left:1px}.ui-datepicker td.selected:not(.selected-end):not(:last-child):not(.last-of-month) a{border-top-right-radius:0;border-bottom-right-radius:0;margin-right:0;padding-right:1px}.ui-datepicker td.selected-start a,.ui-datepicker td.selected-end a,.ui-datepicker td.ui-datepicker-current-day a{background:var(--datepicker-selected-color);color:#fff!important}.ui-datepicker td.selected-start a:hover,.ui-datepicker td.selected-end a:hover,.ui-datepicker td.ui-datepicker-current-day a:hover{background:var(--datepicker-selected-color-hover)}.ui-datepicker-day-marks{justify-content:center;align-items:center;line-height:normal;display:flex;position:absolute;bottom:3px;left:0;right:0}.ui-datepicker-day-marks>i{border:1px solid #fff;border-radius:50%;width:4px;height:4px;margin:0 2px}.ui-datepicker-day-marks-exists{background:var(--color-text-primary)}.ui-datepicker-day-marks-update{background:var(--color-text-negative)}.ui-datepicker-row-break{display:none}\");\n var i = (t) => {\n if (!forms_CbUt_6Ff_esm_js_1.O.$?.ui?.datepicker) {\n console.info(\"Для работы datepicker требуется глобальная загрузка jQuery UI Datepicker\");\n return;\n }\n return forms_CbUt_6Ff_esm_js_1.O.$.datepicker.setDefaults({ dateFormat: forms_CbUt_6Ff_esm_js_1.O.state.dateFormat.toLowerCase().replace(\"m\", \"mm\").replace(\"y\", \"yy\").replace(\"d\", \"dd\") }), forms_CbUt_6Ff_esm_js_1.O.$(t);\n };\n function a(e, t) {\n return i(e)?.datepicker(t);\n }\n var o, s, c, l;\n (0, vue_1.watch)((0, vue_1.toRef)(forms_CbUt_6Ff_esm_js_1.O.state.dateFormat), () => {\n o = (0, forms_CbUt_6Ff_esm_js_1._)(\"2000-01-01\"), s = o.match(/\\D/)?.[0] ?? \"-\", c = o.replace(/\\D+/g, \"\").length, l = [];\n for (let e = 0; e < o.length; e++)\n o[e] === s && l.push(e);\n }, { immediate: !0 });\n function u(e) {\n let t = e.target.selectionEnd, n = e.target.value, r = n.substring(0, t).replace(/\\D+/g, \"\"), i = n.substring(t).replace(/\\D+/g, \"\"), a = r.length + i.length - c;\n if (a > 0) {\n r = r.substring(0, c);\n let e = c - r.length;\n i = i.substring(i.length - e);\n }\n else\n a < 0 && (e.inputType === \"deleteContentForward\" ? r += \"0\".repeat(-a) : i = \"0\".repeat(-a) + i);\n t = r.length, n = r + i;\n for (let e = 0; e < l.length; e++) {\n let r = l[e];\n n = n.substring(0, r) + s + n.substring(r), t >= r && t++;\n }\n e.inputType === \"deleteContentBackward\" && n[t - 1] === s && t--, n !== e.target.value && (e.target.value = n, e.target.selectionStart = t, e.target.selectionEnd = t);\n }\n});\n//# sourceMappingURL=datepicker-BTkZOq7d.esm.js.map\n","import { toRef, watch } from 'vue';\nimport Core from '@/core/core/core';\nimport { dateFormat } from '@/core/utils/date';\n\nimport css from '@/components/forms/inputDate/datepicker.css?inline';\n\nCore.insertStyleToPage(css);\n\nconst $ = (el: HTMLInputElement) => {\n\tif (!Core.$?.ui?.datepicker) {\n\t\tconsole.info('Для работы datepicker требуется глобальная загрузка jQuery UI Datepicker');\n\n\t\treturn;\n\t}\n\n\tCore.$.datepicker.setDefaults({\n\t\tdateFormat: Core.state.dateFormat.toLowerCase().replace('m', 'mm').replace('y', 'yy').replace('d', 'dd'),\n\t});\n\n\treturn Core.$(el);\n};\n\nexport function connectDatepicker(el: HTMLInputElement, options: any) {\n\treturn $(el)?.datepicker(options);\n}\n\nlet dateFormatted;\nlet delimiter: string;\nlet dateNumbersCount: number;\nlet delimitersIndexes: number[];\n\nwatch(toRef(Core.state.dateFormat), () => {\n\t// генерация отформатированной даты, извлечение из нее разделителей и их индексов\n\tdateFormatted = dateFormat('2000-01-01');\n\tdelimiter = dateFormatted.match(/\\D/)?.[0] ?? '-';\n\tdateNumbersCount = dateFormatted.replace(/\\D+/g, '').length;\n\tdelimitersIndexes = [];\n\n\tfor (let i = 0; i < dateFormatted.length; i++) {\n\t\tif (dateFormatted[i] === delimiter) {\n\t\t\tdelimitersIndexes.push(i);\n\t\t}\n\t}\n}, { immediate: true });\n\n/**\n * Автоформат при вводе в поле с датой\n */\nexport function oninput(e: any) {\n\tlet selectionPos = e.target.selectionEnd;\n\tlet value = e.target.value;\n\n\t// разбить занчение на две половины - до и после каретки\n\t// удалить все символы, кроме цифр\n\tlet valueChunkLeft = value.substring(0, selectionPos).replace(/\\D+/g, '');\n\tlet valueChunkRight = value.substring(selectionPos).replace(/\\D+/g, '');\n\n\tlet extraNumbersCount = valueChunkLeft.length + valueChunkRight.length - dateNumbersCount;\n\tif (extraNumbersCount > 0) {\n\t\t// // количество цифр больше требуемого - удалить лишние\n\t\tvalueChunkLeft = valueChunkLeft.substring(0, dateNumbersCount);\n\n\t\tconst valueChunkRightMaxLength = dateNumbersCount - valueChunkLeft.length;\n\t\tvalueChunkRight = valueChunkRight.substring(valueChunkRight.length - valueChunkRightMaxLength);\n\t} else if (extraNumbersCount < 0) {\n\t\t// количество цифр меньше требуемого - добавить 0\n\t\tif (e.inputType === 'deleteContentForward') {\n\t\t\t// нажатие на delete - добавить к левой части для правильного позиционирования каретки\n\t\t\tvalueChunkLeft += '0'.repeat(-extraNumbersCount);\n\t\t} else {\n\t\t\tvalueChunkRight = '0'.repeat(-extraNumbersCount) + valueChunkRight;\n\t\t}\n\t}\n\n\tselectionPos = valueChunkLeft.length;\n\tvalue = valueChunkLeft + valueChunkRight;\n\n\t// вставить разделители\n\tfor (let i = 0; i < delimitersIndexes.length; i++) {\n\t\tconst delimiterIndex = delimitersIndexes[i];\n\n\t\tvalue = value.substring(0, delimiterIndex) + delimiter + value.substring(delimiterIndex);\n\n\t\t// сдвинуть каретку, если разделитель вставлен левее ее\n\t\tif (selectionPos >= delimiterIndex) {\n\t\t\tselectionPos++;\n\t\t}\n\t}\n\n\t// нажатие на backspace - если слева символ разделителя, перенести каретку за него\n\tif (e.inputType === 'deleteContentBackward' && value[selectionPos - 1] === delimiter) {\n\t\tselectionPos--;\n\t}\n\n\t// если значение изменилось - вставить его и переместить каретку\n\tif (value !== e.target.value) {\n\t\te.target.value = value;\n\t\te.target.selectionStart = selectionPos;\n\t\te.target.selectionEnd = selectionPos;\n\t}\n}\n"]}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { O as e, _ as t } from "./forms-CbUt-6Ff.esm.js";
|
|
2
|
+
import { toRef as n, watch as r } from "vue";
|
|
3
|
+
//#endregion
|
|
4
|
+
//#region src/components/forms/inputDate/datepicker.ts
|
|
5
|
+
e.insertStyleToPage(".ui-datepicker{--datepicker-day-color:var(--color-layout-front-1);--datepicker-day-color-hover:var(--color-layer-1);--datepicker-selected-color:var(--color-bg-primary-1);--datepicker-selected-color-hover:var(--color-bg-primary-2);--datepicker-range-color:var(--color-layer-primary-1);--datepicker-range-color-hover:var(--color-layer-primary-2);-webkit-user-select:none;user-select:none;width:auto;padding:0}.ui-datepicker:before,.ui-datepicker:after{display:none}.ui-datepicker-inline{display:inline-block!important}.ui-datepicker:not(.ui-datepicker-inline){background:var(--color-layout-front-1);box-shadow:var(--top-shadow);border-radius:8px;padding:8px;z-index:10000000!important}.ui-datepicker a{text-decoration:none!important}.ui-datepicker option{color:var(--color-text-1);font-size:14px}.ui-datepicker-header{align-items:center;margin:0 0 18px;display:flex;padding:0!important}.ui-datepicker-header>*{justify-content:center;align-items:center;display:flex}.ui-datepicker-title{height:24px;width:100%!important;margin:0!important}.ui-datepicker-month,.ui-datepicker-year{text-align:center;border:none;padding:0;outline:none!important;width:auto!important;margin:0 6px!important;font-size:16px!important}.ui-datepicker-month{color:var(--color-text-1)}.ui-datepicker-year{color:var(--color-text-2)}select.ui-datepicker-month,select.ui-datepicker-year{cursor:pointer}.ui-datepicker-prev,.ui-datepicker-next{cursor:pointer;font-family:Topvisor-2;font-size:24px;width:24px!important;height:24px!important;position:static!important}.ui-datepicker-prev:before{color:var(--color-text-3);content:\"\"}.ui-datepicker-prev-hover:before{color:var(--color-text-1);content:\"\"}.ui-datepicker-next{color:var(--color-text-3);order:1}.ui-datepicker-next-hover{color:var(--color-text-1);order:1}.ui-datepicker-next:before{content:\"\"}.ui-datepicker-prev>*,.ui-datepicker-next>*{display:none!important}.ui-datepicker thead th{color:var(--color-text-3);font-size:14px;width:auto!important;padding:0!important;font-weight:400!important}.ui-datepicker table{font-size:14px;margin:0!important}.ui-datepicker td{color:var(--color-text-1);background:0 0;padding:0!important}.ui-datepicker td span,.ui-datepicker td a{text-align:center;border:none;border-radius:8px;min-width:32px;height:32px;margin:1px;padding:0;line-height:32px;display:block;position:relative;color:var(--color-text-1)!important}.ui-datepicker td a{background:var(--datepicker-day-color)}.ui-datepicker td a:hover{background:var(--datepicker-day-color-hover)}td.ui-datepicker-today span,td.ui-datepicker-today a{background:0 0;position:relative}.ui-datepicker td.selected a{background:var(--datepicker-range-color);margin-left:0;margin-right:1px;padding-left:1px;padding-right:0}.ui-datepicker td.selected a:hover{background:var(--datepicker-range-color-hover)}.ui-datepicker td.selected:not(.selected-start):not(:first-child):not(.first-of-month) a{border-top-left-radius:0;border-bottom-left-radius:0;margin-left:0;padding-left:1px}.ui-datepicker td.selected:not(.selected-end):not(:last-child):not(.last-of-month) a{border-top-right-radius:0;border-bottom-right-radius:0;margin-right:0;padding-right:1px}.ui-datepicker td.selected-start a,.ui-datepicker td.selected-end a,.ui-datepicker td.ui-datepicker-current-day a{background:var(--datepicker-selected-color);color:#fff!important}.ui-datepicker td.selected-start a:hover,.ui-datepicker td.selected-end a:hover,.ui-datepicker td.ui-datepicker-current-day a:hover{background:var(--datepicker-selected-color-hover)}.ui-datepicker-day-marks{justify-content:center;align-items:center;line-height:normal;display:flex;position:absolute;bottom:3px;left:0;right:0}.ui-datepicker-day-marks>i{border:1px solid #fff;border-radius:50%;width:4px;height:4px;margin:0 2px}.ui-datepicker-day-marks-exists{background:var(--color-text-primary)}.ui-datepicker-day-marks-update{background:var(--color-text-negative)}.ui-datepicker-row-break{display:none}");
|
|
6
|
+
var i = (t) => {
|
|
7
|
+
if (!e.$?.ui?.datepicker) {
|
|
8
|
+
console.info("Для работы datepicker требуется глобальная загрузка jQuery UI Datepicker");
|
|
9
|
+
return;
|
|
10
|
+
}
|
|
11
|
+
return e.$.datepicker.setDefaults({ dateFormat: e.state.dateFormat.toLowerCase().replace("m", "mm").replace("y", "yy").replace("d", "dd") }), e.$(t);
|
|
12
|
+
};
|
|
13
|
+
function a(e, t) {
|
|
14
|
+
return i(e)?.datepicker(t);
|
|
15
|
+
}
|
|
16
|
+
var o, s, c, l;
|
|
17
|
+
r(n(e.state.dateFormat), () => {
|
|
18
|
+
o = t("2000-01-01"), s = o.match(/\D/)?.[0] ?? "-", c = o.replace(/\D+/g, "").length, l = [];
|
|
19
|
+
for (let e = 0; e < o.length; e++) o[e] === s && l.push(e);
|
|
20
|
+
}, { immediate: !0 });
|
|
21
|
+
function u(e) {
|
|
22
|
+
let t = e.target.selectionEnd, n = e.target.value, r = n.substring(0, t).replace(/\D+/g, ""), i = n.substring(t).replace(/\D+/g, ""), a = r.length + i.length - c;
|
|
23
|
+
if (a > 0) {
|
|
24
|
+
r = r.substring(0, c);
|
|
25
|
+
let e = c - r.length;
|
|
26
|
+
i = i.substring(i.length - e);
|
|
27
|
+
} else a < 0 && (e.inputType === "deleteContentForward" ? r += "0".repeat(-a) : i = "0".repeat(-a) + i);
|
|
28
|
+
t = r.length, n = r + i;
|
|
29
|
+
for (let e = 0; e < l.length; e++) {
|
|
30
|
+
let r = l[e];
|
|
31
|
+
n = n.substring(0, r) + s + n.substring(r), t >= r && t++;
|
|
32
|
+
}
|
|
33
|
+
e.inputType === "deleteContentBackward" && n[t - 1] === s && t--, n !== e.target.value && (e.target.value = n, e.target.selectionStart = t, e.target.selectionEnd = t);
|
|
34
|
+
}
|
|
35
|
+
//#endregion
|
|
36
|
+
export { a as connectDatepicker, u as oninput };
|
|
37
|
+
|
|
38
|
+
//# sourceMappingURL=datepicker-BTkZOq7d.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"datepicker-BTkZOq7d.esm.js","names":[],"sources":["../../src/components/forms/inputDate/datepicker.css?inline","../../src/components/forms/inputDate/datepicker.ts"],"sourcesContent":["/* ui-datepicker */\n.ui-datepicker {\n\t--datepicker-day-color: var(--color-layout-front-1);\n\t--datepicker-day-color-hover: var(--color-layer-1);\n\t--datepicker-selected-color: var(--color-bg-primary-1);\n\t--datepicker-selected-color-hover: var(--color-bg-primary-2);\n\t--datepicker-range-color: var(--color-layer-primary-1);\n\t--datepicker-range-color-hover: var(--color-layer-primary-2);\n\n\tuser-select: none;\n\twidth: auto;\n\tpadding: 0;\n}\n\n.ui-datepicker:before,\n.ui-datepicker:after {\n\tdisplay: none;\n}\n\n/* на странице */\n.ui-datepicker-inline {\n\tdisplay: inline-block !important;\n}\n\n/* в popup */\n.ui-datepicker:not(.ui-datepicker-inline) {\n\tborder-radius: 8px;\n\tbackground: var(--color-layout-front-1);\n\tbox-shadow: var(--top-shadow);\n\tz-index: 10000000 !important;\n\tpadding: 8px;\n}\n\n.ui-datepicker a {\n\ttext-decoration: none !important;\n}\n\n.ui-datepicker option {\n\tcolor: var(--color-text-1);\n\tfont-size: 14px;\n}\n\n.ui-datepicker-header {\n\tpadding: 0 !important;\n\tmargin: 0 0 18px 0;\n\tdisplay: flex;\n\talign-items: center;\n}\n\n.ui-datepicker-header > * {\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n}\n\n.ui-datepicker-title {\n\twidth: 100% !important;\n\theight: 24px;\n\tmargin: 0 !important;\n}\n\n.ui-datepicker-month,\n.ui-datepicker-year {\n\toutline: none !important;\n\twidth: auto !important;\n\tborder: none;\n\tpadding: 0;\n\tmargin: 0 6px !important;\n\ttext-align: center;\n\tfont-size: 16px !important;\n}\n\n.ui-datepicker-month {\n\tcolor: var(--color-text-1);\n}\n\n.ui-datepicker-year {\n\tcolor: var(--color-text-2);\n}\n\n/*\tselect.ui-datepicker-month,\nselect.ui-datepicker-year{ cursor: pointer; color: var(--color-blue-500); }*/\nselect.ui-datepicker-month,\nselect.ui-datepicker-year {\n\tcursor: pointer;\n}\n\n.ui-datepicker-prev,\n.ui-datepicker-next {\n\tcursor: pointer;\n\twidth: 24px !important;\n\theight: 24px !important;\n\tfont-size: 24px;\n\tfont-family: \"Topvisor-2\";\n\tposition: static !important;\n}\n\n.ui-datepicker-prev:before {\n\tcolor: var(--color-text-3);\n\tcontent: \"\";\n}\n\n.ui-datepicker-prev-hover:before {\n\tcolor: var(--color-text-1);\n\tcontent: \"\";\n}\n\n.ui-datepicker-next {\n\tcolor: var(--color-text-3);\n\torder: 1;\n}\n\n.ui-datepicker-next-hover {\n\tcolor: var(--color-text-1);\n\torder: 1;\n}\n\n.ui-datepicker-next:before {\n\tcontent: \"\";\n}\n\n.ui-datepicker-prev > *,\n.ui-datepicker-next > * {\n\tdisplay: none !important;\n}\n\n.ui-datepicker thead th {\n\twidth: auto !important;\n\tpadding: 0 !important;\n\tcolor: var(--color-text-3);\n\tfont-size: 14px;\n\tfont-weight: 400 !important;\n}\n\n.ui-datepicker table {\n\tmargin: 0 !important;\n\tfont-size: 14px;\n}\n\n.ui-datepicker td {\n\tcolor: var(--color-text-1);\n\tbackground: none;\n\tpadding: 0 !important;\n}\n\n.ui-datepicker td span,\n.ui-datepicker td a {\n\tborder-radius: 8px;\n\tborder: none;\n\tmin-width: 32px;\n\theight: 32px;\n\tpadding: 0;\n\tmargin: 1px;\n\tcolor: var(--color-text-1) !important;\n\tline-height: 32px;\n\ttext-align: center;\n\tposition: relative;\n\tdisplay: block;\n}\n\n/* обычные даты */\n.ui-datepicker td a {\n\tbackground: var(--datepicker-day-color);\n}\n\n.ui-datepicker td a:hover {\n\tbackground: var(--datepicker-day-color-hover);\n}\n\n/* текущий день */\ntd.ui-datepicker-today span,\ntd.ui-datepicker-today a {\n\tbackground: none;\n\tposition: relative;\n}\n\n/* выбранные даты */\n.ui-datepicker td.selected a {\n\tbackground: var(--datepicker-range-color);\n\tpadding-right: 0;\n\tpadding-left: 1px;\n\tmargin-right: 1px;\n\tmargin-left: 0;\n}\n\n.ui-datepicker td.selected a:hover {\n\tbackground: var(--datepicker-range-color-hover);\n}\n\n.ui-datepicker td.selected:not(.selected-start):not(:first-child):not(.first-of-month) a {\n\tborder-top-left-radius: 0;\n\tborder-bottom-left-radius: 0;\n\tpadding-left: 1px;\n\tmargin-left: 0;\n}\n\n.ui-datepicker td.selected:not(.selected-end):not(:last-child):not(.last-of-month) a {\n\tborder-top-right-radius: 0;\n\tborder-bottom-right-radius: 0;\n\tpadding-right: 1px;\n\tmargin-right: 0;\n}\n\n.ui-datepicker td.selected-start a,\n.ui-datepicker td.selected-end a,\n.ui-datepicker td.ui-datepicker-current-day a {\n\tbackground: var(--datepicker-selected-color);\n\tcolor: #FFF !important;\n}\n\n.ui-datepicker td.selected-start a:hover,\n.ui-datepicker td.selected-end a:hover,\n.ui-datepicker td.ui-datepicker-current-day a:hover {\n\tbackground: var(--datepicker-selected-color-hover);\n}\n\n.ui-datepicker-day-marks {\n\tline-height: normal;\n\tposition: absolute;\n\tright: 0;\n\tbottom: 3px;\n\tleft: 0;\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n}\n\n.ui-datepicker-day-marks > i {\n\tborder-radius: 50%;\n\tborder: 1px solid #FFF;\n\twidth: 4px;\n\theight: 4px;\n\tmargin: 0 2px;\n}\n\n.ui-datepicker-day-marks-exists {\n\tbackground: var(--color-text-primary);\n}\n\n.ui-datepicker-day-marks-update {\n\tbackground: var(--color-text-negative);\n}\n\n.ui-datepicker-row-break {\n\tdisplay: none;\n}\n","import { toRef, watch } from 'vue';\nimport Core from '@/core/core/core';\nimport { dateFormat } from '@/core/utils/date';\n\nimport css from '@/components/forms/inputDate/datepicker.css?inline';\n\nCore.insertStyleToPage(css);\n\nconst $ = (el: HTMLInputElement) => {\n\tif (!Core.$?.ui?.datepicker) {\n\t\tconsole.info('Для работы datepicker требуется глобальная загрузка jQuery UI Datepicker');\n\n\t\treturn;\n\t}\n\n\tCore.$.datepicker.setDefaults({\n\t\tdateFormat: Core.state.dateFormat.toLowerCase().replace('m', 'mm').replace('y', 'yy').replace('d', 'dd'),\n\t});\n\n\treturn Core.$(el);\n};\n\nexport function connectDatepicker(el: HTMLInputElement, options: any) {\n\treturn $(el)?.datepicker(options);\n}\n\nlet dateFormatted;\nlet delimiter: string;\nlet dateNumbersCount: number;\nlet delimitersIndexes: number[];\n\nwatch(toRef(Core.state.dateFormat), () => {\n\t// генерация отформатированной даты, извлечение из нее разделителей и их индексов\n\tdateFormatted = dateFormat('2000-01-01');\n\tdelimiter = dateFormatted.match(/\\D/)?.[0] ?? '-';\n\tdateNumbersCount = dateFormatted.replace(/\\D+/g, '').length;\n\tdelimitersIndexes = [];\n\n\tfor (let i = 0; i < dateFormatted.length; i++) {\n\t\tif (dateFormatted[i] === delimiter) {\n\t\t\tdelimitersIndexes.push(i);\n\t\t}\n\t}\n}, { immediate: true });\n\n/**\n * Автоформат при вводе в поле с датой\n */\nexport function oninput(e: any) {\n\tlet selectionPos = e.target.selectionEnd;\n\tlet value = e.target.value;\n\n\t// разбить занчение на две половины - до и после каретки\n\t// удалить все символы, кроме цифр\n\tlet valueChunkLeft = value.substring(0, selectionPos).replace(/\\D+/g, '');\n\tlet valueChunkRight = value.substring(selectionPos).replace(/\\D+/g, '');\n\n\tlet extraNumbersCount = valueChunkLeft.length + valueChunkRight.length - dateNumbersCount;\n\tif (extraNumbersCount > 0) {\n\t\t// // количество цифр больше требуемого - удалить лишние\n\t\tvalueChunkLeft = valueChunkLeft.substring(0, dateNumbersCount);\n\n\t\tconst valueChunkRightMaxLength = dateNumbersCount - valueChunkLeft.length;\n\t\tvalueChunkRight = valueChunkRight.substring(valueChunkRight.length - valueChunkRightMaxLength);\n\t} else if (extraNumbersCount < 0) {\n\t\t// количество цифр меньше требуемого - добавить 0\n\t\tif (e.inputType === 'deleteContentForward') {\n\t\t\t// нажатие на delete - добавить к левой части для правильного позиционирования каретки\n\t\t\tvalueChunkLeft += '0'.repeat(-extraNumbersCount);\n\t\t} else {\n\t\t\tvalueChunkRight = '0'.repeat(-extraNumbersCount) + valueChunkRight;\n\t\t}\n\t}\n\n\tselectionPos = valueChunkLeft.length;\n\tvalue = valueChunkLeft + valueChunkRight;\n\n\t// вставить разделители\n\tfor (let i = 0; i < delimitersIndexes.length; i++) {\n\t\tconst delimiterIndex = delimitersIndexes[i];\n\n\t\tvalue = value.substring(0, delimiterIndex) + delimiter + value.substring(delimiterIndex);\n\n\t\t// сдвинуть каретку, если разделитель вставлен левее ее\n\t\tif (selectionPos >= delimiterIndex) {\n\t\t\tselectionPos++;\n\t\t}\n\t}\n\n\t// нажатие на backspace - если слева символ разделителя, перенести каретку за него\n\tif (e.inputType === 'deleteContentBackward' && value[selectionPos - 1] === delimiter) {\n\t\tselectionPos--;\n\t}\n\n\t// если значение изменилось - вставить его и переместить каретку\n\tif (value !== e.target.value) {\n\t\te.target.value = value;\n\t\te.target.selectionStart = selectionPos;\n\t\te.target.selectionEnd = selectionPos;\n\t}\n}\n"],"mappings":";;;;ACMA,EAAK,63HAAsB;AAE3B,IAAM,KAAK,MAAyB;AACnC,KAAI,CAAC,EAAK,GAAG,IAAI,YAAY;AAC5B,UAAQ,KAAK,2EAA2E;AAExF;;AAOD,QAJA,EAAK,EAAE,WAAW,YAAY,EAC7B,YAAY,EAAK,MAAM,WAAW,aAAa,CAAC,QAAQ,KAAK,KAAK,CAAC,QAAQ,KAAK,KAAK,CAAC,QAAQ,KAAK,KAAK,EACxG,CAAC,EAEK,EAAK,EAAE,EAAG;;AAGlB,SAAgB,EAAkB,GAAsB,GAAc;AACrE,QAAO,EAAE,EAAG,EAAE,WAAW,EAAQ;;AAGlC,IAAI,GACA,GACA,GACA;AAEJ,EAAM,EAAM,EAAK,MAAM,WAAW,QAAQ;AAKzC,CAHA,IAAgB,EAAW,aAAa,EACxC,IAAY,EAAc,MAAM,KAAK,GAAG,MAAM,KAC9C,IAAmB,EAAc,QAAQ,QAAQ,GAAG,CAAC,QACrD,IAAoB,EAAE;AAEtB,MAAK,IAAI,IAAI,GAAG,IAAI,EAAc,QAAQ,IACzC,CAAI,EAAc,OAAO,KACxB,EAAkB,KAAK,EAAE;GAGzB,EAAE,WAAW,IAAM,CAAC;AAKvB,SAAgB,EAAQ,GAAQ;CAC/B,IAAI,IAAe,EAAE,OAAO,cACxB,IAAQ,EAAE,OAAO,OAIjB,IAAiB,EAAM,UAAU,GAAG,EAAa,CAAC,QAAQ,QAAQ,GAAG,EACrE,IAAkB,EAAM,UAAU,EAAa,CAAC,QAAQ,QAAQ,GAAG,EAEnE,IAAoB,EAAe,SAAS,EAAgB,SAAS;AACzE,KAAI,IAAoB,GAAG;AAE1B,MAAiB,EAAe,UAAU,GAAG,EAAiB;EAE9D,IAAM,IAA2B,IAAmB,EAAe;AACnE,MAAkB,EAAgB,UAAU,EAAgB,SAAS,EAAyB;QACpF,IAAoB,MAE1B,EAAE,cAAc,yBAEnB,KAAkB,IAAI,OAAO,CAAC,EAAkB,GAEhD,IAAkB,IAAI,OAAO,CAAC,EAAkB,GAAG;AAKrD,CADA,IAAe,EAAe,QAC9B,IAAQ,IAAiB;AAGzB,MAAK,IAAI,IAAI,GAAG,IAAI,EAAkB,QAAQ,KAAK;EAClD,IAAM,IAAiB,EAAkB;AAKzC,EAHA,IAAQ,EAAM,UAAU,GAAG,EAAe,GAAG,IAAY,EAAM,UAAU,EAAe,EAGpF,KAAgB,KACnB;;AAUF,CALI,EAAE,cAAc,2BAA2B,EAAM,IAAe,OAAO,KAC1E,KAIG,MAAU,EAAE,OAAO,UACtB,EAAE,OAAO,QAAQ,GACjB,EAAE,OAAO,iBAAiB,GAC1B,EAAE,OAAO,eAAe"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
define([`require`,`exports`,`./forms-CbUt-6Ff.amd.js`,`./utils-BwiXsV0S.amd.js`,`vue`,`./dialogs-CMrERMI7.amd.js`],function(e,t,n,r,i){"use strict";Object.defineProperty(t,`__esModule`,{value:!0}),t.t=t.r=t.n=void 0;var a={key:0,style:{display:`none`}},o=[`data-order`,`data-view-page`],s={class:`modal-header`},c={class:`top-title`},l={class:`buttons`},u=[`title`],d=[`title`],f=[`data-order`,`data-view-page`],p={class:`modal-body`},m=(0,i.defineComponent)({__name:`page`,props:{isLoading:{type:Boolean},name:{},order:{default:0},prevName:{},footerFullWith:{type:Boolean}},setup(e){let t=e,m=(0,r.r)(),h=(0,i.computed)(()=>({active:m.pageActive?.value===t.name,"i-load-data":t.isLoading||m.isLoadingPage.value}));return(t,r)=>{let g=(0,i.resolveDirective)(`top-scroll-shadow`);return(0,i.unref)(m).isReady.value?((0,i.openBlock)(),(0,i.createElementBlock)(`div`,a,[((0,i.openBlock)(),(0,i.createBlock)(i.Teleport,{to:`#`+(0,i.unref)(m).idAttr+` .modal-layer-header`,disabled:!(0,i.unref)(m).needShowPage(e.name)},[(0,i.createElementVNode)(`div`,{"data-order":e.order,"data-view-page":e.name,class:(0,i.normalizeClass)(h.value)},[(0,i.createElementVNode)(`div`,s,[(0,i.createElementVNode)(`div`,c,[(0,i.renderSlot)(t.$slots,`header`)]),(0,i.createElementVNode)(`div`,l,[(0,i.renderSlot)(t.$slots,`headerButtons`)]),(0,i.unref)(n.O).state.isMobile&&e.prevName?((0,i.openBlock)(),(0,i.createElementBlock)(`div`,{key:0,class:`close`,title:t.$i18n.Common.Back,"data-top-icon":``,onClick:r[0]||=t=>(0,i.unref)(m).open(e.prevName)},null,8,u)):((0,i.openBlock)(),(0,i.createElementBlock)(`div`,{key:1,class:`close`,title:t.$i18n.Common.Close,"data-top-icon":``,"data-action":`top-dialog-close`},null,8,d))])],10,o)],8,[`to`,`disabled`])),((0,i.openBlock)(),(0,i.createBlock)(i.Teleport,{to:`#`+(0,i.unref)(m).idAttr+` .modal-layer-body`,disabled:!(0,i.unref)(m).needShowPage(e.name)},[(0,i.createElementVNode)(`div`,{"data-order":e.order,"data-view-page":e.name,class:(0,i.normalizeClass)([`has_scroll_container`,h.value]),style:(0,i.normalizeStyle)({"--top-dialog-footer-height":t.$slots.footer?void 0:`0px`})},[(0,i.withDirectives)(((0,i.openBlock)(),(0,i.createElementBlock)(`div`,p,[(0,i.renderSlot)(t.$slots,`body`)])),[[g]]),t.$slots.footer?((0,i.openBlock)(),(0,i.createElementBlock)(`div`,{key:0,class:(0,i.normalizeClass)([`modal-footer`,{"modal-footer-fullWith":e.footerFullWith}])},[(0,i.renderSlot)(t.$slots,`footer`)],2)):(0,i.createCommentVNode)(``,!0)],14,f)],8,[`to`,`disabled`]))])):(0,i.createCommentVNode)(``,!0)}}}),h={name:{type:String,required:!0},order:{type:Number,required:!0},prevName:String,footerFullWith:Boolean},g=(0,i.defineComponent)({__name:`pageComponent`,props:{component:{},keepAlive:{type:Boolean,default:!0},props:{},name:{},order:{},prevName:{},footerFullWith:{type:Boolean}},setup(e){let t=e,n=(0,r.r)(),a=(e,r)=>{if(!r.value){if(e.name!==`AsyncComponentWrapper`){r.value=!0;return}n.needShowPage(t.name)&&(n.isLoadingPage.value=!0,e.__asyncResolved&&(r.value=!0,n.isLoadingPage.value=!1))}};if(t.component.name===`AsyncComponentWrapper`){let e=(0,i.ref)(!1);(0,i.onUpdated)(()=>{a(t.component,e)})}return(r,a)=>((0,i.openBlock)(),(0,i.createBlock)(i.KeepAlive,{include:e.keepAlive?``:`none`},[(0,i.unref)(n).needShowPage(e.name)?((0,i.openBlock)(),(0,i.createBlock)((0,i.resolveDynamicComponent)(e.component),(0,i.mergeProps)({key:0},t,{name:e.name,order:e.order,prevName:e.prevName}),null,16,[`name`,`order`,`prevName`])):(0,i.createCommentVNode)(``,!0)],1032,[`include`]))}});t.r=m,t.n=h,t.t=g});
|
|
2
|
+
//# sourceMappingURL=dialog-DeM4SApg.amd.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[".chunks/dialog-DeM4SApg.esm.js","../../src/components/dialog/dialog/page/page.vue","../../src/components/dialog/dialog/page/types.ts","../../src/components/dialog/dialog/pageComponent/pageComponent.vue"],"names":["exports","x","S","C","w","T","E","D","O","k","A","vue_1","l","n","u","utils_BwiXsV0S_esm_js_1","p","forms_CbUt_6Ff_esm_js_1","$slots","j","M","r","i","s","t"],"mappings":"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","sourcesContent":["define([\"require\", \"exports\", \"./forms-CbUt-6Ff.esm.js\", \"./utils-BwiXsV0S.esm.js\", \"vue\", \"./dialogs-CMrERMI7.esm.js\"], function (require, exports, forms_CbUt_6Ff_esm_js_1, utils_BwiXsV0S_esm_js_1, vue_1) {\n \"use strict\";\n Object.defineProperty(exports, \"__esModule\", { value: true });\n exports.t = exports.r = exports.n = void 0;\n //#region src/components/dialog/dialog/page/page.vue?vue&type=script&setup=true&lang.ts\n var x = {\n key: 0,\n style: { display: \"none\" }\n }, S = [\"data-order\", \"data-view-page\"], C = { class: \"modal-header\" }, w = { class: \"top-title\" }, T = { class: \"buttons\" }, E = [\"title\"], D = [\"title\"], O = [\"data-order\", \"data-view-page\"], k = { class: \"modal-body\" }, A = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"page\",\n props: {\n isLoading: { type: Boolean },\n name: {},\n order: { default: 0 },\n prevName: {},\n footerFullWith: { type: Boolean }\n },\n setup(n) {\n let l = n, u = (0, utils_BwiXsV0S_esm_js_1.r)(), p = (0, vue_1.computed)(() => ({\n active: u.pageActive?.value === l.name,\n \"i-load-data\": l.isLoading || u.isLoadingPage.value\n }));\n return (t, i) => {\n let l = (0, vue_1.resolveDirective)(\"top-scroll-shadow\");\n return (0, vue_1.unref)(u).isReady.value ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", x, [((0, vue_1.openBlock)(), (0, vue_1.createBlock)(vue_1.Teleport, {\n to: \"#\" + (0, vue_1.unref)(u).idAttr + \" .modal-layer-header\",\n disabled: !(0, vue_1.unref)(u).needShowPage(n.name)\n }, [(0, vue_1.createElementVNode)(\"div\", {\n \"data-order\": n.order,\n \"data-view-page\": n.name,\n class: (0, vue_1.normalizeClass)(p.value)\n }, [(0, vue_1.createElementVNode)(\"div\", C, [\n (0, vue_1.createElementVNode)(\"div\", w, [(0, vue_1.renderSlot)(t.$slots, \"header\")]),\n (0, vue_1.createElementVNode)(\"div\", T, [(0, vue_1.renderSlot)(t.$slots, \"headerButtons\")]),\n (0, vue_1.unref)(forms_CbUt_6Ff_esm_js_1.O).state.isMobile && n.prevName ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", {\n key: 0,\n class: \"close\",\n title: t.$i18n.Common.Back,\n \"data-top-icon\": \"\",\n onClick: i[0] ||= (e) => (0, vue_1.unref)(u).open(n.prevName)\n }, null, 8, E)) : ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", {\n key: 1,\n class: \"close\",\n title: t.$i18n.Common.Close,\n \"data-top-icon\": \"\",\n \"data-action\": \"top-dialog-close\"\n }, null, 8, D))\n ])], 10, S)], 8, [\"to\", \"disabled\"])), ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(vue_1.Teleport, {\n to: \"#\" + (0, vue_1.unref)(u).idAttr + \" .modal-layer-body\",\n disabled: !(0, vue_1.unref)(u).needShowPage(n.name)\n }, [(0, vue_1.createElementVNode)(\"div\", {\n \"data-order\": n.order,\n \"data-view-page\": n.name,\n class: (0, vue_1.normalizeClass)([\"has_scroll_container\", p.value]),\n style: (0, vue_1.normalizeStyle)({ \"--top-dialog-footer-height\": t.$slots.footer ? void 0 : \"0px\" })\n }, [(0, vue_1.withDirectives)(((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", k, [(0, vue_1.renderSlot)(t.$slots, \"body\")])), [[l]]), t.$slots.footer ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", {\n key: 0,\n class: (0, vue_1.normalizeClass)([\"modal-footer\", { \"modal-footer-fullWith\": n.footerFullWith }])\n }, [(0, vue_1.renderSlot)(t.$slots, \"footer\")], 2)) : (0, vue_1.createCommentVNode)(\"\", !0)], 14, O)], 8, [\"to\", \"disabled\"]))])) : (0, vue_1.createCommentVNode)(\"\", !0);\n };\n }\n }), j = {\n name: {\n type: String,\n required: !0\n },\n order: {\n type: Number,\n required: !0\n },\n prevName: String,\n footerFullWith: Boolean\n }, M = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"pageComponent\",\n props: {\n component: {},\n keepAlive: {\n type: Boolean,\n default: !0\n },\n props: {},\n name: {},\n order: {},\n prevName: {},\n footerFullWith: { type: Boolean }\n },\n setup(e) {\n let r = e, i = (0, utils_BwiXsV0S_esm_js_1.r)(), s = (e, t) => {\n if (!t.value) {\n if (e.name !== \"AsyncComponentWrapper\") {\n t.value = !0;\n return;\n }\n i.needShowPage(r.name) && (i.isLoadingPage.value = !0, e.__asyncResolved && (t.value = !0, i.isLoadingPage.value = !1));\n }\n };\n if (r.component.name === \"AsyncComponentWrapper\") {\n let e = (0, vue_1.ref)(!1);\n (0, vue_1.onUpdated)(() => {\n s(r.component, e);\n });\n }\n return (t, s) => ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(vue_1.KeepAlive, { include: e.keepAlive ? \"\" : \"none\" }, [(0, vue_1.unref)(i).needShowPage(e.name) ? ((0, vue_1.openBlock)(), (0, vue_1.createBlock)((0, vue_1.resolveDynamicComponent)(e.component), (0, vue_1.mergeProps)({ key: 0 }, r, {\n name: e.name,\n order: e.order,\n prevName: e.prevName\n }), null, 16, [\n \"name\",\n \"order\",\n \"prevName\"\n ])) : (0, vue_1.createCommentVNode)(\"\", !0)], 1032, [\"include\"]));\n }\n });\n exports.r = A;\n exports.n = j;\n exports.t = M;\n});\n//# sourceMappingURL=dialog-DeM4SApg.esm.js.map\n","<script setup lang=\"ts\">\nimport { computed } from 'vue';\nimport Core from '@/core/core/core';\nimport { useTopDialogSelf } from '@/components/dialog/dialog/composables/utils';\nimport type { Props, Slots } from './types';\n\nconst props = withDefaults(defineProps<Props>(), {\n\torder: 0,\n});\n\ndefineSlots<Slots>();\n\nconst dialog = useTopDialogSelf();\n\nconst classes = computed(() => {\n\treturn {\n\t\tactive: dialog.pageActive?.value === props.name,\n\t\t'i-load-data': props.isLoading || dialog.isLoadingPage.value,\n\t};\n});\n</script>\n\n<template>\n\t<div\n\t\tstyle=\"display: none\"\n\t\tv-if=\"dialog.isReady.value\"\n\t>\n\t\t<Teleport :to=\"'#' + dialog.idAttr + ' .modal-layer-header'\" :disabled=\"!dialog.needShowPage(name)\">\n\t\t\t<div\n\t\t\t\t:data-order=\"order\"\n\t\t\t\t:data-view-page=\"name\"\n\t\t\t\t:class=\"classes\"\n\t\t\t>\n\t\t\t\t<div class=\"modal-header\">\n\t\t\t\t\t<div class=\"top-title\">\n\t\t\t\t\t\t<slot name=\"header\"></slot>\n\t\t\t\t\t</div>\n\n\t\t\t\t\t<div class=\"buttons\">\n\t\t\t\t\t\t<slot name=\"headerButtons\"></slot>\n\t\t\t\t\t</div>\n\n\t\t\t\t\t<div\n\t\t\t\t\t\tv-if=\"Core.state.isMobile && prevName\"\n\t\t\t\t\t\tclass=\"close\"\n\t\t\t\t\t\t:title=\"$i18n.Common.Back\"\n\t\t\t\t\t\tdata-top-icon=\"\"\n\t\t\t\t\t\t@click=\"dialog.open(prevName)\"\n\t\t\t\t\t></div>\n\n\t\t\t\t\t<div\n\t\t\t\t\t\tv-else\n\t\t\t\t\t\tclass=\"close\"\n\t\t\t\t\t\t:title=\"$i18n.Common.Close\"\n\t\t\t\t\t\tdata-top-icon=\"\"\n\t\t\t\t\t\tdata-action=\"top-dialog-close\"\n\t\t\t\t\t></div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</Teleport>\n\n\t\t<Teleport :to=\"'#' + dialog.idAttr + ' .modal-layer-body'\" :disabled=\"!dialog.needShowPage(name)\">\n\t\t\t<div\n\t\t\t\t:data-order=\"order\"\n\t\t\t\t:data-view-page=\"name\"\n\t\t\t\tclass=\"has_scroll_container\"\n\t\t\t\t:class=\"classes\"\n\t\t\t\t:style=\"{'--top-dialog-footer-height': $slots.footer ? undefined : '0px'}\"\n\t\t\t>\n\t\t\t\t<div class=\"modal-body\" v-top-scroll-shadow>\n\t\t\t\t\t<slot name=\"body\"></slot>\n\t\t\t\t</div>\n\n\t\t\t\t<div\n\t\t\t\t\tclass=\"modal-footer\"\n\t\t\t\t\t:class=\"{\n\t\t\t\t\t\t'modal-footer-fullWith': footerFullWith\n\t\t\t\t\t}\"\n\t\t\t\t\tv-if=\"$slots.footer\"\n\t\t\t\t>\n\t\t\t\t\t<slot name=\"footer\"></slot>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</Teleport>\n\t</div>\n</template>\n","export interface Props extends PropsCommon {\n\t/**\n\t * Статус загрузки страницы диалогового окна\n\t *\n\t * При включении взаимодействие со страницей блокируется, отображается анимация загрузки\n\t */\n\tisLoading?: boolean;\n}\n\n/**\n * Общие props для компонентов реализуюущих TopDialogPage\n */\nexport interface PropsCommon {\n\t/**\n\t * Имя страницы для диалогового окна\n\t *\n\t * Имя страницы нужно для навигации между страницами в одном диалоговом окне\n\t */\n\tname: string,\n\n\t/**\n\t * Порядкой номер страницы в диалоговом окне\n\t *\n\t * Одна и та же страница может быть подключена в разные диалоговые окна и иметь разный порядковый номер\n\t */\n\torder: number,\n\n\t/**\n\t * Имя предыдущей страницы\n\t *\n\t * Для кнопки Назад / Закрыть в мобильной версии\n\t */\n\tprevName?: string,\n\n\t/**\n\t * Стиль отображения футера, при котороым элементы растягиваются на всю ширину\n\t *\n\t * Разрешены переносы\n\t */\n\tfooterFullWith?: boolean,\n}\n\n/**\n * Общие props для компонентов реализуюущих TopDialogPage\n *\n * Для не SFC компонентов\n */\nexport const propsPageCommon = {\n\tname: {\n\t\ttype: String,\n\t\trequired: true,\n\t},\n\n\torder: {\n\t\ttype: Number,\n\t\trequired: true,\n\t},\n\n\tprevName: String,\n\n\tfooterFullWith: Boolean,\n};\n\nexport interface Slots {\n\t/**\n\t * Шапка страницы\n\t */\n\theader(props: {}): any;\n\n\t/**\n\t * Кнопки для шапки страницы\n\t */\n\theaderButtons?(props: {}): any;\n\n\t/**\n\t * Контент страницы\n\t */\n\tbody(props: {}): any;\n\n\t/**\n\t * Футер страницы\n\t */\n\tfooter?(props: {}): any;\n}\n","<script setup lang=\"ts\">\nimport { type Component, onUpdated, ref, type Ref } from 'vue';\nimport { useTopDialogSelf } from '@/components/dialog/dialog/composables/utils';\nimport type { Props } from './types';\n\nconst props = withDefaults(defineProps<Props>(), {\n\tkeepAlive: true,\n});\n\nconst dialog = useTopDialogSelf();\n\n/**\n * Статус загрузи асинхронного компонента страницы диалогового окна\n */\nconst updateIsLoadingAsyncPage = (component: Component, isLoaded: Ref) => {\n\tif (isLoaded.value) return;\n\n\tif (component.name !== 'AsyncComponentWrapper') {\n\t\tisLoaded.value = true;\n\n\t\treturn;\n\t}\n\n\tif (!dialog.needShowPage(props.name as string)) return;\n\n\tdialog.isLoadingPage.value = true;\n\n\t// @ts-ignore\n\tif (component.__asyncResolved) {\n\t\tisLoaded.value = true;\n\n\t\tdialog.isLoadingPage.value = false;\n\t}\n};\n\nif (props.component.name === 'AsyncComponentWrapper') {\n\tconst isLoaded = ref(false);\n\n\tonUpdated(() => {\n\t\tupdateIsLoadingAsyncPage(props.component, isLoaded);\n\t});\n}\n</script>\n\n<template>\n\t<!-- Teleport внутри при keepAlive размонитроваться не будет, см. TopDialogPage -->\n\t<KeepAlive :include=\"keepAlive ? '' : 'none'\">\n\t\t<Component\n\t\t\t:is=\"component\"\n\t\t\tv-if=\"dialog.needShowPage(name)\"\n\t\t\t:=\"props\"\n\t\t\t:name=\"name\"\n\t\t\t:order=\"order\"\n\t\t\t:prevName=\"prevName\"\n\t\t/>\n\t</KeepAlive>\n</template>\n"]}
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
import { O as e } from "./forms-CbUt-6Ff.esm.js";
|
|
2
|
+
import "./dialogs-CMrERMI7.esm.js";
|
|
3
|
+
import { r as t } from "./utils-BwiXsV0S.esm.js";
|
|
4
|
+
import { KeepAlive as n, Teleport as r, computed as i, createBlock as a, createCommentVNode as o, createElementBlock as s, createElementVNode as c, defineComponent as l, mergeProps as u, normalizeClass as d, normalizeStyle as f, onUpdated as p, openBlock as m, ref as h, renderSlot as g, resolveDirective as _, resolveDynamicComponent as v, unref as y, withDirectives as b } from "vue";
|
|
5
|
+
//#region src/components/dialog/dialog/page/page.vue?vue&type=script&setup=true&lang.ts
|
|
6
|
+
var x = {
|
|
7
|
+
key: 0,
|
|
8
|
+
style: { display: "none" }
|
|
9
|
+
}, S = ["data-order", "data-view-page"], C = { class: "modal-header" }, w = { class: "top-title" }, T = { class: "buttons" }, E = ["title"], D = ["title"], O = ["data-order", "data-view-page"], k = { class: "modal-body" }, A = /* @__PURE__ */ l({
|
|
10
|
+
__name: "page",
|
|
11
|
+
props: {
|
|
12
|
+
isLoading: { type: Boolean },
|
|
13
|
+
name: {},
|
|
14
|
+
order: { default: 0 },
|
|
15
|
+
prevName: {},
|
|
16
|
+
footerFullWith: { type: Boolean }
|
|
17
|
+
},
|
|
18
|
+
setup(n) {
|
|
19
|
+
let l = n, u = t(), p = i(() => ({
|
|
20
|
+
active: u.pageActive?.value === l.name,
|
|
21
|
+
"i-load-data": l.isLoading || u.isLoadingPage.value
|
|
22
|
+
}));
|
|
23
|
+
return (t, i) => {
|
|
24
|
+
let l = _("top-scroll-shadow");
|
|
25
|
+
return y(u).isReady.value ? (m(), s("div", x, [(m(), a(r, {
|
|
26
|
+
to: "#" + y(u).idAttr + " .modal-layer-header",
|
|
27
|
+
disabled: !y(u).needShowPage(n.name)
|
|
28
|
+
}, [c("div", {
|
|
29
|
+
"data-order": n.order,
|
|
30
|
+
"data-view-page": n.name,
|
|
31
|
+
class: d(p.value)
|
|
32
|
+
}, [c("div", C, [
|
|
33
|
+
c("div", w, [g(t.$slots, "header")]),
|
|
34
|
+
c("div", T, [g(t.$slots, "headerButtons")]),
|
|
35
|
+
y(e).state.isMobile && n.prevName ? (m(), s("div", {
|
|
36
|
+
key: 0,
|
|
37
|
+
class: "close",
|
|
38
|
+
title: t.$i18n.Common.Back,
|
|
39
|
+
"data-top-icon": "",
|
|
40
|
+
onClick: i[0] ||= (e) => y(u).open(n.prevName)
|
|
41
|
+
}, null, 8, E)) : (m(), s("div", {
|
|
42
|
+
key: 1,
|
|
43
|
+
class: "close",
|
|
44
|
+
title: t.$i18n.Common.Close,
|
|
45
|
+
"data-top-icon": "",
|
|
46
|
+
"data-action": "top-dialog-close"
|
|
47
|
+
}, null, 8, D))
|
|
48
|
+
])], 10, S)], 8, ["to", "disabled"])), (m(), a(r, {
|
|
49
|
+
to: "#" + y(u).idAttr + " .modal-layer-body",
|
|
50
|
+
disabled: !y(u).needShowPage(n.name)
|
|
51
|
+
}, [c("div", {
|
|
52
|
+
"data-order": n.order,
|
|
53
|
+
"data-view-page": n.name,
|
|
54
|
+
class: d(["has_scroll_container", p.value]),
|
|
55
|
+
style: f({ "--top-dialog-footer-height": t.$slots.footer ? void 0 : "0px" })
|
|
56
|
+
}, [b((m(), s("div", k, [g(t.$slots, "body")])), [[l]]), t.$slots.footer ? (m(), s("div", {
|
|
57
|
+
key: 0,
|
|
58
|
+
class: d(["modal-footer", { "modal-footer-fullWith": n.footerFullWith }])
|
|
59
|
+
}, [g(t.$slots, "footer")], 2)) : o("", !0)], 14, O)], 8, ["to", "disabled"]))])) : o("", !0);
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
}), j = {
|
|
63
|
+
name: {
|
|
64
|
+
type: String,
|
|
65
|
+
required: !0
|
|
66
|
+
},
|
|
67
|
+
order: {
|
|
68
|
+
type: Number,
|
|
69
|
+
required: !0
|
|
70
|
+
},
|
|
71
|
+
prevName: String,
|
|
72
|
+
footerFullWith: Boolean
|
|
73
|
+
}, M = /* @__PURE__ */ l({
|
|
74
|
+
__name: "pageComponent",
|
|
75
|
+
props: {
|
|
76
|
+
component: {},
|
|
77
|
+
keepAlive: {
|
|
78
|
+
type: Boolean,
|
|
79
|
+
default: !0
|
|
80
|
+
},
|
|
81
|
+
props: {},
|
|
82
|
+
name: {},
|
|
83
|
+
order: {},
|
|
84
|
+
prevName: {},
|
|
85
|
+
footerFullWith: { type: Boolean }
|
|
86
|
+
},
|
|
87
|
+
setup(e) {
|
|
88
|
+
let r = e, i = t(), s = (e, t) => {
|
|
89
|
+
if (!t.value) {
|
|
90
|
+
if (e.name !== "AsyncComponentWrapper") {
|
|
91
|
+
t.value = !0;
|
|
92
|
+
return;
|
|
93
|
+
}
|
|
94
|
+
i.needShowPage(r.name) && (i.isLoadingPage.value = !0, e.__asyncResolved && (t.value = !0, i.isLoadingPage.value = !1));
|
|
95
|
+
}
|
|
96
|
+
};
|
|
97
|
+
if (r.component.name === "AsyncComponentWrapper") {
|
|
98
|
+
let e = h(!1);
|
|
99
|
+
p(() => {
|
|
100
|
+
s(r.component, e);
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
return (t, s) => (m(), a(n, { include: e.keepAlive ? "" : "none" }, [y(i).needShowPage(e.name) ? (m(), a(v(e.component), u({ key: 0 }, r, {
|
|
104
|
+
name: e.name,
|
|
105
|
+
order: e.order,
|
|
106
|
+
prevName: e.prevName
|
|
107
|
+
}), null, 16, [
|
|
108
|
+
"name",
|
|
109
|
+
"order",
|
|
110
|
+
"prevName"
|
|
111
|
+
])) : o("", !0)], 1032, ["include"]));
|
|
112
|
+
}
|
|
113
|
+
});
|
|
114
|
+
//#endregion
|
|
115
|
+
export { j as n, A as r, M as t };
|
|
116
|
+
|
|
117
|
+
//# sourceMappingURL=dialog-DeM4SApg.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dialog-DeM4SApg.esm.js","names":["$i18n","$slots"],"sources":["../../src/components/dialog/dialog/page/page.vue","../../src/components/dialog/dialog/page/page.vue","../../src/components/dialog/dialog/page/types.ts","../../src/components/dialog/dialog/pageComponent/pageComponent.vue","../../src/components/dialog/dialog/pageComponent/pageComponent.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed } from 'vue';\nimport Core from '@/core/core/core';\nimport { useTopDialogSelf } from '@/components/dialog/dialog/composables/utils';\nimport type { Props, Slots } from './types';\n\nconst props = withDefaults(defineProps<Props>(), {\n\torder: 0,\n});\n\ndefineSlots<Slots>();\n\nconst dialog = useTopDialogSelf();\n\nconst classes = computed(() => {\n\treturn {\n\t\tactive: dialog.pageActive?.value === props.name,\n\t\t'i-load-data': props.isLoading || dialog.isLoadingPage.value,\n\t};\n});\n</script>\n\n<template>\n\t<div\n\t\tstyle=\"display: none\"\n\t\tv-if=\"dialog.isReady.value\"\n\t>\n\t\t<Teleport :to=\"'#' + dialog.idAttr + ' .modal-layer-header'\" :disabled=\"!dialog.needShowPage(name)\">\n\t\t\t<div\n\t\t\t\t:data-order=\"order\"\n\t\t\t\t:data-view-page=\"name\"\n\t\t\t\t:class=\"classes\"\n\t\t\t>\n\t\t\t\t<div class=\"modal-header\">\n\t\t\t\t\t<div class=\"top-title\">\n\t\t\t\t\t\t<slot name=\"header\"></slot>\n\t\t\t\t\t</div>\n\n\t\t\t\t\t<div class=\"buttons\">\n\t\t\t\t\t\t<slot name=\"headerButtons\"></slot>\n\t\t\t\t\t</div>\n\n\t\t\t\t\t<div\n\t\t\t\t\t\tv-if=\"Core.state.isMobile && prevName\"\n\t\t\t\t\t\tclass=\"close\"\n\t\t\t\t\t\t:title=\"$i18n.Common.Back\"\n\t\t\t\t\t\tdata-top-icon=\"\"\n\t\t\t\t\t\t@click=\"dialog.open(prevName)\"\n\t\t\t\t\t></div>\n\n\t\t\t\t\t<div\n\t\t\t\t\t\tv-else\n\t\t\t\t\t\tclass=\"close\"\n\t\t\t\t\t\t:title=\"$i18n.Common.Close\"\n\t\t\t\t\t\tdata-top-icon=\"\"\n\t\t\t\t\t\tdata-action=\"top-dialog-close\"\n\t\t\t\t\t></div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</Teleport>\n\n\t\t<Teleport :to=\"'#' + dialog.idAttr + ' .modal-layer-body'\" :disabled=\"!dialog.needShowPage(name)\">\n\t\t\t<div\n\t\t\t\t:data-order=\"order\"\n\t\t\t\t:data-view-page=\"name\"\n\t\t\t\tclass=\"has_scroll_container\"\n\t\t\t\t:class=\"classes\"\n\t\t\t\t:style=\"{'--top-dialog-footer-height': $slots.footer ? undefined : '0px'}\"\n\t\t\t>\n\t\t\t\t<div class=\"modal-body\" v-top-scroll-shadow>\n\t\t\t\t\t<slot name=\"body\"></slot>\n\t\t\t\t</div>\n\n\t\t\t\t<div\n\t\t\t\t\tclass=\"modal-footer\"\n\t\t\t\t\t:class=\"{\n\t\t\t\t\t\t'modal-footer-fullWith': footerFullWith\n\t\t\t\t\t}\"\n\t\t\t\t\tv-if=\"$slots.footer\"\n\t\t\t\t>\n\t\t\t\t\t<slot name=\"footer\"></slot>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</Teleport>\n\t</div>\n</template>\n","<script setup lang=\"ts\">\nimport { computed } from 'vue';\nimport Core from '@/core/core/core';\nimport { useTopDialogSelf } from '@/components/dialog/dialog/composables/utils';\nimport type { Props, Slots } from './types';\n\nconst props = withDefaults(defineProps<Props>(), {\n\torder: 0,\n});\n\ndefineSlots<Slots>();\n\nconst dialog = useTopDialogSelf();\n\nconst classes = computed(() => {\n\treturn {\n\t\tactive: dialog.pageActive?.value === props.name,\n\t\t'i-load-data': props.isLoading || dialog.isLoadingPage.value,\n\t};\n});\n</script>\n\n<template>\n\t<div\n\t\tstyle=\"display: none\"\n\t\tv-if=\"dialog.isReady.value\"\n\t>\n\t\t<Teleport :to=\"'#' + dialog.idAttr + ' .modal-layer-header'\" :disabled=\"!dialog.needShowPage(name)\">\n\t\t\t<div\n\t\t\t\t:data-order=\"order\"\n\t\t\t\t:data-view-page=\"name\"\n\t\t\t\t:class=\"classes\"\n\t\t\t>\n\t\t\t\t<div class=\"modal-header\">\n\t\t\t\t\t<div class=\"top-title\">\n\t\t\t\t\t\t<slot name=\"header\"></slot>\n\t\t\t\t\t</div>\n\n\t\t\t\t\t<div class=\"buttons\">\n\t\t\t\t\t\t<slot name=\"headerButtons\"></slot>\n\t\t\t\t\t</div>\n\n\t\t\t\t\t<div\n\t\t\t\t\t\tv-if=\"Core.state.isMobile && prevName\"\n\t\t\t\t\t\tclass=\"close\"\n\t\t\t\t\t\t:title=\"$i18n.Common.Back\"\n\t\t\t\t\t\tdata-top-icon=\"\"\n\t\t\t\t\t\t@click=\"dialog.open(prevName)\"\n\t\t\t\t\t></div>\n\n\t\t\t\t\t<div\n\t\t\t\t\t\tv-else\n\t\t\t\t\t\tclass=\"close\"\n\t\t\t\t\t\t:title=\"$i18n.Common.Close\"\n\t\t\t\t\t\tdata-top-icon=\"\"\n\t\t\t\t\t\tdata-action=\"top-dialog-close\"\n\t\t\t\t\t></div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</Teleport>\n\n\t\t<Teleport :to=\"'#' + dialog.idAttr + ' .modal-layer-body'\" :disabled=\"!dialog.needShowPage(name)\">\n\t\t\t<div\n\t\t\t\t:data-order=\"order\"\n\t\t\t\t:data-view-page=\"name\"\n\t\t\t\tclass=\"has_scroll_container\"\n\t\t\t\t:class=\"classes\"\n\t\t\t\t:style=\"{'--top-dialog-footer-height': $slots.footer ? undefined : '0px'}\"\n\t\t\t>\n\t\t\t\t<div class=\"modal-body\" v-top-scroll-shadow>\n\t\t\t\t\t<slot name=\"body\"></slot>\n\t\t\t\t</div>\n\n\t\t\t\t<div\n\t\t\t\t\tclass=\"modal-footer\"\n\t\t\t\t\t:class=\"{\n\t\t\t\t\t\t'modal-footer-fullWith': footerFullWith\n\t\t\t\t\t}\"\n\t\t\t\t\tv-if=\"$slots.footer\"\n\t\t\t\t>\n\t\t\t\t\t<slot name=\"footer\"></slot>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</Teleport>\n\t</div>\n</template>\n","export interface Props extends PropsCommon {\n\t/**\n\t * Статус загрузки страницы диалогового окна\n\t *\n\t * При включении взаимодействие со страницей блокируется, отображается анимация загрузки\n\t */\n\tisLoading?: boolean;\n}\n\n/**\n * Общие props для компонентов реализуюущих TopDialogPage\n */\nexport interface PropsCommon {\n\t/**\n\t * Имя страницы для диалогового окна\n\t *\n\t * Имя страницы нужно для навигации между страницами в одном диалоговом окне\n\t */\n\tname: string,\n\n\t/**\n\t * Порядкой номер страницы в диалоговом окне\n\t *\n\t * Одна и та же страница может быть подключена в разные диалоговые окна и иметь разный порядковый номер\n\t */\n\torder: number,\n\n\t/**\n\t * Имя предыдущей страницы\n\t *\n\t * Для кнопки Назад / Закрыть в мобильной версии\n\t */\n\tprevName?: string,\n\n\t/**\n\t * Стиль отображения футера, при котороым элементы растягиваются на всю ширину\n\t *\n\t * Разрешены переносы\n\t */\n\tfooterFullWith?: boolean,\n}\n\n/**\n * Общие props для компонентов реализуюущих TopDialogPage\n *\n * Для не SFC компонентов\n */\nexport const propsPageCommon = {\n\tname: {\n\t\ttype: String,\n\t\trequired: true,\n\t},\n\n\torder: {\n\t\ttype: Number,\n\t\trequired: true,\n\t},\n\n\tprevName: String,\n\n\tfooterFullWith: Boolean,\n};\n\nexport interface Slots {\n\t/**\n\t * Шапка страницы\n\t */\n\theader(props: {}): any;\n\n\t/**\n\t * Кнопки для шапки страницы\n\t */\n\theaderButtons?(props: {}): any;\n\n\t/**\n\t * Контент страницы\n\t */\n\tbody(props: {}): any;\n\n\t/**\n\t * Футер страницы\n\t */\n\tfooter?(props: {}): any;\n}\n","<script setup lang=\"ts\">\nimport { type Component, onUpdated, ref, type Ref } from 'vue';\nimport { useTopDialogSelf } from '@/components/dialog/dialog/composables/utils';\nimport type { Props } from './types';\n\nconst props = withDefaults(defineProps<Props>(), {\n\tkeepAlive: true,\n});\n\nconst dialog = useTopDialogSelf();\n\n/**\n * Статус загрузи асинхронного компонента страницы диалогового окна\n */\nconst updateIsLoadingAsyncPage = (component: Component, isLoaded: Ref) => {\n\tif (isLoaded.value) return;\n\n\tif (component.name !== 'AsyncComponentWrapper') {\n\t\tisLoaded.value = true;\n\n\t\treturn;\n\t}\n\n\tif (!dialog.needShowPage(props.name as string)) return;\n\n\tdialog.isLoadingPage.value = true;\n\n\t// @ts-ignore\n\tif (component.__asyncResolved) {\n\t\tisLoaded.value = true;\n\n\t\tdialog.isLoadingPage.value = false;\n\t}\n};\n\nif (props.component.name === 'AsyncComponentWrapper') {\n\tconst isLoaded = ref(false);\n\n\tonUpdated(() => {\n\t\tupdateIsLoadingAsyncPage(props.component, isLoaded);\n\t});\n}\n</script>\n\n<template>\n\t<!-- Teleport внутри при keepAlive размонитроваться не будет, см. TopDialogPage -->\n\t<KeepAlive :include=\"keepAlive ? '' : 'none'\">\n\t\t<Component\n\t\t\t:is=\"component\"\n\t\t\tv-if=\"dialog.needShowPage(name)\"\n\t\t\t:=\"props\"\n\t\t\t:name=\"name\"\n\t\t\t:order=\"order\"\n\t\t\t:prevName=\"prevName\"\n\t\t/>\n\t</KeepAlive>\n</template>\n","<script setup lang=\"ts\">\nimport { type Component, onUpdated, ref, type Ref } from 'vue';\nimport { useTopDialogSelf } from '@/components/dialog/dialog/composables/utils';\nimport type { Props } from './types';\n\nconst props = withDefaults(defineProps<Props>(), {\n\tkeepAlive: true,\n});\n\nconst dialog = useTopDialogSelf();\n\n/**\n * Статус загрузи асинхронного компонента страницы диалогового окна\n */\nconst updateIsLoadingAsyncPage = (component: Component, isLoaded: Ref) => {\n\tif (isLoaded.value) return;\n\n\tif (component.name !== 'AsyncComponentWrapper') {\n\t\tisLoaded.value = true;\n\n\t\treturn;\n\t}\n\n\tif (!dialog.needShowPage(props.name as string)) return;\n\n\tdialog.isLoadingPage.value = true;\n\n\t// @ts-ignore\n\tif (component.__asyncResolved) {\n\t\tisLoaded.value = true;\n\n\t\tdialog.isLoadingPage.value = false;\n\t}\n};\n\nif (props.component.name === 'AsyncComponentWrapper') {\n\tconst isLoaded = ref(false);\n\n\tonUpdated(() => {\n\t\tupdateIsLoadingAsyncPage(props.component, isLoaded);\n\t});\n}\n</script>\n\n<template>\n\t<!-- Teleport внутри при keepAlive размонитроваться не будет, см. TopDialogPage -->\n\t<KeepAlive :include=\"keepAlive ? '' : 'none'\">\n\t\t<Component\n\t\t\t:is=\"component\"\n\t\t\tv-if=\"dialog.needShowPage(name)\"\n\t\t\t:=\"props\"\n\t\t\t:name=\"name\"\n\t\t\t:order=\"order\"\n\t\t\t:prevName=\"prevName\"\n\t\t/>\n\t</KeepAlive>\n</template>\n"],"mappings":"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"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
define([`require`,`exports`,`./forms-CbUt-6Ff.amd.js`,`./dialogs-CMrERMI7.amd.js`,`../utils/string.amd.js`,`./utils-BwiXsV0S.amd.js`,`../utils/searchers.amd.js`,`./dialog-DeM4SApg.amd.js`,`vue`,`../require/css.amd!../assets/dialog_regionSelectorRegions.css`],function(e,t,n,r,i,a,o,s,c){"use strict";Object.defineProperty(t,`__esModule`,{value:!0}),t.default=void 0;var l={class:`dialog_regionSelectorRegions_header`},u=[`data-top-icon`],d=[`src`,`alt`],f={class:`top-ellipsis`},p={class:`dialog_regionSelectorRegions_regionAreaName`},m={key:1},h=[`data-top-icon`];t.default=(0,c.defineComponent)({id:`regionSelectorRegions`,__name:`dialog_regionSelectorRegions`,props:{regions:{},regionsIndexes:{},"@update:regionsIndexes":{type:Function}},setup(e){let t=e,g=(0,a.r)(),_=(0,c.ref)([]),v=(0,c.ref)(null),y=(0,c.reactive)({searcher_key:-1,key:-1,name:-1}),b=(0,c.computed)({get(){return _.value.every(e=>e.selected)},set(e){_.value=_.value.map(t=>({...t,selected:e}))}}),x=e=>{y[e]=-y[e],_.value.sort((t,n)=>!t[e]||!n[e]?-1:t[e]>=n[e]?y[e]:-y[e])},S=()=>{if(!_.value.some(e=>e.selected))return;let e=_.value.filter(e=>e.selected).map(e=>e.index);t[`@update:regionsIndexes`]?.(e),g.close()};(0,c.watch)([()=>t.regions,()=>t.regionsIndexes],()=>{if(_.value=[],!t.regions||!t.regionsIndexes)return;let e=[...t.regions],n=new Map(t.regionsIndexes.map((e,t)=>[e,t]));e.sort((e,t)=>(n.get(e.index)??Number.MAX_VALUE)-(n.get(t.index)??Number.MAX_VALUE)),e.forEach(e=>{let n=e.name;e.areaName&&(n+=` (${e.areaName})`);let r=t.regionsIndexes?.includes(e.index)??!1,a=(0,o.getSearcherGIcon)(e.searcher_key),s=e.lang===void 0?void 0:(0,o.getLangLabel)(e.searcher_key??999,e.lang),c=e.device===void 0?void 0:(0,o.getDeviceGIcon)(e.device),l=e.countryCode===void 0?void 0:(0,i.genFlagLinkByCountryCode)(e.countryCode),u={...e,selected:r,title:n,searcherIcon:a,langLabel:s,deviceIcon:c,flagLink:l};_.value.push(u)})});let C=()=>{if(!n.O.$?.ui.sortable){console.info(`Для работы сортировки требуется глобальная загрузка jQuery UI Sortable`);return}v.value&&$(v.value).sortable({distance:10,stop:()=>{let e=[...v.value.children].map(e=>Number(e.getAttribute(`data-region-index`)));_.value.sort((t,n)=>e.indexOf(t.index)-e.indexOf(n.index))}})},w=()=>{n.O.$?.ui.sortable&&v.value&&$(v.value).sortable(`destroy`)};return(e,t)=>{let n=(0,c.resolveComponent)(`TopCheckbox`),i=(0,c.resolveComponent)(`TopButton`);return(0,c.openBlock)(),(0,c.createBlock)((0,c.unref)(r.a),{id:(0,c.unref)(g).id,pageActive:`regions`,class:`dialog_regionSelectorRegions`,height:`600px`,width:`600px`,onOpen:C,onClose:w},{default:(0,c.withCtx)(()=>[(0,c.createVNode)((0,c.unref)(s.r),{name:`regions`,order:0},{header:(0,c.withCtx)(()=>[(0,c.createElementVNode)(`div`,l,[(0,c.createVNode)(n,{modelValue:b.value,"onUpdate:modelValue":t[0]||=e=>b.value=e},null,8,[`modelValue`]),(0,c.createVNode)(i,{class:`dialog_regionSelectorRegions_sortButton`,color:`theme`,"data-top-icon":``,onClick:t[1]||=e=>x(`searcher_key`),title:e.$i18n.Projects?.Sort_by_search_engine},null,8,[`title`]),(0,c.createVNode)(i,{class:`dialog_regionSelectorRegions_sortButton`,color:`theme`,"data-top-icon":``,onClick:t[2]||=e=>x(`key`),title:e.$i18n.Projects?.Sort_by_yande_region_code},null,8,[`title`]),(0,c.createVNode)(i,{class:`dialog_regionSelectorRegions_sortButton`,color:`theme`,"data-top-icon":``,onClick:t[3]||=e=>x(`name`),title:e.$i18n.Projects?.Sort_by_lphabetically},null,8,[`title`])])]),body:(0,c.withCtx)(()=>[(0,c.createElementVNode)(`div`,{ref_key:`elRegions`,ref:v},[((0,c.openBlock)(!0),(0,c.createElementBlock)(c.Fragment,null,(0,c.renderList)(_.value,e=>((0,c.openBlock)(),(0,c.createBlock)(n,{key:e.index,modelValue:e.selected,"onUpdate:modelValue":t=>e.selected=t,class:`dialog_regionSelectorRegions_region`,"data-region-index":e.index},{default:(0,c.withCtx)(()=>[(0,c.createElementVNode)(`div`,{class:`dialog_regionSelectorRegions_regionSearcherIcon`,"data-top-icon":e.searcherIcon},null,8,u),e.flagLink?((0,c.openBlock)(),(0,c.createElementBlock)(`img`,{key:0,class:`top-flag`,src:`//topvisor.dev`+e.flagLink,alt:e.countryCode},null,8,d)):(0,c.createCommentVNode)(``,!0),(0,c.createElementVNode)(`div`,f,[(0,c.createTextVNode)((0,c.toDisplayString)(e.name)+` `,1),(0,c.createElementVNode)(`span`,p,(0,c.toDisplayString)(e.areaName),1)]),e.langLabel?((0,c.openBlock)(),(0,c.createElementBlock)(`div`,m,` [`+(0,c.toDisplayString)(e.langLabel)+`] `,1)):(0,c.createCommentVNode)(``,!0),e.deviceIcon?((0,c.openBlock)(),(0,c.createElementBlock)(`div`,{key:2,"data-top-icon":e.deviceIcon},null,8,h)):(0,c.createCommentVNode)(``,!0)]),_:2},1032,[`modelValue`,`onUpdate:modelValue`,`data-region-index`]))),128))],512)]),footer:(0,c.withCtx)(()=>[(0,c.createVNode)(i,{onClick:S},{default:(0,c.withCtx)(()=>[(0,c.createTextVNode)((0,c.toDisplayString)(e.$i18n.Common?.Apply),1)]),_:1})]),_:1})]),_:1},8,[`id`])}}})});
|
|
2
|
+
//# sourceMappingURL=dialog_regionSelectorRegions-CYrmaDt3.amd.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[".chunks/dialog_regionSelectorRegions-CYrmaDt3.esm.js","../../src/components/project/regionSelector/dialog_regionSelectorRegions/dialog_regionSelectorRegions.vue"],"names":["exports","E","D","O","k","A","j","M","vue_1","N","g","P","utils_BwiXsV0S_esm_js_1","F","I","L","R","z","B","t","n","s","searchers_js_1","c","l","u","string_js_1","d","V","forms_CbUt_6Ff_esm_js_1","H","r","dialogs_CMrERMI7_esm_js_1","dialog_DeM4SApg_esm_js_1"],"mappings":"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","sourcesContent":["define([\"require\", \"exports\", \"./forms-CbUt-6Ff.esm.js\", \"./dialogs-CMrERMI7.esm.js\", \"../utils/string.js\", \"./utils-BwiXsV0S.esm.js\", \"../utils/searchers.js\", \"./dialog-DeM4SApg.esm.js\", \"vue\"], function (require, exports, forms_CbUt_6Ff_esm_js_1, dialogs_CMrERMI7_esm_js_1, string_js_1, utils_BwiXsV0S_esm_js_1, searchers_js_1, dialog_DeM4SApg_esm_js_1, vue_1) {\n \"use strict\";\n Object.defineProperty(exports, \"__esModule\", { value: true });\n exports.default = void 0;\n //#region src/components/project/regionSelector/dialog_regionSelectorRegions/dialog_regionSelectorRegions.vue?vue&type=script&setup=true&lang.ts\n var E = { class: \"dialog_regionSelectorRegions_header\" }, D = [\"data-top-icon\"], O = [\"src\", \"alt\"], k = { class: \"top-ellipsis\" }, A = { class: \"dialog_regionSelectorRegions_regionAreaName\" }, j = { key: 1 }, M = [\"data-top-icon\"], N = /* @__PURE__ */ (0, vue_1.defineComponent)({\n id: \"regionSelectorRegions\",\n __name: \"dialog_regionSelectorRegions\",\n props: {\n regions: {},\n regionsIndexes: {},\n \"@update:regionsIndexes\": { type: Function }\n },\n setup(g) {\n let N = g, P = (0, utils_BwiXsV0S_esm_js_1.r)(), F = (0, vue_1.ref)([]), I = (0, vue_1.ref)(null), L = (0, vue_1.reactive)({\n searcher_key: -1,\n key: -1,\n name: -1\n }), R = (0, vue_1.computed)({\n get() {\n return F.value.every((e) => e.selected);\n },\n set(e) {\n F.value = F.value.map((t) => ({\n ...t,\n selected: e\n }));\n }\n }), z = (e) => {\n L[e] = -L[e], F.value.sort((t, n) => !t[e] || !n[e] ? -1 : t[e] >= n[e] ? L[e] : -L[e]);\n }, B = () => {\n if (!F.value.some((e) => e.selected))\n return;\n let e = F.value.filter((e) => e.selected).map((e) => e.index);\n N[\"@update:regionsIndexes\"]?.(e), P.close();\n };\n (0, vue_1.watch)([() => N.regions, () => N.regionsIndexes], () => {\n if (F.value = [], !N.regions || !N.regionsIndexes)\n return;\n let e = [...N.regions], t = new Map(N.regionsIndexes.map((e, t) => [e, t]));\n e.sort((e, n) => (t.get(e.index) ?? Number.MAX_VALUE) - (t.get(n.index) ?? Number.MAX_VALUE)), e.forEach((e) => {\n let t = e.name;\n e.areaName && (t += ` (${e.areaName})`);\n let r = N.regionsIndexes?.includes(e.index) ?? !1, s = (0, searchers_js_1.getSearcherGIcon)(e.searcher_key), c = e.lang === void 0 ? void 0 : (0, searchers_js_1.getLangLabel)(e.searcher_key ?? 999, e.lang), l = e.device === void 0 ? void 0 : (0, searchers_js_1.getDeviceGIcon)(e.device), u = e.countryCode === void 0 ? void 0 : (0, string_js_1.genFlagLinkByCountryCode)(e.countryCode), d = {\n ...e,\n selected: r,\n title: t,\n searcherIcon: s,\n langLabel: c,\n deviceIcon: l,\n flagLink: u\n };\n F.value.push(d);\n });\n });\n let V = () => {\n if (!forms_CbUt_6Ff_esm_js_1.O.$?.ui.sortable) {\n console.info(\"Для работы сортировки требуется глобальная загрузка jQuery UI Sortable\");\n return;\n }\n I.value && $(I.value).sortable({\n distance: 10,\n stop: () => {\n let e = [...I.value.children].map((e) => Number(e.getAttribute(\"data-region-index\")));\n F.value.sort((t, n) => e.indexOf(t.index) - e.indexOf(n.index));\n }\n });\n }, H = () => {\n forms_CbUt_6Ff_esm_js_1.O.$?.ui.sortable && I.value && $(I.value).sortable(\"destroy\");\n };\n return (e, n) => {\n let r = (0, vue_1.resolveComponent)(\"TopCheckbox\"), i = (0, vue_1.resolveComponent)(\"TopButton\");\n return (0, vue_1.openBlock)(), (0, vue_1.createBlock)((0, vue_1.unref)(dialogs_CMrERMI7_esm_js_1.a), {\n id: (0, vue_1.unref)(P).id,\n pageActive: \"regions\",\n class: \"dialog_regionSelectorRegions\",\n height: \"600px\",\n width: \"600px\",\n onOpen: V,\n onClose: H\n }, {\n default: (0, vue_1.withCtx)(() => [(0, vue_1.createVNode)((0, vue_1.unref)(dialog_DeM4SApg_esm_js_1.r), {\n name: \"regions\",\n order: 0\n }, {\n header: (0, vue_1.withCtx)(() => [(0, vue_1.createElementVNode)(\"div\", E, [\n (0, vue_1.createVNode)(r, {\n modelValue: R.value,\n \"onUpdate:modelValue\": n[0] ||= (e) => R.value = e\n }, null, 8, [\"modelValue\"]),\n (0, vue_1.createVNode)(i, {\n class: \"dialog_regionSelectorRegions_sortButton\",\n color: \"theme\",\n \"data-top-icon\": \"\",\n onClick: n[1] ||= (e) => z(\"searcher_key\"),\n title: e.$i18n.Projects?.Sort_by_search_engine\n }, null, 8, [\"title\"]),\n (0, vue_1.createVNode)(i, {\n class: \"dialog_regionSelectorRegions_sortButton\",\n color: \"theme\",\n \"data-top-icon\": \"\",\n onClick: n[2] ||= (e) => z(\"key\"),\n title: e.$i18n.Projects?.Sort_by_yande_region_code\n }, null, 8, [\"title\"]),\n (0, vue_1.createVNode)(i, {\n class: \"dialog_regionSelectorRegions_sortButton\",\n color: \"theme\",\n \"data-top-icon\": \"\",\n onClick: n[3] ||= (e) => z(\"name\"),\n title: e.$i18n.Projects?.Sort_by_lphabetically\n }, null, 8, [\"title\"])\n ])]),\n body: (0, vue_1.withCtx)(() => [(0, vue_1.createElementVNode)(\"div\", {\n ref_key: \"elRegions\",\n ref: I\n }, [((0, vue_1.openBlock)(!0), (0, vue_1.createElementBlock)(vue_1.Fragment, null, (0, vue_1.renderList)(F.value, (e) => ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(r, {\n key: e.index,\n modelValue: e.selected,\n \"onUpdate:modelValue\": (t) => e.selected = t,\n class: \"dialog_regionSelectorRegions_region\",\n \"data-region-index\": e.index\n }, {\n default: (0, vue_1.withCtx)(() => [\n (0, vue_1.createElementVNode)(\"div\", {\n class: \"dialog_regionSelectorRegions_regionSearcherIcon\",\n \"data-top-icon\": e.searcherIcon\n }, null, 8, D),\n e.flagLink ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"img\", {\n key: 0,\n class: \"top-flag\",\n src: \"//topvisor.dev\" + e.flagLink,\n alt: e.countryCode\n }, null, 8, O)) : (0, vue_1.createCommentVNode)(\"\", !0),\n (0, vue_1.createElementVNode)(\"div\", k, [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(e.name) + \" \", 1), (0, vue_1.createElementVNode)(\"span\", A, (0, vue_1.toDisplayString)(e.areaName), 1)]),\n e.langLabel ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", j, \" [\" + (0, vue_1.toDisplayString)(e.langLabel) + \"] \", 1)) : (0, vue_1.createCommentVNode)(\"\", !0),\n e.deviceIcon ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", {\n key: 2,\n \"data-top-icon\": e.deviceIcon\n }, null, 8, M)) : (0, vue_1.createCommentVNode)(\"\", !0)\n ]),\n _: 2\n }, 1032, [\n \"modelValue\",\n \"onUpdate:modelValue\",\n \"data-region-index\"\n ]))), 128))], 512)]),\n footer: (0, vue_1.withCtx)(() => [(0, vue_1.createVNode)(i, { onClick: B }, {\n default: (0, vue_1.withCtx)(() => [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(e.$i18n.Common?.Apply), 1)]),\n _: 1\n })]),\n _: 1\n })]),\n _: 1\n }, 8, [\"id\"]);\n };\n }\n });\n exports.default = N;\n});\n//# sourceMappingURL=dialog_regionSelectorRegions-CYrmaDt3.esm.js.map\n","<script setup lang=\"ts\">\nimport { computed, reactive, ref, watch } from 'vue';\nimport { TopDialog, TopDialogPage, useTopDialogSelf } from '@/components/dialog/dialog';\nimport { genFlagLinkByCountryCode } from '@/core/utils/string';\nimport type { Props, RegionRich } from './types';\nimport { getDeviceGIcon, getLangLabel, getSearcherGIcon } from '@/core/utils/searchers';\nimport Core from '@/core/core/core';\n\ndefineOptions({ id: 'regionSelectorRegions' });\n\nconst props = defineProps<Partial<Props>>();\n\nconst dialog = useTopDialogSelf();\n\n/**\n * Список расширенных регионов для использования в компоненте\n */\nconst regionsRich = ref<RegionRich[]>([]);\n\n/**\n * Ссылка на элемент с регионами\n */\nconst elRegions = ref<null | HTMLElement>(null);\n\n/**\n * Направление сортировки по полю\n */\nconst sortedVectorByField = reactive({\n\tsearcher_key: -1,\n\tkey: -1,\n\tname: -1,\n});\n\n/**\n * Выбраны все регионы\n */\nconst isAllSelected = computed({\n\tget() {\n\t\treturn regionsRich.value.every(region => region.selected);\n\t},\n\n\tset(value) {\n\t\tregionsRich.value = regionsRich.value.map(region => ({ ...region, selected: value }));\n\t},\n});\n\n/**\n * Сортировать регионы по выбранному полю\n * @param sortedField - Поле для сортировки\n */\nconst sort = (sortedField: keyof typeof sortedVectorByField) => {\n\tsortedVectorByField[sortedField] = -sortedVectorByField[sortedField];\n\n\tregionsRich.value.sort((regionA, regionB) => {\n\t\tif (!regionA[sortedField] || !regionB[sortedField]) return -1;\n\n\t\treturn regionA[sortedField] >= regionB[sortedField] ? sortedVectorByField[sortedField] : -sortedVectorByField[sortedField];\n\t});\n};\n\n/**\n * Применить изменения\n *\n * Вызывает callback `props['@update:regionsIndexes']`\n */\nconst onSubmit = () => {\n\tif (!regionsRich.value.some(region => region.selected)) return;\n\n\tconst regionsIndexes = regionsRich.value\n\t\t.filter(region => region.selected)\n\t\t.map(region => region.index);\n\n\tprops['@update:regionsIndexes']?.(regionsIndexes);\n\n\tdialog.close();\n};\n\n// генерация регионов\nwatch([\n\t() => props.regions,\n\t() => props.regionsIndexes,\n], () => {\n\tregionsRich.value = [];\n\n\tif (!props.regions) return;\n\tif (!props.regionsIndexes) return;\n\n\tlet regions = [...props.regions];\n\n\t// отсортировать регионы по входным данным\n\tconst orderByRegionIndex = new Map(props.regionsIndexes.map((index, order) => [index, order]));\n\n\tregions.sort((regionA, regionB) => {\n\t\tconst orderA = orderByRegionIndex.get(regionA.index) ?? Number.MAX_VALUE;\n\t\tconst orderB = orderByRegionIndex.get(regionB.index) ?? Number.MAX_VALUE;\n\n\t\treturn orderA - orderB;\n\t});\n\n\tregions.forEach(region => {\n\t\tlet title = region.name;\n\t\tif (region.areaName) title += ` (${region.areaName})`;\n\n\t\tconst selected = props.regionsIndexes?.includes(region.index) ?? false;\n\t\tconst searcherIcon = getSearcherGIcon(region.searcher_key);\n\t\tconst langLabel = region.lang !== undefined ? getLangLabel(region.searcher_key ?? 999, region.lang) : undefined;\n\t\tconst deviceIcon = region.device !== undefined ? getDeviceGIcon(region.device) : undefined;\n\t\tconst flagLink = region.countryCode !== undefined ? genFlagLinkByCountryCode(region.countryCode) : undefined;\n\n\t\tconst regionRich = {\n\t\t\t...region,\n\t\t\tselected,\n\t\t\ttitle,\n\t\t\tsearcherIcon,\n\t\t\tlangLabel,\n\t\t\tdeviceIcon,\n\t\t\tflagLink,\n\t\t};\n\n\t\tregionsRich.value.push(regionRich);\n\t});\n});\n\n/**\n * Проверить на существование sortable\n */\nconst onOpen = () => {\n\tif (!Core.$?.ui['sortable']) {\n\t\tconsole.info('Для работы сортировки требуется глобальная загрузка jQuery UI Sortable');\n\n\t\treturn;\n\t}\n\n\tif (!elRegions.value) return;\n\n\t$(elRegions.value).sortable({\n\t\tdistance: 10,\n\n\t\tstop: () => {\n\t\t\t// Обновляем порядок регионов в массиве regionsRich после сортировки\n\t\t\tconst sortedIndexes = [...elRegions.value!.children].map(el => Number(el.getAttribute('data-region-index')));\n\t\t\tregionsRich.value.sort((a, b) => sortedIndexes.indexOf(a.index) - sortedIndexes.indexOf(b.index));\n\t\t},\n\t});\n};\n\n/**\n * Удаление sortable\n */\nconst onClose = () => {\n\tif (!Core.$?.ui['sortable']) return;\n\tif (!elRegions.value) return;\n\n\t$(elRegions.value).sortable('destroy');\n};\n\n</script>\n\n<template>\n\t<TopDialog\n\t\t:id=\"dialog.id\"\n\t\tpageActive=\"regions\"\n\t\tclass=\"dialog_regionSelectorRegions\"\n\t\theight=\"600px\"\n\t\twidth=\"600px\"\n\t\t@open=\"onOpen\"\n\t\t@close=\"onClose\"\n\t>\n\t\t<TopDialogPage name=\"regions\" :order=\"0\">\n\t\t\t<template #header>\n\t\t\t\t<div class=\"dialog_regionSelectorRegions_header\">\n\t\t\t\t\t<TopCheckbox v-model=\"isAllSelected\"></TopCheckbox>\n\n\t\t\t\t\t<TopButton\n\t\t\t\t\t\tclass=\"dialog_regionSelectorRegions_sortButton\"\n\t\t\t\t\t\tcolor=\"theme\"\n\t\t\t\t\t\tdata-top-icon=\"\"\n\t\t\t\t\t\t@click=\"sort('searcher_key')\"\n\t\t\t\t\t\t:title=\"$i18n.Projects?.Sort_by_search_engine\"\n\t\t\t\t\t/>\n\n\t\t\t\t\t<TopButton\n\t\t\t\t\t\tclass=\"dialog_regionSelectorRegions_sortButton\"\n\t\t\t\t\t\tcolor=\"theme\"\n\t\t\t\t\t\tdata-top-icon=\"\"\n\t\t\t\t\t\t@click=\"sort('key')\"\n\t\t\t\t\t\t:title=\"$i18n.Projects?.Sort_by_yande_region_code\"\n\t\t\t\t\t/>\n\n\t\t\t\t\t<TopButton\n\t\t\t\t\t\tclass=\"dialog_regionSelectorRegions_sortButton\"\n\t\t\t\t\t\tcolor=\"theme\"\n\t\t\t\t\t\tdata-top-icon=\"\"\n\t\t\t\t\t\t@click=\"sort('name')\"\n\t\t\t\t\t\t:title=\"$i18n.Projects?.Sort_by_lphabetically\"\n\t\t\t\t\t/>\n\t\t\t\t</div>\n\t\t\t</template>\n\n\t\t\t<template #body>\n\t\t\t\t<div ref=\"elRegions\">\n\t\t\t\t\t<TopCheckbox\n\t\t\t\t\t\tv-for=\"region of regionsRich\"\n\t\t\t\t\t\t:key=\"region.index\"\n\t\t\t\t\t\tv-model=\"region.selected\"\n\t\t\t\t\t\tclass=\"dialog_regionSelectorRegions_region\"\n\t\t\t\t\t\t:data-region-index=\"region.index\"\n\t\t\t\t\t>\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclass=\"dialog_regionSelectorRegions_regionSearcherIcon\"\n\t\t\t\t\t\t\t:data-top-icon=\"region.searcherIcon\"\n\t\t\t\t\t\t></div>\n\n\t\t\t\t\t\t<img\n\t\t\t\t\t\t\tv-if=\"region.flagLink\"\n\t\t\t\t\t\t\tclass=\"top-flag\"\n\t\t\t\t\t\t\t:src=\"'//topvisor.dev' + region.flagLink\"\n\t\t\t\t\t\t\t:alt=\"region.countryCode\"\n\t\t\t\t\t\t>\n\n\t\t\t\t\t\t<div class=\"top-ellipsis\">\n\t\t\t\t\t\t\t{{ region.name }}\n\n\t\t\t\t\t\t\t<span class=\"dialog_regionSelectorRegions_regionAreaName\">\n\t\t\t\t\t\t\t\t{{ region.areaName }}\n\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t<div v-if=\"region.langLabel\">\n\t\t\t\t\t\t\t[{{ region.langLabel }}]\n\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tv-if=\"region.deviceIcon\"\n\t\t\t\t\t\t\t:data-top-icon=\"region.deviceIcon\"\n\t\t\t\t\t\t></div>\n\t\t\t\t\t</TopCheckbox>\n\t\t\t\t</div>\n\t\t\t</template>\n\n\t\t\t<template #footer>\n\t\t\t\t<TopButton @click=\"onSubmit\">\n\t\t\t\t\t{{ $i18n.Common?.Apply }}\n\t\t\t\t</TopButton>\n\t\t\t</template>\n\t\t</TopDialogPage>\n\t</TopDialog>\n</template>\n\n<style>\n@import \"./style.css\";\n</style>\n"]}
|