@topvisor/ui 0.0.41 → 0.0.43
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/datepicker-92744062.es.js +275 -0
- package/.chunks/datepicker-92744062.es.js.map +1 -0
- package/.chunks/datepicker-a9226b0f.amd.js +234 -0
- package/.chunks/datepicker-a9226b0f.amd.js.map +1 -0
- package/.chunks/{forms-7f061546.es.js → forms-727cc6aa.es.js} +51 -47
- package/.chunks/forms-727cc6aa.es.js.map +1 -0
- package/.chunks/forms-771091d4.amd.js +3 -0
- package/.chunks/forms-771091d4.amd.js.map +1 -0
- package/.chunks/{popup-05538243.es.js → popup-a622fe31.es.js} +429 -427
- package/.chunks/popup-a622fe31.es.js.map +1 -0
- package/.chunks/popup-de28e508.amd.js +377 -0
- package/.chunks/popup-de28e508.amd.js.map +1 -0
- package/README.md +80 -80
- package/assets/core.css +1 -1
- package/assets/forms.css +1 -1
- package/build/cssModules.d.ts +13 -0
- package/build/plugin/amdFix.d.ts +8 -0
- package/build/plugin/autoloadCSS.d.ts +19 -0
- package/build/rollup.config.d.ts +15 -0
- package/common/common.d.ts +1 -0
- package/core/core.amd.js +1 -1
- package/core/core.d.ts +3 -0
- package/core/core.js +1 -1
- package/forms/forms.amd.js +1 -1
- package/forms/forms.d.ts +1 -0
- package/forms/forms.js +1 -1
- package/forms/helpers.amd.js.map +1 -1
- package/forms/helpers.d.ts +1 -0
- package/forms/helpers.js.map +1 -1
- package/formsExt/formsExt.amd.js +1 -1
- package/formsExt/formsExt.amd.js.map +1 -1
- package/formsExt/formsExt.d.ts +1 -0
- package/formsExt/formsExt.js +1 -1
- package/formsExt/formsExt.js.map +1 -1
- package/icomoon/demo-files/demo.css +161 -161
- package/icomoon/demo-files/demo.js +30 -30
- package/icomoon/demo.html +2945 -2945
- package/icomoon/fonts/Topvisor-2.svg +232 -232
- package/icomoon/style.css +647 -647
- package/package.json +19 -19
- package/popup/popup.amd.js +1 -1
- package/popup/popup.amd.js.map +1 -1
- package/popup/popup.d.ts +1 -0
- package/popup/popup.js +17 -17
- package/popup/popup.js.map +1 -1
- package/popup/worker.amd.js +1 -1
- package/popup/worker.amd.js.map +1 -1
- package/popup/worker.d.ts +1 -0
- package/popup/worker.js +3 -2
- package/popup/worker.js.map +1 -1
- package/src/components/common/common.d.ts +0 -0
- package/src/components/common/icon/icon.d.ts +4 -0
- package/src/components/component.d.ts +25 -0
- package/src/components/forms/avatar/avatar.d.ts +29 -0
- package/src/components/forms/avatar/avatar.stories.d.ts +59 -0
- package/src/components/forms/avatar/avatar.vue.d.ts +26 -0
- package/src/components/forms/button/button.d.ts +40 -0
- package/src/components/forms/button/button.stories.d.ts +313 -0
- package/src/components/forms/button/button.vue.d.ts +39 -0
- package/src/components/forms/checkbox/checkbox.d.ts +22 -0
- package/src/components/forms/checkbox/checkbox.stories.d.ts +176 -0
- package/src/components/forms/checkbox/checkbox.vue.d.ts +23 -0
- package/src/components/forms/controlLabel/controlLabel.d.ts +4 -0
- package/src/components/forms/controlLabel/controlLabel.stories.d.ts +97 -0
- package/src/components/forms/controlLabel/controlLabel.vue.d.ts +19 -0
- package/src/components/forms/forms.d.ts +12 -0
- package/src/components/forms/helpers.d.ts +10 -0
- package/src/components/forms/hint/hint.d.ts +8 -0
- package/src/components/forms/hint/hint.stories.d.ts +138 -0
- package/src/components/forms/hint/hint.vue.d.ts +12 -0
- package/src/components/forms/input/input.d.ts +26 -0
- package/src/components/forms/input/input.stories.d.ts +255 -0
- package/src/components/forms/input/input.vue.d.ts +40 -0
- package/src/components/forms/inputDate/datepicker.d.ts +5 -0
- package/src/components/forms/inputDate/inputDate.d.ts +3 -0
- package/src/components/forms/inputDate/inputDate.stories.d.ts +108 -0
- package/src/components/forms/inputDate/inputDate.vue.d.ts +30 -0
- package/src/components/forms/inputRange/inputRange.d.ts +2 -0
- package/src/components/forms/inputRange/inputRange.stories.d.ts +405 -0
- package/src/components/forms/inputRange/inputRange.vue.d.ts +10 -0
- package/src/components/forms/radio/radio.d.ts +14 -0
- package/src/components/forms/radio/radio.stories.d.ts +168 -0
- package/src/components/forms/radio/radio.vue.d.ts +23 -0
- package/src/components/forms/select/select.d.ts +31 -0
- package/src/components/forms/select/select.stories.d.ts +83 -0
- package/src/components/forms/select/select.vue.d.ts +30 -0
- package/src/components/forms/select/stories/exampleOptions.d.ts +4 -0
- package/src/components/forms/switcher/switcher.d.ts +21 -0
- package/src/components/forms/switcher/switcher.stories.d.ts +163 -0
- package/src/components/forms/switcher/switcher.vue.d.ts +23 -0
- package/src/components/forms/textarea/textarea.d.ts +33 -0
- package/src/components/forms/textarea/textarea.stories.d.ts +88 -0
- package/src/components/forms/textarea/textarea.vue.d.ts +33 -0
- package/src/components/formsExt/editArea/editArea.d.ts +20 -0
- package/src/components/formsExt/editArea/editArea.stories.d.ts +140 -0
- package/src/components/formsExt/editArea/editArea.vue.d.ts +38 -0
- package/src/components/formsExt/editInput/editInput.d.ts +16 -0
- package/src/components/formsExt/editInput/editInput.stories.d.ts +129 -0
- package/src/components/formsExt/editInput/editInput.vue.d.ts +23 -0
- package/src/components/formsExt/formsExt.d.ts +3 -0
- package/src/components/formsExt/radioGroup/radioGroup.d.ts +22 -0
- package/src/components/formsExt/radioGroup/radioGroup.stories.d.ts +64 -0
- package/src/components/formsExt/radioGroup/radioGroup.vue.d.ts +30 -0
- package/src/components/helpersStories.d.ts +28 -0
- package/src/components/popup/popup/listItem.vue.d.ts +36 -0
- package/src/components/popup/popup/opener.vue.d.ts +39 -0
- package/src/components/popup/popup/popup.d.ts +79 -0
- package/src/components/popup/popup/popup.stories.d.ts +742 -0
- package/src/components/popup/popup/popup.vue.d.ts +52 -0
- package/src/components/popup/popup.d.ts +3 -0
- package/src/components/popup/worker.d.ts +2 -0
- package/src/components/tabs/tabs/content.vue.d.ts +19 -0
- package/src/components/tabs/tabs/tab.vue.d.ts +19 -0
- package/src/components/tabs/tabs/tabs.d.ts +19 -0
- package/src/components/tabs/tabs/tabs.stories.d.ts +774 -0
- package/src/components/tabs/tabs/tabs.vue.d.ts +21 -0
- package/src/components/tabs/tabs.d.ts +3 -0
- package/src/core/base/Colors.stories.d.ts +19 -0
- package/src/core/base/Layout.stories.d.ts +19 -0
- package/src/core/base/Properties.stories.d.ts +19 -0
- package/src/core/core/core.d.ts +58 -0
- package/src/core/core/events.d.ts +20 -0
- package/src/core/core/options.d.ts +13 -0
- package/src/core/core/page.d.ts +10 -0
- package/src/core/core/state.d.ts +34 -0
- package/src/core/directives/tooltip.d.ts +7 -0
- package/src/core/theme/Colors.stories.d.ts +19 -0
- package/src/core/theme/Properties.stories.d.ts +19 -0
- package/src/core/utils/date.d.ts +27 -0
- package/src/core/utils/device.d.ts +13 -0
- package/src/core/utils/dom.d.ts +98 -0
- package/src/core//320/235/320/260/320/261/320/276/321/200 /320/270/320/272/320/276/320/275/320/276/320/272//320/235/320/260/320/261/320/276/321/200 /320/270/320/272/320/276/320/275/320/276/320/272.stories.d.ts" +6 -0
- package/src/d.d.ts +4 -0
- package/src/resources/styles/core/core.d.ts +0 -0
- package/src/resources/styles/themes/dark.d.ts +0 -0
- package/src/resources/styles/themes/light.d.ts +0 -0
- package/src/storybook/components/icomoon.d.ts +2 -0
- package/tabs/tabs.amd.js +1 -1
- package/tabs/tabs.d.ts +1 -0
- package/tabs/tabs.js +1 -1
- package/utils/date.amd.js +1 -1
- package/utils/date.d.ts +3 -0
- package/utils/date.js +1 -1
- package/utils/device.amd.js +1 -1
- package/utils/device.d.ts +3 -0
- package/utils/device.js +1 -1
- package/utils/dom.amd.js +1 -1
- package/utils/dom.d.ts +3 -0
- package/utils/dom.js +1 -1
- package/.chunks/datepicker-7f54fd80.es.js +0 -275
- package/.chunks/datepicker-7f54fd80.es.js.map +0 -1
- package/.chunks/datepicker-858c1cb6.amd.js +0 -234
- package/.chunks/datepicker-858c1cb6.amd.js.map +0 -1
- package/.chunks/forms-7f061546.es.js.map +0 -1
- package/.chunks/forms-b9e5edd2.amd.js +0 -3
- package/.chunks/forms-b9e5edd2.amd.js.map +0 -1
- package/.chunks/popup-05538243.es.js.map +0 -1
- package/.chunks/popup-a531e9ad.amd.js +0 -377
- package/.chunks/popup-a531e9ad.amd.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"popup-de28e508.amd.js","sources":["../../src/components/component.ts","../../src/components/popup/lib/popup.globalEvents.js","../../src/components/popup/popup/style/popup.css?raw","../../src/components/popup/popup/style/popup.m.css?raw","../../src/components/popup/popup/style/popup.pc.css?raw","../../src/components/popup/lib/popup.js"],"sourcesContent":["import DOM from '@/core/utils/dom';\r\n\r\n/**\r\n * Базовый компонент для js компонентов, не имеет отношения к Vue\r\n */\r\nclass Component {\r\n\r\n\tstatic componentName = 'Top';\r\n\r\n\tcomponentName: string | undefined; // имя класса компонента\r\n\tclassName: string | undefined; // имя css класса компонента\r\n\tuid: string | undefined; // уникальный id компонента\r\n\tel: Element | undefined; // элемент, связанный с компонентом\r\n\toptions = {}; // параметры компонента\r\n\r\n\tunmountEls: Element[] = [];\r\n\tunmountEvents: any[] = [];\r\n\r\n\t// переопредлять нельзя\r\n\t// если компонент инициирован, необходимо сразу его вернуть и выполнить reInit() вместо mount()\r\n\t// используется init вместо constructor, так как super constructor выполняется до Object.defineProperty() параметров класса\r\n\tinit (componentName: string, el: Element, options: object): Component | void {\r\n\t\tif (!el) {\r\n\t\t\tthrow componentName + ': el is undefined';\r\n\t\t}\r\n\r\n\t\tconst component = Component.getComponent(el, componentName);\r\n\r\n\t\tif (component) {\r\n\t\t\tcomponent.reInit(options);\r\n\r\n\t\t\treturn component;\r\n\t\t}\r\n\r\n\t\tthis.componentName = componentName;\r\n\t\tthis.className = 'top' + componentName[0].toUpperCase() + componentName.substring(1);\r\n\t\tthis.uid = this.componentName + (Math.random() + '').replace('.', '');\r\n\r\n\t\tthis._setComponent(el);\r\n\t\tthis.el = el;\r\n\t\tthis.el.classList.add(this.className);\r\n\t\tthis.options = Object.assign(this.options, options);\r\n\r\n\t\tthis.mount();\r\n\t}\r\n\r\n\t// получить инициированный компонент\r\n\tstatic getComponent (el: Element, componentName: string): any {\r\n\t\treturn DOM.storage(el, '#' + componentName);\r\n\t}\r\n\r\n\t// устанвоить компонент\r\n\t_setComponent (el: Element) {\r\n\t\tDOM.storage(el, '#' + this.componentName, this);\r\n\t}\r\n\r\n\t// функция подключения компонента\r\n\tmount (): void {\r\n\t\tthrow 'Please, add method mount() to component: ' + this.componentName;\r\n\t}\r\n\r\n\t// функция отключения компонента\r\n\tunmount (): void {\r\n\t\tDOM.storage(this.el, '#' + this.componentName, null);\r\n\r\n\t\tthis.unmountEls.forEach((el) => {\r\n\t\t\tel.remove();\r\n\t\t});\r\n\r\n\t\tthis.unmountEls = [];\r\n\r\n\t\tthis.unmountEvents.forEach((eventData) => {\r\n\t\t\teventData.el.removeEventListener(eventData.type, eventData.listener, eventData.options);\r\n\t\t});\r\n\r\n\t\tthis.unmountEvents = [];\r\n\t}\r\n\r\n\t// указание новые элементы, которые должны будут удалиться после unmount\r\n\tregisterElForUnmount (el: Element): void {\r\n\t\tthis.unmountEls.push(el);\r\n\t}\r\n\r\n\t// указание новые события, которые должны будут удалиться после unmount\r\n\taddEventListenerWithUnmount (\r\n\t\tel: Element | Document,\r\n\t\ttype: keyof GlobalEventHandlersEventMap,\r\n\t\tlistener: (this: Element, e: Event) => any,\r\n\t\toptions?: any,\r\n\t): void {\r\n\t\tel.addEventListener(type, listener, options);\r\n\r\n\t\tthis.registerEventForUnmount(el, type, listener, options);\r\n\t}\r\n\r\n\t// указание новые события, которые должны будут удалиться после unmount\r\n\tregisterEventForUnmount (\r\n\t\tel: Element | Document,\r\n\t\ttype: keyof GlobalEventHandlersEventMap,\r\n\t\tlistener: (this: Element, e: Event) => any,\r\n\t\toptions?: any\r\n\t): void {\r\n\t\tconst eventData = {\r\n\t\t\tel: el,\r\n\t\t\ttype: type,\r\n\t\t\tlistener: listener,\r\n\t\t\toptions: options,\r\n\t\t};\r\n\r\n\t\tthis.unmountEvents.push(eventData);\r\n\t}\r\n\r\n\t// функция перенастройки уже подключенного компонента\r\n\treInit (_options: object): void {\r\n\t\tthrow 'Please, add method reInit() to component: ' + this.componentName;\r\n\t}\r\n\r\n\tstatic detach (nodes: Node[]): void\r\n\tstatic detach (nodes: Element): void\r\n\r\n\t// удалить элементы из DOM, но не из памяти\r\n\tstatic detach (nodes: any): void {\r\n\t\tif (nodes.forEach) {\r\n\t\t\tnodes.forEach((node: Node) => node.parentElement?.removeChild(node));\r\n\t\t} else {\r\n\t\t\tconst el = nodes;\r\n\t\t\tel.parentElement?.removeChild(el);\r\n\t\t}\r\n\t}\r\n\r\n}\r\n\r\nexport default Component;","import Worker from '@/components/popup/lib/worker';\r\nimport DOM from '@/core/utils/dom';\r\n\r\n/**\r\n * Глобальные события, для реализации Popup\r\n * Автоматически инициируется при первой загрузке, не является выгружаемым модулем\r\n *\r\n * Если в меню встречает класс .preloader, то событие нажатия на кнопку через enter будет остановлено\r\n */\r\nclass GlobalEvents {\r\n\tstatic init () {\r\n\t\tdocument.addEventListener('click', this.onclick);\r\n\t\tdocument.addEventListener('keydown', this.onkeydown);\r\n\t}\r\n\r\n\t/**\r\n\t * Глобальный обработчик кликов\r\n\t * обрабатывает клики внутри Popup\r\n\t * @param {Event} e\r\n\t */\r\n\tstatic onclick (e) {\r\n\t\t// элементы меню, клик по которым должен его закрыть\r\n\t\tconst elCloser = e.target.closest('.closer, a, .a, .top-button');\r\n\t\tif (elCloser) {\r\n\t\t\t// меню\r\n\t\t\tconst elPopup = e.target.closest('.top-popup-wrapper');\r\n\r\n\t\t\t// клик вне меню\r\n\t\t\tif (!elPopup) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\r\n\t\t\t// элемент имеет модификатор, запрещаюущий закрытие меню по клику на него\r\n\t\t\tif (elCloser.matches('.top-popup-noCloser')) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\r\n\t\t\t// deprecated, ссылки с href=\".\" запрещены, они должны быть заменены на .top-popup_listItem-button\r\n\t\t\tif (elCloser.getAttribute('href') === '.') {\r\n\t\t\t\te.preventDefault();\r\n\t\t\t}\r\n\r\n\t\t\t// клик по кнопке открытия другого меню\r\n\t\t\tif (e.target.matches('[data-top-popup]')) {\r\n\t\t\t\t// список меню, в котором был сделан клик\r\n\t\t\t\tconst elUl = e.target.closest('ul');\r\n\r\n\t\t\t\t// элемент меню, по которому был сделан клик\r\n\t\t\t\tconst elItem = e.target.closest('a, .a');\r\n\r\n\t\t\t\t// сделать элемент меню, по которому сделан клик активным\r\n\t\t\t\tif (elUl) {\r\n\t\t\t\t\telUl.querySelector('a.top-active, .a.top-active')?.classList.remove('top-active');\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (elItem) {\r\n\t\t\t\t\telItem.classList.add('top-active');\r\n\t\t\t\t}\r\n\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\r\n\t\t\t// закрыть меню\r\n\t\t\tWorker.close(elPopup);\r\n\t\t}\r\n\r\n\t\t// клик по фону меню\r\n\t\tif (e.target.matches('.top-popup-wrapper')) {\r\n\t\t\tconst elPopup = e.target;\r\n\r\n\t\t\tWorker.close(elPopup);\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t * Глобальный обработчик нажатия кнопки на клавиатуре\r\n\t * @param {Event} e\r\n\t */\r\n\tstatic onkeydown (e) {\r\n\t\tconst elPopup = e.target.closest('.top-popup-wrapper');\r\n\r\n\t\t// нажатие не в меню\r\n\t\tif (!elPopup) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst elUl = elPopup.querySelector('ul.top-popup_content');\r\n\r\n\t\tswitch (e.key) {\r\n\t\t\tcase 'Escape':\r\n\t\t\t\t// PopupWorker.close(elPopup);\r\n\r\n\t\t\t\tbreak;\r\n\r\n\t\t\tcase 'Enter':\r\n\t\t\t\t// атоматическое нажатие кнопок при нажатии Enter\r\n\t\t\t\tif (!elUl) {\r\n\t\t\t\t\tif (DOM.querySelectorVisible(elPopup, '.preloader')) {\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\tconst elBtn = elPopup.querySelector('.top-popup_footer .go, .top-popup_footer [data-action]');\r\n\t\t\t\t\tif (elBtn) {\r\n\t\t\t\t\t\telBtn.click();\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\tbreak;\r\n\t\t\t\t}\r\n\r\n\t\t\t\t// перейти по ссылке по нажатию на Enter\r\n\t\t\t\t// данный функуционал игнорирует SPA\r\n\t\t\t\tconst elLink = DOM.querySelectorVisible(elPopup, 'li > a.top-active');\r\n\t\t\t\tif (elLink) {\r\n\t\t\t\t\t// фокус может находиться на другой ссылке\r\n\t\t\t\t\te.preventDefault();\r\n\r\n\t\t\t\t\tlocation.href = elLink.getAttribute('href');\r\n\t\t\t\t}\r\n\r\n\t\t\t\t// кликнуть по элементу меню по нажатию на Enter\r\n\t\t\t\tconst elItem = elPopup.querySelector('li > .top-active');\r\n\t\t\t\tif (elItem) {\r\n\t\t\t\t\telItem.click();\r\n\t\t\t\t}\r\n\r\n\t\t\t\tbreak;\r\n\r\n\t\t\t// управление стрелками\r\n\t\t\tcase 'ArrowUp':\r\n\t\t\tcase 'ArrowRight':\r\n\t\t\tcase 'ArrowDown':\r\n\t\t\tcase 'ArrowLeft':\r\n\t\t\t\tif (!elUl) {\r\n\t\t\t\t\tbreak;\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (e.key === 'ArrowRight' || e.key === 'ArrowLeft') {\r\n\t\t\t\t\tconst elMoreVisible = DOM.querySelectorVisible(elPopup, 'ul.top-popup_content > li:not(.top-popup_liNoSelectable) > .top-active > .top-popup_listMore');\r\n\t\t\t\t\tif (elMoreVisible) {\r\n\t\t\t\t\t\te.preventDefault();\r\n\t\t\t\t\t}\r\n\t\t\t\t} else {\r\n\t\t\t\t\te.preventDefault();\r\n\t\t\t\t}\r\n\r\n\t\t\t\tconst elItemActive = elPopup.querySelector('ul.top-popup_content > li:not(.top-popup_liNoSelectable) > .top-active')?.parentElement;\r\n\r\n\t\t\t\t// есть подменю\r\n\t\t\t\tif (e.key === 'ArrowRight' && elItemActive) {\r\n\t\t\t\t\t// const elItemMoreActive = elItemActive.querySelector('[data-top-popup].top-active');\r\n\t\t\t\t\t// if (elItemMoreActive) {\r\n\t\t\t\t\t// \treturn elItemMoreActive.click();\r\n\t\t\t\t\t// }\r\n\r\n\t\t\t\t\tconst elMore = elItemActive.querySelector('.top-active > .top-popup_listMore');\r\n\t\t\t\t\tif (elMore) {\r\n\t\t\t\t\t\treturn elMore.click();\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\r\n\t\t\t\tconst elsLiVisible = DOM.querySelectorAllVisible(elPopup, 'ul.top-popup_content > li:not(.top-popup_liNoSelectable)');\r\n\t\t\t\tconst countLi = elsLiVisible.length;\r\n\r\n\t\t\t\tif (!countLi) {\r\n\t\t\t\t\treturn;\r\n\t\t\t\t}\r\n\r\n\t\t\t\tlet index = elsLiVisible.indexOf(elItemActive);\r\n\r\n\t\t\t\tif (e.key === 'ArrowUp' || e.key === 'ArrowLeft') {\r\n\t\t\t\t\tindex--;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tindex++;\r\n\t\t\t\t}\r\n\r\n\t\t\t\t// это первый элемен, \"Назад\" должен закрывать окно\r\n\t\t\t\tif (e.key === 'ArrowLeft' && index === -1) {\r\n\t\t\t\t\tif (e.target.matches('input')) {\r\n\t\t\t\t\t\treturn;\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\treturn Worker.close(elPopup);\r\n\t\t\t\t}\r\n\r\n\t\t\t\t// это последний элемен, \"Вперед\" не должен ни чего делать\r\n\t\t\t\tif (e.key === 'ArrowRight' && index === countLi) {\r\n\t\t\t\t\treturn;\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (index < 0) {\r\n\t\t\t\t\tindex = countLi - 1;\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (index > countLi - 1) {\r\n\t\t\t\t\tindex = 0;\r\n\t\t\t\t}\r\n\r\n\t\t\t\telPopup.querySelectorAll('ul.top-popup_content > li > .top-active').forEach(el => el.classList.remove('top-active'));\r\n\t\t\t\telsLiVisible[index].querySelector(':scope > a, :scope > .a').classList.add('top-active');\r\n\r\n\t\t\t\tWorker.scrollToActive(elPopup);\r\n\r\n\t\t\t\tbreak;\r\n\t\t}\r\n\t}\r\n\r\n}\r\n\r\nexport default GlobalEvents;","export default \":root{\\r\\n\\t--top-popup-background-color: var(--color-bg-3);\\r\\n\\t--top-popup-background-color-hover: var(--color-theme-75);\\r\\n\\t--top-popup-background-color-active: var(--color-theme-100);\\r\\n\\r\\n\\t--top-popup-border-color: var(--color-line-2-opacity);\\r\\n\\t--top-popup-title-background-color: var(--color-theme-50);\\r\\n\\r\\n\\t/* суммарный отсуп от каря popup до элемента */\\r\\n\\t--top-popup-content-padding: calc(var(--top-popup-list-padding) + var(--top-popup-listItem-padding));\\r\\n\\r\\n\\t/* списки */\\r\\n\\t--top-popup-list-padding: var(--top-padding-2);\\r\\n\\r\\n\\t--top-popup-listItem-radius: var(--top-radius-2);\\r\\n\\t--top-popup-listItem-padding: var(--top-padding-2);\\r\\n}\\r\\n\\r\\n.top-popup-front{ position: relative; }\\r\\n\\r\\n.top-popup-wrapper{\\r\\n\\t/* см. recalcPosition() */\\r\\n\\t--top-popup-height: 0px;\\r\\n\\t--top-popup-right-bounding: 0px;\\r\\n\\t--top-popup-bottom-bounding: 0px;\\r\\n\\t--top-popup-top: 0px;\\r\\n\\t--top-popup-right: calc(100vw - var(--top-popup-right-bounding));\\r\\n\\t--top-popup-bottom: calc(var(--100vh) - var(--top-popup-bottom-bounding));\\r\\n\\t--top-popup-left: 0px;\\r\\n\\r\\n\\ttext-align: initial; white-space: normal; word-break: normal;\\r\\n\\tposition: absolute; z-index: 200000;\\r\\n}\\r\\n.top-popup-wrapper:not(.top-popup-wrapper-shown){ overflow: hidden; }\\r\\n\\r\\n/* top-popupPanel */\\r\\n.top-popupPanel {\\r\\n\\tcursor: default;\\r\\n\\tbox-shadow: var(--top-shadow-b);\\r\\n\\tborder-radius: 8px;\\r\\n\\tbackground: var(--top-popup-background-color);\\r\\n\\tposition: absolute; overflow: hidden;\\r\\n\\tdisplay: flex; flex-direction: column;\\r\\n}\\r\\n\\r\\n/* position */\\r\\n.top-popup-wrapper > *{ opacity: 0; transition: opacity 100ms linear, transform 100ms linear; }\\r\\n.top-popup-wrapper.p0 > *{ transform: translateY(-8px); }\\r\\n.top-popup-wrapper.p1 > *{ transform: translateY(8px); }\\r\\n.top-popup-wrapper.p2 > *{ transform: translateX(8px); }\\r\\n.top-popup-wrapper.p3 > *{ transform: translateY(8px); }\\r\\n.top-popup-wrapper.p4 > *{ transform: translateX(-8px); }\\r\\n.top-popup-wrapper-shown:not(.top-popup-wrapper-closed) > *{opacity: 1;transform: translate(0, 0) !important;}\\r\\n\\r\\n.top-popup-wrapper.p0 > .top-popup{ top: calc(-16px); left: calc(0px - 8px); }\\r\\n.top-popup-wrapper.p1 > .top-popup{ bottom: calc(100% + 8px); }\\r\\n.top-popup-wrapper.p2 > .top-popup{ left: calc(100% + 8px); }\\r\\n.top-popup-wrapper.p3 > .top-popup{ top: calc(100% + 8px); }\\r\\n.top-popup-wrapper.p4 > .top-popup{ right: calc(100% + 8px); }\\r\\n.top-popup-wrapper.p2 > .top-popup,\\r\\n.top-popup-wrapper.p4 > .top-popup{ margin-top: -10px; }\\r\\n\\r\\n.top-popup-wrapper.p1.with_notch > .top-popup{ margin-bottom: 5px; }\\r\\n.top-popup-wrapper.p2.with_notch > .top-popup{ margin-left: 5px; }\\r\\n.top-popup-wrapper.p3.with_notch > .top-popup{ margin-top: 5px; }\\r\\n.top-popup-wrapper.p4.with_notch > .top-popup{ margin-right: 5px; }\\r\\n\\r\\n.top-popup-wrapper.invert-x > .top-popup{ right: 0; }\\r\\n.top-popup-wrapper.invert-y > .top-popup{ bottom: 0; }\\r\\n\\r\\n/* notch */\\r\\n.top-popup-wrapper > .notch{ border: 7.4px solid transparent; position: absolute; display: block; }\\r\\n\\r\\n.top-popup-wrapper.p1 > .notch{ border-bottom: 0; border-top: 7.4px solid var(--content-background-color); margin: 0 0 7.4px -7.4px; bottom: 100%; left: 50% }\\r\\n.top-popup-wrapper.p2 > .notch{ border-left: 0; border-right: 7.4px solid var(--content-background-color); margin: 0 0 -7.4px 7.4px; bottom: 50%; left: 100%; }\\r\\n.top-popup-wrapper.p3 > .notch{ border-top: 0; border-bottom: 7.4px solid var(--content-background-color); margin: 7.4px 0 0 -7.4px; top: 100%; left: 50%; }\\r\\n.top-popup-wrapper.p4 > .notch{ border-right: 0; border-left: 7.4px solid var(--content-background-color); margin: 0 7.4px -7.4px 0; bottom: 50%; right: 100%; }\\r\\n\\r\\n.top-popup-wrapper.p1 > .notch-border{ border-top-color: rgba(0,0,0,0.05); margin-bottom: 6px; }\\r\\n.top-popup-wrapper.p2 > .notch-border{ border-right-color: rgba(0,0,0,0.05); margin-left: 6px; }\\r\\n.top-popup-wrapper.p3 > .notch-border{ border-bottom-color: rgba(0,0,0,0.05); margin-top: 6px; }\\r\\n.top-popup-wrapper.p4 > .notch-border{ border-left-color: rgba(0,0,0,0.05); margin-right: 6px; }\\r\\n\\r\\n/* common */\\r\\n.top-popup_header,\\r\\n.top-popup_content,\\r\\n.top-popup_footer{ font-size: 14px; }\\r\\n.top-popup_header,\\r\\n.top-popup_footer{ display: flex; align-items: center; justify-content: space-between; }\\r\\n\\r\\n/* header */\\r\\n.top-popup_header{\\r\\n\\tborder-bottom: 1px solid var(--top-popup-border-color);\\r\\n\\tpadding: var(--top-padding-3);\\r\\n\\tfont-weight: 600;\\r\\n}\\r\\n.top-popup_header > *{ font-weight: 400; }\\r\\n.top-popup_header > .a{ cursor: pointer; color: var(--color-blue-450); }\\r\\n.top-popup_header > .a:hover{ color: var(--color-blue-350); }\\r\\n\\r\\n.top-popup_headerButton{ width: 60px; }\\r\\n\\r\\n/* content */\\r\\n.top-popup_content{\\r\\n\\tmargin: 0;\\r\\n\\tflex-grow: 1;\\r\\n\\toverflow-y: auto;\\r\\n\\tdisplay: flex;\\r\\n\\tflex-direction: column;\\r\\n\\tgap: var(--top-gap-4);\\r\\n\\r\\n\\t-webkit-overflow-scrolling: touch;\\r\\n}\\r\\n\\r\\ndiv.top-popup_content{\\r\\n\\t/* has_scroll */\\r\\n\\t--scroll-padding-top: var(--top-popup-content-padding);\\r\\n\\t--scroll-padding-bottom: var(--top-popup-content-padding);\\r\\n\\r\\n\\tpadding: var(--top-popup-content-padding);\\r\\n}\\r\\ndiv.top-popup_content > *{ flex-shrink: 0; }\\r\\ndiv.top-popup_content > .top-button{ margin: 0; }\\r\\n\\r\\ndiv.top-popup_content .top-unwrap{\\r\\n\\t--top-unwrap-x: var(--top-popup-content-padding);\\r\\n}\\r\\n\\r\\nul.top-popup_content{\\r\\n\\t--scroll-padding-top: var(--top-popup-list-padding);\\r\\n\\t--scroll-padding-bottom: var(--top-popup-list-padding);\\r\\n\\r\\n\\tpadding: var(--top-popup-list-padding);\\r\\n\\tgap: 2px;\\r\\n}\\r\\n\\r\\nul.top-popup_content .top-unwrap{\\r\\n\\t--top-unwrap-x: var(--top-popup-list-padding);\\r\\n}\\r\\n\\r\\n.top-popup_listItem {\\r\\n\\tborder-radius: var(--top-popup-listItem-radius);\\r\\n\\tpadding: var(--top-popup-listItem-padding);\\r\\n\\tline-height: 1 !important;\\r\\n}\\r\\n\\r\\nul.top-popup_content li{ margin: 0; list-style:none; display: flex; position: relative }\\r\\nul.top-popup_content li > *{ flex-grow: 1; }\\r\\nul.top-popup_content li > a:not(.top-button),\\r\\nul.top-popup_content li > .a{\\r\\n\\tcursor: pointer;\\r\\n\\tbox-sizing: border-box;\\r\\n\\tborder-radius: var(--top-popup-listItem-radius);\\r\\n\\tbackground: var(--top-popup-background-color);\\r\\n\\tpadding: var(--top-popup-listItem-padding);\\r\\n\\tcolor: var(--color-text) !important; font-size: 14px; font-weight: normal !important; text-decoration: none !important; font-style: normal;\\r\\n\\tline-height: 1 !important;\\r\\n\\tdisplay: flex; flex: 1 1 100%; align-items: center;\\r\\n\\ttransition: background-color 0.1s ease-in-out;\\r\\n}\\r\\n.top-popup-wrapper-no_animate ul.top-popup_content li > a:not(.top-button),\\r\\n.top-popup-wrapper-no_animate ul.top-popup_content li > .a{ transition: none; }\\r\\n\\r\\nul.top-popup_content li > a:not(.top-button):hover,\\r\\nul.top-popup_content li > .a:hover{ background: var(--top-popup-background-color-hover); }\\r\\nul.top-popup_content li > a:not(.top-button).top-active,\\r\\nul.top-popup_content li > .a.top-active{ background: var(--top-popup-background-color-active); }\\r\\n\\r\\n.top-popup_content + .top-popup_content{ padding-top: 0; }\\r\\n\\r\\n/* listTitle */\\r\\n.top-popup_listItem-title{\\r\\n\\tbackground: var(--top-popup-title-background-color);\\r\\n\\tcolor: var(--color-text-2); font-size: 12px;\\r\\n}\\r\\n\\r\\n/* listDelimiter */\\r\\n.top-popup_listItem-delimiter{\\r\\n\\tborder-radius: 3px;\\r\\n\\tbackground: var(--top-popup-border-color);\\r\\n\\theight: 1px;\\r\\n\\tpadding: 0;\\r\\n\\tmargin: 4px;\\r\\n}\\r\\n\\r\\n/* listMore */\\r\\n.top-popup_listMore{\\r\\n\\tfont-size: 20px;\\r\\n}\\r\\n\\r\\nul.top-popup_content li > .a.top-popup_listMore{\\r\\n\\ttext-align: center;\\r\\n\\tflex-basis: 10px;\\r\\n}\\r\\nul.top-popup_content li > .a.top-popup_listMore:before{ color: var(--color-gray-500); }\\r\\nul.top-popup_content li > * > .top-popup_listMore{\\r\\n\\tpadding: 0 var(--top-popup-listItem-padding); margin-left: auto;\\r\\n\\tcolor: var(--color-gray-500);\\r\\n\\tfont-size: 14px;\\r\\n}\\r\\nul.top-popup_content li > * > i.top-popup_listMore:hover,\\r\\nul.top-popup_content li > * > i.top-popup_listMore.top-active{ color: var(--color-blue-500); }\\r\\nul.top-popup_content li > * > i.top-popup_listMore:before{\\r\\n\\ttransform: rotate(90deg);\\r\\n\\tdisplay: block;\\r\\n}\\r\\n\\r\\nul.top-popup_content li a.close{ background: none !important; }\\r\\n\\r\\n/* data-top-icon */\\r\\n.top-popup_content > [data-top-icon]:before{\\r\\n\\t--top-icon-size: 20px;\\r\\n}\\r\\n\\r\\nul.top-popup_content li > [data-top-icon]:not(.top-button):before{\\r\\n\\t--top-icon-color: var(--color-text-3);\\r\\n\\t--top-icon-size: 20px;\\r\\n\\t--top-icon-width: 20px;\\r\\n\\r\\n\\theight: 1rem; margin-right: 8px; transition: color 0.1s;\\r\\n}\\r\\nul.top-popup_content li:hover > [data-top-icon]:not(.top-button):before,\\r\\nul.top-popup_content li > [data-top-icon]:not(.top-button).top-active:before{\\r\\n\\t--top-icon-color: var(--color-text-2);\\r\\n}\\r\\n\\r\\n/* footer */\\r\\n.top-popup_footer{\\r\\n\\tpadding: var(--top-popup-list-padding);\\r\\n\\tborder-top: 1px solid var(--top-popup-border-color);\\r\\n\\tdisplay: flex;\\r\\n\\tgap:var(--top-gap-2);\\r\\n\\tjustify-content: flex-end;\\r\\n}\\r\\n\\r\\n/* Виджеты */\\r\\n.top-popup > [data-widget]{ padding: 0 var(--top-popup-list-padding); }\\r\\n.top-popup > [data-widget] + hr{ margin: 0 var(--top-popup-list-padding); }\\r\\n\\r\\n.top-popup .placeholder{\\r\\n\\tborder:1px solid #E0D9D9 !important; border-right: none !important; border-left: none !important; background:#F9F9F9 !important; margin: -1px 0; z-index: 1;\\r\\n\\tposition: relative;\\r\\n}\\r\\n\\r\\n/* компоненты */\\r\\n.top-popup-wrapper.simple_list > .top-popup{ min-width: 0; white-space: nowrap; }\\r\\n\\r\\n.top-popup_content .top-column{ display: flex; flex-direction: column; gap: 4px; }\\r\\nhtml .top-popup .top-popup_content li > .top-button{\\r\\n\\tmargin:calc(var(--top-popup-listItem-padding) / 2) var(--top-popup-listItem-padding);\\r\\n}\\r\\n\\r\\n.top-popup li .check_all,\\r\\n.top-popup li .clear_all{ cursor: pointer; color: var(--color-cyan); padding: 8px; display: inline-block; }\\r\\n.top-popup li .check_all:hover,\\r\\n.top-popup li .clear_all:hover{ text-decoration: underline; }\\r\\n.top-popup li .clear_all{ display: none; }\\r\\n\\r\\n/* table */\\r\\n.top-popup_content table{ margin: -9px 0; }\\r\\n.top-popup_content table td,\\r\\n.top-popup_content table th{ padding: 9px var(--top-popup-listItem-padding) 9px 0; vertical-align: top; }\\r\\n.top-popup_content table th{ width: 40%; font-weight: 600; white-space: nowrap; }\\r\\n\\r\\n/* формы */\\r\\nul.top-popup_content .a > [type=\\\"checkbox\\\"],\\r\\nul.top-popup_content .a > [type=\\\"radio\\\"]{ margin: -8px 0 -8px auto; }\\r\\n\\r\\n/* deprecated */\\r\\nul.top-popup_content a > [class*=icon],\\r\\nul.top-popup_content i.a > [class*=icon]{\\r\\n\\ttransition: 0.1s;\\r\\n}\\r\\n\\r\\n.top-popup .buttons{ border-radius:0 0 4px 4px; border-top:1px solid #BDC3C7; background:#ECF0F1; padding:10px 15px; margin:10px -15px -10px -15px; white-space: nowrap; }\\r\\n.top-popup_footer [class*=btn]:not(.btn-transparent){ min-width: 100px; padding: 5px 14px; margin-left: 10px; }\\r\\n.top-popup_footer [class*=btn]:first-child{ margin-left: 0; }\\r\\n.top-popup_footer .btn.full_width{ margin: 0; flex-grow: 1; }\"","export default \":root{\\r\\n\\t--top-popup-list-padding: 0px;\\r\\n\\r\\n\\t--top-popup-listItem-radius: 0px;\\r\\n\\t--top-popup-listItem-padding: var(--top-padding-4);\\r\\n}\\r\\n\\r\\nhtml.with_popup{ background: #808080; }\\r\\n\\r\\n.top-popup-wrapper{\\r\\n\\t--top-popup-footer-offset: 25px;\\r\\n\\r\\n\\twidth: auto !important; height: auto !important;\\r\\n\\tposition: fixed; top: 0 !important; right: 0 !important; left: 0 !important; overflow: hidden;\\r\\n\\ttransition: background 0.3s;\\r\\n}\\r\\n\\r\\n.top-popup-wrapper-shown:not(.top-popup-wrapper-closed){ background: rgba(0,0,0,0.5); backdrop-filter: blur(1px); }\\r\\n.top-popup-wrapper-shown:not(.top-popup-wrapper-closed) > .top-popup{ opacity: 1 !important; }\\r\\n\\r\\n.top-popup{\\r\\n\\tborder-radius: 8px 8px 0 0; width: auto !important; max-height: calc(100% - var(--header-height) - 12px); margin: 0 !important;\\r\\n\\ttop: auto !important; right: 0 !important; bottom: 0 !important; left: 0 !important;\\r\\n\\tdisplay: flex; flex-direction: column;\\r\\n\\r\\n\\t/* невозможно опустить элемент вниз за экран на 100%, fix: opacity и translateY(80%) */\\r\\n\\ttransform: translateY(80%);\\r\\n\\r\\n\\ttransition: opacity 0.3s, transform 0.3s;\\r\\n}\\r\\n\\r\\n/* from top */\\r\\n.top-popup-wrapper.p-from-top{\\r\\n\\t--top-popup-footer-offset: 0px;\\r\\n\\r\\n\\ttop: var(--header-height) !important;\\r\\n}\\r\\n.with_dialog .top-popup-wrapper.p-from-top{ top: 50px !important; }\\r\\n.top-popup-wrapper.p-from-top > .top-popup{\\r\\n\\tborder-radius: 0 0 8px 8px; max-height: calc(100% - 24px); top: 0 !important; bottom: auto !important;\\r\\n\\ttransform: translateY(calc(-100% - 24px));\\r\\n}\\r\\n\\r\\n/* content */\\r\\nul.top-popup_content{\\r\\n\\t--scroll-padding-top: 0px;\\r\\n\\t--scroll-padding-bottom: var(--scroll-padding-top);\\r\\n\\r\\n\\tgap: 0;\\r\\n}\\r\\nul.top-popup_content li:not(:last-child){ border-bottom: 1px solid var(--top-popup-border-color); }\\r\\n\\r\\n.top-popup-wrapper.top-style_alt > .top-popup > ul > li{ border-bottom: none; }\\r\\n\\r\\n/* footer */\\r\\n.top-popup_footer{\\r\\n\\tflex-direction: column-reverse;\\r\\n}\\r\\n.top-popup_footer > .top-button{\\r\\n\\t--top-forms-base-height: var(--top-forms-base-height_xl);\\r\\n\\r\\n\\twidth: 100%;\\r\\n}\\r\\n\\r\\n/* listTitle */\\r\\nul.top-popup_content .top-popup_listItem-title{\\r\\n\\t--top-popup-padding-v: 12px;\\r\\n}\\r\\n\\r\\n/* listDelimiter */\\r\\nul.top-popup_content .top-popup_listItem-delimiter{ background: var(--color-line-1-opacity); height: 4px; margin: 0; }\\r\\nul.top-popup_content li:first-child > .top-popup_listItem-delimiter{ border-top: 1px solid var(--top-popup-border-color); }\"","export default \"html:not(.with_dialog){ margin-right: 0 !important; }\\r\\n\\r\\n.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)); }\\r\\n.top-popup-wrapper.invert-x > .top-popup{ max-width: calc(100vw - var(--top-popup-right) - 16px); }\\r\\n.top-popup-wrapper.invert-y > .top-popup{ max-height: calc(100vh - var(--top-popup-bottom) - 16px); }\\r\\n\\r\\n/* position */\\r\\n.top-popup-wrapper.p1 > .top-popup{ max-height: calc(var(--top-popup-top) - var(--header-height) - 16px); }\\r\\n.top-popup-wrapper.p3 > .top-popup{ max-height: calc(var(--top-popup-bottom) - 16px); }\\r\\n.top-popup-wrapper.p2 > .top-popup{ max-width: calc(var(--top-popup-right) - 16px); }\\r\\n.top-popup-wrapper.p4 > .top-popup{ max-width: calc(var(--top-popup-left) - 16px); }\\r\\n\\r\\n/* notch */\\r\\n.top-popup-wrapper.p1.with_notch > .top-popup,\\r\\n.top-popup-wrapper.p3.with_notch > .top-popup{ margin-left: -16px !important; }\\r\\n.top-popup-wrapper.p1.with_notch > .notch,\\r\\n.top-popup-wrapper.p3.with_notch > .notch{ margin-left: -8px !important; }\\r\\n\\r\\n.top-popup-wrapper.p1.with_notch.invert-x,\\r\\n.top-popup-wrapper.p3.with_notch.invert-x{ margin-left: 3px !important; }\\r\\n.top-popup-wrapper.p1.with_notch.invert-x > .notch,\\r\\n.top-popup-wrapper.p3.with_notch.invert-x > .notch{ margin-left: -9px !important; }\\r\\n\\r\\n/* listMore */\\r\\nul.top-popup_content li > * > i.top-popup_listMore{ visibility: hidden; transition: none; }\\r\\nul.top-popup_content li:hover > * > i.top-popup_listMore,\\r\\nul.top-popup_content li > *.top-active > i.top-popup_listMore,\\r\\nul.top-popup_content li > * > i.top-popup_listMore.top-active{ visibility: visible; }\"","// добавляет jQuery события на this.el, если jQuery загружен:\r\n// aftershow.top-menu-popup\r\n// afterclose.top-menu-popup\r\n\r\nimport Core from '@/core/core/core';\r\nimport Component from '@/components/component';\r\nimport DOM from '@/core/utils/dom';\r\nimport Worker from '@/components/popup/lib/worker';\r\nimport GlobalEvents from '@/components/popup/lib/popup.globalEvents';\r\n\r\nimport css from '@/components/popup/popup/style/popup.css?raw';\r\nimport cssM from '@/components/popup/popup/style/popup.m.css?raw';\r\nimport cssPC from '@/components/popup/popup/style/popup.pc.css?raw';\r\n\r\nCore.appendStyle(css);\r\nCore.appendStyle(cssM, 'm');\r\nCore.appendStyle(cssPC, 'pc');\r\n\r\n/**\r\n * @property {Element} el - элемент, вызвавший открытие Popup\r\n * @property {Element} elPopup - Popup .top-popup-wrapper\r\n * @property {Element} elPopupInner - контентная часть Popup .top-popup\r\n * @property {Element} elPopupHeader\r\n * @property {Element} elPopupBody\r\n * @property {Element} elPopupFooter\r\n */\r\nclass Popup extends Component {\r\n\r\n\tstatic componentName = 'Popup';\r\n\r\n\tel; // элемент, вызвавший открытие Popup\r\n\telActiveByDefault; // элемент уже имеет класс top-active перед открытием окна\r\n\telPopup;\r\n\telPopupInner;\r\n\telPopupHeader;\r\n\telPopupBody;\r\n\telPopupFooter;\r\n\telFront;\r\n\r\n\tpopupParent;\r\n\r\n\t$; // только, если есть jQuery\r\n\r\n\telStartPosition; // используется для useOriginal\r\n\tshift = {\r\n\t\ttop: 0,\r\n\t\tleft: 0,\r\n\t};\r\n\tisClosed = false; // флаг того, что меню закрыто\r\n\tisFirstClick = true;\r\n\ttype; // selector или html\r\n\r\n\toptions = {\r\n\t\tpopup: '', // selector, text\r\n\t\tp: 0, // положение меню (0 - над элементом, 1 - сверху, 2 - справа, 3 - снизу, 4 слева)\r\n\t\tnotch: false, // отображать ли клювик\r\n\r\n\t\tclass: '', // класс, добавляемый меню\r\n\r\n\t\tposBy: 'left', // способ привязки позиционирования меню (left/right - левый/правый край родителя, fixed - по окну)\r\n\t\tfrontSelector: '',\r\n\t\tinvertX: false, // базовая ордината - правая граница элемента, а не левая\r\n\t\topenByHover: false, // открывать при наведении\r\n\r\n\t\tuseOriginal: false, // использовать оригинальный шаблон, без клонирвоания (для сохранения состояния меню)\r\n\r\n\t\tisFullScreen: false,\r\n\t\ti18n: {},\r\n\t};\r\n\r\n\tevents = {};\r\n\r\n\t// el - элемент, открывающий меню\r\n\tconstructor(el, options) {\r\n\t\tsuper();\r\n\r\n\t\treturn this.init(Popup.componentName, el, options);\r\n\t}\r\n\r\n\tasync mount() {\r\n\t\tconst vueConnector = this.vueGetComponent();\r\n\r\n\t\tthis.popupParent = Worker.getPopup(this.el.closest('.top-popup-wrapper'));\r\n\r\n\t\tawait this.mountJQuery();\r\n\r\n\t\tif (DOM.css(this.el, 'position') !== 'absolute') {\r\n\t\t\tthis.el.style.position = 'relative';\r\n\t\t}\r\n\r\n\t\tthis.el.dataset.topPopupOpened = 'opened';\r\n\t\tthis.elActiveByDefault = this.el.classList.contains('top-active');\r\n\t\tthis.el.classList.add('top-active');\r\n\r\n\t\tif (vueConnector) {\r\n\t\t\t// компонент vue Popup\r\n\t\t\tthis.type = 'vue';\r\n\r\n\t\t\tthis.options.popup = '';\r\n\t\t\tthis.elPopup = DOM.genEl('div', {}, this.options.popup);\r\n\t\t} else if (this.options.popup.match(/^[#.]/)) {\r\n\t\t\t// selector\r\n\t\t\tthis.type = 'selector';\r\n\r\n\t\t\tthis.elPopup = document.querySelector(`${this.options.popup}.template`);\r\n\t\t} else {\r\n\t\t\t// html\r\n\t\t\tthis.type = 'html';\r\n\r\n\t\t\tif (this.options.useOriginal) {\r\n\t\t\t\tthrow ('Option useOriginal not allowed for text templates');\r\n\t\t\t}\r\n\r\n\t\t\tthis.elPopup = DOM.genEl('div', {}, this.options.popup);\r\n\t\t}\r\n\r\n\t\tif (!this.elPopup || vueConnector?.opened) {\r\n\t\t\t// возможно шаблон не найден, так как он используется в уже открытом меню\r\n\t\t\tif (this.options.useOriginal || vueConnector?.opened) {\r\n\t\t\t\t// закрыть открытое меню\r\n\t\t\t\tif (vueConnector?.opened) {\r\n\t\t\t\t\tthis.elPopup = vueConnector.popup.elPopup;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tthis.elPopup = document.querySelector(`${this.options.popup}.top-popup-wrapper-shown`);\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (this.elPopup) {\r\n\t\t\t\t\tthis.el.dataset.topPopupOpened = '';\r\n\r\n\t\t\t\t\tif (!this.elActiveByDefault) {\r\n\t\t\t\t\t\tthis.el.classList.remove('top-active');\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\tWorker.close(this.elPopup);\r\n\r\n\t\t\t\t\t// повторит попытку открыть меню\r\n\t\t\t\t\tsetTimeout(() => this.mount(), 300);\r\n\r\n\t\t\t\t\treturn;\r\n\t\t\t\t}\r\n\r\n\t\t\t\tthrow ('Option useOriginal state allowed only elements .template');\r\n\t\t\t}\r\n\r\n\t\t\t// возможно вместо шаблона используется другой элемент\r\n\t\t\tthis.elPopup = document.querySelector(`${this.options.popup}:not(.top-popup-wrapper)`);\r\n\t\t}\r\n\r\n\t\tif (!this.elPopup) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tif (this.options.useOriginal) {\r\n\t\t\tthis.elStartPosition = this.elPopup.closest('.top-popup-el-start-position');\r\n\t\t\tif (!this.elStartPosition) {\r\n\t\t\t\tthis.elStartPosition = DOM.wrap(this.elPopup, 'i');\r\n\t\t\t\tthis.elStartPosition.classList.add('top-popup-el-start-position', 'hidden');\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tthis.elPopup = this.elPopup.cloneNode(true);\r\n\r\n\t\t\t// вывод в меню копии произвольного элемента\r\n\t\t\tif (this.type === 'selector' && !this.elPopup.matches('.template')) {\r\n\t\t\t\tthis.elPopup.classList.remove('hidden');\r\n\r\n\t\t\t\tif (!this.elPopup.querySelector(':scope > .top-popup_content')) {\r\n\t\t\t\t\tthis.elPopup.classList.add('top-popup_content');\r\n\t\t\t\t}\r\n\r\n\t\t\t\tthis.elPopup = DOM.wrap(this.elPopup, 'div');\r\n\t\t\t}\r\n\r\n\t\t\tif (this.type === 'html') {\r\n\t\t\t\tif (!this.elPopup.querySelector(':scope > .top-popup_content')) {\r\n\t\t\t\t\tthis.elPopup.classList.add('top-popup_content');\r\n\r\n\t\t\t\t\tthis.elPopup = DOM.wrap(this.elPopup, 'div');\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t\t// вложенный Popup\r\n\t\t\tif (this.type === 'selector' && !this.elPopup.matches('.template') || this.type === 'html' || this.type === 'vue') {\r\n\t\t\t\tDOM.querySelectorAllArray(this.elPopup, '[data-top-popup]').forEach(el => el.dataset.topPopupPosBy = 'fixed');\r\n\t\t\t\tDOM.querySelectorAllArray(this.elPopup, '.top-popup-wrapper').forEach(el => el.remove());\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tWorker.decoratorBeforeOpen(this);\r\n\r\n\t\tif (vueConnector) {\r\n\t\t\tthis.options.class = vueConnector.classRef.value;\r\n\t\t}\r\n\r\n\t\tthis.elPopupInner = document.createElement('div');\r\n\t\tthis.elPopupInner.classList.add('top-popupPanel', 'top-popup');\r\n\r\n\t\twhile (this.elPopup.firstChild) {\r\n\t\t\tthis.elPopupInner.appendChild(this.elPopup.firstChild);\r\n\t\t}\r\n\r\n\t\tthis.elPopup.append(this.elPopupInner);\r\n\r\n\t\tthis.elPopup.classList.add('top-popup-wrapper');\r\n\r\n\t\tif (this.options.class) {\r\n\t\t\tconst classes = this.options.class.split(' ');\r\n\t\t\tthis.elPopup.classList.add(...classes);\r\n\t\t}\r\n\r\n\t\tif (this.options.notch) {\r\n\t\t\tthis.elPopup.classList.add('with_notch');\r\n\t\t\tthis.elPopup.insertAdjacentHTML('beforeend', '<i class=\"notch notch-border\"></i><i class=\"notch\"></i>');\r\n\t\t}\r\n\r\n\t\tawait this.vueOpen();\r\n\r\n\t\tthis.elPopupHeader = this.elPopupInner.querySelector('.top-popup_header');\r\n\t\tthis.elPopupBody = this.elPopupInner.querySelector('.top-popup_content');\r\n\t\tthis.elPopupFooter = this.elPopupInner.querySelector('.top-popup_footer');\r\n\r\n\t\tconst existsWidgetSearch = !!this.elPopup.querySelector('[data-widget=\"search\"]');\r\n\r\n\t\tif (this.options.isFullScreen && !existsWidgetSearch) {\r\n\t\t\tif (!this.elPopupHeader) {\r\n\t\t\t\tthis.elPopupHeader = DOM.genEl('i', { class: 'top-popup_header' });\r\n\t\t\t\tthis.elPopupInner.prepend(this.elPopupHeader);\r\n\r\n\t\t\t\tthis.elPopupHeader.prepend(DOM.genEl('i', { class: 'a closer' }, this.options.i18n.Close));\r\n\t\t\t\tthis.elPopupHeader.append(DOM.genEl('i', { class: 'top-popup_headerButton' }));\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tDOM.storage(this.elPopup, 'Popup', this);\r\n\r\n\t\tif (this.options.frontSelector) {\r\n\t\t\tthis.elFront = document.querySelector(this.options.frontSelector);\r\n\t\t}\r\n\t\tif (!this.elFront) {\r\n\t\t\tthis.elFront = this.el.closest('.top-popup-front');\r\n\t\t}\r\n\t\tif (!this.elFront) {\r\n\t\t\tthis.elFront = document.body;\r\n\t\t}\r\n\r\n\t\tthis.elPopup.style.width = this.el.offsetWidth + 'px';\r\n\t\tthis.elPopup.style.height = this.el.offsetHeight + 'px';\r\n\t\tthis.elPopup.style.top = this.el.offsetTop + 'px';\r\n\t\tthis.elPopup.style.right = parseInt(this.el.style.right || 0) + 'px';\r\n\t\tthis.elPopup.style.bottom = parseInt(this.el.style.bottom || 0) + 'px';\r\n\r\n\t\tthis.el.parentElement.insertBefore(this.elPopup, this.el);\r\n\t\tthis.elPopup.classList.remove('template');\r\n\r\n\t\tif (this.options.invertX) {\r\n\t\t\tthis.elPopup.classList.add('invert-x');\r\n\t\t}\r\n\r\n\t\tlet fromTop = !!this.el.closest('.modal-header');\r\n\t\tif (!fromTop) {\r\n\t\t\tfromTop = !!this.el.closest('#top_panel');\r\n\t\t}\r\n\t\tif (!fromTop) {\r\n\t\t\tfromTop = !!this.el.closest('#secondmenu');\r\n\t\t}\r\n\t\tif (fromTop) {\r\n\t\t\tthis.elPopup.classList.add('p-from-top');\r\n\t\t}\r\n\r\n\t\t// появление с анимацией\r\n\t\tsetTimeout(() => this.elPopup.classList.add('top-popup-wrapper-shown'));\r\n\r\n\t\tif (this.elFront && !this.elFront.matches('body')) {\r\n\t\t\tthis.elFront.append(this.elPopup);\r\n\r\n\t\t\tthis.shift.top = DOM.offset(this.el).top - this.el.offsetTop - DOM.offset(this.elFront).top;\r\n\t\t\tthis.shift.left = DOM.offset(this.el).left - this.el.offsetLeft - DOM.offset(this.elFront).left;\r\n\r\n\t\t\t// position() не учитывает margin, замечено для flex\r\n\t\t\tthis.shift.top -= parseInt(this.el.style['margin-top'] || 0);\r\n\t\t\tthis.shift.left -= parseInt(this.el.style['margin-left'] || 0);\r\n\r\n\t\t\tthis.elPopup.style.top = parseInt(this.elPopup.style.top || '0') + this.shift.top + 'px';\r\n\t\t\tthis.elPopup.style.left = parseInt(this.elPopup.style.left || '0') + this.shift.left + 'px';\r\n\t\t}\r\n\r\n\t\tif (this.$) {\r\n\t\t\tthis.$.trigger('aftershow.top-menu-popup', [jQuery(this.elPopup)]);\r\n\t\t}\r\n\r\n\t\tthis.recalcPosition();\r\n\r\n\t\tthis.elPopup.setAttribute('tabindex', 0);\r\n\t\tthis.focus();\r\n\r\n\t\tWorker.decoratorAfterOpen(this);\r\n\r\n\t\tthis.mountEvents();\r\n\t}\r\n\r\n\tasync mountJQuery() {\r\n\t\tif (typeof (jQuery) !== 'function') {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tthis.$ = jQuery(this.el);\r\n\t}\r\n\r\n\t/**\r\n\t * Выполнить фокусировку на нужный элемент после открытия окна\r\n\t */\r\n\tfocus() {\r\n\t\tlet el = DOM.querySelectorVisible(this.elPopup, '.top-popup-autofocus');\r\n\r\n\t\t// поле ввода\r\n\t\tif (!el) {\r\n\t\t\tel = DOM.querySelectorVisible(this.elPopup, ':read-write, select:not(:disabled)');\r\n\t\t}\r\n\r\n\t\t// кнопка\r\n\t\tif (!el) {\r\n\t\t\tel = DOM.querySelectorVisible(this.elPopup, '.top-popup_footer .top-button');\r\n\t\t}\r\n\r\n\t\tif (!el) {\r\n\t\t\tel = this.elPopup;\r\n\t\t}\r\n\r\n\t\tel.focus();\r\n\t}\r\n\r\n\tmountEvents() {\r\n\t\t// закрытие при клике вне контекстного меню\r\n\t\tthis.addEventListenerWithUnmount(document, 'mousedown', (e) => this.onMousedown(e));\r\n\r\n\t\t// закрыть другие меню\r\n\t\tthis.addEventListenerWithUnmount(this.elPopup, 'focus', (e) => this.onFocus(e));\r\n\r\n\t\t// автоматическое закрытие при отведении мыши\r\n\t\tif (this.options.openByHover) {\r\n\t\t\tthis.addEventListenerWithUnmount(this.elPopup, 'mouseleave', (e) => this.onMouseleave(e));\r\n\t\t\tthis.addEventListenerWithUnmount(this.elPopupInner, 'mouseleave', (e) => this.onMouseleave(e));\r\n\t\t}\r\n\r\n\t\t// не скроллить страницу\r\n\t\tif (this.options.isFullScreen) {\r\n\t\t\tthis.addEventListenerWithUnmount(this.elPopupBody, 'touchmove', (e) => this.onTouchmove(e));\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t * Обработка клика вне окна\r\n\t * @param {Event} e\r\n\t */\r\n\tonMousedown(e) {\r\n\t\t// // не оригинальное событие\r\n\t\t// if (!e || !e.originalEvent || !e.originalEvent.isTrusted) {\r\n\t\t// \treturn;\r\n\t\t// }\r\n\r\n\t\t// Popup уже закрыт\r\n\t\tif (!this.elPopup) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\t// клик на внешнем элементе\r\n\t\tif (!this.isFirstClick) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tthis.isFirstClick = false;\r\n\t\tsetTimeout(() => this.isFirstClick = true);\r\n\r\n\t\t// клик не основной кнопкой мыши\r\n\t\tif (e.button !== 0) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\t// открыто другое меню с posBy = fixed, сначала должно быть закрыто оно\r\n\t\tlet elPopupOpened = DOM.querySelectorVisibleLast(document.body, ':scope > .top-popup-wrapper');\r\n\t\tif (elPopupOpened && elPopupOpened !== this.elPopup) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\t// открыто другое меню в top-popup-front, сначала должно быть закрыто оно\r\n\t\telPopupOpened = DOM.querySelectorVisibleLast(e.target.closest('.top-popup-front'), ':scope > .top-popup-wrapper');\r\n\t\tif (elPopupOpened && elPopupOpened !== this.elPopup) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\t// клик внутри этого меню\r\n\t\tif (this.elPopup.contains(e.target)) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\t// клик вне родительского диалогового окна\r\n\t\tif (this.elPopup.closest('.ui-dialog') && !e.target.closest('.ui-dialog')) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tif (Worker.decoratorIsIgnoreOuterClick(e)) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tWorker.close(this.elPopup);\r\n\t}\r\n\r\n\t/**\r\n\t * Закрыть другие Popup при фокусе на элемент формы в текущем\r\n\t * @param {Event} e\r\n\t */\r\n\tonFocus(e) {\r\n\t\tif (e.target.matches('input')) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\t// // не оригинальное событие\r\n\t\t// if (!e || !e.originalEvent || !e.originalEvent.isTrusted) {\r\n\t\t// \treturn;\r\n\t\t// }\r\n\r\n\t\t// это окно уже закрывается\r\n\t\tif (this.isClosed) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst elsPopups = Worker.getAllVisible();\r\n\t\telsPopups.forEach(elPopup => {\r\n\t\t\t// фокус внутри этого окна\r\n\t\t\tif (this.elPopup.contains(elPopup)) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\r\n\t\t\t// это Popup из которого был открыт Popup с фокусом\r\n\t\t\t// глубина вложенности: до 3 подменю\r\n\t\t\tif (\r\n\t\t\t\tthis.popupParent?.elPopup === elPopup ||\r\n\t\t\t\tthis.popupParent?.popupParent?.elPopup === elPopup\r\n\t\t\t) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\r\n\t\t\tWorker.close(elPopup);\r\n\t\t});\r\n\t}\r\n\r\n\t/**\r\n\t * Закрыть Popup при отведении мыши\r\n\t * @param {Event} _e\r\n\t */\r\n\tonMouseleave(_e) {\r\n\t\tsetTimeout(() => {\r\n\t\t\tif (this.elPopupInner.matches(':hover')) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\r\n\t\t\tWorker.close(this.elPopup);\r\n\t\t}, 100);\r\n\t}\r\n\r\n\t/**\r\n\t * Контроль положения Popup при fixed позиционировании\r\n\t */\r\n\tonResize() {\r\n\t\t// на android при вызове метода append сбрасывается фокус с input внутри this.elPopup\r\n\t\tif (this.elPopup.parentElement !== document.body) {\r\n\t\t\tdocument.body.append(this.elPopup);\r\n\t\t}\r\n\r\n\t\tthis.elPopup.style.top = DOM.offset(this.el).top + 'px';\r\n\t\tthis.elPopup.style.left = DOM.offset(this.el).left + 'px';\r\n\t}\r\n\r\n\tunmount() {\r\n\t\tsuper.unmount();\r\n\r\n\t\tthis.el.dataset.topPopupOpened = '';\r\n\t\tif (!this.elActiveByDefault) {\r\n\t\t\tthis.el.classList.remove('top-active');\r\n\t\t}\r\n\r\n\t\tlet style = this.el.getAttribute('style');\r\n\t\tif (style) {\r\n\t\t\tstyle = style.replace(/position:[^;]*;?/g, '');\r\n\t\t\tthis.el.setAttribute('style', style);\r\n\t\t}\r\n\t}\r\n\r\n\t// контроль за положением Popup, чтобы оно не вылезало за пределы документа\r\n\trecalcPosition() {\r\n\t\tlet p = this.options.p;\r\n\t\tlet leftPos;\r\n\r\n\t\tthis.elPopup.style.height = this.el.offsetHeight + 'px';\r\n\r\n\t\tthis.elPopup.classList.remove('p0', 'p1', 'p2', 'p3', 'p4');\r\n\t\tthis.elPopup.classList.add('p' + p);\r\n\r\n\t\tswitch (this.options.posBy) {\r\n\t\t\tcase 'left':\r\n\t\t\t\tleftPos = this.el.offsetLeft + parseInt(this.el.style['margin-left'] || 0);\r\n\t\t\t\tleftPos += this.shift.left;\r\n\t\t\t\tthis.elPopup.style.left = leftPos + 'px';\r\n\r\n\t\t\t\tbreak;\r\n\t\t\tcase 'right':\r\n\t\t\t\tleftPos = this.el.offsetLeft + parseInt(this.el.style['margin-left'] || 0);\r\n\t\t\t\tthis.elPopup.style.right = this.el.offsetParent.offsetWidth - this.el.offsetWidth - leftPos + 'px';\r\n\r\n\t\t\t\tbreak;\r\n\t\t\tcase 'fixed':\r\n\t\t\t\tthis.addEventListenerWithUnmount(window, 'resize', () => this.onResize());\r\n\r\n\t\t\t\tthis.onResize();\r\n\r\n\t\t\t\tbreak;\r\n\t\t\tdefault:\r\n\t\t\t\tthis.options.posBy.append(this.elPopup);\r\n\t\t}\r\n\r\n\t\t// контроль за пложением Popup, чтобы оно не вылезало за пределы документа\r\n\t\tconst boundingClientRect = this.elPopup.getBoundingClientRect();\r\n\t\tthis.elPopup.style.setProperty('--top-popup-height', this.elPopup.offsetHeight + 'px');\r\n\t\tthis.elPopup.style.setProperty('--top-popup-right-bounding', boundingClientRect.right + 'px');\r\n\t\tthis.elPopup.style.setProperty('--top-popup-bottom-bounding', boundingClientRect.bottom + 'px');\r\n\t\tthis.elPopup.style.setProperty('--top-popup-top', boundingClientRect.top + 'px');\r\n\t\tthis.elPopup.style.setProperty('--top-popup-left', boundingClientRect.left + 'px');\r\n\r\n\t\tthis.elPopupInner.style.maxWidth = 'unset';\r\n\t\tthis.elPopupInner.style.maxHeight = 'unset';\r\n\r\n\t\tlet outTop = false;\r\n\t\tlet outRight = false;\r\n\t\tlet outBottom = false;\r\n\t\tlet outLeft = false;\r\n\r\n\t\t// имеет ли смысл прикреплять окно к другой стороне кнопки\r\n\t\tlet usefulInvertX = boundingClientRect.left > window.innerWidth / 2;\r\n\t\tlet usefulInvertY = boundingClientRect.top > window.innerHeight / 2;\r\n\r\n\t\tif (p === 4) {\r\n\t\t\tusefulInvertX = !usefulInvertX;\r\n\t\t}\r\n\r\n\t\tif (p === 1) {\r\n\t\t\tusefulInvertY = !usefulInvertY;\r\n\t\t}\r\n\r\n\t\tconst contentBoundingClientRect = this.elPopupInner.getBoundingClientRect();\r\n\t\tconst contentRight = window.innerWidth - contentBoundingClientRect.right;\r\n\t\tconst contentBottom = window.innerHeight - contentBoundingClientRect.bottom;\r\n\r\n\t\tconst margin = 8;\r\n\r\n\t\tif (contentBoundingClientRect.top < margin) {\r\n\t\t\toutTop = true;\r\n\t\t}\r\n\r\n\t\tif (contentRight < margin) {\r\n\t\t\toutRight = true;\r\n\t\t}\r\n\r\n\t\tif (contentBottom < margin) {\r\n\t\t\toutBottom = true;\r\n\t\t}\r\n\r\n\t\tif (contentBoundingClientRect.left < margin) {\r\n\t\t\toutLeft = true;\r\n\t\t}\r\n\r\n\t\tif (outTop && (p === 0 || p === 1) && usefulInvertY) {\r\n\t\t\tp = 3;\r\n\t\t}\r\n\r\n\t\tif (outBottom && p === 3 && usefulInvertY) {\r\n\t\t\tp = 1;\r\n\t\t}\r\n\r\n\t\tif (outRight && p === 2 && usefulInvertX) {\r\n\t\t\tp = 4;\r\n\t\t}\r\n\r\n\t\tif (outLeft && p === 4 && usefulInvertX) {\r\n\t\t\tp = 2;\r\n\t\t}\r\n\r\n\t\tif (outRight && (p === 0 || p === 1 || p === 3)) {\r\n\t\t\tthis.elPopup.classList.add('invert-x');\r\n\t\t}\r\n\r\n\t\tif (outBottom && (p === 2 || p === 4) && usefulInvertY) {\r\n\t\t\t// меню справа может перемещаться вверх, толкьо если есть место слева\r\n\t\t\tif (p === 2 && !usefulInvertX) {\r\n\t\t\t\tthis.elPopup.classList.add('invert-y');\r\n\t\t\t}\r\n\r\n\t\t\t// меню слева перемещаясь вверх, должно открываться влево\r\n\t\t\tif (p === 4 && !usefulInvertX) {\r\n\t\t\t\tthis.elPopup.classList.add('invert-x');\r\n\t\t\t}\r\n\r\n\t\t\tif (!this.elPopup.matches('.invert-y')) {\r\n\t\t\t\tp = 1;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tthis.elPopup.classList.remove('p0', 'p1', 'p2', 'p3', 'p4');\r\n\t\tthis.elPopup.classList.add('p' + p);\r\n\r\n\t\tthis.elPopupInner.style.maxWidth = '';\r\n\t\tthis.elPopupInner.style.maxHeight = '';\r\n\r\n\t\tWorker.scrollToActive(this.elPopup);\r\n\t};\r\n\r\n\tonTouchmove(e) {\r\n\t\t// разрешить горизональный скролл\r\n\t\tlet hasScrollX = e.currentTarget.scrollWidth > e.currentTarget.offsetWidth;\r\n\t\tif (hasScrollX) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\t// разрешить горизональный скролл\r\n\t\tlet hasScrollX2 = e.target.parentElement.scrollWidth > e.target.parentElement.offsetWidth;\r\n\t\tif (hasScrollX2) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tif (!e.currentTarget.matches('.has_scroll')) {\r\n\t\t\te.preventDefault();\r\n\t\t}\r\n\t}\r\n\r\n\tclose() {\r\n\t\tif (this.isClosed) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tthis.isClosed = true;\r\n\r\n\t\tif (this.$) {\r\n\t\t\tthis.$.trigger('afterclose.top-menu-popup', [jQuery(this.elPopup)]);\r\n\t\t}\r\n\r\n\t\tif (Worker.noClose) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tthis.unmount();\r\n\r\n\t\tthis.elPopup.classList.add('top-popup-wrapper-closed');\r\n\r\n\t\tsetTimeout(() => {\r\n\t\t\tthis.vueClose();\r\n\r\n\t\t\tif (this.options.useOriginal) {\r\n\t\t\t\tthis.elPopup.removeAttribute('style');\r\n\t\t\t\tthis.elPopup.classList.remove('top-popup-wrapper-shown', 'top-popup-wrapper-closed');\r\n\t\t\t\tthis.elPopup.classList.add('template');\r\n\t\t\t\tthis.elStartPosition.append(this.elPopup);\r\n\r\n\t\t\t\tthis.elPopup.querySelector('div.top-popup_content.top-column')?.classList.remove('top-column');\r\n\t\t\t\tthis.elPopup.querySelector('.notch-border')?.remove();\r\n\t\t\t\tthis.elPopup.querySelector('.notch')?.remove();\r\n\r\n\t\t\t\tthis.elPopupInner.replaceWith(...this.elPopupInner.childNodes);\r\n\r\n\t\t\t\tDOM.storageClear(this.elPopup);\r\n\t\t\t} else {\r\n\t\t\t\tDOM.storageClear(this.elPopup);\r\n\r\n\t\t\t\tthis.elPopup.remove();\r\n\t\t\t\tdelete this.elPopup;\r\n\t\t\t}\r\n\r\n\t\t\tconst elsPopups = Worker.getAllVisible();\r\n\t\t\tconst elPopupLast = elsPopups.length && elsPopups[elsPopups.length - 1];\r\n\r\n\t\t\tif (elPopupLast) {\r\n\t\t\t\tWorker.getPopup(elPopupLast).focus();\r\n\t\t\t} else {\r\n\t\t\t\tdocument.documentElement.classList.remove('with_popup');\r\n\t\t\t}\r\n\t\t}, 300);\r\n\t}\r\n\r\n\tasync vueOpen() {\r\n\t\tawait this.vueGetComponent()?.onOpen(this);\r\n\t}\r\n\r\n\tvueClose() {\r\n\t\tthis.vueGetComponent()?.onClose(this);\r\n\t}\r\n\r\n\t// получить vueConnectors компонента Popup\r\n\tvueGetComponent() {\r\n\t\treturn Worker.vueConnectors.get(this.el.dataset.topPopupId);\r\n\t}\r\n}\r\n\r\nGlobalEvents.init();\r\n\r\nexport default Popup;"],"names":["Component","componentName","el","options","component","forms","eventData","type","listener","nodes","node","_a","GlobalEvents","e","elCloser","elUl","popup_worker","elPopup","elBtn","elItem","elMore","countLi","elsLiVisible","index","css","cssM","cssPC","Core","Popup","vueConnector","classes","existsWidgetSearch","fromTop","elPopupOpened","p","leftPos","boundingClientRect","outTop","outRight","outBottom","outLeft","usefulInvertX","usefulInvertY","margin","contentBoundingClientRect","contentRight","contentBottom","elsPopups","elPopupLast"],"mappings":"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"}
|
package/README.md
CHANGED
|
@@ -1,81 +1,81 @@
|
|
|
1
|
-
# UI kit Topvisor Vue
|
|
2
|
-
|
|
3
|
-
## Vue компоненты
|
|
4
|
-
|
|
5
|
-
Компоненты поставляются в двух форматах:
|
|
6
|
-
|
|
7
|
-
- amd (requirejs)
|
|
8
|
-
- es
|
|
9
|
-
|
|
10
|
-
Компоненты делятся на разные библиотеки и доступны через импорт этих библиотек.
|
|
11
|
-
|
|
12
|
-
Каждая библиотека находится в отдельной папке, соответствующей имени библиотеки.
|
|
13
|
-
|
|
14
|
-
Все стили модулей находятся в папке /assets/ в файлах соответствующих имени библиотеки.
|
|
15
|
-
В этой же папке располагаются стили для асинхронно загружаемых компонентов.
|
|
16
|
-
Все стили грузятся автоматически вместе с загрузкой компонента.
|
|
17
|
-
|
|
18
|
-
Список доступных библиотек компонентов см. на [npmjs](https://www.npmjs.com/package/@topvisor/ui?activeTab=code).
|
|
19
|
-
|
|
20
|
-
## Общие стили UI
|
|
21
|
-
|
|
22
|
-
- /assets/core.css - основная палитра цветов и общие стили и модификаторы компонентов
|
|
23
|
-
- /assets/light.css - светлая тема
|
|
24
|
-
- /assets/dark.css - темная тема
|
|
25
|
-
|
|
26
|
-
## Подключение стилей
|
|
27
|
-
|
|
28
|
-
Стили компонентов подгружаются автоматически.
|
|
29
|
-
|
|
30
|
-
Стили UI core.css необходимо подгрузить на страницу вручную.
|
|
31
|
-
|
|
32
|
-
```js
|
|
33
|
-
import '@topvisor/ui/assets/core.css';
|
|
34
|
-
```
|
|
35
|
-
|
|
36
|
-
```html
|
|
37
|
-
<link href="https://cdn.jsdelivr.net/npm/@topvisor/ui/assets/core.css" rel="stylesheet">
|
|
38
|
-
```
|
|
39
|
-
|
|
40
|
-
## Подключение стилей темы
|
|
41
|
-
|
|
42
|
-
Стили темы необходимо подгрузить на страницу вручную.
|
|
43
|
-
|
|
44
|
-
Для смены темы необходимо подгрузить файл стилей необходимой темы и отключить стили предыдущей темы.
|
|
45
|
-
|
|
46
|
-
```js
|
|
47
|
-
import '@topvisor/ui/assets/light.css';
|
|
48
|
-
```
|
|
49
|
-
|
|
50
|
-
```html
|
|
51
|
-
<link href="https://cdn.jsdelivr.net/npm/@topvisor/ui/assets/light.css" rel="stylesheet">
|
|
52
|
-
```
|
|
53
|
-
|
|
54
|
-
## Внешние зависимсоти
|
|
55
|
-
|
|
56
|
-
Стили icomoon добавлены в пакет и их необходимо подгрузить на страницу вручную.
|
|
57
|
-
|
|
58
|
-
```js
|
|
59
|
-
import '@topvisor/ui/icomoon/style.css';
|
|
60
|
-
```
|
|
61
|
-
|
|
62
|
-
```html
|
|
63
|
-
<link href="https://cdn.jsdelivr.net/npm/@topvisor/ui/icomoon/style.css" rel="stylesheet">
|
|
64
|
-
```
|
|
65
|
-
|
|
66
|
-
## Подключение компонентов
|
|
67
|
-
|
|
68
|
-
Пример подключения библиотеки Forms и компонента Button:
|
|
69
|
-
|
|
70
|
-
```javascript
|
|
71
|
-
require(['@topvisor/ui/forms/forms.amd'], ({ Button }) => {
|
|
72
|
-
console.log(Button);
|
|
73
|
-
});
|
|
74
|
-
|
|
75
|
-
require(['@topvisor/ui/forms/forms.amd'], Forms => {
|
|
76
|
-
const { Button } = Forms;
|
|
77
|
-
|
|
78
|
-
console.log(Forms);
|
|
79
|
-
console.log(Button);
|
|
80
|
-
});
|
|
1
|
+
# UI kit Topvisor Vue
|
|
2
|
+
|
|
3
|
+
## Vue компоненты
|
|
4
|
+
|
|
5
|
+
Компоненты поставляются в двух форматах:
|
|
6
|
+
|
|
7
|
+
- amd (requirejs)
|
|
8
|
+
- es
|
|
9
|
+
|
|
10
|
+
Компоненты делятся на разные библиотеки и доступны через импорт этих библиотек.
|
|
11
|
+
|
|
12
|
+
Каждая библиотека находится в отдельной папке, соответствующей имени библиотеки.
|
|
13
|
+
|
|
14
|
+
Все стили модулей находятся в папке /assets/ в файлах соответствующих имени библиотеки.
|
|
15
|
+
В этой же папке располагаются стили для асинхронно загружаемых компонентов.
|
|
16
|
+
Все стили грузятся автоматически вместе с загрузкой компонента.
|
|
17
|
+
|
|
18
|
+
Список доступных библиотек компонентов см. на [npmjs](https://www.npmjs.com/package/@topvisor/ui?activeTab=code).
|
|
19
|
+
|
|
20
|
+
## Общие стили UI
|
|
21
|
+
|
|
22
|
+
- /assets/core.css - основная палитра цветов и общие стили и модификаторы компонентов
|
|
23
|
+
- /assets/light.css - светлая тема
|
|
24
|
+
- /assets/dark.css - темная тема
|
|
25
|
+
|
|
26
|
+
## Подключение стилей
|
|
27
|
+
|
|
28
|
+
Стили компонентов подгружаются автоматически.
|
|
29
|
+
|
|
30
|
+
Стили UI core.css необходимо подгрузить на страницу вручную.
|
|
31
|
+
|
|
32
|
+
```js
|
|
33
|
+
import '@topvisor/ui/assets/core.css';
|
|
34
|
+
```
|
|
35
|
+
|
|
36
|
+
```html
|
|
37
|
+
<link href="https://cdn.jsdelivr.net/npm/@topvisor/ui/assets/core.css" rel="stylesheet">
|
|
38
|
+
```
|
|
39
|
+
|
|
40
|
+
## Подключение стилей темы
|
|
41
|
+
|
|
42
|
+
Стили темы необходимо подгрузить на страницу вручную.
|
|
43
|
+
|
|
44
|
+
Для смены темы необходимо подгрузить файл стилей необходимой темы и отключить стили предыдущей темы.
|
|
45
|
+
|
|
46
|
+
```js
|
|
47
|
+
import '@topvisor/ui/assets/light.css';
|
|
48
|
+
```
|
|
49
|
+
|
|
50
|
+
```html
|
|
51
|
+
<link href="https://cdn.jsdelivr.net/npm/@topvisor/ui/assets/light.css" rel="stylesheet">
|
|
52
|
+
```
|
|
53
|
+
|
|
54
|
+
## Внешние зависимсоти
|
|
55
|
+
|
|
56
|
+
Стили icomoon добавлены в пакет и их необходимо подгрузить на страницу вручную.
|
|
57
|
+
|
|
58
|
+
```js
|
|
59
|
+
import '@topvisor/ui/icomoon/style.css';
|
|
60
|
+
```
|
|
61
|
+
|
|
62
|
+
```html
|
|
63
|
+
<link href="https://cdn.jsdelivr.net/npm/@topvisor/ui/icomoon/style.css" rel="stylesheet">
|
|
64
|
+
```
|
|
65
|
+
|
|
66
|
+
## Подключение компонентов
|
|
67
|
+
|
|
68
|
+
Пример подключения библиотеки Forms и компонента Button:
|
|
69
|
+
|
|
70
|
+
```javascript
|
|
71
|
+
require(['@topvisor/ui/forms/forms.amd'], ({ Button }) => {
|
|
72
|
+
console.log(Button);
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
require(['@topvisor/ui/forms/forms.amd'], Forms => {
|
|
76
|
+
const { Button } = Forms;
|
|
77
|
+
|
|
78
|
+
console.log(Forms);
|
|
79
|
+
console.log(Button);
|
|
80
|
+
});
|
|
81
81
|
```
|
package/assets/core.css
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
:root{--color-white: rgba(255, 255, 255, 1);--color-black: rgba(0, 0, 0, 1);--color-black-transparent-40: rgba(0, 0, 0, .4);--color-black-transparent-50: rgba(0, 0, 0, .5);--color-steel-50: rgba(251, 252, 253, 1);--color-steel-100: rgba(248, 250, 252, 1);--color-steel-150: rgba(241, 244, 249, 1);--color-steel-200: rgba(234, 239, 245, 1);--color-steel-250: rgba(228, 234, 241, 1);--color-steel-300: rgba(221, 228, 238, 1);--color-steel-350: rgba(215, 223, 233, 1);--color-steel-400: rgba(209, 218, 229, 1);--color-steel-450: rgba(204, 213, 225, 1);--color-steel-500: rgba(198, 208, 220, 1);--color-steel-550: rgba(193, 203, 215, 1);--color-gray-50: rgba(225, 229, 234, 1);--color-gray-100: rgba(210, 216, 223, 1);--color-gray-150: rgba(196, 203, 212, 1);--color-gray-200: rgba(182, 190, 201, 1);--color-gray-250: rgba(168, 177, 189, 1);--color-gray-300: rgba(154, 164, 177, 1);--color-gray-350: rgba(141, 151, 165, 1);--color-gray-400: rgba(128, 138, 153, 1);--color-gray-450: rgba(115, 125, 140, 1);--color-gray-500: rgba(104, 113, 125, 1);--color-gray-550: rgba(94, 101, 110, 1);--color-gray-600: rgba(83, 88, 95, 1);--color-gray-650: rgba(72, 76, 81, 1);--color-gray-700: rgba(61, 63, 67, 1);--color-gray-750: rgba(49, 51, 53, 1);--color-gray-800: rgba(37, 38, 39, 1);--color-gray-850: rgba(25, 25, 26, 1);--color-gray-900: rgba(13, 13, 13, 1);--color-blue-50: rgba(250, 252, 255, 1);--color-blue-100: rgba(230, 240, 255, 1);--color-blue-150: rgba(204, 224, 255, 1);--color-blue-200: rgba(179, 210, 255, 1);--color-blue-250: rgba(153, 194, 255, 1);--color-blue-300: rgba(128, 179, 255, 1);--color-blue-350: rgba(102, 163, 255, 1);--color-blue-400: rgba(77, 148, 255, 1);--color-blue-450: rgba(51, 132, 255, 1);--color-blue-500: rgba(25, 117, 255, 1);--color-blue-550: rgba(23, 105, 227, 1);--color-blue-600: rgba(20, 91, 198, 1);--color-blue-650: rgba(17, 78, 170, 1);--color-blue-700: rgba(14, 65, 142, 1);--color-blue-750: rgba(12, 52, 113, 1);--color-blue-800: rgba(9, 40, 85, 1);--color-blue-850: rgba(6, 26, 57, 1);--color-blue-900: rgba(3, 13, 28, 1);--color-orange-50: rgba(255, 253, 250, 1);--color-orange-100: rgba(255, 244, 230, 1);--color-orange-150: rgba(255, 234, 204, 1);--color-orange-200: rgba(255, 223, 178, 1);--color-orange-250: rgba(255, 212, 153, 1);--color-orange-300: rgba(255, 202, 128, 1);--color-orange-350: rgba(255, 191, 102, 1);--color-orange-400: rgba(255, 180, 77, 1);--color-orange-450: rgba(255, 170, 51, 1);--color-orange-500: rgba(255, 159, 25, 1);--color-orange-550: rgba(227, 141, 23, 1);--color-orange-600: rgba(198, 124, 20, 1);--color-orange-650: rgba(170, 106, 17, 1);--color-orange-700: rgba(142, 88, 14, 1);--color-orange-750: rgba(113, 71, 12, 1);--color-orange-800: rgba(85, 53, 9, 1);--color-orange-850: rgba(57, 35, 6, 1);--color-orange-900: rgba(28, 18, 3, 1);--color-mint-50: rgba(251, 254, 253, 1);--color-mint-100: rgba(228, 251, 245, 1);--color-mint-150: rgba(200, 246, 235, 1);--color-mint-200: rgba(173, 242, 226, 1);--color-mint-250: rgba(146, 237, 216, 1);--color-mint-300: rgba(118, 233, 206, 1);--color-mint-350: rgba(91, 228, 196, 1);--color-mint-400: rgba(64, 224, 187, 1);--color-mint-450: rgba(36, 219, 177, 1);--color-mint-500: rgba(9, 215, 167, 1);--color-mint-550: rgba(8, 191, 148, 1);--color-mint-600: rgba(7, 167, 130, 1);--color-mint-650: rgba(6, 143, 111, 1);--color-mint-700: rgba(5, 119, 93, 1);--color-mint-750: rgba(4, 96, 74, 1);--color-mint-800: rgba(3, 72, 56, 1);--color-mint-850: rgba(2, 48, 37, 1);--color-mint-900: rgba(1, 24, 19, 1);--color-green-50: rgba(251, 254, 252, 1);--color-green-100: rgba(229, 248, 237, 1);--color-green-150: rgba(203, 242, 220, 1);--color-green-200: rgba(177, 235, 202, 1);--color-green-250: rgba(151, 229, 184, 1);--color-green-300: rgba(126, 222, 167, 1);--color-green-350: rgba(100, 216, 149, 1);--color-green-400: rgba(74, 209, 131, 1);--color-green-450: rgba(48, 203, 114, 1);--color-green-500: rgba(22, 196, 96, 1);--color-green-550: rgba(20, 174, 85, 1);--color-green-600: rgba(17, 152, 75, 1);--color-green-650: rgba(15, 131, 64, 1);--color-green-700: rgba(12, 109, 53, 1);--color-green-750: rgba(10, 87, 43, 1);--color-green-800: rgba(7, 65, 32, 1);--color-green-850: rgba(5, 44, 21, 1);--color-green-900: rgba(2, 22, 11, 1);--color-salad-50: rgba(252, 254, 250, 1);--color-salad-100: rgba(242, 252, 232, 1);--color-salad-150: rgba(228, 248, 208, 1);--color-salad-200: rgba(215, 245, 185, 1);--color-salad-250: rgba(202, 242, 162, 1);--color-salad-300: rgba(188, 238, 138, 1);--color-salad-350: rgba(175, 235, 115, 1);--color-salad-400: rgba(162, 232, 92, 1);--color-salad-450: rgba(148, 228, 68, 1);--color-salad-500: rgba(135, 225, 45, 1);--color-salad-550: rgba(120, 200, 40, 1);--color-salad-600: rgba(105, 175, 35, 1);--color-salad-650: rgba(90, 150, 30, 1);--color-salad-700: rgba(75, 125, 25, 1);--color-salad-750: rgba(60, 100, 20, 1);--color-salad-800: rgba(45, 75, 15, 1);--color-salad-850: rgba(30, 50, 10, 1);--color-salad-900: rgba(15, 25, 5, 1);--color-red-50: rgba(255, 251, 250, 1);--color-red-100: rgba(253, 234, 232, 1);--color-red-150: rgba(250, 213, 209, 1);--color-red-200: rgba(248, 192, 187, 1);--color-red-250: rgba(246, 171, 164, 1);--color-red-300: rgba(243, 149, 141, 1);--color-red-350: rgba(241, 128, 118, 1);--color-red-400: rgba(239, 107, 96, 1);--color-red-450: rgba(236, 86, 73, 1);--color-red-500: rgba(234, 65, 50, 1);--color-red-550: rgba(208, 58, 44, 1);--color-red-600: rgba(182, 51, 39, 1);--color-red-650: rgba(156, 43, 33, 1);--color-red-700: rgba(130, 36, 28, 1);--color-red-750: rgba(104, 29, 22, 1);--color-red-800: rgba(78, 22, 17, 1);--color-red-850: rgba(52, 14, 11, 1);--color-red-900: rgba(26, 7, 6, 1);--color-violet-50: rgba(251, 250, 255, 1);--color-violet-100: rgba(240, 235, 255, 1);--color-violet-150: rgba(225, 215, 255, 1);--color-violet-200: rgba(210, 195, 255, 1);--color-violet-250: rgba(195, 175, 255, 1);--color-violet-300: rgba(181, 156, 255, 1);--color-violet-350: rgba(166, 136, 255, 1);--color-violet-400: rgba(151, 116, 255, 1);--color-violet-450: rgba(136, 96, 255, 1);--color-violet-500: rgba(121, 76, 255, 1);--color-violet-550: rgba(108, 68, 227, 1);--color-violet-600: rgba(94, 59, 198, 1);--color-violet-650: rgba(81, 51, 170, 1);--color-violet-700: rgba(67, 42, 142, 1);--color-violet-750: rgba(54, 34, 113, 1);--color-violet-800: rgba(40, 25, 85, 1);--color-violet-850: rgba(27, 17, 57, 1);--color-violet-900: rgba(13, 8, 28, 1);--color-pink-50: rgba(254, 250, 254, 1);--color-pink-100: rgba(252, 231, 251, 1);--color-pink-150: rgba(250, 207, 246, 1);--color-pink-200: rgba(247, 183, 242, 1);--color-pink-250: rgba(244, 159, 237, 1);--color-pink-300: rgba(242, 135, 233, 1);--color-pink-350: rgba(239, 111, 228, 1);--color-pink-400: rgba(236, 87, 224, 1);--color-pink-450: rgba(234, 63, 219, 1);--color-pink-500: rgba(231, 39, 215, 1);--color-pink-550: rgba(205, 35, 191, 1);--color-pink-600: rgba(180, 30, 167, 1);--color-pink-650: rgba(154, 26, 143, 1);--color-pink-700: rgba(128, 22, 119, 1);--color-pink-750: rgba(103, 17, 96, 1);--color-pink-800: rgba(77, 13, 72, 1);--color-pink-850: rgba(51, 9, 48, 1);--color-pink-900: rgba(26, 4, 24, 1);--color-yellow-50: rgba(255, 254, 250, 1);--color-yellow-100: rgba(253, 252, 231, 1);--color-yellow-150: rgba(251, 248, 208, 1);--color-yellow-200: rgba(248, 245, 184, 1);--color-yellow-250: rgba(246, 242, 160, 1);--color-yellow-300: rgba(244, 238, 137, 1);--color-yellow-350: rgba(242, 235, 113, 1);--color-yellow-400: rgba(239, 232, 89, 1);--color-yellow-450: rgba(237, 228, 66, 1);--color-yellow-500: rgba(235, 225, 42, 1);--color-yellow-550: rgba(209, 200, 37, 1);--color-yellow-600: rgba(183, 175, 33, 1);--color-yellow-650: rgba(157, 150, 28, 1);--color-yellow-700: rgba(131, 125, 23, 1);--color-yellow-750: rgba(104, 100, 19, 1);--color-yellow-800: rgba(78, 75, 14, 1);--color-yellow-850: rgba(52, 50, 9, 1);--color-yellow-900: rgba(26, 25, 5, 1);--color-top-3: #3198DD;--color-top-10: #21936C;--color-top-30: #1ABC9C;--color-top-50: #A6E0A3;--color-top-100: #C7D7D7;--color-top-10000: #FCC94A}:root{--top-padding-1: 4px;--top-padding-2: 8px;--top-padding-3: 12px;--top-padding-4: 16px;--top-padding-5: 20px;--top-padding-6: 24px;--top-padding-7: 28px;--top-padding-8: 32px;--top-padding-9: 36px;--top-padding-10: 40px;--top-padding-11: 44px;--top-padding-12: 48px;--top-gap-1: 4px;--top-gap-2: 8px;--top-gap-3: 12px;--top-gap-4: 16px;--top-gap-5: 20px;--top-gap-6: 24px;--top-gap-7: 28px;--top-gap-8: 32px;--top-gap-9: 36px;--top-gap-10: 40px;--top-gap-11: 44px;--top-gap-12: 48px;--top-radius-1: 4px;--top-radius-2: 8px;--top-radius-3: 12px;--top-radius-4: 16px;--top-radius-5: 20px;--top-radius-6: 24px;--top-radius-7: 28px;--top-radius-8: 32px;--top-radius-9: 36px;--top-radius-10: 40px;--top-radius-11: 44px;--top-radius-12: 48px}.top-comment{color:var(--color-gray-350);font-size:12px}:root{--top-formsCaption-offset: 16px}.top-formsCaptionWrapper{padding-top:20px}.top-formsCaption{pointer-events:none;width:calc(100% - var(--top-forms-padding) - var(--top-icon-both-width) - var(--top-forms_clear-width) - var(--top-select_arrow-width));padding:0 var(--top-forms-padding);color:var(--color-placeholder);white-space:nowrap;text-overflow:ellipsis;transform:translate(var(--top-icon-both-width));position:absolute;overflow:hidden;transition:.1s}.top-error~.top-formsCaption{transition:.1s .1s}.top-formsCaption *{pointer-events:auto}.top-formsCaptionWrapper>input:not([readonly]):focus~.top-formsCaption,.top-formsCaptionWrapper>input:not(:placeholder-shown)~.top-formsCaption,.top-formsCaptionWrapper>textarea:not(:placeholder-shown)~.top-formsCaption,.top-formsCaptionWrapper.top-select>.top-formsCaption,.top-formsCaptionWrapper.top-inputRange>.top-formsCaption,.top-formsCaptionWrapper-always>.top-formsCaption{width:100%;padding:0;color:var(--color-placeholder-active);font-size:11px;transform:translateY(calc(-1em - var(--top-formsCaption-offset)));transition:.1s}.ui-tooltip{pointer-events:none;box-shadow:0 6px 18px #0e152f21,0 -2px 6px #0e152f08;border-radius:8px;border:none;background:var(--content-background-color);width:max-content;padding:16px;margin:0 18px;font-size:13px}.ui-tooltip img{margin:12px 0 0}.ui-tooltip ul{margin-left:24px}button,input,textarea,select{border:1px solid var(--top-forms-border-color);color:var(--color-text);font-size:var(--top-font-size);font-family:inherit}::placeholder{color:var(--color-placeholder)}[contenteditable][placeholder]:empty:before{content:attr(placeholder);color:var(--color-text-secondary)}.top-forms-optionWrapper{cursor:pointer;padding:8px 0;color:var(--color-text);line-height:1.3;display:inline-flex;align-items:flex-start;gap:4px}.top-forms-option{cursor:pointer;padding:0;margin:3px;display:inline-flex;flex-shrink:0;appearance:none;-webkit-appearance:none}.top-forms-focusable:focus-visible,.top-focus{outline:calc(var(--top-forms-border-width) * 2) solid var(--top-forms-option-color);outline-offset:2px;position:relative;z-index:1;transition:border-color .15s}.top-forms-focusable:hover,.top-forms-focusable:focus,.top-focus:hover,.top-focus:focus,.top-input:hover>.top-input_input,.top-select:hover>.top-select_select{--top-forms-border-color: var(--top-forms-border-color-hover);--top-forms-background-color: var(--top-forms-background-color-hover)}[contenteditable]:focus-visible,.top-selector-multiselect:focus-within{outline:2px solid var(--color-blue-100)}:root{--top-font-size: 14px;--top-forms-radius: 8px;--top-forms-border-width: 1px;--top-style_outline-color: transparent;--top-forms-base-height_xs: 24px;--top-forms-base-height_s: 32px;--top-forms-base-height_l: 36px;--top-forms-base-height_xl: 40px;--top-forms-base-height: var(--top-forms-base-height_s);--top-forms-padding: 8px;--top-forms-padding_l: 12px;--top-forms-padding_xl: 16px;--top-forms-option-height: 24px;--top-forms-option-color: var(--color-primary);--top-forms-option-color-hover: var(--color-primary-2);--top-select_arrow-width: 0px;--top-forms_clear-width: 0px}.top-size_xs{--top-forms-base-height: var(--top-forms-base-height_xs)}.top-size_s{--top-forms-base-height: var(--top-forms-base-height_s)}.top-size_l{--top-forms-base-height: var(--top-forms-base-height_l)}.top-size_xl{--top-forms-base-height: var(--top-forms-base-height_xl)}.top-input_input,.top-textarea_textarea,.top-editArea_form,.top-select_select{box-sizing:border-box;border-radius:var(--top-forms-radius);border:var(--top-forms-border-width) solid var(--top-forms-border-color);display:inline-flex;appearance:none;-webkit-appearance:none}.top-select_select{padding-right:calc(var(--top-forms-padding) + var(--top-forms_clear-width) + var(--top-select_arrow-width));padding-left:max(var(--top-forms-padding),var(--top-icon-both-width))}.top-select{position:relative}.top-select[data-top-icon]:before,.top-select[data-top-icon2]:after{position:absolute;z-index:3}.top-select[data-top-icon][data-top-icon2]:after{left:calc(var(--top-icon-width))}.top-cleaner[data-top-icon]{--top-icon-size: 20px;--top-icon-width: 20px;--top-icon-color: var(--color-text-secondary);cursor:pointer;border-radius:50%;width:30px;height:24px;margin-left:-34px;transform:translate(calc(0px - var(--top-forms-border-width) - var(--top-select_arrow-width)));display:flex;align-items:center;justify-content:center;position:relative;z-index:1}.top-cleaner[data-top-icon]:hover{--top-icon-color: var(--color-text-secondary-2)}:root{--top-icon-size: 24px;--top-icon-width: 0px;--top-icon2-size: 24px;--top-icon2-width: 0px;--top-icon-both-width: 0px}[data-top-icon]{--top-icon-width: calc(var(--top-icon-size) + var(--top-forms-padding));--top-icon-color: inherit}[data-top-icon2]{--top-icon2-width: calc(var(--top-icon2-size) + 8px);--top-icon2-color: inherit}[data-top-icon=""]{--top-icon-width: 0px}[data-top-icon2=""]{--top-icon2-width: 0px}[data-top-icon]:before,[data-top-icon2]:after{pointer-events:none;content:attr(data-top-icon);border-radius:var(--top-forms-radius);width:var(--top-icon-width);color:var(--top-icon-color);font-family:Topvisor-2;font-size:var(--top-icon-size);font-weight:400;line-height:1;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}[data-top-icon2]:after{content:attr(data-top-icon2);width:var(--top-icon2-width);color:var(--top-icon2-color);font-size:var(--top-icon2-size)}[data-top-icon],[data-top-icon2]{--top-icon-both-width: calc(var(--top-icon-width) + var(--top-icon2-width))}[data-top-icon=]:before{font-family:Topvisor}.top-as-a{cursor:pointer;color:var(--color-text-link)}.top-as-a:hover{text-decoration:underline}.top-ellipsis{max-height:100%;text-overflow:ellipsis;overflow:hidden;line-height:1.23;flex-grow:1}.top-ellipsis2,.top-ellipsis3{max-width:fit-content;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.top-ellipsis3{-webkit-line-clamp:3}.top-hidden{display:none!important}.top-unvisible{width:0;height:0;overflow:hidden;position:absolute;-webkit-appearance:none;appearance:none;border:none}.top-unvisible:focus-visible{outline:none}.top-disabled{pointer-events:none;-webkit-user-select:none;user-select:none}:disabled:not(option):not(optgroup):not(.top-forms-option),:disabled~.top-formsCaption,.top-disabled[data-top-icon]:before,.top-disabled[data-top-icon2]:after{opacity:.5;filter:grayscale(100%)}.top-error,.top-error::placeholder,.top-error:before{--top-forms-border-color: var(--color-negative);border-color:var(--color-negative)}.top-error{--top-icon-color: var(--color-negative);color:var(--color-negative)}.top-error~.top-formsCaption{color:var(--color-negative)}.top-warning{--top-icon-color: var(--color-orange-500);color:var(--color-orange-500)}input.top-error,textarea.top-error,select.top-error,.top-editArea_form.top-error{animation:top-error .8s}@keyframes top-error{0%{outline-offset:10px;outline:3px solid transparent}50%{outline:3px solid var(--color-red-100);outline-offset:2px}to{outline:3px solid transparent;outline-offset:2px}}@media only screen and (min-width: 900px){.top-only-mobile{display:none!important}}@media only screen and (max-width: 900px){.top-only-pc{display:none!important}}html:not([lang=ru]) .top-only-ru,html:not([lang=en]) .top-only-en{display:none!important}html[data-is_admin="0"] .top-only-admin{display:none!important}.top-select_arrow{--top-select_arrow-color: var(--color-gray-600);--top-select_arrow-size: 12px;--top-select_arrow-width: 24px;background-image:url("data:image/svg+xml,%3Csvg width='16' height='9' viewBox='0 0 16 9' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M14.293 0.29269L8 6.5857L1.70704 0.29269C1.31679 -0.0975633 0.682937 -0.0975633 0.292687 0.29269C-0.0975624 0.682943 -0.0975624 1.31656 0.292687 1.70682L7.29294 8.70713C7.68343 9.09762 8.31657 9.09762 8.70706 8.70713L15.7073 1.70682C16.0976 1.31656 16.0976 0.682943 15.7073 0.29269C15.3171 -0.0975633 14.6832 -0.0975633 14.293 0.29269Z' fill='%23808A99'/%3E%3C/svg%3E");background-size:14px;background-position:calc(100% - var(--top-forms-padding)) 50%;background-repeat:no-repeat;padding-right:32px}.top-select_arrow~.top-cleaner{--top-select_arrow-width: 24px}
|
|
1
|
+
:root{--color-white: rgba(255, 255, 255, 1);--color-black: rgba(0, 0, 0, 1);--color-black-transparent-40: rgba(0, 0, 0, .4);--color-black-transparent-50: rgba(0, 0, 0, .5);--color-steel-50: rgba(251, 252, 253, 1);--color-steel-100: rgba(248, 250, 252, 1);--color-steel-150: rgba(241, 244, 249, 1);--color-steel-200: rgba(234, 239, 245, 1);--color-steel-250: rgba(228, 234, 241, 1);--color-steel-300: rgba(221, 228, 238, 1);--color-steel-350: rgba(215, 223, 233, 1);--color-steel-400: rgba(209, 218, 229, 1);--color-steel-450: rgba(204, 213, 225, 1);--color-steel-500: rgba(198, 208, 220, 1);--color-steel-550: rgba(193, 203, 215, 1);--color-gray-50: rgba(225, 229, 234, 1);--color-gray-100: rgba(210, 216, 223, 1);--color-gray-150: rgba(196, 203, 212, 1);--color-gray-200: rgba(182, 190, 201, 1);--color-gray-250: rgba(168, 177, 189, 1);--color-gray-300: rgba(154, 164, 177, 1);--color-gray-350: rgba(141, 151, 165, 1);--color-gray-400: rgba(128, 138, 153, 1);--color-gray-450: rgba(115, 125, 140, 1);--color-gray-500: rgba(104, 113, 125, 1);--color-gray-550: rgba(94, 101, 110, 1);--color-gray-600: rgba(83, 88, 95, 1);--color-gray-650: rgba(72, 76, 81, 1);--color-gray-700: rgba(61, 63, 67, 1);--color-gray-750: rgba(49, 51, 53, 1);--color-gray-800: rgba(37, 38, 39, 1);--color-gray-850: rgba(25, 25, 26, 1);--color-gray-900: rgba(13, 13, 13, 1);--color-blue-50: rgba(250, 252, 255, 1);--color-blue-100: rgba(230, 240, 255, 1);--color-blue-150: rgba(204, 224, 255, 1);--color-blue-200: rgba(179, 210, 255, 1);--color-blue-250: rgba(153, 194, 255, 1);--color-blue-300: rgba(128, 179, 255, 1);--color-blue-350: rgba(102, 163, 255, 1);--color-blue-400: rgba(77, 148, 255, 1);--color-blue-450: rgba(51, 132, 255, 1);--color-blue-500: rgba(25, 117, 255, 1);--color-blue-550: rgba(23, 105, 227, 1);--color-blue-600: rgba(20, 91, 198, 1);--color-blue-650: rgba(17, 78, 170, 1);--color-blue-700: rgba(14, 65, 142, 1);--color-blue-750: rgba(12, 52, 113, 1);--color-blue-800: rgba(9, 40, 85, 1);--color-blue-850: rgba(6, 26, 57, 1);--color-blue-900: rgba(3, 13, 28, 1);--color-orange-50: rgba(255, 253, 250, 1);--color-orange-100: rgba(255, 244, 230, 1);--color-orange-150: rgba(255, 234, 204, 1);--color-orange-200: rgba(255, 223, 178, 1);--color-orange-250: rgba(255, 212, 153, 1);--color-orange-300: rgba(255, 202, 128, 1);--color-orange-350: rgba(255, 191, 102, 1);--color-orange-400: rgba(255, 180, 77, 1);--color-orange-450: rgba(255, 170, 51, 1);--color-orange-500: rgba(255, 159, 25, 1);--color-orange-550: rgba(227, 141, 23, 1);--color-orange-600: rgba(198, 124, 20, 1);--color-orange-650: rgba(170, 106, 17, 1);--color-orange-700: rgba(142, 88, 14, 1);--color-orange-750: rgba(113, 71, 12, 1);--color-orange-800: rgba(85, 53, 9, 1);--color-orange-850: rgba(57, 35, 6, 1);--color-orange-900: rgba(28, 18, 3, 1);--color-mint-50: rgba(251, 254, 253, 1);--color-mint-100: rgba(228, 251, 245, 1);--color-mint-150: rgba(200, 246, 235, 1);--color-mint-200: rgba(173, 242, 226, 1);--color-mint-250: rgba(146, 237, 216, 1);--color-mint-300: rgba(118, 233, 206, 1);--color-mint-350: rgba(91, 228, 196, 1);--color-mint-400: rgba(64, 224, 187, 1);--color-mint-450: rgba(36, 219, 177, 1);--color-mint-500: rgba(9, 215, 167, 1);--color-mint-550: rgba(8, 191, 148, 1);--color-mint-600: rgba(7, 167, 130, 1);--color-mint-650: rgba(6, 143, 111, 1);--color-mint-700: rgba(5, 119, 93, 1);--color-mint-750: rgba(4, 96, 74, 1);--color-mint-800: rgba(3, 72, 56, 1);--color-mint-850: rgba(2, 48, 37, 1);--color-mint-900: rgba(1, 24, 19, 1);--color-green-50: rgba(251, 254, 252, 1);--color-green-100: rgba(229, 248, 237, 1);--color-green-150: rgba(203, 242, 220, 1);--color-green-200: rgba(177, 235, 202, 1);--color-green-250: rgba(151, 229, 184, 1);--color-green-300: rgba(126, 222, 167, 1);--color-green-350: rgba(100, 216, 149, 1);--color-green-400: rgba(74, 209, 131, 1);--color-green-450: rgba(48, 203, 114, 1);--color-green-500: rgba(22, 196, 96, 1);--color-green-550: rgba(20, 174, 85, 1);--color-green-600: rgba(17, 152, 75, 1);--color-green-650: rgba(15, 131, 64, 1);--color-green-700: rgba(12, 109, 53, 1);--color-green-750: rgba(10, 87, 43, 1);--color-green-800: rgba(7, 65, 32, 1);--color-green-850: rgba(5, 44, 21, 1);--color-green-900: rgba(2, 22, 11, 1);--color-salad-50: rgba(252, 254, 250, 1);--color-salad-100: rgba(242, 252, 232, 1);--color-salad-150: rgba(228, 248, 208, 1);--color-salad-200: rgba(215, 245, 185, 1);--color-salad-250: rgba(202, 242, 162, 1);--color-salad-300: rgba(188, 238, 138, 1);--color-salad-350: rgba(175, 235, 115, 1);--color-salad-400: rgba(162, 232, 92, 1);--color-salad-450: rgba(148, 228, 68, 1);--color-salad-500: rgba(135, 225, 45, 1);--color-salad-550: rgba(120, 200, 40, 1);--color-salad-600: rgba(105, 175, 35, 1);--color-salad-650: rgba(90, 150, 30, 1);--color-salad-700: rgba(75, 125, 25, 1);--color-salad-750: rgba(60, 100, 20, 1);--color-salad-800: rgba(45, 75, 15, 1);--color-salad-850: rgba(30, 50, 10, 1);--color-salad-900: rgba(15, 25, 5, 1);--color-red-50: rgba(255, 251, 250, 1);--color-red-100: rgba(253, 234, 232, 1);--color-red-150: rgba(250, 213, 209, 1);--color-red-200: rgba(248, 192, 187, 1);--color-red-250: rgba(246, 171, 164, 1);--color-red-300: rgba(243, 149, 141, 1);--color-red-350: rgba(241, 128, 118, 1);--color-red-400: rgba(239, 107, 96, 1);--color-red-450: rgba(236, 86, 73, 1);--color-red-500: rgba(234, 65, 50, 1);--color-red-550: rgba(208, 58, 44, 1);--color-red-600: rgba(182, 51, 39, 1);--color-red-650: rgba(156, 43, 33, 1);--color-red-700: rgba(130, 36, 28, 1);--color-red-750: rgba(104, 29, 22, 1);--color-red-800: rgba(78, 22, 17, 1);--color-red-850: rgba(52, 14, 11, 1);--color-red-900: rgba(26, 7, 6, 1);--color-violet-50: rgba(251, 250, 255, 1);--color-violet-100: rgba(240, 235, 255, 1);--color-violet-150: rgba(225, 215, 255, 1);--color-violet-200: rgba(210, 195, 255, 1);--color-violet-250: rgba(195, 175, 255, 1);--color-violet-300: rgba(181, 156, 255, 1);--color-violet-350: rgba(166, 136, 255, 1);--color-violet-400: rgba(151, 116, 255, 1);--color-violet-450: rgba(136, 96, 255, 1);--color-violet-500: rgba(121, 76, 255, 1);--color-violet-550: rgba(108, 68, 227, 1);--color-violet-600: rgba(94, 59, 198, 1);--color-violet-650: rgba(81, 51, 170, 1);--color-violet-700: rgba(67, 42, 142, 1);--color-violet-750: rgba(54, 34, 113, 1);--color-violet-800: rgba(40, 25, 85, 1);--color-violet-850: rgba(27, 17, 57, 1);--color-violet-900: rgba(13, 8, 28, 1);--color-pink-50: rgba(254, 250, 254, 1);--color-pink-100: rgba(252, 231, 251, 1);--color-pink-150: rgba(250, 207, 246, 1);--color-pink-200: rgba(247, 183, 242, 1);--color-pink-250: rgba(244, 159, 237, 1);--color-pink-300: rgba(242, 135, 233, 1);--color-pink-350: rgba(239, 111, 228, 1);--color-pink-400: rgba(236, 87, 224, 1);--color-pink-450: rgba(234, 63, 219, 1);--color-pink-500: rgba(231, 39, 215, 1);--color-pink-550: rgba(205, 35, 191, 1);--color-pink-600: rgba(180, 30, 167, 1);--color-pink-650: rgba(154, 26, 143, 1);--color-pink-700: rgba(128, 22, 119, 1);--color-pink-750: rgba(103, 17, 96, 1);--color-pink-800: rgba(77, 13, 72, 1);--color-pink-850: rgba(51, 9, 48, 1);--color-pink-900: rgba(26, 4, 24, 1);--color-yellow-50: rgba(255, 254, 250, 1);--color-yellow-100: rgba(253, 252, 231, 1);--color-yellow-150: rgba(251, 248, 208, 1);--color-yellow-200: rgba(248, 245, 184, 1);--color-yellow-250: rgba(246, 242, 160, 1);--color-yellow-300: rgba(244, 238, 137, 1);--color-yellow-350: rgba(242, 235, 113, 1);--color-yellow-400: rgba(239, 232, 89, 1);--color-yellow-450: rgba(237, 228, 66, 1);--color-yellow-500: rgba(235, 225, 42, 1);--color-yellow-550: rgba(209, 200, 37, 1);--color-yellow-600: rgba(183, 175, 33, 1);--color-yellow-650: rgba(157, 150, 28, 1);--color-yellow-700: rgba(131, 125, 23, 1);--color-yellow-750: rgba(104, 100, 19, 1);--color-yellow-800: rgba(78, 75, 14, 1);--color-yellow-850: rgba(52, 50, 9, 1);--color-yellow-900: rgba(26, 25, 5, 1);--color-top-3: #3198DD;--color-top-10: #21936C;--color-top-30: #1ABC9C;--color-top-50: #A6E0A3;--color-top-100: #C7D7D7;--color-top-10000: #FCC94A}:root{--top-line-heihgt: 1.36;--top-page-width: 1180px;--top-padding-1: 4px;--top-padding-2: 8px;--top-padding-3: 12px;--top-padding-4: 16px;--top-padding-5: 20px;--top-padding-6: 24px;--top-padding-7: 28px;--top-padding-8: 32px;--top-padding-9: 36px;--top-padding-10: 40px;--top-padding-11: 44px;--top-padding-12: 48px;--top-gap-1: 4px;--top-gap-2: 8px;--top-gap-3: 12px;--top-gap-4: 16px;--top-gap-5: 20px;--top-gap-6: 24px;--top-gap-7: 28px;--top-gap-8: 32px;--top-gap-9: 36px;--top-gap-10: 40px;--top-gap-11: 44px;--top-gap-12: 48px;--top-radius-1: 4px;--top-radius-2: 8px;--top-radius-3: 12px;--top-radius-4: 16px;--top-radius-5: 20px;--top-radius-6: 24px;--top-radius-7: 28px;--top-radius-8: 32px;--top-radius-9: 36px;--top-radius-10: 40px;--top-radius-11: 44px;--top-radius-12: 48px}.top-comment{color:var(--color-gray-350);font-size:12px}:root{--top-formsCaption-offset: 16px}.top-formsCaptionWrapper{padding-top:20px}.top-formsCaption{pointer-events:none;width:calc(100% - var(--top-forms-padding) - var(--top-icon-both-width) - var(--top-forms_clear-width) - var(--top-select_arrow-width));padding:0 var(--top-forms-padding);color:var(--color-placeholder);white-space:nowrap;text-overflow:ellipsis;transform:translate(var(--top-icon-both-width));position:absolute;overflow:hidden;transition:.1s}.top-error~.top-formsCaption{transition:.1s .1s}.top-formsCaption *{pointer-events:auto}.top-formsCaptionWrapper>input:not([readonly]):focus~.top-formsCaption,.top-formsCaptionWrapper>input:not(:placeholder-shown)~.top-formsCaption,.top-formsCaptionWrapper>textarea:not(:placeholder-shown)~.top-formsCaption,.top-formsCaptionWrapper.top-select>.top-formsCaption,.top-formsCaptionWrapper.top-inputRange>.top-formsCaption,.top-formsCaptionWrapper-always>.top-formsCaption{width:100%;padding:0;color:var(--color-placeholder-active);font-size:11px;transform:translateY(calc(-1em - var(--top-formsCaption-offset)));transition:.1s}.ui-tooltip{pointer-events:none;box-shadow:0 6px 18px #0e152f21,0 -2px 6px #0e152f08;border-radius:8px;border:none;background:var(--content-background-color);width:max-content;padding:16px;margin:0 18px;font-size:13px}.ui-tooltip img{margin:12px 0 0}.ui-tooltip ul{margin-left:24px}button,input,textarea,select{border:1px solid var(--top-forms-border-color);color:var(--color-text);font-size:var(--top-font-size);font-family:inherit}::placeholder{color:var(--color-placeholder)}[contenteditable][placeholder]:empty:before{content:attr(placeholder);color:var(--color-text-secondary)}.top-forms-optionWrapper{cursor:pointer;padding:8px 0;color:var(--color-text);line-height:1.3;display:inline-flex;align-items:flex-start;gap:4px}.top-forms-option{cursor:pointer;padding:0;margin:3px;display:inline-flex;flex-shrink:0;appearance:none;-webkit-appearance:none}.top-forms-focusable:focus-visible,.top-focus{outline:calc(var(--top-forms-border-width) * 2) solid var(--top-forms-option-color);outline-offset:2px;position:relative;z-index:1;transition:border-color .15s}.top-forms-focusable:hover,.top-forms-focusable:focus,.top-focus:hover,.top-focus:focus,.top-input:hover>.top-input_input,.top-select:hover>.top-select_select{--top-forms-border-color: var(--top-forms-border-color-hover);--top-forms-background-color: var(--top-forms-background-color-hover)}[contenteditable]:focus-visible,.top-selector-multiselect:focus-within{outline:2px solid var(--color-blue-100)}:root{--top-font-size: 14px;--top-forms-radius: 8px;--top-forms-border-width: 1px;--top-style_outline-color: transparent;--top-forms-base-height_xs: 24px;--top-forms-base-height_s: 32px;--top-forms-base-height_l: 36px;--top-forms-base-height_xl: 40px;--top-forms-base-height: var(--top-forms-base-height_s);--top-forms-padding: 8px;--top-forms-padding_l: 12px;--top-forms-padding_xl: 16px;--top-forms-option-height: 24px;--top-forms-option-color: var(--color-primary);--top-forms-option-color-hover: var(--color-primary-2);--top-select_arrow-width: 0px;--top-forms_clear-width: 0px}.top-size_xs{--top-forms-base-height: var(--top-forms-base-height_xs)}.top-size_s{--top-forms-base-height: var(--top-forms-base-height_s)}.top-size_l{--top-forms-base-height: var(--top-forms-base-height_l)}.top-size_xl{--top-forms-base-height: var(--top-forms-base-height_xl)}.top-input_input,.top-textarea_textarea,.top-editArea_form,.top-select_select{box-sizing:border-box;border-radius:var(--top-forms-radius);border:var(--top-forms-border-width) solid var(--top-forms-border-color);display:inline-flex;appearance:none;-webkit-appearance:none}.top-select_select{padding-right:calc(var(--top-forms-padding) + var(--top-forms_clear-width) + var(--top-select_arrow-width));padding-left:max(var(--top-forms-padding),var(--top-icon-both-width))}.top-select{position:relative}.top-select[data-top-icon]:before,.top-select[data-top-icon2]:after{position:absolute;z-index:3}.top-select[data-top-icon][data-top-icon2]:after{left:calc(var(--top-icon-width))}.top-cleaner[data-top-icon]{--top-icon-size: 20px;--top-icon-width: 20px;--top-icon-color: var(--color-text-secondary);cursor:pointer;border-radius:50%;width:30px;height:24px;margin-left:-34px;transform:translate(calc(0px - var(--top-forms-border-width) - var(--top-select_arrow-width)));display:flex;align-items:center;justify-content:center;position:relative;z-index:1}.top-cleaner[data-top-icon]:hover{--top-icon-color: var(--color-text-secondary-2)}:root{--top-icon-size: 24px;--top-icon-width: 0px;--top-icon2-size: 24px;--top-icon2-width: 0px;--top-icon-both-width: 0px}[data-top-icon]{--top-icon-width: calc(var(--top-icon-size) + var(--top-forms-padding));--top-icon-color: inherit}[data-top-icon2]{--top-icon2-width: calc(var(--top-icon2-size) + 8px);--top-icon2-color: inherit}[data-top-icon=""]{--top-icon-width: 0px}[data-top-icon2=""]{--top-icon2-width: 0px}[data-top-icon]:before,[data-top-icon2]:after{pointer-events:none;content:attr(data-top-icon);border-radius:var(--top-forms-radius);width:var(--top-icon-width);color:var(--top-icon-color);font-family:Topvisor-2;font-size:var(--top-icon-size);font-weight:400;line-height:1;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}[data-top-icon2]:after{content:attr(data-top-icon2);width:var(--top-icon2-width);color:var(--top-icon2-color);font-size:var(--top-icon2-size)}[data-top-icon],[data-top-icon2]{--top-icon-both-width: calc(var(--top-icon-width) + var(--top-icon2-width))}[data-top-icon=]:before{font-family:Topvisor}.top-as-a{cursor:pointer;color:var(--color-text-link)}.top-as-a:hover{text-decoration:underline}.top-ellipsis{max-height:100%;text-overflow:ellipsis;overflow:hidden;line-height:1.23;flex-grow:1}.top-ellipsis2,.top-ellipsis3{max-width:fit-content;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.top-ellipsis3{-webkit-line-clamp:3}.top-hidden{display:none!important}.top-unvisible{width:0;height:0;overflow:hidden;position:absolute;-webkit-appearance:none;appearance:none;border:none}.top-unvisible:focus-visible{outline:none}.top-disabled{pointer-events:none;-webkit-user-select:none;user-select:none}:disabled:not(option):not(optgroup):not(.top-forms-option),:disabled~.top-formsCaption,.top-disabled[data-top-icon]:before,.top-disabled[data-top-icon2]:after{opacity:.5;filter:grayscale(100%)}.top-error,.top-error::placeholder,.top-error:before{--top-forms-border-color: var(--color-negative);border-color:var(--color-negative)}.top-error{--top-icon-color: var(--color-negative);color:var(--color-negative)}.top-error~.top-formsCaption{color:var(--color-negative)}.top-warning{--top-icon-color: var(--color-orange-500);color:var(--color-orange-500)}input.top-error,textarea.top-error,select.top-error,.top-editArea_form.top-error{animation:top-error .8s}@keyframes top-error{0%{outline-offset:10px;outline:3px solid transparent}50%{outline:3px solid var(--color-red-100);outline-offset:2px}to{outline:3px solid transparent;outline-offset:2px}}@media only screen and (min-width: 900px){.top-only-mobile{display:none!important}}@media only screen and (max-width: 900px){.top-only-pc{display:none!important}}html:not([lang=ru]) .top-only-ru,html:not([lang=en]) .top-only-en{display:none!important}html[data-is_admin="0"] .top-only-admin{display:none!important}.top-select_arrow{--top-select_arrow-color: var(--color-gray-600);--top-select_arrow-size: 12px;--top-select_arrow-width: 24px;background-image:url("data:image/svg+xml,%3Csvg width='16' height='9' viewBox='0 0 16 9' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M14.293 0.29269L8 6.5857L1.70704 0.29269C1.31679 -0.0975633 0.682937 -0.0975633 0.292687 0.29269C-0.0975624 0.682943 -0.0975624 1.31656 0.292687 1.70682L7.29294 8.70713C7.68343 9.09762 8.31657 9.09762 8.70706 8.70713L15.7073 1.70682C16.0976 1.31656 16.0976 0.682943 15.7073 0.29269C15.3171 -0.0975633 14.6832 -0.0975633 14.293 0.29269Z' fill='%23808A99'/%3E%3C/svg%3E");background-size:14px;background-position:calc(100% - var(--top-forms-padding)) 50%;background-repeat:no-repeat;padding-right:32px}.top-select_arrow~.top-cleaner{--top-select_arrow-width: 24px}
|
package/assets/forms.css
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
.top-avatar{display:flex;height:var(--9f3c0670);left:0;position:relative;top:0;width:var(--9f3c0670)}.top-avatar_image{border-radius:50%;height:100%;width:100%}.top-avatar_status{background-color:var(--color-green-500);border:2px solid var(--content-background-color);border-radius:50%;bottom:0;height:25%;position:absolute;right:0;width:25%}.top-button{cursor:pointer;box-sizing:border-box;box-shadow:var(--top-button-box-shadow);border-radius:var(--top-forms-radius);border:var(--top-forms-border-width) solid var(--top-forms-border-color);background-color:var(--top-button-background-color);height:var(--top-forms-base-height);padding:0 var(--top-forms-padding);color:var(--top-button-color);line-height:1;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;transition:background-color .15s,border-color .15s,box-shadow .15s}.top-button:hover{box-shadow:var(--top-button-box-shadow-hover);background-color:var(--top-button-background-color-hover)}.top-button:active{box-shadow:var(--top-button-box-shadow-active);background-color:var(--top-button-background-color-active)}.top-button.top-active{box-shadow:var(--top-button-box-shadow-selected);background-color:var(--top-button-background-color-selected)}.top-button.top-button-progress{cursor:help;box-shadow:inset #00000080 0 0 64px;background-image:linear-gradient(-45deg,rgba(255,255,255,.2) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.2) 50%,rgba(255,255,255,.2) 75%,transparent 75%,transparent);background-size:32px 32px;animation:_progress_tkkz7_1 1s linear infinite}@keyframes _progress_tkkz7_1{0%{background-position-x:0px}to{background-position-x:32px}}a.top-button,button.top-button{min-width:100px;text-decoration:none}a.top-button,a.top-button:hover{min-width:var(--top-forms-base-height);text-decoration:none}.top-button[data-top-icon]:not(:empty),.top-button[data-top-icon2]:not(:empty){justify-content:flex-start;text-align:left}.top-button[data-top-icon]{padding-left:0}.top-button[data-top-icon2]{padding-right:var(--top-select_arrow-width)}.top-button[data-top-icon2]:after{margin-left:auto}.top-button:empty{min-width:var(--top-forms-base-height)}.top-button[data-top-icon]:empty,.top-button[data-top-icon2]:empty{padding:0}.top-button.top-color_blue{--top-button-background-color: var(--color-blue-500)}.top-button.top-color_green{--top-button-background-color: var(--color-green-500)}.top-button.top-color_orange{--top-button-background-color: var(--color-orange-500)}.top-button.top-color_red{--top-button-background-color: var(--color-red-500)}.top-button.top-color_pink{--top-button-background-color: var(--color-pink-500)}.top-button.top-color_theme{--top-button-box-shadow-hover: none;--top-button-box-shadow-active: none;--top-button-box-shadow-selected: none;--top-icon-color: var(--color-text-2);--top-icon2-color: var(--color-text-2);--top-button-color: var(--color-text-1);--top-button-background-color: transparent;--top-button-background-color-hover: var(--color-secondary-opacity);--top-button-background-color-active: var(--color-secondary-2-opacity);--top-button-background-color-selected: var(--color-secondary-2-opacity)}.top-button.top-color_theme.top-active{--top-icon-color: var(--color-text-2)}.top-button.top-style_outline{--top-button-box-shadow: none;--top-button-box-shadow-hover: none;--top-button-box-shadow-active: none;--top-button-box-shadow-selected: none;--top-forms-border-color: var(--top-style_outline-color);--top-style_outline-color: var(--color-steel-400);--top-button-color: var(--top-style_outline-color);--top-button-background-color: var(--content-background-color);--top-button-background-color-hover: var(--color-theme-100);--top-button-background-color-active: var(--color-theme-150);--top-button-background-color-selected: var(--color-theme-125);--top-forms-border-width: 1px}.top-button.top-style_outline.top-color_theme{--top-button-color: var(--color-text)}.top-button.top-style_outline.top-color_blue{--top-style_outline-color: var(--color-blue-500)}.top-button.top-style_outline.top-color_green{--top-style_outline-color: var(--color-green-500)}.top-button.top-style_outline.top-color_orange{--top-style_outline-color: var(--color-orange-500)}.top-button.top-style_outline.top-color_red{--top-style_outline-color: var(--color-red-500)}.top-button.top-style_outline.top-color_pink{--top-style_outline-color: var(--color-pink-500)}.top-button.top-style_soft{--top-shadow-darken: none;--top-shadow-darken-2: none;--top-shadow-darken-3: none;--top-button-color: var(--color-text);--top-button-background-color: var(--color-secondary-opacity);--top-button-background-color-hover: var(--color-secondary-2-opacity);--top-button-background-color-active: var(--color-secondary-3-opacity);--top-button-background-color-selected: var(--color-secondary-3-opacity)}.top-button.top-style_soft.top-color_blue{--top-button-color: var(--color-blue-550)}.top-button.top-style_soft.top-color_orange{--top-button-color: var(--color-orange-500)}.top-button.top-style_soft.top-color_green{--top-button-color: var(--color-green-500)}.top-button.top-style_soft.top-color_red{--top-button-color: var(--color-red-500)}.top-button.top-style_soft.top-color_pink{--top-button-color: var(--color-pink-500)}.top-button{--top-button-color: var(--color-white);--top-button-background-color: transparent;--top-button-background-color-hover: var(--top-button-background-color);--top-button-background-color-active: var(--top-button-background-color-hover);--top-button-background-color-selected: var(--top-button-background-color-hover);--top-button-box-shadow: none;--top-button-box-shadow-hover: var(--top-shadow-darken-2);--top-button-box-shadow-active: var(--top-shadow-darken-3);--top-button-box-shadow-selected: var(--top-shadow-darken-3);--top-forms-border-width: 0px;--top-icon-width: calc(var(--top-icon-size) + var(--top-forms-padding));--top-icon2-width: calc(var(--top-icon2-size) + var(--top-forms-padding))}.top-button.top-size_l{--top-forms-padding: var(--top-forms-padding_l);--top-forms-base-height: var(--top-forms-base-height_l)}.top-button.top-size_xl{--top-forms-padding: var(--top-forms-padding_xl);--top-forms-base-height: var(--top-forms-base-height_xl)}.top-forms-optionLabel{flex-grow:1}.top-forms-optionLabel_title{min-height:var(--top-forms-option-height);display:flex;align-items:center}.top-forms-optionLabel_title-disabled{color:var(--color-text-3)}.top-forms-optionLabel_description{color:var(--color-text-2);font-size:.85em;line-height:var(--top-forms-option-height)}.top-forms-optionLabel_description-disabled{color:var(--color-text-3)}.top-checkbox{cursor:pointer;display:inline-flex}.top-checkbox_input{cursor:inherit;border-radius:4px;background:var(--content-background-color);border:1px solid var(--top-forms-border-color);width:calc(var(--top-forms-option-height) - 3px * 2);height:calc(var(--top-forms-option-height) - 3px * 2)}.top-checkbox_input:before{content:" ";color:#fff;font-family:Topvisor-2;font-size:16px}.top-checkbox_input:hover{border-color:var(--top-forms-option-color);background:var(--color-theme-50)}.top-checkbox_input:checked,.top-checkbox_input:indeterminate{border-color:var(--top-forms-option-color);background:var(--top-forms-option-color)}.top-checkbox_input:checked:before{content:""}.top-checkbox_input:indeterminate:before{content:""}.top-checkbox_input:checked:hover,.top-checkbox_input:indeterminate:hover{border-color:var(--top-forms-option-color-hover);background:var(--top-forms-option-color-hover)}.top-checkbox_input:disabled{border-color:var(--color-line-1-opacity);background:var(--color-theme-50)}.top-checkbox_input:checked:disabled,.top-checkbox_input:indeterminate:disabled{border-color:transparent;background:var(--color-theme-400)}.top-checkbox_input.top-error{border-color:var(--color-negative)}.top-checkbox_input.top-error:hover{border-color:var(--color-negative-2)}.top-checkbox_input:checked.top-error,.top-checkbox_input:indeterminate.top-error{background:var(--color-negative)}.top-checkbox_input:checked.top-error:hover,.top-checkbox_input:indeterminate.top-error:hover{background:var(--color-negative-2)}.top-hint{--top-icon-size: 16px;--top-icon-width: var(--top-icon-size);border-radius:50%;background:var(--content-background-color);padding:1px;color:var(--color-text-4);line-height:1;z-index:1;pointer-events:all}.top-hint:hover{color:var(--color-text-3)}.top-input{--top-forms_clear-width: 0px;width:180px;position:relative;display:inline-flex;align-items:center;gap:var(--top-gap-1)}.top-input_input{background:var(--top-forms-background-color);height:var(--top-forms-base-height);padding:0;padding-right:max(var(--top-forms-padding),calc(var(--top-icon2-width) + var(--top-forms_clear-width)));padding-left:max(var(--top-forms-padding),var(--top-icon-width))}.top-input_input:hover{background:var(--top-forms-background-color-hover)}.top-input_input:focus{outline-color:var(--color-theme-75);outline-offset:0}.top-input[data-top-icon]:before,.top-input[data-top-icon2]:after{--top-icon-color: var(--color-text-secondary);--top-icon2-color: var(--color-text-secondary);position:absolute;z-index:3}.top-input[data-top-icon]:before{left:0}.top-input[data-top-icon2]:after{right:0}.top-input-withCleaner{--top-forms_clear-width: 24px}.top-input_cleaner{--top-icon-size: 20px;--top-icon-width: 20px;--top-icon-color: var(--color-text-3);cursor:pointer;border-radius:50%;width:24px;height:24px;position:absolute;right:calc(var(--top-forms-border-width) + max(var(--top-icon2-width),var(--top-forms-padding) / 2));z-index:1;display:flex;align-items:center;justify-content:center}.top-input_cleaner:hover{--top-icon-color: var(--color-text-2)}.top-input_input{width:50%;flex-grow:1}.top-input-datepicker{width:calc(105px + var(--top-icon-width) + var(--top-icon2-width))}.top-input_input-date{opacity:0;position:absolute;inset:0;z-index:-1}.top-input_input-date::-webkit-inner-spin-button{display:none}.top-input_input-date::-webkit-calendar-picker-indicator{opacity:0}.top-inputRange{max-width:320px;vertical-align:baseline;display:inline-flex;gap:8px}.top-inputRange_dash{height:var(--top-forms-base-height);color:var(--color-text-4);align-self:flex-end;display:inline-flex;align-items:center}.top-inputRange>.top-input{flex-grow:1}:root{--top-radio-background-color: var(--content-background-color);--top-radio-background-color-hover: var(--top-radio-background-color);--top-radio-background-color-active: var(--top-radio-background-color)}.top-radio{cursor:pointer}.top-radio_input{border-radius:50%;background:var(--content-background-color);border:1px solid var(--top-forms-border-color);width:calc(var(--top-forms-option-height) - 3px * 2);height:calc(var(--top-forms-option-height) - 3px * 2)}.top-radio_input:hover{border-color:var(--top-forms-option-color);background:var(--color-theme-50)}.top-radio_input:checked{border-color:var(--top-forms-option-color);border-width:5px}.top-radio_input:checked:hover{border-color:var(--top-forms-option-color-hover)}.top-radio_input:disabled{border-color:var(--color-line-1-opacity);background:var(--color-theme-50)}.top-radio_input:checked:disabled{border-color:var(--color-theme-400)}.top-radio_input.top-error{border-color:var(--color-negative)}.top-radio_input.top-error:hover{border-color:var(--color-negative-2)}.top-checkboxSwitcher{cursor:pointer;display:inline-flex;gap:4px}.top-checkboxSwitcher_input{border-radius:9px;border:none;background:var(--color-theme-100);width:36px;height:18px;position:relative}.top-checkboxSwitcher_input:before{content:"";border-radius:50%;background:var(--color-white);width:12px;height:12px;margin:3px;position:absolute;top:0;left:0;transition:left .1s}.top-checkboxSwitcher_input:hover{background:var(--color-theme-150)}.top-checkboxSwitcher_input:checked{background:var(--top-forms-option-color)}.top-checkboxSwitcher_input:checked:hover{background:var(--top-forms-option-color-hover)}.top-checkboxSwitcher_input:checked:before{left:50%}.top-checkboxSwitcher_input:disabled{background:var(--color-theme-400)}.top-checkboxSwitcher_input.top-error{background:var(--color-negative)}.top-checkboxSwitcher_input.top-error:hover{background:var(--color-negative-2)}.top-textarea{width:180px;display:inline-flex;align-items:center;position:relative}.top-textarea_textarea{background:var(--top-forms-background-color);width:100%;padding:var(--top-forms-padding);resize:none}.top-textarea_textarea:hover{background:var(--top-forms-background-color-hover)}.top-textarea_textarea:focus{outline-color:var(--color-theme-75);outline-offset:0px}.top-textarea_textarea.top-textarea_textarea-expandable{width:100%;height:100%;overflow:hidden;position:absolute;top:0;left:0}.top-textarea_pseudoContent{box-sizing:border-box;min-height:var(--c35baa86);padding:var(--top-forms-padding);font-size:14px;white-space:pre-wrap;overflow-wrap:anywhere;pointer-events:none;opacity:0;z-index:-1}.top-textarea_hint{position:absolute;top:2px;right:2px}.top-select{--top-icon-color: var(--color-text-3);--top-icon2-color: var(--color-text-2);align-items:center;width:180px;max-width:100%;display:inline-flex}.top-select-error{--top-icon-color: var(--color-negative);--top-icon2-color: var(--color-negative)}.top-select_select{background-color:var(--top-forms-background-color);padding-left:var(--top-forms-padding);text-indent:clamp(0px,calc(var(--top-icon-both-width) - var(--top-forms-padding)),calc(var(--top-icon-both-width) - var(--top-forms-padding)));width:100%;height:var(--top-forms-base-height);text-overflow:ellipsis;white-space:nowrap;flex-grow:1;overflow:hidden}.top-select_select:focus{outline-color:var(--color-theme-75);outline-offset:0}.top-select_select:disabled{background:var(--color-theme-50)}.top-select optgroup{color:var(--color-text-1);font-style:normal}.top-select option{background:var(--content-background-color);color:var(--color-text-1)}@-moz-document url-prefix(){.top-select_select{text-indent:calc(clamp(0px,calc(var(--top-icon-both-width) - var(--top-forms-padding)),calc(var(--top-icon-both-width) - var(--top-forms-padding)))/2)}}@media only screen and (min-width: 900px){.top-changer{cursor:pointer;border-radius:100%;width:0;transform:translate(-44px);color:var(--color-text-secondary-2);font-size:16px;line-height:1;display:none;z-index:2;order:4}.top-changer:hover{color:var(--color-primary)}.top-changer:after{content:"";background-color:var(--top-forms-background-color);font-family:Topvisor-2}*:hover>.top-changer{display:block}}
|
|
1
|
+
.top-avatar{display:flex;height:var(--4ca8e42a);left:0;position:relative;top:0;width:var(--4ca8e42a)}.top-avatar_image{border-radius:50%;height:100%;width:100%}.top-avatar_status{background-color:var(--color-green-500);border:2px solid var(--content-background-color);border-radius:50%;bottom:0;height:25%;position:absolute;right:0;width:25%}.top-button{cursor:pointer;box-sizing:border-box;box-shadow:var(--top-button-box-shadow);border-radius:var(--top-forms-radius);border:var(--top-forms-border-width) solid var(--top-forms-border-color);background-color:var(--top-button-background-color);height:var(--top-forms-base-height);padding:0 var(--top-forms-padding);color:var(--top-button-color);line-height:1;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;transition:background-color .15s,border-color .15s,box-shadow .15s}.top-button:hover{box-shadow:var(--top-button-box-shadow-hover);background-color:var(--top-button-background-color-hover)}.top-button:active{box-shadow:var(--top-button-box-shadow-active);background-color:var(--top-button-background-color-active)}.top-button.top-active{box-shadow:var(--top-button-box-shadow-selected);background-color:var(--top-button-background-color-selected)}.top-button.top-button-progress{cursor:help;box-shadow:inset #00000080 0 0 64px;background-image:linear-gradient(-45deg,rgba(255,255,255,.2) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.2) 50%,rgba(255,255,255,.2) 75%,transparent 75%,transparent);background-size:32px 32px;animation:_progress_1f1nw_1 1s linear infinite}@keyframes _progress_1f1nw_1{0%{background-position-x:0px}to{background-position-x:32px}}a.top-button,button.top-button{min-width:100px;text-decoration:none}a.top-button,a.top-button:hover{min-width:var(--top-forms-base-height);text-decoration:none}.top-button[data-top-icon]:not(:empty),.top-button[data-top-icon2]:not(:empty){justify-content:flex-start;text-align:left}.top-button[data-top-icon]{padding-left:0}.top-button[data-top-icon2]{padding-right:var(--top-select_arrow-width)}.top-button[data-top-icon2]:after{margin-left:auto}.top-button:empty{min-width:var(--top-forms-base-height)}.top-button[data-top-icon]:empty,.top-button[data-top-icon2]:empty{padding:0}.top-button.top-color_blue{--top-button-background-color: var(--color-blue-500)}.top-button.top-color_green{--top-button-background-color: var(--color-green-500)}.top-button.top-color_orange{--top-button-background-color: var(--color-orange-500)}.top-button.top-color_red{--top-button-background-color: var(--color-red-500)}.top-button.top-color_pink{--top-button-background-color: var(--color-pink-500)}.top-button.top-color_theme{--top-button-box-shadow-hover: none;--top-button-box-shadow-active: none;--top-button-box-shadow-selected: none;--top-icon-color: var(--color-text-2);--top-icon2-color: var(--color-text-2);--top-button-color: var(--color-text-1);--top-button-background-color: transparent;--top-button-background-color-hover: var(--color-secondary-opacity);--top-button-background-color-active: var(--color-secondary-2-opacity);--top-button-background-color-selected: var(--color-secondary-2-opacity)}.top-button.top-color_theme.top-active{--top-icon-color: var(--color-text-2)}.top-button.top-style_outline{--top-button-box-shadow: none;--top-button-box-shadow-hover: none;--top-button-box-shadow-active: none;--top-button-box-shadow-selected: none;--top-forms-border-color: var(--top-style_outline-color);--top-style_outline-color: var(--color-steel-400);--top-button-color: var(--top-style_outline-color);--top-button-background-color: var(--content-background-color);--top-button-background-color-hover: var(--color-theme-100);--top-button-background-color-active: var(--color-theme-150);--top-button-background-color-selected: var(--color-theme-125);--top-forms-border-width: 1px}.top-button.top-style_outline.top-color_theme{--top-button-color: var(--color-text)}.top-button.top-style_outline.top-color_blue{--top-style_outline-color: var(--color-blue-500)}.top-button.top-style_outline.top-color_green{--top-style_outline-color: var(--color-green-500)}.top-button.top-style_outline.top-color_orange{--top-style_outline-color: var(--color-orange-500)}.top-button.top-style_outline.top-color_red{--top-style_outline-color: var(--color-red-500)}.top-button.top-style_outline.top-color_pink{--top-style_outline-color: var(--color-pink-500)}.top-button.top-style_soft{--top-shadow-darken: none;--top-shadow-darken-2: none;--top-shadow-darken-3: none;--top-button-color: var(--color-text);--top-button-background-color: var(--color-secondary-opacity);--top-button-background-color-hover: var(--color-secondary-2-opacity);--top-button-background-color-active: var(--color-secondary-3-opacity);--top-button-background-color-selected: var(--color-secondary-3-opacity)}.top-button.top-style_soft.top-color_blue{--top-button-color: var(--color-blue-550)}.top-button.top-style_soft.top-color_orange{--top-button-color: var(--color-orange-500)}.top-button.top-style_soft.top-color_green{--top-button-color: var(--color-green-500)}.top-button.top-style_soft.top-color_red{--top-button-color: var(--color-red-500)}.top-button.top-style_soft.top-color_pink{--top-button-color: var(--color-pink-500)}.top-button.top-style_transparent{--top-shadow-darken: none;--top-shadow-darken-2: none;--top-shadow-darken-3: none;--top-button-color: var(--color-text);--top-button-background-color: transparent;--top-button-background-color-hover: transparent;--top-button-background-color-active: transparent;--top-button-background-color-selected: var(--color-steel-200)}.top-button.top-style_transparent:hover{opacity:.8}.top-button.top-style_transparent.top-color_blue{--top-button-color: var(--color-blue-450)}.top-button.top-style_transparent.top-color_green{--top-button-color: var(--color-green-450)}.top-button.top-style_transparent.top-color_orange{--top-button-color: var(--color-orange-450)}.top-button.top-style_transparent.top-color_red{--top-button-color: var(--color-red-450)}.top-button.top-style_transparent.top-color_pink{--top-button-color: var(--color-pink-450)}.top-button{--top-button-color: var(--color-white);--top-button-background-color: transparent;--top-button-background-color-hover: var(--top-button-background-color);--top-button-background-color-active: var(--top-button-background-color-hover);--top-button-background-color-selected: var(--top-button-background-color-hover);--top-button-box-shadow: none;--top-button-box-shadow-hover: var(--top-shadow-darken-2);--top-button-box-shadow-active: var(--top-shadow-darken-3);--top-button-box-shadow-selected: var(--top-shadow-darken-3);--top-forms-border-width: 0px;--top-icon-width: calc(var(--top-icon-size) + var(--top-forms-padding));--top-icon2-width: calc(var(--top-icon2-size) + var(--top-forms-padding))}.top-button.top-size_l{--top-forms-padding: var(--top-forms-padding_l);--top-forms-base-height: var(--top-forms-base-height_l)}.top-button.top-size_xl{--top-forms-padding: var(--top-forms-padding_xl);--top-forms-base-height: var(--top-forms-base-height_xl)}.top-forms-optionLabel{flex-grow:1}.top-forms-optionLabel_title{min-height:var(--top-forms-option-height);display:flex;align-items:center}.top-forms-optionLabel_title-disabled{color:var(--color-text-3)}.top-forms-optionLabel_description{color:var(--color-text-2);font-size:.85em;line-height:var(--top-forms-option-height)}.top-forms-optionLabel_description-disabled{color:var(--color-text-3)}.top-checkbox{cursor:pointer;display:inline-flex}.top-checkbox_input{cursor:inherit;border-radius:4px;background:var(--content-background-color);border:1px solid var(--top-forms-border-color);width:calc(var(--top-forms-option-height) - 3px * 2);height:calc(var(--top-forms-option-height) - 3px * 2)}.top-checkbox_input:before{content:" ";color:#fff;font-family:Topvisor-2;font-size:16px}.top-checkbox_input:hover{border-color:var(--top-forms-option-color);background:var(--color-theme-50)}.top-checkbox_input:checked,.top-checkbox_input:indeterminate{border-color:var(--top-forms-option-color);background:var(--top-forms-option-color)}.top-checkbox_input:checked:before{content:""}.top-checkbox_input:indeterminate:before{content:""}.top-checkbox_input:checked:hover,.top-checkbox_input:indeterminate:hover{border-color:var(--top-forms-option-color-hover);background:var(--top-forms-option-color-hover)}.top-checkbox_input:disabled{border-color:var(--color-line-1-opacity);background:var(--color-theme-50)}.top-checkbox_input:checked:disabled,.top-checkbox_input:indeterminate:disabled{border-color:transparent;background:var(--color-theme-400)}.top-checkbox_input.top-error{border-color:var(--color-negative)}.top-checkbox_input.top-error:hover{border-color:var(--color-negative-2)}.top-checkbox_input:checked.top-error,.top-checkbox_input:indeterminate.top-error{background:var(--color-negative)}.top-checkbox_input:checked.top-error:hover,.top-checkbox_input:indeterminate.top-error:hover{background:var(--color-negative-2)}.top-hint{--top-icon-size: 16px;--top-icon-width: var(--top-icon-size);border-radius:50%;background:var(--content-background-color);padding:1px;color:var(--color-text-4);line-height:1;z-index:1;pointer-events:all}.top-hint:hover{color:var(--color-text-3)}.top-input{--top-forms_clear-width: 0px;width:180px;position:relative;display:inline-flex;align-items:center;gap:var(--top-gap-1)}.top-input_input{background:var(--top-forms-background-color);height:var(--top-forms-base-height);padding:0;padding-right:max(var(--top-forms-padding),calc(var(--top-icon2-width) + var(--top-forms_clear-width)));padding-left:max(var(--top-forms-padding),var(--top-icon-width))}.top-input_input:hover{background:var(--top-forms-background-color-hover)}.top-input_input:focus{outline-color:var(--color-theme-75);outline-offset:0}.top-input[data-top-icon]:before,.top-input[data-top-icon2]:after{--top-icon-color: var(--color-text-secondary);--top-icon2-color: var(--color-text-secondary);position:absolute;z-index:3}.top-input[data-top-icon]:before{left:0}.top-input[data-top-icon2]:after{right:0}.top-input-withCleaner{--top-forms_clear-width: 24px}.top-input_cleaner{--top-icon-size: 20px;--top-icon-width: 20px;--top-icon-color: var(--color-text-3);cursor:pointer;border-radius:50%;width:24px;height:24px;position:absolute;right:calc(var(--top-forms-border-width) + max(var(--top-icon2-width),var(--top-forms-padding) / 2));z-index:1;display:flex;align-items:center;justify-content:center}.top-input_cleaner:hover{--top-icon-color: var(--color-text-2)}.top-input_input{width:50%;flex-grow:1}.top-input-datepicker{width:calc(105px + var(--top-icon-width) + var(--top-icon2-width))}.top-input_input-date{opacity:0;position:absolute;inset:0;z-index:-1}.top-input_input-date::-webkit-inner-spin-button{display:none}.top-input_input-date::-webkit-calendar-picker-indicator{opacity:0}.top-inputRange{max-width:320px;vertical-align:baseline;display:inline-flex;gap:8px}.top-inputRange_dash{height:var(--top-forms-base-height);color:var(--color-text-4);align-self:flex-end;display:inline-flex;align-items:center}.top-inputRange>.top-input{flex-grow:1}:root{--top-radio-background-color: var(--content-background-color);--top-radio-background-color-hover: var(--top-radio-background-color);--top-radio-background-color-active: var(--top-radio-background-color)}.top-radio{cursor:pointer}.top-radio_input{border-radius:50%;background:var(--content-background-color);border:1px solid var(--top-forms-border-color);width:calc(var(--top-forms-option-height) - 3px * 2);height:calc(var(--top-forms-option-height) - 3px * 2)}.top-radio_input:hover{border-color:var(--top-forms-option-color);background:var(--color-theme-50)}.top-radio_input:checked{border-color:var(--top-forms-option-color);border-width:5px}.top-radio_input:checked:hover{border-color:var(--top-forms-option-color-hover)}.top-radio_input:disabled{border-color:var(--color-line-1-opacity);background:var(--color-theme-50)}.top-radio_input:checked:disabled{border-color:var(--color-theme-400)}.top-radio_input.top-error{border-color:var(--color-negative)}.top-radio_input.top-error:hover{border-color:var(--color-negative-2)}.top-checkboxSwitcher{cursor:pointer;display:inline-flex;gap:4px}.top-checkboxSwitcher_input{border-radius:9px;border:none;background:var(--color-theme-100);width:36px;height:18px;position:relative}.top-checkboxSwitcher_input:before{content:"";border-radius:50%;background:var(--color-white);width:12px;height:12px;margin:3px;position:absolute;top:0;left:0;transition:left .1s}.top-checkboxSwitcher_input:hover{background:var(--color-theme-150)}.top-checkboxSwitcher_input:checked{background:var(--top-forms-option-color)}.top-checkboxSwitcher_input:checked:hover{background:var(--top-forms-option-color-hover)}.top-checkboxSwitcher_input:checked:before{left:50%}.top-checkboxSwitcher_input:disabled{background:var(--color-theme-400)}.top-checkboxSwitcher_input.top-error{background:var(--color-negative)}.top-checkboxSwitcher_input.top-error:hover{background:var(--color-negative-2)}.top-textarea{width:180px;display:inline-flex;align-items:center;position:relative}.top-textarea_textarea{background:var(--top-forms-background-color);width:100%;padding:var(--top-forms-padding);resize:none}.top-textarea_textarea:hover{background:var(--top-forms-background-color-hover)}.top-textarea_textarea:focus{outline-color:var(--color-theme-75);outline-offset:0px}.top-textarea_textarea.top-textarea_textarea-expandable{width:100%;height:100%;overflow:hidden;position:absolute;top:0;left:0}.top-textarea_pseudoContent{box-sizing:border-box;min-height:var(--c838a038);padding:var(--top-forms-padding);font-size:14px;white-space:pre-wrap;overflow-wrap:anywhere;pointer-events:none;opacity:0;z-index:-1}.top-textarea_hint{position:absolute;top:2px;right:2px}.top-select{--top-icon-color: var(--color-text-3);--top-icon2-color: var(--color-text-2);align-items:center;width:180px;max-width:100%;display:inline-flex}.top-select-error{--top-icon-color: var(--color-negative);--top-icon2-color: var(--color-negative)}.top-select_select{background-color:var(--top-forms-background-color);padding-left:var(--top-forms-padding);text-indent:clamp(0px,calc(var(--top-icon-both-width) - var(--top-forms-padding)),calc(var(--top-icon-both-width) - var(--top-forms-padding)));width:100%;height:var(--top-forms-base-height);text-overflow:ellipsis;white-space:nowrap;flex-grow:1;overflow:hidden}.top-select_select:focus{outline-color:var(--color-theme-75);outline-offset:0}.top-select_select:disabled{background:var(--color-theme-50)}.top-select optgroup{color:var(--color-text-1);font-style:normal}.top-select option{background:var(--content-background-color);color:var(--color-text-1)}@-moz-document url-prefix(){.top-select_select{text-indent:calc(clamp(0px,calc(var(--top-icon-both-width) - var(--top-forms-padding)),calc(var(--top-icon-both-width) - var(--top-forms-padding)))/2)}}@media only screen and (min-width: 900px){.top-changer{cursor:pointer;border-radius:100%;width:0;transform:translate(-44px);color:var(--color-text-secondary-2);font-size:16px;line-height:1;display:none;z-index:2;order:4}.top-changer:hover{color:var(--color-primary)}.top-changer:after{content:"";background-color:var(--top-forms-background-color);font-family:Topvisor-2}*:hover>.top-changer{display:block}}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
declare const _default: {
|
|
2
|
+
/**
|
|
3
|
+
* Оставить глобальные классы без преобразования
|
|
4
|
+
* С глобальными классами нельзя работать через css module
|
|
5
|
+
* С глобальными классами можно работать, определяя их их в интерфесе vue css module
|
|
6
|
+
* @param {type} name - имя класса
|
|
7
|
+
* @param {type} filename - файл стилей
|
|
8
|
+
* @param {type} css - стили
|
|
9
|
+
* @returns {String} - имя класса после предкомпиляции
|
|
10
|
+
*/
|
|
11
|
+
generateScopedName: (name: string, filename: string, css: string) => string;
|
|
12
|
+
};
|
|
13
|
+
export default _default;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import MagicString from 'magic-string';
|
|
2
|
+
import type { Plugin, LibraryOptions, BuildOptions } from 'vite';
|
|
3
|
+
export interface LibOptions extends LibraryOptions {
|
|
4
|
+
build?: BuildOptions;
|
|
5
|
+
rollupOptions?: BuildOptions['rollupOptions'];
|
|
6
|
+
}
|
|
7
|
+
/**
|
|
8
|
+
* Генерация js кода, который должен инициировать загрузку css при исполнении в js модуле
|
|
9
|
+
* Для amd модуля
|
|
10
|
+
* @param fileName - относительный путь к файлу стилей от js модуля, который должен загрузить стили
|
|
11
|
+
*/
|
|
12
|
+
export declare const importCSSCodeAMD: (ms: MagicString, moduleName: string) => MagicString;
|
|
13
|
+
/**
|
|
14
|
+
* Загрузить css через Page.addCss()
|
|
15
|
+
*
|
|
16
|
+
* Для ES
|
|
17
|
+
*/
|
|
18
|
+
declare const _default: (libOptions?: LibOptions) => Plugin;
|
|
19
|
+
export default _default;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { PreRenderedAsset } from 'rollup';
|
|
2
|
+
declare const _default: {
|
|
3
|
+
external: string[];
|
|
4
|
+
output: {
|
|
5
|
+
globals: {
|
|
6
|
+
vue: string;
|
|
7
|
+
};
|
|
8
|
+
manualChunks: {
|
|
9
|
+
forms: string[];
|
|
10
|
+
};
|
|
11
|
+
chunkFileNames: string;
|
|
12
|
+
assetFileNames: (_chunkInfo: PreRenderedAsset) => string;
|
|
13
|
+
};
|
|
14
|
+
};
|
|
15
|
+
export default _default;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from '../src/components/common/common'
|
package/core/core.amd.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
define(["require","vue","../.chunks/forms-
|
|
1
|
+
define(["require","vue","../.chunks/forms-771091d4.amd"],function(r,e,u){"use strict";if(typeof e>"u")var e=window.Vue;return u.Core});
|
|
2
2
|
//# sourceMappingURL=core.amd.js.map
|
package/core/core.d.ts
ADDED
package/core/core.js
CHANGED
package/forms/forms.amd.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
define(["require","exports","../.chunks/forms-
|
|
1
|
+
define(["require","exports","../.chunks/forms-771091d4.amd","vue"],function(t,e,n,a){"use strict";if(typeof a>"u")var a=window.Vue;e.Avatar=n.avatar,e.Button=n.Button,e.Checkbox=n.checkbox,e.ControlLabel=n.ControlLabel,e.Hint=n.Hint,e.Input=n.Input,e.InputDate=n.inputDate,e.InputRange=n.inputRange,e.Radio=n.radio,e.Select=n.select,e.Switcher=n.switcher,e.Textarea=n.Textarea,Object.defineProperty(e,Symbol.toStringTag,{value:"Module"})});
|
|
2
2
|
//# sourceMappingURL=forms.amd.js.map
|
package/forms/forms.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from '../src/components/forms/forms'
|
package/forms/forms.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { b as e, B as o, c as r, d as n, H as i, I as p, i as c, e as u, r as I, f as b, s as l, T as x } from "../.chunks/forms-
|
|
1
|
+
import { b as e, B as o, c as r, d as n, H as i, I as p, i as c, e as u, r as I, f as b, s as l, T as x } from "../.chunks/forms-727cc6aa.es.js";
|
|
2
2
|
import "vue";
|
|
3
3
|
export {
|
|
4
4
|
e as Avatar,
|
package/forms/helpers.amd.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"helpers.amd.js","sources":["../../src/components/forms/helpers.ts"],"sourcesContent":["/**\n * Размеры\n */\nexport const sizes = {\n\txs: 'xs',\n\ts: 's',\n\tl: 'l',\n\txl: 'xl',\n} as const;\n\nexport type Size = typeof sizes[keyof typeof sizes];"],"names":["sizes"],"mappings":"yFAGO,MAAAA,EAAA,4BAKP"}
|
|
1
|
+
{"version":3,"file":"helpers.amd.js","sources":["../../src/components/forms/helpers.ts"],"sourcesContent":["/**\r\n * Размеры\r\n */\r\nexport const sizes = {\r\n\txs: 'xs',\r\n\ts: 's',\r\n\tl: 'l',\r\n\txl: 'xl',\r\n} as const;\r\n\r\nexport type Size = typeof sizes[keyof typeof sizes];"],"names":["sizes"],"mappings":"yFAGO,MAAAA,EAAA,4BAKP"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from '../src/components/forms/helpers'
|
package/forms/helpers.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"helpers.js","sources":["../../src/components/forms/helpers.ts"],"sourcesContent":["/**\n * Размеры\n */\nexport const sizes = {\n\txs: 'xs',\n\ts: 's',\n\tl: 'l',\n\txl: 'xl',\n} as const;\n\nexport type Size = typeof sizes[keyof typeof sizes];"],"names":["sizes"],"mappings":"AAGO,MAAMA,IAAQ;AAAA,EACpB,IAAI;AAAA,EACJ,GAAG;AAAA,EACH,GAAG;AAAA,EACH,IAAI;AACL;"}
|
|
1
|
+
{"version":3,"file":"helpers.js","sources":["../../src/components/forms/helpers.ts"],"sourcesContent":["/**\r\n * Размеры\r\n */\r\nexport const sizes = {\r\n\txs: 'xs',\r\n\ts: 's',\r\n\tl: 'l',\r\n\txl: 'xl',\r\n} as const;\r\n\r\nexport type Size = typeof sizes[keyof typeof sizes];"],"names":["sizes"],"mappings":"AAGO,MAAMA,IAAQ;AAAA,EACpB,IAAI;AAAA,EACJ,GAAG;AAAA,EACH,GAAG;AAAA,EACH,IAAI;AACL;"}
|