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

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 (131) hide show
  1. package/.chunks/datepicker-BsNClLc3.amd.js +247 -0
  2. package/.chunks/datepicker-BsNClLc3.amd.js.map +1 -0
  3. package/.chunks/datepicker-DdvHcBwK.es.js +289 -0
  4. package/.chunks/datepicker-DdvHcBwK.es.js.map +1 -0
  5. package/.chunks/{forms-C__H1yL_.amd.js → forms-Bq9qpePc.amd.js} +3 -3
  6. package/.chunks/forms-Bq9qpePc.amd.js.map +1 -0
  7. package/.chunks/{forms-BfIXIMY_.es.js → forms-zcjs34Ku.es.js} +8 -5
  8. package/.chunks/forms-zcjs34Ku.es.js.map +1 -0
  9. package/.chunks/i18n-BNj2m0Og.amd.js +2 -0
  10. package/.chunks/i18n-BNj2m0Og.amd.js.map +1 -0
  11. package/.chunks/i18n-C5qBPql0.es.js +26 -0
  12. package/.chunks/i18n-C5qBPql0.es.js.map +1 -0
  13. package/.chunks/{listItem.vue_vue_type_script_setup_true_lang-CaBP5R7L.amd.js → listItem.vue_vue_type_script_setup_true_lang-63URXfK9.amd.js} +2 -2
  14. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-63URXfK9.amd.js.map +1 -0
  15. package/.chunks/{listItem.vue_vue_type_script_setup_true_lang-DJZS6vRL.es.js → listItem.vue_vue_type_script_setup_true_lang-HyMltrKI.es.js} +2 -2
  16. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-HyMltrKI.es.js.map +1 -0
  17. package/.chunks/{menu-24EpQtdy.es.js → menu-CeG7B_m0.es.js} +2 -2
  18. package/.chunks/menu-CeG7B_m0.es.js.map +1 -0
  19. package/.chunks/{menu-DV1iSTyB.amd.js → menu-DHEklwfD.amd.js} +2 -2
  20. package/.chunks/menu-DHEklwfD.amd.js.map +1 -0
  21. package/.chunks/{popup-BDbiwl2O.amd.js → popup-BGydNG3O.amd.js} +440 -440
  22. package/.chunks/popup-BGydNG3O.amd.js.map +1 -0
  23. package/.chunks/{popup-brcaxiWt.es.js → popup-DCAWoyiY.es.js} +484 -484
  24. package/.chunks/popup-DCAWoyiY.es.js.map +1 -0
  25. package/.chunks/store-Bl79G7T_.amd.js.map +1 -1
  26. package/.chunks/store-PoMCiuBr.es.js.map +1 -1
  27. package/README.md +86 -86
  28. package/assets/forms.css +1 -1
  29. package/core/app.amd.js +1 -1
  30. package/core/app.amd.js.map +1 -1
  31. package/core/app.js +3 -5
  32. package/core/app.js.map +1 -1
  33. package/core/core/core.d.ts +1 -1
  34. package/core/core/state.d.ts +3 -0
  35. package/core/core.amd.js +1 -1
  36. package/core/core.js +1 -1
  37. package/core/plugins/core.d.ts +5 -4
  38. package/core/plugins/i18n.d.ts +2 -2
  39. package/core/utils/dom.d.ts +11 -11
  40. package/forms/forms.amd.js +1 -1
  41. package/forms/forms.js +1 -1
  42. package/forms/helpers.amd.js.map +1 -1
  43. package/forms/helpers.js.map +1 -1
  44. package/formsExt/formsExt.amd.js +1 -1
  45. package/formsExt/formsExt.amd.js.map +1 -1
  46. package/formsExt/formsExt.js +2 -2
  47. package/formsExt/formsExt.js.map +1 -1
  48. package/icomoon/Read Me.txt +7 -7
  49. package/icomoon/demo-files/demo.css +161 -161
  50. package/icomoon/demo-files/demo.js +30 -30
  51. package/icomoon/demo.html +3379 -3379
  52. package/icomoon/fonts/Topvisor-2.svg +263 -263
  53. package/icomoon/style.css +740 -740
  54. package/package.json +36 -36
  55. package/popup/popup.amd.js +1 -1
  56. package/popup/popup.amd.js.map +1 -1
  57. package/popup/popup.js +2 -2
  58. package/popup/popup.js.map +1 -1
  59. package/popup/worker.amd.js +1 -1
  60. package/popup/worker.amd.js.map +1 -1
  61. package/popup/worker.js +2 -2
  62. package/popup/worker.js.map +1 -1
  63. package/project/project.amd.js +1 -1
  64. package/project/project.amd.js.map +1 -1
  65. package/project/project.js +3 -3
  66. package/project/project.js.map +1 -1
  67. package/require/css.amd.js +11 -11
  68. package/tabs/tabs.amd.js +1 -1
  69. package/tabs/tabs.amd.js.map +1 -1
  70. package/tabs/tabs.js +1 -1
  71. package/tabs/tabs.js.map +1 -1
  72. package/tabsView/tabsView.amd.js +1 -1
  73. package/tabsView/tabsView.amd.js.map +1 -1
  74. package/tabsView/tabsView.js +1 -1
  75. package/tabsView/tabsView.js.map +1 -1
  76. package/utils/check.amd.js.map +1 -1
  77. package/utils/check.js.map +1 -1
  78. package/utils/clipboard.amd.js.map +1 -1
  79. package/utils/clipboard.js.map +1 -1
  80. package/utils/css.amd.js.map +1 -1
  81. package/utils/css.js.map +1 -1
  82. package/utils/date.amd.js +1 -1
  83. package/utils/date.js +1 -1
  84. package/utils/device.amd.js +1 -1
  85. package/utils/device.js +1 -1
  86. package/utils/dom.amd.js +1 -1
  87. package/utils/dom.amd.js.map +1 -1
  88. package/utils/dom.js +12 -1
  89. package/utils/dom.js.map +1 -1
  90. package/utils/image.amd.js.map +1 -1
  91. package/utils/image.js.map +1 -1
  92. package/utils/keyboard.amd.js.map +1 -1
  93. package/utils/keyboard.js.map +1 -1
  94. package/utils/number.amd.js.map +1 -1
  95. package/utils/number.js.map +1 -1
  96. package/utils/price.amd.js +1 -1
  97. package/utils/price.amd.js.map +1 -1
  98. package/utils/price.js +2 -2
  99. package/utils/price.js.map +1 -1
  100. package/utils/route.amd.js.map +1 -1
  101. package/utils/route.js.map +1 -1
  102. package/utils/scroll.amd.js +1 -1
  103. package/utils/scroll.amd.js.map +1 -1
  104. package/utils/scroll.js +1 -1
  105. package/utils/scroll.js.map +1 -1
  106. package/utils/string.amd.js +1 -1
  107. package/utils/string.amd.js.map +1 -1
  108. package/utils/string.js +2 -2
  109. package/utils/string.js.map +1 -1
  110. package/utils/system.amd.js.map +1 -1
  111. package/utils/system.js.map +1 -1
  112. package/utils/url.amd.js.map +1 -1
  113. package/utils/url.js.map +1 -1
  114. package/utils/window.amd.js +1 -1
  115. package/utils/window.js +1 -1
  116. package/.chunks/datepicker-Bh_DAFqD.es.js +0 -289
  117. package/.chunks/datepicker-Bh_DAFqD.es.js.map +0 -1
  118. package/.chunks/datepicker-CIbLjf_3.amd.js +0 -247
  119. package/.chunks/datepicker-CIbLjf_3.amd.js.map +0 -1
  120. package/.chunks/forms-BfIXIMY_.es.js.map +0 -1
  121. package/.chunks/forms-C__H1yL_.amd.js.map +0 -1
  122. package/.chunks/i18n-B5a6l_mZ.es.js +0 -23
  123. package/.chunks/i18n-B5a6l_mZ.es.js.map +0 -1
  124. package/.chunks/i18n-CfQopOHM.amd.js +0 -2
  125. package/.chunks/i18n-CfQopOHM.amd.js.map +0 -1
  126. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-CaBP5R7L.amd.js.map +0 -1
  127. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-DJZS6vRL.es.js.map +0 -1
  128. package/.chunks/menu-24EpQtdy.es.js.map +0 -1
  129. package/.chunks/menu-DV1iSTyB.amd.js.map +0 -1
  130. package/.chunks/popup-BDbiwl2O.amd.js.map +0 -1
  131. package/.chunks/popup-brcaxiWt.es.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"app.amd.js","sources":["../../src/core/directives/focus.ts","../../src/core/directives/sticky.ts","../../src/core/directives/swimUp.ts","../../src/core/directives/tooltip.ts","../../src/core/plugins/core.ts","../../src/core/plugins/piniaTPA.ts"],"sourcesContent":["import type { DirectiveBinding, ObjectDirective } from 'vue';\r\n\r\n/**\r\n * Фокусировка на элементе сразу после его отображения\r\n */\r\nconst focus = {\r\n\tmounted: function (el: HTMLElement, binding: DirectiveBinding) {\r\n\t\tif (binding.value || binding.value === undefined) el.focus();\r\n\t}\r\n} satisfies ObjectDirective;\r\n\r\nexport default focus;\r\n","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\r\n\r\nlet appStickyObserver: IntersectionObserver;\r\n\r\n/**\r\n * Добавление sticky\r\n * К элементу добляется класс переданный как значение диррективы либо **'top-sticky'** по умолчанию\r\n */\r\nconst sticky = {\r\n\tmounted(el: HTMLElement, binding: DirectiveBinding, _vnode: VNode){\r\n\t\tconst className = binding.value || 'top-sticky';\r\n\r\n\t\tappStickyObserver = new IntersectionObserver(entries => {\r\n\t\t\tlet condition = entries[0].intersectionRatio < 1;\r\n\t\t\tif(condition){\r\n\t\t\t\tif(binding.arg === 'bottom' && entries[0].intersectionRect.y === 0) condition = false;\r\n\t\t\t}\r\n\r\n\t\t\tel.classList.toggle(className, condition);\r\n\t\t}, {\r\n\t\t\tthreshold:[1]\r\n\t\t});\r\n\r\n\t\tappStickyObserver.observe(el);\r\n\t},\r\n\r\n\tunmounted(_el: HTMLElement, _binding: DirectiveBinding, _vnode: VNode){\r\n\t\tappStickyObserver?.disconnect();\r\n\t},\r\n} satisfies ObjectDirective;\r\n\r\nexport default sticky;","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\r\nimport Core from '@/core/core/core';\r\n\r\ninterface SwipUpOptions {\r\n\tdistance: number,\r\n\tpercent: number,\r\n}\r\n\r\nlet appSwimUpInited = false;\r\nlet appSwimUpObserver: IntersectionObserver;\r\nlet directiveSwipUpOptions: SwipUpOptions;\r\nconst appSwimUpEls = new Map();\r\n\r\n\r\n/**\r\n * Отодвинуть блок в зависимости от скролла старинцы\r\n * @param el\r\n * @param windowHeight\r\n */\r\nconst swimUpElTransform = (el: HTMLElement, windowHeight: number): void => {\r\n\tconst { distance, percent } = directiveSwipUpOptions;\r\n\r\n\tconst elTop = el.getBoundingClientRect().top;\r\n\r\n\t// во столько раз triggerHeight должен быть меньше, чтобы закончить подплытие к нужной высоте экрана\r\n\tconst triggerHeightReducer = windowHeight * percent / 100 / distance;\r\n\tconst triggerHeight = (windowHeight - elTop) / triggerHeightReducer;\r\n\r\n\tif (triggerHeight <= distance) {\r\n\t\tel.style.transform = `translateY(${distance - triggerHeight}px)`;\r\n\t} else {\r\n\t\tel.style.transform = 'translateY(0px)';\r\n\t}\r\n}\r\n\r\nconst swimUpInit = (el: HTMLElement): void => {\r\n\tlet windowHeight = window.innerHeight;\r\n\r\n\twindow.addEventListener('scroll', () => {\r\n\t\tappSwimUpEls.forEach((el) => swimUpElTransform(el, windowHeight));\r\n\t}, { passive: true });\r\n\r\n\t// проверка того, что элемент в зоне видимости\r\n\tappSwimUpObserver = new IntersectionObserver(entries => {\r\n\t\twindowHeight = window.innerHeight;\r\n\r\n\t\tentries.forEach((entry) => {\r\n\t\t\tconst el = entry.target as HTMLElement;\r\n\r\n\t\t\tif (entry.intersectionRatio < 0.1) {\r\n\t\t\t\t// элемент за областью видимости\r\n\t\t\t\tappSwimUpEls.delete(el);\r\n\t\t\t} else {\r\n\t\t\t\t// элемент на экране\r\n\t\t\t\tappSwimUpEls.set(el, el);\r\n\t\t\t}\r\n\r\n\t\t\tif (entry.intersectionRatio === 0) {\r\n\t\t\t\tconst { distance, percent } = directiveSwipUpOptions;\r\n\t\t\t\tel.style.transform = `translateY(${distance}px)`;\r\n\t\t\t}\r\n\t\t});\r\n\t}, {\r\n\t\tthreshold: 0.1,\r\n\t});\r\n}\r\n\r\n/**\r\n * Добавление анимации подплытия вверх для блока\r\n */\r\nconst swimUp = {\r\n\tmounted(el: HTMLElement, binding: DirectiveBinding, _vnode: VNode): void {\r\n\t\tif (Core.state.isMobileUA) return;\r\n\r\n\t\tconst args = binding.arg?.split(':');\r\n\r\n\t\tlet distance = Number(args?.[0] ?? 100); // количество px на которые блок изначально смещен вниз\r\n\t\tlet percent = Number(args?.[1] ?? 30); // процент высоты экрана поднявшись на который блок закончит подплытие\r\n\r\n\t\tdirectiveSwipUpOptions = {\r\n\t\t\tdistance,\r\n\t\t\tpercent\r\n\t\t}\r\n\r\n\t\tif (!appSwimUpInited) {\r\n\t\t\tswimUpInit(el);\r\n\r\n\t\t\tappSwimUpInited = true;\r\n\t\t}\r\n\r\n\t\tappSwimUpObserver.observe(el);\r\n\t},\r\n\r\n\tunmounted(el: HTMLElement, _binding: DirectiveBinding, _vnode: VNode) {\r\n\t\tappSwimUpEls.delete(el);\r\n\t\tappSwimUpObserver?.unobserve(el);\r\n\t}\r\n} satisfies ObjectDirective;\r\n\r\nexport default swimUp;","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\r\nimport Core from '@/core/core/core';\r\n\r\nconst $ = (el: VNode) => {\r\n\tif (!Core.$?.ui?.tooltip) {\r\n\t\tconsole.info('Для работы v-top-tooltip требуется глобальная загрузка jQuery UI Tooltip');\r\n\r\n\t\treturn;\r\n\t}\r\n\r\n\treturn Core.$(el);\r\n};\r\n\r\nconst tvTooltipGenOptions = (binding: DirectiveBinding, vnode: VNode) => {\r\n\tconst options = binding.value ?? {};\r\n\r\n\toptions.content ??= vnode.props?.title;\r\n\toptions.content = String(options.content).replace(/\\r\\n|\\r|\\n/g, '<br>');\r\n\r\n\toptions.position ??= {\r\n\t\tmy: 'bottom-18px',\r\n\t\tat: 'top center',\r\n\t};\r\n\r\n\treturn options;\r\n};\r\n\r\n/**\r\n * Добавление всплывающей подсказки к элементу.\r\n */\r\nconst tooltip = {\r\n\tmounted(el: VNode, binding: DirectiveBinding, vnode: VNode) {\r\n\t\t$(el)?.tooltip(tvTooltipGenOptions(binding, vnode));\r\n\t},\r\n\r\n\tupdated(el: VNode, binding: DirectiveBinding, vnode: VNode, _prevVnode: VNode) {\r\n\t\t/**\r\n\t\t * В результате обновления может быть открыто несколько тултипов поэтому изменить опции, без перерисовки тултипа\r\n\t\t */\r\n\t\tconst options = tvTooltipGenOptions(binding, vnode);\r\n\t\tconst instance = $(el)?.tooltip('instance') as { options: JQueryUI.TooltipOptions } | undefined;\r\n\t\tif (!instance) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tinstance.options = {\r\n\t\t\t...instance.options,\r\n\t\t\t...options,\r\n\t\t};\r\n\t},\r\n\r\n\tunmounted(el: VNode, _binding: DirectiveBinding, _vnode: VNode) {\r\n\t\t$(el)?.tooltip('destroy');\r\n\t},\r\n} satisfies ObjectDirective;\r\n\r\nexport default tooltip;","import type { Plugin } from 'vue';\r\nimport Core from '@/core/core/core';\r\nimport coreDefaultOptions from '@/core/core/options';\r\nimport * as Forms from '../../components/forms/forms';\r\nimport directiveFocus from '@/core/directives/focus';\r\nimport directiveSticky from '@/core/directives/sticky';\r\nimport directiveSwimUp from '@/core/directives/swimUp';\r\nimport directiveTooltip from '@/core/directives/tooltip';\r\n\r\ndeclare module 'vue' {\r\n\texport interface ComponentCustomProperties {\r\n\t\t$top: {\r\n\t\t\tCore: typeof Core\r\n\t\t};\r\n\t}\r\n\r\n\t/**\r\n\t * Обязательные компоненты UI\r\n\t *\r\n\t * Они подключаются через плагин и доступны без явного указания импорта\r\n\t */\r\n\texport interface GlobalComponents {\r\n\t\tTopAvatar: typeof Forms.TopAvatar;\r\n\t\tTopButton: typeof Forms.TopButton;\r\n\t\tTopCheckbox: typeof Forms.TopCheckbox;\r\n\t\tTopControlLabel: typeof Forms.TopControlLabel;\r\n\t\tTopHint: typeof Forms.TopHint;\r\n\t\tTopInput: typeof Forms.TopInput;\r\n\t\tTopInputDate: typeof Forms.TopInputDate;\r\n\t\tTopInputRange: typeof Forms.TopInputRange;\r\n\t\tTopRadio: typeof Forms.TopRadio;\r\n\t\tTopSwitcher: typeof Forms.TopSwitcher;\r\n\t\tTopTextarea: typeof Forms.TopTextarea;\r\n\t\tTopSelect: typeof Forms.TopSelect;\r\n\t\tTopLoadbar: typeof Forms.TopLoadbar;\r\n\t}\r\n}\r\n\r\ntype PartialBy<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;\r\n\r\ntype Options = PartialBy<typeof coreDefaultOptions, 'gmt'>;\r\n\r\n/**\r\n * Плагин для интеграции UI во Vue приложение\r\n *\r\n * - В глобальную область видимости шаблонов будет добавлен объект $top\r\n * - Будут зарегистрирвоаны директивы UI: https://ui.topvisor.com/?path=/docs/core-directives-focus--docs\r\n * - Будут подключены базовые компоненты UI/Forms: https://ui.topvisor.com/?path=/docs/components-forms-readme--docs\r\n */\r\nexport default {\r\n\r\n\tinstall: (app, options: Options) => {\r\n\t\tapp.config.globalProperties.$top = {\r\n\t\t\tCore,\r\n\t\t};\r\n\r\n\t\t// начальные настройки UI\r\n\t\tfor (const name in options) {\r\n\t\t\tCore.state[name] = options[name];\r\n\t\t}\r\n\r\n\t\tCore.setState();\r\n\r\n\t\t// определение директив\r\n\t\tapp.directive('top-focus', directiveFocus);\r\n\t\tapp.directive('top-sticky', directiveSticky);\r\n\t\tapp.directive('top-swim-up', directiveSwimUp);\r\n\t\tapp.directive('top-tooltip', directiveTooltip);\r\n\r\n\t\t// определение базовых компонентов\r\n\t\tapp.component('TopAvatar', Forms.TopAvatar);\r\n\t\tapp.component('TopButton', Forms.TopButton);\r\n\t\tapp.component('TopCheckbox', Forms.TopCheckbox);\r\n\t\tapp.component('TopControlLabel', Forms.TopControlLabel);\r\n\t\tapp.component('TopHint', Forms.TopHint);\r\n\t\tapp.component('TopInput', Forms.TopInput);\r\n\t\tapp.component('TopInputDate', Forms.TopInputDate);\r\n\t\tapp.component('TopInputRange', Forms.TopInputRange);\r\n\t\tapp.component('TopLoadbar', Forms.TopLoadbar);\r\n\t\tapp.component('TopRadio', Forms.TopRadio);\r\n\t\tapp.component('TopSelect', Forms.TopSelect);\r\n\t\tapp.component('TopSwitcher', Forms.TopSwitcher);\r\n\t\tapp.component('TopTextarea', Forms.TopTextarea);\r\n\r\n\t},\r\n\r\n} satisfies Plugin<Options>;\r\n\r\n// export {\r\n// \tdirectiveFocus,\r\n// \tdirectiveSticky,\r\n// \tdirectiveSwimUp,\r\n// \tdirectiveTooltip,\r\n// };\r\n","import type { PiniaPluginContext, Store } from 'pinia';\r\nimport { watch } from 'vue';\r\nimport { debounce } from 'lodash';\r\nimport { setClipboard } from '@/core/utils/clipboard';\r\nimport { camelToSnakeCase } from '@/core/utils/string.js';\r\nimport type { paths as OpenAPIPaths } from 'topvisor-openapi/src/ts/Topvisor';\r\nimport { getHash, setHash } from '@/core/utils/route';\r\n\r\ntype OpenAPIPath = keyof OpenAPIPaths;\r\n\r\nclass PiniaTPA {\r\n\r\n\treadonly #storeId: string;\r\n\treadonly #store: Store<'test', any>;\r\n\r\n\t/**\r\n\t * @deprecated\r\n\t */\r\n\treadonly #Page: any;\r\n\r\n\treadonly #user: any;\r\n\treadonly #Api: any;\r\n\r\n\treadonly #namesUrlHash: string[] = [];\r\n\treadonly #namesStorage: string[] = [];\r\n\treadonly #namesStorageLocal: string[] = [];\r\n\treadonly #namesGuestLink: string[] = [];\r\n\r\n\tconstructor(context: Context) {\r\n\t\tthis.#store = context.store;\r\n\t\tthis.#storeId = this.#store.$id;\r\n\r\n\t\tthis.#Page = context.options.Page;\r\n\r\n\t\tthis.#user = context.options.user;\r\n\t\tthis.#Api = context.options.Api;\r\n\r\n\t\tthis.#namesUrlHash = context.options.tpaNamesUrlHash || [];\r\n\t\tthis.#namesStorage = context.options.tpaNamesStorage || [];\r\n\t\tthis.#namesStorageLocal = context.options.tpaNamesStorageLocal || [];\r\n\t\tthis.#namesGuestLink = context.options.tpaNamesGuestLink || [];\r\n\r\n\t\tcontext.store.genGuestLink = <Path extends OpenAPIPath>(url: Path, data: any) => this.genGuestLink(url, data);\r\n\r\n\t\tif (!this.#user.guest_data?.data) {\r\n\t\t\tthis.#loadFromStorage();\r\n\t\t\tthis.#loadFromStorage(true);\r\n\r\n\t\t\t// настройки URL hash имеют приоритет\r\n\t\t\tthis.#loadFromHash();\r\n\t\t}\r\n\r\n\t\t// настройки гостевой ссылки имеют приоритет\r\n\t\tthis.#loadFromGuestLink();\r\n\r\n\t\tthis.#prepareParams();\r\n\r\n\t\tconst save = debounce(() => {\r\n\t\t\tthis.#saveInHash();\r\n\t\t\tthis.#saveInStorage();\r\n\t\t});\r\n\r\n\t\tcontext.store.$subscribe(save);\r\n\t}\r\n\r\n\t/**\r\n\t * Сгенерировать гостевую ссылку\r\n\t *\r\n\t * Метод, путь к которому указан в url, должен возвращать сгенерированную ссылку\r\n\t */\r\n\tasync genGuestLink<Path extends OpenAPIPath>(url: Path, data: any) {\r\n\t\tconst dataGuestLink = this.#genOptionsForGuestLink();\r\n\t\tdata = Object.assign(data, Object.fromEntries(dataGuestLink));\r\n\r\n\t\tconst res = await this.#Api.gen(url, 'fetchColumn').call({} as any, data);\r\n\r\n\t\t// @ts-ignore - метод, который скачивает файл не возвращает json\r\n\t\tif (res?.errors) return;\r\n\r\n\t\t// @ts-ignore - метод, который скачивает файл не возвращает json\r\n\t\tawait setClipboard(res.result);\r\n\r\n\t\t// TODO: Оформить через компонент messages\r\n\t\talert('Link copied');\r\n\t}\r\n\r\n\t/**\r\n\t * Сгенерировать опции для гостевой ссылки\r\n\t */\r\n\t#genOptionsForGuestLink() {\r\n\t\tconst data = new Map();\r\n\r\n\t\tthis.#namesGuestLink.forEach(name => {\r\n\t\t\t// формат параметров API: snake_case\r\n\t\t\tconst nameSnakeCase = camelToSnakeCase(name);\r\n\t\t\tdata.set(nameSnakeCase, this.#store[name]);\r\n\t\t});\r\n\r\n\t\treturn data;\r\n\t}\r\n\r\n\t/**\r\n\t * Установить опции из объекта без фиксации состояния\r\n\t */\r\n\t#setOptions(data: Map<string, any>) {\r\n\t\tif (Object.isFrozen(this)) throw 'Please, use setOptions only inner commit function';\r\n\r\n\t\tdata.forEach((value, name) => {\r\n\t\t\tconst currentValue = this.#store[name];\r\n\r\n\t\t\tif (value === null || value === undefined) return;\r\n\t\t\tif (!value?.constructor) return;\r\n\t\t\tif (value.constructor !== currentValue.constructor) return;\r\n\r\n\t\t\t// дополнительная проверка на формат даты\r\n\t\t\tif (name.indexOf('date') === 0) {\r\n\t\t\t\tif (Array.isArray(value)) {\r\n\t\t\t\t\t// value.forEach((valueI) => {\r\n\t\t\t\t\t// \tif (!/\\d\\d\\d\\d-\\d\\d-\\d\\d/.test(valueI)) return;\r\n\t\t\t\t\t// });\r\n\t\t\t\t} else {\r\n\t\t\t\t\tif (typeof (value) === 'string') {\r\n\t\t\t\t\t\tif (!/\\d\\d\\d\\d-\\d\\d-\\d\\d/.test(value)) return;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t\tthis.#store[name] = value;\r\n\t\t});\r\n\t}\r\n\r\n\t/**\r\n\t * Сгенерировать Map объект с опциями со значениями в виде json строк\r\n\t */\r\n\t#genDataFormat(data: Map<string, any>) {\r\n\t\tconst dataFormatted = new Map();\r\n\r\n\t\tdata.forEach((value, name) => {\r\n\t\t\tif (value === null) return;\r\n\r\n\t\t\tvalue = JSON.stringify(value);\r\n\r\n\t\t\tdataFormatted.set(name, value);\r\n\t\t});\r\n\r\n\t\treturn dataFormatted;\r\n\t}\r\n\r\n\t/**\r\n\t * Сгенерировать Map объект с опциями со значениями в оригинальном виде\r\n\t */\r\n\t#genDataUnFormat(dataFormatted: Map<string, string>) {\r\n\t\tconst data: Map<string, any> = new Map();\r\n\r\n\t\tdataFormatted.forEach((value, name) => {\r\n\t\t\tif (value === null || value === undefined || value === 'false') return;\r\n\r\n\t\t\ttry {\r\n\t\t\t\tif (typeof (value) === 'string' && !/^\\d\\d\\d\\d-\\d\\d-\\d\\d$/.test(value)) value = JSON.parse(value);\r\n\r\n\t\t\t\tif (value === null || value === undefined || value === 'false') return;\r\n\t\t\t} catch (e) {\r\n\t\t\t\t// не json строка\r\n\t\t\t}\r\n\r\n\t\t\tdata.set(name, value);\r\n\t\t});\r\n\r\n\t\treturn data;\r\n\t}\r\n\r\n\t/**\r\n\t * Установить опции из хеша адреса страницы\r\n\t */\r\n\t#loadFromHash() {\r\n\t\tlet dataHash: any;\r\n\t\ttry {\r\n\t\t\tdataHash = JSON.parse(getHash(this.#storeId));\r\n\t\t} catch (e) {\r\n\r\n\t\t}\r\n\t\tif (!dataHash) return;\r\n\r\n\t\tconst dataFormatted: Map<string, any> = new Map();\r\n\r\n\t\tthis.#namesUrlHash.forEach((name) => {\r\n\t\t\tconst value = dataHash[name];\r\n\t\t\tif (!value) return;\r\n\r\n\t\t\tdataFormatted.set(name, value);\r\n\t\t});\r\n\r\n\t\tconst data = this.#genDataUnFormat(dataFormatted);\r\n\r\n\t\tthis.#setOptions(data);\r\n\t}\r\n\r\n\t/**\r\n\t * Сохранить опции в хеш адреса страницы\r\n\t */\r\n\t#saveInHash() {\r\n\t\tconst data = new Map();\r\n\r\n\t\tthis.#namesUrlHash.forEach((name) => {\r\n\t\t\tconst value = this.#store[name];\r\n\r\n\t\t\tdata.set(name, value);\r\n\t\t});\r\n\r\n\t\tconst dataObject = Object.fromEntries(data);\r\n\t\tconst dataJSON = JSON.stringify(dataObject);\r\n\r\n\t\tsetHash(this.#storeId, dataJSON);\r\n\t};\r\n\r\n\t/**\r\n\t * Установить опции из localStorage\r\n\t * @param isLocal - сохранить с учетом адреса страницы\r\n\t */\r\n\t#loadFromStorage(isLocal = false) {\r\n\t\tconst dataFormatted = new Map();\r\n\r\n\t\t// let names = this.#namesStorage;\r\n\t\tlet storageNamespace = 'state:' + this.#storeId;\r\n\r\n\t\tif (isLocal) {\r\n\t\t\t// names = this.#namesStorageLocal;\r\n\t\t\tstorageNamespace = 'state:' + this.#storeId + ':' + location.pathname;\r\n\t\t}\r\n\r\n\t\tthis.#namesStorage.forEach((name) => {\r\n\t\t\tconst value = localStorage.getItem(storageNamespace + ':' + name);\r\n\t\t\tdataFormatted.set(name, value);\r\n\t\t});\r\n\r\n\t\tconst data = this.#genDataUnFormat(dataFormatted);\r\n\r\n\t\tthis.#setOptions(data);\r\n\t}\r\n\r\n\t/**\r\n\t * Сохранить опции в localStorage\r\n\t * @param isLocal - сохранить с учетом адреса страницы\r\n\t */\r\n\t#saveInStorage(isLocal = false) {\r\n\t\tconst data = new Map();\r\n\r\n\t\tlet names = this.#namesStorage;\r\n\t\tlet storageNamespace = 'state:' + this.#storeId;\r\n\r\n\t\tif (isLocal) {\r\n\t\t\tnames = this.#namesStorageLocal;\r\n\t\t\tstorageNamespace = 'state:' + this.#storeId + ':' + location.pathname;\r\n\t\t}\r\n\r\n\t\tnames.forEach((name) => {\r\n\t\t\tconst value = this.#store[name];\r\n\r\n\t\t\tdata.set(name, value);\r\n\t\t});\r\n\r\n\t\tconst dataFormatted = this.#genDataFormat(data);\r\n\r\n\t\tnames.forEach((name) => {\r\n\t\t\tconst value = dataFormatted.get(name);\r\n\r\n\t\t\tlocalStorage.setItem(storageNamespace + ':' + name, value);\r\n\t\t});\r\n\t}\r\n\r\n\t/**\r\n\t * Установить опции из гостевой ссылки\r\n\t */\r\n\t#loadFromGuestLink() {\r\n\t\tconst guestData = this.#user?.guest_data?.data;\r\n\t\tif (!guestData) return;\r\n\r\n\t\t// общие правила для гостевых сессий\r\n\t\tif (this.#user.id === -1) this.#user.positionsReverseDates = guestData.positionsReverseDates;\r\n\r\n\t\tconst dataFormatted = new Map();\r\n\r\n\t\tthis.#namesGuestLink.forEach((name) => {\r\n\t\t\tconst value = guestData[name];\r\n\t\t\tdataFormatted.set(name, value);\r\n\t\t});\r\n\r\n\t\tconst data = this.#genDataUnFormat(dataFormatted);\r\n\r\n\t\tthis.#setOptions(data);\r\n\r\n\t\tconst $guestTitle = $('.mod_guest_title');\r\n\r\n\t\t// TODO: вынести в опции плагина\r\n\t\tif (this.#store.competitorsIds?.length === 1 && this.#Page.page.data.competitors) {\r\n\t\t\tlet competitors = this.#Page.page.data.competitors.filter((competitor: any) => competitor.id === guestData.competitorsIds[0]);\r\n\t\t\tif (competitors.length) {\r\n\t\t\t\t$('a', $guestTitle).attr('href', 'http://' + competitors[0].url);\r\n\t\t\t\t$('a', $guestTitle).text(competitors[0].name);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t * Подготовить входные параметры перед инициализацией основного функционала\r\n\t *\r\n\t * Входные параметры устанавливаются при открытии страницы\r\n\t *\r\n\t * Входные параметры могут меняться пользоваталем и устаревать\r\n\t */\r\n\t#prepareParams() {\r\n\t\t// контролль за вводом регионов\r\n\t\t// TODO: вынести в опции плагина\r\n\t\tif (this.#store.regionsIndexes) {\r\n\t\t\twatch(this.#store, (regionsIndexes) => {\r\n\t\t\t\tif (!regionsIndexes.length) return;\r\n\r\n\t\t\t\t// приведение типа\r\n\t\t\t\tregionsIndexes.forEach((regionIndex: number, index: number) => regionsIndexes[index] = regionIndex);\r\n\r\n\t\t\t\t// оставить только включенные регионы\r\n\t\t\t\t// @ts-ignore\r\n\t\t\t\tconst mapSearchers = TplProjectSelectorRegion.genSearchersMap();\r\n\r\n\t\t\t\tconst availableRegionsIndexes: number[] = [];\r\n\t\t\t\tmapSearchers.forEach((searcher: any) => {\r\n\t\t\t\t\tsearcher.regions.forEach((region: any) => {\r\n\t\t\t\t\t\tif (region.index === -1) return;\r\n\r\n\t\t\t\t\t\tavailableRegionsIndexes.push(region.index);\r\n\t\t\t\t\t});\r\n\t\t\t\t});\r\n\r\n\t\t\t\tthis.#store.regionsIndexes = regionsIndexes.filter((regionIndex: number) => availableRegionsIndexes.includes(regionIndex));\r\n\t\t\t}, { immediate: true });\r\n\t\t}\r\n\r\n\t\t// контролль за вводом конкурентов\r\n\t\t// TODO: вынести в опции плагина\r\n\t\tif (this.#store.competitorsIds) {\r\n\t\t\twatch(this.#store, (competitorsIds) => {\r\n\t\t\t\tif (!competitorsIds.length) return;\r\n\r\n\t\t\t\t// приведение типа\r\n\t\t\t\tcompetitorsIds.forEach((competitorId: number, index: number) => competitorId[index] = competitorId);\r\n\r\n\t\t\t\t// оставить только включенных конкурентов\r\n\t\t\t\tconst availableCompetitorsIds = [this.#Page.page.data.project.id];\r\n\t\t\t\tthis.#Page.page.data.project.competitors.forEach((competitor: any) => {\r\n\t\t\t\t\tif (competitor.on >= 0) availableCompetitorsIds.push(competitor.id);\r\n\t\t\t\t});\r\n\r\n\t\t\t\tthis.#store.competitorsIds = competitorsIds.filter((competitorId: number) => availableCompetitorsIds.includes(competitorId));\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\r\n}\r\n\r\ntype Options = {\r\n\t/**\r\n\t * TODO: Убрать из плагина\r\n\t */\r\n\tPage: any,\r\n\r\n\t/**\r\n\t * Объект с настройками пользователя\r\n\t */\r\n\tuser: any,\r\n\r\n\t/**\r\n\t * Объект для работы с API\r\n\t *\r\n\t * См. на айте: @/component/api/core/api.ts\r\n\t */\r\n\tApi: any;\r\n\r\n\t/**\r\n\t * Имена свойств для сохранения в URL\r\n\t */\r\n\ttpaNamesUrlHash?: string[],\r\n\r\n\t/**\r\n\t * Имена свойств для сохранения в localStorage\r\n\t */\r\n\ttpaNamesStorage?: string[],\r\n\r\n\t/**\r\n\t * Имена свойств для сохранения в localStorage с учетом пути URL\r\n\t *\r\n\t * Каждый URL будет работать со своим состоянием\r\n\t */\r\n\ttpaNamesStorageLocal?: string[],\r\n\r\n\t/**\r\n\t * Имена свойств для работы с гостевой ссылкой\r\n\t *\r\n\t * Для генерации гостевой ссылки используйте store.genGuestLink(data, url)\r\n\t */\r\n\ttpaNamesGuestLink?: string[],\r\n};\r\n\r\ntype Context = PiniaPluginContext & {\r\n\toptions: Options\r\n};\r\n\r\n/**\r\n * Плагин tpa (Third-party access) для pinia\r\n *\r\n * Добавляет возможсноть сохранять и загружать данные в/из:\r\n * \t- localStorage\r\n * \t- URL hash\r\n * \t- гостевая ссылка\r\n *\r\n * Для подключение плагина нужно указань одну или несколько опций при defineStore():\r\n * - tpaNamesUrlHash: Array\r\n * - tpaNamesStorage: Array\r\n * - tpaNamesStorageLocal: Array\r\n * - tpaNamesGuestLink: Array\r\n */\r\nexport default (contextPinia: PiniaPluginContext) => {\r\n\tconst context = contextPinia as Context;\r\n\r\n\t// плагин подключать не нужно\r\n\tif (\r\n\t\t!context.options.tpaNamesUrlHash?.length &&\r\n\t\t!context.options.tpaNamesStorage?.length &&\r\n\t\t!context.options.tpaNamesStorageLocal?.length &&\r\n\t\t!context.options.tpaNamesGuestLink?.length\r\n\t) {\r\n\t\treturn;\r\n\t}\r\n\r\n\tnew PiniaTPA(context);\r\n}\r\n"],"names":["focus","el","binding","appStickyObserver","sticky","_vnode","entries","_el","_binding","appSwimUpObserver","directiveSwipUpOptions","appSwimUpEls","swimUpElTransform","windowHeight","triggerHeight","distance","swimUpInit","el2","entry","swimUp","forms","args","percent","$$1","tvTooltipGenOptions","vnode","options","tooltip","_a","instance","core","app","name","PiniaTPA","#storeId","#store","#Page","#user","#Api","context","url","data","#loadFromStorage","#loadFromHash","#loadFromGuestLink","#prepareParams","save","lodash","#saveInHash","#saveInStorage","dataGuestLink","#genOptionsForGuestLink","res","utils_clipboard","nameSnakeCase","utils_string","value","dataFormatted","dataHash","utils_route","#setOptions","isLocal","storageNamespace","names","#namesStorage","#namesStorageLocal","guestData","$guestTitle","competitors","competitor","regionsIndexes","regionIndex","index","mapSearchers","availableRegionsIndexes","searcher","competitorsIds","competitorId","availableCompetitorsIds","piniaTPA","contextPinia","_b","_c","_d"],"mappings":"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"}
1
+ {"version":3,"file":"app.amd.js","sources":["../../src/core/directives/focus.ts","../../src/core/directives/sticky.ts","../../src/core/directives/swimUp.ts","../../src/core/directives/tooltip.ts","../../src/core/plugins/core.ts","../../src/core/plugins/piniaTPA.ts"],"sourcesContent":["import type { DirectiveBinding, ObjectDirective } from 'vue';\n\n/**\n * Фокусировка на элементе сразу после его отображения\n */\nconst focus = {\n\tmounted: function (el: HTMLElement, binding: DirectiveBinding) {\n\t\tif (binding.value || binding.value === undefined) el.focus();\n\t}\n} satisfies ObjectDirective;\n\nexport default focus;\n","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\n\nlet appStickyObserver: IntersectionObserver;\n\n/**\n * Добавление sticky\n * К элементу добляется класс переданный как значение диррективы либо **'top-sticky'** по умолчанию\n */\nconst sticky = {\n\tmounted(el: HTMLElement, binding: DirectiveBinding, _vnode: VNode){\n\t\tconst className = binding.value || 'top-sticky';\n\n\t\tappStickyObserver = new IntersectionObserver(entries => {\n\t\t\tlet condition = entries[0].intersectionRatio < 1;\n\t\t\tif(condition){\n\t\t\t\tif(binding.arg === 'bottom' && entries[0].intersectionRect.y === 0) condition = false;\n\t\t\t}\n\n\t\t\tel.classList.toggle(className, condition);\n\t\t}, {\n\t\t\tthreshold:[1]\n\t\t});\n\n\t\tappStickyObserver.observe(el);\n\t},\n\n\tunmounted(_el: HTMLElement, _binding: DirectiveBinding, _vnode: VNode){\n\t\tappStickyObserver?.disconnect();\n\t},\n} satisfies ObjectDirective;\n\nexport default sticky;","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\nimport Core from '@/core/core/core';\n\ninterface SwipUpOptions {\n\tdistance: number,\n\tpercent: number,\n}\n\nlet appSwimUpInited = false;\nlet appSwimUpObserver: IntersectionObserver;\nlet directiveSwipUpOptions: SwipUpOptions;\nconst appSwimUpEls = new Map();\n\n\n/**\n * Отодвинуть блок в зависимости от скролла старинцы\n * @param el\n * @param windowHeight\n */\nconst swimUpElTransform = (el: HTMLElement, windowHeight: number): void => {\n\tconst { distance, percent } = directiveSwipUpOptions;\n\n\tconst elTop = el.getBoundingClientRect().top;\n\n\t// во столько раз triggerHeight должен быть меньше, чтобы закончить подплытие к нужной высоте экрана\n\tconst triggerHeightReducer = windowHeight * percent / 100 / distance;\n\tconst triggerHeight = (windowHeight - elTop) / triggerHeightReducer;\n\n\tif (triggerHeight <= distance) {\n\t\tel.style.transform = `translateY(${distance - triggerHeight}px)`;\n\t} else {\n\t\tel.style.transform = 'translateY(0px)';\n\t}\n}\n\nconst swimUpInit = (el: HTMLElement): void => {\n\tlet windowHeight = window.innerHeight;\n\n\twindow.addEventListener('scroll', () => {\n\t\tappSwimUpEls.forEach((el) => swimUpElTransform(el, windowHeight));\n\t}, { passive: true });\n\n\t// проверка того, что элемент в зоне видимости\n\tappSwimUpObserver = new IntersectionObserver(entries => {\n\t\twindowHeight = window.innerHeight;\n\n\t\tentries.forEach((entry) => {\n\t\t\tconst el = entry.target as HTMLElement;\n\n\t\t\tif (entry.intersectionRatio < 0.1) {\n\t\t\t\t// элемент за областью видимости\n\t\t\t\tappSwimUpEls.delete(el);\n\t\t\t} else {\n\t\t\t\t// элемент на экране\n\t\t\t\tappSwimUpEls.set(el, el);\n\t\t\t}\n\n\t\t\tif (entry.intersectionRatio === 0) {\n\t\t\t\tconst { distance, percent } = directiveSwipUpOptions;\n\t\t\t\tel.style.transform = `translateY(${distance}px)`;\n\t\t\t}\n\t\t});\n\t}, {\n\t\tthreshold: 0.1,\n\t});\n}\n\n/**\n * Добавление анимации подплытия вверх для блока\n */\nconst swimUp = {\n\tmounted(el: HTMLElement, binding: DirectiveBinding, _vnode: VNode): void {\n\t\tif (Core.state.isMobileUA) return;\n\n\t\tconst args = binding.arg?.split(':');\n\n\t\tlet distance = Number(args?.[0] ?? 100); // количество px на которые блок изначально смещен вниз\n\t\tlet percent = Number(args?.[1] ?? 30); // процент высоты экрана поднявшись на который блок закончит подплытие\n\n\t\tdirectiveSwipUpOptions = {\n\t\t\tdistance,\n\t\t\tpercent\n\t\t}\n\n\t\tif (!appSwimUpInited) {\n\t\t\tswimUpInit(el);\n\n\t\t\tappSwimUpInited = true;\n\t\t}\n\n\t\tappSwimUpObserver.observe(el);\n\t},\n\n\tunmounted(el: HTMLElement, _binding: DirectiveBinding, _vnode: VNode) {\n\t\tappSwimUpEls.delete(el);\n\t\tappSwimUpObserver?.unobserve(el);\n\t}\n} satisfies ObjectDirective;\n\nexport default swimUp;","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\nimport Core from '@/core/core/core';\n\nconst $ = (el: VNode) => {\n\tif (!Core.$?.ui?.tooltip) {\n\t\tconsole.info('Для работы v-top-tooltip требуется глобальная загрузка jQuery UI Tooltip');\n\n\t\treturn;\n\t}\n\n\treturn Core.$(el);\n};\n\nconst tvTooltipGenOptions = (binding: DirectiveBinding, vnode: VNode) => {\n\tconst options = binding.value ?? {};\n\n\toptions.content ??= vnode.props?.title;\n\toptions.content = String(options.content).replace(/\\r\\n|\\r|\\n/g, '<br>');\n\n\toptions.position ??= {\n\t\tmy: 'bottom-18px',\n\t\tat: 'top center',\n\t};\n\n\treturn options;\n};\n\n/**\n * Добавление всплывающей подсказки к элементу.\n */\nconst tooltip = {\n\tmounted(el: VNode, binding: DirectiveBinding, vnode: VNode) {\n\t\t$(el)?.tooltip(tvTooltipGenOptions(binding, vnode));\n\t},\n\n\tupdated(el: VNode, binding: DirectiveBinding, vnode: VNode, _prevVnode: VNode) {\n\t\t/**\n\t\t * В результате обновления может быть открыто несколько тултипов поэтому изменить опции, без перерисовки тултипа\n\t\t */\n\t\tconst options = tvTooltipGenOptions(binding, vnode);\n\t\tconst instance = $(el)?.tooltip('instance') as { options: JQueryUI.TooltipOptions } | undefined;\n\t\tif (!instance) {\n\t\t\treturn;\n\t\t}\n\n\t\tinstance.options = {\n\t\t\t...instance.options,\n\t\t\t...options,\n\t\t};\n\t},\n\n\tunmounted(el: VNode, _binding: DirectiveBinding, _vnode: VNode) {\n\t\t$(el)?.tooltip('destroy');\n\t},\n} satisfies ObjectDirective;\n\nexport default tooltip;","import type { Plugin } from 'vue';\nimport Core from '@/core/core/core';\nimport coreDefaultOptions from '@/core/core/options';\nimport * as Forms from '../../components/forms/forms';\nimport directiveFocus from '@/core/directives/focus';\nimport directiveSticky from '@/core/directives/sticky';\nimport directiveSwimUp from '@/core/directives/swimUp';\nimport directiveTooltip from '@/core/directives/tooltip';\n\ndeclare module 'vue' {\n\texport interface ComponentCustomProperties {\n\t\t/**\n\t\t * Статический класс с текущим состоянимем UI\n\t\t */\n\t\t$core: typeof Core;\n\t}\n\n\t/**\n\t * Обязательные компоненты UI\n\t *\n\t * Они подключаются через плагин и доступны без явного указания импорта\n\t */\n\texport interface GlobalComponents {\n\t\tTopAvatar: typeof Forms.TopAvatar;\n\t\tTopButton: typeof Forms.TopButton;\n\t\tTopCheckbox: typeof Forms.TopCheckbox;\n\t\tTopControlLabel: typeof Forms.TopControlLabel;\n\t\tTopHint: typeof Forms.TopHint;\n\t\tTopInput: typeof Forms.TopInput;\n\t\tTopInputDate: typeof Forms.TopInputDate;\n\t\tTopInputRange: typeof Forms.TopInputRange;\n\t\tTopRadio: typeof Forms.TopRadio;\n\t\tTopSwitcher: typeof Forms.TopSwitcher;\n\t\tTopTextarea: typeof Forms.TopTextarea;\n\t\tTopSelect: typeof Forms.TopSelect;\n\t\tTopLoadbar: typeof Forms.TopLoadbar;\n\t}\n}\n\ntype PartialBy<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;\n\ntype Options = PartialBy<typeof coreDefaultOptions, 'gmt'>;\n\n/**\n * Плагин для интеграции UI во Vue приложение\n *\n * - В глобальную область видимости шаблонов будет добавлен объект $core\n * - Будут зарегистрирвоаны директивы UI: https://ui.topvisor.com/?path=/docs/core-directives-focus--docs\n * - Будут подключены базовые компоненты UI/Forms: https://ui.topvisor.com/?path=/docs/components-forms-readme--docs\n */\nexport default {\n\n\tinstall: (app, options: Options) => {\n\t\tapp.config.globalProperties.$core = Core;\n\n\t\t// начальные настройки UI\n\t\tfor (const name in options) {\n\t\t\tCore.state[name] = options[name];\n\t\t}\n\n\t\tCore.setState();\n\n\t\t// определение директив\n\t\tapp.directive('top-focus', directiveFocus);\n\t\tapp.directive('top-sticky', directiveSticky);\n\t\tapp.directive('top-swim-up', directiveSwimUp);\n\t\tapp.directive('top-tooltip', directiveTooltip);\n\n\t\t// определение базовых компонентов\n\t\tapp.component('TopAvatar', Forms.TopAvatar);\n\t\tapp.component('TopButton', Forms.TopButton);\n\t\tapp.component('TopCheckbox', Forms.TopCheckbox);\n\t\tapp.component('TopControlLabel', Forms.TopControlLabel);\n\t\tapp.component('TopHint', Forms.TopHint);\n\t\tapp.component('TopInput', Forms.TopInput);\n\t\tapp.component('TopInputDate', Forms.TopInputDate);\n\t\tapp.component('TopInputRange', Forms.TopInputRange);\n\t\tapp.component('TopLoadbar', Forms.TopLoadbar);\n\t\tapp.component('TopRadio', Forms.TopRadio);\n\t\tapp.component('TopSelect', Forms.TopSelect);\n\t\tapp.component('TopSwitcher', Forms.TopSwitcher);\n\t\tapp.component('TopTextarea', Forms.TopTextarea);\n\n\t},\n\n} satisfies Plugin<Options>;\n\n// export {\n// \tdirectiveFocus,\n// \tdirectiveSticky,\n// \tdirectiveSwimUp,\n// \tdirectiveTooltip,\n// };\n","import type { PiniaPluginContext, Store } from 'pinia';\nimport { watch } from 'vue';\nimport { debounce } from 'lodash';\nimport { setClipboard } 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<'test', 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});\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 setClipboard(res.result);\n\n\t\t// TODO: Оформить через компонент messages\n\t\talert('Link copied');\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\tif (Object.isFrozen(this)) throw 'Please, use setOptions only inner commit function';\n\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 (!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 dataFormatted: 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\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 * Сохранить опции в хеш адреса страницы\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\t// let names = this.#namesStorage;\n\t\tlet storageNamespace = 'state:' + this.#storeId;\n\n\t\tif (isLocal) {\n\t\t\t// names = this.#namesStorageLocal;\n\t\t\tstorageNamespace = 'state:' + this.#storeId + ':' + location.pathname;\n\t\t}\n\n\t\tthis.#namesStorage.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) => {\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) => {\n\t\t\t\tif (!competitorsIds.length) return;\n\n\t\t\t\t// приведение типа\n\t\t\t\tcompetitorsIds.forEach((competitorId: number, index: number) => competitorId[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});\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- localStorage\n * \t- URL hash\n * \t- гостевая ссылка\n *\n * Для подключение плагина нужно указань одну или несколько опций при defineStore():\n * - tpaNamesUrlHash: Array\n * - tpaNamesStorage: Array\n * - tpaNamesStorageLocal: Array\n * - tpaNamesGuestLink: Array\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":["focus","el","binding","appStickyObserver","sticky","_vnode","entries","_el","_binding","appSwimUpObserver","directiveSwipUpOptions","appSwimUpEls","swimUpElTransform","windowHeight","triggerHeight","distance","swimUpInit","el2","entry","swimUp","forms","args","percent","$$1","tvTooltipGenOptions","vnode","options","tooltip","_a","instance","core","app","name","PiniaTPA","#storeId","#store","#Page","#user","#Api","context","url","data","#loadFromStorage","#loadFromHash","#loadFromGuestLink","#prepareParams","save","lodash","#saveInHash","#saveInStorage","dataGuestLink","#genOptionsForGuestLink","res","utils_clipboard","nameSnakeCase","utils_string","value","dataFormatted","dataHash","utils_route","#setOptions","isLocal","storageNamespace","names","#namesStorage","#namesStorageLocal","guestData","$guestTitle","competitors","competitor","regionsIndexes","regionIndex","index","mapSearchers","availableRegionsIndexes","searcher","competitorsIds","competitorId","availableCompetitorsIds","piniaTPA","contextPinia","_b","_c","_d"],"mappings":"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"}
package/core/app.js CHANGED
@@ -1,5 +1,5 @@
1
- import { C as p, c as b, e as S, f as E, g as I, h as L, j as N, k, l as v, m as y, n as O, o as H, p as R, q as _ } from "../.chunks/forms-BfIXIMY_.es.js";
2
- import { i as et, a as ot, u as st, b as nt } from "../.chunks/i18n-B5a6l_mZ.es.js";
1
+ import { C as p, c as b, e as S, f as E, g as I, h as L, j as N, k, l as v, m as y, n as O, o as H, p as R, q as _ } from "../.chunks/forms-zcjs34Ku.es.js";
2
+ import { i as et, a as ot, u as st, b as nt } from "../.chunks/i18n-C5qBPql0.es.js";
3
3
  import { watch as g } from "vue";
4
4
  import { debounce as P } from "lodash";
5
5
  import { setClipboard as C } from "../utils/clipboard.js";
@@ -91,9 +91,7 @@ const l = /* @__PURE__ */ new Map(), G = (n, t) => {
91
91
  }
92
92
  }, W = {
93
93
  install: (n, t) => {
94
- n.config.globalProperties.$top = {
95
- Core: p
96
- };
94
+ n.config.globalProperties.$core = p;
97
95
  for (const o in t)
98
96
  p.state[o] = t[o];
99
97
  p.setState(), n.directive("top-focus", j), n.directive("top-sticky", A), n.directive("top-swim-up", x), n.directive("top-tooltip", J), n.component("TopAvatar", b), n.component("TopButton", S), n.component("TopCheckbox", E), n.component("TopControlLabel", I), n.component("TopHint", L), n.component("TopInput", N), n.component("TopInputDate", k), n.component("TopInputRange", v), n.component("TopLoadbar", y), n.component("TopRadio", O), n.component("TopSelect", H), n.component("TopSwitcher", R), n.component("TopTextarea", _);
package/core/app.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"app.js","sources":["../../src/core/directives/focus.ts","../../src/core/directives/sticky.ts","../../src/core/directives/swimUp.ts","../../src/core/directives/tooltip.ts","../../src/core/plugins/core.ts","../../src/core/plugins/piniaTPA.ts"],"sourcesContent":["import type { DirectiveBinding, ObjectDirective } from 'vue';\r\n\r\n/**\r\n * Фокусировка на элементе сразу после его отображения\r\n */\r\nconst focus = {\r\n\tmounted: function (el: HTMLElement, binding: DirectiveBinding) {\r\n\t\tif (binding.value || binding.value === undefined) el.focus();\r\n\t}\r\n} satisfies ObjectDirective;\r\n\r\nexport default focus;\r\n","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\r\n\r\nlet appStickyObserver: IntersectionObserver;\r\n\r\n/**\r\n * Добавление sticky\r\n * К элементу добляется класс переданный как значение диррективы либо **'top-sticky'** по умолчанию\r\n */\r\nconst sticky = {\r\n\tmounted(el: HTMLElement, binding: DirectiveBinding, _vnode: VNode){\r\n\t\tconst className = binding.value || 'top-sticky';\r\n\r\n\t\tappStickyObserver = new IntersectionObserver(entries => {\r\n\t\t\tlet condition = entries[0].intersectionRatio < 1;\r\n\t\t\tif(condition){\r\n\t\t\t\tif(binding.arg === 'bottom' && entries[0].intersectionRect.y === 0) condition = false;\r\n\t\t\t}\r\n\r\n\t\t\tel.classList.toggle(className, condition);\r\n\t\t}, {\r\n\t\t\tthreshold:[1]\r\n\t\t});\r\n\r\n\t\tappStickyObserver.observe(el);\r\n\t},\r\n\r\n\tunmounted(_el: HTMLElement, _binding: DirectiveBinding, _vnode: VNode){\r\n\t\tappStickyObserver?.disconnect();\r\n\t},\r\n} satisfies ObjectDirective;\r\n\r\nexport default sticky;","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\r\nimport Core from '@/core/core/core';\r\n\r\ninterface SwipUpOptions {\r\n\tdistance: number,\r\n\tpercent: number,\r\n}\r\n\r\nlet appSwimUpInited = false;\r\nlet appSwimUpObserver: IntersectionObserver;\r\nlet directiveSwipUpOptions: SwipUpOptions;\r\nconst appSwimUpEls = new Map();\r\n\r\n\r\n/**\r\n * Отодвинуть блок в зависимости от скролла старинцы\r\n * @param el\r\n * @param windowHeight\r\n */\r\nconst swimUpElTransform = (el: HTMLElement, windowHeight: number): void => {\r\n\tconst { distance, percent } = directiveSwipUpOptions;\r\n\r\n\tconst elTop = el.getBoundingClientRect().top;\r\n\r\n\t// во столько раз triggerHeight должен быть меньше, чтобы закончить подплытие к нужной высоте экрана\r\n\tconst triggerHeightReducer = windowHeight * percent / 100 / distance;\r\n\tconst triggerHeight = (windowHeight - elTop) / triggerHeightReducer;\r\n\r\n\tif (triggerHeight <= distance) {\r\n\t\tel.style.transform = `translateY(${distance - triggerHeight}px)`;\r\n\t} else {\r\n\t\tel.style.transform = 'translateY(0px)';\r\n\t}\r\n}\r\n\r\nconst swimUpInit = (el: HTMLElement): void => {\r\n\tlet windowHeight = window.innerHeight;\r\n\r\n\twindow.addEventListener('scroll', () => {\r\n\t\tappSwimUpEls.forEach((el) => swimUpElTransform(el, windowHeight));\r\n\t}, { passive: true });\r\n\r\n\t// проверка того, что элемент в зоне видимости\r\n\tappSwimUpObserver = new IntersectionObserver(entries => {\r\n\t\twindowHeight = window.innerHeight;\r\n\r\n\t\tentries.forEach((entry) => {\r\n\t\t\tconst el = entry.target as HTMLElement;\r\n\r\n\t\t\tif (entry.intersectionRatio < 0.1) {\r\n\t\t\t\t// элемент за областью видимости\r\n\t\t\t\tappSwimUpEls.delete(el);\r\n\t\t\t} else {\r\n\t\t\t\t// элемент на экране\r\n\t\t\t\tappSwimUpEls.set(el, el);\r\n\t\t\t}\r\n\r\n\t\t\tif (entry.intersectionRatio === 0) {\r\n\t\t\t\tconst { distance, percent } = directiveSwipUpOptions;\r\n\t\t\t\tel.style.transform = `translateY(${distance}px)`;\r\n\t\t\t}\r\n\t\t});\r\n\t}, {\r\n\t\tthreshold: 0.1,\r\n\t});\r\n}\r\n\r\n/**\r\n * Добавление анимации подплытия вверх для блока\r\n */\r\nconst swimUp = {\r\n\tmounted(el: HTMLElement, binding: DirectiveBinding, _vnode: VNode): void {\r\n\t\tif (Core.state.isMobileUA) return;\r\n\r\n\t\tconst args = binding.arg?.split(':');\r\n\r\n\t\tlet distance = Number(args?.[0] ?? 100); // количество px на которые блок изначально смещен вниз\r\n\t\tlet percent = Number(args?.[1] ?? 30); // процент высоты экрана поднявшись на который блок закончит подплытие\r\n\r\n\t\tdirectiveSwipUpOptions = {\r\n\t\t\tdistance,\r\n\t\t\tpercent\r\n\t\t}\r\n\r\n\t\tif (!appSwimUpInited) {\r\n\t\t\tswimUpInit(el);\r\n\r\n\t\t\tappSwimUpInited = true;\r\n\t\t}\r\n\r\n\t\tappSwimUpObserver.observe(el);\r\n\t},\r\n\r\n\tunmounted(el: HTMLElement, _binding: DirectiveBinding, _vnode: VNode) {\r\n\t\tappSwimUpEls.delete(el);\r\n\t\tappSwimUpObserver?.unobserve(el);\r\n\t}\r\n} satisfies ObjectDirective;\r\n\r\nexport default swimUp;","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\r\nimport Core from '@/core/core/core';\r\n\r\nconst $ = (el: VNode) => {\r\n\tif (!Core.$?.ui?.tooltip) {\r\n\t\tconsole.info('Для работы v-top-tooltip требуется глобальная загрузка jQuery UI Tooltip');\r\n\r\n\t\treturn;\r\n\t}\r\n\r\n\treturn Core.$(el);\r\n};\r\n\r\nconst tvTooltipGenOptions = (binding: DirectiveBinding, vnode: VNode) => {\r\n\tconst options = binding.value ?? {};\r\n\r\n\toptions.content ??= vnode.props?.title;\r\n\toptions.content = String(options.content).replace(/\\r\\n|\\r|\\n/g, '<br>');\r\n\r\n\toptions.position ??= {\r\n\t\tmy: 'bottom-18px',\r\n\t\tat: 'top center',\r\n\t};\r\n\r\n\treturn options;\r\n};\r\n\r\n/**\r\n * Добавление всплывающей подсказки к элементу.\r\n */\r\nconst tooltip = {\r\n\tmounted(el: VNode, binding: DirectiveBinding, vnode: VNode) {\r\n\t\t$(el)?.tooltip(tvTooltipGenOptions(binding, vnode));\r\n\t},\r\n\r\n\tupdated(el: VNode, binding: DirectiveBinding, vnode: VNode, _prevVnode: VNode) {\r\n\t\t/**\r\n\t\t * В результате обновления может быть открыто несколько тултипов поэтому изменить опции, без перерисовки тултипа\r\n\t\t */\r\n\t\tconst options = tvTooltipGenOptions(binding, vnode);\r\n\t\tconst instance = $(el)?.tooltip('instance') as { options: JQueryUI.TooltipOptions } | undefined;\r\n\t\tif (!instance) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tinstance.options = {\r\n\t\t\t...instance.options,\r\n\t\t\t...options,\r\n\t\t};\r\n\t},\r\n\r\n\tunmounted(el: VNode, _binding: DirectiveBinding, _vnode: VNode) {\r\n\t\t$(el)?.tooltip('destroy');\r\n\t},\r\n} satisfies ObjectDirective;\r\n\r\nexport default tooltip;","import type { Plugin } from 'vue';\r\nimport Core from '@/core/core/core';\r\nimport coreDefaultOptions from '@/core/core/options';\r\nimport * as Forms from '../../components/forms/forms';\r\nimport directiveFocus from '@/core/directives/focus';\r\nimport directiveSticky from '@/core/directives/sticky';\r\nimport directiveSwimUp from '@/core/directives/swimUp';\r\nimport directiveTooltip from '@/core/directives/tooltip';\r\n\r\ndeclare module 'vue' {\r\n\texport interface ComponentCustomProperties {\r\n\t\t$top: {\r\n\t\t\tCore: typeof Core\r\n\t\t};\r\n\t}\r\n\r\n\t/**\r\n\t * Обязательные компоненты UI\r\n\t *\r\n\t * Они подключаются через плагин и доступны без явного указания импорта\r\n\t */\r\n\texport interface GlobalComponents {\r\n\t\tTopAvatar: typeof Forms.TopAvatar;\r\n\t\tTopButton: typeof Forms.TopButton;\r\n\t\tTopCheckbox: typeof Forms.TopCheckbox;\r\n\t\tTopControlLabel: typeof Forms.TopControlLabel;\r\n\t\tTopHint: typeof Forms.TopHint;\r\n\t\tTopInput: typeof Forms.TopInput;\r\n\t\tTopInputDate: typeof Forms.TopInputDate;\r\n\t\tTopInputRange: typeof Forms.TopInputRange;\r\n\t\tTopRadio: typeof Forms.TopRadio;\r\n\t\tTopSwitcher: typeof Forms.TopSwitcher;\r\n\t\tTopTextarea: typeof Forms.TopTextarea;\r\n\t\tTopSelect: typeof Forms.TopSelect;\r\n\t\tTopLoadbar: typeof Forms.TopLoadbar;\r\n\t}\r\n}\r\n\r\ntype PartialBy<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;\r\n\r\ntype Options = PartialBy<typeof coreDefaultOptions, 'gmt'>;\r\n\r\n/**\r\n * Плагин для интеграции UI во Vue приложение\r\n *\r\n * - В глобальную область видимости шаблонов будет добавлен объект $top\r\n * - Будут зарегистрирвоаны директивы UI: https://ui.topvisor.com/?path=/docs/core-directives-focus--docs\r\n * - Будут подключены базовые компоненты UI/Forms: https://ui.topvisor.com/?path=/docs/components-forms-readme--docs\r\n */\r\nexport default {\r\n\r\n\tinstall: (app, options: Options) => {\r\n\t\tapp.config.globalProperties.$top = {\r\n\t\t\tCore,\r\n\t\t};\r\n\r\n\t\t// начальные настройки UI\r\n\t\tfor (const name in options) {\r\n\t\t\tCore.state[name] = options[name];\r\n\t\t}\r\n\r\n\t\tCore.setState();\r\n\r\n\t\t// определение директив\r\n\t\tapp.directive('top-focus', directiveFocus);\r\n\t\tapp.directive('top-sticky', directiveSticky);\r\n\t\tapp.directive('top-swim-up', directiveSwimUp);\r\n\t\tapp.directive('top-tooltip', directiveTooltip);\r\n\r\n\t\t// определение базовых компонентов\r\n\t\tapp.component('TopAvatar', Forms.TopAvatar);\r\n\t\tapp.component('TopButton', Forms.TopButton);\r\n\t\tapp.component('TopCheckbox', Forms.TopCheckbox);\r\n\t\tapp.component('TopControlLabel', Forms.TopControlLabel);\r\n\t\tapp.component('TopHint', Forms.TopHint);\r\n\t\tapp.component('TopInput', Forms.TopInput);\r\n\t\tapp.component('TopInputDate', Forms.TopInputDate);\r\n\t\tapp.component('TopInputRange', Forms.TopInputRange);\r\n\t\tapp.component('TopLoadbar', Forms.TopLoadbar);\r\n\t\tapp.component('TopRadio', Forms.TopRadio);\r\n\t\tapp.component('TopSelect', Forms.TopSelect);\r\n\t\tapp.component('TopSwitcher', Forms.TopSwitcher);\r\n\t\tapp.component('TopTextarea', Forms.TopTextarea);\r\n\r\n\t},\r\n\r\n} satisfies Plugin<Options>;\r\n\r\n// export {\r\n// \tdirectiveFocus,\r\n// \tdirectiveSticky,\r\n// \tdirectiveSwimUp,\r\n// \tdirectiveTooltip,\r\n// };\r\n","import type { PiniaPluginContext, Store } from 'pinia';\r\nimport { watch } from 'vue';\r\nimport { debounce } from 'lodash';\r\nimport { setClipboard } from '@/core/utils/clipboard';\r\nimport { camelToSnakeCase } from '@/core/utils/string.js';\r\nimport type { paths as OpenAPIPaths } from 'topvisor-openapi/src/ts/Topvisor';\r\nimport { getHash, setHash } from '@/core/utils/route';\r\n\r\ntype OpenAPIPath = keyof OpenAPIPaths;\r\n\r\nclass PiniaTPA {\r\n\r\n\treadonly #storeId: string;\r\n\treadonly #store: Store<'test', any>;\r\n\r\n\t/**\r\n\t * @deprecated\r\n\t */\r\n\treadonly #Page: any;\r\n\r\n\treadonly #user: any;\r\n\treadonly #Api: any;\r\n\r\n\treadonly #namesUrlHash: string[] = [];\r\n\treadonly #namesStorage: string[] = [];\r\n\treadonly #namesStorageLocal: string[] = [];\r\n\treadonly #namesGuestLink: string[] = [];\r\n\r\n\tconstructor(context: Context) {\r\n\t\tthis.#store = context.store;\r\n\t\tthis.#storeId = this.#store.$id;\r\n\r\n\t\tthis.#Page = context.options.Page;\r\n\r\n\t\tthis.#user = context.options.user;\r\n\t\tthis.#Api = context.options.Api;\r\n\r\n\t\tthis.#namesUrlHash = context.options.tpaNamesUrlHash || [];\r\n\t\tthis.#namesStorage = context.options.tpaNamesStorage || [];\r\n\t\tthis.#namesStorageLocal = context.options.tpaNamesStorageLocal || [];\r\n\t\tthis.#namesGuestLink = context.options.tpaNamesGuestLink || [];\r\n\r\n\t\tcontext.store.genGuestLink = <Path extends OpenAPIPath>(url: Path, data: any) => this.genGuestLink(url, data);\r\n\r\n\t\tif (!this.#user.guest_data?.data) {\r\n\t\t\tthis.#loadFromStorage();\r\n\t\t\tthis.#loadFromStorage(true);\r\n\r\n\t\t\t// настройки URL hash имеют приоритет\r\n\t\t\tthis.#loadFromHash();\r\n\t\t}\r\n\r\n\t\t// настройки гостевой ссылки имеют приоритет\r\n\t\tthis.#loadFromGuestLink();\r\n\r\n\t\tthis.#prepareParams();\r\n\r\n\t\tconst save = debounce(() => {\r\n\t\t\tthis.#saveInHash();\r\n\t\t\tthis.#saveInStorage();\r\n\t\t});\r\n\r\n\t\tcontext.store.$subscribe(save);\r\n\t}\r\n\r\n\t/**\r\n\t * Сгенерировать гостевую ссылку\r\n\t *\r\n\t * Метод, путь к которому указан в url, должен возвращать сгенерированную ссылку\r\n\t */\r\n\tasync genGuestLink<Path extends OpenAPIPath>(url: Path, data: any) {\r\n\t\tconst dataGuestLink = this.#genOptionsForGuestLink();\r\n\t\tdata = Object.assign(data, Object.fromEntries(dataGuestLink));\r\n\r\n\t\tconst res = await this.#Api.gen(url, 'fetchColumn').call({} as any, data);\r\n\r\n\t\t// @ts-ignore - метод, который скачивает файл не возвращает json\r\n\t\tif (res?.errors) return;\r\n\r\n\t\t// @ts-ignore - метод, который скачивает файл не возвращает json\r\n\t\tawait setClipboard(res.result);\r\n\r\n\t\t// TODO: Оформить через компонент messages\r\n\t\talert('Link copied');\r\n\t}\r\n\r\n\t/**\r\n\t * Сгенерировать опции для гостевой ссылки\r\n\t */\r\n\t#genOptionsForGuestLink() {\r\n\t\tconst data = new Map();\r\n\r\n\t\tthis.#namesGuestLink.forEach(name => {\r\n\t\t\t// формат параметров API: snake_case\r\n\t\t\tconst nameSnakeCase = camelToSnakeCase(name);\r\n\t\t\tdata.set(nameSnakeCase, this.#store[name]);\r\n\t\t});\r\n\r\n\t\treturn data;\r\n\t}\r\n\r\n\t/**\r\n\t * Установить опции из объекта без фиксации состояния\r\n\t */\r\n\t#setOptions(data: Map<string, any>) {\r\n\t\tif (Object.isFrozen(this)) throw 'Please, use setOptions only inner commit function';\r\n\r\n\t\tdata.forEach((value, name) => {\r\n\t\t\tconst currentValue = this.#store[name];\r\n\r\n\t\t\tif (value === null || value === undefined) return;\r\n\t\t\tif (!value?.constructor) return;\r\n\t\t\tif (value.constructor !== currentValue.constructor) return;\r\n\r\n\t\t\t// дополнительная проверка на формат даты\r\n\t\t\tif (name.indexOf('date') === 0) {\r\n\t\t\t\tif (Array.isArray(value)) {\r\n\t\t\t\t\t// value.forEach((valueI) => {\r\n\t\t\t\t\t// \tif (!/\\d\\d\\d\\d-\\d\\d-\\d\\d/.test(valueI)) return;\r\n\t\t\t\t\t// });\r\n\t\t\t\t} else {\r\n\t\t\t\t\tif (typeof (value) === 'string') {\r\n\t\t\t\t\t\tif (!/\\d\\d\\d\\d-\\d\\d-\\d\\d/.test(value)) return;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t\tthis.#store[name] = value;\r\n\t\t});\r\n\t}\r\n\r\n\t/**\r\n\t * Сгенерировать Map объект с опциями со значениями в виде json строк\r\n\t */\r\n\t#genDataFormat(data: Map<string, any>) {\r\n\t\tconst dataFormatted = new Map();\r\n\r\n\t\tdata.forEach((value, name) => {\r\n\t\t\tif (value === null) return;\r\n\r\n\t\t\tvalue = JSON.stringify(value);\r\n\r\n\t\t\tdataFormatted.set(name, value);\r\n\t\t});\r\n\r\n\t\treturn dataFormatted;\r\n\t}\r\n\r\n\t/**\r\n\t * Сгенерировать Map объект с опциями со значениями в оригинальном виде\r\n\t */\r\n\t#genDataUnFormat(dataFormatted: Map<string, string>) {\r\n\t\tconst data: Map<string, any> = new Map();\r\n\r\n\t\tdataFormatted.forEach((value, name) => {\r\n\t\t\tif (value === null || value === undefined || value === 'false') return;\r\n\r\n\t\t\ttry {\r\n\t\t\t\tif (typeof (value) === 'string' && !/^\\d\\d\\d\\d-\\d\\d-\\d\\d$/.test(value)) value = JSON.parse(value);\r\n\r\n\t\t\t\tif (value === null || value === undefined || value === 'false') return;\r\n\t\t\t} catch (e) {\r\n\t\t\t\t// не json строка\r\n\t\t\t}\r\n\r\n\t\t\tdata.set(name, value);\r\n\t\t});\r\n\r\n\t\treturn data;\r\n\t}\r\n\r\n\t/**\r\n\t * Установить опции из хеша адреса страницы\r\n\t */\r\n\t#loadFromHash() {\r\n\t\tlet dataHash: any;\r\n\t\ttry {\r\n\t\t\tdataHash = JSON.parse(getHash(this.#storeId));\r\n\t\t} catch (e) {\r\n\r\n\t\t}\r\n\t\tif (!dataHash) return;\r\n\r\n\t\tconst dataFormatted: Map<string, any> = new Map();\r\n\r\n\t\tthis.#namesUrlHash.forEach((name) => {\r\n\t\t\tconst value = dataHash[name];\r\n\t\t\tif (!value) return;\r\n\r\n\t\t\tdataFormatted.set(name, value);\r\n\t\t});\r\n\r\n\t\tconst data = this.#genDataUnFormat(dataFormatted);\r\n\r\n\t\tthis.#setOptions(data);\r\n\t}\r\n\r\n\t/**\r\n\t * Сохранить опции в хеш адреса страницы\r\n\t */\r\n\t#saveInHash() {\r\n\t\tconst data = new Map();\r\n\r\n\t\tthis.#namesUrlHash.forEach((name) => {\r\n\t\t\tconst value = this.#store[name];\r\n\r\n\t\t\tdata.set(name, value);\r\n\t\t});\r\n\r\n\t\tconst dataObject = Object.fromEntries(data);\r\n\t\tconst dataJSON = JSON.stringify(dataObject);\r\n\r\n\t\tsetHash(this.#storeId, dataJSON);\r\n\t};\r\n\r\n\t/**\r\n\t * Установить опции из localStorage\r\n\t * @param isLocal - сохранить с учетом адреса страницы\r\n\t */\r\n\t#loadFromStorage(isLocal = false) {\r\n\t\tconst dataFormatted = new Map();\r\n\r\n\t\t// let names = this.#namesStorage;\r\n\t\tlet storageNamespace = 'state:' + this.#storeId;\r\n\r\n\t\tif (isLocal) {\r\n\t\t\t// names = this.#namesStorageLocal;\r\n\t\t\tstorageNamespace = 'state:' + this.#storeId + ':' + location.pathname;\r\n\t\t}\r\n\r\n\t\tthis.#namesStorage.forEach((name) => {\r\n\t\t\tconst value = localStorage.getItem(storageNamespace + ':' + name);\r\n\t\t\tdataFormatted.set(name, value);\r\n\t\t});\r\n\r\n\t\tconst data = this.#genDataUnFormat(dataFormatted);\r\n\r\n\t\tthis.#setOptions(data);\r\n\t}\r\n\r\n\t/**\r\n\t * Сохранить опции в localStorage\r\n\t * @param isLocal - сохранить с учетом адреса страницы\r\n\t */\r\n\t#saveInStorage(isLocal = false) {\r\n\t\tconst data = new Map();\r\n\r\n\t\tlet names = this.#namesStorage;\r\n\t\tlet storageNamespace = 'state:' + this.#storeId;\r\n\r\n\t\tif (isLocal) {\r\n\t\t\tnames = this.#namesStorageLocal;\r\n\t\t\tstorageNamespace = 'state:' + this.#storeId + ':' + location.pathname;\r\n\t\t}\r\n\r\n\t\tnames.forEach((name) => {\r\n\t\t\tconst value = this.#store[name];\r\n\r\n\t\t\tdata.set(name, value);\r\n\t\t});\r\n\r\n\t\tconst dataFormatted = this.#genDataFormat(data);\r\n\r\n\t\tnames.forEach((name) => {\r\n\t\t\tconst value = dataFormatted.get(name);\r\n\r\n\t\t\tlocalStorage.setItem(storageNamespace + ':' + name, value);\r\n\t\t});\r\n\t}\r\n\r\n\t/**\r\n\t * Установить опции из гостевой ссылки\r\n\t */\r\n\t#loadFromGuestLink() {\r\n\t\tconst guestData = this.#user?.guest_data?.data;\r\n\t\tif (!guestData) return;\r\n\r\n\t\t// общие правила для гостевых сессий\r\n\t\tif (this.#user.id === -1) this.#user.positionsReverseDates = guestData.positionsReverseDates;\r\n\r\n\t\tconst dataFormatted = new Map();\r\n\r\n\t\tthis.#namesGuestLink.forEach((name) => {\r\n\t\t\tconst value = guestData[name];\r\n\t\t\tdataFormatted.set(name, value);\r\n\t\t});\r\n\r\n\t\tconst data = this.#genDataUnFormat(dataFormatted);\r\n\r\n\t\tthis.#setOptions(data);\r\n\r\n\t\tconst $guestTitle = $('.mod_guest_title');\r\n\r\n\t\t// TODO: вынести в опции плагина\r\n\t\tif (this.#store.competitorsIds?.length === 1 && this.#Page.page.data.competitors) {\r\n\t\t\tlet competitors = this.#Page.page.data.competitors.filter((competitor: any) => competitor.id === guestData.competitorsIds[0]);\r\n\t\t\tif (competitors.length) {\r\n\t\t\t\t$('a', $guestTitle).attr('href', 'http://' + competitors[0].url);\r\n\t\t\t\t$('a', $guestTitle).text(competitors[0].name);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t * Подготовить входные параметры перед инициализацией основного функционала\r\n\t *\r\n\t * Входные параметры устанавливаются при открытии страницы\r\n\t *\r\n\t * Входные параметры могут меняться пользоваталем и устаревать\r\n\t */\r\n\t#prepareParams() {\r\n\t\t// контролль за вводом регионов\r\n\t\t// TODO: вынести в опции плагина\r\n\t\tif (this.#store.regionsIndexes) {\r\n\t\t\twatch(this.#store, (regionsIndexes) => {\r\n\t\t\t\tif (!regionsIndexes.length) return;\r\n\r\n\t\t\t\t// приведение типа\r\n\t\t\t\tregionsIndexes.forEach((regionIndex: number, index: number) => regionsIndexes[index] = regionIndex);\r\n\r\n\t\t\t\t// оставить только включенные регионы\r\n\t\t\t\t// @ts-ignore\r\n\t\t\t\tconst mapSearchers = TplProjectSelectorRegion.genSearchersMap();\r\n\r\n\t\t\t\tconst availableRegionsIndexes: number[] = [];\r\n\t\t\t\tmapSearchers.forEach((searcher: any) => {\r\n\t\t\t\t\tsearcher.regions.forEach((region: any) => {\r\n\t\t\t\t\t\tif (region.index === -1) return;\r\n\r\n\t\t\t\t\t\tavailableRegionsIndexes.push(region.index);\r\n\t\t\t\t\t});\r\n\t\t\t\t});\r\n\r\n\t\t\t\tthis.#store.regionsIndexes = regionsIndexes.filter((regionIndex: number) => availableRegionsIndexes.includes(regionIndex));\r\n\t\t\t}, { immediate: true });\r\n\t\t}\r\n\r\n\t\t// контролль за вводом конкурентов\r\n\t\t// TODO: вынести в опции плагина\r\n\t\tif (this.#store.competitorsIds) {\r\n\t\t\twatch(this.#store, (competitorsIds) => {\r\n\t\t\t\tif (!competitorsIds.length) return;\r\n\r\n\t\t\t\t// приведение типа\r\n\t\t\t\tcompetitorsIds.forEach((competitorId: number, index: number) => competitorId[index] = competitorId);\r\n\r\n\t\t\t\t// оставить только включенных конкурентов\r\n\t\t\t\tconst availableCompetitorsIds = [this.#Page.page.data.project.id];\r\n\t\t\t\tthis.#Page.page.data.project.competitors.forEach((competitor: any) => {\r\n\t\t\t\t\tif (competitor.on >= 0) availableCompetitorsIds.push(competitor.id);\r\n\t\t\t\t});\r\n\r\n\t\t\t\tthis.#store.competitorsIds = competitorsIds.filter((competitorId: number) => availableCompetitorsIds.includes(competitorId));\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\r\n}\r\n\r\ntype Options = {\r\n\t/**\r\n\t * TODO: Убрать из плагина\r\n\t */\r\n\tPage: any,\r\n\r\n\t/**\r\n\t * Объект с настройками пользователя\r\n\t */\r\n\tuser: any,\r\n\r\n\t/**\r\n\t * Объект для работы с API\r\n\t *\r\n\t * См. на айте: @/component/api/core/api.ts\r\n\t */\r\n\tApi: any;\r\n\r\n\t/**\r\n\t * Имена свойств для сохранения в URL\r\n\t */\r\n\ttpaNamesUrlHash?: string[],\r\n\r\n\t/**\r\n\t * Имена свойств для сохранения в localStorage\r\n\t */\r\n\ttpaNamesStorage?: string[],\r\n\r\n\t/**\r\n\t * Имена свойств для сохранения в localStorage с учетом пути URL\r\n\t *\r\n\t * Каждый URL будет работать со своим состоянием\r\n\t */\r\n\ttpaNamesStorageLocal?: string[],\r\n\r\n\t/**\r\n\t * Имена свойств для работы с гостевой ссылкой\r\n\t *\r\n\t * Для генерации гостевой ссылки используйте store.genGuestLink(data, url)\r\n\t */\r\n\ttpaNamesGuestLink?: string[],\r\n};\r\n\r\ntype Context = PiniaPluginContext & {\r\n\toptions: Options\r\n};\r\n\r\n/**\r\n * Плагин tpa (Third-party access) для pinia\r\n *\r\n * Добавляет возможсноть сохранять и загружать данные в/из:\r\n * \t- localStorage\r\n * \t- URL hash\r\n * \t- гостевая ссылка\r\n *\r\n * Для подключение плагина нужно указань одну или несколько опций при defineStore():\r\n * - tpaNamesUrlHash: Array\r\n * - tpaNamesStorage: Array\r\n * - tpaNamesStorageLocal: Array\r\n * - tpaNamesGuestLink: Array\r\n */\r\nexport default (contextPinia: PiniaPluginContext) => {\r\n\tconst context = contextPinia as Context;\r\n\r\n\t// плагин подключать не нужно\r\n\tif (\r\n\t\t!context.options.tpaNamesUrlHash?.length &&\r\n\t\t!context.options.tpaNamesStorage?.length &&\r\n\t\t!context.options.tpaNamesStorageLocal?.length &&\r\n\t\t!context.options.tpaNamesGuestLink?.length\r\n\t) {\r\n\t\treturn;\r\n\t}\r\n\r\n\tnew PiniaTPA(context);\r\n}\r\n"],"names":["focus","el","binding","appStickyObserver","sticky","_vnode","className","entries","condition","_el","_binding","appSwimUpInited","appSwimUpObserver","directiveSwipUpOptions","appSwimUpEls","swimUpElTransform","windowHeight","distance","percent","elTop","triggerHeightReducer","triggerHeight","swimUpInit","entry","swimUp","Core","args","_a","$","_b","tvTooltipGenOptions","vnode","options","tooltip","_prevVnode","instance","core","app","name","directiveFocus","directiveSticky","directiveSwimUp","directiveTooltip","Forms.TopAvatar","Forms.TopButton","Forms.TopCheckbox","Forms.TopControlLabel","Forms.TopHint","Forms.TopInput","Forms.TopInputDate","Forms.TopInputRange","Forms.TopLoadbar","Forms.TopRadio","Forms.TopSelect","Forms.TopSwitcher","Forms.TopTextarea","PiniaTPA","#storeId","#store","#Page","#user","#Api","#namesUrlHash","#namesStorage","#namesStorageLocal","#namesGuestLink","context","url","data","#loadFromStorage","#loadFromHash","#loadFromGuestLink","#prepareParams","save","debounce","#saveInHash","#saveInStorage","dataGuestLink","#genOptionsForGuestLink","res","setClipboard","nameSnakeCase","camelToSnakeCase","#setOptions","value","currentValue","#genDataFormat","dataFormatted","#genDataUnFormat","dataHash","getHash","dataObject","dataJSON","setHash","isLocal","storageNamespace","names","guestData","$guestTitle","_c","competitors","competitor","watch","regionsIndexes","regionIndex","index","mapSearchers","availableRegionsIndexes","searcher","region","competitorsIds","competitorId","availableCompetitorsIds","piniaTPA","contextPinia","_d"],"mappings":"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"}
1
+ {"version":3,"file":"app.js","sources":["../../src/core/directives/focus.ts","../../src/core/directives/sticky.ts","../../src/core/directives/swimUp.ts","../../src/core/directives/tooltip.ts","../../src/core/plugins/core.ts","../../src/core/plugins/piniaTPA.ts"],"sourcesContent":["import type { DirectiveBinding, ObjectDirective } from 'vue';\n\n/**\n * Фокусировка на элементе сразу после его отображения\n */\nconst focus = {\n\tmounted: function (el: HTMLElement, binding: DirectiveBinding) {\n\t\tif (binding.value || binding.value === undefined) el.focus();\n\t}\n} satisfies ObjectDirective;\n\nexport default focus;\n","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\n\nlet appStickyObserver: IntersectionObserver;\n\n/**\n * Добавление sticky\n * К элементу добляется класс переданный как значение диррективы либо **'top-sticky'** по умолчанию\n */\nconst sticky = {\n\tmounted(el: HTMLElement, binding: DirectiveBinding, _vnode: VNode){\n\t\tconst className = binding.value || 'top-sticky';\n\n\t\tappStickyObserver = new IntersectionObserver(entries => {\n\t\t\tlet condition = entries[0].intersectionRatio < 1;\n\t\t\tif(condition){\n\t\t\t\tif(binding.arg === 'bottom' && entries[0].intersectionRect.y === 0) condition = false;\n\t\t\t}\n\n\t\t\tel.classList.toggle(className, condition);\n\t\t}, {\n\t\t\tthreshold:[1]\n\t\t});\n\n\t\tappStickyObserver.observe(el);\n\t},\n\n\tunmounted(_el: HTMLElement, _binding: DirectiveBinding, _vnode: VNode){\n\t\tappStickyObserver?.disconnect();\n\t},\n} satisfies ObjectDirective;\n\nexport default sticky;","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\nimport Core from '@/core/core/core';\n\ninterface SwipUpOptions {\n\tdistance: number,\n\tpercent: number,\n}\n\nlet appSwimUpInited = false;\nlet appSwimUpObserver: IntersectionObserver;\nlet directiveSwipUpOptions: SwipUpOptions;\nconst appSwimUpEls = new Map();\n\n\n/**\n * Отодвинуть блок в зависимости от скролла старинцы\n * @param el\n * @param windowHeight\n */\nconst swimUpElTransform = (el: HTMLElement, windowHeight: number): void => {\n\tconst { distance, percent } = directiveSwipUpOptions;\n\n\tconst elTop = el.getBoundingClientRect().top;\n\n\t// во столько раз triggerHeight должен быть меньше, чтобы закончить подплытие к нужной высоте экрана\n\tconst triggerHeightReducer = windowHeight * percent / 100 / distance;\n\tconst triggerHeight = (windowHeight - elTop) / triggerHeightReducer;\n\n\tif (triggerHeight <= distance) {\n\t\tel.style.transform = `translateY(${distance - triggerHeight}px)`;\n\t} else {\n\t\tel.style.transform = 'translateY(0px)';\n\t}\n}\n\nconst swimUpInit = (el: HTMLElement): void => {\n\tlet windowHeight = window.innerHeight;\n\n\twindow.addEventListener('scroll', () => {\n\t\tappSwimUpEls.forEach((el) => swimUpElTransform(el, windowHeight));\n\t}, { passive: true });\n\n\t// проверка того, что элемент в зоне видимости\n\tappSwimUpObserver = new IntersectionObserver(entries => {\n\t\twindowHeight = window.innerHeight;\n\n\t\tentries.forEach((entry) => {\n\t\t\tconst el = entry.target as HTMLElement;\n\n\t\t\tif (entry.intersectionRatio < 0.1) {\n\t\t\t\t// элемент за областью видимости\n\t\t\t\tappSwimUpEls.delete(el);\n\t\t\t} else {\n\t\t\t\t// элемент на экране\n\t\t\t\tappSwimUpEls.set(el, el);\n\t\t\t}\n\n\t\t\tif (entry.intersectionRatio === 0) {\n\t\t\t\tconst { distance, percent } = directiveSwipUpOptions;\n\t\t\t\tel.style.transform = `translateY(${distance}px)`;\n\t\t\t}\n\t\t});\n\t}, {\n\t\tthreshold: 0.1,\n\t});\n}\n\n/**\n * Добавление анимации подплытия вверх для блока\n */\nconst swimUp = {\n\tmounted(el: HTMLElement, binding: DirectiveBinding, _vnode: VNode): void {\n\t\tif (Core.state.isMobileUA) return;\n\n\t\tconst args = binding.arg?.split(':');\n\n\t\tlet distance = Number(args?.[0] ?? 100); // количество px на которые блок изначально смещен вниз\n\t\tlet percent = Number(args?.[1] ?? 30); // процент высоты экрана поднявшись на который блок закончит подплытие\n\n\t\tdirectiveSwipUpOptions = {\n\t\t\tdistance,\n\t\t\tpercent\n\t\t}\n\n\t\tif (!appSwimUpInited) {\n\t\t\tswimUpInit(el);\n\n\t\t\tappSwimUpInited = true;\n\t\t}\n\n\t\tappSwimUpObserver.observe(el);\n\t},\n\n\tunmounted(el: HTMLElement, _binding: DirectiveBinding, _vnode: VNode) {\n\t\tappSwimUpEls.delete(el);\n\t\tappSwimUpObserver?.unobserve(el);\n\t}\n} satisfies ObjectDirective;\n\nexport default swimUp;","import type { DirectiveBinding, ObjectDirective, VNode } from 'vue';\nimport Core from '@/core/core/core';\n\nconst $ = (el: VNode) => {\n\tif (!Core.$?.ui?.tooltip) {\n\t\tconsole.info('Для работы v-top-tooltip требуется глобальная загрузка jQuery UI Tooltip');\n\n\t\treturn;\n\t}\n\n\treturn Core.$(el);\n};\n\nconst tvTooltipGenOptions = (binding: DirectiveBinding, vnode: VNode) => {\n\tconst options = binding.value ?? {};\n\n\toptions.content ??= vnode.props?.title;\n\toptions.content = String(options.content).replace(/\\r\\n|\\r|\\n/g, '<br>');\n\n\toptions.position ??= {\n\t\tmy: 'bottom-18px',\n\t\tat: 'top center',\n\t};\n\n\treturn options;\n};\n\n/**\n * Добавление всплывающей подсказки к элементу.\n */\nconst tooltip = {\n\tmounted(el: VNode, binding: DirectiveBinding, vnode: VNode) {\n\t\t$(el)?.tooltip(tvTooltipGenOptions(binding, vnode));\n\t},\n\n\tupdated(el: VNode, binding: DirectiveBinding, vnode: VNode, _prevVnode: VNode) {\n\t\t/**\n\t\t * В результате обновления может быть открыто несколько тултипов поэтому изменить опции, без перерисовки тултипа\n\t\t */\n\t\tconst options = tvTooltipGenOptions(binding, vnode);\n\t\tconst instance = $(el)?.tooltip('instance') as { options: JQueryUI.TooltipOptions } | undefined;\n\t\tif (!instance) {\n\t\t\treturn;\n\t\t}\n\n\t\tinstance.options = {\n\t\t\t...instance.options,\n\t\t\t...options,\n\t\t};\n\t},\n\n\tunmounted(el: VNode, _binding: DirectiveBinding, _vnode: VNode) {\n\t\t$(el)?.tooltip('destroy');\n\t},\n} satisfies ObjectDirective;\n\nexport default tooltip;","import type { Plugin } from 'vue';\nimport Core from '@/core/core/core';\nimport coreDefaultOptions from '@/core/core/options';\nimport * as Forms from '../../components/forms/forms';\nimport directiveFocus from '@/core/directives/focus';\nimport directiveSticky from '@/core/directives/sticky';\nimport directiveSwimUp from '@/core/directives/swimUp';\nimport directiveTooltip from '@/core/directives/tooltip';\n\ndeclare module 'vue' {\n\texport interface ComponentCustomProperties {\n\t\t/**\n\t\t * Статический класс с текущим состоянимем UI\n\t\t */\n\t\t$core: typeof Core;\n\t}\n\n\t/**\n\t * Обязательные компоненты UI\n\t *\n\t * Они подключаются через плагин и доступны без явного указания импорта\n\t */\n\texport interface GlobalComponents {\n\t\tTopAvatar: typeof Forms.TopAvatar;\n\t\tTopButton: typeof Forms.TopButton;\n\t\tTopCheckbox: typeof Forms.TopCheckbox;\n\t\tTopControlLabel: typeof Forms.TopControlLabel;\n\t\tTopHint: typeof Forms.TopHint;\n\t\tTopInput: typeof Forms.TopInput;\n\t\tTopInputDate: typeof Forms.TopInputDate;\n\t\tTopInputRange: typeof Forms.TopInputRange;\n\t\tTopRadio: typeof Forms.TopRadio;\n\t\tTopSwitcher: typeof Forms.TopSwitcher;\n\t\tTopTextarea: typeof Forms.TopTextarea;\n\t\tTopSelect: typeof Forms.TopSelect;\n\t\tTopLoadbar: typeof Forms.TopLoadbar;\n\t}\n}\n\ntype PartialBy<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;\n\ntype Options = PartialBy<typeof coreDefaultOptions, 'gmt'>;\n\n/**\n * Плагин для интеграции UI во Vue приложение\n *\n * - В глобальную область видимости шаблонов будет добавлен объект $core\n * - Будут зарегистрирвоаны директивы UI: https://ui.topvisor.com/?path=/docs/core-directives-focus--docs\n * - Будут подключены базовые компоненты UI/Forms: https://ui.topvisor.com/?path=/docs/components-forms-readme--docs\n */\nexport default {\n\n\tinstall: (app, options: Options) => {\n\t\tapp.config.globalProperties.$core = Core;\n\n\t\t// начальные настройки UI\n\t\tfor (const name in options) {\n\t\t\tCore.state[name] = options[name];\n\t\t}\n\n\t\tCore.setState();\n\n\t\t// определение директив\n\t\tapp.directive('top-focus', directiveFocus);\n\t\tapp.directive('top-sticky', directiveSticky);\n\t\tapp.directive('top-swim-up', directiveSwimUp);\n\t\tapp.directive('top-tooltip', directiveTooltip);\n\n\t\t// определение базовых компонентов\n\t\tapp.component('TopAvatar', Forms.TopAvatar);\n\t\tapp.component('TopButton', Forms.TopButton);\n\t\tapp.component('TopCheckbox', Forms.TopCheckbox);\n\t\tapp.component('TopControlLabel', Forms.TopControlLabel);\n\t\tapp.component('TopHint', Forms.TopHint);\n\t\tapp.component('TopInput', Forms.TopInput);\n\t\tapp.component('TopInputDate', Forms.TopInputDate);\n\t\tapp.component('TopInputRange', Forms.TopInputRange);\n\t\tapp.component('TopLoadbar', Forms.TopLoadbar);\n\t\tapp.component('TopRadio', Forms.TopRadio);\n\t\tapp.component('TopSelect', Forms.TopSelect);\n\t\tapp.component('TopSwitcher', Forms.TopSwitcher);\n\t\tapp.component('TopTextarea', Forms.TopTextarea);\n\n\t},\n\n} satisfies Plugin<Options>;\n\n// export {\n// \tdirectiveFocus,\n// \tdirectiveSticky,\n// \tdirectiveSwimUp,\n// \tdirectiveTooltip,\n// };\n","import type { PiniaPluginContext, Store } from 'pinia';\nimport { watch } from 'vue';\nimport { debounce } from 'lodash';\nimport { setClipboard } 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<'test', 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});\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 setClipboard(res.result);\n\n\t\t// TODO: Оформить через компонент messages\n\t\talert('Link copied');\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\tif (Object.isFrozen(this)) throw 'Please, use setOptions only inner commit function';\n\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 (!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 dataFormatted: 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\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 * Сохранить опции в хеш адреса страницы\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\t// let names = this.#namesStorage;\n\t\tlet storageNamespace = 'state:' + this.#storeId;\n\n\t\tif (isLocal) {\n\t\t\t// names = this.#namesStorageLocal;\n\t\t\tstorageNamespace = 'state:' + this.#storeId + ':' + location.pathname;\n\t\t}\n\n\t\tthis.#namesStorage.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) => {\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) => {\n\t\t\t\tif (!competitorsIds.length) return;\n\n\t\t\t\t// приведение типа\n\t\t\t\tcompetitorsIds.forEach((competitorId: number, index: number) => competitorId[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});\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- localStorage\n * \t- URL hash\n * \t- гостевая ссылка\n *\n * Для подключение плагина нужно указань одну или несколько опций при defineStore():\n * - tpaNamesUrlHash: Array\n * - tpaNamesStorage: Array\n * - tpaNamesStorageLocal: Array\n * - tpaNamesGuestLink: Array\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":["focus","el","binding","appStickyObserver","sticky","_vnode","className","entries","condition","_el","_binding","appSwimUpInited","appSwimUpObserver","directiveSwipUpOptions","appSwimUpEls","swimUpElTransform","windowHeight","distance","percent","elTop","triggerHeightReducer","triggerHeight","swimUpInit","entry","swimUp","Core","args","_a","$","_b","tvTooltipGenOptions","vnode","options","tooltip","_prevVnode","instance","core","app","name","directiveFocus","directiveSticky","directiveSwimUp","directiveTooltip","Forms.TopAvatar","Forms.TopButton","Forms.TopCheckbox","Forms.TopControlLabel","Forms.TopHint","Forms.TopInput","Forms.TopInputDate","Forms.TopInputRange","Forms.TopLoadbar","Forms.TopRadio","Forms.TopSelect","Forms.TopSwitcher","Forms.TopTextarea","PiniaTPA","#storeId","#store","#Page","#user","#Api","#namesUrlHash","#namesStorage","#namesStorageLocal","#namesGuestLink","context","url","data","#loadFromStorage","#loadFromHash","#loadFromGuestLink","#prepareParams","save","debounce","#saveInHash","#saveInStorage","dataGuestLink","#genOptionsForGuestLink","res","setClipboard","nameSnakeCase","camelToSnakeCase","#setOptions","value","currentValue","#genDataFormat","dataFormatted","#genDataUnFormat","dataHash","getHash","dataObject","dataJSON","setHash","isLocal","storageNamespace","names","guestData","$guestTitle","_c","competitors","competitor","watch","regionsIndexes","regionIndex","index","mapSearchers","availableRegionsIndexes","searcher","region","competitorsIds","competitorId","availableCompetitorsIds","piniaTPA","contextPinia","_d"],"mappings":"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"}
@@ -1,7 +1,7 @@
1
1
  import { default as defaultOptions } from './options';
2
2
 
3
3
  /**
4
- * Статический класс с текущим состоянимем приложения
4
+ * Статический класс с текущим состоянимем UI
5
5
  */
6
6
  export default class Core {
7
7
  /**
@@ -30,6 +30,9 @@ declare const state: {
30
30
  * true при вертикальном расположении устройства
31
31
  */
32
32
  isPortrait: boolean;
33
+ /**
34
+ * Максимальная сторона страницы
35
+ */
33
36
  size: number;
34
37
  /**
35
38
  * true, если страница скрыта
package/core/core.amd.js CHANGED
@@ -1,2 +1,2 @@
1
- define(["require","exports","vue","../.chunks/forms-C__H1yL_.amd"],function(i,e,u,r){"use strict";if(typeof u>"u")var u=window.Vue;e.default=r.Core,Object.defineProperties(e,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})});
1
+ define(["require","exports","vue","../.chunks/forms-Bq9qpePc.amd"],function(i,e,u,r){"use strict";if(typeof u>"u")var u=window.Vue;e.default=r.Core,Object.defineProperties(e,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})});
2
2
  //# sourceMappingURL=core.amd.js.map
package/core/core.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import "vue";
2
- import { C as a } from "../.chunks/forms-BfIXIMY_.es.js";
2
+ import { C as a } from "../.chunks/forms-zcjs34Ku.es.js";
3
3
  export {
4
4
  a as default
5
5
  };
@@ -5,9 +5,10 @@ import { App } from 'vue';
5
5
  import * as Forms from '../../components/forms/forms';
6
6
  declare module 'vue' {
7
7
  interface ComponentCustomProperties {
8
- $top: {
9
- Core: typeof Core;
10
- };
8
+ /**
9
+ * Статический класс с текущим состоянимем UI
10
+ */
11
+ $core: typeof Core;
11
12
  }
12
13
  /**
13
14
  * Обязательные компоненты UI
@@ -35,7 +36,7 @@ type Options = PartialBy<typeof coreDefaultOptions, 'gmt'>;
35
36
  /**
36
37
  * Плагин для интеграции UI во Vue приложение
37
38
  *
38
- * - В глобальную область видимости шаблонов будет добавлен объект $top
39
+ * - В глобальную область видимости шаблонов будет добавлен объект $core
39
40
  * - Будут зарегистрирвоаны директивы UI: https://ui.topvisor.com/?path=/docs/core-directives-focus--docs
40
41
  * - Будут подключены базовые компоненты UI/Forms: https://ui.topvisor.com/?path=/docs/components-forms-readme--docs
41
42
  */
@@ -87,11 +87,11 @@ export default _default;
87
87
  *
88
88
  * @see I18n
89
89
  */
90
- export declare const useI18n: () => I18n;
90
+ export declare const useI18n: () => any;
91
91
  /**
92
92
  * Текущий язык
93
93
  */
94
- export declare const useI18nLang: () => any;
94
+ export declare const useI18nLang: () => Ref<any>;
95
95
  /**
96
96
  * Получить функцию для установки языка
97
97
  */
@@ -8,19 +8,19 @@
8
8
  * @param elsChildrens
9
9
  * @returns - созданный элемент
10
10
  */
11
- declare function genEl(tagName: string, attrs: any, ...elsChildrens: Element[] | string[]): Element;
11
+ export declare function genEl(tagName: string, attrs: any, ...elsChildrens: Element[] | string[]): Element;
12
12
  /**
13
13
  * Проверить видимость элемента
14
14
  * @param el
15
15
  * @returns - вернет true, если элемент считается видимым
16
16
  */
17
- declare function isVisible(el?: Element): boolean;
17
+ export declare function isVisible(el?: Element): boolean;
18
18
  /**
19
19
  * Получить координаты элемента относительно документа
20
20
  * @param el
21
21
  * @returns - координаты элемента относительно документа
22
22
  */
23
- declare function offset(el: Element): {
23
+ export declare function offset(el: Element): {
24
24
  top: number;
25
25
  left: number;
26
26
  };
@@ -30,38 +30,38 @@ declare function offset(el: Element): {
30
30
  * @param property - имя свойства
31
31
  * @return - значение css стиля
32
32
  */
33
- declare function css(el: Element, property: string): string;
33
+ export declare function css(el: Element, property: string): string;
34
34
  /**
35
35
  * Обернуть элемент и вернуть только что созданный элемент
36
36
  * @param el - элемент, который требуется обернуть
37
37
  * @param tagName - имя тега элемента, в который треубется обернуть элемент
38
38
  */
39
- declare function wrap(el: Element, tagName: string): Element;
39
+ export declare function wrap(el: Element, tagName: string): Element;
40
40
  /**
41
41
  * Найти и вернуть первый видимый элемент
42
42
  * @param el - корневой элемент поиска
43
43
  * @param selectors - см. параметр selectors в Document.querySelectorAll()
44
44
  */
45
- declare function querySelectorVisible(el: Element, selectors: string): Element | null;
45
+ export declare function querySelectorVisible(el: Element, selectors: string): Element | null;
46
46
  /**
47
47
  * Найти и вернуть последний видимый элемент
48
48
  * @param el - корневой элемент поиска
49
49
  * @param selectors - см. параметр selectors в Document.querySelectorAll()
50
50
  */
51
- declare function querySelectorVisibleLast(el: Element, selectors: string): Element | null;
51
+ export declare function querySelectorVisibleLast(el: Element, selectors: string): Element | null;
52
52
  /**
53
53
  * Найти видимые элементы
54
54
  * @param el - корневой элемент поиска
55
55
  * @param selectors - см. параметр selectors в Document.querySelectorAll()
56
56
  * @returns - обратите внимание, возвращается не NodeList[], а Element[]
57
57
  */
58
- declare function querySelectorAllVisible(el: Element | Document, selectors: string): Element[];
58
+ export declare function querySelectorAllVisible(el: Element | Document, selectors: string): Element[];
59
59
  /**
60
60
  * Найти элементы и вернуть в виде массива
61
61
  * @param el - корневой элемент поиска
62
62
  * @param selectors - см. параметр selectors в Document.querySelectorAll()
63
63
  */
64
- declare function querySelectorAllArray(el: Element | Document, selectors: string): Element[];
64
+ export declare function querySelectorAllArray(el: Element | Document, selectors: string): Element[];
65
65
  /**
66
66
  * Хранилище данных элемента
67
67
  * @param el
@@ -69,13 +69,13 @@ declare function querySelectorAllArray(el: Element | Document, selectors: string
69
69
  * @param contextData - установить объект с данными, предыдущие данные будут заменены, установите null для удаления данных
70
70
  * @returns - вернет объект контекста или undefined, если данные контекста не найдены
71
71
  */
72
- declare function storage(el?: Element & {
72
+ export declare function storage(el?: Element & {
73
73
  topData?: any;
74
74
  }, contextName?: string, contextData?: object | null | undefined): any | undefined;
75
75
  /**
76
76
  * Очистить хранилище элемента
77
77
  */
78
- declare function storageClear(el?: Element & {
78
+ export declare function storageClear(el?: Element & {
79
79
  topData?: any;
80
80
  }): void;
81
81
  declare const _default: {
@@ -1,2 +1,2 @@
1
- define(["require","exports","../.chunks/forms-C__H1yL_.amd"],function(n,T,a){"use strict";if(typeof e>"u")var e=window.Vue;T.TopAvatar=a.TopAvatar,T.TopButton=a.TopButton$1,T.TopCheckbox=a.TopCheckbox,T.TopControlLabel=a.TopControlLabel,T.TopHint=a.TopHint,T.TopInput=a.TopInput$1,T.TopInputDate=a.TopInputDate,T.TopInputRange=a.TopInputRange,T.TopLoadbar=a.TopLoadbar,T.TopRadio=a.TopRadio,T.TopSelect=a.TopSelect,T.TopSwitcher=a.TopSwitcher,T.TopTextarea=a.TopTextarea,Object.defineProperty(T,Symbol.toStringTag,{value:"Module"})});
1
+ define(["require","exports","../.chunks/forms-Bq9qpePc.amd"],function(n,T,a){"use strict";if(typeof e>"u")var e=window.Vue;T.TopAvatar=a.TopAvatar,T.TopButton=a.TopButton$1,T.TopCheckbox=a.TopCheckbox,T.TopControlLabel=a.TopControlLabel,T.TopHint=a.TopHint,T.TopInput=a.TopInput$1,T.TopInputDate=a.TopInputDate,T.TopInputRange=a.TopInputRange,T.TopLoadbar=a.TopLoadbar,T.TopRadio=a.TopRadio,T.TopSelect=a.TopSelect,T.TopSwitcher=a.TopSwitcher,T.TopTextarea=a.TopTextarea,Object.defineProperty(T,Symbol.toStringTag,{value:"Module"})});
2
2
  //# sourceMappingURL=forms.amd.js.map
package/forms/forms.js CHANGED
@@ -1,4 +1,4 @@
1
- import { c as p, e as T, f as s, g as t, h as e, j as n, k as r, l as c, m as l, n as u, o as b, p as h, q as i } from "../.chunks/forms-BfIXIMY_.es.js";
1
+ import { c as p, e as T, f as s, g as t, h as e, j as n, k as r, l as c, m as l, n as u, o as b, p as h, q as i } from "../.chunks/forms-zcjs34Ku.es.js";
2
2
  export {
3
3
  p as TopAvatar,
4
4
  T as TopButton,
@@ -1 +1 @@
1
- {"version":3,"file":"helpers.amd.js","sources":["../../src/components/forms/helpers.ts"],"sourcesContent":["/**\r\n * Размеры\r\n */\r\nexport const sizes = {\r\n\txs: 'xs',\r\n\ts: 's',\r\n\tm: 'm',\r\n\tl: 'l',\r\n} as const;\r\n\r\nexport type Size = typeof sizes[keyof typeof sizes];"],"names":["sizes"],"mappings":"yFAGO,MAAAA,EAAA,0BAKP"}
1
+ {"version":3,"file":"helpers.amd.js","sources":["../../src/components/forms/helpers.ts"],"sourcesContent":["/**\n * Размеры\n */\nexport const sizes = {\n\txs: 'xs',\n\ts: 's',\n\tm: 'm',\n\tl: 'l',\n} as const;\n\nexport type Size = typeof sizes[keyof typeof sizes];"],"names":["sizes"],"mappings":"yFAGO,MAAAA,EAAA,0BAKP"}
@@ -1 +1 @@
1
- {"version":3,"file":"helpers.js","sources":["../../src/components/forms/helpers.ts"],"sourcesContent":["/**\r\n * Размеры\r\n */\r\nexport const sizes = {\r\n\txs: 'xs',\r\n\ts: 's',\r\n\tm: 'm',\r\n\tl: 'l',\r\n} as const;\r\n\r\nexport type Size = typeof sizes[keyof typeof sizes];"],"names":["sizes"],"mappings":"AAGO,MAAMA,IAAQ;AAAA,EACpB,IAAI;AAAA,EACJ,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AACJ;"}
1
+ {"version":3,"file":"helpers.js","sources":["../../src/components/forms/helpers.ts"],"sourcesContent":["/**\n * Размеры\n */\nexport const sizes = {\n\txs: 'xs',\n\ts: 's',\n\tm: 'm',\n\tl: 'l',\n} as const;\n\nexport type Size = typeof sizes[keyof typeof sizes];"],"names":["sizes"],"mappings":"AAGO,MAAMA,IAAQ;AAAA,EACpB,IAAI;AAAA,EACJ,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AACJ;"}