1
- import { Card , Divider , Button , Space } from 'antd'
1
+ import { Card , Divider , Button , Space , Select , Input } from 'antd'
2
2
import LogicFlow from '@logicflow/core'
3
- import { useEffect , useRef } from 'react'
4
- import { FlowPath } from '@logicflow/extension'
3
+ import { useEffect , useRef , useState } from 'react'
4
+ import { Snapshot , DndPanel } from '@logicflow/extension'
5
5
6
6
import './index.less'
7
7
import '@logicflow/core/es/index.css'
@@ -11,17 +11,16 @@ import data from './data'
11
11
import Uml from './uml'
12
12
13
13
const config : Partial < LogicFlow . Options > = {
14
- stopScrollGraph : true ,
15
- stopZoomGraph : true ,
14
+ partial : true ,
16
15
grid : {
17
16
type : 'dot' ,
18
17
size : 20 ,
19
18
} ,
20
- plugins : [ FlowPath ] ,
19
+ plugins : [ Snapshot , DndPanel ] ,
21
20
}
22
21
23
- interface Snapshot {
24
- data : LogicFlow . GraphConfigData
22
+ interface SnapshotResponse {
23
+ data : Blob
25
24
width : number
26
25
height : number
27
26
}
@@ -30,74 +29,163 @@ export default function HighLightExtension() {
30
29
const containerRef = useRef < HTMLDivElement | null > ( null )
31
30
const imgRef = useRef < HTMLImageElement | null > ( null )
32
31
33
- let lf : LogicFlow
34
- useEffect ( ( ) => {
35
- lf = new LogicFlow ( {
36
- container : containerRef . current ! ,
37
- ...config ,
38
- } )
39
-
40
- lf . register ( Uml )
32
+ const [ fileName , setFileName ] = useState < undefined | string > ( undefined ) // 文件名
33
+ const [ fileType , setFileType ] = useState < string > ( 'png' ) // 下载的图片类型
34
+ const [ width , setWidth ] = useState < string | undefined > ( ) // 宽度
35
+ const [ height , setHeight ] = useState < string | undefined > ( undefined ) // 高度
36
+ const [ padding , setPaddding ] = useState < string | undefined > ( undefined ) //padding
41
37
42
- lf . render ( data )
43
- lf . translateCenter ( )
38
+ const lfRef = useRef < LogicFlow | null > ( null )
39
+ useEffect ( ( ) => {
40
+ if ( ! lfRef . current ) {
41
+ lfRef . current = new LogicFlow ( {
42
+ container : containerRef . current ! ,
43
+ ...config ,
44
+ } )
45
+
46
+ lfRef . current . register ( Uml )
47
+
48
+ lfRef . current . setPatternItems ( [
49
+ {
50
+ type : 'circle' ,
51
+ text : '开始' ,
52
+ label : '开始节点' ,
53
+ icon : '' ,
54
+ } ,
55
+ {
56
+ type : 'rect' ,
57
+ label : '用户任务' ,
58
+ icon : '' ,
59
+ className : 'important-node' ,
60
+ } ,
61
+ {
62
+ type : 'rect' ,
63
+ label : '系统任务' ,
64
+ icon : '' ,
65
+ className : 'import_icon' ,
66
+ } ,
67
+ {
68
+ type : 'diamond' ,
69
+ label : '条件判断' ,
70
+ icon : '' ,
71
+ } ,
72
+ {
73
+ type : 'circle' ,
74
+ text : '结束' ,
75
+ label : '结束节点' ,
76
+ icon : '' ,
77
+ } ,
78
+ ] )
79
+ lfRef . current . render ( data )
80
+ lfRef . current . translateCenter ( )
81
+
82
+ lfRef . current . extension . snapshot . useGlobalRules = false
83
+ lfRef . current . extension . snapshot . customCssRules = `
84
+ .uml-wrapper {
85
+ line-height: 1.2;
86
+ text-align: center;
87
+ color: blue;
88
+ }
89
+ `
90
+ }
44
91
} , [ ] )
45
92
93
+ // 下载
46
94
const downLoad = ( ) => {
47
- lf . getSnapshot ( )
95
+ lfRef . current &&
96
+ lfRef . current . getSnapshot ( fileName , {
97
+ fileType,
98
+ height : height ,
99
+ padding : padding ,
100
+ backgroundColor : 'yellow' ,
101
+ partialElement : true ,
102
+ ...( width ? { width } : { } ) ,
103
+ ...( height ? { height } : { } ) ,
104
+ ...( padding ? { padding } : { } ) ,
105
+ } )
48
106
}
49
107
108
+ // 预览
50
109
const preview = ( ) => {
51
- lf . getSnapshotBlob ( '#FFFFFF' ) . then ( ( { data, width, height } : Snapshot ) => {
52
- // imgRef.current && imgRef.current.src = window.URL.createObjectURL(data);
53
- console . log ( width , height , data )
54
- } )
110
+ lfRef . current &&
111
+ lfRef . current
112
+ . getSnapshotBlob ( '#FFFFFF' , fileType )
113
+ . then ( ( { data } : SnapshotResponse ) => {
114
+ if ( imgRef . current ) {
115
+ imgRef . current . width = 500
116
+ imgRef . current . height = 400
117
+ imgRef . current . src = window . URL . createObjectURL ( data )
118
+ }
119
+ } )
55
120
}
56
121
122
+ // 打印base64地址
57
123
const logBase64 = ( ) => {
58
- lf . getSnapshotBase64 ( ) . then ( ( { data, width, height } : Snapshot ) => {
59
- // document.getElementById('img').src = data
60
- console . log ( width , height , data )
61
- } )
62
- }
63
-
64
- const downloadXml = ( ) => {
65
- const data = lf . getGraphData ( )
66
- console . log ( lfJson2Xml ( data ) )
67
- download ( 'logicflow.xml' , lfJson2Xml ( data ) )
68
-
69
- function download ( filename , text ) {
70
- const element = document . createElement ( 'a' )
71
- element . setAttribute (
72
- 'href' ,
73
- 'data:text/plain;charset=utf-8,' + encodeURIComponent ( text ) ,
74
- )
75
- element . setAttribute ( 'download' , filename )
76
-
77
- element . style . display = 'none'
78
- document . body . appendChild ( element )
79
-
80
- element . click ( )
81
-
82
- document . body . removeChild ( element )
83
- }
124
+ lfRef . current &&
125
+ lfRef . current
126
+ . getSnapshotBase64 ( undefined , fileType )
127
+ . then ( ( { data, width, height } : SnapshotResponse ) => {
128
+ // document.getElementById('img').src = data
129
+ console . log ( width , height , data )
130
+ } )
84
131
}
85
132
86
133
return (
87
134
< Card title = "LogicFlow Extension - Snapshot" >
135
+ < div style = { { marginBottom : '10px' } } >
136
+ < Space >
137
+ < span > 文件名:</ span >
138
+ < Input
139
+ placeholder = "文件名"
140
+ value = { fileName }
141
+ onChange = { ( e ) => setFileName ( e . target . value ) }
142
+ />
143
+ < span > 文件类型(默认png):</ span >
144
+ < Select
145
+ defaultValue = { fileType }
146
+ style = { { width : 120 } }
147
+ onChange = { ( value ) => setFileType ( value ) }
148
+ options = { [
149
+ { value : 'png' , label : 'png' } ,
150
+ { value : 'jpeg' , label : 'jpeg' } ,
151
+ { value : 'webp' , label : 'webp' } ,
152
+ { value : 'gif' , label : 'gif' } ,
153
+ ] }
154
+ />
155
+ < span > 宽度</ span >
156
+ < Input
157
+ placeholder = "width"
158
+ value = { width }
159
+ onChange = { ( e ) => setWidth ( e . target . value ) }
160
+ />
161
+ < span > 高度</ span >
162
+ < Input
163
+ placeholder = "height"
164
+ value = { height }
165
+ onChange = { ( e ) => setHeight ( e . target . value ) }
166
+ />
167
+ < span > padding</ span >
168
+ < Input
169
+ placeholder = "padding"
170
+ value = { padding }
171
+ onChange = { ( e ) => setPaddding ( e . target . value ) }
172
+ />
173
+ < Button id = "download" onClick = { downLoad } >
174
+ 下载快照
175
+ </ Button >
176
+ </ Space >
177
+ </ div >
178
+ < Divider />
88
179
< Space >
89
- < Button id = "download" onClick = { downLoad } >
90
- 下载快照
91
- </ Button >
92
180
< Button id = "preview" onClick = { preview } >
93
181
预览
94
182
</ Button >
95
183
< Button id = "base64" onClick = { logBase64 } >
96
184
打印base64
97
185
</ Button >
98
- < Button id = "downloadXml" onClick = { downloadXml } >
186
+ { /* <Button id="downloadXml" onClick={downloadXml}>
99
187
获取xml
100
- </ Button >
188
+ </Button> */ }
101
189
</ Space >
102
190
< Divider />
103
191
< div ref = { containerRef } id = "graph" > </ div >
0 commit comments