@gadmin2n/schematics 0.0.72 → 0.0.74
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/index.d.ts +2 -0
- package/dist/index.js +2 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/config/prisma/job.prisma +62 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/config/prisma/system.prisma +0 -21
- package/dist/lib/application/files/gadmin2-game-angle-demo/config/prisma/workflow.prisma +171 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/AgendaJob.ts +60 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/Event.ts +1 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/WorkflowEventOutbox.ts +62 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/WorkflowNodeInstance.ts +62 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/WorkflowNodeType.ts +62 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/.env +5 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/package.json +5 -4
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/prisma.config.ts +14 -7
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/seed/index.ts +4 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/seed/permissions.ts +49 -3
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/seed/workflow-node-types.ts +746 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/seed/workflows.ts +786 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/agenda/agenda.controller.ts +6 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/agenda/agenda.service.ts +79 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/agendaJob/agendaJob.controller.spec.ts +20 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/agendaJob/agendaJob.controller.ts +145 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/agendaJob/agendaJob.module.ts +10 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/{canvas/canvas.service.spec.ts → agendaJob/agendaJob.service.spec.ts} +71 -65
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/agendaJob/agendaJob.service.ts +83 -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/workflow/temporal.module.ts +9 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflow/temporal.service.ts +100 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflow/workflow-execution.dto.ts +19 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflow/workflow-export.dto.ts +43 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflow/workflow-export.service.ts +317 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflow/workflow-node-type.controller.ts +16 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflow/workflow-node-type.service.ts +13 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflow/workflow.controller.ts +220 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflow/workflow.dto.ts +82 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflow/workflow.module.ts +16 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflow/workflow.service.ts +505 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowEventOutbox/workflowEventOutbox.controller.spec.ts +22 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowEventOutbox/workflowEventOutbox.controller.ts +147 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowEventOutbox/workflowEventOutbox.module.ts +10 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowEventOutbox/workflowEventOutbox.service.spec.ts +356 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowEventOutbox/workflowEventOutbox.service.ts +110 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowNodeInstance/workflowNodeInstance.controller.spec.ts +22 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowNodeInstance/workflowNodeInstance.controller.ts +216 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowNodeInstance/workflowNodeInstance.module.ts +10 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowNodeInstance/workflowNodeInstance.service.spec.ts +356 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowNodeInstance/workflowNodeInstance.service.ts +168 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowNodeType/workflowNodeType.controller.spec.ts +22 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowNodeType/workflowNodeType.controller.ts +199 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowNodeType/workflowNodeType.module.ts +10 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowNodeType/workflowNodeType.service.spec.ts +348 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowNodeType/workflowNodeType.service.ts +106 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/yarn.lock +579 -1082
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/README.md +278 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/config/development-sql.yaml +5 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/docker-compose.yml +25 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/package.json +13 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/sql/create-event-trigger.sql +87 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/.env +7 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/SANDBOX.md +122 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/package-lock.json +4285 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/package.json +28 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/__tests__/activities/code-execute.test.ts +44 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/__tests__/activities/http-request.test.ts +87 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/__tests__/helpers.test.ts +225 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/__tests__/node-type-consistency.test.ts +101 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/activities/code-execute.ts +51 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/activities/db-execute.ts +85 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/activities/db-query.ts +35 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/activities/http-request.ts +54 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/activities/index.ts +6 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/activities/reporting.ts +62 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/activities/send-notification.ts +47 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/config.ts +13 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/dsl/condition.ts +101 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/dsl/context.ts +58 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/dsl/graph.ts +184 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/dsl/helpers.ts +133 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/dsl/node-types.ts +57 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/dsl/types.ts +77 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/index.ts +36 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/outbox-poller.ts +226 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/workflows/dsl-workflow.ts +411 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/tsconfig.json +19 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/vitest.config.ts +8 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/yarn.lock +1905 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/package-lock.json +17555 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/package.json +5 -2
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/App.tsx +1 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/sider.tsx +5 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/title.tsx +1 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/config/routeRegistry.tsx +63 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/dev-shell/DevShell.tsx +91 -2
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/list.tsx +48 -2
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/show.tsx +43 -2
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/locales/en/common.json +14 -9
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/locales/zh_CN/common.json +14 -9
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/agenda/index.tsx +309 -56
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/agenda/show.tsx +1 -3
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/agendaJob/create.tsx +108 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/agendaJob/edit.tsx +124 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/agendaJob/index.tsx +4 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/agendaJob/list.tsx +245 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/agendaJob/show.tsx +70 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/CanvasListPage.tsx +0 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/CanvasPage.tsx +160 -2
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/CanvasToolbar.tsx +120 -148
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/CodeFloatWindow.tsx +74 -181
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/LivePreview.tsx +15 -13
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/canvasConfigRegistry.tsx +2 -2
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/canvasContextMenuRegistry.tsx +338 -3
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/canvasDefaults.ts +18 -17
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/BarChartDataSourceModal.tsx +10 -4
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/LineChartDataSourceModal.tsx +10 -4
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/{ChartViewerConfigModal.tsx → MultiChartConfigModal.tsx} +30 -18
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/MultiChartDataSourceModal.tsx +427 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/NumCardDataSourceModal.tsx +10 -4
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/PromptModal.tsx +6 -14
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/RadarChartDataSourceModal.tsx +10 -4
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/TableDataSourceModal.tsx +10 -4
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/canvasModalProps.ts +24 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/demos.ts +45 -63
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/components/CustomNode.tsx +99 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/components/ExportModal.tsx +87 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/components/FlowRenderer.tsx +322 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/components/ImportModal.tsx +175 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/components/NodeEditModal.tsx +60 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/components/NodePropertyPanel.tsx +1150 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/components/RunWorkflowModal.tsx +101 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/components/StatusCards.tsx +198 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/components/VersionPanel.tsx +81 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/editor.tsx +566 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/hooks/useWorkflowAgent.ts +224 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/index.tsx +524 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/instance-detail.tsx +343 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/instances.tsx +243 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/node-instances/components/CreateNodeInstanceModal.tsx +363 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/node-instances/components/DynamicConfigForm.tsx +154 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/node-instances/components/NodeInstanceForm.tsx +176 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/node-instances/create.tsx +77 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/node-instances/edit.tsx +112 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/node-instances/index.tsx +305 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/node-instances/show.tsx +282 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/show.tsx +469 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/types.ts +92 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflowEventOutbox/create.tsx +111 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflowEventOutbox/edit.tsx +127 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflowEventOutbox/index.tsx +4 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflowEventOutbox/list.tsx +254 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflowEventOutbox/show.tsx +74 -0
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/yarn.lock +1501 -1199
- package/package.json +1 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/app.controller.spec.ts +0 -22
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/BarChart/index.tsx +0 -896
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/ChartSwitcher/index.tsx +0 -219
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/ChartViewer/index.tsx +0 -159
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/Filter/index.tsx +0 -192
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/LineChart/index.tsx +0 -1034
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/NumCard/NumCard.module.css +0 -8
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/NumCard/index.tsx +0 -509
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/NumLineCard/index.tsx +0 -66
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/PieChart/index.tsx +0 -552
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/RadarChart/index.tsx +0 -263
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/Section/index.tsx +0 -35
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/Table/index.tsx +0 -207
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/TreemapChart/index.tsx +0 -382
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/WorldMap/index.tsx +0 -135
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/chart-constants.ts +0 -53
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/icon/InfoIcon.tsx +0 -8
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/icon/index.ts +0 -1
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/map/config.ts +0 -31
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/map/nameMap.json +0 -9
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/map/world.geo.json +0 -39349
- package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/metric-info-tooltip/index.tsx +0 -19
package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/CanvasToolbar.tsx
CHANGED
|
@@ -1,8 +1,6 @@
|
|
|
1
|
-
import React, {
|
|
1
|
+
import React, { useCallback } from 'react';
|
|
2
2
|
import { Button, Tooltip, Popover } from 'antd';
|
|
3
3
|
import {
|
|
4
|
-
DownOutlined,
|
|
5
|
-
UpOutlined,
|
|
6
4
|
SaveOutlined,
|
|
7
5
|
ArrowLeftOutlined,
|
|
8
6
|
RocketOutlined,
|
|
@@ -36,15 +34,6 @@ const CanvasToolbar: React.FC<CanvasToolbarProps> = ({
|
|
|
36
34
|
onPreview,
|
|
37
35
|
}) => {
|
|
38
36
|
const { t } = useTranslation();
|
|
39
|
-
const [expanded, setExpanded] = useState(true);
|
|
40
|
-
const [everExpanded, setEverExpanded] = useState(true);
|
|
41
|
-
|
|
42
|
-
const handleToggle = useCallback(() => {
|
|
43
|
-
setExpanded((prev) => {
|
|
44
|
-
if (!prev) setEverExpanded(true);
|
|
45
|
-
return !prev;
|
|
46
|
-
});
|
|
47
|
-
}, []);
|
|
48
37
|
|
|
49
38
|
const handleVariantDragStart = useCallback(
|
|
50
39
|
(e: React.DragEvent, componentType: string, variantCode: string) => {
|
|
@@ -110,7 +99,7 @@ const CanvasToolbar: React.FC<CanvasToolbarProps> = ({
|
|
|
110
99
|
</span>
|
|
111
100
|
</div>
|
|
112
101
|
|
|
113
|
-
{/* 中间:
|
|
102
|
+
{/* 中间: 组件库标题 */}
|
|
114
103
|
<div
|
|
115
104
|
style={{
|
|
116
105
|
display: 'flex',
|
|
@@ -121,27 +110,18 @@ const CanvasToolbar: React.FC<CanvasToolbarProps> = ({
|
|
|
121
110
|
<Button
|
|
122
111
|
size="small"
|
|
123
112
|
icon={<AppstoreOutlined />}
|
|
124
|
-
onClick={handleToggle}
|
|
125
113
|
style={{
|
|
126
114
|
fontSize: 13,
|
|
127
115
|
fontWeight: 500,
|
|
128
116
|
borderRadius: 8,
|
|
129
117
|
border: 'none',
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
boxShadow: '0 2px 8px rgba(67,97,238,0.3)',
|
|
135
|
-
}
|
|
136
|
-
: {
|
|
137
|
-
background: '#f0f1f5',
|
|
138
|
-
color: '#444',
|
|
139
|
-
}),
|
|
140
|
-
transition: 'all 200ms ease',
|
|
118
|
+
background: '#4361ee',
|
|
119
|
+
color: '#fff',
|
|
120
|
+
boxShadow: '0 2px 8px rgba(67,97,238,0.3)',
|
|
121
|
+
cursor: 'default',
|
|
141
122
|
}}
|
|
142
123
|
>
|
|
143
|
-
{t('canvas.componentLib')}
|
|
144
|
-
{expanded ? <UpOutlined /> : <DownOutlined />}
|
|
124
|
+
{t('canvas.componentLib')}
|
|
145
125
|
</Button>
|
|
146
126
|
</div>
|
|
147
127
|
|
|
@@ -220,163 +200,155 @@ const CanvasToolbar: React.FC<CanvasToolbarProps> = ({
|
|
|
220
200
|
</div>
|
|
221
201
|
</div>
|
|
222
202
|
|
|
223
|
-
{/* ── Thumbnail row (
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
}}
|
|
239
|
-
>
|
|
240
|
-
{CANVAS_COMPONENTS.map((type) => {
|
|
241
|
-
const def = CANVAS_DEFAULTS[type];
|
|
242
|
-
const variants = def?.variants ?? [];
|
|
243
|
-
|
|
244
|
-
const popoverContent = (
|
|
245
|
-
<div
|
|
246
|
-
style={{
|
|
247
|
-
display: 'flex',
|
|
248
|
-
alignItems: 'center',
|
|
249
|
-
gap: 16,
|
|
250
|
-
padding: 4,
|
|
251
|
-
}}
|
|
252
|
-
>
|
|
253
|
-
{variants.map((v) => (
|
|
254
|
-
<div
|
|
255
|
-
key={v.name}
|
|
256
|
-
draggable
|
|
257
|
-
onDragStart={(e) => handleVariantDragStart(e, type, v.code)}
|
|
258
|
-
style={{
|
|
259
|
-
display: 'flex',
|
|
260
|
-
flexDirection: 'column',
|
|
261
|
-
alignItems: 'center',
|
|
262
|
-
gap: 6,
|
|
263
|
-
cursor: 'grab',
|
|
264
|
-
userSelect: 'none',
|
|
265
|
-
flexShrink: 0,
|
|
266
|
-
}}
|
|
267
|
-
>
|
|
268
|
-
<div
|
|
269
|
-
style={{
|
|
270
|
-
border: '1px solid #e8e8e8',
|
|
271
|
-
borderRadius: 8,
|
|
272
|
-
overflow: 'hidden',
|
|
273
|
-
background: '#fff',
|
|
274
|
-
transition: 'all 180ms ease',
|
|
275
|
-
}}
|
|
276
|
-
onMouseEnter={(e) => {
|
|
277
|
-
const el = e.currentTarget;
|
|
278
|
-
el.style.borderColor = '#4361ee';
|
|
279
|
-
el.style.boxShadow = '0 4px 12px rgba(67,97,238,0.15)';
|
|
280
|
-
el.style.transform = 'translateY(-3px) scale(1.02)';
|
|
281
|
-
}}
|
|
282
|
-
onMouseLeave={(e) => {
|
|
283
|
-
const el = e.currentTarget;
|
|
284
|
-
el.style.borderColor = '#e8e8e8';
|
|
285
|
-
el.style.boxShadow = 'none';
|
|
286
|
-
el.style.transform = 'translateY(0) scale(1)';
|
|
287
|
-
}}
|
|
288
|
-
>
|
|
289
|
-
<ComponentThumbnail
|
|
290
|
-
componentType={type}
|
|
291
|
-
code={v.code}
|
|
292
|
-
width={124}
|
|
293
|
-
/>
|
|
294
|
-
</div>
|
|
295
|
-
<span
|
|
296
|
-
style={{
|
|
297
|
-
fontSize: 10,
|
|
298
|
-
color: '#666',
|
|
299
|
-
fontWeight: 500,
|
|
300
|
-
textAlign: 'center',
|
|
301
|
-
pointerEvents: 'none',
|
|
302
|
-
}}
|
|
303
|
-
>
|
|
304
|
-
{getVariantLabel(v.label, t)}
|
|
305
|
-
</span>
|
|
306
|
-
</div>
|
|
307
|
-
))}
|
|
308
|
-
</div>
|
|
309
|
-
);
|
|
203
|
+
{/* ── Thumbnail row (always visible) ── */}
|
|
204
|
+
<div
|
|
205
|
+
style={{
|
|
206
|
+
display: 'flex',
|
|
207
|
+
alignItems: 'center',
|
|
208
|
+
gap: 24,
|
|
209
|
+
padding: '16px 24px 20px',
|
|
210
|
+
overflowX: 'auto',
|
|
211
|
+
overflowY: 'hidden',
|
|
212
|
+
borderTop: '1px solid #f0f0f0',
|
|
213
|
+
}}
|
|
214
|
+
>
|
|
215
|
+
{CANVAS_COMPONENTS.map((type) => {
|
|
216
|
+
const def = CANVAS_DEFAULTS[type];
|
|
217
|
+
const variants = def?.variants ?? [];
|
|
310
218
|
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
}
|
|
322
|
-
trigger="hover"
|
|
323
|
-
placement="bottomLeft"
|
|
324
|
-
mouseEnterDelay={0.2}
|
|
325
|
-
mouseLeaveDelay={0.3}
|
|
326
|
-
>
|
|
219
|
+
const popoverContent = (
|
|
220
|
+
<div
|
|
221
|
+
style={{
|
|
222
|
+
display: 'flex',
|
|
223
|
+
alignItems: 'center',
|
|
224
|
+
gap: 16,
|
|
225
|
+
padding: 4,
|
|
226
|
+
}}
|
|
227
|
+
>
|
|
228
|
+
{variants.map((v) => (
|
|
327
229
|
<div
|
|
230
|
+
key={v.name}
|
|
231
|
+
draggable
|
|
232
|
+
onDragStart={(e) => handleVariantDragStart(e, type, v.code)}
|
|
328
233
|
style={{
|
|
329
234
|
display: 'flex',
|
|
330
235
|
flexDirection: 'column',
|
|
331
236
|
alignItems: 'center',
|
|
332
|
-
gap:
|
|
237
|
+
gap: 6,
|
|
333
238
|
cursor: 'grab',
|
|
334
239
|
userSelect: 'none',
|
|
335
240
|
flexShrink: 0,
|
|
336
|
-
width: 140,
|
|
337
241
|
}}
|
|
338
242
|
>
|
|
339
243
|
<div
|
|
340
244
|
style={{
|
|
341
|
-
border: '1px solid #
|
|
342
|
-
borderRadius:
|
|
245
|
+
border: '1px solid #e8e8e8',
|
|
246
|
+
borderRadius: 8,
|
|
343
247
|
overflow: 'hidden',
|
|
344
248
|
background: '#fff',
|
|
345
|
-
transition: 'all
|
|
249
|
+
transition: 'all 180ms ease',
|
|
346
250
|
}}
|
|
347
251
|
onMouseEnter={(e) => {
|
|
348
252
|
const el = e.currentTarget;
|
|
349
253
|
el.style.borderColor = '#4361ee';
|
|
350
|
-
el.style.boxShadow = '0 4px
|
|
351
|
-
el.style.transform = 'translateY(-3px) scale(1.
|
|
254
|
+
el.style.boxShadow = '0 4px 12px rgba(67,97,238,0.15)';
|
|
255
|
+
el.style.transform = 'translateY(-3px) scale(1.02)';
|
|
352
256
|
}}
|
|
353
257
|
onMouseLeave={(e) => {
|
|
354
258
|
const el = e.currentTarget;
|
|
355
|
-
el.style.borderColor = '#
|
|
259
|
+
el.style.borderColor = '#e8e8e8';
|
|
356
260
|
el.style.boxShadow = 'none';
|
|
357
261
|
el.style.transform = 'translateY(0) scale(1)';
|
|
358
262
|
}}
|
|
359
263
|
>
|
|
360
|
-
<ComponentThumbnail
|
|
264
|
+
<ComponentThumbnail
|
|
265
|
+
componentType={type}
|
|
266
|
+
code={v.code}
|
|
267
|
+
width={124}
|
|
268
|
+
/>
|
|
361
269
|
</div>
|
|
362
270
|
<span
|
|
363
271
|
style={{
|
|
364
|
-
fontSize:
|
|
365
|
-
color: '#
|
|
272
|
+
fontSize: 10,
|
|
273
|
+
color: '#666',
|
|
366
274
|
fontWeight: 500,
|
|
367
|
-
letterSpacing: '0.3px',
|
|
368
275
|
textAlign: 'center',
|
|
369
276
|
pointerEvents: 'none',
|
|
370
277
|
}}
|
|
371
278
|
>
|
|
372
|
-
{
|
|
279
|
+
{getVariantLabel(v.label, t)}
|
|
373
280
|
</span>
|
|
374
281
|
</div>
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
282
|
+
))}
|
|
283
|
+
</div>
|
|
284
|
+
);
|
|
285
|
+
|
|
286
|
+
return (
|
|
287
|
+
<Popover
|
|
288
|
+
key={type}
|
|
289
|
+
content={popoverContent}
|
|
290
|
+
title={
|
|
291
|
+
<span style={{ fontSize: 12, fontWeight: 600, color: '#333' }}>
|
|
292
|
+
{getComponentLabel(type, t)}
|
|
293
|
+
</span>
|
|
294
|
+
}
|
|
295
|
+
trigger="hover"
|
|
296
|
+
placement="bottomLeft"
|
|
297
|
+
mouseEnterDelay={0.2}
|
|
298
|
+
mouseLeaveDelay={0.3}
|
|
299
|
+
>
|
|
300
|
+
<div
|
|
301
|
+
style={{
|
|
302
|
+
display: 'flex',
|
|
303
|
+
flexDirection: 'column',
|
|
304
|
+
alignItems: 'center',
|
|
305
|
+
gap: 8,
|
|
306
|
+
cursor: 'grab',
|
|
307
|
+
userSelect: 'none',
|
|
308
|
+
flexShrink: 0,
|
|
309
|
+
width: 140,
|
|
310
|
+
}}
|
|
311
|
+
>
|
|
312
|
+
<div
|
|
313
|
+
style={{
|
|
314
|
+
border: '1px solid #eaeaea',
|
|
315
|
+
borderRadius: 10,
|
|
316
|
+
overflow: 'hidden',
|
|
317
|
+
background: '#fff',
|
|
318
|
+
transition: 'all 200ms cubic-bezier(0.4, 0, 0.2, 1)',
|
|
319
|
+
}}
|
|
320
|
+
onMouseEnter={(e) => {
|
|
321
|
+
const el = e.currentTarget;
|
|
322
|
+
el.style.borderColor = '#4361ee';
|
|
323
|
+
el.style.boxShadow = '0 4px 16px rgba(67,97,238,0.12)';
|
|
324
|
+
el.style.transform = 'translateY(-3px) scale(1.03)';
|
|
325
|
+
}}
|
|
326
|
+
onMouseLeave={(e) => {
|
|
327
|
+
const el = e.currentTarget;
|
|
328
|
+
el.style.borderColor = '#eaeaea';
|
|
329
|
+
el.style.boxShadow = 'none';
|
|
330
|
+
el.style.transform = 'translateY(0) scale(1)';
|
|
331
|
+
}}
|
|
332
|
+
>
|
|
333
|
+
<ComponentThumbnail componentType={type} width={140} />
|
|
334
|
+
</div>
|
|
335
|
+
<span
|
|
336
|
+
style={{
|
|
337
|
+
fontSize: 11,
|
|
338
|
+
color: '#888',
|
|
339
|
+
fontWeight: 500,
|
|
340
|
+
letterSpacing: '0.3px',
|
|
341
|
+
textAlign: 'center',
|
|
342
|
+
pointerEvents: 'none',
|
|
343
|
+
}}
|
|
344
|
+
>
|
|
345
|
+
{getComponentLabel(type, t)}
|
|
346
|
+
</span>
|
|
347
|
+
</div>
|
|
348
|
+
</Popover>
|
|
349
|
+
);
|
|
350
|
+
})}
|
|
351
|
+
</div>
|
|
380
352
|
</div>
|
|
381
353
|
);
|
|
382
354
|
};
|