create-young-proj 1.0.0 → 1.1.0-alpha.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (337) hide show
  1. package/.editorconfig +14 -0
  2. package/.vscode/settings.json +39 -0
  3. package/CHANGELOG.md +256 -0
  4. package/README.md +7 -3
  5. package/build.config.ts +22 -0
  6. package/eslint.config.js +35 -0
  7. package/package.json +1 -7
  8. package/src/index.ts +366 -0
  9. package/template-admin-server/.editorconfig +11 -0
  10. package/template-admin-server/.nvmrc +1 -0
  11. package/template-admin-server/.vscode/extensions.json +6 -0
  12. package/template-admin-server/.vscode/settings.json +4 -0
  13. package/template-admin-server/_gitignore +15 -0
  14. package/template-admin-server/_nvmrc +1 -0
  15. package/template-admin-server/boot.mjs +11 -0
  16. package/template-admin-server/package.json +60 -0
  17. package/template-admin-server/rome.json +22 -0
  18. package/template-admin-server/src/config/config.default.ts +56 -0
  19. package/template-admin-server/src/configuration.ts +47 -0
  20. package/template-admin-server/src/controller/admin.controller.ts +397 -0
  21. package/template-admin-server/src/controller/api.controller.ts +98 -0
  22. package/template-admin-server/src/controller/base.controller.ts +70 -0
  23. package/template-admin-server/src/controller/dto/api.ts +47 -0
  24. package/template-admin-server/src/controller/dto/index.ts +36 -0
  25. package/template-admin-server/src/controller/dto/menu.ts +41 -0
  26. package/template-admin-server/src/controller/dto/role.ts +41 -0
  27. package/template-admin-server/src/controller/dto/user.ts +52 -0
  28. package/template-admin-server/src/controller/menu.controller.ts +138 -0
  29. package/template-admin-server/src/controller/role.controller.ts +116 -0
  30. package/template-admin-server/src/controller/user.controller.ts +108 -0
  31. package/template-admin-server/src/entities/Api.ts +29 -0
  32. package/template-admin-server/src/entities/BaseCreate.ts +30 -0
  33. package/template-admin-server/src/entities/Menu.ts +39 -0
  34. package/template-admin-server/src/entities/Role.ts +36 -0
  35. package/template-admin-server/src/entities/User.ts +35 -0
  36. package/template-admin-server/src/entities/index.ts +10 -0
  37. package/template-admin-server/src/filter/default.filter.ts +22 -0
  38. package/template-admin-server/src/filter/notfound.filter.ts +23 -0
  39. package/template-admin-server/src/middleware/helper.middleware.ts +28 -0
  40. package/template-admin-server/src/middleware/index.ts +9 -0
  41. package/template-admin-server/src/middleware/jwt.middleware.ts +32 -0
  42. package/template-admin-server/src/middleware/report.middleware.ts +26 -0
  43. package/template-admin-server/src/service/api.service.ts +174 -0
  44. package/template-admin-server/src/service/basic.ts +118 -0
  45. package/template-admin-server/src/service/index.ts +10 -0
  46. package/template-admin-server/src/service/menu.service.ts +139 -0
  47. package/template-admin-server/src/service/role.service.ts +286 -0
  48. package/template-admin-server/src/service/user.service.ts +124 -0
  49. package/template-admin-server/src/strategy/jwt.strategy.ts +26 -0
  50. package/template-admin-server/src/types/index.ts +42 -0
  51. package/template-admin-server/src/types/types.d.ts +31 -0
  52. package/template-admin-server/tsconfig.json +24 -0
  53. package/template-nuxt-admin/.vscode/extensions.json +12 -0
  54. package/template-nuxt-admin/.vscode/settings.json +39 -0
  55. package/template-nuxt-admin/Dockerfile +41 -0
  56. package/template-nuxt-admin/_gitignore +23 -0
  57. package/template-nuxt-admin/_npmrc +2 -0
  58. package/template-nuxt-admin/_nvmrc +1 -0
  59. package/template-nuxt-admin/app.vue +49 -0
  60. package/template-nuxt-admin/boot.mjs +16 -0
  61. package/template-nuxt-admin/components/ScreenFull.vue +19 -0
  62. package/template-nuxt-admin/components/TopSearch.vue +76 -0
  63. package/template-nuxt-admin/components/TopUser.vue +72 -0
  64. package/template-nuxt-admin/components/YoungChangePassword.vue +94 -0
  65. package/template-nuxt-admin/components/YoungCodeInput.vue +65 -0
  66. package/template-nuxt-admin/components/YoungEditor.vue +81 -0
  67. package/template-nuxt-admin/components/YoungLink.vue +24 -0
  68. package/template-nuxt-admin/components/YoungLoading.vue +39 -0
  69. package/template-nuxt-admin/components/ZenMode.vue +21 -0
  70. package/template-nuxt-admin/components/layout/Footer.vue +29 -0
  71. package/template-nuxt-admin/components/layout/Logo.vue +54 -0
  72. package/template-nuxt-admin/components/layout/Main.vue +26 -0
  73. package/template-nuxt-admin/components/layout/NavBar.vue +90 -0
  74. package/template-nuxt-admin/components/layout/SideBar.vue +96 -0
  75. package/template-nuxt-admin/components/layout/SubMenu.vue +52 -0
  76. package/template-nuxt-admin/components/layout/TabsBar.vue +184 -0
  77. package/template-nuxt-admin/composables/api.ts +97 -0
  78. package/template-nuxt-admin/composables/apis/delete.ts +37 -0
  79. package/template-nuxt-admin/composables/apis/get.ts +83 -0
  80. package/template-nuxt-admin/composables/apis/index.ts +10 -0
  81. package/template-nuxt-admin/composables/apis/patch.ts +74 -0
  82. package/template-nuxt-admin/composables/apis/post.ts +85 -0
  83. package/template-nuxt-admin/composables/config.ts +13 -0
  84. package/template-nuxt-admin/composables/icon.ts +25 -0
  85. package/template-nuxt-admin/composables/nav.ts +85 -0
  86. package/template-nuxt-admin/composables/tags.ts +136 -0
  87. package/template-nuxt-admin/composables/user.ts +48 -0
  88. package/template-nuxt-admin/config/.devrc +1 -0
  89. package/template-nuxt-admin/config/.onlinerc +1 -0
  90. package/template-nuxt-admin/config/.testrc +1 -0
  91. package/template-nuxt-admin/env.d.ts +47 -0
  92. package/template-nuxt-admin/error.vue +61 -0
  93. package/template-nuxt-admin/eslint.config.js +33 -0
  94. package/template-nuxt-admin/layouts/blank.vue +9 -0
  95. package/template-nuxt-admin/layouts/default.vue +163 -0
  96. package/template-nuxt-admin/middleware/auth.global.ts +66 -0
  97. package/template-nuxt-admin/nuxt.config.ts +106 -0
  98. package/template-nuxt-admin/package.json +63 -0
  99. package/template-nuxt-admin/pages/home/[id].vue +28 -0
  100. package/template-nuxt-admin/pages/index.vue +15 -0
  101. package/template-nuxt-admin/pages/login.vue +199 -0
  102. package/template-nuxt-admin/pages/system/api.vue +177 -0
  103. package/template-nuxt-admin/pages/system/hooks/useRole.ts +328 -0
  104. package/template-nuxt-admin/pages/system/menuList.vue +351 -0
  105. package/template-nuxt-admin/pages/system/role.vue +144 -0
  106. package/template-nuxt-admin/pages/system/user.vue +223 -0
  107. package/template-nuxt-admin/plugins/directive.ts +26 -0
  108. package/template-nuxt-admin/public/bg.webp +0 -0
  109. package/template-nuxt-admin/public/default_avatar.svg +1 -0
  110. package/template-nuxt-admin/public/favicon.svg +2 -0
  111. package/template-nuxt-admin/public/image_placeholder.svg +15 -0
  112. package/template-nuxt-admin/public/index.umd.js +74 -0
  113. package/template-nuxt-admin/public/index.umd.js.map +1 -0
  114. package/template-nuxt-admin/public/logo.svg +2 -0
  115. package/template-nuxt-admin/public/tabbar_bg.png +0 -0
  116. package/template-nuxt-admin/server/api/[...all].ts +10 -0
  117. package/template-nuxt-admin/server/plugins/env.ts +88 -0
  118. package/template-nuxt-admin/server/routes/get/env.ts +13 -0
  119. package/template-nuxt-admin/server/tsconfig.json +3 -0
  120. package/template-nuxt-admin/server/utils/index.ts +36 -0
  121. package/template-nuxt-admin/styles/element.scss +30 -0
  122. package/template-nuxt-admin/styles/index.scss +59 -0
  123. package/template-nuxt-admin/styles/variable.scss +103 -0
  124. package/template-nuxt-admin/tsconfig.json +7 -0
  125. package/template-nuxt-admin/typings/global.d.ts +16 -0
  126. package/template-nuxt-admin/typings/system.d.ts +67 -0
  127. package/template-nuxt-admin/typings/user.d.ts +19 -0
  128. package/template-nuxt-admin/uno.config.ts +40 -0
  129. package/template-nuxt-admin/utils/tool.ts +195 -0
  130. package/template-nuxt-admin/yarn.lock +8398 -0
  131. package/template-nuxt-website/.nvmrc +1 -0
  132. package/template-nuxt-website/.vscode/extensions.json +12 -0
  133. package/template-nuxt-website/.vscode/settings.json +39 -0
  134. package/template-nuxt-website/Dockerfile +41 -0
  135. package/template-nuxt-website/_gitignore +26 -0
  136. package/template-nuxt-website/_npmrc +2 -0
  137. package/template-nuxt-website/_nvmrc +1 -0
  138. package/template-nuxt-website/app.vue +66 -0
  139. package/template-nuxt-website/assets/tabbar/event.png +0 -0
  140. package/template-nuxt-website/assets/tabbar/event_active.png +0 -0
  141. package/template-nuxt-website/assets/tabbar/game.png +0 -0
  142. package/template-nuxt-website/assets/tabbar/game_active.png +0 -0
  143. package/template-nuxt-website/assets/tabbar/shop.png +0 -0
  144. package/template-nuxt-website/assets/tabbar/shop_active.png +0 -0
  145. package/template-nuxt-website/assets/tabbar/user.png +0 -0
  146. package/template-nuxt-website/assets/tabbar/user_active.png +0 -0
  147. package/template-nuxt-website/boot.mjs +16 -0
  148. package/template-nuxt-website/components/AboutNav.vue +27 -0
  149. package/template-nuxt-website/components/BreadNav.vue +35 -0
  150. package/template-nuxt-website/components/Follow.vue +48 -0
  151. package/template-nuxt-website/components/FriendLink.vue +36 -0
  152. package/template-nuxt-website/components/mobile/NavBar.vue +50 -0
  153. package/template-nuxt-website/components/top/Extra.vue +50 -0
  154. package/template-nuxt-website/components/top/Nav.vue +87 -0
  155. package/template-nuxt-website/components/young/Banner.vue +100 -0
  156. package/template-nuxt-website/components/young/Footer.vue +44 -0
  157. package/template-nuxt-website/components/young/Header.vue +25 -0
  158. package/template-nuxt-website/components/young/Tabbar.vue +76 -0
  159. package/template-nuxt-website/composables/ad.ts +20 -0
  160. package/template-nuxt-website/composables/config.ts +11 -0
  161. package/template-nuxt-website/composables/nav.ts +30 -0
  162. package/template-nuxt-website/composables/share.ts +22 -0
  163. package/template-nuxt-website/composables/utils.ts +84 -0
  164. package/template-nuxt-website/config/.devrc +11 -0
  165. package/template-nuxt-website/config/.onlinerc +13 -0
  166. package/template-nuxt-website/config/.testrc +11 -0
  167. package/template-nuxt-website/env.d.ts +55 -0
  168. package/template-nuxt-website/error.vue +69 -0
  169. package/template-nuxt-website/eslint.config.js +34 -0
  170. package/template-nuxt-website/layouts/default.vue +80 -0
  171. package/template-nuxt-website/layouts/home.vue +75 -0
  172. package/template-nuxt-website/layouts/tabbar.vue +78 -0
  173. package/template-nuxt-website/nuxt.config.ts +98 -0
  174. package/template-nuxt-website/package.json +41 -0
  175. package/template-nuxt-website/pages/index.html.vue +16 -0
  176. package/template-nuxt-website/pages/index.vue +29 -0
  177. package/template-nuxt-website/pages/match.html.vue +23 -0
  178. package/template-nuxt-website/pages/news/[id].html.vue +57 -0
  179. package/template-nuxt-website/pages/news.html.vue +26 -0
  180. package/template-nuxt-website/pages/shop.html.vue +26 -0
  181. package/template-nuxt-website/public/favicon.ico +0 -0
  182. package/template-nuxt-website/public/robots.txt +2 -0
  183. package/template-nuxt-website/public/svg/image_placeholder.svg +15 -0
  184. package/template-nuxt-website/server/api/get_footer_info.get.ts +52 -0
  185. package/template-nuxt-website/server/api/get_gray_status.get.ts +38 -0
  186. package/template-nuxt-website/server/api/get_head_nav.get.ts +38 -0
  187. package/template-nuxt-website/server/api/get_home_banner.get.ts +28 -0
  188. package/template-nuxt-website/server/api/get_seo_info.get.ts +32 -0
  189. package/template-nuxt-website/server/middleware/platform.ts +11 -0
  190. package/template-nuxt-website/server/plugins/init.ts +147 -0
  191. package/template-nuxt-website/server/tsconfig.json +3 -0
  192. package/template-nuxt-website/server/utils/index.ts +12 -0
  193. package/template-nuxt-website/server/utils/proxy.ts +59 -0
  194. package/template-nuxt-website/tsconfig.json +4 -0
  195. package/template-nuxt-website/typings/banner.d.ts +30 -0
  196. package/template-nuxt-website/typings/nav.d.ts +34 -0
  197. package/template-nuxt-website/typings/system.d.ts +22 -0
  198. package/template-nuxt-website/uno.config.ts +40 -0
  199. package/template-nuxt-website/utils/tool.ts +171 -0
  200. package/template-nuxt-website/yarn.lock +8018 -0
  201. package/template-uni-app/.eslintignore +1 -0
  202. package/template-uni-app/.eslintrc +16 -0
  203. package/template-uni-app/.vscode/css.code-snippets +398 -0
  204. package/template-uni-app/.vscode/extensions.json +12 -0
  205. package/template-uni-app/.vscode/js.code-snippets +1669 -0
  206. package/template-uni-app/.vscode/settings.json +39 -0
  207. package/template-uni-app/.vscode/vue-html.code-snippets +682 -0
  208. package/template-uni-app/_env +3 -0
  209. package/template-uni-app/_env.development +11 -0
  210. package/template-uni-app/_env.production +8 -0
  211. package/template-uni-app/_env.test +11 -0
  212. package/template-uni-app/_gitignore +3 -0
  213. package/template-uni-app/_npmrc +2 -0
  214. package/template-uni-app/_nvmrc +1 -0
  215. package/template-uni-app/auto-imports.d.ts +413 -0
  216. package/template-uni-app/components.d.ts +17 -0
  217. package/template-uni-app/custom-plugins/index.ts +7 -0
  218. package/template-uni-app/custom-plugins/multiconf.ts +74 -0
  219. package/template-uni-app/eslint.config.js +35 -0
  220. package/template-uni-app/index.html +23 -0
  221. package/template-uni-app/manifest.config.ts +88 -0
  222. package/template-uni-app/package.json +109 -0
  223. package/template-uni-app/pages.config.ts +58 -0
  224. package/template-uni-app/pnpm-lock.yaml +10981 -0
  225. package/template-uni-app/src/App.vue +79 -0
  226. package/template-uni-app/src/apis/index.ts +54 -0
  227. package/template-uni-app/src/apis/requests/get.ts +52 -0
  228. package/template-uni-app/src/apis/requests/index.ts +8 -0
  229. package/template-uni-app/src/apis/requests/post.ts +23 -0
  230. package/template-uni-app/src/components/young-loading/young-loading.vue +36 -0
  231. package/template-uni-app/src/components/young-loading-mini/young-loading-mini.vue +35 -0
  232. package/template-uni-app/src/components/young-navbar/young-navbar.vue +252 -0
  233. package/template-uni-app/src/components/young-tabbar/young-tabbar.vue +145 -0
  234. package/template-uni-app/src/config/enum.ts +47 -0
  235. package/template-uni-app/src/config/index.ts +8 -0
  236. package/template-uni-app/src/config/map.ts +15 -0
  237. package/template-uni-app/src/env.d.ts +36 -0
  238. package/template-uni-app/src/layouts/default.vue +22 -0
  239. package/template-uni-app/src/layouts/tabbar.vue +38 -0
  240. package/template-uni-app/src/main.ts +20 -0
  241. package/template-uni-app/src/manifest.json +75 -0
  242. package/template-uni-app/src/pages/demo/index.vue +30 -0
  243. package/template-uni-app/src/pages/index.vue +65 -0
  244. package/template-uni-app/src/pages/my.vue +30 -0
  245. package/template-uni-app/src/pages.json +74 -0
  246. package/template-uni-app/src/static/back.png +0 -0
  247. package/template-uni-app/src/static/h.png +0 -0
  248. package/template-uni-app/src/static/home.png +0 -0
  249. package/template-uni-app/src/static/home_active.png +0 -0
  250. package/template-uni-app/src/static/more.png +0 -0
  251. package/template-uni-app/src/static/my.png +0 -0
  252. package/template-uni-app/src/static/my_active.png +0 -0
  253. package/template-uni-app/src/static/network.png +0 -0
  254. package/template-uni-app/src/store/index.ts +16 -0
  255. package/template-uni-app/src/store/local/index.ts +42 -0
  256. package/template-uni-app/src/store/system.ts +21 -0
  257. package/template-uni-app/src/typings/global.d.ts +7 -0
  258. package/template-uni-app/src/uni.scss +76 -0
  259. package/template-uni-app/src/utils/auth.ts +204 -0
  260. package/template-uni-app/src/utils/index.ts +11 -0
  261. package/template-uni-app/src/utils/map.ts +98 -0
  262. package/template-uni-app/src/utils/modal.ts +120 -0
  263. package/template-uni-app/src/utils/route.ts +151 -0
  264. package/template-uni-app/src/utils/system.ts +67 -0
  265. package/template-uni-app/tsconfig.json +16 -0
  266. package/template-uni-app/unocss.config.ts +30 -0
  267. package/template-uni-app/vite.config.ts +63 -0
  268. package/template-uni-app/volar.config.js +6 -0
  269. package/template-vue-mobile/.vscode/base.code-snippets +24 -0
  270. package/template-vue-mobile/.vscode/extensions.json +10 -0
  271. package/template-vue-mobile/.vscode/settings.json +7 -0
  272. package/template-vue-mobile/Dockerfile +42 -0
  273. package/template-vue-mobile/_env +6 -0
  274. package/template-vue-mobile/_gitignore +30 -0
  275. package/template-vue-mobile/boot.mjs +16 -0
  276. package/template-vue-mobile/build/custom-plugin.ts +30 -0
  277. package/template-vue-mobile/build/index.ts +7 -0
  278. package/template-vue-mobile/build/plugins.ts +68 -0
  279. package/template-vue-mobile/config/.devrc +2 -0
  280. package/template-vue-mobile/config/.onlinerc +1 -0
  281. package/template-vue-mobile/config/.testrc +1 -0
  282. package/template-vue-mobile/index.html +25 -0
  283. package/template-vue-mobile/nitro.config.ts +19 -0
  284. package/template-vue-mobile/package.json +48 -0
  285. package/template-vue-mobile/plugins/env.ts +26 -0
  286. package/template-vue-mobile/public/vite.svg +1 -0
  287. package/template-vue-mobile/rome.json +24 -0
  288. package/template-vue-mobile/routes/[...all].ts +11 -0
  289. package/template-vue-mobile/routes/get/env.ts +25 -0
  290. package/template-vue-mobile/src/App.vue +29 -0
  291. package/template-vue-mobile/src/auto-components.d.ts +24 -0
  292. package/template-vue-mobile/src/auto-imports.d.ts +289 -0
  293. package/template-vue-mobile/src/components/Init.vue +36 -0
  294. package/template-vue-mobile/src/global.d.ts +7 -0
  295. package/template-vue-mobile/src/hooks/useVerifyCode.ts +46 -0
  296. package/template-vue-mobile/src/layouts/blank.vue +9 -0
  297. package/template-vue-mobile/src/layouts/default.vue +27 -0
  298. package/template-vue-mobile/src/layouts/sub.vue +20 -0
  299. package/template-vue-mobile/src/main.ts +35 -0
  300. package/template-vue-mobile/src/modules/1-router.ts +40 -0
  301. package/template-vue-mobile/src/modules/2-pinia.ts +10 -0
  302. package/template-vue-mobile/src/modules/3-net.ts +46 -0
  303. package/template-vue-mobile/src/modules/4-auth.ts +64 -0
  304. package/template-vue-mobile/src/views/[...all_404].vue +557 -0
  305. package/template-vue-mobile/src/views/base/login.vue +110 -0
  306. package/template-vue-mobile/src/views/base/resetPasswd.vue +88 -0
  307. package/template-vue-mobile/src/views/index.vue +18 -0
  308. package/template-vue-mobile/src/views/my.vue +15 -0
  309. package/template-vue-mobile/src/views/sub.vue +18 -0
  310. package/template-vue-mobile/src/vite-env.d.ts +43 -0
  311. package/template-vue-mobile/tsconfig.json +21 -0
  312. package/template-vue-mobile/tsconfig.node.json +9 -0
  313. package/template-vue-mobile/unocss.config.ts +47 -0
  314. package/template-vue-mobile/vite.config.ts +32 -0
  315. package/template-vue-mobile/yarn.lock +4395 -0
  316. package/template-vue-thin/.vscode/extensions.json +10 -0
  317. package/template-vue-thin/.vscode/settings.json +4 -0
  318. package/template-vue-thin/_env +1 -0
  319. package/template-vue-thin/_gitignore +29 -0
  320. package/template-vue-thin/index.html +21 -0
  321. package/template-vue-thin/package.json +40 -0
  322. package/template-vue-thin/public/vite.svg +1 -0
  323. package/template-vue-thin/src/App.vue +9 -0
  324. package/template-vue-thin/src/layouts/blank.vue +9 -0
  325. package/template-vue-thin/src/layouts/default.vue +12 -0
  326. package/template-vue-thin/src/layouts/list.vue +12 -0
  327. package/template-vue-thin/src/main.ts +58 -0
  328. package/template-vue-thin/src/views/[...all_404].vue +488 -0
  329. package/template-vue-thin/src/views/index.vue +19 -0
  330. package/template-vue-thin/src/views/list.vue +17 -0
  331. package/template-vue-thin/src/vite-env.d.ts +22 -0
  332. package/template-vue-thin/tsconfig.json +21 -0
  333. package/template-vue-thin/tsconfig.node.json +9 -0
  334. package/template-vue-thin/unocss.config.ts +47 -0
  335. package/template-vue-thin/vite.config.ts +64 -0
  336. package/tsconfig.json +11 -0
  337. package/dist/index.mjs +0 -51
@@ -0,0 +1,177 @@
1
+ <!--
2
+ * @Author: zhangyang
3
+ * @Date: 2023-07-25 16:44:56
4
+ * @LastEditTime: 2023-11-07 14:42:48
5
+ * @Description:
6
+ -->
7
+ <script lang="ts" setup>
8
+ import { deepClone } from '@bluesyoung/utils'
9
+ import { ElButton, ElTag } from 'element-plus'
10
+
11
+ definePageMeta({
12
+ title: '接口管理',
13
+ })
14
+
15
+ interface Form extends ApiItem { op?: any };
16
+ const FORM_TEMP: Form = {
17
+ id: 0,
18
+ path: '',
19
+ desc: '',
20
+ method: 'POST',
21
+ category: '',
22
+ roleIds: [],
23
+ }
24
+ const {
25
+ isAdd,
26
+ isEdit,
27
+ edit,
28
+ del,
29
+ sure,
30
+ clear,
31
+ form,
32
+ formRef,
33
+ validForm,
34
+ } = useFormMode<Form>(FORM_TEMP, {
35
+ addCbk: async () => {
36
+ const res = await validForm() as boolean
37
+ if (res) {
38
+ const v = deepClone(form.value)
39
+ await apis.post.addApiItem(v)
40
+ ElMessage.success('新增成功!')
41
+ }
42
+ return res
43
+ },
44
+ modCbk: async () => {
45
+ const res = await validForm() as boolean
46
+ if (res) {
47
+ const v = deepClone(form.value)
48
+ await apis.patch.changeApiItem(v)
49
+ ElMessage.success('修改成功!')
50
+ }
51
+ return res
52
+ },
53
+ delCbk: async (row) => {
54
+ await apis.delete.deleteApi(row.id.toString())
55
+ ElMessage.success('删除成功!')
56
+ query.value.pageNum = 1
57
+ },
58
+ cgEffect: () => getList(),
59
+ })
60
+ const tableHead: TableHeadItem<Form>[] = [
61
+ { prop: 'id', label: '接口ID' },
62
+ { prop: 'desc', label: '接口描述' },
63
+ { prop: 'category', label: '接口分组' },
64
+ { prop: 'path', label: '接口路径' },
65
+ { prop: 'creator', label: '创建信息' },
66
+ {
67
+ prop: 'method',
68
+ label: '接口方法',
69
+ render: row => h(ElTag, {
70
+ effect: 'dark',
71
+ type: MethodObj[row.method],
72
+ },
73
+ {
74
+ default: () => row.method,
75
+ },
76
+ ),
77
+ },
78
+ {
79
+ prop: 'op',
80
+ label: '操作',
81
+ render: row => h('div', [
82
+ h(ElButton, { type: 'primary', link: true, onClick: () => edit(row) }, { default: () => '编辑' }),
83
+ h(ElButton, { type: 'danger', link: true, onClick: () => del(row) }, { default: () => '删除' }),
84
+ ]),
85
+ },
86
+ ]
87
+ const tableData = ref<TableDataItem<Form>[]>([])
88
+
89
+ async function getList() {
90
+ const { list: role_list } = await apis.get.getRoleList({ noPagination: true })
91
+ roleList.value = (role_list || []).map((item: RoleItem) => {
92
+ return {
93
+ label: item.name,
94
+ value: item.id,
95
+ }
96
+ })
97
+
98
+ const { list, pageNum, pageSize, total } = await apis.get.getApiList(query.value)
99
+ tableData.value = deepClone(list || [])
100
+ query.value.pageNum = +pageNum || 1
101
+ query.value.pageSize = +pageSize || 50
102
+ query.value.total = +total || 0
103
+ }
104
+
105
+ type Query = BaseQuery & Partial<Form>
106
+ const { query, reset } = useQuery<Query>(
107
+ {
108
+ pageNum: 1,
109
+ pageSize: 10,
110
+ total: 0,
111
+ path: '',
112
+ },
113
+ getList,
114
+ )
115
+ const queryScheme: YoungSearchScheme<Query> = {
116
+ path: {
117
+ type: 'input',
118
+ tip: '接口路径',
119
+ attrs: {
120
+ placeholder: '请输入接口路径',
121
+ },
122
+ },
123
+ }
124
+
125
+ const roleList = ref<SelectOptionItem<number>[]>([])
126
+
127
+ useTabReOpen(getList)
128
+ </script>
129
+
130
+ <template>
131
+ <ElCard>
132
+ <YoungSearchForm v-model="query" :search-scheme="queryScheme" :on-search="getList" :on-reset="reset">
133
+ <template #btns>
134
+ <ElButton type="success" @click="isAdd = true">
135
+ 添加接口
136
+ </ElButton>
137
+ </template>
138
+ </YoungSearchForm>
139
+ </ElCard>
140
+
141
+ <br>
142
+
143
+ <ElCard>
144
+ <YoungTablePro :table-data="tableData" :table-head="tableHead" />
145
+ <YoungPagination
146
+ v-model:page="query.pageNum" v-model:limit="query.pageSize" :total="query.total"
147
+ @page-change="getList"
148
+ />
149
+ </ElCard>
150
+ <YoungDialog :is-add="isAdd" :is-edit="isEdit" :diff-form="form" width="520px" @sure="sure" @clear="clear">
151
+ <template #body>
152
+ <ElForm ref="formRef" :model="form" label-width="100px" :label-position="WindowSize['lt-lg'] ? 'top' : 'left'">
153
+ <ElFormItem label="分组名称" prop="category" :rules="{ required: true, message: '请填写分组名称', trigger: 'blur' }">
154
+ <ElInput v-model.trim="form.category" class="!w-300px" />
155
+ </ElFormItem>
156
+ <ElFormItem label="接口描述" prop="desc" :rules="{ required: true, message: '请填写接口描述', trigger: 'blur' }">
157
+ <ElInput v-model.trim="form.desc" class="!w-300px" />
158
+ </ElFormItem>
159
+ <ElFormItem label="请求方法">
160
+ <YoungSelect
161
+ v-model="form.method" class="!w-300px"
162
+ :options="Object.keys(MethodObj).map((item) => ({ label: item, value: item }))"
163
+ />
164
+ </ElFormItem>
165
+ <ElFormItem
166
+ label="接口路径" prop="path"
167
+ :rules="{ message: '请填写合法的接口路径, eg: /user/list', trigger: 'blur', validator: (_: any, v: string) => /\/(.*)\/(.*)/.test(v) }"
168
+ >
169
+ <ElInput v-model.trim="form.path" class="!w-300px" />
170
+ </ElFormItem>
171
+ <ElFormItem label="关联角色">
172
+ <YoungSelect v-model="form.roleIds" multiple placeholder="请选择角色" class="!w-300px" :options="roleList" />
173
+ </ElFormItem>
174
+ </ElForm>
175
+ </template>
176
+ </YoungDialog>
177
+ </template>
@@ -0,0 +1,328 @@
1
+ /*
2
+ * @Author: zhangyang
3
+ * @Date: 2023-07-26 15:51:14
4
+ * @LastEditTime: 2023-11-07 14:43:01
5
+ * @Description:
6
+ */
7
+ import { deepClone } from '@bluesyoung/utils'
8
+
9
+ export function useRoleBase() {
10
+ const FORM_TEMP: RoleItem = {
11
+ id: 0,
12
+ name: '',
13
+ keyword: '',
14
+ desc: '',
15
+ status: 1,
16
+ sort: 0,
17
+ }
18
+
19
+ const { isAdd, isEdit, edit, del, sure, clear, form, formRef, validForm } = useFormMode(
20
+ FORM_TEMP,
21
+ {
22
+ addCbk: async () => {
23
+ const res = (await validForm()) as boolean
24
+ if (res) {
25
+ const v = deepClone(form.value)
26
+ await apis.post.addRoleItem(v)
27
+ ElMessage.success('新增成功!')
28
+ }
29
+ return res
30
+ },
31
+ modCbk: async () => {
32
+ const res = (await validForm()) as boolean
33
+ if (res) {
34
+ const v = deepClone(form.value)
35
+ await apis.patch.changeRoleItem(v)
36
+ ElMessage.success('修改成功!')
37
+ }
38
+ return res
39
+ },
40
+ delCbk: async (row) => {
41
+ await apis.delete.deleteRole(row.id.toString())
42
+ ElMessage.success('删除成功!')
43
+ query.value.pageNum = 1
44
+ },
45
+ cgEffect: () => getList(),
46
+ },
47
+ )
48
+
49
+ const options: SelectOptionItem[] = [
50
+ { label: '禁用', value: 0 },
51
+ { label: '启用', value: 1 },
52
+ ]
53
+
54
+ const tableHead: TableHeadItem<RoleItem>[] = [
55
+ { label: '角色ID', prop: 'id' },
56
+ { label: '角色关键字', prop: 'keyword' },
57
+ { label: '角色名称', prop: 'name' },
58
+ { label: '角色描述', prop: 'desc' },
59
+ { label: '创建信息', prop: 'creator' },
60
+ {
61
+ label: '启用状态',
62
+ prop: 'status',
63
+ render: row =>
64
+ h(YoungSelect, {
65
+ 'modelValue': row.status,
66
+ options,
67
+ 'onUpdate:modelValue': async (status) => {
68
+ // 状态未修改
69
+ if (status === row.status)
70
+ return
71
+
72
+ row.status = status as 0 | 1
73
+ await apis.patch.changeRoleItem(row)
74
+ ElMessage.success('修改成功!')
75
+ },
76
+ }),
77
+ },
78
+ ]
79
+ const tableData = ref<TableDataItem<RoleItem>[]>([])
80
+ const getList = async () => {
81
+ const { list, pageNum, pageSize, total } = await apis.get.getRoleList(query.value)
82
+ tableData.value = deepClone(list || [])
83
+ query.value.pageNum = +pageNum || 1
84
+ query.value.pageSize = +pageSize || 50
85
+ query.value.total = +total || 0
86
+ }
87
+
88
+ interface Query extends BaseQuery {
89
+ name: string
90
+ keyword: string
91
+ status: 0 | 1
92
+ }
93
+
94
+ const { query, reset } = useQuery<Query>(
95
+ {
96
+ pageNum: 1,
97
+ pageSize: 10,
98
+ total: 0,
99
+ name: '',
100
+ keyword: '',
101
+ status: 1,
102
+ },
103
+ getList,
104
+ )
105
+
106
+ const queryScheme: YoungSearchScheme<Query> = {
107
+ name: {
108
+ type: 'input',
109
+ tip: '角色名称',
110
+ attrs: {
111
+ placeholder: '请输入角色名称(中文)',
112
+ },
113
+ },
114
+ keyword: {
115
+ type: 'input',
116
+ tip: '角色关键字',
117
+ attrs: {
118
+ placeholder: '请输入角色关键字(英文)',
119
+ },
120
+ },
121
+ status: {
122
+ type: 'select',
123
+ tip: '状态',
124
+ attrs: {
125
+ placeholder: '角色状态',
126
+ },
127
+ options,
128
+ },
129
+ }
130
+
131
+ return {
132
+ query,
133
+ queryScheme,
134
+ getList,
135
+ reset,
136
+ tableHead,
137
+ tableData,
138
+ baseFormRef: formRef,
139
+ base: reactive({
140
+ form,
141
+ isAdd,
142
+ isEdit,
143
+ edit,
144
+ del,
145
+ sure,
146
+ clear,
147
+ }),
148
+ }
149
+ }
150
+
151
+ export function useRoleMenu() {
152
+ const showPriority = ref(false)
153
+ const currRole = ref(0)
154
+ const access = ref<number[]>([])
155
+ const origin = ref<number[]>([])
156
+
157
+ const tableHead = ref<TableHeadItem<NavArrItem>[]>([
158
+ { label: '菜单名称', prop: 'title' },
159
+ { label: '菜单id', prop: 'id' },
160
+ { label: '父节点', prop: 'parentId' },
161
+ { label: '页面路径', prop: 'component' },
162
+ ])
163
+ const tableData = ref<TableDataItem<NavArrItem>[]>([])
164
+
165
+ const checkMap = ref<Record<number, boolean>>({})
166
+
167
+ /**
168
+ * 生成节点映射
169
+ */
170
+ const nodeMap = new Map<number, NavArrItem>()
171
+ const generateNodeMap = (list: NavArrItem[]) => {
172
+ for (const node of list) {
173
+ nodeMap.set(node.id, node)
174
+ if (node.children && node.children?.length > 0)
175
+ generateNodeMap(node.children)
176
+ }
177
+ }
178
+
179
+ /**
180
+ * 多级联动选择
181
+ */
182
+ const selectChange = (item: NavArrItem) => {
183
+ if (item.children && item.children?.length !== 0) {
184
+ item.children.forEach((v) => {
185
+ checkMap.value[v.id] = checkMap.value[item.id]
186
+ selectChange(v)
187
+ })
188
+ }
189
+ if (checkMap.value[item.id]) {
190
+ while (item.parentId) {
191
+ const tp = nodeMap.get(item.parentId)
192
+ if (tp) {
193
+ item = tp
194
+ checkMap.value[item.id] = true
195
+ }
196
+ else {
197
+ break
198
+ }
199
+ }
200
+ }
201
+ }
202
+
203
+ const edit = async (row: TableDataItem<RoleItem>) => {
204
+ currRole.value = row.id
205
+ checkMap.value = {}
206
+ nodeMap.clear()
207
+
208
+ const { list, accessIds } = await apis.get.getRoleMenuTree(row.id)
209
+ generateNodeMap(list);
210
+ (Array.from(accessIds) as number[]).forEach((v) => {
211
+ checkMap.value[v] = true
212
+ })
213
+
214
+ tableData.value = deepClone(list)
215
+ access.value = accessIds
216
+ origin.value = accessIds
217
+ showPriority.value = true
218
+ }
219
+ const clear = () => {
220
+ showPriority.value = false
221
+ currRole.value = 0
222
+ tableData.value.length = 0
223
+ }
224
+
225
+ const sure = async () => {
226
+ const before = origin.value.slice()
227
+ const now = Object.entries(checkMap.value)
228
+ .filter(([k, v]) => v)
229
+ .map(([k, v]) => +k)
230
+
231
+ const add = now.filter(v => !before.includes(v))
232
+ const del = before.filter(v => !now.includes(v))
233
+ await apis.patch.changeRoleMenu(currRole.value, add, del)
234
+ ElMessage.success('修改成功!')
235
+ clear()
236
+ }
237
+
238
+ return {
239
+ showPriority,
240
+ menu: reactive({
241
+ checkMap,
242
+ tableHead,
243
+ tableData,
244
+ edit,
245
+ clear,
246
+ sure,
247
+ selectChange,
248
+ }),
249
+ }
250
+ }
251
+
252
+ export function useRoleApi() {
253
+ const showApi = ref(false)
254
+ const currRole = ref(0)
255
+ const access = ref<number[]>([])
256
+ const origin = ref<number[]>([])
257
+
258
+ const tableHead = ref<TableHeadItem<ApiItem>[]>([
259
+ { prop: 'desc', label: '接口描述' },
260
+ { prop: 'id', label: '接口ID' },
261
+ { prop: 'method', label: '接口方法' },
262
+ { prop: 'path', label: '请求地址' },
263
+ ])
264
+ const tableData = ref<TableDataItem<ApiItem>[]>([])
265
+
266
+ const checkMap = ref<Record<number, boolean>>({})
267
+
268
+ const edit = async (row: TableDataItem<RoleItem>) => {
269
+ currRole.value = row.id
270
+ checkMap.value = {}
271
+
272
+ const { list, accessIds } = await apis.get.getRoleApis(row.id);
273
+ (Array.from(accessIds) as number[]).forEach((v) => {
274
+ checkMap.value[v] = true
275
+ })
276
+
277
+ tableData.value = deepClone(
278
+ Array.from(list)
279
+ .map((item: any) => item.children)
280
+ .flat(),
281
+ )
282
+
283
+ access.value = accessIds
284
+ origin.value = accessIds
285
+ showApi.value = true
286
+
287
+ isAll.value = tableData.value.length === access.value.length
288
+ }
289
+ const clear = () => {
290
+ showApi.value = false
291
+ currRole.value = 0
292
+ tableData.value.length = 0
293
+ }
294
+
295
+ const sure = async () => {
296
+ const before = origin.value.slice()
297
+ const now = Object.entries(checkMap.value)
298
+ .filter(([k, v]) => v)
299
+ .map(([k, v]) => +k)
300
+
301
+ const add = now.filter(v => !before.includes(v))
302
+ const del = before.filter(v => !now.includes(v))
303
+ await apis.patch.changeRoleApi(currRole.value, add, del)
304
+ ElMessage.success('修改成功!')
305
+ clear()
306
+ }
307
+
308
+ const isAll = ref(false)
309
+ const changeAll = () => {
310
+ tableData.value.forEach((i) => {
311
+ checkMap.value[i.id] = isAll.value
312
+ })
313
+ }
314
+
315
+ return {
316
+ showApi,
317
+ api: reactive({
318
+ checkMap,
319
+ tableHead,
320
+ tableData,
321
+ edit,
322
+ clear,
323
+ sure,
324
+ isAll,
325
+ changeAll,
326
+ }),
327
+ }
328
+ }