@topvisor/ui 0.9.34-utils-components-4 → 0.9.34-utils-components-6

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 (317) hide show
  1. package/.chunks/datepicker-Bh_DAFqD.es.js +289 -0
  2. package/.chunks/datepicker-Bh_DAFqD.es.js.map +1 -0
  3. package/.chunks/datepicker-CIbLjf_3.amd.js +247 -0
  4. package/.chunks/datepicker-CIbLjf_3.amd.js.map +1 -0
  5. package/.chunks/forms-BfIXIMY_.es.js +1089 -0
  6. package/.chunks/forms-BfIXIMY_.es.js.map +1 -0
  7. package/.chunks/forms-C__H1yL_.amd.js +3 -0
  8. package/.chunks/forms-C__H1yL_.amd.js.map +1 -0
  9. package/.chunks/i18n-B5a6l_mZ.es.js +23 -0
  10. package/.chunks/i18n-B5a6l_mZ.es.js.map +1 -0
  11. package/.chunks/i18n-CfQopOHM.amd.js +2 -0
  12. package/.chunks/i18n-CfQopOHM.amd.js.map +1 -0
  13. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-CaBP5R7L.amd.js +2 -0
  14. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-CaBP5R7L.amd.js.map +1 -0
  15. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-DJZS6vRL.es.js +161 -0
  16. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-DJZS6vRL.es.js.map +1 -0
  17. package/.chunks/{menu-D8Pkjvdh.es.js → menu-24EpQtdy.es.js} +37 -37
  18. package/.chunks/menu-24EpQtdy.es.js.map +1 -0
  19. package/.chunks/menu-DV1iSTyB.amd.js +2 -0
  20. package/.chunks/menu-DV1iSTyB.amd.js.map +1 -0
  21. package/.chunks/popup-BDbiwl2O.amd.js +440 -0
  22. package/.chunks/popup-BDbiwl2O.amd.js.map +1 -0
  23. package/.chunks/{popup-DUd8G4iQ.es.js → popup-brcaxiWt.es.js} +515 -511
  24. package/.chunks/popup-brcaxiWt.es.js.map +1 -0
  25. package/.chunks/store-Bl79G7T_.amd.js.map +1 -1
  26. package/.chunks/store-PoMCiuBr.es.js.map +1 -1
  27. package/README.md +86 -86
  28. package/assets/forms.css +1 -1
  29. package/common/common.d.ts +1 -1
  30. package/{src/components → components}/formsExt/editInput/editInput.vue.d.ts +1 -10
  31. package/{src/components → components}/popup/lib/popup.d.ts +0 -3
  32. package/{src/components → components}/popup/lib/worker.d.ts +0 -4
  33. package/core/app.amd.js +2 -0
  34. package/core/app.amd.js.map +1 -0
  35. package/core/app.d.ts +7 -0
  36. package/core/app.js +307 -0
  37. package/core/app.js.map +1 -0
  38. package/{src/core → core}/core/core.d.ts +17 -24
  39. package/core/core/options.d.ts +24 -0
  40. package/{src/core → core}/core/state.d.ts +3 -2
  41. package/core/core.amd.js +1 -1
  42. package/core/core.d.ts +2 -2
  43. package/core/core.js +1 -1
  44. package/core/directives/focus.d.ts +9 -3
  45. package/core/directives/sticky.d.ts +11 -3
  46. package/core/directives/swimUp.d.ts +10 -3
  47. package/core/directives/tooltip.d.ts +11 -3
  48. package/{src/core/plugin/plugin.d.ts → core/plugins/core.d.ts} +14 -17
  49. package/core/plugins/i18n.d.ts +98 -0
  50. package/core/plugins/piniaTPA.d.ts +18 -0
  51. package/core/utils/clipboard.d.ts +1 -0
  52. package/{src/core → core}/utils/price.d.ts +3 -1
  53. package/{src/core → core}/utils/system.d.ts +0 -1
  54. package/forms/forms.amd.js +1 -1
  55. package/forms/forms.d.ts +1 -1
  56. package/forms/forms.js +7 -7
  57. package/forms/helpers.amd.js.map +1 -1
  58. package/forms/helpers.d.ts +1 -1
  59. package/forms/helpers.js.map +1 -1
  60. package/formsExt/formsExt.amd.js +1 -1
  61. package/formsExt/formsExt.amd.js.map +1 -1
  62. package/formsExt/formsExt.d.ts +1 -1
  63. package/formsExt/formsExt.js +76 -81
  64. package/formsExt/formsExt.js.map +1 -1
  65. package/icomoon/Read Me.txt +7 -7
  66. package/icomoon/demo-files/demo.css +161 -161
  67. package/icomoon/demo-files/demo.js +30 -30
  68. package/icomoon/demo.html +3379 -3379
  69. package/icomoon/fonts/Topvisor-2.svg +263 -263
  70. package/icomoon/style.css +740 -740
  71. package/package.json +36 -32
  72. package/popup/popup.amd.js +1 -1
  73. package/popup/popup.amd.js.map +1 -1
  74. package/popup/popup.d.ts +1 -1
  75. package/popup/popup.js +6 -6
  76. package/popup/popup.js.map +1 -1
  77. package/popup/worker.amd.js +1 -1
  78. package/popup/worker.amd.js.map +1 -1
  79. package/popup/worker.d.ts +2 -2
  80. package/popup/worker.js +5 -7
  81. package/popup/worker.js.map +1 -1
  82. package/project/project.amd.js +1 -1
  83. package/project/project.amd.js.map +1 -1
  84. package/project/project.d.ts +1 -1
  85. package/project/project.js +7 -7
  86. package/project/project.js.map +1 -1
  87. package/require/css.amd.js +11 -11
  88. package/tabs/tabs.amd.js +1 -1
  89. package/tabs/tabs.amd.js.map +1 -1
  90. package/tabs/tabs.d.ts +1 -1
  91. package/tabs/tabs.js +5 -5
  92. package/tabs/tabs.js.map +1 -1
  93. package/tabsView/tabsView.amd.js +1 -1
  94. package/tabsView/tabsView.amd.js.map +1 -1
  95. package/tabsView/tabsView.d.ts +1 -1
  96. package/tabsView/tabsView.js +8 -8
  97. package/tabsView/tabsView.js.map +1 -1
  98. package/utils/check.amd.js.map +1 -1
  99. package/utils/check.d.ts +1 -1
  100. package/utils/check.js.map +1 -1
  101. package/utils/clipboard.amd.js +2 -0
  102. package/utils/clipboard.amd.js.map +1 -0
  103. package/utils/clipboard.d.ts +1 -0
  104. package/utils/clipboard.js +10 -0
  105. package/utils/clipboard.js.map +1 -0
  106. package/utils/css.amd.js.map +1 -1
  107. package/utils/css.d.ts +1 -1
  108. package/utils/css.js.map +1 -1
  109. package/utils/date.amd.js +1 -1
  110. package/utils/date.d.ts +1 -1
  111. package/utils/date.js +4 -4
  112. package/utils/device.amd.js +1 -1
  113. package/utils/device.d.ts +1 -1
  114. package/utils/device.js +5 -5
  115. package/utils/dom.amd.js.map +1 -1
  116. package/utils/dom.d.ts +2 -2
  117. package/utils/dom.js.map +1 -1
  118. package/utils/image.amd.js.map +1 -1
  119. package/utils/image.d.ts +1 -1
  120. package/utils/image.js.map +1 -1
  121. package/utils/keyboard.amd.js.map +1 -1
  122. package/utils/keyboard.d.ts +1 -1
  123. package/utils/keyboard.js.map +1 -1
  124. package/utils/number.amd.js.map +1 -1
  125. package/utils/number.d.ts +1 -1
  126. package/utils/number.js.map +1 -1
  127. package/utils/price.amd.js +1 -1
  128. package/utils/price.amd.js.map +1 -1
  129. package/utils/price.d.ts +1 -1
  130. package/utils/price.js +8 -5
  131. package/utils/price.js.map +1 -1
  132. package/utils/route.amd.js.map +1 -1
  133. package/utils/route.d.ts +1 -1
  134. package/utils/route.js.map +1 -1
  135. package/utils/scroll.amd.js +1 -1
  136. package/utils/scroll.amd.js.map +1 -1
  137. package/utils/scroll.d.ts +1 -1
  138. package/utils/scroll.js +1 -1
  139. package/utils/scroll.js.map +1 -1
  140. package/utils/store.d.ts +1 -1
  141. package/utils/string.amd.js +1 -1
  142. package/utils/string.amd.js.map +1 -1
  143. package/utils/string.d.ts +1 -1
  144. package/utils/string.js +38 -35
  145. package/utils/string.js.map +1 -1
  146. package/utils/system.amd.js +1 -1
  147. package/utils/system.amd.js.map +1 -1
  148. package/utils/system.d.ts +1 -1
  149. package/utils/system.js +16 -17
  150. package/utils/system.js.map +1 -1
  151. package/utils/url.amd.js.map +1 -1
  152. package/utils/url.d.ts +1 -1
  153. package/utils/url.js.map +1 -1
  154. package/utils/window.amd.js +1 -1
  155. package/utils/window.d.ts +1 -1
  156. package/utils/window.js +1 -1
  157. package/.chunks/datepicker-B-QNMaqL.es.js +0 -289
  158. package/.chunks/datepicker-B-QNMaqL.es.js.map +0 -1
  159. package/.chunks/datepicker-BtTKGtP7.amd.js +0 -247
  160. package/.chunks/datepicker-BtTKGtP7.amd.js.map +0 -1
  161. package/.chunks/forms-CRdPxA6a.es.js +0 -1186
  162. package/.chunks/forms-CRdPxA6a.es.js.map +0 -1
  163. package/.chunks/forms-CbJDUr1_.amd.js +0 -3
  164. package/.chunks/forms-CbJDUr1_.amd.js.map +0 -1
  165. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-D5EXHsIJ.es.js +0 -164
  166. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-D5EXHsIJ.es.js.map +0 -1
  167. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-W45jLCVb.amd.js +0 -2
  168. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-W45jLCVb.amd.js.map +0 -1
  169. package/.chunks/menu-BNQ5GpPq.amd.js +0 -2
  170. package/.chunks/menu-BNQ5GpPq.amd.js.map +0 -1
  171. package/.chunks/menu-D8Pkjvdh.es.js.map +0 -1
  172. package/.chunks/popup-DUd8G4iQ.es.js.map +0 -1
  173. package/.chunks/popup-DcfMTbwU.amd.js +0 -440
  174. package/.chunks/popup-DcfMTbwU.amd.js.map +0 -1
  175. package/core/directives/focus.amd.js +0 -2
  176. package/core/directives/focus.amd.js.map +0 -1
  177. package/core/directives/focus.js +0 -5
  178. package/core/directives/focus.js.map +0 -1
  179. package/core/directives/sticky.amd.js +0 -2
  180. package/core/directives/sticky.amd.js.map +0 -1
  181. package/core/directives/sticky.js +0 -5
  182. package/core/directives/sticky.js.map +0 -1
  183. package/core/directives/swimUp.amd.js +0 -2
  184. package/core/directives/swimUp.amd.js.map +0 -1
  185. package/core/directives/swimUp.js +0 -5
  186. package/core/directives/swimUp.js.map +0 -1
  187. package/core/directives/tooltip.amd.js +0 -2
  188. package/core/directives/tooltip.amd.js.map +0 -1
  189. package/core/directives/tooltip.js +0 -5
  190. package/core/directives/tooltip.js.map +0 -1
  191. package/core/plugin/plugin.amd.js +0 -2
  192. package/core/plugin/plugin.amd.js.map +0 -1
  193. package/core/plugin/plugin.d.ts +0 -3
  194. package/core/plugin/plugin.js +0 -23
  195. package/core/plugin/plugin.js.map +0 -1
  196. package/src/components/forms/avatar/avatar.stories.d.ts +0 -85
  197. package/src/components/forms/button/button.stories.d.ts +0 -278
  198. package/src/components/forms/checkbox/checkbox.stories.d.ts +0 -116
  199. package/src/components/forms/controlLabel/controlLabel.stories.d.ts +0 -65
  200. package/src/components/forms/hint/hint.stories.d.ts +0 -75
  201. package/src/components/forms/input/input.stories.d.ts +0 -226
  202. package/src/components/forms/inputDate/inputDate.stories.d.ts +0 -117
  203. package/src/components/forms/inputRange/inputRange.stories.d.ts +0 -285
  204. package/src/components/forms/loadbar/loadbar.stories.d.ts +0 -10
  205. package/src/components/forms/radio/radio.stories.d.ts +0 -132
  206. package/src/components/forms/select/select.stories.d.ts +0 -108
  207. package/src/components/forms/switcher/switcher.stories.d.ts +0 -127
  208. package/src/components/forms/textarea/textarea.stories.d.ts +0 -90
  209. package/src/components/formsExt/editArea/editArea.stories.d.ts +0 -158
  210. package/src/components/formsExt/editInput/editInput.stories.d.ts +0 -98
  211. package/src/components/formsExt/menu/menu.stories.d.ts +0 -82
  212. package/src/components/formsExt/radioGroup/radioGroup.stories.d.ts +0 -67
  213. package/src/components/formsExt/selector2/selector2.stories.d.ts +0 -277
  214. package/src/components/popup/popup/popup.stories.d.ts +0 -701
  215. package/src/components/project/selectorCompetitors/selectorCompetitors.stories.d.ts +0 -43
  216. package/src/components/tabs/tabs/tabs.stories.d.ts +0 -539
  217. package/src/components/tabsView/tabsView/tabsView.stories.d.ts +0 -352
  218. package/src/components/tabsView/tabsView//320/255/320/273/320/265/320/274/320/265/320/275/321/202/321/213/MenuItem.stories.d.ts +0 -333
  219. package/src/components/tabsView/tabsView//320/255/320/273/320/265/320/274/320/265/320/275/321/202/321/213/MenuTitle.stories.d.ts +0 -175
  220. package/src/core/core/options.d.ts +0 -13
  221. package/src/core/core/page.d.ts +0 -7
  222. package/src/core/directives/focus.d.ts +0 -9
  223. package/src/core/directives/sticky.d.ts +0 -11
  224. package/src/core/directives/swimUp.d.ts +0 -10
  225. package/src/core/directives/tooltip.d.ts +0 -11
  226. /package/{src/components → components}/common/common.d.ts +0 -0
  227. /package/{src/components → components}/common/icon/icon.d.ts +0 -0
  228. /package/{src/components → components}/forms/avatar/avatar.d.ts +0 -0
  229. /package/{src/components → components}/forms/avatar/avatar.vue.d.ts +0 -0
  230. /package/{src/components → components}/forms/button/button.d.ts +0 -0
  231. /package/{src/components → components}/forms/button/button.vue.d.ts +0 -0
  232. /package/{src/components → components}/forms/checkbox/checkbox.d.ts +0 -0
  233. /package/{src/components → components}/forms/checkbox/checkbox.vue.d.ts +0 -0
  234. /package/{src/components → components}/forms/controlLabel/controlLabel.d.ts +0 -0
  235. /package/{src/components → components}/forms/controlLabel/controlLabel.vue.d.ts +0 -0
  236. /package/{src/components → components}/forms/forms.d.ts +0 -0
  237. /package/{src/components → components}/forms/helpers.d.ts +0 -0
  238. /package/{src/components → components}/forms/hint/hint.d.ts +0 -0
  239. /package/{src/components → components}/forms/hint/hint.vue.d.ts +0 -0
  240. /package/{src/components → components}/forms/input/input.d.ts +0 -0
  241. /package/{src/components → components}/forms/input/input.vue.d.ts +0 -0
  242. /package/{src/components → components}/forms/inputDate/datepicker.d.ts +0 -0
  243. /package/{src/components → components}/forms/inputDate/inputDate.d.ts +0 -0
  244. /package/{src/components → components}/forms/inputDate/inputDate.vue.d.ts +0 -0
  245. /package/{src/components → components}/forms/inputRange/inputRange.d.ts +0 -0
  246. /package/{src/components → components}/forms/inputRange/inputRange.vue.d.ts +0 -0
  247. /package/{src/components → components}/forms/loadbar/loadbar.vue.d.ts +0 -0
  248. /package/{src/components → components}/forms/radio/radio.d.ts +0 -0
  249. /package/{src/components → components}/forms/radio/radio.vue.d.ts +0 -0
  250. /package/{src/components → components}/forms/select/select.d.ts +0 -0
  251. /package/{src/components → components}/forms/select/select.vue.d.ts +0 -0
  252. /package/{src/components → components}/forms/select/stories/exampleOptions.d.ts +0 -0
  253. /package/{src/components → components}/forms/switcher/switcher.d.ts +0 -0
  254. /package/{src/components → components}/forms/switcher/switcher.vue.d.ts +0 -0
  255. /package/{src/components → components}/forms/textarea/textarea.d.ts +0 -0
  256. /package/{src/components → components}/forms/textarea/textarea.vue.d.ts +0 -0
  257. /package/{src/components → components}/formsExt/editArea/editArea.d.ts +0 -0
  258. /package/{src/components → components}/formsExt/editArea/editArea.vue.d.ts +0 -0
  259. /package/{src/components → components}/formsExt/editInput/editInput.d.ts +0 -0
  260. /package/{src/components → components}/formsExt/formsExt.d.ts +0 -0
  261. /package/{src/components → components}/formsExt/menu/menu.d.ts +0 -0
  262. /package/{src/components → components}/formsExt/menu/menu.vue.d.ts +0 -0
  263. /package/{src/components → components}/formsExt/menu/stories/items.d.ts +0 -0
  264. /package/{src/components → components}/formsExt/radioGroup/radioGroup.d.ts +0 -0
  265. /package/{src/components → components}/formsExt/radioGroup/radioGroup.vue.d.ts +0 -0
  266. /package/{src/components → components}/formsExt/selector2/api.d.ts +0 -0
  267. /package/{src/components → components}/formsExt/selector2/itemMulti.vue.d.ts +0 -0
  268. /package/{src/components → components}/formsExt/selector2/selector2.d.ts +0 -0
  269. /package/{src/components → components}/formsExt/selector2/selector2.vue.d.ts +0 -0
  270. /package/{src/components → components}/formsExt/selector2/stories/dummyAPIRequest.d.ts +0 -0
  271. /package/{src/components → components}/popup/lib/popup.globalEvents.d.ts +0 -0
  272. /package/{src/components → components}/popup/lib/worker.globalEvents.d.ts +0 -0
  273. /package/{src/components → components}/popup/popup/listItem.vue.d.ts +0 -0
  274. /package/{src/components → components}/popup/popup/opener.vue.d.ts +0 -0
  275. /package/{src/components → components}/popup/popup/popup.d.ts +0 -0
  276. /package/{src/components → components}/popup/popup/popup.vue.d.ts +0 -0
  277. /package/{src/components → components}/popup/popup/widgetInput.vue.d.ts +0 -0
  278. /package/{src/components → components}/popup/popup.d.ts +0 -0
  279. /package/{src/components → components}/popup/worker.d.ts +0 -0
  280. /package/{src/components → components}/project/project.d.ts +0 -0
  281. /package/{src/components → components}/project/selectorCompetitors/composables.d.ts +0 -0
  282. /package/{src/components → components}/project/selectorCompetitors/selectorCompetitors.d.ts +0 -0
  283. /package/{src/components → components}/project/selectorCompetitors/selectorCompetitors.vue.d.ts +0 -0
  284. /package/{src/components → components}/project/selectorCompetitors/stories/items.d.ts +0 -0
  285. /package/{src/components → components}/project/selectorCompetitors/types/competitor.d.ts +0 -0
  286. /package/{src/components → components}/tabs/tabs/content.vue.d.ts +0 -0
  287. /package/{src/components → components}/tabs/tabs/tab.vue.d.ts +0 -0
  288. /package/{src/components → components}/tabs/tabs/tabs.d.ts +0 -0
  289. /package/{src/components → components}/tabs/tabs/tabs.vue.d.ts +0 -0
  290. /package/{src/components → components}/tabs/tabs.d.ts +0 -0
  291. /package/{src/components → components}/tabsView/tabsView/menu.vue.d.ts +0 -0
  292. /package/{src/components → components}/tabsView/tabsView/menuDelimeter.vue.d.ts +0 -0
  293. /package/{src/components → components}/tabsView/tabsView/menuItem.vue.d.ts +0 -0
  294. /package/{src/components → components}/tabsView/tabsView/menuTitle.vue.d.ts +0 -0
  295. /package/{src/components → components}/tabsView/tabsView/store.d.ts +0 -0
  296. /package/{src/components → components}/tabsView/tabsView/tabsView.d.ts +0 -0
  297. /package/{src/components → components}/tabsView/tabsView/tabsView.vue.d.ts +0 -0
  298. /package/{src/components → components}/tabsView/tabsView/utils.d.ts +0 -0
  299. /package/{src/components → components}/tabsView/tabsView.d.ts +0 -0
  300. /package/{src/core → core}/core/events.d.ts +0 -0
  301. /package/{src/core → core}/utils/check.d.ts +0 -0
  302. /package/{src/core → core}/utils/css.d.ts +0 -0
  303. /package/{src/core → core}/utils/date.d.ts +0 -0
  304. /package/{src/core → core}/utils/device.d.ts +0 -0
  305. /package/{src/core → core}/utils/dom.d.ts +0 -0
  306. /package/{src/core → core}/utils/image.d.ts +0 -0
  307. /package/{src/core → core}/utils/keyboard.d.ts +0 -0
  308. /package/{src/core → core}/utils/number.d.ts +0 -0
  309. /package/{src/core → core}/utils/route.d.ts +0 -0
  310. /package/{src/core → core}/utils/scroll.d.ts +0 -0
  311. /package/{src/core → core}/utils/store/localStorage.d.ts +0 -0
  312. /package/{src/core → core}/utils/store/plugin.d.ts +0 -0
  313. /package/{src/core → core}/utils/store/store.d.ts +0 -0
  314. /package/{src/core → core}/utils/store.d.ts +0 -0
  315. /package/{src/core → core}/utils/string.d.ts +0 -0
  316. /package/{src/core → core}/utils/url.d.ts +0 -0
  317. /package/{src/core → core}/utils/window.d.ts +0 -0
@@ -1,6 +1,7 @@
1
- import { C as f } from "./forms-CRdPxA6a.es.js";
2
- import n from "../utils/dom.js";
3
- import { TopPopupWorker as l } from "../popup/worker.js";
1
+ import { C as f } from "./forms-BfIXIMY_.es.js";
2
+ import r from "../utils/dom.js";
3
+ import { TopPopupWorker as s } from "../popup/worker.js";
4
+ import { a as P } from "./i18n-B5a6l_mZ.es.js";
4
5
  class v {
5
6
  static componentName = "Top";
6
7
  componentName;
@@ -28,11 +29,11 @@ class v {
28
29
  }
29
30
  // получить инициированный компонент
30
31
  static getComponent(t, p) {
31
- return n.storage(t, "#" + p);
32
+ return r.storage(t, "#" + p);
32
33
  }
33
34
  // устанвоить компонент
34
35
  _setComponent(t) {
35
- n.storage(t, "#" + this.componentName, this);
36
+ r.storage(t, "#" + this.componentName, this);
36
37
  }
37
38
  // функция подключения компонента
38
39
  mount() {
@@ -40,7 +41,7 @@ class v {
40
41
  }
41
42
  // функция отключения компонента
42
43
  unmount() {
43
- n.storage(this.el, "#" + this.componentName, null), this.unmountEls.forEach((t) => {
44
+ r.storage(this.el, "#" + this.componentName, null), this.unmountEls.forEach((t) => {
44
45
  t.remove();
45
46
  }), this.unmountEls = [], this.unmountEvents.forEach((t) => {
46
47
  t.el.removeEventListener(t.type, t.listener, t.options);
@@ -56,13 +57,13 @@ class v {
56
57
  }
57
58
  // указание новые события, которые должны будут удалиться после unmount
58
59
  registerEventForUnmount(t, p, o, e) {
59
- const r = {
60
+ const i = {
60
61
  el: t,
61
62
  type: p,
62
63
  listener: o,
63
64
  options: e
64
65
  };
65
- this.unmountEvents.push(r);
66
+ this.unmountEvents.push(i);
66
67
  }
67
68
  // функция перенастройки уже подключенного компонента
68
69
  reInit(t) {
@@ -82,7 +83,7 @@ class v {
82
83
  }
83
84
  }
84
85
  }
85
- class P {
86
+ class w {
86
87
  static init() {
87
88
  document.addEventListener("click", this.onclick), document.addEventListener("keydown", this.onkeydown);
88
89
  }
@@ -99,22 +100,22 @@ class P {
99
100
  if (!e || p.matches(".top-popup-noCloser"))
100
101
  return;
101
102
  if (p.getAttribute("href") === "." && t.preventDefault(), t.target.matches("[data-top-popup]")) {
102
- const r = t.target.closest("ul"), s = t.target.closest("a, .a");
103
- r && ((o = r.querySelector("a.top-active, .a.top-active")) == null || o.classList.remove("top-active")), s && s.classList.add("top-active");
103
+ const i = t.target.closest("ul"), n = t.target.closest("a, .a");
104
+ i && ((o = i.querySelector("a.top-active, .a.top-active")) == null || o.classList.remove("top-active")), n && n.classList.add("top-active");
104
105
  return;
105
106
  }
106
- l.close(e);
107
+ s.close(e);
107
108
  }
108
109
  if (t.target.matches(".top-popup-wrapper")) {
109
110
  const e = t.target;
110
- l.close(e);
111
+ s.close(e);
111
112
  }
112
113
  }
113
114
  /**
114
115
  * Глобальный обработчик нажатия кнопки на клавиатуре
115
116
  */
116
117
  static onkeydown(t) {
117
- var e, r;
118
+ var e, i;
118
119
  if (!(t.target instanceof Element)) return;
119
120
  const p = t.target.closest(".top-popup-wrapper");
120
121
  if (!p)
@@ -122,25 +123,25 @@ class P {
122
123
  const o = p.querySelector("ul.top-popup_content");
123
124
  switch (t.key) {
124
125
  case "Escape":
125
- l.close(p);
126
+ s.close(p);
126
127
  break;
127
128
  case "Enter":
128
129
  if (!o) {
129
- if (n.querySelectorVisible(p, ".preloader"))
130
+ if (r.querySelectorVisible(p, ".preloader"))
130
131
  break;
131
- const c = n.querySelectorVisible(p, ".top-popup_footer .go, .top-popup_footer [data-action]");
132
+ const c = r.querySelectorVisible(p, ".top-popup_footer .go, .top-popup_footer [data-action]");
132
133
  if (c instanceof HTMLElement) {
133
134
  c.click();
134
135
  break;
135
136
  }
136
- const m = n.querySelectorVisibleLast(p, ".top-popup_footer .top-button");
137
+ const m = r.querySelectorVisibleLast(p, ".top-popup_footer .top-button");
137
138
  m instanceof HTMLElement && m.click();
138
139
  break;
139
140
  }
140
- const s = n.querySelectorVisible(p, "li > a.top-active");
141
- s && s.getAttribute("href") && (t.preventDefault(), location.href = s.getAttribute("href"));
142
- const a = p.querySelector("li > .top-active");
143
- a instanceof HTMLElement && a.click();
141
+ const n = r.querySelectorVisible(p, "li > a.top-active");
142
+ n && n.getAttribute("href") && (t.preventDefault(), location.href = n.getAttribute("href"));
143
+ const u = p.querySelector("li > .top-active");
144
+ u instanceof HTMLElement && u.click();
144
145
  break;
145
146
  case "ArrowUp":
146
147
  case "ArrowRight":
@@ -148,471 +149,471 @@ class P {
148
149
  case "ArrowLeft":
149
150
  if (!o)
150
151
  break;
151
- t.key === "ArrowRight" || t.key === "ArrowLeft" ? n.querySelectorVisible(
152
+ t.key === "ArrowRight" || t.key === "ArrowLeft" ? r.querySelectorVisible(
152
153
  p,
153
154
  "ul.top-popup_content > li:not(.top-popup_liNoSelectable) > .top-active > .top-popup_listMore"
154
155
  ) && t.preventDefault() : t.preventDefault();
155
- const i = (e = p.querySelector("ul.top-popup_content > li:not(.top-popup_liNoSelectable) > .top-active")) == null ? void 0 : e.parentElement;
156
- if (t.key === "ArrowRight" && i) {
157
- const c = i.querySelector(".top-active > .top-popup_listMore");
156
+ const l = (e = p.querySelector("ul.top-popup_content > li:not(.top-popup_liNoSelectable) > .top-active")) == null ? void 0 : e.parentElement;
157
+ if (t.key === "ArrowRight" && l) {
158
+ const c = l.querySelector(".top-active > .top-popup_listMore");
158
159
  if (c instanceof HTMLElement)
159
160
  return c.click();
160
161
  }
161
- const d = n.querySelectorAllVisible(p, "ul.top-popup_content > li:not(.top-popup_liNoSelectable)"), h = d.length;
162
+ const d = r.querySelectorAllVisible(p, "ul.top-popup_content > li:not(.top-popup_liNoSelectable)"), h = d.length;
162
163
  if (!h)
163
164
  return;
164
- let u = -1;
165
- if (i && (u = d.indexOf(i)), t.key === "ArrowUp" || t.key === "ArrowLeft" ? u-- : u++, t.key === "ArrowLeft" && u === -1)
166
- return t.target.matches("input") ? void 0 : l.close(p);
167
- if (t.key === "ArrowRight" && u === h)
165
+ let a = -1;
166
+ if (l && (a = d.indexOf(l)), t.key === "ArrowUp" || t.key === "ArrowLeft" ? a-- : a++, t.key === "ArrowLeft" && a === -1)
167
+ return t.target.matches("input") ? void 0 : s.close(p);
168
+ if (t.key === "ArrowRight" && a === h)
168
169
  return;
169
- u < 0 && (u = h - 1), u > h - 1 && (u = 0), p.querySelectorAll("ul.top-popup_content > li > .top-active").forEach((c) => c.classList.remove("top-active")), (r = d[u].querySelector(":scope > a, :scope > .a")) == null || r.classList.add("top-active"), l.scrollToActive(p);
170
+ a < 0 && (a = h - 1), a > h - 1 && (a = 0), p.querySelectorAll("ul.top-popup_content > li > .top-active").forEach((c) => c.classList.remove("top-active")), (i = d[a].querySelector(":scope > a, :scope > .a")) == null || i.classList.add("top-active"), s.scrollToActive(p);
170
171
  break;
171
172
  }
172
173
  }
173
174
  }
174
- const w = `:root {
175
- --top-popup-z-index: 200000;
176
- --top-popup-transition-delay: 100ms;
177
-
178
- --top-popup-background-color: var(--color-bg-3);
179
- --top-popup-background-color-hover: var(--color-cell-secondary-2);
180
- --top-popup-background-color-active: var(--color-layer-primary-1);
181
-
182
- --top-popup-border-color: var(--color-line-2-opacity);
183
- --top-popup-title-background-color: var(--color-layer-secondary-1);
184
-
185
- /* суммарный отсуп от каря popup до элемента */
186
- --top-popup-content-padding: calc(var(--top-popup-list-padding) + var(--top-popup-listItem-padding));
187
-
188
- /* списки */
189
- --top-popup-list-padding: var(--top-padding-2);
190
-
191
- --top-popup-listItem-radius: var(--top-radius-2);
192
- --top-popup-listItem-padding: var(--top-padding-2);
193
- }
194
-
195
- .top-popup-front { position: relative; }
196
-
197
- .top-popup-wrapper {
198
- /* см. recalcPosition() */
199
- --top-popup-height: 0px;
200
- --top-popup-right-bounding: 0px;
201
- --top-popup-bottom-bounding: 0px;
202
- --top-popup-top: 0px;
203
- --top-popup-right: calc(100vw - var(--top-popup-right-bounding));
204
- --top-popup-bottom: calc(var(--100vh) - var(--top-popup-bottom-bounding));
205
- --top-popup-left: 0px;
206
-
207
- text-align: initial; white-space: normal; word-break: normal;
208
- position: absolute; z-index: 200000;
209
- }
210
-
211
- .top-popup-wrapper:not(.top-popup-wrapper-shown) { overflow: hidden; }
212
-
213
- /* top-popupPanel */
214
- .top-popupPanel {
215
- cursor: default;
216
- box-shadow: var(--top-shadow-b);
217
- border-radius: 14px;
218
- background: var(--top-popup-background-color);
219
- position: absolute; overflow: hidden;
220
- display: flex; flex-direction: column;
221
- }
222
-
223
- /* position */
224
- .top-popup-wrapper > * {
225
- opacity: 0;
226
- transition: opacity var(--top-popup-transition-delay) linear, transform var(--top-popup-transition-delay) linear;
227
- }
228
-
229
- .top-popup-wrapper.p0 > * { transform: translateY(-8px); }
230
-
231
- .top-popup-wrapper.p1 > * { transform: translateY(8px); }
232
-
233
- .top-popup-wrapper.p2 > * { transform: translateX(8px); }
234
-
235
- .top-popup-wrapper.p3 > * { transform: translateY(8px); }
236
-
237
- .top-popup-wrapper.p4 > * { transform: translateX(-8px); }
238
-
239
- .top-popup-wrapper-shown:not(.top-popup-wrapper-closed) > * {opacity: 1;transform: translate(0, 0) !important;}
240
-
241
- .top-popup-wrapper.p0 > .top-popup { top: calc(-16px); left: calc(0px - 8px); }
242
-
243
- .top-popup-wrapper.p1 > .top-popup { bottom: calc(100% + 8px); }
244
-
245
- .top-popup-wrapper.p2 > .top-popup { left: calc(100% + 8px); }
246
-
247
- .top-popup-wrapper.p3 > .top-popup { top: calc(100% + 8px); }
248
-
249
- .top-popup-wrapper.p4 > .top-popup { right: calc(100% + 8px); }
250
-
251
- .top-popup-wrapper.p2 > .top-popup,
252
- .top-popup-wrapper.p4 > .top-popup { margin-top: -10px; }
253
-
254
- .top-popup-wrapper.p1.with_notch > .top-popup { margin-bottom: 5px; }
255
-
256
- .top-popup-wrapper.p2.with_notch > .top-popup { margin-left: 5px; }
257
-
258
- .top-popup-wrapper.p3.with_notch > .top-popup { margin-top: 5px; }
259
-
260
- .top-popup-wrapper.p4.with_notch > .top-popup { margin-right: 5px; }
261
-
262
- .top-popup-wrapper.invert-x > .top-popup { right: 0; }
263
-
264
- .top-popup-wrapper.invert-y > .top-popup { bottom: 0; }
265
-
266
- /* notch */
267
- .top-popup-wrapper > .notch { border: 7.4px solid transparent; position: absolute; display: block; }
268
-
269
- .top-popup-wrapper.p1 > .notch { border-bottom: 0; border-top: 7.4px solid var(--content-background-color); margin: 0 0 7.4px -7.4px; bottom: 100%; left: 50% }
270
-
271
- .top-popup-wrapper.p2 > .notch { border-left: 0; border-right: 7.4px solid var(--content-background-color); margin: 0 0 -7.4px 7.4px; bottom: 50%; left: 100%; }
272
-
273
- .top-popup-wrapper.p3 > .notch { border-top: 0; border-bottom: 7.4px solid var(--content-background-color); margin: 7.4px 0 0 -7.4px; top: 100%; left: 50%; }
274
-
275
- .top-popup-wrapper.p4 > .notch { border-right: 0; border-left: 7.4px solid var(--content-background-color); margin: 0 7.4px -7.4px 0; bottom: 50%; right: 100%; }
276
-
277
- .top-popup-wrapper.p1 > .notch-border { border-top-color: rgba(0, 0, 0, 0.05); margin-bottom: 6px; }
278
-
279
- .top-popup-wrapper.p2 > .notch-border { border-right-color: rgba(0, 0, 0, 0.05); margin-left: 6px; }
280
-
281
- .top-popup-wrapper.p3 > .notch-border { border-bottom-color: rgba(0, 0, 0, 0.05); margin-top: 6px; }
282
-
283
- .top-popup-wrapper.p4 > .notch-border { border-left-color: rgba(0, 0, 0, 0.05); margin-right: 6px; }
284
-
285
- /* common */
286
- .top-popup_header,
287
- .top-popup_content,
288
- .top-popup_footer { font-size: 14px; }
289
-
290
- .top-popup_header,
291
- .top-popup_footer { display: flex; align-items: center; justify-content: space-between; }
292
-
293
- /* header */
294
- .top-popup_header {
295
- color: var(--color-text-1);
296
- border-bottom: 1px solid var(--top-popup-border-color);
297
- padding: var(--top-padding-3);
298
- font-weight: 600;
299
- }
300
-
301
- .top-popup_header > * { font-weight: 400; }
302
-
303
- .top-popup_header > .a { cursor: pointer;}
304
-
305
- .top-popup_header > .a:hover { color: var(--color-text-primary-2); }
306
-
307
- .top-popup_headerButton { width: 60px; }
308
-
309
- /* widget */
310
- .top-popup_widget {
311
- padding: var(--top-padding-2) var(--top-padding-2) 0 var(--top-padding-2);
312
- }
313
-
314
- /* content */
315
- .top-popup_content {
316
- margin: 0;
317
- flex-grow: 1;
318
- overflow-y: auto;
319
- display: flex;
320
- flex-direction: column;
321
- gap: var(--top-gap-4);
322
-
323
- -webkit-overflow-scrolling: touch;
324
- }
325
-
326
- div.top-popup_content {
327
- color: var(--color-text-1);
328
- padding: var(--top-popup-content-padding);
329
- }
330
-
331
- div.top-popup_content > * { flex-shrink: 0; }
332
-
333
- div.top-popup_content > .top-button { margin: 0; }
334
-
335
- div.top-popup_content .top-unwrap {
336
- --top-unwrap-x: var(--top-popup-content-padding);
337
- }
338
-
339
- ul.top-popup_content {
340
- color: var(--color-text-1);
341
- padding: var(--top-popup-list-padding);
342
- gap: 2px;
343
- }
344
-
345
- ul.top-popup_content .top-unwrap {
346
- --top-unwrap-x: var(--top-popup-list-padding);
347
- }
348
-
349
- .top-popup_listItem {
350
- border-radius: var(--top-popup-listItem-radius);
351
- padding: var(--top-popup-listItem-padding);
352
- line-height: 1 !important;
353
- }
354
-
355
- ul.top-popup_content li { margin: 0; list-style: none; display: flex; position: relative }
356
-
357
- ul.top-popup_content li > * { flex-grow: 1; }
358
-
359
- ul.top-popup_content li > a:not(.top-button),
360
- ul.top-popup_content li > .a {
361
- cursor: pointer;
362
- box-sizing: border-box;
363
- border-radius: var(--top-popup-listItem-radius);
364
- background: var(--top-popup-background-color);
365
- padding: var(--top-popup-listItem-padding);
366
- color: var(--color-text-1) !important; font-size: 14px; font-weight: normal !important; text-decoration: none !important; font-style: normal;
367
- line-height: 1 !important;
368
- display: flex; flex: 1 1 100%; align-items: center;
369
- transition: background-color 0.1s ease-in-out;
370
- }
371
-
372
- .top-popup-wrapper-no_animate ul.top-popup_content li > a:not(.top-button),
373
- .top-popup-wrapper-no_animate ul.top-popup_content li > .a { transition: none; }
374
-
375
- ul.top-popup_content li > a:not(.top-button):hover,
376
- ul.top-popup_content li > .a:hover { background: var(--top-popup-background-color-hover); }
377
-
378
- ul.top-popup_content li > a:not(.top-button).top-active,
379
- ul.top-popup_content li > .a.top-active {
380
- --top-icon-color: var(--color-icon-primary-1) !important;
381
-
382
- background: var(--top-popup-background-color-active);
383
- }
384
-
385
- .top-popup_content + .top-popup_content { padding-top: 0; }
386
-
387
- /* listTitle */
388
- .top-popup_listItem-title {
389
- background: var(--color-layer-secondary-1);
390
- color: var(--color-text-1); font-size: 12px;
391
- }
392
-
393
- /* listDelimiter */
394
- .top-popup_listItem-delimiter {
395
- border-radius: 3px;
396
- background: var(--top-popup-border-color);
397
- height: 1px;
398
- padding: 0;
399
- margin: 4px;
400
- }
401
-
402
- /* listMore */
403
- .top-popup_listMore {
404
- font-size: 20px;
405
- margin: calc(0px - var(--top-popup-listItem-padding)) calc(0px - var(--top-popup-listItem-padding) / 2) calc(0px - var(--top-popup-listItem-padding)) 0;
406
- }
407
-
408
- .top-popup_listMore.top-button { margin: 0; }
409
-
410
- ul.top-popup_content li > .a.top-popup_listMore {
411
- text-align: center;
412
- flex-basis: 10px;
413
- }
414
-
415
- ul.top-popup_content li > .a.top-popup_listMore:before { color: var(--color-icon-2); }
416
-
417
- ul.top-popup_content li > * > .top-popup_listMore {
418
- margin-left: auto;
419
- color: var(--color-layer-secondary-4);
420
- font-size: 14px;
421
- }
422
-
423
- ul.top-popup_content li > * > i.top-popup_listMore:hover,
424
- ul.top-popup_content li > * > i.top-popup_listMore.top-active { color: var(--color-text-primary-1); }
425
-
426
- ul.top-popup_content li > * > i.top-popup_listMore:before {
427
- transform: rotate(90deg);
428
- display: block;
429
- }
430
-
431
- ul.top-popup_content li a.close { background: none !important; }
432
-
433
- /* data-top-icon */
434
- .top-popup_content > [data-top-icon]:before {
435
- --top-icon-size: 20px;
436
- }
437
-
438
- ul.top-popup_content li > [data-top-icon]:not(.top-button) {
439
- --top-icon-color: var(--color-icon-3);
440
- --top-icon-size: 20px;
441
- --top-icon-width: 20px;
442
- }
443
-
444
- ul.top-popup_content li > [data-top-icon]:not(.top-button):before {
445
- height: 1rem; margin-right: 8px; transition: color 0.1s;
446
- }
447
-
448
- ul.top-popup_content li:hover > [data-top-icon]:not(.top-button) {
449
- --top-icon-color: var(--color-icon-2);
450
- }
451
-
452
- /* footer */
453
- .top-popup_footer {
454
- padding: var(--top-popup-list-padding);
455
- border-top: 1px solid var(--top-popup-border-color);
456
- display: flex;
457
- gap: var(--top-gap-2);
458
- justify-content: flex-end;
459
- }
460
-
461
- /* Виджеты */
462
- .top-popup > [data-widget] { padding: 0 var(--top-popup-list-padding); }
463
-
464
- .top-popup > [data-widget] + hr { margin: 0 var(--top-popup-list-padding); }
465
-
466
- .top-popup .placeholder {
467
- border: 1px solid #E0D9D9 !important; border-right: none !important; border-left: none !important; background: #F9F9F9 !important; margin: -1px 0; z-index: 1;
468
- position: relative;
469
- }
470
-
471
- /* компоненты */
472
- .top-popup-wrapper.simple_list > .top-popup { min-width: 0; white-space: nowrap; }
473
-
474
- .top-popup_content .top-column { display: flex; flex-direction: column; gap: 4px; }
475
-
476
- html .top-popup .top-popup_content li > .top-button {
477
- margin: calc(var(--top-popup-listItem-padding) / 2) var(--top-popup-listItem-padding);
478
- }
479
-
480
- .top-popup li .check_all,
481
- .top-popup li .clear_all { cursor: pointer; color: var(--color-text-primary-1); padding: 8px; display: inline-block; }
482
-
483
- .top-popup li .check_all:hover,
484
- .top-popup li .clear_all:hover { text-decoration: underline; }
485
-
486
- .top-popup li .clear_all { display: none; }
487
-
488
- /* table */
489
- .top-popup_content table { margin: -9px 0; }
490
-
491
- .top-popup_content table td,
492
- .top-popup_content table th { padding: 9px var(--top-popup-listItem-padding) 9px 0; vertical-align: top; }
493
-
494
- .top-popup_content table th { width: 40%; font-weight: 600; white-space: nowrap; }
495
-
496
- /* формы */
497
- ul.top-popup_content .a > [type="checkbox"],
498
- ul.top-popup_content .a > [type="radio"] { margin: -8px 0 -8px auto; }
499
-
500
- /* deprecated */
501
- ul.top-popup_content a > [class*=icon],
502
- ul.top-popup_content i.a > [class*=icon] {
503
- transition: 0.1s;
504
- }
505
-
506
- .top-popup .buttons { border-radius: 0 0 4px 4px; border-top: 1px solid #BDC3C7; background: #ECF0F1; padding: 10px 15px; margin: 10px -15px -10px -15px; white-space: nowrap; }
507
-
508
- .top-popup_footer [class*=btn]:not(.btn-transparent) { min-width: 100px; padding: 5px 14px; margin-left: 10px; }
509
-
510
- .top-popup_footer [class*=btn]:first-child { margin-left: 0; }
511
-
512
- .top-popup_footer .btn.full_width { margin: 0; flex-grow: 1; }`, y = `:root{
513
- --top-popup-list-padding: 0px;
514
-
515
- --top-popup-listItem-radius: 0px;
516
- --top-popup-listItem-padding: var(--top-padding-4);
517
- }
518
-
519
- html.with_popup{ background: #808080; }
520
-
521
- .top-popup-wrapper{
522
- --top-popup-footer-offset: 25px;
523
-
524
- width: auto !important; height: auto !important;
525
- position: fixed; top: 0 !important; right: 0 !important; left: 0 !important; overflow: hidden;
526
- transition: background 0.3s;
527
- }
528
-
529
- .top-popup-wrapper-shown:not(.top-popup-wrapper-closed){ background: rgba(0,0,0,0.5); backdrop-filter: blur(1px); }
530
- .top-popup-wrapper-shown:not(.top-popup-wrapper-closed) > .top-popup{ opacity: 1 !important; }
531
-
532
- .top-popup{
533
- border-radius: 8px 8px 0 0; width: auto !important; max-height: calc(100% - var(--header-height, 0px) - var(--toolbar-height, 0px) - 12px); margin: 0 !important;
534
- top: auto !important; right: 0 !important; bottom: var(--toolbar-height, 0px) !important; left: 0 !important;
535
- display: flex; flex-direction: column;
536
-
537
- /* невозможно опустить элемент вниз за экран на 100%, fix: opacity и translateY(80%) */
538
- transform: translateY(80%);
539
-
540
- transition: opacity 0.3s, transform 0.3s;
541
- }
542
-
543
-
544
- /* from top */
545
- .top-popup-wrapper.p-from-top{
546
- --top-popup-footer-offset: 0px;
547
-
548
- top: var(--header-height, 0px) !important;
549
- }
550
- .with_dialog .top-popup-wrapper.p-from-top{ top: 50px !important; }
551
- .top-popup-wrapper.p-from-top > .top-popup{
552
- border-radius: 0 0 8px 8px; max-height: calc(100% - 24px); top: 0 !important; bottom: auto !important;
553
- transform: translateY(calc(-100% - 24px));
554
- }
555
-
556
- /* widget */
557
- .top-popup_widget{ padding: var(--top-padding-2);}
558
- .top-popup_widget:not(.p-from-top){ order: 10; }
559
-
560
- /* content */
561
- ul.top-popup_content{
562
- gap: 0;
563
- }
564
- ul.top-popup_content li:not(:last-child){ border-bottom: 1px solid var(--top-popup-border-color); }
565
-
566
- .top-popup-wrapper.top-style_alt > .top-popup > ul > li{ border-bottom: none; }
567
-
568
- /* footer */
569
- .top-popup_footer{
570
- flex-direction: column-reverse;
571
- }
572
- .top-popup_footer > .top-button{
573
- --top-forms-base-height: var(--top-forms-base-height_l);
574
-
575
- width: 100%;
576
- }
577
-
578
- /* listTitle */
579
- ul.top-popup_content .top-popup_listItem-title{
580
- --top-popup-padding-v: 12px;
581
- }
582
-
583
- /* listDelimiter */
584
- ul.top-popup_content .top-popup_listItem-delimiter{ background: var(--color-line-1-opacity); height: 4px; margin: 0; }
585
- ul.top-popup_content li:first-child > .top-popup_listItem-delimiter{ border-top: 1px solid var(--top-popup-border-color); }`, _ = `html:not(.with_dialog){ margin-right: 0 !important; }
586
-
587
- .top-popup{ min-width: 250px; max-width: calc(100vw - var(--top-popup-left) - 16px); max-height: calc(var(--top-popup-bottom) + var(--top-popup-height)); }
588
- .top-popup-wrapper.invert-x > .top-popup{ max-width: calc(100vw - var(--top-popup-right) - 16px); }
589
- .top-popup-wrapper.invert-y > .top-popup{ max-height: calc(100vh - var(--top-popup-bottom) - 16px); }
590
-
591
- /* position */
592
- .top-popup-wrapper.p1 > .top-popup{ max-height: calc(var(--top-popup-top) - var(--header-height, 0px) - 16px); }
593
- .top-popup-wrapper.p3 > .top-popup{ max-height: calc(var(--top-popup-bottom) - 16px); }
594
- .top-popup-wrapper.p2 > .top-popup{ max-width: calc(var(--top-popup-right) - 16px); }
595
- .top-popup-wrapper.p4 > .top-popup{ max-width: calc(var(--top-popup-left) - 16px); }
596
-
597
- /* notch */
598
- .top-popup-wrapper.p1.with_notch > .top-popup,
599
- .top-popup-wrapper.p3.with_notch > .top-popup{ margin-left: -16px !important; }
600
- .top-popup-wrapper.p1.with_notch > .notch,
601
- .top-popup-wrapper.p3.with_notch > .notch{ margin-left: -8px !important; }
602
-
603
- .top-popup-wrapper.p1.with_notch.invert-x,
604
- .top-popup-wrapper.p3.with_notch.invert-x{ margin-left: 3px !important; }
605
- .top-popup-wrapper.p1.with_notch.invert-x > .notch,
606
- .top-popup-wrapper.p3.with_notch.invert-x > .notch{ margin-left: -9px !important; }
607
-
608
- /* listMore */
609
- ul.top-popup_content li > * > i.top-popup_listMore{ visibility: hidden; transition: none; }
610
- ul.top-popup_content li:hover > * > i.top-popup_listMore,
611
- ul.top-popup_content li > *.top-active > i.top-popup_listMore,
175
+ const y = `:root {\r
176
+ --top-popup-z-index: 200000;\r
177
+ --top-popup-transition-delay: 100ms;\r
178
+ \r
179
+ --top-popup-background-color: var(--color-bg-3);\r
180
+ --top-popup-background-color-hover: var(--color-cell-secondary-2);\r
181
+ --top-popup-background-color-active: var(--color-layer-primary-1);\r
182
+ \r
183
+ --top-popup-border-color: var(--color-line-2-opacity);\r
184
+ --top-popup-title-background-color: var(--color-layer-secondary-1);\r
185
+ \r
186
+ /* суммарный отсуп от каря popup до элемента */\r
187
+ --top-popup-content-padding: calc(var(--top-popup-list-padding) + var(--top-popup-listItem-padding));\r
188
+ \r
189
+ /* списки */\r
190
+ --top-popup-list-padding: var(--top-padding-2);\r
191
+ \r
192
+ --top-popup-listItem-radius: var(--top-radius-2);\r
193
+ --top-popup-listItem-padding: var(--top-padding-2);\r
194
+ }\r
195
+ \r
196
+ .top-popup-front { position: relative; }\r
197
+ \r
198
+ .top-popup-wrapper {\r
199
+ /* см. recalcPosition() */\r
200
+ --top-popup-height: 0px;\r
201
+ --top-popup-right-bounding: 0px;\r
202
+ --top-popup-bottom-bounding: 0px;\r
203
+ --top-popup-top: 0px;\r
204
+ --top-popup-right: calc(100vw - var(--top-popup-right-bounding));\r
205
+ --top-popup-bottom: calc(var(--100vh) - var(--top-popup-bottom-bounding));\r
206
+ --top-popup-left: 0px;\r
207
+ \r
208
+ text-align: initial; white-space: normal; word-break: normal;\r
209
+ position: absolute; z-index: 200000;\r
210
+ }\r
211
+ \r
212
+ .top-popup-wrapper:not(.top-popup-wrapper-shown) { overflow: hidden; }\r
213
+ \r
214
+ /* top-popupPanel */\r
215
+ .top-popupPanel {\r
216
+ cursor: default;\r
217
+ box-shadow: var(--top-shadow-b);\r
218
+ border-radius: 14px;\r
219
+ background: var(--top-popup-background-color);\r
220
+ position: absolute; overflow: hidden;\r
221
+ display: flex; flex-direction: column;\r
222
+ }\r
223
+ \r
224
+ /* position */\r
225
+ .top-popup-wrapper > * {\r
226
+ opacity: 0;\r
227
+ transition: opacity var(--top-popup-transition-delay) linear, transform var(--top-popup-transition-delay) linear;\r
228
+ }\r
229
+ \r
230
+ .top-popup-wrapper.p0 > * { transform: translateY(-8px); }\r
231
+ \r
232
+ .top-popup-wrapper.p1 > * { transform: translateY(8px); }\r
233
+ \r
234
+ .top-popup-wrapper.p2 > * { transform: translateX(8px); }\r
235
+ \r
236
+ .top-popup-wrapper.p3 > * { transform: translateY(8px); }\r
237
+ \r
238
+ .top-popup-wrapper.p4 > * { transform: translateX(-8px); }\r
239
+ \r
240
+ .top-popup-wrapper-shown:not(.top-popup-wrapper-closed) > * {opacity: 1;transform: translate(0, 0) !important;}\r
241
+ \r
242
+ .top-popup-wrapper.p0 > .top-popup { top: calc(-16px); left: calc(0px - 8px); }\r
243
+ \r
244
+ .top-popup-wrapper.p1 > .top-popup { bottom: calc(100% + 8px); }\r
245
+ \r
246
+ .top-popup-wrapper.p2 > .top-popup { left: calc(100% + 8px); }\r
247
+ \r
248
+ .top-popup-wrapper.p3 > .top-popup { top: calc(100% + 8px); }\r
249
+ \r
250
+ .top-popup-wrapper.p4 > .top-popup { right: calc(100% + 8px); }\r
251
+ \r
252
+ .top-popup-wrapper.p2 > .top-popup,\r
253
+ .top-popup-wrapper.p4 > .top-popup { margin-top: -10px; }\r
254
+ \r
255
+ .top-popup-wrapper.p1.with_notch > .top-popup { margin-bottom: 5px; }\r
256
+ \r
257
+ .top-popup-wrapper.p2.with_notch > .top-popup { margin-left: 5px; }\r
258
+ \r
259
+ .top-popup-wrapper.p3.with_notch > .top-popup { margin-top: 5px; }\r
260
+ \r
261
+ .top-popup-wrapper.p4.with_notch > .top-popup { margin-right: 5px; }\r
262
+ \r
263
+ .top-popup-wrapper.invert-x > .top-popup { right: 0; }\r
264
+ \r
265
+ .top-popup-wrapper.invert-y > .top-popup { bottom: 0; }\r
266
+ \r
267
+ /* notch */\r
268
+ .top-popup-wrapper > .notch { border: 7.4px solid transparent; position: absolute; display: block; }\r
269
+ \r
270
+ .top-popup-wrapper.p1 > .notch { border-bottom: 0; border-top: 7.4px solid var(--content-background-color); margin: 0 0 7.4px -7.4px; bottom: 100%; left: 50% }\r
271
+ \r
272
+ .top-popup-wrapper.p2 > .notch { border-left: 0; border-right: 7.4px solid var(--content-background-color); margin: 0 0 -7.4px 7.4px; bottom: 50%; left: 100%; }\r
273
+ \r
274
+ .top-popup-wrapper.p3 > .notch { border-top: 0; border-bottom: 7.4px solid var(--content-background-color); margin: 7.4px 0 0 -7.4px; top: 100%; left: 50%; }\r
275
+ \r
276
+ .top-popup-wrapper.p4 > .notch { border-right: 0; border-left: 7.4px solid var(--content-background-color); margin: 0 7.4px -7.4px 0; bottom: 50%; right: 100%; }\r
277
+ \r
278
+ .top-popup-wrapper.p1 > .notch-border { border-top-color: rgba(0, 0, 0, 0.05); margin-bottom: 6px; }\r
279
+ \r
280
+ .top-popup-wrapper.p2 > .notch-border { border-right-color: rgba(0, 0, 0, 0.05); margin-left: 6px; }\r
281
+ \r
282
+ .top-popup-wrapper.p3 > .notch-border { border-bottom-color: rgba(0, 0, 0, 0.05); margin-top: 6px; }\r
283
+ \r
284
+ .top-popup-wrapper.p4 > .notch-border { border-left-color: rgba(0, 0, 0, 0.05); margin-right: 6px; }\r
285
+ \r
286
+ /* common */\r
287
+ .top-popup_header,\r
288
+ .top-popup_content,\r
289
+ .top-popup_footer { font-size: 14px; }\r
290
+ \r
291
+ .top-popup_header,\r
292
+ .top-popup_footer { display: flex; align-items: center; justify-content: space-between; }\r
293
+ \r
294
+ /* header */\r
295
+ .top-popup_header {\r
296
+ color: var(--color-text-1);\r
297
+ border-bottom: 1px solid var(--top-popup-border-color);\r
298
+ padding: var(--top-padding-3);\r
299
+ font-weight: 600;\r
300
+ }\r
301
+ \r
302
+ .top-popup_header > * { font-weight: 400; }\r
303
+ \r
304
+ .top-popup_header > .a { cursor: pointer;}\r
305
+ \r
306
+ .top-popup_header > .a:hover { color: var(--color-text-primary-2); }\r
307
+ \r
308
+ .top-popup_headerButton { width: 60px; }\r
309
+ \r
310
+ /* widget */\r
311
+ .top-popup_widget {\r
312
+ padding: var(--top-padding-2) var(--top-padding-2) 0 var(--top-padding-2);\r
313
+ }\r
314
+ \r
315
+ /* content */\r
316
+ .top-popup_content {\r
317
+ margin: 0;\r
318
+ flex-grow: 1;\r
319
+ overflow-y: auto;\r
320
+ display: flex;\r
321
+ flex-direction: column;\r
322
+ gap: var(--top-gap-4);\r
323
+ \r
324
+ -webkit-overflow-scrolling: touch;\r
325
+ }\r
326
+ \r
327
+ div.top-popup_content {\r
328
+ color: var(--color-text-1);\r
329
+ padding: var(--top-popup-content-padding);\r
330
+ }\r
331
+ \r
332
+ div.top-popup_content > * { flex-shrink: 0; }\r
333
+ \r
334
+ div.top-popup_content > .top-button { margin: 0; }\r
335
+ \r
336
+ div.top-popup_content .top-unwrap {\r
337
+ --top-unwrap-x: var(--top-popup-content-padding);\r
338
+ }\r
339
+ \r
340
+ ul.top-popup_content {\r
341
+ color: var(--color-text-1);\r
342
+ padding: var(--top-popup-list-padding);\r
343
+ gap: 2px;\r
344
+ }\r
345
+ \r
346
+ ul.top-popup_content .top-unwrap {\r
347
+ --top-unwrap-x: var(--top-popup-list-padding);\r
348
+ }\r
349
+ \r
350
+ .top-popup_listItem {\r
351
+ border-radius: var(--top-popup-listItem-radius);\r
352
+ padding: var(--top-popup-listItem-padding);\r
353
+ line-height: 1 !important;\r
354
+ }\r
355
+ \r
356
+ ul.top-popup_content li { margin: 0; list-style: none; display: flex; position: relative }\r
357
+ \r
358
+ ul.top-popup_content li > * { flex-grow: 1; }\r
359
+ \r
360
+ ul.top-popup_content li > a:not(.top-button),\r
361
+ ul.top-popup_content li > .a {\r
362
+ cursor: pointer;\r
363
+ box-sizing: border-box;\r
364
+ border-radius: var(--top-popup-listItem-radius);\r
365
+ background: var(--top-popup-background-color);\r
366
+ padding: var(--top-popup-listItem-padding);\r
367
+ color: var(--color-text-1) !important; font-size: 14px; font-weight: normal !important; text-decoration: none !important; font-style: normal;\r
368
+ line-height: 1 !important;\r
369
+ display: flex; flex: 1 1 100%; align-items: center;\r
370
+ transition: background-color 0.1s ease-in-out;\r
371
+ }\r
372
+ \r
373
+ .top-popup-wrapper-no_animate ul.top-popup_content li > a:not(.top-button),\r
374
+ .top-popup-wrapper-no_animate ul.top-popup_content li > .a { transition: none; }\r
375
+ \r
376
+ ul.top-popup_content li > a:not(.top-button):hover,\r
377
+ ul.top-popup_content li > .a:hover { background: var(--top-popup-background-color-hover); }\r
378
+ \r
379
+ ul.top-popup_content li > a:not(.top-button).top-active,\r
380
+ ul.top-popup_content li > .a.top-active {\r
381
+ --top-icon-color: var(--color-icon-primary-1) !important;\r
382
+ \r
383
+ background: var(--top-popup-background-color-active);\r
384
+ }\r
385
+ \r
386
+ .top-popup_content + .top-popup_content { padding-top: 0; }\r
387
+ \r
388
+ /* listTitle */\r
389
+ .top-popup_listItem-title {\r
390
+ background: var(--color-layer-secondary-1);\r
391
+ color: var(--color-text-1); font-size: 12px;\r
392
+ }\r
393
+ \r
394
+ /* listDelimiter */\r
395
+ .top-popup_listItem-delimiter {\r
396
+ border-radius: 3px;\r
397
+ background: var(--top-popup-border-color);\r
398
+ height: 1px;\r
399
+ padding: 0;\r
400
+ margin: 4px;\r
401
+ }\r
402
+ \r
403
+ /* listMore */\r
404
+ .top-popup_listMore {\r
405
+ font-size: 20px;\r
406
+ margin: calc(0px - var(--top-popup-listItem-padding)) calc(0px - var(--top-popup-listItem-padding) / 2) calc(0px - var(--top-popup-listItem-padding)) 0;\r
407
+ }\r
408
+ \r
409
+ .top-popup_listMore.top-button { margin: 0; }\r
410
+ \r
411
+ ul.top-popup_content li > .a.top-popup_listMore {\r
412
+ text-align: center;\r
413
+ flex-basis: 10px;\r
414
+ }\r
415
+ \r
416
+ ul.top-popup_content li > .a.top-popup_listMore:before { color: var(--color-icon-2); }\r
417
+ \r
418
+ ul.top-popup_content li > * > .top-popup_listMore {\r
419
+ margin-left: auto;\r
420
+ color: var(--color-layer-secondary-4);\r
421
+ font-size: 14px;\r
422
+ }\r
423
+ \r
424
+ ul.top-popup_content li > * > i.top-popup_listMore:hover,\r
425
+ ul.top-popup_content li > * > i.top-popup_listMore.top-active { color: var(--color-text-primary-1); }\r
426
+ \r
427
+ ul.top-popup_content li > * > i.top-popup_listMore:before {\r
428
+ transform: rotate(90deg);\r
429
+ display: block;\r
430
+ }\r
431
+ \r
432
+ ul.top-popup_content li a.close { background: none !important; }\r
433
+ \r
434
+ /* data-top-icon */\r
435
+ .top-popup_content > [data-top-icon]:before {\r
436
+ --top-icon-size: 20px;\r
437
+ }\r
438
+ \r
439
+ ul.top-popup_content li > [data-top-icon]:not(.top-button) {\r
440
+ --top-icon-color: var(--color-icon-3);\r
441
+ --top-icon-size: 20px;\r
442
+ --top-icon-width: 20px;\r
443
+ }\r
444
+ \r
445
+ ul.top-popup_content li > [data-top-icon]:not(.top-button):before {\r
446
+ height: 1rem; margin-right: 8px; transition: color 0.1s;\r
447
+ }\r
448
+ \r
449
+ ul.top-popup_content li:hover > [data-top-icon]:not(.top-button) {\r
450
+ --top-icon-color: var(--color-icon-2);\r
451
+ }\r
452
+ \r
453
+ /* footer */\r
454
+ .top-popup_footer {\r
455
+ padding: var(--top-popup-list-padding);\r
456
+ border-top: 1px solid var(--top-popup-border-color);\r
457
+ display: flex;\r
458
+ gap: var(--top-gap-2);\r
459
+ justify-content: flex-end;\r
460
+ }\r
461
+ \r
462
+ /* Виджеты */\r
463
+ .top-popup > [data-widget] { padding: 0 var(--top-popup-list-padding); }\r
464
+ \r
465
+ .top-popup > [data-widget] + hr { margin: 0 var(--top-popup-list-padding); }\r
466
+ \r
467
+ .top-popup .placeholder {\r
468
+ border: 1px solid #E0D9D9 !important; border-right: none !important; border-left: none !important; background: #F9F9F9 !important; margin: -1px 0; z-index: 1;\r
469
+ position: relative;\r
470
+ }\r
471
+ \r
472
+ /* компоненты */\r
473
+ .top-popup-wrapper.simple_list > .top-popup { min-width: 0; white-space: nowrap; }\r
474
+ \r
475
+ .top-popup_content .top-column { display: flex; flex-direction: column; gap: 4px; }\r
476
+ \r
477
+ html .top-popup .top-popup_content li > .top-button {\r
478
+ margin: calc(var(--top-popup-listItem-padding) / 2) var(--top-popup-listItem-padding);\r
479
+ }\r
480
+ \r
481
+ .top-popup li .check_all,\r
482
+ .top-popup li .clear_all { cursor: pointer; color: var(--color-text-primary-1); padding: 8px; display: inline-block; }\r
483
+ \r
484
+ .top-popup li .check_all:hover,\r
485
+ .top-popup li .clear_all:hover { text-decoration: underline; }\r
486
+ \r
487
+ .top-popup li .clear_all { display: none; }\r
488
+ \r
489
+ /* table */\r
490
+ .top-popup_content table { margin: -9px 0; }\r
491
+ \r
492
+ .top-popup_content table td,\r
493
+ .top-popup_content table th { padding: 9px var(--top-popup-listItem-padding) 9px 0; vertical-align: top; }\r
494
+ \r
495
+ .top-popup_content table th { width: 40%; font-weight: 600; white-space: nowrap; }\r
496
+ \r
497
+ /* формы */\r
498
+ ul.top-popup_content .a > [type="checkbox"],\r
499
+ ul.top-popup_content .a > [type="radio"] { margin: -8px 0 -8px auto; }\r
500
+ \r
501
+ /* deprecated */\r
502
+ ul.top-popup_content a > [class*=icon],\r
503
+ ul.top-popup_content i.a > [class*=icon] {\r
504
+ transition: 0.1s;\r
505
+ }\r
506
+ \r
507
+ .top-popup .buttons { border-radius: 0 0 4px 4px; border-top: 1px solid #BDC3C7; background: #ECF0F1; padding: 10px 15px; margin: 10px -15px -10px -15px; white-space: nowrap; }\r
508
+ \r
509
+ .top-popup_footer [class*=btn]:not(.btn-transparent) { min-width: 100px; padding: 5px 14px; margin-left: 10px; }\r
510
+ \r
511
+ .top-popup_footer [class*=btn]:first-child { margin-left: 0; }\r
512
+ \r
513
+ .top-popup_footer .btn.full_width { margin: 0; flex-grow: 1; }`, _ = `:root{\r
514
+ --top-popup-list-padding: 0px;\r
515
+ \r
516
+ --top-popup-listItem-radius: 0px;\r
517
+ --top-popup-listItem-padding: var(--top-padding-4);\r
518
+ }\r
519
+ \r
520
+ html.with_popup{ background: #808080; }\r
521
+ \r
522
+ .top-popup-wrapper{\r
523
+ --top-popup-footer-offset: 25px;\r
524
+ \r
525
+ width: auto !important; height: auto !important;\r
526
+ position: fixed; top: 0 !important; right: 0 !important; left: 0 !important; overflow: hidden;\r
527
+ transition: background 0.3s;\r
528
+ }\r
529
+ \r
530
+ .top-popup-wrapper-shown:not(.top-popup-wrapper-closed){ background: rgba(0,0,0,0.5); backdrop-filter: blur(1px); }\r
531
+ .top-popup-wrapper-shown:not(.top-popup-wrapper-closed) > .top-popup{ opacity: 1 !important; }\r
532
+ \r
533
+ .top-popup{\r
534
+ border-radius: 8px 8px 0 0; width: auto !important; max-height: calc(100% - var(--header-height, 0px) - var(--toolbar-height, 0px) - 12px); margin: 0 !important;\r
535
+ top: auto !important; right: 0 !important; bottom: var(--toolbar-height, 0px) !important; left: 0 !important;\r
536
+ display: flex; flex-direction: column;\r
537
+ \r
538
+ /* невозможно опустить элемент вниз за экран на 100%, fix: opacity и translateY(80%) */\r
539
+ transform: translateY(80%);\r
540
+ \r
541
+ transition: opacity 0.3s, transform 0.3s;\r
542
+ }\r
543
+ \r
544
+ \r
545
+ /* from top */\r
546
+ .top-popup-wrapper.p-from-top{\r
547
+ --top-popup-footer-offset: 0px;\r
548
+ \r
549
+ top: var(--header-height, 0px) !important;\r
550
+ }\r
551
+ .with_dialog .top-popup-wrapper.p-from-top{ top: 50px !important; }\r
552
+ .top-popup-wrapper.p-from-top > .top-popup{\r
553
+ border-radius: 0 0 8px 8px; max-height: calc(100% - 24px); top: 0 !important; bottom: auto !important;\r
554
+ transform: translateY(calc(-100% - 24px));\r
555
+ }\r
556
+ \r
557
+ /* widget */\r
558
+ .top-popup_widget{ padding: var(--top-padding-2);}\r
559
+ .top-popup_widget:not(.p-from-top){ order: 10; }\r
560
+ \r
561
+ /* content */\r
562
+ ul.top-popup_content{\r
563
+ gap: 0;\r
564
+ }\r
565
+ ul.top-popup_content li:not(:last-child){ border-bottom: 1px solid var(--top-popup-border-color); }\r
566
+ \r
567
+ .top-popup-wrapper.top-style_alt > .top-popup > ul > li{ border-bottom: none; }\r
568
+ \r
569
+ /* footer */\r
570
+ .top-popup_footer{\r
571
+ flex-direction: column-reverse;\r
572
+ }\r
573
+ .top-popup_footer > .top-button{\r
574
+ --top-forms-base-height: var(--top-forms-base-height_l);\r
575
+ \r
576
+ width: 100%;\r
577
+ }\r
578
+ \r
579
+ /* listTitle */\r
580
+ ul.top-popup_content .top-popup_listItem-title{\r
581
+ --top-popup-padding-v: 12px;\r
582
+ }\r
583
+ \r
584
+ /* listDelimiter */\r
585
+ ul.top-popup_content .top-popup_listItem-delimiter{ background: var(--color-line-1-opacity); height: 4px; margin: 0; }\r
586
+ ul.top-popup_content li:first-child > .top-popup_listItem-delimiter{ border-top: 1px solid var(--top-popup-border-color); }`, L = `html:not(.with_dialog){ margin-right: 0 !important; }\r
587
+ \r
588
+ .top-popup{ min-width: 250px; max-width: calc(100vw - var(--top-popup-left) - 16px); max-height: calc(var(--top-popup-bottom) + var(--top-popup-height)); }\r
589
+ .top-popup-wrapper.invert-x > .top-popup{ max-width: calc(100vw - var(--top-popup-right) - 16px); }\r
590
+ .top-popup-wrapper.invert-y > .top-popup{ max-height: calc(100vh - var(--top-popup-bottom) - 16px); }\r
591
+ \r
592
+ /* position */\r
593
+ .top-popup-wrapper.p1 > .top-popup{ max-height: calc(var(--top-popup-top) - var(--header-height, 0px) - 16px); }\r
594
+ .top-popup-wrapper.p3 > .top-popup{ max-height: calc(var(--top-popup-bottom) - 16px); }\r
595
+ .top-popup-wrapper.p2 > .top-popup{ max-width: calc(var(--top-popup-right) - 16px); }\r
596
+ .top-popup-wrapper.p4 > .top-popup{ max-width: calc(var(--top-popup-left) - 16px); }\r
597
+ \r
598
+ /* notch */\r
599
+ .top-popup-wrapper.p1.with_notch > .top-popup,\r
600
+ .top-popup-wrapper.p3.with_notch > .top-popup{ margin-left: -16px !important; }\r
601
+ .top-popup-wrapper.p1.with_notch > .notch,\r
602
+ .top-popup-wrapper.p3.with_notch > .notch{ margin-left: -8px !important; }\r
603
+ \r
604
+ .top-popup-wrapper.p1.with_notch.invert-x,\r
605
+ .top-popup-wrapper.p3.with_notch.invert-x{ margin-left: 3px !important; }\r
606
+ .top-popup-wrapper.p1.with_notch.invert-x > .notch,\r
607
+ .top-popup-wrapper.p3.with_notch.invert-x > .notch{ margin-left: -9px !important; }\r
608
+ \r
609
+ /* listMore */\r
610
+ ul.top-popup_content li > * > i.top-popup_listMore{ visibility: hidden; transition: none; }\r
611
+ ul.top-popup_content li:hover > * > i.top-popup_listMore,\r
612
+ ul.top-popup_content li > *.top-active > i.top-popup_listMore,\r
612
613
  ul.top-popup_content li > * > i.top-popup_listMore.top-active{ visibility: visible; }`;
613
- f.appendStyle(w);
614
- f.appendStyle(y, "m");
615
- f.appendStyle(_, "pc");
614
+ f.appendStyle(y);
615
+ f.appendStyle(_, "m");
616
+ f.appendStyle(L, "pc");
616
617
  class x extends v {
617
618
  static componentName = "Popup";
618
619
  // элемент, вызвавший открытие Popup
@@ -661,8 +662,7 @@ class x extends v {
661
662
  // использовать оригинальный шаблон, без клонирвоания (для сохранения состояния меню)
662
663
  transitionDuration: 100,
663
664
  // значение прописано в css
664
- isFullScreen: !1,
665
- i18n: {}
665
+ isFullScreen: !1
666
666
  };
667
667
  events = {};
668
668
  // el - элемент, открывающий меню
@@ -670,22 +670,22 @@ class x extends v {
670
670
  return super(), this.init(x.componentName, t, p);
671
671
  }
672
672
  async mount() {
673
- var e, r, s, a;
673
+ var e, i;
674
674
  if (!(this.el instanceof HTMLElement)) return;
675
675
  const t = this.vueGetComponent();
676
- if (this.el.closest(".top-popup-wrapper") && (this.popupParent = l.getPopup(this.el.closest(".top-popup-wrapper"))), await this.mountJQuery(), n.css(this.el, "position") !== "absolute" && (this.el.style.position = "relative"), this.el.dataset.topPopupOpened = "opened", this.elActiveByDefault = this.el.classList.contains("top-active"), this.el.classList.add("top-active"), t)
677
- this.type = "vue", this.options.popup = "", this.elPopup = n.genEl("div", {}, this.options.popup);
676
+ if (this.el.closest(".top-popup-wrapper") && (this.popupParent = s.getPopup(this.el.closest(".top-popup-wrapper"))), await this.mountJQuery(), r.css(this.el, "position") !== "absolute" && (this.el.style.position = "relative"), this.el.dataset.topPopupOpened = "opened", this.elActiveByDefault = this.el.classList.contains("top-active"), this.el.classList.add("top-active"), t)
677
+ this.type = "vue", this.options.popup = "", this.elPopup = r.genEl("div", {}, this.options.popup);
678
678
  else if ((e = this.options.popup) != null && e.match(/^[#.]/))
679
679
  this.type = "selector", this.elPopup = document.querySelector(`${this.options.popup}.template`);
680
680
  else {
681
681
  if (this.type = "html", this.options.useOriginal)
682
682
  throw "Option useOriginal not allowed for text templates";
683
- this.elPopup = n.genEl("div", {}, this.options.popup ?? "");
683
+ this.elPopup = r.genEl("div", {}, this.options.popup ?? "");
684
684
  }
685
685
  if (!this.elPopup || t != null && t.opened) {
686
686
  if (this.options.useOriginal || t != null && t.opened) {
687
687
  if (t != null && t.opened ? this.elPopup = t.popup.elPopup : this.elPopup = document.querySelector(`${this.options.popup}.top-popup-wrapper-shown`), this.elPopup) {
688
- this.el.dataset.topPopupOpened = "", this.elActiveByDefault || this.el.classList.remove("top-active"), l.close(this.elPopup), setTimeout(() => this.mount(), this.options.transitionDuration);
688
+ this.el.dataset.topPopupOpened = "", this.elActiveByDefault || this.el.classList.remove("top-active"), s.close(this.elPopup), setTimeout(() => this.mount(), this.options.transitionDuration);
689
689
  return;
690
690
  }
691
691
  throw "Option useOriginal state allowed only elements .template";
@@ -694,25 +694,29 @@ class x extends v {
694
694
  }
695
695
  if (!this.elPopup)
696
696
  return;
697
- for (this.options.useOriginal ? (this.elStartPosition = this.elPopup.closest(".top-popup-el-start-position"), this.elStartPosition || (this.elStartPosition = n.wrap(this.elPopup, "i"), this.elStartPosition.classList.add("top-popup-el-start-position", "hidden"))) : (this.elPopup = this.elPopup.cloneNode(!0), this.type === "selector" && !this.elPopup.matches(".template") && (this.elPopup.classList.remove("hidden"), this.elPopup.querySelector(":scope > .top-popup_content") || this.elPopup.classList.add("top-popup_content"), this.elPopup = n.wrap(this.elPopup, "div")), this.type === "html" && (this.elPopup.querySelector(":scope > .top-popup_content") || (this.elPopup.classList.add("top-popup_content"), this.elPopup = n.wrap(this.elPopup, "div"))), (this.type === "selector" && !this.elPopup.matches(".template") || this.type === "html" || this.type === "vue") && (n.querySelectorAllArray(this.elPopup, "[data-top-popup]").forEach((i) => {
698
- i instanceof HTMLElement && (i.dataset.topPopupPosBy = "fixed");
699
- }), n.querySelectorAllArray(this.elPopup, ".top-popup-wrapper").forEach((i) => i.remove()))), l.decoratorBeforeOpen(this), t && (this.options.class = t.classRef.value, t.transitionDurationRef.value !== void 0 && (this.options.transitionDuration = t.transitionDurationRef.value, this.elPopup instanceof HTMLElement && this.elPopup.style.setProperty(
697
+ for (this.options.useOriginal ? (this.elStartPosition = this.elPopup.closest(".top-popup-el-start-position"), this.elStartPosition || (this.elStartPosition = r.wrap(this.elPopup, "i"), this.elStartPosition.classList.add("top-popup-el-start-position", "hidden"))) : (this.elPopup = this.elPopup.cloneNode(!0), this.type === "selector" && !this.elPopup.matches(".template") && (this.elPopup.classList.remove("hidden"), this.elPopup.querySelector(":scope > .top-popup_content") || this.elPopup.classList.add("top-popup_content"), this.elPopup = r.wrap(this.elPopup, "div")), this.type === "html" && (this.elPopup.querySelector(":scope > .top-popup_content") || (this.elPopup.classList.add("top-popup_content"), this.elPopup = r.wrap(this.elPopup, "div"))), (this.type === "selector" && !this.elPopup.matches(".template") || this.type === "html" || this.type === "vue") && (r.querySelectorAllArray(this.elPopup, "[data-top-popup]").forEach((n) => {
698
+ n instanceof HTMLElement && (n.dataset.topPopupPosBy = "fixed");
699
+ }), r.querySelectorAllArray(this.elPopup, ".top-popup-wrapper").forEach((n) => n.remove()))), s.decoratorBeforeOpen(this), t && (this.options.class = t.classRef.value, t.transitionDurationRef.value !== void 0 && (this.options.transitionDuration = t.transitionDurationRef.value, this.elPopup instanceof HTMLElement && this.elPopup.style.setProperty(
700
700
  "--top-popup-transition-delay",
701
701
  this.options.transitionDuration + "ms"
702
702
  ))), this.elPopupInner = document.createElement("div"), this.elPopupInner.classList.add("top-popupPanel", "top-popup"); this.elPopup.firstChild; )
703
703
  this.elPopupInner.appendChild(this.elPopup.firstChild);
704
704
  if (this.elPopup.append(this.elPopupInner), this.elPopup.classList.add("top-popup-wrapper"), this.options.class) {
705
- const i = this.options.class.split(" ");
706
- this.elPopup.classList.add(...i);
705
+ const n = this.options.class.split(" ");
706
+ this.elPopup.classList.add(...n);
707
707
  }
708
708
  this.options.notch && (this.elPopup.classList.add("with_notch"), this.elPopup.insertAdjacentHTML("beforeend", '<i class="notch notch-border"></i><i class="notch"></i>')), await this.vueOpen(), this.elPopupHeader = this.elPopupInner.querySelector(".top-popup_header"), this.elPopupWidget = this.elPopupInner.querySelector(".top-popup_widget"), this.elPopupBody = this.elPopupInner.querySelector(".top-popup_content"), this.elPopupFooter = this.elPopupInner.querySelector(".top-popup_footer");
709
709
  const p = !!this.elPopup.querySelector('[data-widget="search"]');
710
- this.options.isFullScreen && !p && !this.elPopupHeader && (r = this.options.i18n) != null && r.Close && (this.elPopupHeader = n.genEl("i", { class: "top-popup_header" }), this.elPopupInner.prepend(this.elPopupHeader), this.elPopupHeader.prepend(n.genEl("i", { class: "a closer" }, (s = this.options.i18n) == null ? void 0 : s.Close)), this.elPopupHeader.append(n.genEl("i", { class: "top-popup_headerButton" }))), n.storage(this.elPopup, "Popup", this), this.options.frontSelector && (this.elFront = document.querySelector(this.options.frontSelector)), this.elFront || (this.elFront = this.el.closest(".top-popup-front")), this.elFront || (this.elFront = document.body), this.elPopup instanceof HTMLElement && (this.elPopup.style.width = this.el.offsetWidth + "px", this.elPopup.style.height = this.el.offsetHeight + "px", this.elPopup.style.top = this.el.offsetTop + "px", this.elPopup.style.right = parseInt(this.el.style.right || "0") + "px", this.elPopup.style.bottom = parseInt(this.el.style.bottom || "0") + "px"), (a = this.el.parentElement) == null || a.insertBefore(this.elPopup, this.el), this.elPopup.classList.remove("template"), this.options.invertX && this.elPopup.classList.add("invert-x");
710
+ if (this.options.isFullScreen && !p) {
711
+ const n = P();
712
+ !this.elPopupHeader && n.Common.Close && (this.elPopupHeader = r.genEl("i", { class: "top-popup_header" }), this.elPopupInner.prepend(this.elPopupHeader), this.elPopupHeader.prepend(r.genEl("i", { class: "a closer" }, n.Common.Close)), this.elPopupHeader.append(r.genEl("i", { class: "top-popup_headerButton" })));
713
+ }
714
+ r.storage(this.elPopup, "Popup", this), this.options.frontSelector && (this.elFront = document.querySelector(this.options.frontSelector)), this.elFront || (this.elFront = this.el.closest(".top-popup-front")), this.elFront || (this.elFront = document.body), this.elPopup instanceof HTMLElement && (this.elPopup.style.width = this.el.offsetWidth + "px", this.elPopup.style.height = this.el.offsetHeight + "px", this.elPopup.style.top = this.el.offsetTop + "px", this.elPopup.style.right = parseInt(this.el.style.right || "0") + "px", this.elPopup.style.bottom = parseInt(this.el.style.bottom || "0") + "px"), (i = this.el.parentElement) == null || i.insertBefore(this.elPopup, this.el), this.elPopup.classList.remove("template"), this.options.invertX && this.elPopup.classList.add("invert-x");
711
715
  let o = !!this.el.closest(".modal-header");
712
716
  o || (o = !!this.el.closest("#top_panel")), o || (o = !!this.el.closest("#secondmenu")), o && this.elPopup.classList.add("p-from-top"), setTimeout(() => {
713
- var i;
714
- return (i = this.elPopup) == null ? void 0 : i.classList.add("top-popup-wrapper-shown");
715
- }), this.elFront && !this.elFront.matches("body") && (this.elFront.append(this.elPopup), this.shift.top = n.offset(this.el).top - this.el.offsetTop - n.offset(this.elFront).top, this.shift.left = n.offset(this.el).left - this.el.offsetLeft - n.offset(this.elFront).left, this.shift.top -= parseInt(this.el.style["margin-top"] || 0), this.shift.left -= parseInt(this.el.style["margin-left"] || 0), this.elPopup instanceof HTMLElement && (this.elPopup.style.top = parseInt(this.elPopup.style.top || "0") + this.shift.top + "px", this.elPopup.style.left = parseInt(this.elPopup.style.left || "0") + this.shift.left + "px")), this.$ && f.$ && this.$.trigger("aftershow.top-menu-popup", [f.$(this.elPopup)]), this.recalcPosition(), this.elPopup.setAttribute("tabindex", "0"), this.focus(), l.decoratorAfterOpen(this), this.mountEvents();
717
+ var n;
718
+ return (n = this.elPopup) == null ? void 0 : n.classList.add("top-popup-wrapper-shown");
719
+ }), this.elFront && !this.elFront.matches("body") && (this.elFront.append(this.elPopup), this.shift.top = r.offset(this.el).top - this.el.offsetTop - r.offset(this.elFront).top, this.shift.left = r.offset(this.el).left - this.el.offsetLeft - r.offset(this.elFront).left, this.shift.top -= parseInt(this.el.style["margin-top"] || 0), this.shift.left -= parseInt(this.el.style["margin-left"] || 0), this.elPopup instanceof HTMLElement && (this.elPopup.style.top = parseInt(this.elPopup.style.top || "0") + this.shift.top + "px", this.elPopup.style.left = parseInt(this.elPopup.style.left || "0") + this.shift.left + "px")), this.$ && f.$ && this.$.trigger("aftershow.top-menu-popup", [f.$(this.elPopup)]), this.recalcPosition(), this.elPopup.setAttribute("tabindex", "0"), this.focus(), s.decoratorAfterOpen(this), this.mountEvents();
716
720
  }
717
721
  async mountJQuery() {
718
722
  f.$ && (this.$ = f.$(this.el));
@@ -722,7 +726,7 @@ class x extends v {
722
726
  */
723
727
  focus() {
724
728
  let t;
725
- this.elPopup && (t = n.querySelectorVisible(this.elPopup, ".top-popup-autofocus"), t || (t = n.querySelectorVisible(this.elPopup, ":read-write, select:not(:disabled)")), t || (t = n.querySelectorVisible(this.elPopup, ".top-popup_footer .top-button")), t || (t = this.elPopup), t instanceof HTMLElement && t.focus(), setTimeout(() => {
729
+ this.elPopup && (t = r.querySelectorVisible(this.elPopup, ".top-popup-autofocus"), t || (t = r.querySelectorVisible(this.elPopup, ":read-write, select:not(:disabled)")), t || (t = r.querySelectorVisible(this.elPopup, ".top-popup_footer .top-button")), t || (t = this.elPopup), t instanceof HTMLElement && t.focus(), setTimeout(() => {
726
730
  t instanceof HTMLElement && t.focus();
727
731
  }, this.options.transitionDuration));
728
732
  }
@@ -735,8 +739,8 @@ class x extends v {
735
739
  onMousedown(t) {
736
740
  if (!this.elPopup || !(t.target instanceof Element) || !this.isFirstClick || (this.isFirstClick = !1, setTimeout(() => this.isFirstClick = !0), t instanceof MouseEvent && t.button !== 0))
737
741
  return;
738
- let p = n.querySelectorVisibleLast(document.body, ":scope > .top-popup-wrapper");
739
- p && p !== this.elPopup || t.target.closest(".top-popup-front") && (p = n.querySelectorVisibleLast(t.target.closest(".top-popup-front"), ":scope > .top-popup-wrapper"), p && p !== this.elPopup) || this.elPopup.contains(t.target) || this.elPopup.closest(".ui-dialog") && !t.target.closest(".ui-dialog") || l.decoratorIsIgnoreOuterClick(t) || l.close(this.elPopup);
742
+ let p = r.querySelectorVisibleLast(document.body, ":scope > .top-popup-wrapper");
743
+ p && p !== this.elPopup || t.target.closest(".top-popup-front") && (p = r.querySelectorVisibleLast(t.target.closest(".top-popup-front"), ":scope > .top-popup-wrapper"), p && p !== this.elPopup) || this.elPopup.contains(t.target) || this.elPopup.closest(".ui-dialog") && !t.target.closest(".ui-dialog") || s.decoratorIsIgnoreOuterClick(t) || s.close(this.elPopup);
740
744
  }
741
745
  /**
742
746
  * Закрыть другие Popup при фокусе на элемент формы в текущем
@@ -744,9 +748,9 @@ class x extends v {
744
748
  onFocus(t) {
745
749
  if (t.target instanceof Element && t.target.matches("input") || this.isClosed)
746
750
  return;
747
- l.getAllVisible().forEach((o) => {
748
- var e, r, s, a;
749
- (e = this.elPopup) != null && e.contains(o) || ((r = this.popupParent) == null ? void 0 : r.elPopup) === o || ((a = (s = this.popupParent) == null ? void 0 : s.popupParent) == null ? void 0 : a.elPopup) === o || l.close(o);
751
+ s.getAllVisible().forEach((o) => {
752
+ var e, i, n, u;
753
+ (e = this.elPopup) != null && e.contains(o) || ((i = this.popupParent) == null ? void 0 : i.elPopup) === o || ((u = (n = this.popupParent) == null ? void 0 : n.popupParent) == null ? void 0 : u.elPopup) === o || s.close(o);
750
754
  });
751
755
  }
752
756
  /**
@@ -754,14 +758,14 @@ class x extends v {
754
758
  */
755
759
  onMouseleave(t) {
756
760
  setTimeout(() => {
757
- this.elPopupInner && this.elPopupInner.matches(":hover") || !this.elPopup || l.close(this.elPopup);
761
+ this.elPopupInner && this.elPopupInner.matches(":hover") || !this.elPopup || s.close(this.elPopup);
758
762
  }, 100);
759
763
  }
760
764
  /**
761
765
  * Контроль положения Popup при fixed позиционировании
762
766
  */
763
767
  onResize() {
764
- this.elPopup && this.elPopup.parentElement !== document.body && document.body.append(this.elPopup), this.elPopup instanceof HTMLElement && (this.elPopup.style.top = n.offset(this.el).top + "px", this.elPopup.style.left = n.offset(this.el).left + "px");
768
+ this.elPopup && this.elPopup.parentElement !== document.body && document.body.append(this.elPopup), this.elPopup instanceof HTMLElement && (this.elPopup.style.top = r.offset(this.el).top + "px", this.elPopup.style.left = r.offset(this.el).left + "px");
765
769
  }
766
770
  unmount() {
767
771
  super.unmount(), this.el instanceof HTMLElement && (this.el.dataset.topPopupOpened = ""), this.elActiveByDefault || this.el.classList.remove("top-active");
@@ -790,16 +794,16 @@ class x extends v {
790
794
  }
791
795
  const o = this.elPopup.getBoundingClientRect();
792
796
  this.elPopup.style.setProperty("--top-popup-height", this.elPopup.offsetHeight + "px"), this.elPopup.style.setProperty("--top-popup-right-bounding", o.right + "px"), this.elPopup.style.setProperty("--top-popup-bottom-bounding", o.bottom + "px"), this.elPopup.style.setProperty("--top-popup-top", o.top + "px"), this.elPopup.style.setProperty("--top-popup-left", o.left + "px"), this.elPopupInner instanceof HTMLElement && (this.elPopupInner.style.maxWidth = "unset", this.elPopupInner.style.maxHeight = "unset");
793
- let e = !1, r = !1, s = !1, a = !1, i = o.left > window.innerWidth / 2, d = o.top > window.innerHeight / 2;
794
- t === 4 && (i = !i), t === 1 && (d = !d);
797
+ let e = !1, i = !1, n = !1, u = !1, l = o.left > window.innerWidth / 2, d = o.top > window.innerHeight / 2;
798
+ t === 4 && (l = !l), t === 1 && (d = !d);
795
799
  const h = (b = this.elPopupInner) == null ? void 0 : b.getBoundingClientRect();
796
- let u, c;
800
+ let a, c;
797
801
  if (h) {
798
- u = window.innerWidth - h.right, c = window.innerHeight - h.bottom;
802
+ a = window.innerWidth - h.right, c = window.innerHeight - h.bottom;
799
803
  const g = 8;
800
- h.top < g && (e = !0), u < g && (r = !0), c < g && (s = !0), h.left < g && (a = !0);
804
+ h.top < g && (e = !0), a < g && (i = !0), c < g && (n = !0), h.left < g && (u = !0);
801
805
  }
802
- e && (t === 0 || t === 1) && d && (t = 3), s && t === 3 && d && (t = 1), r && t === 2 && i && (t = 4), a && t === 4 && i && (t = 2), r && (t === 0 || t === 1 || t === 3) && this.elPopup.classList.add("invert-x"), s && (t === 2 || t === 4) && d && (t === 2 && !i && this.elPopup.classList.add("invert-y"), t === 4 && !i && this.elPopup.classList.add("invert-x"), this.elPopup.matches(".invert-y") || (t = 1)), this.elPopup.classList.remove("p0", "p1", "p2", "p3", "p4"), this.elPopup.classList.add("p" + t), this.elPopupInner instanceof HTMLElement && (this.elPopupInner.style.maxWidth = "", this.elPopupInner.style.maxHeight = ""), l.scrollToActive(this.elPopup);
806
+ e && (t === 0 || t === 1) && d && (t = 3), n && t === 3 && d && (t = 1), i && t === 2 && l && (t = 4), u && t === 4 && l && (t = 2), i && (t === 0 || t === 1 || t === 3) && this.elPopup.classList.add("invert-x"), n && (t === 2 || t === 4) && d && (t === 2 && !l && this.elPopup.classList.add("invert-y"), t === 4 && !l && this.elPopup.classList.add("invert-x"), this.elPopup.matches(".invert-y") || (t = 1)), this.elPopup.classList.remove("p0", "p1", "p2", "p3", "p4"), this.elPopup.classList.add("p" + t), this.elPopupInner instanceof HTMLElement && (this.elPopupInner.style.maxWidth = "", this.elPopupInner.style.maxHeight = ""), s.scrollToActive(this.elPopup);
803
807
  }
804
808
  onTouchmove(t) {
805
809
  var p, o, e;
@@ -811,12 +815,12 @@ class x extends v {
811
815
  }
812
816
  close() {
813
817
  var t;
814
- this.isClosed || (this.isClosed = !0, this.$ && f.$ && this.elPopup && this.$.trigger("afterclose.top-menu-popup", [f.$(this.elPopup)]), !l.noClose && (this.unmount(), (t = this.elPopup) == null || t.classList.add("top-popup-wrapper-closed"), setTimeout(() => {
815
- var e, r, s, a, i;
818
+ this.isClosed || (this.isClosed = !0, this.$ && f.$ && this.elPopup && this.$.trigger("afterclose.top-menu-popup", [f.$(this.elPopup)]), !s.noClose && (this.unmount(), (t = this.elPopup) == null || t.classList.add("top-popup-wrapper-closed"), setTimeout(() => {
819
+ var e, i, n, u, l;
816
820
  if (this.vueClose(), !this.elPopup) return;
817
- this.options.useOriginal ? (this.elPopup.removeAttribute("style"), this.elPopup.classList.remove("top-popup-wrapper-shown", "top-popup-wrapper-closed"), this.elPopup.classList.add("template"), (e = this.elStartPosition) == null || e.append(this.elPopup), (r = this.elPopup.querySelector("div.top-popup_content.top-column")) == null || r.classList.remove("top-column"), (s = this.elPopup.querySelector(".notch-border")) == null || s.remove(), (a = this.elPopup.querySelector(".notch")) == null || a.remove(), (i = this.elPopupInner) == null || i.replaceWith(...this.elPopupInner.childNodes), n.storageClear(this.elPopup)) : (n.storageClear(this.elPopup), this.elPopup.remove(), delete this.elPopup);
818
- const p = l.getAllVisible(), o = p.length && p[p.length - 1];
819
- o ? l.getPopup(o).focus() : document.documentElement.classList.remove("with_popup");
821
+ this.options.useOriginal ? (this.elPopup.removeAttribute("style"), this.elPopup.classList.remove("top-popup-wrapper-shown", "top-popup-wrapper-closed"), this.elPopup.classList.add("template"), (e = this.elStartPosition) == null || e.append(this.elPopup), (i = this.elPopup.querySelector("div.top-popup_content.top-column")) == null || i.classList.remove("top-column"), (n = this.elPopup.querySelector(".notch-border")) == null || n.remove(), (u = this.elPopup.querySelector(".notch")) == null || u.remove(), (l = this.elPopupInner) == null || l.replaceWith(...this.elPopupInner.childNodes), r.storageClear(this.elPopup)) : (r.storageClear(this.elPopup), this.elPopup.remove(), delete this.elPopup);
822
+ const p = s.getAllVisible(), o = p.length && p[p.length - 1];
823
+ o ? s.getPopup(o).focus() : document.documentElement.classList.remove("with_popup");
820
824
  }, this.options.transitionDuration)));
821
825
  }
822
826
  async vueOpen() {
@@ -829,12 +833,12 @@ class x extends v {
829
833
  }
830
834
  // получить vueConnectors компонента Popup
831
835
  vueGetComponent() {
832
- if (this.el instanceof HTMLElement) return l.vueConnectors.get(this.el.dataset.topPopupId);
836
+ if (this.el instanceof HTMLElement) return s.vueConnectors.get(this.el.dataset.topPopupId);
833
837
  }
834
838
  }
835
- P.init();
839
+ w.init();
836
840
  export {
837
841
  x as Popup,
838
842
  x as default
839
843
  };
840
- //# sourceMappingURL=popup-DUd8G4iQ.es.js.map
844
+ //# sourceMappingURL=popup-brcaxiWt.es.js.map