@topvisor/ui 1.0.19 → 1.0.20-selector2-3

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 (921) hide show
  1. package/.idea/.gitignore +11 -0
  2. package/.idea/codeStyles/Project.xml +205 -0
  3. package/.idea/codeStyles/codeStyleConfig.xml +5 -0
  4. package/.idea/externalDependencies.xml +6 -0
  5. package/.idea/inspectionProfiles/Disabled.xml +824 -0
  6. package/.idea/inspectionProfiles/Project_Default.xml +33 -0
  7. package/.idea/php.xml +19 -0
  8. package/.idea/vcs.xml +6 -0
  9. package/.storybook/TopTheme.ts +115 -0
  10. package/.storybook/TopThemeManager.ts +53 -0
  11. package/.storybook/main.ts +51 -0
  12. package/.storybook/manager.ts +25 -0
  13. package/.storybook/preview-head.html +21 -0
  14. package/.storybook/preview.ts +47 -0
  15. package/.storybook/vue/coreDecorator.ts +76 -0
  16. package/.storybook/vue/vModelDecorator.ts +46 -0
  17. package/.versionrc.json +16 -0
  18. package/.vscode/extensions.json +11 -0
  19. package/.vscode/keybindings.example.json +121 -0
  20. package/.vscode/settings.json +45 -0
  21. package/CHANGELOG.md +175 -0
  22. package/NPM.md +25 -0
  23. package/PUBLISH.md +63 -0
  24. package/README.md +41 -82
  25. package/STORYBOOK.md +43 -0
  26. package/USE_IN_PROJECT.md +32 -0
  27. package/build/afterBuild.sh +11 -0
  28. package/build/cssModules.ts +39 -0
  29. package/build/genDocs.sh +19 -0
  30. package/build/plugin/amdFix.ts +83 -0
  31. package/build/plugin/autoloadCSS.ts +155 -0
  32. package/build/rollup.config.ts +37 -0
  33. package/package.json +87 -34
  34. package/public/README.md +82 -0
  35. package/public/icomoon/Read Me.txt +7 -0
  36. package/public/icomoon/Topvisor icons.json +6260 -0
  37. package/public/icomoon/demo-files/demo.css +158 -0
  38. package/public/icomoon/demo-files/demo.js +30 -0
  39. package/public/icomoon/demo.html +3558 -0
  40. package/public/icomoon/fonts/Topvisor-2.eot +0 -0
  41. package/public/icomoon/fonts/Topvisor-2.svg +277 -0
  42. package/public/icomoon/fonts/Topvisor-2.ttf +0 -0
  43. package/public/icomoon/fonts/Topvisor-2.woff +0 -0
  44. package/public/icomoon/selection.json +1 -0
  45. package/public/icomoon/style.css +780 -0
  46. package/public/jquery-ui.min.css +6 -0
  47. package/public/require/css.amd.js +12 -0
  48. package/src/components/charts/charts.ts +8 -0
  49. package/src/components/charts/miniChart/miniChart.stories.ts +67 -0
  50. package/src/components/charts/miniChart/miniChart.ts +110 -0
  51. package/src/components/charts/miniChart/miniChart.vue +158 -0
  52. package/src/components/charts/miniChart/stories/README.md +9 -0
  53. package/src/components/charts/miniChart/stories/dummy.ts +25 -0
  54. package/src/components/charts/miniChart/styles/miniChart.css +87 -0
  55. package/src/components/charts/miniChart/utils/consts.ts +9 -0
  56. package/src/components/charts/miniCharts/miniCharts.stories.ts +76 -0
  57. package/src/components/charts/miniCharts/miniCharts.ts +24 -0
  58. package/src/components/charts/miniCharts/miniCharts.vue +128 -0
  59. package/src/components/charts/miniCharts/stories/README.md +18 -0
  60. package/src/components/charts/miniCharts/stories/dummy.ts +70 -0
  61. package/src/components/charts/miniCharts/stories/overview.vue +139 -0
  62. package/src/components/charts/miniCharts/styles/miniCharts.css +32 -0
  63. package/src/components/component.ts +130 -0
  64. package/src/components/core/core.mdx +7 -0
  65. package/src/components/core/notice/item/item.vue +145 -0
  66. package/src/components/core/notice/item/style.css +70 -0
  67. package/src/components/core/notice/item/types.ts +71 -0
  68. package/src/components/core/notice/notice.stories.ts +105 -0
  69. package/src/components/core/notice/notice.vue +69 -0
  70. package/src/components/core/notice/stories/README.md +34 -0
  71. package/src/components/core/notice/types.ts +1 -0
  72. package/src/components/core/notice/utils.ts +115 -0
  73. package/src/components/dialog/dialog/Dialog (code).mdx +61 -0
  74. package/src/components/dialog/dialog/composables/asyncDialogHandle.ts +99 -0
  75. package/src/components/dialog/dialog/composables/dialogHandle.ts +176 -0
  76. package/src/components/dialog/dialog/composables/types.ts +12 -0
  77. package/src/components/dialog/dialog/composables/utils.ts +39 -0
  78. package/src/components/dialog/dialog/dialog.stories.ts +83 -0
  79. package/src/components/dialog/dialog/dialog.vue +74 -0
  80. package/src/components/dialog/dialog/dialogs/dialogs.vue +58 -0
  81. package/src/components/dialog/dialog/page/page.vue +86 -0
  82. package/src/components/dialog/dialog/page/types.ts +84 -0
  83. package/src/components/dialog/dialog/page.stories.ts +27 -0
  84. package/src/components/dialog/dialog/pageComponent/pageComponent.vue +57 -0
  85. package/src/components/dialog/dialog/pageComponent/types.ts +21 -0
  86. package/src/components/dialog/dialog/pageComponent.stories.ts +27 -0
  87. package/src/components/dialog/dialog/stories/README.md +117 -0
  88. package/src/components/dialog/dialog/stories/autoload.ts +12 -0
  89. package/src/components/dialog/dialog/stories/dialog_example/dialog_example.vue +73 -0
  90. package/src/components/dialog/dialog/stories/dialog_example/pages/async.vue +57 -0
  91. package/src/components/dialog/dialog/stories/dialog_example/pages/default.vue +64 -0
  92. package/src/components/dialog/dialog/stories/dialog_example/pages/headerButtons.vue +56 -0
  93. package/src/components/dialog/dialog/stories/dialog_example/pages/utils.ts +26 -0
  94. package/src/components/dialog/dialog/stories/dialog_example/pages/withoutCache.vue +64 -0
  95. package/src/components/dialog/dialog/stories/page/README.md +24 -0
  96. package/src/components/dialog/dialog/stories/pageComponent/README.md +12 -0
  97. package/src/components/dialog/dialog/style/dialog.css +316 -0
  98. package/src/components/dialog/dialog/style/dialog.m.css +40 -0
  99. package/src/components/dialog/dialog/style/dialog.pc.css +73 -0
  100. package/src/components/dialog/dialog/style/modern/dialog.css +12 -0
  101. package/src/components/dialog/dialog/style/modern/dialog.pc.css +3 -0
  102. package/src/components/dialog/dialog/types.ts +69 -0
  103. package/src/components/dialog/dialog.ts +7 -0
  104. package/src/components/dialog/lib/types.ts +26 -0
  105. package/src/components/dialog/lib/utils.globalEvents.ts +175 -0
  106. package/src/components/dialog/lib/utils.ts +525 -0
  107. package/src/components/dialog/lib/worker.ts +273 -0
  108. package/src/components/forms/README.mdx +10 -0
  109. package/src/components/forms/avatar/avatar.stories.ts +38 -0
  110. package/src/components/forms/avatar/avatar.ts +40 -0
  111. package/src/components/forms/avatar/avatar.vue +77 -0
  112. package/src/components/forms/avatar/stories/overview.vue +28 -0
  113. package/src/components/forms/button/button.stories.ts +118 -0
  114. package/src/components/forms/button/button.vue +111 -0
  115. package/src/components/forms/button/stories/README.md +9 -0
  116. package/src/components/forms/button/stories/overview.vue +33 -0
  117. package/src/components/forms/button/style/button.css +139 -0
  118. package/src/components/forms/button/style/style-outline.css +129 -0
  119. package/src/components/forms/button/style/style-soft.css +89 -0
  120. package/src/components/forms/button/style/style-transparent.css +39 -0
  121. package/src/components/forms/button/types.ts +66 -0
  122. package/src/components/forms/checkbox/checkbox.stories.ts +33 -0
  123. package/src/components/forms/checkbox/checkbox.ts +21 -0
  124. package/src/components/forms/checkbox/checkbox.vue +114 -0
  125. package/src/components/forms/checkbox/stories/overview.vue +171 -0
  126. package/src/components/forms/controlLabel/controlLabel.stories.ts +32 -0
  127. package/src/components/forms/controlLabel/controlLabel.ts +4 -0
  128. package/src/components/forms/controlLabel/controlLabel.vue +54 -0
  129. package/src/components/forms/forms.ts +40 -0
  130. package/src/components/forms/helpers.ts +11 -0
  131. package/src/components/forms/hint/hint.stories.ts +41 -0
  132. package/src/components/forms/hint/hint.ts +8 -0
  133. package/src/components/forms/hint/hint.vue +32 -0
  134. package/src/components/forms/input/input.stories.ts +31 -0
  135. package/src/components/forms/input/input.ts +37 -0
  136. package/src/components/forms/input/input.vue +187 -0
  137. package/src/components/forms/input/stories/overview.vue +61 -0
  138. package/src/components/forms/inputDate/datepicker.css +246 -0
  139. package/src/components/forms/inputDate/datepicker.ts +101 -0
  140. package/src/components/forms/inputDate/inputDate.stories.ts +41 -0
  141. package/src/components/forms/inputDate/inputDate.ts +5 -0
  142. package/src/components/forms/inputDate/inputDate.vue +133 -0
  143. package/src/components/forms/inputDate/stories/overview.vue +35 -0
  144. package/src/components/forms/inputRange/inputRange.stories.ts +53 -0
  145. package/src/components/forms/inputRange/inputRange.ts +3 -0
  146. package/src/components/forms/inputRange/inputRange.vue +39 -0
  147. package/src/components/forms/inputRange/stories/overview.vue +129 -0
  148. package/src/components/forms/loadbar/loadbar.stories.ts +17 -0
  149. package/src/components/forms/loadbar/loadbar.vue +37 -0
  150. package/src/components/forms/radio/radio.stories.ts +34 -0
  151. package/src/components/forms/radio/radio.ts +15 -0
  152. package/src/components/forms/radio/radio.vue +97 -0
  153. package/src/components/forms/radio/stories/overview.vue +79 -0
  154. package/src/components/forms/select/select.stories.ts +68 -0
  155. package/src/components/forms/select/select.ts +60 -0
  156. package/src/components/forms/select/select.vue +298 -0
  157. package/src/components/forms/select/stories/exampleOptions.ts +61 -0
  158. package/src/components/forms/select/stories/overview.vue +72 -0
  159. package/src/components/forms/switcher/stories/overview.vue +139 -0
  160. package/src/components/forms/switcher/switcher.stories.ts +33 -0
  161. package/src/components/forms/switcher/switcher.ts +22 -0
  162. package/src/components/forms/switcher/switcher.vue +118 -0
  163. package/src/components/forms/textarea/stories/overview.vue +62 -0
  164. package/src/components/forms/textarea/textarea.stories.ts +33 -0
  165. package/src/components/forms/textarea/textarea.ts +38 -0
  166. package/src/components/forms/textarea/textarea.vue +121 -0
  167. package/src/components/formsExt/README.mdx +5 -0
  168. package/src/components/formsExt/editArea/editArea.stories.ts +41 -0
  169. package/src/components/formsExt/editArea/editArea.ts +41 -0
  170. package/src/components/formsExt/editArea/editArea.vue +195 -0
  171. package/src/components/formsExt/editArea/stories/README.md +21 -0
  172. package/src/components/formsExt/editArea/stories/overview.vue +67 -0
  173. package/src/components/formsExt/editInput/editInput.stories.ts +36 -0
  174. package/src/components/formsExt/editInput/editInput.ts +20 -0
  175. package/src/components/formsExt/editInput/editInput.vue +54 -0
  176. package/src/components/formsExt/editInput/stories/overview.vue +54 -0
  177. package/src/components/formsExt/formsExt.ts +15 -0
  178. package/src/components/formsExt/info/info.stories.ts +35 -0
  179. package/src/components/formsExt/info/info.vue +84 -0
  180. package/src/components/formsExt/info/stories/overview.vue +29 -0
  181. package/src/components/formsExt/info/types.ts +25 -0
  182. package/src/components/formsExt/menu/menu.stories.ts +59 -0
  183. package/src/components/formsExt/menu/menu.ts +45 -0
  184. package/src/components/formsExt/menu/menu.vue +321 -0
  185. package/src/components/formsExt/menu/stories/items.ts +18 -0
  186. package/src/components/formsExt/menu/stories/overview.vue +52 -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 +165 -0
  256. package/src/components/project/selectorRegion/selectorRegion.stories.ts +69 -0
  257. package/src/components/project/selectorRegion/selectorRegion.ts +217 -0
  258. package/src/components/project/selectorRegion/selectorRegion.vue +330 -0
  259. package/src/components/project/selectorRegion/stories/README.md +36 -0
  260. package/src/components/project/selectorRegion/stories/searchers.ts +59 -0
  261. package/src/components/project/selectorRegion/styles/searcherColors.css +41 -0
  262. package/src/components/project/selectorRegion/utils/consts.ts +73 -0
  263. package/src/components/project/selectorRegion/utils/utils.ts +157 -0
  264. package/src/components/project/tagSelector/popupListItem/tagPopupListItem.vue +209 -0
  265. package/src/components/project/tagSelector/popupListItem/types.ts +40 -0
  266. package/src/components/project/tagSelector/popupOpener/popupOpener.vue +145 -0
  267. package/src/components/project/tagSelector/popupOpener/types.ts +71 -0
  268. package/src/components/project/tagSelector/stories/README.md +62 -0
  269. package/src/components/project/tagSelector/stories/overview.vue +152 -0
  270. package/src/components/project/tagSelector/tagIcon/tagIcon.vue +97 -0
  271. package/src/components/project/tagSelector/tagIcon/types.ts +25 -0
  272. package/src/components/project/tagSelector/tagSelector.stories.ts +51 -0
  273. package/src/components/project/tagSelector/tagSelector.vue +359 -0
  274. package/src/components/project/tagSelector/tagsDefaults.ts +54 -0
  275. package/src/components/project/tagSelector/types.ts +159 -0
  276. package/src/components/project/tagSelector/utils/el.ts +151 -0
  277. package/src/components/project/tagSelector/utils/utils.ts +30 -0
  278. package/src/components/tabs/tabs/content.vue +24 -0
  279. package/src/components/tabs/tabs/stories/README.md +12 -0
  280. package/src/components/tabs/tabs/tab.vue +49 -0
  281. package/src/components/tabs/tabs/tabs.stories.ts +171 -0
  282. package/src/components/tabs/tabs/tabs.ts +22 -0
  283. package/src/components/tabs/tabs/tabs.vue +64 -0
  284. package/src/components/tabs/tabs.ts +9 -0
  285. package/src/components/tabsView/tabsView/menu.vue +291 -0
  286. package/src/components/tabsView/tabsView/menuDelimeter.vue +26 -0
  287. package/src/components/tabsView/tabsView/menuItem.vue +125 -0
  288. package/src/components/tabsView/tabsView/menuTitle.vue +46 -0
  289. package/src/components/tabsView/tabsView/store.ts +60 -0
  290. package/src/components/tabsView/tabsView/stories/README.md +22 -0
  291. package/src/components/tabsView/tabsView/tabsView.stories.ts +170 -0
  292. package/src/components/tabsView/tabsView/tabsView.ts +118 -0
  293. package/src/components/tabsView/tabsView/tabsView.vue +120 -0
  294. package/src/components/tabsView/tabsView/utils.ts +27 -0
  295. 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
  296. 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
  297. package/src/components/tabsView/tabsView.ts +9 -0
  298. package/src/components/types.ts +3 -0
  299. package/src/core/app.ts +22 -0
  300. package/src/core/core/core.mdx +36 -0
  301. package/src/core/core/core.ts +287 -0
  302. package/src/core/core/events/resize.ts +47 -0
  303. package/src/core/core/events.ts +6 -0
  304. package/src/core/core/jQuery.mdx +41 -0
  305. package/src/core/core/options.ts +51 -0
  306. package/src/core/core/preloaders.ts +31 -0
  307. package/src/core/core/state.ts +61 -0
  308. package/src/core/directives/data.mdx +24 -0
  309. package/src/core/directives/data.ts +25 -0
  310. package/src/core/directives/focus.mdx +28 -0
  311. package/src/core/directives/focus.ts +73 -0
  312. package/src/core/directives/scrollIntoView.mdx +41 -0
  313. package/src/core/directives/scrollIntoView.ts +123 -0
  314. package/src/core/directives/scrollShadow.mdx +23 -0
  315. package/src/core/directives/scrollShadow.ts +27 -0
  316. package/src/core/directives/sticky.mdx +29 -0
  317. package/src/core/directives/sticky.ts +32 -0
  318. package/src/core/directives/swimUp.mdx +27 -0
  319. package/src/core/directives/swimUp.ts +95 -0
  320. package/src/core/directives/tooltip.mdx +13 -0
  321. package/src/core/directives/tooltip.ts +57 -0
  322. package/src/core/icons/gallery.vue +70 -0
  323. package/src/core/icons/icons.mdx +24 -0
  324. package/src/core/icons/icons.stories.ts +14 -0
  325. package/src/core/plugins/core.ts +131 -0
  326. package/src/core/plugins/i18n.ts +184 -0
  327. package/src/core/plugins/piniaTPA.ts +431 -0
  328. package/src/core/plugins/plugins.mdx +82 -0
  329. package/src/core/styles/CSS Variables.stories.ts +17 -0
  330. package/src/core/styles/styles.mdx +26 -0
  331. package/src/core/theme/Variables.stories.ts +16 -0
  332. package/src/core/theme/theme.mdx +117 -0
  333. package/src/core/utils/References/Docs.mdx +23 -0
  334. package/src/core/utils/References/check/Docs.mdx +15 -0
  335. package/src/core/utils/References/check/functions/getDomainRegexp.mdx +15 -0
  336. package/src/core/utils/References/check/functions/isDomain.mdx +21 -0
  337. package/src/core/utils/References/check/functions/isEmail.mdx +22 -0
  338. package/src/core/utils/References/check/functions/isIp.mdx +21 -0
  339. package/src/core/utils/References/check/functions/validUrl.mdx +22 -0
  340. package/src/core/utils/References/clipboard/Docs.mdx +11 -0
  341. package/src/core/utils/References/clipboard/functions/setClipboard.mdx +23 -0
  342. package/src/core/utils/References/date/Docs.mdx +17 -0
  343. package/src/core/utils/References/date/functions/dateFormat.mdx +28 -0
  344. package/src/core/utils/References/date/functions/dateToString.mdx +26 -0
  345. package/src/core/utils/References/date/functions/dateUnformat.mdx +22 -0
  346. package/src/core/utils/References/date/functions/genDate.mdx +26 -0
  347. package/src/core/utils/References/date/functions/genDateMoscow.mdx +22 -0
  348. package/src/core/utils/References/date/functions/getDayOfWeek.mdx +26 -0
  349. package/src/core/utils/References/date/functions/stringToDate.mdx +21 -0
  350. package/src/core/utils/References/device/Docs.mdx +21 -0
  351. package/src/core/utils/References/device/functions/get$scroll.mdx +15 -0
  352. package/src/core/utils/References/device/functions/getCommandKeyLabel.mdx +15 -0
  353. package/src/core/utils/References/device/functions/getElsScroll.mdx +15 -0
  354. package/src/core/utils/References/device/functions/getOS.mdx +17 -0
  355. package/src/core/utils/References/device/functions/getOSAsync.mdx +15 -0
  356. package/src/core/utils/References/device/functions/getScrollTop.mdx +15 -0
  357. package/src/core/utils/References/device/functions/isApp.mdx +15 -0
  358. package/src/core/utils/References/device/functions/isMacOS.mdx +15 -0
  359. package/src/core/utils/References/device/functions/isMobile.mdx +15 -0
  360. package/src/core/utils/References/device/functions/isRetina.mdx +15 -0
  361. package/src/core/utils/References/device/functions/isSafari.mdx +15 -0
  362. package/src/core/utils/References/dom/Docs.mdx +27 -0
  363. package/src/core/utils/References/dom/functions/css.mdx +24 -0
  364. package/src/core/utils/References/dom/functions/genEl.mdx +28 -0
  365. package/src/core/utils/References/dom/functions/isVisible.mdx +23 -0
  366. package/src/core/utils/References/dom/functions/offset.mdx +35 -0
  367. package/src/core/utils/References/dom/functions/querySelectorAllArray.mdx +22 -0
  368. package/src/core/utils/References/dom/functions/querySelectorAllVisible.mdx +22 -0
  369. package/src/core/utils/References/dom/functions/querySelectorVisible.mdx +22 -0
  370. package/src/core/utils/References/dom/functions/querySelectorVisibleLast.mdx +22 -0
  371. package/src/core/utils/References/dom/functions/storage.mdx +28 -0
  372. package/src/core/utils/References/dom/functions/storageClear.mdx +21 -0
  373. package/src/core/utils/References/dom/functions/wrap.mdx +22 -0
  374. package/src/core/utils/References/dom/variables/default.mdx +241 -0
  375. package/src/core/utils/References/image/Docs.mdx +12 -0
  376. package/src/core/utils/References/image/functions/downloadImageFromString.mdx +22 -0
  377. package/src/core/utils/References/image/functions/genFaviconImgHtml.mdx +22 -0
  378. package/src/core/utils/References/keyboard/Docs.mdx +11 -0
  379. package/src/core/utils/References/keyboard/functions/invertKeyboardLayout.mdx +21 -0
  380. package/src/core/utils/References/lodash/Docs.mdx +20 -0
  381. package/src/core/utils/References/lodash/functions/cloneDeep.mdx +29 -0
  382. package/src/core/utils/References/lodash/functions/debounce.mdx +76 -0
  383. package/src/core/utils/References/lodash/functions/memoize.mdx +26 -0
  384. package/src/core/utils/References/lodash/functions/merge.mdx +200 -0
  385. package/src/core/utils/References/lodash/functions/throttle.mdx +73 -0
  386. package/src/core/utils/References/number/Docs.mdx +11 -0
  387. package/src/core/utils/References/number/functions/percentOfNumber.mdx +26 -0
  388. package/src/core/utils/References/price/Docs.mdx +11 -0
  389. package/src/core/utils/References/price/functions/genPrice.mdx +28 -0
  390. package/src/core/utils/References/route/Docs.mdx +16 -0
  391. package/src/core/utils/References/route/functions/delHash.mdx +26 -0
  392. package/src/core/utils/References/route/functions/genHash.mdx +26 -0
  393. package/src/core/utils/References/route/functions/getHash.mdx +22 -0
  394. package/src/core/utils/References/route/functions/historySetState.mdx +31 -0
  395. package/src/core/utils/References/route/functions/setHash.mdx +26 -0
  396. package/src/core/utils/References/route/functions/setHashs.mdx +22 -0
  397. package/src/core/utils/References/scroll/Docs.mdx +14 -0
  398. package/src/core/utils/References/scroll/functions/amountScrolled.mdx +17 -0
  399. package/src/core/utils/References/scroll/functions/connectScrollShadow.mdx +28 -0
  400. package/src/core/utils/References/scroll/functions/genHasScroll.mdx +25 -0
  401. package/src/core/utils/References/scroll/functions/getScrollPercent.mdx +21 -0
  402. package/src/core/utils/References/searchers/Docs.mdx +19 -0
  403. package/src/core/utils/References/searchers/functions/genVolumeLabel.mdx +26 -0
  404. package/src/core/utils/References/searchers/functions/getDeviceGIcon.mdx +21 -0
  405. package/src/core/utils/References/searchers/functions/getLangLabel.mdx +22 -0
  406. package/src/core/utils/References/searchers/functions/getSearcherGIcon.mdx +21 -0
  407. package/src/core/utils/References/searchers/functions/prepareVolumeType.mdx +22 -0
  408. package/src/core/utils/References/searchers/variables/searchersNames.mdx +97 -0
  409. package/src/core/utils/References/store/Docs.mdx +18 -0
  410. package/src/core/utils/References/store/functions/defineStore.mdx +36 -0
  411. package/src/core/utils/References/store/functions/useStore.mdx +29 -0
  412. package/src/core/utils/References/store/variables/plugin.mdx +66 -0
  413. package/src/core/utils/References/string/Docs.mdx +26 -0
  414. package/src/core/utils/References/string/functions/addCommasWhite.mdx +21 -0
  415. package/src/core/utils/References/string/functions/addLinkTags.mdx +23 -0
  416. package/src/core/utils/References/string/functions/camelToSnakeCase.mdx +21 -0
  417. package/src/core/utils/References/string/functions/ellipsis.mdx +26 -0
  418. package/src/core/utils/References/string/functions/genFlagLinkByCountryCode.mdx +21 -0
  419. package/src/core/utils/References/string/functions/genIntHash.mdx +21 -0
  420. package/src/core/utils/References/string/functions/getRandomHash.mdx +21 -0
  421. package/src/core/utils/References/string/functions/highlightHtml.mdx +25 -0
  422. package/src/core/utils/References/string/functions/htmlspecialchars.mdx +21 -0
  423. package/src/core/utils/References/string/functions/isUrl.mdx +21 -0
  424. package/src/core/utils/References/string/functions/nl2br.mdx +21 -0
  425. package/src/core/utils/References/string/functions/numberEnding.mdx +28 -0
  426. package/src/core/utils/References/string/functions/numberWithWord.mdx +28 -0
  427. package/src/core/utils/References/string/functions/rusToLatin.mdx +21 -0
  428. package/src/core/utils/References/string/functions/toCapitalize.mdx +21 -0
  429. package/src/core/utils/References/string/functions/toRoditPadej.mdx +21 -0
  430. package/src/core/utils/References/system/Docs.mdx +13 -0
  431. package/src/core/utils/References/system/functions/sleep.mdx +21 -0
  432. package/src/core/utils/References/system/functions/sleepWhile.mdx +26 -0
  433. package/src/core/utils/References/system/functions/waitWhile.mdx +26 -0
  434. package/src/core/utils/References/url/Docs.mdx +17 -0
  435. package/src/core/utils/References/url/functions/decode.mdx +21 -0
  436. package/src/core/utils/References/url/functions/encode.mdx +21 -0
  437. package/src/core/utils/References/url/functions/fromPuny.mdx +23 -0
  438. package/src/core/utils/References/url/functions/getHost.mdx +21 -0
  439. package/src/core/utils/References/url/functions/hostToLowerCase.mdx +21 -0
  440. package/src/core/utils/References/url/functions/normalize.mdx +21 -0
  441. package/src/core/utils/References/url/functions/toPuny.mdx +23 -0
  442. package/src/core/utils/check.ts +88 -0
  443. package/src/core/utils/clipboard.ts +51 -0
  444. package/src/core/utils/date.ts +291 -0
  445. package/src/core/utils/device.ts +139 -0
  446. package/src/core/utils/dom.ts +182 -0
  447. package/src/core/utils/image.ts +46 -0
  448. package/src/core/utils/keyboard.ts +29 -0
  449. package/src/core/utils/lodash.ts +18 -0
  450. package/src/core/utils/number.ts +37 -0
  451. package/src/core/utils/price.ts +24 -0
  452. package/src/core/utils/route.ts +115 -0
  453. package/src/core/utils/scroll.ts +120 -0
  454. package/src/core/utils/searchers.ts +189 -0
  455. package/src/core/utils/store/localStorage.ts +56 -0
  456. package/src/core/utils/store/plugin.ts +50 -0
  457. package/src/core/utils/store/store.ts +77 -0
  458. package/src/core/utils/store.ts +7 -0
  459. package/src/core/utils/string.ts +315 -0
  460. package/src/core/utils/system.ts +72 -0
  461. package/src/core/utils/url.ts +138 -0
  462. package/src/core/utils/utils.mdx +6 -0
  463. package/src/d.ts +12 -0
  464. package/src/icomoon.d.ts +98 -0
  465. package/src/resources/styles/core/components.css +102 -0
  466. package/src/resources/styles/core/core.ts +11 -0
  467. package/src/resources/styles/core/forms/clear.css +20 -0
  468. package/src/resources/styles/core/forms/controls.css +20 -0
  469. package/src/resources/styles/core/forms/focusable.css +26 -0
  470. package/src/resources/styles/core/forms/forms.css +117 -0
  471. package/src/resources/styles/core/icon.css +58 -0
  472. package/src/resources/styles/core/jquery.css +1 -0
  473. package/src/resources/styles/core/layout.css +59 -0
  474. package/src/resources/styles/core/modifiers/as.css +9 -0
  475. package/src/resources/styles/core/modifiers/ellipsis.css +26 -0
  476. package/src/resources/styles/core/modifiers/modifiers.css +120 -0
  477. package/src/resources/styles/core/modifiers/only.css +19 -0
  478. package/src/resources/styles/core/modifiers/scrollShadow.css +50 -0
  479. package/src/resources/styles/core/select.css +15 -0
  480. package/src/resources/styles/storybook.css +11 -0
  481. package/src/resources/styles/themes/dark/dark-layout.css +47 -0
  482. package/src/resources/styles/themes/dark/dark-positions.css +66 -0
  483. package/src/resources/styles/themes/dark/dark.css +400 -0
  484. package/src/resources/styles/themes/dark-positions.ts +1 -0
  485. package/src/resources/styles/themes/dark-th/dark-th-layout.css +47 -0
  486. package/src/resources/styles/themes/dark-th/dark-th-positions.css +67 -0
  487. package/src/resources/styles/themes/dark-th/dark-th.css +400 -0
  488. package/src/resources/styles/themes/dark-th-positions.ts +1 -0
  489. package/src/resources/styles/themes/dark-th.ts +3 -0
  490. package/src/resources/styles/themes/dark.ts +3 -0
  491. package/src/resources/styles/themes/light/light-layout.css +47 -0
  492. package/src/resources/styles/themes/light/light-positions.css +66 -0
  493. package/src/resources/styles/themes/light/light.css +400 -0
  494. package/src/resources/styles/themes/light-positions.ts +1 -0
  495. package/src/resources/styles/themes/light.ts +3 -0
  496. package/src/storybook/components/color.vue +47 -0
  497. package/src/storybook/components/cssVariables.vue +195 -0
  498. package/src/storybook/components/icomoon.ts +40 -0
  499. package/src/storybook/jquery.ts +4 -0
  500. 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
  501. 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
  502. 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
  503. 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
  504. 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
  505. 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
  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//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
  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/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
  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/241/321/202/320/270/320/273/320/270.mdx" +53 -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/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
  510. 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
  511. 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
  512. 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
  513. 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
  514. 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
  515. 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
  516. 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
  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/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
  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/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
  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/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
  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/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
  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/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
  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/243/321/202/320/270/320/273/320/270/321/202/321/213.mdx" +5 -0
  523. package/tsconfig.json +91 -0
  524. package/typedoc.json +20 -0
  525. package/vite.config.ts +148 -0
  526. package/web-types.json +130 -130
  527. package/.chunks/datepicker-B8O5mg_G.es.js +0 -44
  528. package/.chunks/datepicker-B8O5mg_G.es.js.map +0 -1
  529. package/.chunks/datepicker-CFiizYlZ.amd.js +0 -2
  530. package/.chunks/datepicker-CFiizYlZ.amd.js.map +0 -1
  531. package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-B55gllXV.amd.js +0 -2
  532. package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-B55gllXV.amd.js.map +0 -1
  533. package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-BkBYW0yR.es.js +0 -266
  534. package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-BkBYW0yR.es.js.map +0 -1
  535. package/.chunks/forms-BWc2kMFD.amd.js +0 -3
  536. package/.chunks/forms-BWc2kMFD.amd.js.map +0 -1
  537. package/.chunks/forms-DW_XLzg8.es.js +0 -2018
  538. package/.chunks/forms-DW_XLzg8.es.js.map +0 -1
  539. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-naMiJruI.amd.js +0 -2
  540. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-naMiJruI.amd.js.map +0 -1
  541. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-saYIC17M.es.js +0 -181
  542. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-saYIC17M.es.js.map +0 -1
  543. package/.chunks/menu.vue_vue_type_style_index_0_lang-06YUloqb.amd.js +0 -2
  544. package/.chunks/menu.vue_vue_type_style_index_0_lang-06YUloqb.amd.js.map +0 -1
  545. package/.chunks/menu.vue_vue_type_style_index_0_lang-CcspstQc.es.js +0 -109
  546. package/.chunks/menu.vue_vue_type_style_index_0_lang-CcspstQc.es.js.map +0 -1
  547. package/.chunks/notice-BQyuy4nF.es.js +0 -175
  548. package/.chunks/notice-BQyuy4nF.es.js.map +0 -1
  549. package/.chunks/notice-zADfJ5TR.amd.js +0 -4
  550. package/.chunks/notice-zADfJ5TR.amd.js.map +0 -1
  551. package/.chunks/popup-CPS-7fSX.amd.js +0 -2
  552. package/.chunks/popup-CPS-7fSX.amd.js.map +0 -1
  553. package/.chunks/popup-DsVptZvL.es.js +0 -415
  554. package/.chunks/popup-DsVptZvL.es.js.map +0 -1
  555. package/.chunks/punycode.es6-C2yitnNb.amd.js +0 -2
  556. package/.chunks/punycode.es6-C2yitnNb.amd.js.map +0 -1
  557. package/.chunks/punycode.es6-CNI-zL6U.es.js +0 -134
  558. package/.chunks/punycode.es6-CNI-zL6U.es.js.map +0 -1
  559. package/.chunks/store-CX_6ZXhO.es.js +0 -29
  560. package/.chunks/store-CX_6ZXhO.es.js.map +0 -1
  561. package/.chunks/store-esTid5oI.amd.js +0 -2
  562. package/.chunks/store-esTid5oI.amd.js.map +0 -1
  563. package/.chunks/utils-B75aamxF.amd.js +0 -2
  564. package/.chunks/utils-B75aamxF.amd.js.map +0 -1
  565. package/.chunks/utils-DIP-BdDy.es.js +0 -225
  566. package/.chunks/utils-DIP-BdDy.es.js.map +0 -1
  567. package/.chunks/utils-DfYj3r9i.amd.js +0 -2
  568. package/.chunks/utils-DfYj3r9i.amd.js.map +0 -1
  569. package/.chunks/utils-h5v4GPgp.es.js +0 -79
  570. package/.chunks/utils-h5v4GPgp.es.js.map +0 -1
  571. package/assets/charts.css +0 -1
  572. package/assets/core.css +0 -1
  573. package/assets/forms.css +0 -1
  574. package/assets/formsExt.css +0 -1
  575. package/assets/layout.css +0 -1
  576. package/assets/listItem.css +0 -1
  577. package/assets/menu.css +0 -1
  578. package/assets/notice.css +0 -1
  579. package/assets/popup.css +0 -1
  580. package/assets/project.css +0 -1
  581. package/assets/tabs.css +0 -1
  582. package/assets/tabsView.css +0 -1
  583. package/assets/themes/dark-th.css +0 -1
  584. package/assets/themes/dark.css +0 -1
  585. package/assets/themes/light.css +0 -1
  586. package/charts/charts.amd.js +0 -2
  587. package/charts/charts.amd.js.map +0 -1
  588. package/charts/charts.d.ts +0 -2
  589. package/charts/charts.js +0 -178
  590. package/charts/charts.js.map +0 -1
  591. package/components/charts/charts.d.ts +0 -5
  592. package/components/charts/miniChart/miniChart.d.ts +0 -92
  593. package/components/charts/miniChart/miniChart.vue.d.ts +0 -15
  594. package/components/charts/miniChart/stories/dummy.d.ts +0 -13
  595. package/components/charts/miniChart/utils/consts.d.ts +0 -8
  596. package/components/charts/miniCharts/miniCharts.d.ts +0 -20
  597. package/components/charts/miniCharts/miniCharts.vue.d.ts +0 -32
  598. package/components/charts/miniCharts/stories/dummy.d.ts +0 -6
  599. package/components/core/notice/item/item.vue.d.ts +0 -10
  600. package/components/core/notice/item/types.d.ts +0 -61
  601. package/components/core/notice/notice.vue.d.ts +0 -5
  602. package/components/core/notice/types.d.ts +0 -1
  603. package/components/core/notice/utils.d.ts +0 -27
  604. package/components/dialog/dialog/composables/asyncDialogHandle.d.ts +0 -51
  605. package/components/dialog/dialog/composables/dialogHandle.d.ts +0 -108
  606. package/components/dialog/dialog/composables/types.d.ts +0 -11
  607. package/components/dialog/dialog/composables/utils.d.ts +0 -21
  608. package/components/dialog/dialog/dialog.vue.d.ts +0 -28
  609. package/components/dialog/dialog/dialogs/dialogs.vue.d.ts +0 -10
  610. package/components/dialog/dialog/page/page.vue.d.ts +0 -19
  611. package/components/dialog/dialog/page/types.d.ts +0 -72
  612. package/components/dialog/dialog/pageComponent/pageComponent.vue.d.ts +0 -6
  613. package/components/dialog/dialog/pageComponent/types.d.ts +0 -18
  614. package/components/dialog/dialog/stories/autoload.d.ts +0 -2
  615. package/components/dialog/dialog/stories/dialog_example/pages/utils.d.ts +0 -7
  616. package/components/dialog/dialog/types.d.ts +0 -58
  617. package/components/dialog/dialog.d.ts +0 -6
  618. package/components/dialog/lib/types.d.ts +0 -21
  619. package/components/dialog/lib/utils.d.ts +0 -14
  620. package/components/dialog/lib/utils.globalEvents.d.ts +0 -8
  621. package/components/dialog/lib/worker.d.ts +0 -60
  622. package/components/forms/avatar/avatar.d.ts +0 -38
  623. package/components/forms/avatar/avatar.vue.d.ts +0 -10
  624. package/components/forms/button/button.vue.d.ts +0 -25
  625. package/components/forms/button/types.d.ts +0 -53
  626. package/components/forms/checkbox/checkbox.d.ts +0 -19
  627. package/components/forms/checkbox/checkbox.vue.d.ts +0 -27
  628. package/components/forms/controlLabel/controlLabel.d.ts +0 -4
  629. package/components/forms/controlLabel/controlLabel.vue.d.ts +0 -19
  630. package/components/forms/forms.d.ts +0 -27
  631. package/components/forms/helpers.d.ts +0 -10
  632. package/components/forms/hint/hint.d.ts +0 -8
  633. package/components/forms/hint/hint.vue.d.ts +0 -4
  634. package/components/forms/input/input.d.ts +0 -26
  635. package/components/forms/input/input.vue.d.ts +0 -27
  636. package/components/forms/inputDate/datepicker.d.ts +0 -5
  637. package/components/forms/inputDate/inputDate.d.ts +0 -3
  638. package/components/forms/inputDate/inputDate.vue.d.ts +0 -12
  639. package/components/forms/inputRange/inputRange.d.ts +0 -2
  640. package/components/forms/inputRange/inputRange.vue.d.ts +0 -19
  641. package/components/forms/loadbar/loadbar.vue.d.ts +0 -3
  642. package/components/forms/radio/radio.d.ts +0 -14
  643. package/components/forms/radio/radio.vue.d.ts +0 -23
  644. package/components/forms/select/select.d.ts +0 -51
  645. package/components/forms/select/select.vue.d.ts +0 -17
  646. package/components/forms/select/stories/exampleOptions.d.ts +0 -5
  647. package/components/forms/switcher/switcher.d.ts +0 -21
  648. package/components/forms/switcher/switcher.vue.d.ts +0 -23
  649. package/components/forms/textarea/textarea.d.ts +0 -33
  650. package/components/forms/textarea/textarea.vue.d.ts +0 -11
  651. package/components/formsExt/editArea/editArea.d.ts +0 -33
  652. package/components/formsExt/editArea/editArea.vue.d.ts +0 -18
  653. package/components/formsExt/editInput/editInput.d.ts +0 -16
  654. package/components/formsExt/editInput/editInput.vue.d.ts +0 -8
  655. package/components/formsExt/formsExt.d.ts +0 -13
  656. package/components/formsExt/info/info.vue.d.ts +0 -20
  657. package/components/formsExt/info/types.d.ts +0 -21
  658. package/components/formsExt/menu/menu.d.ts +0 -37
  659. package/components/formsExt/menu/menu.vue.d.ts +0 -16
  660. package/components/formsExt/menu/stories/items.d.ts +0 -3
  661. package/components/formsExt/radioGroup/radioGroup.d.ts +0 -21
  662. package/components/formsExt/radioGroup/radioGroup.vue.d.ts +0 -19
  663. package/components/formsExt/selector2/api.d.ts +0 -8
  664. package/components/formsExt/selector2/itemMulti.vue.d.ts +0 -8
  665. package/components/formsExt/selector2/selector2.d.ts +0 -130
  666. package/components/formsExt/selector2/selector2.vue.d.ts +0 -210
  667. package/components/formsExt/selector2/stories/dummyAPIRequest.d.ts +0 -10
  668. package/components/layout/islandRows/islandRows.vue.d.ts +0 -17
  669. package/components/layout/islandRows/islandRowsRow/islandRowsRow.vue.d.ts +0 -18
  670. package/components/layout/islandRows/islandRowsRow/types.d.ts +0 -2
  671. package/components/layout/islandRows/islandRowsSubTitle/islandRowsSubTitle.vue.d.ts +0 -18
  672. package/components/layout/islandRows/types.d.ts +0 -10
  673. package/components/layout/layout.d.ts +0 -9
  674. package/components/layout/rows/rows.vue.d.ts +0 -21
  675. package/components/layout/rows/types.d.ts +0 -6
  676. package/components/popup/alert/alert.d.ts +0 -8
  677. package/components/popup/alert/alert.vue.d.ts +0 -31
  678. package/components/popup/confirm/confirm.d.ts +0 -21
  679. package/components/popup/confirm/confirm.vue.d.ts +0 -33
  680. package/components/popup/lib/popup.d.ts +0 -83
  681. package/components/popup/lib/popup.globalEvents.d.ts +0 -26
  682. package/components/popup/lib/worker.d.ts +0 -75
  683. package/components/popup/lib/worker.globalEvents.d.ts +0 -19
  684. package/components/popup/popup/listItem.vue.d.ts +0 -22
  685. package/components/popup/popup/opener.vue.d.ts +0 -23
  686. package/components/popup/popup/popup.d.ts +0 -101
  687. package/components/popup/popup/popup.vue.d.ts +0 -40
  688. package/components/popup/popup/widgetInput.vue.d.ts +0 -17
  689. package/components/popup/popup.d.ts +0 -15
  690. package/components/popup/prompt/prompt.d.ts +0 -21
  691. package/components/popup/prompt/prompt.vue.d.ts +0 -33
  692. package/components/popup/worker.d.ts +0 -1
  693. package/components/project/project.d.ts +0 -15
  694. package/components/project/selectorCompetitors/composables.d.ts +0 -4
  695. package/components/project/selectorCompetitors/selectorCompetitors.d.ts +0 -23
  696. package/components/project/selectorCompetitors/selectorCompetitors.vue.d.ts +0 -14
  697. package/components/project/selectorCompetitors/stories/items.d.ts +0 -3
  698. package/components/project/selectorCompetitors/types/competitor.d.ts +0 -7
  699. package/components/project/selectorRegion/composables/compare.d.ts +0 -12
  700. package/components/project/selectorRegion/composables/selectRegion.d.ts +0 -14
  701. package/components/project/selectorRegion/composables/selectSearcher.d.ts +0 -13
  702. package/components/project/selectorRegion/composables/selectorRegion.d.ts +0 -25
  703. package/components/project/selectorRegion/selectorRegion.d.ts +0 -182
  704. package/components/project/selectorRegion/selectorRegion.vue.d.ts +0 -25
  705. package/components/project/selectorRegion/stories/searchers.d.ts +0 -3
  706. package/components/project/selectorRegion/utils/consts.d.ts +0 -18
  707. package/components/project/selectorRegion/utils/utils.d.ts +0 -23
  708. package/components/project/tagSelector/popupListItem/tagPopupListItem.vue.d.ts +0 -20
  709. package/components/project/tagSelector/popupListItem/types.d.ts +0 -33
  710. package/components/project/tagSelector/popupOpener/popupOpener.vue.d.ts +0 -27
  711. package/components/project/tagSelector/popupOpener/types.d.ts +0 -62
  712. package/components/project/tagSelector/tagIcon/tagIcon.vue.d.ts +0 -4
  713. package/components/project/tagSelector/tagIcon/types.d.ts +0 -21
  714. package/components/project/tagSelector/tagSelector.vue.d.ts +0 -37
  715. package/components/project/tagSelector/tagsDefaults.d.ts +0 -3
  716. package/components/project/tagSelector/types.d.ts +0 -138
  717. package/components/project/tagSelector/utils/el.d.ts +0 -19
  718. package/components/project/tagSelector/utils/utils.d.ts +0 -14
  719. package/components/tabs/tabs/content.vue.d.ts +0 -19
  720. package/components/tabs/tabs/tab.vue.d.ts +0 -19
  721. package/components/tabs/tabs/tabs.d.ts +0 -19
  722. package/components/tabs/tabs/tabs.vue.d.ts +0 -21
  723. package/components/tabs/tabs.d.ts +0 -7
  724. package/components/tabsView/tabsView/menu.vue.d.ts +0 -32
  725. package/components/tabsView/tabsView/menuDelimeter.vue.d.ts +0 -3
  726. package/components/tabsView/tabsView/menuItem.vue.d.ts +0 -23
  727. package/components/tabsView/tabsView/menuTitle.vue.d.ts +0 -20
  728. package/components/tabsView/tabsView/store.d.ts +0 -192
  729. package/components/tabsView/tabsView/tabsView.d.ts +0 -98
  730. package/components/tabsView/tabsView/tabsView.vue.d.ts +0 -34
  731. package/components/tabsView/tabsView/utils.d.ts +0 -11
  732. package/components/tabsView/tabsView.d.ts +0 -7
  733. package/core/app.amd.js +0 -2
  734. package/core/app.amd.js.map +0 -1
  735. package/core/app.d.ts +0 -8
  736. package/core/app.js +0 -402
  737. package/core/app.js.map +0 -1
  738. package/core/core/core.d.ts +0 -113
  739. package/core/core/events/resize.d.ts +0 -16
  740. package/core/core/events.d.ts +0 -15
  741. package/core/core/options.d.ts +0 -46
  742. package/core/core/preloaders.d.ts +0 -19
  743. package/core/core/state.d.ts +0 -49
  744. package/core/directives/data.d.ts +0 -10
  745. package/core/directives/focus.d.ts +0 -10
  746. package/core/directives/scrollIntoView.d.ts +0 -3
  747. package/core/directives/scrollShadow.d.ts +0 -15
  748. package/core/directives/sticky.d.ts +0 -10
  749. package/core/directives/swimUp.d.ts +0 -15
  750. package/core/directives/tooltip.d.ts +0 -10
  751. package/core/plugins/core.d.ts +0 -60
  752. package/core/plugins/i18n.d.ts +0 -107
  753. package/core/plugins/piniaTPA.d.ts +0 -17
  754. package/core/utils/check.d.ts +0 -26
  755. package/core/utils/clipboard.d.ts +0 -12
  756. package/core/utils/date.d.ts +0 -52
  757. package/core/utils/device.d.ts +0 -50
  758. package/core/utils/dom.d.ts +0 -94
  759. package/core/utils/image.d.ts +0 -16
  760. package/core/utils/keyboard.d.ts +0 -8
  761. package/core/utils/lodash.d.ts +0 -6
  762. package/core/utils/number.d.ts +0 -17
  763. package/core/utils/price.d.ts +0 -10
  764. package/core/utils/route.d.ts +0 -33
  765. package/core/utils/scroll.d.ts +0 -32
  766. package/core/utils/searchers.d.ts +0 -38
  767. package/core/utils/store/localStorage.d.ts +0 -6
  768. package/core/utils/store/plugin.d.ts +0 -24
  769. package/core/utils/store/store.d.ts +0 -34
  770. package/core/utils/store.d.ts +0 -6
  771. package/core/utils/string.d.ts +0 -86
  772. package/core/utils/system.d.ts +0 -25
  773. package/core/utils/url.d.ts +0 -36
  774. package/dialog/dialog.amd.js +0 -2
  775. package/dialog/dialog.amd.js.map +0 -1
  776. package/dialog/dialog.d.ts +0 -2
  777. package/dialog/dialog.js +0 -194
  778. package/dialog/dialog.js.map +0 -1
  779. package/forms/forms.amd.js +0 -2
  780. package/forms/forms.amd.js.map +0 -1
  781. package/forms/forms.d.ts +0 -2
  782. package/forms/forms.js +0 -17
  783. package/forms/forms.js.map +0 -1
  784. package/forms/helpers.amd.js +0 -2
  785. package/forms/helpers.amd.js.map +0 -1
  786. package/forms/helpers.d.ts +0 -2
  787. package/forms/helpers.js +0 -10
  788. package/forms/helpers.js.map +0 -1
  789. package/formsExt/formsExt.amd.js +0 -2
  790. package/formsExt/formsExt.amd.js.map +0 -1
  791. package/formsExt/formsExt.d.ts +0 -2
  792. package/formsExt/formsExt.js +0 -483
  793. package/formsExt/formsExt.js.map +0 -1
  794. package/icomoon/Read Me.txt +0 -7
  795. package/icomoon/Topvisor icons.json +0 -6145
  796. package/icomoon/demo-files/demo.css +0 -158
  797. package/icomoon/demo-files/demo.js +0 -30
  798. package/icomoon/demo.html +0 -3488
  799. package/icomoon/fonts/Topvisor-2.eot +0 -0
  800. package/icomoon/fonts/Topvisor-2.svg +0 -272
  801. package/icomoon/fonts/Topvisor-2.ttf +0 -0
  802. package/icomoon/fonts/Topvisor-2.woff +0 -0
  803. package/icomoon/selection.json +0 -1
  804. package/icomoon/style.css +0 -765
  805. package/jquery-ui.min.css +0 -6
  806. package/layout/layout.amd.js +0 -2
  807. package/layout/layout.amd.js.map +0 -1
  808. package/layout/layout.d.ts +0 -2
  809. package/layout/layout.js +0 -62
  810. package/layout/layout.js.map +0 -1
  811. package/popup/popup.amd.js +0 -2
  812. package/popup/popup.amd.js.map +0 -1
  813. package/popup/popup.d.ts +0 -2
  814. package/popup/popup.js +0 -243
  815. package/popup/popup.js.map +0 -1
  816. package/popup/worker.amd.js +0 -2
  817. package/popup/worker.amd.js.map +0 -1
  818. package/popup/worker.d.ts +0 -2
  819. package/popup/worker.js +0 -129
  820. package/popup/worker.js.map +0 -1
  821. package/project/project.amd.js +0 -2
  822. package/project/project.amd.js.map +0 -1
  823. package/project/project.d.ts +0 -2
  824. package/project/project.js +0 -975
  825. package/project/project.js.map +0 -1
  826. package/require/css.amd.js +0 -12
  827. package/tabs/tabs.amd.js +0 -2
  828. package/tabs/tabs.amd.js.map +0 -1
  829. package/tabs/tabs.d.ts +0 -2
  830. package/tabs/tabs.js +0 -81
  831. package/tabs/tabs.js.map +0 -1
  832. package/tabsView/tabsView.amd.js +0 -2
  833. package/tabsView/tabsView.amd.js.map +0 -1
  834. package/tabsView/tabsView.d.ts +0 -2
  835. package/tabsView/tabsView.js +0 -306
  836. package/tabsView/tabsView.js.map +0 -1
  837. package/utils/check.amd.js +0 -2
  838. package/utils/check.amd.js.map +0 -1
  839. package/utils/check.d.ts +0 -2
  840. package/utils/check.js +0 -26
  841. package/utils/check.js.map +0 -1
  842. package/utils/clipboard.amd.js +0 -6
  843. package/utils/clipboard.amd.js.map +0 -1
  844. package/utils/clipboard.d.ts +0 -2
  845. package/utils/clipboard.js +0 -33
  846. package/utils/clipboard.js.map +0 -1
  847. package/utils/date.amd.js +0 -2
  848. package/utils/date.amd.js.map +0 -1
  849. package/utils/date.d.ts +0 -2
  850. package/utils/date.js +0 -11
  851. package/utils/date.js.map +0 -1
  852. package/utils/device.amd.js +0 -2
  853. package/utils/device.amd.js.map +0 -1
  854. package/utils/device.d.ts +0 -2
  855. package/utils/device.js +0 -15
  856. package/utils/device.js.map +0 -1
  857. package/utils/dom.amd.js +0 -2
  858. package/utils/dom.amd.js.map +0 -1
  859. package/utils/dom.d.ts +0 -6
  860. package/utils/dom.js +0 -75
  861. package/utils/dom.js.map +0 -1
  862. package/utils/image.amd.js +0 -12
  863. package/utils/image.amd.js.map +0 -1
  864. package/utils/image.d.ts +0 -2
  865. package/utils/image.js +0 -23
  866. package/utils/image.js.map +0 -1
  867. package/utils/keyboard.amd.js +0 -2
  868. package/utils/keyboard.amd.js.map +0 -1
  869. package/utils/keyboard.d.ts +0 -2
  870. package/utils/keyboard.js +0 -12
  871. package/utils/keyboard.js.map +0 -1
  872. package/utils/lodash.amd.js +0 -2
  873. package/utils/lodash.amd.js.map +0 -1
  874. package/utils/lodash.d.ts +0 -2
  875. package/utils/lodash.js +0 -9
  876. package/utils/lodash.js.map +0 -1
  877. package/utils/number.amd.js +0 -2
  878. package/utils/number.amd.js.map +0 -1
  879. package/utils/number.d.ts +0 -2
  880. package/utils/number.js +0 -13
  881. package/utils/number.js.map +0 -1
  882. package/utils/price.amd.js +0 -2
  883. package/utils/price.amd.js.map +0 -1
  884. package/utils/price.d.ts +0 -2
  885. package/utils/price.js +0 -10
  886. package/utils/price.js.map +0 -1
  887. package/utils/route.amd.js +0 -2
  888. package/utils/route.amd.js.map +0 -1
  889. package/utils/route.d.ts +0 -2
  890. package/utils/route.js +0 -31
  891. package/utils/route.js.map +0 -1
  892. package/utils/scroll.amd.js +0 -2
  893. package/utils/scroll.amd.js.map +0 -1
  894. package/utils/scroll.d.ts +0 -2
  895. package/utils/scroll.js +0 -45
  896. package/utils/scroll.js.map +0 -1
  897. package/utils/searchers.amd.js +0 -2
  898. package/utils/searchers.amd.js.map +0 -1
  899. package/utils/searchers.d.ts +0 -2
  900. package/utils/searchers.js +0 -128
  901. package/utils/searchers.js.map +0 -1
  902. package/utils/store.amd.js +0 -2
  903. package/utils/store.amd.js.map +0 -1
  904. package/utils/store.d.ts +0 -2
  905. package/utils/store.js +0 -7
  906. package/utils/store.js.map +0 -1
  907. package/utils/string.amd.js +0 -2
  908. package/utils/string.amd.js.map +0 -1
  909. package/utils/string.d.ts +0 -2
  910. package/utils/string.js +0 -139
  911. package/utils/string.js.map +0 -1
  912. package/utils/system.amd.js +0 -2
  913. package/utils/system.amd.js.map +0 -1
  914. package/utils/system.d.ts +0 -2
  915. package/utils/system.js +0 -29
  916. package/utils/system.js.map +0 -1
  917. package/utils/url.amd.js +0 -3
  918. package/utils/url.amd.js.map +0 -1
  919. package/utils/url.d.ts +0 -2
  920. package/utils/url.js +0 -48
  921. package/utils/url.js.map +0 -1
@@ -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,51 @@
1
+ import type { Meta, StoryObj } from '@storybook/vue3';
2
+
3
+ import { genArgsTypes, genOverviewStory } from '@/components/helpersStories';
4
+ import Component from './radioGroup.vue';
5
+ import * as ComponentsConst from './radioGroup';
6
+ import OverviewComponent from './stories/overview.vue';
7
+
8
+ const argTypes = genArgsTypes(Component, ComponentsConst);
9
+
10
+ const meta = {
11
+ component: Component,
12
+ tags: ['autodocs'],
13
+ argTypes,
14
+ args: {
15
+ modelValue: '',
16
+ },
17
+ } satisfies Meta<typeof Component>;
18
+
19
+ type Story = StoryObj<typeof meta>;
20
+
21
+ export const Playground = {
22
+ args: {
23
+ radiosProps: [
24
+ {
25
+ value: '0',
26
+ title: 'ПК',
27
+ icon: '',
28
+ },
29
+ {
30
+ value: '1',
31
+ title: 'Планшет',
32
+ icon: '',
33
+ },
34
+ {
35
+ value: '2',
36
+ title: 'Смартфон',
37
+ icon: '',
38
+ },
39
+ ],
40
+ },
41
+ } satisfies Story;
42
+
43
+ export const Overview: Story = genOverviewStory({
44
+ args: {
45
+ size: 's',
46
+ showIndicator: false,
47
+ isError: false,
48
+ },
49
+ }, OverviewComponent);
50
+
51
+ export default meta;
@@ -0,0 +1,28 @@
1
+ import type { Size } from '@/components/forms/helpers';
2
+ import { sizes } from '@/components/forms/helpers';
3
+
4
+ export interface Props {
5
+ modelValue: string;
6
+
7
+ /**
8
+ * Массив props для вставки radioGroupItem
9
+ */
10
+ radiosProps?: ItemProps[];
11
+
12
+ showIndicator?: boolean;
13
+ size?: Size;
14
+ isError?: boolean;
15
+ }
16
+
17
+ export interface Emits {
18
+ (e: 'update:modelValue', value: Props['modelValue']): void;
19
+ }
20
+
21
+ export interface ItemProps {
22
+ value: Props['modelValue'];
23
+ title: string;
24
+ icon?: string;
25
+ disabled?: boolean;
26
+ }
27
+
28
+ export { sizes };
@@ -0,0 +1,146 @@
1
+ <script setup lang="ts">
2
+ import type { Ref } from '@vue/reactivity';
3
+ import { ref, watch } from 'vue';
4
+ import type { Props, Emits } from './radioGroup';
5
+
6
+ const model = defineModel<string>({
7
+ required: true,
8
+ });
9
+
10
+ const props = withDefaults(defineProps<Props>(), {
11
+ size: 's',
12
+ });
13
+
14
+ const emit = defineEmits<Emits>();
15
+
16
+ const elRef: Ref<HTMLElement | null> = ref(null);
17
+
18
+ watch(model, () => {
19
+ if (!props.radiosProps?.some(item => item.value === model.value)) {
20
+ model.value = props.radiosProps?.[0]?.value ?? '';
21
+ }
22
+
23
+ elRef.value?.querySelector('.radioGroup_item-selected')?.scrollIntoView();
24
+ }, { immediate: true });
25
+
26
+ const uid = 'radioGroup-' + Math.random();
27
+ </script>
28
+
29
+ <template>
30
+ <div
31
+ ref="elRef"
32
+ :class="{
33
+ ['top-radioGroup']: true,
34
+ ['top-scrollBarXHidding']: true,
35
+ ['top-size_' + size]: !!size,
36
+ ['top-error']: isError,
37
+ }"
38
+ >
39
+ <label
40
+ v-for="item of radiosProps"
41
+ :class="{
42
+ ['top-radioGroup_item-selected']: item.value === model,
43
+ ['top-radioGroup_item']: true,
44
+ ['top-forms-focusable']: true,
45
+ ['top-disabled']: item.disabled,
46
+ }"
47
+ :data-top-icon="item.icon"
48
+ @click="model = item.value"
49
+ >
50
+ {{ item.title }}
51
+
52
+ <span
53
+ v-if="showIndicator"
54
+ class="top-radioGroup_circle"
55
+ ></span>
56
+
57
+ <!-- Для нативной навигации -->
58
+ <input
59
+ v-model="model"
60
+ :name="uid"
61
+ type="radio"
62
+ :class="{
63
+ ['top-unvisible']: true,
64
+ }"
65
+ :value="item.value"
66
+ :disabled="item.disabled"
67
+ />
68
+ </label>
69
+ </div>
70
+ </template>
71
+
72
+ <style>
73
+ @import "./styles/top-scrollBar.css";
74
+
75
+ .top-radioGroup {
76
+ user-select: none;
77
+ box-sizing: border-box;
78
+ border-radius: 8px;
79
+ background-color: var(--color-layout-middle);
80
+ height: var(--top-forms-base-height);
81
+ padding: 2px;
82
+ gap: 2px;
83
+ display: flex;
84
+ align-items: flex-start;
85
+ }
86
+
87
+ .top-radioGroup_item {
88
+ color: var(--color-text-2);
89
+ cursor: pointer;
90
+ box-sizing: border-box;
91
+ border-radius: 6px;
92
+ height: calc(var(--top-forms-base-height) - 4px);
93
+ padding: 0 16px;
94
+ font-weight: 400;
95
+ white-space: nowrap;
96
+ display: flex;
97
+ align-items: center;
98
+ justify-content: center;
99
+ flex-grow: 1;
100
+ gap: 4px;
101
+ }
102
+
103
+ .top-radioGroup_item:hover {
104
+ background-color: var(--color-layout-front-1);
105
+ box-shadow: 0px 4px 32px 0px rgba(4, 9, 84, 0.10), 0px 0px 4px 0px rgba(4, 9, 84, 0.08);
106
+ }
107
+
108
+ /* selected */
109
+ .top-radioGroup_item-selected {
110
+ color: var(--color-text-1);
111
+ pointer-events: none;
112
+ background-color: var(--color-bg-lightning-1);
113
+ box-shadow: 0px 4px 32px 0px rgba(4, 9, 84, 0.10), 0px 0px 4px 0px rgba(4, 9, 84, 0.08);
114
+ }
115
+
116
+ /* circle */
117
+ .top-radioGroup_circle {
118
+ content: "";
119
+ box-sizing: border-box;
120
+ border: 1px solid var(--color-line-3-opacity);
121
+ border-radius: 50%;
122
+ padding: 3px;
123
+ margin-left: auto;
124
+ width: calc(var(--top-forms-option-height) - 3px * 2);
125
+ height: calc(var(--top-forms-option-height) - 3px * 2);
126
+ }
127
+
128
+ .top-radioGroup_item:hover .top-radioGroup_circle:before {
129
+ border-color: var(--color-line-primary-1);
130
+ }
131
+
132
+ /* circle selected */
133
+ .top-radioGroup_item-selected .top-radioGroup_circle {
134
+ border-color: var(--color-line-primary-1);
135
+ border-width: 5px;
136
+ }
137
+
138
+ .top-radioGroup_item-selected:hover .top-radioGroup_circle {
139
+ border-color: var(--color-line-primary-1);
140
+ }
141
+
142
+ /* top-error */
143
+ .top-radioGroup.top-error .top-radioGroup_item:not(.top-disabled) .top-radioGroup_circle {
144
+ border-color: var(--color-line-negative-1);
145
+ }
146
+ </style>
@@ -0,0 +1,78 @@
1
+ <script setup lang="ts">
2
+ import { ref } from 'vue';
3
+ import type { Props } from '../radioGroup';
4
+ import RadioGroup from '../radioGroup.vue';
5
+
6
+ defineProps<Props>();
7
+
8
+ const modelValue1 = ref('1');
9
+ const modelValue2 = ref('3');
10
+
11
+ const radiosProps1 = [
12
+ {
13
+ value: '0',
14
+ title: 'ПК',
15
+ },
16
+ {
17
+ value: '1',
18
+ title: 'Планшет',
19
+ },
20
+ {
21
+ value: '2',
22
+ title: 'Смартфон',
23
+ },
24
+ {
25
+ value: '3',
26
+ title: 'Книга',
27
+ disabled: true,
28
+ },
29
+ ];
30
+
31
+ const radiosProps2 = [
32
+ {
33
+ value: '0',
34
+ title: 'ПК',
35
+ icon: '',
36
+ },
37
+ {
38
+ value: '1',
39
+ title: 'Планшет',
40
+ icon: '',
41
+ },
42
+ {
43
+ value: '2',
44
+ title: 'Смартфон',
45
+ icon: '',
46
+ },
47
+ {
48
+ value: '3',
49
+ title: 'Книга',
50
+ icon: '',
51
+ disabled: true,
52
+ },
53
+ ];
54
+ </script>
55
+
56
+ <template>
57
+ <div>
58
+ <h2>Стандартный вид</h2>
59
+
60
+ <RadioGroup
61
+ :="$props"
62
+ v-model="modelValue1"
63
+ :radiosProps="radiosProps1"
64
+ />
65
+
66
+ <p><b>Ваш выбор:</b> {{ modelValue1 }}</p>
67
+
68
+ <h2>Со значками</h2>
69
+
70
+ <RadioGroup
71
+ :="$props"
72
+ v-model="modelValue2"
73
+ :radiosProps="radiosProps2"
74
+ />
75
+
76
+ <p><b>Ваш выбор:</b> {{ modelValue2 }}</p>
77
+ </div>
78
+ </template>