@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.
Files changed (173) hide show
  1. package/dist/index.d.ts +2 -0
  2. package/dist/index.js +2 -0
  3. package/dist/lib/application/files/gadmin2-game-angle-demo/config/prisma/job.prisma +62 -0
  4. package/dist/lib/application/files/gadmin2-game-angle-demo/config/prisma/system.prisma +0 -21
  5. package/dist/lib/application/files/gadmin2-game-angle-demo/config/prisma/workflow.prisma +171 -0
  6. package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/AgendaJob.ts +60 -0
  7. package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/Event.ts +1 -1
  8. package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/WorkflowEventOutbox.ts +62 -0
  9. package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/WorkflowNodeInstance.ts +62 -0
  10. package/dist/lib/application/files/gadmin2-game-angle-demo/config/ui/WorkflowNodeType.ts +62 -0
  11. package/dist/lib/application/files/gadmin2-game-angle-demo/server/.env +5 -0
  12. package/dist/lib/application/files/gadmin2-game-angle-demo/server/package.json +5 -4
  13. package/dist/lib/application/files/gadmin2-game-angle-demo/server/prisma.config.ts +14 -7
  14. package/dist/lib/application/files/gadmin2-game-angle-demo/server/seed/index.ts +4 -0
  15. package/dist/lib/application/files/gadmin2-game-angle-demo/server/seed/permissions.ts +49 -3
  16. package/dist/lib/application/files/gadmin2-game-angle-demo/server/seed/workflow-node-types.ts +746 -0
  17. package/dist/lib/application/files/gadmin2-game-angle-demo/server/seed/workflows.ts +786 -0
  18. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/agenda/agenda.controller.ts +6 -0
  19. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/agenda/agenda.service.ts +79 -0
  20. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/agendaJob/agendaJob.controller.spec.ts +20 -0
  21. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/agendaJob/agendaJob.controller.ts +145 -0
  22. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/agendaJob/agendaJob.module.ts +10 -0
  23. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/{canvas/canvas.service.spec.ts → agendaJob/agendaJob.service.spec.ts} +71 -65
  24. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/agendaJob/agendaJob.service.ts +83 -0
  25. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/index.ts +2 -1
  26. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflow/temporal.module.ts +9 -0
  27. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflow/temporal.service.ts +100 -0
  28. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflow/workflow-execution.dto.ts +19 -0
  29. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflow/workflow-export.dto.ts +43 -0
  30. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflow/workflow-export.service.ts +317 -0
  31. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflow/workflow-node-type.controller.ts +16 -0
  32. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflow/workflow-node-type.service.ts +13 -0
  33. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflow/workflow.controller.ts +220 -0
  34. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflow/workflow.dto.ts +82 -0
  35. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflow/workflow.module.ts +16 -0
  36. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflow/workflow.service.ts +505 -0
  37. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowEventOutbox/workflowEventOutbox.controller.spec.ts +22 -0
  38. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowEventOutbox/workflowEventOutbox.controller.ts +147 -0
  39. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowEventOutbox/workflowEventOutbox.module.ts +10 -0
  40. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowEventOutbox/workflowEventOutbox.service.spec.ts +356 -0
  41. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowEventOutbox/workflowEventOutbox.service.ts +110 -0
  42. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowNodeInstance/workflowNodeInstance.controller.spec.ts +22 -0
  43. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowNodeInstance/workflowNodeInstance.controller.ts +216 -0
  44. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowNodeInstance/workflowNodeInstance.module.ts +10 -0
  45. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowNodeInstance/workflowNodeInstance.service.spec.ts +356 -0
  46. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowNodeInstance/workflowNodeInstance.service.ts +168 -0
  47. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowNodeType/workflowNodeType.controller.spec.ts +22 -0
  48. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowNodeType/workflowNodeType.controller.ts +199 -0
  49. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowNodeType/workflowNodeType.module.ts +10 -0
  50. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowNodeType/workflowNodeType.service.spec.ts +348 -0
  51. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/modules/workflowNodeType/workflowNodeType.service.ts +106 -0
  52. package/dist/lib/application/files/gadmin2-game-angle-demo/server/yarn.lock +579 -1082
  53. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/README.md +278 -0
  54. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/config/development-sql.yaml +5 -0
  55. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/docker-compose.yml +25 -0
  56. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/package.json +13 -0
  57. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/sql/create-event-trigger.sql +87 -0
  58. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/.env +7 -0
  59. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/SANDBOX.md +122 -0
  60. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/package-lock.json +4285 -0
  61. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/package.json +28 -0
  62. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/__tests__/activities/code-execute.test.ts +44 -0
  63. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/__tests__/activities/http-request.test.ts +87 -0
  64. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/__tests__/helpers.test.ts +225 -0
  65. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/__tests__/node-type-consistency.test.ts +101 -0
  66. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/activities/code-execute.ts +51 -0
  67. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/activities/db-execute.ts +85 -0
  68. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/activities/db-query.ts +35 -0
  69. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/activities/http-request.ts +54 -0
  70. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/activities/index.ts +6 -0
  71. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/activities/reporting.ts +62 -0
  72. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/activities/send-notification.ts +47 -0
  73. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/config.ts +13 -0
  74. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/dsl/condition.ts +101 -0
  75. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/dsl/context.ts +58 -0
  76. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/dsl/graph.ts +184 -0
  77. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/dsl/helpers.ts +133 -0
  78. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/dsl/node-types.ts +57 -0
  79. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/dsl/types.ts +77 -0
  80. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/index.ts +36 -0
  81. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/outbox-poller.ts +226 -0
  82. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/src/workflows/dsl-workflow.ts +411 -0
  83. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/tsconfig.json +19 -0
  84. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/vitest.config.ts +8 -0
  85. package/dist/lib/application/files/gadmin2-game-angle-demo/temporal/worker/yarn.lock +1905 -0
  86. package/dist/lib/application/files/gadmin2-game-angle-demo/web/package-lock.json +17555 -0
  87. package/dist/lib/application/files/gadmin2-game-angle-demo/web/package.json +5 -2
  88. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/App.tsx +1 -0
  89. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/sider.tsx +5 -1
  90. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/layout/title.tsx +1 -1
  91. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/config/routeRegistry.tsx +63 -0
  92. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/dev-shell/DevShell.tsx +91 -2
  93. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/list.tsx +48 -2
  94. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/helpers/show.tsx +43 -2
  95. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/locales/en/common.json +14 -9
  96. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/locales/zh_CN/common.json +14 -9
  97. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/agenda/index.tsx +309 -56
  98. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/agenda/show.tsx +1 -3
  99. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/agendaJob/create.tsx +108 -0
  100. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/agendaJob/edit.tsx +124 -0
  101. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/agendaJob/index.tsx +4 -0
  102. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/agendaJob/list.tsx +245 -0
  103. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/agendaJob/show.tsx +70 -0
  104. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/CanvasListPage.tsx +0 -1
  105. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/CanvasPage.tsx +160 -2
  106. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/CanvasToolbar.tsx +120 -148
  107. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/CodeFloatWindow.tsx +74 -181
  108. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/LivePreview.tsx +15 -13
  109. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/canvasConfigRegistry.tsx +2 -2
  110. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/canvasContextMenuRegistry.tsx +338 -3
  111. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/canvasDefaults.ts +18 -17
  112. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/BarChartDataSourceModal.tsx +10 -4
  113. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/LineChartDataSourceModal.tsx +10 -4
  114. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/{ChartViewerConfigModal.tsx → MultiChartConfigModal.tsx} +30 -18
  115. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/MultiChartDataSourceModal.tsx +427 -0
  116. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/NumCardDataSourceModal.tsx +10 -4
  117. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/PromptModal.tsx +6 -14
  118. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/RadarChartDataSourceModal.tsx +10 -4
  119. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/TableDataSourceModal.tsx +10 -4
  120. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/components/canvasModalProps.ts +24 -0
  121. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/canvas/demos.ts +45 -63
  122. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/components/CustomNode.tsx +99 -0
  123. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/components/ExportModal.tsx +87 -0
  124. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/components/FlowRenderer.tsx +322 -0
  125. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/components/ImportModal.tsx +175 -0
  126. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/components/NodeEditModal.tsx +60 -0
  127. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/components/NodePropertyPanel.tsx +1150 -0
  128. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/components/RunWorkflowModal.tsx +101 -0
  129. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/components/StatusCards.tsx +198 -0
  130. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/components/VersionPanel.tsx +81 -0
  131. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/editor.tsx +566 -0
  132. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/hooks/useWorkflowAgent.ts +224 -0
  133. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/index.tsx +524 -0
  134. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/instance-detail.tsx +343 -0
  135. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/instances.tsx +243 -0
  136. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/node-instances/components/CreateNodeInstanceModal.tsx +363 -0
  137. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/node-instances/components/DynamicConfigForm.tsx +154 -0
  138. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/node-instances/components/NodeInstanceForm.tsx +176 -0
  139. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/node-instances/create.tsx +77 -0
  140. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/node-instances/edit.tsx +112 -0
  141. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/node-instances/index.tsx +305 -0
  142. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/node-instances/show.tsx +282 -0
  143. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/show.tsx +469 -0
  144. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflow/types.ts +92 -0
  145. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflowEventOutbox/create.tsx +111 -0
  146. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflowEventOutbox/edit.tsx +127 -0
  147. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflowEventOutbox/index.tsx +4 -0
  148. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflowEventOutbox/list.tsx +254 -0
  149. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/routes/workflowEventOutbox/show.tsx +74 -0
  150. package/dist/lib/application/files/gadmin2-game-angle-demo/web/yarn.lock +1501 -1199
  151. package/package.json +1 -1
  152. package/dist/lib/application/files/gadmin2-game-angle-demo/server/src/app.controller.spec.ts +0 -22
  153. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/BarChart/index.tsx +0 -896
  154. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/ChartSwitcher/index.tsx +0 -219
  155. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/ChartViewer/index.tsx +0 -159
  156. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/Filter/index.tsx +0 -192
  157. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/LineChart/index.tsx +0 -1034
  158. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/NumCard/NumCard.module.css +0 -8
  159. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/NumCard/index.tsx +0 -509
  160. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/NumLineCard/index.tsx +0 -66
  161. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/PieChart/index.tsx +0 -552
  162. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/RadarChart/index.tsx +0 -263
  163. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/Section/index.tsx +0 -35
  164. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/Table/index.tsx +0 -207
  165. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/TreemapChart/index.tsx +0 -382
  166. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/WorldMap/index.tsx +0 -135
  167. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/chart-constants.ts +0 -53
  168. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/icon/InfoIcon.tsx +0 -8
  169. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/icon/index.ts +0 -1
  170. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/map/config.ts +0 -31
  171. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/map/nameMap.json +0 -9
  172. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/map/world.geo.json +0 -39349
  173. package/dist/lib/application/files/gadmin2-game-angle-demo/web/src/components/canvas/metric-info-tooltip/index.tsx +0 -19
@@ -1,8 +1,6 @@
1
- import React, { useState, useCallback } from '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
- ...(expanded
131
- ? {
132
- background: '#4361ee',
133
- color: '#fff',
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 (collapsible, lazy-mounted) ── */}
224
- {everExpanded && (
225
- <div
226
- style={{
227
- display: 'flex',
228
- alignItems: 'center',
229
- gap: 24,
230
- padding: expanded ? '16px 24px 20px' : '0 24px',
231
- overflowX: expanded ? 'auto' : 'hidden',
232
- overflowY: 'hidden',
233
- borderTop: expanded ? '1px solid #f0f0f0' : 'none',
234
- maxHeight: expanded ? 280 : 0,
235
- opacity: expanded ? 1 : 0,
236
- transition:
237
- 'max-height 250ms cubic-bezier(0.4, 0, 0.2, 1), opacity 200ms ease, padding 250ms cubic-bezier(0.4, 0, 0.2, 1)',
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
- return (
312
- <Popover
313
- key={type}
314
- content={popoverContent}
315
- title={
316
- <span
317
- style={{ fontSize: 12, fontWeight: 600, color: '#333' }}
318
- >
319
- {getComponentLabel(type, t)}
320
- </span>
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: 8,
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 #eaeaea',
342
- borderRadius: 10,
245
+ border: '1px solid #e8e8e8',
246
+ borderRadius: 8,
343
247
  overflow: 'hidden',
344
248
  background: '#fff',
345
- transition: 'all 200ms cubic-bezier(0.4, 0, 0.2, 1)',
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 16px rgba(67,97,238,0.12)';
351
- el.style.transform = 'translateY(-3px) scale(1.03)';
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 = '#eaeaea';
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 componentType={type} width={140} />
264
+ <ComponentThumbnail
265
+ componentType={type}
266
+ code={v.code}
267
+ width={124}
268
+ />
361
269
  </div>
362
270
  <span
363
271
  style={{
364
- fontSize: 11,
365
- color: '#888',
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
- {getComponentLabel(type, t)}
279
+ {getVariantLabel(v.label, t)}
373
280
  </span>
374
281
  </div>
375
- </Popover>
376
- );
377
- })}
378
- </div>
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
  };