@gadmin2n/schematics 0.0.69 → 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.
- package/dist/lib/application/files/gadmin2-game-angle-demo/config/prisma/canvas.prisma +45 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/config/prisma/example.prisma +24 -23
- package/dist/lib/application/files/gadmin2-game-angle-demo/config/prisma/system.prisma +93 -90
- package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/Audit.ts +70 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/Event.ts +3 -3
- package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/Page.ts +70 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/PageResource.ts +70 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/Resource.ts +70 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/RolePages.ts +70 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/RoleResource.ts +70 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/SavedQuery.ts +70 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/User.ts +70 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/readme.md +95 -2
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/.eslintrc.js +4 -2
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/.prettierignore +7 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/config/index.ts +1 -3
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/gadmin-cli.json +1 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/package.json +6 -5
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/scripts/lib/page-helpers.ts +157 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/scripts/page-manage.ts +290 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/scripts/permission-manage.ts +184 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/scripts/prismaModels.ts +143 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/scripts/sync-resources.ts +100 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/scripts/syncDataMngtPages.ts +119 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/seed/index.ts +1 -3
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/seed/permissions.ts +109 -143
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/main.ts +5 -2
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/canvas/canvas.controller.spec.ts +20 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/canvas/canvas.controller.ts +81 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/canvas/canvas.dto.ts +49 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/canvas/canvas.module.ts +11 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/canvas/canvas.service.spec.ts +334 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/canvas/canvas.service.ts +249 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/index.ts +2 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/page/page.service.ts +2 -2
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/role/role.service.ts +17 -4
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/yarn.lock +7737 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/.env +1 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/.eslintrc.json +38 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/.prettierignore +2 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/dev-shell-entry.html +49 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/package.json +13 -2
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/App.tsx +137 -111
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/auditLogProvider.ts +46 -44
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/authProvider.ts +32 -12
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/BulkActions.tsx +74 -23
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/ListPageHeader.tsx +9 -9
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/RowActions.tsx +57 -31
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/SearchBar.tsx +53 -24
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/SqlModal.tsx +148 -72
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/agentPanel/AgentContext.tsx +190 -16
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/agentPanel/ElementInspector.tsx +914 -63
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/agentPanel/agentAttributes.ts +17 -8
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/agentPanel/index.ts +0 -10
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/agentPanel/inspectorActions.ts +969 -46
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/agentPanel/pagePathUtils.ts +66 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/agentPanel/promptGenerator.ts +85 -25
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/agentPanel/propPatcher.ts +84 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/auditLog/components/eventList/index.tsx +16 -20
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/auditLog/components/index.ts +4 -4
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/auditLog/components/logButton/index.tsx +13 -13
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/auditLog/components/logList/index.tsx +15 -16
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/auditLog/components/modalDiffViewer/index.tsx +15 -15
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/auditLog/index.tsx +2 -2
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/BarChart/index.tsx +896 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/ChartSwitcher/index.tsx +219 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/ChartViewer/index.tsx +159 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/Filter/index.tsx +192 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/LineChart/index.tsx +1034 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/NumCard/NumCard.module.css +8 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/NumCard/index.tsx +509 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/NumLineCard/index.tsx +66 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/PieChart/index.tsx +552 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/RadarChart/index.tsx +263 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/Section/index.tsx +35 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/Table/index.tsx +207 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/TreemapChart/index.tsx +382 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/WorldMap/index.tsx +135 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/chart-constants.ts +53 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/icon/InfoIcon.tsx +8 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/icon/index.ts +1 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/map/config.ts +31 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/map/nameMap.json +9 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/map/world.geo.json +39349 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/metric-info-tooltip/index.tsx +19 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/contexts/business/index.tsx +12 -12
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/contexts/color-mode/index.tsx +22 -26
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/custom-avatar.tsx +13 -9
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/index.ts +4 -4
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/header.tsx +22 -37
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/index.ts +4 -4
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/layout.tsx +10 -10
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/logo.tsx +1 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/sider.tsx +113 -65
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/title.tsx +14 -14
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/offLayoutArea/index.tsx +1 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/pagination-total.tsx +2 -2
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/tags/index.ts +1 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/tags/role-tag.tsx +21 -21
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/text.tsx +17 -13
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/config/http.ts +26 -5
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/config/routeRegistry.tsx +221 -51
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/constants/layout.ts +3 -3
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/dev-shell/AddDataModal.tsx +199 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/dev-shell/AddPageModal.tsx +335 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/dev-shell/DeleteDataConfirm.tsx +56 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/dev-shell/DevShell.tsx +401 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/dev-shell/EditDataModal.tsx +129 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/dev-shell/SkillMenu.tsx +202 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/dev-shell/UndoConfirm.tsx +36 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/dev-shell/index.tsx +8 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/dev-shell/style.css +835 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/enums/audit-log.enum.ts +8 -8
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/enums/index.ts +1 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/form.tsx +120 -70
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/get-name-initials.ts +3 -3
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/get-random-color.ts +11 -11
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/http.ts +16 -19
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/index.tsx +1 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/list.tsx +99 -73
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/login.ts +22 -27
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/page-tree.ts +74 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/show.tsx +95 -51
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/utils.tsx +7 -3
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/types.ts +15 -15
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useBatchDelete.ts +10 -10
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useBatchOperations.ts +8 -7
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useBatchOperationsCore.ts +10 -10
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useBatchUpdate.ts +10 -10
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useDynamicResources.tsx +36 -27
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useECharts.tsx +144 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useFetchData.ts +4 -4
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useListPageState.ts +34 -34
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useRoles.ts +8 -4
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useRowSelection.ts +1 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/hooks/useUserPageAccess.ts +55 -41
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/i18n.ts +8 -8
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/index.tsx +9 -2
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/locales/en/common.json +193 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/locales/zh_CN/common.json +194 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/plugins/devShellPlugin.ts +81 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/components/action-cell.tsx +37 -37
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/create.tsx +23 -31
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/edit.tsx +34 -35
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/index.ts +1 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/index.tsx +4 -6
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/list.tsx +41 -34
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/audit/show.tsx +33 -20
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/CanvasCell.tsx +87 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/CanvasEditPage.tsx +192 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/CanvasListPage.tsx +409 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/CanvasPage.tsx +1372 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/CanvasToolbar.tsx +384 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/CodeFloatWindow.tsx +476 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/ComponentThumbnail.tsx +135 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/IsolatedLivePreview.tsx +101 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/LivePreview.tsx +236 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/PublishModal.tsx +200 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/canvasApi.ts +92 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/canvasConfigRegistry.tsx +25 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/canvasContextMenuRegistry.tsx +875 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/canvasDefaults.ts +126 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/canvasI18n.ts +11 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/BarChartDataSourceModal.tsx +115 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/ChartViewerConfigModal.tsx +217 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/LineChartDataSourceModal.tsx +153 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/NumCardDataSourceModal.tsx +211 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/PromptModal.tsx +90 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/RadarChartDataSourceModal.tsx +87 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/TableDataSourceModal.tsx +204 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/demos.ts +1153 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/index.tsx +2 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/sectionCompactor.ts +45 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/types.ts +45 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas-page/index.tsx +108 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/game/create.tsx +105 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/game/edit.tsx +121 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/game/index.tsx +4 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/game/list.tsx +237 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/game/show.tsx +74 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/Components/AssignRolesModal.tsx +29 -20
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/Components/CreatePageModal.tsx +3 -3
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/Components/EditPageModal.tsx +7 -3
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/Components/PageDetailDrawer.tsx +58 -23
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/Components/PageFormModal.tsx +206 -122
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/hooks/usePageManagement.ts +8 -4
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/index.ts +1 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/list.tsx +345 -190
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/page/types.ts +1 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/permissionReadme/index.tsx +341 -340
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/resource/Components/CreateModal.tsx +2 -2
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/resource/Components/EditModal.tsx +2 -2
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/resource/Components/ResourceDetailDrawer.tsx +41 -24
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/resource/Components/modal.tsx +64 -36
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/resource/index.ts +2 -2
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/resource/list.tsx +78 -40
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/Components/CreateModal.tsx +3 -3
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/Components/EditModal.tsx +4 -4
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/Components/RoleDetailDrawer.tsx +19 -9
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/Components/modal.tsx +45 -47
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/hooks/useRolePage.ts +4 -4
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/index.ts +1 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/list.tsx +121 -147
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/role/types.ts +1 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/components/create-modal.tsx +2 -2
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/components/edit-modal.tsx +2 -2
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/components/form-modal.tsx +25 -19
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/components/index.ts +5 -5
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/components/role-tag.tsx +10 -10
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/components/show-drawer.tsx +31 -26
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/index.ts +1 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/user/list.tsx +76 -71
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/setupTests.ts +1 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/types/audit-log.ts +1 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/types/index.ts +3 -3
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/types/role.ts +1 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/types/user.ts +1 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/vite.config.ts +42 -25
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/yarn.lock +1193 -32
- package/package.json +1 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/seed/seedDataMngtPages.ts +0 -258
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/agentPanel/AgentPanel.tsx +0 -497
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/agentPanel/skills.ts +0 -464
package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/canvasDefaults.ts
ADDED
|
@@ -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
|
+
};
|
package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/canvasI18n.ts
ADDED
|
@@ -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;
|