@topvisor/ui 1.0.34 → 1.0.36

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 (210) hide show
  1. package/.chunks/{core-CUNwUlL6.es.js → core-CO5q-OhH.es.js} +13 -12
  2. package/.chunks/core-CO5q-OhH.es.js.map +1 -0
  3. package/.chunks/core-D-ONEIDC.amd.js +2 -0
  4. package/.chunks/{core-CUNwUlL6.es.js.map → core-D-ONEIDC.amd.js.map} +1 -1
  5. package/.chunks/{datepicker-C0a_eKze.amd.js → datepicker-BKWD8N4r.amd.js} +2 -2
  6. package/.chunks/{datepicker-C0a_eKze.amd.js.map → datepicker-BKWD8N4r.amd.js.map} +1 -1
  7. package/.chunks/{datepicker-CW2Ql1NG.es.js → datepicker-BfPUBUE1.es.js} +2 -2
  8. package/.chunks/{datepicker-CW2Ql1NG.es.js.map → datepicker-BfPUBUE1.es.js.map} +1 -1
  9. package/.chunks/{dialog_selectorRegions-Bkw1LXvI.es.js → dialog_selectorRegions-D3CnPt4V.es.js} +4 -4
  10. package/.chunks/{dialog_selectorRegions-Bkw1LXvI.es.js.map → dialog_selectorRegions-D3CnPt4V.es.js.map} +1 -1
  11. package/.chunks/{dialog_selectorRegions-Bhblg2Ks.amd.js → dialog_selectorRegions-DYPTw--e.amd.js} +2 -2
  12. package/.chunks/{dialog_selectorRegions-Bhblg2Ks.amd.js.map → dialog_selectorRegions-DYPTw--e.amd.js.map} +1 -1
  13. package/.chunks/{dialogs.vue_vue_type_script_setup_true_lang-CXtBj2Ah.amd.js → dialogs.vue_vue_type_script_setup_true_lang-C5vfO9ia.amd.js} +2 -2
  14. package/.chunks/{dialogs.vue_vue_type_script_setup_true_lang-CXtBj2Ah.amd.js.map → dialogs.vue_vue_type_script_setup_true_lang-C5vfO9ia.amd.js.map} +1 -1
  15. package/.chunks/{dialogs.vue_vue_type_script_setup_true_lang-JyillkBh.es.js → dialogs.vue_vue_type_script_setup_true_lang-CEkc3TYu.es.js} +2 -2
  16. package/.chunks/{dialogs.vue_vue_type_script_setup_true_lang-JyillkBh.es.js.map → dialogs.vue_vue_type_script_setup_true_lang-CEkc3TYu.es.js.map} +1 -1
  17. package/.chunks/{forms-CKYHAaPQ.amd.js → forms-DPIu5wcK.amd.js} +3 -3
  18. package/.chunks/{forms-CKYHAaPQ.amd.js.map → forms-DPIu5wcK.amd.js.map} +1 -1
  19. package/.chunks/{forms-zDpk9gMK.es.js → forms-YZl4XC4S.es.js} +300 -280
  20. package/.chunks/{forms-zDpk9gMK.es.js.map → forms-YZl4XC4S.es.js.map} +1 -1
  21. package/.chunks/{listItem.vue_vue_type_script_setup_true_lang-Di1h6iID.es.js → listItem.vue_vue_type_script_setup_true_lang-CDrG3onO.es.js} +23 -23
  22. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-CDrG3onO.es.js.map +1 -0
  23. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-CTbTjIda.amd.js +2 -0
  24. package/.chunks/{listItem.vue_vue_type_script_setup_true_lang-C_ZN2Nia.amd.js.map → listItem.vue_vue_type_script_setup_true_lang-CTbTjIda.amd.js.map} +1 -1
  25. package/.chunks/{menu.vue_vue_type_style_index_0_lang-B5fkWPo5.es.js → menu.vue_vue_type_style_index_0_lang-2vtQvU8o.es.js} +2 -2
  26. package/.chunks/{menu.vue_vue_type_style_index_0_lang-vyCH9NUZ.amd.js.map → menu.vue_vue_type_style_index_0_lang-2vtQvU8o.es.js.map} +1 -1
  27. package/.chunks/{menu.vue_vue_type_style_index_0_lang-vyCH9NUZ.amd.js → menu.vue_vue_type_style_index_0_lang-QsJS5sEm.amd.js} +2 -2
  28. package/.chunks/menu.vue_vue_type_style_index_0_lang-QsJS5sEm.amd.js.map +1 -0
  29. package/.chunks/{notice-CyeaHgdt.amd.js → notice-CwPCnQ9k.amd.js} +2 -2
  30. package/.chunks/{notice-CyeaHgdt.amd.js.map → notice-CwPCnQ9k.amd.js.map} +1 -1
  31. package/.chunks/{notice-B8hUtbou.es.js → notice-CysocnDZ.es.js} +2 -2
  32. package/.chunks/{notice-B8hUtbou.es.js.map → notice-CysocnDZ.es.js.map} +1 -1
  33. package/.chunks/{page.vue_vue_type_script_setup_true_lang-C8oRGxFZ.es.js → page.vue_vue_type_script_setup_true_lang-DOTfcVUC.es.js} +4 -4
  34. package/.chunks/{page.vue_vue_type_script_setup_true_lang-C8oRGxFZ.es.js.map → page.vue_vue_type_script_setup_true_lang-DOTfcVUC.es.js.map} +1 -1
  35. package/.chunks/{page.vue_vue_type_script_setup_true_lang-DmbqzLa6.amd.js → page.vue_vue_type_script_setup_true_lang-vzWb9Ehr.amd.js} +2 -2
  36. package/.chunks/{page.vue_vue_type_script_setup_true_lang-DmbqzLa6.amd.js.map → page.vue_vue_type_script_setup_true_lang-vzWb9Ehr.amd.js.map} +1 -1
  37. package/.chunks/{popup-BaFsC2VD.es.js → popup-Cbr1ckCd.es.js} +2 -2
  38. package/.chunks/{popup-BaFsC2VD.es.js.map → popup-Cbr1ckCd.es.js.map} +1 -1
  39. package/.chunks/{popup-DR6JnpNV.amd.js → popup-DdvupIju.amd.js} +2 -2
  40. package/.chunks/{popup-DR6JnpNV.amd.js.map → popup-DdvupIju.amd.js.map} +1 -1
  41. package/.chunks/utils-ASIXzycS.es.js +227 -0
  42. package/.chunks/{utils-CKggUvLI.es.js.map → utils-ASIXzycS.es.js.map} +1 -1
  43. package/.chunks/{utils-BPcGxQ0s.es.js → utils-Bjl0RkKM.es.js} +2 -2
  44. package/.chunks/{utils-BPcGxQ0s.es.js.map → utils-Bjl0RkKM.es.js.map} +1 -1
  45. package/.chunks/utils-CkpzFGzD.amd.js +2 -0
  46. package/.chunks/{utils-BO3j538g.amd.js.map → utils-CkpzFGzD.amd.js.map} +1 -1
  47. package/.chunks/{utils-BPyrKdwc.amd.js → utils-D_OVY7zV.amd.js} +2 -2
  48. package/.chunks/{utils-BPyrKdwc.amd.js.map → utils-D_OVY7zV.amd.js.map} +1 -1
  49. package/assets/core.css +1 -1
  50. package/assets/forms.css +1 -1
  51. package/assets/layout.css +1 -1
  52. package/charts/charts.amd.js +1 -1
  53. package/charts/charts.amd.js.map +1 -1
  54. package/charts/charts.js +1 -1
  55. package/charts/charts.js.map +1 -1
  56. package/components/charts/miniChart/miniChart.vue.d.ts +1 -1
  57. package/components/charts/miniCharts/miniCharts.d.ts +1 -1
  58. package/components/charts/miniCharts/miniCharts.vue.d.ts +1 -1
  59. package/components/charts/miniCharts/stories/dummy.d.ts +1 -1
  60. package/components/core/notice/item/types.d.ts +2 -0
  61. package/components/forms/avatar/avatar.vue.d.ts +1 -1
  62. package/components/forms/caption/caption.vue.d.ts +17 -0
  63. package/components/forms/caption/types.d.ts +9 -0
  64. package/components/forms/checkbox/checkbox.vue.d.ts +1 -1
  65. package/components/forms/controlLabel/controlLabel.vue.d.ts +1 -1
  66. package/components/forms/forms.d.ts +2 -0
  67. package/components/forms/hint/hint.vue.d.ts +1 -1
  68. package/components/forms/input/input.vue.d.ts +1 -1
  69. package/components/forms/inputDate/inputDate.vue.d.ts +1 -1
  70. package/components/forms/inputDate/types.d.ts +1 -0
  71. package/components/forms/radio/radio.vue.d.ts +1 -1
  72. package/components/forms/select/select.vue.d.ts +1 -1
  73. package/components/forms/select/stories/exampleOptions.d.ts +1 -1
  74. package/components/forms/switcher/switcher.vue.d.ts +1 -1
  75. package/components/forms/textarea/textarea.vue.d.ts +1 -1
  76. package/components/forms/textarea/{textarea.d.ts → types.d.ts} +4 -0
  77. package/components/formsExt/checkboxGroup/checkboxGroup.vue.d.ts +1 -1
  78. package/components/formsExt/editArea/editArea.vue.d.ts +1 -1
  79. package/components/formsExt/editArea/{editArea.d.ts → types.d.ts} +1 -1
  80. package/components/formsExt/editInput/editInput.vue.d.ts +1 -1
  81. package/components/formsExt/editInput/{editInput.d.ts → types.d.ts} +1 -1
  82. package/components/formsExt/menu/menu.vue.d.ts +1 -1
  83. package/components/formsExt/menu/stories/items.d.ts +1 -1
  84. package/components/formsExt/radioGroup/radioGroup.vue.d.ts +1 -1
  85. package/components/formsExt/selector2/{api.d.ts → composables/useAPI.d.ts} +15 -1
  86. package/components/formsExt/selector2/composables/useMenu.d.ts +12 -0
  87. package/components/formsExt/selector2/itemMulti.vue.d.ts +1 -1
  88. package/components/formsExt/selector2/selector2.vue.d.ts +3 -3
  89. package/components/formsExt/selector2/utils.d.ts +6 -0
  90. package/components/popup/alert/alert.vue.d.ts +2 -2
  91. package/components/popup/alert/{alert.d.ts → types.d.ts} +1 -1
  92. package/components/popup/confirm/confirm.vue.d.ts +2 -2
  93. package/components/popup/confirm/{confirm.d.ts → types.d.ts} +1 -1
  94. package/components/popup/lib/worker.d.ts +2 -2
  95. package/components/popup/popup/listItem.vue.d.ts +1 -1
  96. package/components/popup/popup/opener.vue.d.ts +1 -1
  97. package/components/popup/popup/popup.vue.d.ts +1 -1
  98. package/components/popup/popup/widgetInput.vue.d.ts +1 -1
  99. package/components/popup/prompt/prompt.vue.d.ts +2 -2
  100. package/components/popup/prompt/{prompt.d.ts → types.d.ts} +1 -1
  101. package/components/project/selectorCompetitors/composables.d.ts +1 -2
  102. package/components/project/selectorCompetitors/selectorCompetitors.vue.d.ts +1 -1
  103. package/components/project/selectorCompetitors/stories/items.d.ts +1 -1
  104. package/components/project/selectorCompetitors/{selectorCompetitors.d.ts → types.d.ts} +7 -0
  105. package/components/project/selectorRegion/composables/compare.d.ts +1 -1
  106. package/components/project/selectorRegion/composables/selectRegion.d.ts +2 -2
  107. package/components/project/selectorRegion/composables/selectSearcher.d.ts +2 -2
  108. package/components/project/selectorRegion/composables/selectorRegion.d.ts +2 -2
  109. package/components/project/selectorRegion/dialog_selectorRegions/types.d.ts +1 -1
  110. package/components/project/selectorRegion/selectorRegion.vue.d.ts +1 -1
  111. package/components/project/selectorRegion/stories/searchers.d.ts +1 -1
  112. package/components/project/selectorRegion/utils/consts.d.ts +1 -1
  113. package/components/project/selectorRegion/utils/utils.d.ts +1 -1
  114. package/components/project/tagSelector/popupOpener/types.d.ts +2 -0
  115. package/components/project/tagSelector/types.d.ts +2 -0
  116. package/components/project/tagSelector/utils/el.d.ts +1 -1
  117. package/components/tabs/tabs/content.vue.d.ts +1 -1
  118. package/components/tabs/tabs/tab.vue.d.ts +1 -1
  119. package/components/tabs/tabs/tabs.vue.d.ts +1 -1
  120. package/components/tabsView/tabsView/menu.vue.d.ts +1 -1
  121. package/components/tabsView/tabsView/menuItem.vue.d.ts +1 -1
  122. package/components/tabsView/tabsView/menuTitle.vue.d.ts +1 -1
  123. package/components/tabsView/tabsView/store.d.ts +5 -185
  124. package/components/tabsView/tabsView/tabsView.vue.d.ts +1 -1
  125. package/core/app.amd.js +1 -1
  126. package/core/app.js +5 -5
  127. package/core/utils/store.d.ts +1 -1
  128. package/dialog/dialog.amd.js +1 -1
  129. package/dialog/dialog.js +2 -2
  130. package/extra/extra.amd.js +1 -1
  131. package/extra/extra.amd.js.map +1 -1
  132. package/extra/extra.js +1 -0
  133. package/extra/extra.js.map +1 -1
  134. package/forms/forms.amd.js +1 -1
  135. package/forms/forms.js +8 -7
  136. package/formsExt/formsExt.amd.js +1 -1
  137. package/formsExt/formsExt.amd.js.map +1 -1
  138. package/formsExt/formsExt.js +310 -309
  139. package/formsExt/formsExt.js.map +1 -1
  140. package/icomoon/Topvisor icons.json +82 -36
  141. package/icomoon/demo.html +29 -1
  142. package/icomoon/fonts/Topvisor-2.eot +0 -0
  143. package/icomoon/fonts/Topvisor-2.svg +2 -0
  144. package/icomoon/fonts/Topvisor-2.ttf +0 -0
  145. package/icomoon/fonts/Topvisor-2.woff +0 -0
  146. package/icomoon/selection.json +1 -1
  147. package/icomoon/style.css +11 -5
  148. package/layout/layout.amd.js +1 -1
  149. package/layout/layout.amd.js.map +1 -1
  150. package/layout/layout.js +1 -1
  151. package/layout/layout.js.map +1 -1
  152. package/package.json +4 -1
  153. package/popup/popup.amd.js +1 -1
  154. package/popup/popup.amd.js.map +1 -1
  155. package/popup/popup.js +2 -2
  156. package/popup/popup.js.map +1 -1
  157. package/popup/worker.amd.js +1 -1
  158. package/popup/worker.amd.js.map +1 -1
  159. package/popup/worker.js +3 -3
  160. package/popup/worker.js.map +1 -1
  161. package/project/project.amd.js +1 -1
  162. package/project/project.amd.js.map +1 -1
  163. package/project/project.js +244 -241
  164. package/project/project.js.map +1 -1
  165. package/tabsView/tabsView.amd.js +1 -1
  166. package/tabsView/tabsView.amd.js.map +1 -1
  167. package/tabsView/tabsView.js +1 -1
  168. package/tabsView/tabsView.js.map +1 -1
  169. package/utils/clipboard.amd.js +1 -1
  170. package/utils/clipboard.js +1 -1
  171. package/utils/date.amd.js +1 -1
  172. package/utils/date.js +1 -1
  173. package/utils/device.amd.js +1 -1
  174. package/utils/device.js +1 -1
  175. package/utils/lodash.amd.js +1 -1
  176. package/utils/lodash.js +1 -1
  177. package/utils/price.amd.js +1 -1
  178. package/utils/price.js +1 -1
  179. package/utils/searchers.amd.js +1 -1
  180. package/utils/searchers.js +3 -3
  181. package/utils/string.amd.js +1 -1
  182. package/utils/string.amd.js.map +1 -1
  183. package/utils/string.js +5 -5
  184. package/utils/string.js.map +1 -1
  185. package/.chunks/core-BHvOvH4M.amd.js +0 -2
  186. package/.chunks/core-BHvOvH4M.amd.js.map +0 -1
  187. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-C_ZN2Nia.amd.js +0 -2
  188. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-Di1h6iID.es.js.map +0 -1
  189. package/.chunks/menu.vue_vue_type_style_index_0_lang-B5fkWPo5.es.js.map +0 -1
  190. package/.chunks/utils-BO3j538g.amd.js +0 -2
  191. package/.chunks/utils-CKggUvLI.es.js +0 -227
  192. package/components/forms/inputDate/inputDate.d.ts +0 -3
  193. package/components/project/selectorCompetitors/types/competitor.d.ts +0 -7
  194. /package/components/charts/miniChart/{miniChart.d.ts → types.d.ts} +0 -0
  195. /package/components/forms/avatar/{avatar.d.ts → types.d.ts} +0 -0
  196. /package/components/forms/checkbox/{checkbox.d.ts → types.d.ts} +0 -0
  197. /package/components/forms/controlLabel/{controlLabel.d.ts → types.d.ts} +0 -0
  198. /package/components/forms/hint/{hint.d.ts → types.d.ts} +0 -0
  199. /package/components/forms/input/{input.d.ts → types.d.ts} +0 -0
  200. /package/components/forms/inputRange/{inputRange.d.ts → types.d.ts} +0 -0
  201. /package/components/forms/radio/{radio.d.ts → types.d.ts} +0 -0
  202. /package/components/forms/select/{select.d.ts → types.d.ts} +0 -0
  203. /package/components/forms/switcher/{switcher.d.ts → types.d.ts} +0 -0
  204. /package/components/formsExt/menu/{menu.d.ts → types.d.ts} +0 -0
  205. /package/components/formsExt/radioGroup/{radioGroup.d.ts → types.d.ts} +0 -0
  206. /package/components/formsExt/selector2/{selector2.d.ts → types.d.ts} +0 -0
  207. /package/components/popup/popup/{popup.d.ts → types.d.ts} +0 -0
  208. /package/components/project/selectorRegion/{selectorRegion.d.ts → types.d.ts} +0 -0
  209. /package/components/tabs/tabs/{tabs.d.ts → types.d.ts} +0 -0
  210. /package/components/tabsView/tabsView/{tabsView.d.ts → types.d.ts} +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"string.js","sources":["../../src/core/utils/string.ts"],"sourcesContent":["/**\n * Работа со строками\n * @packageDocumentation\n */\n\nimport { getDomainRegexp } from '@/core/utils/check';\nimport { useI18nLang } from '@/core/plugins/i18n';\n\n/**\n * Сгенерировать числовой хэш от строки для идентификатора\n */\nexport const genIntHash = (string: string): number => {\n\tstring += '';\n\n\tlet hash = 0;\n\tif (!string.length) return hash;\n\n\tfor (let i = 0; i < string.length; i++) {\n\t\tconst char = string.charCodeAt(i);\n\t\thash = ((hash << 5) - hash) + char;\n\t\thash = hash & hash;\n\t}\n\n\tif (hash < 0) hash *= -1;\n\n\treturn hash;\n};\n\n/**\n * Проверить что переданная строка является URL\n */\nexport const isUrl = (url: string): boolean => {\n\treturn /^\\w+:\\/\\/([\\w-]+\\.)+[\\w-]+(:\\d+)?(\\/|$)/.test(url);\n};\n\n/**\n * Добавляет пробелы между разрядами если требуется\n * @param nStr строка с числом\n */\nexport const addCommasWhite = (n: number | string): string => {\n\tlet nStr = n + '';\n\n\tnStr = nStr.replace('-', '–');\n\n\tlet x = nStr.split('.');\n\tlet x1 = x[0];\n\tlet x2 = (x.length > 1) ? ('.' + x[1]) : '';\n\n\tif (x1.replace(/[+–]/, '').length <= 4) return nStr;\n\n\tconst rgx = /(\\d+)(\\d{3})/;\n\twhile (rgx.test(x1)) {\n\t\tx1 = x1.replace(rgx, '$1' + ' ' + '$2');\n\t}\n\treturn x1 + x2;\n};\n\n/**\n * Вставляет HTML-код разрыва строки перед каждым переводом строки\n */\nexport const nl2br = (str: string): string => {\n\tif (str === undefined) return '';\n\n\treturn str.replace(/\\r\\n|\\r|\\n/g, '<br>');\n};\n\n/**\n * Перевести число без деситичной приставки в число с деситичной приставкой степеней тысячи (с параметрами по умолчанию 1255 -> '1.26 K')\n * @param number\n * @param precision - точность, количество знаков после запятой\n * @param dimension - размерность, по умолчанию 1000\n * @param suffix - суффикс к десятичной приставке (по умолчанию выводится латинская заглавная буква)\n */\nexport const numberWithWord = (number: number, precision = 2, dimension = 1000, suffix = ''): string => {\n\tconst k = Math.pow(10, precision);\n\n\tlet numberStr = String(number);\n\tif (Math.abs(number) > Math.pow(dimension, 3)) {\n\t\tnumberStr = Math.round(number / Math.pow(dimension, 3) * k) / k + ' <small>G' + suffix + '</small>';\n\t} else if (Math.abs(number) > Math.pow(dimension, 2)) {\n\t\tnumberStr = Math.round(number / Math.pow(dimension, 2) * k) / k + ' <small>M' + suffix + '</small>';\n\t} else if (Math.abs(number) > dimension) {\n\t\tnumberStr = Math.round(number / dimension * k) / k + ' <small>K' + suffix + '</small>';\n\t} else {\n\t\tnumberStr = Math.round(number * k) / k + '';\n\t}\n\n\tnumberStr = numberStr.replace(/^(-?\\d+)(\\d{3})/, '$1 $2');\n\n\treturn numberStr;\n};\n\n/**\n * Обрезать текст под три точки\n * @param string\n * @param max_length - максимальное количество символов текста, остальное обрежеться\n * @param pos - область обрезки 0-начало | 1-середина | 2-конец строки\n */\nexport const ellipsis = (string: string, max_length: number, pos: 0 | 1 | 2 = 1): string => {\n\tif (string == undefined) return '';\n\n\tstring += '';\n\tif (max_length == undefined || string.length <= max_length) return string;\n\n\tif (pos === 0) {\n\t\tstring = string.substr(string.length - max_length, max_length);\n\t\tstring = '...' + string;\n\t} else if (pos === 1) {\n\t\tconst string1 = string.substr(0, max_length / 2);\n\t\tconst string2 = string.substr(string.length - max_length / 2, Math.ceil(max_length / 2));\n\t\tstring = string1 + '...' + string2;\n\t} else if (pos === 2) {\n\t\tstring = string.substr(0, max_length);\n\t\tstring = string + '...';\n\t}\n\n\treturn string;\n};\n\n/**\n * Сгенерировать строку текста для вывода количества в разном склонении\n * @param num\n * @param ending0 - родительный падеж, множ. число (10 модулей)\n * @param ending1 - именительный падеж, ед. число (1 модуль)\n * @param ending2 - винительный падеж, множ. число (3 модуля)\n */\nexport const numberEnding = (num: number, ending0: string, ending1: string, ending2: string): string => {\n\t// склонение по множественному числу\n\tif (useI18nLang().value === 'en') {\n\t\tif (num === 1) {\n\t\t\treturn ending1;\n\t\t} else {\n\t\t\treturn ending0;\n\t\t}\n\t}\n\n\tconst num100 = num % 100;\n\tconst num10 = num % 10;\n\n\tif (num100 >= 5 && num100 <= 20) {\n\t\treturn ending0;\n\t} else if (num10 === 0) {\n\t\treturn ending0;\n\t} else if (num10 === 1) {\n\t\treturn ending1;\n\t} else if (num10 >= 2 && num10 <= 4) {\n\t\treturn ending2;\n\t} else if (num10 >= 5 && num10 <= 9) {\n\t\treturn ending0;\n\t} else {\n\t\treturn ending2;\n\t}\n};\n\n/**\n * Перевести строку в родительный падеж\n */\nexport const toRoditPadej = (str: string): string => {\n\tif (useI18nLang().value != 'ru' || str == '') return str;\n\n\tconst str_array = str.split(' ');\n\n\t$.map(str_array, function (str, index) {\n\t\tstr = str + 'а';\n\t\tstr = str.replace('оа', 'о');\n\t\tstr = str.replace('аяа', 'ой');\n\t\tstr = str.replace('шийа', 'шого');\n\t\tstr = str.replace('ыйа', 'ого');\n\t\tstr = str.replace('йа', 'я');\n\t\tstr = str.replace('ьа', 'я');\n\t\tstr = str.replace('яа', 'и');\n\t\tstr = str.replace('оваа', 'овой');\n\t\tstr = str.replace('аа', 'ы');\n\t\tstr = str.replace('кия', 'кого');\n\t\tstr = str.replace('каи', 'кой');\n\n\t\tstr_array[index] = str;\n\t});\n\n\tstr = str_array.join(' ');\n\n\treturn str;\n};\n\n/**\n * Транслитерация текста\n */\nexport const rusToLatin = (str: string): string => {\n\tconst ru: { [index: string]: string } = {\n\t\t'а': 'a', 'б': 'b', 'в': 'v', 'г': 'g', 'д': 'd',\n\t\t'е': 'e', 'ё': 'e', 'ж': 'j', 'з': 'z', 'и': 'i',\n\t\t'й': 'i', 'к': 'k', 'л': 'l', 'м': 'm', 'н': 'n',\n\t\t'о': 'o', 'п': 'p', 'р': 'r', 'с': 's', 'т': 't',\n\t\t'у': 'u', 'ф': 'f', 'х': 'h', 'ц': 'c', 'ч': 'ch',\n\t\t'ш': 'sh', 'щ': 'shch', 'ъ': '', 'ы': 'y', 'ь': '',\n\t\t'э': 'e', 'ю': 'u', 'я': 'ya',\n\t};\n\n\tconst str_array = str.split(' ');\n\n\t$.map(str_array, function (str, index) {\n\t\tconst newStr: string[] = [];\n\t\tfor (let i = 0; i < str.length; ++i) {\n\t\t\tnewStr.push(\n\t\t\t\tru[str[i]] || ru[str[i].toLowerCase()] == undefined && str[i] || ru[str[i].toLowerCase()].replace(/^(.)/, function (match) {\n\t\t\t\t\treturn match.toUpperCase();\n\t\t\t\t}),\n\t\t\t);\n\t\t}\n\n\t\tstr_array[index] = newStr.join('');\n\t});\n\n\tstr = str_array.join(' ');\n\n\treturn str;\n};\n\n/**\n * Замена html-символов (`&`, `<`, `>`, `\"`, `'`) на имена литер (`&` -> `&amp;`)\n */\nexport const htmlspecialchars = (str: string): string => {\n\tif (typeof (str) == 'string') {\n\t\tstr = str\n\t\t\t.replace(/&/g, '&amp;')\n\t\t\t.replace(/</g, '&lt;')\n\t\t\t.replace(/>/g, '&gt;')\n\t\t\t.replace(/\"/g, '&quot;')\n\t\t\t.replace(/'/g, '&#039;');\n\t}\n\treturn str;\n};\n\n/**\n * Выделить нужное в тексте желтым цветом\n * поиск происходит по строке fieldFilter.values[0]\n */\nexport const highlightHtml = (text: string, fieldFilter: { operator: 'CONTAINS' | 'REGEXP', values: string[] }): string => {\n\tlet regExp: RegExp | null = null;\n\n\tswitch (fieldFilter.operator) {\n\t\tcase 'CONTAINS':\n\t\tcase 'REGEXP':\n\t\t\ttry {\n\t\t\t\tlet regExpString = fieldFilter.values[0];\n\t\t\t\tif (fieldFilter.operator != 'REGEXP') regExpString = regExpString.replace(/([()\\[\\]])/g, '\\\\$1');\n\n\t\t\t\tregExp = new RegExp('(' + regExpString + ')', 'gi');\n\t\t\t} catch (exception) {\n\t\t\t\treturn text;\n\t\t\t}\n\n\t\t\tbreak;\n\t}\n\n\ttext = text.replace(regExp!, '<b class=\"found\">$1</b>');\n\n\treturn text;\n};\n\n/**\n * Пример: logHTTPCodesHundreds => log_http_codes_hundreds\n */\nexport const camelToSnakeCase = (str: string): string | undefined => {\n\treturn str.match(/[A-Z]{2,}(?=[A-Z][a-z]+[0-9]*|\\b)|[A-Z]?[a-z]+[0-9]*|[A-Z]|[0-9]+/g)?.map(token => token.toLowerCase()).join('_');\n};\n\n/**\n * Получить url изображения флага, по коду страны по стандарту ISO 3166-1 alpha-2\n *\n * @todo Опубликовать в CDN или брать c публичного CDN\n */\nexport const genFlagLinkByCountryCode = (countryCode: string) => {\n\tconst urlImage = '/cloud/common/flags/' + countryCode.toUpperCase() + '.svg';\n\treturn `/controller/file/?src=${urlImage}`;\n};\n\n/**\n * Обернуть все ссылки и email в тексте в html-тег `<a>`.\n *\n * Для email ставиться префикс `mailto:`\n */\nexport const addLinkTags = (text: string): string => {\n\tconst domainRegexp = getDomainRegexp();\n\tconst afterDomainRegexp = '(([\\\\/?\\\\w&=%+#;:-]*(\\\\.\\\\w+)?))*';\n\n\tconst regexpMailto = new RegExp(`(^|[\\\\s>(),])([a-z0-9а-яё_.]+@${domainRegexp}${afterDomainRegexp})`, 'gui');\n\ttext = text.replace(regexpMailto, `$1<a href=\"mailto:$2\" target=\"_blank\" rel=\"noopener\">↑[$2]↓</a>`);\n\n\tconst regexpLink = new RegExp(`(^|[\\\\s>(),])(https?:\\/\\/)?(${domainRegexp}${afterDomainRegexp})`, 'gui');\n\ttext = text.replace(regexpLink, `$1<a href=\"√$2$3\" target=\"_blank\" rel=\"nofollow noopener\">$2$3</a>`);\n\n\ttext = text.replaceAll('√http', 'http');\n\ttext = text.replaceAll('√', 'http://');\n\ttext = text.replaceAll(/(↑\\[|]↓)/g, '');\n\n\treturn text;\n};\n\n/**\n * Перевести первую букву строки в верхний регистр\n */\nexport const toCapitalize = (str: string): string => {\n\treturn str.charAt(0).toUpperCase() + str.slice(1);\n};\n\n/**\n * Получить случайную строку\n */\nexport const getRandomHash = (length: number = 20): string => {\n\tconst l = 'AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz1234567890';\n\n\tlet result = '';\n\tfor (let i = 0; i < length; i++) {\n\t\tresult += l[Math.floor(Math.random() * l.length)];\n\t}\n\n\treturn result;\n};\n"],"names":["genIntHash","string","hash","i","char","isUrl","url","addCommasWhite","n","nStr","x","x1","x2","rgx","nl2br","str","numberWithWord","number","precision","dimension","suffix","k","numberStr","ellipsis","max_length","pos","string1","string2","numberEnding","num","ending0","ending1","ending2","useI18nLang","num100","num10","toRoditPadej","str_array","index","rusToLatin","ru","newStr","match","htmlspecialchars","highlightHtml","text","fieldFilter","regExp","regExpString","camelToSnakeCase","_a","token","genFlagLinkByCountryCode","countryCode","addLinkTags","domainRegexp","getDomainRegexp","afterDomainRegexp","regexpMailto","regexpLink","toCapitalize","getRandomHash","length","result"],"mappings":"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"}
1
+ {"version":3,"file":"string.js","sources":["../../src/core/utils/string.ts"],"sourcesContent":["/**\n * Работа со строками\n * @packageDocumentation\n */\n\nimport { getDomainRegexp } from '@/core/utils/check';\nimport { useI18nLang } from '@/core/plugins/i18n';\n\n// export const REGEXP_START_SYMBOL_ICON = new RegExp('^[^a-zа-я0-9_%#!?.:\\'\"«»[\\\\](){} \\\\r\\\\n\\\\t<>&/+-]', 'i');\n//\n// /**\n// * Извлекает иконку и оставшийся контент из строки\n// *\n// * Возвращает объект со свойствами:\n// * - `icon`: содержит символ иконки, если он присутствует, иначе `null`\n// * - `content`: содержит оставшийся текст без символа иконки, если он был извлечен, или всю строку\n// */\n// export const extractIconAndContent = (content: string) => {\n// \tconst iconExists = content?.[0]?.match(REGEXP_START_SYMBOL_ICON);\n//\n// \treturn {\n// \t\ticon: iconExists ? content[0] : null,\n// \t\tcontent: iconExists ? content.substring(1) : content,\n// \t};\n// };\n\n/**\n * Сгенерировать числовой хэш от строки для идентификатора\n */\nexport const genIntHash = (string: string): number => {\n\tstring += '';\n\n\tlet hash = 0;\n\tif (!string.length) return hash;\n\n\tfor (let i = 0; i < string.length; i++) {\n\t\tconst char = string.charCodeAt(i);\n\t\thash = ((hash << 5) - hash) + char;\n\t\thash = hash & hash;\n\t}\n\n\tif (hash < 0) hash *= -1;\n\n\treturn hash;\n};\n\n/**\n * Проверить что переданная строка является URL\n */\nexport const isUrl = (url: string): boolean => {\n\treturn /^\\w+:\\/\\/([\\w-]+\\.)+[\\w-]+(:\\d+)?(\\/|$)/.test(url);\n};\n\n/**\n * Добавляет пробелы между разрядами если требуется\n * @param nStr строка с числом\n */\nexport const addCommasWhite = (n: number | string): string => {\n\tlet nStr = n + '';\n\n\tnStr = nStr.replace('-', '–');\n\n\tlet x = nStr.split('.');\n\tlet x1 = x[0];\n\tlet x2 = (x.length > 1) ? ('.' + x[1]) : '';\n\n\tif (x1.replace(/[+–]/, '').length <= 4) return nStr;\n\n\tconst rgx = /(\\d+)(\\d{3})/;\n\twhile (rgx.test(x1)) {\n\t\tx1 = x1.replace(rgx, '$1' + ' ' + '$2');\n\t}\n\treturn x1 + x2;\n};\n\n/**\n * Вставляет HTML-код разрыва строки перед каждым переводом строки\n */\nexport const nl2br = (str: string): string => {\n\tif (str === undefined) return '';\n\n\treturn str.replace(/\\r\\n|\\r|\\n/g, '<br>');\n};\n\n/**\n * Перевести число без деситичной приставки в число с деситичной приставкой степеней тысячи (с параметрами по умолчанию 1255 -> '1.26 K')\n * @param number\n * @param precision - точность, количество знаков после запятой\n * @param dimension - размерность, по умолчанию 1000\n * @param suffix - суффикс к десятичной приставке (по умолчанию выводится латинская заглавная буква)\n */\nexport const numberWithWord = (number: number, precision = 2, dimension = 1000, suffix = ''): string => {\n\tconst k = Math.pow(10, precision);\n\n\tlet numberStr = String(number);\n\tif (Math.abs(number) > Math.pow(dimension, 3)) {\n\t\tnumberStr = Math.round(number / Math.pow(dimension, 3) * k) / k + ' <small>G' + suffix + '</small>';\n\t} else if (Math.abs(number) > Math.pow(dimension, 2)) {\n\t\tnumberStr = Math.round(number / Math.pow(dimension, 2) * k) / k + ' <small>M' + suffix + '</small>';\n\t} else if (Math.abs(number) > dimension) {\n\t\tnumberStr = Math.round(number / dimension * k) / k + ' <small>K' + suffix + '</small>';\n\t} else {\n\t\tnumberStr = Math.round(number * k) / k + '';\n\t}\n\n\tnumberStr = numberStr.replace(/^(-?\\d+)(\\d{3})/, '$1 $2');\n\n\treturn numberStr;\n};\n\n/**\n * Обрезать текст под три точки\n * @param string\n * @param max_length - максимальное количество символов текста, остальное обрежеться\n * @param pos - область обрезки 0-начало | 1-середина | 2-конец строки\n */\nexport const ellipsis = (string: string, max_length: number, pos: 0 | 1 | 2 = 1): string => {\n\tif (string == undefined) return '';\n\n\tstring += '';\n\tif (max_length == undefined || string.length <= max_length) return string;\n\n\tif (pos === 0) {\n\t\tstring = string.substr(string.length - max_length, max_length);\n\t\tstring = '...' + string;\n\t} else if (pos === 1) {\n\t\tconst string1 = string.substr(0, max_length / 2);\n\t\tconst string2 = string.substr(string.length - max_length / 2, Math.ceil(max_length / 2));\n\t\tstring = string1 + '...' + string2;\n\t} else if (pos === 2) {\n\t\tstring = string.substr(0, max_length);\n\t\tstring = string + '...';\n\t}\n\n\treturn string;\n};\n\n/**\n * Сгенерировать строку текста для вывода количества в разном склонении\n * @param num\n * @param ending0 - родительный падеж, множ. число (10 модулей)\n * @param ending1 - именительный падеж, ед. число (1 модуль)\n * @param ending2 - винительный падеж, множ. число (3 модуля)\n */\nexport const numberEnding = (num: number, ending0: string, ending1: string, ending2: string): string => {\n\t// склонение по множественному числу\n\tif (useI18nLang().value === 'en') {\n\t\tif (num === 1) {\n\t\t\treturn ending1;\n\t\t} else {\n\t\t\treturn ending0;\n\t\t}\n\t}\n\n\tconst num100 = num % 100;\n\tconst num10 = num % 10;\n\n\tif (num100 >= 5 && num100 <= 20) {\n\t\treturn ending0;\n\t} else if (num10 === 0) {\n\t\treturn ending0;\n\t} else if (num10 === 1) {\n\t\treturn ending1;\n\t} else if (num10 >= 2 && num10 <= 4) {\n\t\treturn ending2;\n\t} else if (num10 >= 5 && num10 <= 9) {\n\t\treturn ending0;\n\t} else {\n\t\treturn ending2;\n\t}\n};\n\n/**\n * Перевести строку в родительный падеж\n */\nexport const toRoditPadej = (str: string): string => {\n\tif (useI18nLang().value != 'ru' || str == '') return str;\n\n\tconst str_array = str.split(' ');\n\n\t$.map(str_array, function (str, index) {\n\t\tstr = str + 'а';\n\t\tstr = str.replace('оа', 'о');\n\t\tstr = str.replace('аяа', 'ой');\n\t\tstr = str.replace('шийа', 'шого');\n\t\tstr = str.replace('ыйа', 'ого');\n\t\tstr = str.replace('йа', 'я');\n\t\tstr = str.replace('ьа', 'я');\n\t\tstr = str.replace('яа', 'и');\n\t\tstr = str.replace('оваа', 'овой');\n\t\tstr = str.replace('аа', 'ы');\n\t\tstr = str.replace('кия', 'кого');\n\t\tstr = str.replace('каи', 'кой');\n\n\t\tstr_array[index] = str;\n\t});\n\n\tstr = str_array.join(' ');\n\n\treturn str;\n};\n\n/**\n * Транслитерация текста\n */\nexport const rusToLatin = (str: string): string => {\n\tconst ru: { [index: string]: string } = {\n\t\t'а': 'a', 'б': 'b', 'в': 'v', 'г': 'g', 'д': 'd',\n\t\t'е': 'e', 'ё': 'e', 'ж': 'j', 'з': 'z', 'и': 'i',\n\t\t'й': 'i', 'к': 'k', 'л': 'l', 'м': 'm', 'н': 'n',\n\t\t'о': 'o', 'п': 'p', 'р': 'r', 'с': 's', 'т': 't',\n\t\t'у': 'u', 'ф': 'f', 'х': 'h', 'ц': 'c', 'ч': 'ch',\n\t\t'ш': 'sh', 'щ': 'shch', 'ъ': '', 'ы': 'y', 'ь': '',\n\t\t'э': 'e', 'ю': 'u', 'я': 'ya',\n\t};\n\n\tconst str_array = str.split(' ');\n\n\t$.map(str_array, function (str, index) {\n\t\tconst newStr: string[] = [];\n\t\tfor (let i = 0; i < str.length; ++i) {\n\t\t\tnewStr.push(\n\t\t\t\tru[str[i]] || ru[str[i].toLowerCase()] == undefined && str[i] || ru[str[i].toLowerCase()].replace(/^(.)/, function (match) {\n\t\t\t\t\treturn match.toUpperCase();\n\t\t\t\t}),\n\t\t\t);\n\t\t}\n\n\t\tstr_array[index] = newStr.join('');\n\t});\n\n\tstr = str_array.join(' ');\n\n\treturn str;\n};\n\n/**\n * Замена html-символов (`&`, `<`, `>`, `\"`, `'`) на имена литер (`&` -> `&amp;`)\n */\nexport const htmlspecialchars = (str: string): string => {\n\tstr = str\n\t\t.replace(/&/g, '&amp;')\n\t\t.replace(/</g, '&lt;')\n\t\t.replace(/>/g, '&gt;')\n\t\t.replace(/\"/g, '&quot;')\n\t\t.replace(/'/g, '&#039;');\n\n\treturn str;\n};\n\n/**\n * Выделить нужное в тексте желтым цветом\n * поиск происходит по строке fieldFilter.values[0]\n */\nexport const highlightHtml = (text: string, fieldFilter: { operator: 'CONTAINS' | 'REGEXP', values: string[] }): string => {\n\tlet regExp: RegExp | null = null;\n\n\tswitch (fieldFilter.operator) {\n\t\tcase 'CONTAINS':\n\t\tcase 'REGEXP':\n\t\t\ttry {\n\t\t\t\tlet regExpString = fieldFilter.values[0];\n\t\t\t\tif (fieldFilter.operator != 'REGEXP') regExpString = regExpString.replace(/([()\\[\\]])/g, '\\\\$1');\n\n\t\t\t\tregExp = new RegExp('(' + regExpString + ')', 'gi');\n\t\t\t} catch (exception) {\n\t\t\t\treturn text;\n\t\t\t}\n\n\t\t\tbreak;\n\t}\n\n\ttext = text.replace(regExp!, '<b class=\"found\">$1</b>');\n\n\treturn text;\n};\n\n/**\n * Пример: logHTTPCodesHundreds => log_http_codes_hundreds\n */\nexport const camelToSnakeCase = (str: string): string | undefined => {\n\treturn str.match(/[A-Z]{2,}(?=[A-Z][a-z]+[0-9]*|\\b)|[A-Z]?[a-z]+[0-9]*|[A-Z]|[0-9]+/g)?.map(token => token.toLowerCase()).join('_');\n};\n\n/**\n * Получить url изображения флага, по коду страны по стандарту ISO 3166-1 alpha-2\n *\n * @todo Опубликовать в CDN или брать c публичного CDN\n */\nexport const genFlagLinkByCountryCode = (countryCode: string) => {\n\tconst urlImage = '/cloud/common/flags/' + countryCode.toUpperCase() + '.svg';\n\treturn `/controller/file/?src=${urlImage}`;\n};\n\n/**\n * Обернуть все ссылки и email в тексте в html-тег `<a>`.\n *\n * Для email ставиться префикс `mailto:`\n */\nexport const addLinkTags = (text: string): string => {\n\tconst domainRegexp = getDomainRegexp();\n\tconst afterDomainRegexp = '(([\\\\/?\\\\w&=%+#;:-]*(\\\\.\\\\w+)?))*';\n\n\tconst regexpMailto = new RegExp(`(^|[\\\\s>(),])([a-z0-9а-яё_.]+@${domainRegexp}${afterDomainRegexp})`, 'gui');\n\ttext = text.replace(regexpMailto, `$1<a href=\"mailto:$2\" target=\"_blank\" rel=\"noopener\">↑[$2]↓</a>`);\n\n\tconst regexpLink = new RegExp(`(^|[\\\\s>(),])(https?:\\/\\/)?(${domainRegexp}${afterDomainRegexp})`, 'gui');\n\ttext = text.replace(regexpLink, `$1<a href=\"√$2$3\" target=\"_blank\" rel=\"nofollow noopener\">$2$3</a>`);\n\n\ttext = text.replaceAll('√http', 'http');\n\ttext = text.replaceAll('√', 'http://');\n\ttext = text.replaceAll(/(↑\\[|]↓)/g, '');\n\n\treturn text;\n};\n\n/**\n * Перевести первую букву строки в верхний регистр\n */\nexport const toCapitalize = (str: string): string => {\n\treturn str.charAt(0).toUpperCase() + str.slice(1);\n};\n\n/**\n * Получить случайную строку\n */\nexport const getRandomHash = (length: number = 20): string => {\n\tconst l = 'AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz1234567890';\n\n\tlet result = '';\n\tfor (let i = 0; i < length; i++) {\n\t\tresult += l[Math.floor(Math.random() * l.length)];\n\t}\n\n\treturn result;\n};\n"],"names":["genIntHash","string","hash","i","char","isUrl","url","addCommasWhite","n","nStr","x","x1","x2","rgx","nl2br","str","numberWithWord","number","precision","dimension","suffix","k","numberStr","ellipsis","max_length","pos","string1","string2","numberEnding","num","ending0","ending1","ending2","useI18nLang","num100","num10","toRoditPadej","str_array","index","rusToLatin","ru","newStr","match","htmlspecialchars","highlightHtml","text","fieldFilter","regExp","regExpString","camelToSnakeCase","_a","token","genFlagLinkByCountryCode","countryCode","addLinkTags","domainRegexp","getDomainRegexp","afterDomainRegexp","regexpMailto","regexpLink","toCapitalize","getRandomHash","length","result"],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- define(["require","exports","vue","./forms-CKYHAaPQ.amd","../popup/worker.amd","./dialogs.vue_vue_type_script_setup_true_lang-CXtBj2Ah.amd","../utils/dom.amd"],function(r,V,w,i,l,_,S){"use strict";if(typeof w>"u")var w=window.Vue;class I{static isInited=!1;static init(){this.isInited||(this.isInited=!0,document.addEventListener("mouseover",e=>{var o;!(e.target instanceof HTMLElement)||!((o=e.target.dataset)!=null&&o.topPopupOpenByHover)||e.target.click()}),document.addEventListener("scroll",()=>{i.Core.state.isMobile||i.Core.state.isMobileUA||l.TopPopupWorker.getAll().forEach(e=>l.TopPopupWorker.close(e))}),i.Events.addOnReize(e=>{i.Core.state.isMobile&&e.topEvent.widthDiff&&l.TopPopupWorker.getAll().forEach(o=>l.TopPopupWorker.close(o))}),document.addEventListener("click",this.onclick,{capture:!0}))}static async onclick(e){var n,s,c,a,D;if(!(e.target instanceof HTMLElement))return;let o;switch(!0){case!!((n=e.target.dataset)!=null&&n.topPopup):o=e.target;break;case!!((s=e.target.parentElement)!=null&&s.dataset.topPopup):o=e.target.parentElement;break;case!!((a=(c=e.target.parentElement)==null?void 0:c.parentElement)!=null&&a.dataset.topPopup):o=(D=e.target.parentElement)==null?void 0:D.parentElement;break}o&&(o.dataset.topPopupDisabled||o.dataset.topPopupOpened||(e.preventDefault(),await l.TopPopupWorker.openByOpener(o)))}}let g;const R={mounted:async(t,e)=>{g||(g=(await new Promise((c,a)=>r(["../utils/dom.amd"],c,a))).storage);const o=e.arg,n=e.value;g(t,o,n)}};let h,u=[],b;const M=async()=>{const{isVisible:t}=await new Promise((o,n)=>r(["../utils/dom.amd"],o,n));if(u=u.filter(t),!u.length)return;u[0].focus(),u=[]},C=async t=>{h||(h=await new Promise((e,o)=>r(["../utils/lodash.amd"],e,o))),b||(b=h.debounce(M,30)),u.push(t),b()},x={mounted:function(t,e){t.__TOP_V_FOCUS_VALUE=e.value??!0,(e.value??!0)&&C(t)},updated:function(t,e){e.modifiers.onupdate&&t.__TOP_V_FOCUS_VALUE!==(e.value??!0)&&(t.__TOP_V_FOCUS_VALUE=e.value??!0,(e.value??!0)&&C(t))}};let v,E;const k=t=>(typeof t=="boolean"||(t?t={...t}:t={},t.behavior??="smooth",t.block??="nearest",t.inline??="nearest"),t);let f,P;const H=async()=>{if(!f)return;const t=await y(f);t.isVisible&&f.scrollIntoView(t.scrollIntoViewOptions)},A=async t=>{E||(E=await new Promise((e,o)=>r(["../utils/lodash.amd"],e,o))),P||(P=E.debounce(H,30)),f=t,P()},y=async(t,e)=>{v||(v=await new Promise((n,s)=>r(["../utils/dom.amd"],n,s)));let o=v.storage(t,"v-top-scrollIntoView");return o||(o={isVisible:S.isVisible(t),scrollIntoViewOptions:k(e)},v.storage(t,"v-top-scrollIntoView",o)),o},W={async mounted(t,e){await y(t,e.value),e.modifiers.immediate&&A(t)},async updated(t,e){const o=await y(t,e.value);o.scrollIntoViewOptions=k(e.value);const n=S.isVisible(t);n&&o.isVisible!==n&&A(t),o.isVisible=n}};let d;const $={async mounted(t){d||(d=await new Promise((e,o)=>r(["../utils/scroll.amd"],e,o))),d.connectScrollShadow(t)},async unmounted(t){d||(d=await new Promise((e,o)=>r(["../utils/scroll.amd"],e,o))),d.unconnectScrollShadow(t)}};let p;const N={mounted(t,e,o){const n=e.value||"top-sticky";p=new IntersectionObserver(s=>{let c=s[0].intersectionRatio<1;c&&e.modifiers.bottom&&s[0].intersectionRect.y===0&&(c=!1),t.classList.toggle(n,c)},{threshold:[1]}),p.observe(t)},unmounted(t,e,o){p==null||p.disconnect()}};let L=!1,m;const T=new Map,F=(t,e)=>{const{distance:o,percent:n}=t.directiveSwipUpOptions,s=t.getBoundingClientRect().top,c=e*n/100/o,a=(e-s)/c;a<=o?t.style.transform=`translateY(${o-a}px)`:t.style.transform="translateY(0px)"},B=t=>{let e=window.innerHeight;window.addEventListener("scroll",()=>{T.forEach(o=>F(o,e))},{passive:!0}),m=new IntersectionObserver(o=>{e=window.innerHeight,o.forEach(n=>{const s=n.target;if(n.intersectionRatio<.1?T.delete(s):T.set(s,s),n.intersectionRatio===0){const{distance:c}=s.directiveSwipUpOptions;s.style.transform=`translateY(${c}px)`}})},{threshold:.1})},Y={mounted(t,e,o){var n,s;i.Core.state.isMobileUA||(t.directiveSwipUpOptions={distance:((n=e.value)==null?void 0:n.distance)??100,percent:((s=e.value)==null?void 0:s.percent)??30},L||(B(),L=!0),m.observe(t))},unmounted(t,e,o){T.delete(t),m==null||m.unobserve(t)}},U=t=>{var e,o;if(!((o=(e=i.Core.$)==null?void 0:e.ui)!=null&&o.tooltip)){console.info("Для работы v-top-tooltip требуется глобальная загрузка jQuery UI Tooltip");return}return i.Core.$(t)},O=(t,e)=>{var n;const o=t.value??{};return o.content??=(n=e.props)==null?void 0:n.title,o.content=String(o.content).replace(/\r\n|\r|\n/g,"<br>"),o.position??={my:"bottom-18px",at:"top center"},o},j={mounted(t,e,o){var n;(n=U(t))==null||n.tooltip(O(e,o))},updated(t,e,o,n){var a;const s=O(e,o),c=(a=U(t))==null?void 0:a.tooltip("instance");c&&(c.options={...c.options,...s})},unmounted(t,e,o){var n;(n=U(t))==null||n.tooltip("destroy")}},z=w.defineAsyncComponent(()=>new Promise((t,e)=>r(["./notice-CyeaHgdt.amd"],t,e)));window.vd=console.log;const G={install:(t,e)=>{t.config.globalProperties.$core=i.Core,t.config.globalProperties.$vd=console.log;for(const o in e)i.Core.state[o]=e[o];e.widthForMobile&&(i.Core.widthForMobile=e.widthForMobile),e.themeName&&(i.Core.themeName=e.themeName),i.Core._setState(),e.topPopupOptions&&(l.TopPopupWorker.options=e.topPopupOptions),I.init(),_.TopDialogWorker.init(e.topDialogOptions),t.directive("top-data",R),t.directive("top-focus",x),t.directive("top-scroll-into-view",W),t.directive("top-scroll-shadow",$),t.directive("top-sticky",N),t.directive("top-swim-up",Y),t.directive("top-tooltip",j),t.component("TopAvatar",i.TopAvatar),t.component("TopButton",i.TopButton),t.component("TopCheckbox",i.TopCheckbox),t.component("TopControlLabel",i.TopControlLabel),t.component("TopHint",i.TopHint),t.component("TopInput",i.TopInput),t.component("TopInputDate",i.TopInputDate),t.component("TopInputRange",i.TopInputRange),t.component("TopLoadbar",i.TopLoadbar),t.component("TopRadio",i.TopRadio),t.component("TopSelect",i.TopSelect),t.component("TopSwitcher",i.TopSwitcher),t.component("TopTextarea",i.TopTextarea),t.component("TopNotice",z),t.component("TopDialogs",_._sfc_main)}};V.core=G});
2
- //# sourceMappingURL=core-BHvOvH4M.amd.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"core-BHvOvH4M.amd.js","sources":["../../src/components/popup/lib/worker.globalEvents.ts","../../src/core/directives/data.ts","../../src/core/directives/focus.ts","../../src/core/directives/scrollIntoView.ts","../../src/core/directives/scrollShadow.ts","../../src/core/directives/sticky.ts","../../src/core/directives/swimUp.ts","../../src/core/directives/tooltip.ts","../../src/core/plugins/core.ts"],"sourcesContent":["import Core from '@/core/core/core';\nimport Events from '@/core/core/events';\nimport Worker from '@/components/popup/lib/worker';\n\n/**\n * Глобальные события, для реализации Popup\n */\nclass WorkerEvents {\n\n\tprivate static isInited = false;\n\n\t/**\n\t * Добавить глобальные обработчики\n\t *\n\t * Добавляются на страницу один раз и навсегда\n\t */\n\tstatic init(): void {\n\t\tif (this.isInited) return;\n\n\t\tthis.isInited = true;\n\n\t\t// автоматическое открытие при наведении мыши, событие глобальное, так как инициализация popup отложена\n\t\tdocument.addEventListener('mouseover', (e) => {\n\t\t\tif (!(e.target instanceof HTMLElement) || !e.target.dataset?.topPopupOpenByHover) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\te.target.click();\n\t\t});\n\n\t\t// при скролле страницы закрыть Popup\n\t\tdocument.addEventListener('scroll', () => {\n\t\t\tif (Core.state.isMobile || Core.state.isMobileUA) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tWorker.getAll().forEach(elPopup => Worker.close(elPopup));\n\t\t});\n\n\t\tEvents.addOnReize(e => {\n\t\t\t// закрыть popup при повороте экрана телефона\n\t\t\t// если была отображена ПК версия, она будет закрыта\n\t\t\tif (Core.state.isMobile && e.topEvent.widthDiff) {\n\t\t\t\tWorker.getAll().forEach(elPopup => Worker.close(elPopup));\n\t\t\t}\n\t\t});\n\n\t\tdocument.addEventListener('click', this.onclick, { capture: true });\n\t}\n\n\t/**\n\t * Глобальный обработчик кликов\n\t *\n\t * Обрабатывает клики на открытие Popup\n\t */\n\tprivate static async onclick(e: Event): Promise<void> {\n\t\tif (!(e.target instanceof HTMLElement)) return;\n\n\t\tlet elOpener: HTMLElement | null | undefined;\n\n\t\tswitch (true) {\n\t\t\tcase !!e.target.dataset?.topPopup:\n\t\t\t\telOpener = e.target;\n\n\t\t\t\tbreak;\n\n\t\t\tcase !!e.target.parentElement?.dataset.topPopup:\n\t\t\t\telOpener = e.target.parentElement;\n\n\t\t\t\tbreak;\n\n\t\t\tcase !!e.target.parentElement?.parentElement?.dataset.topPopup:\n\t\t\t\telOpener = e.target.parentElement?.parentElement;\n\n\t\t\t\tbreak;\n\t\t}\n\n\t\tif (!elOpener) {\n\t\t\treturn;\n\t\t}\n\n\t\tif (elOpener.dataset.topPopupDisabled) {\n\t\t\treturn;\n\t\t}\n\n\t\t// меню уже открыто\n\t\tif (elOpener.dataset.topPopupOpened) {\n\t\t\treturn;\n\t\t}\n\n\t\te.preventDefault();\n\n\t\tawait Worker.openByOpener(elOpener);\n\t}\n}\n\nexport default WorkerEvents;\n","import type { DirectiveBinding, ObjectDirective } from 'vue';\n\nlet storage: any;\n\n/**\n * Сохранить данные в элементе\n *\n * Для доступа к данным можно воспользоваться ui/utils/dom storage()\n */\nconst data = {\n\tmounted: async (el: HTMLElement, binding: DirectiveBinding) => {\n\t\tif (!storage) {\n\t\t\tconst UtilsDom = await import('@/core/utils/dom');\n\n\t\t\tstorage = UtilsDom.storage;\n\t\t}\n\n\t\tconst name = binding.arg;\n\t\tconst value = binding.value;\n\n\t\tstorage(el, name, value);\n\t},\n};\n\nexport default data;\n","import type { DirectiveBinding } from 'vue';\n\ntype Binding = DirectiveBinding<boolean, 'onupdate'>;\n\nlet UtilsLodash: typeof import('@/core/utils/lodash');\n\n/**\n * Список элементов, на которых бала запрошена фокусировка, для дедупликации фокусировок\n */\nlet elsActive: HTMLElement[] = [];\n\n/**\n * Функция скролла с дедупликацией\n */\nlet focusOnElActiveDebounce: Function;\n\n/**\n * Выполнить фокусировку на активном элементе\n *\n * Если фокусирока запрошена на несколько элементов, будет выбран первый элемент\n */\nconst focusOnElActive = async () => {\n\tconst { isVisible } = await import('@/core/utils/dom');\n\telsActive = elsActive.filter(isVisible)\n\n\tif (!elsActive.length) return;\n\n\tconst el = elsActive[0];\n\n\tel.focus();\n\n\t// // UX: Если выбрано несколько чекбоксов или радио после выбора фокусировка будет снята, чтобы не делать выбор за пользователя\n\t// if (elsActive.length && el.nodeName === 'INPUT') {\n\t// \tconst type = (el as HTMLInputElement).type;\n\t// \tif (type === 'checkbox' || type === 'radio') el.blur();\n\t// }\n\n\telsActive = [];\n};\n\n/**\n * Выполнить дедуплицированную фокусировку на элементе\n */\nconst focusOnElDebounce = async (el: HTMLElement) => {\n\tif (!UtilsLodash) UtilsLodash = await import('@/core/utils/lodash');\n\tif (!focusOnElActiveDebounce) focusOnElActiveDebounce = UtilsLodash.debounce(focusOnElActive, 30);\n\n\telsActive.push(el);\n\n\tfocusOnElActiveDebounce();\n};\n\n/**\n * Фокусировка на элементе сразу после его отображения\n */\nconst focus = {\n\tmounted: function (el: HTMLElement, binding: Binding) {\n\t\tel['__TOP_V_FOCUS_VALUE'] = binding.value ?? true;\n\n\t\tif (binding.value ?? true) focusOnElDebounce(el);\n\t},\n\n\tupdated: function (el: HTMLElement, binding: Binding) {\n\t\tif (!binding.modifiers.onupdate) return;\n\n\t\tif (el['__TOP_V_FOCUS_VALUE'] === (binding.value ?? true)) return;\n\t\tel['__TOP_V_FOCUS_VALUE'] = binding.value ?? true;\n\n\t\tif (binding.value ?? true) focusOnElDebounce(el);\n\t},\n};\n\nexport default focus;\n","import type { DirectiveBinding, ObjectDirective } from 'vue';\nimport { isVisible } from '@/core/utils/dom';\n\ntype Binding = DirectiveBinding<ScrollIntoViewOptions | boolean | undefined, 'immediate'>;\n\ntype Storage = {\n\t/**\n\t * Сохраненное состояние видимости\n\t */\n\tisVisible: boolean,\n\n\t/**\n\t * Текущие настройки скролла\n\t */\n\tscrollIntoViewOptions: ScrollIntoViewOptions | boolean\n};\n\nlet UtilsDom: typeof import('@/core/utils/dom');\nlet UtilsLodash: typeof import('@/core/utils/lodash');\n\n/**\n * Сгенерировать настройки для скролла\n *\n * @see https://developer.mozilla.org/ru/docs/Web/API/Element/scrollIntoView\n */\nconst genScrollIntoViewOptions = (scrollIntoViewOptions?: ScrollIntoViewOptions | boolean) => {\n\tif (typeof scrollIntoViewOptions === 'boolean') return scrollIntoViewOptions;\n\n\tif (!scrollIntoViewOptions) {\n\t\tscrollIntoViewOptions = {};\n\t} else {\n\t\tscrollIntoViewOptions = { ...scrollIntoViewOptions };\n\t}\n\n\tscrollIntoViewOptions.behavior ??= 'smooth';\n\tscrollIntoViewOptions.block ??= 'nearest';\n\tscrollIntoViewOptions.inline ??= 'nearest';\n\n\treturn scrollIntoViewOptions;\n};\n\n/**\n * Активный элемент, для дедупликации скроллов\n *\n * Только один элемент на странице может считаться активным\n */\nlet elActive: HTMLElement | undefined;\n\n/**\n * Функция скролла с дедупликацией\n */\nlet scrollToElActiveDebounce: Function;\n\n/**\n * Выполнить скролл к текущему активному элементу\n */\nconst scrollToElActive = async () => {\n\tif (!elActive) return;\n\n\tconst storage = await useStorage(elActive);\n\tif (!storage.isVisible) return;\n\n\telActive.scrollIntoView(storage.scrollIntoViewOptions);\n};\n\n/**\n * Выполнить дедуплицированный скролл к элементу\n *\n * Будет выполнен скролл к самому последнему элементу, вызвавшему срабатывание директивы\n */\nconst scrollToElDebounce = async (el: HTMLElement) => {\n\tif (!UtilsLodash) UtilsLodash = await import('@/core/utils/lodash');\n\tif (!scrollToElActiveDebounce) scrollToElActiveDebounce = UtilsLodash.debounce(scrollToElActive, 30);\n\n\telActive = el;\n\n\tscrollToElActiveDebounce();\n};\n\n/**\n * Данные, связанные с элементом и директивой\n */\nconst useStorage = async (el: HTMLElement, scrollIntoViewOptions?: ScrollIntoViewOptions | boolean) => {\n\tif (!UtilsDom) UtilsDom = await import('@/core/utils/dom');\n\n\tlet storage: Storage | undefined = UtilsDom.storage(el, 'v-top-scrollIntoView');\n\n\t// инициализация\n\tif (!storage) {\n\t\tstorage = {\n\t\t\tisVisible: isVisible(el),\n\t\t\tscrollIntoViewOptions: genScrollIntoViewOptions(scrollIntoViewOptions),\n\t\t};\n\n\t\tUtilsDom.storage(el, 'v-top-scrollIntoView', storage);\n\t}\n\n\treturn storage;\n};\n\nconst scrollIntoView: ObjectDirective = {\n\tasync mounted(el: HTMLElement, binding: Binding) {\n\t\tawait useStorage(el, binding.value);\n\n\t\tif (binding.modifiers.immediate) {\n\t\t\tscrollToElDebounce(el);\n\t\t}\n\t},\n\n\tasync updated(el: HTMLElement, binding: Binding) {\n\t\tconst storage = await useStorage(el, binding.value);\n\t\tstorage.scrollIntoViewOptions = genScrollIntoViewOptions(binding.value);\n\n\t\tconst isVisibleNew = isVisible(el);\n\t\tif (isVisibleNew && storage.isVisible !== isVisibleNew) {\n\t\t\tscrollToElDebounce(el);\n\t\t}\n\n\t\tstorage.isVisible = isVisibleNew;\n\t},\n};\n\nexport default scrollIntoView;\n","let UtilsScroll: typeof import('@/core/utils/scroll');\n\n/**\n * Добавить отображение тени при появлении скролла у элемента\n *\n * Будут добавлены события для усатновки модификаторов тени в зависимости от скролла элемента\n *\n * Модификаторы:\n * - top-scrollShadow\n * - top-scrollShadow-started\n * - top-scrollShadow-finished\n */\nconst connectScrollShadow = {\n\tasync mounted(el) {\n\t\tif (!UtilsScroll) UtilsScroll = await import('@/core/utils/scroll');\n\n\t\tUtilsScroll.connectScrollShadow(el);\n\t},\n\n\tasync unmounted(el) {\n\t\tif (!UtilsScroll) UtilsScroll = await import('@/core/utils/scroll');\n\n\t\tUtilsScroll.unconnectScrollShadow(el);\n\t},\n};\n\nexport default connectScrollShadow;\n","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\n\nlet appStickyObserver: IntersectionObserver;\n\n/**\n * Добавление sticky\n * К элементу добляется класс переданный как значение диррективы либо **'top-sticky'** по умолчанию\n */\nconst sticky = {\n\tmounted(el: HTMLElement, binding: DirectiveBinding, _vnode: VNode) {\n\t\tconst className = binding.value || 'top-sticky';\n\n\t\tappStickyObserver = new IntersectionObserver(entries => {\n\t\t\tlet condition = entries[0].intersectionRatio < 1;\n\t\t\tif (condition) {\n\t\t\t\tif (binding.modifiers.bottom && entries[0].intersectionRect.y === 0) condition = false;\n\t\t\t}\n\n\t\t\tel.classList.toggle(className, condition);\n\t\t}, {\n\t\t\tthreshold: [1],\n\t\t});\n\n\t\tappStickyObserver.observe(el);\n\t},\n\n\tunmounted(_el: HTMLElement, _binding: DirectiveBinding, _vnode: VNode) {\n\t\tappStickyObserver?.disconnect();\n\t},\n};\n\nexport default sticky;\n","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\nimport Core from '@/core/core/core';\n\ninterface HTMLElementWithSwimUpOptions extends HTMLElement {\n\tdirectiveSwipUpOptions: {\n\t\tdistance: number,\n\t\tpercent: number,\n\t};\n}\n\nlet appSwimUpInited = false;\nlet appSwimUpObserver: IntersectionObserver;\nconst appSwimUpEls = new Map();\n\n/**\n * Отодвинуть блок в зависимости от скролла старинцы\n * @param el\n * @param windowHeight\n */\nconst swimUpElTransform = (el: HTMLElementWithSwimUpOptions, windowHeight: number): void => {\n\tconst { distance, percent } = el.directiveSwipUpOptions;\n\n\tconst elTop = el.getBoundingClientRect().top;\n\n\t// во столько раз triggerHeight должен быть меньше, чтобы закончить подплытие к нужной высоте экрана\n\tconst triggerHeightReducer = windowHeight * percent / 100 / distance;\n\tconst triggerHeight = (windowHeight - elTop) / triggerHeightReducer;\n\n\tif (triggerHeight <= distance) {\n\t\tel.style.transform = `translateY(${distance - triggerHeight}px)`;\n\t} else {\n\t\tel.style.transform = 'translateY(0px)';\n\t}\n};\n\nconst swimUpInit = (_el: HTMLElementWithSwimUpOptions): void => {\n\tlet windowHeight = window.innerHeight;\n\n\twindow.addEventListener('scroll', () => {\n\t\tappSwimUpEls.forEach((el) => swimUpElTransform(el, windowHeight));\n\t}, { passive: true });\n\n\t// проверка того, что элемент в зоне видимости\n\tappSwimUpObserver = new IntersectionObserver(entries => {\n\t\twindowHeight = window.innerHeight;\n\n\t\tentries.forEach((entry) => {\n\t\t\tconst el = entry.target as HTMLElementWithSwimUpOptions;\n\n\t\t\tif (entry.intersectionRatio < 0.1) {\n\t\t\t\t// элемент за областью видимости\n\t\t\t\tappSwimUpEls.delete(el);\n\t\t\t} else {\n\t\t\t\t// элемент на экране\n\t\t\t\tappSwimUpEls.set(el, el);\n\t\t\t}\n\n\t\t\tif (entry.intersectionRatio === 0) {\n\t\t\t\tconst { distance } = el.directiveSwipUpOptions;\n\t\t\t\tel.style.transform = `translateY(${distance}px)`;\n\t\t\t}\n\t\t});\n\t}, {\n\t\tthreshold: 0.1,\n\t});\n};\n\n/**\n * Добавление анимации подплытия вверх для блока\n */\nconst swimUp = {\n\tmounted(el: HTMLElementWithSwimUpOptions, binding: DirectiveBinding, _vnode: VNode): void {\n\t\tif (Core.state.isMobileUA) return;\n\n\t\tel.directiveSwipUpOptions = {\n\t\t\tdistance: binding.value?.distance ?? 100, // количество px на которые блок изначально смещен вниз,\n\t\t\tpercent: binding.value?.percent ?? 30, // процент высоты экрана поднявшись на который блок закончит подплытие\n\t\t};\n\n\t\tif (!appSwimUpInited) {\n\t\t\tswimUpInit(el);\n\n\t\t\tappSwimUpInited = true;\n\t\t}\n\n\t\tappSwimUpObserver.observe(el);\n\t},\n\n\tunmounted(el: HTMLElementWithSwimUpOptions, _binding: DirectiveBinding, _vnode: VNode) {\n\t\tappSwimUpEls.delete(el);\n\t\tappSwimUpObserver?.unobserve(el);\n\t},\n};\n\nexport default swimUp;\n","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\nimport Core from '@/core/core/core';\n\nconst $ = (el: VNode) => {\n\tif (!Core.$?.ui?.tooltip) {\n\t\tconsole.info('Для работы v-top-tooltip требуется глобальная загрузка jQuery UI Tooltip');\n\n\t\treturn;\n\t}\n\n\treturn Core.$(el);\n};\n\nconst tvTooltipGenOptions = (binding: DirectiveBinding, vnode: VNode) => {\n\tconst options = binding.value ?? {};\n\n\toptions.content ??= vnode.props?.title;\n\toptions.content = String(options.content).replace(/\\r\\n|\\r|\\n/g, '<br>');\n\n\toptions.position ??= {\n\t\tmy: 'bottom-18px',\n\t\tat: 'top center',\n\t};\n\n\treturn options;\n};\n\n/**\n * Добавление всплывающей подсказки к элементу.\n */\nconst tooltip = {\n\tmounted(el: VNode, binding: DirectiveBinding, vnode: VNode) {\n\t\t$(el)?.tooltip(tvTooltipGenOptions(binding, vnode));\n\t},\n\n\tupdated(el: VNode, binding: DirectiveBinding, vnode: VNode, _prevVnode: VNode) {\n\t\t/**\n\t\t * В результате обновления может быть открыто несколько тултипов поэтому изменить опции, без перерисовки тултипа\n\t\t */\n\t\tconst options = tvTooltipGenOptions(binding, vnode);\n\t\tconst instance = $(el)?.tooltip('instance') as { options: JQueryUI.TooltipOptions } | undefined;\n\t\tif (!instance) {\n\t\t\treturn;\n\t\t}\n\n\t\tinstance.options = {\n\t\t\t...instance.options,\n\t\t\t...options,\n\t\t};\n\t},\n\n\tunmounted(el: VNode, _binding: DirectiveBinding, _vnode: VNode) {\n\t\t$(el)?.tooltip('destroy');\n\t},\n};\n\nexport default tooltip;\n","import { defineAsyncComponent, type Plugin } from 'vue';\nimport type { PartialBy } from '@/components/types';\n\nimport Core from '@/core/core/core';\nimport coreDefaultOptions from '@/core/core/options';\n\nimport * as Forms from '../../components/forms/forms';\n\nconst TopNotice = defineAsyncComponent(() => import('@/components/core/notice/notice.vue'));\n\nimport type { Options as TopPopupOptions } from '@/components/popup/lib/worker';\nimport TopPopupWorker from '@/components/popup/lib/worker';\nimport TopPopupWorkerGlobalEvents from '@/components/popup/lib/worker.globalEvents';\n\nimport TopDialogs from '@/components/dialog/dialog/dialogs/dialogs.vue';\nimport { TopDialogWorker } from '@/components/dialog/lib/worker';\nimport type { TopDialogOptions } from '@/components/dialog/lib/types';\n\nimport directiveData from '@/core/directives/data';\nimport directiveFocus from '@/core/directives/focus';\nimport directiveScrollIntoView from '@/core/directives/scrollIntoView';\nimport directiveScrollShadow from '@/core/directives/scrollShadow';\nimport directiveSticky from '@/core/directives/sticky';\nimport directiveSwimUp from '@/core/directives/swimUp';\nimport directiveTooltip from '@/core/directives/tooltip';\n\ndeclare global {\n\tconst vd: typeof console.log;\n}\n\nwindow['vd'] = console.log;\n\ndeclare module '@vue/runtime-core' {\n\tinterface ComponentCustomProperties {\n\t\t/**\n\t\t * Статический класс с текущим состоянимем UI\n\t\t */\n\t\t$core: typeof Core;\n\n\t\t$vd: typeof console.log;\n\t}\n\n\t/**\n\t * Обязательные компоненты UI\n\t *\n\t * Они подключаются через плагин и доступны без явного указания импорта\n\t */\n\texport interface GlobalComponents {\n\t\tTopAvatar: typeof Forms.TopAvatar;\n\t\tTopButton: typeof Forms.TopButton;\n\t\tTopCheckbox: typeof Forms.TopCheckbox;\n\t\tTopControlLabel: typeof Forms.TopControlLabel;\n\t\tTopHint: typeof Forms.TopHint;\n\t\tTopInput: typeof Forms.TopInput;\n\t\tTopInputDate: typeof Forms.TopInputDate;\n\t\tTopInputRange: typeof Forms.TopInputRange;\n\t\tTopRadio: typeof Forms.TopRadio;\n\t\tTopSwitcher: typeof Forms.TopSwitcher;\n\t\tTopTextarea: typeof Forms.TopTextarea;\n\t\tTopSelect: typeof Forms.TopSelect;\n\t\tTopLoadbar: typeof Forms.TopLoadbar;\n\n\t\tTopNotice: typeof TopNotice;\n\t\tTopDialogs: typeof TopDialogs;\n\t}\n}\n\ntype CoreOptions = PartialBy<typeof coreDefaultOptions, 'gmt' | 'documentClassModificators'>;\n\ntype Options = CoreOptions & {\n\ttopPopupOptions?: TopPopupOptions\n\ttopDialogOptions?: TopDialogOptions\n};\n\n/**\n * Плагин для интеграции UI во Vue приложение\n *\n * - В глобальную область видимости шаблонов будет добавлен объект $core\n * - Будут зарегистрирвоаны директивы UI: https://ui.topvisor.com/?path=/docs/core-directives-focus--docs\n * - Будут подключены базовые компоненты UI/Forms: https://ui.topvisor.com/?path=/docs/components-forms-readme--docs\n */\nexport default {\n\n\tinstall: (app, options: Options) => {\n\t\tapp.config.globalProperties.$core = Core;\n\t\tapp.config.globalProperties.$vd = console.log;\n\n\t\t// начальные настройки UI\n\t\tfor (const name in options) {\n\t\t\tCore.state[name] = options[name];\n\t\t}\n\n\t\tif (options.widthForMobile) Core.widthForMobile = options.widthForMobile;\n\t\tif (options.themeName) Core.themeName = options.themeName;\n\n\t\tCore._setState();\n\n\t\tif (options.topPopupOptions) TopPopupWorker.options = options.topPopupOptions;\n\t\tTopPopupWorkerGlobalEvents.init();\n\n\t\tTopDialogWorker.init(options.topDialogOptions);\n\n\t\t// определение директив\n\t\tapp.directive('top-data', directiveData);\n\t\tapp.directive('top-focus', directiveFocus);\n\t\tapp.directive('top-scroll-into-view', directiveScrollIntoView);\n\t\tapp.directive('top-scroll-shadow', directiveScrollShadow);\n\t\tapp.directive('top-sticky', directiveSticky);\n\t\tapp.directive('top-swim-up', directiveSwimUp);\n\t\tapp.directive('top-tooltip', directiveTooltip);\n\n\t\t// определение базовых компонентов\n\t\tapp.component('TopAvatar', Forms.TopAvatar);\n\t\tapp.component('TopButton', Forms.TopButton);\n\t\tapp.component('TopCheckbox', Forms.TopCheckbox);\n\t\tapp.component('TopControlLabel', Forms.TopControlLabel);\n\t\tapp.component('TopHint', Forms.TopHint);\n\t\tapp.component('TopInput', Forms.TopInput);\n\t\tapp.component('TopInputDate', Forms.TopInputDate);\n\t\tapp.component('TopInputRange', Forms.TopInputRange);\n\t\tapp.component('TopLoadbar', Forms.TopLoadbar);\n\t\tapp.component('TopRadio', Forms.TopRadio);\n\t\tapp.component('TopSelect', Forms.TopSelect);\n\t\tapp.component('TopSwitcher', Forms.TopSwitcher);\n\t\tapp.component('TopTextarea', Forms.TopTextarea);\n\n\t\tapp.component('TopNotice', TopNotice);\n\t\tapp.component('TopDialogs', TopDialogs);\n\t},\n\n} satisfies Plugin<Options>;\n"],"names":["WorkerEvents","_a","forms","popup_worker","elPopup","elOpener","_d","_c","storage","data","el","binding","resolve","reject","require","name","value","UtilsLodash$1","focusOnElActiveDebounce","elsActive","isVisible","focusOnElDebounce","focusOnElActive","focus","UtilsDom","UtilsLodash","genScrollIntoViewOptions","scrollIntoViewOptions","elActive","scrollToElActiveDebounce","useStorage","scrollToElDebounce","scrollToElActive","utils_dom","scrollIntoView","isVisibleNew","UtilsScroll","connectScrollShadow","appStickyObserver","sticky","_vnode","className","entries","_el","_binding","appSwimUpObserver","appSwimUpEls","swimUpElTransform","windowHeight","triggerHeight","distance","swimUpInit","entry","swimUp","_b","$","tvTooltipGenOptions","vnode","options","tooltip","core","app","dialogs_vue_vue_type_script_setup_true_lang","TopNotice"],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- define(["require","exports","vue","./forms-CKYHAaPQ.amd","../popup/worker.amd","../require/css.amd!../assets/listItem.css"],function(L,f,e,v,B){"use strict";if(typeof e>"u")var e=window.Vue;const k=e.defineComponent({__name:"opener",props:{id:{},pos:{default:"3"},notch:{type:Boolean,default:!0},openByHover:{type:Boolean},posBy:{default:"fixed"}},setup(r){const n=r,p=n.id||Math.random()+"";let s;function d(t){setTimeout(()=>{s=t.nextElementSibling,s&&a(s)})}e.onUpdated(()=>{s&&a(s)});function a(t){t.dataset.topPopup="#"+p,t.dataset.topPopupId=p,t.dataset.topPopupPos=n.pos,t.dataset.topPopupPosBy=n.posBy,t.dataset.topPopupNotch=n.notch?"true":"",t.dataset.topPopupOpenByHover=n.openByHover?"true":""}return(t,i)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("template",{ref:d}),e.renderSlot(t.$slots,"default")],64))}}),C={key:0,class:"top-popup_header"},h={key:0,class:"top-as-a closer"},_={key:1,class:"top-popup_widget"},$={key:2,class:"top-popup_content"},P={key:4,class:"top-popup_footer"},S=["href"],N=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:p}){const s=r,d=p,a={popup:void 0};n(a);const t=s.id||"top-popup-id-"+Math.random(),i=e.ref(null),m=e.ref(null),c={onOpen:async o=>{o.elPopup&&(i.value=o.elPopup),o.elPopupInner&&(o.elPopupInner.innerText="",m.value=o.elPopupInner),c.opened=!0,c.popup=o,a.popup=o,d("open",{elPopup:o.elPopup,elPopupOpener:o.el})},onClose:o=>{m.value=null,c.opened=!1,c.popup=void 0,d("close",{elPopup:o.elPopup,elPopupOpener:o.el})},classRef:e.toRef(s,"class"),opened:!1,popup:void 0,transitionDurationRef:e.toRef(s,"transitionDuration")};return e.watch(()=>s.class,(o,l)=>{if(!i.value)return;const u=(o==null?void 0:o.split(" "))??[],g=((l==null?void 0:l.split(" "))??[]).filter(I=>!u.includes(I));i.value.classList.remove(...g),i.value.classList.add(...u)}),B.TopPopupWorker.regVueComponent(t,c),e.onUnmounted(()=>{B.TopPopupWorker.unregVueComponent(t)}),(o,l)=>{const u=e.resolveDirective("top-scroll-shadow");return e.openBlock(),e.createElementBlock(e.Fragment,null,[o.$slots.opener?(e.openBlock(),e.createBlock(k,{key:0,id:e.unref(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),m.value?(e.openBlock(),e.createBlock(e.Teleport,{key:1,to:m.value},[o.$slots.header||o.$core.state.isMobile?(e.openBlock(),e.createElementBlock("div",C,[o.$core.state.isMobile?(e.openBlock(),e.createElementBlock("span",h,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",_,[e.renderSlot(o.$slots,"widget")])):e.createCommentVNode("",!0),o.$slots.content?e.withDirectives((e.openBlock(),e.createElementBlock("div",$,[e.renderSlot(o.$slots,"content")])),[[u]]):e.createCommentVNode("",!0),o.$slots.contentList?e.withDirectives((e.openBlock(),e.createElementBlock("ul",{key:3,class:"top-popup_content",onScroll:l[0]||(l[0]=y=>o.$emit("scrollContentList",y))},[e.renderSlot(o.$slots,"contentList")],32)),[[u]]):e.createCommentVNode("",!0),o.$slots.footer||o.footerSupportLink?(e.openBlock(),e.createElementBlock("div",P,[o.footerSupportLink?(e.openBlock(),e.createElementBlock("a",{key:0,class:"top-popup_footerSupportLink",href:o.footerSupportLink,target:"_blank"},[e.createVNode(v._sfc_main$1,{hint:""})],8,S)):e.createCommentVNode("",!0),e.renderSlot(o.$slots,"footer")])):e.createCommentVNode("",!0)],8,["to"])):e.createCommentVNode("",!0)],64)}}}),E=e.defineComponent({inheritAttrs:!1,__name:"listItem",props:{type:{default:"button"},closeByClick:{type:Boolean,default:!0}},setup(r){const n=r;return(p,s)=>(e.openBlock(),e.createElementBlock("li",{class:e.normalizeClass({"top-popup_liNoSelectable":n.type!=="button"})},[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(p.$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":!p.closeByClick}},p.$attrs),{default:e.withCtx(()=>[e.renderSlot(p.$slots,"default")]),_:3},16,["class"]))],2))}});f._sfc_main=N,f._sfc_main$1=E,f._sfc_main$2=k});
2
- //# sourceMappingURL=listItem.vue_vue_type_script_setup_true_lang-C_ZN2Nia.amd.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"listItem.vue_vue_type_script_setup_true_lang-Di1h6iID.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\">\nimport { onUpdated } from 'vue';\nimport type { OpenerProps } from './popup';\n\nconst props = withDefaults(defineProps<OpenerProps>(), {\n\tpos: '3',\n\tnotch: true,\n\tposBy: 'fixed',\n});\n\nconst id = props.id || Math.random() + '';\n\nlet elOpener: Element;\n\n/**\n * Необычная функция для проброски props внтурь элемента слота\n *\n * @param el - вспомогательрный элемент для доступа к элементам слота\n */\nfunction render(el: any) {\n\tsetTimeout(() => {\n\t\telOpener = el.nextElementSibling;\n\n\t\tif (elOpener) {\n\t\t\trenderOpener(elOpener);\n\t\t}\n\t});\n}\n\nonUpdated(() => {\n\tif (elOpener) {\n\t\trenderOpener(elOpener);\n\t}\n});\n\nfunction renderOpener(elOpener: any) {\n\t/**\n\t * topPopup - необходимый атрибут для всез Popup\n\t *\n\t * Для Vue вместо него используется атрибут topPopupId\n\t */\n\telOpener.dataset.topPopup = '#' + id;\n\n\telOpener.dataset.topPopupId = id;\n\telOpener.dataset.topPopupPos = props.pos;\n\telOpener.dataset.topPopupPosBy = props.posBy;\n\telOpener.dataset.topPopupNotch = props.notch ? 'true' : '';\n\telOpener.dataset.topPopupOpenByHover = props.openByHover ? 'true' : '';\n}\n</script>\n\n<template>\n\t<template :ref=\"render\"></template>\n\n\t<!-- @slot элемент для открытия Popup -->\n\t<slot></slot>\n</template>\n\n<!-- Использует общий deprecated класс .btn -->\n<style>\nh3[data-top-popup],\ndiv[data-top-popup],\ni[data-top-popup]:not(.btn),\nb[data-top-popup]:not(.btn) {\n\tcursor: pointer;\n\tuser-select: none;\n\tfont-style: normal;\n\ttext-decoration: none;\n\tdisplay: inline-flex;\n\talign-items: center;\n}\n\n[data-top-popup][data-top-popup-disabled] {\n\tpointer-events: none;\n\tcursor: auto !important;\n}\n\ni[contenteditable] {\n\tcursor: text !important;\n}\n</style>\n","<script setup lang=\"ts\">\nimport { onUnmounted, ref, toRef, watch } from 'vue';\nimport TopHint from '@/components/forms/hint/hint.vue';\nimport type { TopLibPopup } from '@/components/popup/lib/popup';\nimport type { Emits, Props } from './popup';\nimport Opener from './opener.vue';\nimport Worker from '@/components/popup/lib/worker';\n\nconst props = withDefaults(defineProps<Props>(), {\n\tid: '',\n\tpos: '3',\n\tnotch: true,\n\tposBy: 'fixed',\n});\n\nconst emit = defineEmits<Emits>();\n\nconst expose = {\n\tpopup: undefined as TopLibPopup | undefined,\n};\ndefineExpose(expose);\n\nconst id = props.id || 'top-popup-id-' + Math.random() + '';\n\nconst elPopupRef = ref<HTMLElement | null>(null);\nconst elPopupInnerRef = ref<HTMLElement | null>(null);\n\n// см. lib/popup\nconst onOpen = async (popup: TopLibPopup) => {\n\tif (popup.elPopup) elPopupRef.value = popup.elPopup;\n\n\tif (popup.elPopupInner) {\n\t\tpopup.elPopupInner.innerText = '';\n\n\t\telPopupInnerRef.value = popup.elPopupInner;\n\t}\n\n\tvueConnector.opened = true;\n\tvueConnector.popup = popup;\n\n\texpose.popup = popup;\n\n\temit('open', { elPopup: popup.elPopup!, elPopupOpener: popup.el });\n};\n\n// см. lib/popup\nconst onClose = (popup: TopLibPopup) => {\n\telPopupInnerRef.value = null;\n\n\tvueConnector.opened = false;\n\tvueConnector.popup = undefined;\n\n\temit('close', { elPopup: popup.elPopup!, elPopupOpener: popup.el });\n};\n\nconst vueConnector = {\n\tonOpen,\n\tonClose,\n\tclassRef: toRef(props, 'class'),\n\topened: false,\n\tpopup: undefined as TopLibPopup | undefined,\n\ttransitionDurationRef: toRef(props, 'transitionDuration'),\n};\n\nwatch(() => props.class, (newValue, oldValue) => {\n\tif (!elPopupRef.value) return;\n\n\tconst newClasses = newValue?.split(' ') ?? [];\n\tconst oldClasses = oldValue?.split(' ') ?? [];\n\n\tconst delClasses = oldClasses.filter((oldClass) => !newClasses.includes(oldClass));\n\n\telPopupRef.value.classList.remove(...delClasses);\n\telPopupRef.value.classList.add(...newClasses);\n});\n\nWorker.regVueComponent(id, vueConnector);\n\nonUnmounted(() => {\n\tWorker.unregVueComponent(id);\n});\n</script>\n\n<template>\n\t<Opener\n\t\tv-if=\"$slots.opener\"\n\t\t:id=\"id\"\n\t\t:pos=\"pos\"\n\t\t:posBy=\"posBy\"\n\t\t:notch=\"notch\"\n\t\t:openByHover=\"openByHover\"\n\t>\n\t\t<!-- @slot элемент для открытия Popup -->\n\t\t<slot name=\"opener\"></slot>\n\t</Opener>\n\n\t<!-- Это шаблон для компонента Popup, сам Popup генерируется в js и может находиться где угодно -->\n\t<!-- elPopupInnerRef будет установлен только после открытия и будет сброшен сразу после закрытия Popup -->\n\t<teleport\n\t\tv-if=\"elPopupInnerRef\"\n\t\t:to=\"elPopupInnerRef\"\n\t>\n\t\t<div\n\t\t\tv-if=\"$slots.header || $core.state.isMobile\"\n\t\t\tclass=\"top-popup_header\"\n\t\t>\n\t\t\t<span\n\t\t\t\tv-if=\"$core.state.isMobile\"\n\t\t\t\tclass=\"top-as-a closer\"\n\t\t\t>\n\t\t\t\t{{ $i18n.Common.Close }}\n\t\t\t</span>\n\n\t\t\t<!-- @slot Шапка -->\n\t\t\t<slot name=\"header\"></slot>\n\t\t</div>\n\n\t\t<div\n\t\t\tv-if=\"$slots.widget\"\n\t\t\tclass=\"top-popup_widget\"\n\t\t>\n\t\t\t<!-- @slot Виджет -->\n\t\t\t<slot name=\"widget\"></slot>\n\t\t</div>\n\n\t\t<div\n\t\t\tv-if=\"$slots.content\"\n\t\t\tclass=\"top-popup_content\"\n\t\t\tv-top-scroll-shadow\n\t\t>\n\t\t\t<!-- @slot Контент в свободной форме -->\n\t\t\t<slot name=\"content\"></slot>\n\t\t</div>\n\n\t\t<ul\n\t\t\tv-if=\"$slots.contentList\"\n\t\t\tclass=\"top-popup_content\"\n\t\t\t@scroll=\"$emit('scrollContentList', $event)\"\n\t\t\tv-top-scroll-shadow\n\t\t>\n\t\t\t<!-- @slot Контент в виде списка, для вставки элементов списка используйте компонент popup/listItem -->\n\t\t\t<slot name=\"contentList\"></slot>\n\t\t</ul>\n\n\t\t<div\n\t\t\tv-if=\"$slots.footer || footerSupportLink\"\n\t\t\tclass=\"top-popup_footer\"\n\t\t>\n\t\t\t<a\n\t\t\t\tv-if=\"footerSupportLink\"\n\t\t\t\tclass=\"top-popup_footerSupportLink\"\n\t\t\t\t:href=\"footerSupportLink\"\n\t\t\t\ttarget=\"_blank\"\n\t\t\t>\n\t\t\t\t<TopHint hint=\"\"/>\n\t\t\t</a>\n\n\t\t\t<!-- @slot Футер -->\n\t\t\t<slot name=\"footer\"></slot>\n\t\t</div>\n\t</teleport>\n</template>\n\n<style>\n.top-popup_footerSupportLink {\n\tmargin-right: auto;\n}\n</style>\n","<script setup lang=\"ts\">\nimport type { ListItemProps } from './popup';\n\ndefineOptions({\n\tinheritAttrs: false,\n});\n\nconst props = withDefaults(defineProps<ListItemProps>(), {\n\ttype: 'button',\n\tcloseByClick: true,\n});\n</script>\n\n<template>\n\t<li\n\t\t:class=\"{\n\t\t'top-popup_liNoSelectable': props.type !== 'button'\n\t}\"\n\t>\n\t\t<component\n\t\t\t:is=\"$attrs.href ? 'a' : 'div'\"\n\t\t\t:class=\"{\n\t\t\t\t'top-popup_listItem': true,\n\t\t\t\t'top-popup_listItem-button': props.type === 'button', // оформления кнопки\n\t\t\t\t'a': props.type === 'button', // оформления кнопки, deprecated\n\t\t\t\t'top-popup_listItem-title': props.type === 'title',\n\t\t\t\t'top-popup_listItem-delimiter': props.type === 'delimiter',\n\t\t\t\t'top-popup-noCloser': !closeByClick\n\t\t\t}\"\n\t\t\t:=$attrs\n\t\t>\n\t\t\t<slot></slot>\n\t\t</component>\n\t</li>\n</template>\n"],"names":["props","__props","id","elOpener","render","el","renderOpener","onUpdated","elOpener2","emit","__emit","expose","__expose","elPopupRef","ref","elPopupInnerRef","vueConnector","popup","toRef","watch","newValue","oldValue","newClasses","delClasses","oldClass","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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACvCrE,UAAAA,IAAAC,GAOAQ,IAAAC,GAEAC,IAAA;AAAA,MAAe,OAAA;AAAA,IACP;AAER,IAAAC,EAAAD,CAAA;AAEA,UAAAT,IAAAF,EAAA,MAAA,kBAAA,KAAA,OAAA,GAEAa,IAAAC,EAAA,IAAA,GACAC,IAAAD,EAAA,IAAA,GA8BAE,IAAA;AAAA,MAAqB,QA3BrB,OAAAC,MAAA;AACC,QAAAA,EAAA,YAAAJ,EAAA,QAAAI,EAAA,UAEAA,EAAA,iBACCA,EAAA,aAAA,YAAA,IAEAF,EAAA,QAAAE,EAAA,eAGDD,EAAA,SAAA,IACAA,EAAA,QAAAC,GAEAN,EAAA,QAAAM,GAEAR,EAAA,QAAA,EAAA,SAAAQ,EAAA,SAAA,eAAAA,EAAA,GAAA,CAAA;AAAA,MAAiE;AAAA,MAcjE,SAVD,CAAAA,MAAA;AACC,QAAAF,EAAA,QAAA,MAEAC,EAAA,SAAA,IACAA,EAAA,QAAA,QAEAP,EAAA,SAAA,EAAA,SAAAQ,EAAA,SAAA,eAAAA,EAAA,GAAA,CAAA;AAAA,MAAkE;AAAA,MAKlE,UAAAC,EAAAlB,GAAA,OAAA;AAAA,MAC8B,QAAA;AAAA,MACtB,OAAA;AAAA,MACD,uBAAAkB,EAAAlB,GAAA,oBAAA;AAAA,IACiD;AAGzD,WAAAmB,EAAA,MAAAnB,EAAA,OAAA,CAAAoB,GAAAC,MAAA;AACC,UAAA,CAAAR,EAAA,MAAA;AAEA,YAAAS,KAAAF,KAAA,gBAAAA,EAAA,MAAA,SAAA,CAAA,GAGAG,MAFAF,KAAA,gBAAAA,EAAA,MAAA,SAAA,CAAA,GAEA,OAAA,CAAAG,MAAA,CAAAF,EAAA,SAAAE,CAAA,CAAA;AAEA,MAAAX,EAAA,MAAA,UAAA,OAAA,GAAAU,CAAA,GACAV,EAAA,MAAA,UAAA,IAAA,GAAAS,CAAA;AAAA,IAA4C,CAAA,GAG7CG,EAAA,gBAAAvB,GAAAc,CAAA,GAEAU,EAAA,MAAA;AACC,MAAAD,EAAA,kBAAAvB,CAAA;AAAA,IAA2B,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACxE5B,UAAAF,IAAAC;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"menu.vue_vue_type_style_index_0_lang-B5fkWPo5.es.js","sources":["../../src/components/formsExt/menu/menu.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { onMounted, onUpdated, ref } from 'vue';\nimport type { Item, Props } from './menu';\nimport Core from '@/core/core/core';\nimport { isSafari } from '@/core/utils/device';\nimport TopButton from '@/components/forms/button/button.vue';\n\nconst props = withDefaults(defineProps<Props>(), {\n\tstyling: 'default',\n});\n\nconst model = defineModel({\n\trequired: true,\n});\n\nconst el = ref();\n\n// валидация типа modelValue без возможности выбора нескольких значений (ожидается строка)\nif (!props.isMultiple && !(typeof (model.value) === 'string' || model.value instanceof String)) {\n\tconsole.warn('Type check failed for prop \"modelValue\". Expected String: ' + typeof (model.value));\n}\n\n// валидация типа modelValue с возможностью выбора нескольких значений (ожидается массив)\nif (props.isMultiple && !Array.isArray(model.value)) {\n\tconsole.warn('Type check failed for prop \"modelValue\". Expected Array: ' + typeof (model.value));\n}\n\n// для множественного выбора без пустого множества\n// если ничего не выбрано, присваиваем 1-ое значение\nif (props.isMultiple && !props.canBeEmptyMultiple && Array.isArray(model.value) && !model.value.length) {\n\tmodel.value = [props.items[0].href ?? props.items[0].value];\n}\n\nconst itemIsActive = (item: Item) => {\n\tif (!Array.isArray(model.value)) {\n\t\treturn item.value === model.value;\n\t}\n\n\treturn model.value.includes(item.value);\n};\n\n/**\n * Выбрать элемент\n * @param item\n * @param toggle - добавить или исключить элемент, для isMultiple\n */\nconst select = (item: Item, toggle = false) => {\n\tif (Array.isArray(model.value)) {\n\t\tlet modelNew = model.value.slice();\n\n\t\tif (toggle) {\n\t\t\tif (!modelNew.length) modelNew = props.items.map(item => item.value);\n\n\t\t\tconst index = modelNew.indexOf(item.value);\n\t\t\tif (index === -1) {\n\t\t\t\tmodelNew.push(item.value);\n\t\t\t} else {\n\t\t\t\tmodelNew.splice(index, 1);\n\t\t\t}\n\t\t} else {\n\t\t\tif (modelNew.length === 1 && modelNew[0] === item.value) {\n\t\t\t\tmodelNew = [];\n\t\t\t} else {\n\t\t\t\tmodelNew = [item.value];\n\t\t\t}\n\t\t}\n\n\t\tif (!props.canBeEmptyMultiple && !modelNew.length) modelNew = [item.value];\n\n\t\tmodel.value = modelNew;\n\n\t\treturn;\n\t}\n\n\tmodel.value = item.value;\n};\n\n// вертикальный скролл в горизонтальный скролл\nconst onWheel = (event: WheelEvent) => {\n\tif (el.value.scrollWidth <= el.value.offsetWidth) return;\n\tif (event.shiftKey) return;\n\tif (Math.abs(event.deltaY) < 50) return; // устройство с высокой точностью, например тачпад\n\n\tevent.preventDefault();\n\n\tconst delta = event.deltaY > 0 ? 30 : -30;\n\tel.value.scrollLeft = el.value.scrollLeft + delta;\n};\n\n/**\n * Замена стандартному scrollIntoView, который меняет скролл документа\n *\n * Выравнивание по ближнему краю элемента\n *\n * Выравнивается таким образом, чтобы был виден соседний элемент\n */\nconst scrollIntoView = (isSmooth = true) => {\n\tconst elBtn = el.value.querySelector('.top-active');\n\tif (!elBtn) return;\n\n\tconst gap = 24;\n\n\t// левая и правая координаты элемента\n\tconst leftMargin = elBtn.offsetLeft - el.value.offsetLeft - gap;\n\tconst rightMargin = elBtn.offsetLeft - el.value.offsetLeft + elBtn.clientWidth + gap;\n\n\t// левая и правая границы видимой части меню\n\tconst leftMarginParent = el.value.scrollLeft;\n\tconst rightMarginParent = el.value.clientWidth + el.value.scrollLeft;\n\n\tlet scrollLeft: number | undefined = undefined;\n\n\t// левую границу элемента к левой границе меню\n\tif (leftMargin < leftMarginParent) scrollLeft = leftMargin;\n\n\t// правую границу элемента к правой границе меню\n\tif (rightMargin > rightMarginParent) scrollLeft = rightMargin - el.value.clientWidth;\n\n\tif (scrollLeft !== undefined) {\n\t\tif (isSafari()) {\n\t\t\tCore.$?.(el.value).animate({ scrollLeft: scrollLeft }, isSmooth ? 200 : 0);\n\t\t} else {\n\t\t\tel.value.scrollTo({ left: scrollLeft, behavior: isSmooth ? 'smooth' : 'auto' });\n\t\t}\n\t}\n};\n\n/**\n * Выбрать все элементы в меню\n */\nconst selectAll = () => {\n\tif (!Array.isArray(model.value)) return;\n\n\tif (model.value.length === props.items.length) {\n\t\tmodel.value = [props.items[0].href ?? props.items[0].value];\n\t\treturn;\n\t}\n\n\tmodel.value = props.items.map(item => item.href ?? item.value);\n};\n\nonMounted(() => scrollIntoView(false));\nonUpdated(() => scrollIntoView(true));\n\n</script>\n\n<template>\n\t<div\n\t\tref=\"el\"\n\t\t:class=\"{\n\t\t\t'top-menu': true,\n\t\t\t['top-style_' + styling]: true,\n\t\t\t// ['top-unwrap-x']: styling === 'default',\n\t\t}\"\n\t\t@wheel=\"onWheel\"\n\t>\n\t\t<TopButton\n\t\t\tv-for=\"item in items\"\n\t\t\t:=\"item\"\n\t\t\tclass=\"top-menu_item\"\n\t\t\tcolor=\"theme\"\n\t\t\t@click=\"select(item, $event.ctrlKey || $event.metaKey)\"\n\t\t\t:isActive=\"itemIsActive(item)\"\n\t\t>\n\t\t\t<template #default v-if=\"item.content\">\n\t\t\t\t{{ item.content }}\n\t\t\t</template>\n\t\t</TopButton>\n\n\t\t<div\n\t\t\tv-if=\"Array.isArray(model) && selectAllItem\"\n\t\t\tclass=\"top-menu_selectAll\"\n\t\t>\n\t\t\t<TopButton\n\t\t\t\t:=\"selectAllItem\"\n\t\t\t\tclass=\"top-menu_item\"\n\t\t\t\tcolor=\"theme\"\n\t\t\t\tstyling=\"\"\n\t\t\t\t@click=\"selectAll()\"\n\t\t\t\t:isActive=\"model.length === items.length\"\n\t\t\t>\n\t\t\t\t<template #default v-if=\"selectAllItem.content\">\n\t\t\t\t\t{{ selectAllItem.content }}\n\t\t\t\t</template>\n\t\t\t</TopButton>\n\t\t</div>\n\t</div>\n</template>\n\n<style>\n.top-menu {\n\t--scroll-thumb-color: var(--color-line-1);\n\t--scroll-thumb-color-hover: var(--color-line-2);\n\t--scroll-thumb-color-active: var(--color-line-3);\n\n\tmax-width: 100%;\n\tdisplay: flex;\n\talign-items: flex-start;\n\tgap: var(--top-gap-2);\n\toverflow-x: auto;\n\tscrollbar-width: none; /* firefox */\n\n\t/* предотвратить натинвые события браузера (назад / вперед) */\n\toverscroll-behavior-x: contain;\n}\n\n.top-menu::-webkit-scrollbar { display: none; }\n\n.top-menu .top-menu_item {\n\t--top-button-color: var(--color-text-2);\n\n\toutline-offset: -2px !important;\n\tmin-width: 0;\n\tmax-width: 200px;\n\tmargin: 0;\n\tflex-shrink: 0;\n}\n\n.top-menu .top-menu_item[data-top-icon] {\n\t--top-icon-color: var(--color-text-2);\n}\n\n.top-menu_selectAll {\n\tposition: sticky;\n\tright: 0;\n\tbackground: var(--color-layout-front-1);\n\tborder-left: 1px solid var(--color-line-1);\n\tpadding-left: var(--top-padding-1);\n\tbox-shadow: var(--color-layout-front-1) var(--top-padding-2) 0px;\n}\n\n/* style default */\n.top-menu.top-style_default .top-menu_item {\n\t--top-forms-radius: 0;\n\t--top-forms-border-color: transparent;\n\t--top-forms-border-width: 2px;\n\n\tfilter: none;\n\tbox-shadow: none;\n\tborder: none;\n\tborder-bottom: var(--top-forms-border-width) solid var(--top-forms-border-color);\n\tbackground: none;\n}\n\n.top-style_default > .top-menu_item > [data-top-badge] {\n\tmargin-top: 0;\n}\n\n.top-menu.top-style_default .top-menu_item:hover {\n\t--top-icon-color: var(--color-text-1);\n\t--top-button-color: var(--color-text-1);\n\t--top-forms-border-color: var(--color-line-2);\n}\n\n.top-menu.top-style_default .top-menu_item:active,\n.top-menu.top-style_default .top-menu_item.top-active {\n\t--top-icon-color: var(--color-text-primary);\n\t--top-button-color: var(--color-text-1);\n\t--top-forms-border-color: var(--color-line-primary-1);\n}\n\n.top-menu.top-style_default .top-menu_selectAll {\n\tpadding-left: var(--top-padding-2);\n}\n\n/* style bar */\n.top-menu.top-style_bar {\n\tborder-radius: var(--top-radius-3);\n\tborder: 1px solid var(--color-line-2);\n\tpadding: var(--top-padding-1);\n\tgap: 3px;\n}\n.top-menu.top-style_bar .top-menu_item {\n\t--top-button-background-color-hover: var(--color-layer-1);\n\t--top-button-background-color-active: var(--color-layer-2);\n\t--top-button-background-color-selected: var(--color-layer-primary-1);\n\n\tposition: relative;\n}\n\n.top-menu.top-style_bar .top-menu_item:hover {\n\t--top-icon-color: var(--color-text-1);\n\t--top-button-color: var(--color-text-1);\n}\n\n.top-menu.top-style_bar .top-menu_item.top-active {\n\t--top-icon-color: var(--color-text-primary);\n\t--top-button-color: var(--color-text-primary);\n}\n\n/* разделители кнопок в баре */\n.top-menu.top-style_bar .top-menu_item:not(:first-child):not(.top-active):not(:hover):after {\n\tcontent: \"\";\n\tbackground: var(--color-line-1-opacity);\n\twidth: 1px;\n\theight: 60%;\n\tdisplay: block;\n\tposition: absolute;\n\tleft: -2px;\n}\n.top-menu.top-style_bar .top-menu_item.top-active + .top-menu_item:after,\n.top-menu.top-style_bar .top-menu_item:hover + .top-menu_item:after {\n\tcontent: none !important;\n}\n\n/*\n.top-style_bar > .top-menu_item > [data-top-badge] {\n\tmargin-top: -3px;\n}\n*/\n\n/** TODO: .top-unwrap-x надо вынести глобально в UI или добавить в стили для storybook */\n/*\n.top-menu.top-unwrap-x {\n\tpadding-right: var(--top-unwrap-x);\n\tpadding-left: var(--top-unwrap-x);\n\tmargin-right: calc(0px - var(--top-unwrap-x));\n\tmargin-left: calc(0px - var(--top-unwrap-x));\n}\n*/\n</style>\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":"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"}
@@ -1,2 +0,0 @@
1
- define(["require","exports","vue","./forms-CKYHAaPQ.amd","../popup/worker.amd","../utils/system.amd","../utils/route.amd","../utils/scroll.amd","./dialogs.vue_vue_type_script_setup_true_lang-CXtBj2Ah.amd","../utils/dom.amd"],function(J,b,g,p,E,x,_,O,l,k){"use strict";if(typeof g>"u")var g=window.Vue;$;let P=!1;const j=()=>{P||(P=!0,document.addEventListener("keydown",e=>{if(e.key!=="Escape"||!e.target)return;const t=e.target;t.closest(".ui-dialog")&&(t.contentEditable==="true"||t.contentEditable==="plaintext-only"||k.querySelectorVisible(document.documentElement,".top-popup-wrapper")||t.classList.contains("autocomplete")||k.querySelectorVisible(document.documentElement,".fancybox-container")||$(".ui-dialog-content:visible:last").dialog("close"))}),$(document).on("click",'[data-action="top-dialog-close"]',e=>{e.preventDefault();const t=e.target.closest('[data-action="top-dialog-close"]'),o=t.closest(".ui-dialog-content");if(!o)return;const i=$(o),a=t.dataset.toView;if(a=="toPrevPage()"){m.toPrevPage(i);return}if(a){const n=a.split("-"),r=n.shift(),d=n.join("-"),s=$("#"+r);if(!$('[data-view-page="'+d+'"]',s).is(":visible")){const G=l.TopDialogWorker.genViewPageHash(a,"prev");_.historySetState(!1,G);return}}i.dialog("close")}),$(document).on("submit",".modal-body > form, .modal-layer-body > form",function(e){e.preventDefault()}),$(document).on("keypress",".ui-dialog .modal-body :input:not(.searcher), .ui-dialog .modal-body [contenteditable]",function(e){if(e.key==="ENTER"){if(e.target.classList.contains("autocomplete")){e.preventDefault();return}if(e.target.tagName==="TEXTAREA"){if(!e.ctrlKey&&!e.metaKey)return;const t=e.target.closest("form");if(t){let o=$(":submit:visible",t)[0];o||(o=$(":submit:visible",t)[0]),o==null||o.click()}}}}),$(document).on("click",".ui-widget-overlay",function(){let e,t=0;$(".ui-dialog:visible").each((o,i)=>{const a=Number($(i).css("z-index"));a<t||(e=$(i),t=a)}),e&&$(".ui-dialog-content",e).dialog("close")}),$(window).on("resize",m.recalcPositions),m.recalcPositions())},A=':root{--dialog-border-color: var(--color-line-1);--dialog-loading-duration: 10s;--top-dialog-footer-height: var(--top-forms-base-height_s)}html.with_dialog{overflow:hidden!important}a[data-to-view]{cursor:pointer}.ui-widget-overlay{background:#040404;opacity:.5;filter:Alpha(Opacity=50)}.ui-dialog{border-radius:8px;border:none;padding:0}.ui-dialog.ui-widget{border:none}.ui-dialog-titlebar{display:none}.ui-dialog .ui-dialog-content{padding:0;overflow:visible}.ui-dialog .project_name{word-break:break-all}.ui-dialog-content{--dialog-header-height: 50px;--dialog-layer-pageSelector: 0px}.ui-dialog-content-withPageSelector{--dialog-layer-pageSelector: 42px}.modal-header,.modal-body,.modal-footer{font-size:14px;position:relative}.modal-body{padding:var(--padding-default)}.modal-header{border-bottom:1px solid var(--dialog-border-color);height:var(--dialog-header-height);padding:0 var(--padding-default);display:flex;justify-content:space-between;align-items:center;gap:16px}.modal-header>*{padding:10px 0;font-size:16px}.modal-header>.top-title{margin:0;font-weight:400;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-grow:1;order:50;display:flex;align-items:center}.modal-header>.top-title>div[class*=icon]{display:none}.modal-header>div:not(.top-title){order:60}.modal-header>div.close{--top-icon-color: var(--color-text-3);cursor:pointer;background:var(--color-layout-front-1);font-size:16px;order:100;animation-name:none!important}.modal-header>div.close:hover{--top-icon-color: var(--color-text-1)}.modal-header .links_icons{position:absolute;right:50px}.modal-header .links_icons [class*=icon-]{width:auto;height:auto;padding:0 5px;color:#d6dee0}.modal-header .links_icons [class*=icon-].active{color:var(--color-bg-warning-1)}.modal-layer-pageSelector{padding:0 10px!important}.modal-body{max-height:calc(var(--100vh) - var(--dialog-header-height) - 1px - var(--dialog-layer-pageSelector) - var(--top-dialog-footer-height) - 1px);overflow-y:auto;overflow-x:hidden;box-sizing:border-box;flex-grow:1}.modal-body hr{margin:16px -15px}.modal-body h4{padding:0;margin:0 0 10px;line-height:normal}.modal-body .inner{padding:var(--padding-default);margin:0 calc(0px - var(--padding-default));position:relative}.modal-body .inner .bt{border-top:1px dashed var(--color-layout-front-primary-3);position:absolute;top:0;right:0;left:0}.modal-body .inner .bb{border-bottom:1px dashed var(--color-layout-front-primary-3);position:absolute;right:0;bottom:0;left:0}.modal-body .inner.color-1{background:var(--color-layout-front-primary-3);color:var(--color-text-1)}.modal-body .inner strong{color:var(--color-text-1)}.modal-body .comment{line-height:18px}.modal-footer{min-height:var(--top-dialog-footer-height);padding:var(--top-gap-2);display:flex;flex-shrink:0;align-items:center;justify-content:flex-end;gap:var(--top-gap-2)}.modal-footer .modal-footer-btn-left{margin-right:auto}.modal-footer>.btn.full_width,.modal-footer>.top-button.full_width{flex-grow:1;align-self:flex-end}.modal-footer-fullWith{flex-wrap:wrap}.modal-footer-fullWith>*{flex-grow:1}.modal-footer-fullWith>.top-info{flex-grow:5}.modal-footer-fullWith>*:empty{flex-grow:0}.ui-dialog-content>.modal-layer>[data-view-page]>input[type=submit]{position:absolute;visibility:hidden}.help_popup .modal-header{display:none}.help_popup .modal-header a{top:2px;z-index:10}.help_popup .modal-header .top-title{display:none}.modal-layer{overflow:hidden}.modal-layer a[data-top-icon]:empty{color:var(--color-text-4);text-decoration:none}.modal-layer>[data-view-page]>div>div.buttons{display:flex;white-space:nowrap}.modal-layer>[data-view-page]>div>div.buttons:empty{display:none}.modal-layer>[data-view-page]>div>div.buttons>div,.modal-layer>[data-view-page]>div>div.buttons>a{cursor:pointer;width:auto;height:auto;min-width:auto;min-height:auto;padding:10px 9px;color:var(--color-text-4)}.modal-layer>[data-view-page]>div>div.buttons>div:hover{color:var(--color-text-2)}.modal-layer>[data-view-page]>div>div.buttons>div.hidden{display:none!important}.ui-dialog-content[data-view-page-active]{display:flex!important;flex-direction:column;justify-items:stretch}.ui-dialog-content>.modal-layer{display:flex!important;align-items:stretch;position:relative}.ui-dialog-content.i-change-page>.modal-layer{overflow:hidden}.ui-dialog-content>.modal-layer>[data-view-page]{width:100%;position:relative;display:none;flex-direction:column;justify-content:space-between;animation:.3s cubic-bezier(.4,0,.2,1) forwards}.ui-dialog-content>.modal-layer>[data-view-page].active{display:flex}.ui-dialog-content>.modal-layer>[data-view-page].reverse{animation-direction:reverse}.ui-dialog-content>.modal-layer>[data-view-page].center-to-left,.ui-dialog-content>.modal-layer>[data-view-page].right-to-center{display:flex;position:absolute;inset:0}.ui-dialog-content>.modal-layer>[data-view-page].center-to-left>div,.ui-dialog-content>.modal-layer>[data-view-page].right-to-center>div{overflow:hidden}.ui-dialog-content>.modal-layer-header{border-bottom:1px solid var(--dialog-border-color);min-height:var(--dialog-header-height)}.ui-dialog-content>.modal-layer-header>[data-view-page]>.modal-header{border:none;background:none}.ui-dialog-content>.modal-layer-header>[data-view-page]>.modal-header>*{animation:.3s cubic-bezier(.4,0,.2,1) forwards}.ui-dialog-content>.modal-layer-header>[data-view-page].reverse>.modal-header>*{animation-direction:reverse}.ui-dialog-content>.modal-layer-header>[data-view-page].center-to-left>.modal-header>.top-title{animation-name:dialog-center-to-left-header-title}.ui-dialog-content>.modal-layer-header>[data-view-page].right-to-center>.modal-header>.top-title{animation-name:dialog-right-to-center-header-title}.ui-dialog-content>.modal-layer-header>[data-view-page].center-to-left>.modal-header>[class*=widget-]{animation-name:dialog-center-to-left-header-title}.ui-dialog-content>.modal-layer-header>[data-view-page].right-to-center>.modal-header>[class*=widget-]{animation-name:dialog-right-to-center-header-title}.ui-dialog-content>.modal-layer-header>[data-view-page].center-to-left>.modal-header>div{animation-name:dialog-center-to-left-header-icons}.ui-dialog-content>.modal-layer-header>[data-view-page].right-to-center>.modal-header>div{animation-name:dialog-right-to-center-header-icons}.ui-dialog-content>.modal-layer-body{border-radius:0 0 8px 8px;max-height:calc(var(--100vh) - var(--dialog-header-height) - var(--dialog-layer-pageSelector) - var(--toolbar-height));flex-grow:2}.ui-dialog-content.i-change-page>.modal-layer-body>[data-view-page]{background:var(--color-layout-front-1)}.ui-dialog-content>.modal-layer-body>[data-view-page].center-to-left{animation-name:dialog-center-to-left}.ui-dialog-content>.modal-layer-body>[data-view-page].right-to-center{animation-name:dialog-right-to-center}.ui-dialog-content .modal-footer .second_level{box-sizing:border-box;background:var(--color-layout-front-1);width:100%;min-height:25px;display:flex;align-items:center;justify-content:center}.ui-dialog-content .modal-footer .second_level input{border-radius:8px;width:100%;height:var(--top-forms-base-height);padding:var(--top-padding-1) var(--top-padding-3);box-sizing:border-box}.ui-dialog-content>.modal-layer-body>[data-view-page].i-load-data{pointer-events:none}.ui-dialog-content>.modal-layer-body>[data-view-page].i-load-data:before{content:" ";background:#378dc6;width:0;height:4px;position:absolute;top:0;left:0;z-index:100;animation:top-loadbar var(--dialog-loading-duration) forwards}.ui-dialog-content.modal-expanded{width:100vw!important;height:calc(var(--100vh) + 10px)!important}.modal-header>[data-widget]{padding:0 8px;position:absolute;inset:0;opacity:0;overflow:hidden;align-items:center;visibility:hidden;transition:opacity .3s;z-index:1}.modal-header>[data-widget=search] div.cancel{opacity:0;transform:translate(100%);transition:transform,opacity;transition-duration:.3s}[data-view-page].i-show-search .modal-header>:not([data-widget=search]){visibility:hidden}[data-view-page].i-show-search [data-widget=search]{visibility:visible;opacity:1}[data-view-page].i-show-search [data-widget=search] .cancel{transform:translate(0);opacity:1}[data-view-page]>.modal-header>*{transition:opacity .3s}[data-view-page].i-show-search>.modal-header>div.buttons{opacity:0}.modal-layer .top-popup-wrapper{height:100%!important}@keyframes dialog-center-to-left-header-title{0%{transform:translate(0);opacity:1}75%{opacity:0}to{transform:translate(-30%);opacity:0}}@keyframes dialog-right-to-center-header-title{0%{transform:translate(100%);opacity:0}25%{opacity:0}to{transform:translate(0);opacity:1}}@keyframes dialog-center-to-left-header-icons{0%{transform:translate(0);opacity:1}35%{transform:translate(-20%);opacity:0}to{transform:translate(-20%);opacity:0}}@keyframes dialog-right-to-center-header-icons{0%{transform:translate(20%);opacity:0}65%{transform:translate(20%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes dialog-center-to-left{0%{transform:translate(0);filter:brightness(1)}to{transform:translate(-30%);filter:brightness(.9)}}@keyframes dialog-right-to-center{0%{transform:translate(100%);box-shadow:#0000001a 0 0 10px}to{transform:translate(0);box-shadow:#0003 0 0 10px}}@media only screen and (max-width: 1480px){.win_side_panel_opener{display:none}}@media only screen and (min-width: 1480px){.ui-dialog-content.with_side_panel{box-shadow:#0003 0 0 6px}.ui-dialog-content.with_side_panel .modal-layer-body{background:var(--color-layout-front-1)}[data-widget=side_panel]{--side_panel_width: calc((100vw - 900px)/2 - 28px) ;box-sizing:border-box;background:var(--color-layout-front-1);max-width:var(--side_panel_width);padding:18px;position:absolute;top:calc(var(--dialog-header-height) + 1px + var(--dialog-layer-pageSelector));bottom:calc(var(--top-dialog-footer-height) + 1px);z-index:-1;display:block;transition:.2s}.win_side_panel_left{border-radius:8px 0 0 8px;right:100%}.win_side_panel_right{border-radius:0 8px 8px 0;left:100%}.win_side_panel_closed.win_side_panel_left{right:calc(100% - var(--side_panel_width))}.win_side_panel_closed.win_side_panel_right{left:calc(100% - var(--side_panel_width))}[data-widget=side_panel] .template{display:block}[data-widget=side_panel] .template>.header,[data-widget=side_panel] .template>.footer{display:flex}.win_side_panel_opener{cursor:pointer;background:var(--color-cyan);color:#fff;padding:4px;position:absolute;top:20px}.win_side_panel_closed .win_side_panel_opener:not(:hover){opacity:.3}.win_side_panel_left .win_side_panel_opener{border-radius:4px 0 0 4px;right:100%}.win_side_panel_right .win_side_panel_opener{border-radius:0 6px 6px 0;left:100%}}@media only screen and (max-height: 900px){html.with_dialog{background:#f1f1f1;overflow:hidden}.ui-dialog.me-tightly{border-radius:0;height:auto!important;position:fixed;top:0!important;bottom:0!important}.ui-dialog.me-tightly .ui-dialog-content{min-height:100%!important}.ui-dialog.me-tightly>div>.modal-body{position:absolute;top:var(--dialog-header-height);right:0;left:0;bottom:var(--dialog-header-height)}.ui-dialog.me-tightly>div>.modal-body:last-child{bottom:0}.ui-dialog.me-tightly>div>.modal-footer{position:absolute;right:0;bottom:0;left:0}.ui-dialog.me-tightly .modal-layer-body{border-radius:0;min-height:0!important}.ui-dialog.me-tightly .modal-layer-body .modal-footer{min-height:unset}}',L='html.with_dialog body{height:var(--100vh);overflow:hidden}.ui-widget-overlay{height:calc(100% - var(--toolbar-height))}.ui-dialog{border-radius:0;width:auto!important;height:auto!important;position:fixed;inset:0!important}.ui-dialog-content{width:100%!important;height:100%!important;min-width:0!important;max-width:100%!important}.modal-header>.top-title{text-align:center;font-size:14px}.modal-header>div.close{font-size:14px;order:1}.modal-header>div.close:before{content:""}.modal-body:last-child{bottom:0}.modal-footer{bottom:0}.modal-footer .second_level{padding:10px 8px}.modal-layer-body{min-height:0!important}.ui-dialog-content>.modal-layer-body{border-radius:0}.modal-body,.modal-footer{padding-right:12px;padding-left:12px}.modal-footer .btn:last-child{margin-right:12px}.modal-body .inner{padding:12px;margin:0 -12px;position:relative}',q=".modal-menu-opener{order:1!important}.modal-menu-opener:before{--top-icon-size: 20px;--top-icon-color: #FFF;--top-icon-width: var(--top-icon-size);border-radius:50%;background:var(--color-bg-primary-1);padding:3px;transition:transform .1s}.modal-menu-opener:hover:before{background:var(--color-bg-primary-2)}.modal-menu-opener.top-active:before{background:var(--color-bg-primary-2);transform:scale(.8)}.modal-layer .top-popup-wrapper{background:transparent;width:auto!important;padding:0!important;margin:0!important;top:0!important;right:0!important;left:0!important;transition:background .3s}.modal-layer .top-popup-wrapper>.top-popup[class],.modal-layer .top-popup-wrapper.with_notch>.top-popup[class]{border-radius:8px;border:none;margin:12px!important;max-width:100%;max-height:calc(100% - 24px);inset:0 0 auto!important;overflow:auto;display:flex;flex-direction:column;opacity:1;transform:translateY(calc(-100% - 24px));transition:transform .3s}.modal-layer .top-popup>.top-popup_header{background:var(--color-theme-50)}.modal-layer .top-theme-lite .top-popup>.top-popup_header .select{border:none}.modal-layer .top-theme-lite .top-popup>.top-popup_header .select .text{color:#fff}.modal-layer .top-theme-lite .top-popup>.top-popup_header .select .arrow{background:none}.modal-layer .top-popup-wrapper-shown:not(.top-popup-wrapper-closed){background:#34495e40}@media only screen and (min-width: 1480px){.ui-dialog-content.with_side_panel{box-shadow:#0003 0 0 6px}.ui-dialog-content.with_side_panel .modal-layer-body{background:var(--color-layout-front-1)}[data-widget=side_panel]{--side_panel_width: calc((100vw - 900px)/2 - 28px) ;box-sizing:border-box;background:var(--color-layout-front-1);max-width:var(--side_panel_width);padding:18px;display:block;position:absolute;top:51px;bottom:51px;z-index:-1;transition:.2s}.win_side_panel_left{border-radius:8px 0 0 8px;right:100%}.win_side_panel_right{border-radius:0 8px 8px 0;left:100%}.win_side_panel_closed.win_side_panel_left{right:calc(100% - var(--side_panel_width))}.win_side_panel_closed.win_side_panel_right{left:calc(100% - var(--side_panel_width))}[data-widget=side_panel] .template{display:block}[data-widget=side_panel] .template>.header,[data-widget=side_panel] .template>.footer{display:flex}.win_side_panel_opener{cursor:pointer;background:var(--color-cyan);color:#fff;padding:4px;position:absolute;top:20px}.win_side_panel_closed .win_side_panel_opener:not(:hover){opacity:.3}.win_side_panel_left .win_side_panel_opener{border-radius:4px 0 0 4px;right:100%}.win_side_panel_right .win_side_panel_opener{border-radius:0 6px 6px 0;left:100%}}",M="html{--top-dialog-width: auto;--top-dialog-height: auto}.top-dialog{max-width:100vw}.top-dialog .modal-layer-body{height:var(--top-dialog-height)}",D=".top-dialog{width:var(--top-dialog-width)!important}";p.Core.insertStyleToPage(A),p.Core.insertStyleToPage(L,"m"),p.Core.insertStyleToPage(q,"pc"),p.Core.insertStyleToPage(M),p.Core.insertStyleToPage(D,"pc");let T,u=!1;const B=()=>{$.extend($.ui.dialog.prototype.options,{focus:e=>{var t;e.target.focus(),(t=$("[autofocus]",e.target)[0])==null||t.focus()},create:e=>F(e.target),open:e=>I(e.target),close:e=>K(e.target),modal:!0,resizable:!1,closeOnEscape:!1,width:"auto",minHeight:0}),$.ui.dialog.prototype._focusTabbable=$.noop,$.ui.dialog.prototype._moveToTopOriginal=$.ui.dialog.prototype._moveToTop,$.ui.dialog.prototype._moveToTop=function(){this._moveToTopOriginal();const e=$(this.element);e.trigger("dialogsMoveToTop",[e])},j(),u=!0},C=e=>{var o,i,a,n;const t={};return((i=(o=e[0])==null?void 0:o.dataset)==null?void 0:i.modal)==="false"&&(t.modal=!1),(n=(a=e[0])==null?void 0:a.dataset)!=null&&n.position&&(t.position=JSON.parse(e[0].dataset.position)),t},h=async(e,t,o)=>{if(!e.startsWith("dialog_"))return;const i=l.getDialogWorker(e);if(i&&(i.isOpened.value=!0,t!==void 0&&(i.pageActive.value=t),o!==void 0&&(i.pageActiveNext.value=o),await g.nextTick(),o)){const a=$("#"+e);$('[data-view-page="'+o+'"]',a).length||await x.waitWhile(()=>!$('[data-view-page="'+o+'"]',a).length)}},F=e=>{var i,a;const t=$(e),o=$(".modal-body",t);O.connectScrollShadow(o[0]),(a=(i=l.TopDialogWorker.state).decoratorOnCreate)==null||a.call(i,e),H(e)},H=e=>{$(e).on("aftershow.top-menu-popup","[data-top-popup]",(t,o)=>{l.TopDialogWorker.get$pairPage(o).eq(1).prepend(o)})},I=async e=>{var d;const t=$(e),o=t.data("view-page-active"),i=Number($(window).width());p.Core.state.documentClassModificators.set("top-dialog","with_dialog");const n=Number($(window).width())-i;Number($(document).height())>Number($(window).height())&&$("html").css({"margin-right":n+"px"}),z();const r=l.getDialogWorker(t.attr("id"));(d=r==null?void 0:r.emit)==null||d.call(r,"open",o)},K=async e=>{var n;const t=$(e),o=t.attr("id"),i=t.data("view-page-active");if(i){const r={vpn:l.TopDialogWorker.state.viewPageN,["view-"+o]:null};r["view-"+o]=null,(l.TopDialogWorker.state.viewPageN===0||l.TopDialogWorker.state.viewPageN===1)&&(r.vpn=null),_.setHashs(r,!1)}$(".ui-widget-overlay:visible").length||(p.Core.state.documentClassModificators.delete("top-dialog"),$("html").css({"margin-right":""})),t.trigger("viewAfterClose",[t]);const a=l.getDialogWorker(t.attr("id"));a&&(a.isOpened.value=!1,(n=a.emit)==null||n.call(a,"close",i),a.onCloseOnce&&(a.onCloseOnce(a.props,i),a.onCloseOnce=void 0)),window.dispatchEvent(new Event("resize"))},z=()=>{$(".ui-dialog:visible > .ui-dialog-content").each((e,t)=>{const o=$(t),i=$(".modal-body:visible",o),a=o.closest(".ui-dialog");if(!i.length)return;const n=C(o);n.position??={of:window},o.dialog("option",n),a.removeClass("me-tightly"),Number(a.height())>Number($(window).height())&&a.addClass("me-tightly")})},R=async(e,t)=>{const i=/(\w+)[=-]([\w-]+)(?::([\w.:-]+))?/g.exec(e);if(i){const a=i[1],n=i[2],r=i[3];let d=[];r&&(d=r.split(":")),await f(a,n,d,t)}},f=async(e,t,o,i,a)=>{u||await new Promise((r,d)=>{const s=setInterval(()=>{u&&(clearInterval(s),r())},10)}),await g.nextTick();let n;if(typeof e=="object"?n=e:n=$("#"+e),!n.length&&typeof e=="string"&&l.TopDialogWorker.state.load){await l.TopDialogWorker.state.load(e),await f(e,t,o,i,a);return}if(await v(n,t,o,i),n.is(".ui-dialog-content"))n.dialog("open");else{const r=C(n);n.dialog(r)}a&&a(n)},v=async(e,t,o,i)=>{t===void 0&&(t=e.data("view-page-active")),t!=e.data("view-page-active")&&V(e)&&await x.sleep(100),o===void 0&&(o=[]),await h(e.attr("id"),void 0,t);const a=$("> .modal-layer",e),n=$("> .active",a),r=$('> [data-view-page="'+t+'"]',a),d=o.join(":");if(i===void 0&&(i="next",r.data("order")<n.data("order")&&(i="prev")),!!r.length){if(e.data("view-page-active",t),r.is(".active")){r.data("view-page-args")!=d&&r.data("view-page-args",d),S(e,r,t,o),y(e,r,t,o);return}switch(r.data("view-page-args",d),$(".top-popup-wrapper",n).length&&E.TopPopupWorker.close($(".top-popup-wrapper",n)[0]),r.closest(".ui-dialog").is(":hidden")&&(i="none"),n.length||(i="none"),r.is(":visible")&&(i="none"),i){case"prev":r.each((s,c)=>{$(c).insertBefore($(c).siblings(".active"))}),n.addClass("right-to-center reverse"),r.addClass("center-to-left reverse");break;case"next":r.each((s,c)=>{$(c).insertAfter($(c).siblings(".active"))}),n.addClass("center-to-left"),r.addClass("right-to-center");break}if(e.attr("view-page-active",t),n.removeClass("active"),r.addClass("active"),S(e,r,t,o),i){e.addClass("i-change-page");const s=Number(r.css("animation-duration").replace("s",""))*1e3;T=setTimeout(function(){h(e.attr("id"),t,""),V(e),y(e,r,t,o)},s)}else await h(e.attr("id"),t,""),y(e,r,t,o)}},U=e=>{const t=$("> .modal-layer",e),a=$("> .active",t).eq(0).prev("[data-view-page]").data("view-page");a?v(e,a,void 0,"prev"):e.dialog("close")},w=new Set,S=(e,t,o,i)=>{const a=e.attr("id")+t.eq(0).data("view-page")+o+i.join();w.has(a)||(w.add(a),setTimeout(function(){w.delete(a),e.trigger("viewBeforeOpen",[e,t,o,i])}))},y=(e,t,o,i)=>{setTimeout(function(){e.trigger("viewAfterOpen",[e,t,o,i])})},W=e=>e.is(".i-change-page"),V=e=>{if(!W(e))return!1;clearTimeout(T);const t=$("> .modal-layer",e),o=e.data("view-page-active");return e.removeClass("i-change-page"),$("> [data-view-page]",t).removeClass("center-to-left right-to-center reverse active"),$('> [data-view-page="'+o+'"]',t).addClass("active"),!0},m={updatePageVue:h,recalcPositions:z,toViewDirty:R,toView:f,toViewPage:v,toPrevPage:U,setLoading:(e,t,o)=>{e.is("[data-view-page]")||(e=$("[data-view-page]:visible",e)),t?(o!==void 0&&e.each((i,a)=>{a.style.setProperty("--dialog-loading-duration",o+"s")}),e.addClass("i-load-data")):(e.removeClass("i-load-data"),e.each((i,a)=>{a.style.setProperty("--dialog-loading-duration","10s")}))},isLoading:e=>e.is(".i-load-data"),inAnimation:W,close:function(e){const t=$("#"+e);t.dialog("instance")&&t.dialog("close")}};B(),b.TopDialogUtils=m,Object.defineProperty(b,Symbol.toStringTag,{value:"Module"})});
2
- //# sourceMappingURL=utils-BO3j538g.amd.js.map
@@ -1,227 +0,0 @@
1
- import { nextTick as P } from "vue";
2
- import { C as p } from "./forms-zDpk9gMK.es.js";
3
- import { TopPopupWorker as O } from "../popup/worker.js";
4
- import { sleep as V, waitWhile as A } from "../utils/system.js";
5
- import { historySetState as W, setHashs as j } from "../utils/route.js";
6
- import { connectScrollShadow as L } from "../utils/scroll.js";
7
- import { T as s, g as v } from "./dialogs.vue_vue_type_script_setup_true_lang-JyillkBh.es.js";
8
- import { querySelectorVisible as b } from "../utils/dom.js";
9
- $;
10
- let x = !1;
11
- const M = () => {
12
- x || (x = !0, document.addEventListener("keydown", (e) => {
13
- if (e.key !== "Escape" || !e.target) return;
14
- const t = e.target;
15
- t.closest(".ui-dialog") && (t.contentEditable === "true" || t.contentEditable === "plaintext-only" || b(document.documentElement, ".top-popup-wrapper") || t.classList.contains("autocomplete") || b(document.documentElement, ".fancybox-container") || $(".ui-dialog-content:visible:last").dialog("close"));
16
- }), $(document).on("click", '[data-action="top-dialog-close"]', (e) => {
17
- e.preventDefault();
18
- const t = e.target.closest('[data-action="top-dialog-close"]'), o = t.closest(".ui-dialog-content");
19
- if (!o) return;
20
- const i = $(o), a = t.dataset.toView;
21
- if (a == "toPrevPage()") {
22
- u.toPrevPage(i);
23
- return;
24
- }
25
- if (a) {
26
- const n = a.split("-"), r = n.shift(), d = n.join("-"), l = $("#" + r);
27
- if (!$('[data-view-page="' + d + '"]', l).is(":visible")) {
28
- const E = s.genViewPageHash(a, "prev");
29
- W(!1, E);
30
- return;
31
- }
32
- }
33
- i.dialog("close");
34
- }), $(document).on("submit", ".modal-body > form, .modal-layer-body > form", function(e) {
35
- e.preventDefault();
36
- }), $(document).on("keypress", ".ui-dialog .modal-body :input:not(.searcher), .ui-dialog .modal-body [contenteditable]", function(e) {
37
- if (e.key === "ENTER") {
38
- if (e.target.classList.contains("autocomplete")) {
39
- e.preventDefault();
40
- return;
41
- }
42
- if (e.target.tagName === "TEXTAREA") {
43
- if (!e.ctrlKey && !e.metaKey) return;
44
- const t = e.target.closest("form");
45
- if (t) {
46
- let o = $(":submit:visible", t)[0];
47
- o || (o = $(":submit:visible", t)[0]), o == null || o.click();
48
- }
49
- }
50
- }
51
- }), $(document).on("click", ".ui-widget-overlay", function() {
52
- let e, t = 0;
53
- $(".ui-dialog:visible").each((o, i) => {
54
- const a = Number($(i).css("z-index"));
55
- a < t || (e = $(i), t = a);
56
- }), e && $(".ui-dialog-content", e).dialog("close");
57
- }), $(window).on("resize", u.recalcPositions), u.recalcPositions());
58
- }, B = ':root{--dialog-border-color: var(--color-line-1);--dialog-loading-duration: 10s;--top-dialog-footer-height: var(--top-forms-base-height_s)}html.with_dialog{overflow:hidden!important}a[data-to-view]{cursor:pointer}.ui-widget-overlay{background:#040404;opacity:.5;filter:Alpha(Opacity=50)}.ui-dialog{border-radius:8px;border:none;padding:0}.ui-dialog.ui-widget{border:none}.ui-dialog-titlebar{display:none}.ui-dialog .ui-dialog-content{padding:0;overflow:visible}.ui-dialog .project_name{word-break:break-all}.ui-dialog-content{--dialog-header-height: 50px;--dialog-layer-pageSelector: 0px}.ui-dialog-content-withPageSelector{--dialog-layer-pageSelector: 42px}.modal-header,.modal-body,.modal-footer{font-size:14px;position:relative}.modal-body{padding:var(--padding-default)}.modal-header{border-bottom:1px solid var(--dialog-border-color);height:var(--dialog-header-height);padding:0 var(--padding-default);display:flex;justify-content:space-between;align-items:center;gap:16px}.modal-header>*{padding:10px 0;font-size:16px}.modal-header>.top-title{margin:0;font-weight:400;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-grow:1;order:50;display:flex;align-items:center}.modal-header>.top-title>div[class*=icon]{display:none}.modal-header>div:not(.top-title){order:60}.modal-header>div.close{--top-icon-color: var(--color-text-3);cursor:pointer;background:var(--color-layout-front-1);font-size:16px;order:100;animation-name:none!important}.modal-header>div.close:hover{--top-icon-color: var(--color-text-1)}.modal-header .links_icons{position:absolute;right:50px}.modal-header .links_icons [class*=icon-]{width:auto;height:auto;padding:0 5px;color:#d6dee0}.modal-header .links_icons [class*=icon-].active{color:var(--color-bg-warning-1)}.modal-layer-pageSelector{padding:0 10px!important}.modal-body{max-height:calc(var(--100vh) - var(--dialog-header-height) - 1px - var(--dialog-layer-pageSelector) - var(--top-dialog-footer-height) - 1px);overflow-y:auto;overflow-x:hidden;box-sizing:border-box;flex-grow:1}.modal-body hr{margin:16px -15px}.modal-body h4{padding:0;margin:0 0 10px;line-height:normal}.modal-body .inner{padding:var(--padding-default);margin:0 calc(0px - var(--padding-default));position:relative}.modal-body .inner .bt{border-top:1px dashed var(--color-layout-front-primary-3);position:absolute;top:0;right:0;left:0}.modal-body .inner .bb{border-bottom:1px dashed var(--color-layout-front-primary-3);position:absolute;right:0;bottom:0;left:0}.modal-body .inner.color-1{background:var(--color-layout-front-primary-3);color:var(--color-text-1)}.modal-body .inner strong{color:var(--color-text-1)}.modal-body .comment{line-height:18px}.modal-footer{min-height:var(--top-dialog-footer-height);padding:var(--top-gap-2);display:flex;flex-shrink:0;align-items:center;justify-content:flex-end;gap:var(--top-gap-2)}.modal-footer .modal-footer-btn-left{margin-right:auto}.modal-footer>.btn.full_width,.modal-footer>.top-button.full_width{flex-grow:1;align-self:flex-end}.modal-footer-fullWith{flex-wrap:wrap}.modal-footer-fullWith>*{flex-grow:1}.modal-footer-fullWith>.top-info{flex-grow:5}.modal-footer-fullWith>*:empty{flex-grow:0}.ui-dialog-content>.modal-layer>[data-view-page]>input[type=submit]{position:absolute;visibility:hidden}.help_popup .modal-header{display:none}.help_popup .modal-header a{top:2px;z-index:10}.help_popup .modal-header .top-title{display:none}.modal-layer{overflow:hidden}.modal-layer a[data-top-icon]:empty{color:var(--color-text-4);text-decoration:none}.modal-layer>[data-view-page]>div>div.buttons{display:flex;white-space:nowrap}.modal-layer>[data-view-page]>div>div.buttons:empty{display:none}.modal-layer>[data-view-page]>div>div.buttons>div,.modal-layer>[data-view-page]>div>div.buttons>a{cursor:pointer;width:auto;height:auto;min-width:auto;min-height:auto;padding:10px 9px;color:var(--color-text-4)}.modal-layer>[data-view-page]>div>div.buttons>div:hover{color:var(--color-text-2)}.modal-layer>[data-view-page]>div>div.buttons>div.hidden{display:none!important}.ui-dialog-content[data-view-page-active]{display:flex!important;flex-direction:column;justify-items:stretch}.ui-dialog-content>.modal-layer{display:flex!important;align-items:stretch;position:relative}.ui-dialog-content.i-change-page>.modal-layer{overflow:hidden}.ui-dialog-content>.modal-layer>[data-view-page]{width:100%;position:relative;display:none;flex-direction:column;justify-content:space-between;animation:.3s cubic-bezier(.4,0,.2,1) forwards}.ui-dialog-content>.modal-layer>[data-view-page].active{display:flex}.ui-dialog-content>.modal-layer>[data-view-page].reverse{animation-direction:reverse}.ui-dialog-content>.modal-layer>[data-view-page].center-to-left,.ui-dialog-content>.modal-layer>[data-view-page].right-to-center{display:flex;position:absolute;inset:0}.ui-dialog-content>.modal-layer>[data-view-page].center-to-left>div,.ui-dialog-content>.modal-layer>[data-view-page].right-to-center>div{overflow:hidden}.ui-dialog-content>.modal-layer-header{border-bottom:1px solid var(--dialog-border-color);min-height:var(--dialog-header-height)}.ui-dialog-content>.modal-layer-header>[data-view-page]>.modal-header{border:none;background:none}.ui-dialog-content>.modal-layer-header>[data-view-page]>.modal-header>*{animation:.3s cubic-bezier(.4,0,.2,1) forwards}.ui-dialog-content>.modal-layer-header>[data-view-page].reverse>.modal-header>*{animation-direction:reverse}.ui-dialog-content>.modal-layer-header>[data-view-page].center-to-left>.modal-header>.top-title{animation-name:dialog-center-to-left-header-title}.ui-dialog-content>.modal-layer-header>[data-view-page].right-to-center>.modal-header>.top-title{animation-name:dialog-right-to-center-header-title}.ui-dialog-content>.modal-layer-header>[data-view-page].center-to-left>.modal-header>[class*=widget-]{animation-name:dialog-center-to-left-header-title}.ui-dialog-content>.modal-layer-header>[data-view-page].right-to-center>.modal-header>[class*=widget-]{animation-name:dialog-right-to-center-header-title}.ui-dialog-content>.modal-layer-header>[data-view-page].center-to-left>.modal-header>div{animation-name:dialog-center-to-left-header-icons}.ui-dialog-content>.modal-layer-header>[data-view-page].right-to-center>.modal-header>div{animation-name:dialog-right-to-center-header-icons}.ui-dialog-content>.modal-layer-body{border-radius:0 0 8px 8px;max-height:calc(var(--100vh) - var(--dialog-header-height) - var(--dialog-layer-pageSelector) - var(--toolbar-height));flex-grow:2}.ui-dialog-content.i-change-page>.modal-layer-body>[data-view-page]{background:var(--color-layout-front-1)}.ui-dialog-content>.modal-layer-body>[data-view-page].center-to-left{animation-name:dialog-center-to-left}.ui-dialog-content>.modal-layer-body>[data-view-page].right-to-center{animation-name:dialog-right-to-center}.ui-dialog-content .modal-footer .second_level{box-sizing:border-box;background:var(--color-layout-front-1);width:100%;min-height:25px;display:flex;align-items:center;justify-content:center}.ui-dialog-content .modal-footer .second_level input{border-radius:8px;width:100%;height:var(--top-forms-base-height);padding:var(--top-padding-1) var(--top-padding-3);box-sizing:border-box}.ui-dialog-content>.modal-layer-body>[data-view-page].i-load-data{pointer-events:none}.ui-dialog-content>.modal-layer-body>[data-view-page].i-load-data:before{content:" ";background:#378dc6;width:0;height:4px;position:absolute;top:0;left:0;z-index:100;animation:top-loadbar var(--dialog-loading-duration) forwards}.ui-dialog-content.modal-expanded{width:100vw!important;height:calc(var(--100vh) + 10px)!important}.modal-header>[data-widget]{padding:0 8px;position:absolute;inset:0;opacity:0;overflow:hidden;align-items:center;visibility:hidden;transition:opacity .3s;z-index:1}.modal-header>[data-widget=search] div.cancel{opacity:0;transform:translate(100%);transition:transform,opacity;transition-duration:.3s}[data-view-page].i-show-search .modal-header>:not([data-widget=search]){visibility:hidden}[data-view-page].i-show-search [data-widget=search]{visibility:visible;opacity:1}[data-view-page].i-show-search [data-widget=search] .cancel{transform:translate(0);opacity:1}[data-view-page]>.modal-header>*{transition:opacity .3s}[data-view-page].i-show-search>.modal-header>div.buttons{opacity:0}.modal-layer .top-popup-wrapper{height:100%!important}@keyframes dialog-center-to-left-header-title{0%{transform:translate(0);opacity:1}75%{opacity:0}to{transform:translate(-30%);opacity:0}}@keyframes dialog-right-to-center-header-title{0%{transform:translate(100%);opacity:0}25%{opacity:0}to{transform:translate(0);opacity:1}}@keyframes dialog-center-to-left-header-icons{0%{transform:translate(0);opacity:1}35%{transform:translate(-20%);opacity:0}to{transform:translate(-20%);opacity:0}}@keyframes dialog-right-to-center-header-icons{0%{transform:translate(20%);opacity:0}65%{transform:translate(20%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes dialog-center-to-left{0%{transform:translate(0);filter:brightness(1)}to{transform:translate(-30%);filter:brightness(.9)}}@keyframes dialog-right-to-center{0%{transform:translate(100%);box-shadow:#0000001a 0 0 10px}to{transform:translate(0);box-shadow:#0003 0 0 10px}}@media only screen and (max-width: 1480px){.win_side_panel_opener{display:none}}@media only screen and (min-width: 1480px){.ui-dialog-content.with_side_panel{box-shadow:#0003 0 0 6px}.ui-dialog-content.with_side_panel .modal-layer-body{background:var(--color-layout-front-1)}[data-widget=side_panel]{--side_panel_width: calc((100vw - 900px)/2 - 28px) ;box-sizing:border-box;background:var(--color-layout-front-1);max-width:var(--side_panel_width);padding:18px;position:absolute;top:calc(var(--dialog-header-height) + 1px + var(--dialog-layer-pageSelector));bottom:calc(var(--top-dialog-footer-height) + 1px);z-index:-1;display:block;transition:.2s}.win_side_panel_left{border-radius:8px 0 0 8px;right:100%}.win_side_panel_right{border-radius:0 8px 8px 0;left:100%}.win_side_panel_closed.win_side_panel_left{right:calc(100% - var(--side_panel_width))}.win_side_panel_closed.win_side_panel_right{left:calc(100% - var(--side_panel_width))}[data-widget=side_panel] .template{display:block}[data-widget=side_panel] .template>.header,[data-widget=side_panel] .template>.footer{display:flex}.win_side_panel_opener{cursor:pointer;background:var(--color-cyan);color:#fff;padding:4px;position:absolute;top:20px}.win_side_panel_closed .win_side_panel_opener:not(:hover){opacity:.3}.win_side_panel_left .win_side_panel_opener{border-radius:4px 0 0 4px;right:100%}.win_side_panel_right .win_side_panel_opener{border-radius:0 6px 6px 0;left:100%}}@media only screen and (max-height: 900px){html.with_dialog{background:#f1f1f1;overflow:hidden}.ui-dialog.me-tightly{border-radius:0;height:auto!important;position:fixed;top:0!important;bottom:0!important}.ui-dialog.me-tightly .ui-dialog-content{min-height:100%!important}.ui-dialog.me-tightly>div>.modal-body{position:absolute;top:var(--dialog-header-height);right:0;left:0;bottom:var(--dialog-header-height)}.ui-dialog.me-tightly>div>.modal-body:last-child{bottom:0}.ui-dialog.me-tightly>div>.modal-footer{position:absolute;right:0;bottom:0;left:0}.ui-dialog.me-tightly .modal-layer-body{border-radius:0;min-height:0!important}.ui-dialog.me-tightly .modal-layer-body .modal-footer{min-height:unset}}', q = 'html.with_dialog body{height:var(--100vh);overflow:hidden}.ui-widget-overlay{height:calc(100% - var(--toolbar-height))}.ui-dialog{border-radius:0;width:auto!important;height:auto!important;position:fixed;inset:0!important}.ui-dialog-content{width:100%!important;height:100%!important;min-width:0!important;max-width:100%!important}.modal-header>.top-title{text-align:center;font-size:14px}.modal-header>div.close{font-size:14px;order:1}.modal-header>div.close:before{content:""}.modal-body:last-child{bottom:0}.modal-footer{bottom:0}.modal-footer .second_level{padding:10px 8px}.modal-layer-body{min-height:0!important}.ui-dialog-content>.modal-layer-body{border-radius:0}.modal-body,.modal-footer{padding-right:12px;padding-left:12px}.modal-footer .btn:last-child{margin-right:12px}.modal-body .inner{padding:12px;margin:0 -12px;position:relative}', F = ".modal-menu-opener{order:1!important}.modal-menu-opener:before{--top-icon-size: 20px;--top-icon-color: #FFF;--top-icon-width: var(--top-icon-size);border-radius:50%;background:var(--color-bg-primary-1);padding:3px;transition:transform .1s}.modal-menu-opener:hover:before{background:var(--color-bg-primary-2)}.modal-menu-opener.top-active:before{background:var(--color-bg-primary-2);transform:scale(.8)}.modal-layer .top-popup-wrapper{background:transparent;width:auto!important;padding:0!important;margin:0!important;top:0!important;right:0!important;left:0!important;transition:background .3s}.modal-layer .top-popup-wrapper>.top-popup[class],.modal-layer .top-popup-wrapper.with_notch>.top-popup[class]{border-radius:8px;border:none;margin:12px!important;max-width:100%;max-height:calc(100% - 24px);inset:0 0 auto!important;overflow:auto;display:flex;flex-direction:column;opacity:1;transform:translateY(calc(-100% - 24px));transition:transform .3s}.modal-layer .top-popup>.top-popup_header{background:var(--color-theme-50)}.modal-layer .top-theme-lite .top-popup>.top-popup_header .select{border:none}.modal-layer .top-theme-lite .top-popup>.top-popup_header .select .text{color:#fff}.modal-layer .top-theme-lite .top-popup>.top-popup_header .select .arrow{background:none}.modal-layer .top-popup-wrapper-shown:not(.top-popup-wrapper-closed){background:#34495e40}@media only screen and (min-width: 1480px){.ui-dialog-content.with_side_panel{box-shadow:#0003 0 0 6px}.ui-dialog-content.with_side_panel .modal-layer-body{background:var(--color-layout-front-1)}[data-widget=side_panel]{--side_panel_width: calc((100vw - 900px)/2 - 28px) ;box-sizing:border-box;background:var(--color-layout-front-1);max-width:var(--side_panel_width);padding:18px;display:block;position:absolute;top:51px;bottom:51px;z-index:-1;transition:.2s}.win_side_panel_left{border-radius:8px 0 0 8px;right:100%}.win_side_panel_right{border-radius:0 8px 8px 0;left:100%}.win_side_panel_closed.win_side_panel_left{right:calc(100% - var(--side_panel_width))}.win_side_panel_closed.win_side_panel_right{left:calc(100% - var(--side_panel_width))}[data-widget=side_panel] .template{display:block}[data-widget=side_panel] .template>.header,[data-widget=side_panel] .template>.footer{display:flex}.win_side_panel_opener{cursor:pointer;background:var(--color-cyan);color:#fff;padding:4px;position:absolute;top:20px}.win_side_panel_closed .win_side_panel_opener:not(:hover){opacity:.3}.win_side_panel_left .win_side_panel_opener{border-radius:4px 0 0 4px;right:100%}.win_side_panel_right .win_side_panel_opener{border-radius:0 6px 6px 0;left:100%}}", H = "html{--top-dialog-width: auto;--top-dialog-height: auto}.top-dialog{max-width:100vw}.top-dialog .modal-layer-body{height:var(--top-dialog-height)}", I = ".top-dialog{width:var(--top-dialog-width)!important}";
59
- p.insertStyleToPage(B);
60
- p.insertStyleToPage(q, "m");
61
- p.insertStyleToPage(F, "pc");
62
- p.insertStyleToPage(H);
63
- p.insertStyleToPage(I, "pc");
64
- let C, f = !1;
65
- const K = () => {
66
- $.extend($.ui.dialog.prototype.options, {
67
- focus: (e) => {
68
- var t;
69
- e.target.focus(), (t = $("[autofocus]", e.target)[0]) == null || t.focus();
70
- },
71
- create: (e) => R(e.target),
72
- open: (e) => J(e.target),
73
- close: (e) => U(e.target),
74
- modal: !0,
75
- resizable: !1,
76
- closeOnEscape: !1,
77
- width: "auto",
78
- minHeight: 0
79
- }), $.ui.dialog.prototype._focusTabbable = $.noop, $.ui.dialog.prototype._moveToTopOriginal = $.ui.dialog.prototype._moveToTop, $.ui.dialog.prototype._moveToTop = function() {
80
- this._moveToTopOriginal();
81
- const e = $(this.element);
82
- e.trigger("dialogsMoveToTop", [e]);
83
- }, M(), f = !0;
84
- }, T = (e) => {
85
- var o, i, a, n;
86
- const t = {};
87
- return ((i = (o = e[0]) == null ? void 0 : o.dataset) == null ? void 0 : i.modal) === "false" && (t.modal = !1), (n = (a = e[0]) == null ? void 0 : a.dataset) != null && n.position && (t.position = JSON.parse(e[0].dataset.position)), t;
88
- }, g = async (e, t, o) => {
89
- if (!e.startsWith("dialog_")) return;
90
- const i = v(e);
91
- if (i && (i.isOpened.value = !0, t !== void 0 && (i.pageActive.value = t), o !== void 0 && (i.pageActiveNext.value = o), await P(), o)) {
92
- const a = $("#" + e);
93
- $('[data-view-page="' + o + '"]', a).length || await A(() => !$('[data-view-page="' + o + '"]', a).length);
94
- }
95
- }, R = (e) => {
96
- var i, a;
97
- const t = $(e), o = $(".modal-body", t);
98
- L(o[0]), (a = (i = s.state).decoratorOnCreate) == null || a.call(i, e), G(e);
99
- }, G = (e) => {
100
- $(e).on("aftershow.top-menu-popup", "[data-top-popup]", (t, o) => {
101
- s.get$pairPage(o).eq(1).prepend(o);
102
- });
103
- }, J = async (e) => {
104
- var d;
105
- const t = $(e), o = t.data("view-page-active"), i = Number($(window).width());
106
- p.state.documentClassModificators.set("top-dialog", "with_dialog");
107
- const n = Number($(window).width()) - i;
108
- Number($(document).height()) > Number($(window).height()) && $("html").css({ "margin-right": n + "px" }), z();
109
- const r = v(t.attr("id"));
110
- (d = r == null ? void 0 : r.emit) == null || d.call(r, "open", o);
111
- }, U = async (e) => {
112
- var n;
113
- const t = $(e), o = t.attr("id"), i = t.data("view-page-active");
114
- if (i) {
115
- const r = {
116
- vpn: s.state.viewPageN,
117
- ["view-" + o]: null
118
- };
119
- r["view-" + o] = null, (s.state.viewPageN === 0 || s.state.viewPageN === 1) && (r.vpn = null), j(r, !1);
120
- }
121
- $(".ui-widget-overlay:visible").length || (p.state.documentClassModificators.delete("top-dialog"), $("html").css({ "margin-right": "" })), t.trigger("viewAfterClose", [t]);
122
- const a = v(t.attr("id"));
123
- a && (a.isOpened.value = !1, (n = a.emit) == null || n.call(a, "close", i), a.onCloseOnce && (a.onCloseOnce(a.props, i), a.onCloseOnce = void 0)), window.dispatchEvent(new Event("resize"));
124
- }, z = () => {
125
- $(".ui-dialog:visible > .ui-dialog-content").each((e, t) => {
126
- const o = $(t), i = $(".modal-body:visible", o), a = o.closest(".ui-dialog");
127
- if (!i.length) return;
128
- const n = T(o);
129
- n.position ??= { of: window }, o.dialog("option", n), a.removeClass("me-tightly"), Number(a.height()) > Number($(window).height()) && a.addClass("me-tightly");
130
- });
131
- }, X = async (e, t) => {
132
- const i = /(\w+)[=-]([\w-]+)(?::([\w.:-]+))?/g.exec(e);
133
- if (i) {
134
- const a = i[1], n = i[2], r = i[3];
135
- let d = [];
136
- r && (d = r.split(":")), await w(a, n, d, t);
137
- }
138
- }, w = async (e, t, o, i, a) => {
139
- f || await new Promise((r, d) => {
140
- const l = setInterval(() => {
141
- f && (clearInterval(l), r());
142
- }, 10);
143
- }), await P();
144
- let n;
145
- if (typeof e == "object" ? n = e : n = $("#" + e), !n.length && typeof e == "string" && s.state.load) {
146
- await s.state.load(e), await w(e, t, o, i, a);
147
- return;
148
- }
149
- if (await y(n, t, o, i), n.is(".ui-dialog-content"))
150
- n.dialog("open");
151
- else {
152
- const r = T(n);
153
- n.dialog(r);
154
- }
155
- a && a(n);
156
- }, y = async (e, t, o, i) => {
157
- t === void 0 && (t = e.data("view-page-active")), t != e.data("view-page-active") && k(e) && await V(100), o === void 0 && (o = []), await g(e.attr("id"), void 0, t);
158
- const a = $("> .modal-layer", e), n = $("> .active", a), r = $('> [data-view-page="' + t + '"]', a), d = o.join(":");
159
- if (i === void 0 && (i = "next", r.data("order") < n.data("order") && (i = "prev")), !!r.length) {
160
- if (e.data("view-page-active", t), r.is(".active")) {
161
- r.data("view-page-args") != d && r.data("view-page-args", d), _(e, r, t, o), h(e, r, t, o);
162
- return;
163
- }
164
- switch (r.data("view-page-args", d), $(".top-popup-wrapper", n).length && O.close($(".top-popup-wrapper", n)[0]), r.closest(".ui-dialog").is(":hidden") && (i = "none"), n.length || (i = "none"), r.is(":visible") && (i = "none"), i) {
165
- case "prev":
166
- r.each((l, c) => {
167
- $(c).insertBefore($(c).siblings(".active"));
168
- }), n.addClass("right-to-center reverse"), r.addClass("center-to-left reverse");
169
- break;
170
- case "next":
171
- r.each((l, c) => {
172
- $(c).insertAfter($(c).siblings(".active"));
173
- }), n.addClass("center-to-left"), r.addClass("right-to-center");
174
- break;
175
- }
176
- if (e.attr("view-page-active", t), n.removeClass("active"), r.addClass("active"), _(e, r, t, o), i) {
177
- e.addClass("i-change-page");
178
- const l = Number(r.css("animation-duration").replace("s", "")) * 1e3;
179
- C = setTimeout(function() {
180
- g(e.attr("id"), t, ""), k(e), h(e, r, t, o);
181
- }, l);
182
- } else
183
- await g(e.attr("id"), t, ""), h(e, r, t, o);
184
- }
185
- }, Y = (e) => {
186
- const t = $("> .modal-layer", e), a = $("> .active", t).eq(0).prev("[data-view-page]").data("view-page");
187
- a ? y(e, a, void 0, "prev") : e.dialog("close");
188
- }, m = /* @__PURE__ */ new Set(), _ = (e, t, o, i) => {
189
- const a = e.attr("id") + t.eq(0).data("view-page") + o + i.join();
190
- m.has(a) || (m.add(a), setTimeout(function() {
191
- m.delete(a), e.trigger("viewBeforeOpen", [e, t, o, i]);
192
- }));
193
- }, h = (e, t, o, i) => {
194
- setTimeout(function() {
195
- e.trigger("viewAfterOpen", [e, t, o, i]);
196
- });
197
- }, S = (e) => e.is(".i-change-page"), k = (e) => {
198
- if (!S(e)) return !1;
199
- clearTimeout(C);
200
- const t = $("> .modal-layer", e), o = e.data("view-page-active");
201
- return e.removeClass("i-change-page"), $("> [data-view-page]", t).removeClass("center-to-left right-to-center reverse active"), $('> [data-view-page="' + o + '"]', t).addClass("active"), !0;
202
- }, Z = function(e) {
203
- const t = $("#" + e);
204
- t.dialog("instance") && t.dialog("close");
205
- }, Q = (e, t, o) => {
206
- e.is("[data-view-page]") || (e = $("[data-view-page]:visible", e)), t ? (o !== void 0 && e.each((i, a) => {
207
- a.style.setProperty("--dialog-loading-duration", o + "s");
208
- }), e.addClass("i-load-data")) : (e.removeClass("i-load-data"), e.each((i, a) => {
209
- a.style.setProperty("--dialog-loading-duration", "10s");
210
- }));
211
- }, D = (e) => e.is(".i-load-data"), u = {
212
- updatePageVue: g,
213
- recalcPositions: z,
214
- toViewDirty: X,
215
- toView: w,
216
- toViewPage: y,
217
- toPrevPage: Y,
218
- setLoading: Q,
219
- isLoading: D,
220
- inAnimation: S,
221
- close: Z
222
- };
223
- K();
224
- export {
225
- u as TopDialogUtils
226
- };
227
- //# sourceMappingURL=utils-CKggUvLI.es.js.map
@@ -1,3 +0,0 @@
1
- import { Emits, Props } from '../input/input';
2
- export * from '../../forms/input/input';
3
- export type { Props, Emits };
@@ -1,7 +0,0 @@
1
- export type Competitor = {
2
- id: number;
3
- name: string;
4
- site: string;
5
- on: 0 | 1;
6
- url: string;
7
- };
File without changes