@topvisor/ui 1.0.42-policy.0 → 1.1.0-addNativeDialog.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 (511) hide show
  1. package/.chunks/core-6NjSIwIA.amd.js +2 -0
  2. package/.chunks/{core-SEtL6T0A.amd.js.map → core-6NjSIwIA.amd.js.map} +1 -1
  3. package/.chunks/{core-BCV4xehV.es.js → core-CKa0qCEH.es.js} +4 -4
  4. package/.chunks/{core-BCV4xehV.es.js.map → core-CKa0qCEH.es.js.map} +1 -1
  5. package/.chunks/datepicker-DsKl-YZR.amd.js +2 -0
  6. package/.chunks/{datepicker-Ba8QPoiv.amd.js.map → datepicker-DsKl-YZR.amd.js.map} +1 -1
  7. package/.chunks/{datepicker-DHxSFb-9.es.js → datepicker-U31BrqE_.es.js} +2 -2
  8. package/.chunks/{datepicker-DHxSFb-9.es.js.map → datepicker-U31BrqE_.es.js.map} +1 -1
  9. package/.chunks/dialog_selectorRegions-BCXCCaXi.amd.js +2 -0
  10. package/.chunks/{dialog_selectorRegions-CiWJsA9r.amd.js.map → dialog_selectorRegions-BCXCCaXi.amd.js.map} +1 -1
  11. package/.chunks/{dialog_selectorRegions-Cd7_dHoH.es.js → dialog_selectorRegions-C_RhsGzk.es.js} +4 -4
  12. package/.chunks/{dialog_selectorRegions-Cd7_dHoH.es.js.map → dialog_selectorRegions-C_RhsGzk.es.js.map} +1 -1
  13. package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-BhAl3bT-.es.js +700 -0
  14. package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-BhAl3bT-.es.js.map +1 -0
  15. package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-DVp-tQ6l.amd.js +2 -0
  16. package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-DVp-tQ6l.amd.js.map +1 -0
  17. package/.chunks/field-Cvv0SRcJ.amd.js +2 -0
  18. package/.chunks/field-Cvv0SRcJ.amd.js.map +1 -0
  19. package/.chunks/field-CyyFzM-Y.es.js +16 -0
  20. package/.chunks/field-CyyFzM-Y.es.js.map +1 -0
  21. package/.chunks/forms-DRhpgERJ.amd.js +3 -0
  22. package/.chunks/{forms-L6BGV_om.amd.js.map → forms-DRhpgERJ.amd.js.map} +1 -1
  23. package/.chunks/{forms-DC7ffuv2.es.js → forms-t2AEUjqg.es.js} +16 -16
  24. package/.chunks/{forms-DC7ffuv2.es.js.map → forms-t2AEUjqg.es.js.map} +1 -1
  25. package/.chunks/lazy-Dr-Frbwe.amd.js +2 -0
  26. package/.chunks/lazy-Dr-Frbwe.amd.js.map +1 -0
  27. package/.chunks/lazy-Dy9IVVUy.es.js +19 -0
  28. package/.chunks/lazy-Dy9IVVUy.es.js.map +1 -0
  29. package/.chunks/{listItem.vue_vue_type_script_setup_true_lang-CXp02bYr.es.js → listItem.vue_vue_type_script_setup_true_lang-B6psuRkm.es.js} +2 -2
  30. package/.chunks/{listItem.vue_vue_type_script_setup_true_lang-CXp02bYr.es.js.map → listItem.vue_vue_type_script_setup_true_lang-B6psuRkm.es.js.map} +1 -1
  31. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-C8PDRggQ.amd.js +2 -0
  32. package/.chunks/{listItem.vue_vue_type_script_setup_true_lang-M0ZTpQlF.amd.js.map → listItem.vue_vue_type_script_setup_true_lang-C8PDRggQ.amd.js.map} +1 -1
  33. package/.chunks/{menu.vue_vue_type_style_index_0_lang-DNsbNhVH.es.js → menu.vue_vue_type_style_index_0_lang-6kqWYFuX.es.js} +2 -2
  34. package/.chunks/{menu.vue_vue_type_style_index_0_lang-DNsbNhVH.es.js.map → menu.vue_vue_type_style_index_0_lang-6kqWYFuX.es.js.map} +1 -1
  35. package/.chunks/menu.vue_vue_type_style_index_0_lang-DRHk9iBB.amd.js +2 -0
  36. package/.chunks/{menu.vue_vue_type_style_index_0_lang-DepdFfhE.amd.js.map → menu.vue_vue_type_style_index_0_lang-DRHk9iBB.amd.js.map} +1 -1
  37. package/.chunks/{notice-DQXlrM4Y.es.js → notice-4bdzRXtl.es.js} +2 -2
  38. package/.chunks/{notice-DQXlrM4Y.es.js.map → notice-4bdzRXtl.es.js.map} +1 -1
  39. package/.chunks/{notice-ZTC1xm1R.amd.js → notice-DQ9qFyQ2.amd.js} +3 -3
  40. package/.chunks/{notice-ZTC1xm1R.amd.js.map → notice-DQ9qFyQ2.amd.js.map} +1 -1
  41. package/.chunks/page.vue_vue_type_script_setup_true_lang-BgGzBbMZ.amd.js +2 -0
  42. package/.chunks/page.vue_vue_type_script_setup_true_lang-BgGzBbMZ.amd.js.map +1 -0
  43. package/.chunks/page.vue_vue_type_script_setup_true_lang-BstJVz3j.es.js +176 -0
  44. package/.chunks/page.vue_vue_type_script_setup_true_lang-BstJVz3j.es.js.map +1 -0
  45. package/.chunks/pageComponent.vue_vue_type_script_setup_true_lang-B6ollFUC.amd.js +2 -0
  46. package/.chunks/pageComponent.vue_vue_type_script_setup_true_lang-B6ollFUC.amd.js.map +1 -0
  47. package/.chunks/pageComponent.vue_vue_type_script_setup_true_lang-DbaqFJra.es.js +56 -0
  48. package/.chunks/pageComponent.vue_vue_type_script_setup_true_lang-DbaqFJra.es.js.map +1 -0
  49. package/.chunks/{popup-B7GI-vlM.es.js → popup-DuraSW2f.es.js} +2 -2
  50. package/.chunks/{popup-B7GI-vlM.es.js.map → popup-DuraSW2f.es.js.map} +1 -1
  51. package/.chunks/popup-IcMnYYXr.amd.js +2 -0
  52. package/.chunks/{popup-Kvk7IPNI.amd.js.map → popup-IcMnYYXr.amd.js.map} +1 -1
  53. package/.chunks/punycode.es6-CNOnFR2-.amd.js +2 -0
  54. package/.chunks/{punycode.es6-C2yitnNb.amd.js.map → punycode.es6-CNOnFR2-.amd.js.map} +1 -1
  55. package/.chunks/punycode.es6-CgGegfA_.es.js +134 -0
  56. package/.chunks/{punycode.es6-CNI-zL6U.es.js.map → punycode.es6-CgGegfA_.es.js.map} +1 -1
  57. package/.chunks/store-CX_6ZXhO.es.js.map +1 -1
  58. package/.chunks/store-YRW59xEF.amd.js +2 -0
  59. package/.chunks/{store-esTid5oI.amd.js.map → store-YRW59xEF.amd.js.map} +1 -1
  60. package/.chunks/{utils-BkchlCXw.es.js → utils-Bd5whKoS.es.js} +5 -5
  61. package/.chunks/{utils-BkchlCXw.es.js.map → utils-Bd5whKoS.es.js.map} +1 -1
  62. package/.chunks/utils-BkF4g-PH.amd.js +2 -0
  63. package/.chunks/{utils-Bg7IV0KZ.amd.js.map → utils-BkF4g-PH.amd.js.map} +1 -1
  64. package/api/additional.amd.js +2 -0
  65. package/api/additional.amd.js.map +1 -0
  66. package/api/additional.js +66 -0
  67. package/api/additional.js.map +1 -0
  68. package/api/index.amd.js +2 -0
  69. package/api/index.amd.js.map +1 -0
  70. package/api/index.js +257 -0
  71. package/api/index.js.map +1 -0
  72. package/assets/themes/dark-th.css +1 -1
  73. package/assets/themes/dark.css +1 -1
  74. package/assets/themes/light.css +1 -1
  75. package/charts/charts.amd.js +1 -1
  76. package/charts/charts.amd.js.map +1 -1
  77. package/charts/charts.js +1 -1
  78. package/charts/charts.js.map +1 -1
  79. package/core/app.amd.js +1 -1
  80. package/core/app.amd.js.map +1 -1
  81. package/core/app.js +8 -8
  82. package/core/app.js.map +1 -1
  83. package/dialog/dialog.amd.js +1 -1
  84. package/dialog/dialog.amd.js.map +1 -1
  85. package/dialog/dialog.js +8 -57
  86. package/dialog/dialog.js.map +1 -1
  87. package/dialogV1AndDialogV2/dialog.amd.js +2 -0
  88. package/dialogV1AndDialogV2/dialog.amd.js.map +1 -0
  89. package/dialogV1AndDialogV2/dialog.js +11 -0
  90. package/dialogV1AndDialogV2/dialog.js.map +1 -0
  91. package/dialogV1Original/dialog.amd.js +2 -0
  92. package/dialogV1Original/dialog.amd.js.map +1 -0
  93. package/dialogV1Original/dialog.js +11 -0
  94. package/dialogV1Original/dialog.js.map +1 -0
  95. package/dialogV2/dialog.amd.js +2 -0
  96. package/dialogV2/dialog.amd.js.map +1 -0
  97. package/dialogV2/dialog.js +11 -0
  98. package/dialogV2/dialog.js.map +1 -0
  99. package/extra/extra.amd.js +1 -1
  100. package/extra/extra.amd.js.map +1 -1
  101. package/forms/forms.amd.js +1 -1
  102. package/forms/forms.js +1 -1
  103. package/forms/helpers.amd.js +1 -1
  104. package/formsExt/formsExt.amd.js +1 -1
  105. package/formsExt/formsExt.amd.js.map +1 -1
  106. package/formsExt/formsExt.js +3 -4
  107. package/formsExt/formsExt.js.map +1 -1
  108. package/layout/layout.amd.js +1 -1
  109. package/layout/layout.amd.js.map +1 -1
  110. package/layout/layout.js +1 -1
  111. package/package.json +3 -4
  112. package/popup/popup.amd.js +1 -1
  113. package/popup/popup.amd.js.map +1 -1
  114. package/popup/popup.js +2 -2
  115. package/popup/popup.js.map +1 -1
  116. package/popup/worker.amd.js +1 -1
  117. package/popup/worker.amd.js.map +1 -1
  118. package/popup/worker.js +2 -2
  119. package/popup/worker.js.map +1 -1
  120. package/project/project.amd.js +1 -1
  121. package/project/project.amd.js.map +1 -1
  122. package/project/project.js +157 -157
  123. package/project/project.js.map +1 -1
  124. package/tabs/tabs.amd.js +1 -1
  125. package/tabs/tabs.amd.js.map +1 -1
  126. package/tabs/tabs.js.map +1 -1
  127. package/tabsView/tabsView.amd.js +1 -1
  128. package/tabsView/tabsView.amd.js.map +1 -1
  129. package/tabsView/tabsView.js +1 -1
  130. package/tabsView/tabsView.js.map +1 -1
  131. package/types/api/additional.d.ts +2 -0
  132. package/types/api/api/additional.d.ts +1 -0
  133. package/types/api/api/client/client.d.ts +55 -0
  134. package/types/api/api/client/request-options.d.ts +1 -0
  135. package/types/api/api/client/request.d.ts +2 -0
  136. package/types/api/api/index.d.ts +12 -0
  137. package/types/api/api/tests/model.d.ts +0 -0
  138. package/types/api/api/tests/test.d.ts +16 -0
  139. package/types/api/api/types/api.d.ts +139 -0
  140. package/types/api/api/types/client/middleware.d.ts +65 -0
  141. package/types/api/api/types/client/options.d.ts +60 -0
  142. package/types/api/api/types/client/request-context.d.ts +35 -0
  143. package/types/api/api/types/client/request-options.d.ts +73 -0
  144. package/types/api/api/types/client/request.d.ts +85 -0
  145. package/types/api/api/types/ext.d.ts +51 -0
  146. package/types/api/api/types/field.d.ts +33 -0
  147. package/types/api/api/types/index.d.ts +11 -0
  148. package/types/api/api/types/schema.d.ts +50 -0
  149. package/types/api/api/types/tv.d.ts +59 -0
  150. package/types/api/api/types/utils.d.ts +51 -0
  151. package/types/api/api/utils/common.d.ts +16 -0
  152. package/types/api/api/utils/field.d.ts +8 -0
  153. package/types/api/api/utils/filters.d.ts +48 -0
  154. package/types/api/api/utils/lazy.d.ts +13 -0
  155. package/types/api/index.d.ts +2 -0
  156. package/types/components/dialog/dialog/dialog.vue.d.ts +28 -0
  157. package/types/components/dialog/lib/utils.d.ts +54 -0
  158. package/types/components/dialog/lib/worker.d.ts +78 -0
  159. package/types/components/dialogV1AndDialogV2/dialog/composables/asyncDialogHandle.d.ts +51 -0
  160. package/types/components/dialogV1AndDialogV2/dialog/composables/dialogHandle.d.ts +108 -0
  161. package/types/components/dialogV1AndDialogV2/dialog/composables/types.d.ts +11 -0
  162. package/types/components/dialogV1AndDialogV2/dialog/composables/utils.d.ts +23 -0
  163. package/types/components/dialogV1AndDialogV2/dialog/dialog.vue.d.ts +28 -0
  164. package/types/components/dialogV1AndDialogV2/dialog/dialogs/dialogs.vue.d.ts +13 -0
  165. package/types/components/dialogV1AndDialogV2/dialog/page/types.d.ts +72 -0
  166. package/types/components/dialogV1AndDialogV2/dialog/pageComponent/types.d.ts +18 -0
  167. package/types/components/dialogV1AndDialogV2/dialog/stories/dialog_example/pages/utils.d.ts +7 -0
  168. package/types/components/dialogV1AndDialogV2/dialog/types.d.ts +58 -0
  169. package/types/components/dialogV1AndDialogV2/dialog.d.ts +6 -0
  170. package/types/components/dialogV1AndDialogV2/lib/types.d.ts +44 -0
  171. package/types/components/dialogV1AndDialogV2/lib/utils.d.ts +18 -0
  172. package/types/components/dialogV1AndDialogV2/lib/utils.globalEvents.d.ts +8 -0
  173. package/types/components/dialogV1AndDialogV2/lib/worker.d.ts +72 -0
  174. package/types/components/dialogV1Original/dialog/composables/asyncDialogHandle.d.ts +51 -0
  175. package/types/components/dialogV1Original/dialog/composables/dialogHandle.d.ts +108 -0
  176. package/types/components/dialogV1Original/dialog/composables/types.d.ts +11 -0
  177. package/types/components/dialogV1Original/dialog/composables/utils.d.ts +23 -0
  178. package/types/components/dialogV1Original/dialog/dialogs/dialogs.vue.d.ts +13 -0
  179. package/types/components/dialogV1Original/dialog/page/types.d.ts +72 -0
  180. package/types/components/dialogV1Original/dialog/pageComponent/types.d.ts +18 -0
  181. package/types/components/dialogV1Original/dialog/stories/dialog_example/pages/utils.d.ts +7 -0
  182. package/types/components/dialogV1Original/dialog/types.d.ts +58 -0
  183. package/types/components/dialogV1Original/dialog.d.ts +6 -0
  184. package/types/components/dialogV1Original/lib/types.d.ts +44 -0
  185. package/types/components/dialogV1Original/lib/utils.globalEvents.d.ts +8 -0
  186. package/types/components/dialogV2/dialog/composables/asyncDialogHandle.d.ts +51 -0
  187. package/types/components/dialogV2/dialog/composables/dialogHandle.d.ts +108 -0
  188. package/types/components/dialogV2/dialog/composables/types.d.ts +11 -0
  189. package/types/components/dialogV2/dialog/composables/utils.d.ts +23 -0
  190. package/types/components/dialogV2/dialog/dialog.vue.d.ts +28 -0
  191. package/types/components/dialogV2/dialog/dialogs/dialogs.vue.d.ts +13 -0
  192. package/types/components/dialogV2/dialog/page/types.d.ts +72 -0
  193. package/types/components/dialogV2/dialog/pageComponent/types.d.ts +18 -0
  194. package/types/components/dialogV2/dialog/stories/dialog_example/pages/utils.d.ts +7 -0
  195. package/types/components/dialogV2/dialog/types.d.ts +58 -0
  196. package/types/components/dialogV2/dialog.d.ts +6 -0
  197. package/types/components/dialogV2/lib/types.d.ts +44 -0
  198. package/types/components/dialogV2/lib/utils.d.ts +15 -0
  199. package/types/components/dialogV2/lib/utils.globalEvents.d.ts +8 -0
  200. package/types/components/dialogV2/lib/worker.d.ts +62 -0
  201. package/{components → types/components}/forms/checkbox/checkbox.vue.d.ts +2 -2
  202. package/types/components/formsExt/policy/policy.vue.d.ts +8 -0
  203. package/{components → types/components}/formsExt/policy/types.d.ts +0 -4
  204. package/{components → types/components}/project/selectorRegion/dialog_selectorRegions/dialog_selectorRegions.vue.d.ts +1 -1
  205. package/{components → types/components}/project/selectorRegion/utils/utils.d.ts +1 -1
  206. package/types/dialogV1AndDialogV2/dialog.d.ts +2 -0
  207. package/types/dialogV1Original/dialog.d.ts +2 -0
  208. package/types/dialogV2/dialog.d.ts +2 -0
  209. package/types/for-delete/dark-positions.d.ts +1 -0
  210. package/types/for-delete/dark-th-positions.d.ts +1 -0
  211. package/types/for-delete/dark-th.d.ts +1 -0
  212. package/types/for-delete/dark.d.ts +1 -0
  213. package/types/for-delete/light-positions.d.ts +1 -0
  214. package/types/for-delete/light.d.ts +1 -0
  215. package/types/forms/helpers.d.ts +1 -0
  216. package/utils/check.amd.js +1 -1
  217. package/utils/check.amd.js.map +1 -1
  218. package/utils/check.js.map +1 -1
  219. package/utils/clipboard.amd.js +2 -2
  220. package/utils/clipboard.amd.js.map +1 -1
  221. package/utils/clipboard.js +1 -1
  222. package/utils/clipboard.js.map +1 -1
  223. package/utils/date.amd.js +1 -1
  224. package/utils/date.js +1 -1
  225. package/utils/device.amd.js +1 -1
  226. package/utils/device.js +1 -1
  227. package/utils/dom.amd.js +1 -1
  228. package/utils/dom.amd.js.map +1 -1
  229. package/utils/dom.js.map +1 -1
  230. package/utils/image.amd.js +2 -2
  231. package/utils/image.amd.js.map +1 -1
  232. package/utils/image.js +1 -1
  233. package/utils/image.js.map +1 -1
  234. package/utils/keyboard.amd.js +1 -1
  235. package/utils/keyboard.amd.js.map +1 -1
  236. package/utils/keyboard.js.map +1 -1
  237. package/utils/lodash.amd.js +1 -1
  238. package/utils/lodash.js +1 -1
  239. package/utils/number.amd.js +1 -1
  240. package/utils/number.amd.js.map +1 -1
  241. package/utils/number.js.map +1 -1
  242. package/utils/price.amd.js +1 -1
  243. package/utils/price.amd.js.map +1 -1
  244. package/utils/price.js +1 -1
  245. package/utils/price.js.map +1 -1
  246. package/utils/route.amd.js +1 -1
  247. package/utils/route.amd.js.map +1 -1
  248. package/utils/route.js.map +1 -1
  249. package/utils/scroll.amd.js +1 -1
  250. package/utils/scroll.amd.js.map +1 -1
  251. package/utils/scroll.js.map +1 -1
  252. package/utils/searchers.amd.js +1 -1
  253. package/utils/searchers.amd.js.map +1 -1
  254. package/utils/searchers.js +3 -3
  255. package/utils/searchers.js.map +1 -1
  256. package/utils/store.amd.js +1 -1
  257. package/utils/string.amd.js +1 -1
  258. package/utils/string.amd.js.map +1 -1
  259. package/utils/string.js +1 -1
  260. package/utils/string.js.map +1 -1
  261. package/utils/system.amd.js +1 -1
  262. package/utils/system.amd.js.map +1 -1
  263. package/utils/system.js.map +1 -1
  264. package/utils/url.amd.js +2 -2
  265. package/utils/url.amd.js.map +1 -1
  266. package/utils/url.js +1 -1
  267. package/utils/url.js.map +1 -1
  268. package/.chunks/core-SEtL6T0A.amd.js +0 -2
  269. package/.chunks/datepicker-Ba8QPoiv.amd.js +0 -2
  270. package/.chunks/dialog_selectorRegions-CiWJsA9r.amd.js +0 -2
  271. package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-C-wpHg-4.amd.js +0 -2
  272. package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-C-wpHg-4.amd.js.map +0 -1
  273. package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-Deg17t8D.es.js +0 -322
  274. package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-Deg17t8D.es.js.map +0 -1
  275. package/.chunks/forms-L6BGV_om.amd.js +0 -3
  276. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-M0ZTpQlF.amd.js +0 -2
  277. package/.chunks/menu.vue_vue_type_style_index_0_lang-DepdFfhE.amd.js +0 -2
  278. package/.chunks/page.vue_vue_type_script_setup_true_lang-CDgPLGAn.es.js +0 -143
  279. package/.chunks/page.vue_vue_type_script_setup_true_lang-CDgPLGAn.es.js.map +0 -1
  280. package/.chunks/page.vue_vue_type_script_setup_true_lang-ZB87yGeU.amd.js +0 -2
  281. package/.chunks/page.vue_vue_type_script_setup_true_lang-ZB87yGeU.amd.js.map +0 -1
  282. package/.chunks/popup-Kvk7IPNI.amd.js +0 -2
  283. package/.chunks/punycode.es6-C2yitnNb.amd.js +0 -2
  284. package/.chunks/punycode.es6-CNI-zL6U.es.js +0 -134
  285. package/.chunks/store-esTid5oI.amd.js +0 -2
  286. package/.chunks/utils-BKooGtxR.amd.js +0 -2
  287. package/.chunks/utils-BKooGtxR.amd.js.map +0 -1
  288. package/.chunks/utils-Bg7IV0KZ.amd.js +0 -2
  289. package/.chunks/utils-CyqZFHE6.es.js +0 -304
  290. package/.chunks/utils-CyqZFHE6.es.js.map +0 -1
  291. package/components/charts/miniChart/stories/dummy.d.ts +0 -13
  292. package/components/charts/miniCharts/stories/dummy.d.ts +0 -6
  293. package/components/dialog/dialog/stories/autoload.d.ts +0 -2
  294. package/components/forms/select/stories/exampleOptions.d.ts +0 -5
  295. package/components/formsExt/checkboxGroup/stories/example.d.ts +0 -15
  296. package/components/formsExt/menu/stories/items.d.ts +0 -3
  297. package/components/formsExt/policy/policy.vue.d.ts +0 -21
  298. package/components/formsExt/radioGroup/stories/example.d.ts +0 -20
  299. package/components/formsExt/selector2/stories/dummyAPIRequest.d.ts +0 -9
  300. package/components/project/selectorCompetitors/stories/items.d.ts +0 -3
  301. package/components/project/selectorRegion/stories/searchers.d.ts +0 -3
  302. package/{charts → types/charts}/charts.d.ts +0 -0
  303. package/{components → types/components}/charts/charts.d.ts +0 -0
  304. package/{components → types/components}/charts/miniChart/miniChart.vue.d.ts +0 -0
  305. package/{components → types/components}/charts/miniChart/types.d.ts +0 -0
  306. package/{components → types/components}/charts/miniChart/utils/consts.d.ts +0 -0
  307. package/{components → types/components}/charts/miniCharts/miniCharts.d.ts +0 -0
  308. package/{components → types/components}/charts/miniCharts/miniCharts.vue.d.ts +0 -0
  309. package/{components → types/components}/core/notice/item/item.vue.d.ts +0 -0
  310. package/{components → types/components}/core/notice/item/types.d.ts +0 -0
  311. package/{components → types/components}/core/notice/notice.vue.d.ts +0 -0
  312. package/{components → types/components}/core/notice/types.d.ts +0 -0
  313. package/{components → types/components}/core/notice/utils.d.ts +0 -0
  314. package/{components → types/components}/dialog/dialog/composables/asyncDialogHandle.d.ts +0 -0
  315. package/{components → types/components}/dialog/dialog/composables/dialogHandle.d.ts +0 -0
  316. package/{components → types/components}/dialog/dialog/composables/types.d.ts +0 -0
  317. package/{components → types/components}/dialog/dialog/composables/utils.d.ts +0 -0
  318. package/{components → types/components}/dialog/dialog/dialogs/dialogs.vue.d.ts +0 -0
  319. package/{components → types/components}/dialog/dialog/page/page.vue.d.ts +0 -0
  320. package/{components → types/components}/dialog/dialog/page/types.d.ts +0 -0
  321. package/{components → types/components}/dialog/dialog/pageComponent/pageComponent.vue.d.ts +0 -0
  322. package/{components → types/components}/dialog/dialog/pageComponent/types.d.ts +0 -0
  323. package/{components → types/components}/dialog/dialog/stories/dialog_example/pages/utils.d.ts +0 -0
  324. package/{components → types/components}/dialog/dialog/types.d.ts +0 -0
  325. package/{components → types/components}/dialog/dialog.d.ts +0 -0
  326. package/{components → types/components}/dialog/lib/types.d.ts +0 -0
  327. package/{components → types/components}/dialog/lib/utils.globalEvents.d.ts +0 -0
  328. package/{components/dialog → types/components/dialogV1Original}/dialog/dialog.vue.d.ts +1 -1
  329. package/{components/dialog → types/components/dialogV1Original}/lib/utils.d.ts +0 -0
  330. package/{components/dialog → types/components/dialogV1Original}/lib/worker.d.ts +0 -0
  331. package/{components → types/components}/extra/extra.d.ts +0 -0
  332. package/{components → types/components}/extra/rive/rive.vue.d.ts +0 -0
  333. package/{components → types/components}/extra/rive/types.d.ts +0 -0
  334. package/{components → types/components}/forms/avatar/avatar.vue.d.ts +1 -1
  335. /package/{components → types/components}/forms/avatar/types.d.ts +0 -0
  336. /package/{components → types/components}/forms/button/button.vue.d.ts +0 -0
  337. /package/{components → types/components}/forms/button/types.d.ts +0 -0
  338. /package/{components → types/components}/forms/caption/caption.vue.d.ts +0 -0
  339. /package/{components → types/components}/forms/caption/types.d.ts +0 -0
  340. /package/{components → types/components}/forms/checkbox/types.d.ts +0 -0
  341. /package/{components → types/components}/forms/controlLabel/controlLabel.vue.d.ts +0 -0
  342. /package/{components → types/components}/forms/controlLabel/types.d.ts +0 -0
  343. /package/{components → types/components}/forms/forms.d.ts +0 -0
  344. /package/{components → types/components}/forms/helpers.d.ts +0 -0
  345. /package/{components → types/components}/forms/hint/hint.vue.d.ts +0 -0
  346. /package/{components → types/components}/forms/hint/types.d.ts +0 -0
  347. /package/{components → types/components}/forms/input/input.vue.d.ts +0 -0
  348. /package/{components → types/components}/forms/input/types.d.ts +0 -0
  349. /package/{components → types/components}/forms/inputDate/datepicker.d.ts +0 -0
  350. /package/{components → types/components}/forms/inputDate/inputDate.vue.d.ts +0 -0
  351. /package/{components → types/components}/forms/inputDate/types.d.ts +0 -0
  352. /package/{components → types/components}/forms/inputRange/inputRange.vue.d.ts +0 -0
  353. /package/{components → types/components}/forms/inputRange/types.d.ts +0 -0
  354. /package/{components → types/components}/forms/loadbar/loadbar.vue.d.ts +0 -0
  355. /package/{components → types/components}/forms/preloader/preloader.vue.d.ts +0 -0
  356. /package/{components → types/components}/forms/preloader/types.d.ts +0 -0
  357. /package/{components → types/components}/forms/radio/radio.vue.d.ts +0 -0
  358. /package/{components → types/components}/forms/radio/types.d.ts +0 -0
  359. /package/{components → types/components}/forms/select/select.vue.d.ts +0 -0
  360. /package/{components → types/components}/forms/select/types.d.ts +0 -0
  361. /package/{components → types/components}/forms/switcher/switcher.vue.d.ts +0 -0
  362. /package/{components → types/components}/forms/switcher/types.d.ts +0 -0
  363. /package/{components → types/components}/forms/textarea/textarea.vue.d.ts +0 -0
  364. /package/{components → types/components}/forms/textarea/types.d.ts +0 -0
  365. /package/{components → types/components}/formsExt/checkboxGroup/checkboxGroup.vue.d.ts +0 -0
  366. /package/{components → types/components}/formsExt/checkboxGroup/types.d.ts +0 -0
  367. /package/{components → types/components}/formsExt/editArea/editArea.vue.d.ts +0 -0
  368. /package/{components → types/components}/formsExt/editArea/types.d.ts +0 -0
  369. /package/{components → types/components}/formsExt/editInput/editInput.vue.d.ts +0 -0
  370. /package/{components → types/components}/formsExt/editInput/types.d.ts +0 -0
  371. /package/{components → types/components}/formsExt/formsExt.d.ts +0 -0
  372. /package/{components → types/components}/formsExt/info/info.vue.d.ts +0 -0
  373. /package/{components → types/components}/formsExt/info/types.d.ts +0 -0
  374. /package/{components → types/components}/formsExt/menu/menu.vue.d.ts +0 -0
  375. /package/{components → types/components}/formsExt/menu/types.d.ts +0 -0
  376. /package/{components → types/components}/formsExt/radioGroup/radioGroup.vue.d.ts +0 -0
  377. /package/{components → types/components}/formsExt/radioGroup/types.d.ts +0 -0
  378. /package/{components → types/components}/formsExt/selector2/composables/useAPI.d.ts +0 -0
  379. /package/{components → types/components}/formsExt/selector2/composables/useMenu.d.ts +0 -0
  380. /package/{components → types/components}/formsExt/selector2/itemMulti.vue.d.ts +0 -0
  381. /package/{components → types/components}/formsExt/selector2/selector2.vue.d.ts +0 -0
  382. /package/{components → types/components}/formsExt/selector2/types.d.ts +0 -0
  383. /package/{components → types/components}/formsExt/selector2/utils.d.ts +0 -0
  384. /package/{components → types/components}/layout/islandRows/islandRows.vue.d.ts +0 -0
  385. /package/{components → types/components}/layout/islandRows/islandRowsRow/islandRowsRow.vue.d.ts +0 -0
  386. /package/{components → types/components}/layout/islandRows/islandRowsRow/types.d.ts +0 -0
  387. /package/{components → types/components}/layout/islandRows/islandRowsSubTitle/islandRowsSubTitle.vue.d.ts +0 -0
  388. /package/{components → types/components}/layout/islandRows/types.d.ts +0 -0
  389. /package/{components → types/components}/layout/layout.d.ts +0 -0
  390. /package/{components → types/components}/layout/rows/rows.vue.d.ts +0 -0
  391. /package/{components → types/components}/layout/rows/types.d.ts +0 -0
  392. /package/{components → types/components}/popup/alert/alert.vue.d.ts +0 -0
  393. /package/{components → types/components}/popup/alert/types.d.ts +0 -0
  394. /package/{components → types/components}/popup/confirm/confirm.vue.d.ts +0 -0
  395. /package/{components → types/components}/popup/confirm/types.d.ts +0 -0
  396. /package/{components → types/components}/popup/lib/popup.d.ts +0 -0
  397. /package/{components → types/components}/popup/lib/popup.globalEvents.d.ts +0 -0
  398. /package/{components → types/components}/popup/lib/worker.d.ts +0 -0
  399. /package/{components → types/components}/popup/lib/worker.globalEvents.d.ts +0 -0
  400. /package/{components → types/components}/popup/popup/listItem.vue.d.ts +0 -0
  401. /package/{components → types/components}/popup/popup/opener.vue.d.ts +0 -0
  402. /package/{components → types/components}/popup/popup/popup.vue.d.ts +0 -0
  403. /package/{components → types/components}/popup/popup/types.d.ts +0 -0
  404. /package/{components → types/components}/popup/popup/widgetInput.vue.d.ts +0 -0
  405. /package/{components → types/components}/popup/popup.d.ts +0 -0
  406. /package/{components → types/components}/popup/prompt/prompt.vue.d.ts +0 -0
  407. /package/{components → types/components}/popup/prompt/types.d.ts +0 -0
  408. /package/{components → types/components}/popup/worker.d.ts +0 -0
  409. /package/{components → types/components}/project/project.d.ts +0 -0
  410. /package/{components → types/components}/project/selectorCompetitors/composables.d.ts +0 -0
  411. /package/{components → types/components}/project/selectorCompetitors/selectorCompetitors.vue.d.ts +0 -0
  412. /package/{components → types/components}/project/selectorCompetitors/types.d.ts +0 -0
  413. /package/{components → types/components}/project/selectorRegion/composables/compare.d.ts +0 -0
  414. /package/{components → types/components}/project/selectorRegion/composables/selectRegion.d.ts +0 -0
  415. /package/{components → types/components}/project/selectorRegion/composables/selectSearcher.d.ts +0 -0
  416. /package/{components → types/components}/project/selectorRegion/composables/selectorRegion.d.ts +0 -0
  417. /package/{components → types/components}/project/selectorRegion/dialog_selectorRegions/types.d.ts +0 -0
  418. /package/{components → types/components}/project/selectorRegion/selectorRegion.vue.d.ts +0 -0
  419. /package/{components → types/components}/project/selectorRegion/types.d.ts +0 -0
  420. /package/{components → types/components}/project/selectorRegion/utils/consts.d.ts +0 -0
  421. /package/{components → types/components}/project/tagSelector/popupListItem/tagPopupListItem.vue.d.ts +0 -0
  422. /package/{components → types/components}/project/tagSelector/popupListItem/types.d.ts +0 -0
  423. /package/{components → types/components}/project/tagSelector/popupOpener/popupOpener.vue.d.ts +0 -0
  424. /package/{components → types/components}/project/tagSelector/popupOpener/types.d.ts +0 -0
  425. /package/{components → types/components}/project/tagSelector/tagIcon/tagIcon.vue.d.ts +0 -0
  426. /package/{components → types/components}/project/tagSelector/tagIcon/types.d.ts +0 -0
  427. /package/{components → types/components}/project/tagSelector/tagSelector.vue.d.ts +0 -0
  428. /package/{components → types/components}/project/tagSelector/tagsDefaults.d.ts +0 -0
  429. /package/{components → types/components}/project/tagSelector/types.d.ts +0 -0
  430. /package/{components → types/components}/project/tagSelector/utils/el.d.ts +0 -0
  431. /package/{components → types/components}/project/tagSelector/utils/utils.d.ts +0 -0
  432. /package/{components → types/components}/tabs/tabs/content.vue.d.ts +0 -0
  433. /package/{components → types/components}/tabs/tabs/tab.vue.d.ts +0 -0
  434. /package/{components → types/components}/tabs/tabs/tabs.vue.d.ts +0 -0
  435. /package/{components → types/components}/tabs/tabs/types.d.ts +0 -0
  436. /package/{components → types/components}/tabs/tabs.d.ts +0 -0
  437. /package/{components → types/components}/tabsView/tabsView/menu.vue.d.ts +0 -0
  438. /package/{components → types/components}/tabsView/tabsView/menuDelimeter.vue.d.ts +0 -0
  439. /package/{components → types/components}/tabsView/tabsView/menuItem.vue.d.ts +0 -0
  440. /package/{components → types/components}/tabsView/tabsView/menuTitle.vue.d.ts +0 -0
  441. /package/{components → types/components}/tabsView/tabsView/store.d.ts +0 -0
  442. /package/{components → types/components}/tabsView/tabsView/tabsView.vue.d.ts +0 -0
  443. /package/{components → types/components}/tabsView/tabsView/types.d.ts +0 -0
  444. /package/{components → types/components}/tabsView/tabsView/utils.d.ts +0 -0
  445. /package/{components → types/components}/tabsView/tabsView.d.ts +0 -0
  446. /package/{core → types/core}/app.d.ts +0 -0
  447. /package/{core → types/core}/core/core.d.ts +0 -0
  448. /package/{core → types/core}/core/events/resize.d.ts +0 -0
  449. /package/{core → types/core}/core/events.d.ts +0 -0
  450. /package/{core → types/core}/core/options.d.ts +0 -0
  451. /package/{core → types/core}/core/preloaders.d.ts +0 -0
  452. /package/{core → types/core}/core/state.d.ts +0 -0
  453. /package/{core → types/core}/directives/data.d.ts +0 -0
  454. /package/{core → types/core}/directives/focus.d.ts +0 -0
  455. /package/{core → types/core}/directives/preloader.d.ts +0 -0
  456. /package/{core → types/core}/directives/scrollIntoView.d.ts +0 -0
  457. /package/{core → types/core}/directives/scrollShadow.d.ts +0 -0
  458. /package/{core → types/core}/directives/sticky.d.ts +0 -0
  459. /package/{core → types/core}/directives/swimUp.d.ts +0 -0
  460. /package/{core → types/core}/directives/tooltip.d.ts +0 -0
  461. /package/{core → types/core}/plugins/core.d.ts +0 -0
  462. /package/{core → types/core}/plugins/i18n.d.ts +0 -0
  463. /package/{core → types/core}/plugins/piniaTPA.d.ts +0 -0
  464. /package/{core → types/core}/utils/check.d.ts +0 -0
  465. /package/{core → types/core}/utils/clipboard.d.ts +0 -0
  466. /package/{core → types/core}/utils/date.d.ts +0 -0
  467. /package/{core → types/core}/utils/device.d.ts +0 -0
  468. /package/{core → types/core}/utils/dom.d.ts +0 -0
  469. /package/{core → types/core}/utils/image.d.ts +0 -0
  470. /package/{core → types/core}/utils/keyboard.d.ts +0 -0
  471. /package/{core → types/core}/utils/lodash.d.ts +0 -0
  472. /package/{core → types/core}/utils/number.d.ts +0 -0
  473. /package/{core → types/core}/utils/price.d.ts +0 -0
  474. /package/{core → types/core}/utils/route.d.ts +0 -0
  475. /package/{core → types/core}/utils/scroll.d.ts +0 -0
  476. /package/{core → types/core}/utils/searchers.d.ts +0 -0
  477. /package/{core → types/core}/utils/store/localStorage.d.ts +0 -0
  478. /package/{core → types/core}/utils/store/plugin.d.ts +0 -0
  479. /package/{core → types/core}/utils/store/store.d.ts +0 -0
  480. /package/{core → types/core}/utils/store.d.ts +0 -0
  481. /package/{core → types/core}/utils/string.d.ts +0 -0
  482. /package/{core → types/core}/utils/system.d.ts +0 -0
  483. /package/{core → types/core}/utils/url.d.ts +0 -0
  484. /package/{dialog → types/dialog}/dialog.d.ts +0 -0
  485. /package/{extra → types/extra}/extra.d.ts +0 -0
  486. /package/{forms/helpers.d.ts → types/for-delete/core.d.ts} +0 -0
  487. /package/{forms → types/forms}/forms.d.ts +0 -0
  488. /package/{formsExt → types/formsExt}/formsExt.d.ts +0 -0
  489. /package/{layout → types/layout}/layout.d.ts +0 -0
  490. /package/{popup → types/popup}/popup.d.ts +0 -0
  491. /package/{popup → types/popup}/worker.d.ts +0 -0
  492. /package/{project → types/project}/project.d.ts +0 -0
  493. /package/{tabs → types/tabs}/tabs.d.ts +0 -0
  494. /package/{tabsView → types/tabsView}/tabsView.d.ts +0 -0
  495. /package/{utils → types/utils}/check.d.ts +0 -0
  496. /package/{utils → types/utils}/clipboard.d.ts +0 -0
  497. /package/{utils → types/utils}/date.d.ts +0 -0
  498. /package/{utils → types/utils}/device.d.ts +0 -0
  499. /package/{utils → types/utils}/dom.d.ts +0 -0
  500. /package/{utils → types/utils}/image.d.ts +0 -0
  501. /package/{utils → types/utils}/keyboard.d.ts +0 -0
  502. /package/{utils → types/utils}/lodash.d.ts +0 -0
  503. /package/{utils → types/utils}/number.d.ts +0 -0
  504. /package/{utils → types/utils}/price.d.ts +0 -0
  505. /package/{utils → types/utils}/route.d.ts +0 -0
  506. /package/{utils → types/utils}/scroll.d.ts +0 -0
  507. /package/{utils → types/utils}/searchers.d.ts +0 -0
  508. /package/{utils → types/utils}/store.d.ts +0 -0
  509. /package/{utils → types/utils}/string.d.ts +0 -0
  510. /package/{utils → types/utils}/system.d.ts +0 -0
  511. /package/{utils → types/utils}/url.d.ts +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../src/api/api/client/request-options.ts","../../src/api/api/utils/common.ts","../../src/api/api/client/request.ts","../../src/api/api/client/client.ts","../../src/api/api/index.ts"],"sourcesContent":["export const createRequestOptions = (requestOptions: Partial<Api.ClientRequestOptions> = {}): Api.ClientRequestOptions => {\n\trequestOptions = { ...requestOptions };\n\trequestOptions.loadingEl ??= document.body;\n\trequestOptions.loadingShowSpinner ??= true;\n\trequestOptions.method ??= 'POST';\n\trequestOptions.accept ??= 'application/json';\n\n\treturn requestOptions as Api.ClientRequestOptions;\n};\n","/**\n * Сгенерировать объект ответа в формате расширения OpenAPI\n *\n * @see Api.Ext\n */\nexport const genExtRes = (\n\tresult: any,\n\terrors?: Api.Ext.Schemas['ResponseError']['errors'],\n\tresponse?: Response,\n): Api.Response<any> => {\n\treturn {\n\t\tresult,\n\t\terrors,\n\t\tresponse,\n\t};\n};\n\n/**\n * Это публичное API, к которому открыт доступ по прямой ссылке через GET\n *\n * Используется для кеширования и генерации файлов через API\n */\nexport const isPublicAPI = (path: Api.PathAbstract) => {\n\treturn path.startsWith('/system_2/common/');\n};\n\n/**\n * Сгенерировать baseUrl на основе текущего домена\n */\nexport const getBaseDomainUrl = (useMainDomain = false, input: string = window.location.href) => {\n\tconst { protocol, hostname, port } = new URL(input);\n\n\t/**\n\t * localhost / IP-адреса / одноуровневые домены оставляем как есть\n\t */\n\tconst parts = hostname.split('.');\n\tconst baseHostname = !useMainDomain || parts.length <= 2 || /^[\\d.]+$/.test(hostname) || hostname === 'localhost'\n\t\t? hostname\n\t\t: parts.slice(-2).join('.');\n\n\treturn `${protocol}//${baseHostname}${port ? `:${port}` : ''}`;\n};\n","import type { Client } from './client';\nimport { createRequestOptions } from './request-options';\nimport { genExtRes } from '../utils/common';\n\nexport const createRequest = <\n\tRequestContext extends Api.ClientRequestContext<any, any, any>,\n\tFieldsNarrow extends Api.ParamsFields<RequestContext>,\n>(\n\tclient: Client<RequestContext['Paths'], RequestContext['UseExt']>,\n\tpath: RequestContext['Path'],\n\tfieldsNarrow?: FieldsNarrow,\n): Api.ClientRequest<RequestContext, FieldsNarrow> => {\n\tconst clientRequest = {\n\t\tinLoading: false,\n\t\tpath: path as Api.PathAbstract,\n\t\turl: client.options.baseUrl + path,\n\t\toptions: createRequestOptions(client.options.requestOptions),\n\t\tparams: {} as any, // незаполненное свойство\n\t\tgetInLoading: () => clientRequest.inLoading,\n\n\t\tsetParams: (params) => {\n\t\t\tclientRequest.params = { ...params } as any;\n\n\t\t\treturn clientRequest;\n\t\t},\n\n\t\tchangeParams: (params) => {\n\t\t\tObject.assign(clientRequest.params, params);\n\n\t\t\treturn clientRequest;\n\t\t},\n\n\t\tsetOptions: (options) => {\n\t\t\tObject.assign(clientRequest.options, options);\n\n\t\t\treturn clientRequest;\n\t\t},\n\n\t\tcall: async (fields?) => {\n\t\t\treturn clientRequest.exec(fields);\n\t\t},\n\n\t\tcallFetch: async (fetchStyle, fields?) => {\n\t\t\treturn clientRequest.exec(fields, fetchStyle);\n\t\t},\n\n\t\tcallInNewWindow: async (fields?) => {\n\t\t\tconst data = clientRequest.genData(fields);\n\n\t\t\tconst middlewareCtx = client.genMiddlewareCtx(clientRequest, data);\n\n\t\t\tclient.options.onPrepareData?.(data, middlewareCtx);\n\n\t\t\tconst { postInWindow } = await import('../utils/lazy');\n\t\t\tvoid postInWindow(clientRequest.url, data, '_blank');\n\t\t},\n\n\t\tcallInSelfWindow: async (fields?) => {\n\t\t\tconst data = clientRequest.genData(fields);\n\n\t\t\tconst middlewareCtx = client.genMiddlewareCtx(clientRequest, data);\n\n\t\t\tclient.options.onPrepareData?.(data, middlewareCtx);\n\n\t\t\tconst { postInWindow } = await import('../utils/lazy');\n\t\t\tvoid postInWindow(clientRequest.url, data, '_self');\n\t\t},\n\n\t\tgenData: (fields?, fetchStyle?) => {\n\t\t\tconst post: any = { ...clientRequest.params };\n\n\t\t\t// в старом коде fields вставлялись в params, оставлено для совместимости\n\t\t\t// delete post.fields;\n\t\t\tdelete post.fetch_style;\n\n\t\t\t// поля, указанные при запуске запроса\n\t\t\tif (fields) {\n\t\t\t\tlet fieldsPrepared = [...fields as any[]];\n\n\t\t\t\t// поля, указанные при создании запроса\n\t\t\t\tif (fieldsNarrow) {\n\t\t\t\t\tfieldsPrepared = fieldsPrepared.filter(field => fieldsNarrow.includes(field));\n\t\t\t\t}\n\n\t\t\t\tpost.fields = fieldsPrepared;\n\t\t\t} else {\n\t\t\t\tif (fieldsNarrow) {\n\t\t\t\t\tpost.fields = fieldsNarrow;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (fetchStyle) {\n\t\t\t\tpost.fetch_style = fetchStyle;\n\t\t\t}\n\n\t\t\treturn post;\n\t\t},\n\n\t\t/**\n\t\t * Общая функция выполнения запросов\n\t\t */\n\t\tasync exec(fields?: FieldsNarrow, fetchStyle?: RequestContext['ParamsFetchStyle']): Promise<any> {\n\t\t\tconst Request = client.options.Request;\n\t\t\tconst fetch = client.options.fetch;\n\n\t\t\tconst data = clientRequest.genData(fields, fetchStyle);\n\n\t\t\tconst middlewareCtxWithoutRequest = client.genMiddlewareCtx(clientRequest, data);\n\n\t\t\tclient.options.onPrepareData?.(data, middlewareCtxWithoutRequest);\n\n\t\t\tlet url = clientRequest.url;\n\n\t\t\tlet requestInitBody: string | undefined = undefined;\n\t\t\tif (clientRequest.options.method !== 'POST') {\n\t\t\t\turl += '?' + new URLSearchParams(data).toString();\n\t\t\t} else {\n\t\t\t\trequestInitBody = client.options.bodySerializer(data);\n\t\t\t}\n\n\t\t\t// checkFingerprint\n\t\t\tlet requestInitSignal: AbortController['signal'] | undefined;\n\n\t\t\tif (this.options.checkFingerprint) {\n\t\t\t\tconst fingerprint = this.path + this.options.checkFingerprint;\n\n\t\t\t\tconst controller = new AbortController();\n\t\t\t\tclient.abortControllers[fingerprint] = controller;\n\n\t\t\t}\n\n\t\t\tconst requestInit = {\n\t\t\t\t...client.options,\n\t\t\t\tmethod: clientRequest.options.method,\n\t\t\t\tbody: requestInitBody,\n\t\t\t\tsignal: requestInitSignal,\n\t\t\t};\n\n\t\t\tlet request = new Request(url, requestInit);\n\n\t\t\trequest.headers.set('x-request-id', middlewareCtxWithoutRequest.id);\n\t\t\trequest.headers.set('content-type', 'application/json');\n\t\t\trequest.headers.set('accept', clientRequest.options.accept);\n\n\t\t\tconst middlewareCtx: Api.MiddlewareCallbackParams = {\n\t\t\t\t...middlewareCtxWithoutRequest,\n\t\t\t\trequest,\n\t\t\t};\n\n\t\t\tclientRequest.inLoading = true;\n\t\t\tclientRequest.options.onLoading?.(clientRequest.inLoading, middlewareCtx);\n\n\t\t\tlet response: Response | undefined = undefined;\n\n\t\t\tconst requestOrResponse = await client.middlewareOnRequest(request, middlewareCtx);\n\n\t\t\tif (requestOrResponse instanceof Response) {\n\t\t\t\tresponse = requestOrResponse;\n\t\t\t} else if (requestOrResponse instanceof Request) {\n\t\t\t\trequest = requestOrResponse;\n\t\t\t}\n\n\t\t\tif (!response) {\n\t\t\t\ttry {\n\t\t\t\t\tresponse = await fetch(request);\n\t\t\t\t} catch (e) {\n\t\t\t\t\tresponse = await client.middlewareOnError(e, middlewareCtx);\n\t\t\t\t} finally {\n\t\t\t\t\tclientRequest.inLoading = false;\n\t\t\t\t\tclientRequest.options.onLoading?.(clientRequest.inLoading, middlewareCtx);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tresponse = await client.middlewareOnResponse(response, middlewareCtx);\n\n\t\t\tlet res: any;\n\t\t\tlet responseText: string | undefined;\n\t\t\tlet formatError: undefined | Api.FormatError = undefined;\n\n\t\t\ttry {\n\t\t\t\t// json - стандартные формат, он может быть возвращен в запросах с другим responseType, если в них произошла ошибка\n\t\t\t\tconst isJSON = response.headers.get('content-type')?.includes('application/json');\n\n\t\t\t\tresponseText = await response.text();\n\n\t\t\t\tif (request.headers.get('Content-Type')?.includes('application/json') || isJSON) {\n\t\t\t\t\tres = JSON.parse(responseText);\n\t\t\t\t} else {\n\t\t\t\t\tif (client.useExt) {\n\t\t\t\t\t\tres = genExtRes(responseText, undefined, response);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tres = responseText;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\tif (e instanceof SyntaxError || e instanceof TypeError) {\n\t\t\t\t\tformatError = e;\n\t\t\t\t\tformatError.responseText = responseText;\n\t\t\t\t}\n\n\t\t\t\t// если в результате не пришел json, сгенерировать объект результата и добавить информацию об ответе API\n\t\t\t\tif (client.useExt && formatError) {\n\t\t\t\t\tlet errorCode = response.status;\n\t\t\t\t\tlet errorMessage = response.statusText;\n\n\t\t\t\t\tif (errorCode === 200) {\n\t\t\t\t\t\terrorCode = 10000;\n\t\t\t\t\t\terrorMessage = 'Error API response';\n\t\t\t\t\t}\n\n\t\t\t\t\tres = genExtRes(null, [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tcode: errorCode,\n\t\t\t\t\t\t\tstring: errorMessage,\n\t\t\t\t\t\t},\n\t\t\t\t\t], response);\n\n\t\t\t\t\tif (client.options.useApiConsole) console.error(e);\n\t\t\t\t} else {\n\t\t\t\t\tthrow e;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (client.useExt) {\n\t\t\t\tres.response = response;\n\n\t\t\t\tif (res) {\n\t\t\t\t\tclientRequest.options.onApiLoaded?.(res, middlewareCtx);\n\t\t\t\t}\n\n\t\t\t\tif (res?.errors) {\n\t\t\t\t\tif (client.options.useApiConsole) console.warn(new Error('API error'), { res });\n\n\t\t\t\t\tclientRequest.options.onApiError?.(res, { ...middlewareCtx, formatError }, client.options.requestOptions?.onApiError);\n\t\t\t\t}\n\n\t\t\t\tif (res?.messages) {\n\t\t\t\t\tclientRequest.options.onApiMessage?.(res, middlewareCtx);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn res;\n\t\t},\n\t};\n\n\treturn clientRequest;\n};\n","import { createRequestOptions } from './request-options';\nimport { createRequest } from './request';\n\nexport class Client<paths extends Api.PathsAbstract, UseExt extends Api.Ext.UseExt> {\n\n\treadonly options: Readonly<Api.ClientOptions>;\n\treadonly useExt: UseExt;\n\treadonly middlewares: Api.Middleware[] = [];\n\tabortControllers: Record<string, AbortController> = {};\n\n\tconstructor(clientOptions: Partial<Api.ClientOptions> = {}, useExt: UseExt) {\n\t\tclientOptions.requestOptions = createRequestOptions(clientOptions.requestOptions);\n\t\tclientOptions.useApiConsole ??= true;\n\n\t\tclientOptions.fetch ??= globalThis.fetch;\n\t\tclientOptions.Request ??= globalThis.Request;\n\t\tclientOptions.querySerializer ??= (params) => new URLSearchParams(params as any).toString();\n\t\tclientOptions.bodySerializer ??= (body) => typeof body === 'string' ? body : JSON.stringify(body);\n\n\t\tthis.options = clientOptions as Api.ClientOptions;\n\n\t\tthis.useExt = useExt;\n\t}\n\n\tprivate generateUUID() {\n\t\tif (crypto?.randomUUID) {\n\t\t\treturn crypto.randomUUID();\n\t\t}\n\n\t\treturn 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, c => {\n\t\t\tconst r = Math.random() * 16 | 0;\n\t\t\tconst v = c === 'x' ? r : (r & 0x3 | 0x8);\n\t\t\treturn v.toString(16);\n\t\t});\n\t}\n\n\t/**\n\t * Зарегистрировать middleware\n\t */\n\tuse(middleware: Api.Middleware) {\n\t\tthis.middlewares.push(middleware);\n\t}\n\n\t/**\n\t * Создать объект запроса\n\t *\n\t * После создания объекта он заполняется необходимыми данными и выполняет запросы к API с помощью APIRequest2.call();\n\t *\n\t * Опционально generic указывать нельзя, поэтому необходимо дублировать определение fetchStyle, [см.](https://github.com/Microsoft/TypeScript/issues/26242)\n\t *\n\t * @param path Путь метода API\n\t * @param fieldsNarrow Список получаемых полей, для методов API с моделью. Если объект запроса переиспользуется, и список полей меняется, указывайте его непосредственно при вызове `api.call()`\n\t */\n\tgen<\n\t\tPath extends Api.Path<paths>,\n\t\tFieldsNarrow extends Api.ParamsFields<Api.ClientRequestContext<paths, Path, UseExt>>\n\t>(\n\t\tpath: Path,\n\t\tfieldsNarrow?: FieldsNarrow,\n\t): Api.ClientRequest<Api.ClientRequestContext<paths, Path, UseExt>, FieldsNarrow> {\n\t\ttype RequestContext = Api.ClientRequestContext<paths, Path, UseExt>;\n\n\t\treturn createRequest<RequestContext, FieldsNarrow>(this, path, fieldsNarrow);\n\t}\n\n\t/**\n\t * Создать объект запроса, не описанного в OpenAPI\n\t */\n\tgenAny<\n\t\tParams extends {},\n\t\tResult = {},\n\t\tFieldsNarrow extends Api.Ext.Schemas['Fields'] | undefined = undefined\n\t>(path: Api.PathAbstract, fieldsNarrow?: FieldsNarrow): Api.ClientRequestCustom<UseExt, Params, Result> {\n\t\treturn this.gen(path as any, fieldsNarrow as any) as unknown as Api.ClientRequestCustom<UseExt, Params, Result>;\n\t}\n\n\t/**\n\t * Создать контекст выполнения запроса\n\t */\n\tgenMiddlewareCtx(\n\t\tclientRequest: Api.ClientRequest<any, any, any>,\n\t\tdata: Record<string, any>,\n\t): Omit<Api.MiddlewareCallbackParams, 'request'> {\n\t\tconst id = this.generateUUID();\n\n\t\tconst options: Api.BaseOptions = Object.freeze({\n\t\t\tbaseUrl: this.options.baseUrl,\n\t\t\tquerySerializer: this.options.querySerializer,\n\t\t\tbodySerializer: this.options.bodySerializer,\n\t\t\tRequest: this.options.Request,\n\t\t\tfetch: this.options.fetch,\n\t\t});\n\n\t\treturn {\n\t\t\tuseExt: this.useExt,\n\t\t\trequestOptions: clientRequest.options,\n\t\t\tdata,\n\t\t\tmiddlewareData: {},\n\t\t\toptions,\n\t\t\tschemaPath: clientRequest.path,\n\t\t\tid,\n\t\t};\n\t};\n\n\t/**\n\t * Обработчик middleware.onRequest\n\t *\n\t * @param request Запрос для обработки\n\t * @param middlewareCtx Контекст выполнения запроса\n\t * @return Новый экземпляр `Request` или `Response` при модификации запроса, или undefined\n\t */\n\tasync middlewareOnRequest(\n\t\trequest: Request,\n\t\tmiddlewareCtx: Api.MiddlewareCallbackParams,\n\t): Promise<Request | Response | undefined> {\n\t\tfor (const middleware of this.middlewares) {\n\t\t\tconst result = await middleware.onRequest?.({\n\t\t\t\t...middlewareCtx,\n\t\t\t\trequest,\n\t\t\t});\n\n\t\t\tif (result) {\n\t\t\t\tif (result instanceof Request) {\n\t\t\t\t\trequest = result;\n\t\t\t\t} else if (result instanceof Response) {\n\t\t\t\t\treturn result;\n\t\t\t\t} else {\n\t\t\t\t\tthrow new Error('onRequest: must return new Request() or Response() when modifying the request');\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn request;\n\t}\n\n\t/**\n\t * Обработчик middleware.onResponse\n\t *\n\t * @param `error` Ошибка, переданная для обработки\n\t * @param middlewareCtx\n\t * @return Новый экземпляр `Response` при успешной обработке или выбрасывает ошибку\n\t */\n\tasync middlewareOnError(\n\t\terror: Error | unknown,\n\t\tmiddlewareCtx: Api.MiddlewareCallbackParams,\n\t): Promise<Response | never> {\n\t\tlet errorAfterMiddleware = error;\n\n\t\tfor (const middleware of this.middlewares) {\n\t\t\tconst result = await middleware.onError?.({\n\t\t\t\t...middlewareCtx,\n\t\t\t\terror: errorAfterMiddleware,\n\t\t\t});\n\n\t\t\tif (result) {\n\t\t\t\tif (result instanceof Response) {\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\n\t\t\t\tif (result instanceof Error) {\n\t\t\t\t\terrorAfterMiddleware = result;\n\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tthrow new Error('onError: must return new Response() or instance of Error');\n\t\t\t}\n\t\t}\n\n\t\tthrow errorAfterMiddleware;\n\t}\n\n\t/**\n\t * Обработчик middleware.onResponse\n\t *\n\t * @param response Ответ для обработки\n\t * @param middlewareCtx Контекст выполнения запроса\n\t * @return Новый экземпляр `Response` при модификации ответа, или undefined\n\t */\n\tasync middlewareOnResponse(\n\t\tresponse: Response,\n\t\tmiddlewareCtx: Api.MiddlewareCallbackParams,\n\t): Promise<Response> {\n\t\tfor (const middleware of this.middlewares) {\n\t\t\tconst result = await middleware.onResponse?.({\n\t\t\t\t...middlewareCtx,\n\t\t\t\tresponse,\n\t\t\t});\n\n\t\t\tif (result) {\n\t\t\t\tif (!(result instanceof Response)) {\n\t\t\t\t\tthrow new Error('onResponse: must return new Response() when modifying the response');\n\t\t\t\t}\n\n\t\t\t\tresponse = result;\n\t\t\t}\n\t\t}\n\n\t\treturn response;\n\t}\n\n}\n","import { Client } from './client/client';\n\nexport * from './utils/field';\nexport * from './utils/common';\n\nexport const postInWindow: typeof import('./utils/lazy').postInWindow = async (...args) => {\n\tconst { postInWindow } = await import('./utils/lazy');\n\n\treturn postInWindow(...args);\n};\n\nexport const dataToForm: typeof import('./utils/lazy').dataToForm = async (...args) => {\n\tconst { dataToForm } = await import('./utils/lazy');\n\n\treturn dataToForm(...args);\n};\n\n/**\n * Создать API клиент\n *\n * @see Api.Ext.UseExt\n */\nexport const createClient = <\n\tpaths extends Api.PathsAbstract,\n\tUseExt extends Api.Ext.UseExt\n>(\n\tclientOptions: Partial<Api.ClientOptions> = {},\n\tuseExt: UseExt,\n) => {\n\treturn new Client<paths, UseExt>(clientOptions, useExt);\n};\n"],"names":["createRequestOptions","requestOptions","genExtRes","result","errors","response","isPublicAPI","path","getBaseDomainUrl","useMainDomain","input","protocol","hostname","port","parts","baseHostname","createRequest","client","fieldsNarrow","clientRequest","params","options","fields","fetchStyle","data","middlewareCtx","_b","_a","postInWindow","post","fieldsPrepared","field","Request","fetch","middlewareCtxWithoutRequest","url","requestInitBody","requestInitSignal","fingerprint","controller","requestInit","request","_d","_c","requestOrResponse","e","_f","_e","res","responseText","formatError","isJSON","_g","_h","errorCode","errorMessage","_j","_i","_m","_l","_k","_o","_n","Client","clientOptions","useExt","body","c","r","middleware","id","error","errorAfterMiddleware","args","dataToForm","createClient"],"mappings":"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"}
@@ -1 +1 @@
1
- :root{color-scheme:dark;--color-theme-0: #000000;--color-theme-50: #0E0E11;--color-theme-75: #101013;--color-theme-100: #131316;--color-theme-125: #17171C;--color-theme-150: #1C1C21;--color-theme-175: #212126;--color-theme-200: #26262C;--color-theme-225: #2A2A32;--color-theme-250: #2F2F37;--color-theme-260: #34343D;--color-theme-275: #393942;--color-theme-300: #3D3D47;--color-theme-325: #42424D;--color-theme-350: #464653;--color-theme-360: #4B4B58;--color-theme-375: #50505E;--color-theme-400: #555563;--color-theme-410: #595969;--color-theme-420: #5E5E6E;--color-theme-430: #626274;--color-theme-440: #676779;--color-theme-450: #6C6C7E;--color-theme-460: #717184;--color-theme-465: #75758A;--color-theme-470: #7B7B8E;--color-theme-475: #818193;--color-theme-480: #868698;--color-theme-485: #8B8B9D;--color-theme-500: #9191A1;--color-theme-550: #9696A6;--color-theme-575: #9C9CAA;--color-theme-600: #A1A1AF;--color-theme-625: #A7A7B4;--color-theme-650: #ACACB9;--color-theme-675: #B2B2BD;--color-theme-700: #B8B8C2;--color-theme-710: #BDBDC6;--color-theme-725: #C2C2CB;--color-theme-750: #C8C8D0;--color-theme-800: #CDCDD5;--color-theme-850: #D3D3D9;--color-theme-900: #D9D9DE;--color-theme-925: #DEDEE3;--color-theme-950: #E3E3E8;--color-theme-955: #E9E9EC;--color-theme-960: #EEEEF1;--color-theme-965: #F4F4F5;--color-theme-970: #FAFAFA;--color-theme-1000: #FFFFFF;--color-white: rgba(255, 255, 255, 1);--color-black: rgba(0, 0, 0, 1);--color-primary-25: #1F232E;--color-primary-50: #1C2736;--color-primary-100: #18293E;--color-primary-125: #142B48;--color-primary-150: #16355A;--color-primary-200: #183E6D;--color-primary-225: #184781;--color-primary-250: #185095;--color-primary-275: #175AAB;--color-primary-300: #1563C1;--color-primary-350: #136BD8;--color-primary-400: #0F74F0;--color-primary-450: #1E7FF6;--color-primary-500: #2D8AFB;--color-primary-550: #3D94FF;--color-primary-600: #52A0FF;--color-primary-650: #66ABFF;--color-primary-700: #7AB6FF;--color-primary-720: #8FC1FF;--color-primary-740: #A3CDFF;--color-primary-760: #B8D8FF;--color-primary-780: #C2DDFF;--color-primary-800: #CCE3FF;--color-primary-825: #D6E9FF;--color-primary-850: #E0EEFF;--color-primary-900: #EBF4FF;--color-primary-950: #F5F9FF;--color-positive-25: #232424;--color-positive-50: #282A29;--color-positive-100: #25312C;--color-positive-125: #223A30;--color-positive-150: #274939;--color-positive-200: #2C5940;--color-positive-225: #2F6A46;--color-positive-250: #327B49;--color-positive-275: #348D4A;--color-positive-300: #36A150;--color-positive-350: #36B556;--color-positive-400: #36C95B;--color-positive-450: #41D265;--color-positive-500: #4DDB71;--color-positive-550: #5AE27C;--color-positive-600: #6CE58A;--color-positive-650: #87E89F;--color-positive-700: #8EEBA5;--color-positive-720: #A0EEB3;--color-positive-740: #B1F1C1;--color-positive-760: #BAF3C8;--color-positive-780: #C2F4CF;--color-positive-800: #CBF6D6;--color-positive-825: #D4F7DD;--color-positive-850: #DCF9E3;--color-positive-900: #E5FAEA;--color-positive-950: #EEFCF1;--color-warning-25: #322020;--color-warning-50: #39221D;--color-warning-100: #42211A;--color-warning-125: #4C1E15;--color-warning-150: #5E2817;--color-warning-200: #713319;--color-warning-225: #854119;--color-warning-250: #9A5119;--color-warning-275: #AF6418;--color-warning-300: #C56E16;--color-warning-350: #DD7813;--color-warning-400: #F08214;--color-warning-450: #F68C23;--color-warning-500: #FB9632;--color-warning-550: #FFA042;--color-warning-600: #FFAB57;--color-warning-650: #FFB56B;--color-warning-700: #FFBF80;--color-warning-720: #FFC994;--color-warning-740: #FFD3A8;--color-warning-760: #FFDEBD;--color-warning-780: #FFE3C7;--color-warning-800: #FFE8D1;--color-warning-825: #FFEDDB;--color-warning-850: #FFF3E6;--color-warning-900: #FFF7F0;--color-warning-950: #FFFDFA;--color-negative-25: #2F2229;--color-negative-50: #371F2D;--color-negative-100: #401C30;--color-negative-125: #4A1733;--color-negative-150: #5B1A3A;--color-negative-200: #6E1C3E;--color-negative-225: #821C40;--color-negative-250: #961D3F;--color-negative-275: #AB1C31;--color-negative-300: #C11A33;--color-negative-350: #D81834;--color-negative-400: #EB1938;--color-negative-450: #F12745;--color-negative-500: #F73652;--color-negative-550: #FF425E;--color-negative-600: #FF576F;--color-negative-650: #FF6B81;--color-negative-700: #FF8092;--color-negative-720: #FF94A4;--color-negative-740: #FFA8B5;--color-negative-760: #FFBDC6;--color-negative-780: #FFC7CF;--color-negative-800: #FFD1D8;--color-negative-825: #FFDBE1;--color-negative-850: #FFE5E9;--color-negative-900: #FFF0F2;--color-negative-950: #FFFAFA;--color-info-25: #1E1D2B;--color-info-50: #1C1A32;--color-info-100: #1A173B;--color-info-125: #181344;--color-info-150: #201556;--color-info-200: #2A1769;--color-info-225: #36187C;--color-info-250: #441891;--color-info-275: #5517A6;--color-info-300: #5E15BC;--color-info-350: #6612D3;--color-info-400: #6F0FEB;--color-info-450: #7919F5;--color-info-500: #8428FB;--color-info-550: #8F38FF;--color-info-600: #9A4DFF;--color-info-650: #A561FF;--color-info-700: #B175FF;--color-info-720: #BC8AFF;--color-info-740: #C89EFF;--color-info-760: #D4B2FF;--color-info-780: #D9BDFF;--color-info-800: #DFC7FF;--color-info-825: #E5D1FF;--color-info-850: #EBDBFF;--color-info-900: #F1E5FF;--color-info-950: #F6F0FF;--color-layer-1: rgba(140, 140, 166, .08);--color-layer-2: rgba(140, 140, 166, .14);--color-layer-3: rgba(140, 140, 166, .18);--color-layer-4: rgba(140, 140, 166, .24);--color-layer-primary-1: rgba(45, 110, 251, .14);--color-layer-primary-2: rgba(45, 110, 251, .2);--color-layer-primary-3: rgba(45, 110, 251, .3);--color-layer-primary-4: rgba(45, 110, 251, .4);--color-layer-positive-1: rgba(54, 181, 86, .14);--color-layer-positive-2: rgba(54, 181, 86, .2);--color-layer-positive-3: rgba(54, 181, 86, .3);--color-layer-positive-4: rgba(54, 181, 86, .4);--color-layer-warning-1: rgba(255, 160, 66, .14);--color-layer-warning-2: rgba(255, 160, 66, .2);--color-layer-warning-3: rgba(255, 160, 66, .3);--color-layer-warning-4: rgba(255, 160, 66, .4);--color-layer-negative-1: rgba(247, 54, 82, .14);--color-layer-negative-2: rgba(247, 54, 82, .2);--color-layer-negative-3: rgba(247, 54, 82, .3);--color-layer-negative-4: rgba(247, 54, 82, .4);--color-layer-info-1: rgba(165, 97, 255, .14);--color-layer-info-2: rgba(165, 97, 255, .2);--color-layer-info-3: rgba(165, 97, 255, .3);--color-layer-info-4: rgba(165, 97, 255, .4);--top-shadow-xs: 0px 0px 3px rgba(0, 0, 0, .11), 0px 5px 25px rgba(0, 0, 0, .08);--top-shadow-s: 0px 0px 3px rgba(0, 0, 0, .11), 0px 5px 25px rgba(0, 0, 0, .17);--top-shadow: 0px 0px 4px rgba(0, 0, 0, .14), 0px 4px 32px rgba(0, 0, 0, .2);--top-shadow-m: 0px 0px 4px 0px rgba(0, 0, 0, .14), 0px 4px 32px 0px rgba(0, 0, 0, .2);--top-shadow-b: 0px 0px 4px rgba(0, 0, 0, .15), 0px 18px 32px rgba(0, 0, 0, .34);--top-shadow-darken: inset 1000px 1000px 1000px 1000px rgba(0, 0, 0, .03);--top-shadow-darken-2: inset 1000px 1000px 1000px 1000px rgba(0, 0, 0, .12);--top-shadow-darken-3: inset 1000px 1000px 1000px 1000px rgba(0, 0, 0, .1);--color-bg-preloader: rgba(255, 255, 255, .01)}:root{--color-brand-1: #FFE500;--color-brand-2: #FFD400;--color-brand-3: #F5BC00;--color-bg-shading-1: var(--color-theme-150);--color-bg-shading-2: var(--color-theme-125);--color-bg-shading-3: var(--color-theme-100);--color-bg-shading-4: var(--color-theme-75);--color-bg-shading-5: var(--color-theme-50);--color-bg-shading-6: var(--color-theme-0);--color-bg-lightning-1: var(--color-theme-260);--color-bg-inverted-1: var(--color-theme-970);--color-bg-inverted-2: var(--color-theme-955);--color-bg-inverted-3: var(--color-theme-900);--color-bg-inverted-4: var(--color-theme-850);--color-bg-inverted-5: var(--color-theme-800);--color-bg-inverted-6: var(--color-theme-750);--color-bg-inverted-7: var(--color-theme-725);--color-bg-inverted-8: var(--color-theme-710);--color-bg-inverted-9: var(--color-theme-700);--color-bg-inverted-10: var(--color-theme-675);--color-bg-primary-1: var(--color-primary-550);--color-bg-primary-2: var(--color-primary-650);--color-bg-primary-3: var(--color-primary-720);--color-bg-positive-1: var(--color-positive-400);--color-bg-positive-2: var(--color-positive-600);--color-bg-positive-3: var(--color-positive-740);--color-bg-warning-1: var(--color-warning-450);--color-bg-warning-2: var(--color-warning-600);--color-bg-warning-3: var(--color-warning-700);--color-bg-negative-1: var(--color-negative-550);--color-bg-negative-2: var(--color-negative-650);--color-bg-negative-3: var(--color-negative-720);--color-bg-info-1: var(--color-info-650);--color-bg-info-2: var(--color-info-720);--color-bg-info-3: var(--color-info-780);--top-panel-background-color: rgba(24, 24, 27, .8);--color-text-1: var(--color-theme-970);--color-text-2: var(--color-theme-750);--color-text-3: var(--color-theme-500);--color-text-4: var(--color-theme-450);--color-text-1-inverse: var(--color-theme-100);--color-text-white: var(--color-white);--color-text-primary: var(--color-primary-550);--color-text-primary-alt: var(--color-primary-650);--color-text-positive: var(--color-positive-450);--color-text-positive-alt: var(--color-positive-700);--color-text-warning: var(--color-warning-450);--color-text-warning-alt: var(--color-warning-650);--color-text-negative: var(--color-negative-600);--color-text-negative-alt: var(--color-negative-720);--color-text-info: var(--color-info-650);--color-text-info-alt: var(--color-info-740);--color-line-1: var(--color-theme-350);--color-line-2: var(--color-theme-400);--color-line-3: var(--color-theme-485);--color-line-4: var(--color-theme-650);--color-line-1-opacity: rgba(193, 203, 215, .1);--color-line-2-opacity: rgba(193, 203, 215, .15);--color-line-3-opacity: rgba(193, 203, 215, .27);--color-line-primary-1: var(--color-primary-700);--color-line-primary-2: var(--color-primary-760);--color-line-primary-3: var(--color-primary-850);--color-line-primary-1-opacity: rgba(122, 164, 255, .14);--color-line-primary-2-opacity: rgba(122, 164, 255, .28);--color-line-primary-3-opacity: rgba(122, 164, 255, .38);--color-line-positive-1: var(--color-positive-450);--color-line-positive-2: var(--color-positive-600);--color-line-positive-3: var(--color-positive-740);--color-line-positive-1-opacity: rgba(164, 233, 171, .14);--color-line-positive-2-opacity: rgba(164, 233, 171, .28);--color-line-positive-3-opacity: rgba(164, 233, 171, .38);--color-line-warning-1: var(--color-warning-500);--color-line-warning-2: var(--color-warning-650);--color-line-warning-3: var(--color-warning-740);--color-line-warning-1-opacity: rgba(255, 191, 128, .14);--color-line-warning-2-opacity: rgba(255, 191, 128, .28);--color-line-warning-3-opacity: rgba(255, 191, 128, .38);--color-line-negative-1: var(--color-negative-600);--color-line-negative-2: var(--color-negative-650);--color-line-negative-3: var(--color-negative-740);--color-line-negative-1-opacity: rgba(239, 135, 148, .14);--color-line-negative-2-opacity: rgba(239, 135, 148, .28);--color-line-negative-3-opacity: rgba(239, 135, 148, .38);--color-line-info-1: var(--color-info-650);--color-line-info-2: var(--color-info-720);--color-line-info-3: var(--color-info-780);--color-line-info-1-opacity: rgba(168, 120, 247, .14);--color-line-info-2-opacity: rgba(168, 120, 247, .28);--color-line-info-3-opacity: rgba(168, 120, 247, .38);--scroll-track-color: var(--color-theme-225);--scroll-thumb-color: var(--color-theme-250);--scroll-thumb-color-hover: var(--color-theme-300);--scroll-thumb-color-active: var(--color-theme-400);--body-background-color: var(--color-layout-front-1);--content-background-color: var(--color-layout-front-1);--top-forms-option-color: var(--color-primary-500);--top-forms-option-color-hover: var(--color-primary-600)}:root{--color-layout-back: var(--color-theme-50);--color-layout-header: var(--color-theme-175);--color-layout-middle: var(--color-theme-125);--color-layout-front-1: var(--color-theme-175);--color-layout-front-2: var(--color-theme-200);--color-layout-front-3: var(--color-theme-225);--color-layout-front-4: var(--color-theme-250);--color-layout-front-5: var(--color-theme-260);--color-layout-front-6: var(--color-theme-275);--color-layout-front-primary-1: #232F41;--color-layout-front-primary-2: #232F41;--color-layout-front-primary-3: #243149;--color-layout-front-primary-4: #243450;--color-layout-front-primary-5: #253758;--color-layout-front-primary-6: #253960;--color-layout-front-positive-1: #25333B;--color-layout-front-positive-2: #25333B;--color-layout-front-positive-3: #263A3D;--color-layout-front-positive-4: #284140;--color-layout-front-positive-5: #2A4842;--color-layout-front-positive-6: #2B4F44;--color-layout-front-warning-1: #2B3038;--color-layout-front-warning-2: #2B3038;--color-layout-front-warning-3: #343437;--color-layout-front-warning-4: #3C3836;--color-layout-front-warning-5: #453B35;--color-layout-front-warning-6: #4D3F35;--color-layout-front-negative-1: #2B2C3A;--color-layout-front-negative-2: #2B2C3A;--color-layout-front-negative-3: #342D3B;--color-layout-front-negative-4: #3C2D3C;--color-layout-front-negative-5: #452E3D;--color-layout-front-negative-6: #4D2E3E;--color-layout-front-info-1: #272C41;--color-layout-front-info-2: #272C41;--color-layout-front-info-3: #2B2C49;--color-layout-front-info-4: #2F2C50;--color-layout-front-info-5: #332B58;--color-layout-front-info-6: #362B60}:root{--color-summary-top-3: #5BA8DC;--color-summary-top-10: #1AAD7B;--color-summary-top-30: #4BD2B8;--color-summary-top-50: #68CA63;--color-summary-top-100: #9DAAAA;--color-summary-top-10000: #CAA549;--color-table-top-1: #425C8F;--color-table-top-2: #384E7A;--color-table-top-3: #394660;--color-table-top-4: #357550;--color-table-top-5: #336F4E;--color-table-top-6: #326B4D;--color-table-top-7: #31684C;--color-table-top-8: #30624A;--color-table-top-9: #2F5D48;--color-table-top-10: #2D5747;--color-table-move-up-10: #0E6A44;--color-table-move-up-9: #116542;--color-table-move-up-8: #145F40;--color-table-move-up-7: #165A3E;--color-table-move-up-6: #19543C;--color-table-move-up-5: #1B4F3A;--color-table-move-up-4: #1E4938;--color-table-move-up-3: #204335;--color-table-move-up-2: #233E33;--color-table-move-up-1: #263832;--color-table-move-0: #313135;--color-table-move-down-1: #46303F;--color-table-move-down-2: #4F3040;--color-table-move-down-3: #583142;--color-table-move-down-4: #633244;--color-table-move-down-5: #6C3345;--color-table-move-down-6: #723446;--color-table-move-down-7: #793547;--color-table-move-down-8: #823649;--color-table-move-down-9: #8A364A;--color-table-move-down-10: #93374C;--color-table-down: #46303F;--color-table-down-10: #4F3040;--color-table-up: #365344;--color-table-up-10: #2C5145;--color-table-base: var(--color-layout-front-1);--color-table-featured-snippet: #878742;--color-table-empty: var(--color-layout-front-3);--color-table-not_found: #FFF6C6;--color-snapshot-panel-gradient-1: rgba(35, 44, 77, .5);--color-snapshot-panel-gradient-2: rgba(35, 44, 77, .8);--color-snippet-title: #A2C2FA;--color-snippet-title-visited: #BC8CF2;--color-snippet-url: #007700}
1
+ :root{color-scheme:dark;--color-theme-0: #000000;--color-theme-50: #0E0E11;--color-theme-75: #101013;--color-theme-100: #131316;--color-theme-125: #17171C;--color-theme-150: #1C1C21;--color-theme-175: #212126;--color-theme-200: #26262C;--color-theme-225: #2A2A32;--color-theme-250: #2F2F37;--color-theme-260: #34343D;--color-theme-275: #393942;--color-theme-300: #3D3D47;--color-theme-325: #42424D;--color-theme-350: #464653;--color-theme-360: #4B4B58;--color-theme-375: #50505E;--color-theme-400: #555563;--color-theme-410: #595969;--color-theme-420: #5E5E6E;--color-theme-430: #626274;--color-theme-440: #676779;--color-theme-450: #6C6C7E;--color-theme-460: #717184;--color-theme-465: #75758A;--color-theme-470: #7B7B8E;--color-theme-475: #818193;--color-theme-480: #868698;--color-theme-485: #8B8B9D;--color-theme-500: #9191A1;--color-theme-550: #9696A6;--color-theme-575: #9C9CAA;--color-theme-600: #A1A1AF;--color-theme-625: #A7A7B4;--color-theme-650: #ACACB9;--color-theme-675: #B2B2BD;--color-theme-700: #B8B8C2;--color-theme-710: #BDBDC6;--color-theme-725: #C2C2CB;--color-theme-750: #C8C8D0;--color-theme-800: #CDCDD5;--color-theme-850: #D3D3D9;--color-theme-900: #D9D9DE;--color-theme-925: #DEDEE3;--color-theme-950: #E3E3E8;--color-theme-955: #E9E9EC;--color-theme-960: #EEEEF1;--color-theme-965: #F4F4F5;--color-theme-970: #FAFAFA;--color-theme-1000: #FFFFFF;--color-white: rgba(255, 255, 255, 1);--color-black: rgba(0, 0, 0, 1);--color-primary-25: #1F232E;--color-primary-50: #1C2736;--color-primary-100: #18293E;--color-primary-125: #142B48;--color-primary-150: #16355A;--color-primary-200: #183E6D;--color-primary-225: #184781;--color-primary-250: #185095;--color-primary-275: #175AAB;--color-primary-300: #1563C1;--color-primary-350: #136BD8;--color-primary-400: #0F74F0;--color-primary-450: #1E7FF6;--color-primary-500: #2D8AFB;--color-primary-550: #3D94FF;--color-primary-600: #52A0FF;--color-primary-650: #66ABFF;--color-primary-700: #7AB6FF;--color-primary-720: #8FC1FF;--color-primary-740: #A3CDFF;--color-primary-760: #B8D8FF;--color-primary-780: #C2DDFF;--color-primary-800: #CCE3FF;--color-primary-825: #D6E9FF;--color-primary-850: #E0EEFF;--color-primary-900: #EBF4FF;--color-primary-950: #F5F9FF;--color-positive-25: #232424;--color-positive-50: #282A29;--color-positive-100: #25312C;--color-positive-125: #223A30;--color-positive-150: #274939;--color-positive-200: #2C5940;--color-positive-225: #2F6A46;--color-positive-250: #327B49;--color-positive-275: #348D4A;--color-positive-300: #36A150;--color-positive-350: #36B556;--color-positive-400: #36C95B;--color-positive-450: #41D265;--color-positive-500: #4DDB71;--color-positive-550: #5AE27C;--color-positive-600: #6CE58A;--color-positive-650: #87E89F;--color-positive-700: #8EEBA5;--color-positive-720: #A0EEB3;--color-positive-740: #B1F1C1;--color-positive-760: #BAF3C8;--color-positive-780: #C2F4CF;--color-positive-800: #CBF6D6;--color-positive-825: #D4F7DD;--color-positive-850: #DCF9E3;--color-positive-900: #E5FAEA;--color-positive-950: #EEFCF1;--color-warning-25: #322020;--color-warning-50: #39221D;--color-warning-100: #42211A;--color-warning-125: #4C1E15;--color-warning-150: #5E2817;--color-warning-200: #713319;--color-warning-225: #854119;--color-warning-250: #9A5119;--color-warning-275: #AF6418;--color-warning-300: #C56E16;--color-warning-350: #DD7813;--color-warning-400: #F08214;--color-warning-450: #F68C23;--color-warning-500: #FB9632;--color-warning-550: #FFA042;--color-warning-600: #FFAB57;--color-warning-650: #FFB56B;--color-warning-700: #FFBF80;--color-warning-720: #FFC994;--color-warning-740: #FFD3A8;--color-warning-760: #FFDEBD;--color-warning-780: #FFE3C7;--color-warning-800: #FFE8D1;--color-warning-825: #FFEDDB;--color-warning-850: #FFF3E6;--color-warning-900: #FFF7F0;--color-warning-950: #FFFDFA;--color-negative-25: #2F2229;--color-negative-50: #371F2D;--color-negative-100: #401C30;--color-negative-125: #4A1733;--color-negative-150: #5B1A3A;--color-negative-200: #6E1C3E;--color-negative-225: #821C40;--color-negative-250: #961D3F;--color-negative-275: #AB1C31;--color-negative-300: #C11A33;--color-negative-350: #D81834;--color-negative-400: #EB1938;--color-negative-450: #F12745;--color-negative-500: #F73652;--color-negative-550: #FF425E;--color-negative-600: #FF576F;--color-negative-650: #FF6B81;--color-negative-700: #FF8092;--color-negative-720: #FF94A4;--color-negative-740: #FFA8B5;--color-negative-760: #FFBDC6;--color-negative-780: #FFC7CF;--color-negative-800: #FFD1D8;--color-negative-825: #FFDBE1;--color-negative-850: #FFE5E9;--color-negative-900: #FFF0F2;--color-negative-950: #FFFAFA;--color-info-25: #1E1D2B;--color-info-50: #1C1A32;--color-info-100: #1A173B;--color-info-125: #181344;--color-info-150: #201556;--color-info-200: #2A1769;--color-info-225: #36187C;--color-info-250: #441891;--color-info-275: #5517A6;--color-info-300: #5E15BC;--color-info-350: #6612D3;--color-info-400: #6F0FEB;--color-info-450: #7919F5;--color-info-500: #8428FB;--color-info-550: #8F38FF;--color-info-600: #9A4DFF;--color-info-650: #A561FF;--color-info-700: #B175FF;--color-info-720: #BC8AFF;--color-info-740: #C89EFF;--color-info-760: #D4B2FF;--color-info-780: #D9BDFF;--color-info-800: #DFC7FF;--color-info-825: #E5D1FF;--color-info-850: #EBDBFF;--color-info-900: #F1E5FF;--color-info-950: #F6F0FF;--color-layer-1: rgba(140, 140, 166, .08);--color-layer-2: rgba(140, 140, 166, .14);--color-layer-3: rgba(140, 140, 166, .18);--color-layer-4: rgba(140, 140, 166, .24);--color-layer-primary-1: rgba(45, 110, 251, .14);--color-layer-primary-2: rgba(45, 110, 251, .2);--color-layer-primary-3: rgba(45, 110, 251, .3);--color-layer-primary-4: rgba(45, 110, 251, .4);--color-layer-positive-1: rgba(54, 181, 86, .14);--color-layer-positive-2: rgba(54, 181, 86, .2);--color-layer-positive-3: rgba(54, 181, 86, .3);--color-layer-positive-4: rgba(54, 181, 86, .4);--color-layer-warning-1: rgba(255, 160, 66, .14);--color-layer-warning-2: rgba(255, 160, 66, .2);--color-layer-warning-3: rgba(255, 160, 66, .3);--color-layer-warning-4: rgba(255, 160, 66, .4);--color-layer-negative-1: rgba(247, 54, 82, .14);--color-layer-negative-2: rgba(247, 54, 82, .2);--color-layer-negative-3: rgba(247, 54, 82, .3);--color-layer-negative-4: rgba(247, 54, 82, .4);--color-layer-info-1: rgba(165, 97, 255, .14);--color-layer-info-2: rgba(165, 97, 255, .2);--color-layer-info-3: rgba(165, 97, 255, .3);--color-layer-info-4: rgba(165, 97, 255, .4);--top-shadow-xs: 0px 0px 3px rgba(0, 0, 0, .11), 0px 5px 25px rgba(0, 0, 0, .08);--top-shadow-s: 0px 0px 3px rgba(0, 0, 0, .11), 0px 5px 25px rgba(0, 0, 0, .17);--top-shadow: 0px 0px 4px rgba(0, 0, 0, .14), 0px 4px 32px rgba(0, 0, 0, .2);--top-shadow-m: 0px 0px 4px 0px rgba(0, 0, 0, .14), 0px 4px 32px 0px rgba(0, 0, 0, .2);--top-shadow-b: 0px 0px 4px rgba(0, 0, 0, .15), 0px 18px 32px rgba(0, 0, 0, .34);--top-shadow-darken: inset 1000px 1000px 1000px 1000px rgba(0, 0, 0, .03);--top-shadow-darken-2: inset 1000px 1000px 1000px 1000px rgba(0, 0, 0, .12);--top-shadow-darken-3: inset 1000px 1000px 1000px 1000px rgba(0, 0, 0, .1);--color-bg-preloader: rgba(255, 255, 255, .01)}:root{--color-brand-1: #FFE500;--color-brand-2: #FFD400;--color-brand-3: #F5BC00;--color-bg-shading-1: var(--color-theme-150);--color-bg-shading-2: var(--color-theme-125);--color-bg-shading-3: var(--color-theme-100);--color-bg-shading-4: var(--color-theme-75);--color-bg-shading-5: var(--color-theme-50);--color-bg-shading-6: var(--color-theme-0);--color-bg-lightning-1: var(--color-theme-260);--color-bg-primary-1: var(--color-primary-550);--color-bg-primary-2: var(--color-primary-650);--color-bg-primary-3: var(--color-primary-720);--color-bg-positive-1: var(--color-positive-400);--color-bg-positive-2: var(--color-positive-600);--color-bg-positive-3: var(--color-positive-740);--color-bg-warning-1: var(--color-warning-450);--color-bg-warning-2: var(--color-warning-600);--color-bg-warning-3: var(--color-warning-700);--color-bg-negative-1: var(--color-negative-550);--color-bg-negative-2: var(--color-negative-650);--color-bg-negative-3: var(--color-negative-720);--color-bg-info-1: var(--color-info-650);--color-bg-info-2: var(--color-info-720);--color-bg-info-3: var(--color-info-780);--top-panel-background-color: rgba(24, 24, 27, .8);--color-text-1: var(--color-theme-970);--color-text-2: var(--color-theme-750);--color-text-3: var(--color-theme-500);--color-text-4: var(--color-theme-450);--color-text-1-inverse: var(--color-theme-100);--color-text-white: var(--color-white);--color-text-primary: var(--color-primary-550);--color-text-primary-alt: var(--color-primary-650);--color-text-positive: var(--color-positive-450);--color-text-positive-alt: var(--color-positive-700);--color-text-warning: var(--color-warning-450);--color-text-warning-alt: var(--color-warning-650);--color-text-negative: var(--color-negative-600);--color-text-negative-alt: var(--color-negative-720);--color-text-info: var(--color-info-650);--color-text-info-alt: var(--color-info-740);--color-line-1: var(--color-theme-350);--color-line-2: var(--color-theme-400);--color-line-3: var(--color-theme-485);--color-line-4: var(--color-theme-650);--color-line-1-opacity: rgba(193, 203, 215, .1);--color-line-2-opacity: rgba(193, 203, 215, .15);--color-line-3-opacity: rgba(193, 203, 215, .27);--color-line-primary-1: var(--color-primary-700);--color-line-primary-2: var(--color-primary-760);--color-line-primary-3: var(--color-primary-850);--color-line-primary-1-opacity: rgba(122, 164, 255, .14);--color-line-primary-2-opacity: rgba(122, 164, 255, .28);--color-line-primary-3-opacity: rgba(122, 164, 255, .38);--color-line-positive-1: var(--color-positive-450);--color-line-positive-2: var(--color-positive-600);--color-line-positive-3: var(--color-positive-740);--color-line-positive-1-opacity: rgba(164, 233, 171, .14);--color-line-positive-2-opacity: rgba(164, 233, 171, .28);--color-line-positive-3-opacity: rgba(164, 233, 171, .38);--color-line-warning-1: var(--color-warning-500);--color-line-warning-2: var(--color-warning-650);--color-line-warning-3: var(--color-warning-740);--color-line-warning-1-opacity: rgba(255, 191, 128, .14);--color-line-warning-2-opacity: rgba(255, 191, 128, .28);--color-line-warning-3-opacity: rgba(255, 191, 128, .38);--color-line-negative-1: var(--color-negative-600);--color-line-negative-2: var(--color-negative-650);--color-line-negative-3: var(--color-negative-740);--color-line-negative-1-opacity: rgba(239, 135, 148, .14);--color-line-negative-2-opacity: rgba(239, 135, 148, .28);--color-line-negative-3-opacity: rgba(239, 135, 148, .38);--color-line-info-1: var(--color-info-650);--color-line-info-2: var(--color-info-720);--color-line-info-3: var(--color-info-780);--color-line-info-1-opacity: rgba(168, 120, 247, .14);--color-line-info-2-opacity: rgba(168, 120, 247, .28);--color-line-info-3-opacity: rgba(168, 120, 247, .38);--scroll-track-color: var(--color-theme-225);--scroll-thumb-color: var(--color-theme-250);--scroll-thumb-color-hover: var(--color-theme-300);--scroll-thumb-color-active: var(--color-theme-400);--body-background-color: var(--color-layout-front-1);--content-background-color: var(--color-layout-front-1);--top-forms-option-color: var(--color-primary-500);--top-forms-option-color-hover: var(--color-primary-600)}:root{--color-layout-back: var(--color-theme-50);--color-layout-header: var(--color-theme-175);--color-layout-middle: var(--color-theme-125);--color-layout-front-1: var(--color-theme-175);--color-layout-front-2: var(--color-theme-200);--color-layout-front-3: var(--color-theme-225);--color-layout-front-4: var(--color-theme-250);--color-layout-front-5: var(--color-theme-260);--color-layout-front-6: var(--color-theme-275);--color-layout-front-primary-1: #232F41;--color-layout-front-primary-2: #232F41;--color-layout-front-primary-3: #243149;--color-layout-front-primary-4: #243450;--color-layout-front-primary-5: #253758;--color-layout-front-primary-6: #253960;--color-layout-front-positive-1: #25333B;--color-layout-front-positive-2: #25333B;--color-layout-front-positive-3: #263A3D;--color-layout-front-positive-4: #284140;--color-layout-front-positive-5: #2A4842;--color-layout-front-positive-6: #2B4F44;--color-layout-front-warning-1: #2B3038;--color-layout-front-warning-2: #2B3038;--color-layout-front-warning-3: #343437;--color-layout-front-warning-4: #3C3836;--color-layout-front-warning-5: #453B35;--color-layout-front-warning-6: #4D3F35;--color-layout-front-negative-1: #2B2C3A;--color-layout-front-negative-2: #2B2C3A;--color-layout-front-negative-3: #342D3B;--color-layout-front-negative-4: #3C2D3C;--color-layout-front-negative-5: #452E3D;--color-layout-front-negative-6: #4D2E3E;--color-layout-front-info-1: #272C41;--color-layout-front-info-2: #272C41;--color-layout-front-info-3: #2B2C49;--color-layout-front-info-4: #2F2C50;--color-layout-front-info-5: #332B58;--color-layout-front-info-6: #362B60}:root{--color-summary-top-3: #5BA8DC;--color-summary-top-10: #1AAD7B;--color-summary-top-30: #4BD2B8;--color-summary-top-50: #68CA63;--color-summary-top-100: #9DAAAA;--color-summary-top-10000: #CAA549;--color-table-top-1: #425C8F;--color-table-top-2: #384E7A;--color-table-top-3: #394660;--color-table-top-4: #357550;--color-table-top-5: #336F4E;--color-table-top-6: #326B4D;--color-table-top-7: #31684C;--color-table-top-8: #30624A;--color-table-top-9: #2F5D48;--color-table-top-10: #2D5747;--color-table-move-up-10: #0E6A44;--color-table-move-up-9: #116542;--color-table-move-up-8: #145F40;--color-table-move-up-7: #165A3E;--color-table-move-up-6: #19543C;--color-table-move-up-5: #1B4F3A;--color-table-move-up-4: #1E4938;--color-table-move-up-3: #204335;--color-table-move-up-2: #233E33;--color-table-move-up-1: #263832;--color-table-move-0: #313135;--color-table-move-down-1: #46303F;--color-table-move-down-2: #4F3040;--color-table-move-down-3: #583142;--color-table-move-down-4: #633244;--color-table-move-down-5: #6C3345;--color-table-move-down-6: #723446;--color-table-move-down-7: #793547;--color-table-move-down-8: #823649;--color-table-move-down-9: #8A364A;--color-table-move-down-10: #93374C;--color-table-down: #46303F;--color-table-down-10: #4F3040;--color-table-up: #365344;--color-table-up-10: #2C5145;--color-table-base: var(--color-layout-front-1);--color-table-featured-snippet: #878742;--color-table-empty: var(--color-layout-front-3);--color-table-not_found: #FFF6C6;--color-snapshot-panel-gradient-1: rgba(35, 44, 77, .5);--color-snapshot-panel-gradient-2: rgba(35, 44, 77, .8);--color-snippet-title: #A2C2FA;--color-snippet-title-visited: #BC8CF2;--color-snippet-url: #007700}
@@ -1 +1 @@
1
- :root{color-scheme:dark;--color-theme-0: #000000;--color-theme-50: #050815;--color-theme-75: #090A18;--color-theme-100: #0E121B;--color-theme-125: #111722;--color-theme-150: #141C29;--color-theme-175: #172130;--color-theme-200: #1B2637;--color-theme-225: #1E2B3E;--color-theme-250: #223044;--color-theme-260: #25344C;--color-theme-275: #293852;--color-theme-300: #2C3E58;--color-theme-325: #2F4360;--color-theme-350: #324867;--color-theme-360: #364D6D;--color-theme-375: #395175;--color-theme-400: #3D557B;--color-theme-410: #405A82;--color-theme-420: #435F89;--color-theme-430: #47648F;--color-theme-440: #4A6996;--color-theme-450: #4D6E9D;--color-theme-460: #5173A4;--color-theme-465: #5476AB;--color-theme-470: #5B7DAE;--color-theme-475: #6281B2;--color-theme-480: #6987B5;--color-theme-485: #708DB8;--color-theme-500: #7692BC;--color-theme-550: #7D97BF;--color-theme-575: #849DC2;--color-theme-600: #8AA2C6;--color-theme-625: #92A7C9;--color-theme-650: #98AECD;--color-theme-675: #9FB3D0;--color-theme-700: #A7B9D3;--color-theme-710: #ADBED6;--color-theme-725: #B3C3DA;--color-theme-750: #BBC9DD;--color-theme-800: #C1CEE1;--color-theme-850: #C8D3E4;--color-theme-900: #CFD9E8;--color-theme-925: #D6DEEB;--color-theme-950: #DDE3EE;--color-theme-955: #E4EAF1;--color-theme-960: #EAEFF5;--color-theme-965: #F1F4F8;--color-theme-970: #F9FAFB;--color-theme-1000: #FFFFFF;--color-white: rgba(255, 255, 255, 1);--color-black: rgba(0, 0, 0, 1);--color-primary-25: #1F252E;--color-primary-50: #1C2736;--color-primary-100: #18293E;--color-primary-125: #142B48;--color-primary-150: #16355A;--color-primary-200: #183E6D;--color-primary-225: #184781;--color-primary-250: #185095;--color-primary-275: #175AAB;--color-primary-300: #1563C1;--color-primary-350: #136BD8;--color-primary-400: #0F74F0;--color-primary-450: #1E7FF6;--color-primary-500: #2D8AFB;--color-primary-550: #3D94FF;--color-primary-600: #52A0FF;--color-primary-650: #66ABFF;--color-primary-700: #7AB6FF;--color-primary-720: #8FC1FF;--color-primary-740: #A3CDFF;--color-primary-760: #B8D8FF;--color-primary-780: #C2DDFF;--color-primary-800: #CCE3FF;--color-primary-825: #D6E9FF;--color-primary-850: #E0EEFF;--color-primary-900: #EBF4FF;--color-primary-950: #F5F9FF;--color-positive-25: #111311;--color-positive-50: #131612;--color-positive-100: #141A14;--color-positive-125: #161E15;--color-positive-150: #1C2C1C;--color-positive-200: #223A23;--color-positive-225: #27492B;--color-positive-250: #2C5934;--color-positive-275: #2F6A3E;--color-positive-300: #327B44;--color-positive-350: #348D4B;--color-positive-400: #36A150;--color-positive-450: #36B556;--color-positive-500: #36C95B;--color-positive-550: #41D265;--color-positive-600: #4DDB73;--color-positive-650: #5AE27C;--color-positive-700: #6CE58A;--color-positive-720: #7DE898;--color-positive-740: #8EEBA5;--color-positive-760: #A0EEB3;--color-positive-780: #B1F1C1;--color-positive-800: #C2F4CF;--color-positive-825: #D8F8E0;--color-positive-850: #E5FAEA;--color-positive-900: #EEFCF1;--color-positive-950: #F6FDF8;--color-warning-25: #3C1F1F;--color-warning-50: #39221B;--color-warning-100: #421B1A;--color-warning-125: #4C2015;--color-warning-150: #5E2517;--color-warning-200: #71321E;--color-warning-225: #7F3D19;--color-warning-250: #9A511A;--color-warning-275: #AF6420;--color-warning-300: #C56D1C;--color-warning-350: #DD780C;--color-warning-400: #F08214;--color-warning-450: #F48B1B;--color-warning-500: #FB9632;--color-warning-550: #FFA042;--color-warning-600: #FFAB57;--color-warning-650: #FFB56B;--color-warning-700: #FFBF80;--color-warning-720: #FFCB94;--color-warning-740: #FFD7A8;--color-warning-760: #FFDEBF;--color-warning-780: #FFE3C7;--color-warning-800: #FFE8CF;--color-warning-825: #FFEDDB;--color-warning-850: #FFF3E6;--color-warning-900: #FFF7F0;--color-warning-950: #FFFDFA;--color-negative-25: #2E2229;--color-negative-50: #371F2B;--color-negative-100: #402030;--color-negative-125: #4A1733;--color-negative-150: #5B193A;--color-negative-200: #6E1C2F;--color-negative-225: #8A1C34;--color-negative-250: #9B1D32;--color-negative-275: #AB1A2F;--color-negative-300: #C31A30;--color-negative-350: #D81534;--color-negative-400: #EB1938;--color-negative-450: #F12745;--color-negative-500: #F73652;--color-negative-550: #FF4262;--color-negative-600: #FF576F;--color-negative-650: #FF6B7B;--color-negative-700: #FF8092;--color-negative-720: #FF949F;--color-negative-740: #FFA8B5;--color-negative-760: #FFBFC6;--color-negative-780: #FFC7CF;--color-negative-800: #FFD1D8;--color-negative-825: #FFDDE1;--color-negative-850: #FFE5E9;--color-negative-900: #FFF0F2;--color-negative-950: #FFFAFB;--color-info-25: #1E1D2B;--color-info-50: #1C1A32;--color-info-100: #1A173B;--color-info-125: #181344;--color-info-150: #201556;--color-info-200: #2A1769;--color-info-225: #36187C;--color-info-250: #441891;--color-info-275: #5517A6;--color-info-300: #5E15BC;--color-info-350: #6612D3;--color-info-400: #6F0FEB;--color-info-450: #7919F5;--color-info-500: #8428FB;--color-info-550: #8F38FF;--color-info-600: #9A4DFF;--color-info-650: #A561FF;--color-info-700: #B175FF;--color-info-720: #BC8AFF;--color-info-740: #C89EFF;--color-info-760: #D4B2FF;--color-info-780: #D9BDFF;--color-info-800: #DFC7FF;--color-info-825: #E5D1FF;--color-info-850: #EBDBFF;--color-info-900: #F1E5FF;--color-info-950: #F6F0FF;--color-layer-1: rgba(129, 148, 177, .08);--color-layer-2: rgba(129, 148, 177, .14);--color-layer-3: rgba(129, 148, 177, .18);--color-layer-4: rgba(129, 148, 177, .24);--color-layer-primary-1: rgba(45, 110, 251, .14);--color-layer-primary-2: rgba(45, 110, 251, .2);--color-layer-primary-3: rgba(45, 110, 251, .3);--color-layer-primary-4: rgba(45, 110, 251, .4);--color-layer-positive-1: rgba(54, 181, 86, .14);--color-layer-positive-2: rgba(54, 181, 86, .2);--color-layer-positive-3: rgba(54, 181, 86, .3);--color-layer-positive-4: rgba(54, 181, 86, .4);--color-layer-warning-1: rgba(255, 160, 66, .14);--color-layer-warning-2: rgba(255, 160, 66, .2);--color-layer-warning-3: rgba(255, 160, 66, .3);--color-layer-warning-4: rgba(255, 160, 66, .4);--color-layer-negative-1: rgba(247, 54, 82, .14);--color-layer-negative-2: rgba(247, 54, 82, .2);--color-layer-negative-3: rgba(247, 54, 82, .3);--color-layer-negative-4: rgba(247, 54, 82, .4);--color-layer-info-1: rgba(165, 97, 255, .14);--color-layer-info-2: rgba(165, 97, 255, .2);--color-layer-info-3: rgba(165, 97, 255, .3);--color-layer-info-4: rgba(165, 97, 255, .4);--top-shadow-xs: 0px 0px 3px rgba(0, 0, 0, .11), 0px 5px 25px rgba(0, 0, 0, .08);--top-shadow-s: 0px 0px 3px rgba(0, 0, 0, .11), 0px 5px 25px rgba(0, 0, 0, .17);--top-shadow: 0px 0px 4px rgba(0, 0, 0, .14), 0px 4px 32px rgba(0, 0, 0, .2);--top-shadow-m: 0px 0px 4px 0px rgba(0, 0, 0, .14), 0px 4px 32px 0px rgba(0, 0, 0, .2);--top-shadow-b: 0px 0px 4px rgba(0, 0, 0, .15), 0px 18px 32px rgba(0, 0, 0, .34);--top-shadow-darken-1: inset 1000px 1000px 1000px 1000px rgba(0, 0, 0, .03);--top-shadow-darken-2: inset 1000px 1000px 1000px 1000px rgba(0, 0, 0, .12);--top-shadow-darken-3: inset 1000px 1000px 1000px 1000px rgba(0, 0, 0, .1);--color-bg-preloader: rgba(255, 255, 255, .01)}:root{--color-brand-1: var(--color-primary-700);--color-brand-2: var(--color-primary-740);--color-brand-3: var(--color-primary-800);--color-bg-shading-1: var(--color-theme-200);--color-bg-shading-2: var(--color-theme-175);--color-bg-shading-3: var(--color-theme-150);--color-bg-shading-4: var(--color-theme-125);--color-bg-shading-5: var(--color-theme-100);--color-bg-shading-6: var(--color-theme-50);--color-bg-lightning-1: var(--color-theme-260);--color-bg-inverted-1: var(--color-theme-970);--color-bg-inverted-2: var(--color-theme-955);--color-bg-inverted-3: var(--color-theme-900);--color-bg-inverted-4: var(--color-theme-850);--color-bg-inverted-5: var(--color-theme-800);--color-bg-inverted-6: var(--color-theme-750);--color-bg-inverted-7: var(--color-theme-725);--color-bg-inverted-8: var(--color-theme-710);--color-bg-inverted-9: var(--color-theme-700);--color-bg-inverted-10: var(--color-theme-675);--color-bg-primary-1: var(--color-primary-550);--color-bg-primary-2: var(--color-primary-650);--color-bg-primary-3: var(--color-primary-720);--color-bg-positive-1: var(--color-positive-450);--color-bg-positive-2: var(--color-positive-600);--color-bg-positive-3: var(--color-positive-740);--color-bg-warning-1: var(--color-warning-450);--color-bg-warning-2: var(--color-warning-600);--color-bg-warning-3: var(--color-warning-700);--color-bg-negative-1: var(--color-negative-550);--color-bg-negative-2: var(--color-negative-650);--color-bg-negative-3: var(--color-negative-720);--color-bg-info-1: var(--color-info-650);--color-bg-info-2: var(--color-info-720);--color-bg-info-3: var(--color-info-780);--top-panel-background-color: rgba(17, 23, 34, .8);--color-text-1: var(--color-theme-970);--color-text-2: var(--color-theme-750);--color-text-3: var(--color-theme-500);--color-text-4: var(--color-theme-450);--color-text-1-inverse: var(--color-theme-100);--color-text-white: var(--color-white);--color-text-primary: var(--color-primary-550);--color-text-primary-alt: var(--color-primary-650);--color-text-positive: var(--color-positive-450);--color-text-positive-alt: var(--color-positive-600);--color-text-warning: var(--color-warning-450);--color-text-warning-alt: var(--color-warning-650);--color-text-negative: var(--color-negative-550);--color-text-negative-alt: var(--color-negative-650);--color-text-info: var(--color-info-650);--color-text-info-alt: var(--color-info-740);--color-line-1: var(--color-theme-350);--color-line-2: var(--color-theme-400);--color-line-3: var(--color-theme-485);--color-line-4: var(--color-theme-650);--color-line-1-opacity: rgba(193, 203, 215, .1);--color-line-2-opacity: rgba(193, 203, 215, .15);--color-line-3-opacity: rgba(193, 203, 215, .27);--color-line-primary-1: var(--color-primary-450);--color-line-primary-2: var(--color-primary-600);--color-line-primary-3: var(--color-primary-740);--color-line-primary-1-opacity: rgba(122, 164, 255, .14);--color-line-primary-2-opacity: rgba(122, 164, 255, .28);--color-line-primary-3-opacity: rgba(122, 164, 255, .38);--color-line-positive-1: var(--color-positive-450);--color-line-positive-2: var(--color-positive-600);--color-line-positive-3: var(--color-positive-740);--color-line-positive-1-opacity: rgba(164, 233, 171, .14);--color-line-positive-2-opacity: rgba(164, 233, 171, .28);--color-line-positive-3-opacity: rgba(164, 233, 171, .38);--color-line-warning-1: var(--color-warning-450);--color-line-warning-2: var(--color-warning-600);--color-line-warning-3: var(--color-warning-700);--color-line-warning-1-opacity: rgba(255, 191, 128, .14);--color-line-warning-2-opacity: rgba(255, 191, 128, .28);--color-line-warning-3-opacity: rgba(255, 191, 128, .38);--color-line-negative-1: var(--color-negative-550);--color-line-negative-2: var(--color-negative-650);--color-line-negative-3: var(--color-negative-720);--color-line-negative-1-opacity: rgba(239, 135, 148, .14);--color-line-negative-2-opacity: rgba(239, 135, 148, .28);--color-line-negative-3-opacity: rgba(239, 135, 148, .38);--color-line-info-1: var(--color-info-650);--color-line-info-2: var(--color-info-720);--color-line-info-3: var(--color-info-780);--color-line-info-1-opacity: rgba(168, 120, 247, .14);--color-line-info-2-opacity: rgba(168, 120, 247, .28);--color-line-info-3-opacity: rgba(168, 120, 247, .38);--scroll-track-color: var(--color-theme-225);--scroll-thumb-color: var(--color-theme-300);--scroll-thumb-color-hover: var(--color-theme-450);--scroll-thumb-color-active: var(--color-theme-550);--body-background-color: var(--color-layout-front-1);--content-background-color: var(--color-layout-front-1);--top-forms-option-color: var(--color-primary-550);--top-forms-option-color-hover: var(--color-primary-650)}:root{--color-layout-back: var(--color-theme-100);--color-layout-header: var(--color-theme-225);--color-layout-middle: var(--color-theme-125);--color-layout-front-1: var(--color-theme-225);--color-layout-front-2: #222F43;--color-layout-front-3: #253348;--color-layout-front-4: #29374D;--color-layout-front-5: #2C3B52;--color-layout-front-6: #2C3B52;--color-layout-front-primary-1: #202C3F;--color-layout-front-primary-2: #232f41;--color-layout-front-primary-3: #243149;--color-layout-front-primary-4: #243450;--color-layout-front-primary-5: #253758;--color-layout-front-primary-6: #253960;--color-layout-front-positive-1: #202D3D;--color-layout-front-positive-2: #25333b;--color-layout-front-positive-3: #263a3d;--color-layout-front-positive-4: #284140;--color-layout-front-positive-5: #2a4842;--color-layout-front-positive-6: #2b4f44;--color-layout-front-warning-1: #222D3C;--color-layout-front-warning-2: #2b3038;--color-layout-front-warning-3: #343437;--color-layout-front-warning-4: #3c3836;--color-layout-front-warning-5: #453b35;--color-layout-front-warning-6: #4d3f35;--color-layout-front-negative-1: #222B3D;--color-layout-front-negative-2: #2b2c3a;--color-layout-front-negative-3: #342d3b;--color-layout-front-negative-4: #3c2d3c;--color-layout-front-negative-5: #452e3d;--color-layout-front-negative-6: #4d2e3e;--color-layout-front-info-1: #212B3F;--color-layout-front-info-2: #272c41;--color-layout-front-info-3: #2b2c49;--color-layout-front-info-4: #2f2c50;--color-layout-front-info-5: #332b58;--color-layout-front-info-6: #362b60}:root{--color-summary-top-3: #5BA8DC;--color-summary-top-10: #1AAD7B;--color-summary-top-30: #4BD2B8;--color-summary-top-50: #68CA63;--color-summary-top-100: #9DAAAA;--color-summary-top-10000: #CAA549;--color-table-top-1: #435E93;--color-table-top-2: #3F5788;--color-table-top-3: #3B5381;--color-table-top-4: #357550;--color-table-top-5: #336F4E;--color-table-top-6: #326B4D;--color-table-top-7: #31684C;--color-table-top-8: #30624A;--color-table-top-9: #2F5D48;--color-table-top-10: #2D5747;--color-table-move-up-10: #0E6A44;--color-table-move-up-9: #116542;--color-table-move-up-8: #145F40;--color-table-move-up-7: #165A3E;--color-table-move-up-6: #19543C;--color-table-move-up-5: #1B4F3A;--color-table-move-up-4: #1E4938;--color-table-move-up-3: #204335;--color-table-move-up-2: #233E33;--color-table-move-up-1: #263832;--color-table-move-0: #313135;--color-table-move-down-1: #46303F;--color-table-move-down-2: #4F3040;--color-table-move-down-3: #583142;--color-table-move-down-4: #633244;--color-table-move-down-5: #6C3345;--color-table-move-down-6: #723446;--color-table-move-down-7: #793547;--color-table-move-down-8: #823649;--color-table-move-down-9: #8A364A;--color-table-move-down-10: #93374C;--color-table-down: #46303F;--color-table-down-10: #4F3040;--color-table-up: #365344;--color-table-up-10: #2C5145;--color-table-base: var(--color-layout-front-1);--color-table-featured-snippet: #7D7B45;--color-table-empty: var(--color-layout-front-3);--color-table-not_found: #313638;--color-snapshot-panel-gradient-1: rgba(35, 44, 77, .5);--color-snapshot-panel-gradient-2: rgba(35, 44, 77, .8);--color-snippet-title: #A2C2FA;--color-snippet-title-visited: #BC8CF2;--color-snippet-url: #007700}
1
+ :root{color-scheme:dark;--color-theme-0: #000000;--color-theme-50: #050815;--color-theme-75: #090A18;--color-theme-100: #0E121B;--color-theme-125: #111722;--color-theme-150: #141C29;--color-theme-175: #172130;--color-theme-200: #1B2637;--color-theme-225: #1E2B3E;--color-theme-250: #223044;--color-theme-260: #25344C;--color-theme-275: #293852;--color-theme-300: #2C3E58;--color-theme-325: #2F4360;--color-theme-350: #324867;--color-theme-360: #364D6D;--color-theme-375: #395175;--color-theme-400: #3D557B;--color-theme-410: #405A82;--color-theme-420: #435F89;--color-theme-430: #47648F;--color-theme-440: #4A6996;--color-theme-450: #4D6E9D;--color-theme-460: #5173A4;--color-theme-465: #5476AB;--color-theme-470: #5B7DAE;--color-theme-475: #6281B2;--color-theme-480: #6987B5;--color-theme-485: #708DB8;--color-theme-500: #7692BC;--color-theme-550: #7D97BF;--color-theme-575: #849DC2;--color-theme-600: #8AA2C6;--color-theme-625: #92A7C9;--color-theme-650: #98AECD;--color-theme-675: #9FB3D0;--color-theme-700: #A7B9D3;--color-theme-710: #ADBED6;--color-theme-725: #B3C3DA;--color-theme-750: #BBC9DD;--color-theme-800: #C1CEE1;--color-theme-850: #C8D3E4;--color-theme-900: #CFD9E8;--color-theme-925: #D6DEEB;--color-theme-950: #DDE3EE;--color-theme-955: #E4EAF1;--color-theme-960: #EAEFF5;--color-theme-965: #F1F4F8;--color-theme-970: #F9FAFB;--color-theme-1000: #FFFFFF;--color-white: rgba(255, 255, 255, 1);--color-black: rgba(0, 0, 0, 1);--color-primary-25: #1F252E;--color-primary-50: #1C2736;--color-primary-100: #18293E;--color-primary-125: #142B48;--color-primary-150: #16355A;--color-primary-200: #183E6D;--color-primary-225: #184781;--color-primary-250: #185095;--color-primary-275: #175AAB;--color-primary-300: #1563C1;--color-primary-350: #136BD8;--color-primary-400: #0F74F0;--color-primary-450: #1E7FF6;--color-primary-500: #2D8AFB;--color-primary-550: #3D94FF;--color-primary-600: #52A0FF;--color-primary-650: #66ABFF;--color-primary-700: #7AB6FF;--color-primary-720: #8FC1FF;--color-primary-740: #A3CDFF;--color-primary-760: #B8D8FF;--color-primary-780: #C2DDFF;--color-primary-800: #CCE3FF;--color-primary-825: #D6E9FF;--color-primary-850: #E0EEFF;--color-primary-900: #EBF4FF;--color-primary-950: #F5F9FF;--color-positive-25: #111311;--color-positive-50: #131612;--color-positive-100: #141A14;--color-positive-125: #161E15;--color-positive-150: #1C2C1C;--color-positive-200: #223A23;--color-positive-225: #27492B;--color-positive-250: #2C5934;--color-positive-275: #2F6A3E;--color-positive-300: #327B44;--color-positive-350: #348D4B;--color-positive-400: #36A150;--color-positive-450: #36B556;--color-positive-500: #36C95B;--color-positive-550: #41D265;--color-positive-600: #4DDB73;--color-positive-650: #5AE27C;--color-positive-700: #6CE58A;--color-positive-720: #7DE898;--color-positive-740: #8EEBA5;--color-positive-760: #A0EEB3;--color-positive-780: #B1F1C1;--color-positive-800: #C2F4CF;--color-positive-825: #D8F8E0;--color-positive-850: #E5FAEA;--color-positive-900: #EEFCF1;--color-positive-950: #F6FDF8;--color-warning-25: #3C1F1F;--color-warning-50: #39221B;--color-warning-100: #421B1A;--color-warning-125: #4C2015;--color-warning-150: #5E2517;--color-warning-200: #71321E;--color-warning-225: #7F3D19;--color-warning-250: #9A511A;--color-warning-275: #AF6420;--color-warning-300: #C56D1C;--color-warning-350: #DD780C;--color-warning-400: #F08214;--color-warning-450: #F48B1B;--color-warning-500: #FB9632;--color-warning-550: #FFA042;--color-warning-600: #FFAB57;--color-warning-650: #FFB56B;--color-warning-700: #FFBF80;--color-warning-720: #FFCB94;--color-warning-740: #FFD7A8;--color-warning-760: #FFDEBF;--color-warning-780: #FFE3C7;--color-warning-800: #FFE8CF;--color-warning-825: #FFEDDB;--color-warning-850: #FFF3E6;--color-warning-900: #FFF7F0;--color-warning-950: #FFFDFA;--color-negative-25: #2E2229;--color-negative-50: #371F2B;--color-negative-100: #402030;--color-negative-125: #4A1733;--color-negative-150: #5B193A;--color-negative-200: #6E1C2F;--color-negative-225: #8A1C34;--color-negative-250: #9B1D32;--color-negative-275: #AB1A2F;--color-negative-300: #C31A30;--color-negative-350: #D81534;--color-negative-400: #EB1938;--color-negative-450: #F12745;--color-negative-500: #F73652;--color-negative-550: #FF4262;--color-negative-600: #FF576F;--color-negative-650: #FF6B7B;--color-negative-700: #FF8092;--color-negative-720: #FF949F;--color-negative-740: #FFA8B5;--color-negative-760: #FFBFC6;--color-negative-780: #FFC7CF;--color-negative-800: #FFD1D8;--color-negative-825: #FFDDE1;--color-negative-850: #FFE5E9;--color-negative-900: #FFF0F2;--color-negative-950: #FFFAFB;--color-info-25: #1E1D2B;--color-info-50: #1C1A32;--color-info-100: #1A173B;--color-info-125: #181344;--color-info-150: #201556;--color-info-200: #2A1769;--color-info-225: #36187C;--color-info-250: #441891;--color-info-275: #5517A6;--color-info-300: #5E15BC;--color-info-350: #6612D3;--color-info-400: #6F0FEB;--color-info-450: #7919F5;--color-info-500: #8428FB;--color-info-550: #8F38FF;--color-info-600: #9A4DFF;--color-info-650: #A561FF;--color-info-700: #B175FF;--color-info-720: #BC8AFF;--color-info-740: #C89EFF;--color-info-760: #D4B2FF;--color-info-780: #D9BDFF;--color-info-800: #DFC7FF;--color-info-825: #E5D1FF;--color-info-850: #EBDBFF;--color-info-900: #F1E5FF;--color-info-950: #F6F0FF;--color-layer-1: rgba(129, 148, 177, .08);--color-layer-2: rgba(129, 148, 177, .14);--color-layer-3: rgba(129, 148, 177, .18);--color-layer-4: rgba(129, 148, 177, .24);--color-layer-primary-1: rgba(45, 110, 251, .14);--color-layer-primary-2: rgba(45, 110, 251, .2);--color-layer-primary-3: rgba(45, 110, 251, .3);--color-layer-primary-4: rgba(45, 110, 251, .4);--color-layer-positive-1: rgba(54, 181, 86, .14);--color-layer-positive-2: rgba(54, 181, 86, .2);--color-layer-positive-3: rgba(54, 181, 86, .3);--color-layer-positive-4: rgba(54, 181, 86, .4);--color-layer-warning-1: rgba(255, 160, 66, .14);--color-layer-warning-2: rgba(255, 160, 66, .2);--color-layer-warning-3: rgba(255, 160, 66, .3);--color-layer-warning-4: rgba(255, 160, 66, .4);--color-layer-negative-1: rgba(247, 54, 82, .14);--color-layer-negative-2: rgba(247, 54, 82, .2);--color-layer-negative-3: rgba(247, 54, 82, .3);--color-layer-negative-4: rgba(247, 54, 82, .4);--color-layer-info-1: rgba(165, 97, 255, .14);--color-layer-info-2: rgba(165, 97, 255, .2);--color-layer-info-3: rgba(165, 97, 255, .3);--color-layer-info-4: rgba(165, 97, 255, .4);--top-shadow-xs: 0px 0px 3px rgba(0, 0, 0, .11), 0px 5px 25px rgba(0, 0, 0, .08);--top-shadow-s: 0px 0px 3px rgba(0, 0, 0, .11), 0px 5px 25px rgba(0, 0, 0, .17);--top-shadow: 0px 0px 4px rgba(0, 0, 0, .14), 0px 4px 32px rgba(0, 0, 0, .2);--top-shadow-m: 0px 0px 4px 0px rgba(0, 0, 0, .14), 0px 4px 32px 0px rgba(0, 0, 0, .2);--top-shadow-b: 0px 0px 4px rgba(0, 0, 0, .15), 0px 18px 32px rgba(0, 0, 0, .34);--top-shadow-darken-1: inset 1000px 1000px 1000px 1000px rgba(0, 0, 0, .03);--top-shadow-darken-2: inset 1000px 1000px 1000px 1000px rgba(0, 0, 0, .12);--top-shadow-darken-3: inset 1000px 1000px 1000px 1000px rgba(0, 0, 0, .1);--color-bg-preloader: rgba(255, 255, 255, .01)}:root{--color-brand-1: var(--color-primary-700);--color-brand-2: var(--color-primary-740);--color-brand-3: var(--color-primary-800);--color-bg-shading-1: var(--color-theme-200);--color-bg-shading-2: var(--color-theme-175);--color-bg-shading-3: var(--color-theme-150);--color-bg-shading-4: var(--color-theme-125);--color-bg-shading-5: var(--color-theme-100);--color-bg-shading-6: var(--color-theme-50);--color-bg-lightning-1: var(--color-theme-260);--color-bg-primary-1: var(--color-primary-550);--color-bg-primary-2: var(--color-primary-650);--color-bg-primary-3: var(--color-primary-720);--color-bg-positive-1: var(--color-positive-450);--color-bg-positive-2: var(--color-positive-600);--color-bg-positive-3: var(--color-positive-740);--color-bg-warning-1: var(--color-warning-450);--color-bg-warning-2: var(--color-warning-600);--color-bg-warning-3: var(--color-warning-700);--color-bg-negative-1: var(--color-negative-550);--color-bg-negative-2: var(--color-negative-650);--color-bg-negative-3: var(--color-negative-720);--color-bg-info-1: var(--color-info-650);--color-bg-info-2: var(--color-info-720);--color-bg-info-3: var(--color-info-780);--top-panel-background-color: rgba(17, 23, 34, .8);--color-text-1: var(--color-theme-970);--color-text-2: var(--color-theme-750);--color-text-3: var(--color-theme-500);--color-text-4: var(--color-theme-450);--color-text-1-inverse: var(--color-theme-100);--color-text-white: var(--color-white);--color-text-primary: var(--color-primary-550);--color-text-primary-alt: var(--color-primary-650);--color-text-positive: var(--color-positive-450);--color-text-positive-alt: var(--color-positive-600);--color-text-warning: var(--color-warning-450);--color-text-warning-alt: var(--color-warning-650);--color-text-negative: var(--color-negative-550);--color-text-negative-alt: var(--color-negative-650);--color-text-info: var(--color-info-650);--color-text-info-alt: var(--color-info-740);--color-line-1: var(--color-theme-350);--color-line-2: var(--color-theme-400);--color-line-3: var(--color-theme-485);--color-line-4: var(--color-theme-650);--color-line-1-opacity: rgba(193, 203, 215, .1);--color-line-2-opacity: rgba(193, 203, 215, .15);--color-line-3-opacity: rgba(193, 203, 215, .27);--color-line-primary-1: var(--color-primary-450);--color-line-primary-2: var(--color-primary-600);--color-line-primary-3: var(--color-primary-740);--color-line-primary-1-opacity: rgba(122, 164, 255, .14);--color-line-primary-2-opacity: rgba(122, 164, 255, .28);--color-line-primary-3-opacity: rgba(122, 164, 255, .38);--color-line-positive-1: var(--color-positive-450);--color-line-positive-2: var(--color-positive-600);--color-line-positive-3: var(--color-positive-740);--color-line-positive-1-opacity: rgba(164, 233, 171, .14);--color-line-positive-2-opacity: rgba(164, 233, 171, .28);--color-line-positive-3-opacity: rgba(164, 233, 171, .38);--color-line-warning-1: var(--color-warning-450);--color-line-warning-2: var(--color-warning-600);--color-line-warning-3: var(--color-warning-700);--color-line-warning-1-opacity: rgba(255, 191, 128, .14);--color-line-warning-2-opacity: rgba(255, 191, 128, .28);--color-line-warning-3-opacity: rgba(255, 191, 128, .38);--color-line-negative-1: var(--color-negative-550);--color-line-negative-2: var(--color-negative-650);--color-line-negative-3: var(--color-negative-720);--color-line-negative-1-opacity: rgba(239, 135, 148, .14);--color-line-negative-2-opacity: rgba(239, 135, 148, .28);--color-line-negative-3-opacity: rgba(239, 135, 148, .38);--color-line-info-1: var(--color-info-650);--color-line-info-2: var(--color-info-720);--color-line-info-3: var(--color-info-780);--color-line-info-1-opacity: rgba(168, 120, 247, .14);--color-line-info-2-opacity: rgba(168, 120, 247, .28);--color-line-info-3-opacity: rgba(168, 120, 247, .38);--scroll-track-color: var(--color-theme-225);--scroll-thumb-color: var(--color-theme-300);--scroll-thumb-color-hover: var(--color-theme-450);--scroll-thumb-color-active: var(--color-theme-550);--body-background-color: var(--color-layout-front-1);--content-background-color: var(--color-layout-front-1);--top-forms-option-color: var(--color-primary-550);--top-forms-option-color-hover: var(--color-primary-650)}:root{--color-layout-back: var(--color-theme-100);--color-layout-header: var(--color-theme-225);--color-layout-middle: var(--color-theme-125);--color-layout-front-1: var(--color-theme-225);--color-layout-front-2: #222F43;--color-layout-front-3: #253348;--color-layout-front-4: #29374D;--color-layout-front-5: #2C3B52;--color-layout-front-6: #2C3B52;--color-layout-front-primary-1: #202C3F;--color-layout-front-primary-2: #232f41;--color-layout-front-primary-3: #243149;--color-layout-front-primary-4: #243450;--color-layout-front-primary-5: #253758;--color-layout-front-primary-6: #253960;--color-layout-front-positive-1: #202D3D;--color-layout-front-positive-2: #25333b;--color-layout-front-positive-3: #263a3d;--color-layout-front-positive-4: #284140;--color-layout-front-positive-5: #2a4842;--color-layout-front-positive-6: #2b4f44;--color-layout-front-warning-1: #222D3C;--color-layout-front-warning-2: #2b3038;--color-layout-front-warning-3: #343437;--color-layout-front-warning-4: #3c3836;--color-layout-front-warning-5: #453b35;--color-layout-front-warning-6: #4d3f35;--color-layout-front-negative-1: #222B3D;--color-layout-front-negative-2: #2b2c3a;--color-layout-front-negative-3: #342d3b;--color-layout-front-negative-4: #3c2d3c;--color-layout-front-negative-5: #452e3d;--color-layout-front-negative-6: #4d2e3e;--color-layout-front-info-1: #212B3F;--color-layout-front-info-2: #272c41;--color-layout-front-info-3: #2b2c49;--color-layout-front-info-4: #2f2c50;--color-layout-front-info-5: #332b58;--color-layout-front-info-6: #362b60}:root{--color-summary-top-3: #5BA8DC;--color-summary-top-10: #1AAD7B;--color-summary-top-30: #4BD2B8;--color-summary-top-50: #68CA63;--color-summary-top-100: #9DAAAA;--color-summary-top-10000: #CAA549;--color-table-top-1: #435E93;--color-table-top-2: #3F5788;--color-table-top-3: #3B5381;--color-table-top-4: #357550;--color-table-top-5: #336F4E;--color-table-top-6: #326B4D;--color-table-top-7: #31684C;--color-table-top-8: #30624A;--color-table-top-9: #2F5D48;--color-table-top-10: #2D5747;--color-table-move-up-10: #0E6A44;--color-table-move-up-9: #116542;--color-table-move-up-8: #145F40;--color-table-move-up-7: #165A3E;--color-table-move-up-6: #19543C;--color-table-move-up-5: #1B4F3A;--color-table-move-up-4: #1E4938;--color-table-move-up-3: #204335;--color-table-move-up-2: #233E33;--color-table-move-up-1: #263832;--color-table-move-0: #313135;--color-table-move-down-1: #46303F;--color-table-move-down-2: #4F3040;--color-table-move-down-3: #583142;--color-table-move-down-4: #633244;--color-table-move-down-5: #6C3345;--color-table-move-down-6: #723446;--color-table-move-down-7: #793547;--color-table-move-down-8: #823649;--color-table-move-down-9: #8A364A;--color-table-move-down-10: #93374C;--color-table-down: #46303F;--color-table-down-10: #4F3040;--color-table-up: #365344;--color-table-up-10: #2C5145;--color-table-base: var(--color-layout-front-1);--color-table-featured-snippet: #7D7B45;--color-table-empty: var(--color-layout-front-3);--color-table-not_found: #313638;--color-snapshot-panel-gradient-1: rgba(35, 44, 77, .5);--color-snapshot-panel-gradient-2: rgba(35, 44, 77, .8);--color-snippet-title: #A2C2FA;--color-snippet-title-visited: #BC8CF2;--color-snippet-url: #007700}
@@ -1 +1 @@
1
- :root{color-scheme:light;--color-theme-0: #FFFFFF;--color-theme-50: #F9FAFB;--color-theme-75: #F6F7F9;--color-theme-100: #F3F4F6;--color-theme-125: #EDEFF2;--color-theme-150: #E7EAEE;--color-theme-175: #E2E5E9;--color-theme-200: #DCE0E5;--color-theme-225: #D6DBE1;--color-theme-250: #D0D5DC;--color-theme-260: #CAD0D8;--color-theme-275: #C4CBD4;--color-theme-300: #BEC5CF;--color-theme-325: #B8C0CB;--color-theme-350: #B3BBC7;--color-theme-360: #ADB5C2;--color-theme-375: #A7B0BE;--color-theme-400: #A1ABBA;--color-theme-410: #9BA6B5;--color-theme-420: #95A0B1;--color-theme-430: #8F9BAD;--color-theme-440: #8A96A8;--color-theme-450: #8491A4;--color-theme-460: #7E8BA0;--color-theme-465: #78869C;--color-theme-470: #728197;--color-theme-475: #6C7B93;--color-theme-480: #68778D;--color-theme-485: #637287;--color-theme-500: #5F6D81;--color-theme-550: #5B687B;--color-theme-575: #576375;--color-theme-600: #525E70;--color-theme-625: #4E596A;--color-theme-650: #4A5564;--color-theme-675: #454F5E;--color-theme-700: #414A58;--color-theme-710: #3D4552;--color-theme-725: #38404C;--color-theme-750: #343B47;--color-theme-800: #303641;--color-theme-850: #2B323B;--color-theme-900: #272D35;--color-theme-925: #23282F;--color-theme-950: #1E2329;--color-theme-955: #1A1E23;--color-theme-960: #16191D;--color-theme-965: #111318;--color-theme-970: #0D0F12;--color-theme-1000: #000000;--color-white: rgba(255, 255, 255, 1);--color-black: rgba(0, 0, 0, 1);--color-primary-25: #F5F9FF;--color-primary-50: #EBF4FF;--color-primary-100: #D6E9FF;--color-primary-125: #CCE3FF;--color-primary-150: #C2DDFF;--color-primary-200: #B8D8FF;--color-primary-225: #A3CDFF;--color-primary-250: #8FC1FF;--color-primary-275: #7AB6FF;--color-primary-300: #66ABFF;--color-primary-350: #52A0FF;--color-primary-400: #3D94FF;--color-primary-450: #2D8AFB;--color-primary-500: #1E7FF6;--color-primary-550: #0F74F0;--color-primary-600: #136BD8;--color-primary-650: #1563C1;--color-primary-700: #175AAB;--color-primary-720: #185095;--color-primary-740: #184781;--color-primary-760: #183E6D;--color-primary-780: #16355A;--color-primary-800: #142B48;--color-primary-825: #18293E;--color-primary-850: #1C2736;--color-primary-900: #1C2736;--color-primary-950: #1F252E;--color-positive-25: #F6FDF8;--color-positive-50: #EEFCF1;--color-positive-100: #E5FAEA;--color-positive-125: #D8F8E0;--color-positive-150: #C2F4CF;--color-positive-200: #B1F1C1;--color-positive-225: #A0EEB3;--color-positive-250: #8EEBA5;--color-positive-275: #7DE898;--color-positive-300: #6CE58A;--color-positive-350: #5AE27C;--color-positive-400: #4DDB73;--color-positive-450: #41D265;--color-positive-500: #36C95B;--color-positive-550: #36B556;--color-positive-600: #36A150;--color-positive-650: #348D4B;--color-positive-700: #327B44;--color-positive-720: #2F6A3E;--color-positive-740: #2C5934;--color-positive-760: #27492B;--color-positive-780: #223A23;--color-positive-800: #1C2C1C;--color-positive-825: #161E15;--color-positive-850: #141A14;--color-positive-900: #131612;--color-positive-950: #111311;--color-warning-25: #FFFDFA;--color-warning-50: #FFF7F0;--color-warning-100: #FFF3E6;--color-warning-125: #FFEDDB;--color-warning-150: #FFE8CF;--color-warning-200: #FFE3C7;--color-warning-225: #FFDEBF;--color-warning-250: #FFD7A8;--color-warning-275: #FFCB94;--color-warning-300: #FFBF80;--color-warning-350: #FFB56B;--color-warning-400: #FFAB57;--color-warning-450: #FFA042;--color-warning-500: #FB9632;--color-warning-550: #F48B1B;--color-warning-600: #F08214;--color-warning-650: #DD780C;--color-warning-700: #C56D1C;--color-warning-720: #AF6420;--color-warning-740: #9A511A;--color-warning-760: #7F3D19;--color-warning-780: #71321E;--color-warning-800: #5E2517;--color-warning-825: #4C2015;--color-warning-850: #421B1A;--color-warning-900: #391F1E;--color-warning-950: #312121;--color-negative-25: #FFFAFA;--color-negative-50: #FFF1F0;--color-negative-100: #FFE6E5;--color-negative-125: #FFDCDB;--color-negative-150: #FFD3D1;--color-negative-200: #FFC9C7;--color-negative-225: #FFBFBD;--color-negative-250: #FFABA8;--color-negative-275: #FF9894;--color-negative-300: #FF8480;--color-negative-350: #FF706B;--color-negative-400: #FF5D57;--color-negative-450: #FF4842;--color-negative-500: #F73C36;--color-negative-550: #F12E27;--color-negative-600: #EB2019;--color-negative-650: #D81E18;--color-negative-700: #C1201A;--color-negative-720: #AB211C;--color-negative-740: #96211D;--color-negative-760: #821F1C;--color-negative-780: #6E1F1C;--color-negative-800: #5B1C1A;--color-negative-825: #4A1917;--color-negative-850: #401D1C;--color-negative-900: #37201F;--color-negative-950: #2F2222;--color-info-25: #FCFAFF;--color-info-50: #F9F5FF;--color-info-100: #F6F0FF;--color-info-125: #F1E5FF;--color-info-150: #EBDBFF;--color-info-200: #E5D1FF;--color-info-225: #DFC7FF;--color-info-250: #D9BDFF;--color-info-275: #D4B2FF;--color-info-300: #C89EFF;--color-info-350: #BC8AFF;--color-info-400: #B175FF;--color-info-450: #A561FF;--color-info-500: #9A4DFF;--color-info-550: #8F38FF;--color-info-600: #8428FB;--color-info-650: #7919F5;--color-info-700: #6F0FEB;--color-info-720: #6612D3;--color-info-740: #5E15BC;--color-info-760: #5517A6;--color-info-780: #441891;--color-info-800: #36187C;--color-info-825: #2A1769;--color-info-850: #201556;--color-info-900: #181344;--color-info-950: #1E1D2B;--color-layer-1: rgba(97, 121, 158, .1);--color-layer-2: rgba(97, 121, 158, .14);--color-layer-3: rgba(97, 121, 158, .18);--color-layer-4: rgba(97, 121, 158, .24);--color-layer-primary-1: rgba(45, 110, 251, .08);--color-layer-primary-2: rgba(45, 110, 251, .12);--color-layer-primary-3: rgba(45, 110, 251, .18);--color-layer-primary-4: rgba(45, 110, 251, .24);--color-layer-positive-1: rgba(54, 181, 86, .08);--color-layer-positive-2: rgba(54, 181, 86, .12);--color-layer-positive-3: rgba(54, 181, 86, .18);--color-layer-positive-4: rgba(54, 181, 86, .24);--color-layer-warning-1: rgba(240, 130, 20, .08);--color-layer-warning-2: rgba(240, 130, 20, .12);--color-layer-warning-3: rgba(240, 130, 20, .18);--color-layer-warning-4: rgba(240, 130, 20, .24);--color-layer-negative-1: rgba(241, 46, 39, .08);--color-layer-negative-2: rgba(241, 46, 39, .12);--color-layer-negative-3: rgba(241, 46, 39, .18);--color-layer-negative-4: rgba(241, 46, 39, .24);--color-layer-info-1: rgba(165, 97, 255, .08);--color-layer-info-2: rgba(165, 97, 255, .12);--color-layer-info-3: rgba(165, 97, 255, .18);--color-layer-info-4: rgba(165, 97, 255, .24);--top-shadow-xs: 0px 0px 3px rgba(112, 144, 176, .07), 0px 5px 25px rgba(112, 144, 176, .06);--top-shadow-s: 0px 0px 3px rgba(112, 144, 176, .07), 0px 5px 25px rgba(112, 144, 176, .12);--top-shadow: 0px 0px 4px rgba(4, 9, 84, .08), 0px 4px 32px rgba(4, 9, 84, .1);--top-shadow-m: 0px 0px 4px 0px rgba(4, 9, 84, .08), 0px 4px 32px 0px rgba(4, 9, 84, .1);--top-shadow-b: 0px 0px 4px rgba(4, 36, 84, .08), 0px 18px 32px rgba(4, 25, 84, .18);--top-shadow-darken-1: inset 1000px 1000px 1000px 1000px rgba(0, 0, 0, .03);--top-shadow-darken-2: inset 1000px 1000px 1000px 1000px rgba(0, 0, 0, .09);--top-shadow-darken-3: inset 1000px 1000px 1000px 1000px rgba(0, 0, 0, .18);--color-bg-preloader: rgba(255, 255, 255, .01)}:root{--color-brand-1: var(--color-primary-500);--color-brand-2: var(--color-primary-600);--color-brand-3: var(--color-primary-720);--color-bg-shading-1: var(--color-theme-50);--color-bg-shading-2: var(--color-theme-100);--color-bg-shading-3: var(--color-theme-125);--color-bg-shading-4: var(--color-theme-150);--color-bg-shading-5: var(--color-theme-175);--color-bg-shading-6: var(--color-theme-200);--color-bg-lightning-1: var(--color-theme-0);--color-bg-inverted-1: var(--color-theme-950);--color-bg-inverted-2: var(--color-theme-900);--color-bg-inverted-3: var(--color-theme-800);--color-bg-inverted-4: var(--color-theme-750);--color-bg-inverted-5: var(--color-theme-725);--color-bg-inverted-6: var(--color-theme-700);--color-bg-inverted-7: var(--color-theme-675);--color-bg-inverted-8: var(--color-theme-650);--color-bg-inverted-9: var(--color-theme-625);--color-bg-inverted-10: var(--color-theme-600);--color-bg-primary-1: var(--color-primary-500);--color-bg-primary-2: var(--color-primary-600);--color-bg-primary-3: var(--color-primary-720);--color-bg-positive-1: var(--color-positive-500);--color-bg-positive-2: var(--color-positive-700);--color-bg-positive-3: var(--color-positive-760);--color-bg-warning-1: var(--color-warning-500);--color-bg-warning-2: var(--color-warning-600);--color-bg-warning-3: var(--color-warning-720);--color-bg-negative-1: var(--color-negative-500);--color-bg-negative-2: var(--color-negative-650);--color-bg-negative-3: var(--color-negative-720);--color-bg-info-1: var(--color-info-500);--color-bg-info-2: var(--color-info-650);--color-bg-info-3: var(--color-info-720);--top-panel-background-color: rgba(255, 255, 255, .8);--color-text-1: var(--color-theme-850);--color-text-2: var(--color-theme-600);--color-text-3: var(--color-theme-450);--color-text-4: var(--color-theme-300);--color-text-1-inverse: var(--color-theme-0);--color-text-white: var(--color-white);--color-text-primary: var(--color-primary-550);--color-text-primary-alt: var(--color-primary-700);--color-text-positive: var(--color-positive-550);--color-text-positive-alt: var(--color-positive-700);--color-text-warning: var(--color-warning-550);--color-text-warning-alt: var(--color-warning-700);--color-text-negative: var(--color-negative-550);--color-text-negative-alt: var(--color-negative-700);--color-text-info: var(--color-info-550);--color-text-info-alt: var(--color-info-700);--color-line-1: var(--color-theme-200);--color-line-2: var(--color-theme-250);--color-line-3: var(--color-theme-375);--color-line-4: var(--color-theme-470);--color-line-1-opacity: rgba(14, 65, 142, .1);--color-line-2-opacity: rgba(14, 65, 142, .19);--color-line-3-opacity: rgba(14, 65, 142, .39);--color-line-primary-1: var(--color-primary-500);--color-line-primary-2: var(--color-primary-650);--color-line-primary-3: var(--color-primary-720);--color-line-primary-1-opacity: rgba(15, 86, 240, .14);--color-line-primary-2-opacity: rgba(15, 86, 240, .28);--color-line-primary-3-opacity: rgba(15, 86, 240, .38);--color-line-positive-1: var(--color-positive-550);--color-line-positive-2: var(--color-positive-600);--color-line-positive-3: var(--color-positive-720);--color-line-positive-1-opacity: rgba(54, 161, 80, .14);--color-line-positive-2-opacity: rgba(54, 161, 80, .28);--color-line-positive-3-opacity: rgba(54, 161, 80, .38);--color-line-warning-1: var(--color-warning-600);--color-line-warning-2: var(--color-warning-700);--color-line-warning-3: var(--color-warning-740);--color-line-warning-1-opacity: rgba(251, 150, 50, .14);--color-line-warning-2-opacity: rgba(251, 150, 50, .28);--color-line-warning-3-opacity: rgba(251, 150, 50, .38);--color-line-negative-1: var(--color-negative-550);--color-line-negative-2: var(--color-negative-700);--color-line-negative-3: var(--color-negative-740);--color-line-negative-1-opacity: rgba(247, 60, 54, .14);--color-line-negative-2-opacity: rgba(247, 60, 54, .28);--color-line-negative-3-opacity: rgba(247, 60, 54, .38);--color-line-info-1: var(--color-info-500);--color-line-info-2: var(--color-info-550);--color-line-info-3: var(--color-info-600);--color-line-info-1-opacity: rgba(122, 47, 242, .14);--color-line-info-2-opacity: rgba(122, 47, 242, .28);--color-line-info-3-opacity: rgba(122, 47, 242, .38);--scroll-track-color: var(--color-theme-225);--scroll-thumb-color: var(--color-theme-300);--scroll-thumb-color-hover: var(--color-theme-450);--scroll-thumb-color-active: var(--color-theme-550);--body-background-color: var(--color-layout-front-1);--content-background-color: var(--color-layout-front-1);--top-forms-option-color: var(--color-primary-500);--top-forms-option-color-hover: var(--color-primary-600)}:root{--color-layout-back: var(--color-theme-200);--color-layout-header: var(--color-theme-0);--color-layout-middle: var(--color-theme-125);--color-layout-front-1: var(--color-theme-0);--color-layout-front-2: #FCFCFD;--color-layout-front-3: #F6F6F8;--color-layout-front-4: #EBEDF1;--color-layout-front-5: #E2E5EA;--color-layout-front-6: #D8DCE2;--color-layout-front-primary-1: #FFFFFF;--color-layout-front-primary-2: #F7F9FF;--color-layout-front-primary-3: #EEF3FF;--color-layout-front-primary-4: #E6EEFF;--color-layout-front-primary-5: #DDE8FE;--color-layout-front-primary-6: #D5E2FE;--color-layout-front-positive-1: #FFFFFF;--color-layout-front-positive-2: #F8FEF9;--color-layout-front-positive-3: #F1FCF4;--color-layout-front-positive-4: #EAFBEF;--color-layout-front-positive-5: #E3F9E8;--color-layout-front-positive-6: #DBF8E3;--color-layout-front-warning-1: #FFFFFF;--color-layout-front-warning-2: #FFFBF7;--color-layout-front-warning-3: #FFF7F0;--color-layout-front-warning-4: #FFF4E8;--color-layout-front-warning-5: #FFF0E1;--color-layout-front-warning-6: #FFECDA;--color-layout-front-negative-1: #FFFFFF;--color-layout-front-negative-2: #FFF7F8;--color-layout-front-negative-3: #FEF0F1;--color-layout-front-negative-4: #FEE7E9;--color-layout-front-negative-5: #FEDFE3;--color-layout-front-negative-6: #FDD7DC;--color-layout-front-info-1: #FFFFFF;--color-layout-front-info-2: #FAF6FF;--color-layout-front-info-3: #F5EEFF;--color-layout-front-info-4: #F0E5FF;--color-layout-front-info-5: #EBDBFE;--color-layout-front-info-6: #E6D4FE}:root{--color-summary-top-3: #3198DD;--color-summary-top-10: #21936C;--color-summary-top-30: #1ABC9C;--color-summary-top-50: #94DA90;--color-summary-top-100: #BCC8C8;--color-summary-top-10000: #FCC53B;--color-table-top-1: #B3D2FF;--color-table-top-2: #CCE0FF;--color-table-top-3: #CCE0FF;--color-table-top-4: #8AF3B7;--color-table-top-5: #98F5C1;--color-table-top-6: #A2F7C8;--color-table-top-7: #ACF9CE;--color-table-top-8: #B6FBD5;--color-table-top-9: #BFFDDB;--color-table-top-10: #CCFFE4;--color-table-move-up-10: #8AF3B7;--color-table-move-up-9: #8AF3B7;--color-table-move-up-8: #A2F7C8;--color-table-move-up-7: #A2F7C8;--color-table-move-up-6: #B6FBD5;--color-table-move-up-5: #B6FBD5;--color-table-move-up-4: #BFFDDB;--color-table-move-up-3: #BFFDDB;--color-table-move-up-2: #CCFFE4;--color-table-move-up-1: #CCFFE4;--color-table-move-0: #FCFEFD;--color-table-move-down-1: #FFF1F0;--color-table-move-down-2: #FFF1F0;--color-table-move-down-3: #FFF1F0;--color-table-move-down-4: #FFF1F0;--color-table-move-down-5: #FFE7E6;--color-table-move-down-6: #FFE7E6;--color-table-move-down-7: #FFE7E6;--color-table-move-down-8: #FFD5D4;--color-table-move-down-9: #FFD5D4;--color-table-move-down-10: #FFD5D4;--color-table-down: #FFF1F0;--color-table-up: #CCFFE4;--color-table-down-10: #FFE7E6;--color-table-up-10: #BFFDDB;--color-table-base: var(--color-layout-front-1);--color-table-featured-snippet: #F6F2A0;--color-table-empty: var(--color-layout-front-3);--color-table-not_found: #FFF6C6;--color-snapshot-panel-gradient-1: rgba(255, 255, 255, .5);--color-snapshot-panel-gradient-2: rgba(255, 255, 255, .8);--color-snippet-title: #1A0DAB;--color-snippet-title-visited: #660099;--color-snippet-url: #007700}
1
+ :root{color-scheme:light;--color-theme-0: #FFFFFF;--color-theme-50: #F9FAFB;--color-theme-75: #F6F7F9;--color-theme-100: #F3F4F6;--color-theme-125: #EDEFF2;--color-theme-150: #E7EAEE;--color-theme-175: #E2E5E9;--color-theme-200: #DCE0E5;--color-theme-225: #D6DBE1;--color-theme-250: #D0D5DC;--color-theme-260: #CAD0D8;--color-theme-275: #C4CBD4;--color-theme-300: #BEC5CF;--color-theme-325: #B8C0CB;--color-theme-350: #B3BBC7;--color-theme-360: #ADB5C2;--color-theme-375: #A7B0BE;--color-theme-400: #A1ABBA;--color-theme-410: #9BA6B5;--color-theme-420: #95A0B1;--color-theme-430: #8F9BAD;--color-theme-440: #8A96A8;--color-theme-450: #8491A4;--color-theme-460: #7E8BA0;--color-theme-465: #78869C;--color-theme-470: #728197;--color-theme-475: #6C7B93;--color-theme-480: #68778D;--color-theme-485: #637287;--color-theme-500: #5F6D81;--color-theme-550: #5B687B;--color-theme-575: #576375;--color-theme-600: #525E70;--color-theme-625: #4E596A;--color-theme-650: #4A5564;--color-theme-675: #454F5E;--color-theme-700: #414A58;--color-theme-710: #3D4552;--color-theme-725: #38404C;--color-theme-750: #343B47;--color-theme-800: #303641;--color-theme-850: #2B323B;--color-theme-900: #272D35;--color-theme-925: #23282F;--color-theme-950: #1E2329;--color-theme-955: #1A1E23;--color-theme-960: #16191D;--color-theme-965: #111318;--color-theme-970: #0D0F12;--color-theme-1000: #000000;--color-white: rgba(255, 255, 255, 1);--color-black: rgba(0, 0, 0, 1);--color-primary-25: #F5F9FF;--color-primary-50: #EBF4FF;--color-primary-100: #D6E9FF;--color-primary-125: #CCE3FF;--color-primary-150: #C2DDFF;--color-primary-200: #B8D8FF;--color-primary-225: #A3CDFF;--color-primary-250: #8FC1FF;--color-primary-275: #7AB6FF;--color-primary-300: #66ABFF;--color-primary-350: #52A0FF;--color-primary-400: #3D94FF;--color-primary-450: #2D8AFB;--color-primary-500: #1E7FF6;--color-primary-550: #0F74F0;--color-primary-600: #136BD8;--color-primary-650: #1563C1;--color-primary-700: #175AAB;--color-primary-720: #185095;--color-primary-740: #184781;--color-primary-760: #183E6D;--color-primary-780: #16355A;--color-primary-800: #142B48;--color-primary-825: #18293E;--color-primary-850: #1C2736;--color-primary-900: #1C2736;--color-primary-950: #1F252E;--color-positive-25: #F6FDF8;--color-positive-50: #EEFCF1;--color-positive-100: #E5FAEA;--color-positive-125: #D8F8E0;--color-positive-150: #C2F4CF;--color-positive-200: #B1F1C1;--color-positive-225: #A0EEB3;--color-positive-250: #8EEBA5;--color-positive-275: #7DE898;--color-positive-300: #6CE58A;--color-positive-350: #5AE27C;--color-positive-400: #4DDB73;--color-positive-450: #41D265;--color-positive-500: #36C95B;--color-positive-550: #36B556;--color-positive-600: #36A150;--color-positive-650: #348D4B;--color-positive-700: #327B44;--color-positive-720: #2F6A3E;--color-positive-740: #2C5934;--color-positive-760: #27492B;--color-positive-780: #223A23;--color-positive-800: #1C2C1C;--color-positive-825: #161E15;--color-positive-850: #141A14;--color-positive-900: #131612;--color-positive-950: #111311;--color-warning-25: #FFFDFA;--color-warning-50: #FFF7F0;--color-warning-100: #FFF3E6;--color-warning-125: #FFEDDB;--color-warning-150: #FFE8CF;--color-warning-200: #FFE3C7;--color-warning-225: #FFDEBF;--color-warning-250: #FFD7A8;--color-warning-275: #FFCB94;--color-warning-300: #FFBF80;--color-warning-350: #FFB56B;--color-warning-400: #FFAB57;--color-warning-450: #FFA042;--color-warning-500: #FB9632;--color-warning-550: #F48B1B;--color-warning-600: #F08214;--color-warning-650: #DD780C;--color-warning-700: #C56D1C;--color-warning-720: #AF6420;--color-warning-740: #9A511A;--color-warning-760: #7F3D19;--color-warning-780: #71321E;--color-warning-800: #5E2517;--color-warning-825: #4C2015;--color-warning-850: #421B1A;--color-warning-900: #391F1E;--color-warning-950: #312121;--color-negative-25: #FFFAFA;--color-negative-50: #FFF1F0;--color-negative-100: #FFE6E5;--color-negative-125: #FFDCDB;--color-negative-150: #FFD3D1;--color-negative-200: #FFC9C7;--color-negative-225: #FFBFBD;--color-negative-250: #FFABA8;--color-negative-275: #FF9894;--color-negative-300: #FF8480;--color-negative-350: #FF706B;--color-negative-400: #FF5D57;--color-negative-450: #FF4842;--color-negative-500: #F73C36;--color-negative-550: #F12E27;--color-negative-600: #EB2019;--color-negative-650: #D81E18;--color-negative-700: #C1201A;--color-negative-720: #AB211C;--color-negative-740: #96211D;--color-negative-760: #821F1C;--color-negative-780: #6E1F1C;--color-negative-800: #5B1C1A;--color-negative-825: #4A1917;--color-negative-850: #401D1C;--color-negative-900: #37201F;--color-negative-950: #2F2222;--color-info-25: #FCFAFF;--color-info-50: #F9F5FF;--color-info-100: #F6F0FF;--color-info-125: #F1E5FF;--color-info-150: #EBDBFF;--color-info-200: #E5D1FF;--color-info-225: #DFC7FF;--color-info-250: #D9BDFF;--color-info-275: #D4B2FF;--color-info-300: #C89EFF;--color-info-350: #BC8AFF;--color-info-400: #B175FF;--color-info-450: #A561FF;--color-info-500: #9A4DFF;--color-info-550: #8F38FF;--color-info-600: #8428FB;--color-info-650: #7919F5;--color-info-700: #6F0FEB;--color-info-720: #6612D3;--color-info-740: #5E15BC;--color-info-760: #5517A6;--color-info-780: #441891;--color-info-800: #36187C;--color-info-825: #2A1769;--color-info-850: #201556;--color-info-900: #181344;--color-info-950: #1E1D2B;--color-layer-1: rgba(97, 121, 158, .1);--color-layer-2: rgba(97, 121, 158, .14);--color-layer-3: rgba(97, 121, 158, .18);--color-layer-4: rgba(97, 121, 158, .24);--color-layer-primary-1: rgba(45, 110, 251, .08);--color-layer-primary-2: rgba(45, 110, 251, .12);--color-layer-primary-3: rgba(45, 110, 251, .18);--color-layer-primary-4: rgba(45, 110, 251, .24);--color-layer-positive-1: rgba(54, 181, 86, .08);--color-layer-positive-2: rgba(54, 181, 86, .12);--color-layer-positive-3: rgba(54, 181, 86, .18);--color-layer-positive-4: rgba(54, 181, 86, .24);--color-layer-warning-1: rgba(240, 130, 20, .08);--color-layer-warning-2: rgba(240, 130, 20, .12);--color-layer-warning-3: rgba(240, 130, 20, .18);--color-layer-warning-4: rgba(240, 130, 20, .24);--color-layer-negative-1: rgba(241, 46, 39, .08);--color-layer-negative-2: rgba(241, 46, 39, .12);--color-layer-negative-3: rgba(241, 46, 39, .18);--color-layer-negative-4: rgba(241, 46, 39, .24);--color-layer-info-1: rgba(165, 97, 255, .08);--color-layer-info-2: rgba(165, 97, 255, .12);--color-layer-info-3: rgba(165, 97, 255, .18);--color-layer-info-4: rgba(165, 97, 255, .24);--top-shadow-xs: 0px 0px 3px rgba(112, 144, 176, .07), 0px 5px 25px rgba(112, 144, 176, .06);--top-shadow-s: 0px 0px 3px rgba(112, 144, 176, .07), 0px 5px 25px rgba(112, 144, 176, .12);--top-shadow: 0px 0px 4px rgba(4, 9, 84, .08), 0px 4px 32px rgba(4, 9, 84, .1);--top-shadow-m: 0px 0px 4px 0px rgba(4, 9, 84, .08), 0px 4px 32px 0px rgba(4, 9, 84, .1);--top-shadow-b: 0px 0px 4px rgba(4, 36, 84, .08), 0px 18px 32px rgba(4, 25, 84, .18);--top-shadow-darken-1: inset 1000px 1000px 1000px 1000px rgba(0, 0, 0, .03);--top-shadow-darken-2: inset 1000px 1000px 1000px 1000px rgba(0, 0, 0, .09);--top-shadow-darken-3: inset 1000px 1000px 1000px 1000px rgba(0, 0, 0, .18);--color-bg-preloader: rgba(255, 255, 255, .01)}:root{--color-brand-1: var(--color-primary-500);--color-brand-2: var(--color-primary-600);--color-brand-3: var(--color-primary-720);--color-bg-shading-1: var(--color-theme-50);--color-bg-shading-2: var(--color-theme-100);--color-bg-shading-3: var(--color-theme-125);--color-bg-shading-4: var(--color-theme-150);--color-bg-shading-5: var(--color-theme-175);--color-bg-shading-6: var(--color-theme-200);--color-bg-lightning-1: var(--color-theme-0);--color-bg-primary-1: var(--color-primary-500);--color-bg-primary-2: var(--color-primary-600);--color-bg-primary-3: var(--color-primary-720);--color-bg-positive-1: var(--color-positive-500);--color-bg-positive-2: var(--color-positive-700);--color-bg-positive-3: var(--color-positive-760);--color-bg-warning-1: var(--color-warning-500);--color-bg-warning-2: var(--color-warning-600);--color-bg-warning-3: var(--color-warning-720);--color-bg-negative-1: var(--color-negative-500);--color-bg-negative-2: var(--color-negative-650);--color-bg-negative-3: var(--color-negative-720);--color-bg-info-1: var(--color-info-500);--color-bg-info-2: var(--color-info-650);--color-bg-info-3: var(--color-info-720);--top-panel-background-color: rgba(255, 255, 255, .8);--color-text-1: var(--color-theme-850);--color-text-2: var(--color-theme-600);--color-text-3: var(--color-theme-450);--color-text-4: var(--color-theme-300);--color-text-1-inverse: var(--color-theme-0);--color-text-white: var(--color-white);--color-text-primary: var(--color-primary-550);--color-text-primary-alt: var(--color-primary-700);--color-text-positive: var(--color-positive-550);--color-text-positive-alt: var(--color-positive-700);--color-text-warning: var(--color-warning-550);--color-text-warning-alt: var(--color-warning-700);--color-text-negative: var(--color-negative-550);--color-text-negative-alt: var(--color-negative-700);--color-text-info: var(--color-info-550);--color-text-info-alt: var(--color-info-700);--color-line-1: var(--color-theme-200);--color-line-2: var(--color-theme-250);--color-line-3: var(--color-theme-375);--color-line-4: var(--color-theme-470);--color-line-1-opacity: rgba(14, 65, 142, .1);--color-line-2-opacity: rgba(14, 65, 142, .19);--color-line-3-opacity: rgba(14, 65, 142, .39);--color-line-primary-1: var(--color-primary-500);--color-line-primary-2: var(--color-primary-650);--color-line-primary-3: var(--color-primary-720);--color-line-primary-1-opacity: rgba(15, 86, 240, .14);--color-line-primary-2-opacity: rgba(15, 86, 240, .28);--color-line-primary-3-opacity: rgba(15, 86, 240, .38);--color-line-positive-1: var(--color-positive-550);--color-line-positive-2: var(--color-positive-600);--color-line-positive-3: var(--color-positive-720);--color-line-positive-1-opacity: rgba(54, 161, 80, .14);--color-line-positive-2-opacity: rgba(54, 161, 80, .28);--color-line-positive-3-opacity: rgba(54, 161, 80, .38);--color-line-warning-1: var(--color-warning-600);--color-line-warning-2: var(--color-warning-700);--color-line-warning-3: var(--color-warning-740);--color-line-warning-1-opacity: rgba(251, 150, 50, .14);--color-line-warning-2-opacity: rgba(251, 150, 50, .28);--color-line-warning-3-opacity: rgba(251, 150, 50, .38);--color-line-negative-1: var(--color-negative-550);--color-line-negative-2: var(--color-negative-700);--color-line-negative-3: var(--color-negative-740);--color-line-negative-1-opacity: rgba(247, 60, 54, .14);--color-line-negative-2-opacity: rgba(247, 60, 54, .28);--color-line-negative-3-opacity: rgba(247, 60, 54, .38);--color-line-info-1: var(--color-info-500);--color-line-info-2: var(--color-info-550);--color-line-info-3: var(--color-info-600);--color-line-info-1-opacity: rgba(122, 47, 242, .14);--color-line-info-2-opacity: rgba(122, 47, 242, .28);--color-line-info-3-opacity: rgba(122, 47, 242, .38);--scroll-track-color: var(--color-theme-225);--scroll-thumb-color: var(--color-theme-300);--scroll-thumb-color-hover: var(--color-theme-450);--scroll-thumb-color-active: var(--color-theme-550);--body-background-color: var(--color-layout-front-1);--content-background-color: var(--color-layout-front-1);--top-forms-option-color: var(--color-primary-500);--top-forms-option-color-hover: var(--color-primary-600)}:root{--color-layout-back: var(--color-theme-200);--color-layout-header: var(--color-theme-0);--color-layout-middle: var(--color-theme-125);--color-layout-front-1: var(--color-theme-0);--color-layout-front-2: #FCFCFD;--color-layout-front-3: #F6F6F8;--color-layout-front-4: #EBEDF1;--color-layout-front-5: #E2E5EA;--color-layout-front-6: #D8DCE2;--color-layout-front-primary-1: #FFFFFF;--color-layout-front-primary-2: #F7F9FF;--color-layout-front-primary-3: #EEF3FF;--color-layout-front-primary-4: #E6EEFF;--color-layout-front-primary-5: #DDE8FE;--color-layout-front-primary-6: #D5E2FE;--color-layout-front-positive-1: #FFFFFF;--color-layout-front-positive-2: #F8FEF9;--color-layout-front-positive-3: #F1FCF4;--color-layout-front-positive-4: #EAFBEF;--color-layout-front-positive-5: #E3F9E8;--color-layout-front-positive-6: #DBF8E3;--color-layout-front-warning-1: #FFFFFF;--color-layout-front-warning-2: #FFFBF7;--color-layout-front-warning-3: #FFF7F0;--color-layout-front-warning-4: #FFF4E8;--color-layout-front-warning-5: #FFF0E1;--color-layout-front-warning-6: #FFECDA;--color-layout-front-negative-1: #FFFFFF;--color-layout-front-negative-2: #FFF7F8;--color-layout-front-negative-3: #FEF0F1;--color-layout-front-negative-4: #FEE7E9;--color-layout-front-negative-5: #FEDFE3;--color-layout-front-negative-6: #FDD7DC;--color-layout-front-info-1: #FFFFFF;--color-layout-front-info-2: #FAF6FF;--color-layout-front-info-3: #F5EEFF;--color-layout-front-info-4: #F0E5FF;--color-layout-front-info-5: #EBDBFE;--color-layout-front-info-6: #E6D4FE}:root{--color-summary-top-3: #3198DD;--color-summary-top-10: #21936C;--color-summary-top-30: #1ABC9C;--color-summary-top-50: #94DA90;--color-summary-top-100: #BCC8C8;--color-summary-top-10000: #FCC53B;--color-table-top-1: #B3D2FF;--color-table-top-2: #CCE0FF;--color-table-top-3: #CCE0FF;--color-table-top-4: #8AF3B7;--color-table-top-5: #98F5C1;--color-table-top-6: #A2F7C8;--color-table-top-7: #ACF9CE;--color-table-top-8: #B6FBD5;--color-table-top-9: #BFFDDB;--color-table-top-10: #CCFFE4;--color-table-move-up-10: #8AF3B7;--color-table-move-up-9: #8AF3B7;--color-table-move-up-8: #A2F7C8;--color-table-move-up-7: #A2F7C8;--color-table-move-up-6: #B6FBD5;--color-table-move-up-5: #B6FBD5;--color-table-move-up-4: #BFFDDB;--color-table-move-up-3: #BFFDDB;--color-table-move-up-2: #CCFFE4;--color-table-move-up-1: #CCFFE4;--color-table-move-0: #FCFEFD;--color-table-move-down-1: #FFF1F0;--color-table-move-down-2: #FFF1F0;--color-table-move-down-3: #FFF1F0;--color-table-move-down-4: #FFF1F0;--color-table-move-down-5: #FFE7E6;--color-table-move-down-6: #FFE7E6;--color-table-move-down-7: #FFE7E6;--color-table-move-down-8: #FFD5D4;--color-table-move-down-9: #FFD5D4;--color-table-move-down-10: #FFD5D4;--color-table-down: #FFF1F0;--color-table-up: #CCFFE4;--color-table-down-10: #FFE7E6;--color-table-up-10: #BFFDDB;--color-table-base: var(--color-layout-front-1);--color-table-featured-snippet: #F6F2A0;--color-table-empty: var(--color-layout-front-3);--color-table-not_found: #FFF6C6;--color-snapshot-panel-gradient-1: rgba(255, 255, 255, .5);--color-snapshot-panel-gradient-2: rgba(255, 255, 255, .8);--color-snippet-title: #1A0DAB;--color-snippet-title-visited: #660099;--color-snippet-url: #007700}
@@ -1,2 +1,2 @@
1
- define(["require","exports","vue","../.chunks/forms-L6BGV_om.amd","../utils/number.amd","../require/css.amd!../assets/charts.css"],function(L,C,e,M,g){"use strict";if(typeof e>"u")var e=window.Vue;const k=90,y=10,V=["data-top-icon"],B={class:"top-miniChart_chart"},b=["onMouseenter"],E={class:"top-miniChart_data"},_={class:"top-miniChart_dataValue"},w=["innerHTML"],D=e.defineComponent({__name:"miniChart",props:e.mergeModels({title:{},gIcon:{},color:{default:"blue"},dates:{},values:{},activeDates:{},keysForDyn:{},dynamic:{},isInvert:{type:Boolean},numberCols:{default:k},additionalHTML:{},modelValue:{},valueSuffix:{},hideChartInMobile:{type:Boolean}},{modelValue:{},modelModifiers:{}}),emits:["update:modelValue"],setup(m){const o=m,s=e.useModel(m,"modelValue"),i=t=>{let l=u.value;o.isInvert&&(t-=1,l-=1);let a=l>0?Math.round(t/l*(100-y)):0;return o.isInvert?100-a:a+y},p=t=>o.activeDates.includes(t),u=e.computed(()=>Math.max(...o.values)),c=e.computed(()=>o.dates.slice().reverse()),v=e.computed(()=>o.dates.length?o.numberCols-o.dates.length:0),h=()=>{s.value=null},r=(t,l,a)=>{t.target instanceof HTMLElement&&(s.value={elCol:t.target,date:M.dateFormat(l),value:a===null?"--":a+(o.valueSuffix??"")})},n=e.computed(()=>{let t=o.dynamic;if(typeof t>"u"){const a=o.values[o.keysForDyn.start];t=o.values[o.keysForDyn.end]-a}return(t<0?-1:1)*g.percentOfNumber(Math.abs(t))}),d=e.computed(()=>{let t="stay";return o.isInvert?(n.value>0&&(t="down"),n.value<0&&(t="up")):(n.value>0&&(t="up"),n.value<0&&(t="down")),t});return(t,l)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass({"top-miniChart":!0,"top-miniChart_hideChartInMobile":t.hideChartInMobile,[`top-color_${t.color}`]:!0})},[e.createElementVNode("div",{class:"top-miniChart_title top-ellipsis","data-top-icon":t.gIcon},e.toDisplayString(t.title),9,V),e.createElementVNode("div",B,[e.createElementVNode("div",{class:"top-miniChart_chartGrid",onMouseleave:l[1]||(l[1]=a=>h())},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(c.value,(a,f)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass({"top-miniChart_chartGridCol":!0,"top-active":p(a)}),onMouseenter:z=>r(z,a,t.values[t.values.length-f-1])},[e.createElementVNode("div",{style:e.normalizeStyle("height:"+i(t.values[t.values.length-f-1])+"%")},null,4)],42,b))),256)),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(v.value,()=>(e.openBlock(),e.createElementBlock("div",{class:"top-miniChart_chartGridCol top-miniChart_chartGridCol-none",onMouseenter:l[0]||(l[0]=a=>h())},l[2]||(l[2]=[e.createElementVNode("div",null,null,-1)]),32))),256))],32)]),e.createElementVNode("div",E,[e.createElementVNode("span",{class:e.normalizeClass({"top-miniChart_dataDynamic":!0,[`top-miniChart_dataDynamic-direction_${d.value}`]:!0})},e.toDisplayString(Math.abs(n.value)||""),3),e.createElementVNode("span",_,e.toDisplayString(e.unref(g.percentOfNumber)(t.values[t.values.length-1])||0),1)]),t.additionalHTML?(e.openBlock(),e.createElementBlock("div",{key:0,innerHTML:t.additionalHTML},null,8,w)):e.createCommentVNode("",!0)],2))}}),N={key:0,class:"top-miniCharts_pages"},S=["onClick"],T=e.defineComponent({__name:"miniCharts",props:e.mergeModels({modelValue:{},countCharts:{},hideChartInMobile:{type:Boolean}},{modelValue:{},modelModifiers:{}}),emits:["update:modelValue"],setup(m){const o=m,s=e.useModel(m,"modelValue"),i=e.ref(null);let p;const u=e.ref(1),c=e.ref(1),v=()=>{u.value=Math.round(i.value.scrollHeight/i.value.clientHeight)};e.watch(u,()=>{u.value<c.value&&(c.value=1)}),e.watch(()=>o.countCharts,()=>v(),{flush:"post"});const h=e.computed(()=>{if(!s.value)return{};const r=s.value.elCol.getBoundingClientRect(),n={top:r.bottom+window.scrollY+"px"};return document.documentElement.clientWidth/2>r.right?n.left=r.right+window.scrollX+10+"px":(n.left=r.left+window.scrollX-10+"px",n.transform="translate(-100%, 0)"),n});return e.onMounted(()=>{p=new ResizeObserver(()=>v()),p.observe(i.value),e.watch(c,()=>{const d=(i.value.children[0].clientHeight+parseInt(window.getComputedStyle(i.value).getPropertyValue("row-gap")))*(c.value-1);i.value.scrollTo({top:d,behavior:"smooth"})})}),e.onUnmounted(()=>{p.disconnect()}),(r,n)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(["top-miniCharts",{"top-miniCharts":!0,scrollable:u.value>1,"top-miniCharts_hideChartInMobile":r.hideChartInMobile}]),ref_key:"elRef",ref:i},[e.renderSlot(r.$slots,"default"),u.value>1?(e.openBlock(),e.createElementBlock("div",N,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(u.value,d=>(e.openBlock(),e.createElementBlock("span",{class:e.normalizeClass({"top-active":d===c.value}),onClick:t=>c.value=d},null,10,S))),256))])):e.createCommentVNode("",!0),(e.openBlock(),e.createBlock(e.Teleport,{to:"body"},[s.value?(e.openBlock(),e.createElementBlock("div",{key:0,class:"top-miniCharts_tooltip",style:e.normalizeStyle(h.value)},[e.createElementVNode("span",null,e.toDisplayString(s.value.date),1),e.createElementVNode("span",null,e.toDisplayString(s.value.value),1)],4)):e.createCommentVNode("",!0)]))],2))}}),H=D,I=T;C.TopMiniChart=H,C.TopMiniCharts=I,Object.defineProperty(C,Symbol.toStringTag,{value:"Module"})});
1
+ define(["require","exports","vue","../.chunks/forms-DRhpgERJ.amd","../utils/number.amd","../require/css.amd!../assets/charts.css"],(function(L,C,e,M,g){"use strict";if(typeof e>"u")var e=window.Vue;const k=90,y=10,V=["data-top-icon"],B={class:"top-miniChart_chart"},b=["onMouseenter"],E={class:"top-miniChart_data"},_={class:"top-miniChart_dataValue"},w=["innerHTML"],D=e.defineComponent({__name:"miniChart",props:e.mergeModels({title:{},gIcon:{},color:{default:"blue"},dates:{},values:{},activeDates:{},keysForDyn:{},dynamic:{},isInvert:{type:Boolean},numberCols:{default:k},additionalHTML:{},modelValue:{},valueSuffix:{},hideChartInMobile:{type:Boolean}},{modelValue:{},modelModifiers:{}}),emits:["update:modelValue"],setup(m){const o=m,s=e.useModel(m,"modelValue"),i=t=>{let l=u.value;o.isInvert&&(t-=1,l-=1);let a=l>0?Math.round(t/l*(100-y)):0;return o.isInvert?100-a:a+y},p=t=>o.activeDates.includes(t),u=e.computed(()=>Math.max(...o.values)),c=e.computed(()=>o.dates.slice().reverse()),v=e.computed(()=>o.dates.length?o.numberCols-o.dates.length:0),h=()=>{s.value=null},r=(t,l,a)=>{t.target instanceof HTMLElement&&(s.value={elCol:t.target,date:M.dateFormat(l),value:a===null?"--":a+(o.valueSuffix??"")})},n=e.computed(()=>{let t=o.dynamic;if(typeof t>"u"){const a=o.values[o.keysForDyn.start];t=o.values[o.keysForDyn.end]-a}return(t<0?-1:1)*g.percentOfNumber(Math.abs(t))}),d=e.computed(()=>{let t="stay";return o.isInvert?(n.value>0&&(t="down"),n.value<0&&(t="up")):(n.value>0&&(t="up"),n.value<0&&(t="down")),t});return(t,l)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass({"top-miniChart":!0,"top-miniChart_hideChartInMobile":t.hideChartInMobile,[`top-color_${t.color}`]:!0})},[e.createElementVNode("div",{class:"top-miniChart_title top-ellipsis","data-top-icon":t.gIcon},e.toDisplayString(t.title),9,V),e.createElementVNode("div",B,[e.createElementVNode("div",{class:"top-miniChart_chartGrid",onMouseleave:l[1]||(l[1]=a=>h())},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(c.value,(a,f)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass({"top-miniChart_chartGridCol":!0,"top-active":p(a)}),onMouseenter:z=>r(z,a,t.values[t.values.length-f-1])},[e.createElementVNode("div",{style:e.normalizeStyle("height:"+i(t.values[t.values.length-f-1])+"%")},null,4)],42,b))),256)),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(v.value,()=>(e.openBlock(),e.createElementBlock("div",{class:"top-miniChart_chartGridCol top-miniChart_chartGridCol-none",onMouseenter:l[0]||(l[0]=a=>h())},l[2]||(l[2]=[e.createElementVNode("div",null,null,-1)]),32))),256))],32)]),e.createElementVNode("div",E,[e.createElementVNode("span",{class:e.normalizeClass({"top-miniChart_dataDynamic":!0,[`top-miniChart_dataDynamic-direction_${d.value}`]:!0})},e.toDisplayString(Math.abs(n.value)||""),3),e.createElementVNode("span",_,e.toDisplayString(e.unref(g.percentOfNumber)(t.values[t.values.length-1])||0),1)]),t.additionalHTML?(e.openBlock(),e.createElementBlock("div",{key:0,innerHTML:t.additionalHTML},null,8,w)):e.createCommentVNode("",!0)],2))}}),N={key:0,class:"top-miniCharts_pages"},S=["onClick"],T=e.defineComponent({__name:"miniCharts",props:e.mergeModels({modelValue:{},countCharts:{},hideChartInMobile:{type:Boolean}},{modelValue:{},modelModifiers:{}}),emits:["update:modelValue"],setup(m){const o=m,s=e.useModel(m,"modelValue"),i=e.ref(null);let p;const u=e.ref(1),c=e.ref(1),v=()=>{u.value=Math.round(i.value.scrollHeight/i.value.clientHeight)};e.watch(u,()=>{u.value<c.value&&(c.value=1)}),e.watch(()=>o.countCharts,()=>v(),{flush:"post"});const h=e.computed(()=>{if(!s.value)return{};const r=s.value.elCol.getBoundingClientRect(),n={top:r.bottom+window.scrollY+"px"};return document.documentElement.clientWidth/2>r.right?n.left=r.right+window.scrollX+10+"px":(n.left=r.left+window.scrollX-10+"px",n.transform="translate(-100%, 0)"),n});return e.onMounted(()=>{p=new ResizeObserver(()=>v()),p.observe(i.value),e.watch(c,()=>{const d=(i.value.children[0].clientHeight+parseInt(window.getComputedStyle(i.value).getPropertyValue("row-gap")))*(c.value-1);i.value.scrollTo({top:d,behavior:"smooth"})})}),e.onUnmounted(()=>{p.disconnect()}),(r,n)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(["top-miniCharts",{"top-miniCharts":!0,scrollable:u.value>1,"top-miniCharts_hideChartInMobile":r.hideChartInMobile}]),ref_key:"elRef",ref:i},[e.renderSlot(r.$slots,"default"),u.value>1?(e.openBlock(),e.createElementBlock("div",N,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(u.value,d=>(e.openBlock(),e.createElementBlock("span",{class:e.normalizeClass({"top-active":d===c.value}),onClick:t=>c.value=d},null,10,S))),256))])):e.createCommentVNode("",!0),(e.openBlock(),e.createBlock(e.Teleport,{to:"body"},[s.value?(e.openBlock(),e.createElementBlock("div",{key:0,class:"top-miniCharts_tooltip",style:e.normalizeStyle(h.value)},[e.createElementVNode("span",null,e.toDisplayString(s.value.date),1),e.createElementVNode("span",null,e.toDisplayString(s.value.value),1)],4)):e.createCommentVNode("",!0)]))],2))}}),H=D,I=T;C.TopMiniChart=H,C.TopMiniCharts=I,Object.defineProperty(C,Symbol.toStringTag,{value:"Module"})}));
2
2
  //# sourceMappingURL=charts.amd.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"charts.amd.js","sources":["../../src/components/charts/miniChart/miniChart.vue","../../src/components/charts/miniCharts/miniCharts.vue","../../src/components/charts/charts.ts"],"sourcesContent":["<script setup lang=\"ts\">\nimport type { Props } from './types';\nimport { computed } from 'vue';\nimport { dateFormat } from '@/core/utils/date';\nimport { percentOfNumber } from '@/core/utils/number';\nimport { defaultNumberCols, minHeight } from './utils/consts';\n\nconst props = withDefaults(defineProps<Props>(), {\n\tcolor: 'blue',\n\tnumberCols: defaultNumberCols,\n});\nconst model = defineModel<Props['modelValue']>();\n\n/**\n * Расчет высоты колонки (в процентах)\n */\nconst genColHeight = (value: number): number => {\n\tlet maximumValue = maxValue.value;\n\n\t// для графиков средней и медианной делаем максимум 1\n\tif (props.isInvert) {\n\t\tvalue -= 1;\n\t\tmaximumValue -= 1;\n\t}\n\n\tlet height = maximumValue > 0 ? Math.round((value / maximumValue) * (100 - minHeight)) : 0;\n\tif (props.isInvert) return 100 - height;\n\n\treturn height + minHeight;\n};\n\nconst isActiveDate = (date: string) => props.activeDates.includes(date);\n\nconst maxValue = computed(() => Math.max(...props.values));\n\n/**\n * Из-за стиля .top-miniChart_chartGrid - direction: rtl\n */\nconst reversedDates = computed(() => props.dates.slice().reverse());\n\n/**\n * Кол-во пустых колонок\n */\nconst numOfEmptyCols = computed(() => {\n\tif (!props.dates.length) return 0;\n\n\treturn props.numberCols - props.dates.length;\n});\n\nconst resetModel = () => {\n\tmodel.value = null;\n};\n\nconst setModel = (e: Event, date: string, value: number | null) => {\n\tif (!(e.target instanceof HTMLElement)) return;\n\n\tmodel.value = {\n\t\telCol: e.target,\n\t\tdate: dateFormat(date),\n\t\tvalue: value === null ? '--' : value + (props.valueSuffix ?? ''),\n\t};\n};\n\n/**\n * Возвращает численный показатель динамики графика\n */\nconst localDynamic = computed(() => {\n\tlet dynamic = props.dynamic;\n\n\tif (typeof dynamic === 'undefined') {\n\t\tconst prevPeriodValue = props.values[props.keysForDyn.start];\n\t\tconst currentValue = props.values[props.keysForDyn.end];\n\t\tdynamic = currentValue - prevPeriodValue;\n\t}\n\n\tconst sign = dynamic < 0 ? -1 : 1;\n\n\treturn sign * (percentOfNumber(Math.abs(dynamic)) as number);\n});\n\nconst dynamicDirection = computed(() => {\n\tlet direction: 'up' | 'stay' | 'down' = 'stay';\n\n\tif (!props.isInvert) {\n\t\tif (localDynamic.value > 0) direction = 'up';\n\t\tif (localDynamic.value < 0) direction = 'down';\n\t} else {\n\t\tif (localDynamic.value > 0) direction = 'down';\n\t\tif (localDynamic.value < 0) direction = 'up';\n\t}\n\n\treturn direction;\n});\n\n</script>\n\n<template>\n\t<div\n\t\t:class=\"{\n\t\t\t['top-miniChart']: true,\n\t\t\t['top-miniChart_hideChartInMobile']: hideChartInMobile,\n\t\t\t[`top-color_${color}`]: true\n\t\t}\"\n\t>\n\t\t<div\n\t\t\tclass=\"top-miniChart_title top-ellipsis\"\n\t\t\t:data-top-icon=\"gIcon\"\n\t\t>\n\t\t\t{{ title }}\n\t\t</div>\n\n\t\t<div class=\"top-miniChart_chart\">\n\t\t\t<div\n\t\t\t\tclass=\"top-miniChart_chartGrid\"\n\t\t\t\t@mouseleave=\"resetModel()\"\n\t\t\t>\n\t\t\t\t<div\n\t\t\t\t\tv-for=\"(date, i) in reversedDates\"\n\t\t\t\t\t:class=\"{\n\t\t\t\t\t\t['top-miniChart_chartGridCol']: true,\n\t\t\t\t\t\t['top-active']: isActiveDate(date)\n\t\t\t\t\t}\"\n\t\t\t\t\t@mouseenter=\"setModel($event, date, values[values.length - i - 1])\"\n\t\t\t\t>\n\t\t\t\t\t<div :style=\"'height:' + genColHeight(values[values.length - i - 1]) + '%'\"/>\n\t\t\t\t</div>\n\t\t\t\t<div\n\t\t\t\t\tv-for=\"() in numOfEmptyCols\"\n\t\t\t\t\tclass=\"top-miniChart_chartGridCol top-miniChart_chartGridCol-none\"\n\t\t\t\t\t@mouseenter=\"resetModel()\"\n\t\t\t\t>\n\t\t\t\t\t<div></div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\n\t\t<div class=\"top-miniChart_data\">\n\t\t\t<span :class=\"{\n\t\t\t\t['top-miniChart_dataDynamic']: true,\n\t\t\t\t[`top-miniChart_dataDynamic-direction_${dynamicDirection}`]: true,\n\t\t\t}\">\n\t\t\t\t{{ Math.abs(localDynamic) || '' }}\n\t\t\t</span>\n\t\t\t<span class=\"top-miniChart_dataValue\">\n\t\t\t\t{{ percentOfNumber(values[values.length - 1]) || 0 }}\n\t\t\t</span>\n\t\t</div>\n\n\t\t<div\n\t\t\tv-if=\"additionalHTML\"\n\t\t\tv-html=\"additionalHTML\"\n\t\t/>\n\t</div>\n\n</template>\n<style>\n@import \"./styles/miniChart.css\";\n</style>\n","<script setup lang=\"ts\">\nimport { computed, onMounted, onUnmounted, ref, watch } from 'vue';\nimport type { Props, Style } from './miniCharts';\n\nconst props = defineProps<Props>();\nconst model = defineModel<Props['modelValue']>();\n\nconst elRef = ref<HTMLElement | null>(null);\n\nlet pagesResizeObserver: ResizeObserver;\n\n/**\n * Количество страниц\n */\nconst countPages = ref(1);\n\n/**\n * Активная страница\n */\nconst activePage = ref(1);\n\n/**\n * Установка количества страниц в блоке\n */\nconst setCountPages = () => {\n\tcountPages.value = Math.round(elRef.value!.scrollHeight / elRef.value!.clientHeight);\n};\n\nwatch(countPages, () => {\n\tif (countPages.value < activePage.value) {\n\t\tactivePage.value = 1;\n\t}\n});\n\nwatch(\n\t() => props.countCharts,\n\t() => setCountPages(),\n\t{ flush: 'post' },\n);\n\n/**\n * Расчет положения для подсказки\n */\nconst tooltipStyle = computed(() => {\n\tif (!model.value) return {};\n\n\tconst box = model.value.elCol.getBoundingClientRect();\n\n\tconst style: Style = {\n\t\ttop: box.bottom + window.scrollY + 'px',\n\t};\n\n\tif (document.documentElement.clientWidth / 2 > box.right) {\n\t\tstyle.left = box.right + window.scrollX + 10 + 'px';\n\t} else {\n\t\tstyle.left = box.left + window.scrollX - 10 + 'px';\n\t\tstyle.transform = 'translate(-100%, 0)';\n\t}\n\n\treturn style;\n});\n\nonMounted(() => {\n\t/**\n\t * Функционал переключения экранов графиков\n\t */\n\tpagesResizeObserver = new ResizeObserver(() => setCountPages());\n\tpagesResizeObserver.observe(elRef.value!);\n\n\twatch(activePage, () => {\n\t\tconst elMiniChart = elRef.value!.children[0];\n\t\tconst pageHeight = elMiniChart.clientHeight + parseInt(window.getComputedStyle(elRef.value!).getPropertyValue('row-gap'));\n\t\tconst scrollTop = pageHeight * (activePage.value - 1);\n\n\t\telRef.value!.scrollTo({ top: scrollTop, behavior: 'smooth' });\n\t});\n});\n\nonUnmounted(() => {\n\tpagesResizeObserver.disconnect();\n});\n</script>\n\n<template>\n\t<div\n\t\tclass=\"top-miniCharts\"\n\t\t:class=\"{\n\t\t\t['top-miniCharts']: true,\n\t\t\t['scrollable']: countPages > 1,\n\t\t\t['top-miniCharts_hideChartInMobile']: hideChartInMobile,\n\t\t}\"\n\t\tref=\"elRef\"\n\t>\n\n\t\t<slot></slot>\n\n\t\t<div\n\t\t\tv-if=\"countPages > 1\"\n\t\t\tclass=\"top-miniCharts_pages\"\n\t\t>\n\t\t\t<span\n\t\t\t\tv-for=\"n in countPages\"\n\t\t\t\t:class=\"{['top-active']: n === activePage}\"\n\t\t\t\t@click=\"activePage = n\"\n\t\t\t></span>\n\t\t</div>\n\n\t\t<Teleport to=\"body\">\n\t\t\t<div\n\t\t\t\tv-if=\"model\"\n\t\t\t\tclass=\"top-miniCharts_tooltip\"\n\t\t\t\t:style=\"tooltipStyle\"\n\t\t\t>\n\t\t\t\t<span>{{ model.date }}</span>\n\t\t\t\t<span>{{ model.value }}</span>\n\t\t\t</div>\n\t\t</Teleport>\n\t</div>\n\n</template>\n\n<style>\n@import \"./styles/miniCharts.css\";\n</style>\n","import type { ComponentCustomProps } from 'vue';\n\nimport MiniChart from './miniChart/miniChart.vue';\nimport MiniCharts from './miniCharts/miniCharts.vue';\n\nexport const TopMiniChart = MiniChart as typeof MiniChart & ComponentCustomProps;\n\nexport const TopMiniCharts = MiniCharts as typeof MiniCharts & ComponentCustomProps;\n"],"names":["genColHeight","value","maximumValue","maxValue","props","isActiveDate","date","vue","reversedDates","numOfEmptyCols","model","e","forms","localDynamic","dynamic","prevPeriodValue","dynamicDirection","direction","_hoisted_2$1","_cache","$event","resetModel","_hoisted_5","utils_number","_ctx","_hoisted_6","elRef","pagesResizeObserver","countPages","activePage","tooltipStyle","box","style","scrollTop","_hoisted_1","n","_hoisted_2","TopMiniChart","_sfc_main$1","TopMiniCharts","_sfc_main"],"mappings":"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"}
1
+ {"version":3,"file":"charts.amd.js","sources":["../../src/components/charts/miniChart/miniChart.vue","../../src/components/charts/miniCharts/miniCharts.vue","../../src/components/charts/charts.ts"],"sourcesContent":["<script setup lang=\"ts\">\nimport type { Props } from './types';\nimport { computed } from 'vue';\nimport { dateFormat } from '@/core/utils/date';\nimport { percentOfNumber } from '@/core/utils/number';\nimport { defaultNumberCols, minHeight } from './utils/consts';\n\nconst props = withDefaults(defineProps<Props>(), {\n\tcolor: 'blue',\n\tnumberCols: defaultNumberCols,\n});\nconst model = defineModel<Props['modelValue']>();\n\n/**\n * Расчет высоты колонки (в процентах)\n */\nconst genColHeight = (value: number): number => {\n\tlet maximumValue = maxValue.value;\n\n\t// для графиков средней и медианной делаем максимум 1\n\tif (props.isInvert) {\n\t\tvalue -= 1;\n\t\tmaximumValue -= 1;\n\t}\n\n\tlet height = maximumValue > 0 ? Math.round((value / maximumValue) * (100 - minHeight)) : 0;\n\tif (props.isInvert) return 100 - height;\n\n\treturn height + minHeight;\n};\n\nconst isActiveDate = (date: string) => props.activeDates.includes(date);\n\nconst maxValue = computed(() => Math.max(...props.values));\n\n/**\n * Из-за стиля .top-miniChart_chartGrid - direction: rtl\n */\nconst reversedDates = computed(() => props.dates.slice().reverse());\n\n/**\n * Кол-во пустых колонок\n */\nconst numOfEmptyCols = computed(() => {\n\tif (!props.dates.length) return 0;\n\n\treturn props.numberCols - props.dates.length;\n});\n\nconst resetModel = () => {\n\tmodel.value = null;\n};\n\nconst setModel = (e: Event, date: string, value: number | null) => {\n\tif (!(e.target instanceof HTMLElement)) return;\n\n\tmodel.value = {\n\t\telCol: e.target,\n\t\tdate: dateFormat(date),\n\t\tvalue: value === null ? '--' : value + (props.valueSuffix ?? ''),\n\t};\n};\n\n/**\n * Возвращает численный показатель динамики графика\n */\nconst localDynamic = computed(() => {\n\tlet dynamic = props.dynamic;\n\n\tif (typeof dynamic === 'undefined') {\n\t\tconst prevPeriodValue = props.values[props.keysForDyn.start];\n\t\tconst currentValue = props.values[props.keysForDyn.end];\n\t\tdynamic = currentValue - prevPeriodValue;\n\t}\n\n\tconst sign = dynamic < 0 ? -1 : 1;\n\n\treturn sign * (percentOfNumber(Math.abs(dynamic)) as number);\n});\n\nconst dynamicDirection = computed(() => {\n\tlet direction: 'up' | 'stay' | 'down' = 'stay';\n\n\tif (!props.isInvert) {\n\t\tif (localDynamic.value > 0) direction = 'up';\n\t\tif (localDynamic.value < 0) direction = 'down';\n\t} else {\n\t\tif (localDynamic.value > 0) direction = 'down';\n\t\tif (localDynamic.value < 0) direction = 'up';\n\t}\n\n\treturn direction;\n});\n\n</script>\n\n<template>\n\t<div\n\t\t:class=\"{\n\t\t\t['top-miniChart']: true,\n\t\t\t['top-miniChart_hideChartInMobile']: hideChartInMobile,\n\t\t\t[`top-color_${color}`]: true\n\t\t}\"\n\t>\n\t\t<div\n\t\t\tclass=\"top-miniChart_title top-ellipsis\"\n\t\t\t:data-top-icon=\"gIcon\"\n\t\t>\n\t\t\t{{ title }}\n\t\t</div>\n\n\t\t<div class=\"top-miniChart_chart\">\n\t\t\t<div\n\t\t\t\tclass=\"top-miniChart_chartGrid\"\n\t\t\t\t@mouseleave=\"resetModel()\"\n\t\t\t>\n\t\t\t\t<div\n\t\t\t\t\tv-for=\"(date, i) in reversedDates\"\n\t\t\t\t\t:class=\"{\n\t\t\t\t\t\t['top-miniChart_chartGridCol']: true,\n\t\t\t\t\t\t['top-active']: isActiveDate(date)\n\t\t\t\t\t}\"\n\t\t\t\t\t@mouseenter=\"setModel($event, date, values[values.length - i - 1])\"\n\t\t\t\t>\n\t\t\t\t\t<div :style=\"'height:' + genColHeight(values[values.length - i - 1]) + '%'\"/>\n\t\t\t\t</div>\n\t\t\t\t<div\n\t\t\t\t\tv-for=\"() in numOfEmptyCols\"\n\t\t\t\t\tclass=\"top-miniChart_chartGridCol top-miniChart_chartGridCol-none\"\n\t\t\t\t\t@mouseenter=\"resetModel()\"\n\t\t\t\t>\n\t\t\t\t\t<div></div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\n\t\t<div class=\"top-miniChart_data\">\n\t\t\t<span :class=\"{\n\t\t\t\t['top-miniChart_dataDynamic']: true,\n\t\t\t\t[`top-miniChart_dataDynamic-direction_${dynamicDirection}`]: true,\n\t\t\t}\">\n\t\t\t\t{{ Math.abs(localDynamic) || '' }}\n\t\t\t</span>\n\t\t\t<span class=\"top-miniChart_dataValue\">\n\t\t\t\t{{ percentOfNumber(values[values.length - 1]) || 0 }}\n\t\t\t</span>\n\t\t</div>\n\n\t\t<div\n\t\t\tv-if=\"additionalHTML\"\n\t\t\tv-html=\"additionalHTML\"\n\t\t/>\n\t</div>\n\n</template>\n<style>\n@import \"./styles/miniChart.css\";\n</style>\n","<script setup lang=\"ts\">\nimport { computed, onMounted, onUnmounted, ref, watch } from 'vue';\nimport type { Props, Style } from './miniCharts';\n\nconst props = defineProps<Props>();\nconst model = defineModel<Props['modelValue']>();\n\nconst elRef = ref<HTMLElement | null>(null);\n\nlet pagesResizeObserver: ResizeObserver;\n\n/**\n * Количество страниц\n */\nconst countPages = ref(1);\n\n/**\n * Активная страница\n */\nconst activePage = ref(1);\n\n/**\n * Установка количества страниц в блоке\n */\nconst setCountPages = () => {\n\tcountPages.value = Math.round(elRef.value!.scrollHeight / elRef.value!.clientHeight);\n};\n\nwatch(countPages, () => {\n\tif (countPages.value < activePage.value) {\n\t\tactivePage.value = 1;\n\t}\n});\n\nwatch(\n\t() => props.countCharts,\n\t() => setCountPages(),\n\t{ flush: 'post' },\n);\n\n/**\n * Расчет положения для подсказки\n */\nconst tooltipStyle = computed(() => {\n\tif (!model.value) return {};\n\n\tconst box = model.value.elCol.getBoundingClientRect();\n\n\tconst style: Style = {\n\t\ttop: box.bottom + window.scrollY + 'px',\n\t};\n\n\tif (document.documentElement.clientWidth / 2 > box.right) {\n\t\tstyle.left = box.right + window.scrollX + 10 + 'px';\n\t} else {\n\t\tstyle.left = box.left + window.scrollX - 10 + 'px';\n\t\tstyle.transform = 'translate(-100%, 0)';\n\t}\n\n\treturn style;\n});\n\nonMounted(() => {\n\t/**\n\t * Функционал переключения экранов графиков\n\t */\n\tpagesResizeObserver = new ResizeObserver(() => setCountPages());\n\tpagesResizeObserver.observe(elRef.value!);\n\n\twatch(activePage, () => {\n\t\tconst elMiniChart = elRef.value!.children[0];\n\t\tconst pageHeight = elMiniChart.clientHeight + parseInt(window.getComputedStyle(elRef.value!).getPropertyValue('row-gap'));\n\t\tconst scrollTop = pageHeight * (activePage.value - 1);\n\n\t\telRef.value!.scrollTo({ top: scrollTop, behavior: 'smooth' });\n\t});\n});\n\nonUnmounted(() => {\n\tpagesResizeObserver.disconnect();\n});\n</script>\n\n<template>\n\t<div\n\t\tclass=\"top-miniCharts\"\n\t\t:class=\"{\n\t\t\t['top-miniCharts']: true,\n\t\t\t['scrollable']: countPages > 1,\n\t\t\t['top-miniCharts_hideChartInMobile']: hideChartInMobile,\n\t\t}\"\n\t\tref=\"elRef\"\n\t>\n\n\t\t<slot></slot>\n\n\t\t<div\n\t\t\tv-if=\"countPages > 1\"\n\t\t\tclass=\"top-miniCharts_pages\"\n\t\t>\n\t\t\t<span\n\t\t\t\tv-for=\"n in countPages\"\n\t\t\t\t:class=\"{['top-active']: n === activePage}\"\n\t\t\t\t@click=\"activePage = n\"\n\t\t\t></span>\n\t\t</div>\n\n\t\t<Teleport to=\"body\">\n\t\t\t<div\n\t\t\t\tv-if=\"model\"\n\t\t\t\tclass=\"top-miniCharts_tooltip\"\n\t\t\t\t:style=\"tooltipStyle\"\n\t\t\t>\n\t\t\t\t<span>{{ model.date }}</span>\n\t\t\t\t<span>{{ model.value }}</span>\n\t\t\t</div>\n\t\t</Teleport>\n\t</div>\n\n</template>\n\n<style>\n@import \"./styles/miniCharts.css\";\n</style>\n","import type { ComponentCustomProps } from 'vue';\n\nimport MiniChart from './miniChart/miniChart.vue';\nimport MiniCharts from './miniCharts/miniCharts.vue';\n\nexport const TopMiniChart = MiniChart as typeof MiniChart & ComponentCustomProps;\n\nexport const TopMiniCharts = MiniCharts as typeof MiniCharts & ComponentCustomProps;\n"],"names":["genColHeight","value","maximumValue","maxValue","props","isActiveDate","date","vue","reversedDates","numOfEmptyCols","model","e","forms","localDynamic","dynamic","prevPeriodValue","dynamicDirection","direction","_hoisted_2$1","_cache","$event","resetModel","_hoisted_5","utils_number","_ctx","additionalHTML","elRef","pagesResizeObserver","countPages","activePage","tooltipStyle","box","style","scrollTop","hideChartInMobile","_hoisted_1","n","_hoisted_2","TopMiniChart","_sfc_main$1","TopMiniCharts","_sfc_main"],"mappings":"gwBAgBAA,EAAAC,GAAA,CACC,IAAAC,EAAAC,EAAA,MAGAC,EAAA,qFAQgB,EAGjBC,EAAAC,GAAAF,EAAA,YAAA,SAAAE,CAAA,EAEAH,EAAAI,EAAA,SAAA,IAAA,KAAA,IAAA,GAAAH,EAAA,MAAA,CAAA,EAKAI,EAAAD,EAAA,SAAA,IAAAH,EAAA,MAAA,MAAA,EAAA,QAAA,CAAA,EAKAK,EAAAF,EAAA,SAAA,gDAGuC,SAItCG,EAAA,MAAA,IAAc,yDAMA,MAAAC,EAAA,OACJ,KAAAC,EAAA,WAAAN,CAAA,EACY,MAAAL,IAAA,KAAA,KAAAA,GAAAG,EAAA,aAAA,KAEtB,EAMDS,EAAAN,EAAA,SAAA,IAAA,CACC,IAAAO,EAAAV,EAAA,QAEA,GAAA,OAAAU,EAAA,IAAA,CACC,MAAAC,EAAAX,EAAA,OAAAA,EAAA,WAAA,KAAA,EAEAU,EADAV,EAAA,OAAAA,EAAA,WAAA,GAAA,EACAW,iDAK+C,CAAA,EAGjDC,EAAAT,EAAA,SAAA,IAAA,cAGC,OAAAH,EAAA,iGAQAa,CAAO,CAAA,yTAiBGV,EAAA,mBAAA,MAAAW,EAAA,6DAKD,aAAAC,EAAA,CAAA,IAAAA,EAAA,CAAA,EAAAC,GAAAC,EAAA,EACiB,EAAA,uMAIuE,CAAA,sDAIjC,EAAA,yTAMtD,aAAAF,EAAA,CAAA,IAAAA,EAAA,CAAA,EAAAC,GAAAC,EAAA,sSAaiBd,EAAA,mBAAA,OAAAe,EAAAf,EAAA,gBAAAA,EAAA,MAAAgB,EAAA,eAAA,EAAAC,EAAA,OAAAA,EAAA,OAAA,OAAA,CAAA,CAAA,GAAA,CAAA,EAAA,CAAA,CAGe,CAAA,8FAMhCC,EAAAA,KAAAA,EAAAA,CAAAA,GAAAA,EAAAA,mBAAAA,GAAAA,EAAAA,2SC/IXC,EAAAnB,EAAA,IAAA,IAAA,EAEA,IAAAoB,EAKA,MAAAC,EAAArB,EAAA,IAAA,CAAA,EAKAsB,EAAAtB,EAAA,IAAA,CAAA,SAMCqB,EAAA,MAAA,KAAA,MAAAF,EAAA,MAAA,aAAAA,EAAA,MAAA,YAAA,CAAmF,EAGpFnB,EAAA,MAAAqB,EAAA,IAAA,mBAEEC,EAAA,MAAA,EACD,CAAA,EAGDtB,EAAA,gDASA,MAAAuB,EAAAvB,EAAA,SAAA,IAAA,CACC,GAAA,CAAAG,EAAA,MAAA,MAAA,CAAA,qFAQA,OAAA,SAAA,gBAAA,YAAA,EAAAqB,EAAA,MACCC,EAAA,KAAAD,EAAA,MAAA,OAAA,QAAA,GAAA,MAEAC,EAAA,KAAAD,EAAA,KAAA,OAAA,QAAA,GAAA,KACAC,EAAA,UAAA,uBAGDA,CAAO,CAAA,wDAQPL,EAAA,QAAAD,EAAA,KAAA,EAEAnB,EAAA,MAAAsB,EAAA,IAAA,+HAKCH,EAAA,MAAA,SAAA,CAAA,IAAAO,EAAA,SAAA,QAAA,CAAA,CAA4D,CAAA,CAC5D,CAAA,mCAI8B,CAAA,oDAsCzB,MAAA1B,EAAA,eAAA,CAAA,iBAAA,0CA/B+D,mCAAAiB,EAAA,iBAA+CU,CAAAA,CAAAA,kBAK/G,IAAAR,CAAA,EAAA,kCAGSE,EAAA,MAAA,GAAArB,EAAA,UAAA,EAAAA,EAAA,mBAAA,MAAA4B,EAAA,EAWP5B,EAAA,UAAA,EAAA,EAAAA,EAAA,mBAAAA,EAAA,SAAA,KAAAA,EAAA,WAAAqB,EAAA,MAAAQ,+CADG,MAAA7B,EAAA,eAAA,CAAA,aAAA6B,IAAAP,EAAA,KAAA,CAAA,sBADc,EAAA,KAAA,GAAAQ,CAAA,sLAOf,MAAA9B,EAAA,eAAAuB,EAAA,KAAA,CACc,EAAA,qEAEDvB,EAAA,mBAAA,OAAA,KAAAA,EAAA,gBAAAG,EAAA,MAAA,KAAA,EAAA,CAAA,8CC5GhB4B,EAAAC,EAEAC,EAAAC"}
package/charts/charts.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import { Core as P } from "../core/app.js";
2
2
  import { defineComponent as T, mergeModels as S, useModel as $, computed as h, createElementBlock as i, openBlock as a, normalizeClass as f, createElementVNode as r, createCommentVNode as k, toDisplayString as g, Fragment as w, renderList as H, normalizeStyle as L, unref as F, ref as b, watch as V, onMounted as N, onUnmounted as R, renderSlot as z, createBlock as G, Teleport as O } from "vue";
3
- import { c as X } from "../.chunks/forms-DC7ffuv2.es.js";
3
+ import { c as X } from "../.chunks/forms-t2AEUjqg.es.js";
4
4
  import { percentOfNumber as I } from "../utils/number.js";
5
5
  const E = ["../assets/charts.css"].map((v) => import.meta.resolve(v));
6
6
  P.insertCSSLinkToPage(E, !0);
@@ -1 +1 @@
1
- {"version":3,"file":"charts.js","sources":["../../src/components/charts/miniChart/utils/consts.ts","../../src/components/charts/miniChart/miniChart.vue","../../src/components/charts/miniCharts/miniCharts.vue","../../src/components/charts/charts.ts"],"sourcesContent":["/**\n * Кол-во столбцов по умолчанию\n */\nexport const defaultNumberCols = 90;\n\n/**\n * Минимальная высота колонки (в процентах)\n */\nexport const minHeight = 10; // %","<script setup lang=\"ts\">\nimport type { Props } from './types';\nimport { computed } from 'vue';\nimport { dateFormat } from '@/core/utils/date';\nimport { percentOfNumber } from '@/core/utils/number';\nimport { defaultNumberCols, minHeight } from './utils/consts';\n\nconst props = withDefaults(defineProps<Props>(), {\n\tcolor: 'blue',\n\tnumberCols: defaultNumberCols,\n});\nconst model = defineModel<Props['modelValue']>();\n\n/**\n * Расчет высоты колонки (в процентах)\n */\nconst genColHeight = (value: number): number => {\n\tlet maximumValue = maxValue.value;\n\n\t// для графиков средней и медианной делаем максимум 1\n\tif (props.isInvert) {\n\t\tvalue -= 1;\n\t\tmaximumValue -= 1;\n\t}\n\n\tlet height = maximumValue > 0 ? Math.round((value / maximumValue) * (100 - minHeight)) : 0;\n\tif (props.isInvert) return 100 - height;\n\n\treturn height + minHeight;\n};\n\nconst isActiveDate = (date: string) => props.activeDates.includes(date);\n\nconst maxValue = computed(() => Math.max(...props.values));\n\n/**\n * Из-за стиля .top-miniChart_chartGrid - direction: rtl\n */\nconst reversedDates = computed(() => props.dates.slice().reverse());\n\n/**\n * Кол-во пустых колонок\n */\nconst numOfEmptyCols = computed(() => {\n\tif (!props.dates.length) return 0;\n\n\treturn props.numberCols - props.dates.length;\n});\n\nconst resetModel = () => {\n\tmodel.value = null;\n};\n\nconst setModel = (e: Event, date: string, value: number | null) => {\n\tif (!(e.target instanceof HTMLElement)) return;\n\n\tmodel.value = {\n\t\telCol: e.target,\n\t\tdate: dateFormat(date),\n\t\tvalue: value === null ? '--' : value + (props.valueSuffix ?? ''),\n\t};\n};\n\n/**\n * Возвращает численный показатель динамики графика\n */\nconst localDynamic = computed(() => {\n\tlet dynamic = props.dynamic;\n\n\tif (typeof dynamic === 'undefined') {\n\t\tconst prevPeriodValue = props.values[props.keysForDyn.start];\n\t\tconst currentValue = props.values[props.keysForDyn.end];\n\t\tdynamic = currentValue - prevPeriodValue;\n\t}\n\n\tconst sign = dynamic < 0 ? -1 : 1;\n\n\treturn sign * (percentOfNumber(Math.abs(dynamic)) as number);\n});\n\nconst dynamicDirection = computed(() => {\n\tlet direction: 'up' | 'stay' | 'down' = 'stay';\n\n\tif (!props.isInvert) {\n\t\tif (localDynamic.value > 0) direction = 'up';\n\t\tif (localDynamic.value < 0) direction = 'down';\n\t} else {\n\t\tif (localDynamic.value > 0) direction = 'down';\n\t\tif (localDynamic.value < 0) direction = 'up';\n\t}\n\n\treturn direction;\n});\n\n</script>\n\n<template>\n\t<div\n\t\t:class=\"{\n\t\t\t['top-miniChart']: true,\n\t\t\t['top-miniChart_hideChartInMobile']: hideChartInMobile,\n\t\t\t[`top-color_${color}`]: true\n\t\t}\"\n\t>\n\t\t<div\n\t\t\tclass=\"top-miniChart_title top-ellipsis\"\n\t\t\t:data-top-icon=\"gIcon\"\n\t\t>\n\t\t\t{{ title }}\n\t\t</div>\n\n\t\t<div class=\"top-miniChart_chart\">\n\t\t\t<div\n\t\t\t\tclass=\"top-miniChart_chartGrid\"\n\t\t\t\t@mouseleave=\"resetModel()\"\n\t\t\t>\n\t\t\t\t<div\n\t\t\t\t\tv-for=\"(date, i) in reversedDates\"\n\t\t\t\t\t:class=\"{\n\t\t\t\t\t\t['top-miniChart_chartGridCol']: true,\n\t\t\t\t\t\t['top-active']: isActiveDate(date)\n\t\t\t\t\t}\"\n\t\t\t\t\t@mouseenter=\"setModel($event, date, values[values.length - i - 1])\"\n\t\t\t\t>\n\t\t\t\t\t<div :style=\"'height:' + genColHeight(values[values.length - i - 1]) + '%'\"/>\n\t\t\t\t</div>\n\t\t\t\t<div\n\t\t\t\t\tv-for=\"() in numOfEmptyCols\"\n\t\t\t\t\tclass=\"top-miniChart_chartGridCol top-miniChart_chartGridCol-none\"\n\t\t\t\t\t@mouseenter=\"resetModel()\"\n\t\t\t\t>\n\t\t\t\t\t<div></div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\n\t\t<div class=\"top-miniChart_data\">\n\t\t\t<span :class=\"{\n\t\t\t\t['top-miniChart_dataDynamic']: true,\n\t\t\t\t[`top-miniChart_dataDynamic-direction_${dynamicDirection}`]: true,\n\t\t\t}\">\n\t\t\t\t{{ Math.abs(localDynamic) || '' }}\n\t\t\t</span>\n\t\t\t<span class=\"top-miniChart_dataValue\">\n\t\t\t\t{{ percentOfNumber(values[values.length - 1]) || 0 }}\n\t\t\t</span>\n\t\t</div>\n\n\t\t<div\n\t\t\tv-if=\"additionalHTML\"\n\t\t\tv-html=\"additionalHTML\"\n\t\t/>\n\t</div>\n\n</template>\n<style>\n@import \"./styles/miniChart.css\";\n</style>\n","<script setup lang=\"ts\">\nimport { computed, onMounted, onUnmounted, ref, watch } from 'vue';\nimport type { Props, Style } from './miniCharts';\n\nconst props = defineProps<Props>();\nconst model = defineModel<Props['modelValue']>();\n\nconst elRef = ref<HTMLElement | null>(null);\n\nlet pagesResizeObserver: ResizeObserver;\n\n/**\n * Количество страниц\n */\nconst countPages = ref(1);\n\n/**\n * Активная страница\n */\nconst activePage = ref(1);\n\n/**\n * Установка количества страниц в блоке\n */\nconst setCountPages = () => {\n\tcountPages.value = Math.round(elRef.value!.scrollHeight / elRef.value!.clientHeight);\n};\n\nwatch(countPages, () => {\n\tif (countPages.value < activePage.value) {\n\t\tactivePage.value = 1;\n\t}\n});\n\nwatch(\n\t() => props.countCharts,\n\t() => setCountPages(),\n\t{ flush: 'post' },\n);\n\n/**\n * Расчет положения для подсказки\n */\nconst tooltipStyle = computed(() => {\n\tif (!model.value) return {};\n\n\tconst box = model.value.elCol.getBoundingClientRect();\n\n\tconst style: Style = {\n\t\ttop: box.bottom + window.scrollY + 'px',\n\t};\n\n\tif (document.documentElement.clientWidth / 2 > box.right) {\n\t\tstyle.left = box.right + window.scrollX + 10 + 'px';\n\t} else {\n\t\tstyle.left = box.left + window.scrollX - 10 + 'px';\n\t\tstyle.transform = 'translate(-100%, 0)';\n\t}\n\n\treturn style;\n});\n\nonMounted(() => {\n\t/**\n\t * Функционал переключения экранов графиков\n\t */\n\tpagesResizeObserver = new ResizeObserver(() => setCountPages());\n\tpagesResizeObserver.observe(elRef.value!);\n\n\twatch(activePage, () => {\n\t\tconst elMiniChart = elRef.value!.children[0];\n\t\tconst pageHeight = elMiniChart.clientHeight + parseInt(window.getComputedStyle(elRef.value!).getPropertyValue('row-gap'));\n\t\tconst scrollTop = pageHeight * (activePage.value - 1);\n\n\t\telRef.value!.scrollTo({ top: scrollTop, behavior: 'smooth' });\n\t});\n});\n\nonUnmounted(() => {\n\tpagesResizeObserver.disconnect();\n});\n</script>\n\n<template>\n\t<div\n\t\tclass=\"top-miniCharts\"\n\t\t:class=\"{\n\t\t\t['top-miniCharts']: true,\n\t\t\t['scrollable']: countPages > 1,\n\t\t\t['top-miniCharts_hideChartInMobile']: hideChartInMobile,\n\t\t}\"\n\t\tref=\"elRef\"\n\t>\n\n\t\t<slot></slot>\n\n\t\t<div\n\t\t\tv-if=\"countPages > 1\"\n\t\t\tclass=\"top-miniCharts_pages\"\n\t\t>\n\t\t\t<span\n\t\t\t\tv-for=\"n in countPages\"\n\t\t\t\t:class=\"{['top-active']: n === activePage}\"\n\t\t\t\t@click=\"activePage = n\"\n\t\t\t></span>\n\t\t</div>\n\n\t\t<Teleport to=\"body\">\n\t\t\t<div\n\t\t\t\tv-if=\"model\"\n\t\t\t\tclass=\"top-miniCharts_tooltip\"\n\t\t\t\t:style=\"tooltipStyle\"\n\t\t\t>\n\t\t\t\t<span>{{ model.date }}</span>\n\t\t\t\t<span>{{ model.value }}</span>\n\t\t\t</div>\n\t\t</Teleport>\n\t</div>\n\n</template>\n\n<style>\n@import \"./styles/miniCharts.css\";\n</style>\n","import type { ComponentCustomProps } from 'vue';\n\nimport MiniChart from './miniChart/miniChart.vue';\nimport MiniCharts from './miniCharts/miniCharts.vue';\n\nexport const TopMiniChart = MiniChart as typeof MiniChart & ComponentCustomProps;\n\nexport const TopMiniCharts = MiniCharts as typeof MiniCharts & ComponentCustomProps;\n"],"names":["defaultNumberCols","minHeight","props","__props","model","useModel","genColHeight","value","maximumValue","maxValue","height","isActiveDate","date","computed","reversedDates","numOfEmptyCols","resetModel","setModel","dateFormat","localDynamic","dynamic","prevPeriodValue","percentOfNumber","dynamicDirection","direction","normalizeClass","_ctx","toDisplayString","_hoisted_1$1","createElementVNode","_hoisted_2$1","_cache","$event","normalizeStyle","i","_hoisted_5","unref","_hoisted_6","createCommentVNode","elRef","ref","pagesResizeObserver","countPages","activePage","setCountPages","watch","tooltipStyle","box","style","onMounted","scrollTop","onUnmounted","openBlock","createElementBlock","_hoisted_1","Fragment","renderList","n","_hoisted_2","TopMiniChart","_sfc_main$1","TopMiniCharts","_sfc_main"],"mappings":"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"}
1
+ {"version":3,"file":"charts.js","sources":["../../src/components/charts/miniChart/utils/consts.ts","../../src/components/charts/miniChart/miniChart.vue","../../src/components/charts/miniCharts/miniCharts.vue","../../src/components/charts/charts.ts"],"sourcesContent":["/**\n * Кол-во столбцов по умолчанию\n */\nexport const defaultNumberCols = 90;\n\n/**\n * Минимальная высота колонки (в процентах)\n */\nexport const minHeight = 10; // %","<script setup lang=\"ts\">\nimport type { Props } from './types';\nimport { computed } from 'vue';\nimport { dateFormat } from '@/core/utils/date';\nimport { percentOfNumber } from '@/core/utils/number';\nimport { defaultNumberCols, minHeight } from './utils/consts';\n\nconst props = withDefaults(defineProps<Props>(), {\n\tcolor: 'blue',\n\tnumberCols: defaultNumberCols,\n});\nconst model = defineModel<Props['modelValue']>();\n\n/**\n * Расчет высоты колонки (в процентах)\n */\nconst genColHeight = (value: number): number => {\n\tlet maximumValue = maxValue.value;\n\n\t// для графиков средней и медианной делаем максимум 1\n\tif (props.isInvert) {\n\t\tvalue -= 1;\n\t\tmaximumValue -= 1;\n\t}\n\n\tlet height = maximumValue > 0 ? Math.round((value / maximumValue) * (100 - minHeight)) : 0;\n\tif (props.isInvert) return 100 - height;\n\n\treturn height + minHeight;\n};\n\nconst isActiveDate = (date: string) => props.activeDates.includes(date);\n\nconst maxValue = computed(() => Math.max(...props.values));\n\n/**\n * Из-за стиля .top-miniChart_chartGrid - direction: rtl\n */\nconst reversedDates = computed(() => props.dates.slice().reverse());\n\n/**\n * Кол-во пустых колонок\n */\nconst numOfEmptyCols = computed(() => {\n\tif (!props.dates.length) return 0;\n\n\treturn props.numberCols - props.dates.length;\n});\n\nconst resetModel = () => {\n\tmodel.value = null;\n};\n\nconst setModel = (e: Event, date: string, value: number | null) => {\n\tif (!(e.target instanceof HTMLElement)) return;\n\n\tmodel.value = {\n\t\telCol: e.target,\n\t\tdate: dateFormat(date),\n\t\tvalue: value === null ? '--' : value + (props.valueSuffix ?? ''),\n\t};\n};\n\n/**\n * Возвращает численный показатель динамики графика\n */\nconst localDynamic = computed(() => {\n\tlet dynamic = props.dynamic;\n\n\tif (typeof dynamic === 'undefined') {\n\t\tconst prevPeriodValue = props.values[props.keysForDyn.start];\n\t\tconst currentValue = props.values[props.keysForDyn.end];\n\t\tdynamic = currentValue - prevPeriodValue;\n\t}\n\n\tconst sign = dynamic < 0 ? -1 : 1;\n\n\treturn sign * (percentOfNumber(Math.abs(dynamic)) as number);\n});\n\nconst dynamicDirection = computed(() => {\n\tlet direction: 'up' | 'stay' | 'down' = 'stay';\n\n\tif (!props.isInvert) {\n\t\tif (localDynamic.value > 0) direction = 'up';\n\t\tif (localDynamic.value < 0) direction = 'down';\n\t} else {\n\t\tif (localDynamic.value > 0) direction = 'down';\n\t\tif (localDynamic.value < 0) direction = 'up';\n\t}\n\n\treturn direction;\n});\n\n</script>\n\n<template>\n\t<div\n\t\t:class=\"{\n\t\t\t['top-miniChart']: true,\n\t\t\t['top-miniChart_hideChartInMobile']: hideChartInMobile,\n\t\t\t[`top-color_${color}`]: true\n\t\t}\"\n\t>\n\t\t<div\n\t\t\tclass=\"top-miniChart_title top-ellipsis\"\n\t\t\t:data-top-icon=\"gIcon\"\n\t\t>\n\t\t\t{{ title }}\n\t\t</div>\n\n\t\t<div class=\"top-miniChart_chart\">\n\t\t\t<div\n\t\t\t\tclass=\"top-miniChart_chartGrid\"\n\t\t\t\t@mouseleave=\"resetModel()\"\n\t\t\t>\n\t\t\t\t<div\n\t\t\t\t\tv-for=\"(date, i) in reversedDates\"\n\t\t\t\t\t:class=\"{\n\t\t\t\t\t\t['top-miniChart_chartGridCol']: true,\n\t\t\t\t\t\t['top-active']: isActiveDate(date)\n\t\t\t\t\t}\"\n\t\t\t\t\t@mouseenter=\"setModel($event, date, values[values.length - i - 1])\"\n\t\t\t\t>\n\t\t\t\t\t<div :style=\"'height:' + genColHeight(values[values.length - i - 1]) + '%'\"/>\n\t\t\t\t</div>\n\t\t\t\t<div\n\t\t\t\t\tv-for=\"() in numOfEmptyCols\"\n\t\t\t\t\tclass=\"top-miniChart_chartGridCol top-miniChart_chartGridCol-none\"\n\t\t\t\t\t@mouseenter=\"resetModel()\"\n\t\t\t\t>\n\t\t\t\t\t<div></div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\n\t\t<div class=\"top-miniChart_data\">\n\t\t\t<span :class=\"{\n\t\t\t\t['top-miniChart_dataDynamic']: true,\n\t\t\t\t[`top-miniChart_dataDynamic-direction_${dynamicDirection}`]: true,\n\t\t\t}\">\n\t\t\t\t{{ Math.abs(localDynamic) || '' }}\n\t\t\t</span>\n\t\t\t<span class=\"top-miniChart_dataValue\">\n\t\t\t\t{{ percentOfNumber(values[values.length - 1]) || 0 }}\n\t\t\t</span>\n\t\t</div>\n\n\t\t<div\n\t\t\tv-if=\"additionalHTML\"\n\t\t\tv-html=\"additionalHTML\"\n\t\t/>\n\t</div>\n\n</template>\n<style>\n@import \"./styles/miniChart.css\";\n</style>\n","<script setup lang=\"ts\">\nimport { computed, onMounted, onUnmounted, ref, watch } from 'vue';\nimport type { Props, Style } from './miniCharts';\n\nconst props = defineProps<Props>();\nconst model = defineModel<Props['modelValue']>();\n\nconst elRef = ref<HTMLElement | null>(null);\n\nlet pagesResizeObserver: ResizeObserver;\n\n/**\n * Количество страниц\n */\nconst countPages = ref(1);\n\n/**\n * Активная страница\n */\nconst activePage = ref(1);\n\n/**\n * Установка количества страниц в блоке\n */\nconst setCountPages = () => {\n\tcountPages.value = Math.round(elRef.value!.scrollHeight / elRef.value!.clientHeight);\n};\n\nwatch(countPages, () => {\n\tif (countPages.value < activePage.value) {\n\t\tactivePage.value = 1;\n\t}\n});\n\nwatch(\n\t() => props.countCharts,\n\t() => setCountPages(),\n\t{ flush: 'post' },\n);\n\n/**\n * Расчет положения для подсказки\n */\nconst tooltipStyle = computed(() => {\n\tif (!model.value) return {};\n\n\tconst box = model.value.elCol.getBoundingClientRect();\n\n\tconst style: Style = {\n\t\ttop: box.bottom + window.scrollY + 'px',\n\t};\n\n\tif (document.documentElement.clientWidth / 2 > box.right) {\n\t\tstyle.left = box.right + window.scrollX + 10 + 'px';\n\t} else {\n\t\tstyle.left = box.left + window.scrollX - 10 + 'px';\n\t\tstyle.transform = 'translate(-100%, 0)';\n\t}\n\n\treturn style;\n});\n\nonMounted(() => {\n\t/**\n\t * Функционал переключения экранов графиков\n\t */\n\tpagesResizeObserver = new ResizeObserver(() => setCountPages());\n\tpagesResizeObserver.observe(elRef.value!);\n\n\twatch(activePage, () => {\n\t\tconst elMiniChart = elRef.value!.children[0];\n\t\tconst pageHeight = elMiniChart.clientHeight + parseInt(window.getComputedStyle(elRef.value!).getPropertyValue('row-gap'));\n\t\tconst scrollTop = pageHeight * (activePage.value - 1);\n\n\t\telRef.value!.scrollTo({ top: scrollTop, behavior: 'smooth' });\n\t});\n});\n\nonUnmounted(() => {\n\tpagesResizeObserver.disconnect();\n});\n</script>\n\n<template>\n\t<div\n\t\tclass=\"top-miniCharts\"\n\t\t:class=\"{\n\t\t\t['top-miniCharts']: true,\n\t\t\t['scrollable']: countPages > 1,\n\t\t\t['top-miniCharts_hideChartInMobile']: hideChartInMobile,\n\t\t}\"\n\t\tref=\"elRef\"\n\t>\n\n\t\t<slot></slot>\n\n\t\t<div\n\t\t\tv-if=\"countPages > 1\"\n\t\t\tclass=\"top-miniCharts_pages\"\n\t\t>\n\t\t\t<span\n\t\t\t\tv-for=\"n in countPages\"\n\t\t\t\t:class=\"{['top-active']: n === activePage}\"\n\t\t\t\t@click=\"activePage = n\"\n\t\t\t></span>\n\t\t</div>\n\n\t\t<Teleport to=\"body\">\n\t\t\t<div\n\t\t\t\tv-if=\"model\"\n\t\t\t\tclass=\"top-miniCharts_tooltip\"\n\t\t\t\t:style=\"tooltipStyle\"\n\t\t\t>\n\t\t\t\t<span>{{ model.date }}</span>\n\t\t\t\t<span>{{ model.value }}</span>\n\t\t\t</div>\n\t\t</Teleport>\n\t</div>\n\n</template>\n\n<style>\n@import \"./styles/miniCharts.css\";\n</style>\n","import type { ComponentCustomProps } from 'vue';\n\nimport MiniChart from './miniChart/miniChart.vue';\nimport MiniCharts from './miniCharts/miniCharts.vue';\n\nexport const TopMiniChart = MiniChart as typeof MiniChart & ComponentCustomProps;\n\nexport const TopMiniCharts = MiniCharts as typeof MiniCharts & ComponentCustomProps;\n"],"names":["defaultNumberCols","minHeight","props","__props","model","useModel","genColHeight","value","maximumValue","maxValue","height","isActiveDate","date","computed","reversedDates","numOfEmptyCols","resetModel","setModel","dateFormat","localDynamic","dynamic","prevPeriodValue","percentOfNumber","dynamicDirection","direction","normalizeClass","hideChartInMobile","_ctx","gIcon","createElementVNode","_hoisted_2$1","_cache","$event","normalizeStyle","i","_hoisted_5","toDisplayString","unref","additionalHTML","elRef","ref","pagesResizeObserver","countPages","activePage","setCountPages","watch","tooltipStyle","box","style","onMounted","scrollTop","onUnmounted","openBlock","createElementBlock","_hoisted_1","Fragment","renderList","n","_hoisted_2","createCommentVNode","TopMiniChart","_sfc_main$1","TopMiniCharts","_sfc_main"],"mappings":"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"}
package/core/app.amd.js CHANGED
@@ -1,2 +1,2 @@
1
- define(["require","exports","../.chunks/forms-L6BGV_om.amd","../.chunks/core-SEtL6T0A.amd","vue","../utils/clipboard.amd","../utils/string.amd","../utils/route.amd","../.chunks/utils-Bg7IV0KZ.amd","../.chunks/dialogs.vue_vue_type_script_setup_true_lang-C-wpHg-4.amd"],function(y,n,c,l,d,m,S,p,g,k){"use strict";if(typeof d>"u")var d=window.Vue;class E{#s;#t;#e;#i;#c;#a=[];#o=[];#n=[];#r=[];constructor(s){var t;this.#t=s.store,this.#s=this.#t.$id,this.#e=s.options.Page,this.#i=s.options.user,this.#c=s.options.Api,this.#a=s.options.tpaNamesUrlHash||[],this.#o=s.options.tpaNamesStorage||[],this.#n=s.options.tpaNamesStorageLocal||[],this.#r=s.options.tpaNamesGuestLink||[],s.store.genGuestLink=(i,a)=>this.genGuestLink(i,a),(t=this.#i.guest_data)!=null&&t.data||(this.#u(),this.#u(!0),this.#l()),this.#S(),this.#k();const e=c.debounce(()=>{this.#m(),this.#p(),this.#p(!0)});s.store.$subscribe(e)}async genGuestLink(s,e){const t=this.#g();e=Object.assign(e,Object.fromEntries(t));const i=await this.#c.gen(s,"fetchColumn").call({},e);i!=null&&i.errors||await m.guestLinkToClipboard(i.result)}#g(){const s=new Map;return this.#r.forEach(e=>{const t=S.camelToSnakeCase(e);s.set(t,this.#t[e])}),s}#h(s){s.forEach((e,t)=>{const i=this.#t[t];if(e!=null&&i!==void 0&&e!=null&&e.constructor&&e.constructor===i.constructor){if(t.indexOf("date")===0&&!Array.isArray(e)){if(typeof e=="string"&&!/\d\d\d\d-\d\d-\d\d/.test(e))return}this.#t[t]=e}})}#f(s){const e=new Map;return s.forEach((t,i)=>{t!==null&&(t=JSON.stringify(t),e.set(i,t))}),e}#d(s){const e=new Map;return s.forEach((t,i)=>{if(!(t==null||t==="false")){try{if(typeof t=="string"&&!/^\d\d\d\d-\d\d-\d\d$/.test(t)&&(t=JSON.parse(t)),t==null||t==="false")return}catch{}e.set(i,t)}}),e}#l(){let s;try{s=JSON.parse(p.getHash(this.#s))}catch{}if(!s)return;const e=new Map;this.#a.forEach(t=>{const i=s[t];i&&e.set(t,i)}),this.#h(e)}#m(){const s=new Map;this.#a.forEach(i=>{const a=this.#t[i];s.set(i,a)});const e=Object.fromEntries(s),t=JSON.stringify(e);p.setHash(this.#s,t)}#u(s=!1){const e=new Map;let t=this.#o,i="state:"+this.#s;s&&(t=this.#n,i="state:"+this.#s+":"+location.pathname),t.forEach(o=>{const r=localStorage.getItem(i+":"+o);e.set(o,r)});const a=this.#d(e);this.#h(a)}#p(s=!1){const e=new Map;let t=this.#o,i="state:"+this.#s;s&&(t=this.#n,i="state:"+this.#s+":"+location.pathname),t.forEach(o=>{const r=this.#t[o];e.set(o,r)});const a=this.#f(e);t.forEach(o=>{const r=a.get(o);localStorage.setItem(i+":"+o,r)})}#S(){var a,o,r;const s=(o=(a=this.#i)==null?void 0:a.guest_data)==null?void 0:o.data;if(!s)return;this.#i.id===-1&&(this.#i.positionsReverseDates=s.positionsReverseDates);const e=new Map;this.#r.forEach(h=>{const u=s[h];e.set(h,u)});const t=this.#d(e);this.#h(t);const i=$(".mod_guest_title");if(((r=this.#t.competitorsIds)==null?void 0:r.length)===1&&this.#e.page.data.competitors){let h=this.#e.page.data.competitors.filter(u=>u.id===s.competitorsIds[0]);h.length&&($("a",i).attr("href","http://"+h[0].url),$("a",i).text(h[0].name))}}#k(){this.#t.regionsIndexes&&d.watch(this.#t.regionsIndexes,s=>{if(!s.length)return;s.forEach((i,a)=>s[a]=i);const e=TplProjectSelectorRegion.genSearchersMap(),t=[];e.forEach(i=>{i.regions.forEach(a=>{a.index!==-1&&t.push(a.index)})}),this.#t.regionsIndexes=s.filter(i=>t.includes(i))},{immediate:!0}),this.#t.competitorsIds&&d.watch(this.#t.competitorsIds,s=>{if(!s.length)return;s.forEach((t,i)=>s[i]=t);const e=[this.#e.page.data.project.id];this.#e.page.data.project.competitors.forEach(t=>{t.on>=0&&e.push(t.id)}),this.#t.competitorsIds=s.filter(t=>e.includes(t))},{immediate:!0})}}const w=f=>{var e,t,i,a;const s=f;!((e=s.options.tpaNamesUrlHash)!=null&&e.length)&&!((t=s.options.tpaNamesStorage)!=null&&t.length)&&!((i=s.options.tpaNamesStorageLocal)!=null&&i.length)&&!((a=s.options.tpaNamesGuestLink)!=null&&a.length)||new E(s)};n.Core=c.Core,n.i18nPlugin=c.i18n,n.useI18n=c.useI18n,n.useI18nLang=c.useI18nLang,n.corePlugin=l.core,n.useAsyncTopDialog=g.useAsyncTopDialog,n.useTopDialog=g.useTopDialog,n.TopDialogWorker=k.TopDialogWorker,n.piniaTPAPlugin=w,Object.defineProperty(n,Symbol.toStringTag,{value:"Module"})});
1
+ define(["require","exports","../.chunks/forms-DRhpgERJ.amd","../.chunks/core-6NjSIwIA.amd","vue","../utils/clipboard.amd","../utils/string.amd","../utils/route.amd","../.chunks/utils-BkF4g-PH.amd","../.chunks/dialogs.vue_vue_type_script_setup_true_lang-DVp-tQ6l.amd"],(function(y,n,c,l,d,m,S,p,g,k){"use strict";if(typeof d>"u")var d=window.Vue;class E{#s;#t;#e;#i;#c;#a=[];#o=[];#n=[];#r=[];constructor(s){var t;this.#t=s.store,this.#s=this.#t.$id,this.#e=s.options.Page,this.#i=s.options.user,this.#c=s.options.Api,this.#a=s.options.tpaNamesUrlHash||[],this.#o=s.options.tpaNamesStorage||[],this.#n=s.options.tpaNamesStorageLocal||[],this.#r=s.options.tpaNamesGuestLink||[],s.store.genGuestLink=(i,a)=>this.genGuestLink(i,a),(t=this.#i.guest_data)!=null&&t.data||(this.#u(),this.#u(!0),this.#l()),this.#S(),this.#k();const e=c.debounce(()=>{this.#m(),this.#p(),this.#p(!0)});s.store.$subscribe(e)}async genGuestLink(s,e){const t=this.#g();e=Object.assign(e,Object.fromEntries(t));const i=await this.#c.gen(s,"fetchColumn").call({},e);i!=null&&i.errors||await m.guestLinkToClipboard(i.result)}#g(){const s=new Map;return this.#r.forEach(e=>{const t=S.camelToSnakeCase(e);s.set(t,this.#t[e])}),s}#h(s){s.forEach((e,t)=>{const i=this.#t[t];if(e!=null&&i!==void 0&&e!=null&&e.constructor&&e.constructor===i.constructor){if(t.indexOf("date")===0&&!Array.isArray(e)){if(typeof e=="string"&&!/\d\d\d\d-\d\d-\d\d/.test(e))return}this.#t[t]=e}})}#f(s){const e=new Map;return s.forEach((t,i)=>{t!==null&&(t=JSON.stringify(t),e.set(i,t))}),e}#d(s){const e=new Map;return s.forEach((t,i)=>{if(!(t==null||t==="false")){try{if(typeof t=="string"&&!/^\d\d\d\d-\d\d-\d\d$/.test(t)&&(t=JSON.parse(t)),t==null||t==="false")return}catch{}e.set(i,t)}}),e}#l(){let s;try{s=JSON.parse(p.getHash(this.#s))}catch{}if(!s)return;const e=new Map;this.#a.forEach(t=>{const i=s[t];i&&e.set(t,i)}),this.#h(e)}#m(){const s=new Map;this.#a.forEach(i=>{const a=this.#t[i];s.set(i,a)});const e=Object.fromEntries(s),t=JSON.stringify(e);p.setHash(this.#s,t)}#u(s=!1){const e=new Map;let t=this.#o,i="state:"+this.#s;s&&(t=this.#n,i="state:"+this.#s+":"+location.pathname),t.forEach(o=>{const r=localStorage.getItem(i+":"+o);e.set(o,r)});const a=this.#d(e);this.#h(a)}#p(s=!1){const e=new Map;let t=this.#o,i="state:"+this.#s;s&&(t=this.#n,i="state:"+this.#s+":"+location.pathname),t.forEach(o=>{const r=this.#t[o];e.set(o,r)});const a=this.#f(e);t.forEach(o=>{const r=a.get(o);localStorage.setItem(i+":"+o,r)})}#S(){var a,o,r;const s=(o=(a=this.#i)==null?void 0:a.guest_data)==null?void 0:o.data;if(!s)return;this.#i.id===-1&&(this.#i.positionsReverseDates=s.positionsReverseDates);const e=new Map;this.#r.forEach(h=>{const u=s[h];e.set(h,u)});const t=this.#d(e);this.#h(t);const i=$(".mod_guest_title");if(((r=this.#t.competitorsIds)==null?void 0:r.length)===1&&this.#e.page.data.competitors){let h=this.#e.page.data.competitors.filter(u=>u.id===s.competitorsIds[0]);h.length&&($("a",i).attr("href","http://"+h[0].url),$("a",i).text(h[0].name))}}#k(){this.#t.regionsIndexes&&d.watch(this.#t.regionsIndexes,s=>{if(!s.length)return;s.forEach((i,a)=>s[a]=i);const e=TplProjectSelectorRegion.genSearchersMap(),t=[];e.forEach(i=>{i.regions.forEach(a=>{a.index!==-1&&t.push(a.index)})}),this.#t.regionsIndexes=s.filter(i=>t.includes(i))},{immediate:!0}),this.#t.competitorsIds&&d.watch(this.#t.competitorsIds,s=>{if(!s.length)return;s.forEach((t,i)=>s[i]=t);const e=[this.#e.page.data.project.id];this.#e.page.data.project.competitors.forEach(t=>{t.on>=0&&e.push(t.id)}),this.#t.competitorsIds=s.filter(t=>e.includes(t))},{immediate:!0})}}const w=f=>{var e,t,i,a;const s=f;!((e=s.options.tpaNamesUrlHash)!=null&&e.length)&&!((t=s.options.tpaNamesStorage)!=null&&t.length)&&!((i=s.options.tpaNamesStorageLocal)!=null&&i.length)&&!((a=s.options.tpaNamesGuestLink)!=null&&a.length)||new E(s)};n.Core=c.Core,n.i18nPlugin=c.i18n,n.useI18n=c.useI18n,n.useI18nLang=c.useI18nLang,n.corePlugin=l.core,n.useAsyncTopDialog=g.useAsyncTopDialog,n.useTopDialog=g.useTopDialog,n.TopDialogWorker=k.TopDialogWorker,n.piniaTPAPlugin=w,Object.defineProperty(n,Symbol.toStringTag,{value:"Module"})}));
2
2
  //# sourceMappingURL=app.amd.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"app.amd.js","sources":["../../src/core/plugins/piniaTPA.ts"],"sourcesContent":["import type { PiniaPluginContext, Store } from 'pinia';\nimport { watch } from 'vue';\nimport Core from '@/core/core/core';\nimport { useI18n } from '@/core/plugins/i18n';\nimport { debounce } from '@/core/utils/lodash';\nimport { guestLinkToClipboard } from '@/core/utils/clipboard';\nimport { camelToSnakeCase } from '@/core/utils/string.js';\nimport type { paths as OpenAPIPaths } from 'topvisor-openapi/src/ts/Topvisor';\nimport { getHash, setHash } from '@/core/utils/route';\n\ntype OpenAPIPath = keyof OpenAPIPaths;\n\nclass PiniaTPA {\n\n\treadonly #storeId: string;\n\treadonly #store: Store<string, any>;\n\n\t/**\n\t * @deprecated\n\t */\n\treadonly #Page: any;\n\n\treadonly #user: any;\n\treadonly #Api: any;\n\n\treadonly #namesUrlHash: string[] = [];\n\treadonly #namesStorage: string[] = [];\n\treadonly #namesStorageLocal: string[] = [];\n\treadonly #namesGuestLink: string[] = [];\n\n\tconstructor(context: Context) {\n\t\tthis.#store = context.store;\n\t\tthis.#storeId = this.#store.$id;\n\n\t\tthis.#Page = context.options.Page;\n\n\t\tthis.#user = context.options.user;\n\t\tthis.#Api = context.options.Api;\n\n\t\tthis.#namesUrlHash = context.options.tpaNamesUrlHash || [];\n\t\tthis.#namesStorage = context.options.tpaNamesStorage || [];\n\t\tthis.#namesStorageLocal = context.options.tpaNamesStorageLocal || [];\n\t\tthis.#namesGuestLink = context.options.tpaNamesGuestLink || [];\n\n\t\tcontext.store.genGuestLink = <Path extends OpenAPIPath>(url: Path, data: any) => this.genGuestLink(url, data);\n\n\t\tif (!this.#user.guest_data?.data) {\n\t\t\tthis.#loadFromStorage();\n\t\t\tthis.#loadFromStorage(true);\n\n\t\t\t// настройки URL hash имеют приоритет\n\t\t\tthis.#loadFromHash();\n\t\t}\n\n\t\t// настройки гостевой ссылки имеют приоритет\n\t\tthis.#loadFromGuestLink();\n\n\t\tthis.#prepareParams();\n\n\t\tconst save = debounce(() => {\n\t\t\tthis.#saveInHash();\n\t\t\tthis.#saveInStorage();\n\t\t\tthis.#saveInStorage(true);\n\t\t});\n\n\t\tcontext.store.$subscribe(save);\n\t}\n\n\t/**\n\t * Сгенерировать гостевую ссылку\n\t *\n\t * Метод, путь к которому указан в url, должен возвращать сгенерированную ссылку\n\t */\n\tasync genGuestLink<Path extends OpenAPIPath>(url: Path, data: any) {\n\t\tconst dataGuestLink = this.#genOptionsForGuestLink();\n\t\tdata = Object.assign(data, Object.fromEntries(dataGuestLink));\n\n\t\tconst res = await this.#Api.gen(url, 'fetchColumn').call({} as any, data);\n\n\t\t// @ts-ignore - метод, который скачивает файл не возвращает json\n\t\tif (res?.errors) return;\n\n\t\t// @ts-ignore - метод, который скачивает файл не возвращает json\n\t\tawait guestLinkToClipboard(res.result);\n\t}\n\n\t/**\n\t * Сгенерировать опции для гостевой ссылки\n\t */\n\t#genOptionsForGuestLink() {\n\t\tconst data = new Map();\n\n\t\tthis.#namesGuestLink.forEach(name => {\n\t\t\t// формат параметров API: snake_case\n\t\t\tconst nameSnakeCase = camelToSnakeCase(name);\n\t\t\tdata.set(nameSnakeCase, this.#store[name]);\n\t\t});\n\n\t\treturn data;\n\t}\n\n\t/**\n\t * Установить опции из объекта без фиксации состояния\n\t */\n\t#setOptions(data: Map<string, any>) {\n\t\tdata.forEach((value, name) => {\n\t\t\tconst currentValue = this.#store[name];\n\n\t\t\tif (value === null || value === undefined) return;\n\t\t\tif (currentValue === undefined) return;\n\t\t\tif (!value?.constructor) return;\n\t\t\tif (value.constructor !== currentValue.constructor) return;\n\n\t\t\t// дополнительная проверка на формат даты\n\t\t\tif (name.indexOf('date') === 0) {\n\t\t\t\tif (Array.isArray(value)) {\n\t\t\t\t\t// value.forEach((valueI) => {\n\t\t\t\t\t// \tif (!/\\d\\d\\d\\d-\\d\\d-\\d\\d/.test(valueI)) return;\n\t\t\t\t\t// });\n\t\t\t\t} else {\n\t\t\t\t\tif (typeof (value) === 'string') {\n\t\t\t\t\t\tif (!/\\d\\d\\d\\d-\\d\\d-\\d\\d/.test(value)) return;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis.#store[name] = value;\n\t\t});\n\t}\n\n\t/**\n\t * Сгенерировать Map объект с опциями со значениями в виде json строк\n\t */\n\t#genDataFormat(data: Map<string, any>) {\n\t\tconst dataFormatted = new Map();\n\n\t\tdata.forEach((value, name) => {\n\t\t\tif (value === null) return;\n\n\t\t\tvalue = JSON.stringify(value);\n\n\t\t\tdataFormatted.set(name, value);\n\t\t});\n\n\t\treturn dataFormatted;\n\t}\n\n\t/**\n\t * Сгенерировать Map объект с опциями со значениями в оригинальном виде\n\t */\n\t#genDataUnFormat(dataFormatted: Map<string, string>) {\n\t\tconst data: Map<string, any> = new Map();\n\n\t\tdataFormatted.forEach((value, name) => {\n\t\t\tif (value === null || value === undefined || value === 'false') return;\n\n\t\t\ttry {\n\t\t\t\tif (typeof (value) === 'string' && !/^\\d\\d\\d\\d-\\d\\d-\\d\\d$/.test(value)) value = JSON.parse(value);\n\n\t\t\t\tif (value === null || value === undefined || value === 'false') return;\n\t\t\t} catch (e) {\n\t\t\t\t// не json строка\n\t\t\t}\n\n\t\t\tdata.set(name, value);\n\t\t});\n\n\t\treturn data;\n\t}\n\n\t/**\n\t * Установить опции из хеша адреса страницы\n\t */\n\t#loadFromHash() {\n\t\tlet dataHash: any;\n\t\ttry {\n\t\t\tdataHash = JSON.parse(getHash(this.#storeId));\n\t\t} catch (e) {\n\n\t\t}\n\t\tif (!dataHash) return;\n\n\t\tconst data: Map<string, any> = new Map();\n\n\t\tthis.#namesUrlHash.forEach((name) => {\n\t\t\tconst value = dataHash[name];\n\t\t\tif (!value) return;\n\n\t\t\tdata.set(name, value);\n\t\t});\n\n\t\tthis.#setOptions(data);\n\t}\n\n\t/**\n\t * Сохранить опции в хеш адреса страницы\n\t */\n\t#saveInHash() {\n\t\tconst data = new Map();\n\n\t\tthis.#namesUrlHash.forEach((name) => {\n\t\t\tconst value = this.#store[name];\n\n\t\t\tdata.set(name, value);\n\t\t});\n\n\t\tconst dataObject = Object.fromEntries(data);\n\t\tconst dataJSON = JSON.stringify(dataObject);\n\n\t\tsetHash(this.#storeId, dataJSON);\n\t};\n\n\t/**\n\t * Установить опции из localStorage\n\t * @param isLocal - сохранить с учетом адреса страницы\n\t */\n\t#loadFromStorage(isLocal = false) {\n\t\tconst dataFormatted = new Map();\n\n\t\tlet names = this.#namesStorage;\n\t\tlet storageNamespace = 'state:' + this.#storeId;\n\n\t\tif (isLocal) {\n\t\t\tnames = this.#namesStorageLocal;\n\t\t\tstorageNamespace = 'state:' + this.#storeId + ':' + location.pathname;\n\t\t}\n\n\t\tnames.forEach((name) => {\n\t\t\tconst value = localStorage.getItem(storageNamespace + ':' + name);\n\t\t\tdataFormatted.set(name, value);\n\t\t});\n\n\t\tconst data = this.#genDataUnFormat(dataFormatted);\n\n\t\tthis.#setOptions(data);\n\t}\n\n\t/**\n\t * Сохранить опции в localStorage\n\t * @param isLocal - сохранить с учетом адреса страницы\n\t */\n\t#saveInStorage(isLocal = false) {\n\t\tconst data = new Map();\n\n\t\tlet names = this.#namesStorage;\n\t\tlet storageNamespace = 'state:' + this.#storeId;\n\n\t\tif (isLocal) {\n\t\t\tnames = this.#namesStorageLocal;\n\t\t\tstorageNamespace = 'state:' + this.#storeId + ':' + location.pathname;\n\t\t}\n\n\t\tnames.forEach((name) => {\n\t\t\tconst value = this.#store[name];\n\n\t\t\tdata.set(name, value);\n\t\t});\n\n\t\tconst dataFormatted = this.#genDataFormat(data);\n\n\t\tnames.forEach((name) => {\n\t\t\tconst value = dataFormatted.get(name);\n\n\t\t\tlocalStorage.setItem(storageNamespace + ':' + name, value);\n\t\t});\n\t}\n\n\t/**\n\t * Установить опции из гостевой ссылки\n\t */\n\t#loadFromGuestLink() {\n\t\tconst guestData = this.#user?.guest_data?.data;\n\t\tif (!guestData) return;\n\n\t\t// общие правила для гостевых сессий\n\t\tif (this.#user.id === -1) this.#user.positionsReverseDates = guestData.positionsReverseDates;\n\n\t\tconst dataFormatted = new Map();\n\n\t\tthis.#namesGuestLink.forEach((name) => {\n\t\t\tconst value = guestData[name];\n\t\t\tdataFormatted.set(name, value);\n\t\t});\n\n\t\tconst data = this.#genDataUnFormat(dataFormatted);\n\n\t\tthis.#setOptions(data);\n\n\t\tconst $guestTitle = $('.mod_guest_title');\n\n\t\t// TODO: вынести в опции плагина\n\t\tif (this.#store.competitorsIds?.length === 1 && this.#Page.page.data.competitors) {\n\t\t\tlet competitors = this.#Page.page.data.competitors.filter((competitor: any) => competitor.id === guestData.competitorsIds[0]);\n\t\t\tif (competitors.length) {\n\t\t\t\t$('a', $guestTitle).attr('href', 'http://' + competitors[0].url);\n\t\t\t\t$('a', $guestTitle).text(competitors[0].name);\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Подготовить входные параметры перед инициализацией основного функционала\n\t *\n\t * Входные параметры устанавливаются при открытии страницы\n\t *\n\t * Входные параметры могут меняться пользоваталем и устаревать\n\t */\n\t#prepareParams() {\n\t\t// контролль за вводом регионов\n\t\t// TODO: вынести в опции плагина\n\t\tif (this.#store.regionsIndexes) {\n\t\t\twatch(this.#store.regionsIndexes, (regionsIndexes) => {\n\t\t\t\tif (!regionsIndexes.length) return;\n\n\t\t\t\t// приведение типа\n\t\t\t\tregionsIndexes.forEach((regionIndex: number, index: number) => regionsIndexes[index] = regionIndex);\n\n\t\t\t\t// оставить только включенные регионы\n\t\t\t\t// @ts-ignore\n\t\t\t\tconst mapSearchers = TplProjectSelectorRegion.genSearchersMap();\n\n\t\t\t\tconst availableRegionsIndexes: number[] = [];\n\t\t\t\tmapSearchers.forEach((searcher: any) => {\n\t\t\t\t\tsearcher.regions.forEach((region: any) => {\n\t\t\t\t\t\tif (region.index === -1) return;\n\n\t\t\t\t\t\tavailableRegionsIndexes.push(region.index);\n\t\t\t\t\t});\n\t\t\t\t});\n\n\t\t\t\tthis.#store.regionsIndexes = regionsIndexes.filter((regionIndex: number) => availableRegionsIndexes.includes(regionIndex));\n\t\t\t}, { immediate: true });\n\t\t}\n\n\t\t// контролль за вводом конкурентов\n\t\t// TODO: вынести в опции плагина\n\t\tif (this.#store.competitorsIds) {\n\t\t\twatch(this.#store.competitorsIds, (competitorsIds) => {\n\t\t\t\tif (!competitorsIds.length) return;\n\n\t\t\t\t// приведение типа\n\t\t\t\tcompetitorsIds.forEach((competitorId: number, index: number) => competitorsIds[index] = competitorId);\n\n\t\t\t\t// оставить только включенных конкурентов\n\t\t\t\tconst availableCompetitorsIds = [this.#Page.page.data.project.id];\n\t\t\t\tthis.#Page.page.data.project.competitors.forEach((competitor: any) => {\n\t\t\t\t\tif (competitor.on >= 0) availableCompetitorsIds.push(competitor.id);\n\t\t\t\t});\n\n\t\t\t\tthis.#store.competitorsIds = competitorsIds.filter((competitorId: number) => availableCompetitorsIds.includes(competitorId));\n\t\t\t}, { immediate: true });\n\t\t}\n\t}\n\n}\n\ntype Options = {\n\t/**\n\t * TODO: Убрать из плагина\n\t */\n\tPage: any,\n\n\t/**\n\t * Объект с настройками пользователя\n\t */\n\tuser: any,\n\n\t/**\n\t * Объект для работы с API\n\t *\n\t * См. на сайте: @/component/api/core/api.ts\n\t */\n\tApi: any;\n\n\t/**\n\t * Имена свойств для сохранения в URL\n\t */\n\ttpaNamesUrlHash?: string[],\n\n\t/**\n\t * Имена свойств для сохранения в localStorage\n\t */\n\ttpaNamesStorage?: string[],\n\n\t/**\n\t * Имена свойств для сохранения в localStorage с учетом пути URL\n\t *\n\t * Каждый URL будет работать со своим состоянием\n\t */\n\ttpaNamesStorageLocal?: string[],\n\n\t/**\n\t * Имена свойств для работы с гостевой ссылкой\n\t *\n\t * Для генерации гостевой ссылки используйте store.genGuestLink(data, url)\n\t */\n\ttpaNamesGuestLink?: string[],\n};\n\ntype Context = PiniaPluginContext & {\n\toptions: Options\n};\n\n/**\n * Плагин tpa (Third-party access) для pinia\n *\n * Добавляет возможность сохранять и загружать данные в/из:\n * \t- URL hash в адресе страницы\n * \t- localStorage\n * \t- гостевая ссылка\n *\n * Для подключения плагина нужно указань одну или несколько опций при определении defineStore():\n * - tpaNamesUrlHash\n * - tpaNamesStorage\n * - tpaNamesStorageLocal\n * - tpaNamesGuestLink\n */\nexport default (contextPinia: PiniaPluginContext) => {\n\tconst context = contextPinia as Context;\n\n\t// плагин подключать не нужно\n\tif (\n\t\t!context.options.tpaNamesUrlHash?.length &&\n\t\t!context.options.tpaNamesStorage?.length &&\n\t\t!context.options.tpaNamesStorageLocal?.length &&\n\t\t!context.options.tpaNamesGuestLink?.length\n\t) {\n\t\treturn;\n\t}\n\n\tnew PiniaTPA(context);\n}\n"],"names":["PiniaTPA","#storeId","#store","#Page","#user","#Api","context","url","data","#loadFromStorage","save","forms","#saveInStorage","dataGuestLink","#genOptionsForGuestLink","res","utils_clipboard","nameSnakeCase","utils_string","name","currentValue","value","dataFormatted","#loadFromHash","dataHash","utils_route","#setOptions","#saveInHash","dataJSON","isLocal","names","#namesStorage","storageNamespace","#namesStorageLocal","#loadFromGuestLink","guestData","$guestTitle","competitors","competitor","#prepareParams","regionsIndexes","regionIndex","index","mapSearchers","searcher","region","availableRegionsIndexes","competitorsIds","competitorId","availableCompetitorsIds","piniaTPA","contextPinia","_a","_b","_c","_d"],"mappings":"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"}
1
+ {"version":3,"file":"app.amd.js","sources":["../../src/core/plugins/piniaTPA.ts"],"sourcesContent":["import type { PiniaPluginContext, Store } from 'pinia';\nimport { watch } from 'vue';\nimport Core from '@/core/core/core';\nimport { useI18n } from '@/core/plugins/i18n';\nimport { debounce } from '@/core/utils/lodash';\nimport { guestLinkToClipboard } from '@/core/utils/clipboard';\nimport { camelToSnakeCase } from '@/core/utils/string.js';\nimport type { paths as OpenAPIPaths } from 'topvisor-openapi/src/ts/Topvisor';\nimport { getHash, setHash } from '@/core/utils/route';\n\ntype OpenAPIPath = keyof OpenAPIPaths;\n\nclass PiniaTPA {\n\n\treadonly #storeId: string;\n\treadonly #store: Store<string, any>;\n\n\t/**\n\t * @deprecated\n\t */\n\treadonly #Page: any;\n\n\treadonly #user: any;\n\treadonly #Api: any;\n\n\treadonly #namesUrlHash: string[] = [];\n\treadonly #namesStorage: string[] = [];\n\treadonly #namesStorageLocal: string[] = [];\n\treadonly #namesGuestLink: string[] = [];\n\n\tconstructor(context: Context) {\n\t\tthis.#store = context.store;\n\t\tthis.#storeId = this.#store.$id;\n\n\t\tthis.#Page = context.options.Page;\n\n\t\tthis.#user = context.options.user;\n\t\tthis.#Api = context.options.Api;\n\n\t\tthis.#namesUrlHash = context.options.tpaNamesUrlHash || [];\n\t\tthis.#namesStorage = context.options.tpaNamesStorage || [];\n\t\tthis.#namesStorageLocal = context.options.tpaNamesStorageLocal || [];\n\t\tthis.#namesGuestLink = context.options.tpaNamesGuestLink || [];\n\n\t\tcontext.store.genGuestLink = <Path extends OpenAPIPath>(url: Path, data: any) => this.genGuestLink(url, data);\n\n\t\tif (!this.#user.guest_data?.data) {\n\t\t\tthis.#loadFromStorage();\n\t\t\tthis.#loadFromStorage(true);\n\n\t\t\t// настройки URL hash имеют приоритет\n\t\t\tthis.#loadFromHash();\n\t\t}\n\n\t\t// настройки гостевой ссылки имеют приоритет\n\t\tthis.#loadFromGuestLink();\n\n\t\tthis.#prepareParams();\n\n\t\tconst save = debounce(() => {\n\t\t\tthis.#saveInHash();\n\t\t\tthis.#saveInStorage();\n\t\t\tthis.#saveInStorage(true);\n\t\t});\n\n\t\tcontext.store.$subscribe(save);\n\t}\n\n\t/**\n\t * Сгенерировать гостевую ссылку\n\t *\n\t * Метод, путь к которому указан в url, должен возвращать сгенерированную ссылку\n\t */\n\tasync genGuestLink<Path extends OpenAPIPath>(url: Path, data: any) {\n\t\tconst dataGuestLink = this.#genOptionsForGuestLink();\n\t\tdata = Object.assign(data, Object.fromEntries(dataGuestLink));\n\n\t\tconst res = await this.#Api.gen(url, 'fetchColumn').call({} as any, data);\n\n\t\t// @ts-ignore - метод, который скачивает файл не возвращает json\n\t\tif (res?.errors) return;\n\n\t\t// @ts-ignore - метод, который скачивает файл не возвращает json\n\t\tawait guestLinkToClipboard(res.result);\n\t}\n\n\t/**\n\t * Сгенерировать опции для гостевой ссылки\n\t */\n\t#genOptionsForGuestLink() {\n\t\tconst data = new Map();\n\n\t\tthis.#namesGuestLink.forEach(name => {\n\t\t\t// формат параметров API: snake_case\n\t\t\tconst nameSnakeCase = camelToSnakeCase(name);\n\t\t\tdata.set(nameSnakeCase, this.#store[name]);\n\t\t});\n\n\t\treturn data;\n\t}\n\n\t/**\n\t * Установить опции из объекта без фиксации состояния\n\t */\n\t#setOptions(data: Map<string, any>) {\n\t\tdata.forEach((value, name) => {\n\t\t\tconst currentValue = this.#store[name];\n\n\t\t\tif (value === null || value === undefined) return;\n\t\t\tif (currentValue === undefined) return;\n\t\t\tif (!value?.constructor) return;\n\t\t\tif (value.constructor !== currentValue.constructor) return;\n\n\t\t\t// дополнительная проверка на формат даты\n\t\t\tif (name.indexOf('date') === 0) {\n\t\t\t\tif (Array.isArray(value)) {\n\t\t\t\t\t// value.forEach((valueI) => {\n\t\t\t\t\t// \tif (!/\\d\\d\\d\\d-\\d\\d-\\d\\d/.test(valueI)) return;\n\t\t\t\t\t// });\n\t\t\t\t} else {\n\t\t\t\t\tif (typeof (value) === 'string') {\n\t\t\t\t\t\tif (!/\\d\\d\\d\\d-\\d\\d-\\d\\d/.test(value)) return;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis.#store[name] = value;\n\t\t});\n\t}\n\n\t/**\n\t * Сгенерировать Map объект с опциями со значениями в виде json строк\n\t */\n\t#genDataFormat(data: Map<string, any>) {\n\t\tconst dataFormatted = new Map();\n\n\t\tdata.forEach((value, name) => {\n\t\t\tif (value === null) return;\n\n\t\t\tvalue = JSON.stringify(value);\n\n\t\t\tdataFormatted.set(name, value);\n\t\t});\n\n\t\treturn dataFormatted;\n\t}\n\n\t/**\n\t * Сгенерировать Map объект с опциями со значениями в оригинальном виде\n\t */\n\t#genDataUnFormat(dataFormatted: Map<string, string>) {\n\t\tconst data: Map<string, any> = new Map();\n\n\t\tdataFormatted.forEach((value, name) => {\n\t\t\tif (value === null || value === undefined || value === 'false') return;\n\n\t\t\ttry {\n\t\t\t\tif (typeof (value) === 'string' && !/^\\d\\d\\d\\d-\\d\\d-\\d\\d$/.test(value)) value = JSON.parse(value);\n\n\t\t\t\tif (value === null || value === undefined || value === 'false') return;\n\t\t\t} catch (e) {\n\t\t\t\t// не json строка\n\t\t\t}\n\n\t\t\tdata.set(name, value);\n\t\t});\n\n\t\treturn data;\n\t}\n\n\t/**\n\t * Установить опции из хеша адреса страницы\n\t */\n\t#loadFromHash() {\n\t\tlet dataHash: any;\n\t\ttry {\n\t\t\tdataHash = JSON.parse(getHash(this.#storeId));\n\t\t} catch (e) {\n\n\t\t}\n\t\tif (!dataHash) return;\n\n\t\tconst data: Map<string, any> = new Map();\n\n\t\tthis.#namesUrlHash.forEach((name) => {\n\t\t\tconst value = dataHash[name];\n\t\t\tif (!value) return;\n\n\t\t\tdata.set(name, value);\n\t\t});\n\n\t\tthis.#setOptions(data);\n\t}\n\n\t/**\n\t * Сохранить опции в хеш адреса страницы\n\t */\n\t#saveInHash() {\n\t\tconst data = new Map();\n\n\t\tthis.#namesUrlHash.forEach((name) => {\n\t\t\tconst value = this.#store[name];\n\n\t\t\tdata.set(name, value);\n\t\t});\n\n\t\tconst dataObject = Object.fromEntries(data);\n\t\tconst dataJSON = JSON.stringify(dataObject);\n\n\t\tsetHash(this.#storeId, dataJSON);\n\t};\n\n\t/**\n\t * Установить опции из localStorage\n\t * @param isLocal - сохранить с учетом адреса страницы\n\t */\n\t#loadFromStorage(isLocal = false) {\n\t\tconst dataFormatted = new Map();\n\n\t\tlet names = this.#namesStorage;\n\t\tlet storageNamespace = 'state:' + this.#storeId;\n\n\t\tif (isLocal) {\n\t\t\tnames = this.#namesStorageLocal;\n\t\t\tstorageNamespace = 'state:' + this.#storeId + ':' + location.pathname;\n\t\t}\n\n\t\tnames.forEach((name) => {\n\t\t\tconst value = localStorage.getItem(storageNamespace + ':' + name);\n\t\t\tdataFormatted.set(name, value);\n\t\t});\n\n\t\tconst data = this.#genDataUnFormat(dataFormatted);\n\n\t\tthis.#setOptions(data);\n\t}\n\n\t/**\n\t * Сохранить опции в localStorage\n\t * @param isLocal - сохранить с учетом адреса страницы\n\t */\n\t#saveInStorage(isLocal = false) {\n\t\tconst data = new Map();\n\n\t\tlet names = this.#namesStorage;\n\t\tlet storageNamespace = 'state:' + this.#storeId;\n\n\t\tif (isLocal) {\n\t\t\tnames = this.#namesStorageLocal;\n\t\t\tstorageNamespace = 'state:' + this.#storeId + ':' + location.pathname;\n\t\t}\n\n\t\tnames.forEach((name) => {\n\t\t\tconst value = this.#store[name];\n\n\t\t\tdata.set(name, value);\n\t\t});\n\n\t\tconst dataFormatted = this.#genDataFormat(data);\n\n\t\tnames.forEach((name) => {\n\t\t\tconst value = dataFormatted.get(name);\n\n\t\t\tlocalStorage.setItem(storageNamespace + ':' + name, value);\n\t\t});\n\t}\n\n\t/**\n\t * Установить опции из гостевой ссылки\n\t */\n\t#loadFromGuestLink() {\n\t\tconst guestData = this.#user?.guest_data?.data;\n\t\tif (!guestData) return;\n\n\t\t// общие правила для гостевых сессий\n\t\tif (this.#user.id === -1) this.#user.positionsReverseDates = guestData.positionsReverseDates;\n\n\t\tconst dataFormatted = new Map();\n\n\t\tthis.#namesGuestLink.forEach((name) => {\n\t\t\tconst value = guestData[name];\n\t\t\tdataFormatted.set(name, value);\n\t\t});\n\n\t\tconst data = this.#genDataUnFormat(dataFormatted);\n\n\t\tthis.#setOptions(data);\n\n\t\tconst $guestTitle = $('.mod_guest_title');\n\n\t\t// TODO: вынести в опции плагина\n\t\tif (this.#store.competitorsIds?.length === 1 && this.#Page.page.data.competitors) {\n\t\t\tlet competitors = this.#Page.page.data.competitors.filter((competitor: any) => competitor.id === guestData.competitorsIds[0]);\n\t\t\tif (competitors.length) {\n\t\t\t\t$('a', $guestTitle).attr('href', 'http://' + competitors[0].url);\n\t\t\t\t$('a', $guestTitle).text(competitors[0].name);\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Подготовить входные параметры перед инициализацией основного функционала\n\t *\n\t * Входные параметры устанавливаются при открытии страницы\n\t *\n\t * Входные параметры могут меняться пользоваталем и устаревать\n\t */\n\t#prepareParams() {\n\t\t// контролль за вводом регионов\n\t\t// TODO: вынести в опции плагина\n\t\tif (this.#store.regionsIndexes) {\n\t\t\twatch(this.#store.regionsIndexes, (regionsIndexes) => {\n\t\t\t\tif (!regionsIndexes.length) return;\n\n\t\t\t\t// приведение типа\n\t\t\t\tregionsIndexes.forEach((regionIndex: number, index: number) => regionsIndexes[index] = regionIndex);\n\n\t\t\t\t// оставить только включенные регионы\n\t\t\t\t// @ts-ignore\n\t\t\t\tconst mapSearchers = TplProjectSelectorRegion.genSearchersMap();\n\n\t\t\t\tconst availableRegionsIndexes: number[] = [];\n\t\t\t\tmapSearchers.forEach((searcher: any) => {\n\t\t\t\t\tsearcher.regions.forEach((region: any) => {\n\t\t\t\t\t\tif (region.index === -1) return;\n\n\t\t\t\t\t\tavailableRegionsIndexes.push(region.index);\n\t\t\t\t\t});\n\t\t\t\t});\n\n\t\t\t\tthis.#store.regionsIndexes = regionsIndexes.filter((regionIndex: number) => availableRegionsIndexes.includes(regionIndex));\n\t\t\t}, { immediate: true });\n\t\t}\n\n\t\t// контролль за вводом конкурентов\n\t\t// TODO: вынести в опции плагина\n\t\tif (this.#store.competitorsIds) {\n\t\t\twatch(this.#store.competitorsIds, (competitorsIds) => {\n\t\t\t\tif (!competitorsIds.length) return;\n\n\t\t\t\t// приведение типа\n\t\t\t\tcompetitorsIds.forEach((competitorId: number, index: number) => competitorsIds[index] = competitorId);\n\n\t\t\t\t// оставить только включенных конкурентов\n\t\t\t\tconst availableCompetitorsIds = [this.#Page.page.data.project.id];\n\t\t\t\tthis.#Page.page.data.project.competitors.forEach((competitor: any) => {\n\t\t\t\t\tif (competitor.on >= 0) availableCompetitorsIds.push(competitor.id);\n\t\t\t\t});\n\n\t\t\t\tthis.#store.competitorsIds = competitorsIds.filter((competitorId: number) => availableCompetitorsIds.includes(competitorId));\n\t\t\t}, { immediate: true });\n\t\t}\n\t}\n\n}\n\ntype Options = {\n\t/**\n\t * TODO: Убрать из плагина\n\t */\n\tPage: any,\n\n\t/**\n\t * Объект с настройками пользователя\n\t */\n\tuser: any,\n\n\t/**\n\t * Объект для работы с API\n\t *\n\t * См. на сайте: @/component/api/core/api.ts\n\t */\n\tApi: any;\n\n\t/**\n\t * Имена свойств для сохранения в URL\n\t */\n\ttpaNamesUrlHash?: string[],\n\n\t/**\n\t * Имена свойств для сохранения в localStorage\n\t */\n\ttpaNamesStorage?: string[],\n\n\t/**\n\t * Имена свойств для сохранения в localStorage с учетом пути URL\n\t *\n\t * Каждый URL будет работать со своим состоянием\n\t */\n\ttpaNamesStorageLocal?: string[],\n\n\t/**\n\t * Имена свойств для работы с гостевой ссылкой\n\t *\n\t * Для генерации гостевой ссылки используйте store.genGuestLink(data, url)\n\t */\n\ttpaNamesGuestLink?: string[],\n};\n\ntype Context = PiniaPluginContext & {\n\toptions: Options\n};\n\n/**\n * Плагин tpa (Third-party access) для pinia\n *\n * Добавляет возможность сохранять и загружать данные в/из:\n * \t- URL hash в адресе страницы\n * \t- localStorage\n * \t- гостевая ссылка\n *\n * Для подключения плагина нужно указань одну или несколько опций при определении defineStore():\n * - tpaNamesUrlHash\n * - tpaNamesStorage\n * - tpaNamesStorageLocal\n * - tpaNamesGuestLink\n */\nexport default (contextPinia: PiniaPluginContext) => {\n\tconst context = contextPinia as Context;\n\n\t// плагин подключать не нужно\n\tif (\n\t\t!context.options.tpaNamesUrlHash?.length &&\n\t\t!context.options.tpaNamesStorage?.length &&\n\t\t!context.options.tpaNamesStorageLocal?.length &&\n\t\t!context.options.tpaNamesGuestLink?.length\n\t) {\n\t\treturn;\n\t}\n\n\tnew PiniaTPA(context);\n}\n"],"names":["PiniaTPA","#storeId","#store","#Page","#user","#Api","context","url","data","#loadFromStorage","save","forms","#saveInStorage","dataGuestLink","#genOptionsForGuestLink","res","utils_clipboard","nameSnakeCase","utils_string","name","currentValue","value","dataFormatted","#loadFromHash","dataHash","utils_route","#setOptions","#saveInHash","dataJSON","isLocal","names","#namesStorage","storageNamespace","#namesStorageLocal","#loadFromGuestLink","guestData","$guestTitle","competitors","competitor","#prepareParams","regionsIndexes","regionIndex","index","mapSearchers","searcher","region","availableRegionsIndexes","competitorsIds","competitorId","availableCompetitorsIds","piniaTPA","contextPinia","_a","_b","_c","_d"],"mappings":"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"}