@topvisor/ui 1.0.22-test-ci-cd-10 → 1.2.0

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 (941) hide show
  1. package/.gitlab-ci/.gitlab-ci.yml +26 -0
  2. package/.gitlab-ci/common/install.yml +21 -0
  3. package/.gitlab-ci/common/lint.yml +14 -0
  4. package/.gitlab-ci/common/version.yml +23 -0
  5. package/.gitlab-ci/storybook/build.yml +20 -0
  6. package/.gitlab-ci/storybook/deploy.yml +49 -0
  7. package/.gitlab-ci/ui/build.yml +13 -0
  8. package/.gitlab-ci/ui/deploy.yml +23 -0
  9. package/.idea/.gitignore +11 -0
  10. package/.idea/codeStyles/Project.xml +205 -0
  11. package/.idea/codeStyles/codeStyleConfig.xml +5 -0
  12. package/.idea/externalDependencies.xml +6 -0
  13. package/.idea/inspectionProfiles/Disabled.xml +824 -0
  14. package/.idea/inspectionProfiles/Project_Default.xml +33 -0
  15. package/.idea/php.xml +19 -0
  16. package/.idea/vcs.xml +6 -0
  17. package/.storybook/TopTheme.ts +115 -0
  18. package/.storybook/TopThemeManager.ts +53 -0
  19. package/.storybook/main.ts +51 -0
  20. package/.storybook/manager.ts +25 -0
  21. package/.storybook/preview-head.html +21 -0
  22. package/.storybook/preview.ts +47 -0
  23. package/.storybook/vue/coreDecorator.ts +77 -0
  24. package/.storybook/vue/vModelDecorator.ts +46 -0
  25. package/.versionrc.json +16 -0
  26. package/.vscode/extensions.json +11 -0
  27. package/.vscode/keybindings.example.json +121 -0
  28. package/.vscode/settings.json +45 -0
  29. package/CHANGELOG.md +223 -0
  30. package/NPM.md +25 -0
  31. package/PUBLISH.md +63 -0
  32. package/README.md +20 -69
  33. package/STORYBOOK.md +48 -0
  34. package/USE_IN_PROJECT.md +32 -0
  35. package/build/afterBuild.sh +11 -0
  36. package/build/cssModules.ts +39 -0
  37. package/build/genDocs.sh +19 -0
  38. package/build/plugin/amdFix.ts +83 -0
  39. package/build/plugin/autoloadCSS.ts +155 -0
  40. package/build/rollup.config.ts +37 -0
  41. package/package.json +56 -1
  42. package/public/README.md +82 -0
  43. package/src/components/charts/charts.ts +8 -0
  44. package/src/components/charts/miniChart/miniChart.stories.ts +67 -0
  45. package/src/components/charts/miniChart/miniChart.ts +110 -0
  46. package/src/components/charts/miniChart/miniChart.vue +158 -0
  47. package/src/components/charts/miniChart/stories/README.md +9 -0
  48. package/src/components/charts/miniChart/stories/dummy.ts +25 -0
  49. package/src/components/charts/miniChart/styles/miniChart.css +87 -0
  50. package/src/components/charts/miniChart/utils/consts.ts +9 -0
  51. package/src/components/charts/miniCharts/miniCharts.stories.ts +76 -0
  52. package/src/components/charts/miniCharts/miniCharts.ts +24 -0
  53. package/src/components/charts/miniCharts/miniCharts.vue +128 -0
  54. package/src/components/charts/miniCharts/stories/README.md +18 -0
  55. package/src/components/charts/miniCharts/stories/dummy.ts +70 -0
  56. package/src/components/charts/miniCharts/stories/overview.vue +139 -0
  57. package/src/components/charts/miniCharts/styles/miniCharts.css +32 -0
  58. package/src/components/component.ts +130 -0
  59. package/src/components/core/core.mdx +7 -0
  60. package/src/components/core/notice/item/item.vue +145 -0
  61. package/src/components/core/notice/item/style.css +70 -0
  62. package/src/components/core/notice/item/types.ts +71 -0
  63. package/src/components/core/notice/notice.stories.ts +105 -0
  64. package/src/components/core/notice/notice.vue +69 -0
  65. package/src/components/core/notice/stories/README.md +34 -0
  66. package/src/components/core/notice/types.ts +1 -0
  67. package/src/components/core/notice/utils.ts +115 -0
  68. package/src/components/dialog/dialog/Dialog (code).mdx +61 -0
  69. package/src/components/dialog/dialog/composables/asyncDialogHandle.ts +99 -0
  70. package/src/components/dialog/dialog/composables/dialogHandle.ts +176 -0
  71. package/src/components/dialog/dialog/composables/types.ts +12 -0
  72. package/src/components/dialog/dialog/composables/utils.ts +39 -0
  73. package/src/components/dialog/dialog/dialog.stories.ts +83 -0
  74. package/src/components/dialog/dialog/dialog.vue +74 -0
  75. package/src/components/dialog/dialog/dialogs/dialogs.vue +58 -0
  76. package/src/components/dialog/dialog/page/page.vue +86 -0
  77. package/src/components/dialog/dialog/page/types.ts +84 -0
  78. package/src/components/dialog/dialog/page.stories.ts +27 -0
  79. package/src/components/dialog/dialog/pageComponent/pageComponent.vue +57 -0
  80. package/src/components/dialog/dialog/pageComponent/types.ts +21 -0
  81. package/src/components/dialog/dialog/pageComponent.stories.ts +27 -0
  82. package/src/components/dialog/dialog/stories/README.md +117 -0
  83. package/src/components/dialog/dialog/stories/autoload.ts +12 -0
  84. package/src/components/dialog/dialog/stories/dialog_example/dialog_example.vue +73 -0
  85. package/src/components/dialog/dialog/stories/dialog_example/pages/async.vue +57 -0
  86. package/src/components/dialog/dialog/stories/dialog_example/pages/default.vue +64 -0
  87. package/src/components/dialog/dialog/stories/dialog_example/pages/headerButtons.vue +56 -0
  88. package/src/components/dialog/dialog/stories/dialog_example/pages/utils.ts +26 -0
  89. package/src/components/dialog/dialog/stories/dialog_example/pages/withoutCache.vue +64 -0
  90. package/src/components/dialog/dialog/stories/page/README.md +24 -0
  91. package/src/components/dialog/dialog/stories/pageComponent/README.md +12 -0
  92. package/src/components/dialog/dialog/style/dialog.css +316 -0
  93. package/src/components/dialog/dialog/style/dialog.m.css +40 -0
  94. package/src/components/dialog/dialog/style/dialog.pc.css +73 -0
  95. package/src/components/dialog/dialog/style/modern/dialog.css +12 -0
  96. package/src/components/dialog/dialog/style/modern/dialog.pc.css +3 -0
  97. package/src/components/dialog/dialog/types.ts +69 -0
  98. package/src/components/dialog/dialog.ts +7 -0
  99. package/src/components/dialog/lib/types.ts +26 -0
  100. package/src/components/dialog/lib/utils.globalEvents.ts +175 -0
  101. package/src/components/dialog/lib/utils.ts +525 -0
  102. package/src/components/dialog/lib/worker.ts +273 -0
  103. package/src/components/forms/README.mdx +10 -0
  104. package/src/components/forms/avatar/avatar.stories.ts +38 -0
  105. package/src/components/forms/avatar/avatar.ts +40 -0
  106. package/src/components/forms/avatar/avatar.vue +77 -0
  107. package/src/components/forms/avatar/stories/overview.vue +28 -0
  108. package/src/components/forms/button/button.stories.ts +118 -0
  109. package/src/components/forms/button/button.vue +111 -0
  110. package/src/components/forms/button/stories/README.md +9 -0
  111. package/src/components/forms/button/stories/overview.vue +33 -0
  112. package/src/components/forms/button/style/button.css +139 -0
  113. package/src/components/forms/button/style/style-outline.css +129 -0
  114. package/src/components/forms/button/style/style-soft.css +89 -0
  115. package/src/components/forms/button/style/style-transparent.css +39 -0
  116. package/src/components/forms/button/types.ts +66 -0
  117. package/src/components/forms/checkbox/checkbox.stories.ts +33 -0
  118. package/src/components/forms/checkbox/checkbox.ts +21 -0
  119. package/src/components/forms/checkbox/checkbox.vue +114 -0
  120. package/src/components/forms/checkbox/stories/overview.vue +171 -0
  121. package/src/components/forms/controlLabel/controlLabel.stories.ts +32 -0
  122. package/src/components/forms/controlLabel/controlLabel.ts +4 -0
  123. package/src/components/forms/controlLabel/controlLabel.vue +54 -0
  124. package/src/components/forms/forms.ts +40 -0
  125. package/src/components/forms/helpers.ts +11 -0
  126. package/src/components/forms/hint/hint.stories.ts +41 -0
  127. package/src/components/forms/hint/hint.ts +8 -0
  128. package/src/components/forms/hint/hint.vue +32 -0
  129. package/src/components/forms/input/input.stories.ts +32 -0
  130. package/src/components/forms/input/input.ts +47 -0
  131. package/src/components/forms/input/input.vue +189 -0
  132. package/src/components/forms/input/stories/overview.vue +61 -0
  133. package/src/components/forms/inputDate/datepicker.css +246 -0
  134. package/src/components/forms/inputDate/datepicker.ts +101 -0
  135. package/src/components/forms/inputDate/inputDate.stories.ts +41 -0
  136. package/src/components/forms/inputDate/inputDate.ts +5 -0
  137. package/src/components/forms/inputDate/inputDate.vue +133 -0
  138. package/src/components/forms/inputDate/stories/overview.vue +35 -0
  139. package/src/components/forms/inputRange/inputRange.stories.ts +53 -0
  140. package/src/components/forms/inputRange/inputRange.ts +3 -0
  141. package/src/components/forms/inputRange/inputRange.vue +39 -0
  142. package/src/components/forms/inputRange/stories/overview.vue +129 -0
  143. package/src/components/forms/loadbar/loadbar.stories.ts +17 -0
  144. package/src/components/forms/loadbar/loadbar.vue +37 -0
  145. package/src/components/forms/radio/radio.stories.ts +34 -0
  146. package/src/components/forms/radio/radio.ts +15 -0
  147. package/src/components/forms/radio/radio.vue +97 -0
  148. package/src/components/forms/radio/stories/overview.vue +79 -0
  149. package/src/components/forms/select/select.stories.ts +69 -0
  150. package/src/components/forms/select/select.ts +69 -0
  151. package/src/components/forms/select/select.vue +300 -0
  152. package/src/components/forms/select/stories/exampleOptions.ts +61 -0
  153. package/src/components/forms/select/stories/overview.vue +72 -0
  154. package/src/components/forms/switcher/stories/overview.vue +139 -0
  155. package/src/components/forms/switcher/switcher.stories.ts +33 -0
  156. package/src/components/forms/switcher/switcher.ts +22 -0
  157. package/src/components/forms/switcher/switcher.vue +118 -0
  158. package/src/components/forms/textarea/stories/overview.vue +62 -0
  159. package/src/components/forms/textarea/textarea.stories.ts +34 -0
  160. package/src/components/forms/textarea/textarea.ts +47 -0
  161. package/src/components/forms/textarea/textarea.vue +123 -0
  162. package/src/components/formsExt/README.mdx +5 -0
  163. package/src/components/formsExt/editArea/editArea.stories.ts +41 -0
  164. package/src/components/formsExt/editArea/editArea.ts +41 -0
  165. package/src/components/formsExt/editArea/editArea.vue +198 -0
  166. package/src/components/formsExt/editArea/stories/README.md +21 -0
  167. package/src/components/formsExt/editArea/stories/overview.vue +67 -0
  168. package/src/components/formsExt/editInput/editInput.stories.ts +36 -0
  169. package/src/components/formsExt/editInput/editInput.ts +20 -0
  170. package/src/components/formsExt/editInput/editInput.vue +54 -0
  171. package/src/components/formsExt/editInput/stories/overview.vue +54 -0
  172. package/src/components/formsExt/formsExt.ts +15 -0
  173. package/src/components/formsExt/info/info.stories.ts +35 -0
  174. package/src/components/formsExt/info/info.vue +84 -0
  175. package/src/components/formsExt/info/stories/overview.vue +29 -0
  176. package/src/components/formsExt/info/types.ts +25 -0
  177. package/src/components/formsExt/menu/menu.stories.ts +59 -0
  178. package/src/components/formsExt/menu/menu.ts +45 -0
  179. package/src/components/formsExt/menu/menu.vue +321 -0
  180. package/src/components/formsExt/menu/stories/items.ts +18 -0
  181. package/src/components/formsExt/menu/stories/overview.vue +52 -0
  182. package/src/components/formsExt/navigationMenu/item.vue +186 -0
  183. package/src/components/formsExt/navigationMenu/navigationMenu.stories.ts +37 -0
  184. package/src/components/formsExt/navigationMenu/navigationMenu.ts +28 -0
  185. package/src/components/formsExt/navigationMenu/navigationMenu.vue +40 -0
  186. package/src/components/formsExt/navigationMenu/stories/items.ts +116 -0
  187. package/src/components/formsExt/radioGroup/radioGroup.stories.ts +51 -0
  188. package/src/components/formsExt/radioGroup/radioGroup.ts +28 -0
  189. package/src/components/formsExt/radioGroup/radioGroup.vue +146 -0
  190. package/src/components/formsExt/radioGroup/stories/overview.vue +78 -0
  191. package/src/components/formsExt/radioGroup/styles/top-scrollBar.css +52 -0
  192. package/src/components/formsExt/selector2/api.ts +148 -0
  193. package/src/components/formsExt/selector2/itemMulti.vue +57 -0
  194. package/src/components/formsExt/selector2/selector2.stories.ts +48 -0
  195. package/src/components/formsExt/selector2/selector2.ts +145 -0
  196. package/src/components/formsExt/selector2/selector2.vue +389 -0
  197. package/src/components/formsExt/selector2/stories/dummyAPIRequest.ts +58 -0
  198. package/src/components/formsExt/selector2/stories/overview.vue +93 -0
  199. package/src/components/helper.js +10 -0
  200. package/src/components/helpersStories.ts +205 -0
  201. package/src/components/layout/islandRows/islandRows.stories.ts +139 -0
  202. package/src/components/layout/islandRows/islandRows.vue +53 -0
  203. package/src/components/layout/islandRows/islandRowsRow/islandRowsRow.vue +36 -0
  204. package/src/components/layout/islandRows/islandRowsRow/types.ts +1 -0
  205. package/src/components/layout/islandRows/islandRowsSubTitle/islandRowsSubTitle.vue +16 -0
  206. package/src/components/layout/islandRows/stories/README.md +8 -0
  207. package/src/components/layout/islandRows/types.ts +11 -0
  208. package/src/components/layout/layout.ts +11 -0
  209. package/src/components/layout/rows/rows.stories.ts +48 -0
  210. package/src/components/layout/rows/rows.vue +46 -0
  211. package/src/components/layout/rows/stories/README.md +10 -0
  212. package/src/components/layout/rows/types.ts +6 -0
  213. package/src/components/popup/alert/alert.stories.ts +71 -0
  214. package/src/components/popup/alert/alert.ts +11 -0
  215. package/src/components/popup/alert/alert.vue +46 -0
  216. package/src/components/popup/alert/stories/overview.vue +40 -0
  217. package/src/components/popup/confirm/confirm.stories.ts +75 -0
  218. package/src/components/popup/confirm/confirm.ts +26 -0
  219. package/src/components/popup/confirm/confirm.vue +75 -0
  220. package/src/components/popup/confirm/stories/overview.vue +62 -0
  221. package/src/components/popup/lib/popup.globalEvents.ts +239 -0
  222. package/src/components/popup/lib/popup.ts +790 -0
  223. package/src/components/popup/lib/worker.globalEvents.ts +97 -0
  224. package/src/components/popup/lib/worker.ts +286 -0
  225. package/src/components/popup/popup/listItem.vue +35 -0
  226. package/src/components/popup/popup/opener.vue +81 -0
  227. package/src/components/popup/popup/popup.stories.ts +74 -0
  228. package/src/components/popup/popup/popup.ts +120 -0
  229. package/src/components/popup/popup/popup.vue +168 -0
  230. package/src/components/popup/popup/stories/README.md +55 -0
  231. package/src/components/popup/popup/stories/listItems.vue +44 -0
  232. package/src/components/popup/popup/stories/listSubItems.vue +47 -0
  233. package/src/components/popup/popup/stories/overview.vue +210 -0
  234. package/src/components/popup/popup/style/popup.css +345 -0
  235. package/src/components/popup/popup/style/popup.m.css +72 -0
  236. package/src/components/popup/popup/style/popup.pc.css +26 -0
  237. package/src/components/popup/popup/widgetInput.vue +43 -0
  238. package/src/components/popup/popup.ts +17 -0
  239. package/src/components/popup/prompt/prompt.stories.ts +78 -0
  240. package/src/components/popup/prompt/prompt.ts +26 -0
  241. package/src/components/popup/prompt/prompt.vue +84 -0
  242. package/src/components/popup/prompt/stories/overview.vue +50 -0
  243. package/src/components/popup/worker.ts +1 -0
  244. package/src/components/project/project.ts +23 -0
  245. package/src/components/project/selectorCompetitors/composables.ts +21 -0
  246. package/src/components/project/selectorCompetitors/selectorCompetitors.stories.ts +33 -0
  247. package/src/components/project/selectorCompetitors/selectorCompetitors.ts +27 -0
  248. package/src/components/project/selectorCompetitors/selectorCompetitors.vue +75 -0
  249. package/src/components/project/selectorCompetitors/stories/README.md +20 -0
  250. package/src/components/project/selectorCompetitors/stories/items.ts +30 -0
  251. package/src/components/project/selectorCompetitors/types/competitor.ts +7 -0
  252. package/src/components/project/selectorRegion/composables/compare.ts +87 -0
  253. package/src/components/project/selectorRegion/composables/selectRegion.ts +147 -0
  254. package/src/components/project/selectorRegion/composables/selectSearcher.ts +64 -0
  255. package/src/components/project/selectorRegion/composables/selectorRegion.ts +167 -0
  256. package/src/components/project/selectorRegion/dialog_selectorRegions/dialog_selectorRegions.vue +190 -0
  257. package/src/components/project/selectorRegion/dialog_selectorRegions/style.css +49 -0
  258. package/src/components/project/selectorRegion/dialog_selectorRegions/types.ts +31 -0
  259. package/src/components/project/selectorRegion/selectorRegion.stories.ts +85 -0
  260. package/src/components/project/selectorRegion/selectorRegion.ts +204 -0
  261. package/src/components/project/selectorRegion/selectorRegion.vue +335 -0
  262. package/src/components/project/selectorRegion/stories/README.md +36 -0
  263. package/src/components/project/selectorRegion/stories/searchers.ts +77 -0
  264. package/src/components/project/selectorRegion/styles/searcherColors.css +41 -0
  265. package/src/components/project/selectorRegion/utils/consts.ts +73 -0
  266. package/src/components/project/selectorRegion/utils/utils.ts +167 -0
  267. package/src/components/project/tagSelector/popupListItem/tagPopupListItem.vue +209 -0
  268. package/src/components/project/tagSelector/popupListItem/types.ts +40 -0
  269. package/src/components/project/tagSelector/popupOpener/popupOpener.vue +145 -0
  270. package/src/components/project/tagSelector/popupOpener/types.ts +71 -0
  271. package/src/components/project/tagSelector/stories/README.md +62 -0
  272. package/src/components/project/tagSelector/stories/overview.vue +152 -0
  273. package/src/components/project/tagSelector/tagIcon/tagIcon.vue +97 -0
  274. package/src/components/project/tagSelector/tagIcon/types.ts +25 -0
  275. package/src/components/project/tagSelector/tagSelector.stories.ts +51 -0
  276. package/src/components/project/tagSelector/tagSelector.vue +359 -0
  277. package/src/components/project/tagSelector/tagsDefaults.ts +54 -0
  278. package/src/components/project/tagSelector/types.ts +159 -0
  279. package/src/components/project/tagSelector/utils/el.ts +151 -0
  280. package/src/components/project/tagSelector/utils/utils.ts +30 -0
  281. package/src/components/tabs/tabs/content.vue +24 -0
  282. package/src/components/tabs/tabs/stories/README.md +12 -0
  283. package/src/components/tabs/tabs/tab.vue +49 -0
  284. package/src/components/tabs/tabs/tabs.stories.ts +171 -0
  285. package/src/components/tabs/tabs/tabs.ts +22 -0
  286. package/src/components/tabs/tabs/tabs.vue +64 -0
  287. package/src/components/tabs/tabs.ts +9 -0
  288. package/src/components/tabsView/tabsView/menu.vue +291 -0
  289. package/src/components/tabsView/tabsView/menuDelimeter.vue +26 -0
  290. package/src/components/tabsView/tabsView/menuItem.vue +125 -0
  291. package/src/components/tabsView/tabsView/menuTitle.vue +46 -0
  292. package/src/components/tabsView/tabsView/store.ts +60 -0
  293. package/src/components/tabsView/tabsView/stories/README.md +22 -0
  294. package/src/components/tabsView/tabsView/tabsView.stories.ts +170 -0
  295. package/src/components/tabsView/tabsView/tabsView.ts +118 -0
  296. package/src/components/tabsView/tabsView/tabsView.vue +120 -0
  297. package/src/components/tabsView/tabsView/utils.ts +27 -0
  298. package/src/components/tabsView/tabsView//320/255/320/273/320/265/320/274/320/265/320/275/321/202/321/213/MenuItem.stories.ts +47 -0
  299. package/src/components/tabsView/tabsView//320/255/320/273/320/265/320/274/320/265/320/275/321/202/321/213/MenuTitle.stories.ts +43 -0
  300. package/src/components/tabsView/tabsView.ts +9 -0
  301. package/src/components/types.ts +3 -0
  302. package/src/core/app.ts +22 -0
  303. package/src/core/core/core.mdx +36 -0
  304. package/src/core/core/core.ts +287 -0
  305. package/src/core/core/events/resize.ts +47 -0
  306. package/src/core/core/events.ts +6 -0
  307. package/src/core/core/jQuery.mdx +41 -0
  308. package/src/core/core/options.ts +51 -0
  309. package/src/core/core/preloaders.ts +31 -0
  310. package/src/core/core/state.ts +61 -0
  311. package/src/core/directives/data.mdx +24 -0
  312. package/src/core/directives/data.ts +25 -0
  313. package/src/core/directives/focus.mdx +28 -0
  314. package/src/core/directives/focus.ts +73 -0
  315. package/src/core/directives/scrollIntoView.mdx +41 -0
  316. package/src/core/directives/scrollIntoView.ts +123 -0
  317. package/src/core/directives/scrollShadow.mdx +23 -0
  318. package/src/core/directives/scrollShadow.ts +27 -0
  319. package/src/core/directives/sticky.mdx +29 -0
  320. package/src/core/directives/sticky.ts +32 -0
  321. package/src/core/directives/swimUp.mdx +27 -0
  322. package/src/core/directives/swimUp.ts +95 -0
  323. package/src/core/directives/tooltip.mdx +13 -0
  324. package/src/core/directives/tooltip.ts +57 -0
  325. package/src/core/icons/gallery.vue +70 -0
  326. package/src/core/icons/icons.mdx +24 -0
  327. package/src/core/icons/icons.stories.ts +14 -0
  328. package/src/core/plugins/core.ts +131 -0
  329. package/src/core/plugins/i18n.ts +184 -0
  330. package/src/core/plugins/piniaTPA.ts +431 -0
  331. package/src/core/plugins/plugins.mdx +82 -0
  332. package/src/core/styles/CSS Variables.stories.ts +17 -0
  333. package/src/core/styles/styles.mdx +26 -0
  334. package/src/core/theme/Variables.stories.ts +16 -0
  335. package/src/core/theme/theme.mdx +117 -0
  336. package/src/core/utils/References/Docs.mdx +23 -0
  337. package/src/core/utils/References/check/Docs.mdx +15 -0
  338. package/src/core/utils/References/check/functions/getDomainRegexp.mdx +15 -0
  339. package/src/core/utils/References/check/functions/isDomain.mdx +21 -0
  340. package/src/core/utils/References/check/functions/isEmail.mdx +22 -0
  341. package/src/core/utils/References/check/functions/isIp.mdx +21 -0
  342. package/src/core/utils/References/check/functions/validUrl.mdx +22 -0
  343. package/src/core/utils/References/clipboard/Docs.mdx +11 -0
  344. package/src/core/utils/References/clipboard/functions/setClipboard.mdx +23 -0
  345. package/src/core/utils/References/date/Docs.mdx +17 -0
  346. package/src/core/utils/References/date/functions/dateFormat.mdx +28 -0
  347. package/src/core/utils/References/date/functions/dateToString.mdx +26 -0
  348. package/src/core/utils/References/date/functions/dateUnformat.mdx +22 -0
  349. package/src/core/utils/References/date/functions/genDate.mdx +26 -0
  350. package/src/core/utils/References/date/functions/genDateMoscow.mdx +22 -0
  351. package/src/core/utils/References/date/functions/getDayOfWeek.mdx +26 -0
  352. package/src/core/utils/References/date/functions/stringToDate.mdx +21 -0
  353. package/src/core/utils/References/device/Docs.mdx +21 -0
  354. package/src/core/utils/References/device/functions/get$scroll.mdx +15 -0
  355. package/src/core/utils/References/device/functions/getCommandKeyLabel.mdx +15 -0
  356. package/src/core/utils/References/device/functions/getElsScroll.mdx +15 -0
  357. package/src/core/utils/References/device/functions/getOS.mdx +17 -0
  358. package/src/core/utils/References/device/functions/getOSAsync.mdx +15 -0
  359. package/src/core/utils/References/device/functions/getScrollTop.mdx +15 -0
  360. package/src/core/utils/References/device/functions/isApp.mdx +15 -0
  361. package/src/core/utils/References/device/functions/isMacOS.mdx +15 -0
  362. package/src/core/utils/References/device/functions/isMobile.mdx +15 -0
  363. package/src/core/utils/References/device/functions/isRetina.mdx +15 -0
  364. package/src/core/utils/References/device/functions/isSafari.mdx +15 -0
  365. package/src/core/utils/References/dom/Docs.mdx +27 -0
  366. package/src/core/utils/References/dom/functions/css.mdx +24 -0
  367. package/src/core/utils/References/dom/functions/genEl.mdx +28 -0
  368. package/src/core/utils/References/dom/functions/isVisible.mdx +23 -0
  369. package/src/core/utils/References/dom/functions/offset.mdx +35 -0
  370. package/src/core/utils/References/dom/functions/querySelectorAllArray.mdx +22 -0
  371. package/src/core/utils/References/dom/functions/querySelectorAllVisible.mdx +22 -0
  372. package/src/core/utils/References/dom/functions/querySelectorVisible.mdx +22 -0
  373. package/src/core/utils/References/dom/functions/querySelectorVisibleLast.mdx +22 -0
  374. package/src/core/utils/References/dom/functions/storage.mdx +28 -0
  375. package/src/core/utils/References/dom/functions/storageClear.mdx +21 -0
  376. package/src/core/utils/References/dom/functions/wrap.mdx +22 -0
  377. package/src/core/utils/References/dom/variables/default.mdx +241 -0
  378. package/src/core/utils/References/image/Docs.mdx +12 -0
  379. package/src/core/utils/References/image/functions/downloadImageFromString.mdx +22 -0
  380. package/src/core/utils/References/image/functions/genFaviconImgHtml.mdx +22 -0
  381. package/src/core/utils/References/keyboard/Docs.mdx +11 -0
  382. package/src/core/utils/References/keyboard/functions/invertKeyboardLayout.mdx +21 -0
  383. package/src/core/utils/References/lodash/Docs.mdx +20 -0
  384. package/src/core/utils/References/lodash/functions/cloneDeep.mdx +29 -0
  385. package/src/core/utils/References/lodash/functions/debounce.mdx +76 -0
  386. package/src/core/utils/References/lodash/functions/memoize.mdx +26 -0
  387. package/src/core/utils/References/lodash/functions/merge.mdx +200 -0
  388. package/src/core/utils/References/lodash/functions/throttle.mdx +73 -0
  389. package/src/core/utils/References/number/Docs.mdx +11 -0
  390. package/src/core/utils/References/number/functions/percentOfNumber.mdx +26 -0
  391. package/src/core/utils/References/price/Docs.mdx +11 -0
  392. package/src/core/utils/References/price/functions/genPrice.mdx +28 -0
  393. package/src/core/utils/References/route/Docs.mdx +16 -0
  394. package/src/core/utils/References/route/functions/delHash.mdx +26 -0
  395. package/src/core/utils/References/route/functions/genHash.mdx +26 -0
  396. package/src/core/utils/References/route/functions/getHash.mdx +22 -0
  397. package/src/core/utils/References/route/functions/historySetState.mdx +31 -0
  398. package/src/core/utils/References/route/functions/setHash.mdx +26 -0
  399. package/src/core/utils/References/route/functions/setHashs.mdx +22 -0
  400. package/src/core/utils/References/scroll/Docs.mdx +14 -0
  401. package/src/core/utils/References/scroll/functions/amountScrolled.mdx +17 -0
  402. package/src/core/utils/References/scroll/functions/connectScrollShadow.mdx +28 -0
  403. package/src/core/utils/References/scroll/functions/genHasScroll.mdx +25 -0
  404. package/src/core/utils/References/scroll/functions/getScrollPercent.mdx +21 -0
  405. package/src/core/utils/References/searchers/Docs.mdx +19 -0
  406. package/src/core/utils/References/searchers/functions/genVolumeLabel.mdx +26 -0
  407. package/src/core/utils/References/searchers/functions/getDeviceGIcon.mdx +21 -0
  408. package/src/core/utils/References/searchers/functions/getLangLabel.mdx +22 -0
  409. package/src/core/utils/References/searchers/functions/getSearcherGIcon.mdx +21 -0
  410. package/src/core/utils/References/searchers/functions/prepareVolumeType.mdx +22 -0
  411. package/src/core/utils/References/searchers/variables/searchersNames.mdx +97 -0
  412. package/src/core/utils/References/store/Docs.mdx +18 -0
  413. package/src/core/utils/References/store/functions/defineStore.mdx +36 -0
  414. package/src/core/utils/References/store/functions/useStore.mdx +29 -0
  415. package/src/core/utils/References/store/variables/plugin.mdx +66 -0
  416. package/src/core/utils/References/string/Docs.mdx +26 -0
  417. package/src/core/utils/References/string/functions/addCommasWhite.mdx +21 -0
  418. package/src/core/utils/References/string/functions/addLinkTags.mdx +23 -0
  419. package/src/core/utils/References/string/functions/camelToSnakeCase.mdx +21 -0
  420. package/src/core/utils/References/string/functions/ellipsis.mdx +26 -0
  421. package/src/core/utils/References/string/functions/genFlagLinkByCountryCode.mdx +21 -0
  422. package/src/core/utils/References/string/functions/genIntHash.mdx +21 -0
  423. package/src/core/utils/References/string/functions/getRandomHash.mdx +21 -0
  424. package/src/core/utils/References/string/functions/highlightHtml.mdx +25 -0
  425. package/src/core/utils/References/string/functions/htmlspecialchars.mdx +21 -0
  426. package/src/core/utils/References/string/functions/isUrl.mdx +21 -0
  427. package/src/core/utils/References/string/functions/nl2br.mdx +21 -0
  428. package/src/core/utils/References/string/functions/numberEnding.mdx +28 -0
  429. package/src/core/utils/References/string/functions/numberWithWord.mdx +28 -0
  430. package/src/core/utils/References/string/functions/rusToLatin.mdx +21 -0
  431. package/src/core/utils/References/string/functions/toCapitalize.mdx +21 -0
  432. package/src/core/utils/References/string/functions/toRoditPadej.mdx +21 -0
  433. package/src/core/utils/References/system/Docs.mdx +13 -0
  434. package/src/core/utils/References/system/functions/sleep.mdx +21 -0
  435. package/src/core/utils/References/system/functions/sleepWhile.mdx +26 -0
  436. package/src/core/utils/References/system/functions/waitWhile.mdx +26 -0
  437. package/src/core/utils/References/url/Docs.mdx +17 -0
  438. package/src/core/utils/References/url/functions/decode.mdx +21 -0
  439. package/src/core/utils/References/url/functions/encode.mdx +21 -0
  440. package/src/core/utils/References/url/functions/fromPuny.mdx +23 -0
  441. package/src/core/utils/References/url/functions/getHost.mdx +21 -0
  442. package/src/core/utils/References/url/functions/hostToLowerCase.mdx +21 -0
  443. package/src/core/utils/References/url/functions/normalize.mdx +21 -0
  444. package/src/core/utils/References/url/functions/toPuny.mdx +23 -0
  445. package/src/core/utils/check.ts +88 -0
  446. package/src/core/utils/clipboard.ts +51 -0
  447. package/src/core/utils/date.ts +291 -0
  448. package/src/core/utils/device.ts +139 -0
  449. package/src/core/utils/dom.ts +182 -0
  450. package/src/core/utils/image.ts +46 -0
  451. package/src/core/utils/keyboard.ts +29 -0
  452. package/src/core/utils/lodash.ts +18 -0
  453. package/src/core/utils/number.ts +37 -0
  454. package/src/core/utils/price.ts +24 -0
  455. package/src/core/utils/route.ts +115 -0
  456. package/src/core/utils/scroll.ts +120 -0
  457. package/src/core/utils/searchers.ts +191 -0
  458. package/src/core/utils/store/localStorage.ts +56 -0
  459. package/src/core/utils/store/plugin.ts +50 -0
  460. package/src/core/utils/store/store.ts +77 -0
  461. package/src/core/utils/store.ts +7 -0
  462. package/src/core/utils/string.ts +317 -0
  463. package/src/core/utils/system.ts +72 -0
  464. package/src/core/utils/url.ts +138 -0
  465. package/src/core/utils/utils.mdx +6 -0
  466. package/src/d.ts +12 -0
  467. package/src/icomoon.d.ts +98 -0
  468. package/src/resources/styles/core/components.css +111 -0
  469. package/src/resources/styles/core/core.ts +11 -0
  470. package/src/resources/styles/core/forms/clear.css +20 -0
  471. package/src/resources/styles/core/forms/controls.css +20 -0
  472. package/src/resources/styles/core/forms/focusable.css +26 -0
  473. package/src/resources/styles/core/forms/forms.css +156 -0
  474. package/src/resources/styles/core/icon.css +58 -0
  475. package/src/resources/styles/core/jquery.css +1 -0
  476. package/src/resources/styles/core/layout.css +59 -0
  477. package/src/resources/styles/core/modifiers/as.css +9 -0
  478. package/src/resources/styles/core/modifiers/ellipsis.css +26 -0
  479. package/src/resources/styles/core/modifiers/modifiers.css +120 -0
  480. package/src/resources/styles/core/modifiers/only.css +19 -0
  481. package/src/resources/styles/core/modifiers/scrollShadow.css +50 -0
  482. package/src/resources/styles/core/select.css +15 -0
  483. package/src/resources/styles/storybook.css +11 -0
  484. package/src/resources/styles/themes/dark/dark-layout.css +47 -0
  485. package/src/resources/styles/themes/dark/dark-positions.css +66 -0
  486. package/src/resources/styles/themes/dark/dark.css +400 -0
  487. package/src/resources/styles/themes/dark-positions.ts +1 -0
  488. package/src/resources/styles/themes/dark-th/dark-th-layout.css +47 -0
  489. package/src/resources/styles/themes/dark-th/dark-th-positions.css +67 -0
  490. package/src/resources/styles/themes/dark-th/dark-th.css +400 -0
  491. package/src/resources/styles/themes/dark-th-positions.ts +1 -0
  492. package/src/resources/styles/themes/dark-th.ts +3 -0
  493. package/src/resources/styles/themes/dark.ts +3 -0
  494. package/src/resources/styles/themes/light/light-layout.css +47 -0
  495. package/src/resources/styles/themes/light/light-positions.css +66 -0
  496. package/src/resources/styles/themes/light/light.css +400 -0
  497. package/src/resources/styles/themes/light-positions.ts +1 -0
  498. package/src/resources/styles/themes/light.ts +3 -0
  499. package/src/storybook/components/color.vue +47 -0
  500. package/src/storybook/components/cssVariables.vue +195 -0
  501. package/src/storybook/components/icomoon.ts +40 -0
  502. package/src/storybook/jquery.ts +4 -0
  503. package/src//320/221/321/213/321/201/321/202/321/200/321/213/320/271 /321/201/321/202/320/260/321/200/321/202.mdx" +181 -0
  504. package/src//320/230/320/275/321/204/320/276/321/200/320/274/320/260/321/206/320/270/321/217 /320/276 /321/201/320/261/320/276/321/200/320/272/320/265.mdx" +12 -0
  505. package/src//320/240/320/260/320/267/321/200/320/260/320/261/320/276/321/202/320/272/320/260 (Contributing)/CHANGELOG.md.mdx" +4 -0
  506. package/src//320/240/320/260/320/267/321/200/320/260/320/261/320/276/321/202/320/272/320/260 (Contributing)/CSS/FAQ.mdx" +43 -0
  507. package/src//320/240/320/260/320/267/321/200/320/260/320/261/320/276/321/202/320/272/320/260 (Contributing)/CSS//320/236/320/261/321/211/320/270/320/265 /320/274/320/276/320/264/320/270/321/204/320/270/320/272/320/260/321/202/320/276/321/200/321/213.mdx" +155 -0
  508. package/src//320/240/320/260/320/267/321/200/320/260/320/261/320/276/321/202/320/272/320/260 (Contributing)/CSS//320/237/320/265/321/200/320/265/320/274/320/265/320/275/320/275/321/213/320/265.mdx" +35 -0
  509. package/src//320/240/320/260/320/267/321/200/320/260/320/261/320/276/321/202/320/272/320/260 (Contributing)/CSS//320/237/321/200/320/265/320/264/320/277/321/200/320/276/321/206/320/265/321/201/321/201/320/276/321/200/321/213.mdx" +15 -0
  510. package/src//320/240/320/260/320/267/321/200/320/260/320/261/320/276/321/202/320/272/320/260 (Contributing)/CSS//320/240/320/265/320/272/320/276/320/274/320/265/320/275/320/264/320/260/321/206/320/270/320/270 /320/221/320/255/320/234.mdx" +56 -0
  511. package/src//320/240/320/260/320/267/321/200/320/260/320/261/320/276/321/202/320/272/320/260 (Contributing)/CSS//320/241/321/202/320/270/320/273/320/270.mdx" +53 -0
  512. package/src//320/240/320/260/320/267/321/200/320/260/320/261/320/276/321/202/320/272/320/260 (Contributing)/CSS//320/247/321/202/320/276 /321/202/320/260/320/272/320/276/320/265 css /320/274/320/276/320/264/321/203/320/273/321/214.mdx" +55 -0
  513. package/src//320/240/320/260/320/267/321/200/320/260/320/261/320/276/321/202/320/272/320/260 (Contributing)/PUBLISH.md.mdx" +4 -0
  514. package/src//320/240/320/260/320/267/321/200/320/260/320/261/320/276/321/202/320/272/320/260 (Contributing)/README.md.mdx" +4 -0
  515. package/src//320/240/320/260/320/267/321/200/320/260/320/261/320/276/321/202/320/272/320/260 (Contributing)/STORYBOOK.md.mdx" +4 -0
  516. package/src//320/240/320/260/320/267/321/200/320/260/320/261/320/276/321/202/320/272/320/260 (Contributing)/USE_IN_PROJECT.md.mdx" +3 -0
  517. package/src//320/240/320/260/320/267/321/200/320/260/320/261/320/276/321/202/320/272/320/260 (Contributing)//320/222/320/262/320/265/320/264/320/265/320/275/320/270/320/265 /320/262 NPM.md.mdx" +4 -0
  518. package/src//320/240/320/260/320/267/321/200/320/260/320/261/320/276/321/202/320/272/320/260 (Contributing)//320/224/320/276/320/277/320/276/320/273/320/275/320/270/321/202/320/265/320/273/321/214/320/275/320/260/321/217 /320/273/320/270/321/202/320/265/321/200/320/260/321/202/321/203/321/200/320/260.mdx" +15 -0
  519. package/src//320/240/320/260/320/267/321/200/320/260/320/261/320/276/321/202/320/272/320/260 (Contributing)//320/241/321/202/320/260/320/275/320/264/320/260/321/200/321/202/321/213 /320/272/320/276/320/264/320/260//320/235/320/260/321/201/321/202/321/200/320/276/320/271/320/272/320/260 IDE.mdx" +45 -0
  520. package/src//320/240/320/260/320/267/321/200/320/260/320/261/320/276/321/202/320/272/320/260 (Contributing)//320/241/321/202/320/260/320/275/320/264/320/260/321/200/321/202/321/213 /320/272/320/276/320/264/320/260//320/236/321/204/320/276/321/200/320/274/320/273/320/265/320/275/320/270/320/265 /320/272/320/276/320/264/320/260.mdx" +31 -0
  521. package/src//320/240/320/260/320/267/321/200/320/260/320/261/320/276/321/202/320/272/320/260 (Contributing)//320/241/321/202/320/260/320/275/320/264/320/260/321/200/321/202/321/213 /320/272/320/276/320/264/320/260//320/241/321/202/320/260/320/275/320/264/320/260/321/200/321/202/321/213 /320/272/320/276/320/264/320/260.mdx" +29 -0
  522. package/src//320/240/320/260/320/267/321/200/320/260/320/261/320/276/321/202/320/272/320/260 (Contributing)//320/241/321/202/321/200/321/203/320/272/321/202/321/203/321/200/320/260 UI//320/232/320/276/320/274/320/277/320/276/320/275/320/265/320/275/321/202/321/213//320/232/320/276/320/274/320/277/320/276/320/275/320/265/320/275/321/202/321/213.mdx" +41 -0
  523. package/src//320/240/320/260/320/267/321/200/320/260/320/261/320/276/321/202/320/272/320/260 (Contributing)//320/241/321/202/321/200/321/203/320/272/321/202/321/203/321/200/320/260 UI//320/232/320/276/320/274/320/277/320/276/320/275/320/265/320/275/321/202/321/213//320/241/321/202/320/270/320/273/320/270 /320/272/320/276/320/274/320/277/320/276/320/275/320/265/320/275/321/202/321/213.mdx" +58 -0
  524. package/src//320/240/320/260/320/267/321/200/320/260/320/261/320/276/321/202/320/272/320/260 (Contributing)//320/241/321/202/321/200/321/203/320/272/321/202/321/203/321/200/320/260 UI//320/241/321/202/321/200/321/203/320/272/321/202/321/203/321/200/320/260 UI.mdx" +11 -0
  525. package/src//320/240/320/260/320/267/321/200/320/260/320/261/320/276/321/202/320/272/320/260 (Contributing)//320/241/321/202/321/200/321/203/320/272/321/202/321/203/321/200/320/260 UI//320/243/321/202/320/270/320/273/320/270/321/202/321/213.mdx" +5 -0
  526. package/storybook-dev.sh +14 -0
  527. package/tsconfig.json +91 -0
  528. package/typedoc.json +20 -0
  529. package/vite.config.ts +148 -0
  530. package/.chunks/core-CcWs0qYw.amd.js +0 -2
  531. package/.chunks/core-CcWs0qYw.amd.js.map +0 -1
  532. package/.chunks/core-Dsl28h7N.es.js +0 -196
  533. package/.chunks/core-Dsl28h7N.es.js.map +0 -1
  534. package/.chunks/datepicker-B6kIyIcw.amd.js +0 -2
  535. package/.chunks/datepicker-B6kIyIcw.amd.js.map +0 -1
  536. package/.chunks/datepicker-BTiE5Grw.es.js +0 -44
  537. package/.chunks/datepicker-BTiE5Grw.es.js.map +0 -1
  538. package/.chunks/dialog_selectorRegions-BZcnnvJM.es.js +0 -140
  539. package/.chunks/dialog_selectorRegions-BZcnnvJM.es.js.map +0 -1
  540. package/.chunks/dialog_selectorRegions-CePGUsCo.amd.js +0 -2
  541. package/.chunks/dialog_selectorRegions-CePGUsCo.amd.js.map +0 -1
  542. package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-B5hK613K.es.js +0 -266
  543. package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-B5hK613K.es.js.map +0 -1
  544. package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-izSFcRLb.amd.js +0 -2
  545. package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-izSFcRLb.amd.js.map +0 -1
  546. package/.chunks/forms-BsuCen2-.es.js +0 -1999
  547. package/.chunks/forms-BsuCen2-.es.js.map +0 -1
  548. package/.chunks/forms-BwGakScF.amd.js +0 -3
  549. package/.chunks/forms-BwGakScF.amd.js.map +0 -1
  550. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-CfM8kOV1.amd.js +0 -2
  551. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-CfM8kOV1.amd.js.map +0 -1
  552. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-CszHDnB0.es.js +0 -181
  553. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-CszHDnB0.es.js.map +0 -1
  554. package/.chunks/menu.vue_vue_type_style_index_0_lang-DQTVNJGq.amd.js +0 -2
  555. package/.chunks/menu.vue_vue_type_style_index_0_lang-DQTVNJGq.amd.js.map +0 -1
  556. package/.chunks/menu.vue_vue_type_style_index_0_lang-DmY5w4yr.es.js +0 -109
  557. package/.chunks/menu.vue_vue_type_style_index_0_lang-DmY5w4yr.es.js.map +0 -1
  558. package/.chunks/notice-CJdCc72d.amd.js +0 -4
  559. package/.chunks/notice-CJdCc72d.amd.js.map +0 -1
  560. package/.chunks/notice-Cqs1dKt8.es.js +0 -175
  561. package/.chunks/notice-Cqs1dKt8.es.js.map +0 -1
  562. package/.chunks/page.vue_vue_type_script_setup_true_lang-1JWduCTr.amd.js +0 -2
  563. package/.chunks/page.vue_vue_type_script_setup_true_lang-1JWduCTr.amd.js.map +0 -1
  564. package/.chunks/page.vue_vue_type_script_setup_true_lang-BCfksgg3.es.js +0 -143
  565. package/.chunks/page.vue_vue_type_script_setup_true_lang-BCfksgg3.es.js.map +0 -1
  566. package/.chunks/popup-CLhWWJDe.amd.js +0 -2
  567. package/.chunks/popup-CLhWWJDe.amd.js.map +0 -1
  568. package/.chunks/popup-N10MDafw.es.js +0 -416
  569. package/.chunks/popup-N10MDafw.es.js.map +0 -1
  570. package/.chunks/punycode.es6-C2yitnNb.amd.js +0 -2
  571. package/.chunks/punycode.es6-C2yitnNb.amd.js.map +0 -1
  572. package/.chunks/punycode.es6-CNI-zL6U.es.js +0 -134
  573. package/.chunks/punycode.es6-CNI-zL6U.es.js.map +0 -1
  574. package/.chunks/store-CX_6ZXhO.es.js +0 -29
  575. package/.chunks/store-CX_6ZXhO.es.js.map +0 -1
  576. package/.chunks/store-esTid5oI.amd.js +0 -2
  577. package/.chunks/store-esTid5oI.amd.js.map +0 -1
  578. package/.chunks/utils-B1H3EGkg.es.js +0 -79
  579. package/.chunks/utils-B1H3EGkg.es.js.map +0 -1
  580. package/.chunks/utils-B7GVqGBH.amd.js +0 -2
  581. package/.chunks/utils-B7GVqGBH.amd.js.map +0 -1
  582. package/.chunks/utils-DIy2mbYd.amd.js +0 -2
  583. package/.chunks/utils-DIy2mbYd.amd.js.map +0 -1
  584. package/.chunks/utils-bjr7c5my.es.js +0 -225
  585. package/.chunks/utils-bjr7c5my.es.js.map +0 -1
  586. package/assets/charts.css +0 -1
  587. package/assets/core.css +0 -1
  588. package/assets/dialog_selectorRegions.css +0 -1
  589. package/assets/forms.css +0 -1
  590. package/assets/formsExt.css +0 -1
  591. package/assets/layout.css +0 -1
  592. package/assets/listItem.css +0 -1
  593. package/assets/menu.css +0 -1
  594. package/assets/notice.css +0 -1
  595. package/assets/popup.css +0 -1
  596. package/assets/project.css +0 -1
  597. package/assets/tabs.css +0 -1
  598. package/assets/tabsView.css +0 -1
  599. package/assets/themes/dark-th.css +0 -1
  600. package/assets/themes/dark.css +0 -1
  601. package/assets/themes/light.css +0 -1
  602. package/charts/charts.amd.js +0 -2
  603. package/charts/charts.amd.js.map +0 -1
  604. package/charts/charts.d.ts +0 -2
  605. package/charts/charts.js +0 -178
  606. package/charts/charts.js.map +0 -1
  607. package/components/charts/charts.d.ts +0 -5
  608. package/components/charts/miniChart/miniChart.d.ts +0 -92
  609. package/components/charts/miniChart/miniChart.vue.d.ts +0 -15
  610. package/components/charts/miniChart/stories/dummy.d.ts +0 -13
  611. package/components/charts/miniChart/utils/consts.d.ts +0 -8
  612. package/components/charts/miniCharts/miniCharts.d.ts +0 -20
  613. package/components/charts/miniCharts/miniCharts.vue.d.ts +0 -32
  614. package/components/charts/miniCharts/stories/dummy.d.ts +0 -6
  615. package/components/core/notice/item/item.vue.d.ts +0 -10
  616. package/components/core/notice/item/types.d.ts +0 -61
  617. package/components/core/notice/notice.vue.d.ts +0 -5
  618. package/components/core/notice/types.d.ts +0 -1
  619. package/components/core/notice/utils.d.ts +0 -27
  620. package/components/dialog/dialog/composables/asyncDialogHandle.d.ts +0 -51
  621. package/components/dialog/dialog/composables/dialogHandle.d.ts +0 -108
  622. package/components/dialog/dialog/composables/types.d.ts +0 -11
  623. package/components/dialog/dialog/composables/utils.d.ts +0 -21
  624. package/components/dialog/dialog/dialog.vue.d.ts +0 -28
  625. package/components/dialog/dialog/dialogs/dialogs.vue.d.ts +0 -10
  626. package/components/dialog/dialog/page/page.vue.d.ts +0 -19
  627. package/components/dialog/dialog/page/types.d.ts +0 -72
  628. package/components/dialog/dialog/pageComponent/pageComponent.vue.d.ts +0 -6
  629. package/components/dialog/dialog/pageComponent/types.d.ts +0 -18
  630. package/components/dialog/dialog/stories/autoload.d.ts +0 -2
  631. package/components/dialog/dialog/stories/dialog_example/pages/utils.d.ts +0 -7
  632. package/components/dialog/dialog/types.d.ts +0 -58
  633. package/components/dialog/dialog.d.ts +0 -6
  634. package/components/dialog/lib/types.d.ts +0 -21
  635. package/components/dialog/lib/utils.d.ts +0 -14
  636. package/components/dialog/lib/utils.globalEvents.d.ts +0 -8
  637. package/components/dialog/lib/worker.d.ts +0 -60
  638. package/components/forms/avatar/avatar.d.ts +0 -38
  639. package/components/forms/avatar/avatar.vue.d.ts +0 -10
  640. package/components/forms/button/button.vue.d.ts +0 -25
  641. package/components/forms/button/types.d.ts +0 -53
  642. package/components/forms/checkbox/checkbox.d.ts +0 -21
  643. package/components/forms/checkbox/checkbox.vue.d.ts +0 -27
  644. package/components/forms/controlLabel/controlLabel.d.ts +0 -4
  645. package/components/forms/controlLabel/controlLabel.vue.d.ts +0 -19
  646. package/components/forms/forms.d.ts +0 -27
  647. package/components/forms/helpers.d.ts +0 -10
  648. package/components/forms/hint/hint.d.ts +0 -8
  649. package/components/forms/hint/hint.vue.d.ts +0 -4
  650. package/components/forms/input/input.d.ts +0 -34
  651. package/components/forms/input/input.vue.d.ts +0 -28
  652. package/components/forms/inputDate/datepicker.d.ts +0 -5
  653. package/components/forms/inputDate/inputDate.d.ts +0 -3
  654. package/components/forms/inputDate/inputDate.vue.d.ts +0 -12
  655. package/components/forms/inputRange/inputRange.d.ts +0 -2
  656. package/components/forms/inputRange/inputRange.vue.d.ts +0 -19
  657. package/components/forms/loadbar/loadbar.vue.d.ts +0 -3
  658. package/components/forms/radio/radio.d.ts +0 -14
  659. package/components/forms/radio/radio.vue.d.ts +0 -23
  660. package/components/forms/select/select.d.ts +0 -58
  661. package/components/forms/select/select.vue.d.ts +0 -18
  662. package/components/forms/select/stories/exampleOptions.d.ts +0 -5
  663. package/components/forms/switcher/switcher.d.ts +0 -21
  664. package/components/forms/switcher/switcher.vue.d.ts +0 -23
  665. package/components/forms/textarea/textarea.d.ts +0 -40
  666. package/components/forms/textarea/textarea.vue.d.ts +0 -12
  667. package/components/formsExt/editArea/editArea.d.ts +0 -33
  668. package/components/formsExt/editArea/editArea.vue.d.ts +0 -18
  669. package/components/formsExt/editInput/editInput.d.ts +0 -16
  670. package/components/formsExt/editInput/editInput.vue.d.ts +0 -8
  671. package/components/formsExt/formsExt.d.ts +0 -13
  672. package/components/formsExt/info/info.vue.d.ts +0 -20
  673. package/components/formsExt/info/types.d.ts +0 -21
  674. package/components/formsExt/menu/menu.d.ts +0 -37
  675. package/components/formsExt/menu/menu.vue.d.ts +0 -16
  676. package/components/formsExt/menu/stories/items.d.ts +0 -3
  677. package/components/formsExt/navigationMenu/navigationMenu.d.ts +0 -24
  678. package/components/formsExt/navigationMenu/stories/items.d.ts +0 -3
  679. package/components/formsExt/radioGroup/radioGroup.d.ts +0 -21
  680. package/components/formsExt/radioGroup/radioGroup.vue.d.ts +0 -19
  681. package/components/formsExt/selector2/api.d.ts +0 -8
  682. package/components/formsExt/selector2/itemMulti.vue.d.ts +0 -8
  683. package/components/formsExt/selector2/selector2.d.ts +0 -130
  684. package/components/formsExt/selector2/selector2.vue.d.ts +0 -210
  685. package/components/formsExt/selector2/stories/dummyAPIRequest.d.ts +0 -10
  686. package/components/layout/islandRows/islandRows.vue.d.ts +0 -17
  687. package/components/layout/islandRows/islandRowsRow/islandRowsRow.vue.d.ts +0 -18
  688. package/components/layout/islandRows/islandRowsRow/types.d.ts +0 -2
  689. package/components/layout/islandRows/islandRowsSubTitle/islandRowsSubTitle.vue.d.ts +0 -18
  690. package/components/layout/islandRows/types.d.ts +0 -10
  691. package/components/layout/layout.d.ts +0 -9
  692. package/components/layout/rows/rows.vue.d.ts +0 -21
  693. package/components/layout/rows/types.d.ts +0 -6
  694. package/components/popup/alert/alert.d.ts +0 -8
  695. package/components/popup/alert/alert.vue.d.ts +0 -31
  696. package/components/popup/confirm/confirm.d.ts +0 -21
  697. package/components/popup/confirm/confirm.vue.d.ts +0 -33
  698. package/components/popup/lib/popup.d.ts +0 -83
  699. package/components/popup/lib/popup.globalEvents.d.ts +0 -26
  700. package/components/popup/lib/worker.d.ts +0 -75
  701. package/components/popup/lib/worker.globalEvents.d.ts +0 -19
  702. package/components/popup/popup/listItem.vue.d.ts +0 -22
  703. package/components/popup/popup/opener.vue.d.ts +0 -23
  704. package/components/popup/popup/popup.d.ts +0 -101
  705. package/components/popup/popup/popup.vue.d.ts +0 -40
  706. package/components/popup/popup/widgetInput.vue.d.ts +0 -17
  707. package/components/popup/popup.d.ts +0 -15
  708. package/components/popup/prompt/prompt.d.ts +0 -21
  709. package/components/popup/prompt/prompt.vue.d.ts +0 -33
  710. package/components/popup/worker.d.ts +0 -1
  711. package/components/project/project.d.ts +0 -15
  712. package/components/project/selectorCompetitors/composables.d.ts +0 -4
  713. package/components/project/selectorCompetitors/selectorCompetitors.d.ts +0 -23
  714. package/components/project/selectorCompetitors/selectorCompetitors.vue.d.ts +0 -14
  715. package/components/project/selectorCompetitors/stories/items.d.ts +0 -3
  716. package/components/project/selectorCompetitors/types/competitor.d.ts +0 -7
  717. package/components/project/selectorRegion/composables/compare.d.ts +0 -12
  718. package/components/project/selectorRegion/composables/selectRegion.d.ts +0 -14
  719. package/components/project/selectorRegion/composables/selectSearcher.d.ts +0 -13
  720. package/components/project/selectorRegion/composables/selectorRegion.d.ts +0 -25
  721. package/components/project/selectorRegion/dialog_selectorRegions/dialog_selectorRegions.vue.d.ts +0 -4
  722. package/components/project/selectorRegion/dialog_selectorRegions/types.d.ts +0 -26
  723. package/components/project/selectorRegion/selectorRegion.d.ts +0 -170
  724. package/components/project/selectorRegion/selectorRegion.vue.d.ts +0 -23
  725. package/components/project/selectorRegion/stories/searchers.d.ts +0 -3
  726. package/components/project/selectorRegion/utils/consts.d.ts +0 -18
  727. package/components/project/selectorRegion/utils/utils.d.ts +0 -32
  728. package/components/project/tagSelector/popupListItem/tagPopupListItem.vue.d.ts +0 -20
  729. package/components/project/tagSelector/popupListItem/types.d.ts +0 -33
  730. package/components/project/tagSelector/popupOpener/popupOpener.vue.d.ts +0 -27
  731. package/components/project/tagSelector/popupOpener/types.d.ts +0 -62
  732. package/components/project/tagSelector/tagIcon/tagIcon.vue.d.ts +0 -4
  733. package/components/project/tagSelector/tagIcon/types.d.ts +0 -21
  734. package/components/project/tagSelector/tagSelector.vue.d.ts +0 -37
  735. package/components/project/tagSelector/tagsDefaults.d.ts +0 -3
  736. package/components/project/tagSelector/types.d.ts +0 -138
  737. package/components/project/tagSelector/utils/el.d.ts +0 -19
  738. package/components/project/tagSelector/utils/utils.d.ts +0 -14
  739. package/components/tabs/tabs/content.vue.d.ts +0 -19
  740. package/components/tabs/tabs/tab.vue.d.ts +0 -19
  741. package/components/tabs/tabs/tabs.d.ts +0 -19
  742. package/components/tabs/tabs/tabs.vue.d.ts +0 -21
  743. package/components/tabs/tabs.d.ts +0 -7
  744. package/components/tabsView/tabsView/menu.vue.d.ts +0 -32
  745. package/components/tabsView/tabsView/menuDelimeter.vue.d.ts +0 -3
  746. package/components/tabsView/tabsView/menuItem.vue.d.ts +0 -23
  747. package/components/tabsView/tabsView/menuTitle.vue.d.ts +0 -20
  748. package/components/tabsView/tabsView/store.d.ts +0 -192
  749. package/components/tabsView/tabsView/tabsView.d.ts +0 -98
  750. package/components/tabsView/tabsView/tabsView.vue.d.ts +0 -34
  751. package/components/tabsView/tabsView/utils.d.ts +0 -11
  752. package/components/tabsView/tabsView.d.ts +0 -7
  753. package/core/app.amd.js +0 -2
  754. package/core/app.amd.js.map +0 -1
  755. package/core/app.d.ts +0 -8
  756. package/core/app.js +0 -214
  757. package/core/app.js.map +0 -1
  758. package/core/core/core.d.ts +0 -113
  759. package/core/core/events/resize.d.ts +0 -16
  760. package/core/core/events.d.ts +0 -15
  761. package/core/core/options.d.ts +0 -46
  762. package/core/core/preloaders.d.ts +0 -19
  763. package/core/core/state.d.ts +0 -49
  764. package/core/directives/data.d.ts +0 -10
  765. package/core/directives/focus.d.ts +0 -10
  766. package/core/directives/scrollIntoView.d.ts +0 -3
  767. package/core/directives/scrollShadow.d.ts +0 -15
  768. package/core/directives/sticky.d.ts +0 -10
  769. package/core/directives/swimUp.d.ts +0 -15
  770. package/core/directives/tooltip.d.ts +0 -10
  771. package/core/plugins/core.d.ts +0 -60
  772. package/core/plugins/i18n.d.ts +0 -97
  773. package/core/plugins/piniaTPA.d.ts +0 -17
  774. package/core/utils/check.d.ts +0 -26
  775. package/core/utils/clipboard.d.ts +0 -12
  776. package/core/utils/date.d.ts +0 -52
  777. package/core/utils/device.d.ts +0 -50
  778. package/core/utils/dom.d.ts +0 -94
  779. package/core/utils/image.d.ts +0 -16
  780. package/core/utils/keyboard.d.ts +0 -8
  781. package/core/utils/lodash.d.ts +0 -6
  782. package/core/utils/number.d.ts +0 -17
  783. package/core/utils/price.d.ts +0 -10
  784. package/core/utils/route.d.ts +0 -33
  785. package/core/utils/scroll.d.ts +0 -32
  786. package/core/utils/searchers.d.ts +0 -38
  787. package/core/utils/store/localStorage.d.ts +0 -6
  788. package/core/utils/store/plugin.d.ts +0 -24
  789. package/core/utils/store/store.d.ts +0 -34
  790. package/core/utils/store.d.ts +0 -6
  791. package/core/utils/string.d.ts +0 -88
  792. package/core/utils/system.d.ts +0 -25
  793. package/core/utils/url.d.ts +0 -36
  794. package/dialog/dialog.amd.js +0 -2
  795. package/dialog/dialog.amd.js.map +0 -1
  796. package/dialog/dialog.d.ts +0 -2
  797. package/dialog/dialog.js +0 -60
  798. package/dialog/dialog.js.map +0 -1
  799. package/forms/forms.amd.js +0 -2
  800. package/forms/forms.amd.js.map +0 -1
  801. package/forms/forms.d.ts +0 -2
  802. package/forms/forms.js +0 -17
  803. package/forms/forms.js.map +0 -1
  804. package/forms/helpers.amd.js +0 -2
  805. package/forms/helpers.amd.js.map +0 -1
  806. package/forms/helpers.d.ts +0 -2
  807. package/forms/helpers.js +0 -10
  808. package/forms/helpers.js.map +0 -1
  809. package/formsExt/formsExt.amd.js +0 -2
  810. package/formsExt/formsExt.amd.js.map +0 -1
  811. package/formsExt/formsExt.d.ts +0 -2
  812. package/formsExt/formsExt.js +0 -493
  813. package/formsExt/formsExt.js.map +0 -1
  814. package/layout/layout.amd.js +0 -2
  815. package/layout/layout.amd.js.map +0 -1
  816. package/layout/layout.d.ts +0 -2
  817. package/layout/layout.js +0 -62
  818. package/layout/layout.js.map +0 -1
  819. package/popup/popup.amd.js +0 -2
  820. package/popup/popup.amd.js.map +0 -1
  821. package/popup/popup.d.ts +0 -2
  822. package/popup/popup.js +0 -244
  823. package/popup/popup.js.map +0 -1
  824. package/popup/worker.amd.js +0 -2
  825. package/popup/worker.amd.js.map +0 -1
  826. package/popup/worker.d.ts +0 -2
  827. package/popup/worker.js +0 -129
  828. package/popup/worker.js.map +0 -1
  829. package/project/project.amd.js +0 -2
  830. package/project/project.amd.js.map +0 -1
  831. package/project/project.d.ts +0 -2
  832. package/project/project.js +0 -976
  833. package/project/project.js.map +0 -1
  834. package/tabs/tabs.amd.js +0 -2
  835. package/tabs/tabs.amd.js.map +0 -1
  836. package/tabs/tabs.d.ts +0 -2
  837. package/tabs/tabs.js +0 -81
  838. package/tabs/tabs.js.map +0 -1
  839. package/tabsView/tabsView.amd.js +0 -2
  840. package/tabsView/tabsView.amd.js.map +0 -1
  841. package/tabsView/tabsView.d.ts +0 -2
  842. package/tabsView/tabsView.js +0 -306
  843. package/tabsView/tabsView.js.map +0 -1
  844. package/utils/check.amd.js +0 -2
  845. package/utils/check.amd.js.map +0 -1
  846. package/utils/check.d.ts +0 -2
  847. package/utils/check.js +0 -26
  848. package/utils/check.js.map +0 -1
  849. package/utils/clipboard.amd.js +0 -6
  850. package/utils/clipboard.amd.js.map +0 -1
  851. package/utils/clipboard.d.ts +0 -2
  852. package/utils/clipboard.js +0 -33
  853. package/utils/clipboard.js.map +0 -1
  854. package/utils/date.amd.js +0 -2
  855. package/utils/date.amd.js.map +0 -1
  856. package/utils/date.d.ts +0 -2
  857. package/utils/date.js +0 -11
  858. package/utils/date.js.map +0 -1
  859. package/utils/device.amd.js +0 -2
  860. package/utils/device.amd.js.map +0 -1
  861. package/utils/device.d.ts +0 -2
  862. package/utils/device.js +0 -15
  863. package/utils/device.js.map +0 -1
  864. package/utils/dom.amd.js +0 -2
  865. package/utils/dom.amd.js.map +0 -1
  866. package/utils/dom.d.ts +0 -6
  867. package/utils/dom.js +0 -75
  868. package/utils/dom.js.map +0 -1
  869. package/utils/image.amd.js +0 -12
  870. package/utils/image.amd.js.map +0 -1
  871. package/utils/image.d.ts +0 -2
  872. package/utils/image.js +0 -23
  873. package/utils/image.js.map +0 -1
  874. package/utils/keyboard.amd.js +0 -2
  875. package/utils/keyboard.amd.js.map +0 -1
  876. package/utils/keyboard.d.ts +0 -2
  877. package/utils/keyboard.js +0 -12
  878. package/utils/keyboard.js.map +0 -1
  879. package/utils/lodash.amd.js +0 -2
  880. package/utils/lodash.amd.js.map +0 -1
  881. package/utils/lodash.d.ts +0 -2
  882. package/utils/lodash.js +0 -9
  883. package/utils/lodash.js.map +0 -1
  884. package/utils/number.amd.js +0 -2
  885. package/utils/number.amd.js.map +0 -1
  886. package/utils/number.d.ts +0 -2
  887. package/utils/number.js +0 -13
  888. package/utils/number.js.map +0 -1
  889. package/utils/price.amd.js +0 -2
  890. package/utils/price.amd.js.map +0 -1
  891. package/utils/price.d.ts +0 -2
  892. package/utils/price.js +0 -10
  893. package/utils/price.js.map +0 -1
  894. package/utils/route.amd.js +0 -2
  895. package/utils/route.amd.js.map +0 -1
  896. package/utils/route.d.ts +0 -2
  897. package/utils/route.js +0 -31
  898. package/utils/route.js.map +0 -1
  899. package/utils/scroll.amd.js +0 -2
  900. package/utils/scroll.amd.js.map +0 -1
  901. package/utils/scroll.d.ts +0 -2
  902. package/utils/scroll.js +0 -45
  903. package/utils/scroll.js.map +0 -1
  904. package/utils/searchers.amd.js +0 -2
  905. package/utils/searchers.amd.js.map +0 -1
  906. package/utils/searchers.d.ts +0 -2
  907. package/utils/searchers.js +0 -134
  908. package/utils/searchers.js.map +0 -1
  909. package/utils/store.amd.js +0 -2
  910. package/utils/store.amd.js.map +0 -1
  911. package/utils/store.d.ts +0 -2
  912. package/utils/store.js +0 -7
  913. package/utils/store.js.map +0 -1
  914. package/utils/string.amd.js +0 -2
  915. package/utils/string.amd.js.map +0 -1
  916. package/utils/string.d.ts +0 -2
  917. package/utils/string.js +0 -139
  918. package/utils/string.js.map +0 -1
  919. package/utils/system.amd.js +0 -2
  920. package/utils/system.amd.js.map +0 -1
  921. package/utils/system.d.ts +0 -2
  922. package/utils/system.js +0 -29
  923. package/utils/system.js.map +0 -1
  924. package/utils/url.amd.js +0 -3
  925. package/utils/url.amd.js.map +0 -1
  926. package/utils/url.d.ts +0 -2
  927. package/utils/url.js +0 -48
  928. package/utils/url.js.map +0 -1
  929. /package/{icomoon → public/icomoon}/Read Me.txt +0 -0
  930. /package/{icomoon → public/icomoon}/Topvisor icons.json +0 -0
  931. /package/{icomoon → public/icomoon}/demo-files/demo.css +0 -0
  932. /package/{icomoon → public/icomoon}/demo-files/demo.js +0 -0
  933. /package/{icomoon → public/icomoon}/demo.html +0 -0
  934. /package/{icomoon → public/icomoon}/fonts/Topvisor-2.eot +0 -0
  935. /package/{icomoon → public/icomoon}/fonts/Topvisor-2.svg +0 -0
  936. /package/{icomoon → public/icomoon}/fonts/Topvisor-2.ttf +0 -0
  937. /package/{icomoon → public/icomoon}/fonts/Topvisor-2.woff +0 -0
  938. /package/{icomoon → public/icomoon}/selection.json +0 -0
  939. /package/{icomoon → public/icomoon}/style.css +0 -0
  940. /package/{jquery-ui.min.css → public/jquery-ui.min.css} +0 -0
  941. /package/{require → public/require}/css.amd.js +0 -0
@@ -0,0 +1,74 @@
1
+ <script setup lang="ts">
2
+ import type { ComponentInternalInstance } from 'vue';
3
+ import { getCurrentInstance, onMounted, provide, watch } from 'vue';
4
+ import { getDialogWorker } from './dialogs/dialogs.vue';
5
+ import type { Emits, Props, Slots } from './types';
6
+
7
+ const props = withDefaults(defineProps<Props>(), {
8
+ width: '600px',
9
+ height: 'auto',
10
+ modal: true,
11
+ historyType: 'push',
12
+ });
13
+
14
+ defineEmits<Emits>();
15
+
16
+ defineSlots<Slots>();
17
+
18
+ const dialog = getDialogWorker(props.id);
19
+ if (!dialog) {
20
+ throw new Error('TopDialog cannot be used in a template, use useTopDialog() / useAsyncTopDialog()');
21
+ }
22
+
23
+ /**
24
+ * Для useTopDialogSelf()
25
+ */
26
+ provide('dialogWorker', dialog);
27
+
28
+ /**
29
+ * Инициализация начального состояния TopDialogHandle
30
+ */
31
+ onMounted(() => {
32
+ const topDialogBaseComponent = getCurrentInstance() as ComponentInternalInstance;
33
+ const topDialogComponent = topDialogBaseComponent.parent;
34
+
35
+ if (topDialogComponent?.parent?.type.name !== 'DialogWrapper') {
36
+ throw new Error('TopDialog cannot be used in a template, use useTopDialog()');
37
+ }
38
+
39
+ if (Array.isArray(topDialogComponent.subTree.children) && topDialogComponent.subTree.children.length !== 1) {
40
+ throw new Error('TopDialog can has only one root element');
41
+ }
42
+
43
+ dialog.onMounted(topDialogComponent, topDialogBaseComponent);
44
+ });
45
+
46
+ watch(dialog.isOpened, () => {
47
+ dialog.isReady.value = true;
48
+ }, {
49
+ flush: 'post',
50
+ once: true,
51
+ });
52
+ </script>
53
+
54
+ <template>
55
+ <div
56
+ :id="dialog.idAttr"
57
+ class="top-dialog"
58
+ :class="classes"
59
+ :style="{
60
+ '--top-dialog-width': width,
61
+ '--top-dialog-height': height,
62
+ }"
63
+ tabindex="-1"
64
+ :data-view-page-active="dialog.pageActive.value"
65
+ :data-modal="modal"
66
+ :data-position="position"
67
+ >
68
+ <div class="modal-layer modal-layer-header"></div>
69
+
70
+ <div class="modal-layer modal-layer-body" :style="{'min-height': height + 'px'}"></div>
71
+
72
+ <slot name="default"></slot>
73
+ </div>
74
+ </template>
@@ -0,0 +1,58 @@
1
+ <script lang="ts">
2
+ import { shallowReactive } from 'vue';
3
+ import { TopDialogHandle } from '@/components/dialog/dialog/composables/dialogHandle';
4
+ import type { TopDialogComponent } from '@/components/dialog/dialog/composables/types';
5
+
6
+ /**
7
+ * Словарь всех используемых диалоговых окон
8
+ *
9
+ * В других компонентах не использовать
10
+ */
11
+ const dialogsWorkers = shallowReactive(new Map<string, TopDialogHandle<TopDialogComponent>>());
12
+
13
+ export const getDialogWorker = (id: string) => {
14
+ id = id.replace(/^dialog_/, '');
15
+
16
+ return dialogsWorkers.get(id);
17
+ };
18
+
19
+ /**
20
+ * Добавить компонент диалогового окна для использования
21
+ */
22
+ export const addDialogWorker = <T extends TopDialogComponent>(TopDialogComponent: T): TopDialogHandle<T> => {
23
+ if (!TopDialogComponent?.id) {
24
+ console.log({ TopDialogComponent: TopDialogComponent });
25
+
26
+ throw new Error('Expected TopDialogComponent');
27
+ }
28
+
29
+ if (!dialogsWorkers.has(TopDialogComponent.id)) {
30
+ dialogsWorkers.set(TopDialogComponent.id, new TopDialogHandle(TopDialogComponent));
31
+ }
32
+
33
+ return dialogsWorkers.get(TopDialogComponent.id) as TopDialogHandle<T>;
34
+ };
35
+ </script>
36
+
37
+ <script setup lang="ts">
38
+ import { onUnmounted } from 'vue';
39
+
40
+ defineOptions({
41
+ name: 'DialogWrapper',
42
+ });
43
+
44
+ onUnmounted(() => {
45
+ dialogsWorkers.forEach(dialog => dialog.destroy());
46
+ dialogsWorkers.clear();
47
+ });
48
+ </script>
49
+
50
+ <template>
51
+ <div class="top-dialogs" style="display: none;">
52
+ <component
53
+ v-for="[dialogId, dialog] in dialogsWorkers"
54
+ :is="dialog.Component"
55
+ :key="dialogId"
56
+ />
57
+ </div>
58
+ </template>
@@ -0,0 +1,86 @@
1
+ <script setup lang="ts">
2
+ import { computed } from 'vue';
3
+ import Core from '@/core/core/core';
4
+ import { useTopDialogSelf } from '@/components/dialog/dialog/composables/utils';
5
+ import type { Props, Slots } from './types';
6
+
7
+ const props = withDefaults(defineProps<Props>(), {
8
+ order: 0,
9
+ });
10
+
11
+ defineSlots<Slots>();
12
+
13
+ const dialog = useTopDialogSelf();
14
+
15
+ const classes = computed(() => {
16
+ return {
17
+ active: dialog.pageActive?.value === props.name,
18
+ 'i-load-data': props.isLoading || dialog.isLoadingPage.value,
19
+ };
20
+ });
21
+ </script>
22
+
23
+ <template>
24
+ <div
25
+ style="display: none"
26
+ v-if="dialog.isReady.value"
27
+ >
28
+ <Teleport :to="'#' + dialog.idAttr + ' .modal-layer-header'" :disabled="!dialog.needShowPage(name)">
29
+ <div
30
+ :data-order="order"
31
+ :data-view-page="name"
32
+ :class="classes"
33
+ >
34
+ <div class="modal-header">
35
+ <div class="top-title">
36
+ <slot name="header"></slot>
37
+ </div>
38
+
39
+ <div class="buttons">
40
+ <slot name="headerButtons"></slot>
41
+ </div>
42
+
43
+ <div
44
+ v-if="Core.state.isMobile && prevName"
45
+ class="close"
46
+ :title="$i18n.Common.Back"
47
+ data-top-icon=""
48
+ @click="dialog.open(prevName)"
49
+ ></div>
50
+
51
+ <div
52
+ v-else
53
+ class="close"
54
+ :title="$i18n.Common.Close"
55
+ data-top-icon=""
56
+ data-action="top-dialog-close"
57
+ ></div>
58
+ </div>
59
+ </div>
60
+ </Teleport>
61
+
62
+ <Teleport :to="'#' + dialog.idAttr + ' .modal-layer-body'" :disabled="!dialog.needShowPage(name)">
63
+ <div
64
+ :data-order="order"
65
+ :data-view-page="name"
66
+ class="has_scroll_container"
67
+ :class="classes"
68
+ :style="{'--top-dialog-footer-height': $slots.footer ? undefined : '0px'}"
69
+ >
70
+ <div class="modal-body" v-top-scroll-shadow>
71
+ <slot name="body"></slot>
72
+ </div>
73
+
74
+ <div
75
+ class="modal-footer"
76
+ :class="{
77
+ 'modal-footer-fullWith': footerFullWith
78
+ }"
79
+ v-if="$slots.footer"
80
+ >
81
+ <slot name="footer"></slot>
82
+ </div>
83
+ </div>
84
+ </Teleport>
85
+ </div>
86
+ </template>
@@ -0,0 +1,84 @@
1
+ export interface Props extends PropsCommon {
2
+ /**
3
+ * Статус загрузки страницы диалогового окна
4
+ *
5
+ * При включении взаимодействие со страницей блокируется, отображается анимация загрузки
6
+ */
7
+ isLoading?: boolean;
8
+ }
9
+
10
+ /**
11
+ * Общие props для компонентов реализуюущих TopDialogPage
12
+ */
13
+ export interface PropsCommon {
14
+ /**
15
+ * Имя страницы для диалогового окна
16
+ *
17
+ * Имя страницы нужно для навигации между страницами в одном диалоговом окне
18
+ */
19
+ name: string,
20
+
21
+ /**
22
+ * Порядкой номер страницы в диалоговом окне
23
+ *
24
+ * Одна и та же страница может быть подключена в разные диалоговые окна и иметь разный порядковый номер
25
+ */
26
+ order: number,
27
+
28
+ /**
29
+ * Имя предыдущей страницы
30
+ *
31
+ * Для кнопки Назад / Закрыть в мобильной версии
32
+ */
33
+ prevName?: string,
34
+
35
+ /**
36
+ * Стиль отображения футера, при котороым элементы растягиваются на всю ширину
37
+ *
38
+ * Разрешены переносы
39
+ */
40
+ footerFullWith?: boolean,
41
+ }
42
+
43
+ /**
44
+ * Общие props для компонентов реализуюущих TopDialogPage
45
+ *
46
+ * Для не SFC компонентов
47
+ */
48
+ export const propsPageCommon = {
49
+ name: {
50
+ type: String,
51
+ required: true,
52
+ },
53
+
54
+ order: {
55
+ type: Number,
56
+ required: true,
57
+ },
58
+
59
+ prevName: String,
60
+
61
+ footerFullWith: Boolean,
62
+ };
63
+
64
+ export interface Slots {
65
+ /**
66
+ * Шапка страницы
67
+ */
68
+ header(props: {}): any;
69
+
70
+ /**
71
+ * Кнопки для шапки страницы
72
+ */
73
+ headerButtons(props: {}): any;
74
+
75
+ /**
76
+ * Контент страницы
77
+ */
78
+ body(props: {}): any;
79
+
80
+ /**
81
+ * Футер страницы
82
+ */
83
+ footer(props: {}): any;
84
+ }
@@ -0,0 +1,27 @@
1
+ import type { Meta } from '@storybook/vue3';
2
+
3
+ import { genArgsTypes } from '@/components/helpersStories';
4
+ import Component from './page/page.vue';
5
+ import * as ComponentsConst from '@/components/dialog/lib/types';
6
+ import ReadMe from './stories/page/README.md?raw';
7
+ import { Dialog as Dialog_Base } from './dialog.stories';
8
+
9
+ const argTypes = genArgsTypes(Component, ComponentsConst, ['header', 'headerButtons', 'body', 'footer'], true);
10
+
11
+ const meta = {
12
+ component: Component,
13
+ tags: ['autodocs'],
14
+ argTypes,
15
+ parameters: {
16
+ docs: {
17
+ description: {
18
+ component: ReadMe,
19
+ },
20
+ },
21
+ },
22
+ } satisfies Meta<typeof Component>;
23
+
24
+ export const Dialog = { ...Dialog_Base } as unknown as Meta<typeof Component>;
25
+ Dialog.args = {};
26
+
27
+ export default meta;
@@ -0,0 +1,57 @@
1
+ <script setup lang="ts">
2
+ import { type Component, onUpdated, ref, type Ref } from 'vue';
3
+ import { useTopDialogSelf } from '@/components/dialog/dialog/composables/utils';
4
+ import type { Props } from './types';
5
+
6
+ const props = withDefaults(defineProps<Props>(), {
7
+ keepAlive: true,
8
+ });
9
+
10
+ const dialog = useTopDialogSelf();
11
+
12
+ /**
13
+ * Статус загрузи асинхронного компонента страницы диалогового окна
14
+ */
15
+ const updateIsLoadingAsyncPage = (component: Component, isLoaded: Ref) => {
16
+ if (isLoaded.value) return;
17
+
18
+ if (component.name !== 'AsyncComponentWrapper') {
19
+ isLoaded.value = true;
20
+
21
+ return;
22
+ }
23
+
24
+ if (!dialog.needShowPage(props.name as string)) return;
25
+
26
+ dialog.isLoadingPage.value = true;
27
+
28
+ // @ts-ignore
29
+ if (component.__asyncResolved) {
30
+ isLoaded.value = true;
31
+
32
+ dialog.isLoadingPage.value = false;
33
+ }
34
+ };
35
+
36
+ if (props.component.name === 'AsyncComponentWrapper') {
37
+ const isLoaded = ref(false);
38
+
39
+ onUpdated(() => {
40
+ updateIsLoadingAsyncPage(props.component, isLoaded);
41
+ });
42
+ }
43
+ </script>
44
+
45
+ <template>
46
+ <!-- Teleport внутри при keepAlive размонитроваться не будет, см. TopDialogPage -->
47
+ <KeepAlive :include="keepAlive ? '' : 'none'">
48
+ <Component
49
+ :is="component"
50
+ v-if="dialog.needShowPage(name)"
51
+ :="props"
52
+ :name="name"
53
+ :order="order"
54
+ :prevName="prevName"
55
+ />
56
+ </KeepAlive>
57
+ </template>
@@ -0,0 +1,21 @@
1
+ import type { PropsCommon } from '../page/types';
2
+ import type { Component } from 'vue';
3
+
4
+ export interface Props extends PropsCommon {
5
+ /**
6
+ * Компонент страницы с реализицией TopDialogPage
7
+ */
8
+ component: Component,
9
+
10
+ /**
11
+ * Кешировать ли эту страницу
12
+ *
13
+ * По умолчанию: true
14
+ */
15
+ keepAlive?: boolean,
16
+
17
+ /**
18
+ * Произвольный набор props, который будет передан в компонент страницы
19
+ */
20
+ props?: Record<string, any>,
21
+ }
@@ -0,0 +1,27 @@
1
+ import type { Meta } from '@storybook/vue3';
2
+
3
+ import { genArgsTypes } from '@/components/helpersStories';
4
+ import Component from './pageComponent/pageComponent.vue';
5
+ import * as ComponentsConst from '@/components/dialog/lib/types';
6
+ import ReadMe from './stories/pageComponent/README.md?raw';
7
+ import { Dialog as Dialog_Base } from './dialog.stories';
8
+
9
+ const argTypes = genArgsTypes(Component, ComponentsConst, [], true);
10
+
11
+ const meta = {
12
+ component: Component,
13
+ tags: ['autodocs'],
14
+ argTypes,
15
+ parameters: {
16
+ docs: {
17
+ description: {
18
+ component: ReadMe,
19
+ },
20
+ },
21
+ },
22
+ } satisfies Meta<typeof Component>;
23
+
24
+ export const Dialog = { ...Dialog_Base } as unknown as Meta<typeof Component>;
25
+ Dialog.args = {};
26
+
27
+ export default meta;
@@ -0,0 +1,117 @@
1
+ ## Описание функционала
2
+
3
+ `TopDialog` - универсальный компонент для создания диалоговых окон на vue c богатым функционалом.
4
+
5
+ Вот некоторые фичи TopDialog:
6
+
7
+ - открытие диалогового окна из **любого** места в приложении, с возможной передачей настроек через **props**
8
+ - **ленивая** подгрузка кода компонента
9
+ - сохранение состояния открытых диалоговых окон в **hash-навигации** в url страницы,
10
+ автоматическое открытие / закрытие диалоговых окон при переходе в истории браузера с автозагрузкой диалоговых окон
11
+ - вывод **несколько страниц** в одном диалоговом окне
12
+ - анимация при смене страниц
13
+ - кеширование состояния страницы
14
+ - ленивая подгрузка страницы
15
+ - адаптивный дизайн, мобильная версия
16
+
17
+ ## Термины
18
+
19
+ - **ручка (worker)**: объект для управления диалоговым окном
20
+ - **диалоговое окно**: компонент, встраиваемый в приложение и доступный через **ручку**, не имеет связи с тем, откуда вызывается (за исключением
21
+ события `onCloseOnce`), включает в себя страницы, отображает нужную страницу
22
+ - **страница**: компонент для вывода страницы в диалоговом окне
23
+
24
+ ## Гайдлайн
25
+
26
+ - Имя файла для компонента диалогового принято называть в формате: `dialog_{{ dialogId }}.{{ ext }}`
27
+ - **ручки** принято сохранять в переменной с именем `dialog`
28
+
29
+ ## Подключение
30
+
31
+ Общие настройки определяются при подключении [corePlugin](?path=/docs/core-plugins--docs#coreplugin):
32
+
33
+ - `topDialogOptions.load`: автозагрузка диалоговых окон, для открытия нужных диалоговых окон по ссылке
34
+
35
+ Подключите компонент в корне приложения, компонент будет импортирован и подключен автоматически в `corePlugin`: `<top-dialogs></top-dialogs>`.
36
+
37
+ `TopDialog` должен использовать только как корневой элемент компонента.
38
+
39
+ Подключение:
40
+
41
+ - Создайте компонент, который будет реализовывать диалоговое окно и разместите в нем `TopDialog`
42
+ - Укажите в объекте компонента свойсто `id`, для SFC укажите id через `defineOptions({ id })`
43
+ - При необходимости определите в компоненте вашего диалогового окна `props` и укажите `@open` и `@close` для `TopDialog`
44
+ - Вставьте в `TopDialog` компонент `TopDialogPage` с нужными слотами шапки и контента или `TopDialogPageComponent` с ссылкой на компонент страницы
45
+ - Через `useAsyncTopDialog()` / `useTopDialog` определите **ручку** для работы с диалоговым окном
46
+ - Открывайте диалоговое окно и управляйте им через **ручку**
47
+
48
+ Подробнее о [TopDialogPage](?path=/docs/components-dialog-dialog-page--docs)
49
+
50
+ Подробнее о [TopDialogPageComponent](?path=/docs/components-dialog-dialog-pagecomponent--docs)
51
+
52
+ ## Пример
53
+
54
+ ```js
55
+ // создать ручку
56
+ const dialog = useAsyncTopDialog(() => import('./myDialog.vue'));
57
+
58
+ // ...
59
+
60
+ // открыть диалоговое окно с нужными props на нужной старнице, можно указать onCloseOnce, для перехвата закрытия открытого окна
61
+ await dialog.open();
62
+
63
+ // открыть диалоговое окно через hash-навигацию
64
+ await dialog.openAsLink();
65
+
66
+ // закрыть диалоговое окно
67
+ await dialog.close();
68
+
69
+ // усатнвоить props диалогового окна
70
+ await dialog.setProps();
71
+
72
+ // определить, нужно ли отображать указанную страницу
73
+ await dialog.needShowPage(pageName);
74
+ ```
75
+
76
+ ## Hash-навигация
77
+
78
+ При **hash-навигации** в url страницы будет подставляться:
79
+
80
+ - `view-dialog_{{ id }}={{ pageName }}`: ссылка на диалоговое окно, может указываться сразу несколько ссылок
81
+ - `vpn={{ number }}`: порядковый номер открытого диалогового окна, viewPageN
82
+
83
+ Для генерации ссылки на открытие диалогового окна используйте `genViewPageHash()`.
84
+
85
+ В шаблонах для автоматического создания ссылки на диалоговое окно добавьте к ссылке атрибут `data-to-view` с указателем на диалоговое окно.
86
+ При выполнении перехода по ссылке, значение `href` будет автоматически меняться на нужное.
87
+
88
+ ```html
89
+ <a href="." data-to-view="dialog_example-inline">Ссылка на диалоговое окно</a>
90
+ ```
91
+
92
+ # Дополнительные компоненты
93
+
94
+ - `TopDialogPage`: компонент страницы диалогового окна
95
+ - `TopDialogPageComponent`: компонент для вывода страницы диалогового окна, определенного в другом файле
96
+
97
+ # Классы
98
+
99
+ При открытии добавляет элементу html класс `.with_dialog`. В основном класс нужен для блокировки основного скролла страницы.
100
+
101
+ ## Утилиты
102
+
103
+ - `useAsyncTopDialog()`: - создает асинхронную **ручку** для работы с указанным диалоговым окном, не загружает диалоговое окно, пока это не будет
104
+ необходимо
105
+ - `useTopDialog()`: - создает **ручку** для работы с указанным диалоговым окном
106
+ - `useTopDialogSelf()`: создает **ручку** для работы с **текущим** диалоговым окном, используется внутри компонента вашего диалогового окна или его
107
+ страницы
108
+ - `genViewPageHash()`: сгенерировать **hash** с ссылкой на диалоговое окно и его страницу, может использоваться для смены `location.hash` или для
109
+ генерации ссылок
110
+
111
+ ## Зависмости
112
+
113
+ Требует подключение словарей:
114
+
115
+ * i18n/Common
116
+
117
+ Требует подключение **jquery**, **jquery-ui dialog**
@@ -0,0 +1,12 @@
1
+ import { useTopDialog } from '@/components/dialog/dialog/composables/utils';
2
+ import type { TopDialogLoad } from '@/components/dialog/lib/types';
3
+ import { waitWhile } from '@/core/utils/system';
4
+
5
+ export const load: TopDialogLoad = async (dialogId) => {
6
+ const ComponentModule = await import(`./${dialogId}/${dialogId}.vue`);
7
+
8
+ const dialog = useTopDialog(ComponentModule.default);
9
+
10
+ // ожидание инициализации компонента диалогового окна
11
+ await waitWhile(() => !dialog.isMounted.value);
12
+ };
@@ -0,0 +1,73 @@
1
+ <script setup lang="ts">
2
+ import { defineAsyncComponent } from 'vue';
3
+ import { TopDialog, TopDialogPage, TopDialogPageComponent, useTopDialogSelf } from '@/components/dialog/dialog';
4
+
5
+ import PageDefault from './pages/default.vue';
6
+ import PageWithoutCache from './pages/withoutCache.vue';
7
+ import PageHeaderButtons from './pages/headerButtons.vue';
8
+
9
+ /**
10
+ * id компонента диалогового окна
11
+ *
12
+ * Гайдлайн: название файла этого компонента должно соответствовать формату: `dialog_${ id }`
13
+ */
14
+ const id = 'example';
15
+
16
+ defineOptions({ id });
17
+
18
+ const PageAsync = defineAsyncComponent(() => import('./pages/async.vue'));
19
+
20
+ withDefaults(defineProps<{
21
+ a?: number
22
+ }>(), {
23
+ a: 0,
24
+ });
25
+
26
+ const dialog = useTopDialogSelf();
27
+ </script>
28
+
29
+ <template>
30
+ <TopDialog
31
+ id="example"
32
+ pageActive="inline"
33
+ height="400px"
34
+ @open="console.log('Открыто окно Example, страница: ' + $event)"
35
+ @close="console.log('Закрыто окно Example, страница: ' + $event)"
36
+ >
37
+ <KeepAlive>
38
+ <TopDialogPage :order="0" name="inline" v-if="dialog.needShowPage('inline')">
39
+ <template #header>
40
+ Простая страница: inline
41
+ </template>
42
+
43
+ <template #body>
44
+ props диалогового окна: {{ $props }}<br><br>
45
+
46
+ Код данной страницы диалогового окна реализуется в самом компоненте диалогового окна, в остальных примерах страницы будут
47
+ подключаться отдельными компонентами<br><br>
48
+
49
+ Такой способ реализации предпочтителен для дилоговых окон с одной страницей.
50
+
51
+ <br><br>
52
+
53
+ <TopTextarea
54
+ model-value=""
55
+ :expandable="false"
56
+ :rows="15"
57
+ ></TopTextarea>
58
+ </template>
59
+
60
+ <template #footer>
61
+ <TopButton color="theme" styling="outline" @click="dialog.close()" style="margin-right: auto">Закрыть</TopButton>
62
+
63
+ <TopButton @click="dialog.open('default')">Далее</TopButton>
64
+ </template>
65
+ </TopDialogPage>
66
+ </KeepAlive>
67
+
68
+ <TopDialogPageComponent name="default" :order="1" prevName="inline" :component="PageDefault" :a/>
69
+ <TopDialogPageComponent name="async" :order="2" prevName="default" :component="PageAsync" :a/>
70
+ <TopDialogPageComponent name="withoutCache" :order="3" prevName="async" :component="PageWithoutCache" :keepAlive="false" :a/>
71
+ <TopDialogPageComponent name="headerButtons" :order="4" prevName="withoutCache" :component="PageHeaderButtons"/>
72
+ </TopDialog>
73
+ </template>