@gx-design-vue/create-gx-cli 0.0.5 → 0.0.6

Sign up to get free protection for your applications and to get access to all the features.
Files changed (257) hide show
  1. package/package.json +1 -1
  2. package/src/cli.js +1 -1
  3. package/src/main.js +4 -0
  4. package/template-design-pro/.editorconfig +0 -19
  5. package/template-design-pro/.env +0 -2
  6. package/template-design-pro/.env.development +0 -18
  7. package/template-design-pro/.env.pro +0 -32
  8. package/template-design-pro/.env.production +0 -32
  9. package/template-design-pro/.env.test +0 -20
  10. package/template-design-pro/.eslintignore +0 -16
  11. package/template-design-pro/.eslintrc.js +0 -64
  12. package/template-design-pro/.gitpod.yml +0 -6
  13. package/template-design-pro/.husky/pre-commit +0 -4
  14. package/template-design-pro/.prettierignore +0 -9
  15. package/template-design-pro/.stylelintignore +0 -3
  16. package/template-design-pro/.yarnclean +0 -48
  17. package/template-design-pro/LICENSE +0 -21
  18. package/template-design-pro/README.md +0 -111
  19. package/template-design-pro/build/constant.ts +0 -6
  20. package/template-design-pro/build/generate/generateModifyVars.ts +0 -18
  21. package/template-design-pro/build/getConfigFileName.ts +0 -13
  22. package/template-design-pro/build/script/buildConf.ts +0 -44
  23. package/template-design-pro/build/script/postBuild.ts +0 -25
  24. package/template-design-pro/build/script/reSetRootHtml.ts +0 -20
  25. package/template-design-pro/build/utils.ts +0 -85
  26. package/template-design-pro/build/vite/cdn.ts +0 -7
  27. package/template-design-pro/build/vite/optimizer.ts +0 -22
  28. package/template-design-pro/build/vite/plugin/autoImport.ts +0 -18
  29. package/template-design-pro/build/vite/plugin/compress.ts +0 -35
  30. package/template-design-pro/build/vite/plugin/hmr.ts +0 -25
  31. package/template-design-pro/build/vite/plugin/html.ts +0 -47
  32. package/template-design-pro/build/vite/plugin/index.ts +0 -89
  33. package/template-design-pro/build/vite/plugin/mock.ts +0 -20
  34. package/template-design-pro/build/vite/plugin/pwa.ts +0 -37
  35. package/template-design-pro/build/vite/plugin/styleImport.ts +0 -129
  36. package/template-design-pro/build/vite/plugin/visualizer.ts +0 -17
  37. package/template-design-pro/build/vite/plugin/vite-plugin-antd-theme/index.ts +0 -24
  38. package/template-design-pro/build/vite/plugin/vite-plugin-mock/createMockServer.ts +0 -303
  39. package/template-design-pro/build/vite/plugin/vite-plugin-mock/createProdMockServer.ts +0 -93
  40. package/template-design-pro/build/vite/plugin/vite-plugin-mock/index.ts +0 -68
  41. package/template-design-pro/build/vite/plugin/vite-plugin-mock/types.ts +0 -30
  42. package/template-design-pro/build/vite/plugin/vite-plugin-mock/utils.ts +0 -26
  43. package/template-design-pro/commitlint.config.js +0 -32
  44. package/template-design-pro/config/config.ts +0 -14
  45. package/template-design-pro/config/default/animate.ts +0 -30
  46. package/template-design-pro/config/default/defaultSettings.ts +0 -75
  47. package/template-design-pro/config/default/network.ts +0 -16
  48. package/template-design-pro/config/default/proxy.ts +0 -26
  49. package/template-design-pro/config/default/theme.ts +0 -43
  50. package/template-design-pro/config/default/themeColor.ts +0 -62
  51. package/template-design-pro/index.html +0 -45
  52. package/template-design-pro/jest.config.mjs +0 -36
  53. package/template-design-pro/mock/_createProductionServer.ts +0 -19
  54. package/template-design-pro/mock/_util.ts +0 -55
  55. package/template-design-pro/mock/controller/menu.ts +0 -85
  56. package/template-design-pro/mock/controller/notices.ts +0 -114
  57. package/template-design-pro/mock/system/dict.ts +0 -60
  58. package/template-design-pro/mock/system/user.ts +0 -218
  59. package/template-design-pro/package.json +0 -151
  60. package/template-design-pro/pnpm-lock.yaml +0 -9913
  61. package/template-design-pro/postcss.config.js +0 -5
  62. package/template-design-pro/prettier.config.js +0 -18
  63. package/template-design-pro/public/resource/css/index.css +0 -171
  64. package/template-design-pro/public/resource/img/favicon.ico +0 -0
  65. package/template-design-pro/public/resource/img/logo.png +0 -0
  66. package/template-design-pro/public/resource/img/pro_icon.svg +0 -5
  67. package/template-design-pro/public/resource/img/pwa-192x192.png +0 -0
  68. package/template-design-pro/public/resource/img/pwa-512x512.png +0 -0
  69. package/template-design-pro/src/App.vue +0 -47
  70. package/template-design-pro/src/assets/error_images/403.png +0 -0
  71. package/template-design-pro/src/assets/error_images/404.png +0 -0
  72. package/template-design-pro/src/assets/error_images/cloud.png +0 -0
  73. package/template-design-pro/src/assets/login_images/login_background.svg +0 -69
  74. package/template-design-pro/src/assets/logo.png +0 -0
  75. package/template-design-pro/src/assets/menu_font/iconfont.css +0 -94
  76. package/template-design-pro/src/assets/menu_font/iconfont.eot +0 -0
  77. package/template-design-pro/src/assets/menu_font/iconfont.js +0 -1
  78. package/template-design-pro/src/assets/menu_font/iconfont.json +0 -142
  79. package/template-design-pro/src/assets/menu_font/iconfont.svg +0 -57
  80. package/template-design-pro/src/assets/menu_font/iconfont.ttf +0 -0
  81. package/template-design-pro/src/assets/menu_font/iconfont.woff +0 -0
  82. package/template-design-pro/src/assets/menu_font/iconfont.woff2 +0 -0
  83. package/template-design-pro/src/assets/menu_font/index.less +0 -94
  84. package/template-design-pro/src/common/global.ts +0 -1
  85. package/template-design-pro/src/components/GDesign/ProLayout/BasicLayout.less +0 -80
  86. package/template-design-pro/src/components/GDesign/ProLayout/BasicLayout.tsx +0 -342
  87. package/template-design-pro/src/components/GDesign/ProLayout/PageLoading.tsx +0 -20
  88. package/template-design-pro/src/components/GDesign/ProLayout/RenderTypings.ts +0 -31
  89. package/template-design-pro/src/components/GDesign/ProLayout/RouteContext.tsx +0 -82
  90. package/template-design-pro/src/components/GDesign/ProLayout/WrapContent.tsx +0 -69
  91. package/template-design-pro/src/components/GDesign/ProLayout/components/GlobalFooter/index.tsx +0 -88
  92. package/template-design-pro/src/components/GDesign/ProLayout/components/GlobalHeader/DefaultHeader.tsx +0 -189
  93. package/template-design-pro/src/components/GDesign/ProLayout/components/GlobalHeader/Header.less +0 -8
  94. package/template-design-pro/src/components/GDesign/ProLayout/components/GlobalHeader/index.tsx +0 -105
  95. package/template-design-pro/src/components/GDesign/ProLayout/components/GlobalHeader/props.ts +0 -69
  96. package/template-design-pro/src/components/GDesign/ProLayout/components/GlobalHeader/style.less +0 -144
  97. package/template-design-pro/src/components/GDesign/ProLayout/components/LogoContent/index.tsx +0 -81
  98. package/template-design-pro/src/components/GDesign/ProLayout/components/LogoContent/props.ts +0 -29
  99. package/template-design-pro/src/components/GDesign/ProLayout/components/MultiTab/index.tsx +0 -384
  100. package/template-design-pro/src/components/GDesign/ProLayout/components/MultiTab/props.ts +0 -15
  101. package/template-design-pro/src/components/GDesign/ProLayout/components/MultiTab/style.less +0 -79
  102. package/template-design-pro/src/components/GDesign/ProLayout/components/NoticeIcon/NoticeIcon.tsx +0 -148
  103. package/template-design-pro/src/components/GDesign/ProLayout/components/NoticeIcon/NoticeList.module.less +0 -115
  104. package/template-design-pro/src/components/GDesign/ProLayout/components/NoticeIcon/NoticeList.tsx +0 -154
  105. package/template-design-pro/src/components/GDesign/ProLayout/components/NoticeIcon/index.less +0 -39
  106. package/template-design-pro/src/components/GDesign/ProLayout/components/NoticeIcon/index.tsx +0 -133
  107. package/template-design-pro/src/components/GDesign/ProLayout/components/PageContainer/index.tsx +0 -190
  108. package/template-design-pro/src/components/GDesign/ProLayout/components/PageContainer/props.ts +0 -48
  109. package/template-design-pro/src/components/GDesign/ProLayout/components/PageContainer/style.less +0 -128
  110. package/template-design-pro/src/components/GDesign/ProLayout/components/PageContainer/typings.ts +0 -0
  111. package/template-design-pro/src/components/GDesign/ProLayout/components/RightContent/AvatarDropdown.tsx +0 -63
  112. package/template-design-pro/src/components/GDesign/ProLayout/components/RightContent/HeaderSearch.tsx +0 -122
  113. package/template-design-pro/src/components/GDesign/ProLayout/components/RightContent/headerSearch.less +0 -30
  114. package/template-design-pro/src/components/GDesign/ProLayout/components/RightContent/index.tsx +0 -95
  115. package/template-design-pro/src/components/GDesign/ProLayout/components/RightContent/style.less +0 -90
  116. package/template-design-pro/src/components/GDesign/ProLayout/components/SettingDrawer/BlockCheckbox.tsx +0 -70
  117. package/template-design-pro/src/components/GDesign/ProLayout/components/SettingDrawer/LayoutSetting.tsx +0 -107
  118. package/template-design-pro/src/components/GDesign/ProLayout/components/SettingDrawer/ThemeColor.tsx +0 -68
  119. package/template-design-pro/src/components/GDesign/ProLayout/components/SettingDrawer/index.tsx +0 -346
  120. package/template-design-pro/src/components/GDesign/ProLayout/components/SiderMenu/BaseMenu.tsx +0 -224
  121. package/template-design-pro/src/components/GDesign/ProLayout/components/SiderMenu/SiderMenu.tsx +0 -224
  122. package/template-design-pro/src/components/GDesign/ProLayout/components/SiderMenu/index.tsx +0 -43
  123. package/template-design-pro/src/components/GDesign/ProLayout/components/SiderMenu/props.ts +0 -112
  124. package/template-design-pro/src/components/GDesign/ProLayout/components/SiderMenu/style.less +0 -262
  125. package/template-design-pro/src/components/GDesign/ProLayout/components/SiderMenu/typings.ts +0 -44
  126. package/template-design-pro/src/components/GDesign/ProLayout/default.less +0 -2
  127. package/template-design-pro/src/components/GDesign/ProLayout/defaultSettings.ts +0 -121
  128. package/template-design-pro/src/components/GDesign/ProLayout/hooks/context/index.ts +0 -45
  129. package/template-design-pro/src/components/GDesign/ProLayout/index.ts +0 -43
  130. package/template-design-pro/src/components/GDesign/ProLayout/props.ts +0 -57
  131. package/template-design-pro/src/components/GDesign/ProLayout/style.less +0 -272
  132. package/template-design-pro/src/components/GDesign/ProLayout/typings.ts +0 -1
  133. package/template-design-pro/src/components/GDesign/ProLayout/utils/getMenuData.ts +0 -31
  134. package/template-design-pro/src/components/GDesign/ProLayout/utils/index.ts +0 -94
  135. package/template-design-pro/src/components/GDesign/ProLayout/utils/isImg/index.ts +0 -6
  136. package/template-design-pro/src/components/GDesign/ProLayout/utils/isUrl/index.ts +0 -5
  137. package/template-design-pro/src/components/GDesign/Result/index.tsx +0 -142
  138. package/template-design-pro/src/components/GDesign/Result/style.less +0 -140
  139. package/template-design-pro/src/components/GDesign/Scrollbars/components/Bar/index.tsx +0 -56
  140. package/template-design-pro/src/components/GDesign/Scrollbars/components/Bar/props.ts +0 -23
  141. package/template-design-pro/src/components/GDesign/Scrollbars/components/Thumb/index.tsx +0 -164
  142. package/template-design-pro/src/components/GDesign/Scrollbars/components/Thumb/props.ts +0 -11
  143. package/template-design-pro/src/components/GDesign/Scrollbars/context.ts +0 -10
  144. package/template-design-pro/src/components/GDesign/Scrollbars/index.tsx +0 -200
  145. package/template-design-pro/src/components/GDesign/Scrollbars/props.ts +0 -65
  146. package/template-design-pro/src/components/GDesign/Scrollbars/style.less +0 -85
  147. package/template-design-pro/src/components/GDesign/Scrollbars/util.ts +0 -40
  148. package/template-design-pro/src/components/GDesign/utils/index.ts +0 -7
  149. package/template-design-pro/src/components/PageLoading/index.tsx +0 -44
  150. package/template-design-pro/src/components/PageTransition/index.vue +0 -98
  151. package/template-design-pro/src/components/index.ts +0 -6
  152. package/template-design-pro/src/core/ant-design/index.ts +0 -14
  153. package/template-design-pro/src/core/gx-admin-design/index.ts +0 -7
  154. package/template-design-pro/src/core/gx-admin-directives/index.ts +0 -8
  155. package/template-design-pro/src/core/gx-admin-directives/permission.ts +0 -28
  156. package/template-design-pro/src/core/gx-design/index.ts +0 -7
  157. package/template-design-pro/src/core/gx-pro-design/index.ts +0 -10
  158. package/template-design-pro/src/core/index.ts +0 -27
  159. package/template-design-pro/src/design/ant-design/index.less +0 -4
  160. package/template-design-pro/src/design/ant-design/layout.less +0 -29
  161. package/template-design-pro/src/design/ant-design/menu.less +0 -55
  162. package/template-design-pro/src/design/ant-design/table.less +0 -67
  163. package/template-design-pro/src/design/ant-design/tooltip.less +0 -13
  164. package/template-design-pro/src/design/color.less +0 -1
  165. package/template-design-pro/src/design/config.less +0 -5
  166. package/template-design-pro/src/design/index.less +0 -41
  167. package/template-design-pro/src/design/mixin.less +0 -66
  168. package/template-design-pro/src/design/normalize.less +0 -390
  169. package/template-design-pro/src/global.less +0 -15
  170. package/template-design-pro/src/hooks/core/index.ts +0 -3
  171. package/template-design-pro/src/hooks/core/useRequest/index.ts +0 -70
  172. package/template-design-pro/src/hooks/core/useRequest/typings.ts +0 -0
  173. package/template-design-pro/src/hooks/event/index.ts +0 -3
  174. package/template-design-pro/src/hooks/event/useClipboard.ts +0 -14
  175. package/template-design-pro/src/hooks/system/index.ts +0 -5
  176. package/template-design-pro/src/hooks/system/useDict.ts +0 -62
  177. package/template-design-pro/src/hooks/system/usePermissions.ts +0 -39
  178. package/template-design-pro/src/hooks/typings.ts +0 -17
  179. package/template-design-pro/src/layout/BasicLayout.vue +0 -104
  180. package/template-design-pro/src/layout/BlankLayout.vue +0 -5
  181. package/template-design-pro/src/layout/ContentView.vue +0 -76
  182. package/template-design-pro/src/layout/IframeView.vue +0 -1
  183. package/template-design-pro/src/layout/UserLayout.vue +0 -7
  184. package/template-design-pro/src/main.ts +0 -34
  185. package/template-design-pro/src/plugins/index.ts +0 -3
  186. package/template-design-pro/src/router/guard/index.ts +0 -84
  187. package/template-design-pro/src/router/guard/permissions.ts +0 -73
  188. package/template-design-pro/src/router/guard/stateGuard.ts +0 -11
  189. package/template-design-pro/src/router/helper/routeHelper.ts +0 -244
  190. package/template-design-pro/src/router/helper/utils.ts +0 -19
  191. package/template-design-pro/src/router/index.ts +0 -30
  192. package/template-design-pro/src/router/routes/index.ts +0 -85
  193. package/template-design-pro/src/router/routes/modules/workplace.ts +0 -19
  194. package/template-design-pro/src/services/common/index.ts +0 -11
  195. package/template-design-pro/src/services/controller/router.ts +0 -10
  196. package/template-design-pro/src/services/controller/user.ts +0 -35
  197. package/template-design-pro/src/services/system/dictData.ts +0 -10
  198. package/template-design-pro/src/services/system/notices.ts +0 -9
  199. package/template-design-pro/src/store/index.ts +0 -32
  200. package/template-design-pro/src/store/modules/dict.ts +0 -27
  201. package/template-design-pro/src/store/modules/permission.ts +0 -19
  202. package/template-design-pro/src/store/modules/routes.ts +0 -110
  203. package/template-design-pro/src/store/modules/settings.ts +0 -102
  204. package/template-design-pro/src/store/modules/tabsRouter.ts +0 -73
  205. package/template-design-pro/src/store/modules/user.ts +0 -153
  206. package/template-design-pro/src/utils/accessToken.ts +0 -93
  207. package/template-design-pro/src/utils/crypto.ts +0 -39
  208. package/template-design-pro/src/utils/env.ts +0 -52
  209. package/template-design-pro/src/utils/fetchFile.ts +0 -79
  210. package/template-design-pro/src/utils/index.ts +0 -127
  211. package/template-design-pro/src/utils/pageTitle.ts +0 -17
  212. package/template-design-pro/src/utils/request/XHR.ts +0 -131
  213. package/template-design-pro/src/utils/request/axiosCancel.ts +0 -60
  214. package/template-design-pro/src/utils/request/checkStatus.ts +0 -26
  215. package/template-design-pro/src/utils/request/index.ts +0 -145
  216. package/template-design-pro/src/utils/request/typings.ts +0 -114
  217. package/template-design-pro/src/utils/storage.ts +0 -194
  218. package/template-design-pro/src/utils/uploadFile.ts +0 -26
  219. package/template-design-pro/src/utils/util.ts +0 -278
  220. package/template-design-pro/src/utils/validate.ts +0 -221
  221. package/template-design-pro/src/views/Iframe/index.vue +0 -76
  222. package/template-design-pro/src/views/MenuOne/index.vue +0 -15
  223. package/template-design-pro/src/views/MenuTwo/index.vue +0 -13
  224. package/template-design-pro/src/views/exception/403/index.vue +0 -9
  225. package/template-design-pro/src/views/exception/404/index.vue +0 -9
  226. package/template-design-pro/src/views/user/login/index.vue +0 -110
  227. package/template-design-pro/src/views/user/login/style.less +0 -38
  228. package/template-design-pro/stylelint.config.js +0 -106
  229. package/template-design-pro/tests/__mocks__/fileMock.ts +0 -1
  230. package/template-design-pro/tests/__mocks__/styleMock.ts +0 -1
  231. package/template-design-pro/tests/__mocks__/workerMock.ts +0 -5
  232. package/template-design-pro/tests/server/README.md +0 -15
  233. package/template-design-pro/tests/server/controller/FileController.ts +0 -18
  234. package/template-design-pro/tests/server/controller/UserController.ts +0 -15
  235. package/template-design-pro/tests/server/ecosystem.config.js +0 -18
  236. package/template-design-pro/tests/server/index.ts +0 -63
  237. package/template-design-pro/tests/server/nodemon.json +0 -8
  238. package/template-design-pro/tests/server/package.json +0 -36
  239. package/template-design-pro/tests/server/routes.ts +0 -23
  240. package/template-design-pro/tests/server/service/FileService.ts +0 -54
  241. package/template-design-pro/tests/server/service/UserService.ts +0 -25
  242. package/template-design-pro/tests/server/tsconfig.json +0 -15
  243. package/template-design-pro/tests/server/utils.ts +0 -9
  244. package/template-design-pro/tests/server/yarn.lock +0 -2955
  245. package/template-design-pro/tests/test.spec.ts +0 -16
  246. package/template-design-pro/tsconfig.json +0 -47
  247. package/template-design-pro/types/auto-imports.d.ts +0 -61
  248. package/template-design-pro/types/config.d.ts +0 -100
  249. package/template-design-pro/types/global.d.ts +0 -103
  250. package/template-design-pro/types/gx-components.d.ts +0 -24
  251. package/template-design-pro/types/index.d.ts +0 -13
  252. package/template-design-pro/types/mock.d.ts +0 -23
  253. package/template-design-pro/types/module.d.ts +0 -16
  254. package/template-design-pro/types/response.d.ts +0 -15
  255. package/template-design-pro/types/route.d.ts +0 -89
  256. package/template-design-pro/vite.config.ts +0 -136
  257. package/template-design-pro/yarn.lock +0 -9697
@@ -1,224 +0,0 @@
1
- import {
2
- defineComponent,
3
- VNodeChild,
4
- VNode,
5
- computed,
6
- isVNode,
7
- resolveComponent,
8
- ExtractPropTypes,
9
- ConcreteComponent
10
- } from 'vue'
11
- import { useRouter } from 'vue-router'
12
- import { Menu } from 'ant-design-vue'
13
- import { createFromIconfontCN } from '@ant-design/icons-vue'
14
- import { baseMenuProps } from './props'
15
- import { defaultSettings } from '../../defaultSettings'
16
- import { isImg, isUrl } from '../../utils'
17
-
18
- export interface CustomMenuRender {
19
- menuItemRender?: WithFalse<
20
- (args: { item: AppRouteModule; title?: JSX.Element; icon?: JSX.Element }) => CustomRender
21
- >
22
- subMenuItemRender?: WithFalse<
23
- (args: { item: AppRouteModule; children?: CustomRender[] }) => CustomRender
24
- >
25
- }
26
-
27
- export type BaseMenuProps = ExtractPropTypes<typeof baseMenuProps>
28
-
29
- const IconFont: any = (iconfontUrl) => {
30
- return createFromIconfontCN({
31
- scriptUrl: iconfontUrl || defaultSettings.iconfontUrl
32
- })
33
- }
34
-
35
- const LazyIcon = (props: {
36
- icon: VNodeChild | string
37
- iconType?: number
38
- iconfontUrl?: string
39
- }) => {
40
- const { icon, iconType, iconfontUrl } = props
41
- if (!icon) {
42
- return null
43
- }
44
- if (typeof icon === 'string' && icon !== '') {
45
- if (isUrl(icon) || isImg(icon)) {
46
- return <img src={icon} alt="icon" class={`gx-pro-sider-menu-icon customimg`} />
47
- }
48
- if (iconType === 1) {
49
- return iconfontUrl ? <IconFont type={icon} /> : <i class={`iconfont ${icon} customicon`}></i>
50
- }
51
- }
52
- if (isVNode(icon)) {
53
- return icon
54
- }
55
- const DynamicIcon = resolveComponent(icon as string) as any
56
- return (typeof LazyIcon === 'function' && <DynamicIcon />) || null
57
- }
58
-
59
- LazyIcon.props = {
60
- icon: {
61
- type: [String, Function, Object] as PropType<string | Function | VNode | JSX.Element>
62
- },
63
- iconType: Number,
64
- iconfontUrl: String
65
- }
66
-
67
- export default defineComponent({
68
- name: 'BaseMenu',
69
- props: baseMenuProps,
70
- emits: ['update:openKeys', 'update:selectedKeys', 'click'],
71
- setup(props, { attrs, emit }) {
72
- const router = useRouter()
73
- const handleOpenChange = (openKeys: string[]): void => {
74
- emit('update:openKeys', openKeys)
75
- }
76
- const handleSelect = (params: {
77
- key: string | number
78
- keyPath: string[] | number[]
79
- item: VNodeChild | any
80
- domEvent: MouseEvent
81
- selectedKeys: string[]
82
- }): void => {
83
- emit('update:selectedKeys', params.selectedKeys)
84
- }
85
- const handleClick = (args: {
86
- item: VNodeChild
87
- key: string | number
88
- keyPath: string | string[] | number | number[]
89
- }) => {
90
- emit('click', args)
91
- }
92
- const isTotargetLink = (meta: any, routerInfo: any) => {
93
- const target = (meta.target || '') as string
94
- const hasUrl = isUrl(target)
95
- if (router.currentRoute.value?.fullPath !== routerInfo.to) {
96
- if (hasUrl && target && meta.targetStatus === 1) {
97
- window.open(target)
98
- }
99
- }
100
- }
101
- const RouterLink = resolveComponent('router-link') as ConcreteComponent
102
- const getNavMenuItems = (menusData: AppRouteModule[] = []) => {
103
- return menusData.map((item) => getSubMenuOrItem(item)).filter((item) => item)
104
- }
105
- const getSubMenuOrItem = (item: AppRouteModule): VNode => {
106
- if (
107
- Array.isArray(item.children) &&
108
- item.children.length > 0 &&
109
- !item?.meta?.hideInMenu &&
110
- !item?.meta?.hideChildrenInMenu
111
- ) {
112
- if (props.subMenuItemRender) {
113
- return props.subMenuItemRender({
114
- item,
115
- children: getNavMenuItems(item.children)
116
- }) as VNode
117
- }
118
- const menuTitle = item.meta?.title
119
- const defaultTitle = item.meta?.icon ? (
120
- <span class={`gx-pro-sider-menu-item`}>
121
- <span class={`gx-pro-sider-menu-item-title`}>{menuTitle}</span>
122
- </span>
123
- ) : (
124
- <span class={`gx-pro-sider-menu-item`}>{menuTitle}</span>
125
- )
126
-
127
- const hasGroup = item.meta?.type === 'group'
128
-
129
- const MenuComponent = hasGroup ? Menu.ItemGroup : Menu.SubMenu
130
-
131
- return (
132
- <MenuComponent
133
- title={defaultTitle}
134
- key={item.path}
135
- icon={
136
- hasGroup ? null : (
137
- <LazyIcon
138
- icon={item.meta?.icon}
139
- iconfontUrl={props.iconfontUrl}
140
- iconType={item.meta?.iconType}
141
- />
142
- )
143
- }
144
- >
145
- {getNavMenuItems(item.children)}
146
- </MenuComponent>
147
- )
148
- }
149
-
150
- const [title, icon] = getMenuItem(item)
151
-
152
- return (
153
- ((props.menuItemRender && props.menuItemRender({ item, title, icon })) as VNode) || (
154
- <Menu.Item
155
- disabled={item.meta?.disabled}
156
- danger={item.meta?.danger}
157
- key={item.path}
158
- icon={icon}
159
- >
160
- {title}
161
- </Menu.Item>
162
- )
163
- )
164
- }
165
- const getMenuItem = (item: AppRouteModule) => {
166
- const meta = { ...item.meta }
167
- const CustomTag: any = meta.targetStatus === 1 && meta.target ? 'a' : RouterLink
168
- const parames = { to: item.linkPath || item.path || '' }
169
- if (parames.to === '/live/list/operation/:id') parames.to = '/live/list/operation/add'
170
-
171
- const menuTitle = item.meta?.title
172
- const defaultTitle = item.meta?.icon ? (
173
- <CustomTag
174
- {...parames}
175
- class={`gx-pro-sider-menu-item`}
176
- onClick={() => isTotargetLink(meta, parames)}
177
- >
178
- <span class={`gx-pro-sider-menu-item-title`}>{menuTitle}</span>
179
- </CustomTag>
180
- ) : (
181
- <CustomTag
182
- {...parames}
183
- class={`gx-pro-sider-menu-item`}
184
- onClick={() => isTotargetLink(meta, parames)}
185
- >
186
- <span>{menuTitle}</span>
187
- </CustomTag>
188
- )
189
-
190
- const icon =
191
- (item.meta?.icon && (
192
- <LazyIcon
193
- icon={item.meta?.icon}
194
- iconfontUrl={props.iconfontUrl}
195
- iconType={item.meta?.iconType}
196
- />
197
- )) ||
198
- undefined
199
-
200
- return [defaultTitle, icon]
201
- }
202
- const getMenuItems = computed(() => {
203
- return getNavMenuItems(props.menuData)
204
- })
205
- return () => (
206
- <Menu
207
- key="Menu"
208
- inlineIndent={16}
209
- mode={props.mode}
210
- theme={props.theme as 'dark' | 'light'}
211
- openKeys={props.openKeys === false ? [] : props.openKeys}
212
- selectedKeys={props.selectedKeys || []}
213
- style={attrs.style}
214
- class={attrs.class}
215
- onOpenChange={handleOpenChange}
216
- onSelect={handleSelect}
217
- onClick={handleClick}
218
- {...props.menuProps}
219
- >
220
- {getMenuItems.value}
221
- </Menu>
222
- )
223
- }
224
- })
@@ -1,224 +0,0 @@
1
- import type { FunctionalComponent as FC, ExtractPropTypes } from 'vue'
2
- import { computed, unref } from 'vue'
3
- import { Layout, Spin, Menu } from 'ant-design-vue'
4
- import { MenuUnfoldOutlined, MenuFoldOutlined } from '@ant-design/icons-vue'
5
- import BaseMenu from './BaseMenu'
6
- import { siderMenuProps } from './props'
7
- import LogoContent from '../LogoContent'
8
- import { useRouteContext } from '../../RouteContext'
9
-
10
- const { Sider } = Layout
11
-
12
- const { Item } = Menu
13
-
14
- export type SiderMenuProps = Partial<ExtractPropTypes<typeof siderMenuProps>>
15
-
16
- export type PrivateSiderMenuProps = {
17
- matchMenuKeys?: string[]
18
- }
19
-
20
- export const defaultRenderCollapsedButton = (collapsed?: boolean): CustomRender =>
21
- collapsed ? <MenuUnfoldOutlined /> : <MenuFoldOutlined />
22
-
23
- const SiderMenu: FC<SiderMenuProps> = (props: SiderMenuProps) => {
24
- const {
25
- theme,
26
- layout,
27
- isMobile,
28
- menuLoading,
29
- breakpoint,
30
- fixSiderbar,
31
- collapsed,
32
- siderWidth,
33
- collapsedWidth = 48,
34
- menuExtraRender = false,
35
- menuContentRender = false,
36
- menuFooterRender = false,
37
- collapsedButtonRender = defaultRenderCollapsedButton,
38
- links,
39
- onCollapse,
40
- onOpenKeys
41
- } = props
42
-
43
- const context = useRouteContext()
44
-
45
- const baseClassName = context.getPrefixCls({
46
- suffixCls: 'sider',
47
- isPor: true
48
- })
49
-
50
- const hasContentWide = computed(() => props.layout === 'wide')
51
- const hasSplitMenu = computed(() => props.layout === 'mix' && !props.isMobile && props.splitMenus)
52
- const layoutSide = computed(() => layout === 'side' || layout === 'simple')
53
- const sTheme = computed(
54
- () => ((props.layout === 'mix' || hasContentWide.value) && 'light') || theme
55
- )
56
- const sSideWidth = computed(() => (props.collapsed ? props.collapsedWidth : props.siderWidth))
57
- const classNames = computed(() => {
58
- return [
59
- baseClassName,
60
- isMobile ? 'shadow' : null,
61
- sTheme.value,
62
- hasContentWide.value ? 'wide' : null,
63
- fixSiderbar && props.layout !== 'wide' ? `${baseClassName}-fixed` : null
64
- ]
65
- })
66
-
67
- const handleSelect = ($event: string[]) => {
68
- if (props.onSelect) {
69
- if (unref(hasSplitMenu)) {
70
- props.onSelect([context?.selectedKeys?.[0], ...$event])
71
- return
72
- }
73
- props.onSelect($event)
74
- }
75
- }
76
-
77
- if (hasSplitMenu.value && unref(context.flatMenuData).length === 0) {
78
- return null
79
- }
80
-
81
- const defaultMenuDom = (
82
- <BaseMenu
83
- class={`${baseClassName}-menu`}
84
- theme={sTheme.value}
85
- mode="inline"
86
- menuData={hasSplitMenu.value ? context.flatMenuData : context.menuData}
87
- collapsed={props.collapsed}
88
- openKeys={context.openKeys}
89
- selectedKeys={context.selectedKeys}
90
- menuItemRender={props.menuItemRender}
91
- subMenuItemRender={props.subMenuItemRender}
92
- onClick={props.onMenuClick}
93
- style={{
94
- width: '100%'
95
- }}
96
- {...{
97
- 'onUpdate:openKeys': ($event: string[]) => onOpenKeys && onOpenKeys($event),
98
- 'onUpdate:selectedKeys': handleSelect
99
- }}
100
- />
101
- )
102
-
103
- const headerDom =
104
- layoutSide.value || isMobile ? <LogoContent drawer={isMobile} {...props} /> : null
105
-
106
- const extraDom = menuExtraRender && menuExtraRender(props)
107
-
108
- const linksChild = computed(() => {
109
- if (typeof links === 'function') return links?.()
110
- return links
111
- })
112
-
113
- watch(
114
- () => sTheme.value,
115
- (val) => {
116
- console.log(val)
117
- }
118
- )
119
-
120
- return (
121
- <>
122
- {!!(hasSplitMenu.value ? context.flatMenuData : context.menuData).length && (
123
- <>
124
- {fixSiderbar && (
125
- <div
126
- style={{
127
- width: `${sSideWidth.value}px`,
128
- overflow: 'hidden',
129
- flex: `0 0 ${sSideWidth.value}px`,
130
- maxWidth: `${sSideWidth.value}px`,
131
- minWidth: `${sSideWidth.value}px`,
132
- transition: `background-color 0.3s, min-width 0.3s, max-width 0.3s cubic-bezier(0.645, 0.045, 0.355, 1)`
133
- }}
134
- />
135
- )}
136
- <Sider
137
- collapsible
138
- trigger={null}
139
- class={classNames.value}
140
- style={{
141
- overflow: 'hidden',
142
- zIndex: fixSiderbar ? 101 : undefined,
143
- paddingTop:
144
- layoutSide.value || props.isMobile || hasContentWide.value
145
- ? 0
146
- : `${props.headerHeight}px`,
147
- top: props.layout === 'wide' ? `${props.headerHeight + 20}px` : undefined,
148
- height:
149
- props.layout === 'wide'
150
- ? `calc(100vh - ${props.headerHeight + 20 * 2}px)`
151
- : undefined
152
- }}
153
- theme={sTheme.value}
154
- breakpoint={breakpoint || undefined}
155
- collapsed={collapsed}
156
- width={siderWidth}
157
- collapsedWidth={collapsedWidth}
158
- onCollapse={(collapse) => {
159
- if (props.isMobile) return
160
- onCollapse?.(collapse)
161
- }}
162
- >
163
- {menuLoading && (
164
- <div class="gx-pro-sider-loading">
165
- <Spin spinning={menuLoading} />
166
- </div>
167
- )}
168
- {headerDom || null}
169
- {extraDom && !props.collapsed && (
170
- <div
171
- class={{
172
- [`${baseClassName}-extra`]: true,
173
- [`${baseClassName}-extra-no-logo`]: !headerDom
174
- }}
175
- >
176
- {extraDom}
177
- </div>
178
- )}
179
- <div style="flex: 1 1 0%; overflow: hidden auto">
180
- {(menuContentRender && menuContentRender(props, defaultMenuDom)) || defaultMenuDom}
181
- </div>
182
- {props.layout !== 'wide' && (
183
- <div class={`${baseClassName}-links`}>
184
- <Menu
185
- theme={sTheme.value}
186
- inlineIndent={16}
187
- class={`${baseClassName}-link-menu`}
188
- selectedKeys={[]}
189
- openKeys={[]}
190
- mode="inline"
191
- >
192
- {((linksChild.value || []) as any[]).map((node, index) => (
193
- <Item class={`${baseClassName}-link`} key={index}>
194
- {node}
195
- </Item>
196
- ))}
197
- {collapsedButtonRender && !isMobile && (
198
- <Item
199
- class={`${baseClassName}-collapsed-button`}
200
- title={false}
201
- key="collapsed"
202
- onClick={() => {
203
- if (onCollapse) {
204
- onCollapse(!collapsed)
205
- }
206
- }}
207
- >
208
- {collapsedButtonRender(collapsed)}
209
- </Item>
210
- )}
211
- </Menu>
212
- </div>
213
- )}
214
- {menuFooterRender && (
215
- <div class={`${baseClassName}-footer`}>{menuFooterRender(props)}</div>
216
- )}
217
- </Sider>
218
- </>
219
- )}
220
- </>
221
- )
222
- }
223
-
224
- export default SiderMenu
@@ -1,43 +0,0 @@
1
- import type { FunctionalComponent as FC } from 'vue'
2
- import { Drawer } from 'ant-design-vue'
3
- import { siderMenuProps } from './props'
4
- import SiderMenu, { SiderMenuProps, PrivateSiderMenuProps } from './SiderMenu'
5
-
6
- export type SiderMenuWrapperProps = Partial<SiderMenuProps> & Partial<PrivateSiderMenuProps>
7
-
8
- const SiderMenuWrapper: FC<SiderMenuWrapperProps> = (props, { attrs }) => {
9
- return props.isMobile ? (
10
- <Drawer
11
- visible={!props.collapsed}
12
- closable={false}
13
- placement="left"
14
- style={{
15
- padding: 0,
16
- height: '100vh'
17
- }}
18
- onClose={() => props.onCollapse && props.onCollapse(true)}
19
- width={props.siderWidth}
20
- bodyStyle={{
21
- height: '100vh',
22
- padding: 0,
23
- display: 'flex',
24
- flexDirection: 'row'
25
- }}
26
- >
27
- <SiderMenu {...attrs} {...props} collapsed={props.isMobile ? false : props.collapsed} />
28
- </Drawer>
29
- ) : (
30
- <SiderMenu {...attrs} {...props} />
31
- )
32
- }
33
-
34
- SiderMenuWrapper.inheritAttrs = false
35
- SiderMenuWrapper.displayName = 'SiderMenuWrapper'
36
-
37
- export {
38
- SiderMenu,
39
- // vue props
40
- siderMenuProps
41
- }
42
-
43
- export default SiderMenuWrapper
@@ -1,112 +0,0 @@
1
- import type { themeConfig, MenuTheme } from '/types/config'
2
- import { PropTypes } from '@/utils'
3
- import type { CustomMenuRender } from './BaseMenu'
4
- import type { SiderProps, MenuMode } from './typings'
5
- import logoContentProps from '../LogoContent/props'
6
- import type { LinksRender, MenuExtraRender, MenuFooterRender } from '../../RenderTypings'
7
- import { defaultSettingProps } from '../../defaultSettings'
8
- import { HeaderLogoRender, MenuContentRender } from '../../RenderTypings'
9
-
10
- export const baseMenuProps = {
11
- ...defaultSettingProps,
12
-
13
- mode: {
14
- type: String as PropType<MenuMode>,
15
- default: 'inline'
16
- },
17
- menuData: {
18
- type: Array as PropType<AppRouteModule[]>,
19
- default: () => []
20
- },
21
- theme: {
22
- type: String as PropType<MenuTheme>,
23
- default: 'dark'
24
- },
25
- layout: {
26
- type: String as PropType<themeConfig['layout']>,
27
- default: 'mix'
28
- },
29
- collapsed: {
30
- type: Boolean as PropType<boolean | undefined>,
31
- default: () => false
32
- },
33
- openKeys: {
34
- type: Array as PropType<WithFalse<string[]>>,
35
- default: () => undefined
36
- },
37
- selectedKeys: {
38
- type: Array as PropType<WithFalse<string[]>>,
39
- default: () => undefined
40
- },
41
- menuProps: {
42
- type: Object as PropType<Record<string, any>>,
43
- default: () => null
44
- },
45
- menuItemRender: {
46
- type: [ Function, Boolean ] as PropType<CustomMenuRender['menuItemRender']>,
47
- default: () => false
48
- },
49
- subMenuItemRender: {
50
- type: [ Function, Boolean ] as PropType<CustomMenuRender['subMenuItemRender']>,
51
- default: () => false
52
- },
53
- onClick: [ Function, Object ] as PropType<(...args: any) => void>
54
- }
55
-
56
- export const siderMenuProps = {
57
- ...defaultSettingProps,
58
- ...baseMenuProps,
59
- menuLoading: PropTypes.looseBool,
60
- logo: logoContentProps.logo,
61
- logoStyle: logoContentProps.logoStyle,
62
- logoDirection: logoContentProps.logoDirection,
63
- siderWidth: PropTypes.number.def(208),
64
- headerHeight: PropTypes.number.def(48),
65
- collapsedWidth: PropTypes.number.def(48),
66
- links: {
67
- type: [ Function, Object, Array ] as PropType<LinksRender>,
68
- default: () => undefined
69
- },
70
- menuHeaderRender: {
71
- type: [ Function, Object ] as PropType<HeaderLogoRender>,
72
- default: () => undefined
73
- },
74
- menuFooterRender: {
75
- type: [ Function, Object ] as PropType<MenuFooterRender>,
76
- default: () => undefined
77
- },
78
- menuContentRender: {
79
- type: [ Function, Object ] as PropType<MenuContentRender>,
80
- default: () => undefined
81
- },
82
- menuExtraRender: {
83
- type: [ Function, Object ] as PropType<MenuExtraRender>,
84
- default: () => undefined
85
- },
86
- collapsedButtonRender: {
87
- type: [ Function, Object, Boolean ] as PropType<WithFalse<(collapsed?: boolean) => CustomRender>>,
88
- default: () => undefined
89
- },
90
- breakpoint: {
91
- type: [ Object, Boolean ] as PropType<SiderProps['breakpoint'] | false>,
92
- default: () => false
93
- },
94
- isMobile: PropTypes.looseBool,
95
- matchMenuKeys: {
96
- type: Array as PropType<string[]>,
97
- default: () => []
98
- },
99
-
100
- // events
101
- onMenuHeaderClick: PropTypes.func,
102
- onMenuClick: PropTypes.func,
103
- onCollapse: {
104
- type: Function as PropType<(collapsed: boolean) => void>
105
- },
106
- onOpenKeys: {
107
- type: Function as PropType<(openKeys: WithFalse<string[]>) => void>
108
- },
109
- onSelect: {
110
- type: Function as PropType<(selectedKeys: WithFalse<string[]>) => void>
111
- }
112
- }