@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
@@ -0,0 +1,124 @@
1
+ import {
2
+ FieldDataType,
3
+ handleInitialValues,
4
+ handleOnFinish,
5
+ ModelType,
6
+ produceModel,
7
+ } from '@gadmin2n/react-common';
8
+ import {
9
+ Edit,
10
+ ListButton,
11
+ RefreshButton,
12
+ useFileUploadState,
13
+ useForm,
14
+ } from '@refinedev/antd';
15
+ import { Form } from 'antd';
16
+ import {
17
+ IResourceComponentsProps,
18
+ useApiUrl,
19
+ useParsed,
20
+ useTranslate,
21
+ } from '@refinedev/core';
22
+ import { getFormItem, onFormValuesChange } from '../../helpers';
23
+ import React, { useContext, useState } from 'react';
24
+
25
+ import { modelsMap, modelsEnum } from '../../generated/models.index';
26
+ import {
27
+ agendaJobFormConfig as formConfig,
28
+ agendaJobFormPrismaSelect as formPrismaSelect,
29
+ } from '../../generated/props/agendaJob/config';
30
+ import {
31
+ agendaJobModel,
32
+ useRelation,
33
+ } from '../../generated/props/agendaJob/model';
34
+ import { AgendaJob } from '../../generated/types/prisma.types';
35
+ import { AgendaJobForm as transformClass } from '../../generated/props/agendaJob/form.validator';
36
+ import { BusinessContext } from 'components/contexts/business';
37
+
38
+ export const AgendaJobEdit: React.FC<IResourceComponentsProps> = () => {
39
+ const resourceName = 'agendaJob';
40
+ const t = useTranslate();
41
+
42
+ const [[fields, model]] = useState(() => {
43
+ const model: ModelType = produceModel(
44
+ agendaJobModel,
45
+ {
46
+ // all formItem attrs surport, https://ant.design/components/form#formitem
47
+ // description : { component : <MDEditor data-color-mode="light" /> },
48
+ // status : { normalize : (value: any) => value ? "1" : "0" },
49
+ // cron: {validator: { validator: runCronValidator },},
50
+ },
51
+ transformClass,
52
+ );
53
+
54
+ const fields: FieldDataType[] = formConfig.fields
55
+ .map((fieldName: string) => model[fieldName])
56
+ .filter((field: FieldDataType) => field);
57
+
58
+ return [fields, model] as const;
59
+ });
60
+
61
+ const { formProps, saveButtonProps, onFinish, form } = useForm<AgendaJob>({
62
+ meta: { select: formPrismaSelect },
63
+ });
64
+ formProps.initialValues = handleInitialValues(
65
+ formProps.initialValues || {},
66
+ fields,
67
+ );
68
+
69
+ const apiUrl = useApiUrl();
70
+ const { isLoading, onChange } = useFileUploadState();
71
+
72
+ const relationSelectProps = useRelation(modelsMap);
73
+
74
+ return (
75
+ <Edit
76
+ saveButtonProps={{
77
+ ...saveButtonProps,
78
+ disabled: isLoading,
79
+ }}
80
+ headerButtons={
81
+ <>
82
+ <ListButton />
83
+ <RefreshButton meta={{ select: formPrismaSelect }} />
84
+ </>
85
+ }
86
+ >
87
+ <Form
88
+ {...formProps}
89
+ validateTrigger="onBlur"
90
+ onFinish={(values) => {
91
+ onFinish(
92
+ handleOnFinish(
93
+ {
94
+ ...values,
95
+
96
+ id: undefined,
97
+ },
98
+ fields,
99
+ 'edit',
100
+ ),
101
+ );
102
+ }}
103
+ layout="vertical"
104
+ form={form}
105
+ onValuesChange={onFormValuesChange(form, formConfig.reaction)}
106
+ >
107
+ {fields.map((field) => {
108
+ return getFormItem(
109
+ field,
110
+ resourceName,
111
+ t,
112
+ form,
113
+ formConfig.reaction,
114
+ modelsEnum,
115
+ model,
116
+ apiUrl,
117
+ relationSelectProps,
118
+ onChange,
119
+ );
120
+ })}
121
+ </Form>
122
+ </Edit>
123
+ );
124
+ };
@@ -0,0 +1,4 @@
1
+ export * from './list';
2
+ export * from './create';
3
+ export * from './edit';
4
+ export * from './show';
@@ -0,0 +1,245 @@
1
+ /**
2
+ * AgendaJob List Page
3
+ *
4
+ * Generated using simplified pattern with @gadmin2n/react-common hooks and components.
5
+ *
6
+ * Flexibility Levels:
7
+ * 1. Basic usage - Use components with defaults (this file)
8
+ * 2. Render props - Customize specific buttons/elements
9
+ * 3. Children function - Complete UI control
10
+ * 4. Core hooks - No UI assumptions, full control
11
+ *
12
+ * See: examples/ListPageExamples.tsx for all patterns
13
+ */
14
+ import React, { useMemo } from 'react';
15
+ import { Table } from 'antd';
16
+ import { List, useTable, useImport } from '@refinedev/antd';
17
+ import {
18
+ HttpError,
19
+ IResourceComponentsProps,
20
+ parseTableParams,
21
+ useExport,
22
+ useTranslate,
23
+ useApiUrl,
24
+ } from '@refinedev/core';
25
+ import { useLocation } from 'react-router-dom';
26
+ import {
27
+ getColumns,
28
+ ModelType,
29
+ produceModel,
30
+ tableSearchBar,
31
+ } from '@gadmin2n/react-common';
32
+
33
+ // Generated imports
34
+ import { modelsEnum, modelsMap } from 'generated/models.index';
35
+ import {
36
+ agendaJobTableConfig as tableConfig,
37
+ agendaJobTablePrismaSelect as prismaSelect,
38
+ } from 'generated/props/agendaJob/config';
39
+ import { agendaJobModel, useRelation } from 'generated/props/agendaJob/model';
40
+ import type { AgendaJob } from 'generated/types/prisma.types';
41
+
42
+ // Local imports
43
+ import { BulkActions, ListPageHeader, RowActions, SearchBar } from 'components';
44
+ import { getRowActionsColumnProps } from 'components/agentPanel';
45
+ import { requestHeaders } from 'helpers/login';
46
+ import { useBatchOperations } from 'hooks';
47
+ import {
48
+ createSearchFormOnFinish,
49
+ getSearchFormInitialValues,
50
+ getTableColumnV2,
51
+ TableColumnContext,
52
+ } from 'helpers';
53
+
54
+ const { placeholder: searchPlaceholder, getSearchFilters } = tableSearchBar(
55
+ tableConfig['toolbar']['searchBar'],
56
+ agendaJobModel,
57
+ );
58
+
59
+ // https://refine.dev/docs/api-reference/antd/hooks/table/useTable/
60
+ export const AgendaJobList: React.FC<IResourceComponentsProps> = () => {
61
+ const resourceName = 'agendaJob';
62
+ const t = useTranslate();
63
+ const apiUrl = useApiUrl();
64
+ const { search } = useLocation();
65
+ const { parsedSorter, parsedFilters } = parseTableParams(search);
66
+
67
+ // Relations
68
+ const relationSelectProps = useRelation(modelsMap);
69
+
70
+ // Model with customizations
71
+ const [columns, model] = useMemo(() => {
72
+ const model: ModelType = produceModel(agendaJobModel, {
73
+ // Custom column renderers can be added here
74
+ // cron: { render: (value) => humanizeCronInChinese(value) },
75
+ });
76
+
77
+ const columns = getColumns('AgendaJob', tableConfig.fields, {
78
+ ...modelsMap,
79
+ AgendaJob: { model, meta: modelsMap['AgendaJob'].meta },
80
+ });
81
+
82
+ return [columns, model] as const;
83
+ }, []);
84
+
85
+ // Table hook
86
+ const {
87
+ tableProps,
88
+ sorters: sorter,
89
+ setCurrent,
90
+ setFilters,
91
+ filters,
92
+ tableQueryResult,
93
+ searchFormProps,
94
+ } = useTable<AgendaJob, HttpError>({
95
+ meta: {
96
+ transformQFn: getSearchFilters,
97
+ select: prismaSelect,
98
+ model: agendaJobModel,
99
+ },
100
+ filters: { initial: parsedFilters, defaultBehavior: 'merge' },
101
+ sorters: { initial: parsedSorter },
102
+ });
103
+
104
+ // initialValues: 从 URL 的 parsedFilters 中恢复 q(搜索关键词)和 createdAt(日期范围)
105
+ // onFinish: 将表单值转换为 CrudFilters 并更新筛选条件
106
+ // 有 createdAt 字段的模型(默认)
107
+ searchFormProps.initialValues = getSearchFormInitialValues(parsedFilters);
108
+ searchFormProps.onFinish = createSearchFormOnFinish(setCurrent, setFilters);
109
+
110
+ // 没有 createdAt 字段的模型
111
+ // searchFormProps.initialValues = getSearchFormInitialValues(parsedFilters, { dateField: null });
112
+ // searchFormProps.onFinish = createSearchFormOnFinish(setCurrent, setFilters, { dateField: null });
113
+
114
+ // 使用其他日期字段(如 updatedAt)
115
+ // searchFormProps.initialValues = getSearchFormInitialValues(parsedFilters, { dateField: 'updatedAt' });
116
+ // searchFormProps.onFinish = createSearchFormOnFinish(setCurrent, setFilters, { dateField: 'updatedAt' });
117
+
118
+ // Batch operations (selection, update, delete)
119
+ const batchOps = useBatchOperations({
120
+ resourceName,
121
+ apiUrl,
122
+ requestHeaders,
123
+ onSuccess: () => tableQueryResult.refetch(),
124
+ t,
125
+ });
126
+
127
+ // Export all
128
+ const { triggerExport, isLoading: exportLoading } = useExport<AgendaJob>({
129
+ maxItemCount: 200,
130
+ pageSize: 100,
131
+ });
132
+
133
+ // Export selected
134
+ const {
135
+ triggerExport: triggerExportSelected,
136
+ isLoading: exportSelectedLoading,
137
+ } = useExport<AgendaJob>({
138
+ pageSize: 100,
139
+ meta: { where: { id: { in: batchOps.selectedRowKeys.map(Number) } } },
140
+ });
141
+
142
+ // Import
143
+ const importProps = useImport<AgendaJob>({
144
+ mapData: (item: any) => ({
145
+ ...item,
146
+ }),
147
+ batchSize: 1,
148
+ });
149
+
150
+ // Context for table columns
151
+ const columnContext: TableColumnContext = {
152
+ resourceName,
153
+ t,
154
+ model,
155
+ modelsEnum,
156
+ modelsMap,
157
+ tableConfig,
158
+ sorter,
159
+ filters,
160
+ relationSelectProps,
161
+ };
162
+
163
+ return (
164
+ <List
165
+ headerProps={{
166
+ subTitle: (
167
+ <BulkActions
168
+ selectedRowKeys={batchOps.selectedRowKeys}
169
+ actions={tableConfig.rowSelection.actions}
170
+ onUpdateSelected={batchOps.updateSelectedItems}
171
+ onDeleteSelected={batchOps.deleteSelectedItems}
172
+ onExportSelected={triggerExportSelected}
173
+ updateLoading={batchOps.updateManyIsLoading}
174
+ deleteLoading={batchOps.deleteManyIsLoading}
175
+ exportLoading={exportSelectedLoading}
176
+ t={t}
177
+ resourceName={resourceName}
178
+ showDelete={false}
179
+ // Render props examples (uncomment to customize):
180
+ // renderDeleteButton={(onClick, loading) => <Button danger onClick={onClick} loading={loading}>Delete</Button>}
181
+ // renderSelectionCount={(count) => <Badge count={count}><Tag>Selected</Tag></Badge>}
182
+ // extraActions={<Button>Custom Action</Button>}
183
+ />
184
+ ),
185
+ extra: (
186
+ <ListPageHeader
187
+ importProps={importProps}
188
+ onExport={triggerExport}
189
+ exportLoading={exportLoading}
190
+ resourceName={resourceName}
191
+ showCreate={false}
192
+ showImport={false}
193
+ />
194
+ ),
195
+ }}
196
+ >
197
+ {/* Search Bar */}
198
+ <SearchBar
199
+ formProps={searchFormProps}
200
+ t={t}
201
+ resourceName={resourceName}
202
+ searchPlaceholder={searchPlaceholder}
203
+ // Render props examples (uncomment to customize):
204
+ // renderKeywordInput={(field, defaultInput) => <Input.Search placeholder={field.placeholder} />}
205
+ // renderSubmitButton={(defaultButton) => <Space>{defaultButton}<Button>Reset</Button></Space>}
206
+ // extraActions={<Button type="link">Advanced</Button>}
207
+ />
208
+
209
+ {/* Data Table */}
210
+ <Table {...tableProps} rowKey="id" rowSelection={batchOps.rowSelection}>
211
+ {columns.map((col) =>
212
+ getTableColumnV2({ col, context: columnContext }),
213
+ )}
214
+
215
+ {/* Actions Column */}
216
+ <Table.Column<AgendaJob>
217
+ title={t('table.actions')}
218
+ dataIndex="actions"
219
+ {...getRowActionsColumnProps(resourceName)}
220
+ render={(_, record) => (
221
+ <RowActions
222
+ record={record}
223
+ actions={tableConfig.rowActions.actions}
224
+ onUpdate={batchOps.updateOne}
225
+ updateLoading={batchOps.updateManyIsLoading}
226
+ t={t}
227
+ resourceName={resourceName}
228
+ showEdit={false}
229
+ showDelete={false}
230
+ showClone={false}
231
+ // Render props examples (uncomment to customize):
232
+ // showClone={false}
233
+ // showDelete={false}
234
+ // renderEditButton={(id) => <Button type="link" size="small">Quick Edit</Button>}
235
+ // renderDeleteButton={(id) => <Popconfirm title="Sure?"><Button danger size="small">Remove</Button></Popconfirm>}
236
+ // extraPrimaryActions={<Button type="text" size="small">Quick View</Button>}
237
+ />
238
+ )}
239
+ />
240
+ </Table>
241
+ </List>
242
+ );
243
+ };
244
+
245
+ export default AgendaJobList;
@@ -0,0 +1,70 @@
1
+ import { ModelType, getColumns, produceModel } from '@gadmin2n/react-common';
2
+ import { ListButton, Show } from '@refinedev/antd';
3
+ import {
4
+ IResourceComponentsProps,
5
+ useShow,
6
+ useTranslate,
7
+ } from '@refinedev/core';
8
+ import React, { useState } from 'react';
9
+ import { getShowField } from '../../helpers';
10
+ import type { AgendaJob } from '../../generated/types/prisma.types'; //'.prisma/client/index';
11
+ import {
12
+ agendaJobShowConfig as showConfig,
13
+ agendaJobShowPrismaSelect as showPrismaSelect,
14
+ } from '../../generated/props/agendaJob/config';
15
+ import { agendaJobModel } from '../../generated/props/agendaJob/model';
16
+ import { modelsMap } from 'generated/models.index';
17
+ import { agentAttrs } from '../../components/agentPanel/agentAttributes';
18
+
19
+ export const AgendaJobShow: React.FC<IResourceComponentsProps> = () => {
20
+ const resourceName = 'agendaJob';
21
+ const t = useTranslate();
22
+
23
+ const { queryResult } = useShow<AgendaJob>({
24
+ meta: { select: showPrismaSelect },
25
+ });
26
+ const { data, isLoading } = queryResult;
27
+ const record = data?.data;
28
+
29
+ const [[fields, model]] = useState(() => {
30
+ const model: ModelType = produceModel(agendaJobModel, {
31
+ // status: { render: xxxxx }
32
+ });
33
+
34
+ // getColumns is a function that returns an array of fields
35
+ const fields = getColumns('AgendaJob', showConfig.fields, {
36
+ ...modelsMap,
37
+ AgendaJob: { model, meta: modelsMap['AgendaJob'].meta },
38
+ });
39
+
40
+ return [fields, model] as const;
41
+ });
42
+
43
+ return (
44
+ <Show
45
+ isLoading={isLoading}
46
+ headerButtons={
47
+ <div
48
+ style={{ display: 'inline-flex', gap: 8 }}
49
+ {...agentAttrs({ type: 'show-header', resource: resourceName })}
50
+ >
51
+ <ListButton />
52
+ {/* 该资源为只读:Edit / Clone / Delete / Refresh 均已移除 */}
53
+ </div>
54
+ }
55
+ contentProps={{ styles: { body: { padding: 0 } } }}
56
+ >
57
+ <div
58
+ style={{
59
+ border: '1px solid #f0f0f0',
60
+ borderRadius: 8,
61
+ overflow: 'hidden',
62
+ }}
63
+ >
64
+ {fields.map((field: any) => {
65
+ return getShowField(field, resourceName, record, t, model, modelsMap);
66
+ })}
67
+ </div>
68
+ </Show>
69
+ );
70
+ };
@@ -176,7 +176,6 @@ const CanvasListPage: React.FC = () => {
176
176
  return (
177
177
  <div
178
178
  style={{
179
- padding: 24,
180
179
  background: '#f0f2f5',
181
180
  minHeight: 'calc(100vh - 64px)',
182
181
  }}
@@ -34,6 +34,7 @@ import TableDataSourceModal from './components/TableDataSourceModal';
34
34
  import BarChartDataSourceModal from './components/BarChartDataSourceModal';
35
35
  import LineChartDataSourceModal from './components/LineChartDataSourceModal';
36
36
  import RadarChartDataSourceModal from './components/RadarChartDataSourceModal';
37
+ import MultiChartDataSourceModal from './components/MultiChartDataSourceModal';
37
38
  import PromptModal from './components/PromptModal';
38
39
  import { createSectionCompactor } from './sectionCompactor';
39
40
  import type { CanvasItem as CanvasItemType } from './types';
@@ -298,6 +299,38 @@ const CanvasPage: React.FC<CanvasPageProps> = ({
298
299
  };
299
300
  }, [updateCode]);
300
301
 
302
+ // ── MultiChart 工具栏切换图表类型时,同步更新代码中的 defaultVariant ──
303
+ useEffect(() => {
304
+ const handler = (e: Event) => {
305
+ const { variant } = (e as CustomEvent).detail;
306
+ if (!variant) return;
307
+ // 从事件源找到对应的 canvas item
308
+ const target = e.target as HTMLElement;
309
+ const testId = target?.getAttribute('data-testid');
310
+ if (!testId) return;
311
+ const { items } = liveRef.current;
312
+ const item = items.find((i) => i.code?.includes(`testId="${testId}"`));
313
+ if (!item) return;
314
+ // 更新 defaultVariant
315
+ let newCode = item.code;
316
+ if (/defaultVariant\s*=\s*"[^"]*"/.test(newCode)) {
317
+ newCode = newCode.replace(
318
+ /defaultVariant\s*=\s*"[^"]*"/,
319
+ `defaultVariant="${variant}"`,
320
+ );
321
+ } else if (/testId\s*=/.test(newCode)) {
322
+ newCode = newCode.replace(
323
+ /([ \t]*)(testId\s*=)/,
324
+ `$1defaultVariant="${variant}"\n$1$2`,
325
+ );
326
+ }
327
+ if (newCode !== item.code) updateCode(item.id, newCode);
328
+ };
329
+ document.addEventListener('multichart-variant-change', handler);
330
+ return () =>
331
+ document.removeEventListener('multichart-variant-change', handler);
332
+ }, [updateCode]);
333
+
301
334
  const handleDragStop = useCallback((_layout: readonly LayoutItem[]) => {
302
335
  setIsDragging(false);
303
336
  if (_layout.some((l) => l.i === '__dropping-elem__')) return;
@@ -444,7 +477,10 @@ const CanvasPage: React.FC<CanvasPageProps> = ({
444
477
  {
445
478
  key: 'config',
446
479
  icon: <SettingOutlined />,
447
- label: t('canvas.config'),
480
+ label:
481
+ componentType === 'MultiChart'
482
+ ? (t('canvas.configCharts') ?? '配置显示图表与顺序')
483
+ : t('canvas.config'),
448
484
  onClick: () => {
449
485
  setConfigModal({ id: itemMenu.id, componentType });
450
486
  setItemMenu(null);
@@ -462,7 +498,8 @@ const CanvasPage: React.FC<CanvasPageProps> = ({
462
498
  componentType === 'Table' ||
463
499
  componentType === 'BarChart' ||
464
500
  componentType === 'LineChart' ||
465
- componentType === 'RadarChart'
501
+ componentType === 'RadarChart' ||
502
+ componentType === 'MultiChart'
466
503
  ) {
467
504
  setDataSourceModal({
468
505
  id: itemMenu.id,
@@ -1301,6 +1338,127 @@ const CanvasPage: React.FC<CanvasPageProps> = ({
1301
1338
  onCancel={() => setDataSourceModal(null)}
1302
1339
  />
1303
1340
 
1341
+ {/* MultiChart 修改数据来源 Modal */}
1342
+ <MultiChartDataSourceModal
1343
+ open={
1344
+ !!dataSourceModal && dataSourceModal.componentType === 'MultiChart'
1345
+ }
1346
+ code={dataSourceModal?.code ?? ''}
1347
+ onConfirm={({
1348
+ dataDescription,
1349
+ charts,
1350
+ chartConfigs,
1351
+ code: origCode,
1352
+ }) => {
1353
+ if (!dataSourceModal) return;
1354
+ let newCode = origCode;
1355
+
1356
+ // 更新 charts prop
1357
+ const chartsStr = `charts={${JSON.stringify(charts)}}`;
1358
+ if (/charts=\{.*?\}/s.test(newCode)) {
1359
+ newCode = newCode.replace(/charts=\{.*?\}/s, chartsStr);
1360
+ } else if (/testId\s*=/.test(newCode)) {
1361
+ newCode = newCode.replace(
1362
+ /([ \t]*)(testId\s*=)/,
1363
+ `$1${chartsStr}\n$1$2`,
1364
+ );
1365
+ }
1366
+
1367
+ // 更新 chartConfig prop
1368
+ const configObj: Record<string, Record<string, any>> = {};
1369
+ for (const [chartKey, config] of Object.entries(chartConfigs)) {
1370
+ const nonDefaults: Record<string, any> = {};
1371
+ for (const [k, v] of Object.entries(config)) {
1372
+ // 只存非默认值的配置
1373
+ if (
1374
+ k === 'showGrid' ||
1375
+ k === 'showLabel' ||
1376
+ k === 'legendShow'
1377
+ ) {
1378
+ if (!v) nonDefaults[k] = false;
1379
+ } else {
1380
+ if (v) nonDefaults[k] = true;
1381
+ }
1382
+ }
1383
+ if (Object.keys(nonDefaults).length > 0) {
1384
+ configObj[chartKey] = nonDefaults;
1385
+ }
1386
+ }
1387
+ if (Object.keys(configObj).length > 0) {
1388
+ const configStr = `chartConfig={${JSON.stringify(configObj)}}`;
1389
+ if (/chartConfig=\{[\s\S]*?\}\s*(?=\w+=|\/?>)/.test(newCode)) {
1390
+ newCode = newCode.replace(
1391
+ /chartConfig=\{[\s\S]*?\}\s*(?=\w+=|\/?>)/,
1392
+ configStr + '\n ',
1393
+ );
1394
+ } else if (/testId\s*=/.test(newCode)) {
1395
+ newCode = newCode.replace(
1396
+ /([ \t]*)(testId\s*=)/,
1397
+ `$1${configStr}\n$1$2`,
1398
+ );
1399
+ }
1400
+ }
1401
+
1402
+ updateCode(dataSourceModal.id, newCode);
1403
+ setDataSourceModal(null);
1404
+
1405
+ // 构造 prompt 发给 agent
1406
+ const parts: string[] = [];
1407
+ if (dataDescription) parts.push(dataDescription);
1408
+ parts.push(`复合图表包含:${charts.join('、')}`);
1409
+ // 附加各图表配置描述(与单独图表 DataSource modal 输出一致)
1410
+ for (const [chartKey, config] of Object.entries(chartConfigs)) {
1411
+ const flags: string[] = [];
1412
+ for (const [k, v] of Object.entries(config)) {
1413
+ if (v === false || v === '' || v === undefined || v === null)
1414
+ continue;
1415
+ // select/slider 类型:输出具体值
1416
+ if (typeof v === 'string') {
1417
+ if (k === 'variant' && v === 'groupBar') flags.push('多系列');
1418
+ else if (k === 'variant' && v === 'bar') flags.push('单系列');
1419
+ else if (k === 'variant' && v === 'ring')
1420
+ flags.push('环形图');
1421
+ else if (k === 'direction' && v === 'horizontal')
1422
+ flags.push('横向');
1423
+ else if (k === 'direction' && v === 'vertical')
1424
+ flags.push('纵向');
1425
+ } else if (typeof v === 'number') {
1426
+ if (k === 'dimensionCount') flags.push(`${v}个维度`);
1427
+ } else if (v === true) {
1428
+ // boolean 类型:输出中文描述
1429
+ if (k === 'stacked') flags.push('堆叠');
1430
+ else if (k === 'percent') flags.push('百分比');
1431
+ else if (k === 'area') flags.push('面积填充');
1432
+ else if (k === 'smooth') flags.push('拟合曲线');
1433
+ else if (k === 'showDots') flags.push('显示坐标点');
1434
+ else if (k === 'showLabel') flags.push('显示坐标点数据');
1435
+ // 默认开启的项目只在关闭时才有意义,开启时不输出
1436
+ }
1437
+ }
1438
+ // 默认开启的项目关闭时输出
1439
+ if (config.showGrid === false) flags.push('隐藏网格线');
1440
+ if (config.showAxis === false) flags.push('隐藏坐标轴');
1441
+ if (config.legendShow === false) flags.push('隐藏图例');
1442
+ if (config.showLabel === false) flags.push('隐藏数据标签');
1443
+ if (flags.length > 0) {
1444
+ parts.push(`${chartKey}: ${flags.join(', ')}`);
1445
+ }
1446
+ }
1447
+ parts.push(
1448
+ '请返回 MultiChartData 格式:{ xData: string[], series: [{ name, data }] }',
1449
+ );
1450
+ const userPrompt = parts.join('。');
1451
+ triggerDataSourceAgent(
1452
+ dataSourceModal.id,
1453
+ dataSourceModal.componentType,
1454
+ newCode,
1455
+ userPrompt,
1456
+ 'canvas-sql-query',
1457
+ );
1458
+ }}
1459
+ onCancel={() => setDataSourceModal(null)}
1460
+ />
1461
+
1304
1462
  {/* ── 通用文本输入弹窗(如修改标题) ── */}
1305
1463
  <PromptModal
1306
1464
  open={!!promptModal}