@topvisor/ui 0.0.41 → 0.0.43

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (159) hide show
  1. package/.chunks/datepicker-92744062.es.js +275 -0
  2. package/.chunks/datepicker-92744062.es.js.map +1 -0
  3. package/.chunks/datepicker-a9226b0f.amd.js +234 -0
  4. package/.chunks/datepicker-a9226b0f.amd.js.map +1 -0
  5. package/.chunks/{forms-7f061546.es.js → forms-727cc6aa.es.js} +51 -47
  6. package/.chunks/forms-727cc6aa.es.js.map +1 -0
  7. package/.chunks/forms-771091d4.amd.js +3 -0
  8. package/.chunks/forms-771091d4.amd.js.map +1 -0
  9. package/.chunks/{popup-05538243.es.js → popup-a622fe31.es.js} +429 -427
  10. package/.chunks/popup-a622fe31.es.js.map +1 -0
  11. package/.chunks/popup-de28e508.amd.js +377 -0
  12. package/.chunks/popup-de28e508.amd.js.map +1 -0
  13. package/README.md +80 -80
  14. package/assets/core.css +1 -1
  15. package/assets/forms.css +1 -1
  16. package/build/cssModules.d.ts +13 -0
  17. package/build/plugin/amdFix.d.ts +8 -0
  18. package/build/plugin/autoloadCSS.d.ts +19 -0
  19. package/build/rollup.config.d.ts +15 -0
  20. package/common/common.d.ts +1 -0
  21. package/core/core.amd.js +1 -1
  22. package/core/core.d.ts +3 -0
  23. package/core/core.js +1 -1
  24. package/forms/forms.amd.js +1 -1
  25. package/forms/forms.d.ts +1 -0
  26. package/forms/forms.js +1 -1
  27. package/forms/helpers.amd.js.map +1 -1
  28. package/forms/helpers.d.ts +1 -0
  29. package/forms/helpers.js.map +1 -1
  30. package/formsExt/formsExt.amd.js +1 -1
  31. package/formsExt/formsExt.amd.js.map +1 -1
  32. package/formsExt/formsExt.d.ts +1 -0
  33. package/formsExt/formsExt.js +1 -1
  34. package/formsExt/formsExt.js.map +1 -1
  35. package/icomoon/demo-files/demo.css +161 -161
  36. package/icomoon/demo-files/demo.js +30 -30
  37. package/icomoon/demo.html +2945 -2945
  38. package/icomoon/fonts/Topvisor-2.svg +232 -232
  39. package/icomoon/style.css +647 -647
  40. package/package.json +19 -19
  41. package/popup/popup.amd.js +1 -1
  42. package/popup/popup.amd.js.map +1 -1
  43. package/popup/popup.d.ts +1 -0
  44. package/popup/popup.js +17 -17
  45. package/popup/popup.js.map +1 -1
  46. package/popup/worker.amd.js +1 -1
  47. package/popup/worker.amd.js.map +1 -1
  48. package/popup/worker.d.ts +1 -0
  49. package/popup/worker.js +3 -2
  50. package/popup/worker.js.map +1 -1
  51. package/src/components/common/common.d.ts +0 -0
  52. package/src/components/common/icon/icon.d.ts +4 -0
  53. package/src/components/component.d.ts +25 -0
  54. package/src/components/forms/avatar/avatar.d.ts +29 -0
  55. package/src/components/forms/avatar/avatar.stories.d.ts +59 -0
  56. package/src/components/forms/avatar/avatar.vue.d.ts +26 -0
  57. package/src/components/forms/button/button.d.ts +40 -0
  58. package/src/components/forms/button/button.stories.d.ts +313 -0
  59. package/src/components/forms/button/button.vue.d.ts +39 -0
  60. package/src/components/forms/checkbox/checkbox.d.ts +22 -0
  61. package/src/components/forms/checkbox/checkbox.stories.d.ts +176 -0
  62. package/src/components/forms/checkbox/checkbox.vue.d.ts +23 -0
  63. package/src/components/forms/controlLabel/controlLabel.d.ts +4 -0
  64. package/src/components/forms/controlLabel/controlLabel.stories.d.ts +97 -0
  65. package/src/components/forms/controlLabel/controlLabel.vue.d.ts +19 -0
  66. package/src/components/forms/forms.d.ts +12 -0
  67. package/src/components/forms/helpers.d.ts +10 -0
  68. package/src/components/forms/hint/hint.d.ts +8 -0
  69. package/src/components/forms/hint/hint.stories.d.ts +138 -0
  70. package/src/components/forms/hint/hint.vue.d.ts +12 -0
  71. package/src/components/forms/input/input.d.ts +26 -0
  72. package/src/components/forms/input/input.stories.d.ts +255 -0
  73. package/src/components/forms/input/input.vue.d.ts +40 -0
  74. package/src/components/forms/inputDate/datepicker.d.ts +5 -0
  75. package/src/components/forms/inputDate/inputDate.d.ts +3 -0
  76. package/src/components/forms/inputDate/inputDate.stories.d.ts +108 -0
  77. package/src/components/forms/inputDate/inputDate.vue.d.ts +30 -0
  78. package/src/components/forms/inputRange/inputRange.d.ts +2 -0
  79. package/src/components/forms/inputRange/inputRange.stories.d.ts +405 -0
  80. package/src/components/forms/inputRange/inputRange.vue.d.ts +10 -0
  81. package/src/components/forms/radio/radio.d.ts +14 -0
  82. package/src/components/forms/radio/radio.stories.d.ts +168 -0
  83. package/src/components/forms/radio/radio.vue.d.ts +23 -0
  84. package/src/components/forms/select/select.d.ts +31 -0
  85. package/src/components/forms/select/select.stories.d.ts +83 -0
  86. package/src/components/forms/select/select.vue.d.ts +30 -0
  87. package/src/components/forms/select/stories/exampleOptions.d.ts +4 -0
  88. package/src/components/forms/switcher/switcher.d.ts +21 -0
  89. package/src/components/forms/switcher/switcher.stories.d.ts +163 -0
  90. package/src/components/forms/switcher/switcher.vue.d.ts +23 -0
  91. package/src/components/forms/textarea/textarea.d.ts +33 -0
  92. package/src/components/forms/textarea/textarea.stories.d.ts +88 -0
  93. package/src/components/forms/textarea/textarea.vue.d.ts +33 -0
  94. package/src/components/formsExt/editArea/editArea.d.ts +20 -0
  95. package/src/components/formsExt/editArea/editArea.stories.d.ts +140 -0
  96. package/src/components/formsExt/editArea/editArea.vue.d.ts +38 -0
  97. package/src/components/formsExt/editInput/editInput.d.ts +16 -0
  98. package/src/components/formsExt/editInput/editInput.stories.d.ts +129 -0
  99. package/src/components/formsExt/editInput/editInput.vue.d.ts +23 -0
  100. package/src/components/formsExt/formsExt.d.ts +3 -0
  101. package/src/components/formsExt/radioGroup/radioGroup.d.ts +22 -0
  102. package/src/components/formsExt/radioGroup/radioGroup.stories.d.ts +64 -0
  103. package/src/components/formsExt/radioGroup/radioGroup.vue.d.ts +30 -0
  104. package/src/components/helpersStories.d.ts +28 -0
  105. package/src/components/popup/popup/listItem.vue.d.ts +36 -0
  106. package/src/components/popup/popup/opener.vue.d.ts +39 -0
  107. package/src/components/popup/popup/popup.d.ts +79 -0
  108. package/src/components/popup/popup/popup.stories.d.ts +742 -0
  109. package/src/components/popup/popup/popup.vue.d.ts +52 -0
  110. package/src/components/popup/popup.d.ts +3 -0
  111. package/src/components/popup/worker.d.ts +2 -0
  112. package/src/components/tabs/tabs/content.vue.d.ts +19 -0
  113. package/src/components/tabs/tabs/tab.vue.d.ts +19 -0
  114. package/src/components/tabs/tabs/tabs.d.ts +19 -0
  115. package/src/components/tabs/tabs/tabs.stories.d.ts +774 -0
  116. package/src/components/tabs/tabs/tabs.vue.d.ts +21 -0
  117. package/src/components/tabs/tabs.d.ts +3 -0
  118. package/src/core/base/Colors.stories.d.ts +19 -0
  119. package/src/core/base/Layout.stories.d.ts +19 -0
  120. package/src/core/base/Properties.stories.d.ts +19 -0
  121. package/src/core/core/core.d.ts +58 -0
  122. package/src/core/core/events.d.ts +20 -0
  123. package/src/core/core/options.d.ts +13 -0
  124. package/src/core/core/page.d.ts +10 -0
  125. package/src/core/core/state.d.ts +34 -0
  126. package/src/core/directives/tooltip.d.ts +7 -0
  127. package/src/core/theme/Colors.stories.d.ts +19 -0
  128. package/src/core/theme/Properties.stories.d.ts +19 -0
  129. package/src/core/utils/date.d.ts +27 -0
  130. package/src/core/utils/device.d.ts +13 -0
  131. package/src/core/utils/dom.d.ts +98 -0
  132. package/src/core//320/235/320/260/320/261/320/276/321/200 /320/270/320/272/320/276/320/275/320/276/320/272//320/235/320/260/320/261/320/276/321/200 /320/270/320/272/320/276/320/275/320/276/320/272.stories.d.ts" +6 -0
  133. package/src/d.d.ts +4 -0
  134. package/src/resources/styles/core/core.d.ts +0 -0
  135. package/src/resources/styles/themes/dark.d.ts +0 -0
  136. package/src/resources/styles/themes/light.d.ts +0 -0
  137. package/src/storybook/components/icomoon.d.ts +2 -0
  138. package/tabs/tabs.amd.js +1 -1
  139. package/tabs/tabs.d.ts +1 -0
  140. package/tabs/tabs.js +1 -1
  141. package/utils/date.amd.js +1 -1
  142. package/utils/date.d.ts +3 -0
  143. package/utils/date.js +1 -1
  144. package/utils/device.amd.js +1 -1
  145. package/utils/device.d.ts +3 -0
  146. package/utils/device.js +1 -1
  147. package/utils/dom.amd.js +1 -1
  148. package/utils/dom.d.ts +3 -0
  149. package/utils/dom.js +1 -1
  150. package/.chunks/datepicker-7f54fd80.es.js +0 -275
  151. package/.chunks/datepicker-7f54fd80.es.js.map +0 -1
  152. package/.chunks/datepicker-858c1cb6.amd.js +0 -234
  153. package/.chunks/datepicker-858c1cb6.amd.js.map +0 -1
  154. package/.chunks/forms-7f061546.es.js.map +0 -1
  155. package/.chunks/forms-b9e5edd2.amd.js +0 -3
  156. package/.chunks/forms-b9e5edd2.amd.js.map +0 -1
  157. package/.chunks/popup-05538243.es.js.map +0 -1
  158. package/.chunks/popup-a531e9ad.amd.js +0 -377
  159. package/.chunks/popup-a531e9ad.amd.js.map +0 -1
@@ -1,5 +1,5 @@
1
- import { D as n, C as f } from "./forms-7f061546.es.js";
2
- import i from "../popup/worker.js";
1
+ import { D as r, C as f } from "./forms-727cc6aa.es.js";
2
+ import { PopupWorker as n } from "../popup/worker.js";
3
3
  import "vue";
4
4
  class m {
5
5
  static componentName = "Top";
@@ -28,11 +28,11 @@ class m {
28
28
  }
29
29
  // получить инициированный компонент
30
30
  static getComponent(t, p) {
31
- return n.storage(t, "#" + p);
31
+ return r.storage(t, "#" + p);
32
32
  }
33
33
  // устанвоить компонент
34
34
  _setComponent(t) {
35
- n.storage(t, "#" + this.componentName, this);
35
+ r.storage(t, "#" + this.componentName, this);
36
36
  }
37
37
  // функция подключения компонента
38
38
  mount() {
@@ -40,7 +40,7 @@ class m {
40
40
  }
41
41
  // функция отключения компонента
42
42
  unmount() {
43
- n.storage(this.el, "#" + this.componentName, null), this.unmountEls.forEach((t) => {
43
+ r.storage(this.el, "#" + this.componentName, null), this.unmountEls.forEach((t) => {
44
44
  t.remove();
45
45
  }), this.unmountEls = [], this.unmountEvents.forEach((t) => {
46
46
  t.el.removeEventListener(t.type, t.listener, t.options);
@@ -56,13 +56,13 @@ class m {
56
56
  }
57
57
  // указание новые события, которые должны будут удалиться после unmount
58
58
  registerEventForUnmount(t, p, o, e) {
59
- const r = {
59
+ const i = {
60
60
  el: t,
61
61
  type: p,
62
62
  listener: o,
63
63
  options: e
64
64
  };
65
- this.unmountEvents.push(r);
65
+ this.unmountEvents.push(i);
66
66
  }
67
67
  // функция перенастройки уже подключенного компонента
68
68
  reInit(t) {
@@ -99,15 +99,15 @@ class b {
99
99
  if (!e || p.matches(".top-popup-noCloser"))
100
100
  return;
101
101
  if (p.getAttribute("href") === "." && t.preventDefault(), t.target.matches("[data-top-popup]")) {
102
- const r = t.target.closest("ul"), l = t.target.closest("a, .a");
103
- r && ((o = r.querySelector("a.top-active, .a.top-active")) == null || o.classList.remove("top-active")), l && l.classList.add("top-active");
102
+ const i = t.target.closest("ul"), l = t.target.closest("a, .a");
103
+ i && ((o = i.querySelector("a.top-active, .a.top-active")) == null || o.classList.remove("top-active")), l && l.classList.add("top-active");
104
104
  return;
105
105
  }
106
- i.close(e);
106
+ n.close(e);
107
107
  }
108
108
  if (t.target.matches(".top-popup-wrapper")) {
109
109
  const e = t.target;
110
- i.close(e);
110
+ n.close(e);
111
111
  }
112
112
  }
113
113
  /**
@@ -125,14 +125,14 @@ class b {
125
125
  break;
126
126
  case "Enter":
127
127
  if (!o) {
128
- if (n.querySelectorVisible(p, ".preloader"))
128
+ if (r.querySelectorVisible(p, ".preloader"))
129
129
  break;
130
- const u = p.querySelector(".top-popup_footer .go, .top-popup_footer [data-action]");
131
- u && u.click();
130
+ const c = p.querySelector(".top-popup_footer .go, .top-popup_footer [data-action]");
131
+ c && c.click();
132
132
  break;
133
133
  }
134
- const r = n.querySelectorVisible(p, "li > a.top-active");
135
- r && (t.preventDefault(), location.href = r.getAttribute("href"));
134
+ const i = r.querySelectorVisible(p, "li > a.top-active");
135
+ i && (t.preventDefault(), location.href = i.getAttribute("href"));
136
136
  const l = p.querySelector("li > .top-active");
137
137
  l && l.click();
138
138
  break;
@@ -142,399 +142,401 @@ class b {
142
142
  case "ArrowLeft":
143
143
  if (!o)
144
144
  break;
145
- t.key === "ArrowRight" || t.key === "ArrowLeft" ? n.querySelectorVisible(p, "ul.top-popup_content > li:not(.top-popup_liNoSelectable) > .top-active > .top-popup_listMore") && t.preventDefault() : t.preventDefault();
145
+ t.key === "ArrowRight" || t.key === "ArrowLeft" ? r.querySelectorVisible(p, "ul.top-popup_content > li:not(.top-popup_liNoSelectable) > .top-active > .top-popup_listMore") && t.preventDefault() : t.preventDefault();
146
146
  const h = (e = p.querySelector("ul.top-popup_content > li:not(.top-popup_liNoSelectable) > .top-active")) == null ? void 0 : e.parentElement;
147
- if (console.log(h), t.key === "ArrowRight" && h) {
148
- const u = h.querySelector(".top-active > .top-popup_listMore");
149
- if (u)
150
- return u.click();
147
+ if (t.key === "ArrowRight" && h) {
148
+ const c = h.querySelector(".top-active > .top-popup_listMore");
149
+ if (c)
150
+ return c.click();
151
151
  }
152
- const a = n.querySelectorAllVisible(p, "ul.top-popup_content > li:not(.top-popup_liNoSelectable)"), c = a.length;
152
+ const a = r.querySelectorAllVisible(p, "ul.top-popup_content > li:not(.top-popup_liNoSelectable)"), u = a.length;
153
+ if (!u)
154
+ return;
153
155
  let s = a.indexOf(h);
154
156
  if (t.key === "ArrowUp" || t.key === "ArrowLeft" ? s-- : s++, t.key === "ArrowLeft" && s === -1)
155
- return t.target.matches("input") ? void 0 : i.close(p);
156
- if (t.key === "ArrowRight" && s === c)
157
+ return t.target.matches("input") ? void 0 : n.close(p);
158
+ if (t.key === "ArrowRight" && s === u)
157
159
  return;
158
- s < 0 && (s = c - 1), s > c - 1 && (s = 0), p.querySelectorAll("ul.top-popup_content > li > .top-active").forEach((u) => u.classList.remove("top-active")), a[s].querySelector(":scope > a, :scope > .a").classList.add("top-active"), i.scrollToActive(p);
160
+ s < 0 && (s = u - 1), s > u - 1 && (s = 0), p.querySelectorAll("ul.top-popup_content > li > .top-active").forEach((c) => c.classList.remove("top-active")), a[s].querySelector(":scope > a, :scope > .a").classList.add("top-active"), n.scrollToActive(p);
159
161
  break;
160
162
  }
161
163
  }
162
164
  }
163
- const x = `:root{
164
- --top-popup-background-color: var(--color-bg-3);
165
- --top-popup-background-color-hover: var(--color-theme-75);
166
- --top-popup-background-color-active: var(--color-theme-100);
167
-
168
- --top-popup-border-color: var(--color-line-2-opacity);
169
- --top-popup-title-background-color: var(--color-theme-50);
170
-
171
- /* суммарный отсуп от каря popup до элемента */
172
- --top-popup-content-padding: calc(var(--top-popup-list-padding) + var(--top-popup-listItem-padding));
173
-
174
- /* списки */
175
- --top-popup-list-padding: var(--top-padding-2);
176
-
177
- --top-popup-listItem-radius: var(--top-radius-2);
178
- --top-popup-listItem-padding: var(--top-padding-2);
179
- }
180
-
181
- .top-popup-front{ position: relative; }
182
-
183
- .top-popup-wrapper{
184
- /* см. recalcPosition() */
185
- --top-popup-height: 0px;
186
- --top-popup-right-bounding: 0px;
187
- --top-popup-bottom-bounding: 0px;
188
- --top-popup-top: 0px;
189
- --top-popup-right: calc(100vw - var(--top-popup-right-bounding));
190
- --top-popup-bottom: calc(var(--100vh) - var(--top-popup-bottom-bounding));
191
- --top-popup-left: 0px;
192
-
193
- text-align: initial; white-space: normal; word-break: normal;
194
- position: absolute; z-index: 200000;
195
- }
196
- .top-popup-wrapper:not(.top-popup-wrapper-shown){ overflow: hidden; }
197
-
198
- /* top-popupPanel */
199
- .top-popupPanel {
200
- cursor: default;
201
- box-shadow: var(--top-shadow-b);
202
- border-radius: 8px;
203
- background: var(--top-popup-background-color);
204
- position: absolute; overflow: hidden;
205
- display: flex; flex-direction: column;
206
- }
207
-
208
- /* position */
209
- .top-popup-wrapper > *{ opacity: 0; transition: opacity 100ms linear, transform 100ms linear; }
210
- .top-popup-wrapper.p0 > *{ transform: translateY(-8px); }
211
- .top-popup-wrapper.p1 > *{ transform: translateY(8px); }
212
- .top-popup-wrapper.p2 > *{ transform: translateX(8px); }
213
- .top-popup-wrapper.p3 > *{ transform: translateY(8px); }
214
- .top-popup-wrapper.p4 > *{ transform: translateX(-8px); }
215
- .top-popup-wrapper-shown:not(.top-popup-wrapper-closed) > *{opacity: 1;transform: translate(0, 0) !important;}
216
-
217
- .top-popup-wrapper.p0 > .top-popup{ top: calc(-16px); left: calc(0px - 8px); }
218
- .top-popup-wrapper.p1 > .top-popup{ bottom: calc(100% + 8px); }
219
- .top-popup-wrapper.p2 > .top-popup{ left: calc(100% + 8px); }
220
- .top-popup-wrapper.p3 > .top-popup{ top: calc(100% + 8px); }
221
- .top-popup-wrapper.p4 > .top-popup{ right: calc(100% + 8px); }
222
- .top-popup-wrapper.p2 > .top-popup,
223
- .top-popup-wrapper.p4 > .top-popup{ margin-top: -10px; }
224
-
225
- .top-popup-wrapper.p1.with_notch > .top-popup{ margin-bottom: 5px; }
226
- .top-popup-wrapper.p2.with_notch > .top-popup{ margin-left: 5px; }
227
- .top-popup-wrapper.p3.with_notch > .top-popup{ margin-top: 5px; }
228
- .top-popup-wrapper.p4.with_notch > .top-popup{ margin-right: 5px; }
229
-
230
- .top-popup-wrapper.invert-x > .top-popup{ right: 0; }
231
- .top-popup-wrapper.invert-y > .top-popup{ bottom: 0; }
232
-
233
- /* notch */
234
- .top-popup-wrapper > .notch{ border: 7.4px solid transparent; position: absolute; display: block; }
235
-
236
- .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% }
237
- .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%; }
238
- .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%; }
239
- .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%; }
240
-
241
- .top-popup-wrapper.p1 > .notch-border{ border-top-color: rgba(0,0,0,0.05); margin-bottom: 6px; }
242
- .top-popup-wrapper.p2 > .notch-border{ border-right-color: rgba(0,0,0,0.05); margin-left: 6px; }
243
- .top-popup-wrapper.p3 > .notch-border{ border-bottom-color: rgba(0,0,0,0.05); margin-top: 6px; }
244
- .top-popup-wrapper.p4 > .notch-border{ border-left-color: rgba(0,0,0,0.05); margin-right: 6px; }
245
-
246
- /* common */
247
- .top-popup_header,
248
- .top-popup_content,
249
- .top-popup_footer{ font-size: 14px; }
250
- .top-popup_header,
251
- .top-popup_footer{ display: flex; align-items: center; justify-content: space-between; }
252
-
253
- /* header */
254
- .top-popup_header{
255
- border-bottom: 1px solid var(--top-popup-border-color);
256
- padding: var(--top-padding-3);
257
- font-weight: 600;
258
- }
259
- .top-popup_header > *{ font-weight: 400; }
260
- .top-popup_header > .a{ cursor: pointer; color: var(--color-blue-450); }
261
- .top-popup_header > .a:hover{ color: var(--color-blue-350); }
262
-
263
- .top-popup_headerButton{ width: 60px; }
264
-
265
- /* content */
266
- .top-popup_content{
267
- margin: 0;
268
- line-height:1 !important;
269
- flex-grow: 1;
270
- overflow-y: auto;
271
- display: flex;
272
- flex-direction: column;
273
- gap: var(--top-gap-4);
274
-
275
- -webkit-overflow-scrolling: touch;
276
- }
277
-
278
- div.top-popup_content{
279
- /* has_scroll */
280
- --scroll-padding-top: var(--top-popup-content-padding);
281
- --scroll-padding-bottom: var(--top-popup-content-padding);
282
-
283
- padding: var(--top-popup-content-padding);
284
- }
285
- div.top-popup_content > *{ flex-shrink: 0; }
286
- div.top-popup_content > .top-button{ margin: 0; }
287
-
288
- div.top-popup_content .top-unwrap{
289
- --top-unwrap-x: var(--top-popup-content-padding);
290
- }
291
-
292
- ul.top-popup_content{
293
- --scroll-padding-top: var(--top-popup-list-padding);
294
- --scroll-padding-bottom: var(--top-popup-list-padding);
295
-
296
- padding: var(--top-popup-list-padding);
297
- gap: 2px;
298
- }
299
-
300
- ul.top-popup_content .top-unwrap{
301
- --top-unwrap-x: var(--top-popup-list-padding);
302
- }
303
-
304
- .top-popup_listItem{
305
- border-radius: var(--top-popup-listItem-radius);
306
- padding: var(--top-popup-listItem-padding);
307
- }
308
-
309
- ul.top-popup_content li{ margin: 0; list-style:none; display: flex; position: relative }
310
- ul.top-popup_content li > *{ flex-grow: 1; }
311
- ul.top-popup_content li > a:not(.top-button),
312
- ul.top-popup_content li > .a{
313
- cursor: pointer;
314
- box-sizing: border-box;
315
- border-radius: var(--top-popup-listItem-radius);
316
- background: var(--top-popup-background-color);
317
- padding: var(--top-popup-listItem-padding);
318
- color:var(--color-text) !important; font-size: 14px; font-weight: normal !important; text-decoration:none !important; font-style: normal;
319
- display:flex; flex: 1 1 100%; align-items: center;
320
- transition: background-color 0.1s ease-in-out;
321
- }
322
- .top-popup-wrapper-no_animate ul.top-popup_content li > a:not(.top-button),
323
- .top-popup-wrapper-no_animate ul.top-popup_content li > .a{ transition: none; }
324
-
325
- ul.top-popup_content li > a:not(.top-button):hover,
326
- ul.top-popup_content li > .a:hover{ background: var(--top-popup-background-color-hover); }
327
- ul.top-popup_content li > a:not(.top-button).top-active,
328
- ul.top-popup_content li > .a.top-active{ background: var(--top-popup-background-color-active); }
329
-
330
- .top-popup_content + .top-popup_content{ padding-top: 0; }
331
-
332
- /* listTitle */
333
- .top-popup_listItem-title{
334
- background: var(--top-popup-title-background-color);
335
- color: var(--color-text-2); font-size: 12px;
336
- }
337
-
338
- /* listDelimiter */
339
- .top-popup_listItem-delimiter{
340
- border-radius: 3px;
341
- background: var(--top-popup-border-color);
342
- height: 1px;
343
- padding: 0;
344
- margin: 4px;
345
- }
346
-
347
- /* listMore */
348
- .top-popup_listMore{
349
- margin: calc(0px - var(--top-popup-listItem-padding)) 0;
350
- }
351
-
352
- ul.top-popup_content li > .a.top-popup_listMore{
353
- height: auto; padding-right: 4px; padding-left: 4px;
354
- font-size: 24px; line-height: 17px; text-align: center;
355
- flex-basis: 10px;
356
- }
357
- ul.top-popup_content li > .a.top-popup_listMore:before{ color: var(--color-gray-500); }
358
- ul.top-popup_content li > * > .top-popup_listMore{
359
- padding: 0 var(--top-popup-listItem-padding); margin-left: auto;
360
- color: var(--color-gray-500);
361
- font-size: 14px;
362
- }
363
- ul.top-popup_content li > * > i.top-popup_listMore:hover,
364
- ul.top-popup_content li > * > i.top-popup_listMore.top-active{ color: var(--color-blue-500); }
365
- ul.top-popup_content li > * > i.top-popup_listMore:before{
366
- transform: rotate(90deg);
367
- display: block;
368
- }
369
-
370
- ul.top-popup_content li a.close{ background: none !important; }
371
-
372
- /* data-top-icon */
373
- .top-popup_content > [data-top-icon]:before{
374
- --top-icon-size: 20px;
375
- }
376
-
377
- ul.top-popup_content li > [data-top-icon]:not(.top-button):before{
378
- --top-icon-color: var(--color-text-3);
379
- --top-icon-size: 20px;
380
- --top-icon-width: 20px;
381
-
382
- height: 1rem; margin-right: 8px; transition: color 0.1s;
383
- }
384
- ul.top-popup_content li:hover > [data-top-icon]:not(.top-button):before,
385
- ul.top-popup_content li > [data-top-icon]:not(.top-button).top-active:before{
386
- --top-icon-color: var(--color-text-2);
387
- }
388
-
389
- /* footer */
390
- .top-popup_footer{
391
- padding: var(--top-popup-list-padding);
392
- border-top: 1px solid var(--top-popup-border-color);
393
- display: flex;
394
- gap:var(--top-gap-2);
395
- justify-content: flex-end;
396
- }
397
-
398
- /* Виджеты */
399
- .top-popup > [data-widget]{ padding: 0 var(--top-popup-list-padding); }
400
- .top-popup > [data-widget] + hr{ margin: 0 var(--top-popup-list-padding); }
401
-
402
- .top-popup .placeholder{
403
- border:1px solid #E0D9D9 !important; border-right: none !important; border-left: none !important; background:#F9F9F9 !important; margin: -1px 0; z-index: 1;
404
- position: relative;
405
- }
406
-
407
- /* компоненты */
408
- .top-popup-wrapper.simple_list > .top-popup{ min-width: 0; white-space: nowrap; }
409
-
410
- .top-popup_content .top-column{ display: flex; flex-direction: column; gap: 4px; }
411
- html .top-popup .top-popup_content li > .top-button{
412
- margin:calc(var(--top-popup-listItem-padding) / 2) var(--top-popup-listItem-padding);
413
- }
414
-
415
- .top-popup li .check_all,
416
- .top-popup li .clear_all{ cursor: pointer; color: var(--color-cyan); padding: 8px; display: inline-block; }
417
- .top-popup li .check_all:hover,
418
- .top-popup li .clear_all:hover{ text-decoration: underline; }
419
- .top-popup li .clear_all{ display: none; }
420
-
421
- /* table */
422
- .top-popup_content table{ margin: -9px 0; }
423
- .top-popup_content table td,
424
- .top-popup_content table th{ padding: 9px var(--top-popup-listItem-padding) 9px 0; vertical-align: top; }
425
- .top-popup_content table th{ width: 40%; font-weight: 600; white-space: nowrap; }
426
-
427
- /* формы */
428
- ul.top-popup_content .a > [type="checkbox"],
429
- ul.top-popup_content .a > [type="radio"]{ margin: -8px 0 -8px auto; }
430
-
431
- /* deprecated */
432
- ul.top-popup_content a > [class*=icon],
433
- ul.top-popup_content i.a > [class*=icon]{
434
- transition: 0.1s;
435
- }
436
-
437
- .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; }
438
- .top-popup_footer [class*=btn]:not(.btn-transparent){ min-width: 100px; padding: 5px 14px; margin-left: 10px; }
439
- .top-popup_footer [class*=btn]:first-child{ margin-left: 0; }
440
- .top-popup_footer .btn.full_width{ margin: 0; flex-grow: 1; }`, w = `:root{
441
- --top-popup-list-padding: 0px;
442
-
443
- --top-popup-listItem-radius: 0px;
444
- --top-popup-listItem-padding: var(--top-padding-4);
445
- }
446
-
447
- html.with_popup{ background: #808080; }
448
-
449
- .top-popup-wrapper{
450
- --top-popup-footer-offset: 25px;
451
-
452
- width: auto !important; height: auto !important;
453
- position: fixed; top: 0 !important; right: 0 !important; left: 0 !important; overflow: hidden;
454
- transition: background 0.3s;
455
- }
456
-
457
- .top-popup-wrapper-shown:not(.top-popup-wrapper-closed){ background: rgba(0,0,0,0.5); backdrop-filter: blur(1px); }
458
- .top-popup-wrapper-shown:not(.top-popup-wrapper-closed) > .top-popup{ opacity: 1 !important; }
459
-
460
- .top-popup{
461
- border-radius: 8px 8px 0 0; width: auto !important; max-height: calc(100% - var(--header-height) - 12px); margin: 0 !important;
462
- top: auto !important; right: 0 !important; bottom: 0 !important; left: 0 !important;
463
- display: flex; flex-direction: column;
464
-
465
- /* невозможно опустить элемент вниз за экран на 100%, fix: opacity и translateY(80%) */
466
- transform: translateY(80%);
467
-
468
- transition: opacity 0.3s, transform 0.3s;
469
- }
470
-
471
- /* from top */
472
- .top-popup-wrapper.p-from-top{
473
- --top-popup-footer-offset: 0px;
474
-
475
- top: var(--header-height) !important;
476
- }
477
- .with_dialog .top-popup-wrapper.p-from-top{ top: 50px !important; }
478
- .top-popup-wrapper.p-from-top > .top-popup{
479
- border-radius: 0 0 8px 8px; max-height: calc(100% - 24px); top: 0 !important; bottom: auto !important;
480
- transform: translateY(calc(-100% - 24px));
481
- }
482
-
483
- /* content */
484
- ul.top-popup_content{
485
- --scroll-padding-top: 0px;
486
- --scroll-padding-bottom: var(--scroll-padding-top);
487
-
488
- gap: 0;
489
- }
490
- ul.top-popup_content li:not(:last-child){ border-bottom: 1px solid var(--top-popup-border-color); }
491
-
492
- .top-popup-wrapper.top-style_alt > .top-popup > ul > li{ border-bottom: none; }
493
-
494
- /* footer */
495
- .top-popup_footer{
496
- flex-direction: column-reverse;
497
- }
498
- .top-popup_footer > .top-button{
499
- --top-forms-base-height: var(--top-forms-base-height_xl);
500
-
501
- width: 100%;
502
- }
503
-
504
- /* listTitle */
505
- ul.top-popup_content .top-popup_listItem-title{
506
- --top-popup-padding-v: 12px;
507
- }
508
-
509
- /* listDelimiter */
510
- ul.top-popup_content .top-popup_listItem-delimiter{ background: var(--color-line-1-opacity); height: 4px; margin: 0; }
511
- ul.top-popup_content li:first-child > .top-popup_listItem-delimiter{ border-top: 1px solid var(--top-popup-border-color); }`, P = `html:not(.with_dialog){ margin-right: 0 !important; }
512
-
513
- .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)); }
514
- .top-popup-wrapper.invert-x > .top-popup{ max-width: calc(100vw - var(--top-popup-right) - 16px); }
515
- .top-popup-wrapper.invert-y > .top-popup{ max-height: calc(100vh - var(--top-popup-bottom) - 16px); }
516
-
517
- /* position */
518
- .top-popup-wrapper.p1 > .top-popup{ max-height: calc(var(--top-popup-top) - var(--header-height) - 16px); }
519
- .top-popup-wrapper.p3 > .top-popup{ max-height: calc(var(--top-popup-bottom) - 16px); }
520
- .top-popup-wrapper.p2 > .top-popup{ max-width: calc(var(--top-popup-right) - 16px); }
521
- .top-popup-wrapper.p4 > .top-popup{ max-width: calc(var(--top-popup-left) - 16px); }
522
-
523
- /* notch */
524
- .top-popup-wrapper.p1.with_notch > .top-popup,
525
- .top-popup-wrapper.p3.with_notch > .top-popup{ margin-left: -16px !important; }
526
- .top-popup-wrapper.p1.with_notch > .notch,
527
- .top-popup-wrapper.p3.with_notch > .notch{ margin-left: -8px !important; }
528
-
529
- .top-popup-wrapper.p1.with_notch.invert-x,
530
- .top-popup-wrapper.p3.with_notch.invert-x{ margin-left: 3px !important; }
531
- .top-popup-wrapper.p1.with_notch.invert-x > .notch,
532
- .top-popup-wrapper.p3.with_notch.invert-x > .notch{ margin-left: -9px !important; }
533
-
534
- /* listMore */
535
- ul.top-popup_content li > * > i.top-popup_listMore{ visibility: hidden; transition: none; }
536
- ul.top-popup_content li:hover > * > i.top-popup_listMore,
537
- ul.top-popup_content li > *.top-active > i.top-popup_listMore,
165
+ const x = `:root{\r
166
+ --top-popup-background-color: var(--color-bg-3);\r
167
+ --top-popup-background-color-hover: var(--color-theme-75);\r
168
+ --top-popup-background-color-active: var(--color-theme-100);\r
169
+ \r
170
+ --top-popup-border-color: var(--color-line-2-opacity);\r
171
+ --top-popup-title-background-color: var(--color-theme-50);\r
172
+ \r
173
+ /* суммарный отсуп от каря popup до элемента */\r
174
+ --top-popup-content-padding: calc(var(--top-popup-list-padding) + var(--top-popup-listItem-padding));\r
175
+ \r
176
+ /* списки */\r
177
+ --top-popup-list-padding: var(--top-padding-2);\r
178
+ \r
179
+ --top-popup-listItem-radius: var(--top-radius-2);\r
180
+ --top-popup-listItem-padding: var(--top-padding-2);\r
181
+ }\r
182
+ \r
183
+ .top-popup-front{ position: relative; }\r
184
+ \r
185
+ .top-popup-wrapper{\r
186
+ /* см. recalcPosition() */\r
187
+ --top-popup-height: 0px;\r
188
+ --top-popup-right-bounding: 0px;\r
189
+ --top-popup-bottom-bounding: 0px;\r
190
+ --top-popup-top: 0px;\r
191
+ --top-popup-right: calc(100vw - var(--top-popup-right-bounding));\r
192
+ --top-popup-bottom: calc(var(--100vh) - var(--top-popup-bottom-bounding));\r
193
+ --top-popup-left: 0px;\r
194
+ \r
195
+ text-align: initial; white-space: normal; word-break: normal;\r
196
+ position: absolute; z-index: 200000;\r
197
+ }\r
198
+ .top-popup-wrapper:not(.top-popup-wrapper-shown){ overflow: hidden; }\r
199
+ \r
200
+ /* top-popupPanel */\r
201
+ .top-popupPanel {\r
202
+ cursor: default;\r
203
+ box-shadow: var(--top-shadow-b);\r
204
+ border-radius: 8px;\r
205
+ background: var(--top-popup-background-color);\r
206
+ position: absolute; overflow: hidden;\r
207
+ display: flex; flex-direction: column;\r
208
+ }\r
209
+ \r
210
+ /* position */\r
211
+ .top-popup-wrapper > *{ opacity: 0; transition: opacity 100ms linear, transform 100ms linear; }\r
212
+ .top-popup-wrapper.p0 > *{ transform: translateY(-8px); }\r
213
+ .top-popup-wrapper.p1 > *{ transform: translateY(8px); }\r
214
+ .top-popup-wrapper.p2 > *{ transform: translateX(8px); }\r
215
+ .top-popup-wrapper.p3 > *{ transform: translateY(8px); }\r
216
+ .top-popup-wrapper.p4 > *{ transform: translateX(-8px); }\r
217
+ .top-popup-wrapper-shown:not(.top-popup-wrapper-closed) > *{opacity: 1;transform: translate(0, 0) !important;}\r
218
+ \r
219
+ .top-popup-wrapper.p0 > .top-popup{ top: calc(-16px); left: calc(0px - 8px); }\r
220
+ .top-popup-wrapper.p1 > .top-popup{ bottom: calc(100% + 8px); }\r
221
+ .top-popup-wrapper.p2 > .top-popup{ left: calc(100% + 8px); }\r
222
+ .top-popup-wrapper.p3 > .top-popup{ top: calc(100% + 8px); }\r
223
+ .top-popup-wrapper.p4 > .top-popup{ right: calc(100% + 8px); }\r
224
+ .top-popup-wrapper.p2 > .top-popup,\r
225
+ .top-popup-wrapper.p4 > .top-popup{ margin-top: -10px; }\r
226
+ \r
227
+ .top-popup-wrapper.p1.with_notch > .top-popup{ margin-bottom: 5px; }\r
228
+ .top-popup-wrapper.p2.with_notch > .top-popup{ margin-left: 5px; }\r
229
+ .top-popup-wrapper.p3.with_notch > .top-popup{ margin-top: 5px; }\r
230
+ .top-popup-wrapper.p4.with_notch > .top-popup{ margin-right: 5px; }\r
231
+ \r
232
+ .top-popup-wrapper.invert-x > .top-popup{ right: 0; }\r
233
+ .top-popup-wrapper.invert-y > .top-popup{ bottom: 0; }\r
234
+ \r
235
+ /* notch */\r
236
+ .top-popup-wrapper > .notch{ border: 7.4px solid transparent; position: absolute; display: block; }\r
237
+ \r
238
+ .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
239
+ .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
240
+ .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
241
+ .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
242
+ \r
243
+ .top-popup-wrapper.p1 > .notch-border{ border-top-color: rgba(0,0,0,0.05); margin-bottom: 6px; }\r
244
+ .top-popup-wrapper.p2 > .notch-border{ border-right-color: rgba(0,0,0,0.05); margin-left: 6px; }\r
245
+ .top-popup-wrapper.p3 > .notch-border{ border-bottom-color: rgba(0,0,0,0.05); margin-top: 6px; }\r
246
+ .top-popup-wrapper.p4 > .notch-border{ border-left-color: rgba(0,0,0,0.05); margin-right: 6px; }\r
247
+ \r
248
+ /* common */\r
249
+ .top-popup_header,\r
250
+ .top-popup_content,\r
251
+ .top-popup_footer{ font-size: 14px; }\r
252
+ .top-popup_header,\r
253
+ .top-popup_footer{ display: flex; align-items: center; justify-content: space-between; }\r
254
+ \r
255
+ /* header */\r
256
+ .top-popup_header{\r
257
+ border-bottom: 1px solid var(--top-popup-border-color);\r
258
+ padding: var(--top-padding-3);\r
259
+ font-weight: 600;\r
260
+ }\r
261
+ .top-popup_header > *{ font-weight: 400; }\r
262
+ .top-popup_header > .a{ cursor: pointer; color: var(--color-blue-450); }\r
263
+ .top-popup_header > .a:hover{ color: var(--color-blue-350); }\r
264
+ \r
265
+ .top-popup_headerButton{ width: 60px; }\r
266
+ \r
267
+ /* content */\r
268
+ .top-popup_content{\r
269
+ margin: 0;\r
270
+ flex-grow: 1;\r
271
+ overflow-y: auto;\r
272
+ display: flex;\r
273
+ flex-direction: column;\r
274
+ gap: var(--top-gap-4);\r
275
+ \r
276
+ -webkit-overflow-scrolling: touch;\r
277
+ }\r
278
+ \r
279
+ div.top-popup_content{\r
280
+ /* has_scroll */\r
281
+ --scroll-padding-top: var(--top-popup-content-padding);\r
282
+ --scroll-padding-bottom: var(--top-popup-content-padding);\r
283
+ \r
284
+ padding: var(--top-popup-content-padding);\r
285
+ }\r
286
+ div.top-popup_content > *{ flex-shrink: 0; }\r
287
+ div.top-popup_content > .top-button{ margin: 0; }\r
288
+ \r
289
+ div.top-popup_content .top-unwrap{\r
290
+ --top-unwrap-x: var(--top-popup-content-padding);\r
291
+ }\r
292
+ \r
293
+ ul.top-popup_content{\r
294
+ --scroll-padding-top: var(--top-popup-list-padding);\r
295
+ --scroll-padding-bottom: var(--top-popup-list-padding);\r
296
+ \r
297
+ padding: var(--top-popup-list-padding);\r
298
+ gap: 2px;\r
299
+ }\r
300
+ \r
301
+ ul.top-popup_content .top-unwrap{\r
302
+ --top-unwrap-x: var(--top-popup-list-padding);\r
303
+ }\r
304
+ \r
305
+ .top-popup_listItem {\r
306
+ border-radius: var(--top-popup-listItem-radius);\r
307
+ padding: var(--top-popup-listItem-padding);\r
308
+ line-height: 1 !important;\r
309
+ }\r
310
+ \r
311
+ ul.top-popup_content li{ margin: 0; list-style:none; display: flex; position: relative }\r
312
+ ul.top-popup_content li > *{ flex-grow: 1; }\r
313
+ ul.top-popup_content li > a:not(.top-button),\r
314
+ ul.top-popup_content li > .a{\r
315
+ cursor: pointer;\r
316
+ box-sizing: border-box;\r
317
+ border-radius: var(--top-popup-listItem-radius);\r
318
+ background: var(--top-popup-background-color);\r
319
+ padding: var(--top-popup-listItem-padding);\r
320
+ color: var(--color-text) !important; font-size: 14px; font-weight: normal !important; text-decoration: none !important; font-style: normal;\r
321
+ line-height: 1 !important;\r
322
+ display: flex; flex: 1 1 100%; align-items: center;\r
323
+ transition: background-color 0.1s ease-in-out;\r
324
+ }\r
325
+ .top-popup-wrapper-no_animate ul.top-popup_content li > a:not(.top-button),\r
326
+ .top-popup-wrapper-no_animate ul.top-popup_content li > .a{ transition: none; }\r
327
+ \r
328
+ ul.top-popup_content li > a:not(.top-button):hover,\r
329
+ ul.top-popup_content li > .a:hover{ background: var(--top-popup-background-color-hover); }\r
330
+ ul.top-popup_content li > a:not(.top-button).top-active,\r
331
+ ul.top-popup_content li > .a.top-active{ background: var(--top-popup-background-color-active); }\r
332
+ \r
333
+ .top-popup_content + .top-popup_content{ padding-top: 0; }\r
334
+ \r
335
+ /* listTitle */\r
336
+ .top-popup_listItem-title{\r
337
+ background: var(--top-popup-title-background-color);\r
338
+ color: var(--color-text-2); font-size: 12px;\r
339
+ }\r
340
+ \r
341
+ /* listDelimiter */\r
342
+ .top-popup_listItem-delimiter{\r
343
+ border-radius: 3px;\r
344
+ background: var(--top-popup-border-color);\r
345
+ height: 1px;\r
346
+ padding: 0;\r
347
+ margin: 4px;\r
348
+ }\r
349
+ \r
350
+ /* listMore */\r
351
+ .top-popup_listMore{\r
352
+ font-size: 20px;\r
353
+ }\r
354
+ \r
355
+ ul.top-popup_content li > .a.top-popup_listMore{\r
356
+ text-align: center;\r
357
+ flex-basis: 10px;\r
358
+ }\r
359
+ ul.top-popup_content li > .a.top-popup_listMore:before{ color: var(--color-gray-500); }\r
360
+ ul.top-popup_content li > * > .top-popup_listMore{\r
361
+ padding: 0 var(--top-popup-listItem-padding); margin-left: auto;\r
362
+ color: var(--color-gray-500);\r
363
+ font-size: 14px;\r
364
+ }\r
365
+ ul.top-popup_content li > * > i.top-popup_listMore:hover,\r
366
+ ul.top-popup_content li > * > i.top-popup_listMore.top-active{ color: var(--color-blue-500); }\r
367
+ ul.top-popup_content li > * > i.top-popup_listMore:before{\r
368
+ transform: rotate(90deg);\r
369
+ display: block;\r
370
+ }\r
371
+ \r
372
+ ul.top-popup_content li a.close{ background: none !important; }\r
373
+ \r
374
+ /* data-top-icon */\r
375
+ .top-popup_content > [data-top-icon]:before{\r
376
+ --top-icon-size: 20px;\r
377
+ }\r
378
+ \r
379
+ ul.top-popup_content li > [data-top-icon]:not(.top-button):before{\r
380
+ --top-icon-color: var(--color-text-3);\r
381
+ --top-icon-size: 20px;\r
382
+ --top-icon-width: 20px;\r
383
+ \r
384
+ height: 1rem; margin-right: 8px; transition: color 0.1s;\r
385
+ }\r
386
+ ul.top-popup_content li:hover > [data-top-icon]:not(.top-button):before,\r
387
+ ul.top-popup_content li > [data-top-icon]:not(.top-button).top-active:before{\r
388
+ --top-icon-color: var(--color-text-2);\r
389
+ }\r
390
+ \r
391
+ /* footer */\r
392
+ .top-popup_footer{\r
393
+ padding: var(--top-popup-list-padding);\r
394
+ border-top: 1px solid var(--top-popup-border-color);\r
395
+ display: flex;\r
396
+ gap:var(--top-gap-2);\r
397
+ justify-content: flex-end;\r
398
+ }\r
399
+ \r
400
+ /* Виджеты */\r
401
+ .top-popup > [data-widget]{ padding: 0 var(--top-popup-list-padding); }\r
402
+ .top-popup > [data-widget] + hr{ margin: 0 var(--top-popup-list-padding); }\r
403
+ \r
404
+ .top-popup .placeholder{\r
405
+ border:1px solid #E0D9D9 !important; border-right: none !important; border-left: none !important; background:#F9F9F9 !important; margin: -1px 0; z-index: 1;\r
406
+ position: relative;\r
407
+ }\r
408
+ \r
409
+ /* компоненты */\r
410
+ .top-popup-wrapper.simple_list > .top-popup{ min-width: 0; white-space: nowrap; }\r
411
+ \r
412
+ .top-popup_content .top-column{ display: flex; flex-direction: column; gap: 4px; }\r
413
+ html .top-popup .top-popup_content li > .top-button{\r
414
+ margin:calc(var(--top-popup-listItem-padding) / 2) var(--top-popup-listItem-padding);\r
415
+ }\r
416
+ \r
417
+ .top-popup li .check_all,\r
418
+ .top-popup li .clear_all{ cursor: pointer; color: var(--color-cyan); padding: 8px; display: inline-block; }\r
419
+ .top-popup li .check_all:hover,\r
420
+ .top-popup li .clear_all:hover{ text-decoration: underline; }\r
421
+ .top-popup li .clear_all{ display: none; }\r
422
+ \r
423
+ /* table */\r
424
+ .top-popup_content table{ margin: -9px 0; }\r
425
+ .top-popup_content table td,\r
426
+ .top-popup_content table th{ padding: 9px var(--top-popup-listItem-padding) 9px 0; vertical-align: top; }\r
427
+ .top-popup_content table th{ width: 40%; font-weight: 600; white-space: nowrap; }\r
428
+ \r
429
+ /* формы */\r
430
+ ul.top-popup_content .a > [type="checkbox"],\r
431
+ ul.top-popup_content .a > [type="radio"]{ margin: -8px 0 -8px auto; }\r
432
+ \r
433
+ /* deprecated */\r
434
+ ul.top-popup_content a > [class*=icon],\r
435
+ ul.top-popup_content i.a > [class*=icon]{\r
436
+ transition: 0.1s;\r
437
+ }\r
438
+ \r
439
+ .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
440
+ .top-popup_footer [class*=btn]:not(.btn-transparent){ min-width: 100px; padding: 5px 14px; margin-left: 10px; }\r
441
+ .top-popup_footer [class*=btn]:first-child{ margin-left: 0; }\r
442
+ .top-popup_footer .btn.full_width{ margin: 0; flex-grow: 1; }`, w = `:root{\r
443
+ --top-popup-list-padding: 0px;\r
444
+ \r
445
+ --top-popup-listItem-radius: 0px;\r
446
+ --top-popup-listItem-padding: var(--top-padding-4);\r
447
+ }\r
448
+ \r
449
+ html.with_popup{ background: #808080; }\r
450
+ \r
451
+ .top-popup-wrapper{\r
452
+ --top-popup-footer-offset: 25px;\r
453
+ \r
454
+ width: auto !important; height: auto !important;\r
455
+ position: fixed; top: 0 !important; right: 0 !important; left: 0 !important; overflow: hidden;\r
456
+ transition: background 0.3s;\r
457
+ }\r
458
+ \r
459
+ .top-popup-wrapper-shown:not(.top-popup-wrapper-closed){ background: rgba(0,0,0,0.5); backdrop-filter: blur(1px); }\r
460
+ .top-popup-wrapper-shown:not(.top-popup-wrapper-closed) > .top-popup{ opacity: 1 !important; }\r
461
+ \r
462
+ .top-popup{\r
463
+ border-radius: 8px 8px 0 0; width: auto !important; max-height: calc(100% - var(--header-height) - 12px); margin: 0 !important;\r
464
+ top: auto !important; right: 0 !important; bottom: 0 !important; left: 0 !important;\r
465
+ display: flex; flex-direction: column;\r
466
+ \r
467
+ /* невозможно опустить элемент вниз за экран на 100%, fix: opacity и translateY(80%) */\r
468
+ transform: translateY(80%);\r
469
+ \r
470
+ transition: opacity 0.3s, transform 0.3s;\r
471
+ }\r
472
+ \r
473
+ /* from top */\r
474
+ .top-popup-wrapper.p-from-top{\r
475
+ --top-popup-footer-offset: 0px;\r
476
+ \r
477
+ top: var(--header-height) !important;\r
478
+ }\r
479
+ .with_dialog .top-popup-wrapper.p-from-top{ top: 50px !important; }\r
480
+ .top-popup-wrapper.p-from-top > .top-popup{\r
481
+ border-radius: 0 0 8px 8px; max-height: calc(100% - 24px); top: 0 !important; bottom: auto !important;\r
482
+ transform: translateY(calc(-100% - 24px));\r
483
+ }\r
484
+ \r
485
+ /* content */\r
486
+ ul.top-popup_content{\r
487
+ --scroll-padding-top: 0px;\r
488
+ --scroll-padding-bottom: var(--scroll-padding-top);\r
489
+ \r
490
+ gap: 0;\r
491
+ }\r
492
+ ul.top-popup_content li:not(:last-child){ border-bottom: 1px solid var(--top-popup-border-color); }\r
493
+ \r
494
+ .top-popup-wrapper.top-style_alt > .top-popup > ul > li{ border-bottom: none; }\r
495
+ \r
496
+ /* footer */\r
497
+ .top-popup_footer{\r
498
+ flex-direction: column-reverse;\r
499
+ }\r
500
+ .top-popup_footer > .top-button{\r
501
+ --top-forms-base-height: var(--top-forms-base-height_xl);\r
502
+ \r
503
+ width: 100%;\r
504
+ }\r
505
+ \r
506
+ /* listTitle */\r
507
+ ul.top-popup_content .top-popup_listItem-title{\r
508
+ --top-popup-padding-v: 12px;\r
509
+ }\r
510
+ \r
511
+ /* listDelimiter */\r
512
+ ul.top-popup_content .top-popup_listItem-delimiter{ background: var(--color-line-1-opacity); height: 4px; margin: 0; }\r
513
+ ul.top-popup_content li:first-child > .top-popup_listItem-delimiter{ border-top: 1px solid var(--top-popup-border-color); }`, P = `html:not(.with_dialog){ margin-right: 0 !important; }\r
514
+ \r
515
+ .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
516
+ .top-popup-wrapper.invert-x > .top-popup{ max-width: calc(100vw - var(--top-popup-right) - 16px); }\r
517
+ .top-popup-wrapper.invert-y > .top-popup{ max-height: calc(100vh - var(--top-popup-bottom) - 16px); }\r
518
+ \r
519
+ /* position */\r
520
+ .top-popup-wrapper.p1 > .top-popup{ max-height: calc(var(--top-popup-top) - var(--header-height) - 16px); }\r
521
+ .top-popup-wrapper.p3 > .top-popup{ max-height: calc(var(--top-popup-bottom) - 16px); }\r
522
+ .top-popup-wrapper.p2 > .top-popup{ max-width: calc(var(--top-popup-right) - 16px); }\r
523
+ .top-popup-wrapper.p4 > .top-popup{ max-width: calc(var(--top-popup-left) - 16px); }\r
524
+ \r
525
+ /* notch */\r
526
+ .top-popup-wrapper.p1.with_notch > .top-popup,\r
527
+ .top-popup-wrapper.p3.with_notch > .top-popup{ margin-left: -16px !important; }\r
528
+ .top-popup-wrapper.p1.with_notch > .notch,\r
529
+ .top-popup-wrapper.p3.with_notch > .notch{ margin-left: -8px !important; }\r
530
+ \r
531
+ .top-popup-wrapper.p1.with_notch.invert-x,\r
532
+ .top-popup-wrapper.p3.with_notch.invert-x{ margin-left: 3px !important; }\r
533
+ .top-popup-wrapper.p1.with_notch.invert-x > .notch,\r
534
+ .top-popup-wrapper.p3.with_notch.invert-x > .notch{ margin-left: -9px !important; }\r
535
+ \r
536
+ /* listMore */\r
537
+ ul.top-popup_content li > * > i.top-popup_listMore{ visibility: hidden; transition: none; }\r
538
+ ul.top-popup_content li:hover > * > i.top-popup_listMore,\r
539
+ ul.top-popup_content li > *.top-active > i.top-popup_listMore,\r
538
540
  ul.top-popup_content li > * > i.top-popup_listMore.top-active{ visibility: visible; }`;
539
541
  f.appendStyle(x);
540
542
  f.appendStyle(w, "m");
@@ -593,19 +595,19 @@ class g extends m {
593
595
  }
594
596
  async mount() {
595
597
  const t = this.vueGetComponent();
596
- if (this.popupParent = i.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)
597
- this.type = "vue", this.options.popup = "", this.elPopup = n.genEl("div", {}, this.options.popup);
598
+ if (this.popupParent = n.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)
599
+ this.type = "vue", this.options.popup = "", this.elPopup = r.genEl("div", {}, this.options.popup);
598
600
  else if (this.options.popup.match(/^[#.]/))
599
601
  this.type = "selector", this.elPopup = document.querySelector(`${this.options.popup}.template`);
600
602
  else {
601
603
  if (this.type = "html", this.options.useOriginal)
602
604
  throw "Option useOriginal not allowed for text templates";
603
- this.elPopup = n.genEl("div", {}, this.options.popup);
605
+ this.elPopup = r.genEl("div", {}, this.options.popup);
604
606
  }
605
607
  if (!this.elPopup || t != null && t.opened) {
606
608
  if (this.options.useOriginal || t != null && t.opened) {
607
609
  if (t != null && t.opened ? this.elPopup = t.popup.elPopup : this.elPopup = document.querySelector(`${this.options.popup}.top-popup-wrapper-shown`), this.elPopup) {
608
- this.el.dataset.topPopupOpened = "", this.elActiveByDefault || this.el.classList.remove("top-active"), i.close(this.elPopup), setTimeout(() => this.mount(), 300);
610
+ this.el.dataset.topPopupOpened = "", this.elActiveByDefault || this.el.classList.remove("top-active"), n.close(this.elPopup), setTimeout(() => this.mount(), 300);
609
611
  return;
610
612
  }
611
613
  throw "Option useOriginal state allowed only elements .template";
@@ -614,7 +616,7 @@ class g extends m {
614
616
  }
615
617
  if (!this.elPopup)
616
618
  return;
617
- 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((e) => e.dataset.topPopupPosBy = "fixed"), n.querySelectorAllArray(this.elPopup, ".top-popup-wrapper").forEach((e) => e.remove()))), i.decoratorBeforeOpen(this), t && (this.options.class = t.classRef.value), this.elPopupInner = document.createElement("div"), this.elPopupInner.classList.add("top-popupPanel", "top-popup"); this.elPopup.firstChild; )
619
+ 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((e) => e.dataset.topPopupPosBy = "fixed"), r.querySelectorAllArray(this.elPopup, ".top-popup-wrapper").forEach((e) => e.remove()))), n.decoratorBeforeOpen(this), t && (this.options.class = t.classRef.value), this.elPopupInner = document.createElement("div"), this.elPopupInner.classList.add("top-popupPanel", "top-popup"); this.elPopup.firstChild; )
618
620
  this.elPopupInner.appendChild(this.elPopup.firstChild);
619
621
  if (this.elPopup.append(this.elPopupInner), this.elPopup.classList.add("top-popup-wrapper"), this.options.class) {
620
622
  const e = this.options.class.split(" ");
@@ -622,9 +624,9 @@ class g extends m {
622
624
  }
623
625
  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.elPopupBody = this.elPopupInner.querySelector(".top-popup_content"), this.elPopupFooter = this.elPopupInner.querySelector(".top-popup_footer");
624
626
  const p = !!this.elPopup.querySelector('[data-widget="search"]');
625
- this.options.isFullScreen && !p && (this.elPopupHeader || (this.elPopupHeader = n.genEl("i", { class: "top-popup_header" }), this.elPopupInner.prepend(this.elPopupHeader), this.elPopupHeader.prepend(n.genEl("i", { class: "a closer" }, this.options.i18n.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.style.width = this.el.offsetWidth + "px", this.elPopup.style.height = this.el.offsetHeight + "px", this.elPopup.style.top = this.el.offsetTop + "px", this.elPopup.style.right = parseInt(this.el.style.right || 0) + "px", this.elPopup.style.bottom = parseInt(this.el.style.bottom || 0) + "px", this.el.parentElement.insertBefore(this.elPopup, this.el), this.elPopup.classList.remove("template"), this.options.invertX && this.elPopup.classList.add("invert-x");
627
+ this.options.isFullScreen && !p && (this.elPopupHeader || (this.elPopupHeader = r.genEl("i", { class: "top-popup_header" }), this.elPopupInner.prepend(this.elPopupHeader), this.elPopupHeader.prepend(r.genEl("i", { class: "a closer" }, this.options.i18n.Close)), this.elPopupHeader.append(r.genEl("i", { class: "top-popup_headerButton" })))), 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.style.width = this.el.offsetWidth + "px", this.elPopup.style.height = this.el.offsetHeight + "px", this.elPopup.style.top = this.el.offsetTop + "px", this.elPopup.style.right = parseInt(this.el.style.right || 0) + "px", this.elPopup.style.bottom = parseInt(this.el.style.bottom || 0) + "px", this.el.parentElement.insertBefore(this.elPopup, this.el), this.elPopup.classList.remove("template"), this.options.invertX && this.elPopup.classList.add("invert-x");
626
628
  let o = !!this.el.closest(".modal-header");
627
- o || (o = !!this.el.closest("#top_panel")), o || (o = !!this.el.closest("#secondmenu")), o && this.elPopup.classList.add("p-from-top"), setTimeout(() => this.elPopup.classList.add("top-popup-wrapper-shown")), this.elFront && !this.elFront.matches("body") && (this.elFront.append(this.elPopup), this.shift.top = 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.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.$ && this.$.trigger("aftershow.top-menu-popup", [jQuery(this.elPopup)]), this.recalcPosition(), this.elPopup.setAttribute("tabindex", 0), this.focus(), i.decoratorAfterOpen(this), this.mountEvents();
629
+ o || (o = !!this.el.closest("#top_panel")), o || (o = !!this.el.closest("#secondmenu")), o && this.elPopup.classList.add("p-from-top"), setTimeout(() => this.elPopup.classList.add("top-popup-wrapper-shown")), this.elFront && !this.elFront.matches("body") && (this.elFront.append(this.elPopup), this.shift.top = 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.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.$ && this.$.trigger("aftershow.top-menu-popup", [jQuery(this.elPopup)]), this.recalcPosition(), this.elPopup.setAttribute("tabindex", 0), this.focus(), n.decoratorAfterOpen(this), this.mountEvents();
628
630
  }
629
631
  async mountJQuery() {
630
632
  typeof jQuery == "function" && (this.$ = jQuery(this.el));
@@ -633,8 +635,8 @@ class g extends m {
633
635
  * Выполнить фокусировку на нужный элемент после открытия окна
634
636
  */
635
637
  focus() {
636
- let t = n.querySelectorVisible(this.elPopup, ".top-popup-autofocus");
637
- 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.focus();
638
+ let t = r.querySelectorVisible(this.elPopup, ".top-popup-autofocus");
639
+ 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.focus();
638
640
  }
639
641
  mountEvents() {
640
642
  this.addEventListenerWithUnmount(document, "mousedown", (t) => this.onMousedown(t)), this.addEventListenerWithUnmount(this.elPopup, "focus", (t) => this.onFocus(t)), this.options.openByHover && (this.addEventListenerWithUnmount(this.elPopup, "mouseleave", (t) => this.onMouseleave(t)), this.addEventListenerWithUnmount(this.elPopupInner, "mouseleave", (t) => this.onMouseleave(t))), this.options.isFullScreen && this.addEventListenerWithUnmount(this.elPopupBody, "touchmove", (t) => this.onTouchmove(t));
@@ -646,8 +648,8 @@ class g extends m {
646
648
  onMousedown(t) {
647
649
  if (!this.elPopup || !this.isFirstClick || (this.isFirstClick = !1, setTimeout(() => this.isFirstClick = !0), t.button !== 0))
648
650
  return;
649
- let p = n.querySelectorVisibleLast(document.body, ":scope > .top-popup-wrapper");
650
- p && p !== this.elPopup || (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") || i.decoratorIsIgnoreOuterClick(t) || i.close(this.elPopup)));
651
+ let p = r.querySelectorVisibleLast(document.body, ":scope > .top-popup-wrapper");
652
+ p && p !== this.elPopup || (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") || n.decoratorIsIgnoreOuterClick(t) || n.close(this.elPopup)));
651
653
  }
652
654
  /**
653
655
  * Закрыть другие Popup при фокусе на элемент формы в текущем
@@ -656,9 +658,9 @@ class g extends m {
656
658
  onFocus(t) {
657
659
  if (t.target.matches("input") || this.isClosed)
658
660
  return;
659
- i.getAllVisible().forEach((o) => {
660
- var e, r, l;
661
- this.elPopup.contains(o) || ((e = this.popupParent) == null ? void 0 : e.elPopup) === o || ((l = (r = this.popupParent) == null ? void 0 : r.popupParent) == null ? void 0 : l.elPopup) === o || i.close(o);
661
+ n.getAllVisible().forEach((o) => {
662
+ var e, i, l;
663
+ this.elPopup.contains(o) || ((e = this.popupParent) == null ? void 0 : e.elPopup) === o || ((l = (i = this.popupParent) == null ? void 0 : i.popupParent) == null ? void 0 : l.elPopup) === o || n.close(o);
662
664
  });
663
665
  }
664
666
  /**
@@ -667,14 +669,14 @@ class g extends m {
667
669
  */
668
670
  onMouseleave(t) {
669
671
  setTimeout(() => {
670
- this.elPopupInner.matches(":hover") || i.close(this.elPopup);
672
+ this.elPopupInner.matches(":hover") || n.close(this.elPopup);
671
673
  }, 100);
672
674
  }
673
675
  /**
674
676
  * Контроль положения Popup при fixed позиционировании
675
677
  */
676
678
  onResize() {
677
- this.elPopup.parentElement !== document.body && document.body.append(this.elPopup), this.elPopup.style.top = n.offset(this.el).top + "px", this.elPopup.style.left = n.offset(this.el).left + "px";
679
+ this.elPopup.parentElement !== document.body && document.body.append(this.elPopup), this.elPopup.style.top = r.offset(this.el).top + "px", this.elPopup.style.left = r.offset(this.el).left + "px";
678
680
  }
679
681
  unmount() {
680
682
  super.unmount(), this.el.dataset.topPopupOpened = "", this.elActiveByDefault || this.el.classList.remove("top-active");
@@ -699,20 +701,20 @@ class g extends m {
699
701
  }
700
702
  const o = this.elPopup.getBoundingClientRect();
701
703
  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.style.maxWidth = "unset", this.elPopupInner.style.maxHeight = "unset";
702
- let e = !1, r = !1, l = !1, h = !1, a = o.left > window.innerWidth / 2, c = o.top > window.innerHeight / 2;
703
- t === 4 && (a = !a), t === 1 && (c = !c);
704
- const s = this.elPopupInner.getBoundingClientRect(), u = window.innerWidth - s.right, v = window.innerHeight - s.bottom, d = 8;
705
- s.top < d && (e = !0), u < d && (r = !0), v < d && (l = !0), s.left < d && (h = !0), e && (t === 0 || t === 1) && c && (t = 3), l && t === 3 && c && (t = 1), r && t === 2 && a && (t = 4), h && t === 4 && a && (t = 2), r && (t === 0 || t === 1 || t === 3) && this.elPopup.classList.add("invert-x"), l && (t === 2 || t === 4) && c && (t === 2 && !a && this.elPopup.classList.add("invert-y"), t === 4 && !a && 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.style.maxWidth = "", this.elPopupInner.style.maxHeight = "", i.scrollToActive(this.elPopup);
704
+ let e = !1, i = !1, l = !1, h = !1, a = o.left > window.innerWidth / 2, u = o.top > window.innerHeight / 2;
705
+ t === 4 && (a = !a), t === 1 && (u = !u);
706
+ const s = this.elPopupInner.getBoundingClientRect(), c = window.innerWidth - s.right, v = window.innerHeight - s.bottom, d = 8;
707
+ s.top < d && (e = !0), c < d && (i = !0), v < d && (l = !0), s.left < d && (h = !0), e && (t === 0 || t === 1) && u && (t = 3), l && t === 3 && u && (t = 1), i && t === 2 && a && (t = 4), h && t === 4 && a && (t = 2), i && (t === 0 || t === 1 || t === 3) && this.elPopup.classList.add("invert-x"), l && (t === 2 || t === 4) && u && (t === 2 && !a && this.elPopup.classList.add("invert-y"), t === 4 && !a && 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.style.maxWidth = "", this.elPopupInner.style.maxHeight = "", n.scrollToActive(this.elPopup);
706
708
  }
707
709
  onTouchmove(t) {
708
710
  t.currentTarget.scrollWidth > t.currentTarget.offsetWidth || t.target.parentElement.scrollWidth > t.target.parentElement.offsetWidth || t.currentTarget.matches(".has_scroll") || t.preventDefault();
709
711
  }
710
712
  close() {
711
- this.isClosed || (this.isClosed = !0, this.$ && this.$.trigger("afterclose.top-menu-popup", [jQuery(this.elPopup)]), !i.noClose && (this.unmount(), this.elPopup.classList.add("top-popup-wrapper-closed"), setTimeout(() => {
712
- var o, e, r;
713
- this.vueClose(), this.options.useOriginal ? (this.elPopup.removeAttribute("style"), this.elPopup.classList.remove("top-popup-wrapper-shown", "top-popup-wrapper-closed"), this.elPopup.classList.add("template"), this.elStartPosition.append(this.elPopup), (o = this.elPopup.querySelector("div.top-popup_content.top-column")) == null || o.classList.remove("top-column"), (e = this.elPopup.querySelector(".notch-border")) == null || e.remove(), (r = this.elPopup.querySelector(".notch")) == null || r.remove(), this.elPopupInner.replaceWith(...this.elPopupInner.childNodes), n.storageClear(this.elPopup)) : (n.storageClear(this.elPopup), this.elPopup.remove(), delete this.elPopup);
714
- const t = i.getAllVisible(), p = t.length && t[t.length - 1];
715
- p ? i.getPopup(p).focus() : document.documentElement.classList.remove("with_popup");
713
+ this.isClosed || (this.isClosed = !0, this.$ && this.$.trigger("afterclose.top-menu-popup", [jQuery(this.elPopup)]), !n.noClose && (this.unmount(), this.elPopup.classList.add("top-popup-wrapper-closed"), setTimeout(() => {
714
+ var o, e, i;
715
+ this.vueClose(), this.options.useOriginal ? (this.elPopup.removeAttribute("style"), this.elPopup.classList.remove("top-popup-wrapper-shown", "top-popup-wrapper-closed"), this.elPopup.classList.add("template"), this.elStartPosition.append(this.elPopup), (o = this.elPopup.querySelector("div.top-popup_content.top-column")) == null || o.classList.remove("top-column"), (e = this.elPopup.querySelector(".notch-border")) == null || e.remove(), (i = this.elPopup.querySelector(".notch")) == null || i.remove(), this.elPopupInner.replaceWith(...this.elPopupInner.childNodes), r.storageClear(this.elPopup)) : (r.storageClear(this.elPopup), this.elPopup.remove(), delete this.elPopup);
716
+ const t = n.getAllVisible(), p = t.length && t[t.length - 1];
717
+ p ? n.getPopup(p).focus() : document.documentElement.classList.remove("with_popup");
716
718
  }, 300)));
717
719
  }
718
720
  async vueOpen() {
@@ -725,11 +727,11 @@ class g extends m {
725
727
  }
726
728
  // получить vueConnectors компонента Popup
727
729
  vueGetComponent() {
728
- return i.vueConnectors.get(this.el.dataset.topPopupId);
730
+ return n.vueConnectors.get(this.el.dataset.topPopupId);
729
731
  }
730
732
  }
731
733
  b.init();
732
734
  export {
733
735
  g as default
734
736
  };
735
- //# sourceMappingURL=popup-05538243.es.js.map
737
+ //# sourceMappingURL=popup-a622fe31.es.js.map