@topvisor/ui 1.4.3-updateVue.0 → 1.5.0-updates.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.chunks/core-Dgj_YGWh.es.js +268 -0
- package/.chunks/core-Dgj_YGWh.es.js.map +1 -0
- package/.chunks/core-DzDFXOdI.amd.js +2 -0
- package/.chunks/core-DzDFXOdI.amd.js.map +1 -0
- package/.chunks/{datepicker-Dhlk31EZ.amd.js → datepicker-oa8ZwRhq.amd.js} +2 -2
- package/.chunks/{datepicker-Dhlk31EZ.amd.js.map → datepicker-oa8ZwRhq.amd.js.map} +1 -1
- package/.chunks/{datepicker-3ihHfSr7.es.js → datepicker-qToxk2nN.es.js} +2 -2
- package/.chunks/{datepicker-3ihHfSr7.es.js.map → datepicker-qToxk2nN.es.js.map} +1 -1
- package/.chunks/{dialog_regionSelectorRegions-nk70o5Ht.amd.js → dialog_regionSelectorRegions-CZ0tMVSq.amd.js} +2 -2
- package/.chunks/{dialog_regionSelectorRegions-nk70o5Ht.amd.js.map → dialog_regionSelectorRegions-CZ0tMVSq.amd.js.map} +1 -1
- package/.chunks/{dialog_regionSelectorRegions-D9ZHTNkd.es.js → dialog_regionSelectorRegions-qDW2Ejsv.es.js} +5 -5
- package/.chunks/{dialog_regionSelectorRegions-D9ZHTNkd.es.js.map → dialog_regionSelectorRegions-qDW2Ejsv.es.js.map} +1 -1
- package/.chunks/{dialogs.vue_vue_type_script_setup_true_lang-B8xv-moy.amd.js → dialogs.vue_vue_type_script_setup_true_lang-BBix_8WK.amd.js} +2 -2
- package/.chunks/{dialogs.vue_vue_type_script_setup_true_lang-B8xv-moy.amd.js.map → dialogs.vue_vue_type_script_setup_true_lang-BBix_8WK.amd.js.map} +1 -1
- package/.chunks/{dialogs.vue_vue_type_script_setup_true_lang-BI9rU5DL.es.js → dialogs.vue_vue_type_script_setup_true_lang-CJ97l1ST.es.js} +3 -3
- package/.chunks/{dialogs.vue_vue_type_script_setup_true_lang-BI9rU5DL.es.js.map → dialogs.vue_vue_type_script_setup_true_lang-CJ97l1ST.es.js.map} +1 -1
- package/.chunks/{forms-D6S85mMQ.amd.js → forms-DDNzqU6o.amd.js} +3 -3
- package/.chunks/{forms-D6S85mMQ.amd.js.map → forms-DDNzqU6o.amd.js.map} +1 -1
- package/.chunks/{forms-CsPxqywz.es.js → forms-DtC-EKJL.es.js} +217 -213
- package/.chunks/{forms-CsPxqywz.es.js.map → forms-DtC-EKJL.es.js.map} +1 -1
- package/.chunks/lazy-DDNqYkXn.amd.js +2 -0
- package/.chunks/lazy-DDNqYkXn.amd.js.map +1 -0
- package/.chunks/{lazy-40pjr8cZ.es.js → lazy-HKSyLh72.es.js} +23 -19
- package/.chunks/lazy-HKSyLh72.es.js.map +1 -0
- package/.chunks/{notice-IPOLYVCW.es.js → notice-BvQl911b.es.js} +3 -3
- package/.chunks/{notice-IPOLYVCW.es.js.map → notice-BvQl911b.es.js.map} +1 -1
- package/.chunks/{notice-CNyRUCZZ.amd.js → notice-CJ3WOTCM.amd.js} +2 -2
- package/.chunks/{notice-CNyRUCZZ.amd.js.map → notice-CJ3WOTCM.amd.js.map} +1 -1
- package/.chunks/{page.vue_vue_type_script_setup_true_lang-CRea7lRi.es.js → page.vue_vue_type_script_setup_true_lang-Dd5-B4Ss.es.js} +9 -9
- package/.chunks/{page.vue_vue_type_script_setup_true_lang-CRea7lRi.es.js.map → page.vue_vue_type_script_setup_true_lang-Dd5-B4Ss.es.js.map} +1 -1
- package/.chunks/{page.vue_vue_type_script_setup_true_lang-BEpRLx2z.amd.js → page.vue_vue_type_script_setup_true_lang-fl6-Ql4d.amd.js} +2 -2
- package/.chunks/{page.vue_vue_type_script_setup_true_lang-BEpRLx2z.amd.js.map → page.vue_vue_type_script_setup_true_lang-fl6-Ql4d.amd.js.map} +1 -1
- package/.chunks/policy.vue_vue_type_style_index_0_lang-Bv3LwNDC.es.js +519 -0
- package/.chunks/policy.vue_vue_type_style_index_0_lang-Bv3LwNDC.es.js.map +1 -0
- package/.chunks/policy.vue_vue_type_style_index_0_lang-Da7rztT5.amd.js +2 -0
- package/.chunks/policy.vue_vue_type_style_index_0_lang-Da7rztT5.amd.js.map +1 -0
- package/.chunks/{popup-DvXkX-lu.es.js → popup-OuDglAOF.es.js} +4 -4
- package/.chunks/popup-OuDglAOF.es.js.map +1 -0
- package/.chunks/{popup-BrEWCQkR.amd.js → popup-yXIpyok3.amd.js} +2 -2
- package/.chunks/popup-yXIpyok3.amd.js.map +1 -0
- package/.chunks/{popupHint.vue_vue_type_style_index_0_lang-KuWtifP4.amd.js → popupHint.vue_vue_type_style_index_0_lang-Bu_HvFoW.amd.js} +2 -2
- package/.chunks/{popupHint.vue_vue_type_style_index_0_lang-KuWtifP4.amd.js.map → popupHint.vue_vue_type_style_index_0_lang-Bu_HvFoW.amd.js.map} +1 -1
- package/.chunks/{popupHint.vue_vue_type_style_index_0_lang-TWsWJQFN.es.js → popupHint.vue_vue_type_style_index_0_lang-DAQIAxvu.es.js} +5 -5
- package/.chunks/{popupHint.vue_vue_type_style_index_0_lang-TWsWJQFN.es.js.map → popupHint.vue_vue_type_style_index_0_lang-DAQIAxvu.es.js.map} +1 -1
- package/.chunks/{utils-BywGu5Tr.es.js → utils-BNzP9anP.es.js} +2 -2
- package/.chunks/{utils-BywGu5Tr.es.js.map → utils-BNzP9anP.es.js.map} +1 -1
- package/.chunks/{utils-B0_n8dlR.amd.js → utils-CWn_G7OO.amd.js} +2 -2
- package/.chunks/{utils-B0_n8dlR.amd.js.map → utils-CWn_G7OO.amd.js.map} +1 -1
- package/.chunks/utils-DIviuVEw.amd.js +2 -0
- package/.chunks/utils-DIviuVEw.amd.js.map +1 -0
- package/.chunks/{utils-BlXb8CrZ.es.js → utils-Dma85ehT.es.js} +68 -68
- package/.chunks/utils-Dma85ehT.es.js.map +1 -0
- package/.chunks/{widgetInput.vue_vue_type_script_setup_true_lang-Pp4anQxP.es.js → widgetInput.vue_vue_type_script_setup_true_lang-CX_BOcVY.es.js} +6 -6
- package/.chunks/{widgetInput.vue_vue_type_script_setup_true_lang-Pp4anQxP.es.js.map → widgetInput.vue_vue_type_script_setup_true_lang-CX_BOcVY.es.js.map} +1 -1
- package/.chunks/{widgetInput.vue_vue_type_script_setup_true_lang-BUY8yqxb.amd.js → widgetInput.vue_vue_type_script_setup_true_lang-CkOmb3VD.amd.js} +2 -2
- package/.chunks/{widgetInput.vue_vue_type_script_setup_true_lang-BUY8yqxb.amd.js.map → widgetInput.vue_vue_type_script_setup_true_lang-CkOmb3VD.amd.js.map} +1 -1
- package/api/additional.d.ts +0 -1
- package/api/index.amd.js +1 -1
- package/api/index.d.ts +0 -1
- package/api/index.js +6 -6
- package/assets/charts.css +1 -1
- package/assets/core.css +1 -1
- package/assets/forms.css +1 -1
- package/assets/notice.css +1 -1
- package/assets/policy.css +1 -1
- package/assets/project.css +1 -1
- package/assets/tabsView.css +1 -1
- package/assets/themes/dark.css +1 -1
- package/assets/themes/light.css +1 -1
- package/charts/charts.amd.js +1 -1
- package/charts/charts.d.ts +0 -1
- package/charts/charts.js +14 -14
- package/core/app.amd.js +1 -1
- package/core/app.d.ts +0 -1
- package/core/app.js +15 -15
- package/dialog/dialog.amd.js +1 -1
- package/dialog/dialog.d.ts +0 -1
- package/dialog/dialog.js +6 -6
- package/extra/extra.amd.js +1 -1
- package/extra/extra.amd.js.map +1 -1
- package/extra/extra.d.ts +0 -1
- package/extra/extra.js +10 -6
- package/extra/extra.js.map +1 -1
- package/forms/forms.amd.js +1 -1
- package/forms/forms.d.ts +0 -1
- package/forms/forms.js +1 -1
- package/formsExt/formsExt.amd.js +1 -1
- package/formsExt/formsExt.amd.js.map +1 -1
- package/formsExt/formsExt.d.ts +0 -1
- package/formsExt/formsExt.js +46 -45
- package/formsExt/formsExt.js.map +1 -1
- package/icomoon/Topvisor icons.json +776 -334
- package/icomoon/demo.html +85 -1
- package/icomoon/fonts/Topvisor-2.eot +0 -0
- package/icomoon/fonts/Topvisor-2.svg +6 -0
- package/icomoon/fonts/Topvisor-2.ttf +0 -0
- package/icomoon/fonts/Topvisor-2.woff +0 -0
- package/icomoon/selection.json +1 -1
- package/icomoon/style.css +23 -5
- package/layout/layout.amd.js +1 -1
- package/layout/layout.d.ts +0 -1
- package/layout/layout.js +7 -7
- package/package.json +6 -6
- package/popup/popup.amd.js +1 -1
- package/popup/popup.d.ts +0 -1
- package/popup/popup.js +9 -9
- package/popup/worker.amd.js +1 -1
- package/popup/worker.d.ts +0 -1
- package/popup/worker.js +2 -2
- package/project/project.amd.js +1 -1
- package/project/project.amd.js.map +1 -1
- package/project/project.d.ts +0 -1
- package/project/project.js +1052 -662
- package/project/project.js.map +1 -1
- package/src/{components → src/components}/charts/miniCharts/miniCharts.d.ts +1 -1
- package/src/{components → src/components}/core/notice/item/types.d.ts +1 -1
- package/src/{components → src/components}/core/notice/utils.d.ts +1 -1
- package/src/{components → src/components}/dialog/dialog/composables/dialogHandle.d.ts +1 -1
- package/src/{components → src/components}/dialog/dialog/dialogs/dialogs.vue.d.ts +2 -2
- package/src/{components → src/components}/dialog/dialog/stories/dialog_example/pages/utils.d.ts +1 -1
- package/src/src/components/dialog/dialog.d.ts +6 -0
- package/src/{components → src/components}/dialog/lib/worker.d.ts +1 -1
- package/src/{components → src/components}/forms/button/types.d.ts +1 -1
- package/src/{components → src/components}/forms/input/types.d.ts +1 -1
- package/src/src/components/forms/inputDate/types.d.ts +1 -0
- package/src/{components → src/components}/forms/select/types.d.ts +1 -1
- package/src/{components → src/components}/formsExt/editArea/types.d.ts +1 -1
- package/src/{components → src/components}/formsExt/editInput/types.d.ts +6 -2
- package/src/{components → src/components}/formsExt/libs/optionGroup/types.d.ts +1 -1
- package/src/{components → src/components}/formsExt/menu/types.d.ts +1 -1
- package/src/{components → src/components}/formsExt/policy/policy.vue.d.ts +1 -1
- package/src/{components → src/components}/formsExt/selector2/composables/useAPI.d.ts +210 -124
- package/src/{components → src/components}/formsExt/selector2/composables/useMenu.d.ts +211 -125
- package/src/{components → src/components}/formsExt/selector2/selector2.vue.d.ts +8 -5
- package/src/{components → src/components}/formsExt/selector2/types.d.ts +45 -3
- package/src/{components → src/components}/formsExt/selector2/utils.d.ts +2 -0
- package/src/{components → src/components}/popup/lib/popup.d.ts +3 -3
- package/src/{components → src/components}/popup/lib/worker.d.ts +2 -2
- package/src/{components → src/components}/popup/popup/opener/types.d.ts +1 -1
- package/src/{components → src/components}/popup/popup/popup.vue.d.ts +1 -1
- package/src/{components → src/components}/popup/popup/widgetInput/widgetInput.vue.d.ts +1 -1
- package/src/{components → src/components}/popup/popupConfirm/popupConfirm.vue.d.ts +1 -1
- package/src/{components → src/components}/project/competitorSelector/composables.d.ts +1 -1
- package/src/{components → src/components}/project/competitorSelector/types.d.ts +1 -1
- package/src/{components → src/components}/project/groupSelector/folders/types.d.ts +2 -1
- package/src/src/components/project/groupSelector/folders/utils.d.ts +422 -0
- package/src/{components → src/components}/project/groupSelector/groupSelector.vue.d.ts +2 -1
- package/src/{components → src/components}/project/groupSelector/groups/groups.vue.d.ts +20 -10
- package/src/{components → src/components}/project/groupSelector/groups/types.d.ts +2 -1
- package/src/src/components/project/groupSelector/groups/utils.d.ts +791 -0
- package/src/{components → src/components}/project/groupSelector/stories/mocks/index.d.ts +1 -1
- package/src/{components → src/components}/project/groupSelector/types.d.ts +6 -0
- package/src/src/components/project/groupSelector/utils.d.ts +37 -0
- package/src/{components → src/components}/project/project.d.ts +2 -0
- package/src/src/components/project/projectSelector/cache.d.ts +29 -0
- package/src/src/components/project/projectSelector/projectSelector.vue.d.ts +128 -0
- package/src/src/components/project/projectSelector/submenu/submenu.vue.d.ts +4 -0
- package/src/src/components/project/projectSelector/submenu/types.d.ts +17 -0
- package/src/src/components/project/projectSelector/types.d.ts +48 -0
- package/src/src/components/project/projectSelector/utils.d.ts +248 -0
- package/src/{components → src/components}/project/regionSelector/composables/selectRegion.d.ts +1 -1
- package/src/{components → src/components}/project/regionSelector/composables/selectSearcher.d.ts +1 -1
- package/src/{components → src/components}/project/regionSelector/dialog_regionSelectorRegions/types.d.ts +1 -1
- package/src/{components → src/components}/project/regionSelector/types.d.ts +9 -4
- package/src/{components → src/components}/project/regionSelector/utils/utils.d.ts +5 -5
- package/src/{components → src/components}/project/tagSelector/popupOpener/types.d.ts +1 -1
- package/src/{components → src/components}/project/tagSelector/types.d.ts +1 -1
- package/src/{components → src/components}/project/tagSelector/utils/el.d.ts +1 -1
- package/src/{components → src/components}/tabsView/tabsView/menu.vue.d.ts +2 -6
- package/src/{components → src/components}/tabsView/tabsView/store.d.ts +1 -1
- package/src/{core → src/core}/app.d.ts +2 -2
- package/src/{core → src/core}/core/core.d.ts +3 -3
- package/src/{core → src/core}/directives/shortcut.d.ts +2 -1
- package/src/src/core/directives/tooltip.d.ts +6 -0
- package/src/{core → src/core}/plugins/core.d.ts +6 -6
- package/src/{core → src/core}/utils/price.d.ts +2 -2
- package/src/src/core/utils/store.d.ts +6 -0
- package/src/src/core/utils/tests/date/dateFormat.test.d.ts +1 -0
- package/tabs/tabs.d.ts +0 -1
- package/tabs/tabs.js +5 -5
- package/tabsView/tabsView.amd.js +1 -1
- package/tabsView/tabsView.amd.js.map +1 -1
- package/tabsView/tabsView.d.ts +0 -1
- package/tabsView/tabsView.js +93 -104
- package/tabsView/tabsView.js.map +1 -1
- package/utils/check.d.ts +0 -1
- package/utils/clipboard.amd.js +1 -1
- package/utils/clipboard.d.ts +0 -1
- package/utils/clipboard.js +1 -1
- package/utils/date.amd.js +1 -1
- package/utils/date.d.ts +0 -1
- package/utils/date.js +1 -1
- package/utils/device.amd.js +1 -1
- package/utils/device.d.ts +0 -1
- package/utils/device.js +1 -1
- package/utils/dom.d.ts +0 -5
- package/utils/image.d.ts +0 -1
- package/utils/keyboard.d.ts +0 -1
- package/utils/lodash.amd.js +1 -1
- package/utils/lodash.d.ts +0 -1
- package/utils/lodash.js +1 -1
- package/utils/number.d.ts +0 -1
- package/utils/price.amd.js +1 -1
- package/utils/price.d.ts +0 -1
- package/utils/price.js +1 -1
- package/utils/route.d.ts +0 -1
- package/utils/scroll.d.ts +0 -1
- package/utils/searchers.amd.js +1 -1
- package/utils/searchers.d.ts +0 -1
- package/utils/searchers.js +3 -3
- package/utils/store.d.ts +0 -1
- package/utils/string.amd.js +1 -1
- package/utils/string.d.ts +0 -1
- package/utils/string.js +1 -1
- package/utils/system.d.ts +0 -1
- package/utils/url.d.ts +0 -1
- package/.chunks/core-CkdcFIiA.amd.js +0 -2
- package/.chunks/core-CkdcFIiA.amd.js.map +0 -1
- package/.chunks/core-D8Ou2oPH.es.js +0 -242
- package/.chunks/core-D8Ou2oPH.es.js.map +0 -1
- package/.chunks/lazy-40pjr8cZ.es.js.map +0 -1
- package/.chunks/lazy-DSFLxvj4.amd.js +0 -2
- package/.chunks/lazy-DSFLxvj4.amd.js.map +0 -1
- package/.chunks/policy.vue_vue_type_style_index_0_lang-CtJ7J9YB.amd.js +0 -2
- package/.chunks/policy.vue_vue_type_style_index_0_lang-CtJ7J9YB.amd.js.map +0 -1
- package/.chunks/policy.vue_vue_type_style_index_0_lang-D-FVZi-G.es.js +0 -496
- package/.chunks/policy.vue_vue_type_style_index_0_lang-D-FVZi-G.es.js.map +0 -1
- package/.chunks/popup-BrEWCQkR.amd.js.map +0 -1
- package/.chunks/popup-DvXkX-lu.es.js.map +0 -1
- package/.chunks/utils-BlXb8CrZ.es.js.map +0 -1
- package/.chunks/utils-Daq8EBlT.amd.js +0 -2
- package/.chunks/utils-Daq8EBlT.amd.js.map +0 -1
- package/src/components/dialog/dialog.d.ts +0 -6
- package/src/components/forms/inputDate/types.d.ts +0 -1
- package/src/components/project/groupSelector/folders/utils.d.ts +0 -63
- package/src/components/project/groupSelector/groups/utils.d.ts +0 -92
- package/src/core/directives/tooltip.d.ts +0 -10
- package/src/core/utils/store.d.ts +0 -6
- /package/src/{api → src/api}/api/additional.d.ts +0 -0
- /package/src/{api → src/api}/api/client/client.d.ts +0 -0
- /package/src/{api → src/api}/api/client/request-options.d.ts +0 -0
- /package/src/{api → src/api}/api/client/request.d.ts +0 -0
- /package/src/{api → src/api}/api/index.d.ts +0 -0
- /package/src/{api → src/api}/api/mocker/index.d.ts +0 -0
- /package/src/{api → src/api}/api/tests/types.test-d.d.ts +0 -0
- /package/src/{api → src/api}/api/types/api.d.ts +0 -0
- /package/src/{api → src/api}/api/types/client/client.d.ts +0 -0
- /package/src/{api → src/api}/api/types/client/middleware.d.ts +0 -0
- /package/src/{api → src/api}/api/types/client/options.d.ts +0 -0
- /package/src/{api → src/api}/api/types/client/request-context.d.ts +0 -0
- /package/src/{api → src/api}/api/types/client/request-options.d.ts +0 -0
- /package/src/{api → src/api}/api/types/client/request.d.ts +0 -0
- /package/src/{api → src/api}/api/types/ext.d.ts +0 -0
- /package/src/{api → src/api}/api/types/field.d.ts +0 -0
- /package/src/{api → src/api}/api/types/index.d.ts +0 -0
- /package/src/{api → src/api}/api/types/mocker.d.ts +0 -0
- /package/src/{api → src/api}/api/types/schema.d.ts +0 -0
- /package/src/{api → src/api}/api/types/tv.d.ts +0 -0
- /package/src/{api → src/api}/api/types/utils.d.ts +0 -0
- /package/src/{api → src/api}/api/utils/common.d.ts +0 -0
- /package/src/{api → src/api}/api/utils/field.d.ts +0 -0
- /package/src/{api → src/api}/api/utils/filters.d.ts +0 -0
- /package/src/{api → src/api}/api/utils/lazy.d.ts +0 -0
- /package/src/{components → src/components}/charts/charts.d.ts +0 -0
- /package/src/{components → src/components}/charts/miniChart/miniChart.vue.d.ts +0 -0
- /package/src/{components → src/components}/charts/miniChart/types.d.ts +0 -0
- /package/src/{components → src/components}/charts/miniChart/utils/consts.d.ts +0 -0
- /package/src/{components → src/components}/charts/miniCharts/miniCharts.vue.d.ts +0 -0
- /package/src/{components → src/components}/core/notice/item/item.vue.d.ts +0 -0
- /package/src/{components → src/components}/core/notice/notice.vue.d.ts +0 -0
- /package/src/{components → src/components}/core/notice/types.d.ts +0 -0
- /package/src/{components → src/components}/dialog/dialog/composables/asyncDialogHandle.d.ts +0 -0
- /package/src/{components → src/components}/dialog/dialog/composables/types.d.ts +0 -0
- /package/src/{components → src/components}/dialog/dialog/composables/utils.d.ts +0 -0
- /package/src/{components → src/components}/dialog/dialog/dialog.vue.d.ts +0 -0
- /package/src/{components → src/components}/dialog/dialog/page/page.vue.d.ts +0 -0
- /package/src/{components → src/components}/dialog/dialog/page/types.d.ts +0 -0
- /package/src/{components → src/components}/dialog/dialog/pageComponent/pageComponent.vue.d.ts +0 -0
- /package/src/{components → src/components}/dialog/dialog/pageComponent/types.d.ts +0 -0
- /package/src/{components → src/components}/dialog/dialog/types.d.ts +0 -0
- /package/src/{components → src/components}/dialog/lib/types.d.ts +0 -0
- /package/src/{components → src/components}/dialog/lib/utils.d.ts +0 -0
- /package/src/{components → src/components}/dialog/lib/utils.globalEvents.d.ts +0 -0
- /package/src/{components → src/components}/extra/extra.d.ts +0 -0
- /package/src/{components → src/components}/extra/rive/rive.vue.d.ts +0 -0
- /package/src/{components → src/components}/extra/rive/types.d.ts +0 -0
- /package/src/{components → src/components}/forms/avatar/avatar.vue.d.ts +0 -0
- /package/src/{components → src/components}/forms/avatar/types.d.ts +0 -0
- /package/src/{components → src/components}/forms/button/button.vue.d.ts +0 -0
- /package/src/{components → src/components}/forms/caption/caption.vue.d.ts +0 -0
- /package/src/{components → src/components}/forms/caption/types.d.ts +0 -0
- /package/src/{components → src/components}/forms/checkbox/checkbox.vue.d.ts +0 -0
- /package/src/{components → src/components}/forms/checkbox/types.d.ts +0 -0
- /package/src/{components → src/components}/forms/controlLabel/controlLabel.vue.d.ts +0 -0
- /package/src/{components → src/components}/forms/controlLabel/types.d.ts +0 -0
- /package/src/{components → src/components}/forms/forms.d.ts +0 -0
- /package/src/{components → src/components}/forms/helpers.d.ts +0 -0
- /package/src/{components → src/components}/forms/hint/hint.vue.d.ts +0 -0
- /package/src/{components → src/components}/forms/hint/types.d.ts +0 -0
- /package/src/{components → src/components}/forms/input/input.vue.d.ts +0 -0
- /package/src/{components → src/components}/forms/inputDate/datepicker.d.ts +0 -0
- /package/src/{components → src/components}/forms/inputDate/inputDate.vue.d.ts +0 -0
- /package/src/{components → src/components}/forms/inputRange/inputRange.vue.d.ts +0 -0
- /package/src/{components → src/components}/forms/inputRange/types.d.ts +0 -0
- /package/src/{components → src/components}/forms/loadbar/loadbar.vue.d.ts +0 -0
- /package/src/{components → src/components}/forms/preloader/preloader.vue.d.ts +0 -0
- /package/src/{components → src/components}/forms/preloader/types.d.ts +0 -0
- /package/src/{components → src/components}/forms/radio/radio.vue.d.ts +0 -0
- /package/src/{components → src/components}/forms/radio/types.d.ts +0 -0
- /package/src/{components → src/components}/forms/select/select.vue.d.ts +0 -0
- /package/src/{components → src/components}/forms/switcher/switcher.vue.d.ts +0 -0
- /package/src/{components → src/components}/forms/switcher/types.d.ts +0 -0
- /package/src/{components → src/components}/forms/textarea/textarea.vue.d.ts +0 -0
- /package/src/{components → src/components}/forms/textarea/types.d.ts +0 -0
- /package/src/{components → src/components}/formsExt/checkboxGroup/checkboxGroup.vue.d.ts +0 -0
- /package/src/{components → src/components}/formsExt/checkboxGroup/types.d.ts +0 -0
- /package/src/{components → src/components}/formsExt/editArea/editArea.vue.d.ts +0 -0
- /package/src/{components → src/components}/formsExt/editInput/editInput.vue.d.ts +0 -0
- /package/src/{components → src/components}/formsExt/formsExt.d.ts +0 -0
- /package/src/{components → src/components}/formsExt/info/info.vue.d.ts +0 -0
- /package/src/{components → src/components}/formsExt/info/types.d.ts +0 -0
- /package/src/{components → src/components}/formsExt/libs/optionGroup/optionGroup.vue.d.ts +0 -0
- /package/src/{components → src/components}/formsExt/menu/menu.vue.d.ts +0 -0
- /package/src/{components → src/components}/formsExt/policy/types.d.ts +0 -0
- /package/src/{components → src/components}/formsExt/radioGroup/radioGroup.vue.d.ts +0 -0
- /package/src/{components → src/components}/formsExt/radioGroup/types.d.ts +0 -0
- /package/src/{components → src/components}/formsExt/selector2/cache.d.ts +0 -0
- /package/src/{components → src/components}/formsExt/selector2/itemMulti.vue.d.ts +0 -0
- /package/src/{components → src/components}/layout/islandRows/islandRows.vue.d.ts +0 -0
- /package/src/{components → src/components}/layout/islandRows/islandRowsRow/islandRowsRow.vue.d.ts +0 -0
- /package/src/{components → src/components}/layout/islandRows/islandRowsRow/types.d.ts +0 -0
- /package/src/{components → src/components}/layout/islandRows/islandRowsSubTitle/islandRowsSubTitle.vue.d.ts +0 -0
- /package/src/{components → src/components}/layout/islandRows/types.d.ts +0 -0
- /package/src/{components → src/components}/layout/layout.d.ts +0 -0
- /package/src/{components → src/components}/layout/rows/rows.vue.d.ts +0 -0
- /package/src/{components → src/components}/layout/rows/types.d.ts +0 -0
- /package/src/{components → src/components}/popup/lib/popup.globalEvents.d.ts +0 -0
- /package/src/{components → src/components}/popup/lib/worker.globalEvents.d.ts +0 -0
- /package/src/{components → src/components}/popup/popup/listItem.vue.d.ts +0 -0
- /package/src/{components → src/components}/popup/popup/opener/opener.vue.d.ts +0 -0
- /package/src/{components → src/components}/popup/popup/types.d.ts +0 -0
- /package/src/{components → src/components}/popup/popup.d.ts +0 -0
- /package/src/{components → src/components}/popup/popupAlert/popupAlert.vue.d.ts +0 -0
- /package/src/{components → src/components}/popup/popupAlert/types.d.ts +0 -0
- /package/src/{components → src/components}/popup/popupConfirm/types.d.ts +0 -0
- /package/src/{components → src/components}/popup/popupHint/popupHint.vue.d.ts +0 -0
- /package/src/{components → src/components}/popup/popupHint/types.d.ts +0 -0
- /package/src/{components → src/components}/popup/popupPrompt/popupPrompt.vue.d.ts +0 -0
- /package/src/{components → src/components}/popup/popupPrompt/types.d.ts +0 -0
- /package/src/{components → src/components}/popup/worker.d.ts +0 -0
- /package/src/{components → src/components}/project/competitorSelector/competitorSelector.vue.d.ts +0 -0
- /package/src/{components → src/components}/project/groupSelector/folders/folders.vue.d.ts +0 -0
- /package/src/{components → src/components}/project/groupSelector/stories/mocks/folders.d.ts +0 -0
- /package/src/{components → src/components}/project/groupSelector/stories/mocks/groups.d.ts +0 -0
- /package/src/{components → src/components}/project/regionSelector/composables/compare.d.ts +0 -0
- /package/src/{components → src/components}/project/regionSelector/composables/selectorRegion.d.ts +0 -0
- /package/src/{components → src/components}/project/regionSelector/dialog_regionSelectorRegions/dialog_regionSelectorRegions.vue.d.ts +0 -0
- /package/src/{components → src/components}/project/regionSelector/regionSelector.vue.d.ts +0 -0
- /package/src/{components → src/components}/project/regionSelector/utils/consts.d.ts +0 -0
- /package/src/{components → src/components}/project/tagSelector/popupListItem/tagPopupListItem.vue.d.ts +0 -0
- /package/src/{components → src/components}/project/tagSelector/popupListItem/types.d.ts +0 -0
- /package/src/{components → src/components}/project/tagSelector/popupOpener/popupOpener.vue.d.ts +0 -0
- /package/src/{components → src/components}/project/tagSelector/tagIcon/tagIcon.vue.d.ts +0 -0
- /package/src/{components → src/components}/project/tagSelector/tagIcon/types.d.ts +0 -0
- /package/src/{components → src/components}/project/tagSelector/tagSelector.vue.d.ts +0 -0
- /package/src/{components → src/components}/project/tagSelector/tagsDefaults.d.ts +0 -0
- /package/src/{components → src/components}/project/tagSelector/utils/utils.d.ts +0 -0
- /package/src/{components → src/components}/tabs/tabs/content.vue.d.ts +0 -0
- /package/src/{components → src/components}/tabs/tabs/tab.vue.d.ts +0 -0
- /package/src/{components → src/components}/tabs/tabs/tabs.vue.d.ts +0 -0
- /package/src/{components → src/components}/tabs/tabs/types.d.ts +0 -0
- /package/src/{components → src/components}/tabs/tabs.d.ts +0 -0
- /package/src/{components → src/components}/tabsView/tabsView/menuDelimeter.vue.d.ts +0 -0
- /package/src/{components → src/components}/tabsView/tabsView/menuItem.vue.d.ts +0 -0
- /package/src/{components → src/components}/tabsView/tabsView/menuTitle.vue.d.ts +0 -0
- /package/src/{components → src/components}/tabsView/tabsView/tabsView.vue.d.ts +0 -0
- /package/src/{components → src/components}/tabsView/tabsView/types.d.ts +0 -0
- /package/src/{components → src/components}/tabsView/tabsView/utils.d.ts +0 -0
- /package/src/{components → src/components}/tabsView/tabsView.d.ts +0 -0
- /package/src/{core → src/core}/core/events/resize.d.ts +0 -0
- /package/src/{core → src/core}/core/events.d.ts +0 -0
- /package/src/{core → src/core}/core/options.d.ts +0 -0
- /package/src/{core → src/core}/core/preloaders.d.ts +0 -0
- /package/src/{core → src/core}/core/state.d.ts +0 -0
- /package/src/{core → src/core}/directives/data.d.ts +0 -0
- /package/src/{core → src/core}/directives/focus.d.ts +0 -0
- /package/src/{core → src/core}/directives/preloader.d.ts +0 -0
- /package/src/{core → src/core}/directives/scrollIntoView.d.ts +0 -0
- /package/src/{core → src/core}/directives/scrollShadow.d.ts +0 -0
- /package/src/{core → src/core}/directives/sticky.d.ts +0 -0
- /package/src/{core → src/core}/directives/swimUp.d.ts +0 -0
- /package/src/{core → src/core}/plugins/i18n.d.ts +0 -0
- /package/src/{core → src/core}/plugins/piniaTPA.d.ts +0 -0
- /package/src/{core → src/core}/utils/check.d.ts +0 -0
- /package/src/{core → src/core}/utils/clipboard.d.ts +0 -0
- /package/src/{core → src/core}/utils/composables/useWatch.d.ts +0 -0
- /package/src/{core → src/core}/utils/date.d.ts +0 -0
- /package/src/{core → src/core}/utils/device.d.ts +0 -0
- /package/src/{core → src/core}/utils/dom.d.ts +0 -0
- /package/src/{core → src/core}/utils/image.d.ts +0 -0
- /package/src/{core → src/core}/utils/keyboard.d.ts +0 -0
- /package/src/{core → src/core}/utils/lodash.d.ts +0 -0
- /package/src/{core → src/core}/utils/number.d.ts +0 -0
- /package/src/{core → src/core}/utils/route.d.ts +0 -0
- /package/src/{core → src/core}/utils/scroll.d.ts +0 -0
- /package/src/{core → src/core}/utils/searchers.d.ts +0 -0
- /package/src/{core → src/core}/utils/store/localStorage.d.ts +0 -0
- /package/src/{core → src/core}/utils/store/plugin.d.ts +0 -0
- /package/src/{core → src/core}/utils/store/store.d.ts +0 -0
- /package/src/{core → src/core}/utils/string.d.ts +0 -0
- /package/src/{core → src/core}/utils/system.d.ts +0 -0
- /package/src/{core → src/core}/utils/url.d.ts +0 -0
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
define(["require","exports","./forms-D6S85mMQ.amd","../utils/dom.amd","../popup/worker.amd"],(function(C,y,h,e,n){"use strict";if(typeof _>"u")var _=window.Vue;class P{static componentName="Top";componentName;className;uid;el;options={};unmountEls=[];unmountEvents=[];init(t,p,i){if(!p)throw t+": el is undefined";const o=P.getComponent(p,t);if(o)return o.reInit(i),o;this.componentName=t,this.className="top"+t[0].toUpperCase()+t.substring(1),this.uid=this.componentName+(Math.random()+"").replace(".",""),this._setComponent(p),this.el=p,this.el.classList.add(this.className),this.options=Object.assign(this.options,i),this.mount()}static getComponent(t,p){return e.default.storage(t,"#"+p)}_setComponent(t){e.default.storage(t,"#"+this.componentName,this)}mount(){throw"Please, add method mount() to component: "+this.componentName}unmount(){e.default.storage(this.el,"#"+this.componentName,null),this.unmountEls.forEach(t=>{t.remove()}),this.unmountEls=[],this.unmountEvents.forEach(t=>{t.el.removeEventListener(t.type,t.listener,t.options)}),this.unmountEvents=[]}registerElForUnmount(t){this.unmountEls.push(t)}addEventListenerWithUnmount(t,p,i,o){t.addEventListener(p,i,o),this.registerEventForUnmount(t,p,i,o)}registerEventForUnmount(t,p,i,o){const s={el:t,type:p,listener:i,options:o};this.unmountEvents.push(s)}reInit(t){throw"Please, add method reInit() to component: "+this.componentName}static detach(t){if(t instanceof NodeList)t.forEach(p=>p.parentElement?.removeChild(p));else{const p=t;p.parentElement?.removeChild(p)}}}class I{static isInited=!1;static init(){this.isInited||(this.isInited=!0,document.addEventListener("click",this.onclickCapture,{capture:!0}),document.addEventListener("click",this.onclick),document.addEventListener("keydown",this.onkeydown))}static onclickCapture(t){if(!(!(t.target instanceof HTMLElement)||!t.target.closest(".top-popup-wrapper"))){if(t.target.matches("[data-top-popup]")){const i=t.target.closest("ul"),o=t.target.closest("a, .a");i&&i.querySelector("a.top-active, .a.top-active")?.classList.remove("top-active"),o&&o.classList.add("top-active"),t.stopPropagation();return}if(t.target.matches(".top-popup-wrapper")){const i=t.target;n.TopPopupWorker.close(i,!0),t.stopPropagation();return}}}static onclick(t){if(!(t.target instanceof HTMLElement))return;const p=t.target.closest(".closer, a, .a, .top-button");if(p){const i=t.target.closest(".top-popup-wrapper");if(!i||p.matches(".top-popup-noCloser"))return;p.getAttribute("href")==="."&&t.preventDefault(),n.TopPopupWorker.close(i,!0)}}static onkeydown(t){if(!(t.target instanceof HTMLElement))return;let p=t.target.closest(".top-popup-wrapper");if(p||(p=n.TopPopupWorker.getPopupFromOpener(t.target)?.elPopup??null),!p)return;const i=p.querySelector("ul.top-popup_content");switch(t.key){case"Escape":n.TopPopupWorker.close(p,!0);break;case"Enter":if(!i){if(e.default.querySelectorVisible(p,".preloader"))break;const u=e.default.querySelectorVisible(p,".top-popup_footer .go, .top-popup_footer [data-action]");if(u instanceof HTMLElement){u.click();break}let f=e.default.querySelectorVisibleLast(p,".top-popup_footer .top-button:focus");f||(f=e.default.querySelectorVisibleLast(p,".top-popup_footer .top-button")),f instanceof HTMLElement&&f.click();break}const o=e.default.querySelectorVisible(p,"li > a.top-active");o&&o.getAttribute("href")&&(t.preventDefault(),location.href=o.getAttribute("href"));const s=p.querySelector("li > .top-active");s instanceof HTMLElement&&s.click();break;case"ArrowUp":case"ArrowRight":case"ArrowDown":case"ArrowLeft":if(!i)break;if(t.key==="ArrowRight"||t.key==="ArrowLeft"){if(e.default.querySelectorVisible(p,"ul.top-popup_content > li:not(.top-popup_liNoSelectable) > .top-active > .top-popup_listMore"))t.preventDefault();else if(t.target.tagName==="INPUT")break}else t.preventDefault();const a=p.querySelector("ul.top-popup_content > li:not(.top-popup_liNoSelectable) > .top-active")?.parentElement;if(t.key==="ArrowRight"&&a){const u=a.querySelector(".top-active > .top-popup_listMore");if(u instanceof HTMLElement)return u.click()}const d=e.default.querySelectorAllVisible(p,"ul.top-popup_content > li:not(.top-popup_liNoSelectable)"),c=d.length;if(!c)return;let r=-1;if(a&&(r=d.indexOf(a)),t.key==="ArrowUp"||t.key==="ArrowLeft"?r--:r++,t.key==="ArrowLeft"&&r===-1)return t.target.matches("input")?void 0:n.TopPopupWorker.close(p,!0);if(t.key==="ArrowRight"&&r===c)return;r<0&&(r=c-1),r>c-1&&(r=0),p.querySelectorAll("ul.top-popup_content > li > .top-active").forEach(u=>u.classList.remove("top-active")),d[r].querySelector(":scope > a, :scope > .a")?.classList.add("top-active"),n.TopPopupWorker.scrollToActive(p);break}}}const L=":root{--top-popup-z-index: 200000;--top-popup-transition-delay: .1s;--top-popup-offset: var(--top-padding-2);--top-popup-background-color: var(--color-layout-front-1);--top-popup-background-color-hover: var(--color-layout-front-3);--top-popup-background-color-active: var(--color-layout-front-4);--top-popup-border-color: var(--color-line-2-opacity);--top-popup-title-background-color: var(--color-layer-1);--top-popup-content-padding: calc(var(--top-popup-list-padding) + var(--top-popup-listItem-padding));--top-popup-list-padding: var(--top-padding-2);--top-popup-listItem-radius: var(--top-radius-2);--top-popup-listItem-padding: var(--top-padding-2)}.top-popup-front{position:relative}.top-popup-wrapper{--top-popup-height: 0px;--top-popup-right-bounding: 0px;--top-popup-bottom-bounding: 0px;--top-popup-top: 0px;--top-popup-right: calc(100vw - var(--top-popup-right-bounding));--top-popup-bottom: calc(var(--100vh) - var(--top-popup-bottom-bounding));--top-popup-left: 0px;--top-popup-margin: -10px;text-align:initial;white-space:normal;word-break:normal;position:absolute;z-index:200000;outline:none}.top-popup-wrapper:not(.top-popup-wrapper-shown){overflow:hidden}.top-popupPanel{cursor:default;box-shadow:var(--top-shadow-b);border-radius:14px;background:var(--top-popup-background-color);position:absolute;overflow:hidden;display:flex;flex-direction:column}.top-popup-wrapper>*{opacity:0;transition:opacity var(--top-popup-transition-delay) linear,transform var(--top-popup-transition-delay) linear;pointer-events:auto}.top-popup-wrapper-shown:not(.top-popup-wrapper-closed)>*{opacity:1;transform:translate(0)!important}.top-popup_header,.top-popup_content,.top-popup_footer{font-size:14px}.top-popup_header,.top-popup_footer{display:flex;align-items:center;justify-content:space-between}.top-popup_header{color:var(--color-text-1);border-bottom:1px solid var(--top-popup-border-color);padding:var(--top-padding-3);font-weight:600}.top-popup_header>*{font-weight:400}.top-popup_header>.a{cursor:pointer}.top-popup_header>.a:hover{color:var(--color-text-primary)}.top-popup_headerButton{width:60px}.top-popup_widget{padding:var(--top-padding-2)}.top-popup_content{margin:0;flex-grow:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--top-gap-4);-webkit-overflow-scrolling:touch}div.top-popup_content{color:var(--color-text-1);padding:var(--top-popup-content-padding)}div.top-popup_content>*{flex-shrink:0}div.top-popup_content>.top-button{margin:0}div.top-popup_content .top-unwrap{--top-unwrap-x: var(--top-popup-content-padding)}ul.top-popup_content{color:var(--color-text-1);padding:var(--top-popup-list-padding);gap:2px}ul.top-popup_content .top-unwrap{--top-unwrap-x: var(--top-popup-list-padding)}.top-popup_listItem{border-radius:var(--top-popup-listItem-radius);padding:var(--top-popup-listItem-padding);line-height:1!important}ul.top-popup_content li{margin:0;list-style:none;display:flex;align-items:center;position:relative}ul.top-popup_content li>*{flex-grow:1}ul.top-popup_content li>a:not(.top-button),ul.top-popup_content li>.a{cursor:pointer;box-sizing:border-box;border-radius:var(--top-popup-listItem-radius);background:var(--top-popup-background-color);padding:var(--top-popup-listItem-padding);color:var(--color-text-1)!important;font-size:14px;font-weight:400!important;text-decoration:none!important;font-style:normal;line-height:1!important;display:flex;flex:1 1 100%;align-items:center;transition:background-color .1s ease-in-out}.top-popup-wrapper-no_animate ul.top-popup_content li>a:not(.top-button),.top-popup-wrapper-no_animate ul.top-popup_content li>.a{transition:none}ul.top-popup_content li>a:not(.top-button):hover,ul.top-popup_content li>.a:hover{background:var(--top-popup-background-color-hover)}ul.top-popup_content li>a:not(.top-button).top-active,ul.top-popup_content li>.a.top-active{--top-icon-color: var(--color-text-primary) !important;background:var(--top-popup-background-color-active)}.top-popup_liastItem-withActions{width:240px;max-width:100%}.top-popup_listItemActionsLabel{flex-grow:1}.top-popup_listItemActions{margin-left:auto;flex-grow:0;display:flex}.top-popup_listItemActions>[data-top-icon]{--top-icon-size: 20px;--top-icon-color: var(--color-text-4)}.top-popup_listItemActions>[data-top-icon]:before{line-height:0}.top-popup_listItemActions>[data-top-icon]:hover,.top-popup_listItemActions>[data-top-icon].top-active{--top-icon-color: var(--color-text-3)}.top-popup_content+.top-popup_content{padding-top:0}.top-popup_listItem-title{background:var(--color-layer-1);color:var(--color-text-1);font-size:12px}.top-popup_listItem-formControls{padding-top:0;padding-bottom:0;display:flex;flex-direction:column}.top-popup_listItem-delimiter{border-radius:3px;background:var(--top-popup-border-color);height:1px;padding:0;margin:4px}.top-popup_listMore{font-size:20px;margin:calc(0px - var(--top-popup-listItem-padding)) calc(0px - var(--top-popup-listItem-padding) / 2) calc(0px - var(--top-popup-listItem-padding)) 0}.top-popup_listMore.top-button{margin:0}ul.top-popup_content li>.a.top-popup_listMore{text-align:center;flex-basis:10px}ul.top-popup_content li>.a.top-popup_listMore:before{color:var(--color-text-2)}ul.top-popup_content li>*>.top-popup_listMore{margin-left:auto;color:var(--color-layer-4);font-size:14px}ul.top-popup_content li>*>i.top-popup_listMore:hover,ul.top-popup_content li>*>i.top-popup_listMore.top-active{color:var(--color-text-primary)}ul.top-popup_content li>*>i.top-popup_listMore:before{transform:rotate(90deg);display:block}ul.top-popup_content li a.close{background:none!important}.top-popup_content>[data-top-icon]:before{--top-icon-size: 20px}ul.top-popup_content li>[data-top-icon]{--top-icon-color: var(--color-text-2);--top-icon-size: 20px;--top-icon-width: 20px}ul.top-popup_content li>[data-top-icon]:not(.top-button):before{height:1rem;margin-right:8px;transition:color .1s}ul.top-popup_content li:hover>[data-top-icon]:not(.top-button){--top-icon-color: var(--color-text-2)}.top-popup_footer{padding:var(--top-padding-3);border-top:1px solid var(--top-popup-border-color);display:flex;gap:var(--top-gap-2);justify-content:flex-end}.top-popup_footerSupportLink{margin-right:auto}.top-popup>[data-widget]{padding:0 var(--top-popup-list-padding)}.top-popup>[data-widget]+hr{margin:0 var(--top-popup-list-padding)}.top-popup .placeholder{border:1px solid #E0D9D9!important;border-right:none!important;border-left:none!important;background:#f9f9f9!important;margin:-1px 0;z-index:1;position:relative}.top-popup-wrapper.simple_list>.top-popup{min-width:0;white-space:nowrap}.top-popup_content .top-column{display:flex;flex-direction:column;gap:4px}.top-popup li .check_all,.top-popup li .clear_all{cursor:pointer;color:var(--color-text-primary);padding:8px;display:inline-block}.top-popup li .check_all:hover,.top-popup li .clear_all:hover{text-decoration:underline}.top-popup li .clear_all{display:none}.top-popup_content table{margin:-9px 0}.top-popup_content table td,.top-popup_content table th{padding:9px var(--top-popup-listItem-padding) 9px 0;vertical-align:top}.top-popup_content table th{width:40%;font-weight:600;white-space:nowrap}ul.top-popup_content .a>[type=checkbox],ul.top-popup_content .a>[type=radio]{margin:-8px 0 -8px auto}ul.top-popup_content a>[class*=icon],ul.top-popup_content i.a>[class*=icon]{transition:.1s}.top-popup .buttons{border-radius:0 0 4px 4px;border-top:1px solid #BDC3C7;background:#ecf0f1;padding:10px 15px;margin:10px -15px -10px;white-space:nowrap}.top-popup_footer [class*=btn]:not(.btn-transparent){min-width:100px;padding:5px 14px;margin-left:10px}.top-popup_footer [class*=btn]:first-child{margin-left:0}.top-popup_footer .btn.full_width{margin:0;flex-grow:1}",E=":root{--top-popup-list-padding: 0px;--top-popup-listItem-radius: 0px;--top-popup-listItem-padding: var(--top-padding-4)}.top-popup-wrapper{--top-popup-footer-offset: 25px;width:auto!important;height:auto!important;position:fixed;top:0!important;right:0!important;left:0!important;overflow:hidden;transition:background .3s}.top-popup-wrapper-shown:not(.top-popup-wrapper-closed){background:#00000080;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.top-popup-wrapper-shown:not(.top-popup-wrapper-closed)>.top-popup{opacity:1!important}.top-popup{border-radius:8px 8px 0 0;width:auto!important;max-height:calc(100% - var(--header-height, 0px) - var(--toolbar-height, 0px) - 12px);margin:0!important;top:auto!important;right:0!important;bottom:var(--toolbar-height, 0px)!important;left:0!important;display:flex;flex-direction:column;transform:translateY(80%);transition:opacity .3s,transform .3s}.top-popup-wrapper.p-from-top{--top-popup-footer-offset: 0px;top:var(--header-height, 0px)!important}.with_dialog .top-popup-wrapper.p-from-top{top:50px!important}.top-popup-wrapper.p-from-top>.top-popup{border-radius:0 0 8px 8px;max-height:calc(100% - 24px);top:0!important;bottom:auto!important;transform:translateY(calc(-100% - 24px))}.top-popup_widget:not(.p-from-top){order:10}ul.top-popup_content{gap:0}ul.top-popup_content li:not(:last-child){border-bottom:1px solid var(--top-popup-border-color)}.top-popup-wrapper.top-style_alt>.top-popup>ul>li{border-bottom:none}.top-popup_footer{flex-direction:column-reverse}.top-popup_footer>.top-button{--top-forms-base-height: var(--top-forms-base-height_l);width:100%}ul.top-popup_content .top-popup_listItem-title{--top-popup-padding-v: 12px}ul.top-popup_content .top-popup_listItem-delimiter{background:var(--color-line-1-opacity);height:4px;margin:0}ul.top-popup_content li:first-child>.top-popup_listItem-delimiter{border-top:1px solid var(--top-popup-border-color)}",k=".top-popup-wrapper{pointer-events:none}.top-popup{min-width:250px;max-width:calc(100vw - var(--top-popup-left) - 16px);max-height:calc(var(--top-popup-bottom) + var(--top-popup-height))}.top-popup-wrapper.p0>*{transform:translateY(-8px)}.top-popup-wrapper.p1>*{transform:translateY(8px)}.top-popup-wrapper.p2>*{transform:translate(8px)}.top-popup-wrapper.p3>*{transform:translateY(8px)}.top-popup-wrapper.p4>*{transform:translate(-8px)}.top-popup-wrapper.p0>.top-popup{top:-16px;left:-8px}.top-popup-wrapper.p1>.top-popup{bottom:calc(100% + 8px)}.top-popup-wrapper.p2>.top-popup{left:calc(100% + 8px)}.top-popup-wrapper.p3>.top-popup{top:calc(100% + 8px)}.top-popup-wrapper.p4>.top-popup{right:calc(100% + 8px)}.top-popup-wrapper.p2>.top-popup,.top-popup-wrapper.p4>.top-popup{margin-top:var(--top-popup-margin)}.top-popup-wrapper.p2.invert-y>.top-popup,.top-popup-wrapper.p4.invert-y>.top-popup{margin-bottom:var(--top-popup-margin)}.top-popup-wrapper.p1.with_notch>.top-popup{margin-bottom:5px}.top-popup-wrapper.p2.with_notch>.top-popup{margin-left:5px}.top-popup-wrapper.p3.with_notch>.top-popup{margin-top:5px}.top-popup-wrapper.p4.with_notch>.top-popup{margin-right:5px}.top-popup-wrapper.invert-x>.top-popup{right:0}.top-popup-wrapper.invert-y>.top-popup{bottom:0}.top-popup-wrapper.p1>.top-popup{max-height:calc(var(--top-popup-top) - var(--header-height, 0px) - 16px)}.top-popup-wrapper.p3>.top-popup{max-height:calc(var(--top-popup-bottom) - 16px)}.top-popup-wrapper.p2>.top-popup{max-width:calc(var(--top-popup-right) - 16px)}.top-popup-wrapper.p4>.top-popup{max-width:calc(var(--top-popup-left) - 16px)}.top-popup-wrapper.invert-x>.top-popup{max-width:calc(100vw - var(--top-popup-right) - 16px)}.top-popup-wrapper.invert-y>.top-popup{max-height:calc(100vh - var(--top-popup-bottom) - 16px)}.top-popup-wrapper>.notch{border:7.4px solid transparent;position:absolute;display:block}.top-popup-wrapper.p1>.notch{border-bottom:0;border-top:7.4px solid var(--color-layout-front-1);margin:0 0 7.4px -7.4px;bottom:100%;left:50%}.top-popup-wrapper.p2>.notch{border-left:0;border-right:7.4px solid var(--color-layout-front-1);margin:0 0 -7.4px 7.4px;bottom:50%;left:100%}.top-popup-wrapper.p3>.notch{border-top:0;border-bottom:7.4px solid var(--color-layout-front-1);margin:7.4px 0 0 -7.4px;top:100%;left:50%}.top-popup-wrapper.p4>.notch{border-right:0;border-left:7.4px solid var(--color-layout-front-1);margin:0 7.4px -7.4px 0;bottom:50%;right:100%}.top-popup-wrapper.p1>.notch-border{border-top-color:#0000000d;margin-bottom:6px}.top-popup-wrapper.p2>.notch-border{border-right-color:#0000000d;margin-left:6px}.top-popup-wrapper.p3>.notch-border{border-bottom-color:#0000000d;margin-top:6px}.top-popup-wrapper.p4>.notch-border{border-left-color:#0000000d;margin-right:6px}.top-popup-wrapper.p1.with_notch>.top-popup,.top-popup-wrapper.p3.with_notch>.top-popup{margin-left:-16px!important}.top-popup-wrapper.p1.with_notch>.notch,.top-popup-wrapper.p3.with_notch>.notch{margin-left:-8px!important}.top-popup-wrapper.p1.with_notch.invert-x,.top-popup-wrapper.p3.with_notch.invert-x{margin-left:3px!important}.top-popup-wrapper.p1.with_notch.invert-x>.notch,.top-popup-wrapper.p3.with_notch.invert-x>.notch{margin-left:-9px!important}ul.top-popup_content li>*>i.top-popup_listMore{visibility:hidden;transition:none}ul.top-popup_content li:hover>*>i.top-popup_listMore,ul.top-popup_content li>*.top-active>i.top-popup_listMore,ul.top-popup_content li>*>i.top-popup_listMore.top-active{visibility:visible}.top-popup_listItemActions{display:none}.top-popup_listItem.top-active>.top-popup_listItemActions,.top-popup_listItem:hover>.top-popup_listItemActions{display:flex}";h.Core.insertStyleToPage(L),h.Core.insertStyleToPage(E,"m"),h.Core.insertStyleToPage(k,"pc");class g extends P{static componentName="TopPopup";elActiveByDefault;elPopup;elPopupInner;elPopupHeader;elPopupWidget;elPopupBody;elPopupFooter;elFront;openerIsInput=!1;popupParent;$;elStartPosition;shift={top:0,left:0};isClosed=!1;isFirstClick=!0;type;options={popup:"",p:0,notch:!1,class:"",posBy:"left",frontSelector:"",invertX:!1,openByHover:!1,useOriginal:!1,transitionDuration:100,isFullScreen:!1};events={};constructor(t,p){super(),this.init(g.componentName,t,p)}async mount(){if(!(this.el instanceof HTMLElement))return;const t=this.vueGetComponent();if(this.el.closest(".top-popup-wrapper")&&(this.popupParent=n.TopPopupWorker.getPopup(this.el.closest(".top-popup-wrapper"))),await this.mountJQuery(),e.default.css(this.el,"position")!=="absolute"&&(this.el.style.position="relative"),this.el.dataset.topPopupOpened="opened",this.elActiveByDefault=this.el.classList.contains("top-active"),this.el.classList.add("top-active"),this.openerIsInput=this.el.classList.contains("top-input"),this.el.classList.contains("top-input-project_name")&&(this.openerIsInput=!1),this.openerIsInput){const o=this.el.querySelector("input");o&&!o.__popupOnBlur&&(o.__popupOnBlur=!0,o.addEventListener("blur",s=>{n.TopPopupWorker.getPopupFromOpener(this.el)?.close()}))}if(t)this.type="vue",this.options.popup="",this.elPopup=e.default.genEl("div",{},this.options.popup);else if(this.options.popup?.match(/^[#.]/))this.type="selector",this.elPopup=document.querySelector(`${this.options.popup}.template`)||void 0;else{if(this.type="html",this.options.useOriginal)throw"Option useOriginal not allowed for text templates";this.elPopup=e.default.genEl("div",{},this.options.popup??"")}if(this.type!=="html"&&!t||t?.opened){if(!t||t?.opened){let o;if(t?.opened?o=t.popup.elPopup:o=document.querySelector(`${this.options.popup}.top-popup-wrapper-shown`)||void 0,o){this.elPopup=o,this.el.dataset.topPopupOpened="",this.elActiveByDefault||this.el.classList.remove("top-active"),n.TopPopupWorker.close(this.elPopup),setTimeout(()=>this.mount(),this.options.transitionDuration);return}}this.elPopup||(this.elPopup=document.querySelector(`${this.options.popup}:not(.top-popup-wrapper)`)||void 0)}if(!this.elPopup)return;for(this.options.useOriginal?(this.elStartPosition=this.elPopup.closest(".top-popup-el-start-position"),this.elStartPosition||(this.elStartPosition=e.default.wrap(this.elPopup,"i"),this.elStartPosition.classList.add("top-popup-el-start-position","hidden"))):(this.elPopup=this.elPopup.cloneNode(!0),this.type==="selector"&&!this.elPopup.matches(".template")&&(this.elPopup.classList.remove("hidden"),this.elPopup.querySelector(":scope > .top-popup_content")||this.elPopup.classList.add("top-popup_content"),this.elPopup=e.default.wrap(this.elPopup,"div")),this.type==="html"&&(this.elPopup.querySelector(":scope > .top-popup_content")||(this.elPopup.classList.add("top-popup_content"),this.elPopup=e.default.wrap(this.elPopup,"div"))),(this.type==="selector"&&!this.elPopup.matches(".template")||this.type==="html"||this.type==="vue")&&(e.default.querySelectorAllArray(this.elPopup,"[data-top-popup]").forEach(o=>{o instanceof HTMLElement&&(o.dataset.topPopupPosBy="fixed")}),e.default.querySelectorAllArray(this.elPopup,".top-popup-wrapper").forEach(o=>o.remove()))),n.TopPopupWorker.decoratorBeforeOpen(this),t&&(this.options.class=t.classRef.value,t.transitionDurationRef.value!==void 0&&(this.options.transitionDuration=t.transitionDurationRef.value,this.elPopup instanceof HTMLElement&&this.elPopup.style.setProperty("--top-popup-transition-delay",this.options.transitionDuration+"ms"))),this.elPopupInner=document.createElement("div"),this.elPopupInner.classList.add("top-popupPanel","top-popup");this.elPopup.firstChild;)this.elPopupInner.appendChild(this.elPopup.firstChild);if(this.elPopup.append(this.elPopupInner),this.elPopup.classList.add("top-popup-wrapper"),this.options.class){const o=this.options.class.split(" ");this.elPopup.classList.add(...o)}this.options.notch&&(this.elPopup.classList.add("with_notch"),this.elPopup.insertAdjacentHTML("beforeend",'<i class="notch notch-border"></i><i class="notch"></i>')),await this.vueOpen(),this.elPopupHeader=this.elPopupInner.querySelector(".top-popup_header"),this.elPopupWidget=this.elPopupInner.querySelector(".top-popup_widget"),this.elPopupBody=this.elPopupInner.querySelector(".top-popup_content"),this.elPopupFooter=this.elPopupInner.querySelector(".top-popup_footer");const p=!!this.elPopup.querySelector('[data-widget="search"]');if(this.options.isFullScreen&&!p){const o=h.useI18n();!this.elPopupHeader&&o.Common.Close&&(this.elPopupHeader=e.default.genEl("i",{class:"top-popup_header"}),this.elPopupInner.prepend(this.elPopupHeader),this.elPopupHeader.prepend(e.default.genEl("i",{class:"a closer"},o.Common.Close)),this.elPopupHeader.append(e.default.genEl("i",{class:"top-popup_headerButton"})))}e.default.storage(this.elPopup,g.componentName,this),this.options.frontSelector&&(this.elFront=document.querySelector(this.options.frontSelector)),this.elFront||(this.elFront=this.el.closest(".top-popup-front")),this.elFront||(this.elFront=document.body),this.elPopup instanceof HTMLElement&&(this.elPopup.style.width=this.el.offsetWidth+"px",this.elPopup.style.height=this.el.offsetHeight+"px",this.elPopup.style.top=this.el.offsetTop+"px",this.elPopup.style.right=parseInt(this.el.style.right||"0")+"px",this.elPopup.style.bottom=parseInt(this.el.style.bottom||"0")+"px"),this.el.parentElement?.insertBefore(this.elPopup,this.el),this.elPopup.classList.remove("template"),this.options.invertX&&this.elPopup.classList.add("invert-x");let i=!!this.el.closest(".modal-header");i||(i=!!this.el.closest("#top_panel")),i||(i=!!this.el.closest("#secondmenu")),i&&this.elPopup.classList.add("p-from-top"),setTimeout(()=>this.elPopup?.classList.add("top-popup-wrapper-shown")),this.elFront&&!this.elFront.matches("body")&&(this.elFront.append(this.elPopup),this.shift.top=e.default.offset(this.el).top-this.el.offsetTop-e.default.offset(this.elFront).top,this.shift.left=e.default.offset(this.el).left-this.el.offsetLeft-e.default.offset(this.elFront).left,this.shift.top-=parseInt(this.el.style["margin-top"]||0),this.shift.left-=parseInt(this.el.style["margin-left"]||0),this.elPopup instanceof HTMLElement&&(this.elPopup.style.top=parseInt(this.elPopup.style.top||"0")+this.shift.top+"px",this.elPopup.style.left=parseInt(this.elPopup.style.left||"0")+this.shift.left+"px")),this.$&&h.Core.$&&this.$.trigger("aftershow.top-menu-popup",[h.Core.$(this.elPopup)]),this.recalcPosition(),this.elPopup.setAttribute("tabindex","0"),this.focus(),n.TopPopupWorker.decoratorAfterOpen(this),this.mountEvents()}async mountJQuery(){h.Core.$&&(this.$=h.Core.$(this.el))}focus(){let t;this.elPopup&&(t=e.default.querySelectorVisible(this.elPopup,".top-popup-autofocus"),t||(t=e.default.querySelectorVisible(this.elPopup,":read-write, select:not(:disabled)")),t||(t=e.default.querySelectorVisible(this.elPopup,".top-popup_footer .top-button")),t||(t=this.elPopup),this.openerIsInput||(t instanceof HTMLElement&&t.focus(),setTimeout(()=>{t instanceof HTMLElement&&t.focus()},this.options.transitionDuration)))}mountEvents(){this.addEventListenerWithUnmount(document,"mousedown",t=>this.onMousedown(t)),this.openerIsInput?this.onFocusCloseOthers():this.elPopup&&this.elPopupInner&&(this.addEventListenerWithUnmount(this.elPopup,"focus",t=>this.onFocus(t)),this.options.openByHover&&(this.addEventListenerWithUnmount(this.elPopup,"mouseleave",t=>this.onMouseleave(t)),this.addEventListenerWithUnmount(this.elPopupInner,"mouseleave",t=>this.onMouseleave(t)))),this.options.isFullScreen&&this.elPopupBody&&this.addEventListenerWithUnmount(this.elPopupBody,"touchmove",t=>this.onTouchmove(t))}onMousedown(t){if(!this.elPopup||!(t.target instanceof Element)||!this.isFirstClick||(this.isFirstClick=!1,setTimeout(()=>this.isFirstClick=!0),t instanceof MouseEvent&&t.button!==0))return;let p=e.default.querySelectorVisibleLast(document.body,":scope > .top-popup-wrapper");if(p&&p!==this.elPopup||t.target.closest(".top-popup-front")&&(p=e.default.querySelectorVisibleLast(t.target.closest(".top-popup-front"),":scope > .top-popup-wrapper"),p&&p!==this.elPopup))return;if(t.target.closest(`[data-top-popup-id="${this.options.id}"]`)){t.preventDefault();return}let i=t.target.closest("input, select, textarea, button, [tabindex]");i===this.elPopup&&(i=null);const o=!i;o&&this.openerIsInput&&t.preventDefault(),!this.elPopup.contains(t.target)&&(this.elPopup.closest(".ui-dialog")&&!t.target.closest(".ui-dialog")||n.TopPopupWorker.decoratorIsIgnoreOuterClick(t)||n.TopPopupWorker.close(this.elPopup,o))}onFocus(t){t.target instanceof Element&&t.target.matches("input")||this.onFocusCloseOthers()}onFocusCloseOthers(){if(this.isClosed)return;n.TopPopupWorker.getAllVisible().forEach(p=>{this.elPopup?.contains(p)||this.popupParent?.elPopup===p||this.popupParent?.popupParent?.elPopup===p||n.TopPopupWorker.close(p)})}onMouseleave(t){setTimeout(()=>{this.elPopupInner&&this.elPopupInner.matches(":hover")||!this.elPopup||n.TopPopupWorker.close(this.elPopup)},100)}onResize(){this.elPopup&&this.elPopup.parentElement!==document.body&&document.body.append(this.elPopup),this.elPopup instanceof HTMLElement&&(this.elPopup.style.top=e.default.offset(this.el).top+"px",this.elPopup.style.left=e.default.offset(this.el).left+"px")}unmount(){super.unmount(),this.el instanceof HTMLElement&&(this.el.dataset.topPopupOpened=""),this.elActiveByDefault||this.el.classList.remove("top-active");let t=this.el.getAttribute("style");t&&(t=t.replace(/position:[^;]*;?/g,""),this.el.setAttribute("style",t))}recalcPosition(t){if(!(this.elPopup instanceof HTMLElement))return;let p=t??this.options.p,i;if(this.el instanceof HTMLElement)switch(this.elPopup.style.height=this.el.offsetHeight+"px",this.elPopup.classList.remove("p0","p1","p2","p3","p4"),this.elPopup.classList.add("p"+p),this.options.posBy){case"left":i=this.el.offsetLeft+parseInt(this.el.style["margin-left"]||"0"),i+=this.shift.left,this.elPopup.style.left=i+"px";break;case"right":if(!(this.el.offsetParent instanceof HTMLElement))break;i=this.el.offsetLeft+parseInt(this.el.style["margin-left"]||"0"),this.elPopup.style.right=this.el.offsetParent.offsetWidth-this.el.offsetWidth-i+"px";break;case"fixed":this.addEventListenerWithUnmount(window,"resize",()=>this.onResize()),this.onResize();break;default:this.options.posBy?.append(this.elPopup)}const o=this.elPopup.getBoundingClientRect();this.elPopup.style.setProperty("--top-popup-height",this.elPopup.offsetHeight+"px"),this.elPopup.style.setProperty("--top-popup-right-bounding",o.right+"px"),this.elPopup.style.setProperty("--top-popup-bottom-bounding",o.bottom+"px"),this.elPopup.style.setProperty("--top-popup-top",o.top+"px"),this.elPopup.style.setProperty("--top-popup-left",o.left+"px"),this.elPopupInner instanceof HTMLElement&&(this.elPopupInner.style.maxWidth="unset",this.elPopupInner.style.maxHeight="unset");const s={top:!1,right:!1,bottom:!1,left:!1},a={top:!1,right:!1,bottom:!1,left:!1};let d=o.left>window.innerWidth/2,c=o.top>window.innerHeight/2;p===4&&(d=!d),p===1&&(c=!c);const r=this.elPopupInner?.getBoundingClientRect();let u,f;const m=e.default.cssNumber(this.elPopup,"--top-popup-offset"),x=this.el.offsetHeight,T=this.el.offsetWidth;r&&(u=window.innerWidth-r.right,f=window.innerHeight-r.bottom,r.top<m&&(s.top=!0,r.top<m*2-r.height+x&&(a.top=!0)),u<m&&(s.right=!0,u<m*2-r.width+T&&(a.right=!0)),f<m&&(s.bottom=!0,f<m*2-r.height+x&&(a.bottom=!0)),r.left<m&&(s.left=!0,r.left<m*2-r.width+x&&(a.left=!0)));const S=(v,l)=>{if(v==="x"){if(!s.right&&!s.left||(l===1||l===3)&&!a.right&&!a.left&&d)return l;s.right&&(l===0||l===2)&&d&&(l=4),s.left&&(l===0||l===4)&&d&&(l=2)}if(v==="y"){if(!s.top&&!s.bottom||(l===2||l===4)&&!a.top&&!a.bottom&&c)return l;s.top&&(l===0||l===1)&&c&&(l=3),s.bottom&&c&&(l=1)}return l};let w=["x","y"];(p===0||p===1||p===3)&&(w=["y","x"]);let b=p??0;w.forEach(v=>{b=S(v,b)}),p=b,s.bottom&&(p===2||p===4)&&c&&this.elPopup.classList.add("invert-y"),s.right&&(p===0||p===1||p===3)&&this.elPopup.classList.add("invert-x"),this.elPopup.classList.remove("p0","p1","p2","p3","p4"),this.elPopup.classList.add("p"+p),this.elPopupInner instanceof HTMLElement&&(this.elPopupInner.style.maxWidth="",this.elPopupInner.style.maxHeight=""),n.TopPopupWorker.scrollToActive(this.elPopup)}onTouchmove(t){if(t.currentTarget instanceof HTMLElement&&t.target instanceof HTMLElement){if(t.currentTarget.scrollWidth>t.currentTarget.offsetWidth||t.target.parentElement?.scrollWidth&&t.target.parentElement?.offsetWidth&&t.target.parentElement.scrollWidth>t.target.parentElement?.offsetWidth)return;t.currentTarget.matches(".has_scroll")||t.preventDefault()}}close(){this.isClosed||(this.isClosed=!0,this.$&&h.Core.$&&this.elPopup&&this.$.trigger("afterclose.top-menu-popup",[h.Core.$(this.elPopup)]),!n.TopPopupWorker.noClose&&(this.unmount(),this.elPopup?.classList.add("top-popup-wrapper-closed"),setTimeout(()=>{if(this.vueClose(),!this.elPopup)return;this.options.useOriginal?(this.elPopup.removeAttribute("style"),this.elPopup.classList.remove("top-popup-wrapper-shown","top-popup-wrapper-closed"),this.elPopup.classList.add("template"),this.elStartPosition?.append(this.elPopup),this.elPopup.querySelector("div.top-popup_content.top-column")?.classList.remove("top-column"),this.elPopup.querySelector(".notch-border")?.remove(),this.elPopup.querySelector(".notch")?.remove(),this.elPopupInner?.replaceWith(...this.elPopupInner.childNodes),e.default.storageClear(this.elPopup)):(e.default.storageClear(this.elPopup),this.elPopup.remove(),delete this.elPopup);const t=n.TopPopupWorker.getAllVisible(),p=t.length&&t[t.length-1];p?n.TopPopupWorker.getPopup(p).focus():document.documentElement.classList.remove("with_popup")},this.options.transitionDuration)))}async vueOpen(){await this.vueGetComponent()?.onOpen(this)}vueClose(){this.vueGetComponent()?.onClose(this)}vueGetComponent(){if(this.el instanceof HTMLElement&&this.options.id)return n.TopPopupWorker.vueConnectors.get(this.options.id)}}I.init(),y.TopLibPopup=g,Object.defineProperty(y,Symbol.toStringTag,{value:"Module"})}));
|
|
2
|
-
//# sourceMappingURL=popup-
|
|
1
|
+
define(["require","exports","./forms-DDNzqU6o.amd","../utils/dom.amd","../popup/worker.amd"],(function(C,y,h,e,n){"use strict";if(typeof _>"u")var _=window.Vue;class P{static componentName="Top";componentName;className;uid;el;options={};unmountEls=[];unmountEvents=[];init(t,p,i){if(!p)throw t+": el is undefined";const o=P.getComponent(p,t);if(o)return o.reInit(i),o;this.componentName=t,this.className="top"+t[0].toUpperCase()+t.substring(1),this.uid=this.componentName+(Math.random()+"").replace(".",""),this._setComponent(p),this.el=p,this.el.classList.add(this.className),this.options=Object.assign(this.options,i),this.mount()}static getComponent(t,p){return e.default.storage(t,"#"+p)}_setComponent(t){e.default.storage(t,"#"+this.componentName,this)}mount(){throw"Please, add method mount() to component: "+this.componentName}unmount(){e.default.storage(this.el,"#"+this.componentName,null),this.unmountEls.forEach(t=>{t.remove()}),this.unmountEls=[],this.unmountEvents.forEach(t=>{t.el.removeEventListener(t.type,t.listener,t.options)}),this.unmountEvents=[]}registerElForUnmount(t){this.unmountEls.push(t)}addEventListenerWithUnmount(t,p,i,o){t.addEventListener(p,i,o),this.registerEventForUnmount(t,p,i,o)}registerEventForUnmount(t,p,i,o){const s={el:t,type:p,listener:i,options:o};this.unmountEvents.push(s)}reInit(t){throw"Please, add method reInit() to component: "+this.componentName}static detach(t){if(t instanceof NodeList)t.forEach(p=>p.parentElement?.removeChild(p));else{const p=t;p.parentElement?.removeChild(p)}}}class I{static isInited=!1;static init(){this.isInited||(this.isInited=!0,document.addEventListener("click",this.onclickCapture,{capture:!0}),document.addEventListener("click",this.onclick),document.addEventListener("keydown",this.onkeydown))}static onclickCapture(t){if(!(!(t.target instanceof HTMLElement)||!t.target.closest(".top-popup-wrapper"))){if(t.target.matches("[data-top-popup]")){const i=t.target.closest("ul"),o=t.target.closest("a, .a");i&&i.querySelector("a.top-active, .a.top-active")?.classList.remove("top-active"),o&&o.classList.add("top-active"),t.stopPropagation();return}if(t.target.matches(".top-popup-wrapper")){const i=t.target;n.TopPopupWorker.close(i,!0),t.stopPropagation();return}}}static onclick(t){if(!(t.target instanceof HTMLElement))return;const p=t.target.closest(".closer, a, .a, .top-button");if(p){const i=t.target.closest(".top-popup-wrapper");if(!i||p.matches(".top-popup-noCloser"))return;p.getAttribute("href")==="."&&t.preventDefault(),n.TopPopupWorker.close(i,!0)}}static onkeydown(t){if(!(t.target instanceof HTMLElement))return;let p=t.target.closest(".top-popup-wrapper");if(p||(p=n.TopPopupWorker.getPopupFromOpener(t.target)?.elPopup??null),!p)return;const i=p.querySelector("ul.top-popup_content");switch(t.key){case"Escape":n.TopPopupWorker.close(p,!0);break;case"Enter":if(!i){if(e.default.querySelectorVisible(p,".preloader"))break;const u=e.default.querySelectorVisible(p,".top-popup_footer .go, .top-popup_footer [data-action]");if(u instanceof HTMLElement){u.click();break}let f=e.default.querySelectorVisibleLast(p,".top-popup_footer .top-button:focus");f||(f=e.default.querySelectorVisibleLast(p,".top-popup_footer .top-button")),f instanceof HTMLElement&&f.click();break}const o=e.default.querySelectorVisible(p,"li > a.top-active");o&&o.getAttribute("href")&&(t.preventDefault(),location.href=o.getAttribute("href"));const s=p.querySelector("li > .top-active");s instanceof HTMLElement&&s.click();break;case"ArrowUp":case"ArrowRight":case"ArrowDown":case"ArrowLeft":if(!i)break;if(t.key==="ArrowRight"||t.key==="ArrowLeft"){if(e.default.querySelectorVisible(p,"ul.top-popup_content > li:not(.top-popup_liNoSelectable) > .top-active > .top-popup_listMore"))t.preventDefault();else if(t.target.tagName==="INPUT")break}else t.preventDefault();const a=p.querySelector("ul.top-popup_content > li:not(.top-popup_liNoSelectable) > .top-active")?.parentElement;if(t.key==="ArrowRight"&&a){const u=a.querySelector(".top-active > .top-popup_listMore");if(u instanceof HTMLElement)return u.click()}const d=e.default.querySelectorAllVisible(p,"ul.top-popup_content > li:not(.top-popup_liNoSelectable)"),c=d.length;if(!c)return;let r=-1;if(a&&(r=d.indexOf(a)),t.key==="ArrowUp"||t.key==="ArrowLeft"?r--:r++,t.key==="ArrowLeft"&&r===-1)return t.target.matches("input")?void 0:n.TopPopupWorker.close(p,!0);if(t.key==="ArrowRight"&&r===c)return;r<0&&(r=c-1),r>c-1&&(r=0),p.querySelectorAll("ul.top-popup_content > li > .top-active").forEach(u=>u.classList.remove("top-active")),d[r].querySelector(":scope > a, :scope > .a")?.classList.add("top-active"),n.TopPopupWorker.scrollToActive(p);break}}}const L=":root{--top-popup-z-index: 200000;--top-popup-transition-delay: .1s;--top-popup-offset: var(--top-padding-2);--top-popup-background-color: var(--color-layout-front-1);--top-popup-background-color-hover: var(--color-layout-front-3);--top-popup-background-color-active: var(--color-layout-front-4);--top-popup-border-color: var(--color-line-2-opacity);--top-popup-title-background-color: var(--color-layer-1);--top-popup-content-padding: calc(var(--top-popup-list-padding) + var(--top-popup-listItem-padding));--top-popup-list-padding: var(--top-padding-2);--top-popup-listItem-radius: var(--top-radius-2);--top-popup-listItem-padding: var(--top-padding-2)}.top-popup-front{position:relative}.top-popup-wrapper{--top-popup-height: 0px;--top-popup-right-bounding: 0px;--top-popup-bottom-bounding: 0px;--top-popup-top: 0px;--top-popup-right: calc(100vw - var(--top-popup-right-bounding));--top-popup-bottom: calc(var(--100vh) - var(--top-popup-bottom-bounding));--top-popup-left: 0px;--top-popup-margin: -10px;text-align:initial;white-space:normal;word-break:normal;position:absolute;z-index:200000;outline:none}.top-popup-wrapper:not(.top-popup-wrapper-shown){overflow:hidden}.top-popupPanel{cursor:default;box-shadow:var(--top-shadow-b);border-radius:14px;background:var(--top-popup-background-color);position:absolute;overflow:hidden;display:flex;flex-direction:column}.top-popup-wrapper>*{opacity:0;transition:opacity var(--top-popup-transition-delay) linear,transform var(--top-popup-transition-delay) linear;pointer-events:auto}.top-popup-wrapper-shown:not(.top-popup-wrapper-closed)>*{opacity:1;transform:translate(0)!important}.top-popup_header,.top-popup_content,.top-popup_footer{font-size:14px}.top-popup_header,.top-popup_footer{display:flex;align-items:center;justify-content:space-between}.top-popup_header{color:var(--color-text-1);border-bottom:1px solid var(--top-popup-border-color);padding:var(--top-padding-3);font-weight:600}.top-popup_header>*{font-weight:400}.top-popup_header>.a{cursor:pointer}.top-popup_header>.a:hover{color:var(--color-text-primary)}.top-popup_headerButton{width:60px}.top-popup_widget{padding:var(--top-padding-2)}.top-popup_content{margin:0;flex-grow:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--top-gap-4);-webkit-overflow-scrolling:touch}div.top-popup_content{color:var(--color-text-1);padding:var(--top-popup-content-padding)}div.top-popup_content>*{flex-shrink:0}div.top-popup_content>.top-button{margin:0}div.top-popup_content .top-unwrap{--top-unwrap-x: var(--top-popup-content-padding)}ul.top-popup_content{color:var(--color-text-1);padding:var(--top-popup-list-padding);gap:2px}ul.top-popup_content .top-unwrap{--top-unwrap-x: var(--top-popup-list-padding)}.top-popup_listItem{border-radius:var(--top-popup-listItem-radius);padding:var(--top-popup-listItem-padding);line-height:1!important}ul.top-popup_content li{margin:0;list-style:none;display:flex;align-items:center;position:relative}ul.top-popup_content li>*{flex-grow:1}ul.top-popup_content li>a:not(.top-button),ul.top-popup_content li>.a{cursor:pointer;box-sizing:border-box;border-radius:var(--top-popup-listItem-radius);background:var(--top-popup-background-color);padding:var(--top-popup-listItem-padding);color:var(--color-text-1)!important;font-size:14px;font-weight:400!important;text-decoration:none!important;font-style:normal;line-height:1!important;display:flex;flex:1 1 100%;align-items:center;transition:background-color .1s ease-in-out}.top-popup-wrapper-no_animate ul.top-popup_content li>a:not(.top-button),.top-popup-wrapper-no_animate ul.top-popup_content li>.a{transition:none}ul.top-popup_content li>a:not(.top-button):hover,ul.top-popup_content li>.a:hover{background:var(--top-popup-background-color-hover)}ul.top-popup_content li>a:not(.top-button).top-active,ul.top-popup_content li>.a.top-active{--top-icon-color: var(--color-text-primary) !important;background:var(--top-popup-background-color-active)}.top-popup_liastItem-withActions{width:240px;max-width:100%}.top-popup_listItemActionsLabel{flex-grow:1}.top-popup_listItemActions{margin-left:auto;flex-grow:0;display:flex}.top-popup_listItemActions>[data-top-icon]{--top-icon-size: 20px;--top-icon-color: var(--color-text-4)}.top-popup_listItemActions>[data-top-icon]:before{line-height:0}.top-popup_listItemActions>[data-top-icon]:hover,.top-popup_listItemActions>[data-top-icon].top-active{--top-icon-color: var(--color-text-3)}.top-popup_content+.top-popup_content{padding-top:0}.top-popup_listItem-title{background:var(--color-layer-1);color:var(--color-text-1);font-size:12px}.top-popup_listItem-formControls{padding-top:0;padding-bottom:0;display:flex;flex-direction:column}.top-popup_listItem-delimiter{border-radius:3px;background:var(--top-popup-border-color);height:1px;padding:0;margin:4px}.top-popup_listMore{font-size:20px;margin:calc(0px - var(--top-popup-listItem-padding)) calc(0px - var(--top-popup-listItem-padding) / 2) calc(0px - var(--top-popup-listItem-padding)) 0}.top-popup_listMore.top-button{margin:0}ul.top-popup_content li>.a.top-popup_listMore{text-align:center;flex-basis:10px}ul.top-popup_content li>.a.top-popup_listMore:before{color:var(--color-text-2)}ul.top-popup_content li>*>.top-popup_listMore{margin-left:auto;color:var(--color-layer-4);font-size:14px}ul.top-popup_content li>*>i.top-popup_listMore:hover,ul.top-popup_content li>*>i.top-popup_listMore.top-active{color:var(--color-text-primary)}ul.top-popup_content li>*>i.top-popup_listMore:before{transform:rotate(90deg);display:block}ul.top-popup_content li a.close{background:none!important}.top-popup_content>[data-top-icon]:before{--top-icon-size: 20px}ul.top-popup_content li>[data-top-icon]{--top-icon-color: var(--color-text-2);--top-icon-size: 20px;--top-icon-width: 20px}ul.top-popup_content li>[data-top-icon]:not(.top-button):before{height:1rem;margin-right:8px;transition:color .1s}ul.top-popup_content li:hover>[data-top-icon]:not(.top-button){--top-icon-color: var(--color-text-2)}.top-popup_footer{padding:var(--top-padding-3);border-top:1px solid var(--top-popup-border-color);display:flex;gap:var(--top-gap-2);justify-content:flex-end}.top-popup_footerSupportLink{margin-right:auto}.top-popup>[data-widget]{padding:0 var(--top-popup-list-padding)}.top-popup>[data-widget]+hr{margin:0 var(--top-popup-list-padding)}.top-popup .placeholder{border:1px solid #E0D9D9!important;border-right:none!important;border-left:none!important;background:#f9f9f9!important;margin:-1px 0;z-index:1;position:relative}.top-popup-wrapper.simple_list>.top-popup{min-width:0;white-space:nowrap}.top-popup_content .top-column{display:flex;flex-direction:column;gap:4px}.top-popup li .check_all,.top-popup li .clear_all{cursor:pointer;color:var(--color-text-primary);padding:8px;display:inline-block}.top-popup li .check_all:hover,.top-popup li .clear_all:hover{text-decoration:underline}.top-popup li .clear_all{display:none}.top-popup_content table{margin:-9px 0}.top-popup_content table td,.top-popup_content table th{padding:9px var(--top-popup-listItem-padding) 9px 0;vertical-align:top}.top-popup_content table th{width:40%;font-weight:600;white-space:nowrap}ul.top-popup_content .a>[type=checkbox],ul.top-popup_content .a>[type=radio]{margin:-8px 0 -8px auto}ul.top-popup_content a>[class*=icon],ul.top-popup_content i.a>[class*=icon]{transition:.1s}.top-popup .buttons{border-radius:0 0 4px 4px;border-top:1px solid #BDC3C7;background:#ecf0f1;padding:10px 15px;margin:10px -15px -10px;white-space:nowrap}.top-popup_footer [class*=btn]:not(.btn-transparent){min-width:100px;padding:5px 14px;margin-left:10px}.top-popup_footer [class*=btn]:first-child{margin-left:0}.top-popup_footer .btn.full_width{margin:0;flex-grow:1}",E=":root{--top-popup-list-padding: 0px;--top-popup-listItem-radius: 0px;--top-popup-listItem-padding: var(--top-padding-4)}.top-popup-wrapper{--top-popup-footer-offset: 25px;width:auto!important;height:auto!important;position:fixed;top:0!important;right:0!important;left:0!important;overflow:hidden;transition:background .3s}.top-popup-wrapper-shown:not(.top-popup-wrapper-closed){background:#00000080;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.top-popup-wrapper-shown:not(.top-popup-wrapper-closed)>.top-popup{opacity:1!important}.top-popup{border-radius:8px 8px 0 0;width:auto!important;max-height:calc(100% - var(--header-height, 0px) - var(--toolbar-height, 0px) - 12px);margin:0!important;top:auto!important;right:0!important;bottom:var(--toolbar-height, 0px)!important;left:0!important;display:flex;flex-direction:column;transform:translateY(80%);transition:opacity .3s,transform .3s}.top-popup-wrapper.p-from-top{--top-popup-footer-offset: 0px;top:var(--header-height, 0px)!important}.with_dialog .top-popup-wrapper.p-from-top{top:50px!important}.top-popup-wrapper.p-from-top>.top-popup{border-radius:0 0 8px 8px;max-height:calc(100% - 24px);top:0!important;bottom:auto!important;transform:translateY(calc(-100% - 24px))}.top-popup_widget:not(.p-from-top){order:10}ul.top-popup_content{gap:0}ul.top-popup_content li:not(:last-child){border-bottom:1px solid var(--top-popup-border-color)}.top-popup-wrapper.top-style_alt>.top-popup>ul>li{border-bottom:none}.top-popup_footer{flex-direction:column-reverse}.top-popup_footer>.top-button{--top-forms-base-height: var(--top-forms-base-height_l);width:100%}ul.top-popup_content .top-popup_listItem-title{--top-popup-padding-v: 12px}ul.top-popup_content .top-popup_listItem-delimiter{background:var(--color-line-1-opacity);height:4px;margin:0}ul.top-popup_content li:first-child>.top-popup_listItem-delimiter{border-top:1px solid var(--top-popup-border-color)}",k=".top-popup-wrapper{pointer-events:none}.top-popup{min-width:250px;max-width:calc(100vw - var(--top-popup-left) - 16px);max-height:calc(var(--top-popup-bottom) + var(--top-popup-height))}.top-popup-wrapper.p0>*{transform:translateY(-8px)}.top-popup-wrapper.p1>*{transform:translateY(8px)}.top-popup-wrapper.p2>*{transform:translate(8px)}.top-popup-wrapper.p3>*{transform:translateY(8px)}.top-popup-wrapper.p4>*{transform:translate(-8px)}.top-popup-wrapper.p0>.top-popup{top:-16px;left:-8px}.top-popup-wrapper.p1>.top-popup{bottom:calc(100% + 8px)}.top-popup-wrapper.p2>.top-popup{left:calc(100% + 8px)}.top-popup-wrapper.p3>.top-popup{top:calc(100% + 8px)}.top-popup-wrapper.p4>.top-popup{right:calc(100% + 8px)}.top-popup-wrapper.p2>.top-popup,.top-popup-wrapper.p4>.top-popup{margin-top:var(--top-popup-margin)}.top-popup-wrapper.p2.invert-y>.top-popup,.top-popup-wrapper.p4.invert-y>.top-popup{margin-bottom:var(--top-popup-margin)}.top-popup-wrapper.p1.with_notch>.top-popup{margin-bottom:5px}.top-popup-wrapper.p2.with_notch>.top-popup{margin-left:5px}.top-popup-wrapper.p3.with_notch>.top-popup{margin-top:5px}.top-popup-wrapper.p4.with_notch>.top-popup{margin-right:5px}.top-popup-wrapper.invert-x>.top-popup{right:0}.top-popup-wrapper.invert-y>.top-popup{bottom:0}.top-popup-wrapper.p1>.top-popup{max-height:calc(var(--top-popup-top) - var(--header-height, 0px) - 16px)}.top-popup-wrapper.p3>.top-popup{max-height:calc(var(--top-popup-bottom) - 16px)}.top-popup-wrapper.p2>.top-popup{max-width:calc(var(--top-popup-right) - 16px)}.top-popup-wrapper.p4>.top-popup{max-width:calc(var(--top-popup-left) - 16px)}.top-popup-wrapper.invert-x>.top-popup{max-width:calc(100vw - var(--top-popup-right) - 16px)}.top-popup-wrapper.invert-y>.top-popup{max-height:calc(100vh - var(--top-popup-bottom) - 16px)}.top-popup-wrapper>.notch{border:7.4px solid transparent;position:absolute;display:block}.top-popup-wrapper.p1>.notch{border-bottom:0;border-top:7.4px solid var(--color-layout-front-1);margin:0 0 7.4px -7.4px;bottom:100%;left:50%}.top-popup-wrapper.p2>.notch{border-left:0;border-right:7.4px solid var(--color-layout-front-1);margin:0 0 -7.4px 7.4px;bottom:50%;left:100%}.top-popup-wrapper.p3>.notch{border-top:0;border-bottom:7.4px solid var(--color-layout-front-1);margin:7.4px 0 0 -7.4px;top:100%;left:50%}.top-popup-wrapper.p4>.notch{border-right:0;border-left:7.4px solid var(--color-layout-front-1);margin:0 7.4px -7.4px 0;bottom:50%;right:100%}.top-popup-wrapper.p1>.notch-border{border-top-color:#0000000d;margin-bottom:6px}.top-popup-wrapper.p2>.notch-border{border-right-color:#0000000d;margin-left:6px}.top-popup-wrapper.p3>.notch-border{border-bottom-color:#0000000d;margin-top:6px}.top-popup-wrapper.p4>.notch-border{border-left-color:#0000000d;margin-right:6px}.top-popup-wrapper.p1.with_notch>.top-popup,.top-popup-wrapper.p3.with_notch>.top-popup{margin-left:-16px!important}.top-popup-wrapper.p1.with_notch>.notch,.top-popup-wrapper.p3.with_notch>.notch{margin-left:-8px!important}.top-popup-wrapper.p1.with_notch.invert-x,.top-popup-wrapper.p3.with_notch.invert-x{margin-left:3px!important}.top-popup-wrapper.p1.with_notch.invert-x>.notch,.top-popup-wrapper.p3.with_notch.invert-x>.notch{margin-left:-9px!important}ul.top-popup_content li>*>i.top-popup_listMore{visibility:hidden;transition:none}ul.top-popup_content li:hover>*>i.top-popup_listMore,ul.top-popup_content li>*.top-active>i.top-popup_listMore,ul.top-popup_content li>*>i.top-popup_listMore.top-active{visibility:visible}.top-popup_listItemActions{display:none}.top-popup_listItem.top-active>.top-popup_listItemActions,.top-popup_listItem:hover>.top-popup_listItemActions{display:flex}";h.Core.insertStyleToPage(L),h.Core.insertStyleToPage(E,"m"),h.Core.insertStyleToPage(k,"pc");class g extends P{static componentName="TopPopup";elActiveByDefault;elPopup;elPopupInner;elPopupHeader;elPopupWidget;elPopupBody;elPopupFooter;elFront;openerIsInput=!1;popupParent;$;elStartPosition;shift={top:0,left:0};isClosed=!1;isFirstClick=!0;type;options={popup:"",p:0,notch:!1,class:"",posBy:"left",frontSelector:"",invertX:!1,openByHover:!1,useOriginal:!1,transitionDuration:100,isFullScreen:!1};events={};constructor(t,p){super(),this.init(g.componentName,t,p)}async mount(){if(!(this.el instanceof HTMLElement))return;const t=this.vueGetComponent();if(this.el.closest(".top-popup-wrapper")&&(this.popupParent=n.TopPopupWorker.getPopup(this.el.closest(".top-popup-wrapper"))),await this.mountJQuery(),e.default.css(this.el,"position")!=="absolute"&&(this.el.style.position="relative"),this.el.dataset.topPopupOpened="opened",this.elActiveByDefault=this.el.classList.contains("top-active"),this.el.classList.add("top-active"),this.openerIsInput=this.el.classList.contains("top-input"),this.el.classList.contains("top-input-project_name")&&(this.openerIsInput=!1),this.openerIsInput){const o=this.el.querySelector("input");o&&!o.__popupOnBlur&&(o.__popupOnBlur=!0,o.addEventListener("blur",s=>{n.TopPopupWorker.getPopupFromOpener(this.el)?.close()}))}if(t)this.type="vue",this.options.popup="",this.elPopup=e.default.genEl("div",{},this.options.popup);else if(this.options.popup?.match(/^[#.]/))this.type="selector",this.elPopup=document.querySelector(`${this.options.popup}.template`)||void 0;else{if(this.type="html",this.options.useOriginal)throw"Option useOriginal not allowed for text templates";this.elPopup=e.default.genEl("div",{},this.options.popup??"")}if(this.type!=="html"&&!t||t?.opened){if(!t||t?.opened){let o;if(t?.opened?o=t.popup.elPopup:o=document.querySelector(`${this.options.popup}.top-popup-wrapper-shown`)||void 0,o){this.elPopup=o,this.el.dataset.topPopupOpened="",this.elActiveByDefault||this.el.classList.remove("top-active"),n.TopPopupWorker.close(this.elPopup),setTimeout(()=>this.mount(),this.options.transitionDuration);return}}this.elPopup||(this.elPopup=document.querySelector(`${this.options.popup}:not(.top-popup-wrapper)`)||void 0)}if(!this.elPopup)return;for(this.options.useOriginal?(this.elStartPosition=this.elPopup.closest(".top-popup-el-start-position"),this.elStartPosition||(this.elStartPosition=e.default.wrap(this.elPopup,"i"),this.elStartPosition.classList.add("top-popup-el-start-position","hidden"))):(this.elPopup=this.elPopup.cloneNode(!0),this.type==="selector"&&!this.elPopup.matches(".template")&&(this.elPopup.classList.remove("hidden"),this.elPopup.querySelector(":scope > .top-popup_content")||this.elPopup.classList.add("top-popup_content"),this.elPopup=e.default.wrap(this.elPopup,"div")),this.type==="html"&&(this.elPopup.querySelector(":scope > .top-popup_content")||(this.elPopup.classList.add("top-popup_content"),this.elPopup=e.default.wrap(this.elPopup,"div"))),(this.type==="selector"&&!this.elPopup.matches(".template")||this.type==="html"||this.type==="vue")&&(e.default.querySelectorAllArray(this.elPopup,"[data-top-popup]").forEach(o=>{o instanceof HTMLElement&&(o.dataset.topPopupPosBy="fixed")}),e.default.querySelectorAllArray(this.elPopup,".top-popup-wrapper").forEach(o=>o.remove()))),n.TopPopupWorker.decoratorBeforeOpen(this),t&&(this.options.class=t.classRef.value,t.transitionDurationRef.value!==void 0&&(this.options.transitionDuration=t.transitionDurationRef.value,this.elPopup instanceof HTMLElement&&this.elPopup.style.setProperty("--top-popup-transition-delay",this.options.transitionDuration+"ms"))),this.elPopupInner=document.createElement("div"),this.elPopupInner.classList.add("top-popupPanel","top-popup");this.elPopup.firstChild;)this.elPopupInner.appendChild(this.elPopup.firstChild);if(this.elPopup.append(this.elPopupInner),this.elPopup.classList.add("top-popup-wrapper"),this.options.class){const o=this.options.class.split(" ");this.elPopup.classList.add(...o)}this.options.notch&&(this.elPopup.classList.add("with_notch"),this.elPopup.insertAdjacentHTML("beforeend",'<i class="notch notch-border"></i><i class="notch"></i>')),await this.vueOpen(),this.elPopupHeader=this.elPopupInner.querySelector(".top-popup_header"),this.elPopupWidget=this.elPopupInner.querySelector(".top-popup_widget"),this.elPopupBody=this.elPopupInner.querySelector(".top-popup_content"),this.elPopupFooter=this.elPopupInner.querySelector(".top-popup_footer");const p=!!this.elPopup.querySelector('[data-widget="search"]');if(this.options.isFullScreen&&!p){const o=h.useI18n();!this.elPopupHeader&&o.Common.Close&&(this.elPopupHeader=e.default.genEl("i",{class:"top-popup_header"}),this.elPopupInner.prepend(this.elPopupHeader),this.elPopupHeader.prepend(e.default.genEl("i",{class:"a closer"},o.Common.Close)),this.elPopupHeader.append(e.default.genEl("i",{class:"top-popup_headerButton"})))}e.default.storage(this.elPopup,g.componentName,this),this.options.frontSelector&&(this.elFront=document.querySelector(this.options.frontSelector)),this.elFront||(this.elFront=this.el.closest(".top-popup-front")),this.elFront||(this.elFront=document.body),this.elPopup instanceof HTMLElement&&(this.elPopup.style.width=this.el.offsetWidth+"px",this.elPopup.style.height=this.el.offsetHeight+"px",this.elPopup.style.top=this.el.offsetTop+"px",this.elPopup.style.right=parseInt(this.el.style.right||"0")+"px",this.elPopup.style.bottom=parseInt(this.el.style.bottom||"0")+"px"),this.el.parentElement?.insertBefore(this.elPopup,this.el),this.elPopup.classList.remove("template"),this.options.invertX&&this.elPopup.classList.add("invert-x");let i=!!this.el.closest(".modal-header");i||(i=!!this.el.closest("#top_panel")),i||(i=!!this.el.closest("#secondmenu")),i&&this.elPopup.classList.add("p-from-top"),setTimeout(()=>this.elPopup?.classList.add("top-popup-wrapper-shown")),this.elFront&&!this.elFront.matches("body")&&(this.elFront.append(this.elPopup),this.shift.top=e.default.offset(this.el).top-this.el.offsetTop-e.default.offset(this.elFront).top,this.shift.left=e.default.offset(this.el).left-this.el.offsetLeft-e.default.offset(this.elFront).left,this.shift.top-=parseInt(this.el.style["margin-top"]||0),this.shift.left-=parseInt(this.el.style["margin-left"]||0),this.elPopup instanceof HTMLElement&&(this.elPopup.style.top=parseInt(this.elPopup.style.top||"0")+this.shift.top+"px",this.elPopup.style.left=parseInt(this.elPopup.style.left||"0")+this.shift.left+"px")),this.$&&h.Core.$&&this.$.trigger("aftershow.top-menu-popup",[h.Core.$(this.elPopup)]),this.recalcPosition(),this.elPopup.setAttribute("tabindex","0"),this.focus(),n.TopPopupWorker.decoratorAfterOpen(this),this.mountEvents()}async mountJQuery(){h.Core.$&&(this.$=h.Core.$(this.el))}focus(){let t;this.elPopup&&(t=e.default.querySelectorVisible(this.elPopup,".top-popup-autofocus"),t||(t=e.default.querySelectorVisible(this.elPopup,":read-write, select:not(:disabled)")),t||(t=e.default.querySelectorVisible(this.elPopup,".top-popup_footer .top-button")),t||(t=this.elPopup),this.openerIsInput||(t instanceof HTMLElement&&t.focus({preventScroll:!0}),setTimeout(()=>{t instanceof HTMLElement&&t.focus({preventScroll:!0})},this.options.transitionDuration)))}mountEvents(){this.addEventListenerWithUnmount(document,"mousedown",t=>this.onMousedown(t)),this.openerIsInput?this.onFocusCloseOthers():this.elPopup&&this.elPopupInner&&(this.addEventListenerWithUnmount(this.elPopup,"focus",t=>this.onFocus(t)),this.options.openByHover&&(this.addEventListenerWithUnmount(this.elPopup,"mouseleave",t=>this.onMouseleave(t)),this.addEventListenerWithUnmount(this.elPopupInner,"mouseleave",t=>this.onMouseleave(t)))),this.options.isFullScreen&&this.elPopupBody&&this.addEventListenerWithUnmount(this.elPopupBody,"touchmove",t=>this.onTouchmove(t))}onMousedown(t){if(!this.elPopup||!(t.target instanceof Element)||!this.isFirstClick||(this.isFirstClick=!1,setTimeout(()=>this.isFirstClick=!0),t instanceof MouseEvent&&t.button!==0))return;let p=e.default.querySelectorVisibleLast(document.body,":scope > .top-popup-wrapper");if(p&&p!==this.elPopup||t.target.closest(".top-popup-front")&&(p=e.default.querySelectorVisibleLast(t.target.closest(".top-popup-front"),":scope > .top-popup-wrapper"),p&&p!==this.elPopup))return;if(t.target.closest(`[data-top-popup-id="${this.options.id}"]`)){t.preventDefault();return}let i=t.target.closest("input, select, textarea, button, [tabindex]");i===this.elPopup&&(i=null);const o=!i;o&&this.openerIsInput&&t.preventDefault(),!this.elPopup.contains(t.target)&&(this.elPopup.closest(".ui-dialog")&&!t.target.closest(".ui-dialog")||n.TopPopupWorker.decoratorIsIgnoreOuterClick(t)||n.TopPopupWorker.close(this.elPopup,o))}onFocus(t){t.target instanceof Element&&t.target.matches("input")||this.onFocusCloseOthers()}onFocusCloseOthers(){if(this.isClosed)return;n.TopPopupWorker.getAllVisible().forEach(p=>{this.elPopup?.contains(p)||this.popupParent?.elPopup===p||this.popupParent?.popupParent?.elPopup===p||n.TopPopupWorker.close(p)})}onMouseleave(t){setTimeout(()=>{this.elPopupInner&&this.elPopupInner.matches(":hover")||!this.elPopup||n.TopPopupWorker.close(this.elPopup)},100)}onResize(){this.elPopup&&this.elPopup.parentElement!==document.body&&document.body.append(this.elPopup),this.elPopup instanceof HTMLElement&&(this.elPopup.style.top=e.default.offset(this.el).top+"px",this.elPopup.style.left=e.default.offset(this.el).left+"px")}unmount(){super.unmount(),this.el instanceof HTMLElement&&(this.el.dataset.topPopupOpened=""),this.elActiveByDefault||this.el.classList.remove("top-active");let t=this.el.getAttribute("style");t&&(t=t.replace(/position:[^;]*;?/g,""),this.el.setAttribute("style",t))}recalcPosition(t){if(!(this.elPopup instanceof HTMLElement))return;let p=t??this.options.p,i;if(this.el instanceof HTMLElement)switch(this.elPopup.style.height=this.el.offsetHeight+"px",this.elPopup.classList.remove("p0","p1","p2","p3","p4"),this.elPopup.classList.add("p"+p),this.options.posBy){case"left":i=this.el.offsetLeft+parseInt(this.el.style["margin-left"]||"0"),i+=this.shift.left,this.elPopup.style.left=i+"px";break;case"right":if(!(this.el.offsetParent instanceof HTMLElement))break;i=this.el.offsetLeft+parseInt(this.el.style["margin-left"]||"0"),this.elPopup.style.right=this.el.offsetParent.offsetWidth-this.el.offsetWidth-i+"px";break;case"fixed":this.addEventListenerWithUnmount(window,"resize",()=>this.onResize()),this.onResize();break;default:this.options.posBy?.append(this.elPopup)}const o=this.elPopup.getBoundingClientRect();this.elPopup.style.setProperty("--top-popup-height",this.elPopup.offsetHeight+"px"),this.elPopup.style.setProperty("--top-popup-right-bounding",o.right+"px"),this.elPopup.style.setProperty("--top-popup-bottom-bounding",o.bottom+"px"),this.elPopup.style.setProperty("--top-popup-top",o.top+"px"),this.elPopup.style.setProperty("--top-popup-left",o.left+"px"),this.elPopupInner instanceof HTMLElement&&(this.elPopupInner.style.maxWidth="unset",this.elPopupInner.style.maxHeight="unset");const s={top:!1,right:!1,bottom:!1,left:!1},a={top:!1,right:!1,bottom:!1,left:!1};let d=o.left>window.innerWidth/2,c=o.top>window.innerHeight/2;p===4&&(d=!d),p===1&&(c=!c);const r=this.elPopupInner?.getBoundingClientRect();let u,f;const m=e.default.cssNumber(this.elPopup,"--top-popup-offset"),x=this.el.offsetHeight,T=this.el.offsetWidth;r&&(u=window.innerWidth-r.right,f=window.innerHeight-r.bottom,r.top<m&&(s.top=!0,r.top<m*2-r.height+x&&(a.top=!0)),u<m&&(s.right=!0,u<m*2-r.width+T&&(a.right=!0)),f<m&&(s.bottom=!0,f<m*2-r.height+x&&(a.bottom=!0)),r.left<m&&(s.left=!0,r.left<m*2-r.width+x&&(a.left=!0)));const S=(v,l)=>{if(v==="x"){if(!s.right&&!s.left||(l===1||l===3)&&!a.right&&!a.left&&d)return l;s.right&&(l===0||l===2)&&d&&(l=4),s.left&&(l===0||l===4)&&d&&(l=2)}if(v==="y"){if(!s.top&&!s.bottom||(l===2||l===4)&&!a.top&&!a.bottom&&c)return l;s.top&&(l===0||l===1)&&c&&(l=3),s.bottom&&c&&(l=1)}return l};let w=["x","y"];(p===0||p===1||p===3)&&(w=["y","x"]);let b=p??0;w.forEach(v=>{b=S(v,b)}),p=b,s.bottom&&(p===2||p===4)&&c&&this.elPopup.classList.add("invert-y"),s.right&&(p===0||p===1||p===3)&&this.elPopup.classList.add("invert-x"),this.elPopup.classList.remove("p0","p1","p2","p3","p4"),this.elPopup.classList.add("p"+p),this.elPopupInner instanceof HTMLElement&&(this.elPopupInner.style.maxWidth="",this.elPopupInner.style.maxHeight=""),n.TopPopupWorker.scrollToActive(this.elPopup)}onTouchmove(t){if(t.currentTarget instanceof HTMLElement&&t.target instanceof HTMLElement){if(t.currentTarget.scrollWidth>t.currentTarget.offsetWidth||t.target.parentElement?.scrollWidth&&t.target.parentElement?.offsetWidth&&t.target.parentElement.scrollWidth>t.target.parentElement?.offsetWidth)return;t.currentTarget.matches(".has_scroll")||t.preventDefault()}}close(){this.isClosed||(this.isClosed=!0,this.$&&h.Core.$&&this.elPopup&&this.$.trigger("afterclose.top-menu-popup",[h.Core.$(this.elPopup)]),!n.TopPopupWorker.noClose&&(this.unmount(),this.elPopup?.classList.add("top-popup-wrapper-closed"),setTimeout(()=>{if(this.vueClose(),!this.elPopup)return;this.options.useOriginal?(this.elPopup.removeAttribute("style"),this.elPopup.classList.remove("top-popup-wrapper-shown","top-popup-wrapper-closed"),this.elPopup.classList.add("template"),this.elStartPosition?.append(this.elPopup),this.elPopup.querySelector("div.top-popup_content.top-column")?.classList.remove("top-column"),this.elPopup.querySelector(".notch-border")?.remove(),this.elPopup.querySelector(".notch")?.remove(),this.elPopupInner?.replaceWith(...this.elPopupInner.childNodes),e.default.storageClear(this.elPopup)):(e.default.storageClear(this.elPopup),this.elPopup.remove(),delete this.elPopup);const t=n.TopPopupWorker.getAllVisible(),p=t.length&&t[t.length-1];p?n.TopPopupWorker.getPopup(p).focus():document.documentElement.classList.remove("with_popup")},this.options.transitionDuration)))}async vueOpen(){await this.vueGetComponent()?.onOpen(this)}vueClose(){this.vueGetComponent()?.onClose(this)}vueGetComponent(){if(this.el instanceof HTMLElement&&this.options.id)return n.TopPopupWorker.vueConnectors.get(this.options.id)}}I.init(),y.TopLibPopup=g,Object.defineProperty(y,Symbol.toStringTag,{value:"Module"})}));
|
|
2
|
+
//# sourceMappingURL=popup-yXIpyok3.amd.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"popup-yXIpyok3.amd.js","sources":["../../src/components/component.ts","../../src/components/popup/lib/popup.globalEvents.ts","../../src/components/popup/lib/popup.ts"],"sourcesContent":["import DOM from '@/core/utils/dom';\n\n/**\n * Базовый компонент для js компонентов, не имеет отношения к Vue\n */\nclass Component {\n\n\tstatic componentName = 'Top';\n\n\tcomponentName: string | undefined; // имя класса компонента\n\tclassName: string | undefined; // имя css класса компонента\n\tuid: string | undefined; // уникальный id компонента\n\tel: HTMLElement | undefined; // элемент, связанный с компонентом\n\toptions = {}; // параметры компонента\n\n\tunmountEls: HTMLElement[] = [];\n\tunmountEvents: any[] = [];\n\n\t// переопредлять нельзя\n\t// если компонент инициирован, необходимо сразу его вернуть и выполнить reInit() вместо mount()\n\t// используется init вместо constructor, так как super constructor выполняется до Object.defineProperty() параметров класса\n\tinit(componentName: string, el: HTMLElement, options: object): Component | void {\n\t\tif (!el) {\n\t\t\tthrow componentName + ': el is undefined';\n\t\t}\n\n\t\tconst component = Component.getComponent(el, componentName);\n\n\t\tif (component) {\n\t\t\tcomponent.reInit(options);\n\n\t\t\treturn component;\n\t\t}\n\n\t\tthis.componentName = componentName;\n\t\tthis.className = 'top' + componentName[0].toUpperCase() + componentName.substring(1);\n\t\tthis.uid = this.componentName + (Math.random() + '').replace('.', '');\n\n\t\tthis._setComponent(el);\n\t\tthis.el = el;\n\t\tthis.el.classList.add(this.className);\n\t\tthis.options = Object.assign(this.options, options);\n\n\t\tthis.mount();\n\t}\n\n\t// получить инициированный компонент\n\tstatic getComponent(el: HTMLElement, componentName: string): any {\n\t\treturn DOM.storage(el, '#' + componentName);\n\t}\n\n\t// устанвоить компонент\n\t_setComponent(el: HTMLElement) {\n\t\tDOM.storage(el, '#' + this.componentName, this);\n\t}\n\n\t// функция подключения компонента\n\tmount(): void {\n\t\tthrow 'Please, add method mount() to component: ' + this.componentName;\n\t}\n\n\t// функция отключения компонента\n\tunmount(): void {\n\t\tDOM.storage(this.el, '#' + this.componentName, null);\n\n\t\tthis.unmountEls.forEach((el) => {\n\t\t\tel.remove();\n\t\t});\n\n\t\tthis.unmountEls = [];\n\n\t\tthis.unmountEvents.forEach((eventData) => {\n\t\t\teventData.el.removeEventListener(eventData.type, eventData.listener, eventData.options);\n\t\t});\n\n\t\tthis.unmountEvents = [];\n\t}\n\n\t// указание новые элементы, которые должны будут удалиться после unmount\n\tregisterElForUnmount(el: HTMLElement): void {\n\t\tthis.unmountEls.push(el);\n\t}\n\n\t// указание новые события, которые должны будут удалиться после unmount\n\taddEventListenerWithUnmount(\n\t\tel: HTMLElement | Document | Window,\n\t\ttype: keyof GlobalEventHandlersEventMap,\n\t\tlistener: (this: HTMLElement, e: Event) => any,\n\t\toptions?: any,\n\t): void {\n\t\tel.addEventListener(type, listener, options);\n\n\t\tthis.registerEventForUnmount(el, type, listener, options);\n\t}\n\n\t// указание новые события, которые должны будут удалиться после unmount\n\tregisterEventForUnmount(\n\t\tel: HTMLElement | Document | Window,\n\t\ttype: keyof GlobalEventHandlersEventMap,\n\t\tlistener: (this: HTMLElement, e: Event) => any,\n\t\toptions?: any,\n\t): void {\n\t\tconst eventData = {\n\t\t\tel: el,\n\t\t\ttype: type,\n\t\t\tlistener: listener,\n\t\t\toptions: options,\n\t\t};\n\n\t\tthis.unmountEvents.push(eventData);\n\t}\n\n\t// функция перенастройки уже подключенного компонента\n\treInit(_options: object): void {\n\t\tthrow 'Please, add method reInit() to component: ' + this.componentName;\n\t}\n\n\t// удалить элементы из DOM, но не из памяти\n\tstatic detach(nodes: NodeList | HTMLElement): void {\n\t\tif (nodes instanceof NodeList) {\n\t\t\tnodes.forEach((node) => node.parentElement?.removeChild(node));\n\t\t} else {\n\t\t\tconst el = nodes;\n\t\t\tel.parentElement?.removeChild(el);\n\t\t}\n\t}\n\n}\n\nexport default Component;\n","import Worker from '@/components/popup/lib/worker';\nimport DOM from '@/core/utils/dom';\n\n/**\n * Глобальные события, для реализации Popup\n * Автоматически инициируется при первой загрузке, не является выгружаемым модулем\n *\n * Если в меню встречает класс .preloader, то событие нажатия на кнопку через enter будет остановлено\n */\nclass GlobalEvents {\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\tdocument.addEventListener('click', this.onclickCapture, { capture: true });\n\t\tdocument.addEventListener('click', this.onclick);\n\t\tdocument.addEventListener('keydown', this.onkeydown);\n\t}\n\n\t/**\n\t * Глобальный обработчик захватов кликов\n\t *\n\t * Обрабатывает захватов клики внутри Popup\n\t */\n\tprivate static onclickCapture(e: Event): void {\n\t\tif (!(e.target instanceof HTMLElement)) return;\n\n\t\t// меню\n\t\tconst elPopup = e.target.closest<HTMLElement>('.top-popup-wrapper');\n\n\t\t// клик вне меню\n\t\tif (!elPopup) {\n\t\t\treturn;\n\t\t}\n\n\t\t// клик по кнопке открытия другого меню\n\t\tif (e.target.matches('[data-top-popup]')) {\n\t\t\t// список меню, в котором был сделан клик\n\t\t\tconst elUl = e.target.closest<HTMLElement>('ul');\n\n\t\t\t// элемент меню, по которому был сделан клик\n\t\t\tconst elItem = e.target.closest<HTMLElement>('a, .a');\n\n\t\t\t// сделать элемент меню, по которому сделан клик активным\n\t\t\tif (elUl) {\n\t\t\t\telUl.querySelector('a.top-active, .a.top-active')?.classList.remove('top-active');\n\t\t\t}\n\n\t\t\tif (elItem) {\n\t\t\t\telItem.classList.add('top-active');\n\t\t\t}\n\n\t\t\te.stopPropagation();\n\n\t\t\treturn;\n\t\t}\n\n\t\t// клик по фону меню\n\t\tif (e.target.matches('.top-popup-wrapper')) {\n\t\t\tconst elPopup = e.target;\n\n\t\t\tWorker.close(elPopup, true);\n\n\t\t\te.stopPropagation();\n\n\t\t\treturn;\n\t\t}\n\t}\n\n\t/**\n\t * Глобальный обработчик кликов\n\t *\n\t * Обрабатывает клики внутри Popup\n\t */\n\tprivate static onclick(e: Event): void {\n\t\tif (!(e.target instanceof HTMLElement)) return;\n\n\t\t// элементы меню, клик по которым должен его закрыть\n\t\tconst elCloser = e.target.closest<HTMLElement>('.closer, a, .a, .top-button');\n\t\tif (elCloser) {\n\t\t\t// меню\n\t\t\tconst elPopup = e.target.closest<HTMLElement>('.top-popup-wrapper');\n\n\t\t\t// клик вне меню\n\t\t\tif (!elPopup) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// элемент имеет модификатор, запрещаюущий закрытие меню по клику на него\n\t\t\tif (elCloser.matches('.top-popup-noCloser')) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// deprecated, ссылки с href=\".\" запрещены, они должны быть заменены на .top-popup_listItem-button\n\t\t\tif (elCloser.getAttribute('href') === '.') {\n\t\t\t\te.preventDefault();\n\t\t\t}\n\n\t\t\t// закрыть меню\n\t\t\tWorker.close(elPopup, true);\n\t\t}\n\t}\n\n\t/**\n\t * Глобальный обработчик нажатия кнопки на клавиатуре\n\t */\n\tprivate static onkeydown(e: KeyboardEvent): void {\n\t\tif (!(e.target instanceof HTMLElement)) return;\n\n\t\tlet elPopup = e.target.closest<HTMLElement>('.top-popup-wrapper');\n\n\t\tif (!elPopup) {\n\t\t\telPopup = Worker.getPopupFromOpener(e.target)?.elPopup ?? null;\n\t\t}\n\n\t\t// нажатие не в меню\n\t\tif (!elPopup) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst elUl = elPopup.querySelector<HTMLElement>('ul.top-popup_content');\n\n\t\tswitch (e.key) {\n\t\t\tcase 'Escape':\n\t\t\t\tWorker.close(elPopup, true);\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'Enter':\n\t\t\t\t// атоматическое нажатие кнопок при нажатии Enter\n\t\t\t\tif (!elUl) {\n\t\t\t\t\tif (DOM.querySelectorVisible(elPopup, '.preloader')) {\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\n\t\t\t\t\t// deprecated, старый код на сайте\n\t\t\t\t\tconst elBtn = DOM.querySelectorVisible(elPopup, '.top-popup_footer .go, .top-popup_footer [data-action]');\n\t\t\t\t\tif (elBtn instanceof HTMLElement) {\n\t\t\t\t\t\telBtn.click();\n\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Запуск клика последней кнопки, расположенной в footer'е Popup'а, нажатием клавиши Enter\n\t\t\t\t\tlet elFooterLastBtn = DOM.querySelectorVisibleLast(elPopup, '.top-popup_footer .top-button:focus');\n\t\t\t\t\tif (!elFooterLastBtn) elFooterLastBtn = DOM.querySelectorVisibleLast(elPopup, '.top-popup_footer .top-button');\n\t\t\t\t\tif (elFooterLastBtn instanceof HTMLElement) {\n\t\t\t\t\t\telFooterLastBtn.click();\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\t// перейти по ссылке по нажатию на Enter\n\t\t\t\t// данный функуционал игнорирует SPA\n\t\t\t\tconst elLink = DOM.querySelectorVisible(elPopup, 'li > a.top-active');\n\t\t\t\tif (elLink && elLink.getAttribute('href')) {\n\t\t\t\t\t// фокус может находиться на другой ссылке\n\t\t\t\t\te.preventDefault();\n\n\t\t\t\t\tlocation.href = elLink.getAttribute('href')!;\n\t\t\t\t}\n\n\t\t\t\t// кликнуть по элементу меню по нажатию на Enter\n\t\t\t\tconst elItem = elPopup.querySelector<HTMLElement>('li > .top-active');\n\t\t\t\tif (elItem instanceof HTMLElement) {\n\t\t\t\t\telItem.click();\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\n\t\t\t// управление стрелками\n\t\t\tcase 'ArrowUp':\n\t\t\tcase 'ArrowRight':\n\t\t\tcase 'ArrowDown':\n\t\t\tcase 'ArrowLeft':\n\t\t\t\tif (!elUl) {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\tif (e.key === 'ArrowRight' || e.key === 'ArrowLeft') {\n\t\t\t\t\tconst elMoreVisible = DOM.querySelectorVisible(\n\t\t\t\t\t\telPopup,\n\t\t\t\t\t\t'ul.top-popup_content > li:not(.top-popup_liNoSelectable) > .top-active > .top-popup_listMore',\n\t\t\t\t\t);\n\n\t\t\t\t\tif (elMoreVisible) {\n\t\t\t\t\t\te.preventDefault();\n\t\t\t\t\t}else if((e.target as HTMLElement).tagName === 'INPUT'){\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\te.preventDefault();\n\t\t\t\t}\n\n\t\t\t\tconst elItemActive = elPopup.querySelector<HTMLElement>('ul.top-popup_content > li:not(.top-popup_liNoSelectable) > .top-active')?.parentElement;\n\n\t\t\t\t// есть подменю\n\t\t\t\tif (e.key === 'ArrowRight' && elItemActive) {\n\t\t\t\t\t// const elItemMoreActive = elItemActive.querySelector<HTMLElement>('[data-top-popup].top-active');\n\t\t\t\t\t// if (elItemMoreActive) {\n\t\t\t\t\t// \treturn elItemMoreActive.click();\n\t\t\t\t\t// }\n\n\t\t\t\t\tconst elMore = elItemActive.querySelector<HTMLElement>('.top-active > .top-popup_listMore');\n\t\t\t\t\tif (elMore instanceof HTMLElement) {\n\t\t\t\t\t\treturn elMore.click();\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tconst elsLiVisible = DOM.querySelectorAllVisible(elPopup, 'ul.top-popup_content > li:not(.top-popup_liNoSelectable)');\n\t\t\t\tconst countLi = elsLiVisible.length;\n\n\t\t\t\tif (!countLi) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tlet index = -1;\n\t\t\t\tif (elItemActive) {\n\t\t\t\t\tindex = elsLiVisible.indexOf(elItemActive);\n\t\t\t\t}\n\n\t\t\t\tif (e.key === 'ArrowUp' || e.key === 'ArrowLeft') {\n\t\t\t\t\tindex--;\n\t\t\t\t} else {\n\t\t\t\t\tindex++;\n\t\t\t\t}\n\n\t\t\t\t// это первый элемен, \"Назад\" должен закрывать окно\n\t\t\t\tif (e.key === 'ArrowLeft' && index === -1) {\n\t\t\t\t\tif (e.target.matches('input')) {\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\treturn Worker.close(elPopup, true);\n\t\t\t\t}\n\n\t\t\t\t// это последний элемен, \"Вперед\" не должен ни чего делать\n\t\t\t\tif (e.key === 'ArrowRight' && index === countLi) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (index < 0) {\n\t\t\t\t\tindex = countLi - 1;\n\t\t\t\t}\n\n\t\t\t\tif (index > countLi - 1) {\n\t\t\t\t\tindex = 0;\n\t\t\t\t}\n\n\t\t\t\telPopup.querySelectorAll('ul.top-popup_content > li > .top-active').forEach(el => el.classList.remove('top-active'));\n\t\t\t\telsLiVisible[index].querySelector(':scope > a, :scope > .a')?.classList.add('top-active');\n\n\t\t\t\tWorker.scrollToActive(elPopup);\n\n\t\t\t\tbreak;\n\t\t}\n\t}\n\n}\n\nexport default GlobalEvents;\n","import Core from '@/core/core/core';\nimport Component from '@/components/component';\nimport DOM from '@/core/utils/dom';\nimport Worker from '@/components/popup/lib/worker';\nimport GlobalEvents from '@/components/popup/lib/popup.globalEvents';\n\nimport css from '@/components/popup/popup/style/popup.css?inline';\nimport cssM from '@/components/popup/popup/style/popup.m.css?inline';\nimport cssPC from '@/components/popup/popup/style/popup.pc.css?inline';\nimport { useI18n } from '@/core/plugins/i18n';\nimport type { OpenerProps } from '@/components/popup/popup/opener/types';\n\nCore.insertStyleToPage(css);\nCore.insertStyleToPage(cssM, 'm');\nCore.insertStyleToPage(cssPC, 'pc');\n\nexport interface PopupOptions {\n\tpopup?: string,\n\tid?: string,\n\tp?: number,\n\tnotch?: boolean,\n\tclass?: string,\n\tposBy?: 'left' | 'right' | 'fixed' | Element,\n\tfrontSelector?: string,\n\tinvertX?: boolean,\n\topenByHover?: boolean,\n\tuseOriginal?: boolean,\n\ttransitionDuration?: number,\n\tisFullScreen?: boolean,\n}\n\n/**\n * Основной объект js компонента TopPopup\n *\n * Добавляет jQuery события на this.el, если jQuery загружен:\n *\n * - aftershow.top-menu-popup\n * - afterclose.top-menu-popup\n */\nexport class TopLibPopup<T extends Record<string, any> | undefined = Record<string, any>> extends Component {\n\n\tstatic componentName = 'TopPopup';\n\n\tdeclare el: HTMLElement & { __TopPopupOpenerProps: OpenerProps<T> }; // элемент, вызвавший открытие Popup\n\telActiveByDefault: boolean | undefined; // элемент уже имеет класс top-active перед открытием окна\n\telPopup: HTMLElement | undefined; // Popup .top-popup-wrapper\n\telPopupInner: HTMLElement | undefined; // контентная часть Popup .top-popup\n\telPopupHeader: HTMLElement | undefined | null;\n\telPopupWidget: HTMLElement | undefined | null;\n\telPopupBody: HTMLElement | undefined | null;\n\telPopupFooter: HTMLElement | undefined | null;\n\telFront: HTMLElement | undefined | null;\n\n\t/**\n\t * Для openerIsInput фокусировка срабатывает при входе в поле ввода\n\t *\n\t * Фокусировка на сам Popup не производится\n\t *\n\t * @see https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Reference/Roles/combobox_role\n\t */\n\topenerIsInput = false;\n\n\tpopupParent: TopLibPopup | undefined;\n\n\t$: JQuery<HTMLElement> | undefined; // только если есть jQuery\n\n\telStartPosition: HTMLElement | undefined | null; // используется для useOriginal\n\tshift = {\n\t\ttop: 0,\n\t\tleft: 0,\n\t};\n\tisClosed = false; // флаг того, что меню закрыто\n\tisFirstClick = true;\n\ttype: string | undefined; // selector или html\n\n\toptions: PopupOptions = {\n\t\tpopup: '', // selector, text\n\t\tp: 0, // положение меню (0 - над элементом, 1 - сверху, 2 - справа, 3 - снизу, 4 слева)\n\t\tnotch: false, // отображать ли клювик\n\n\t\tclass: '', // класс, добавляемый меню\n\n\t\tposBy: 'left', // способ привязки позиционирования меню (left/right - левый/правый край родителя, fixed - по документу)\n\t\tfrontSelector: '',\n\t\tinvertX: false, // базовая ордината - правая граница элемента, а не левая\n\t\topenByHover: false, // открывать при наведении\n\n\t\tuseOriginal: false, // использовать оригинальный шаблон, без клонирвоания (для сохранения состояния меню)\n\n\t\ttransitionDuration: 100, // значение прописано в css\n\n\t\tisFullScreen: false,\n\t};\n\n\tevents = {};\n\n\t/**\n\t * Создать Popup\n\t * @param el - элемент, открывающий меню\n\t * @param options\n\t */\n\tconstructor(el: HTMLElement, options: PopupOptions) {\n\t\tsuper();\n\n\t\tthis.init(TopLibPopup.componentName, el, options);\n\t}\n\n\tasync mount(): Promise<void> {\n\t\tif (!(this.el instanceof HTMLElement)) return;\n\t\tconst vueConnector = this.vueGetComponent();\n\n\t\tif (this.el.closest('.top-popup-wrapper')) this.popupParent = Worker.getPopup(this.el.closest('.top-popup-wrapper')!);\n\n\t\tawait this.mountJQuery();\n\n\t\tif (DOM.css(this.el, 'position') !== 'absolute') {\n\t\t\tthis.el.style.position = 'relative';\n\t\t}\n\n\t\tthis.el.dataset.topPopupOpened = 'opened';\n\t\tthis.elActiveByDefault = this.el.classList.contains('top-active');\n\t\tthis.el.classList.add('top-active');\n\n\t\tthis.openerIsInput = this.el.classList.contains('top-input');\n\n\t\t// todo: удалить после переписать TopProjectSelector на vue\n\t\tif (this.el.classList.contains('top-input-project_name')) {\n\t\t\tthis.openerIsInput = false;\n\t\t}\n\n\t\tif (this.openerIsInput) {\n\t\t\tconst elInput = this.el.querySelector('input');\n\t\t\tif (elInput && !elInput['__popupOnBlur']) {\n\t\t\t\telInput['__popupOnBlur'] = true;\n\n\t\t\t\telInput.addEventListener('blur', e => {\n\t\t\t\t\t// элемент один, экземпляры popup разные\n\t\t\t\t\tWorker.getPopupFromOpener(this.el)?.close();\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\tif (vueConnector) {\n\t\t\t// компонент vue Popup\n\t\t\tthis.type = 'vue';\n\n\t\t\tthis.options.popup = '';\n\t\t\tthis.elPopup = DOM.genEl('div', {}, this.options.popup);\n\t\t} else if (this.options.popup?.match(/^[#.]/)) {\n\t\t\t// selector\n\t\t\tthis.type = 'selector';\n\n\t\t\t// шаблон php\n\t\t\tthis.elPopup = document.querySelector<HTMLElement>(`${this.options.popup}.template`) || undefined;\n\t\t} else {\n\t\t\t// html\n\t\t\tthis.type = 'html';\n\n\t\t\tif (this.options.useOriginal) {\n\t\t\t\tthrow ('Option useOriginal not allowed for text templates');\n\t\t\t}\n\n\t\t\tthis.elPopup = DOM.genEl('div', {}, this.options.popup ?? '');\n\t\t}\n\n\t\t// запретить открывать одновременно один и тот же TopPopup дважды\n\t\tif (this.type !== 'html' && !vueConnector || vueConnector?.opened) {\n\t\t\t// // возможно, шаблон не найден, так как он используется в уже открытом меню (для php шаблонов)\n\t\t\t// if (this.options.useOriginal || vueConnector?.opened) {\n\n\t\t\t// возможно, шаблон не найден, так как используется js версия TopPopup\n\t\t\tif (!vueConnector || vueConnector?.opened) {\n\t\t\t\tlet elPopupSame: HTMLElement | undefined;\n\n\t\t\t\t// закрыть открытое меню\n\t\t\t\tif (vueConnector?.opened) {\n\t\t\t\t\telPopupSame = vueConnector.popup.elPopup;\n\t\t\t\t} else {\n\t\t\t\t\telPopupSame = document.querySelector<HTMLElement>(`${this.options.popup}.top-popup-wrapper-shown`) || undefined;\n\t\t\t\t}\n\n\t\t\t\tif (elPopupSame) {\n\t\t\t\t\tthis.elPopup = elPopupSame;\n\t\t\t\t\tthis.el.dataset.topPopupOpened = '';\n\n\t\t\t\t\tif (!this.elActiveByDefault) {\n\t\t\t\t\t\tthis.el.classList.remove('top-active');\n\t\t\t\t\t}\n\n\t\t\t\t\tWorker.close(this.elPopup);\n\n\t\t\t\t\t// повторит попытку открыть меню\n\t\t\t\t\tsetTimeout(() => this.mount(), this.options.transitionDuration);\n\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\t// throw ('Option useOriginal state allowed only elements .template');\n\t\t\t}\n\n\t\t\t// возможно, вместо шаблона используется другой элемент\n\t\t\tif (!this.elPopup) {\n\t\t\t\tthis.elPopup = document.querySelector<HTMLElement>(`${this.options.popup}:not(.top-popup-wrapper)`) || undefined;\n\t\t\t}\n\t\t}\n\n\t\tif (!this.elPopup) {\n\t\t\treturn;\n\t\t}\n\n\t\tif (this.options.useOriginal) {\n\t\t\tthis.elStartPosition = this.elPopup.closest<HTMLElement>('.top-popup-el-start-position');\n\t\t\tif (!this.elStartPosition) {\n\t\t\t\tthis.elStartPosition = DOM.wrap(this.elPopup, 'i');\n\t\t\t\tthis.elStartPosition.classList.add('top-popup-el-start-position', 'hidden');\n\t\t\t}\n\t\t} else {\n\t\t\tthis.elPopup = this.elPopup.cloneNode(true) as HTMLElement;\n\n\t\t\t// вывод в меню копии произвольного элемента\n\t\t\tif (this.type === 'selector' && !this.elPopup.matches('.template')) {\n\t\t\t\tthis.elPopup.classList.remove('hidden');\n\n\t\t\t\tif (!this.elPopup.querySelector(':scope > .top-popup_content')) {\n\t\t\t\t\tthis.elPopup.classList.add('top-popup_content');\n\t\t\t\t}\n\n\t\t\t\tthis.elPopup = DOM.wrap(this.elPopup, 'div');\n\t\t\t}\n\n\t\t\tif (this.type === 'html') {\n\t\t\t\tif (!this.elPopup.querySelector(':scope > .top-popup_content')) {\n\t\t\t\t\tthis.elPopup.classList.add('top-popup_content');\n\n\t\t\t\t\tthis.elPopup = DOM.wrap(this.elPopup, 'div');\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// вложенный Popup\n\t\t\tif (this.type === 'selector' && !this.elPopup.matches('.template') || this.type === 'html' || this.type === 'vue') {\n\t\t\t\tDOM.querySelectorAllArray(this.elPopup, '[data-top-popup]').forEach(el => {\n\t\t\t\t\tif (el instanceof HTMLElement) el.dataset.topPopupPosBy = 'fixed';\n\t\t\t\t});\n\t\t\t\tDOM.querySelectorAllArray(this.elPopup, '.top-popup-wrapper').forEach(el => el.remove());\n\t\t\t}\n\t\t}\n\n\t\tWorker.decoratorBeforeOpen(this);\n\n\t\tif (vueConnector) {\n\t\t\tthis.options.class = vueConnector.classRef.value;\n\t\t\tif (vueConnector.transitionDurationRef.value !== undefined) {\n\t\t\t\tthis.options.transitionDuration = vueConnector.transitionDurationRef.value;\n\n\t\t\t\tif (this.elPopup instanceof HTMLElement) {\n\t\t\t\t\tthis.elPopup.style.setProperty(\n\t\t\t\t\t\t'--top-popup-transition-delay',\n\t\t\t\t\t\tthis.options.transitionDuration + 'ms',\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tthis.elPopupInner = document.createElement('div');\n\t\tthis.elPopupInner.classList.add('top-popupPanel', 'top-popup');\n\n\t\twhile (this.elPopup.firstChild) {\n\t\t\tthis.elPopupInner.appendChild(this.elPopup.firstChild);\n\t\t}\n\n\t\tthis.elPopup.append(this.elPopupInner);\n\n\t\tthis.elPopup.classList.add('top-popup-wrapper');\n\n\t\tif (this.options.class) {\n\t\t\tconst classes = this.options.class.split(' ');\n\n\t\t\tthis.elPopup.classList.add(...classes);\n\t\t}\n\n\t\tif (this.options.notch) {\n\t\t\tthis.elPopup.classList.add('with_notch');\n\n\t\t\tthis.elPopup.insertAdjacentHTML('beforeend', '<i class=\"notch notch-border\"></i><i class=\"notch\"></i>');\n\t\t}\n\n\t\tawait this.vueOpen();\n\n\t\tthis.elPopupHeader = this.elPopupInner.querySelector<HTMLElement>('.top-popup_header');\n\t\tthis.elPopupWidget = this.elPopupInner.querySelector<HTMLElement>('.top-popup_widget');\n\t\tthis.elPopupBody = this.elPopupInner.querySelector<HTMLElement>('.top-popup_content');\n\t\tthis.elPopupFooter = this.elPopupInner.querySelector<HTMLElement>('.top-popup_footer');\n\n\t\tconst existsWidgetSearch = !!this.elPopup.querySelector('[data-widget=\"search\"]');\n\n\t\tif (this.options.isFullScreen && !existsWidgetSearch) {\n\t\t\tconst i18n = useI18n();\n\n\t\t\tif (!this.elPopupHeader && i18n.Common.Close) {\n\t\t\t\tthis.elPopupHeader = DOM.genEl('i', { class: 'top-popup_header' });\n\t\t\t\tthis.elPopupInner.prepend(this.elPopupHeader);\n\n\t\t\t\tthis.elPopupHeader.prepend(DOM.genEl('i', { class: 'a closer' }, i18n.Common.Close));\n\t\t\t\tthis.elPopupHeader.append(DOM.genEl('i', { class: 'top-popup_headerButton' }));\n\t\t\t}\n\t\t}\n\n\t\tDOM.storage(this.elPopup, TopLibPopup.componentName, this);\n\n\t\tif (this.options.frontSelector) {\n\t\t\tthis.elFront = document.querySelector<HTMLElement>(this.options.frontSelector);\n\t\t}\n\t\tif (!this.elFront) {\n\t\t\tthis.elFront = this.el.closest<HTMLElement>('.top-popup-front');\n\t\t}\n\t\tif (!this.elFront) {\n\t\t\tthis.elFront = document.body;\n\t\t}\n\n\t\tif (this.elPopup instanceof HTMLElement) {\n\t\t\tthis.elPopup.style.width = this.el.offsetWidth + 'px';\n\t\t\tthis.elPopup.style.height = this.el.offsetHeight + 'px';\n\t\t\tthis.elPopup.style.top = this.el.offsetTop + 'px';\n\t\t\tthis.elPopup.style.right = parseInt(this.el.style.right || '0') + 'px';\n\t\t\tthis.elPopup.style.bottom = parseInt(this.el.style.bottom || '0') + 'px';\n\t\t}\n\n\t\tthis.el.parentElement?.insertBefore(this.elPopup, this.el);\n\t\tthis.elPopup.classList.remove('template');\n\n\t\tif (this.options.invertX) {\n\t\t\tthis.elPopup.classList.add('invert-x');\n\t\t}\n\n\t\tlet fromTop = !!this.el.closest('.modal-header');\n\t\tif (!fromTop) {\n\t\t\tfromTop = !!this.el.closest('#top_panel');\n\t\t}\n\t\tif (!fromTop) {\n\t\t\tfromTop = !!this.el.closest('#secondmenu');\n\t\t}\n\t\tif (fromTop) {\n\t\t\tthis.elPopup.classList.add('p-from-top');\n\t\t}\n\n\t\t// появление с анимацией\n\t\tsetTimeout(() => this.elPopup?.classList.add('top-popup-wrapper-shown'));\n\n\t\tif (this.elFront && !this.elFront.matches('body')) {\n\t\t\tthis.elFront.append(this.elPopup);\n\n\t\t\tthis.shift.top = DOM.offset(this.el).top - this.el.offsetTop - DOM.offset(this.elFront).top;\n\t\t\tthis.shift.left = DOM.offset(this.el).left - this.el.offsetLeft - DOM.offset(this.elFront).left;\n\n\t\t\t// position() не учитывает margin, замечено для flex\n\t\t\tthis.shift.top -= parseInt(this.el.style['margin-top'] || 0);\n\t\t\tthis.shift.left -= parseInt(this.el.style['margin-left'] || 0);\n\n\t\t\tif (this.elPopup instanceof HTMLElement) {\n\t\t\t\tthis.elPopup.style.top = parseInt(this.elPopup.style.top || '0') + this.shift.top + 'px';\n\t\t\t\tthis.elPopup.style.left = parseInt(this.elPopup.style.left || '0') + this.shift.left + 'px';\n\t\t\t}\n\t\t}\n\n\t\tif (this.$ && Core.$) {\n\t\t\tthis.$.trigger('aftershow.top-menu-popup', [Core.$(this.elPopup)]);\n\t\t}\n\n\t\tthis.recalcPosition();\n\n\t\tthis.elPopup.setAttribute('tabindex', '0');\n\t\tthis.focus();\n\n\t\tWorker.decoratorAfterOpen(this);\n\n\t\tthis.mountEvents();\n\t}\n\n\tasync mountJQuery() {\n\t\tif (!Core.$) return;\n\n\t\tthis.$ = Core.$(this.el);\n\t}\n\n\t/**\n\t * Выполнить фокусировку на нужный элемент после открытия окна\n\t */\n\tfocus(): void {\n\t\tlet el: Element | null;\n\n\t\tif (this.elPopup) {\n\t\t\tel = DOM.querySelectorVisible(this.elPopup, '.top-popup-autofocus');\n\n\t\t\t// поле ввода\n\t\t\tif (!el) {\n\t\t\t\tel = DOM.querySelectorVisible(this.elPopup, ':read-write, select:not(:disabled)');\n\t\t\t}\n\n\t\t\t// кнопка\n\t\t\tif (!el) {\n\t\t\t\tel = DOM.querySelectorVisible(this.elPopup, '.top-popup_footer .top-button');\n\t\t\t}\n\n\t\t\tif (!el) {\n\t\t\t\tel = this.elPopup;\n\t\t\t}\n\n\t\t\t/**\n\t\t\t * @see this.openerIsInput\n\t\t\t */\n\t\t\tif (!this.openerIsInput) {\n\t\t\t\t// выполнить фокусировку сразу, для применения необходимых стилей\n\t\t\t\tif (el instanceof HTMLElement) el.focus({ preventScroll: true });\n\n\t\t\t\t// выполнить фокусировку после завершения анимации открытия popup\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tif (el instanceof HTMLElement) el.focus({ preventScroll: true });\n\t\t\t\t}, this.options.transitionDuration);\n\t\t\t}\n\t\t}\n\t}\n\n\tmountEvents(): void {\n\t\t// закрытие при клике вне контекстного меню\n\t\tthis.addEventListenerWithUnmount(document, 'mousedown', (e) => this.onMousedown(e as MouseEvent));\n\n\t\tif (this.openerIsInput) {\n\t\t\t/**\n\t\t\t * Фокусировка к моменту открытия popup уже установлена на поле ввода\n\t\t\t *\n\t\t\t * @see this.openerIsInput\n\t\t\t */\n\t\t\tthis.onFocusCloseOthers();\n\t\t} else {\n\t\t\tif (this.elPopup && this.elPopupInner) {\n\t\t\t\t// закрыть другие меню\n\t\t\t\tthis.addEventListenerWithUnmount(this.elPopup, 'focus', (e) => this.onFocus(e as FocusEvent));\n\n\t\t\t\t// автоматическое закрытие при отведении мыши\n\t\t\t\tif (this.options.openByHover) {\n\t\t\t\t\tthis.addEventListenerWithUnmount(this.elPopup, 'mouseleave', (e) => this.onMouseleave(e as MouseEvent));\n\t\t\t\t\tthis.addEventListenerWithUnmount(this.elPopupInner, 'mouseleave', (e) => this.onMouseleave(e as MouseEvent));\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// не скроллить страницу\n\t\tif (this.options.isFullScreen && this.elPopupBody) {\n\t\t\tthis.addEventListenerWithUnmount(this.elPopupBody, 'touchmove', (e) => this.onTouchmove(e as TouchEvent));\n\t\t}\n\t}\n\n\t/**\n\t * Обработка клика вне окна\n\t */\n\tprivate onMousedown(e: MouseEvent): void {\n\t\t// // не оригинальное событие\n\t\t// if (!e || !e.originalEvent || !e.originalEvent.isTrusted) {\n\t\t// \treturn;\n\t\t// }\n\n\t\t// Popup уже закрыт\n\t\tif (!this.elPopup || !(e.target instanceof Element)) {\n\t\t\treturn;\n\t\t}\n\n\t\t// клик на внешнем элементе\n\t\tif (!this.isFirstClick) {\n\t\t\treturn;\n\t\t}\n\n\t\tthis.isFirstClick = false;\n\t\tsetTimeout(() => this.isFirstClick = true);\n\n\t\t// клик не основной кнопкой мыши\n\t\tif (e instanceof MouseEvent && e.button !== 0) {\n\t\t\treturn;\n\t\t}\n\n\t\t// открыто другое меню с posBy = fixed, сначала должно быть закрыто оно\n\t\tlet elPopupOpened = DOM.querySelectorVisibleLast(document.body, ':scope > .top-popup-wrapper');\n\t\tif (elPopupOpened && elPopupOpened !== this.elPopup) {\n\t\t\treturn;\n\t\t}\n\n\t\t// открыто другое меню в top-popup-front, сначала должно быть закрыто оно\n\t\tif (e.target.closest('.top-popup-front')) {\n\t\t\telPopupOpened = DOM.querySelectorVisibleLast(e.target.closest('.top-popup-front')!, ':scope > .top-popup-wrapper');\n\n\t\t\tif (elPopupOpened && elPopupOpened !== this.elPopup) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\n\t\t// клик на кнопке открытия этого меню\n\t\tif (e.target.closest(`[data-top-popup-id=\"${this.options.id}\"]`)) {\n\t\t\te.preventDefault();\n\n\t\t\treturn;\n\t\t}\n\n\t\t// элемент формы, к которому идет переход\n\t\tlet toFormEl: HTMLElement | null = e.target.closest('input, select, textarea, button, [tabindex]');\n\t\tif (toFormEl === this.elPopup) toFormEl = null;\n\n\t\t// сохранить фокус после закрытия popup, если это не переход к другому элементу\n\t\tconst restoreFocus = !toFormEl;\n\n\t\t/**\n\t\t * Не сбравсывать уже установленный фокус\n\t\t */\n\t\tif (restoreFocus && this.openerIsInput) {\n\t\t\te.preventDefault();\n\t\t}\n\n\t\t// клик внутри этого меню\n\t\tif (this.elPopup.contains(e.target)) {\n\t\t\treturn;\n\t\t}\n\n\t\t// клик вне родительского диалогового окна\n\t\tif (this.elPopup.closest('.ui-dialog') && !e.target.closest('.ui-dialog')) {\n\t\t\treturn;\n\t\t}\n\n\t\tif (Worker.decoratorIsIgnoreOuterClick(e)) {\n\t\t\treturn;\n\t\t}\n\n\t\tWorker.close(this.elPopup, restoreFocus);\n\t}\n\n\t/**\n\t * Произошла фокусировка на этот popup\n\t */\n\tprivate onFocus(e: FocusEvent): void {\n\t\t// // не оригинальное событие\n\t\t// if (!e || !e.originalEvent || !e.originalEvent.isTrusted) {\n\t\t// \treturn;\n\t\t// }\n\n\t\tif (e.target instanceof Element && e.target.matches('input')) {\n\t\t\treturn;\n\t\t}\n\n\t\tthis.onFocusCloseOthers();\n\t}\n\n\t/**\n\t * Закрыть другие Popup при фокусе на элемент формы в текущем\n\t */\n\tprivate onFocusCloseOthers(): void {\n\t\t// это окно уже закрывается\n\t\tif (this.isClosed) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst elsPopups = Worker.getAllVisible();\n\t\telsPopups.forEach(elPopup => {\n\t\t\t// фокус внутри этого окна\n\t\t\tif (this.elPopup?.contains(elPopup)) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// это Popup из которого был открыт Popup с фокусом\n\t\t\t// глубина вложенности: до 3 подменю\n\t\t\tif (\n\t\t\t\tthis.popupParent?.elPopup === elPopup ||\n\t\t\t\tthis.popupParent?.popupParent?.elPopup === elPopup\n\t\t\t) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tWorker.close(elPopup);\n\t\t});\n\t}\n\n\t/**\n\t * Закрыть Popup при отведении мыши\n\t */\n\tprivate onMouseleave(_e: MouseEvent): void {\n\t\tsetTimeout(() => {\n\t\t\tif (this.elPopupInner && this.elPopupInner.matches(':hover') || !this.elPopup) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tWorker.close(this.elPopup);\n\t\t}, 100);\n\t}\n\n\t/**\n\t * Контроль положения Popup при fixed позиционировании\n\t */\n\tprivate onResize(): void {\n\t\t// на android при вызове метода append сбрасывается фокус с input внутри this.elPopup\n\t\tif (this.elPopup && this.elPopup.parentElement !== document.body) {\n\t\t\tdocument.body.append(this.elPopup);\n\t\t}\n\n\t\tif (this.elPopup instanceof HTMLElement) {\n\t\t\tthis.elPopup.style.top = DOM.offset(this.el).top + 'px';\n\t\t\tthis.elPopup.style.left = DOM.offset(this.el).left + 'px';\n\t\t}\n\t}\n\n\tunmount(): void {\n\t\tsuper.unmount();\n\n\t\tif (this.el instanceof HTMLElement) this.el.dataset.topPopupOpened = '';\n\t\tif (!this.elActiveByDefault) {\n\t\t\tthis.el.classList.remove('top-active');\n\t\t}\n\n\t\tlet style = this.el.getAttribute('style');\n\t\tif (style) {\n\t\t\tstyle = style.replace(/position:[^;]*;?/g, '');\n\t\t\tthis.el.setAttribute('style', style);\n\t\t}\n\t}\n\n\t// контроль за положением Popup, чтобы оно не вылезало за пределы документа\n\trecalcPosition(pForce?: typeof this.options.p): void {\n\t\tif (!(this.elPopup instanceof HTMLElement)) return;\n\n\t\tlet p = pForce ?? this.options.p;\n\t\tlet leftPos: number;\n\n\t\tif (this.el instanceof HTMLElement) {\n\t\t\tthis.elPopup.style.height = this.el.offsetHeight + 'px';\n\n\t\t\tthis.elPopup.classList.remove('p0', 'p1', 'p2', 'p3', 'p4');\n\t\t\tthis.elPopup.classList.add('p' + p);\n\n\t\t\tswitch (this.options.posBy) {\n\t\t\t\tcase 'left':\n\t\t\t\t\tleftPos = this.el.offsetLeft + parseInt(this.el.style['margin-left'] || '0');\n\t\t\t\t\tleftPos += this.shift.left;\n\t\t\t\t\tthis.elPopup.style.left = leftPos + 'px';\n\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'right':\n\t\t\t\t\tif (!(this.el.offsetParent instanceof HTMLElement)) break;\n\n\t\t\t\t\tleftPos = this.el.offsetLeft + parseInt(this.el.style['margin-left'] || '0');\n\t\t\t\t\tthis.elPopup.style.right = this.el.offsetParent.offsetWidth - this.el.offsetWidth - leftPos + 'px';\n\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'fixed':\n\t\t\t\t\tthis.addEventListenerWithUnmount(window, 'resize', () => this.onResize());\n\n\t\t\t\t\tthis.onResize();\n\n\t\t\t\t\tbreak;\n\t\t\t\tdefault:\n\t\t\t\t\tthis.options.posBy?.append(this.elPopup);\n\t\t\t}\n\t\t}\n\n\t\t// контроль за пложением Popup, чтобы оно не вылезало за пределы документа\n\t\tconst boundingClientRect = this.elPopup.getBoundingClientRect();\n\t\tthis.elPopup.style.setProperty('--top-popup-height', this.elPopup.offsetHeight + 'px');\n\t\tthis.elPopup.style.setProperty('--top-popup-right-bounding', boundingClientRect.right + 'px');\n\t\tthis.elPopup.style.setProperty('--top-popup-bottom-bounding', boundingClientRect.bottom + 'px');\n\t\tthis.elPopup.style.setProperty('--top-popup-top', boundingClientRect.top + 'px');\n\t\tthis.elPopup.style.setProperty('--top-popup-left', boundingClientRect.left + 'px');\n\n\t\tif (this.elPopupInner instanceof HTMLElement) {\n\t\t\tthis.elPopupInner.style.maxWidth = 'unset';\n\t\t\tthis.elPopupInner.style.maxHeight = 'unset';\n\t\t}\n\n\t\t// выходит ли popup за экран с конкретного края\n\t\tconst out = {\n\t\t\ttop: false,\n\t\t\tright: false,\n\t\t\tbottom: false,\n\t\t\tleft: false,\n\t\t};\n\n\t\t// выходит ли popup за экран с конкретного края, если применено инвертирование\n\t\tconst outWithInvert = {\n\t\t\ttop: false,\n\t\t\tright: false,\n\t\t\tbottom: false,\n\t\t\tleft: false,\n\t\t};\n\n\t\t// имеет ли смысл прикреплять окно к другой стороне кнопки\n\t\tlet canUseInvertX = boundingClientRect.left > window.innerWidth / 2;\n\t\tlet canUseInvertY = boundingClientRect.top > window.innerHeight / 2;\n\n\t\tif (p === 4) {\n\t\t\tcanUseInvertX = !canUseInvertX;\n\t\t}\n\n\t\tif (p === 1) {\n\t\t\tcanUseInvertY = !canUseInvertY;\n\t\t}\n\n\t\tconst contentBoundingClientRect = this.elPopupInner?.getBoundingClientRect();\n\n\t\tlet contentRight: number;\n\t\tlet contentBottom: number;\n\n\t\tconst margin = DOM.cssNumber(this.elPopup, '--top-popup-offset');\n\t\tconst elHeight = this.el.offsetHeight;\n\t\tconst elWidth = this.el.offsetWidth;\n\n\t\tif (contentBoundingClientRect) {\n\t\t\tcontentRight = window.innerWidth - contentBoundingClientRect.right;\n\t\t\tcontentBottom = window.innerHeight - contentBoundingClientRect.bottom;\n\n\t\t\tif (contentBoundingClientRect.top < margin) {\n\t\t\t\tout.top = true;\n\n\t\t\t\tif (contentBoundingClientRect.top < margin * 2 - contentBoundingClientRect.height + elHeight) {\n\t\t\t\t\toutWithInvert.top = true;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (contentRight < margin) {\n\t\t\t\tout.right = true;\n\n\t\t\t\tif (contentRight < margin * 2 - contentBoundingClientRect.width + elWidth) {\n\t\t\t\t\toutWithInvert.right = true;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (contentBottom < margin) {\n\t\t\t\tout.bottom = true;\n\n\t\t\t\tif (contentBottom < margin * 2 - contentBoundingClientRect.height + elHeight) {\n\t\t\t\t\toutWithInvert.bottom = true;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (contentBoundingClientRect.left < margin) {\n\t\t\t\tout.left = true;\n\n\t\t\t\tif (contentBoundingClientRect.left < margin * 2 - contentBoundingClientRect.width + elHeight) {\n\t\t\t\t\toutWithInvert.left = true;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t/**\n\t\t * Определить новое положение p, если popup не помещается\n\t\t *\n\t\t * Следует выполнять в два этапа:\n\t\t * - по горизонтали\n\t\t * - по вертикали\n\t\t */\n\t\tconst genP = (axis: 'x' | 'y', p: number) => {\n\t\t\t// проверяем горизонталь\n\t\t\tif (axis === 'x') {\n\t\t\t\tif (!out.right && !out.left) return p;\n\n\t\t\t\tif (p === 1 || p === 3) {\n\t\t\t\t\tif (!outWithInvert.right && !outWithInvert.left && canUseInvertX) return p;\n\t\t\t\t}\n\n\t\t\t\tif (out.right && (p === 0 || p === 2) && canUseInvertX) {\n\t\t\t\t\tp = 4;\n\t\t\t\t}\n\n\t\t\t\tif (out.left && (p === 0 || p === 4) && canUseInvertX) {\n\t\t\t\t\tp = 2;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// проверяем вертикаль\n\t\t\tif (axis === 'y') {\n\t\t\t\t// не помещается и можно использовать инвертирование\n\t\t\t\tif (!out.top && !out.bottom) return p;\n\n\t\t\t\tif (p === 2 || p === 4) {\n\t\t\t\t\tif (!outWithInvert.top && !outWithInvert.bottom && canUseInvertY) return p;\n\t\t\t\t}\n\n\t\t\t\tif (out.top && (p === 0 || p === 1) && canUseInvertY) {\n\t\t\t\t\tp = 3;\n\t\t\t\t}\n\n\t\t\t\tif (out.bottom && canUseInvertY) {\n\t\t\t\t\tp = 1;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn p;\n\t\t};\n\n\t\t/**\n\t\t * Приоритет определения `p` по осям зависит от начального значения `p`\n\t\t *\n\t\t * Пытаемся сохранить выбранную ось: X или Y\n\t\t */\n\t\tlet axis: Array<'x' | 'y'> = ['x', 'y'];\n\t\tif (p === 0 || p === 1 || p === 3) axis = ['y', 'x'];\n\n\t\tlet newP = p ?? 0;\n\t\taxis.forEach((axisI) => {\n\t\t\tnewP = genP(axisI, newP);\n\t\t});\n\t\tp = newP;\n\n\t\tif (out.bottom && (p === 2 || p === 4) && canUseInvertY) {\n\t\t\t// меню справа может перемещаться вверх, только если есть место слева\n\t\t\tthis.elPopup.classList.add('invert-y');\n\t\t}\n\n\t\tif (out.right && (p === 0 || p === 1 || p === 3)) {\n\t\t\tthis.elPopup.classList.add('invert-x');\n\t\t}\n\n\t\tthis.elPopup.classList.remove('p0', 'p1', 'p2', 'p3', 'p4');\n\t\tthis.elPopup.classList.add('p' + p);\n\n\t\tif (this.elPopupInner instanceof HTMLElement) {\n\t\t\tthis.elPopupInner.style.maxWidth = '';\n\t\t\tthis.elPopupInner.style.maxHeight = '';\n\t\t}\n\n\t\t// if (this.elPopupBody instanceof HTMLElement) {\n\t\t// \t// отобразить popup по вертикали с другой стороны, если с другой стороны больше места\n\t\t// \tconst hasScroll = this.elPopupBody.offsetHeight < this.elPopupBody.scrollHeight;\n\t\t// \tvd(this.elPopupBody.scrollHeight);\n\t\t// \tvd(this.elPopupBody.offsetHeight);\n\t\t// \tif (hasScroll && pForce === undefined) {\n\t\t// \t\tconst contentBoundingClientRect = this.elPopupBody?.getBoundingClientRect();\n\t\t// \t\tif (\n\t\t// \t\t\tp === 1 && contentBoundingClientRect.top * 2 < contentBoundingClientRect.bottom ||\n\t\t// \t\t\tp === 3 && contentBoundingClientRect.bottom * 2 < contentBoundingClientRect.top\n\t\t// \t\t) {\n\t\t// \t\t\tthis.recalcPosition(p === 1 ? 3 : 1);\n\t\t//\n\t\t// \t\t\treturn;\n\t\t// \t\t}\n\t\t// \t}\n\t\t// }\n\n\t\tWorker.scrollToActive(this.elPopup);\n\t};\n\n\tonTouchmove(e: TouchEvent): void {\n\t\tif (e.currentTarget instanceof HTMLElement && e.target instanceof HTMLElement) {\n\t\t\t// разрешить горизональный скролл\n\t\t\tlet hasScrollX = e.currentTarget.scrollWidth > e.currentTarget.offsetWidth;\n\t\t\tif (hasScrollX) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif (e.target.parentElement?.scrollWidth && e.target.parentElement?.offsetWidth) {\n\t\t\t\t// разрешить горизональный скролл\n\t\t\t\tlet hasScrollX2 = e.target.parentElement.scrollWidth > e.target.parentElement?.offsetWidth;\n\t\t\t\tif (hasScrollX2) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (!e.currentTarget.matches('.has_scroll')) {\n\t\t\t\te.preventDefault();\n\t\t\t}\n\t\t}\n\t}\n\n\tclose(): void {\n\t\tif (this.isClosed) {\n\t\t\treturn;\n\t\t}\n\n\t\tthis.isClosed = true;\n\n\t\tif (this.$ && Core.$ && this.elPopup) {\n\t\t\tthis.$.trigger('afterclose.top-menu-popup', [Core.$(this.elPopup)]);\n\t\t}\n\n\t\tif (Worker.noClose) {\n\t\t\treturn;\n\t\t}\n\n\t\tthis.unmount();\n\n\t\tthis.elPopup?.classList.add('top-popup-wrapper-closed');\n\n\t\tsetTimeout(() => {\n\t\t\tthis.vueClose();\n\n\t\t\tif (!this.elPopup) return;\n\n\t\t\tif (this.options.useOriginal) {\n\t\t\t\tthis.elPopup.removeAttribute('style');\n\t\t\t\tthis.elPopup.classList.remove('top-popup-wrapper-shown', 'top-popup-wrapper-closed');\n\t\t\t\tthis.elPopup.classList.add('template');\n\t\t\t\tthis.elStartPosition?.append(this.elPopup);\n\n\t\t\t\tthis.elPopup.querySelector('div.top-popup_content.top-column')?.classList.remove('top-column');\n\t\t\t\tthis.elPopup.querySelector('.notch-border')?.remove();\n\t\t\t\tthis.elPopup.querySelector('.notch')?.remove();\n\n\t\t\t\tthis.elPopupInner?.replaceWith(...this.elPopupInner.childNodes);\n\n\t\t\t\tDOM.storageClear(this.elPopup);\n\t\t\t} else {\n\t\t\t\tDOM.storageClear(this.elPopup);\n\n\t\t\t\tthis.elPopup.remove();\n\t\t\t\tdelete this.elPopup;\n\t\t\t}\n\n\t\t\tconst elsPopups = Worker.getAllVisible();\n\t\t\tconst elPopupLast = elsPopups.length && elsPopups[elsPopups.length - 1];\n\n\t\t\tif (elPopupLast) {\n\t\t\t\tWorker.getPopup(elPopupLast).focus();\n\t\t\t} else {\n\t\t\t\tdocument.documentElement.classList.remove('with_popup');\n\t\t\t}\n\t\t}, this.options.transitionDuration);\n\t}\n\n\tasync vueOpen(): Promise<void> {\n\t\tawait this.vueGetComponent()?.onOpen(this);\n\t}\n\n\tvueClose(): void {\n\t\tthis.vueGetComponent()?.onClose(this);\n\t}\n\n\t// получить vueConnectors компонента Popup\n\tvueGetComponent() {\n\t\tif (this.el instanceof HTMLElement && this.options.id) return Worker.vueConnectors.get(this.options.id);\n\t}\n}\n\nGlobalEvents.init();\n"],"names":["Component","componentName","el","options","component","utils_dom","eventData","type","listener","nodes","node","GlobalEvents","e","elUl","elItem","elPopup2","popup_worker","elCloser","elPopup","elBtn","elFooterLastBtn","elMore","countLi","elsLiVisible","index","elItemActive","Core","vueConnector","elInput","elPopupSame","classes","existsWidgetSearch","i18n","forms","TopLibPopup","fromTop","elPopupOpened","restoreFocus","toFormEl","leftPos","boundingClientRect","contentRight","contentBottom","margin","elHeight","elWidth","contentBoundingClientRect","out","outWithInvert","genP","axis2","p2","canUseInvertX","canUseInvertY","axis","newP","axisI","elsPopups","elPopupLast"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
define(["require","exports","vue","./forms-
|
|
2
|
-
//# sourceMappingURL=popupHint.vue_vue_type_style_index_0_lang-
|
|
1
|
+
define(["require","exports","vue","./forms-DDNzqU6o.amd","../popup/worker.amd","../require/css.amd!../assets/popupHint.css"],(function(w,y,e,P,u){"use strict";if(typeof e>"u")var e=window.Vue;const k=e.defineComponent({__name:"opener",props:{id:{},pos:{default:"3"},notch:{type:Boolean,default:!0},openByFocusInput:{type:Boolean},openByHover:{type:Boolean},disabled:{type:Boolean},posBy:{default:"fixed"},data:{}},setup(s){const n=s,l=n.id||Math.random()+"";let p;function f(t){setTimeout(()=>{p=t.nextElementSibling,p&&r(p)})}e.onUpdated(()=>{p&&r(p)});function r(t){t.dataset.topPopup="#"+l;const i=!!t.dataset.topPopupDisabled;if(t.dataset.topPopupId=l,t.dataset.topPopupPos=n.pos,t.dataset.topPopupPosBy=n.posBy,t.dataset.topPopupNotch=n.notch?"true":"",t.dataset.topPopupOpenByHover=n.openByHover?"true":"",t.dataset.topPopupDisabled=n.disabled?"true":"",t.__TopPopupOpenerProps=n,n.openByFocusInput&&t.classList.contains("top-input")){const c=t.querySelector("input");if(c.onfocus=()=>{t.dataset.topPopupDisabled||u.TopPopupWorker.openByOpener(t)},n.disabled!==i&&c===document.activeElement){const a=u.TopPopupWorker.getPopupFromOpener(t);!n.disabled&&!a&&u.TopPopupWorker.openByOpener(t),n.disabled&&a&&a.close()}}}return(t,i)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("template",{ref:f}),e.renderSlot(t.$slots,"default")],64))}}),h={key:0,class:"top-popup_header"},$={key:0,class:"top-as-a closer"},C={key:1,class:"top-popup_widget"},b={key:2,class:"top-popup_content"},S={key:4,class:"top-popup_footer"},I=["href"],E=e.defineComponent({__name:"popup",props:{id:{default:""},class:{},transitionDuration:{},footerSupportLink:{},pos:{default:"3"},notch:{type:Boolean,default:!0},openByFocusInput:{type:Boolean},openByHover:{type:Boolean},disabled:{type:Boolean},posBy:{default:"fixed"},data:{}},emits:["open","close","scrollContentList"],setup(s,{expose:n,emit:l}){const p=s,f=l,r=p.id||"top-popup-id-"+Math.random(),t={id:r,popup:void 0};n(t);const i=e.ref(null),c=e.ref(null),a=e.ref(),d={onOpen:async o=>{o.elPopup&&(i.value=o.elPopup),o.elPopupInner&&(o.elPopupInner.innerText="",c.value=o.elPopupInner),d.opened=!0,d.popup=o,t.popup=o,a.value=o.el.__TopPopupOpenerProps.data,f("open",{elPopup:o.elPopup,elPopupOpener:o.el,data:a.value})},onClose:o=>{c.value=null,d.opened=!1,d.popup=void 0,a.value=void 0,f("close",{elPopup:o.elPopup,elPopupOpener:o.el,data:o.el.__TopPopupOpenerProps.data})},classRef:e.toRef(p,"class"),opened:!1,popup:void 0,transitionDurationRef:e.toRef(p,"transitionDuration")};return e.watch(()=>p.class,(o,B)=>{if(!i.value)return;const m=o?.split(" ")??[],L=(B?.split(" ")??[]).filter(_=>!m.includes(_));i.value.classList.remove(...L),i.value.classList.add(...m)}),u.TopPopupWorker.regVueComponent(r,d),e.onUnmounted(()=>{u.TopPopupWorker.unregVueComponent(r)}),(o,B)=>{const m=e.resolveDirective("top-scroll-shadow");return e.openBlock(),e.createElementBlock(e.Fragment,null,[o.$slots.opener?(e.openBlock(),e.createBlock(k,{key:0,id:e.unref(r),pos:s.pos,posBy:s.posBy,notch:s.notch,openByFocusInput:s.openByFocusInput,openByHover:o.$core.state.isMobile||o.$core.state.isMobileUA?!1:s.openByHover,disabled:s.disabled},{default:e.withCtx(()=>[e.renderSlot(o.$slots,"opener")]),_:3},8,["id","pos","posBy","notch","openByFocusInput","openByHover","disabled"])):e.createCommentVNode("",!0),c.value?(e.openBlock(),e.createBlock(e.Teleport,{key:1,to:c.value},[o.$slots.header||o.$core.state.isMobile?(e.openBlock(),e.createElementBlock("div",h,[o.$core.state.isMobile?(e.openBlock(),e.createElementBlock("span",$,e.toDisplayString(o.$i18n.Common.Close),1)):e.createCommentVNode("",!0),e.renderSlot(o.$slots,"header",{data:a.value})])):e.createCommentVNode("",!0),o.$slots.widget?(e.openBlock(),e.createElementBlock("div",C,[e.renderSlot(o.$slots,"widget")])):e.createCommentVNode("",!0),o.$slots.content?e.withDirectives((e.openBlock(),e.createElementBlock("div",b,[e.renderSlot(o.$slots,"content",{data:a.value})])),[[m]]):e.createCommentVNode("",!0),o.$slots.contentList?e.withDirectives((e.openBlock(),e.createElementBlock("ul",{key:3,class:"top-popup_content",onScroll:B[0]||(B[0]=v=>o.$emit("scrollContentList",v))},[e.renderSlot(o.$slots,"contentList",{data:a.value})],32)),[[m]]):e.createCommentVNode("",!0),o.$slots.footer||s.footerSupportLink?(e.openBlock(),e.createElementBlock("div",S,[s.footerSupportLink?(e.openBlock(),e.createElementBlock("a",{key:0,class:"top-popup_footerSupportLink",href:s.footerSupportLink,target:"_blank"},[e.createVNode(P._sfc_main$2,{hint:""})],8,I)):e.createCommentVNode("",!0),e.renderSlot(o.$slots,"footer",{data:a.value})])):e.createCommentVNode("",!0)],8,["to"])):e.createCommentVNode("",!0)],64)}}}),V={class:"top-popup_listItemActionsLabel top-ellipsis1"},N={class:"top-popup_listItemActions"},g=e.defineComponent({inheritAttrs:!1,__name:"listItem",props:{type:{default:"button"},closeByClick:{type:Boolean,default:!0},attrs:{}},setup(s){const n=s;return(l,p)=>(e.openBlock(),e.createElementBlock("li",{class:e.normalizeClass({"top-popup_liNoSelectable":n.type!=="button"})},[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(l.$attrs.href?"a":"div"),e.mergeProps({class:{"top-popup_listItem":!0,["top-popup_listItem-"+n.type]:!!n.type,"top-popup_liastItem-withActions":l.$slots.actions,"top-popup-noCloser":!s.closeByClick,a:n.type==="button"}},{...l.$attrs,...s.attrs}),{default:e.withCtx(()=>[l.$slots.actions?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createElementVNode("div",V,[e.renderSlot(l.$slots,"default")]),e.createElementVNode("div",N,[e.renderSlot(l.$slots,"actions")])],64)):e.renderSlot(l.$slots,"default",{key:1})]),_:3},16,["class"])),e.renderSlot(l.$slots,"buttons")],2))}});y._sfc_main=E,y._sfc_main$1=g,y._sfc_main$2=k}));
|
|
2
|
+
//# sourceMappingURL=popupHint.vue_vue_type_style_index_0_lang-Bu_HvFoW.amd.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"popupHint.vue_vue_type_style_index_0_lang-KuWtifP4.amd.js","sources":["../../src/components/popup/popup/opener/opener.vue","../../src/components/popup/popup/popup.vue","../../src/components/popup/popup/listItem.vue"],"sourcesContent":["<script setup lang=\"ts\" generic=\"T extends Record<string, any> | undefined = undefined\">\nimport { onUpdated } from 'vue';\nimport type { OpenerProps } from './types';\nimport Worker from '../../lib/worker';\n\nconst props = withDefaults(defineProps<OpenerProps<T>>(), {\n\tpos: '3',\n\tnotch: true,\n\tposBy: 'fixed',\n});\n\nconst id = props.id || Math.random() + '';\n\nlet elOpener: Element;\n\n/**\n * Необычная функция для проброски props внутрь элемента слота\n *\n * @param el - вспомогательный элемент для доступа к элементам слота\n */\nfunction render(el: any) {\n\tsetTimeout(() => {\n\t\telOpener = el.nextElementSibling;\n\n\t\tif (elOpener) {\n\t\t\trenderOpener(elOpener);\n\t\t}\n\t});\n}\n\nonUpdated(() => {\n\tif (elOpener) {\n\t\trenderOpener(elOpener);\n\t}\n});\n\nfunction renderOpener(elOpener: any) {\n\t/**\n\t * topPopup - необходимый атрибут для всез Popup\n\t *\n\t * Для Vue вместо него используется атрибут topPopupId\n\t */\n\telOpener.dataset.topPopup = '#' + id;\n\n\tconst disabledOld = !!elOpener.dataset.topPopupDisabled;\n\n\telOpener.dataset.topPopupId = id;\n\telOpener.dataset.topPopupPos = props.pos;\n\telOpener.dataset.topPopupPosBy = props.posBy;\n\telOpener.dataset.topPopupNotch = props.notch ? 'true' : '';\n\telOpener.dataset.topPopupOpenByHover = props.openByHover ? 'true' : '';\n\telOpener.dataset.topPopupDisabled = props.disabled ? 'true' : '';\n\telOpener.__TopPopupOpenerProps = props;\n\n\tif (props.openByFocusInput && elOpener.classList.contains('top-input')) {\n\t\tconst elInput = elOpener.querySelector('input');\n\n\t\telInput.onfocus = () => {\n\t\t\tif (elOpener.dataset.topPopupDisabled) return;\n\n\t\t\tWorker.openByOpener(elOpener);\n\t\t};\n\n\t\t/**\n\t\t * Открыть или закрыть `popup` в момент ввода значения, если он становится активным\n\t\t *\n\t\t * Для обработки ввода значения с проверкой `minLength`\n\t\t */\n\t\tif (props.disabled !== disabledOld && elInput === document.activeElement) {\n\t\t\tconst popup = Worker.getPopupFromOpener(elOpener);\n\n\t\t\tif (!props.disabled && !popup) {\n\t\t\t\tWorker.openByOpener(elOpener);\n\t\t\t}\n\n\t\t\tif (props.disabled && popup) {\n\t\t\t\tpopup.close();\n\t\t\t}\n\t\t}\n\t}\n}\n</script>\n\n<template>\n\t<template :ref=\"render\"></template>\n\n\t<!-- @slot элемент для открытия Popup -->\n\t<slot></slot>\n</template>\n\n<!-- Использует общий deprecated класс .btn -->\n<style>\nh3[data-top-popup],\ndiv[data-top-popup],\ni[data-top-popup]:not(.btn),\nb[data-top-popup]:not(.btn) {\n\tcursor: pointer;\n\tuser-select: none;\n\tfont-style: normal;\n\ttext-decoration: none;\n\tdisplay: inline-flex;\n\talign-items: center;\n}\n\n[data-top-popup][data-top-popup-disabled] {\n\t/*\n\tpointer-events: none;\n\tcursor: auto !important;\n\t*/\n}\n\ni[contenteditable] {\n\tcursor: text !important;\n}\n</style>\n","<script setup lang=\"ts\" generic=\"T extends Record<string, any> | undefined = undefined\">\nimport { onUnmounted, ref, toRef, watch } from 'vue';\nimport TopHint from '@/components/forms/hint/hint.vue';\nimport type { TopLibPopup } from '@/components/popup/lib/popup';\nimport type { Emits, Props } from './types';\nimport Opener from './opener/opener.vue';\nimport Worker from '@/components/popup/lib/worker';\n\nconst props = withDefaults(defineProps<Props<T>>(), {\n\tid: '',\n\tpos: '3',\n\tnotch: true,\n\tposBy: 'fixed',\n});\n\nconst emit = defineEmits<Emits<T>>();\n\nconst id = props.id || 'top-popup-id-' + Math.random() + '';\n\nconst expose = {\n\tid,\n\tpopup: undefined as TopLibPopup<T> | undefined,\n};\n\ndefineExpose(expose);\n\nconst elPopupRef = ref<HTMLElement | null>(null);\nconst elPopupInnerRef = ref<HTMLElement | null>(null);\n\nconst data = ref<T>();\n\n// см. lib/popup\nconst onOpen = async (popup: TopLibPopup<T>) => {\n\tif (popup.elPopup) elPopupRef.value = popup.elPopup;\n\n\tif (popup.elPopupInner) {\n\t\tpopup.elPopupInner.innerText = '';\n\n\t\telPopupInnerRef.value = popup.elPopupInner;\n\t}\n\n\tvueConnector.opened = true;\n\tvueConnector.popup = popup;\n\n\texpose.popup = popup;\n\n\tdata.value = popup.el.__TopPopupOpenerProps.data;\n\n\temit('open', { elPopup: popup.elPopup!, elPopupOpener: popup.el, data: data.value });\n};\n\n// см. lib/popup\nconst onClose = (popup: TopLibPopup<T>) => {\n\telPopupInnerRef.value = null;\n\n\tvueConnector.opened = false;\n\tvueConnector.popup = undefined;\n\n\tdata.value = undefined;\n\n\temit('close', { elPopup: popup.elPopup!, elPopupOpener: popup.el, data: popup.el.__TopPopupOpenerProps.data });\n};\n\nconst vueConnector = {\n\tonOpen,\n\tonClose,\n\tclassRef: toRef(props, 'class'),\n\topened: false,\n\tpopup: undefined as TopLibPopup<T> | undefined,\n\ttransitionDurationRef: toRef(props, 'transitionDuration'),\n};\n\nwatch(() => props.class, (newValue, oldValue) => {\n\tif (!elPopupRef.value) return;\n\n\tconst newClasses = newValue?.split(' ') ?? [];\n\tconst oldClasses = oldValue?.split(' ') ?? [];\n\n\tconst delClasses = oldClasses.filter((oldClass) => !newClasses.includes(oldClass));\n\n\telPopupRef.value.classList.remove(...delClasses);\n\telPopupRef.value.classList.add(...newClasses);\n});\n\nWorker.regVueComponent(id, vueConnector);\n\nonUnmounted(() => {\n\tWorker.unregVueComponent(id);\n});\n</script>\n\n<template>\n\t<Opener\n\t\tv-if=\"$slots.opener\"\n\t\t:id\n\t\t:pos\n\t\t:posBy\n\t\t:notch\n\t\t:openByFocusInput\n\t\t:openByHover=\"($core.state.isMobile || $core.state.isMobileUA) ? false : openByHover\"\n\t\t:disabled\n\t>\n\t\t<!-- @slot элемент для открытия Popup -->\n\t\t<slot name=\"opener\"></slot>\n\t</Opener>\n\n\t<!-- Это шаблон для компонента Popup, сам Popup генерируется в js и может находиться где угодно -->\n\t<!-- elPopupInnerRef будет установлен только после открытия и будет сброшен сразу после закрытия Popup -->\n\t<teleport\n\t\tv-if=\"elPopupInnerRef\"\n\t\t:to=\"elPopupInnerRef\"\n\t>\n\t\t<div\n\t\t\tv-if=\"$slots.header || $core.state.isMobile\"\n\t\t\tclass=\"top-popup_header\"\n\t\t>\n\t\t\t<span\n\t\t\t\tv-if=\"$core.state.isMobile\"\n\t\t\t\tclass=\"top-as-a closer\"\n\t\t\t>\n\t\t\t\t{{ $i18n.Common.Close }}\n\t\t\t</span>\n\n\t\t\t<!-- @slot Шапка -->\n\t\t\t<slot name=\"header\" :data=\"data\"></slot>\n\t\t</div>\n\n\t\t<div\n\t\t\tv-if=\"$slots.widget\"\n\t\t\tclass=\"top-popup_widget\"\n\t\t>\n\t\t\t<!-- @slot Виджет -->\n\t\t\t<slot name=\"widget\"></slot>\n\t\t</div>\n\n\t\t<div\n\t\t\tv-if=\"$slots.content\"\n\t\t\tclass=\"top-popup_content\"\n\t\t\tv-top-scroll-shadow\n\t\t>\n\t\t\t<!-- @slot Контент в свободной форме -->\n\t\t\t<slot name=\"content\" :data=\"data\"></slot>\n\t\t</div>\n\n\t\t<ul\n\t\t\tv-if=\"$slots.contentList\"\n\t\t\tclass=\"top-popup_content\"\n\t\t\t@scroll=\"$emit('scrollContentList', $event)\"\n\t\t\tv-top-scroll-shadow\n\t\t>\n\t\t\t<!-- @slot Контент в виде списка, для вставки элементов списка используйте компонент popup/listItem -->\n\t\t\t<slot name=\"contentList\" :data=\"data\"></slot>\n\t\t</ul>\n\n\t\t<div\n\t\t\tv-if=\"$slots.footer || footerSupportLink\"\n\t\t\tclass=\"top-popup_footer\"\n\t\t>\n\t\t\t<a\n\t\t\t\tv-if=\"footerSupportLink\"\n\t\t\t\tclass=\"top-popup_footerSupportLink\"\n\t\t\t\t:href=\"footerSupportLink\"\n\t\t\t\ttarget=\"_blank\"\n\t\t\t>\n\t\t\t\t<TopHint hint=\"\"/>\n\t\t\t</a>\n\n\t\t\t<!-- @slot Футер -->\n\t\t\t<slot name=\"footer\" :data=\"data\"></slot>\n\t\t</div>\n\t</teleport>\n</template>\n\n<style>\n.top-popup_footerSupportLink {\n\tmargin-right: auto;\n}\n</style>\n","<script setup lang=\"ts\">\nimport type { ListItemProps } from './types';\n\ndefineOptions({\n\tinheritAttrs: false,\n});\n\nconst props = withDefaults(defineProps<ListItemProps>(), {\n\ttype: 'button',\n\tcloseByClick: true,\n});\n</script>\n\n<template>\n\t<li\n\t\t:class=\"{\n\t\t\t'top-popup_liNoSelectable': props.type !== 'button'\n\t\t}\"\n\t>\n\t\t<component\n\t\t\t:is=\"$attrs.href ? 'a' : 'div'\"\n\t\t\t:class=\"{\n\t\t\t\t'top-popup_listItem': true,\n\t\t\t\t['top-popup_listItem-' + props.type]: !!props.type,\n\t\t\t\t'top-popup_liastItem-withActions': $slots.actions,\n\t\t\t\t'top-popup-noCloser': !closeByClick,\n\n\t\t\t\t'a': props.type === 'button', // оформления кнопки, deprecated\n\t\t\t}\"\n\t\t\t:=\"{...$attrs, ...attrs}\"\n\t\t>\n\t\t\t<template v-if=\"$slots.actions\">\n\t\t\t\t<div class=\"top-popup_listItemActionsLabel top-ellipsis1\">\n\t\t\t\t\t<slot></slot>\n\t\t\t\t</div>\n\n\t\t\t\t<div class=\"top-popup_listItemActions\">\n\t\t\t\t\t<slot name=\"actions\"></slot>\n\t\t\t\t</div>\n\t\t\t</template>\n\n\t\t\t<template v-else>\n\t\t\t\t<slot></slot>\n\t\t\t</template>\n\t\t</component>\n\n\t\t<slot name=\"buttons\"></slot>\n\t</li>\n</template>\n"],"names":["id","props","elOpener","render","el","renderOpener","elOpener2","elInput","popup_worker","disabledOld","popup","vue","_ctx","elPopupRef","elPopupInnerRef","data","vueConnector","expose","delClasses","oldClass","newClasses","__props","_hoisted_2$1","_hoisted_1"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"popupHint.vue_vue_type_style_index_0_lang-Bu_HvFoW.amd.js","sources":["../../src/components/popup/popup/opener/opener.vue","../../src/components/popup/popup/popup.vue","../../src/components/popup/popup/listItem.vue"],"sourcesContent":["<script setup lang=\"ts\" generic=\"T extends Record<string, any> | undefined = undefined\">\nimport { onUpdated } from 'vue';\nimport type { OpenerProps } from './types';\nimport Worker from '../../lib/worker';\n\nconst props = withDefaults(defineProps<OpenerProps<T>>(), {\n\tpos: '3',\n\tnotch: true,\n\tposBy: 'fixed',\n});\n\nconst id = props.id || Math.random() + '';\n\nlet elOpener: Element;\n\n/**\n * Необычная функция для проброски props внутрь элемента слота\n *\n * @param el - вспомогательный элемент для доступа к элементам слота\n */\nfunction render(el: any) {\n\tsetTimeout(() => {\n\t\telOpener = el.nextElementSibling;\n\n\t\tif (elOpener) {\n\t\t\trenderOpener(elOpener);\n\t\t}\n\t});\n}\n\nonUpdated(() => {\n\tif (elOpener) {\n\t\trenderOpener(elOpener);\n\t}\n});\n\nfunction renderOpener(elOpener: any) {\n\t/**\n\t * topPopup - необходимый атрибут для всез Popup\n\t *\n\t * Для Vue вместо него используется атрибут topPopupId\n\t */\n\telOpener.dataset.topPopup = '#' + id;\n\n\tconst disabledOld = !!elOpener.dataset.topPopupDisabled;\n\n\telOpener.dataset.topPopupId = id;\n\telOpener.dataset.topPopupPos = props.pos;\n\telOpener.dataset.topPopupPosBy = props.posBy;\n\telOpener.dataset.topPopupNotch = props.notch ? 'true' : '';\n\telOpener.dataset.topPopupOpenByHover = props.openByHover ? 'true' : '';\n\telOpener.dataset.topPopupDisabled = props.disabled ? 'true' : '';\n\telOpener.__TopPopupOpenerProps = props;\n\n\tif (props.openByFocusInput && elOpener.classList.contains('top-input')) {\n\t\tconst elInput = elOpener.querySelector('input');\n\n\t\telInput.onfocus = () => {\n\t\t\tif (elOpener.dataset.topPopupDisabled) return;\n\n\t\t\tWorker.openByOpener(elOpener);\n\t\t};\n\n\t\t/**\n\t\t * Открыть или закрыть `popup` в момент ввода значения, если он становится активным\n\t\t *\n\t\t * Для обработки ввода значения с проверкой `minLength`\n\t\t */\n\t\tif (props.disabled !== disabledOld && elInput === document.activeElement) {\n\t\t\tconst popup = Worker.getPopupFromOpener(elOpener);\n\n\t\t\tif (!props.disabled && !popup) {\n\t\t\t\tWorker.openByOpener(elOpener);\n\t\t\t}\n\n\t\t\tif (props.disabled && popup) {\n\t\t\t\tpopup.close();\n\t\t\t}\n\t\t}\n\t}\n}\n</script>\n\n<template>\n\t<template :ref=\"render\"></template>\n\n\t<!-- @slot элемент для открытия Popup -->\n\t<slot></slot>\n</template>\n\n<!-- Использует общий deprecated класс .btn -->\n<style>\nh3[data-top-popup],\ndiv[data-top-popup],\ni[data-top-popup]:not(.btn),\nb[data-top-popup]:not(.btn) {\n\tcursor: pointer;\n\tuser-select: none;\n\tfont-style: normal;\n\ttext-decoration: none;\n\tdisplay: inline-flex;\n\talign-items: center;\n}\n\n[data-top-popup][data-top-popup-disabled] {\n\t/*\n\tpointer-events: none;\n\tcursor: auto !important;\n\t*/\n}\n\ni[contenteditable] {\n\tcursor: text !important;\n}\n</style>\n","<script setup lang=\"ts\" generic=\"T extends Record<string, any> | undefined = undefined\">\nimport { onUnmounted, ref, toRef, watch } from 'vue';\nimport TopHint from '@/components/forms/hint/hint.vue';\nimport type { TopLibPopup } from '@/components/popup/lib/popup';\nimport type { Emits, Props } from './types';\nimport Opener from './opener/opener.vue';\nimport Worker from '@/components/popup/lib/worker';\n\nconst props = withDefaults(defineProps<Props<T>>(), {\n\tid: '',\n\tpos: '3',\n\tnotch: true,\n\tposBy: 'fixed',\n});\n\nconst emit = defineEmits<Emits<T>>();\n\nconst id = props.id || 'top-popup-id-' + Math.random() + '';\n\nconst expose = {\n\tid,\n\tpopup: undefined as TopLibPopup<T> | undefined,\n};\n\ndefineExpose(expose);\n\nconst elPopupRef = ref<HTMLElement | null>(null);\nconst elPopupInnerRef = ref<HTMLElement | null>(null);\n\nconst data = ref<T>();\n\n// см. lib/popup\nconst onOpen = async (popup: TopLibPopup<T>) => {\n\tif (popup.elPopup) elPopupRef.value = popup.elPopup;\n\n\tif (popup.elPopupInner) {\n\t\tpopup.elPopupInner.innerText = '';\n\n\t\telPopupInnerRef.value = popup.elPopupInner;\n\t}\n\n\tvueConnector.opened = true;\n\tvueConnector.popup = popup;\n\n\texpose.popup = popup;\n\n\tdata.value = popup.el.__TopPopupOpenerProps.data;\n\n\temit('open', { elPopup: popup.elPopup!, elPopupOpener: popup.el, data: data.value });\n};\n\n// см. lib/popup\nconst onClose = (popup: TopLibPopup<T>) => {\n\telPopupInnerRef.value = null;\n\n\tvueConnector.opened = false;\n\tvueConnector.popup = undefined;\n\n\tdata.value = undefined;\n\n\temit('close', { elPopup: popup.elPopup!, elPopupOpener: popup.el, data: popup.el.__TopPopupOpenerProps.data });\n};\n\nconst vueConnector = {\n\tonOpen,\n\tonClose,\n\tclassRef: toRef(props, 'class'),\n\topened: false,\n\tpopup: undefined as TopLibPopup<T> | undefined,\n\ttransitionDurationRef: toRef(props, 'transitionDuration'),\n};\n\nwatch(() => props.class, (newValue, oldValue) => {\n\tif (!elPopupRef.value) return;\n\n\tconst newClasses = newValue?.split(' ') ?? [];\n\tconst oldClasses = oldValue?.split(' ') ?? [];\n\n\tconst delClasses = oldClasses.filter((oldClass) => !newClasses.includes(oldClass));\n\n\telPopupRef.value.classList.remove(...delClasses);\n\telPopupRef.value.classList.add(...newClasses);\n});\n\nWorker.regVueComponent(id, vueConnector);\n\nonUnmounted(() => {\n\tWorker.unregVueComponent(id);\n});\n</script>\n\n<template>\n\t<Opener\n\t\tv-if=\"$slots.opener\"\n\t\t:id\n\t\t:pos\n\t\t:posBy\n\t\t:notch\n\t\t:openByFocusInput\n\t\t:openByHover=\"($core.state.isMobile || $core.state.isMobileUA) ? false : openByHover\"\n\t\t:disabled\n\t>\n\t\t<!-- @slot элемент для открытия Popup -->\n\t\t<slot name=\"opener\"></slot>\n\t</Opener>\n\n\t<!-- Это шаблон для компонента Popup, сам Popup генерируется в js и может находиться где угодно -->\n\t<!-- elPopupInnerRef будет установлен только после открытия и будет сброшен сразу после закрытия Popup -->\n\t<teleport\n\t\tv-if=\"elPopupInnerRef\"\n\t\t:to=\"elPopupInnerRef\"\n\t>\n\t\t<div\n\t\t\tv-if=\"$slots.header || $core.state.isMobile\"\n\t\t\tclass=\"top-popup_header\"\n\t\t>\n\t\t\t<span\n\t\t\t\tv-if=\"$core.state.isMobile\"\n\t\t\t\tclass=\"top-as-a closer\"\n\t\t\t>\n\t\t\t\t{{ $i18n.Common.Close }}\n\t\t\t</span>\n\n\t\t\t<!-- @slot Шапка -->\n\t\t\t<slot name=\"header\" :data=\"data\"></slot>\n\t\t</div>\n\n\t\t<div\n\t\t\tv-if=\"$slots.widget\"\n\t\t\tclass=\"top-popup_widget\"\n\t\t>\n\t\t\t<!-- @slot Виджет -->\n\t\t\t<slot name=\"widget\"></slot>\n\t\t</div>\n\n\t\t<div\n\t\t\tv-if=\"$slots.content\"\n\t\t\tclass=\"top-popup_content\"\n\t\t\tv-top-scroll-shadow\n\t\t>\n\t\t\t<!-- @slot Контент в свободной форме -->\n\t\t\t<slot name=\"content\" :data=\"data\"></slot>\n\t\t</div>\n\n\t\t<ul\n\t\t\tv-if=\"$slots.contentList\"\n\t\t\tclass=\"top-popup_content\"\n\t\t\t@scroll=\"$emit('scrollContentList', $event)\"\n\t\t\tv-top-scroll-shadow\n\t\t>\n\t\t\t<!-- @slot Контент в виде списка, для вставки элементов списка используйте компонент popup/listItem -->\n\t\t\t<slot name=\"contentList\" :data=\"data\"></slot>\n\t\t</ul>\n\n\t\t<div\n\t\t\tv-if=\"$slots.footer || footerSupportLink\"\n\t\t\tclass=\"top-popup_footer\"\n\t\t>\n\t\t\t<a\n\t\t\t\tv-if=\"footerSupportLink\"\n\t\t\t\tclass=\"top-popup_footerSupportLink\"\n\t\t\t\t:href=\"footerSupportLink\"\n\t\t\t\ttarget=\"_blank\"\n\t\t\t>\n\t\t\t\t<TopHint hint=\"\"/>\n\t\t\t</a>\n\n\t\t\t<!-- @slot Футер -->\n\t\t\t<slot name=\"footer\" :data=\"data\"></slot>\n\t\t</div>\n\t</teleport>\n</template>\n\n<style>\n.top-popup_footerSupportLink {\n\tmargin-right: auto;\n}\n</style>\n","<script setup lang=\"ts\">\nimport type { ListItemProps } from './types';\n\ndefineOptions({\n\tinheritAttrs: false,\n});\n\nconst props = withDefaults(defineProps<ListItemProps>(), {\n\ttype: 'button',\n\tcloseByClick: true,\n});\n</script>\n\n<template>\n\t<li\n\t\t:class=\"{\n\t\t\t'top-popup_liNoSelectable': props.type !== 'button'\n\t\t}\"\n\t>\n\t\t<component\n\t\t\t:is=\"$attrs.href ? 'a' : 'div'\"\n\t\t\t:class=\"{\n\t\t\t\t'top-popup_listItem': true,\n\t\t\t\t['top-popup_listItem-' + props.type]: !!props.type,\n\t\t\t\t'top-popup_liastItem-withActions': $slots.actions,\n\t\t\t\t'top-popup-noCloser': !closeByClick,\n\n\t\t\t\t'a': props.type === 'button', // оформления кнопки, deprecated\n\t\t\t}\"\n\t\t\t:=\"{...$attrs, ...attrs}\"\n\t\t>\n\t\t\t<template v-if=\"$slots.actions\">\n\t\t\t\t<div class=\"top-popup_listItemActionsLabel top-ellipsis1\">\n\t\t\t\t\t<slot></slot>\n\t\t\t\t</div>\n\n\t\t\t\t<div class=\"top-popup_listItemActions\">\n\t\t\t\t\t<slot name=\"actions\"></slot>\n\t\t\t\t</div>\n\t\t\t</template>\n\n\t\t\t<template v-else>\n\t\t\t\t<slot></slot>\n\t\t\t</template>\n\t\t</component>\n\n\t\t<slot name=\"buttons\"></slot>\n\t</li>\n</template>\n"],"names":["id","props","elOpener","render","el","renderOpener","elOpener2","elInput","popup_worker","disabledOld","popup","vue","_ctx","elPopupRef","elPopupInnerRef","data","vueConnector","expose","delClasses","oldClass","newClasses","__props","_hoisted_2$1","_hoisted_1"],"mappings":"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"}
|
|
@@ -3,8 +3,8 @@
|
|
|
3
3
|
const fileNames = ['../assets/popupHint.css'].map(fileName => import.meta.resolve(fileName));
|
|
4
4
|
_autoloadCSSCore.insertCSSLinkToPage(fileNames, true);
|
|
5
5
|
|
|
6
|
-
import { defineComponent as k, onUpdated as D,
|
|
7
|
-
import { f as W } from "./forms-
|
|
6
|
+
import { defineComponent as k, onUpdated as D, openBlock as n, createElementBlock as i, Fragment as C, createElementVNode as $, renderSlot as u, ref as h, toRef as L, watch as F, onUnmounted as H, resolveDirective as T, createBlock as b, unref as M, withCtx as S, createCommentVNode as r, Teleport as A, toDisplayString as N, withDirectives as g, createVNode as R, normalizeClass as V, resolveDynamicComponent as E, mergeProps as U } from "vue";
|
|
7
|
+
import { f as W } from "./forms-DtC-EKJL.es.js";
|
|
8
8
|
import { TopPopupWorker as v } from "../popup/worker.js";
|
|
9
9
|
const q = /* @__PURE__ */ k({
|
|
10
10
|
__name: "opener",
|
|
@@ -203,7 +203,7 @@ const q = /* @__PURE__ */ k({
|
|
|
203
203
|
});
|
|
204
204
|
export {
|
|
205
205
|
to as _,
|
|
206
|
-
|
|
207
|
-
|
|
206
|
+
so as a,
|
|
207
|
+
q as b
|
|
208
208
|
};
|
|
209
|
-
//# sourceMappingURL=popupHint.vue_vue_type_style_index_0_lang-
|
|
209
|
+
//# sourceMappingURL=popupHint.vue_vue_type_style_index_0_lang-DAQIAxvu.es.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"popupHint.vue_vue_type_style_index_0_lang-TWsWJQFN.es.js","sources":["../../src/components/popup/popup/opener/opener.vue","../../src/components/popup/popup/popup.vue","../../src/components/popup/popup/listItem.vue"],"sourcesContent":["<script setup lang=\"ts\" generic=\"T extends Record<string, any> | undefined = undefined\">\nimport { onUpdated } from 'vue';\nimport type { OpenerProps } from './types';\nimport Worker from '../../lib/worker';\n\nconst props = withDefaults(defineProps<OpenerProps<T>>(), {\n\tpos: '3',\n\tnotch: true,\n\tposBy: 'fixed',\n});\n\nconst id = props.id || Math.random() + '';\n\nlet elOpener: Element;\n\n/**\n * Необычная функция для проброски props внутрь элемента слота\n *\n * @param el - вспомогательный элемент для доступа к элементам слота\n */\nfunction render(el: any) {\n\tsetTimeout(() => {\n\t\telOpener = el.nextElementSibling;\n\n\t\tif (elOpener) {\n\t\t\trenderOpener(elOpener);\n\t\t}\n\t});\n}\n\nonUpdated(() => {\n\tif (elOpener) {\n\t\trenderOpener(elOpener);\n\t}\n});\n\nfunction renderOpener(elOpener: any) {\n\t/**\n\t * topPopup - необходимый атрибут для всез Popup\n\t *\n\t * Для Vue вместо него используется атрибут topPopupId\n\t */\n\telOpener.dataset.topPopup = '#' + id;\n\n\tconst disabledOld = !!elOpener.dataset.topPopupDisabled;\n\n\telOpener.dataset.topPopupId = id;\n\telOpener.dataset.topPopupPos = props.pos;\n\telOpener.dataset.topPopupPosBy = props.posBy;\n\telOpener.dataset.topPopupNotch = props.notch ? 'true' : '';\n\telOpener.dataset.topPopupOpenByHover = props.openByHover ? 'true' : '';\n\telOpener.dataset.topPopupDisabled = props.disabled ? 'true' : '';\n\telOpener.__TopPopupOpenerProps = props;\n\n\tif (props.openByFocusInput && elOpener.classList.contains('top-input')) {\n\t\tconst elInput = elOpener.querySelector('input');\n\n\t\telInput.onfocus = () => {\n\t\t\tif (elOpener.dataset.topPopupDisabled) return;\n\n\t\t\tWorker.openByOpener(elOpener);\n\t\t};\n\n\t\t/**\n\t\t * Открыть или закрыть `popup` в момент ввода значения, если он становится активным\n\t\t *\n\t\t * Для обработки ввода значения с проверкой `minLength`\n\t\t */\n\t\tif (props.disabled !== disabledOld && elInput === document.activeElement) {\n\t\t\tconst popup = Worker.getPopupFromOpener(elOpener);\n\n\t\t\tif (!props.disabled && !popup) {\n\t\t\t\tWorker.openByOpener(elOpener);\n\t\t\t}\n\n\t\t\tif (props.disabled && popup) {\n\t\t\t\tpopup.close();\n\t\t\t}\n\t\t}\n\t}\n}\n</script>\n\n<template>\n\t<template :ref=\"render\"></template>\n\n\t<!-- @slot элемент для открытия Popup -->\n\t<slot></slot>\n</template>\n\n<!-- Использует общий deprecated класс .btn -->\n<style>\nh3[data-top-popup],\ndiv[data-top-popup],\ni[data-top-popup]:not(.btn),\nb[data-top-popup]:not(.btn) {\n\tcursor: pointer;\n\tuser-select: none;\n\tfont-style: normal;\n\ttext-decoration: none;\n\tdisplay: inline-flex;\n\talign-items: center;\n}\n\n[data-top-popup][data-top-popup-disabled] {\n\t/*\n\tpointer-events: none;\n\tcursor: auto !important;\n\t*/\n}\n\ni[contenteditable] {\n\tcursor: text !important;\n}\n</style>\n","<script setup lang=\"ts\" generic=\"T extends Record<string, any> | undefined = undefined\">\nimport { onUnmounted, ref, toRef, watch } from 'vue';\nimport TopHint from '@/components/forms/hint/hint.vue';\nimport type { TopLibPopup } from '@/components/popup/lib/popup';\nimport type { Emits, Props } from './types';\nimport Opener from './opener/opener.vue';\nimport Worker from '@/components/popup/lib/worker';\n\nconst props = withDefaults(defineProps<Props<T>>(), {\n\tid: '',\n\tpos: '3',\n\tnotch: true,\n\tposBy: 'fixed',\n});\n\nconst emit = defineEmits<Emits<T>>();\n\nconst id = props.id || 'top-popup-id-' + Math.random() + '';\n\nconst expose = {\n\tid,\n\tpopup: undefined as TopLibPopup<T> | undefined,\n};\n\ndefineExpose(expose);\n\nconst elPopupRef = ref<HTMLElement | null>(null);\nconst elPopupInnerRef = ref<HTMLElement | null>(null);\n\nconst data = ref<T>();\n\n// см. lib/popup\nconst onOpen = async (popup: TopLibPopup<T>) => {\n\tif (popup.elPopup) elPopupRef.value = popup.elPopup;\n\n\tif (popup.elPopupInner) {\n\t\tpopup.elPopupInner.innerText = '';\n\n\t\telPopupInnerRef.value = popup.elPopupInner;\n\t}\n\n\tvueConnector.opened = true;\n\tvueConnector.popup = popup;\n\n\texpose.popup = popup;\n\n\tdata.value = popup.el.__TopPopupOpenerProps.data;\n\n\temit('open', { elPopup: popup.elPopup!, elPopupOpener: popup.el, data: data.value });\n};\n\n// см. lib/popup\nconst onClose = (popup: TopLibPopup<T>) => {\n\telPopupInnerRef.value = null;\n\n\tvueConnector.opened = false;\n\tvueConnector.popup = undefined;\n\n\tdata.value = undefined;\n\n\temit('close', { elPopup: popup.elPopup!, elPopupOpener: popup.el, data: popup.el.__TopPopupOpenerProps.data });\n};\n\nconst vueConnector = {\n\tonOpen,\n\tonClose,\n\tclassRef: toRef(props, 'class'),\n\topened: false,\n\tpopup: undefined as TopLibPopup<T> | undefined,\n\ttransitionDurationRef: toRef(props, 'transitionDuration'),\n};\n\nwatch(() => props.class, (newValue, oldValue) => {\n\tif (!elPopupRef.value) return;\n\n\tconst newClasses = newValue?.split(' ') ?? [];\n\tconst oldClasses = oldValue?.split(' ') ?? [];\n\n\tconst delClasses = oldClasses.filter((oldClass) => !newClasses.includes(oldClass));\n\n\telPopupRef.value.classList.remove(...delClasses);\n\telPopupRef.value.classList.add(...newClasses);\n});\n\nWorker.regVueComponent(id, vueConnector);\n\nonUnmounted(() => {\n\tWorker.unregVueComponent(id);\n});\n</script>\n\n<template>\n\t<Opener\n\t\tv-if=\"$slots.opener\"\n\t\t:id\n\t\t:pos\n\t\t:posBy\n\t\t:notch\n\t\t:openByFocusInput\n\t\t:openByHover=\"($core.state.isMobile || $core.state.isMobileUA) ? false : openByHover\"\n\t\t:disabled\n\t>\n\t\t<!-- @slot элемент для открытия Popup -->\n\t\t<slot name=\"opener\"></slot>\n\t</Opener>\n\n\t<!-- Это шаблон для компонента Popup, сам Popup генерируется в js и может находиться где угодно -->\n\t<!-- elPopupInnerRef будет установлен только после открытия и будет сброшен сразу после закрытия Popup -->\n\t<teleport\n\t\tv-if=\"elPopupInnerRef\"\n\t\t:to=\"elPopupInnerRef\"\n\t>\n\t\t<div\n\t\t\tv-if=\"$slots.header || $core.state.isMobile\"\n\t\t\tclass=\"top-popup_header\"\n\t\t>\n\t\t\t<span\n\t\t\t\tv-if=\"$core.state.isMobile\"\n\t\t\t\tclass=\"top-as-a closer\"\n\t\t\t>\n\t\t\t\t{{ $i18n.Common.Close }}\n\t\t\t</span>\n\n\t\t\t<!-- @slot Шапка -->\n\t\t\t<slot name=\"header\" :data=\"data\"></slot>\n\t\t</div>\n\n\t\t<div\n\t\t\tv-if=\"$slots.widget\"\n\t\t\tclass=\"top-popup_widget\"\n\t\t>\n\t\t\t<!-- @slot Виджет -->\n\t\t\t<slot name=\"widget\"></slot>\n\t\t</div>\n\n\t\t<div\n\t\t\tv-if=\"$slots.content\"\n\t\t\tclass=\"top-popup_content\"\n\t\t\tv-top-scroll-shadow\n\t\t>\n\t\t\t<!-- @slot Контент в свободной форме -->\n\t\t\t<slot name=\"content\" :data=\"data\"></slot>\n\t\t</div>\n\n\t\t<ul\n\t\t\tv-if=\"$slots.contentList\"\n\t\t\tclass=\"top-popup_content\"\n\t\t\t@scroll=\"$emit('scrollContentList', $event)\"\n\t\t\tv-top-scroll-shadow\n\t\t>\n\t\t\t<!-- @slot Контент в виде списка, для вставки элементов списка используйте компонент popup/listItem -->\n\t\t\t<slot name=\"contentList\" :data=\"data\"></slot>\n\t\t</ul>\n\n\t\t<div\n\t\t\tv-if=\"$slots.footer || footerSupportLink\"\n\t\t\tclass=\"top-popup_footer\"\n\t\t>\n\t\t\t<a\n\t\t\t\tv-if=\"footerSupportLink\"\n\t\t\t\tclass=\"top-popup_footerSupportLink\"\n\t\t\t\t:href=\"footerSupportLink\"\n\t\t\t\ttarget=\"_blank\"\n\t\t\t>\n\t\t\t\t<TopHint hint=\"\"/>\n\t\t\t</a>\n\n\t\t\t<!-- @slot Футер -->\n\t\t\t<slot name=\"footer\" :data=\"data\"></slot>\n\t\t</div>\n\t</teleport>\n</template>\n\n<style>\n.top-popup_footerSupportLink {\n\tmargin-right: auto;\n}\n</style>\n","<script setup lang=\"ts\">\nimport type { ListItemProps } from './types';\n\ndefineOptions({\n\tinheritAttrs: false,\n});\n\nconst props = withDefaults(defineProps<ListItemProps>(), {\n\ttype: 'button',\n\tcloseByClick: true,\n});\n</script>\n\n<template>\n\t<li\n\t\t:class=\"{\n\t\t\t'top-popup_liNoSelectable': props.type !== 'button'\n\t\t}\"\n\t>\n\t\t<component\n\t\t\t:is=\"$attrs.href ? 'a' : 'div'\"\n\t\t\t:class=\"{\n\t\t\t\t'top-popup_listItem': true,\n\t\t\t\t['top-popup_listItem-' + props.type]: !!props.type,\n\t\t\t\t'top-popup_liastItem-withActions': $slots.actions,\n\t\t\t\t'top-popup-noCloser': !closeByClick,\n\n\t\t\t\t'a': props.type === 'button', // оформления кнопки, deprecated\n\t\t\t}\"\n\t\t\t:=\"{...$attrs, ...attrs}\"\n\t\t>\n\t\t\t<template v-if=\"$slots.actions\">\n\t\t\t\t<div class=\"top-popup_listItemActionsLabel top-ellipsis1\">\n\t\t\t\t\t<slot></slot>\n\t\t\t\t</div>\n\n\t\t\t\t<div class=\"top-popup_listItemActions\">\n\t\t\t\t\t<slot name=\"actions\"></slot>\n\t\t\t\t</div>\n\t\t\t</template>\n\n\t\t\t<template v-else>\n\t\t\t\t<slot></slot>\n\t\t\t</template>\n\t\t</component>\n\n\t\t<slot name=\"buttons\"></slot>\n\t</li>\n</template>\n"],"names":["props","__props","id","elOpener","render","el","renderOpener","onUpdated","disabledOld","elInput","Worker","popup","_createElementVNode","_renderSlot","_ctx","emit","__emit","expose","__expose","elPopupRef","ref","elPopupInnerRef","data","vueConnector","toRef","watch","newValue","oldValue","newClasses","delClasses","oldClass","onUnmounted","$slots","_createBlock","Opener","_unref","$core","_Teleport","_openBlock","_createElementBlock","_hoisted_1","_hoisted_2","_toDisplayString","$i18n","_hoisted_3","_withDirectives","_hoisted_4","_cache","$event","$emit","_hoisted_5","_createVNode","TopHint","_normalizeClass","_resolveDynamicComponent","$attrs","_mergeProps","_Fragment"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"popupHint.vue_vue_type_style_index_0_lang-DAQIAxvu.es.js","sources":["../../src/components/popup/popup/opener/opener.vue","../../src/components/popup/popup/popup.vue","../../src/components/popup/popup/listItem.vue"],"sourcesContent":["<script setup lang=\"ts\" generic=\"T extends Record<string, any> | undefined = undefined\">\nimport { onUpdated } from 'vue';\nimport type { OpenerProps } from './types';\nimport Worker from '../../lib/worker';\n\nconst props = withDefaults(defineProps<OpenerProps<T>>(), {\n\tpos: '3',\n\tnotch: true,\n\tposBy: 'fixed',\n});\n\nconst id = props.id || Math.random() + '';\n\nlet elOpener: Element;\n\n/**\n * Необычная функция для проброски props внутрь элемента слота\n *\n * @param el - вспомогательный элемент для доступа к элементам слота\n */\nfunction render(el: any) {\n\tsetTimeout(() => {\n\t\telOpener = el.nextElementSibling;\n\n\t\tif (elOpener) {\n\t\t\trenderOpener(elOpener);\n\t\t}\n\t});\n}\n\nonUpdated(() => {\n\tif (elOpener) {\n\t\trenderOpener(elOpener);\n\t}\n});\n\nfunction renderOpener(elOpener: any) {\n\t/**\n\t * topPopup - необходимый атрибут для всез Popup\n\t *\n\t * Для Vue вместо него используется атрибут topPopupId\n\t */\n\telOpener.dataset.topPopup = '#' + id;\n\n\tconst disabledOld = !!elOpener.dataset.topPopupDisabled;\n\n\telOpener.dataset.topPopupId = id;\n\telOpener.dataset.topPopupPos = props.pos;\n\telOpener.dataset.topPopupPosBy = props.posBy;\n\telOpener.dataset.topPopupNotch = props.notch ? 'true' : '';\n\telOpener.dataset.topPopupOpenByHover = props.openByHover ? 'true' : '';\n\telOpener.dataset.topPopupDisabled = props.disabled ? 'true' : '';\n\telOpener.__TopPopupOpenerProps = props;\n\n\tif (props.openByFocusInput && elOpener.classList.contains('top-input')) {\n\t\tconst elInput = elOpener.querySelector('input');\n\n\t\telInput.onfocus = () => {\n\t\t\tif (elOpener.dataset.topPopupDisabled) return;\n\n\t\t\tWorker.openByOpener(elOpener);\n\t\t};\n\n\t\t/**\n\t\t * Открыть или закрыть `popup` в момент ввода значения, если он становится активным\n\t\t *\n\t\t * Для обработки ввода значения с проверкой `minLength`\n\t\t */\n\t\tif (props.disabled !== disabledOld && elInput === document.activeElement) {\n\t\t\tconst popup = Worker.getPopupFromOpener(elOpener);\n\n\t\t\tif (!props.disabled && !popup) {\n\t\t\t\tWorker.openByOpener(elOpener);\n\t\t\t}\n\n\t\t\tif (props.disabled && popup) {\n\t\t\t\tpopup.close();\n\t\t\t}\n\t\t}\n\t}\n}\n</script>\n\n<template>\n\t<template :ref=\"render\"></template>\n\n\t<!-- @slot элемент для открытия Popup -->\n\t<slot></slot>\n</template>\n\n<!-- Использует общий deprecated класс .btn -->\n<style>\nh3[data-top-popup],\ndiv[data-top-popup],\ni[data-top-popup]:not(.btn),\nb[data-top-popup]:not(.btn) {\n\tcursor: pointer;\n\tuser-select: none;\n\tfont-style: normal;\n\ttext-decoration: none;\n\tdisplay: inline-flex;\n\talign-items: center;\n}\n\n[data-top-popup][data-top-popup-disabled] {\n\t/*\n\tpointer-events: none;\n\tcursor: auto !important;\n\t*/\n}\n\ni[contenteditable] {\n\tcursor: text !important;\n}\n</style>\n","<script setup lang=\"ts\" generic=\"T extends Record<string, any> | undefined = undefined\">\nimport { onUnmounted, ref, toRef, watch } from 'vue';\nimport TopHint from '@/components/forms/hint/hint.vue';\nimport type { TopLibPopup } from '@/components/popup/lib/popup';\nimport type { Emits, Props } from './types';\nimport Opener from './opener/opener.vue';\nimport Worker from '@/components/popup/lib/worker';\n\nconst props = withDefaults(defineProps<Props<T>>(), {\n\tid: '',\n\tpos: '3',\n\tnotch: true,\n\tposBy: 'fixed',\n});\n\nconst emit = defineEmits<Emits<T>>();\n\nconst id = props.id || 'top-popup-id-' + Math.random() + '';\n\nconst expose = {\n\tid,\n\tpopup: undefined as TopLibPopup<T> | undefined,\n};\n\ndefineExpose(expose);\n\nconst elPopupRef = ref<HTMLElement | null>(null);\nconst elPopupInnerRef = ref<HTMLElement | null>(null);\n\nconst data = ref<T>();\n\n// см. lib/popup\nconst onOpen = async (popup: TopLibPopup<T>) => {\n\tif (popup.elPopup) elPopupRef.value = popup.elPopup;\n\n\tif (popup.elPopupInner) {\n\t\tpopup.elPopupInner.innerText = '';\n\n\t\telPopupInnerRef.value = popup.elPopupInner;\n\t}\n\n\tvueConnector.opened = true;\n\tvueConnector.popup = popup;\n\n\texpose.popup = popup;\n\n\tdata.value = popup.el.__TopPopupOpenerProps.data;\n\n\temit('open', { elPopup: popup.elPopup!, elPopupOpener: popup.el, data: data.value });\n};\n\n// см. lib/popup\nconst onClose = (popup: TopLibPopup<T>) => {\n\telPopupInnerRef.value = null;\n\n\tvueConnector.opened = false;\n\tvueConnector.popup = undefined;\n\n\tdata.value = undefined;\n\n\temit('close', { elPopup: popup.elPopup!, elPopupOpener: popup.el, data: popup.el.__TopPopupOpenerProps.data });\n};\n\nconst vueConnector = {\n\tonOpen,\n\tonClose,\n\tclassRef: toRef(props, 'class'),\n\topened: false,\n\tpopup: undefined as TopLibPopup<T> | undefined,\n\ttransitionDurationRef: toRef(props, 'transitionDuration'),\n};\n\nwatch(() => props.class, (newValue, oldValue) => {\n\tif (!elPopupRef.value) return;\n\n\tconst newClasses = newValue?.split(' ') ?? [];\n\tconst oldClasses = oldValue?.split(' ') ?? [];\n\n\tconst delClasses = oldClasses.filter((oldClass) => !newClasses.includes(oldClass));\n\n\telPopupRef.value.classList.remove(...delClasses);\n\telPopupRef.value.classList.add(...newClasses);\n});\n\nWorker.regVueComponent(id, vueConnector);\n\nonUnmounted(() => {\n\tWorker.unregVueComponent(id);\n});\n</script>\n\n<template>\n\t<Opener\n\t\tv-if=\"$slots.opener\"\n\t\t:id\n\t\t:pos\n\t\t:posBy\n\t\t:notch\n\t\t:openByFocusInput\n\t\t:openByHover=\"($core.state.isMobile || $core.state.isMobileUA) ? false : openByHover\"\n\t\t:disabled\n\t>\n\t\t<!-- @slot элемент для открытия Popup -->\n\t\t<slot name=\"opener\"></slot>\n\t</Opener>\n\n\t<!-- Это шаблон для компонента Popup, сам Popup генерируется в js и может находиться где угодно -->\n\t<!-- elPopupInnerRef будет установлен только после открытия и будет сброшен сразу после закрытия Popup -->\n\t<teleport\n\t\tv-if=\"elPopupInnerRef\"\n\t\t:to=\"elPopupInnerRef\"\n\t>\n\t\t<div\n\t\t\tv-if=\"$slots.header || $core.state.isMobile\"\n\t\t\tclass=\"top-popup_header\"\n\t\t>\n\t\t\t<span\n\t\t\t\tv-if=\"$core.state.isMobile\"\n\t\t\t\tclass=\"top-as-a closer\"\n\t\t\t>\n\t\t\t\t{{ $i18n.Common.Close }}\n\t\t\t</span>\n\n\t\t\t<!-- @slot Шапка -->\n\t\t\t<slot name=\"header\" :data=\"data\"></slot>\n\t\t</div>\n\n\t\t<div\n\t\t\tv-if=\"$slots.widget\"\n\t\t\tclass=\"top-popup_widget\"\n\t\t>\n\t\t\t<!-- @slot Виджет -->\n\t\t\t<slot name=\"widget\"></slot>\n\t\t</div>\n\n\t\t<div\n\t\t\tv-if=\"$slots.content\"\n\t\t\tclass=\"top-popup_content\"\n\t\t\tv-top-scroll-shadow\n\t\t>\n\t\t\t<!-- @slot Контент в свободной форме -->\n\t\t\t<slot name=\"content\" :data=\"data\"></slot>\n\t\t</div>\n\n\t\t<ul\n\t\t\tv-if=\"$slots.contentList\"\n\t\t\tclass=\"top-popup_content\"\n\t\t\t@scroll=\"$emit('scrollContentList', $event)\"\n\t\t\tv-top-scroll-shadow\n\t\t>\n\t\t\t<!-- @slot Контент в виде списка, для вставки элементов списка используйте компонент popup/listItem -->\n\t\t\t<slot name=\"contentList\" :data=\"data\"></slot>\n\t\t</ul>\n\n\t\t<div\n\t\t\tv-if=\"$slots.footer || footerSupportLink\"\n\t\t\tclass=\"top-popup_footer\"\n\t\t>\n\t\t\t<a\n\t\t\t\tv-if=\"footerSupportLink\"\n\t\t\t\tclass=\"top-popup_footerSupportLink\"\n\t\t\t\t:href=\"footerSupportLink\"\n\t\t\t\ttarget=\"_blank\"\n\t\t\t>\n\t\t\t\t<TopHint hint=\"\"/>\n\t\t\t</a>\n\n\t\t\t<!-- @slot Футер -->\n\t\t\t<slot name=\"footer\" :data=\"data\"></slot>\n\t\t</div>\n\t</teleport>\n</template>\n\n<style>\n.top-popup_footerSupportLink {\n\tmargin-right: auto;\n}\n</style>\n","<script setup lang=\"ts\">\nimport type { ListItemProps } from './types';\n\ndefineOptions({\n\tinheritAttrs: false,\n});\n\nconst props = withDefaults(defineProps<ListItemProps>(), {\n\ttype: 'button',\n\tcloseByClick: true,\n});\n</script>\n\n<template>\n\t<li\n\t\t:class=\"{\n\t\t\t'top-popup_liNoSelectable': props.type !== 'button'\n\t\t}\"\n\t>\n\t\t<component\n\t\t\t:is=\"$attrs.href ? 'a' : 'div'\"\n\t\t\t:class=\"{\n\t\t\t\t'top-popup_listItem': true,\n\t\t\t\t['top-popup_listItem-' + props.type]: !!props.type,\n\t\t\t\t'top-popup_liastItem-withActions': $slots.actions,\n\t\t\t\t'top-popup-noCloser': !closeByClick,\n\n\t\t\t\t'a': props.type === 'button', // оформления кнопки, deprecated\n\t\t\t}\"\n\t\t\t:=\"{...$attrs, ...attrs}\"\n\t\t>\n\t\t\t<template v-if=\"$slots.actions\">\n\t\t\t\t<div class=\"top-popup_listItemActionsLabel top-ellipsis1\">\n\t\t\t\t\t<slot></slot>\n\t\t\t\t</div>\n\n\t\t\t\t<div class=\"top-popup_listItemActions\">\n\t\t\t\t\t<slot name=\"actions\"></slot>\n\t\t\t\t</div>\n\t\t\t</template>\n\n\t\t\t<template v-else>\n\t\t\t\t<slot></slot>\n\t\t\t</template>\n\t\t</component>\n\n\t\t<slot name=\"buttons\"></slot>\n\t</li>\n</template>\n"],"names":["props","__props","id","elOpener","render","el","renderOpener","onUpdated","disabledOld","elInput","Worker","popup","_createElementVNode","_renderSlot","_ctx","emit","__emit","expose","__expose","elPopupRef","ref","elPopupInnerRef","data","vueConnector","toRef","watch","newValue","oldValue","newClasses","delClasses","oldClass","onUnmounted","$slots","_createBlock","Opener","_unref","$core","_Teleport","_openBlock","_createElementBlock","_hoisted_1","_hoisted_2","_toDisplayString","$i18n","_hoisted_3","_withDirectives","_hoisted_4","_cache","$event","$emit","_hoisted_5","_createVNode","TopHint","_normalizeClass","_resolveDynamicComponent","$attrs","_mergeProps","_Fragment"],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ref as s, getCurrentInstance as a, inject as n } from "vue";
|
|
2
|
-
import { a as i, g as c } from "./dialogs.vue_vue_type_script_setup_true_lang-
|
|
2
|
+
import { a as i, g as c } from "./dialogs.vue_vue_type_script_setup_true_lang-CJ97l1ST.es.js";
|
|
3
3
|
import { waitWhile as l } from "../utils/system.js";
|
|
4
4
|
class w {
|
|
5
5
|
/**
|
|
@@ -75,4 +75,4 @@ export {
|
|
|
75
75
|
d as b,
|
|
76
76
|
h as u
|
|
77
77
|
};
|
|
78
|
-
//# sourceMappingURL=utils-
|
|
78
|
+
//# sourceMappingURL=utils-BNzP9anP.es.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils-
|
|
1
|
+
{"version":3,"file":"utils-BNzP9anP.es.js","sources":["../../src/components/dialog/dialog/composables/asyncDialogHandle.ts","../../src/components/dialog/dialog/composables/utils.ts"],"sourcesContent":["import type { Ref } from 'vue';\nimport { ref } from 'vue';\nimport { useTopDialog } from './utils';\nimport { waitWhile } from '@/core/utils/system';\nimport type { AsyncTopDialogComponentLoader, TopDialogComponent } from './types';\nimport { TopDialogHandle } from './dialogHandle';\n\n/**\n * Объект для работы с асинхронным диалоговым окном\n *\n * Является прослойкой для доступа к TopDialogHandle\n */\nexport class AsyncTopDialogHandle<T extends TopDialogComponent> {\n\n\t/**\n\t * Функция, определяющая компонент TopDialogComponent\n\t */\n\treadonly resolve: AsyncTopDialogComponentLoader<T>;\n\n\t/**\n\t * Реактивная Сссылка на объект worker,\n\t *\n\t * Ссылка не будет указывать на объект, если диалоговое окно еще не загружено\n\t */\n\treadonly worker: Ref<TopDialogHandle<T> | null> = ref(null);\n\n\tconstructor(resolve: AsyncTopDialogComponentLoader<T>) {\n\t\tthis.resolve = resolve;\n\t}\n\n\t/**\n\t * Получить доступ к TopDialogHandle\n\t */\n\tasync get() {\n\t\tif (this.worker.value) return this.worker.value;\n\n\t\tconst result = await this.resolve();\n\t\tconst TopDialogComponent = result.default;\n\n\t\tthis.worker.value = useTopDialog(TopDialogComponent);\n\n\t\tconst worker = this.worker.value;\n\n\t\tawait waitWhile(() => !worker.isMounted);\n\n\t\treturn worker;\n\t}\n\n\t/**\n\t * Открыть диалоговое окно\n\t */\n\tasync open(...args: Parameters<TopDialogHandle<T>['open']>) {\n\t\tconst worker = await this.get();\n\n\t\tawait worker.open(...args);\n\t}\n\n\t/**\n\t * Открыть диалоговое окно как ссылку, для хеш-навигации\n\t *\n\t * Только общедоступные диалоговые окна, расположенные в @/dialogs\n\t */\n\tasync openAsLink(...args: Parameters<TopDialogHandle<T>['open']>) {\n\t\tconst worker = await this.get();\n\n\t\tvoid worker.openAsLink(...args);\n\t}\n\n\t/**\n\t * Закрыть диалоговое окно\n\t *\n\t * Не меняет состояние компонента диалогового окна\n\t */\n\tasync close(...args: Parameters<TopDialogHandle<T>['close']>) {\n\t\tconst worker = await this.get();\n\n\t\tworker.close(...args);\n\t}\n\n\t/**\n\t * Размонтировать виджет диалогового окна\n\t */\n\tasync destroy(...args: Parameters<TopDialogHandle<T>['close']>) {\n\t\tconst worker = await this.get();\n\n\t\tworker.destroy(...args);\n\t}\n\n\t/**\n\t * Установить props\n\t *\n\t * Полностью сбрасывается состояние props\n\t */\n\tasync setProps(...args: Parameters<TopDialogHandle<T>['setProps']>) {\n\t\tconst worker = await this.get();\n\n\t\tawait worker.setProps(...args);\n\t}\n}\n","import { getCurrentInstance, inject } from 'vue';\nimport { TopDialogHandle } from './dialogHandle';\nimport { AsyncTopDialogHandle } from './asyncDialogHandle';\nimport type { AsyncTopDialogComponentLoader, TopDialogComponent } from './types';\nimport { addDialogWorker, getDialogWorker } from '../dialogs/dialogs.vue';\n\n/**\n * Получить объект управленя текущим диалоговым окном\n */\nexport const useTopDialogSelf = () => {\n\t// вызов из пользовтаельского компонента диалога\n\tconst topDialogComponent = getCurrentInstance() as any;\n\tif (topDialogComponent?.type?.id) {\n\t\tconst dialogWorker = getDialogWorker(topDialogComponent.type.id);\n\t\tif (dialogWorker) return dialogWorker;\n\t}\n\n\treturn inject('dialogWorker') as TopDialogHandle<TopDialogComponent>;\n};\n\n/**\n * Получить объект управленя диалоговым окном\n *\n * При первом вызове компонент диалогового окна будет внедрен в компонент DialogWrapper\n */\nexport const useTopDialog = <T extends TopDialogComponent>(DialogComponent: T): TopDialogHandle<T> => {\n\treturn addDialogWorker(DialogComponent);\n};\n\n/**\n * Получить объект управленя асинхронным диалоговым окном\n *\n * Компонент диалогового окна будет загружен и инициирован при первом взаимодействии с объектом\n *\n * Использует useTopDialog()\n */\nexport const useAsyncTopDialog = <T extends TopDialogComponent>(resolve: AsyncTopDialogComponentLoader<T>): AsyncTopDialogHandle<T> => {\n\treturn new AsyncTopDialogHandle(resolve);\n};\n"],"names":["AsyncTopDialogHandle","ref","resolve","TopDialogComponent","useTopDialog","worker","waitWhile","args","useTopDialogSelf","topDialogComponent","getCurrentInstance","dialogWorker","getDialogWorker","inject","DialogComponent","addDialogWorker","useAsyncTopDialog"],"mappings":";;;AAYO,MAAMA,EAAmD;AAAA;AAAA;AAAA;AAAA,EAKtD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,SAAyCC,EAAI,IAAI;AAAA,EAE1D,YAAYC,GAA2C;AACtD,SAAK,UAAUA;AAAA,EAChB;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,MAAM;AACX,QAAI,KAAK,OAAO,MAAO,QAAO,KAAK,OAAO;AAG1C,UAAMC,KADS,MAAM,KAAK,QAAA,GACQ;AAElC,SAAK,OAAO,QAAQC,EAAaD,CAAkB;AAEnD,UAAME,IAAS,KAAK,OAAO;AAE3B,iBAAMC,EAAU,MAAM,CAACD,EAAO,SAAS,GAEhCA;AAAA,EACR;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,QAAQE,GAA8C;AAG3D,WAFe,MAAM,KAAK,IAAA,GAEb,KAAK,GAAGA,CAAI;AAAA,EAC1B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAM,cAAcA,GAA8C;AAGjE,KAFe,MAAM,KAAK,IAAA,GAEd,WAAW,GAAGA,CAAI;AAAA,EAC/B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAM,SAASA,GAA+C;AAG7D,KAFe,MAAM,KAAK,IAAA,GAEnB,MAAM,GAAGA,CAAI;AAAA,EACrB;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,WAAWA,GAA+C;AAG/D,KAFe,MAAM,KAAK,IAAA,GAEnB,QAAQ,GAAGA,CAAI;AAAA,EACvB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAM,YAAYA,GAAkD;AAGnE,WAFe,MAAM,KAAK,IAAA,GAEb,SAAS,GAAGA,CAAI;AAAA,EAC9B;AACD;ACzFO,MAAMC,IAAmB,MAAM;AAErC,QAAMC,IAAqBC,EAAA;AAC3B,MAAID,GAAoB,MAAM,IAAI;AACjC,UAAME,IAAeC,EAAgBH,EAAmB,KAAK,EAAE;AAC/D,QAAIE,EAAc,QAAOA;AAAA,EAC1B;AAEA,SAAOE,EAAO,cAAc;AAC7B,GAOaT,IAAe,CAA+BU,MACnDC,EAAgBD,CAAe,GAU1BE,IAAoB,CAA+Bd,MACxD,IAAIF,EAAqBE,CAAO;"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
define(["require","exports","vue","./dialogs.vue_vue_type_script_setup_true_lang-
|
|
2
|
-
//# sourceMappingURL=utils-
|
|
1
|
+
define(["require","exports","vue","./dialogs.vue_vue_type_script_setup_true_lang-BBix_8WK.amd","../utils/system.amd"],(function(k,s,t,i,l){"use strict";if(typeof t>"u")var t=window.Vue;class u{resolve;worker=t.ref(null);constructor(e){this.resolve=e}async get(){if(this.worker.value)return this.worker.value;const r=(await this.resolve()).default;this.worker.value=n(r);const a=this.worker.value;return await l.waitWhile(()=>!a.isMounted),a}async open(...e){await(await this.get()).open(...e)}async openAsLink(...e){(await this.get()).openAsLink(...e)}async close(...e){(await this.get()).close(...e)}async destroy(...e){(await this.get()).destroy(...e)}async setProps(...e){await(await this.get()).setProps(...e)}}const c=()=>{const o=t.getCurrentInstance();if(o?.type?.id){const e=i.getDialogWorker(o.type.id);if(e)return e}return t.inject("dialogWorker")},n=o=>i.addDialogWorker(o),w=o=>new u(o);s.useAsyncTopDialog=w,s.useTopDialog=n,s.useTopDialogSelf=c}));
|
|
2
|
+
//# sourceMappingURL=utils-CWn_G7OO.amd.js.map
|