@gadmin2n/schematics 0.0.64 → 0.0.66

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 (198) hide show
  1. package/dist/lib/application/files/gadmin2-game-angle-demo/.dockerignore +2 -2
  2. package/dist/lib/application/files/gadmin2-game-angle-demo/Dockerfile +40 -26
  3. package/dist/lib/application/files/gadmin2-game-angle-demo/Jenkinsfile +30 -4
  4. package/dist/lib/application/files/gadmin2-game-angle-demo/config/prisma/example.prisma +33 -0
  5. package/dist/lib/application/files/gadmin2-game-angle-demo/config/prisma/system.prisma +170 -0
  6. package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/Event.ts +70 -0
  7. package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/Game.ts +6 -6
  8. package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/ITActivityDay.ts +70 -0
  9. package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/Log.ts +2 -2
  10. package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/Role.ts +2 -2
  11. package/dist/lib/application/files/gadmin2-game-angle-demo/server/.env +20 -9
  12. package/dist/lib/application/files/gadmin2-game-angle-demo/server/.env.local +1 -0
  13. package/dist/lib/application/files/gadmin2-game-angle-demo/server/.eslintrc.js +1 -0
  14. package/dist/lib/application/files/gadmin2-game-angle-demo/server/.prettierignore +1 -0
  15. package/dist/lib/application/files/gadmin2-game-angle-demo/server/README.md +2 -18
  16. package/dist/lib/application/files/gadmin2-game-angle-demo/server/gadmin-cli.json +1 -1
  17. package/dist/lib/application/files/gadmin2-game-angle-demo/server/migrate-between-pg-schemas.js +1232 -0
  18. package/dist/lib/application/files/gadmin2-game-angle-demo/server/package.json +65 -38
  19. package/dist/lib/application/files/gadmin2-game-angle-demo/server/prisma/.generator.prisma +4 -3
  20. package/dist/lib/application/files/gadmin2-game-angle-demo/server/prisma.config.ts +16 -0
  21. package/dist/lib/application/files/gadmin2-game-angle-demo/server/seed/games.ts +1 -71
  22. package/dist/lib/application/files/gadmin2-game-angle-demo/server/seed/index.ts +17 -21
  23. package/dist/lib/application/files/gadmin2-game-angle-demo/server/seed/permissions.ts +278 -0
  24. package/dist/lib/application/files/gadmin2-game-angle-demo/server/seed/seedDataMngtPages.ts +258 -0
  25. package/dist/lib/application/files/gadmin2-game-angle-demo/server/seed/users.ts +7 -0
  26. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/alias.config.ts +7 -0
  27. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/app.controller.ts +151 -11
  28. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/app.module.ts +29 -13
  29. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/app.service.ts +151 -12
  30. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/lib/auth.guard.ts +87 -41
  31. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/lib/http-cache.interceptor.ts +21 -0
  32. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/lib/logger.ts +19 -0
  33. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/lib/safe-log.util.ts +176 -0
  34. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/lib/{yufuid.ts → taihu.ts} +49 -34
  35. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/lib/tracing.ts +174 -0
  36. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/lib/trim.pipe.ts +51 -0
  37. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/lib/utils.ts +91 -0
  38. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/lib/woaAuth.ts +25 -12
  39. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/main.ts +22 -12
  40. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/audit/audit.controller.spec.ts +20 -0
  41. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/audit/audit.controller.ts +190 -0
  42. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/audit/audit.module.ts +10 -0
  43. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/audit/audit.service.spec.ts +338 -0
  44. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/audit/audit.service.ts +83 -0
  45. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/game/game.controller.spec.ts +20 -0
  46. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/game/game.controller.ts +188 -0
  47. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/game/game.module.ts +10 -0
  48. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/game/game.service.spec.ts +18 -0
  49. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/game/game.service.ts +83 -0
  50. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/page/page.controller.spec.ts +20 -0
  51. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/page/page.controller.ts +250 -0
  52. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/page/page.module.ts +10 -0
  53. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/page/page.service.spec.ts +18 -0
  54. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/page/page.service.ts +1051 -0
  55. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/pageResource/pageResource.controller.spec.ts +20 -0
  56. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/pageResource/pageResource.controller.ts +196 -0
  57. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/pageResource/pageResource.module.ts +13 -0
  58. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/pageResource/pageResource.service.spec.ts +18 -0
  59. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/pageResource/pageResource.service.ts +219 -0
  60. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/resource/resource.controller.spec.ts +20 -0
  61. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/resource/resource.controller.ts +196 -0
  62. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/resource/resource.module.ts +10 -0
  63. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/resource/resource.service.spec.ts +18 -0
  64. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/resource/resource.service.ts +199 -0
  65. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/role/role.controller.spec.ts +20 -0
  66. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/role/role.controller.ts +210 -0
  67. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/role/role.module.ts +12 -0
  68. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/role/role.service.spec.ts +18 -0
  69. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/role/role.service.ts +849 -0
  70. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/role/roles-refresher.service.ts +133 -0
  71. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/rolePages/rolePages.controller.spec.ts +20 -0
  72. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/rolePages/rolePages.controller.ts +196 -0
  73. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/rolePages/rolePages.module.ts +10 -0
  74. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/rolePages/rolePages.service.spec.ts +18 -0
  75. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/rolePages/rolePages.service.ts +201 -0
  76. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/roleResource/roleResource.controller.spec.ts +20 -0
  77. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/roleResource/roleResource.controller.ts +196 -0
  78. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/roleResource/roleResource.module.ts +10 -0
  79. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/roleResource/roleResource.service.spec.ts +18 -0
  80. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/roleResource/roleResource.service.ts +216 -0
  81. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/user/user.controller.spec.ts +20 -0
  82. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/user/user.controller.ts +198 -0
  83. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/user/user.module.ts +10 -0
  84. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/user/user.service.spec.ts +18 -0
  85. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/user/user.service.ts +104 -0
  86. package/dist/lib/application/files/gadmin2-game-angle-demo/server/start-prod.sh +130 -0
  87. package/dist/lib/application/files/gadmin2-game-angle-demo/server/tsconfig.json +18 -3
  88. package/dist/lib/application/files/gadmin2-game-angle-demo/web/index.html +19 -0
  89. package/dist/lib/application/files/gadmin2-game-angle-demo/web/package.json +34 -42
  90. package/dist/lib/application/files/gadmin2-game-angle-demo/web/postcss.config.cjs +6 -0
  91. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/App.tsx +111 -185
  92. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/auditLogProvider.ts +5 -5
  93. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/authProvider.ts +2 -2
  94. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/SqlModal.tsx +419 -0
  95. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/contexts/business/index.tsx +1 -1
  96. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/contexts/color-mode/index.tsx +49 -51
  97. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/custom-avatar.tsx +38 -0
  98. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/index.ts +4 -0
  99. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/{header/index.tsx → header.tsx} +22 -31
  100. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/index.ts +3 -1
  101. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/layout.tsx +32 -0
  102. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/logo.tsx +19 -0
  103. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/sider.tsx +331 -166
  104. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/title.tsx +61 -0
  105. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/pagination-total.tsx +21 -0
  106. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/tags/index.ts +1 -0
  107. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/tags/role-tag.tsx +44 -0
  108. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/text.tsx +74 -0
  109. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/config/http.ts +28 -0
  110. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/config/routeRegistry.tsx +258 -0
  111. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/constants/layout.ts +16 -0
  112. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/enums/audit-log.enum.ts +13 -0
  113. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/enums/index.ts +1 -0
  114. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/get-name-initials.ts +8 -0
  115. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/get-random-color.ts +27 -0
  116. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/http.ts +87 -0
  117. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/index.tsx +6 -1
  118. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/login.ts +22 -59
  119. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/utils.tsx +5 -0
  120. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useDynamicResources.tsx +211 -0
  121. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useFetchData.ts +33 -0
  122. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useRoles.ts +30 -0
  123. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useUserPageAccess.ts +339 -0
  124. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/i18n.ts +8 -4
  125. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/index.tsx +3 -11
  126. package/dist/lib/application/files/gadmin2-game-angle-demo/web/{public → src}/locales/en/common.json +1 -1
  127. package/dist/lib/application/files/gadmin2-game-angle-demo/web/{public → src}/locales/zh_CN/common.json +1 -1
  128. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/components/action-cell.css +3 -0
  129. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/components/action-cell.tsx +134 -0
  130. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/create.tsx +113 -0
  131. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/edit.tsx +122 -0
  132. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/index.ts +8 -0
  133. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/index.tsx +6 -0
  134. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/list.tsx +213 -0
  135. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/show.tsx +61 -0
  136. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/Components/AssignRolesModal.tsx +168 -0
  137. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/Components/CreatePageModal.tsx +42 -0
  138. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/Components/EditPageModal.tsx +42 -0
  139. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/Components/PageDetailDrawer.tsx +101 -0
  140. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/Components/PageFormModal.tsx +731 -0
  141. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/hooks/usePageManagement.ts +36 -0
  142. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/index.ts +1 -0
  143. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/list.tsx +1215 -0
  144. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/queries.ts +17 -0
  145. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/types.ts +45 -0
  146. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/permissionReadme/index.tsx +1089 -0
  147. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/resource/Components/CreateModal.tsx +25 -0
  148. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/resource/Components/EditModal.tsx +28 -0
  149. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/resource/Components/ResourceDetailDrawer.tsx +160 -0
  150. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/resource/Components/modal.tsx +202 -0
  151. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/resource/index.ts +2 -0
  152. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/resource/list.tsx +212 -0
  153. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/resource/queries.ts +10 -0
  154. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/resource/types.ts +9 -0
  155. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/Components/CreateModal.tsx +30 -0
  156. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/Components/EditModal.tsx +47 -0
  157. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/Components/RoleDetailDrawer.tsx +56 -0
  158. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/Components/modal.tsx +302 -0
  159. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/hooks/useRolePage.ts +35 -0
  160. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/index.ts +1 -0
  161. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/list.tsx +431 -0
  162. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/queries.ts +8 -0
  163. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/types.ts +8 -0
  164. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/components/create-modal.tsx +17 -0
  165. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/components/edit-modal.tsx +19 -0
  166. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/components/form-modal.tsx +188 -0
  167. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/components/index.ts +5 -0
  168. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/components/role-tag.tsx +48 -0
  169. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/components/show-drawer.tsx +140 -0
  170. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/index.ts +1 -0
  171. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/list.tsx +372 -0
  172. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/queries.ts +14 -0
  173. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/styles/antd.css +132 -0
  174. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/styles/fc.css +58 -0
  175. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/styles/index.css +128 -0
  176. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/styles/show-drawer.module.css +18 -0
  177. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/styles/show-page.module.css +21 -0
  178. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/types/audit-log.ts +1 -0
  179. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/types/index.ts +3 -0
  180. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/types/role.ts +7 -0
  181. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/types/user.ts +1 -0
  182. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/vite-env.d.ts +1 -0
  183. package/dist/lib/application/files/gadmin2-game-angle-demo/web/tsconfig.json +5 -4
  184. package/dist/lib/application/files/gadmin2-game-angle-demo/web/vite.config.ts +31 -0
  185. package/dist/lib/application/files/gadmin2-game-angle-demo/web/yarn.lock +8321 -0
  186. package/package.json +1 -1
  187. package/dist/lib/application/files/gadmin2-game-angle-demo/config/prisma/sample.prisma +0 -65
  188. package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/Source.ts +0 -76
  189. package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/Tasklog.ts +0 -76
  190. package/dist/lib/application/files/gadmin2-game-angle-demo/server/seed/roles.ts +0 -4
  191. package/dist/lib/application/files/gadmin2-game-angle-demo/web/craco.config.js +0 -27
  192. package/dist/lib/application/files/gadmin2-game-angle-demo/web/public/index.html +0 -53
  193. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/styles.ts +0 -10
  194. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/utils.ts +0 -76
  195. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/react-app-env.d.ts +0 -1
  196. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/reportWebVitals.ts +0 -15
  197. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/styles/antd.less +0 -79
  198. /package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/VanillaJSONEditor/{index.js → index.jsx} +0 -0
@@ -0,0 +1,48 @@
1
+ import React from "react";
2
+
3
+ import { CrownOutlined, StarOutlined, UserOutlined } from "@ant-design/icons";
4
+ import { Tag, type TagProps } from "antd";
5
+
6
+ type Props = {
7
+ role: any;
8
+ };
9
+
10
+ export const RoleTag: React.FC<Props> = ({ role }) => {
11
+ const variants: {
12
+ [key in any]: {
13
+ color: TagProps["color"];
14
+ icon: React.ReactNode;
15
+ };
16
+ } = {
17
+ ADMIN: {
18
+ color: "red",
19
+ icon: <CrownOutlined />,
20
+ },
21
+ SALES_INTERN: {
22
+ color: "blue",
23
+ icon: <UserOutlined />,
24
+ },
25
+ SALES_PERSON: {
26
+ color: "geekblue",
27
+ icon: <UserOutlined />,
28
+ },
29
+ SALES_MANAGER: {
30
+ color: "cyan",
31
+ icon: <StarOutlined />,
32
+ },
33
+ };
34
+
35
+ const text = role.replace("_", " ").toLowerCase();
36
+
37
+ return (
38
+ <Tag
39
+ style={{
40
+ textTransform: "capitalize",
41
+ }}
42
+ color={variants[role].color}
43
+ icon={variants[role].icon}
44
+ >
45
+ {text}
46
+ </Tag>
47
+ );
48
+ };
@@ -0,0 +1,140 @@
1
+ import React from "react";
2
+
3
+ import { TagField } from "@refinedev/antd";
4
+ import { useShow } from "@refinedev/core";
5
+
6
+ import { CloseOutlined } from "@ant-design/icons";
7
+ import { Button, Drawer, Space, Tag, Typography } from "antd";
8
+ import dayjs from "dayjs";
9
+
10
+ import styles from "@/styles/show-drawer.module.css";
11
+ import { User } from "@/types";
12
+
13
+ import { UserSelect } from "../queries";
14
+
15
+ const { Title, Text } = Typography;
16
+
17
+ interface ShowDrawerProps {
18
+ id?: number;
19
+ onClose: () => void;
20
+ }
21
+
22
+ export const ShowDrawer: React.FC<ShowDrawerProps> = ({ id, onClose }) => {
23
+ const { query } = useShow<User>({
24
+ resource: "user",
25
+ id,
26
+ meta: {
27
+ select: UserSelect,
28
+ },
29
+ });
30
+
31
+ const { data, isLoading, isError } = query;
32
+
33
+ if (isError) {
34
+ onClose();
35
+ return null;
36
+ }
37
+
38
+ const {
39
+ userid,
40
+ username,
41
+ roles,
42
+ isApiKey,
43
+ apiKey,
44
+ description,
45
+ isActive,
46
+ lastUsedAt,
47
+ creator,
48
+ createdAt,
49
+ updatedAt,
50
+ } = data?.data ?? {};
51
+
52
+ return (
53
+ <Drawer
54
+ open
55
+ onClose={onClose}
56
+ loading={isLoading}
57
+ width={756}
58
+ styles={{
59
+ body: { background: "#f5f5f5", padding: 0 },
60
+ header: { display: "none" },
61
+ }}
62
+ >
63
+ <div className={styles.header}>
64
+ <Button type="text" icon={<CloseOutlined />} onClick={onClose} />
65
+ </div>
66
+ <div className={styles.container}>
67
+ <div key="id">
68
+ <Title level={5}>ID</Title>
69
+ <Text>{id}</Text>
70
+ </div>
71
+ <div key="userid">
72
+ <Title level={5}>User ID</Title>
73
+ <Text>{userid}</Text>
74
+ </div>
75
+ <div key="username">
76
+ <Title level={5}>User Name</Title>
77
+ <Text>{username || "-"}</Text>
78
+ </div>
79
+ <div key="roles">
80
+ <Title level={5}>Roles</Title>
81
+ <Space>
82
+ {(Array.isArray(roles) ? roles : JSON.parse(roles || "[]"))?.map?.(
83
+ (v: string) => (
84
+ <TagField key={v} value={String(v)} />
85
+ )
86
+ )}
87
+ </Space>
88
+ </div>
89
+ <div key="isApiKey">
90
+ <Title level={5}>Is API Key</Title>
91
+ <Tag color={isApiKey ? "blue" : "default"}>
92
+ {isApiKey ? "Yes" : "No"}
93
+ </Tag>
94
+ </div>
95
+ {isApiKey && (
96
+ <>
97
+ <div key="apiKey">
98
+ <Title level={5}>API Key</Title>
99
+ <Text copyable={{ text: apiKey || "" }} style={{ fontFamily: "monospace" }}>
100
+ {apiKey || "-"}
101
+ </Text>
102
+ </div>
103
+ <div key="description">
104
+ <Title level={5}>Description</Title>
105
+ <Text>{description || "-"}</Text>
106
+ </div>
107
+ <div key="lastUsedAt">
108
+ <Title level={5}>Last Used At</Title>
109
+ <Text>
110
+ {lastUsedAt ? dayjs(lastUsedAt).format("YYYY-MM-DD HH:mm:ss") : "-"}
111
+ </Text>
112
+ </div>
113
+ </>
114
+ )}
115
+ <div key="isActive">
116
+ <Title level={5}>Is Active</Title>
117
+ <Tag color={isActive ? "green" : "red"}>
118
+ {isActive ? "Active" : "Inactive"}
119
+ </Tag>
120
+ </div>
121
+ <div key="creator">
122
+ <Title level={5}>Creator</Title>
123
+ <Text>{creator || "-"}</Text>
124
+ </div>
125
+ <div key="createdAt">
126
+ <Title level={5}>Created At</Title>
127
+ <Text>
128
+ {createdAt ? dayjs(createdAt).format("YYYY-MM-DD HH:mm:ss") : "-"}
129
+ </Text>
130
+ </div>
131
+ <div key="updatedAt">
132
+ <Title level={5}>Updated At</Title>
133
+ <Text>
134
+ {updatedAt ? dayjs(updatedAt).format("YYYY-MM-DD HH:mm:ss") : "-"}
135
+ </Text>
136
+ </div>
137
+ </div>
138
+ </Drawer>
139
+ );
140
+ };
@@ -0,0 +1,372 @@
1
+ import React, { type PropsWithChildren, useState } from "react";
2
+
3
+ import {
4
+ DeleteButton,
5
+ EditButton,
6
+ FilterDropdown,
7
+ List,
8
+ ShowButton,
9
+ useTable,
10
+ } from "@refinedev/antd";
11
+ import { getDefaultFilter, type HttpError, useGetIdentity } from "@refinedev/core";
12
+
13
+ import { PlusOutlined, CodeOutlined } from "@ant-design/icons";
14
+ import { Button, Form, Input, Select, Space, Table, Tag, Tooltip } from "antd";
15
+ import debounce from "lodash/debounce";
16
+
17
+ import {
18
+ CustomAvatar,
19
+ PaginationTotal,
20
+ RoleStatusTag,
21
+ Text,
22
+ } from "@/components";
23
+ import { useRoles } from "@/hooks/useRoles";
24
+ import { User } from "@/types";
25
+
26
+ import { CreateModal } from "./components/create-modal";
27
+ import { EditModal } from "./components/edit-modal";
28
+ import { ShowDrawer } from "./components/show-drawer";
29
+ import { LIST_CONTENT_PROPS } from "@/constants/layout";
30
+ import { SqlModal, generateUserSql } from "../../components/SqlModal";
31
+
32
+ export const UserListPage: React.FC<PropsWithChildren> = ({ children }) => {
33
+ const [form] = Form.useForm();
34
+ const { data: identity } = useGetIdentity<any>();
35
+
36
+ // Fetch roles from backend using custom hook
37
+ const { roleOptions, loading: rolesLoading } = useRoles();
38
+
39
+ // We want to always parse the query string even when syncWithLocation is
40
+ // deactivated, for hotlinking to work properly.
41
+ // 转换布尔字段过滤器的值(从字符串 "Yes"/"No" 转为 boolean)
42
+ const transformBooleanFilters = (filters: any[]) => {
43
+ return filters.map((filter) => {
44
+ if (
45
+ (filter.field === "isApiKey" || filter.field === "isActive") &&
46
+ filter.operator === "eq"
47
+ ) {
48
+ let boolValue: boolean | undefined;
49
+ if (filter.value === "Yes" || filter.value === "Active") {
50
+ boolValue = true;
51
+ } else if (filter.value === "No" || filter.value === "Inactive") {
52
+ boolValue = false;
53
+ }
54
+ return { ...filter, value: boolValue };
55
+ }
56
+ return filter;
57
+ });
58
+ };
59
+
60
+ const {
61
+ tableProps,
62
+ searchFormProps,
63
+ filters,
64
+ sorters,
65
+ tableQuery: tableQueryResult,
66
+ } = useTable<User, HttpError, Partial<User>>({
67
+ resource: "user",
68
+ pagination: {
69
+ pageSize: 20,
70
+ },
71
+ onSearch: (values: Partial<User>) => {
72
+ return Object.entries(values)
73
+ .filter(([, value]) => value !== undefined && value !== "")
74
+ .map(([field, value]) => ({
75
+ field,
76
+ operator: "contains" as const,
77
+ value: value || "",
78
+ }));
79
+ },
80
+ // https://refine.dev/docs/ui-integrations/ant-design/components/filter-dropdown/#example
81
+ filters: {
82
+ initial: [
83
+ { field: "username", operator: "contains", value: "" },
84
+ { field: "roles", operator: "contains", value: "" },
85
+ ],
86
+ defaultBehavior: "merge",
87
+ },
88
+ sorters: {
89
+ initial: [],
90
+ },
91
+ meta: {
92
+ transformFn: transformBooleanFilters,
93
+ },
94
+ });
95
+
96
+ const onSearch = () => {
97
+ const values = form.getFieldsValue();
98
+ searchFormProps?.onFinish?.({
99
+ ...values,
100
+ });
101
+ };
102
+
103
+ const debouncedOnChange = debounce(onSearch, 500);
104
+
105
+ // fix for ant design filter dropdown contains operator
106
+ filters.map((filter) => {
107
+ if (filter.operator === "contains" && Array.isArray(filter.value)) {
108
+ filter.value = filter.value.join(",");
109
+ }
110
+ });
111
+
112
+ // 修改modal状态类型
113
+ const [showModal, setShowModal] = useState<{
114
+ type: "show" | "edit" | "create" | null;
115
+ id: number | null;
116
+ }>({
117
+ type: null,
118
+ id: null,
119
+ });
120
+
121
+ const [sqlModal, setSqlModal] = useState<{
122
+ open: boolean;
123
+ title: string;
124
+ sql: string;
125
+ }>({ open: false, title: "", sql: "" });
126
+
127
+ const handleShowSql = (record: any) => {
128
+ const operator = { authorId: identity?.userid, authorName: identity?.username };
129
+ const sql = generateUserSql(record, operator);
130
+ setSqlModal({ open: true, title: `SQL — User: ${record.userid}`, sql });
131
+ };
132
+
133
+ // 处理modal关闭
134
+ const handleModalClose = () => {
135
+ setShowModal({ type: null, id: null });
136
+ };
137
+
138
+ return (
139
+ <div className="page-container">
140
+ <List
141
+ breadcrumb={false}
142
+ contentProps={LIST_CONTENT_PROPS}
143
+ headerButtons={() => {
144
+ return (
145
+ <Button
146
+ type="primary"
147
+ icon={<PlusOutlined />}
148
+ onClick={() => setShowModal({ type: "create", id: null })}
149
+ >
150
+ Add User
151
+ </Button>
152
+ );
153
+ }}
154
+ >
155
+ <Table
156
+ {...tableProps}
157
+ pagination={{
158
+ ...tableProps.pagination,
159
+ showTotal: (total) => (
160
+ <PaginationTotal total={total} entityName="user" />
161
+ ),
162
+ }}
163
+ rowKey="id"
164
+ >
165
+ <Table.Column
166
+ dataIndex="userid"
167
+ title="User ID"
168
+ render={(_, record) => {
169
+ return (
170
+ <Space>
171
+ <CustomAvatar
172
+ shape="square"
173
+ name={record.userid || ""}
174
+ src={`https://rhrc.woa.com/photo/150/${record.userid}.png`}
175
+ />
176
+ <Text style={{ whiteSpace: "nowrap" }}>{record.userid}</Text>
177
+ </Space>
178
+ );
179
+ }}
180
+ />
181
+ <Table.Column
182
+ dataIndex="username"
183
+ title="User Name"
184
+ filterDropdown={(props) => (
185
+ <FilterDropdown
186
+ {...props}
187
+ clearFilters={() => {
188
+ props.setSelectedKeys([]);
189
+ props.confirm?.();
190
+ }}
191
+ >
192
+ <Input />
193
+ </FilterDropdown>
194
+ )}
195
+ defaultFilteredValue={getDefaultFilter(
196
+ "username",
197
+ filters,
198
+ "contains"
199
+ )}
200
+ /*filterIcon={<SearchOutlined />}*/
201
+ />
202
+ <Table.Column
203
+ dataIndex="roles"
204
+ title="Roles"
205
+ defaultFilteredValue={getDefaultFilter(
206
+ "roles",
207
+ filters,
208
+ "contains"
209
+ )}
210
+ filterDropdown={(props) => (
211
+ <FilterDropdown
212
+ {...props}
213
+ clearFilters={() => {
214
+ props.setSelectedKeys([]);
215
+ props.confirm?.();
216
+ }}
217
+ >
218
+ <Select
219
+ options={roleOptions}
220
+ style={{ width: "150px" }}
221
+ placeholder="Select Role"
222
+ loading={rolesLoading}
223
+ />
224
+ </FilterDropdown>
225
+ )}
226
+ render={(value) => {
227
+ return JSON.parse(value || "[]").map(
228
+ (role: string) => (
229
+ <RoleStatusTag key={role} role={role} />
230
+ )
231
+ );
232
+ }}
233
+ />
234
+ <Table.Column
235
+ dataIndex="isApiKey"
236
+ title="API Key"
237
+ defaultFilteredValue={getDefaultFilter("isApiKey", filters, "eq")}
238
+ filterDropdown={(props) => (
239
+ <FilterDropdown
240
+ {...props}
241
+ mapValue={(selectedKeys) => {
242
+ if (selectedKeys?.[0] === "Yes") return true;
243
+ if (selectedKeys?.[0] === "No") return false;
244
+ return selectedKeys;
245
+ }}
246
+ clearFilters={() => {
247
+ props.setSelectedKeys([]);
248
+ props.confirm?.();
249
+ }}
250
+ >
251
+ <Select
252
+ style={{ width: "120px" }}
253
+ placeholder="Select"
254
+ allowClear
255
+ options={[
256
+ { label: "Yes", value: "Yes" },
257
+ { label: "No", value: "No" },
258
+ ]}
259
+ />
260
+ </FilterDropdown>
261
+ )}
262
+ render={(value) => (
263
+ <Tag color={value ? "blue" : "default"}>
264
+ {value ? "Yes" : "No"}
265
+ </Tag>
266
+ )}
267
+ />
268
+ <Table.Column
269
+ dataIndex="isActive"
270
+ title="Active"
271
+ defaultFilteredValue={getDefaultFilter("isActive", filters, "eq")}
272
+ filterDropdown={(props) => (
273
+ <FilterDropdown
274
+ {...props}
275
+ mapValue={(selectedKeys) => {
276
+ if (selectedKeys?.[0] === "Active") return true;
277
+ if (selectedKeys?.[0] === "Inactive") return false;
278
+ return selectedKeys;
279
+ }}
280
+ clearFilters={() => {
281
+ props.setSelectedKeys([]);
282
+ props.confirm?.();
283
+ }}
284
+ >
285
+ <Select
286
+ style={{ width: "120px" }}
287
+ placeholder="Select"
288
+ allowClear
289
+ options={[
290
+ { label: "Active", value: "Active" },
291
+ { label: "Inactive", value: "Inactive" },
292
+ ]}
293
+ />
294
+ </FilterDropdown>
295
+ )}
296
+ render={(value) => (
297
+ <Tag color={value ? "green" : "red"}>
298
+ {value ? "Active" : "Inactive"}
299
+ </Tag>
300
+ )}
301
+ />
302
+ <Table.Column
303
+ fixed="right"
304
+ title="Actions"
305
+ dataIndex="actions"
306
+ render={(_, record) => {
307
+ return (
308
+ <Space>
309
+ <ShowButton
310
+ hideText
311
+ size="small"
312
+ style={{ backgroundColor: "transparent" }}
313
+ onClick={() =>
314
+ setShowModal({ type: "show", id: record.id })
315
+ }
316
+ />
317
+ <EditButton
318
+ hideText
319
+ size="small"
320
+ style={{ backgroundColor: "transparent" }}
321
+ onClick={() =>
322
+ setShowModal({ type: "edit", id: record.id })
323
+ }
324
+ />
325
+ <Tooltip title="Generate SQL">
326
+ <Button
327
+ size="small"
328
+ icon={<CodeOutlined />}
329
+ style={{ backgroundColor: "transparent" }}
330
+ onClick={() => handleShowSql(record)}
331
+ />
332
+ </Tooltip>
333
+ <DeleteButton
334
+ hideText
335
+ size="small"
336
+ recordItemId={record.id}
337
+ style={{ backgroundColor: "transparent" }}
338
+ />
339
+ </Space>
340
+ );
341
+ }}
342
+ />
343
+ </Table>
344
+ </List>
345
+
346
+ {/* Show Drawer */}
347
+ {showModal.type === "show" && showModal.id && (
348
+ <ShowDrawer id={showModal.id} onClose={handleModalClose} />
349
+ )}
350
+
351
+ {/* Edit Modal */}
352
+ {showModal.type === "edit" && showModal.id && (
353
+ <EditModal id={showModal.id} onClose={handleModalClose} />
354
+ )}
355
+
356
+ {/* Create Modal */}
357
+ {showModal.type === "create" && (
358
+ <CreateModal onClose={handleModalClose} />
359
+ )}
360
+
361
+ {/* SQL Modal */}
362
+ <SqlModal
363
+ open={sqlModal.open}
364
+ onClose={() => setSqlModal({ open: false, title: "", sql: "" })}
365
+ title={sqlModal.title}
366
+ sql={sqlModal.sql}
367
+ />
368
+
369
+ {children}
370
+ </div>
371
+ );
372
+ };
@@ -0,0 +1,14 @@
1
+ export const UserSelect = {
2
+ id: true,
3
+ userid: true,
4
+ username: true,
5
+ roles: true,
6
+ isApiKey: true,
7
+ apiKey: true,
8
+ description: true,
9
+ isActive: true,
10
+ lastUsedAt: true,
11
+ creator: true,
12
+ createdAt: true,
13
+ updatedAt: true,
14
+ };
@@ -0,0 +1,132 @@
1
+ .ant-modal {
2
+ .ant-modal-content {
3
+ padding: 0;
4
+ }
5
+
6
+ .ant-modal-header {
7
+ padding: 20px 24px;
8
+ border-bottom: 1px solid #d9d9d9;
9
+ margin-bottom: 0px;
10
+ }
11
+
12
+ .ant-modal-close {
13
+ top: 20px;
14
+ }
15
+
16
+ .ant-modal-body {
17
+ padding: 20px 24px;
18
+ }
19
+
20
+ .ant-modal-footer {
21
+ padding: 20px 24px;
22
+ border-top: 1px solid #d9d9d9;
23
+ margin-top: 0px;
24
+ }
25
+ }
26
+
27
+ .kanban-update-modal {
28
+ .ant-modal-body {
29
+ padding: 0px;
30
+ }
31
+
32
+ .ant-modal-footer {
33
+ border-top: none;
34
+ text-align: unset;
35
+ }
36
+ }
37
+
38
+ .ant-select.kanban-users-form-select {
39
+ .ant-select-selector {
40
+ background-color: #fff;
41
+ }
42
+ }
43
+
44
+ .audit-log-table {
45
+ .ant-table {
46
+ .ant-table-tbody {
47
+ & > tr.ant-table-row:hover > td {
48
+ background: none !important;
49
+ }
50
+ }
51
+
52
+ .ant-table-cell {
53
+ vertical-align: top;
54
+ }
55
+ }
56
+ }
57
+
58
+ .ant-picker-calendar {
59
+ .ant-picker-panel {
60
+ .ant-picker-body {
61
+ .ant-picker-cell {
62
+ .ant-picker-calendar-date-content {
63
+ height: 92px;
64
+ overflow: hidden;
65
+ }
66
+ }
67
+ }
68
+ }
69
+ }
70
+
71
+ .ant-pagination-total-text {
72
+ margin-right: auto;
73
+ font-size: 14px !important;
74
+ color: rgba(0, 0, 0, 0.45) !important;
75
+ margin-inline-end: auto !important;
76
+ }
77
+
78
+ .ant-color-picker {
79
+ .ant-popover-content {
80
+ .ant-collapse-header {
81
+ display: none;
82
+ }
83
+ }
84
+ }
85
+
86
+ .ant-table-cell {
87
+ white-space: nowrap;
88
+ }
89
+
90
+ th.ant-table-column-sort {
91
+ background-color: #fafafa !important;
92
+ }
93
+
94
+ td.ant-table-column-sort {
95
+ background-color: #ffffff !important;
96
+ }
97
+
98
+ .ant-table-tbody > tr > td {
99
+ padding: 12px 11.25px 11px 16px !important;
100
+ }
101
+
102
+ /* .ant-table-tbody > tr:first-child > td {
103
+ padding: 0px !important;
104
+ } */
105
+
106
+ .ant-page-header-content {
107
+ padding-block-start: 8px;
108
+ }
109
+
110
+ tr.ant-table-measure-row {
111
+ visibility: collapse;
112
+ }
113
+ .ant-carousel .slick-prev,
114
+ .ant-carousel .slick-next,
115
+ .ant-carousel .slick-prev:hover,
116
+ .ant-carousel .slick-next:hover {
117
+ font-size: inherit;
118
+ color: currentColor;
119
+ }
120
+
121
+ .ant-spin-nested-loading,
122
+ .ant-spin-container {
123
+ width: 100%;
124
+ height: 100%;
125
+ }
126
+
127
+ .ant-picker-input > input[disabled] {
128
+ color: #777 !important;
129
+ }
130
+ .ant-table-expanded-row-level-1 {
131
+ background-color: #eee;
132
+ }