@gadmin2n/schematics 0.0.68 → 0.0.70

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 (223) hide show
  1. package/dist/lib/application/files/gadmin2-game-angle-demo/config/prisma/canvas.prisma +45 -0
  2. package/dist/lib/application/files/gadmin2-game-angle-demo/config/prisma/example.prisma +24 -23
  3. package/dist/lib/application/files/gadmin2-game-angle-demo/config/prisma/system.prisma +93 -90
  4. package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/Audit.ts +70 -0
  5. package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/Event.ts +3 -3
  6. package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/Page.ts +70 -0
  7. package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/PageResource.ts +70 -0
  8. package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/Resource.ts +70 -0
  9. package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/RolePages.ts +70 -0
  10. package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/RoleResource.ts +70 -0
  11. package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/SavedQuery.ts +70 -0
  12. package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/User.ts +70 -0
  13. package/dist/lib/application/files/gadmin2-game-angle-demo/readme.md +95 -2
  14. package/dist/lib/application/files/gadmin2-game-angle-demo/server/.eslintrc.js +4 -2
  15. package/dist/lib/application/files/gadmin2-game-angle-demo/server/.prettierignore +7 -1
  16. package/dist/lib/application/files/gadmin2-game-angle-demo/server/config/index.ts +1 -3
  17. package/dist/lib/application/files/gadmin2-game-angle-demo/server/gadmin-cli.json +2 -2
  18. package/dist/lib/application/files/gadmin2-game-angle-demo/server/package.json +6 -5
  19. package/dist/lib/application/files/gadmin2-game-angle-demo/server/scripts/lib/page-helpers.ts +157 -0
  20. package/dist/lib/application/files/gadmin2-game-angle-demo/server/scripts/page-manage.ts +290 -0
  21. package/dist/lib/application/files/gadmin2-game-angle-demo/server/scripts/permission-manage.ts +184 -0
  22. package/dist/lib/application/files/gadmin2-game-angle-demo/server/scripts/prismaModels.ts +143 -0
  23. package/dist/lib/application/files/gadmin2-game-angle-demo/server/scripts/sync-resources.ts +100 -0
  24. package/dist/lib/application/files/gadmin2-game-angle-demo/server/scripts/syncDataMngtPages.ts +119 -0
  25. package/dist/lib/application/files/gadmin2-game-angle-demo/server/seed/index.ts +1 -3
  26. package/dist/lib/application/files/gadmin2-game-angle-demo/server/seed/permissions.ts +109 -143
  27. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/main.ts +5 -2
  28. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/canvas/canvas.controller.spec.ts +20 -0
  29. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/canvas/canvas.controller.ts +81 -0
  30. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/canvas/canvas.dto.ts +49 -0
  31. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/canvas/canvas.module.ts +11 -0
  32. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/canvas/canvas.service.spec.ts +334 -0
  33. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/canvas/canvas.service.ts +249 -0
  34. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/index.ts +2 -1
  35. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/page/page.service.ts +2 -2
  36. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/role/role.service.ts +17 -4
  37. package/dist/lib/application/files/gadmin2-game-angle-demo/server/yarn.lock +7737 -0
  38. package/dist/lib/application/files/gadmin2-game-angle-demo/web/.env +1 -0
  39. package/dist/lib/application/files/gadmin2-game-angle-demo/web/.eslintrc.json +38 -0
  40. package/dist/lib/application/files/gadmin2-game-angle-demo/web/.prettierignore +2 -0
  41. package/dist/lib/application/files/gadmin2-game-angle-demo/web/dev-shell-entry.html +49 -0
  42. package/dist/lib/application/files/gadmin2-game-angle-demo/web/package.json +13 -2
  43. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/App.tsx +137 -111
  44. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/auditLogProvider.ts +46 -44
  45. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/authProvider.ts +32 -12
  46. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/BulkActions.tsx +74 -23
  47. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/ListPageHeader.tsx +9 -9
  48. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/RowActions.tsx +57 -31
  49. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/SearchBar.tsx +53 -24
  50. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/SqlModal.tsx +148 -72
  51. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/agentPanel/AgentContext.tsx +190 -16
  52. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/agentPanel/ElementInspector.tsx +914 -63
  53. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/agentPanel/agentAttributes.ts +17 -8
  54. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/agentPanel/index.ts +0 -10
  55. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/agentPanel/inspectorActions.ts +969 -46
  56. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/agentPanel/pagePathUtils.ts +66 -0
  57. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/agentPanel/promptGenerator.ts +85 -25
  58. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/agentPanel/propPatcher.ts +84 -0
  59. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/auditLog/components/eventList/index.tsx +16 -20
  60. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/auditLog/components/index.ts +4 -4
  61. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/auditLog/components/logButton/index.tsx +13 -13
  62. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/auditLog/components/logList/index.tsx +15 -16
  63. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/auditLog/components/modalDiffViewer/index.tsx +15 -15
  64. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/auditLog/index.tsx +2 -2
  65. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/BarChart/index.tsx +896 -0
  66. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/ChartSwitcher/index.tsx +219 -0
  67. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/ChartViewer/index.tsx +159 -0
  68. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/Filter/index.tsx +192 -0
  69. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/LineChart/index.tsx +1034 -0
  70. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/NumCard/NumCard.module.css +8 -0
  71. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/NumCard/index.tsx +509 -0
  72. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/NumLineCard/index.tsx +66 -0
  73. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/PieChart/index.tsx +552 -0
  74. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/RadarChart/index.tsx +263 -0
  75. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/Section/index.tsx +35 -0
  76. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/Table/index.tsx +207 -0
  77. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/TreemapChart/index.tsx +382 -0
  78. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/WorldMap/index.tsx +135 -0
  79. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/chart-constants.ts +53 -0
  80. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/icon/InfoIcon.tsx +8 -0
  81. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/icon/index.ts +1 -0
  82. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/map/config.ts +31 -0
  83. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/map/nameMap.json +9 -0
  84. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/map/world.geo.json +39349 -0
  85. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/metric-info-tooltip/index.tsx +19 -0
  86. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/contexts/business/index.tsx +12 -12
  87. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/contexts/color-mode/index.tsx +22 -26
  88. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/custom-avatar.tsx +13 -9
  89. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/index.ts +4 -4
  90. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/header.tsx +22 -37
  91. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/index.ts +4 -4
  92. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/layout.tsx +10 -10
  93. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/logo.tsx +1 -1
  94. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/sider.tsx +113 -65
  95. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/title.tsx +14 -14
  96. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/offLayoutArea/index.tsx +1 -1
  97. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/pagination-total.tsx +2 -2
  98. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/tags/index.ts +1 -1
  99. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/tags/role-tag.tsx +21 -21
  100. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/text.tsx +17 -13
  101. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/config/http.ts +26 -5
  102. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/config/routeRegistry.tsx +221 -51
  103. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/constants/layout.ts +3 -3
  104. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/dev-shell/AddDataModal.tsx +199 -0
  105. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/dev-shell/AddPageModal.tsx +335 -0
  106. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/dev-shell/DeleteDataConfirm.tsx +56 -0
  107. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/dev-shell/DevShell.tsx +401 -0
  108. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/dev-shell/EditDataModal.tsx +129 -0
  109. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/dev-shell/SkillMenu.tsx +202 -0
  110. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/dev-shell/UndoConfirm.tsx +36 -0
  111. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/dev-shell/index.tsx +8 -0
  112. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/dev-shell/style.css +835 -0
  113. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/enums/audit-log.enum.ts +8 -8
  114. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/enums/index.ts +1 -1
  115. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/form.tsx +120 -70
  116. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/get-name-initials.ts +3 -3
  117. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/get-random-color.ts +11 -11
  118. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/http.ts +16 -19
  119. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/index.tsx +1 -1
  120. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/list.tsx +99 -73
  121. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/login.ts +22 -27
  122. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/page-tree.ts +74 -0
  123. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/show.tsx +95 -51
  124. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/utils.tsx +7 -3
  125. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/types.ts +15 -15
  126. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useBatchDelete.ts +10 -10
  127. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useBatchOperations.ts +8 -7
  128. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useBatchOperationsCore.ts +10 -10
  129. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useBatchUpdate.ts +10 -10
  130. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useDynamicResources.tsx +36 -27
  131. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useECharts.tsx +144 -0
  132. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useFetchData.ts +4 -4
  133. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useListPageState.ts +34 -34
  134. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useRoles.ts +8 -4
  135. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useRowSelection.ts +1 -1
  136. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useUserPageAccess.ts +55 -41
  137. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/i18n.ts +8 -8
  138. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/index.tsx +9 -2
  139. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/locales/en/common.json +193 -0
  140. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/locales/zh_CN/common.json +194 -0
  141. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/plugins/devShellPlugin.ts +81 -0
  142. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/components/action-cell.tsx +37 -37
  143. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/create.tsx +23 -31
  144. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/edit.tsx +34 -35
  145. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/index.ts +1 -1
  146. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/index.tsx +4 -6
  147. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/list.tsx +41 -34
  148. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/show.tsx +33 -20
  149. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/CanvasCell.tsx +87 -0
  150. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/CanvasEditPage.tsx +192 -0
  151. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/CanvasListPage.tsx +409 -0
  152. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/CanvasPage.tsx +1372 -0
  153. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/CanvasToolbar.tsx +384 -0
  154. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/CodeFloatWindow.tsx +476 -0
  155. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/ComponentThumbnail.tsx +135 -0
  156. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/IsolatedLivePreview.tsx +101 -0
  157. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/LivePreview.tsx +236 -0
  158. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/PublishModal.tsx +200 -0
  159. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/canvasApi.ts +92 -0
  160. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/canvasConfigRegistry.tsx +25 -0
  161. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/canvasContextMenuRegistry.tsx +875 -0
  162. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/canvasDefaults.ts +126 -0
  163. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/canvasI18n.ts +11 -0
  164. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/BarChartDataSourceModal.tsx +115 -0
  165. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/ChartViewerConfigModal.tsx +217 -0
  166. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/LineChartDataSourceModal.tsx +153 -0
  167. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/NumCardDataSourceModal.tsx +211 -0
  168. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/PromptModal.tsx +90 -0
  169. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/RadarChartDataSourceModal.tsx +87 -0
  170. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/TableDataSourceModal.tsx +204 -0
  171. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/demos.ts +1153 -0
  172. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/index.tsx +2 -0
  173. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/sectionCompactor.ts +45 -0
  174. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/types.ts +45 -0
  175. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas-page/index.tsx +108 -0
  176. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/game/create.tsx +105 -0
  177. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/game/edit.tsx +121 -0
  178. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/game/index.tsx +4 -0
  179. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/game/list.tsx +237 -0
  180. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/game/show.tsx +74 -0
  181. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/Components/AssignRolesModal.tsx +29 -20
  182. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/Components/CreatePageModal.tsx +3 -3
  183. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/Components/EditPageModal.tsx +7 -3
  184. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/Components/PageDetailDrawer.tsx +58 -23
  185. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/Components/PageFormModal.tsx +206 -122
  186. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/hooks/usePageManagement.ts +8 -4
  187. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/index.ts +1 -1
  188. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/list.tsx +345 -190
  189. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/types.ts +1 -1
  190. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/permissionReadme/index.tsx +341 -340
  191. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/resource/Components/CreateModal.tsx +2 -2
  192. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/resource/Components/EditModal.tsx +2 -2
  193. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/resource/Components/ResourceDetailDrawer.tsx +41 -24
  194. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/resource/Components/modal.tsx +64 -36
  195. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/resource/index.ts +2 -2
  196. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/resource/list.tsx +78 -40
  197. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/Components/CreateModal.tsx +3 -3
  198. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/Components/EditModal.tsx +4 -4
  199. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/Components/RoleDetailDrawer.tsx +19 -9
  200. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/Components/modal.tsx +45 -47
  201. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/hooks/useRolePage.ts +4 -4
  202. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/index.ts +1 -1
  203. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/list.tsx +121 -147
  204. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/types.ts +1 -1
  205. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/components/create-modal.tsx +2 -2
  206. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/components/edit-modal.tsx +2 -2
  207. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/components/form-modal.tsx +25 -19
  208. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/components/index.ts +5 -5
  209. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/components/role-tag.tsx +10 -10
  210. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/components/show-drawer.tsx +31 -26
  211. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/index.ts +1 -1
  212. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/list.tsx +76 -71
  213. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/setupTests.ts +1 -1
  214. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/types/audit-log.ts +1 -1
  215. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/types/index.ts +3 -3
  216. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/types/role.ts +1 -1
  217. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/types/user.ts +1 -1
  218. package/dist/lib/application/files/gadmin2-game-angle-demo/web/vite.config.ts +42 -25
  219. package/dist/lib/application/files/gadmin2-game-angle-demo/web/yarn.lock +1193 -32
  220. package/package.json +1 -1
  221. package/dist/lib/application/files/gadmin2-game-angle-demo/server/seed/seedDataMngtPages.ts +0 -258
  222. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/agentPanel/AgentPanel.tsx +0 -497
  223. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/agentPanel/skills.ts +0 -464
@@ -0,0 +1,126 @@
1
+ import { allDemos } from './demos';
2
+ import type { ComponentVariant, PropDoc } from './types';
3
+
4
+ // ─── 从 demos.ts 提取 props 文档 ──────────────────────────────────────────────
5
+
6
+ function getPropsFor(title: string): PropDoc[] {
7
+ return allDemos.find((d) => d.title === title)?.props ?? [];
8
+ }
9
+
10
+ function getVariantsFor(title: string): ComponentVariant[] {
11
+ return allDemos.find((d) => d.title === title)?.variants ?? [];
12
+ }
13
+
14
+ // ─── 每种组件的画布默认配置 ───────────────────────────────────────────────────
15
+
16
+ export interface CanvasDefault {
17
+ code: string;
18
+ layout: { w: number; h: number; minW?: number; minH?: number };
19
+ props: PropDoc[];
20
+ imports: string;
21
+ variants: ComponentVariant[];
22
+ }
23
+
24
+ export const CANVAS_COMPONENTS: string[] = [
25
+ 'NumCard',
26
+ 'BarChart',
27
+ 'LineChart',
28
+ 'PieChart',
29
+ 'RadarChart',
30
+ 'TreemapChart',
31
+ 'Table',
32
+ 'WorldMap',
33
+ ];
34
+
35
+ export const CANVAS_DEFAULTS: Record<string, CanvasDefault> = {
36
+ NumCard: {
37
+ code: `<NumCard variant="default" title="指标" value={0} testId="canvas-numcard" />`,
38
+ layout: { w: 10, h: 8, minW: 4, minH: 2 },
39
+ props: getPropsFor('NumCard'),
40
+ variants: getVariantsFor('NumCard'),
41
+ imports: `import { NumCard } from "@/components/canvas/NumCard";`,
42
+ },
43
+
44
+ Filter: {
45
+ code: `<Filter layout="card-grid" columns={2} onSearch={() => {}} testId="canvas-filter"><Form.Item name="keyword"><Input /></Form.Item></Filter>`,
46
+ layout: { w: 48, h: 10, minW: 20, minH: 4 },
47
+ props: getPropsFor('Filter'),
48
+ variants: getVariantsFor('Filter'),
49
+ imports: `import { Filter } from "@/components/canvas/Filter";\nimport { Form, Select, Input } from "antd";`,
50
+ },
51
+
52
+ BarChart: {
53
+ code: `<BarChart variant="bar" data={[{ name: "A", value: 1 }]} height={300} legendShow={true} testId="canvas-barchart" />`,
54
+ layout: { w: 24, h: 20, minW: 8, minH: 8 },
55
+ props: getPropsFor('BarChart'),
56
+ variants: getVariantsFor('BarChart'),
57
+ imports: `import { BarChart } from "@/components/canvas/BarChart";`,
58
+ },
59
+
60
+ LineChart: {
61
+ code: `<LineChart data={[{ name: "A", value: 1 }]} height={300} legendShow={true} testId="canvas-linechart" />`,
62
+ layout: { w: 24, h: 20, minW: 10, minH: 8 },
63
+ props: getPropsFor('LineChart'),
64
+ variants: getVariantsFor('LineChart'),
65
+ imports: `import { LineChart } from "@/components/canvas/LineChart";`,
66
+ },
67
+
68
+ PieChart: {
69
+ code: `<PieChart variant="pie" data={[{ name: "A", value: 1 }]} height={300} legendShow={true} testId="canvas-piechart" />`,
70
+ layout: { w: 24, h: 20, minW: 8, minH: 8 },
71
+ props: getPropsFor('PieChart'),
72
+ variants: getVariantsFor('PieChart'),
73
+ imports: `import { PieChart } from "@/components/canvas/PieChart";`,
74
+ },
75
+
76
+ RadarChart: {
77
+ code: `<RadarChart indicators={[{ name: "A" }]} series={[{ name: "S", data: [1] }]} height={300} testId="canvas-radarchart" />`,
78
+ layout: { w: 24, h: 20, minW: 8, minH: 8 },
79
+ props: getPropsFor('RadarChart'),
80
+ variants: getVariantsFor('RadarChart'),
81
+ imports: `import { RadarChart } from "@/components/canvas/RadarChart";`,
82
+ },
83
+
84
+ TreemapChart: {
85
+ code: `<TreemapChart data={[{ name: "A", value: 1 }]} height={300} legendShow={true} testId="canvas-treemap" />`,
86
+ layout: { w: 24, h: 20, minW: 8, minH: 8 },
87
+ props: getPropsFor('TreemapChart'),
88
+ variants: getVariantsFor('TreemapChart'),
89
+ imports: `import { TreemapChart } from "@/components/canvas/TreemapChart";`,
90
+ },
91
+
92
+ Table: {
93
+ code: `<Table size="small" dataSource={[]} columns={[]} testId="canvas-table" />`,
94
+ layout: { w: 24, h: 20, minW: 10, minH: 5 },
95
+ props: getPropsFor('Table'),
96
+ variants: getVariantsFor('Table'),
97
+ imports: `import { Table } from "@/components/canvas/Table";`,
98
+ },
99
+
100
+ WorldMap: {
101
+ code: `<WorldMap option={{ geo: {}, series: [] }} style={{ height: 400 }} testId="canvas-worldmap" />`,
102
+ layout: { w: 32, h: 20, minW: 14, minH: 10 },
103
+ props: getPropsFor('WorldMap'),
104
+ variants: getVariantsFor('WorldMap'),
105
+ imports: `import { WorldMap } from "@/components/canvas/WorldMap";`,
106
+ },
107
+
108
+ ChartViewer: {
109
+ code: `<ChartViewer
110
+ height={300}
111
+ testId="canvas-chartviewer"
112
+ />`,
113
+ layout: { w: 24, h: 20, minW: 8, minH: 8 },
114
+ props: getPropsFor('ChartViewer'),
115
+ variants: getVariantsFor('ChartViewer'),
116
+ imports: `import { ChartViewer } from "@/components/canvas/ChartViewer";`,
117
+ },
118
+
119
+ Section: {
120
+ code: `<Section title="分组标题" testId="canvas-section" />`,
121
+ layout: { w: 24, h: 14, minW: 8, minH: 4 },
122
+ props: getPropsFor('Section'),
123
+ variants: getVariantsFor('Section'),
124
+ imports: `import { Section } from "@/components/canvas/Section";`,
125
+ },
126
+ };
@@ -0,0 +1,11 @@
1
+ import type { TFunction } from 'i18next';
2
+
3
+ /** 根据组件 type 获取本地化 display name */
4
+ export function getComponentLabel(type: string, t: TFunction): string {
5
+ return t(`canvas.components.${type}`, { defaultValue: type });
6
+ }
7
+
8
+ /** 根据 variant label key 获取本地化名称 */
9
+ export function getVariantLabel(label: string, t: TFunction): string {
10
+ return t(`canvas.variants.${label}`, { defaultValue: label });
11
+ }
@@ -0,0 +1,115 @@
1
+ import React, { useState, useEffect } from 'react';
2
+ import { Modal, Radio, Input, Checkbox } from 'antd';
3
+ import { useTranslation } from 'react-i18next';
4
+
5
+ export interface BarChartDataSourceResult {
6
+ direction: 'vertical' | 'horizontal';
7
+ showGrid: boolean;
8
+ showLabel: boolean;
9
+ dataDescription: string;
10
+ code: string;
11
+ }
12
+
13
+ interface BarChartDataSourceModalProps {
14
+ open: boolean;
15
+ code: string;
16
+ onConfirm: (result: BarChartDataSourceResult) => void;
17
+ onCancel: () => void;
18
+ }
19
+
20
+ const BarChartDataSourceModal: React.FC<BarChartDataSourceModalProps> = ({
21
+ open,
22
+ code,
23
+ onConfirm,
24
+ onCancel,
25
+ }) => {
26
+ const { t } = useTranslation();
27
+ const DIRECTIONS = [
28
+ { label: t('canvas.dataSourceModal.barVertical'), value: 'vertical' },
29
+ { label: t('canvas.dataSourceModal.barHorizontal'), value: 'horizontal' },
30
+ ];
31
+
32
+ const [direction, setDirection] = useState<'vertical' | 'horizontal'>(
33
+ 'vertical',
34
+ );
35
+ const [showGrid, setShowGrid] = useState(true);
36
+ const [showLabel, setShowLabel] = useState(true);
37
+ const [dataDescription, setDataDescription] = useState('');
38
+
39
+ useEffect(() => {
40
+ if (open) {
41
+ const hasHorizontal = /direction\s*=\s*"horizontal"/.test(code);
42
+ setDirection(hasHorizontal ? 'horizontal' : 'vertical');
43
+ setShowGrid(!/showGrid\s*=\s*\{false\}/.test(code));
44
+ setShowLabel(!/showLabel\s*=\s*\{false\}/.test(code));
45
+ setDataDescription('');
46
+ }
47
+ }, [open, code]);
48
+
49
+ const handleConfirm = () => {
50
+ onConfirm({
51
+ direction,
52
+ showGrid,
53
+ showLabel,
54
+ dataDescription: dataDescription.trim(),
55
+ code,
56
+ });
57
+ };
58
+
59
+ return (
60
+ <Modal
61
+ title={t('canvas.dataSourceModal.title')}
62
+ open={open}
63
+ onOk={handleConfirm}
64
+ onCancel={onCancel}
65
+ okText={t('canvas.dataSourceModal.ok')}
66
+ cancelText={t('canvas.dataSourceModal.cancel')}
67
+ width={420}
68
+ centered
69
+ destroyOnClose
70
+ >
71
+ <div style={{ display: 'flex', flexDirection: 'column', gap: 16 }}>
72
+ <div>
73
+ <div style={{ marginBottom: 6, fontSize: 13, color: '#595959' }}>
74
+ 方向:
75
+ </div>
76
+ <Radio.Group
77
+ options={DIRECTIONS}
78
+ value={direction}
79
+ onChange={(e) => setDirection(e.target.value)}
80
+ />
81
+ </div>
82
+
83
+ <div style={{ display: 'flex', flexDirection: 'column', gap: 8 }}>
84
+ <Checkbox
85
+ checked={showGrid}
86
+ onChange={(e) => setShowGrid(e.target.checked)}
87
+ >
88
+ 显示网格线
89
+ </Checkbox>
90
+ <Checkbox
91
+ checked={showLabel}
92
+ onChange={(e) => setShowLabel(e.target.checked)}
93
+ >
94
+ 显示数据标签
95
+ </Checkbox>
96
+ </div>
97
+
98
+ <div>
99
+ <div style={{ marginBottom: 6, fontSize: 13, color: '#595959' }}>
100
+ 数据来源描述:
101
+ </div>
102
+ <Input.TextArea
103
+ value={dataDescription}
104
+ onChange={(e) => setDataDescription(e.target.value)}
105
+ placeholder={t('canvas.dataSourceModal.barPlaceholder')}
106
+ rows={3}
107
+ style={{ resize: 'vertical' }}
108
+ />
109
+ </div>
110
+ </div>
111
+ </Modal>
112
+ );
113
+ };
114
+
115
+ export default BarChartDataSourceModal;
@@ -0,0 +1,217 @@
1
+ import React, { useState, useCallback } from 'react';
2
+ import { Modal, Checkbox, Flex } from 'antd';
3
+ import {
4
+ HolderOutlined,
5
+ BarChartOutlined,
6
+ LineChartOutlined,
7
+ PieChartOutlined,
8
+ } from '@ant-design/icons';
9
+ import {
10
+ DndContext,
11
+ PointerSensor,
12
+ useSensor,
13
+ useSensors,
14
+ type DragEndEvent,
15
+ } from '@dnd-kit/core';
16
+ import {
17
+ SortableContext,
18
+ arrayMove,
19
+ useSortable,
20
+ verticalListSortingStrategy,
21
+ } from '@dnd-kit/sortable';
22
+ import { CSS } from '@dnd-kit/utilities';
23
+ import { restrictToVerticalAxis } from '@dnd-kit/modifiers';
24
+ import type { CanvasConfigModalProps } from '../canvasConfigRegistry';
25
+ import type { ChartViewerChart } from '@/components/canvas/ChartViewer';
26
+
27
+ // ─── 所有可选图表的元信息 ─────────────────────────────────────────────────────
28
+
29
+ const ALL_CHARTS: {
30
+ key: ChartViewerChart;
31
+ label: string;
32
+ icon: React.ReactNode;
33
+ }[] = [
34
+ { key: 'bar', label: '柱状图', icon: <BarChartOutlined /> },
35
+ { key: 'line', label: '折线图', icon: <LineChartOutlined /> },
36
+ { key: 'pie', label: '饼图', icon: <PieChartOutlined /> },
37
+ ];
38
+
39
+ // ─── 从 code 字符串解析 charts prop ──────────────────────────────────────────
40
+
41
+ function parseCharts(code: string): ChartViewerChart[] {
42
+ const match = code.match(/charts=\{(\[.*?\])\}/s);
43
+ if (!match) return ['bar', 'line', 'pie'];
44
+ try {
45
+ const parsed = JSON.parse(match[1].replace(/'/g, '"'));
46
+ if (Array.isArray(parsed)) return parsed as ChartViewerChart[];
47
+ } catch {
48
+ // 解析失败时返回默认值
49
+ }
50
+ return ['bar', 'line', 'pie'];
51
+ }
52
+
53
+ // ─── 将新的 charts 写回 code 字符串 ──────────────────────────────────────────
54
+
55
+ function writeCharts(code: string, charts: ChartViewerChart[]): string {
56
+ const chartsStr = `charts={${JSON.stringify(charts)}}`;
57
+ // 已有 charts prop → 替换
58
+ if (/charts=\{.*?\}/s.test(code)) {
59
+ return code.replace(/charts=\{.*?\}/s, chartsStr);
60
+ }
61
+ // 没有 charts prop → 插入到 testId 之前
62
+ return code.replace(/(testId=)/, `${chartsStr}\n $1`);
63
+ }
64
+
65
+ // ─── SortableChartItem ────────────────────────────────────────────────────────
66
+
67
+ interface SortableChartItemProps {
68
+ chartKey: ChartViewerChart;
69
+ label: string;
70
+ icon: React.ReactNode;
71
+ checked: boolean;
72
+ disabled: boolean;
73
+ onToggle: (key: ChartViewerChart, checked: boolean) => void;
74
+ }
75
+
76
+ const SortableChartItem: React.FC<SortableChartItemProps> = ({
77
+ chartKey,
78
+ label,
79
+ icon,
80
+ checked,
81
+ disabled,
82
+ onToggle,
83
+ }) => {
84
+ const {
85
+ attributes,
86
+ listeners,
87
+ setNodeRef,
88
+ transform,
89
+ transition,
90
+ isDragging,
91
+ } = useSortable({ id: chartKey });
92
+
93
+ return (
94
+ <Flex
95
+ ref={setNodeRef}
96
+ align="center"
97
+ gap={12}
98
+ style={{
99
+ transform: CSS.Transform.toString(transform),
100
+ transition,
101
+ opacity: isDragging ? 0.5 : 1,
102
+ padding: '8px 0',
103
+ borderBottom: '1px solid #f0f0f0',
104
+ userSelect: 'none',
105
+ }}
106
+ >
107
+ <HolderOutlined
108
+ {...attributes}
109
+ {...listeners}
110
+ style={{
111
+ color: '#ccc',
112
+ cursor: 'grab',
113
+ touchAction: 'none',
114
+ fontSize: 16,
115
+ }}
116
+ />
117
+ <Checkbox
118
+ checked={checked}
119
+ disabled={disabled}
120
+ onChange={(e) => onToggle(chartKey, e.target.checked)}
121
+ />
122
+ {icon}
123
+ <span style={{ fontSize: 14 }}>{label}</span>
124
+ </Flex>
125
+ );
126
+ };
127
+
128
+ // ─── ChartViewerConfigModal ───────────────────────────────────────────────────
129
+
130
+ const ChartViewerConfigModal: React.FC<CanvasConfigModalProps> = ({
131
+ code,
132
+ onConfirm,
133
+ onCancel,
134
+ }) => {
135
+ const initialCharts = parseCharts(code);
136
+ // 将 ALL_CHARTS 按 initialCharts 顺序排列,未在 initialCharts 中的追加到末尾
137
+ const initialOrder: ChartViewerChart[] = [
138
+ ...initialCharts,
139
+ ...ALL_CHARTS.map((c) => c.key).filter((k) => !initialCharts.includes(k)),
140
+ ];
141
+
142
+ const [order, setOrder] = useState<ChartViewerChart[]>(initialOrder);
143
+ const [checked, setChecked] = useState<Set<ChartViewerChart>>(
144
+ new Set(initialCharts),
145
+ );
146
+
147
+ const checkedCount = checked.size;
148
+
149
+ const sensors = useSensors(
150
+ useSensor(PointerSensor, { activationConstraint: { distance: 5 } }),
151
+ );
152
+
153
+ const handleToggle = useCallback(
154
+ (key: ChartViewerChart, isChecked: boolean) => {
155
+ setChecked((prev) => {
156
+ const next = new Set(prev);
157
+ if (isChecked) next.add(key);
158
+ else next.delete(key);
159
+ return next;
160
+ });
161
+ },
162
+ [],
163
+ );
164
+
165
+ const handleDragEnd = useCallback((event: DragEndEvent) => {
166
+ const { active, over } = event;
167
+ if (!over || active.id === over.id) return;
168
+ setOrder((prev) => {
169
+ const oldIndex = prev.indexOf(active.id as ChartViewerChart);
170
+ const newIndex = prev.indexOf(over.id as ChartViewerChart);
171
+ return arrayMove(prev, oldIndex, newIndex);
172
+ });
173
+ }, []);
174
+
175
+ const handleOk = useCallback(() => {
176
+ // 按当前 order 顺序,只取 checked 中的项
177
+ const result = order.filter((k) => checked.has(k));
178
+ onConfirm(writeCharts(code, result));
179
+ }, [order, checked, code, onConfirm]);
180
+
181
+ return (
182
+ <Modal
183
+ open
184
+ title="配置图表"
185
+ okText="确认"
186
+ cancelText="取消"
187
+ onOk={handleOk}
188
+ onCancel={onCancel}
189
+ width={360}
190
+ >
191
+ <DndContext
192
+ sensors={sensors}
193
+ modifiers={[restrictToVerticalAxis]}
194
+ onDragEnd={handleDragEnd}
195
+ >
196
+ <SortableContext items={order} strategy={verticalListSortingStrategy}>
197
+ {order.map((key) => {
198
+ const meta = ALL_CHARTS.find((c) => c.key === key)!;
199
+ return (
200
+ <SortableChartItem
201
+ key={key}
202
+ chartKey={key}
203
+ label={meta.label}
204
+ icon={meta.icon}
205
+ checked={checked.has(key)}
206
+ disabled={checked.has(key) && checkedCount === 1}
207
+ onToggle={handleToggle}
208
+ />
209
+ );
210
+ })}
211
+ </SortableContext>
212
+ </DndContext>
213
+ </Modal>
214
+ );
215
+ };
216
+
217
+ export default ChartViewerConfigModal;
@@ -0,0 +1,153 @@
1
+ import React, { useState, useEffect } from 'react';
2
+ import { Modal, Checkbox, Input } from 'antd';
3
+ import { useTranslation } from 'react-i18next';
4
+
5
+ export interface LineChartDataSourceResult {
6
+ legendShow: boolean;
7
+ showGrid: boolean;
8
+ showAxis: boolean;
9
+ showDots: boolean;
10
+ showLabel: boolean;
11
+ stacked: boolean;
12
+ area: boolean;
13
+ smooth: boolean;
14
+ dataDescription: string;
15
+ code: string;
16
+ }
17
+
18
+ interface LineChartDataSourceModalProps {
19
+ open: boolean;
20
+ code: string;
21
+ onConfirm: (result: LineChartDataSourceResult) => void;
22
+ onCancel: () => void;
23
+ }
24
+
25
+ const LineChartDataSourceModal: React.FC<LineChartDataSourceModalProps> = ({
26
+ open,
27
+ code,
28
+ onConfirm,
29
+ onCancel,
30
+ }) => {
31
+ const { t } = useTranslation();
32
+ const [legendShow, setLegendShow] = useState(true);
33
+ const [showGrid, setShowGrid] = useState(true);
34
+ const [showAxis, setShowAxis] = useState(true);
35
+ const [showDots, setShowDots] = useState(false);
36
+ const [showLabel, setShowLabel] = useState(false);
37
+ const [stacked, setStacked] = useState(false);
38
+ const [area, setArea] = useState(false);
39
+ const [smooth, setSmooth] = useState(false);
40
+ const [dataDescription, setDataDescription] = useState('');
41
+
42
+ useEffect(() => {
43
+ if (open) {
44
+ // 从 code 解析当前状态
45
+ setLegendShow(!/legendShow\s*=\s*\{false\}/.test(code));
46
+ setShowGrid(!/showGrid\s*=\s*\{false\}/.test(code));
47
+ setShowAxis(!/showAxis\s*=\s*\{false\}/.test(code));
48
+ setShowDots(/showDots\s*=\s*\{true\}/.test(code));
49
+ setShowLabel(/showLabel\s*=\s*\{true\}/.test(code));
50
+ setStacked(/stacked\s*=\s*\{true\}/.test(code));
51
+ setArea(/area\s*=\s*\{true\}/.test(code));
52
+ setSmooth(
53
+ /smooth\s*=\s*\{true\}/.test(code) || /\bsmooth\b(?!\s*=)/.test(code),
54
+ );
55
+ setDataDescription('');
56
+ }
57
+ }, [open, code]);
58
+
59
+ const handleConfirm = () => {
60
+ onConfirm({
61
+ legendShow,
62
+ showGrid,
63
+ showAxis,
64
+ showDots,
65
+ showLabel,
66
+ stacked,
67
+ area,
68
+ smooth,
69
+ dataDescription: dataDescription.trim(),
70
+ code,
71
+ });
72
+ };
73
+
74
+ return (
75
+ <Modal
76
+ title={t('canvas.dataSourceModal.title')}
77
+ open={open}
78
+ onOk={handleConfirm}
79
+ onCancel={onCancel}
80
+ okText={t('canvas.dataSourceModal.ok')}
81
+ cancelText={t('canvas.dataSourceModal.cancel')}
82
+ width={420}
83
+ centered
84
+ destroyOnClose
85
+ >
86
+ <div style={{ display: 'flex', flexDirection: 'column', gap: 16 }}>
87
+ <Checkbox
88
+ checked={legendShow}
89
+ onChange={(e) => setLegendShow(e.target.checked)}
90
+ >
91
+ {t('canvas.dataSourceModal.showLegend')}
92
+ </Checkbox>
93
+ <Checkbox
94
+ checked={showGrid}
95
+ onChange={(e) => setShowGrid(e.target.checked)}
96
+ >
97
+ 显示网格线
98
+ </Checkbox>
99
+ <Checkbox
100
+ checked={showAxis}
101
+ onChange={(e) => setShowAxis(e.target.checked)}
102
+ >
103
+ 显示坐标轴
104
+ </Checkbox>
105
+ <Checkbox
106
+ checked={showDots}
107
+ onChange={(e) => setShowDots(e.target.checked)}
108
+ >
109
+ 显示坐标点
110
+ </Checkbox>
111
+ {showDots && (
112
+ <Checkbox
113
+ checked={showLabel}
114
+ onChange={(e) => setShowLabel(e.target.checked)}
115
+ style={{ marginLeft: 24 }}
116
+ >
117
+ 显示坐标点数据
118
+ </Checkbox>
119
+ )}
120
+ <Checkbox
121
+ checked={stacked}
122
+ onChange={(e) => setStacked(e.target.checked)}
123
+ >
124
+ 堆叠模式
125
+ </Checkbox>
126
+ <Checkbox checked={area} onChange={(e) => setArea(e.target.checked)}>
127
+ 面积填充
128
+ </Checkbox>
129
+ <Checkbox
130
+ checked={smooth}
131
+ onChange={(e) => setSmooth(e.target.checked)}
132
+ >
133
+ 拟合曲线
134
+ </Checkbox>
135
+
136
+ <div style={{ marginTop: 4 }}>
137
+ <div style={{ marginBottom: 6, fontSize: 13, color: '#595959' }}>
138
+ 数据来源描述:
139
+ </div>
140
+ <Input.TextArea
141
+ value={dataDescription}
142
+ onChange={(e) => setDataDescription(e.target.value)}
143
+ placeholder={t('canvas.dataSourceModal.linePlaceholder')}
144
+ rows={3}
145
+ style={{ resize: 'vertical' }}
146
+ />
147
+ </div>
148
+ </div>
149
+ </Modal>
150
+ );
151
+ };
152
+
153
+ export default LineChartDataSourceModal;