@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,321 @@
1
+ <script setup lang="ts">
2
+ import { onMounted, onUpdated, ref } from 'vue';
3
+ import type { Item, Props } from './menu';
4
+ import Core from '@/core/core/core';
5
+ import { isSafari } from '@/core/utils/device';
6
+ import TopButton from '@/components/forms/button/button.vue';
7
+
8
+ const props = withDefaults(defineProps<Props>(), {
9
+ styling: 'default',
10
+ });
11
+
12
+ const model = defineModel({
13
+ required: true,
14
+ });
15
+
16
+ const el = ref();
17
+
18
+ // валидация типа modelValue без возможности выбора нескольких значений (ожидается строка)
19
+ if (!props.isMultiple && !(typeof (model.value) === 'string' || model.value instanceof String)) {
20
+ console.warn('Type check failed for prop "modelValue". Expected String: ' + typeof (model.value));
21
+ }
22
+
23
+ // валидация типа modelValue с возможностью выбора нескольких значений (ожидается массив)
24
+ if (props.isMultiple && !Array.isArray(model.value)) {
25
+ console.warn('Type check failed for prop "modelValue". Expected Array: ' + typeof (model.value));
26
+ }
27
+
28
+ // для множественного выбора без пустого множества
29
+ // если ничего не выбрано, присваиваем 1-ое значение
30
+ if (props.isMultiple && !props.canBeEmptyMultiple && Array.isArray(model.value) && !model.value.length) {
31
+ model.value = [props.items[0].href ?? props.items[0].value];
32
+ }
33
+
34
+ const itemIsActive = (item: Item) => {
35
+ if (!Array.isArray(model.value)) {
36
+ return item.value === model.value;
37
+ }
38
+
39
+ return model.value.includes(item.value);
40
+ };
41
+
42
+ /**
43
+ * Выбрать элемент
44
+ * @param item
45
+ * @param toggle - добавить или исключить элемент, для isMultiple
46
+ */
47
+ const select = (item: Item, toggle = false) => {
48
+ if (Array.isArray(model.value)) {
49
+ let modelNew = model.value.slice();
50
+
51
+ if (toggle) {
52
+ if (!modelNew.length) modelNew = props.items.map(item => item.value);
53
+
54
+ const index = modelNew.indexOf(item.value);
55
+ if (index === -1) {
56
+ modelNew.push(item.value);
57
+ } else {
58
+ modelNew.splice(index, 1);
59
+ }
60
+ } else {
61
+ if (modelNew.length === 1 && modelNew[0] === item.value) {
62
+ modelNew = [];
63
+ } else {
64
+ modelNew = [item.value];
65
+ }
66
+ }
67
+
68
+ if (!props.canBeEmptyMultiple && !modelNew.length) modelNew = [item.value];
69
+
70
+ model.value = modelNew;
71
+
72
+ return;
73
+ }
74
+
75
+ model.value = item.value;
76
+ };
77
+
78
+ // вертикальный скролл в горизонтальный скролл
79
+ const onWheel = (event: WheelEvent) => {
80
+ if (el.value.scrollWidth <= el.value.offsetWidth) return;
81
+ if (event.shiftKey) return;
82
+ if (Math.abs(event.deltaY) < 50) return; // устройство с высокой точностью, например тачпад
83
+
84
+ event.preventDefault();
85
+
86
+ const delta = event.deltaY > 0 ? 30 : -30;
87
+ el.value.scrollLeft = el.value.scrollLeft + delta;
88
+ };
89
+
90
+ /**
91
+ * Замена стандартному scrollIntoView, который меняет скролл документа
92
+ *
93
+ * Выравнивание по ближнему краю элемента
94
+ *
95
+ * Выравнивается таким образом, чтобы был виден соседний элемент
96
+ */
97
+ const scrollIntoView = (isSmooth = true) => {
98
+ const elBtn = el.value.querySelector('.top-active');
99
+ if (!elBtn) return;
100
+
101
+ const gap = 24;
102
+
103
+ // левая и правая координаты элемента
104
+ const leftMargin = elBtn.offsetLeft - el.value.offsetLeft - gap;
105
+ const rightMargin = elBtn.offsetLeft - el.value.offsetLeft + elBtn.clientWidth + gap;
106
+
107
+ // левая и правая границы видимой части меню
108
+ const leftMarginParent = el.value.scrollLeft;
109
+ const rightMarginParent = el.value.clientWidth + el.value.scrollLeft;
110
+
111
+ let scrollLeft: number | undefined = undefined;
112
+
113
+ // левую границу элемента к левой границе меню
114
+ if (leftMargin < leftMarginParent) scrollLeft = leftMargin;
115
+
116
+ // правую границу элемента к правой границе меню
117
+ if (rightMargin > rightMarginParent) scrollLeft = rightMargin - el.value.clientWidth;
118
+
119
+ if (scrollLeft !== undefined) {
120
+ if (isSafari()) {
121
+ Core.$?.(el.value).animate({ scrollLeft: scrollLeft }, isSmooth ? 200 : 0);
122
+ } else {
123
+ el.value.scrollTo({ left: scrollLeft, behavior: isSmooth ? 'smooth' : 'auto' });
124
+ }
125
+ }
126
+ };
127
+
128
+ /**
129
+ * Выбрать все элементы в меню
130
+ */
131
+ const selectAll = () => {
132
+ if (!Array.isArray(model.value)) return;
133
+
134
+ if (model.value.length === props.items.length) {
135
+ model.value = [props.items[0].href ?? props.items[0].value];
136
+ return;
137
+ }
138
+
139
+ model.value = props.items.map(item => item.href ?? item.value);
140
+ };
141
+
142
+ onMounted(() => scrollIntoView(false));
143
+ onUpdated(() => scrollIntoView(true));
144
+
145
+ </script>
146
+
147
+ <template>
148
+ <div
149
+ ref="el"
150
+ :class="{
151
+ 'top-menu': true,
152
+ ['top-style_' + styling]: true,
153
+ // ['top-unwrap-x']: styling === 'default',
154
+ }"
155
+ @wheel="onWheel"
156
+ >
157
+ <TopButton
158
+ v-for="item in items"
159
+ :="item"
160
+ class="top-menu_item"
161
+ color="theme"
162
+ @click="select(item, $event.ctrlKey)"
163
+ :isActive="itemIsActive(item)"
164
+ >
165
+ <template #default v-if="item.content">
166
+ {{ item.content }}
167
+ </template>
168
+ </TopButton>
169
+
170
+ <div
171
+ v-if="Array.isArray(model) && selectAllItem"
172
+ class="top-menu_selectAll"
173
+ >
174
+ <TopButton
175
+ :="selectAllItem"
176
+ class="top-menu_item"
177
+ color="theme"
178
+ styling=""
179
+ @click="selectAll()"
180
+ :isActive="model.length === items.length"
181
+ >
182
+ <template #default v-if="selectAllItem.content">
183
+ {{ selectAllItem.content }}
184
+ </template>
185
+ </TopButton>
186
+ </div>
187
+ </div>
188
+ </template>
189
+
190
+ <style>
191
+ .top-menu {
192
+ --scroll-thumb-color: var(--color-line-1);
193
+ --scroll-thumb-color-hover: var(--color-line-2);
194
+ --scroll-thumb-color-active: var(--color-line-3);
195
+
196
+ max-width: 100%;
197
+ display: flex;
198
+ align-items: flex-start;
199
+ gap: var(--top-gap-2);
200
+ overflow-x: auto;
201
+ scrollbar-width: none; /* firefox */
202
+
203
+ /* предотвратить натинвые события браузера (назад / вперед) */
204
+ overscroll-behavior-x: contain;
205
+ }
206
+
207
+ .top-menu::-webkit-scrollbar { display: none; }
208
+
209
+ .top-menu .top-menu_item {
210
+ --top-button-color: var(--color-text-2);
211
+
212
+ outline-offset: -2px !important;
213
+ min-width: 0;
214
+ max-width: 200px;
215
+ margin: 0;
216
+ flex-shrink: 0;
217
+ }
218
+
219
+ .top-menu .top-menu_item[data-top-icon] {
220
+ --top-icon-color: var(--color-text-2);
221
+ }
222
+
223
+ .top-menu_selectAll {
224
+ position: sticky;
225
+ right: 0;
226
+ background: var(--color-layout-front-1);
227
+ border-left: 1px solid var(--color-line-1);
228
+ padding-left: var(--top-padding-1);
229
+ box-shadow: var(--color-layout-front-1) var(--top-padding-2) 0px;
230
+ }
231
+
232
+ /* style default */
233
+ .top-menu.top-style_default .top-menu_item {
234
+ --top-forms-radius: 0;
235
+ --top-forms-border-color: transparent;
236
+ --top-forms-border-width: 2px;
237
+
238
+ filter: none;
239
+ box-shadow: none;
240
+ border: none;
241
+ border-bottom: var(--top-forms-border-width) solid var(--top-forms-border-color);
242
+ background: none;
243
+ }
244
+
245
+ .top-style_default > .top-menu_item > [data-top-badge] {
246
+ margin-top: 0;
247
+ }
248
+
249
+ .top-menu.top-style_default .top-menu_item:hover {
250
+ --top-icon-color: var(--color-text-1);
251
+ --top-button-color: var(--color-text-1);
252
+ --top-forms-border-color: var(--color-line-2);
253
+ }
254
+
255
+ .top-menu.top-style_default .top-menu_item:active,
256
+ .top-menu.top-style_default .top-menu_item.top-active {
257
+ --top-icon-color: var(--color-text-primary);
258
+ --top-button-color: var(--color-text-1);
259
+ --top-forms-border-color: var(--color-line-primary-1);
260
+ }
261
+
262
+ .top-menu.top-style_default .top-menu_selectAll {
263
+ padding-left: var(--top-padding-2);
264
+ }
265
+
266
+ /* style bar */
267
+ .top-menu.top-style_bar {
268
+ border-radius: var(--top-radius-3);
269
+ border: 1px solid var(--color-line-2);
270
+ padding: var(--top-padding-1);
271
+ gap: 3px;
272
+ }
273
+ .top-menu.top-style_bar .top-menu_item {
274
+ --top-button-background-color-hover: var(--color-layer-1);
275
+ --top-button-background-color-active: var(--color-layer-2);
276
+ --top-button-background-color-selected: var(--color-layer-primary-1);
277
+
278
+ position: relative;
279
+ }
280
+
281
+ .top-menu.top-style_bar .top-menu_item:hover {
282
+ --top-icon-color: var(--color-text-1);
283
+ --top-button-color: var(--color-text-1);
284
+ }
285
+
286
+ .top-menu.top-style_bar .top-menu_item.top-active {
287
+ --top-icon-color: var(--color-text-primary);
288
+ --top-button-color: var(--color-text-primary);
289
+ }
290
+
291
+ /* разделители кнопок в баре */
292
+ .top-menu.top-style_bar .top-menu_item:not(:first-child):not(.top-active):not(:hover):after {
293
+ content: "";
294
+ background: var(--color-line-1-opacity);
295
+ width: 1px;
296
+ height: 60%;
297
+ display: block;
298
+ position: absolute;
299
+ left: -2px;
300
+ }
301
+ .top-menu.top-style_bar .top-menu_item.top-active + .top-menu_item:after,
302
+ .top-menu.top-style_bar .top-menu_item:hover + .top-menu_item:after {
303
+ content: none !important;
304
+ }
305
+
306
+ /*
307
+ .top-style_bar > .top-menu_item > [data-top-badge] {
308
+ margin-top: -3px;
309
+ }
310
+ */
311
+
312
+ /** TODO: .top-unwrap-x надо вынести глобально в UI или добавить в стили для storybook */
313
+ /*
314
+ .top-menu.top-unwrap-x {
315
+ padding-right: var(--top-unwrap-x);
316
+ padding-left: var(--top-unwrap-x);
317
+ margin-right: calc(0px - var(--top-unwrap-x));
318
+ margin-left: calc(0px - var(--top-unwrap-x));
319
+ }
320
+ */
321
+ </style>
@@ -0,0 +1,18 @@
1
+ import type { Item } from '../menu';
2
+ import { fakerRU } from '@faker-js/faker';
3
+
4
+ const items: Item[] = [];
5
+
6
+ for (let i = 1; i <= 10; i++) {
7
+ const name = fakerRU.animal.cat();
8
+
9
+ items.push({
10
+ icon: '',
11
+ title: `Длинное описание для ${name}`,
12
+ value: i,
13
+ content: name,
14
+ badgeNumber: fakerRU.number.int(99) * fakerRU.number.int(1),
15
+ });
16
+ }
17
+
18
+ export default items;
@@ -0,0 +1,52 @@
1
+ <script setup lang="ts">
2
+ import { ref } from 'vue';
3
+ import type { Props } from '../menu';
4
+ import Menu from '../menu.vue';
5
+
6
+ defineProps<Props>();
7
+
8
+ const modelMenu = defineModel();
9
+ const modelMenuMultiple = ref([]);
10
+ </script>
11
+
12
+ <template>
13
+ <div>
14
+ <h2>Одиночный выбор</h2>
15
+
16
+ <h3>Стиль: По умолчанию</h3>
17
+
18
+ <Menu
19
+ :="$props"
20
+ v-model="modelMenu"
21
+ />
22
+
23
+ <h3>Стиль: В баре</h3>
24
+
25
+ <Menu
26
+ :="$props"
27
+ v-model="modelMenu"
28
+ styling="bar"
29
+ />
30
+
31
+ <h2>Множественный выбор</h2>
32
+
33
+ Для множественного выбора используйте: <b>ctrl + click</b>.
34
+
35
+ <h3>Стиль: По умолчанию</h3>
36
+
37
+ <Menu
38
+ :="$props"
39
+ v-model="modelMenuMultiple"
40
+ :isMultiple="true"
41
+ />
42
+
43
+ <h3>Стиль: В баре (с кнопкой выбрать все)</h3>
44
+
45
+ <Menu
46
+ :="$props"
47
+ v-model="modelMenuMultiple"
48
+ :isMultiple="true"
49
+ styling="bar"
50
+ />
51
+ </div>
52
+ </template>
@@ -0,0 +1,186 @@
1
+ <script setup lang="ts">
2
+ import { ref, watch } from 'vue';
3
+ import type { NavigationMenuItem, PropsItem, EmitsItem } from './navigationMenu';
4
+
5
+ const props = defineProps<NavigationMenuItem>();
6
+ const emit = defineEmits<EmitsItem>();
7
+
8
+ const isItemsOpened = ref(false);
9
+ const activeItemId = ref(props.activeItemId);
10
+
11
+ const handlerClick = (item: PropsItem) => {
12
+ if (!isItemsOpened.value) isItemsOpened.value = true;
13
+
14
+ activeItemId.value = item.id;
15
+ emit('updateActiveItem', item);
16
+ };
17
+
18
+ watch(() => props.activeItemId, (newVal) => {
19
+ activeItemId.value = newVal;
20
+ });
21
+
22
+ /**
23
+ * Устанавливаем начальную высоту, запускаем анимацию, устанавливая высоту на полный размер
24
+ */
25
+ const onEnter = (el: Element) => {
26
+ const element = el as HTMLElement;
27
+ element.style.height = '0';
28
+
29
+ requestAnimationFrame(() => {
30
+ element.style.height = `${element.scrollHeight}px`;
31
+ });
32
+ };
33
+
34
+ /**
35
+ * Убираем фиксированную высоту, чтобы подпункты могли открываться
36
+ */
37
+ const onAfterEnter = (el: Element) => {
38
+ (el as HTMLElement).style.height = 'auto';
39
+ };
40
+
41
+ /**
42
+ * Возвращаем фиксированную высоту, запускаем анимацию, устанавливая высоту в 0
43
+ */
44
+ const onLeave = (el: Element) => {
45
+ const element = el as HTMLElement;
46
+ element.style.height = `${element.scrollHeight}px`;
47
+
48
+ requestAnimationFrame(() => {
49
+ element.style.height = '0';
50
+ });
51
+ };
52
+ </script>
53
+
54
+ <template>
55
+ <li
56
+ :class="{
57
+ 'top-navigationMenuItem': true,
58
+ ['top-navigationMenuItem-depth-' + depth]: true,
59
+ 'top-navigationMenuItem-opened': item.subitems?.length && isItemsOpened,
60
+ 'top-navigationMenuItem-active': activeItemId === item.id,
61
+ }"
62
+ >
63
+ <span
64
+ v-if="item.subitems?.length && depth <= 3"
65
+ class="top-navigationMenuItemChevron"
66
+ data-top-icon=""
67
+ @click="isItemsOpened = !isItemsOpened"
68
+ ></span>
69
+
70
+ <a
71
+ class="top-navigationMenuItem_link"
72
+ :href="item.url"
73
+ :data-top-icon="depth === 1 ? item.icon : undefined"
74
+ @click.prevent="handlerClick(item)"
75
+ >
76
+ {{ item.title }}
77
+ </a>
78
+
79
+ <Transition
80
+ name="expand"
81
+ @enter="onEnter"
82
+ @after-enter="onAfterEnter"
83
+ @leave="onLeave"
84
+ >
85
+ <ul
86
+ v-if="item.subitems?.length && depth <= 3"
87
+ v-show="isItemsOpened"
88
+ class="top-navigationMenuItem_subitems"
89
+ >
90
+ <Item
91
+ v-for="subitem in item.subitems"
92
+ :item="subitem"
93
+ :depth="depth + 1"
94
+ :activeItemId="activeItemId"
95
+ @updateActiveItem="(activeItem: PropsItem) => handlerClick(activeItem)"
96
+ />
97
+ </ul>
98
+ </Transition>
99
+ </li>
100
+ </template>
101
+
102
+ <style>
103
+ .top-navigationMenuItem {
104
+ --top-icon-color: var(--color-text-2);
105
+ --top-link-color: var(--color-text-2);
106
+
107
+ width: 320px;
108
+ padding: 0;
109
+ position: relative;
110
+ z-index: 2;
111
+ }
112
+
113
+ .top-navigationMenuItem-active {
114
+ --top-icon-color: var(--color-text-white);
115
+ --top-link-color: var(--color-text-white);
116
+ }
117
+
118
+ .top-navigationMenuItemChevron,
119
+ .top-navigationMenuItem_link {
120
+ --top-forms-padding: 0px;
121
+ }
122
+
123
+ .top-navigationMenuItemChevron {
124
+ cursor: pointer;
125
+ position: absolute;
126
+ margin: 12px 0 12px var(--top-chevron-margin-left);
127
+ z-index: 1;
128
+ }
129
+
130
+ .top-navigationMenuItem_link {
131
+ color: var(--top-link-color);
132
+ text-decoration: none;
133
+ padding: var(--top-padding-3);
134
+ padding-left: var(--top-link-padding-left);
135
+ display: block;
136
+ }
137
+
138
+ .top-navigationMenuItem_link:before {
139
+ padding-right: var(--top-padding-1);
140
+ }
141
+
142
+ .top-navigationMenuItem:not(.top-navigationMenuItem-active) > .top-navigationMenuItem_link:hover {
143
+ background-color: var(--color-layout-front-3);
144
+ }
145
+
146
+ .top-navigationMenuItem-active > .top-navigationMenuItem_link {
147
+ background-color: var(--color-bg-primary-1);
148
+ }
149
+
150
+ .top-navigationMenuItem-depth-1 {
151
+ --top-chevron-margin-left: var(--top-padding-2);
152
+ --top-link-padding-left: var(--top-padding-8);
153
+ }
154
+
155
+ .top-navigationMenuItem-depth-2 {
156
+ --top-chevron-margin-left: calc(var(--top-padding-2) + var(--top-padding-7));
157
+ --top-link-padding-left: calc(var(--top-padding-8) + var(--top-padding-7));
158
+ }
159
+
160
+ .top-navigationMenuItem-depth-3 {
161
+ --top-chevron-margin-left: calc(var(--top-padding-2) + var(--top-padding-7) + var(--top-padding-4));
162
+ --top-link-padding-left: calc(var(--top-padding-8) + var(--top-padding-7) + var(--top-padding-4));
163
+ }
164
+
165
+ .top-navigationMenuItem-depth-4 {
166
+ --top-chevron-margin-left: calc(var(--top-padding-2) + var(--top-padding-7) + var(--top-padding-4) + var(--top-padding-4));
167
+ --top-link-padding-left: calc(var(--top-padding-8) + var(--top-padding-7) + var(--top-padding-4) + var(--top-padding-4));
168
+ }
169
+
170
+ /* Анимация стрелочки */
171
+ .top-navigationMenuItemChevron:before {
172
+ transform: rotate(-90deg);
173
+ transition: transform var(--transition-fast);
174
+ }
175
+
176
+ .top-navigationMenuItem-opened > .top-navigationMenuItemChevron:before {
177
+ transform: rotate(0deg);
178
+ }
179
+
180
+ /* Анимация раскрывающегося списка */
181
+ .expand-enter-active,
182
+ .expand-leave-active {
183
+ transition: height var(--transition-fast);
184
+ overflow: hidden;
185
+ }
186
+ </style>
@@ -0,0 +1,37 @@
1
+ import type { Meta, StoryObj } from '@storybook/vue3';
2
+
3
+ import { genArgsTypes } from '@/components/helpersStories';
4
+
5
+ import Component from './navigationMenu.vue';
6
+ import * as ComponentsConst from './navigationMenu';
7
+ import items from './stories/items';
8
+
9
+ const argTypes = genArgsTypes(Component, ComponentsConst);
10
+
11
+ /**
12
+ * Компонент предназначен для вывода навигационного меню с древовидной структурой
13
+ *
14
+ * Максимальная степень вложенности - 4. Пункты с более глубокой вложенности отображены не будут.
15
+ *
16
+ * Иконки отображаются только на первом уровне вложенности
17
+ *
18
+ * ## Подкомпоненты
19
+ *
20
+ * - **NavigationMenuItem**: пункт меню, может содержать внутри себя подпункты
21
+ */
22
+ const meta = {
23
+ component: Component,
24
+ tags: ['autodocs'],
25
+ args: {},
26
+ argTypes,
27
+ } satisfies Meta<typeof Component>;
28
+
29
+ type Story = StoryObj<typeof meta>;
30
+
31
+ export const Playground = {
32
+ args: {
33
+ items,
34
+ },
35
+ } satisfies Story;
36
+
37
+ export default meta;
@@ -0,0 +1,28 @@
1
+ /**
2
+ * Определение параметров
3
+ */
4
+ export interface Props {
5
+ items: PropsItem[];
6
+ }
7
+
8
+ export interface NavigationMenuItem {
9
+ depth: number;
10
+ activeItemId?: number;
11
+ item: PropsItem;
12
+ }
13
+
14
+ export interface PropsItem {
15
+ id: number;
16
+ url?: string;
17
+ title?: string;
18
+ icon?: string;
19
+ subitems?: PropsItem[];
20
+ }
21
+
22
+ export interface EmitsItem {
23
+ (e: 'updateActiveItem', item: PropsItem): void;
24
+ }
25
+
26
+ export interface Emits {
27
+ (e: 'updateActiveItem', item: PropsItem): void;
28
+ }
@@ -0,0 +1,40 @@
1
+ <script setup lang="ts">
2
+ import { ref } from 'vue';
3
+ import NavigationMenuItem from './item.vue';
4
+ import type { Props, PropsItem, Emits } from './navigationMenu';
5
+
6
+ defineProps<Props>();
7
+ const emit = defineEmits<Emits>();
8
+
9
+ const activeItemId = ref();
10
+
11
+ const handler = (activeItem: PropsItem) => {
12
+ activeItemId.value = activeItem.id;
13
+ emit('updateActiveItem', activeItem);
14
+ };
15
+ </script>
16
+
17
+ <template>
18
+ <ul class="top-navigationMenu">
19
+ <NavigationMenuItem
20
+ v-for="item in items"
21
+ :depth="1"
22
+ :activeItemId="activeItemId"
23
+ :item="item"
24
+ @updateActiveItem="(activeItem) => handler(activeItem)"
25
+ />
26
+ </ul>
27
+ </template>
28
+
29
+ <style>
30
+ .top-navigationMenu,
31
+ ul.top-navigationMenu ul {
32
+ margin: 0;
33
+ padding: 0;
34
+ }
35
+
36
+ ul.top-navigationMenu li {
37
+ margin: 0;
38
+ list-style: none;
39
+ }
40
+ </style>