| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
 | | import { NODES, TYPE, ConditionType } from './enum' |  | import { Create } from '@/libs/Create/Create' |  | import { v4 as uuidv4 } from 'uuid' |  | import { fontSize, nodeFontSize } from '../components/Nodes' |  |   |  | interface NodeItem { |  |   type: TYPE.NODE | TYPE.EDGE |  |   label: string |  | } |  |   |  | interface PointType { |  |   x: number |  |   y: number |  |   properties: any |  | } |  | export default class Core { |  |   createNode({ label, type }: NodeItem, { x, y, properties }: PointType) { |  |     const id = uuidv4() |  |     return new Create({ |  |       id, |  |       type, |  |       label, |  |       x, |  |       y, |  |       properties, |  |       Name: label, |  |       name: label, |  |     }) |  |   } |  |   setDefaultProps() { |  |     return { |  |       fitCenter: true, |  |       animate: true, |  |       minZoom: 0.2, |  |       maxZoom: 1.4, |  |       defaultNode: { |  |         type: NODES.ACTIVITIES, |  |         labelCfg: { |  |           style: { |  |             fill: '#333', |  |             fontSize: nodeFontSize, |  |             textAlign: 'center', |  |             textBaseline: 'middle', |  |             fontWeight: 'bold', |  |           }, |  |         }, |  |       }, |  |       defaultEdge: { |  |         type: 'polyline', |  |   |  |         labelCfg: { |  |           // refX: 10, |  |           // refY: -5, |  |           style: { |  |             fill: '#333', |  |             stroke: '#aaa', |  |             fontSize: fontSize - 2, |  |           }, |  |         }, |  |         style: { |  |           radius: 20, |  |           offset: 45, |  |           endArrow: true, |  |           lineWidth: 3, |  |           stroke: '#aaa', |  |           // router: true, |  |         }, |  |       }, |  |       edgeStateStyles: { |  |         active: { |  |           stroke: '#5a84ff', |  |           lineWidth: 6, |  |           'text-shape': { |  |             fontSize: fontSize, |  |           }, |  |         }, |  |         hover: { |  |           stroke: '#5a84ff', |  |           lineWidth: 6, |  |           'text-shape': { |  |             fontSize: fontSize, |  |           }, |  |         }, |  |       }, |  |       nodeStateStyles: { |  |         hover: { |  |           stroke: '#d9d9d9', |  |           fill: '#8ca9ff', |  |           'text-shape': { |  |             fill: '#fff', |  |           }, |  |         }, |  |         active: { |  |           stroke: 'rgb(104 53 255 / 50%)', |  |           shadowColor: '#5b8ff9', |  |           shadowBlur: 7, |  |           'text-shape': { |  |             fill: '#333', |  |           }, |  |         }, |  |         selected: { |  |           stroke: 'rgb(104 53 255 / 50%)', |  |           fill: '#8ca9ff', |  |           'text-shape': { |  |             fill: '#fff', |  |           }, |  |         }, |  |       }, |  |     } |  |   } |  |   static createRoot() { |  |     return new Create({ |  |       id: '启动', |  |       type: NODES.ACTIVITIES, |  |       isRoot: true, |  |       text: { |  |         x: 0, |  |         y: 0, |  |       }, |  |       label: '启动', |  |       properties: { |  |         Alias: '启动', |  |         Name: '启动', |  |         Description: '', |  |         EnterMode: '', |  |         ExitMode: '', |  |         JoinType: '', |  |         SplitType: '', |  |         ExtendedProperty: '', |  |         [ConditionType]: '', |  |         type: NODES.ACTIVITIES, |  |         id: '启动', |  |         name: '启动', |  |         label: '启动', |  |       }, |  |       isEdit: true, |  |     }) |  |   } |  |   |  |   static createBaseXml(name?: string) { |  |     name = name || '' |  |     return `<ProcessflowDefine Version="1"> |  |       <Define> |  |         <ProcessflowBuilder xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema"> |  |           <Parameters></Parameters> |  |           <Name>${name}</Name> |  |           <Description></Description> |  |           <Root xsi:type=""> |  |             <Alias>启动</Alias> |  |             <Name>启动</Name> |  |             <Description></Description> |  |             <EnterMode></EnterMode> |  |             <ExitMode></ExitMode> |  |             <JoinType></JoinType> |  |             <SplitType></SplitType> |  |             <ExtendedProperty></ExtendedProperty> |  |           </Root> |  |           <Activities></Activities> |  |           <Transitions></Transitions> |  |         </ProcessflowBuilder> |  |       </Define> |  |       <Appearance> |  |         <ProcessflowAppearance> |  |           <启动> |  |             <x>74.55000000000001</x> |  |             <y>56.25</y> |  |           </启动> |  |         </ProcessflowAppearance> |  |       </Appearance> |  |     </ProcessflowDefine>` |  |   } |  | } | 
 |