@topvisor/ui 1.0.1 → 1.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (159) hide show
  1. package/.chunks/datepicker-3uPurK_5.es.js +290 -0
  2. package/.chunks/datepicker-3uPurK_5.es.js.map +1 -0
  3. package/.chunks/datepicker-BJGX0c7G.amd.js +248 -0
  4. package/.chunks/datepicker-BJGX0c7G.amd.js.map +1 -0
  5. package/.chunks/forms-BImXJ_ZO.amd.js +3 -0
  6. package/.chunks/forms-BImXJ_ZO.amd.js.map +1 -0
  7. package/.chunks/forms-D9r2-H5Y.es.js +2000 -0
  8. package/.chunks/forms-D9r2-H5Y.es.js.map +1 -0
  9. package/.chunks/i18n-C_OH9IT3.amd.js.map +1 -1
  10. package/.chunks/i18n-DuTvft1T.es.js.map +1 -1
  11. package/.chunks/{listItem.vue_vue_type_script_setup_true_lang-B3E-SDdg.es.js → listItem.vue_vue_type_script_setup_true_lang-Bdv8YBAk.es.js} +2 -2
  12. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-Bdv8YBAk.es.js.map +1 -0
  13. package/.chunks/{listItem.vue_vue_type_script_setup_true_lang-uKhci19t.amd.js → listItem.vue_vue_type_script_setup_true_lang-BxpjEUsq.amd.js} +2 -2
  14. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-BxpjEUsq.amd.js.map +1 -0
  15. package/.chunks/{menu-CcyqVSfg.es.js → menu-B0Ul7Kbg.es.js} +2 -2
  16. package/.chunks/menu-B0Ul7Kbg.es.js.map +1 -0
  17. package/.chunks/{menu-DTbsTDGK.amd.js → menu-CbhB9e4x.amd.js} +2 -2
  18. package/.chunks/menu-CbhB9e4x.amd.js.map +1 -0
  19. package/.chunks/{popup-C5yk4q8p.es.js → popup-Coq_61yv.es.js} +495 -495
  20. package/.chunks/popup-Coq_61yv.es.js.map +1 -0
  21. package/.chunks/{popup-DAruCfQv.amd.js → popup-pQCswyfj.amd.js} +447 -447
  22. package/.chunks/popup-pQCswyfj.amd.js.map +1 -0
  23. package/.chunks/store-CX_6ZXhO.es.js.map +1 -1
  24. package/.chunks/store-esTid5oI.amd.js.map +1 -1
  25. package/README.md +86 -86
  26. package/assets/core.css +1 -1
  27. package/assets/forms.css +1 -1
  28. package/assets/formsExt.css +1 -1
  29. package/assets/menu.css +1 -1
  30. package/assets/popup.css +1 -1
  31. package/assets/tabs.css +1 -1
  32. package/assets/tabsView.css +1 -1
  33. package/assets/themes/dark.css +1 -0
  34. package/assets/themes/light.css +1 -0
  35. package/components/forms/select/select.d.ts +1 -2
  36. package/components/tabsView/tabsView/store.d.ts +1 -1
  37. package/components/tabsView/tabsView/tabsView.d.ts +1 -1
  38. package/core/app.amd.js +1 -1
  39. package/core/app.amd.js.map +1 -1
  40. package/core/app.js +58 -59
  41. package/core/app.js.map +1 -1
  42. package/core/core/core.d.ts +10 -9
  43. package/core/core/events/resize.d.ts +16 -0
  44. package/core/core/events.d.ts +12 -17
  45. package/core/core/options.d.ts +22 -0
  46. package/core/core/state.d.ts +12 -1
  47. package/core/core.amd.js +1 -1
  48. package/core/core.js +1 -1
  49. package/forms/forms.amd.js +1 -1
  50. package/forms/forms.js +1 -1
  51. package/forms/helpers.amd.js.map +1 -1
  52. package/forms/helpers.js.map +1 -1
  53. package/formsExt/formsExt.amd.js +1 -1
  54. package/formsExt/formsExt.amd.js.map +1 -1
  55. package/formsExt/formsExt.js +17 -18
  56. package/formsExt/formsExt.js.map +1 -1
  57. package/icomoon/Read Me.txt +7 -7
  58. package/icomoon/demo-files/demo.css +161 -161
  59. package/icomoon/demo-files/demo.js +30 -30
  60. package/icomoon/demo.html +3379 -3379
  61. package/icomoon/fonts/Topvisor-2.svg +263 -263
  62. package/icomoon/style.css +740 -740
  63. package/package.json +37 -36
  64. package/popup/popup.amd.js +1 -1
  65. package/popup/popup.amd.js.map +1 -1
  66. package/popup/popup.js +18 -18
  67. package/popup/popup.js.map +1 -1
  68. package/popup/worker.amd.js +1 -1
  69. package/popup/worker.amd.js.map +1 -1
  70. package/popup/worker.js +2 -2
  71. package/popup/worker.js.map +1 -1
  72. package/project/project.amd.js +1 -1
  73. package/project/project.amd.js.map +1 -1
  74. package/project/project.js +3 -3
  75. package/project/project.js.map +1 -1
  76. package/require/css.amd.js +12 -12
  77. package/tabs/tabs.amd.js +1 -1
  78. package/tabs/tabs.amd.js.map +1 -1
  79. package/tabs/tabs.js +7 -8
  80. package/tabs/tabs.js.map +1 -1
  81. package/tabsView/tabsView.amd.js +1 -1
  82. package/tabsView/tabsView.amd.js.map +1 -1
  83. package/tabsView/tabsView.js +106 -98
  84. package/tabsView/tabsView.js.map +1 -1
  85. package/test/themes/themes/dark-positions.amd.js +2 -0
  86. package/test/themes/themes/dark-positions.amd.js.map +1 -0
  87. package/test/themes/themes/dark-positions.d.ts +1 -0
  88. package/test/themes/themes/dark-positions.js +2 -0
  89. package/test/themes/themes/dark-positions.js.map +1 -0
  90. package/test/themes/themes/dark.amd.js +2 -0
  91. package/test/themes/themes/dark.amd.js.map +1 -0
  92. package/test/themes/themes/dark.d.ts +1 -0
  93. package/test/themes/themes/dark.js +4 -0
  94. package/test/themes/themes/dark.js.map +1 -0
  95. package/test/themes/themes/light-positions.amd.js +2 -0
  96. package/test/themes/themes/light-positions.amd.js.map +1 -0
  97. package/test/themes/themes/light-positions.d.ts +1 -0
  98. package/test/themes/themes/light-positions.js +2 -0
  99. package/test/themes/themes/light-positions.js.map +1 -0
  100. package/test/themes/themes/light.amd.js +2 -0
  101. package/test/themes/themes/light.amd.js.map +1 -0
  102. package/test/themes/themes/light.d.ts +1 -0
  103. package/test/themes/themes/light.js +4 -0
  104. package/test/themes/themes/light.js.map +1 -0
  105. package/utils/check.amd.js.map +1 -1
  106. package/utils/check.js.map +1 -1
  107. package/utils/clipboard.amd.js.map +1 -1
  108. package/utils/clipboard.js.map +1 -1
  109. package/utils/date.amd.js +1 -1
  110. package/utils/date.js +1 -1
  111. package/utils/device.amd.js +1 -1
  112. package/utils/device.js +3 -3
  113. package/utils/dom.amd.js.map +1 -1
  114. package/utils/dom.js.map +1 -1
  115. package/utils/image.amd.js.map +1 -1
  116. package/utils/image.js.map +1 -1
  117. package/utils/keyboard.amd.js.map +1 -1
  118. package/utils/keyboard.js.map +1 -1
  119. package/utils/lodash.amd.js +1 -1
  120. package/utils/lodash.amd.js.map +1 -1
  121. package/utils/lodash.js +6 -703
  122. package/utils/lodash.js.map +1 -1
  123. package/utils/number.amd.js.map +1 -1
  124. package/utils/number.js.map +1 -1
  125. package/utils/price.amd.js +1 -1
  126. package/utils/price.amd.js.map +1 -1
  127. package/utils/price.js +1 -1
  128. package/utils/price.js.map +1 -1
  129. package/utils/route.amd.js.map +1 -1
  130. package/utils/route.js.map +1 -1
  131. package/utils/scroll.amd.js.map +1 -1
  132. package/utils/scroll.js.map +1 -1
  133. package/utils/string.amd.js.map +1 -1
  134. package/utils/string.js.map +1 -1
  135. package/utils/system.amd.js.map +1 -1
  136. package/utils/system.js.map +1 -1
  137. package/utils/url.amd.js.map +1 -1
  138. package/utils/url.js.map +1 -1
  139. package/web-types.json +72 -72
  140. package/.chunks/datepicker-CS24dmLk.es.js +0 -290
  141. package/.chunks/datepicker-CS24dmLk.es.js.map +0 -1
  142. package/.chunks/datepicker-DsMs2YKL.amd.js +0 -248
  143. package/.chunks/datepicker-DsMs2YKL.amd.js.map +0 -1
  144. package/.chunks/debounce-4ipCj607.amd.js +0 -2
  145. package/.chunks/debounce-4ipCj607.amd.js.map +0 -1
  146. package/.chunks/debounce-BISRz08p.es.js +0 -116
  147. package/.chunks/debounce-BISRz08p.es.js.map +0 -1
  148. package/.chunks/forms-DKL0e9tp.amd.js +0 -3
  149. package/.chunks/forms-DKL0e9tp.amd.js.map +0 -1
  150. package/.chunks/forms-DT_fsN6V.es.js +0 -1161
  151. package/.chunks/forms-DT_fsN6V.es.js.map +0 -1
  152. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-B3E-SDdg.es.js.map +0 -1
  153. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-uKhci19t.amd.js.map +0 -1
  154. package/.chunks/menu-CcyqVSfg.es.js.map +0 -1
  155. package/.chunks/menu-DTbsTDGK.amd.js.map +0 -1
  156. package/.chunks/popup-C5yk4q8p.es.js.map +0 -1
  157. package/.chunks/popup-DAruCfQv.amd.js.map +0 -1
  158. package/assets/dark.css +0 -1
  159. package/assets/light.css +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"i18n-C_OH9IT3.amd.js","sources":["../../src/core/plugins/i18n.ts"],"sourcesContent":["import type { ObjectPlugin, Reactive, Ref } from 'vue';\nimport { getCurrentInstance, inject, reactive, ref } from 'vue';\nimport type { components as I18nComponents } from 'topvisor-openapi/src/ts/I18n';\n\nexport type Lang = 'ru' | 'en';\n\ntype Options = {\n\t/**\n\t * Предзагруженные словари\n\t *\n\t * Для загрузки нужного словаря используйте @r/i18n.esm.js\n\t *\n\t * ```js\n\t * import '@r/i18n.esm.js?Projects';\n\t * ```\n\t */\n\ti18n: I18nComponents['schemas'];\n\n\t/**\n\t * Текущий язык\n\t */\n\tlang: Lang;\n};\n\n/**\n * Загруженные словари\n *\n * Для загрузки нужного словаря используйте @r/i18n.esm.js\n *\n * ```js\n * import '@r/i18n.esm.js?Projects';\n * ```\n */\ntype I18n = Reactive<Options['i18n']>;\n\ntype i18nSetLang = (lang: Lang, forceReload?: boolean) => void;\n\ndeclare module 'vue' {\n\texport interface ComponentCustomProperties {\n\t\t/**\n\t\t * Загруженные словари\n\t\t *\n\t\t * @see I18n\n\t\t */\n\t\t$i18n: I18n;\n\n\t\t/**\n\t\t * Текущий язык\n\t\t */\n\t\t$i18nLang: Ref<Lang>;\n\n\t\t/**\n\t\t * Установить язык\n\t\t */\n\t\t$i18nSetLang: i18nSetLang;\n\t}\n}\n\n/**\n * Плагин работает в сваязке с плагином requirejs('i18n')\n *\n * При инициализации необходимо указать в $i18n объект с предзагруежнными словарями, остальные словари можно импортировать диномически вместе с\n * компонентами\n *\n * Внутри UI дозагрузка словарей недоступна и требует предзагрузки необходимых словарей\n *\n * Добавляет глобальные свойства:\n * - \\$i18n\n * - \\$i18nLang\n * - \\$i18nSetLang\n *\n * Для загрузки необходимого словаря указывайте его в зависимостях компонента:\n *\n * ```js\n * import '@r/i18n.esm.js?Projects';\n * ```\n *\n * В setup():\n *\n * ```js\n * useI18n().Projects.Site; // выполнит inject('$i18n').Projects.Site, не испоьзуйте inject('$i18n') напрямую, так как он не типизирован\n * ```\n *\n * В template:\n *\n * ```html\n * {{ $i18n.Projects.Site }}\n * ```\n */\nexport default {\n\n\tinstall: (app, options) => {\n\t\tapp.config.globalProperties.$i18n = reactive(options.i18n);\n\t\tapp.config.globalProperties.$i18nLang = ref(options.lang);\n\t\tapp.config.globalProperties.$i18nSetLang = () => {};\n\n\t\t/**\n\t\t * @deprecated\n\t\t */\n\t\tapp.config.globalProperties.i18n = app.config.globalProperties.$i18n;\n\n\t\t// только в браузере (не ssr)\n\t\tif (typeof window !== 'undefined' && window['requirejs']) {\n\t\t\tapp.config.globalProperties.$i18nSetLang = async (lang, forceReload) => {\n\t\t\t\tawait window['requirejs']('i18n').setLang(lang, forceReload);\n\n\t\t\t\tconst categoriesActual = window['requirejs']('i18n').categories[lang];\n\t\t\t\tObject.keys(categoriesActual).forEach(categoryName => {\n\t\t\t\t\tapp.config.globalProperties.$i18n[categoryName] = categoriesActual[categoryName];\n\t\t\t\t});\n\n\t\t\t\tapp.config.globalProperties.$i18nLang.value = lang;\n\t\t\t};\n\t\t}\n\n\t\tapp.provide('$i18n', app.config.globalProperties.$i18n);\n\t\tapp.provide('$i18nLang', app.config.globalProperties.$i18nLang);\n\t\tapp.provide('$i18nSetLang', app.config.globalProperties.$i18nSetLang);\n\n\t\t/**\n\t\t * @deprecated\n\t\t */\n\t\tapp.provide('i18n', app.config.globalProperties.i18n);\n\t},\n\n} satisfies ObjectPlugin<Options>;\n\n/**\n * Получить доступ к загруженным словарям\n *\n * @see I18n\n */\nexport const useI18n = (): I18n => {\n\t// @ts-ignore - no vue\n\tif (!getCurrentInstance() && window['mo']?.user?.lang) return requirejs('i18n').categories[mo.user.lang];\n\n\treturn inject('$i18n') as I18n;\n};\n\n/**\n * Текущий язык\n */\nexport const useI18nLang = (): Ref<Lang> => {\n\t// @ts-ignore - no vue\n\tif (!getCurrentInstance() && window['mo']?.user?.lang) return ref(mo.user.lang);\n\n\treturn inject('$i18nLang') as Ref<Lang>;\n};\n\n/**\n * Получить функцию для установки языка\n */\nexport const useI18nSetLang = () => {\n\treturn inject('$i18nSetLang') as i18nSetLang;\n};\n"],"names":["i18n","app","options","vue","lang","forceReload","categoriesActual","categoryName","useI18n","_b","_a","useI18nLang","useI18nSetLang"],"mappings":"iGAyFA,MAAAA,EAAA,CAAe,QAAA,CAAAC,EAAAC,IAAA,CAGbD,EAAA,OAAA,iBAAA,MAAAE,EAAA,SAAAD,EAAA,IAAA,EACAD,EAAA,OAAA,iBAAA,UAAAE,EAAA,IAAAD,EAAA,IAAA,8CACiD,EAKjDD,EAAA,OAAA,iBAAA,KAAAA,EAAA,OAAA,iBAAA,4CAICA,EAAA,OAAA,iBAAA,aAAA,MAAAG,EAAAC,IAAA,CACC,MAAA,OAAA,UAAA,MAAA,EAAA,QAAAD,EAAAC,CAAA,EAEA,MAAAC,EAAA,OAAA,UAAA,MAAA,EAAA,WAAAF,CAAA,6BAECH,EAAA,OAAA,iBAAA,MAAAM,CAAA,EAAAD,EAAAC,CAAA,CAA+E,CAAA,6CAGlC,GAIhDN,EAAA,QAAA,QAAAA,EAAA,OAAA,iBAAA,KAAA,EACAA,EAAA,QAAA,YAAAA,EAAA,OAAA,iBAAA,SAAA,EACAA,EAAA,QAAA,eAAAA,EAAA,OAAA,iBAAA,YAAA,EAKAA,EAAA,QAAA,OAAAA,EAAA,OAAA,iBAAA,IAAA,EAGF,EAOOO,EAAA,IAAA,SAEN,MAAA,CAAAL,EAAA,mBAAA,KAAAM,GAAAC,EAAA,OAAA,KAAA,YAAAA,EAAA,OAAA,MAAAD,EAAA,MAAA,UAAA,MAAA,EAAA,WAAA,GAAA,KAAA,IAAA,EAEAN,EAAA,OAAA,OAAA,GAMMQ,EAAA,IAAA,kHAINR,EAAA,OAAA,WAAA,GAMMS,EAAA,IACNT,EAAA,OAAA,cAAA"}
1
+ {"version":3,"file":"i18n-C_OH9IT3.amd.js","sources":["../../src/core/plugins/i18n.ts"],"sourcesContent":["import type { ObjectPlugin, Reactive, Ref } from 'vue';\r\nimport { getCurrentInstance, inject, reactive, ref } from 'vue';\r\nimport type { components as I18nComponents } from 'topvisor-openapi/src/ts/I18n';\r\n\r\nexport type Lang = 'ru' | 'en';\r\n\r\ntype Options = {\r\n\t/**\r\n\t * Предзагруженные словари\r\n\t *\r\n\t * Для загрузки нужного словаря используйте @r/i18n.esm.js\r\n\t *\r\n\t * ```js\r\n\t * import '@r/i18n.esm.js?Projects';\r\n\t * ```\r\n\t */\r\n\ti18n: I18nComponents['schemas'];\r\n\r\n\t/**\r\n\t * Текущий язык\r\n\t */\r\n\tlang: Lang;\r\n};\r\n\r\n/**\r\n * Загруженные словари\r\n *\r\n * Для загрузки нужного словаря используйте @r/i18n.esm.js\r\n *\r\n * ```js\r\n * import '@r/i18n.esm.js?Projects';\r\n * ```\r\n */\r\ntype I18n = Reactive<Options['i18n']>;\r\n\r\ntype i18nSetLang = (lang: Lang, forceReload?: boolean) => void;\r\n\r\ndeclare module 'vue' {\r\n\texport interface ComponentCustomProperties {\r\n\t\t/**\r\n\t\t * Загруженные словари\r\n\t\t *\r\n\t\t * @see I18n\r\n\t\t */\r\n\t\t$i18n: I18n;\r\n\r\n\t\t/**\r\n\t\t * Текущий язык\r\n\t\t */\r\n\t\t$i18nLang: Ref<Lang>;\r\n\r\n\t\t/**\r\n\t\t * Установить язык\r\n\t\t */\r\n\t\t$i18nSetLang: i18nSetLang;\r\n\t}\r\n}\r\n\r\n/**\r\n * Плагин работает в сваязке с плагином requirejs('i18n')\r\n *\r\n * При инициализации необходимо указать в $i18n объект с предзагруежнными словарями, остальные словари можно импортировать диномически вместе с\r\n * компонентами\r\n *\r\n * Внутри UI дозагрузка словарей недоступна и требует предзагрузки необходимых словарей\r\n *\r\n * Добавляет глобальные свойства:\r\n * - \\$i18n\r\n * - \\$i18nLang\r\n * - \\$i18nSetLang\r\n *\r\n * Для загрузки необходимого словаря указывайте его в зависимостях компонента:\r\n *\r\n * ```js\r\n * import '@r/i18n.esm.js?Projects';\r\n * ```\r\n *\r\n * В setup():\r\n *\r\n * ```js\r\n * useI18n().Projects.Site; // выполнит inject('$i18n').Projects.Site, не испоьзуйте inject('$i18n') напрямую, так как он не типизирован\r\n * ```\r\n *\r\n * В template:\r\n *\r\n * ```html\r\n * {{ $i18n.Projects.Site }}\r\n * ```\r\n */\r\nexport default {\r\n\r\n\tinstall: (app, options) => {\r\n\t\tapp.config.globalProperties.$i18n = reactive(options.i18n);\r\n\t\tapp.config.globalProperties.$i18nLang = ref(options.lang);\r\n\t\tapp.config.globalProperties.$i18nSetLang = () => {};\r\n\r\n\t\t/**\r\n\t\t * @deprecated\r\n\t\t */\r\n\t\tapp.config.globalProperties.i18n = app.config.globalProperties.$i18n;\r\n\r\n\t\t// только в браузере (не ssr)\r\n\t\tif (typeof window !== 'undefined' && window['requirejs']) {\r\n\t\t\tapp.config.globalProperties.$i18nSetLang = async (lang, forceReload) => {\r\n\t\t\t\tawait window['requirejs']('i18n').setLang(lang, forceReload);\r\n\r\n\t\t\t\tconst categoriesActual = window['requirejs']('i18n').categories[lang];\r\n\t\t\t\tObject.keys(categoriesActual).forEach(categoryName => {\r\n\t\t\t\t\tapp.config.globalProperties.$i18n[categoryName] = categoriesActual[categoryName];\r\n\t\t\t\t});\r\n\r\n\t\t\t\tapp.config.globalProperties.$i18nLang.value = lang;\r\n\t\t\t};\r\n\t\t}\r\n\r\n\t\tapp.provide('$i18n', app.config.globalProperties.$i18n);\r\n\t\tapp.provide('$i18nLang', app.config.globalProperties.$i18nLang);\r\n\t\tapp.provide('$i18nSetLang', app.config.globalProperties.$i18nSetLang);\r\n\r\n\t\t/**\r\n\t\t * @deprecated\r\n\t\t */\r\n\t\tapp.provide('i18n', app.config.globalProperties.i18n);\r\n\t},\r\n\r\n} satisfies ObjectPlugin<Options>;\r\n\r\n/**\r\n * Получить доступ к загруженным словарям\r\n *\r\n * @see I18n\r\n */\r\nexport const useI18n = (): I18n => {\r\n\t// @ts-ignore - no vue\r\n\tif (!getCurrentInstance() && window['mo']?.user?.lang) return requirejs('i18n').categories[mo.user.lang];\r\n\r\n\treturn inject('$i18n') as I18n;\r\n};\r\n\r\n/**\r\n * Текущий язык\r\n */\r\nexport const useI18nLang = (): Ref<Lang> => {\r\n\t// @ts-ignore - no vue\r\n\tif (!getCurrentInstance() && window['mo']?.user?.lang) return ref(mo.user.lang);\r\n\r\n\treturn inject('$i18nLang') as Ref<Lang>;\r\n};\r\n\r\n/**\r\n * Получить функцию для установки языка\r\n */\r\nexport const useI18nSetLang = () => {\r\n\treturn inject('$i18nSetLang') as i18nSetLang;\r\n};\r\n"],"names":["i18n","app","options","vue","lang","forceReload","categoriesActual","categoryName","useI18n","_b","_a","useI18nLang","useI18nSetLang"],"mappings":"iGAyFA,MAAAA,EAAA,CAAe,QAAA,CAAAC,EAAAC,IAAA,CAGbD,EAAA,OAAA,iBAAA,MAAAE,EAAA,SAAAD,EAAA,IAAA,EACAD,EAAA,OAAA,iBAAA,UAAAE,EAAA,IAAAD,EAAA,IAAA,8CACiD,EAKjDD,EAAA,OAAA,iBAAA,KAAAA,EAAA,OAAA,iBAAA,4CAICA,EAAA,OAAA,iBAAA,aAAA,MAAAG,EAAAC,IAAA,CACC,MAAA,OAAA,UAAA,MAAA,EAAA,QAAAD,EAAAC,CAAA,EAEA,MAAAC,EAAA,OAAA,UAAA,MAAA,EAAA,WAAAF,CAAA,6BAECH,EAAA,OAAA,iBAAA,MAAAM,CAAA,EAAAD,EAAAC,CAAA,CAA+E,CAAA,6CAGlC,GAIhDN,EAAA,QAAA,QAAAA,EAAA,OAAA,iBAAA,KAAA,EACAA,EAAA,QAAA,YAAAA,EAAA,OAAA,iBAAA,SAAA,EACAA,EAAA,QAAA,eAAAA,EAAA,OAAA,iBAAA,YAAA,EAKAA,EAAA,QAAA,OAAAA,EAAA,OAAA,iBAAA,IAAA,EAGF,EAOOO,EAAA,IAAA,SAEN,MAAA,CAAAL,EAAA,mBAAA,KAAAM,GAAAC,EAAA,OAAA,KAAA,YAAAA,EAAA,OAAA,MAAAD,EAAA,MAAA,UAAA,MAAA,EAAA,WAAA,GAAA,KAAA,IAAA,EAEAN,EAAA,OAAA,OAAA,GAMMQ,EAAA,IAAA,kHAINR,EAAA,OAAA,WAAA,GAMMS,EAAA,IACNT,EAAA,OAAA,cAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"i18n-DuTvft1T.es.js","sources":["../../src/core/plugins/i18n.ts"],"sourcesContent":["import type { ObjectPlugin, Reactive, Ref } from 'vue';\nimport { getCurrentInstance, inject, reactive, ref } from 'vue';\nimport type { components as I18nComponents } from 'topvisor-openapi/src/ts/I18n';\n\nexport type Lang = 'ru' | 'en';\n\ntype Options = {\n\t/**\n\t * Предзагруженные словари\n\t *\n\t * Для загрузки нужного словаря используйте @r/i18n.esm.js\n\t *\n\t * ```js\n\t * import '@r/i18n.esm.js?Projects';\n\t * ```\n\t */\n\ti18n: I18nComponents['schemas'];\n\n\t/**\n\t * Текущий язык\n\t */\n\tlang: Lang;\n};\n\n/**\n * Загруженные словари\n *\n * Для загрузки нужного словаря используйте @r/i18n.esm.js\n *\n * ```js\n * import '@r/i18n.esm.js?Projects';\n * ```\n */\ntype I18n = Reactive<Options['i18n']>;\n\ntype i18nSetLang = (lang: Lang, forceReload?: boolean) => void;\n\ndeclare module 'vue' {\n\texport interface ComponentCustomProperties {\n\t\t/**\n\t\t * Загруженные словари\n\t\t *\n\t\t * @see I18n\n\t\t */\n\t\t$i18n: I18n;\n\n\t\t/**\n\t\t * Текущий язык\n\t\t */\n\t\t$i18nLang: Ref<Lang>;\n\n\t\t/**\n\t\t * Установить язык\n\t\t */\n\t\t$i18nSetLang: i18nSetLang;\n\t}\n}\n\n/**\n * Плагин работает в сваязке с плагином requirejs('i18n')\n *\n * При инициализации необходимо указать в $i18n объект с предзагруежнными словарями, остальные словари можно импортировать диномически вместе с\n * компонентами\n *\n * Внутри UI дозагрузка словарей недоступна и требует предзагрузки необходимых словарей\n *\n * Добавляет глобальные свойства:\n * - \\$i18n\n * - \\$i18nLang\n * - \\$i18nSetLang\n *\n * Для загрузки необходимого словаря указывайте его в зависимостях компонента:\n *\n * ```js\n * import '@r/i18n.esm.js?Projects';\n * ```\n *\n * В setup():\n *\n * ```js\n * useI18n().Projects.Site; // выполнит inject('$i18n').Projects.Site, не испоьзуйте inject('$i18n') напрямую, так как он не типизирован\n * ```\n *\n * В template:\n *\n * ```html\n * {{ $i18n.Projects.Site }}\n * ```\n */\nexport default {\n\n\tinstall: (app, options) => {\n\t\tapp.config.globalProperties.$i18n = reactive(options.i18n);\n\t\tapp.config.globalProperties.$i18nLang = ref(options.lang);\n\t\tapp.config.globalProperties.$i18nSetLang = () => {};\n\n\t\t/**\n\t\t * @deprecated\n\t\t */\n\t\tapp.config.globalProperties.i18n = app.config.globalProperties.$i18n;\n\n\t\t// только в браузере (не ssr)\n\t\tif (typeof window !== 'undefined' && window['requirejs']) {\n\t\t\tapp.config.globalProperties.$i18nSetLang = async (lang, forceReload) => {\n\t\t\t\tawait window['requirejs']('i18n').setLang(lang, forceReload);\n\n\t\t\t\tconst categoriesActual = window['requirejs']('i18n').categories[lang];\n\t\t\t\tObject.keys(categoriesActual).forEach(categoryName => {\n\t\t\t\t\tapp.config.globalProperties.$i18n[categoryName] = categoriesActual[categoryName];\n\t\t\t\t});\n\n\t\t\t\tapp.config.globalProperties.$i18nLang.value = lang;\n\t\t\t};\n\t\t}\n\n\t\tapp.provide('$i18n', app.config.globalProperties.$i18n);\n\t\tapp.provide('$i18nLang', app.config.globalProperties.$i18nLang);\n\t\tapp.provide('$i18nSetLang', app.config.globalProperties.$i18nSetLang);\n\n\t\t/**\n\t\t * @deprecated\n\t\t */\n\t\tapp.provide('i18n', app.config.globalProperties.i18n);\n\t},\n\n} satisfies ObjectPlugin<Options>;\n\n/**\n * Получить доступ к загруженным словарям\n *\n * @see I18n\n */\nexport const useI18n = (): I18n => {\n\t// @ts-ignore - no vue\n\tif (!getCurrentInstance() && window['mo']?.user?.lang) return requirejs('i18n').categories[mo.user.lang];\n\n\treturn inject('$i18n') as I18n;\n};\n\n/**\n * Текущий язык\n */\nexport const useI18nLang = (): Ref<Lang> => {\n\t// @ts-ignore - no vue\n\tif (!getCurrentInstance() && window['mo']?.user?.lang) return ref(mo.user.lang);\n\n\treturn inject('$i18nLang') as Ref<Lang>;\n};\n\n/**\n * Получить функцию для установки языка\n */\nexport const useI18nSetLang = () => {\n\treturn inject('$i18nSetLang') as i18nSetLang;\n};\n"],"names":["i18n","app","options","reactive","ref","lang","forceReload","categoriesActual","categoryName","useI18n","getCurrentInstance","_b","_a","inject","useI18nLang","useI18nSetLang"],"mappings":";AAyFA,MAAeA,IAAA;AAAA,EAEd,SAAS,CAACC,GAAKC,MAAY;AAC1B,IAAAD,EAAI,OAAO,iBAAiB,QAAQE,EAASD,EAAQ,IAAI,GACzDD,EAAI,OAAO,iBAAiB,YAAYG,EAAIF,EAAQ,IAAI,GACpDD,EAAA,OAAO,iBAAiB,eAAe,MAAM;AAAA,IAAA,GAKjDA,EAAI,OAAO,iBAAiB,OAAOA,EAAI,OAAO,iBAAiB,OAG3D,OAAO,SAAW,OAAe,OAAO,cAC3CA,EAAI,OAAO,iBAAiB,eAAe,OAAOI,GAAMC,MAAgB;AACvE,YAAM,OAAO,UAAa,MAAM,EAAE,QAAQD,GAAMC,CAAW;AAE3D,YAAMC,IAAmB,OAAO,UAAa,MAAM,EAAE,WAAWF,CAAI;AACpE,aAAO,KAAKE,CAAgB,EAAE,QAAQ,CAAgBC,MAAA;AACrD,QAAAP,EAAI,OAAO,iBAAiB,MAAMO,CAAY,IAAID,EAAiBC,CAAY;AAAA,MAAA,CAC/E,GAEGP,EAAA,OAAO,iBAAiB,UAAU,QAAQI;AAAA,IAAA,IAIhDJ,EAAI,QAAQ,SAASA,EAAI,OAAO,iBAAiB,KAAK,GACtDA,EAAI,QAAQ,aAAaA,EAAI,OAAO,iBAAiB,SAAS,GAC9DA,EAAI,QAAQ,gBAAgBA,EAAI,OAAO,iBAAiB,YAAY,GAKpEA,EAAI,QAAQ,QAAQA,EAAI,OAAO,iBAAiB,IAAI;AAAA,EACrD;AAED,GAOaQ,IAAU,MAAY;;AAElC,SAAI,CAACC,EAAA,OAAwBC,KAAAC,IAAA,OAAO,OAAP,gBAAAA,EAAc,SAAd,QAAAD,EAAoB,QAAa,UAAU,MAAM,EAAE,WAAW,GAAG,KAAK,IAAI,IAEhGE,EAAO,OAAO;AACtB,GAKaC,IAAc,MAAiB;;AAE3C,SAAI,CAACJ,EAAA,OAAwBC,KAAAC,IAAA,OAAO,OAAP,gBAAAA,EAAc,SAAd,QAAAD,EAAoB,QAAaP,EAAI,GAAG,KAAK,IAAI,IAEvES,EAAO,WAAW;AAC1B,GAKaE,IAAiB,MACtBF,EAAO,cAAc;"}
1
+ {"version":3,"file":"i18n-DuTvft1T.es.js","sources":["../../src/core/plugins/i18n.ts"],"sourcesContent":["import type { ObjectPlugin, Reactive, Ref } from 'vue';\r\nimport { getCurrentInstance, inject, reactive, ref } from 'vue';\r\nimport type { components as I18nComponents } from 'topvisor-openapi/src/ts/I18n';\r\n\r\nexport type Lang = 'ru' | 'en';\r\n\r\ntype Options = {\r\n\t/**\r\n\t * Предзагруженные словари\r\n\t *\r\n\t * Для загрузки нужного словаря используйте @r/i18n.esm.js\r\n\t *\r\n\t * ```js\r\n\t * import '@r/i18n.esm.js?Projects';\r\n\t * ```\r\n\t */\r\n\ti18n: I18nComponents['schemas'];\r\n\r\n\t/**\r\n\t * Текущий язык\r\n\t */\r\n\tlang: Lang;\r\n};\r\n\r\n/**\r\n * Загруженные словари\r\n *\r\n * Для загрузки нужного словаря используйте @r/i18n.esm.js\r\n *\r\n * ```js\r\n * import '@r/i18n.esm.js?Projects';\r\n * ```\r\n */\r\ntype I18n = Reactive<Options['i18n']>;\r\n\r\ntype i18nSetLang = (lang: Lang, forceReload?: boolean) => void;\r\n\r\ndeclare module 'vue' {\r\n\texport interface ComponentCustomProperties {\r\n\t\t/**\r\n\t\t * Загруженные словари\r\n\t\t *\r\n\t\t * @see I18n\r\n\t\t */\r\n\t\t$i18n: I18n;\r\n\r\n\t\t/**\r\n\t\t * Текущий язык\r\n\t\t */\r\n\t\t$i18nLang: Ref<Lang>;\r\n\r\n\t\t/**\r\n\t\t * Установить язык\r\n\t\t */\r\n\t\t$i18nSetLang: i18nSetLang;\r\n\t}\r\n}\r\n\r\n/**\r\n * Плагин работает в сваязке с плагином requirejs('i18n')\r\n *\r\n * При инициализации необходимо указать в $i18n объект с предзагруежнными словарями, остальные словари можно импортировать диномически вместе с\r\n * компонентами\r\n *\r\n * Внутри UI дозагрузка словарей недоступна и требует предзагрузки необходимых словарей\r\n *\r\n * Добавляет глобальные свойства:\r\n * - \\$i18n\r\n * - \\$i18nLang\r\n * - \\$i18nSetLang\r\n *\r\n * Для загрузки необходимого словаря указывайте его в зависимостях компонента:\r\n *\r\n * ```js\r\n * import '@r/i18n.esm.js?Projects';\r\n * ```\r\n *\r\n * В setup():\r\n *\r\n * ```js\r\n * useI18n().Projects.Site; // выполнит inject('$i18n').Projects.Site, не испоьзуйте inject('$i18n') напрямую, так как он не типизирован\r\n * ```\r\n *\r\n * В template:\r\n *\r\n * ```html\r\n * {{ $i18n.Projects.Site }}\r\n * ```\r\n */\r\nexport default {\r\n\r\n\tinstall: (app, options) => {\r\n\t\tapp.config.globalProperties.$i18n = reactive(options.i18n);\r\n\t\tapp.config.globalProperties.$i18nLang = ref(options.lang);\r\n\t\tapp.config.globalProperties.$i18nSetLang = () => {};\r\n\r\n\t\t/**\r\n\t\t * @deprecated\r\n\t\t */\r\n\t\tapp.config.globalProperties.i18n = app.config.globalProperties.$i18n;\r\n\r\n\t\t// только в браузере (не ssr)\r\n\t\tif (typeof window !== 'undefined' && window['requirejs']) {\r\n\t\t\tapp.config.globalProperties.$i18nSetLang = async (lang, forceReload) => {\r\n\t\t\t\tawait window['requirejs']('i18n').setLang(lang, forceReload);\r\n\r\n\t\t\t\tconst categoriesActual = window['requirejs']('i18n').categories[lang];\r\n\t\t\t\tObject.keys(categoriesActual).forEach(categoryName => {\r\n\t\t\t\t\tapp.config.globalProperties.$i18n[categoryName] = categoriesActual[categoryName];\r\n\t\t\t\t});\r\n\r\n\t\t\t\tapp.config.globalProperties.$i18nLang.value = lang;\r\n\t\t\t};\r\n\t\t}\r\n\r\n\t\tapp.provide('$i18n', app.config.globalProperties.$i18n);\r\n\t\tapp.provide('$i18nLang', app.config.globalProperties.$i18nLang);\r\n\t\tapp.provide('$i18nSetLang', app.config.globalProperties.$i18nSetLang);\r\n\r\n\t\t/**\r\n\t\t * @deprecated\r\n\t\t */\r\n\t\tapp.provide('i18n', app.config.globalProperties.i18n);\r\n\t},\r\n\r\n} satisfies ObjectPlugin<Options>;\r\n\r\n/**\r\n * Получить доступ к загруженным словарям\r\n *\r\n * @see I18n\r\n */\r\nexport const useI18n = (): I18n => {\r\n\t// @ts-ignore - no vue\r\n\tif (!getCurrentInstance() && window['mo']?.user?.lang) return requirejs('i18n').categories[mo.user.lang];\r\n\r\n\treturn inject('$i18n') as I18n;\r\n};\r\n\r\n/**\r\n * Текущий язык\r\n */\r\nexport const useI18nLang = (): Ref<Lang> => {\r\n\t// @ts-ignore - no vue\r\n\tif (!getCurrentInstance() && window['mo']?.user?.lang) return ref(mo.user.lang);\r\n\r\n\treturn inject('$i18nLang') as Ref<Lang>;\r\n};\r\n\r\n/**\r\n * Получить функцию для установки языка\r\n */\r\nexport const useI18nSetLang = () => {\r\n\treturn inject('$i18nSetLang') as i18nSetLang;\r\n};\r\n"],"names":["i18n","app","options","reactive","ref","lang","forceReload","categoriesActual","categoryName","useI18n","getCurrentInstance","_b","_a","inject","useI18nLang","useI18nSetLang"],"mappings":";AAyFA,MAAeA,IAAA;AAAA,EAEd,SAAS,CAACC,GAAKC,MAAY;AAC1B,IAAAD,EAAI,OAAO,iBAAiB,QAAQE,EAASD,EAAQ,IAAI,GACzDD,EAAI,OAAO,iBAAiB,YAAYG,EAAIF,EAAQ,IAAI,GACpDD,EAAA,OAAO,iBAAiB,eAAe,MAAM;AAAA,IAAA,GAKjDA,EAAI,OAAO,iBAAiB,OAAOA,EAAI,OAAO,iBAAiB,OAG3D,OAAO,SAAW,OAAe,OAAO,cAC3CA,EAAI,OAAO,iBAAiB,eAAe,OAAOI,GAAMC,MAAgB;AACvE,YAAM,OAAO,UAAa,MAAM,EAAE,QAAQD,GAAMC,CAAW;AAE3D,YAAMC,IAAmB,OAAO,UAAa,MAAM,EAAE,WAAWF,CAAI;AACpE,aAAO,KAAKE,CAAgB,EAAE,QAAQ,CAAgBC,MAAA;AACrD,QAAAP,EAAI,OAAO,iBAAiB,MAAMO,CAAY,IAAID,EAAiBC,CAAY;AAAA,MAAA,CAC/E,GAEGP,EAAA,OAAO,iBAAiB,UAAU,QAAQI;AAAA,IAAA,IAIhDJ,EAAI,QAAQ,SAASA,EAAI,OAAO,iBAAiB,KAAK,GACtDA,EAAI,QAAQ,aAAaA,EAAI,OAAO,iBAAiB,SAAS,GAC9DA,EAAI,QAAQ,gBAAgBA,EAAI,OAAO,iBAAiB,YAAY,GAKpEA,EAAI,QAAQ,QAAQA,EAAI,OAAO,iBAAiB,IAAI;AAAA,EACrD;AAED,GAOaQ,IAAU,MAAY;;AAElC,SAAI,CAACC,EAAA,OAAwBC,KAAAC,IAAA,OAAO,OAAP,gBAAAA,EAAc,SAAd,QAAAD,EAAoB,QAAa,UAAU,MAAM,EAAE,WAAW,GAAG,KAAK,IAAI,IAEhGE,EAAO,OAAO;AACtB,GAKaC,IAAc,MAAiB;;AAE3C,SAAI,CAACJ,EAAA,OAAwBC,KAAAC,IAAA,OAAO,OAAP,gBAAAA,EAAc,SAAd,QAAAD,EAAoB,QAAaP,EAAI,GAAG,KAAK,IAAI,IAEvES,EAAO,WAAW;AAC1B,GAKaE,IAAiB,MACtBF,EAAO,cAAc;"}
@@ -1,6 +1,6 @@
1
1
  import S from "../core/core.js";
2
2
  import { defineComponent as _, onUpdated as g, openBlock as p, createElementBlock as n, Fragment as C, createElementVNode as b, renderSlot as a, ref as I, toRef as k, onUnmounted as H, createBlock as y, unref as m, withCtx as $, createCommentVNode as l, Teleport as M, toDisplayString as N, createVNode as T, normalizeClass as D, resolveDynamicComponent as V, mergeProps as w } from "vue";
3
- import { C as B, a as R, _ as E } from "./forms-DT_fsN6V.es.js";
3
+ import { C as B, a as R, _ as E } from "./forms-D9r2-H5Y.es.js";
4
4
  import { TopPopupWorker as v } from "../popup/worker.js";
5
5
  const L = ["../assets/listItem.css"].map((u) => import.meta.resolve(u));
6
6
  S.insertCSSLinkToPage(L, !0);
@@ -171,4 +171,4 @@ export {
171
171
  eo as _,
172
172
  U as a
173
173
  };
174
- //# sourceMappingURL=listItem.vue_vue_type_script_setup_true_lang-B3E-SDdg.es.js.map
174
+ //# sourceMappingURL=listItem.vue_vue_type_script_setup_true_lang-Bdv8YBAk.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"listItem.vue_vue_type_script_setup_true_lang-Bdv8YBAk.es.js","sources":["../../src/components/popup/popup/opener.vue","../../src/components/popup/popup/popup.vue","../../src/components/popup/popup/listItem.vue"],"sourcesContent":["<script setup lang=\"ts\">\r\nimport { onUpdated } from 'vue';\r\nimport type { OpenerProps } from './popup';\r\n\r\nconst props = withDefaults(defineProps<OpenerProps>(), {\r\n\tpos: '3',\r\n\tnotch: true,\r\n\tposBy: 'fixed',\r\n});\r\n\r\nconst id = props.id || Math.random() + '';\r\n\r\nlet elOpener: Element;\r\n\r\n/**\r\n * Необычная функция для проброски props внтурь элемента слота\r\n *\r\n * @param el - вспомогательрный элемент для доступа к элементам слота\r\n */\r\nfunction render(el: any) {\r\n\tsetTimeout(() => {\r\n\t\telOpener = el.nextElementSibling;\r\n\r\n\t\tif (elOpener) {\r\n\t\t\trenderOpener(elOpener);\r\n\t\t}\r\n\t});\r\n}\r\n\r\nonUpdated(() => {\r\n\tif (elOpener) {\r\n\t\trenderOpener(elOpener);\r\n\t}\r\n});\r\n\r\nfunction renderOpener(elOpener: any) {\r\n\t/**\r\n\t * topPopup - необходимый атрибут для всез Popup\r\n\t *\r\n\t * Для Vue вместо него используется атрибут topPopupId\r\n\t */\r\n\telOpener.dataset.topPopup = '#' + id;\r\n\r\n\telOpener.dataset.topPopupId = id;\r\n\telOpener.dataset.topPopupPos = props.pos;\r\n\telOpener.dataset.topPopupPosBy = props.posBy;\r\n\telOpener.dataset.topPopupNotch = props.notch ? 'true' : '';\r\n\telOpener.dataset.topPopupOpenByHover = props.openByHover ? 'true' : '';\r\n}\r\n</script>\r\n\r\n<template>\r\n\t<template :ref=\"render\"></template>\r\n\r\n\t<!-- @slot элемент для открытия Popup -->\r\n\t<slot></slot>\r\n</template>\r\n\r\n<!-- Использует общий deprecated класс .btn -->\r\n<style>\r\nh3[data-top-popup],\r\ndiv[data-top-popup],\r\ni[data-top-popup]:not(.btn),\r\nb[data-top-popup]:not(.btn) {\r\n\tcursor: pointer;\r\n\tuser-select: none;\r\n\tfont-style: normal;\r\n\ttext-decoration: none;\r\n\tdisplay: inline-flex;\r\n\talign-items: center;\r\n}\r\n\r\n[data-top-popup][data-top-popup-disabled] {\r\n\tpointer-events: none;\r\n\tcursor: auto !important;\r\n}\r\n\r\ni[contenteditable] {\r\n\tcursor: text !important;\r\n}\r\n</style>\r\n","<script setup lang=\"ts\">\r\nimport { type Ref } from 'vue';\r\nimport { onUnmounted, ref, toRef } from 'vue';\r\nimport TopHint from '@/components/forms/hint/hint.vue';\r\nimport type PopupClass from '@/components/popup/lib/popup';\r\nimport Core from '@/core/core/core';\r\nimport type { Emits, Props } from './popup';\r\nimport Opener from './opener.vue';\r\nimport Worker from '@/components/popup/lib/worker';\r\n\r\nconst props = withDefaults(defineProps<Props>(), {\r\n\tid: '',\r\n\tpos: '3',\r\n\tnotch: true,\r\n\tposBy: 'fixed',\r\n});\r\n\r\nconst emit = defineEmits<Emits>();\r\n\r\nconst expose = {\r\n\tpopup: undefined as PopupClass | undefined,\r\n};\r\ndefineExpose(expose);\r\n\r\nconst id = props.id || 'top-popup-id-' + Math.random() + '';\r\nconst elPopupRef: Ref<null | Element> = ref(null);\r\n\r\n// см. lib/popup\r\nconst onOpen = async (popup: PopupClass) => {\r\n\tif (popup.elPopupInner) {\r\n\t\tpopup.elPopupInner.innerText = '';\r\n\r\n\t\telPopupRef.value = popup.elPopupInner;\r\n\t}\r\n\r\n\tvueConnector.opened = true;\r\n\tvueConnector.popup = popup;\r\n\r\n\texpose.popup = popup;\r\n\r\n\temit('open');\r\n};\r\n\r\n// см. lib/popup\r\nconst onClose = (_popup: PopupClass) => {\r\n\telPopupRef.value = null;\r\n\r\n\tvueConnector.opened = false;\r\n\tvueConnector.popup = undefined;\r\n\r\n\temit('close');\r\n};\r\n\r\nconst vueConnector = {\r\n\tonOpen,\r\n\tonClose,\r\n\tclassRef: toRef(props, 'class'),\r\n\topened: false,\r\n\tpopup: undefined as PopupClass | undefined,\r\n\ttransitionDurationRef: toRef(props, 'transitionDuration'),\r\n};\r\n\r\nWorker.regVueComponent(id, vueConnector);\r\n\r\nonUnmounted(() => {\r\n\tWorker.unregVueComponent(id);\r\n});\r\n</script>\r\n\r\n<template>\r\n\t<Opener\r\n\t\tv-if=\"$slots.opener\"\r\n\t\t:id=\"id\"\r\n\t\t:pos=\"pos\"\r\n\t\t:posBy=\"posBy\"\r\n\t\t:notch=\"notch\"\r\n\t\t:openByHover=\"openByHover\"\r\n\t>\r\n\t\t<!-- @slot элемент для открытия Popup -->\r\n\t\t<slot name=\"opener\"></slot>\r\n\t</Opener>\r\n\r\n\t<!-- Это шаблон для компонента Popup, сам Popup генерируется в js и может находиться где угодно -->\r\n\t<!-- elPopupRef будет установлен только после открытия и будет сброшен сразу после закрытия Popup -->\r\n\t<teleport\r\n\t\tv-if=\"elPopupRef\"\r\n\t\t:to=\"elPopupRef\"\r\n\t>\r\n\t\t<div v-if=\"$slots.header || Core.state.isMobile\" class=\"top-popup_header\">\r\n\t\t\t<span\r\n\t\t\t\tv-if=\"Core.state.isMobile\"\r\n\t\t\t\tclass=\"top-as-a closer\"\r\n\t\t\t>\r\n\t\t\t\t{{ $i18n.Common.Close }}\r\n\t\t\t</span>\r\n\r\n\t\t\t<!-- @slot Шапка -->\r\n\t\t\t<slot name=\"header\"></slot>\r\n\t\t</div>\r\n\r\n\t\t<div v-if=\"$slots.widget\" class=\"top-popup_widget\">\r\n\t\t\t<!-- @slot Виджет -->\r\n\t\t\t<slot name=\"widget\"></slot>\r\n\t\t</div>\r\n\r\n\t\t<div v-if=\"$slots.content\" class=\"top-popup_content\">\r\n\t\t\t<!-- @slot Контент в свободной форме -->\r\n\t\t\t<slot name=\"content\"></slot>\r\n\t\t</div>\r\n\r\n\t\t<ul\r\n\t\t\tv-if=\"$slots.contentList\"\r\n\t\t\tclass=\"top-popup_content\"\r\n\t\t\t@scroll=\"$emit('scrollContentList', $event)\"\r\n\t\t>\r\n\t\t\t<!-- @slot Контент в виде списка, для вставки элементов списка используйте компонент popup/listItem -->\r\n\t\t\t<slot name=\"contentList\"></slot>\r\n\t\t</ul>\r\n\r\n\t\t<div v-if=\"$slots.footer || footerSupportLink\" class=\"top-popup_footer\">\r\n\t\t\t<a\r\n\t\t\t\tv-if=\"footerSupportLink\"\r\n\t\t\t\tclass=\"top-popup_footerSupportLink\"\r\n\t\t\t\t:href=\"footerSupportLink\"\r\n\t\t\t\ttarget=\"_blank\"\r\n\t\t\t>\r\n\t\t\t\t<TopHint hint=\"\"/>\r\n\t\t\t</a>\r\n\r\n\t\t\t<!-- @slot Футер -->\r\n\t\t\t<slot name=\"footer\"></slot>\r\n\t\t</div>\r\n\t</teleport>\r\n</template>\r\n\r\n<style module>\r\n.top-popup_footerSupportLink {\r\n\tmargin-right: auto;\r\n}\r\n</style>\r\n","<script setup lang=\"ts\">\r\nimport type { ListItemProps } from './popup';\r\n\r\ndefineOptions({\r\n\tinheritAttrs: false,\r\n});\r\n\r\nconst props = withDefaults(defineProps<ListItemProps>(), {\r\n\ttype: 'button',\r\n\tcloseByClick: true,\r\n});\r\n</script>\r\n\r\n<template>\r\n\t<li\r\n\t\t:class=\"{\r\n\t\t'top-popup_liNoSelectable': props.type !== 'button'\r\n\t}\"\r\n\t>\r\n\t\t<component\r\n\t\t\t:is=\"$attrs.href ? 'a' : 'div'\"\r\n\t\t\t:class=\"{\r\n\t\t\t\t'top-popup_listItem': true,\r\n\t\t\t\t'top-popup_listItem-button': props.type === 'button', // оформления кнопки\r\n\t\t\t\t'a': props.type === 'button', // оформления кнопки, deprecated\r\n\t\t\t\t'top-popup_listItem-title': props.type === 'title',\r\n\t\t\t\t'top-popup_listItem-delimiter': props.type === 'delimiter',\r\n\t\t\t\t'top-popup-noCloser': !closeByClick\r\n\t\t\t}\"\r\n\t\t\t:=$attrs\r\n\t\t>\r\n\t\t\t<slot></slot>\r\n\t\t</component>\r\n\t</li>\r\n</template>\r\n"],"names":["props","__props","id","elOpener","render","el","renderOpener","onUpdated","elOpener2","emit","__emit","expose","__expose","elPopupRef","ref","vueConnector","popup","_popup","toRef","Worker","onUnmounted"],"mappings":";;;;;;;;;;;;;;;;AAIA,UAAAA,IAAAC,GAMAC,IAAAF,EAAA,MAAA,KAAA,OAAA,IAAA;AAEA,QAAAG;AAOA,aAAAC,EAAAC,GAAA;AACC,iBAAA,MAAA;AACC,QAAAF,IAAAE,EAAA,oBAEAF,KACCG,EAAAH,CAAA;AAAA,MACD,CAAA;AAAA,IACA;AAGF,IAAAI,EAAA,MAAA;AACC,MAAAJ,KACCG,EAAAH,CAAA;AAAA,IACD,CAAA;AAGD,aAAAG,EAAAE,GAAA;AAMC,MAAAA,EAAA,QAAA,WAAA,MAAAN,GAEAM,EAAA,QAAA,aAAAN,GACAM,EAAA,QAAA,cAAAR,EAAA,KACAQ,EAAA,QAAA,gBAAAR,EAAA,OACAQ,EAAA,QAAA,gBAAAR,EAAA,QAAA,SAAA,IACAQ,EAAA,QAAA,sBAAAR,EAAA,cAAA,SAAA;AAAA,IAAoE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACrCrE,UAAAA,IAAAC,GAOAQ,IAAAC,GAEAC,IAAA;AAAA,MAAe,OAAA;AAAA,IACP;AAER,IAAAC,EAAAD,CAAA;AAEA,UAAAT,IAAAF,EAAA,MAAA,kBAAA,KAAA,OAAA,GACAa,IAAAC,EAAA,IAAA,GA4BAC,IAAA;AAAA,MAAqB,QAzBrB,OAAAC,MAAA;AACC,QAAAA,EAAA,iBACCA,EAAA,aAAA,YAAA,IAEAH,EAAA,QAAAG,EAAA,eAGDD,EAAA,SAAA,IACAA,EAAA,QAAAC,GAEAL,EAAA,QAAAK,GAEAP,EAAA,MAAA;AAAA,MAAW;AAAA,MAcX,SAVD,CAAAQ,MAAA;AACC,QAAAJ,EAAA,QAAA,MAEAE,EAAA,SAAA,IACAA,EAAA,QAAA,QAEAN,EAAA,OAAA;AAAA,MAAY;AAAA,MAKZ,UAAAS,EAAAlB,GAAA,OAAA;AAAA,MAC8B,QAAA;AAAA,MACtB,OAAA;AAAA,MACD,uBAAAkB,EAAAlB,GAAA,oBAAA;AAAA,IACiD;AAGzD,WAAAmB,EAAA,gBAAAjB,GAAAa,CAAA,GAEAK,EAAA,MAAA;AACC,MAAAD,EAAA,kBAAAjB,CAAA;AAAA,IAA2B,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC1D5B,UAAAF,IAAAC;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,2 +1,2 @@
1
- define(["require","exports","vue","./forms-DKL0e9tp.amd","../popup/worker.amd","../require/css.amd!../assets/listItem.css"],function(E,d,e,i,m){"use strict";if(typeof e>"u")var e=window.Vue;const f=e.defineComponent({__name:"opener",props:{id:{},pos:{default:"3"},notch:{type:Boolean,default:!0},openByHover:{type:Boolean},posBy:{default:"fixed"}},setup(r){const n=r,s=n.id||Math.random()+"";let p;function c(t){setTimeout(()=>{p=t.nextElementSibling,p&&l(p)})}e.onUpdated(()=>{p&&l(p)});function l(t){t.dataset.topPopup="#"+s,t.dataset.topPopupId=s,t.dataset.topPopupPos=n.pos,t.dataset.topPopupPosBy=n.posBy,t.dataset.topPopupNotch=n.notch?"true":"",t.dataset.topPopupOpenByHover=n.openByHover?"true":""}return(t,a)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("template",{ref:c}),e.renderSlot(t.$slots,"default")],64))}}),B={key:0,class:"top-popup_header"},y={key:0,class:"top-as-a closer"},C={key:1,class:"top-popup_widget"},h={key:2,class:"top-popup_content"},_={key:4,class:"top-popup_footer"},v=["href"],$=e.defineComponent({__name:"popup",props:{id:{default:""},class:{},transitionDuration:{},footerSupportLink:{},pos:{default:"3"},notch:{type:Boolean,default:!0},openByHover:{type:Boolean},posBy:{default:"fixed"}},emits:["open","close","scrollContentList"],setup(r,{expose:n,emit:s}){const p=r,c=s,l={popup:void 0};n(l);const t=p.id||"top-popup-id-"+Math.random(),a=e.ref(null),u={onOpen:async o=>{o.elPopupInner&&(o.elPopupInner.innerText="",a.value=o.elPopupInner),u.opened=!0,u.popup=o,l.popup=o,c("open")},onClose:o=>{a.value=null,u.opened=!1,u.popup=void 0,c("close")},classRef:e.toRef(p,"class"),opened:!1,popup:void 0,transitionDurationRef:e.toRef(p,"transitionDuration")};return m.TopPopupWorker.regVueComponent(t,u),e.onUnmounted(()=>{m.TopPopupWorker.unregVueComponent(t)}),(o,k)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[o.$slots.opener?(e.openBlock(),e.createBlock(f,{key:0,id:e.unref(t),pos:o.pos,posBy:o.posBy,notch:o.notch,openByHover:o.openByHover},{default:e.withCtx(()=>[e.renderSlot(o.$slots,"opener")]),_:3},8,["id","pos","posBy","notch","openByHover"])):e.createCommentVNode("",!0),a.value?(e.openBlock(),e.createBlock(e.Teleport,{key:1,to:a.value},[o.$slots.header||e.unref(i.Core).state.isMobile?(e.openBlock(),e.createElementBlock("div",B,[e.unref(i.Core).state.isMobile?(e.openBlock(),e.createElementBlock("span",y,e.toDisplayString(o.$i18n.Common.Close),1)):e.createCommentVNode("",!0),e.renderSlot(o.$slots,"header")])):e.createCommentVNode("",!0),o.$slots.widget?(e.openBlock(),e.createElementBlock("div",C,[e.renderSlot(o.$slots,"widget")])):e.createCommentVNode("",!0),o.$slots.content?(e.openBlock(),e.createElementBlock("div",h,[e.renderSlot(o.$slots,"content")])):e.createCommentVNode("",!0),o.$slots.contentList?(e.openBlock(),e.createElementBlock("ul",{key:3,class:"top-popup_content",onScroll:k[0]||(k[0]=N=>o.$emit("scrollContentList",N))},[e.renderSlot(o.$slots,"contentList")],32)):e.createCommentVNode("",!0),o.$slots.footer||o.footerSupportLink?(e.openBlock(),e.createElementBlock("div",_,[o.footerSupportLink?(e.openBlock(),e.createElementBlock("a",{key:0,class:"top-popup_footerSupportLink",href:o.footerSupportLink,target:"_blank"},[e.createVNode(i.TopHint,{hint:""})],8,v)):e.createCommentVNode("",!0),e.renderSlot(o.$slots,"footer")])):e.createCommentVNode("",!0)],8,["to"])):e.createCommentVNode("",!0)],64))}}),S={$style:{"top-popup_footerSupportLink":"top-popup_footerSupportLink"}},P=i._export_sfc($,[["__cssModules",S]]),V=e.defineComponent({inheritAttrs:!1,__name:"listItem",props:{type:{default:"button"},closeByClick:{type:Boolean,default:!0}},setup(r){const n=r;return(s,p)=>(e.openBlock(),e.createElementBlock("li",{class:e.normalizeClass({"top-popup_liNoSelectable":n.type!=="button"})},[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(s.$attrs.href?"a":"div"),e.mergeProps({class:{"top-popup_listItem":!0,"top-popup_listItem-button":n.type==="button",a:n.type==="button","top-popup_listItem-title":n.type==="title","top-popup_listItem-delimiter":n.type==="delimiter","top-popup-noCloser":!s.closeByClick}},s.$attrs),{default:e.withCtx(()=>[e.renderSlot(s.$slots,"default")]),_:3},16,["class"]))],2))}});d.Popup=P,d._sfc_main=V,d._sfc_main$1=f});
2
- //# sourceMappingURL=listItem.vue_vue_type_script_setup_true_lang-uKhci19t.amd.js.map
1
+ define(["require","exports","vue","./forms-BImXJ_ZO.amd","../popup/worker.amd","../require/css.amd!../assets/listItem.css"],function(E,d,e,i,m){"use strict";if(typeof e>"u")var e=window.Vue;const f=e.defineComponent({__name:"opener",props:{id:{},pos:{default:"3"},notch:{type:Boolean,default:!0},openByHover:{type:Boolean},posBy:{default:"fixed"}},setup(r){const n=r,s=n.id||Math.random()+"";let p;function c(t){setTimeout(()=>{p=t.nextElementSibling,p&&l(p)})}e.onUpdated(()=>{p&&l(p)});function l(t){t.dataset.topPopup="#"+s,t.dataset.topPopupId=s,t.dataset.topPopupPos=n.pos,t.dataset.topPopupPosBy=n.posBy,t.dataset.topPopupNotch=n.notch?"true":"",t.dataset.topPopupOpenByHover=n.openByHover?"true":""}return(t,a)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("template",{ref:c}),e.renderSlot(t.$slots,"default")],64))}}),B={key:0,class:"top-popup_header"},y={key:0,class:"top-as-a closer"},C={key:1,class:"top-popup_widget"},h={key:2,class:"top-popup_content"},_={key:4,class:"top-popup_footer"},v=["href"],$=e.defineComponent({__name:"popup",props:{id:{default:""},class:{},transitionDuration:{},footerSupportLink:{},pos:{default:"3"},notch:{type:Boolean,default:!0},openByHover:{type:Boolean},posBy:{default:"fixed"}},emits:["open","close","scrollContentList"],setup(r,{expose:n,emit:s}){const p=r,c=s,l={popup:void 0};n(l);const t=p.id||"top-popup-id-"+Math.random(),a=e.ref(null),u={onOpen:async o=>{o.elPopupInner&&(o.elPopupInner.innerText="",a.value=o.elPopupInner),u.opened=!0,u.popup=o,l.popup=o,c("open")},onClose:o=>{a.value=null,u.opened=!1,u.popup=void 0,c("close")},classRef:e.toRef(p,"class"),opened:!1,popup:void 0,transitionDurationRef:e.toRef(p,"transitionDuration")};return m.TopPopupWorker.regVueComponent(t,u),e.onUnmounted(()=>{m.TopPopupWorker.unregVueComponent(t)}),(o,k)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[o.$slots.opener?(e.openBlock(),e.createBlock(f,{key:0,id:e.unref(t),pos:o.pos,posBy:o.posBy,notch:o.notch,openByHover:o.openByHover},{default:e.withCtx(()=>[e.renderSlot(o.$slots,"opener")]),_:3},8,["id","pos","posBy","notch","openByHover"])):e.createCommentVNode("",!0),a.value?(e.openBlock(),e.createBlock(e.Teleport,{key:1,to:a.value},[o.$slots.header||e.unref(i.Core).state.isMobile?(e.openBlock(),e.createElementBlock("div",B,[e.unref(i.Core).state.isMobile?(e.openBlock(),e.createElementBlock("span",y,e.toDisplayString(o.$i18n.Common.Close),1)):e.createCommentVNode("",!0),e.renderSlot(o.$slots,"header")])):e.createCommentVNode("",!0),o.$slots.widget?(e.openBlock(),e.createElementBlock("div",C,[e.renderSlot(o.$slots,"widget")])):e.createCommentVNode("",!0),o.$slots.content?(e.openBlock(),e.createElementBlock("div",h,[e.renderSlot(o.$slots,"content")])):e.createCommentVNode("",!0),o.$slots.contentList?(e.openBlock(),e.createElementBlock("ul",{key:3,class:"top-popup_content",onScroll:k[0]||(k[0]=N=>o.$emit("scrollContentList",N))},[e.renderSlot(o.$slots,"contentList")],32)):e.createCommentVNode("",!0),o.$slots.footer||o.footerSupportLink?(e.openBlock(),e.createElementBlock("div",_,[o.footerSupportLink?(e.openBlock(),e.createElementBlock("a",{key:0,class:"top-popup_footerSupportLink",href:o.footerSupportLink,target:"_blank"},[e.createVNode(i.TopHint,{hint:""})],8,v)):e.createCommentVNode("",!0),e.renderSlot(o.$slots,"footer")])):e.createCommentVNode("",!0)],8,["to"])):e.createCommentVNode("",!0)],64))}}),S={$style:{"top-popup_footerSupportLink":"top-popup_footerSupportLink"}},P=i._export_sfc($,[["__cssModules",S]]),V=e.defineComponent({inheritAttrs:!1,__name:"listItem",props:{type:{default:"button"},closeByClick:{type:Boolean,default:!0}},setup(r){const n=r;return(s,p)=>(e.openBlock(),e.createElementBlock("li",{class:e.normalizeClass({"top-popup_liNoSelectable":n.type!=="button"})},[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(s.$attrs.href?"a":"div"),e.mergeProps({class:{"top-popup_listItem":!0,"top-popup_listItem-button":n.type==="button",a:n.type==="button","top-popup_listItem-title":n.type==="title","top-popup_listItem-delimiter":n.type==="delimiter","top-popup-noCloser":!s.closeByClick}},s.$attrs),{default:e.withCtx(()=>[e.renderSlot(s.$slots,"default")]),_:3},16,["class"]))],2))}});d.Popup=P,d._sfc_main=V,d._sfc_main$1=f});
2
+ //# sourceMappingURL=listItem.vue_vue_type_script_setup_true_lang-BxpjEUsq.amd.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"listItem.vue_vue_type_script_setup_true_lang-BxpjEUsq.amd.js","sources":["../../src/components/popup/popup/opener.vue","../../src/components/popup/popup/popup.vue","../../src/components/popup/popup/listItem.vue"],"sourcesContent":["<script setup lang=\"ts\">\r\nimport { onUpdated } from 'vue';\r\nimport type { OpenerProps } from './popup';\r\n\r\nconst props = withDefaults(defineProps<OpenerProps>(), {\r\n\tpos: '3',\r\n\tnotch: true,\r\n\tposBy: 'fixed',\r\n});\r\n\r\nconst id = props.id || Math.random() + '';\r\n\r\nlet elOpener: Element;\r\n\r\n/**\r\n * Необычная функция для проброски props внтурь элемента слота\r\n *\r\n * @param el - вспомогательрный элемент для доступа к элементам слота\r\n */\r\nfunction render(el: any) {\r\n\tsetTimeout(() => {\r\n\t\telOpener = el.nextElementSibling;\r\n\r\n\t\tif (elOpener) {\r\n\t\t\trenderOpener(elOpener);\r\n\t\t}\r\n\t});\r\n}\r\n\r\nonUpdated(() => {\r\n\tif (elOpener) {\r\n\t\trenderOpener(elOpener);\r\n\t}\r\n});\r\n\r\nfunction renderOpener(elOpener: any) {\r\n\t/**\r\n\t * topPopup - необходимый атрибут для всез Popup\r\n\t *\r\n\t * Для Vue вместо него используется атрибут topPopupId\r\n\t */\r\n\telOpener.dataset.topPopup = '#' + id;\r\n\r\n\telOpener.dataset.topPopupId = id;\r\n\telOpener.dataset.topPopupPos = props.pos;\r\n\telOpener.dataset.topPopupPosBy = props.posBy;\r\n\telOpener.dataset.topPopupNotch = props.notch ? 'true' : '';\r\n\telOpener.dataset.topPopupOpenByHover = props.openByHover ? 'true' : '';\r\n}\r\n</script>\r\n\r\n<template>\r\n\t<template :ref=\"render\"></template>\r\n\r\n\t<!-- @slot элемент для открытия Popup -->\r\n\t<slot></slot>\r\n</template>\r\n\r\n<!-- Использует общий deprecated класс .btn -->\r\n<style>\r\nh3[data-top-popup],\r\ndiv[data-top-popup],\r\ni[data-top-popup]:not(.btn),\r\nb[data-top-popup]:not(.btn) {\r\n\tcursor: pointer;\r\n\tuser-select: none;\r\n\tfont-style: normal;\r\n\ttext-decoration: none;\r\n\tdisplay: inline-flex;\r\n\talign-items: center;\r\n}\r\n\r\n[data-top-popup][data-top-popup-disabled] {\r\n\tpointer-events: none;\r\n\tcursor: auto !important;\r\n}\r\n\r\ni[contenteditable] {\r\n\tcursor: text !important;\r\n}\r\n</style>\r\n","<script setup lang=\"ts\">\r\nimport { type Ref } from 'vue';\r\nimport { onUnmounted, ref, toRef } from 'vue';\r\nimport TopHint from '@/components/forms/hint/hint.vue';\r\nimport type PopupClass from '@/components/popup/lib/popup';\r\nimport Core from '@/core/core/core';\r\nimport type { Emits, Props } from './popup';\r\nimport Opener from './opener.vue';\r\nimport Worker from '@/components/popup/lib/worker';\r\n\r\nconst props = withDefaults(defineProps<Props>(), {\r\n\tid: '',\r\n\tpos: '3',\r\n\tnotch: true,\r\n\tposBy: 'fixed',\r\n});\r\n\r\nconst emit = defineEmits<Emits>();\r\n\r\nconst expose = {\r\n\tpopup: undefined as PopupClass | undefined,\r\n};\r\ndefineExpose(expose);\r\n\r\nconst id = props.id || 'top-popup-id-' + Math.random() + '';\r\nconst elPopupRef: Ref<null | Element> = ref(null);\r\n\r\n// см. lib/popup\r\nconst onOpen = async (popup: PopupClass) => {\r\n\tif (popup.elPopupInner) {\r\n\t\tpopup.elPopupInner.innerText = '';\r\n\r\n\t\telPopupRef.value = popup.elPopupInner;\r\n\t}\r\n\r\n\tvueConnector.opened = true;\r\n\tvueConnector.popup = popup;\r\n\r\n\texpose.popup = popup;\r\n\r\n\temit('open');\r\n};\r\n\r\n// см. lib/popup\r\nconst onClose = (_popup: PopupClass) => {\r\n\telPopupRef.value = null;\r\n\r\n\tvueConnector.opened = false;\r\n\tvueConnector.popup = undefined;\r\n\r\n\temit('close');\r\n};\r\n\r\nconst vueConnector = {\r\n\tonOpen,\r\n\tonClose,\r\n\tclassRef: toRef(props, 'class'),\r\n\topened: false,\r\n\tpopup: undefined as PopupClass | undefined,\r\n\ttransitionDurationRef: toRef(props, 'transitionDuration'),\r\n};\r\n\r\nWorker.regVueComponent(id, vueConnector);\r\n\r\nonUnmounted(() => {\r\n\tWorker.unregVueComponent(id);\r\n});\r\n</script>\r\n\r\n<template>\r\n\t<Opener\r\n\t\tv-if=\"$slots.opener\"\r\n\t\t:id=\"id\"\r\n\t\t:pos=\"pos\"\r\n\t\t:posBy=\"posBy\"\r\n\t\t:notch=\"notch\"\r\n\t\t:openByHover=\"openByHover\"\r\n\t>\r\n\t\t<!-- @slot элемент для открытия Popup -->\r\n\t\t<slot name=\"opener\"></slot>\r\n\t</Opener>\r\n\r\n\t<!-- Это шаблон для компонента Popup, сам Popup генерируется в js и может находиться где угодно -->\r\n\t<!-- elPopupRef будет установлен только после открытия и будет сброшен сразу после закрытия Popup -->\r\n\t<teleport\r\n\t\tv-if=\"elPopupRef\"\r\n\t\t:to=\"elPopupRef\"\r\n\t>\r\n\t\t<div v-if=\"$slots.header || Core.state.isMobile\" class=\"top-popup_header\">\r\n\t\t\t<span\r\n\t\t\t\tv-if=\"Core.state.isMobile\"\r\n\t\t\t\tclass=\"top-as-a closer\"\r\n\t\t\t>\r\n\t\t\t\t{{ $i18n.Common.Close }}\r\n\t\t\t</span>\r\n\r\n\t\t\t<!-- @slot Шапка -->\r\n\t\t\t<slot name=\"header\"></slot>\r\n\t\t</div>\r\n\r\n\t\t<div v-if=\"$slots.widget\" class=\"top-popup_widget\">\r\n\t\t\t<!-- @slot Виджет -->\r\n\t\t\t<slot name=\"widget\"></slot>\r\n\t\t</div>\r\n\r\n\t\t<div v-if=\"$slots.content\" class=\"top-popup_content\">\r\n\t\t\t<!-- @slot Контент в свободной форме -->\r\n\t\t\t<slot name=\"content\"></slot>\r\n\t\t</div>\r\n\r\n\t\t<ul\r\n\t\t\tv-if=\"$slots.contentList\"\r\n\t\t\tclass=\"top-popup_content\"\r\n\t\t\t@scroll=\"$emit('scrollContentList', $event)\"\r\n\t\t>\r\n\t\t\t<!-- @slot Контент в виде списка, для вставки элементов списка используйте компонент popup/listItem -->\r\n\t\t\t<slot name=\"contentList\"></slot>\r\n\t\t</ul>\r\n\r\n\t\t<div v-if=\"$slots.footer || footerSupportLink\" class=\"top-popup_footer\">\r\n\t\t\t<a\r\n\t\t\t\tv-if=\"footerSupportLink\"\r\n\t\t\t\tclass=\"top-popup_footerSupportLink\"\r\n\t\t\t\t:href=\"footerSupportLink\"\r\n\t\t\t\ttarget=\"_blank\"\r\n\t\t\t>\r\n\t\t\t\t<TopHint hint=\"\"/>\r\n\t\t\t</a>\r\n\r\n\t\t\t<!-- @slot Футер -->\r\n\t\t\t<slot name=\"footer\"></slot>\r\n\t\t</div>\r\n\t</teleport>\r\n</template>\r\n\r\n<style module>\r\n.top-popup_footerSupportLink {\r\n\tmargin-right: auto;\r\n}\r\n</style>\r\n","<script setup lang=\"ts\">\r\nimport type { ListItemProps } from './popup';\r\n\r\ndefineOptions({\r\n\tinheritAttrs: false,\r\n});\r\n\r\nconst props = withDefaults(defineProps<ListItemProps>(), {\r\n\ttype: 'button',\r\n\tcloseByClick: true,\r\n});\r\n</script>\r\n\r\n<template>\r\n\t<li\r\n\t\t:class=\"{\r\n\t\t'top-popup_liNoSelectable': props.type !== 'button'\r\n\t}\"\r\n\t>\r\n\t\t<component\r\n\t\t\t:is=\"$attrs.href ? 'a' : 'div'\"\r\n\t\t\t:class=\"{\r\n\t\t\t\t'top-popup_listItem': true,\r\n\t\t\t\t'top-popup_listItem-button': props.type === 'button', // оформления кнопки\r\n\t\t\t\t'a': props.type === 'button', // оформления кнопки, deprecated\r\n\t\t\t\t'top-popup_listItem-title': props.type === 'title',\r\n\t\t\t\t'top-popup_listItem-delimiter': props.type === 'delimiter',\r\n\t\t\t\t'top-popup-noCloser': !closeByClick\r\n\t\t\t}\"\r\n\t\t\t:=$attrs\r\n\t\t>\r\n\t\t\t<slot></slot>\r\n\t\t</component>\r\n\t</li>\r\n</template>\r\n"],"names":["props","__props","id","render","el","elOpener","renderOpener","elOpener2","emit","__emit","__expose","expose","elPopupRef","vue","popup","vueConnector","_popup","popup_worker"],"mappings":"qWAIA,MAAAA,EAAAC,EAMAC,EAAAF,EAAA,IAAA,KAAA,OAAA,EAAA,SASA,SAAAG,EAAAC,EAAA,iBAEEC,EAAAD,EAAA,sBAGCE,EAAAD,CAAA,CACD,CAAA,sBAMAC,EAAAD,CAAA,CACD,CAAA,EAGD,SAAAC,EAAAC,EAAA,0BAQCA,EAAA,QAAA,WAAAL,8DAGAK,EAAA,QAAA,cAAAP,EAAA,MAAA,OAAA,GACAO,EAAA,QAAA,oBAAAP,EAAA,YAAA,OAAA,6mBCrCD,MAAAA,EAAAC,EAOAO,EAAAC,iBAGQ,EAERC,EAAAC,CAAA,EAEA,MAAAT,EAAAF,EAAA,IAAA,gBAAA,KAAA,OAAA,EACAY,EAAAC,EAAA,IAAA,IAAA,KA4BqB,OAzBrB,MAAAC,GAAA,CACCA,EAAA,eACCA,EAAA,aAAA,UAAA,GAEAF,EAAA,MAAAE,EAAA,cAGDC,EAAA,OAAA,GACAA,EAAA,MAAAD,EAEAH,EAAA,MAAAG,EAEAN,EAAA,MAAA,CAAW,EAcX,QAVDQ,GAAA,CACCJ,EAAA,MAAA,KAEAG,EAAA,OAAA,GACAA,EAAA,MAAA,OAEAP,EAAA,OAAA,CAAY,EAKZ,SAAAK,EAAA,MAAAb,EAAA,OAAA,yBAGO,sBAAAa,EAAA,MAAAb,EAAA,oBAAA,CACiD,kEAMxDiB,EAAA,eAAA,kBAAAf,CAAA,CAA2B,CAAA,6yDC1D5B,MAAAF,EAAAC"}
@@ -1,6 +1,6 @@
1
1
  import S from "../core/core.js";
2
2
  import { defineComponent as T, mergeModels as E, useModel as W, ref as w, onMounted as N, onUpdated as b, openBlock as c, createElementBlock as f, normalizeClass as P, Fragment as $, renderList as q, createBlock as x, mergeProps as d, createSlots as y, withCtx as h, createTextVNode as A, toDisplayString as g, createVNode as D, createCommentVNode as K } from "vue";
3
- import { T as M, i as Y, C as z, _ as F } from "./forms-DT_fsN6V.es.js";
3
+ import { T as M, i as Y, C as z, _ as F } from "./forms-D9r2-H5Y.es.js";
4
4
  const I = ["../assets/menu.css"].map((i) => import.meta.resolve(i));
5
5
  S.insertCSSLinkToPage(I, !0);
6
6
  const O = {
@@ -115,4 +115,4 @@ const O = {
115
115
  export {
116
116
  R as M
117
117
  };
118
- //# sourceMappingURL=menu-CcyqVSfg.es.js.map
118
+ //# sourceMappingURL=menu-B0Ul7Kbg.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"menu-B0Ul7Kbg.es.js","sources":["../../src/components/formsExt/menu/menu.vue"],"sourcesContent":["<script setup lang=\"ts\">\r\nimport { onMounted, onUpdated, ref } from 'vue';\r\nimport type { Item, Props } from './menu';\r\nimport Core from '@/core/core/core';\r\nimport { isSafari } from '@/core/utils/device';\r\nimport TopButton from '@/components/forms/button/button.vue';\r\n\r\nconst props = withDefaults(defineProps<Props>(), {\r\n\tstyling: 'default',\r\n});\r\n\r\nconst model = defineModel({\r\n\trequired: true,\r\n});\r\n\r\nconst el = ref();\r\n\r\n// валидация типа modelValue без возможности выбора нескольких значений (ожидается строка)\r\nif (!props.isMultiple && !(typeof (model.value) === 'string' || model.value instanceof String)) {\r\n\tconsole.warn('Type check failed for prop \"modelValue\". Expected String: ' + typeof (model.value));\r\n}\r\n\r\n// валидация типа modelValue с возможностью выбора нескольких значений (ожидается массив)\r\nif (props.isMultiple && !Array.isArray(model.value)) {\r\n\tconsole.warn('Type check failed for prop \"modelValue\". Expected Array: ' + typeof (model.value));\r\n}\r\n\r\n// для множественного выбора без пустого множества\r\n// если ничего не выбрано, присваиваем 1-ое значение\r\nif (props.isMultiple && !props.canBeEmptyMultiple && Array.isArray(model.value) && !model.value.length) {\r\n\tmodel.value = [props.items[0].href ?? props.items[0].value];\r\n}\r\n\r\nconst itemIsActive = (item: Item) => {\r\n\tif (!Array.isArray(model.value)) {\r\n\t\treturn item.value === model.value;\r\n\t}\r\n\r\n\treturn model.value.includes(item.value);\r\n};\r\n\r\n/**\r\n * Выбрать элемент\r\n * @param item\r\n * @param toggle - добавить или исключить элемент, для isMultiple\r\n */\r\nconst select = (item: Item, toggle = false) => {\r\n\tif (Array.isArray(model.value)) {\r\n\t\tlet modelNew = model.value.slice();\r\n\r\n\t\tif (toggle) {\r\n\t\t\tif (!modelNew.length) modelNew = props.items.map(item => item.value);\r\n\r\n\t\t\tconst index = modelNew.indexOf(item.value);\r\n\t\t\tif (index === -1) {\r\n\t\t\t\tmodelNew.push(item.value);\r\n\t\t\t} else {\r\n\t\t\t\tmodelNew.splice(index, 1);\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tif (modelNew.length === 1 && modelNew[0] === item.value) {\r\n\t\t\t\tmodelNew = [];\r\n\t\t\t} else {\r\n\t\t\t\tmodelNew = [item.value];\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (!props.canBeEmptyMultiple && !modelNew.length) modelNew = [item.value];\r\n\r\n\t\tmodel.value = modelNew;\r\n\r\n\t\treturn;\r\n\t}\r\n\r\n\tmodel.value = item.value;\r\n};\r\n\r\n// вертикальный скролл в горизонтальный скролл\r\nconst onWheel = (event: WheelEvent) => {\r\n\tif (el.value.scrollWidth <= el.value.offsetWidth) return;\r\n\tif (event.shiftKey) return;\r\n\tif (Math.abs(event.deltaY) < 50) return; // устройство с высокой точностью, например тачпад\r\n\r\n\tevent.preventDefault();\r\n\r\n\tconst delta = event.deltaY > 0 ? 30 : -30;\r\n\tel.value.scrollLeft = el.value.scrollLeft + delta;\r\n};\r\n\r\n/**\r\n * Замена стандартному scrollIntoView, который меняет скролл документа\r\n *\r\n * Выравнивание по ближнему краю элемента\r\n *\r\n * Выравнивается таким образом, чтобы был виден соседний элемент\r\n */\r\nconst scrollIntoView = (isSmooth = true) => {\r\n\tconst elBtn = el.value.querySelector('.top-active');\r\n\tif (!elBtn) return;\r\n\r\n\tconst gap = 24;\r\n\r\n\t// левая и правая координаты элемента\r\n\tconst leftMargin = elBtn.offsetLeft - el.value.offsetLeft - gap;\r\n\tconst rightMargin = elBtn.offsetLeft - el.value.offsetLeft + elBtn.clientWidth + gap;\r\n\r\n\t// левая и правая границы видимой части меню\r\n\tconst leftMarginParent = el.value.scrollLeft;\r\n\tconst rightMarginParent = el.value.clientWidth + el.value.scrollLeft;\r\n\r\n\tlet scrollLeft: number | undefined = undefined;\r\n\r\n\t// левую границу элемента к левой границе меню\r\n\tif (leftMargin < leftMarginParent) scrollLeft = leftMargin;\r\n\r\n\t// правую границу элемента к правой границе меню\r\n\tif (rightMargin > rightMarginParent) scrollLeft = rightMargin - el.value.clientWidth;\r\n\r\n\tif (scrollLeft !== undefined) {\r\n\t\tif (isSafari()) {\r\n\t\t\tCore.$?.(el.value).animate({ scrollLeft: scrollLeft }, isSmooth ? 200 : 0);\r\n\t\t} else {\r\n\t\t\tel.value.scrollTo({ left: scrollLeft, behavior: isSmooth ? 'smooth' : 'auto' });\r\n\t\t}\r\n\t}\r\n};\r\n\r\n/**\r\n * Выбрать все элементы в меню\r\n */\r\nconst selectAll = () => {\r\n\tif (!Array.isArray(model.value)) return;\r\n\r\n\tif (model.value.length === props.items.length) {\r\n\t\tmodel.value = [props.items[0].href ?? props.items[0].value];\r\n\t\treturn;\r\n\t}\r\n\r\n\tmodel.value = props.items.map(item => item.href ?? item.value);\r\n};\r\n\r\nonMounted(() => scrollIntoView(false));\r\nonUpdated(() => scrollIntoView(true));\r\n\r\n</script>\r\n\r\n<template>\r\n\t<div\r\n\t\tref=\"el\"\r\n\t\t:class=\"{\r\n\t\t\t'top-menu': true,\r\n\t\t\t['top-style_' + styling]: true,\r\n\t\t\t// ['top-unwrap-x']: styling === 'default',\r\n\t\t}\"\r\n\t\t@wheel=\"onWheel\"\r\n\t>\r\n\t\t<TopButton\r\n\t\t\tv-for=\"item in items\"\r\n\t\t\t:=\"item\"\r\n\t\t\tclass=\"top-menu_item\"\r\n\t\t\tcolor=\"theme\"\r\n\t\t\t@click=\"select(item, $event.ctrlKey)\"\r\n\t\t\t:isActive=\"itemIsActive(item)\"\r\n\t\t>\r\n\t\t\t<template #default v-if=\"item.content\">\r\n\t\t\t\t{{ item.content }}\r\n\t\t\t</template>\r\n\t\t</TopButton>\r\n\r\n\t\t<div\r\n\t\t\tv-if=\"Array.isArray(model) && selectAllItem\"\r\n\t\t\tclass=\"top-menu_selectAll\"\r\n\t\t>\r\n\t\t\t<TopButton\r\n\t\t\t\t:=\"selectAllItem\"\r\n\t\t\t\tclass=\"top-menu_item\"\r\n\t\t\t\tcolor=\"theme\"\r\n\t\t\t\tstyling=\"\"\r\n\t\t\t\t@click=\"selectAll()\"\r\n\t\t\t\t:isActive=\"model.length === items.length\"\r\n\t\t\t>\r\n\t\t\t\t<template #default v-if=\"selectAllItem.content\">\r\n\t\t\t\t\t{{ selectAllItem.content }}\r\n\t\t\t\t</template>\r\n\t\t\t</TopButton>\r\n\t\t</div>\r\n\t</div>\r\n</template>\r\n\r\n<style module>\r\n.top-menu {\r\n\t--scroll-thumb-color: var(--color-line-1);\r\n\t--scroll-thumb-color-hover: var(--color-line-2);\r\n\t--scroll-thumb-color-active: var(--color-line-3);\r\n\r\n\tmax-width: 100%;\r\n\tdisplay: flex;\r\n\talign-items: flex-start;\r\n\tgap: var(--top-gap-2);\r\n\toverflow-x: auto;\r\n\tscrollbar-width: none; /* firefox */\r\n\r\n\t/* предотвратить натинвые события браузера (назад / вперед) */\r\n\toverscroll-behavior-x: contain;\r\n}\r\n\r\n.top-menu::-webkit-scrollbar { display: none; }\r\n\r\n.top-menu .top-menu_item {\r\n\t--top-button-color: var(--color-text-2);\r\n\r\n\toutline-offset: -2px !important;\r\n\tmin-width: 0;\r\n\tmargin: 0;\r\n\tflex-shrink: 0;\r\n}\r\n\r\n.top-menu .top-menu_item[data-top-icon] {\r\n\t--top-icon-color: var(--color-text-2);\r\n}\r\n\r\n.top-menu_selectAll {\r\n\tposition: sticky;\r\n\tright: 0;\r\n\tbackground: var(--color-layout-front-1);\r\n\tborder-left: 1px solid var(--color-line-1);\r\n\tpadding-left: var(--top-padding-1);\r\n\tbox-shadow: var(--color-layout-front-1) var(--top-padding-2) 0px;\r\n}\r\n\r\n/* style default */\r\n.top-menu.top-style_default .top-menu_item {\r\n\t--top-forms-radius: 0;\r\n\t--top-forms-border-color: transparent;\r\n\t--top-forms-border-width: 2px;\r\n\r\n\tfilter: none;\r\n\tbox-shadow: none;\r\n\tborder: none;\r\n\tborder-bottom: var(--top-forms-border-width) solid var(--top-forms-border-color);\r\n\tbackground: none;\r\n}\r\n\r\n.top-style_default > .top-menu_item > [data-top-badge] {\r\n\tmargin-top: 0;\r\n}\r\n\r\n.top-menu.top-style_default .top-menu_item:hover {\r\n\t--top-icon-color: var(--color-text-1);\r\n\t--top-button-color: var(--color-text-1);\r\n\t--top-forms-border-color: var(--color-line-2);\r\n}\r\n\r\n.top-menu.top-style_default .top-menu_item:active,\r\n.top-menu.top-style_default .top-menu_item.top-active {\r\n\t--top-icon-color: var(--color-text-primary);\r\n\t--top-button-color: var(--color-text-1);\r\n\t--top-forms-border-color: var(--color-line-primary-1);\r\n}\r\n\r\n.top-menu.top-style_default .top-menu_selectAll {\r\n\tpadding-left: var(--top-padding-2);\r\n}\r\n\r\n/* style bar */\r\n.top-menu.top-style_bar {\r\n\tborder-radius: var(--top-radius-3);\r\n\tborder: 1px solid var(--color-line-2);\r\n\tpadding: var(--top-padding-1);\r\n\tgap: 3px;\r\n}\r\n.top-menu.top-style_bar .top-menu_item {\r\n\t--top-button-background-color-hover: var(--color-layer-1);\r\n\t--top-button-background-color-active: var(--color-layer-2);\r\n\t--top-button-background-color-selected: var(--color-layer-primary-1);\r\n\r\n\tposition: relative;\r\n}\r\n\r\n.top-menu.top-style_bar .top-menu_item:hover {\r\n\t--top-icon-color: var(--color-text-1);\r\n\t--top-button-color: var(--color-text-1);\r\n}\r\n\r\n.top-menu.top-style_bar .top-menu_item.top-active {\r\n\t--top-icon-color: var(--color-text-primary);\r\n\t--top-button-color: var(--color-text-primary);\r\n}\r\n\r\n/* разделители кнопок в баре */\r\n.top-menu.top-style_bar .top-menu_item:not(:first-child):not(.top-active):not(:hover):after {\r\n\tcontent: \"\";\r\n\tbackground: var(--color-line-1-opacity);\r\n\twidth: 1px;\r\n\theight: 60%;\r\n\tdisplay: block;\r\n\tposition: absolute;\r\n\tleft: -2px;\r\n}\r\n.top-menu.top-style_bar .top-menu_item.top-active + .top-menu_item:after,\r\n.top-menu.top-style_bar .top-menu_item:hover + .top-menu_item:after {\r\n\tcontent: none !important;\r\n}\r\n\r\n/*\r\n.top-style_bar > .top-menu_item > [data-top-badge] {\r\n\tmargin-top: -3px;\r\n}\r\n*/\r\n\r\n/** TODO: .top-unwrap-x надо вынести глобально в UI или добавить в стили для storybook */\r\n/*\r\n.top-menu.top-unwrap-x {\r\n\tpadding-right: var(--top-unwrap-x);\r\n\tpadding-left: var(--top-unwrap-x);\r\n\tmargin-right: calc(0px - var(--top-unwrap-x));\r\n\tmargin-left: calc(0px - var(--top-unwrap-x));\r\n}\r\n*/\r\n</style>\r\n"],"names":["props","__props","model","useModel","el","ref","itemIsActive","item","select","toggle","modelNew","item2","index","onWheel","event","delta","scrollIntoView","isSmooth","elBtn","gap","leftMargin","rightMargin","leftMarginParent","rightMarginParent","scrollLeft","isSafari","_b","_a","Core","selectAll","onMounted","onUpdated"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAOA,UAAAA,IAAAC,GAIAC,IAAAC,EAAAF,GAAA,YAAA,GAIAG,IAAAC,EAAA;AAGA,IAAA,CAAAL,EAAA,cAAA,EAAA,OAAAE,EAAA,SAAA,YAAAA,EAAA,iBAAA,WACC,QAAA,KAAA,+DAAA,OAAAA,EAAA,KAAA,GAIDF,EAAA,cAAA,CAAA,MAAA,QAAAE,EAAA,KAAA,KACC,QAAA,KAAA,8DAAA,OAAAA,EAAA,KAAA,GAKDF,EAAA,cAAA,CAAAA,EAAA,sBAAA,MAAA,QAAAE,EAAA,KAAA,KAAA,CAAAA,EAAA,MAAA,WACCA,EAAA,QAAA,CAAAF,EAAA,MAAA,CAAA,EAAA,QAAAA,EAAA,MAAA,CAAA,EAAA,KAAA;AAGD,UAAAM,IAAA,CAAAC,MACC,MAAA,QAAAL,EAAA,KAAA,IAIAA,EAAA,MAAA,SAAAK,EAAA,KAAA,IAHCA,EAAA,UAAAL,EAAA,OAWFM,IAAA,CAAAD,GAAAE,IAAA,OAAA;AACC,UAAA,MAAA,QAAAP,EAAA,KAAA,GAAA;AACC,YAAAQ,IAAAR,EAAA,MAAA,MAAA;AAEA,YAAAO,GAAA;AACC,UAAAC,EAAA,WAAAA,IAAAV,EAAA,MAAA,IAAA,CAAAW,MAAAA,EAAA,KAAA;AAEA,gBAAAC,IAAAF,EAAA,QAAAH,EAAA,KAAA;AACA,UAAAK,MAAA,KACCF,EAAA,KAAAH,EAAA,KAAA,IAEAG,EAAA,OAAAE,GAAA,CAAA;AAAA,QACD;AAEA,UAAAF,EAAA,WAAA,KAAAA,EAAA,CAAA,MAAAH,EAAA,QACCG,IAAA,CAAA,IAEAA,IAAA,CAAAH,EAAA,KAAA;AAIF,QAAA,CAAAP,EAAA,sBAAA,CAAAU,EAAA,WAAAA,IAAA,CAAAH,EAAA,KAAA,IAEAL,EAAA,QAAAQ;AAEA;AAAA,MAAA;AAGD,MAAAR,EAAA,QAAAK,EAAA;AAAA,IAAmB,GAIpBM,IAAA,CAAAC,MAAA;AAGC,UAFAV,EAAA,MAAA,eAAAA,EAAA,MAAA,eACAU,EAAA,YACA,KAAA,IAAAA,EAAA,MAAA,IAAA,GAAA;AAEA,MAAAA,EAAA,eAAA;AAEA,YAAAC,IAAAD,EAAA,SAAA,IAAA,KAAA;AACA,MAAAV,EAAA,MAAA,aAAAA,EAAA,MAAA,aAAAW;AAAA,IAA4C,GAU7CC,IAAA,CAAAC,IAAA,OAAA;;AACC,YAAAC,IAAAd,EAAA,MAAA,cAAA,aAAA;AACA,UAAA,CAAAc,EAAA;AAEA,YAAAC,IAAA,IAGAC,IAAAF,EAAA,aAAAd,EAAA,MAAA,aAAAe,GACAE,IAAAH,EAAA,aAAAd,EAAA,MAAA,aAAAc,EAAA,cAAAC,GAGAG,IAAAlB,EAAA,MAAA,YACAmB,IAAAnB,EAAA,MAAA,cAAAA,EAAA,MAAA;AAEA,UAAAoB;AAGA,MAAAJ,IAAAE,MAAAE,IAAAJ,IAGAC,IAAAE,MAAAC,IAAAH,IAAAjB,EAAA,MAAA,cAEAoB,MAAA,WACCC,EAAA,KACCC,KAAAC,IAAAC,GAAA,MAAA,QAAAF,EAAA,KAAAC,GAAAvB,EAAA,OAAA,QAAA,EAAA,YAAAoB,EAAA,GAAAP,IAAA,MAAA,KAEAb,EAAA,MAAA,SAAA,EAAA,MAAAoB,GAAA,UAAAP,IAAA,WAAA,OAAA,CAAA;AAAA,IAEF,GAMDY,IAAA,MAAA;AACC,UAAA,MAAA,QAAA3B,EAAA,KAAA,GAEA;AAAA,YAAAA,EAAA,MAAA,WAAAF,EAAA,MAAA,QAAA;AACC,UAAAE,EAAA,QAAA,CAAAF,EAAA,MAAA,CAAA,EAAA,QAAAA,EAAA,MAAA,CAAA,EAAA,KAAA;AACA;AAAA,QAAA;AAGD,QAAAE,EAAA,QAAAF,EAAA,MAAA,IAAA,CAAAO,MAAAA,EAAA,QAAAA,EAAA,KAAA;AAAA;AAAA,IAA6D;AAG9D,WAAAuB,EAAA,MAAAd,EAAA,EAAA,CAAA,GACAe,EAAA,MAAAf,EAAA,EAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,2 +1,2 @@
1
- define(["require","exports","vue","./forms-DKL0e9tp.amd","../require/css.amd!../assets/menu.css"],function(C,m,e,u){"use strict";if(typeof e>"u")var e=window.Vue;const y={key:0,class:"top-menu_selectAll"},h=e.defineComponent({__name:"menu",props:e.mergeModels({modelValue:{},items:{},isMultiple:{type:Boolean},canBeEmptyMultiple:{type:Boolean},styling:{default:"default"},selectAllItem:{}},{modelValue:{required:!0},modelModifiers:{}}),emits:["update:modelValue"],setup(f){const s=f,o=e.useModel(f,"modelValue"),a=e.ref();!s.isMultiple&&!(typeof o.value=="string"||o.value instanceof String)&&console.warn('Type check failed for prop "modelValue". Expected String: '+typeof o.value),s.isMultiple&&!Array.isArray(o.value)&&console.warn('Type check failed for prop "modelValue". Expected Array: '+typeof o.value),s.isMultiple&&!s.canBeEmptyMultiple&&Array.isArray(o.value)&&!o.value.length&&(o.value=[s.items[0].href??s.items[0].value]);const M=t=>Array.isArray(o.value)?o.value.includes(t.value):t.value===o.value,k=(t,r=!1)=>{if(Array.isArray(o.value)){let l=o.value.slice();if(r){l.length||(l=s.items.map(c=>c.value));const n=l.indexOf(t.value);n===-1?l.push(t.value):l.splice(n,1)}else l.length===1&&l[0]===t.value?l=[]:l=[t.value];!s.canBeEmptyMultiple&&!l.length&&(l=[t.value]),o.value=l;return}o.value=t.value},_=t=>{if(a.value.scrollWidth<=a.value.offsetWidth||t.shiftKey||Math.abs(t.deltaY)<50)return;t.preventDefault();const r=t.deltaY>0?30:-30;a.value.scrollLeft=a.value.scrollLeft+r},p=(t=!0)=>{var v,d;const r=a.value.querySelector(".top-active");if(!r)return;const l=24,n=r.offsetLeft-a.value.offsetLeft-l,c=r.offsetLeft-a.value.offsetLeft+r.clientWidth+l,V=a.value.scrollLeft,L=a.value.clientWidth+a.value.scrollLeft;let i;n<V&&(i=n),c>L&&(i=c-a.value.clientWidth),i!==void 0&&(u.isSafari()?(d=(v=u.Core).$)==null||d.call(v,a.value).animate({scrollLeft:i},t?200:0):a.value.scrollTo({left:i,behavior:t?"smooth":"auto"}))},B=()=>{if(Array.isArray(o.value)){if(o.value.length===s.items.length){o.value=[s.items[0].href??s.items[0].value];return}o.value=s.items.map(t=>t.href??t.value)}};return e.onMounted(()=>p(!1)),e.onUpdated(()=>p(!0)),(t,r)=>(e.openBlock(),e.createElementBlock("div",{ref_key:"el",ref:a,class:e.normalizeClass({"top-menu":!0,["top-style_"+t.styling]:!0}),onWheel:_},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.items,l=>(e.openBlock(),e.createBlock(u.TopButton,e.mergeProps({ref_for:!0},l,{class:"top-menu_item",color:"theme",onClick:n=>k(l,n.ctrlKey),isActive:M(l)}),e.createSlots({_:2},[l.content?{name:"default",fn:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(l.content),1)]),key:"0"}:void 0]),1040,["onClick","isActive"]))),256)),Array.isArray(o.value)&&t.selectAllItem?(e.openBlock(),e.createElementBlock("div",y,[e.createVNode(u.TopButton,e.mergeProps(t.selectAllItem,{class:"top-menu_item",color:"theme",styling:"",onClick:r[0]||(r[0]=l=>B()),isActive:o.value.length===t.items.length}),e.createSlots({_:2},[t.selectAllItem.content?{name:"default",fn:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(t.selectAllItem.content),1)]),key:"0"}:void 0]),1040,["isActive"])])):e.createCommentVNode("",!0)],34))}}),g={$style:{"top-menu":"top-menu","top-menu_item":"top-menu_item","top-menu_selectAll":"top-menu_selectAll","top-style_default":"top-style_default","top-active":"top-active","top-style_bar":"top-style_bar"}},A=u._export_sfc(h,[["__cssModules",g]]);m.Menu=A});
2
- //# sourceMappingURL=menu-DTbsTDGK.amd.js.map
1
+ define(["require","exports","vue","./forms-BImXJ_ZO.amd","../require/css.amd!../assets/menu.css"],function(C,m,e,u){"use strict";if(typeof e>"u")var e=window.Vue;const y={key:0,class:"top-menu_selectAll"},h=e.defineComponent({__name:"menu",props:e.mergeModels({modelValue:{},items:{},isMultiple:{type:Boolean},canBeEmptyMultiple:{type:Boolean},styling:{default:"default"},selectAllItem:{}},{modelValue:{required:!0},modelModifiers:{}}),emits:["update:modelValue"],setup(f){const s=f,o=e.useModel(f,"modelValue"),a=e.ref();!s.isMultiple&&!(typeof o.value=="string"||o.value instanceof String)&&console.warn('Type check failed for prop "modelValue". Expected String: '+typeof o.value),s.isMultiple&&!Array.isArray(o.value)&&console.warn('Type check failed for prop "modelValue". Expected Array: '+typeof o.value),s.isMultiple&&!s.canBeEmptyMultiple&&Array.isArray(o.value)&&!o.value.length&&(o.value=[s.items[0].href??s.items[0].value]);const M=t=>Array.isArray(o.value)?o.value.includes(t.value):t.value===o.value,k=(t,r=!1)=>{if(Array.isArray(o.value)){let l=o.value.slice();if(r){l.length||(l=s.items.map(c=>c.value));const n=l.indexOf(t.value);n===-1?l.push(t.value):l.splice(n,1)}else l.length===1&&l[0]===t.value?l=[]:l=[t.value];!s.canBeEmptyMultiple&&!l.length&&(l=[t.value]),o.value=l;return}o.value=t.value},_=t=>{if(a.value.scrollWidth<=a.value.offsetWidth||t.shiftKey||Math.abs(t.deltaY)<50)return;t.preventDefault();const r=t.deltaY>0?30:-30;a.value.scrollLeft=a.value.scrollLeft+r},p=(t=!0)=>{var v,d;const r=a.value.querySelector(".top-active");if(!r)return;const l=24,n=r.offsetLeft-a.value.offsetLeft-l,c=r.offsetLeft-a.value.offsetLeft+r.clientWidth+l,V=a.value.scrollLeft,L=a.value.clientWidth+a.value.scrollLeft;let i;n<V&&(i=n),c>L&&(i=c-a.value.clientWidth),i!==void 0&&(u.isSafari()?(d=(v=u.Core).$)==null||d.call(v,a.value).animate({scrollLeft:i},t?200:0):a.value.scrollTo({left:i,behavior:t?"smooth":"auto"}))},B=()=>{if(Array.isArray(o.value)){if(o.value.length===s.items.length){o.value=[s.items[0].href??s.items[0].value];return}o.value=s.items.map(t=>t.href??t.value)}};return e.onMounted(()=>p(!1)),e.onUpdated(()=>p(!0)),(t,r)=>(e.openBlock(),e.createElementBlock("div",{ref_key:"el",ref:a,class:e.normalizeClass({"top-menu":!0,["top-style_"+t.styling]:!0}),onWheel:_},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.items,l=>(e.openBlock(),e.createBlock(u.TopButton,e.mergeProps({ref_for:!0},l,{class:"top-menu_item",color:"theme",onClick:n=>k(l,n.ctrlKey),isActive:M(l)}),e.createSlots({_:2},[l.content?{name:"default",fn:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(l.content),1)]),key:"0"}:void 0]),1040,["onClick","isActive"]))),256)),Array.isArray(o.value)&&t.selectAllItem?(e.openBlock(),e.createElementBlock("div",y,[e.createVNode(u.TopButton,e.mergeProps(t.selectAllItem,{class:"top-menu_item",color:"theme",styling:"",onClick:r[0]||(r[0]=l=>B()),isActive:o.value.length===t.items.length}),e.createSlots({_:2},[t.selectAllItem.content?{name:"default",fn:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(t.selectAllItem.content),1)]),key:"0"}:void 0]),1040,["isActive"])])):e.createCommentVNode("",!0)],34))}}),g={$style:{"top-menu":"top-menu","top-menu_item":"top-menu_item","top-menu_selectAll":"top-menu_selectAll","top-style_default":"top-style_default","top-active":"top-active","top-style_bar":"top-style_bar"}},A=u._export_sfc(h,[["__cssModules",g]]);m.Menu=A});
2
+ //# sourceMappingURL=menu-CbhB9e4x.amd.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"menu-CbhB9e4x.amd.js","sources":["../../src/components/formsExt/menu/menu.vue"],"sourcesContent":["<script setup lang=\"ts\">\r\nimport { onMounted, onUpdated, ref } from 'vue';\r\nimport type { Item, Props } from './menu';\r\nimport Core from '@/core/core/core';\r\nimport { isSafari } from '@/core/utils/device';\r\nimport TopButton from '@/components/forms/button/button.vue';\r\n\r\nconst props = withDefaults(defineProps<Props>(), {\r\n\tstyling: 'default',\r\n});\r\n\r\nconst model = defineModel({\r\n\trequired: true,\r\n});\r\n\r\nconst el = ref();\r\n\r\n// валидация типа modelValue без возможности выбора нескольких значений (ожидается строка)\r\nif (!props.isMultiple && !(typeof (model.value) === 'string' || model.value instanceof String)) {\r\n\tconsole.warn('Type check failed for prop \"modelValue\". Expected String: ' + typeof (model.value));\r\n}\r\n\r\n// валидация типа modelValue с возможностью выбора нескольких значений (ожидается массив)\r\nif (props.isMultiple && !Array.isArray(model.value)) {\r\n\tconsole.warn('Type check failed for prop \"modelValue\". Expected Array: ' + typeof (model.value));\r\n}\r\n\r\n// для множественного выбора без пустого множества\r\n// если ничего не выбрано, присваиваем 1-ое значение\r\nif (props.isMultiple && !props.canBeEmptyMultiple && Array.isArray(model.value) && !model.value.length) {\r\n\tmodel.value = [props.items[0].href ?? props.items[0].value];\r\n}\r\n\r\nconst itemIsActive = (item: Item) => {\r\n\tif (!Array.isArray(model.value)) {\r\n\t\treturn item.value === model.value;\r\n\t}\r\n\r\n\treturn model.value.includes(item.value);\r\n};\r\n\r\n/**\r\n * Выбрать элемент\r\n * @param item\r\n * @param toggle - добавить или исключить элемент, для isMultiple\r\n */\r\nconst select = (item: Item, toggle = false) => {\r\n\tif (Array.isArray(model.value)) {\r\n\t\tlet modelNew = model.value.slice();\r\n\r\n\t\tif (toggle) {\r\n\t\t\tif (!modelNew.length) modelNew = props.items.map(item => item.value);\r\n\r\n\t\t\tconst index = modelNew.indexOf(item.value);\r\n\t\t\tif (index === -1) {\r\n\t\t\t\tmodelNew.push(item.value);\r\n\t\t\t} else {\r\n\t\t\t\tmodelNew.splice(index, 1);\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tif (modelNew.length === 1 && modelNew[0] === item.value) {\r\n\t\t\t\tmodelNew = [];\r\n\t\t\t} else {\r\n\t\t\t\tmodelNew = [item.value];\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (!props.canBeEmptyMultiple && !modelNew.length) modelNew = [item.value];\r\n\r\n\t\tmodel.value = modelNew;\r\n\r\n\t\treturn;\r\n\t}\r\n\r\n\tmodel.value = item.value;\r\n};\r\n\r\n// вертикальный скролл в горизонтальный скролл\r\nconst onWheel = (event: WheelEvent) => {\r\n\tif (el.value.scrollWidth <= el.value.offsetWidth) return;\r\n\tif (event.shiftKey) return;\r\n\tif (Math.abs(event.deltaY) < 50) return; // устройство с высокой точностью, например тачпад\r\n\r\n\tevent.preventDefault();\r\n\r\n\tconst delta = event.deltaY > 0 ? 30 : -30;\r\n\tel.value.scrollLeft = el.value.scrollLeft + delta;\r\n};\r\n\r\n/**\r\n * Замена стандартному scrollIntoView, который меняет скролл документа\r\n *\r\n * Выравнивание по ближнему краю элемента\r\n *\r\n * Выравнивается таким образом, чтобы был виден соседний элемент\r\n */\r\nconst scrollIntoView = (isSmooth = true) => {\r\n\tconst elBtn = el.value.querySelector('.top-active');\r\n\tif (!elBtn) return;\r\n\r\n\tconst gap = 24;\r\n\r\n\t// левая и правая координаты элемента\r\n\tconst leftMargin = elBtn.offsetLeft - el.value.offsetLeft - gap;\r\n\tconst rightMargin = elBtn.offsetLeft - el.value.offsetLeft + elBtn.clientWidth + gap;\r\n\r\n\t// левая и правая границы видимой части меню\r\n\tconst leftMarginParent = el.value.scrollLeft;\r\n\tconst rightMarginParent = el.value.clientWidth + el.value.scrollLeft;\r\n\r\n\tlet scrollLeft: number | undefined = undefined;\r\n\r\n\t// левую границу элемента к левой границе меню\r\n\tif (leftMargin < leftMarginParent) scrollLeft = leftMargin;\r\n\r\n\t// правую границу элемента к правой границе меню\r\n\tif (rightMargin > rightMarginParent) scrollLeft = rightMargin - el.value.clientWidth;\r\n\r\n\tif (scrollLeft !== undefined) {\r\n\t\tif (isSafari()) {\r\n\t\t\tCore.$?.(el.value).animate({ scrollLeft: scrollLeft }, isSmooth ? 200 : 0);\r\n\t\t} else {\r\n\t\t\tel.value.scrollTo({ left: scrollLeft, behavior: isSmooth ? 'smooth' : 'auto' });\r\n\t\t}\r\n\t}\r\n};\r\n\r\n/**\r\n * Выбрать все элементы в меню\r\n */\r\nconst selectAll = () => {\r\n\tif (!Array.isArray(model.value)) return;\r\n\r\n\tif (model.value.length === props.items.length) {\r\n\t\tmodel.value = [props.items[0].href ?? props.items[0].value];\r\n\t\treturn;\r\n\t}\r\n\r\n\tmodel.value = props.items.map(item => item.href ?? item.value);\r\n};\r\n\r\nonMounted(() => scrollIntoView(false));\r\nonUpdated(() => scrollIntoView(true));\r\n\r\n</script>\r\n\r\n<template>\r\n\t<div\r\n\t\tref=\"el\"\r\n\t\t:class=\"{\r\n\t\t\t'top-menu': true,\r\n\t\t\t['top-style_' + styling]: true,\r\n\t\t\t// ['top-unwrap-x']: styling === 'default',\r\n\t\t}\"\r\n\t\t@wheel=\"onWheel\"\r\n\t>\r\n\t\t<TopButton\r\n\t\t\tv-for=\"item in items\"\r\n\t\t\t:=\"item\"\r\n\t\t\tclass=\"top-menu_item\"\r\n\t\t\tcolor=\"theme\"\r\n\t\t\t@click=\"select(item, $event.ctrlKey)\"\r\n\t\t\t:isActive=\"itemIsActive(item)\"\r\n\t\t>\r\n\t\t\t<template #default v-if=\"item.content\">\r\n\t\t\t\t{{ item.content }}\r\n\t\t\t</template>\r\n\t\t</TopButton>\r\n\r\n\t\t<div\r\n\t\t\tv-if=\"Array.isArray(model) && selectAllItem\"\r\n\t\t\tclass=\"top-menu_selectAll\"\r\n\t\t>\r\n\t\t\t<TopButton\r\n\t\t\t\t:=\"selectAllItem\"\r\n\t\t\t\tclass=\"top-menu_item\"\r\n\t\t\t\tcolor=\"theme\"\r\n\t\t\t\tstyling=\"\"\r\n\t\t\t\t@click=\"selectAll()\"\r\n\t\t\t\t:isActive=\"model.length === items.length\"\r\n\t\t\t>\r\n\t\t\t\t<template #default v-if=\"selectAllItem.content\">\r\n\t\t\t\t\t{{ selectAllItem.content }}\r\n\t\t\t\t</template>\r\n\t\t\t</TopButton>\r\n\t\t</div>\r\n\t</div>\r\n</template>\r\n\r\n<style module>\r\n.top-menu {\r\n\t--scroll-thumb-color: var(--color-line-1);\r\n\t--scroll-thumb-color-hover: var(--color-line-2);\r\n\t--scroll-thumb-color-active: var(--color-line-3);\r\n\r\n\tmax-width: 100%;\r\n\tdisplay: flex;\r\n\talign-items: flex-start;\r\n\tgap: var(--top-gap-2);\r\n\toverflow-x: auto;\r\n\tscrollbar-width: none; /* firefox */\r\n\r\n\t/* предотвратить натинвые события браузера (назад / вперед) */\r\n\toverscroll-behavior-x: contain;\r\n}\r\n\r\n.top-menu::-webkit-scrollbar { display: none; }\r\n\r\n.top-menu .top-menu_item {\r\n\t--top-button-color: var(--color-text-2);\r\n\r\n\toutline-offset: -2px !important;\r\n\tmin-width: 0;\r\n\tmargin: 0;\r\n\tflex-shrink: 0;\r\n}\r\n\r\n.top-menu .top-menu_item[data-top-icon] {\r\n\t--top-icon-color: var(--color-text-2);\r\n}\r\n\r\n.top-menu_selectAll {\r\n\tposition: sticky;\r\n\tright: 0;\r\n\tbackground: var(--color-layout-front-1);\r\n\tborder-left: 1px solid var(--color-line-1);\r\n\tpadding-left: var(--top-padding-1);\r\n\tbox-shadow: var(--color-layout-front-1) var(--top-padding-2) 0px;\r\n}\r\n\r\n/* style default */\r\n.top-menu.top-style_default .top-menu_item {\r\n\t--top-forms-radius: 0;\r\n\t--top-forms-border-color: transparent;\r\n\t--top-forms-border-width: 2px;\r\n\r\n\tfilter: none;\r\n\tbox-shadow: none;\r\n\tborder: none;\r\n\tborder-bottom: var(--top-forms-border-width) solid var(--top-forms-border-color);\r\n\tbackground: none;\r\n}\r\n\r\n.top-style_default > .top-menu_item > [data-top-badge] {\r\n\tmargin-top: 0;\r\n}\r\n\r\n.top-menu.top-style_default .top-menu_item:hover {\r\n\t--top-icon-color: var(--color-text-1);\r\n\t--top-button-color: var(--color-text-1);\r\n\t--top-forms-border-color: var(--color-line-2);\r\n}\r\n\r\n.top-menu.top-style_default .top-menu_item:active,\r\n.top-menu.top-style_default .top-menu_item.top-active {\r\n\t--top-icon-color: var(--color-text-primary);\r\n\t--top-button-color: var(--color-text-1);\r\n\t--top-forms-border-color: var(--color-line-primary-1);\r\n}\r\n\r\n.top-menu.top-style_default .top-menu_selectAll {\r\n\tpadding-left: var(--top-padding-2);\r\n}\r\n\r\n/* style bar */\r\n.top-menu.top-style_bar {\r\n\tborder-radius: var(--top-radius-3);\r\n\tborder: 1px solid var(--color-line-2);\r\n\tpadding: var(--top-padding-1);\r\n\tgap: 3px;\r\n}\r\n.top-menu.top-style_bar .top-menu_item {\r\n\t--top-button-background-color-hover: var(--color-layer-1);\r\n\t--top-button-background-color-active: var(--color-layer-2);\r\n\t--top-button-background-color-selected: var(--color-layer-primary-1);\r\n\r\n\tposition: relative;\r\n}\r\n\r\n.top-menu.top-style_bar .top-menu_item:hover {\r\n\t--top-icon-color: var(--color-text-1);\r\n\t--top-button-color: var(--color-text-1);\r\n}\r\n\r\n.top-menu.top-style_bar .top-menu_item.top-active {\r\n\t--top-icon-color: var(--color-text-primary);\r\n\t--top-button-color: var(--color-text-primary);\r\n}\r\n\r\n/* разделители кнопок в баре */\r\n.top-menu.top-style_bar .top-menu_item:not(:first-child):not(.top-active):not(:hover):after {\r\n\tcontent: \"\";\r\n\tbackground: var(--color-line-1-opacity);\r\n\twidth: 1px;\r\n\theight: 60%;\r\n\tdisplay: block;\r\n\tposition: absolute;\r\n\tleft: -2px;\r\n}\r\n.top-menu.top-style_bar .top-menu_item.top-active + .top-menu_item:after,\r\n.top-menu.top-style_bar .top-menu_item:hover + .top-menu_item:after {\r\n\tcontent: none !important;\r\n}\r\n\r\n/*\r\n.top-style_bar > .top-menu_item > [data-top-badge] {\r\n\tmargin-top: -3px;\r\n}\r\n*/\r\n\r\n/** TODO: .top-unwrap-x надо вынести глобально в UI или добавить в стили для storybook */\r\n/*\r\n.top-menu.top-unwrap-x {\r\n\tpadding-right: var(--top-unwrap-x);\r\n\tpadding-left: var(--top-unwrap-x);\r\n\tmargin-right: calc(0px - var(--top-unwrap-x));\r\n\tmargin-left: calc(0px - var(--top-unwrap-x));\r\n}\r\n*/\r\n</style>\r\n"],"names":["props","__props","el","vue","model","itemIsActive","item","index","modelNew","onWheel","event","delta","scrollIntoView","isSmooth","elBtn","gap","leftMargin","rightMargin","rightMarginParent","scrollLeft"],"mappings":"ydAOA,MAAAA,EAAAC,+BAQAC,EAAAC,EAAA,IAAA,mKAQAH,EAAA,YAAA,CAAA,MAAA,QAAAI,EAAA,KAAA,wNAUA,MAAAC,EAAAC,2MAqBGC,IAAA,gCAIA,MAEAC,EAAA,SAAA,GAAAA,EAAA,CAAA,IAAAF,EAAA,WAGCE,EAAA,CAAAF,EAAA,KAAA,EAIF,CAAAN,EAAA,oBAAA,CAAAQ,EAAA,SAAAA,EAAA,CAAAF,EAAA,KAAA,GAEAF,EAAA,MAAAI,EAEA,OAGDJ,EAAA,MAAAE,EAAA,KAAmB,EAIpBG,EAAAC,GAAA,CAGC,GAFAR,EAAA,MAAA,aAAAA,EAAA,MAAA,aACAQ,EAAA,UACA,KAAA,IAAAA,EAAA,MAAA,EAAA,GAAA,OAEAA,EAAA,eAAA,EAEA,MAAAC,EAAAD,EAAA,OAAA,EAAA,GAAA,IACAR,EAAA,MAAA,WAAAA,EAAA,MAAA,WAAAS,CAA4C,EAU7CC,EAAA,CAAAC,EAAA,KAAA,sDAEC,GAAA,CAAAC,EAAA,OAEA,MAAAC,EAAA,GAGAC,EAAAF,EAAA,WAAAZ,EAAA,MAAA,WAAAa,EACAE,EAAAH,EAAA,WAAAZ,EAAA,MAAA,WAAAY,EAAA,YAAAC,uBAIAG,EAAAhB,EAAA,MAAA,YAAAA,EAAA,MAAA,WAEA,IAAAiB,aAMAF,EAAAC,IAAAC,EAAAF,EAAAf,EAAA,MAAA,aAEAiB,IAAA,sJAMA,mCASA,IAAAf,EAAA,MAAA,SAAAJ,EAAA,MAAA,OAAA,6CAEC,+CAG4D"}