dcim-topology2d 1.1.6 → 3.0.2
Sign up to get free protection for your applications and to get access to all the features.
- package/activity-diagram/src/final/final.d.ts +1 -1
- package/activity-diagram/src/final/final.rect.d.ts +1 -1
- package/activity-diagram/src/final/final.rect.js +1 -1
- package/activity-diagram/src/fork/fork.anchor.d.ts +1 -1
- package/activity-diagram/src/fork/fork.anchor.js +1 -1
- package/activity-diagram/src/fork/fork.d.ts +1 -1
- package/activity-diagram/src/fork/fork.rect.d.ts +1 -1
- package/activity-diagram/src/fork/fork.rect.js +1 -1
- package/activity-diagram/src/register.js +1 -1
- package/activity-diagram/src/swimlaneH/swimlaneH.d.ts +1 -1
- package/activity-diagram/src/swimlaneH/swimlaneH.rect.d.ts +1 -1
- package/activity-diagram/src/swimlaneH/swimlaneH.rect.js +1 -1
- package/activity-diagram/src/swimlaneV/swimlaneV.d.ts +1 -1
- package/activity-diagram/src/swimlaneV/swimlaneV.rect.d.ts +1 -1
- package/activity-diagram/src/swimlaneV/swimlaneV.rect.js +1 -1
- package/chart-diagram/index.d.ts +0 -2
- package/chart-diagram/index.js +0 -1
- package/chart-diagram/src/echarts/index.d.ts +2 -1
- package/chart-diagram/src/echarts/index.js +104 -106
- package/chart-diagram/src/register.js +8 -9
- package/class-diagram/src/class/class.d.ts +1 -1
- package/class-diagram/src/class/class.rect.d.ts +1 -1
- package/class-diagram/src/class/class.rect.js +1 -1
- package/class-diagram/src/register.js +1 -1
- package/core/index.d.ts +0 -1
- package/core/index.js +0 -1
- package/core/src/activeLayer.d.ts +10 -2
- package/core/src/activeLayer.js +41 -42
- package/core/src/animateLayer.d.ts +7 -3
- package/core/src/animateLayer.js +12 -10
- package/core/src/calling.d.ts +4 -1
- package/core/src/calling.js +41 -43
- package/core/src/canvas.d.ts +6 -1
- package/core/src/canvas.js +18 -17
- package/core/src/common.d.ts +5 -5
- package/core/src/common.js +202 -172
- package/core/src/core.d.ts +4 -3
- package/core/src/core.js +321 -339
- package/core/src/divLayer.d.ts +33 -2
- package/core/src/divLayer.js +292 -41
- package/core/src/healps/changeData.d.ts +1 -1
- package/core/src/healps/changeData.js +44 -102
- package/core/src/hoverLayer.d.ts +9 -2
- package/core/src/hoverLayer.js +34 -31
- package/core/src/middles/default.d.ts +3 -1
- package/core/src/middles/default.js +51 -51
- package/core/src/middles/index.js +2 -3
- package/core/src/middles/nodes/pentagon.rect.js +1 -1
- package/core/src/middles/nodes/rectangle.rect.js +1 -1
- package/core/src/models/data.d.ts +26 -0
- package/core/src/models/data.js +77 -0
- package/core/src/models/data.js.map +1 -0
- package/core/src/models/index.d.ts +1 -0
- package/core/src/models/index.js +1 -0
- package/core/src/models/node.d.ts +0 -6
- package/core/src/models/node.js +16 -29
- package/core/src/models/pen.js +7 -16
- package/core/src/mqtt.d.ts +14 -0
- package/core/src/mqtt.js +82 -0
- package/core/src/mqtt.js.map +1 -0
- package/core/src/offscreen.d.ts +4 -1
- package/core/src/offscreen.js +8 -10
- package/core/src/options.js +0 -1
- package/core/src/poll.js +2 -0
- package/core/src/preview.d.ts +13 -1
- package/core/src/preview.js +34 -56
- package/core/src/renderLayer.d.ts +3 -1
- package/core/src/renderLayer.js +31 -26
- package/core/src/socket.d.ts +10 -0
- package/core/src/socket.js +51 -0
- package/core/src/socket.js.map +1 -0
- package/core/src/utils/canvas.js +1 -1
- package/core/src/utils/conversion.d.ts +0 -7
- package/core/src/utils/conversion.js +0 -54
- package/core/src/utils/dom.d.ts +5 -6
- package/core/src/utils/dom.js +46 -82
- package/core/src/utils/index.d.ts +0 -1
- package/core/src/utils/index.js +0 -1
- package/core/src/utils/onmousevent.js +3 -12
- package/flow-diagram/src/comment/comment.anchor.d.ts +1 -1
- package/flow-diagram/src/comment/comment.anchor.js +1 -1
- package/flow-diagram/src/comment/comment.d.ts +1 -1
- package/flow-diagram/src/data/data.anchor.d.ts +1 -1
- package/flow-diagram/src/data/data.anchor.js +1 -1
- package/flow-diagram/src/data/data.d.ts +1 -1
- package/flow-diagram/src/data/data.rect.d.ts +1 -1
- package/flow-diagram/src/data/data.rect.js +1 -1
- package/flow-diagram/src/db/db.d.ts +1 -1
- package/flow-diagram/src/db/db.rect.d.ts +1 -1
- package/flow-diagram/src/db/db.rect.js +1 -1
- package/flow-diagram/src/display/display.anchor.d.ts +1 -1
- package/flow-diagram/src/display/display.anchor.js +1 -1
- package/flow-diagram/src/display/display.d.ts +1 -1
- package/flow-diagram/src/display/display.rect.d.ts +1 -1
- package/flow-diagram/src/display/display.rect.js +1 -1
- package/flow-diagram/src/document/document.anchor.d.ts +1 -1
- package/flow-diagram/src/document/document.anchor.js +1 -1
- package/flow-diagram/src/document/document.d.ts +1 -1
- package/flow-diagram/src/document/document.rect.d.ts +1 -1
- package/flow-diagram/src/document/document.rect.js +1 -1
- package/flow-diagram/src/externStorage/externStorage.anchor.d.ts +1 -1
- package/flow-diagram/src/externStorage/externStorage.anchor.js +1 -1
- package/flow-diagram/src/externStorage/externStorage.d.ts +1 -1
- package/flow-diagram/src/externStorage/externStorage.rect.d.ts +1 -1
- package/flow-diagram/src/externStorage/externStorage.rect.js +1 -1
- package/flow-diagram/src/internalStorage/internalStorage.d.ts +1 -1
- package/flow-diagram/src/internalStorage/internalStorage.rect.d.ts +1 -1
- package/flow-diagram/src/internalStorage/internalStorage.rect.js +1 -1
- package/flow-diagram/src/manually/manually.anchor.d.ts +1 -1
- package/flow-diagram/src/manually/manually.anchor.js +1 -1
- package/flow-diagram/src/manually/manually.d.ts +1 -1
- package/flow-diagram/src/manually/manually.rect.d.ts +1 -1
- package/flow-diagram/src/manually/manually.rect.js +1 -1
- package/flow-diagram/src/parallel/parallel.anchor.d.ts +1 -1
- package/flow-diagram/src/parallel/parallel.anchor.js +1 -1
- package/flow-diagram/src/parallel/parallel.d.ts +1 -1
- package/flow-diagram/src/queue/queue.d.ts +1 -1
- package/flow-diagram/src/queue/queue.rect.d.ts +1 -1
- package/flow-diagram/src/queue/queue.rect.js +1 -1
- package/flow-diagram/src/register.js +1 -1
- package/flow-diagram/src/subprocess/subprocess.d.ts +1 -1
- package/flow-diagram/src/subprocess/subprocess.rect.d.ts +1 -1
- package/flow-diagram/src/subprocess/subprocess.rect.js +1 -1
- package/layout/src/align.d.ts +1 -1
- package/layout/src/align.js +1 -1
- package/layout/src/layout.d.ts +1 -1
- package/layout/src/layout.js +1 -1
- package/myShape-diagram/myShape.js +1 -1
- package/package.json +1 -1
- package/sequence-diagram/src/focus/focus.anchor.d.ts +1 -1
- package/sequence-diagram/src/focus/focus.anchor.js +1 -1
- package/sequence-diagram/src/focus/focus.d.ts +1 -1
- package/sequence-diagram/src/focus/focus.rect.d.ts +1 -1
- package/sequence-diagram/src/focus/focus.rect.js +1 -1
- package/sequence-diagram/src/lifeline/lifeline.anchor.d.ts +1 -1
- package/sequence-diagram/src/lifeline/lifeline.anchor.js +1 -1
- package/sequence-diagram/src/lifeline/lifeline.d.ts +1 -1
- package/sequence-diagram/src/lifeline/lifeline.rect.d.ts +1 -1
- package/sequence-diagram/src/lifeline/lifeline.rect.js +1 -1
- package/sequence-diagram/src/register.js +1 -1
- package/chart-diagram/src/utils/changeOptions.d.ts +0 -4
- package/chart-diagram/src/utils/changeOptions.js +0 -163
- package/chart-diagram/src/utils/conversion.d.ts +0 -17
- package/chart-diagram/src/utils/conversion.js +0 -179
- package/chart-diagram/src/utils/drawGraphic.d.ts +0 -3
- package/chart-diagram/src/utils/drawGraphic.js +0 -97
- package/chart-diagram/src/utils/index.d.ts +0 -3
- package/chart-diagram/src/utils/index.js +0 -3
- package/core/src/middles/arrows/index.d.ts +0 -4
- package/core/src/middles/arrows/index.js +0 -5
- package/core/src/middles/lines/index.d.ts +0 -4
- package/core/src/middles/lines/index.js +0 -5
- package/core/src/middles/nodes/iframe.d.ts +0 -2
- package/core/src/middles/nodes/iframe.js +0 -12
- package/core/src/middles/nodes/index.d.ts +0 -46
- package/core/src/middles/nodes/index.js +0 -47
- package/core/src/store/common.d.ts +0 -9
- package/core/src/store/common.js +0 -5
- package/core/src/store/data.d.ts +0 -129
- package/core/src/store/data.js +0 -86
- package/core/src/store/index.d.ts +0 -2
- package/core/src/store/index.js +0 -2
- package/core/src/utils/assignment.d.ts +0 -3
- package/core/src/utils/assignment.js +0 -69
- package/static/echartsDefaultData.js +0 -239
- package/static/echartsStore.js +0 -14
- package/static/index.js +0 -2
- package/style/index.css +0 -13
@@ -1,9 +1,6 @@
|
|
1
1
|
//let DETAILDATA = null;
|
2
|
-
import { echartsDefaultDataMap } from '../../../static';
|
3
|
-
import { commonStore } from '../store'
|
4
2
|
export function setConfItemNode(pen, syn_synata) {
|
5
3
|
if (!pen.data) return
|
6
|
-
commonStore[pen.TID].data.dataResize = 1;
|
7
4
|
if(pen.data instanceof Array) {
|
8
5
|
let _syn = ''
|
9
6
|
let isResetVal = false
|
@@ -81,6 +78,7 @@ export function setConfItemNode(pen, syn_synata) {
|
|
81
78
|
color = '#D38C00';
|
82
79
|
break;
|
83
80
|
}
|
81
|
+
|
84
82
|
// 显示的属性
|
85
83
|
if (name === 'text') {
|
86
84
|
pen.font.color = color
|
@@ -90,129 +88,73 @@ export function setConfItemNode(pen, syn_synata) {
|
|
90
88
|
}else {
|
91
89
|
pen.fillStyle = color
|
92
90
|
}
|
91
|
+
|
93
92
|
if (name === 'electricFan') setFanData(pen, _syn)
|
94
93
|
}else {
|
95
94
|
if (pen.elementRendered) pen.elementRendered = false;
|
96
|
-
if(pen.data.echarts) {
|
95
|
+
if(pen.data.params && pen.data.echarts) {
|
97
96
|
const { echartDataValue } = syn_synata;
|
97
|
+
//const seriesData = pen.data.echarts.option.series.length > 1 ? echartDataValue : echartData
|
98
98
|
const seriesData = echartDataValue;
|
99
|
-
|
100
|
-
const staticForType = pen.data.params && pen.data.params.staticForType || '';//统计类型:日,周,月,年
|
101
|
-
pen.data.echarts.option = setStatisticalData(pen, null, staticForType, chartData);
|
99
|
+
if(seriesData) pen.data.echarts = setStatisticalData(pen, seriesData)
|
102
100
|
}
|
103
101
|
}
|
104
102
|
return pen
|
105
103
|
}
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
* @param staticForType 统计类型:日,周,月,年
|
112
|
-
* @param chartData // 图表实时数据
|
113
|
-
* @returns {*}
|
114
|
-
*/
|
115
|
-
export function setStatisticalData(pen, dataType, staticForType, chartData) {
|
116
|
-
const node = JSON.parse(JSON.stringify(pen));
|
117
|
-
const echartsOption = node.data.echarts.option;
|
118
|
-
const optionDisplayMode = echartsOption.displayMode;
|
119
|
-
let displayMode = 0;
|
120
|
-
if(typeof optionDisplayMode === 'string') {
|
121
|
-
|
122
|
-
const displayType = optionDisplayMode.split('_')[0];
|
123
|
-
|
124
|
-
displayMode = parseInt(displayType);
|
125
|
-
|
126
|
-
}else {
|
127
|
-
displayMode = parseInt(optionDisplayMode);
|
128
|
-
}
|
129
|
-
const defaultData = echartsDefaultDataMap[`displayMode_${optionDisplayMode}`];
|
130
|
-
const staticTypeData = chartData && chartData[`${staticForType}_Data`];
|
131
|
-
const chartRealData = staticForType ? staticTypeData || defaultData : chartData || defaultData;
|
132
|
-
if (displayMode === 1 || displayMode === 2){ // 折线图,柱状图
|
104
|
+
export function setStatisticalData(pen, echartData) {
|
105
|
+
const node = Object.assign({}, pen);
|
106
|
+
const displayMode = parseInt(node.data.echarts.option.displayMode);
|
107
|
+
const chartData = echartData[node.data.params.id];
|
108
|
+
if ((displayMode === 1 || displayMode === 2) && chartData){ // 折线图,柱状图
|
133
109
|
//const xData = [], seriesData = [];
|
134
|
-
|
135
|
-
const seriesNodes =
|
136
|
-
const isBaseLineBar = ['line', 'bar'].includes(node.appearance.type);
|
110
|
+
const staticForType = node.data.params.staticForType ? node.data.params.staticForType : '';//统计类型:日,周,月,年
|
111
|
+
const seriesNodes = node.data.echarts.option.series;
|
137
112
|
// 双轴曲线
|
138
|
-
if(seriesNodes.length > 1 || node.data.params
|
113
|
+
if(seriesNodes.length > 1 || node.data.params.curveNum > 1){
|
114
|
+
const chartOptions = staticForType ? chartData[`${staticForType}_Data`] : chartData;
|
139
115
|
const legendData = [];
|
140
|
-
|
141
|
-
|
142
|
-
let
|
143
|
-
|
144
|
-
|
145
|
-
|
146
|
-
|
147
|
-
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
|
155
|
-
|
156
|
-
}else {
|
157
|
-
// 自动生成series数据计算
|
158
|
-
for(let i = 0, sdl = seriesItem.data.length; i < sdl; i++){
|
159
|
-
displayMode === 1 ? seriesItem.data[i] -= 400 : seriesItem.data[i] += 100;
|
160
|
-
}
|
161
|
-
seriesItem.name = `标注${index + 1}`;
|
162
|
-
item.data = seriesItem.data;
|
163
|
-
}
|
164
|
-
}else {
|
165
|
-
// 执行类型为实时数据
|
166
|
-
seriesItem = chartRealData.seriesData[index];
|
167
|
-
if(!seriesItem) return item.data = [];
|
168
|
-
item.data = seriesItem.data;
|
169
|
-
}
|
170
|
-
// 获取角标数据
|
171
|
-
if(seriesItem.name) {
|
172
|
-
item.name = seriesItem.name;
|
173
|
-
legendData.push(seriesItem.name);
|
174
|
-
legendChange = true;
|
175
|
-
}
|
176
|
-
});
|
177
|
-
if(echartsOption.legend && legendChange) echartsOption.legend.data = legendData; // 为角标数据赋值
|
116
|
+
if(!chartOptions) return;
|
117
|
+
node.data.echarts.option.xAxis[0].data = chartOptions.XData;
|
118
|
+
let legend = node.data.echarts.option.legend;
|
119
|
+
if(chartOptions.seriesData.length) {
|
120
|
+
//循环给每条统计数据赋值
|
121
|
+
seriesNodes.map((item, index) => {
|
122
|
+
const { name, data } = chartOptions.seriesData[index];
|
123
|
+
item.name = name;
|
124
|
+
item.data = data;
|
125
|
+
legendData.push(name);
|
126
|
+
});
|
127
|
+
legend.data = legendData;
|
128
|
+
}else {
|
129
|
+
node.data.echarts.option.legend = [];
|
130
|
+
node.data.echarts.option.series = []
|
131
|
+
}
|
178
132
|
}else {
|
179
|
-
|
180
|
-
|
181
|
-
|
182
|
-
|
183
|
-
|
184
|
-
}
|
185
|
-
}
|
186
|
-
if(displayMode === 4) { // top排行榜
|
187
|
-
echartsOption.yAxis[0].data = chartRealData.XData;
|
188
|
-
const { data } = chartRealData.seriesData[0];
|
189
|
-
echartsOption.yAxis[1].data = data;
|
190
|
-
for (let i = 0; i < echartsOption.series.length; i++) {
|
191
|
-
const node = echartsOption.series[i];
|
192
|
-
node.symbolBoundingData = chartRealData.total;
|
193
|
-
node.data = data;
|
133
|
+
const chartOptions = staticForType ? chartData[`${staticForType}_Data`] : chartData;
|
134
|
+
if(chartOptions) {
|
135
|
+
node.data.echarts.option.xAxis[0].data = chartOptions.XData;
|
136
|
+
node.data.echarts.option.series[0].data = chartOptions.seriesData;
|
137
|
+
}
|
194
138
|
}
|
195
139
|
}
|
196
|
-
if (displayMode === 5
|
197
|
-
const colors =
|
198
|
-
const pieData = staticForType ? chartData || defaultData : chartData && chartData.data || defaultData.seriesData;
|
140
|
+
if (displayMode === 5 && chartData){ // 饼图
|
141
|
+
const colors = node.data.echarts.option.color;
|
199
142
|
const seriesData = [];
|
200
|
-
|
143
|
+
chartData.map((chd, index) => {
|
201
144
|
seriesData.push({
|
202
145
|
itemStyle: { color: colors[index] },
|
203
146
|
name: chd.name,
|
204
147
|
value: chd.value
|
205
148
|
})
|
206
149
|
})
|
207
|
-
|
150
|
+
node.data.echarts.option.series[0].data = seriesData;
|
208
151
|
}
|
209
|
-
if(displayMode === 6){ // 仪表盘
|
210
|
-
|
211
|
-
|
212
|
-
|
213
|
-
echartsOption.series[0].data[0].value = chartData && chartData.value || defaultData.value;
|
152
|
+
if(displayMode === 6 && chartData){ // 仪表盘
|
153
|
+
node.appearance.title.text = chartData.name;
|
154
|
+
node.data.echarts.option.title.text = chartData.name;
|
155
|
+
node.data.echarts.option.series[0].data[0].value = chartData.value;
|
214
156
|
}
|
215
|
-
return
|
157
|
+
return node.data.echarts;
|
216
158
|
}
|
217
159
|
export function setNodeEvents(item, pen) {
|
218
160
|
|
package/core/src/hoverLayer.d.ts
CHANGED
@@ -1,6 +1,13 @@
|
|
1
|
-
import {
|
1
|
+
import { TopologyData } from './models/data';
|
2
|
+
import { Rect } from './models/rect';
|
3
|
+
import { Point } from './models/point';
|
4
|
+
import { Line } from './models/line';
|
5
|
+
import { Node } from './models/node';
|
6
|
+
import { Options } from './options';
|
2
7
|
import { Layer } from './layer';
|
3
8
|
export declare class HoverLayer extends Layer {
|
9
|
+
options: Options;
|
10
|
+
protected data: TopologyData;
|
4
11
|
line: Line;
|
5
12
|
initLine: Line;
|
6
13
|
node: Node;
|
@@ -12,7 +19,7 @@ export declare class HoverLayer extends Layer {
|
|
12
19
|
dockLineY: number;
|
13
20
|
root: Node;
|
14
21
|
dragRect: Rect;
|
15
|
-
constructor(TID: String);
|
22
|
+
constructor(options: Options, TID: String);
|
16
23
|
lineTo(to: Point, toArrow?: string): void;
|
17
24
|
lineFrom(from: Point): void;
|
18
25
|
lineMove(pt: Point, initPos: {
|
package/core/src/hoverLayer.js
CHANGED
@@ -1,8 +1,8 @@
|
|
1
1
|
var __extends = (this && this.__extends) || (function () {
|
2
2
|
var extendStatics = function (d, b) {
|
3
3
|
extendStatics = Object.setPrototypeOf ||
|
4
|
-
|
5
|
-
|
4
|
+
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
5
|
+
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
|
6
6
|
return extendStatics(d, b);
|
7
7
|
};
|
8
8
|
return function (d, b) {
|
@@ -11,17 +11,22 @@ var __extends = (this && this.__extends) || (function () {
|
|
11
11
|
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
12
12
|
};
|
13
13
|
})();
|
14
|
-
import { Point
|
14
|
+
import { Point } from './models/point';
|
15
|
+
import { Node } from './models/node';
|
16
|
+
import { PenType } from './models/pen';
|
15
17
|
import { Store } from 'le5le-store';
|
18
|
+
import { Lock } from './models/status';
|
16
19
|
import { Layer } from './layer';
|
17
|
-
import { commonStore } from './store'
|
18
20
|
var HoverLayer = /** @class */ (function (_super) {
|
19
21
|
__extends(HoverLayer, _super);
|
20
|
-
function HoverLayer(TID) {
|
22
|
+
function HoverLayer(options, TID) {
|
23
|
+
if (options === void 0) { options = {}; }
|
21
24
|
var _this = _super.call(this, TID) || this;
|
25
|
+
_this.options = options;
|
22
26
|
_this.hoverAnchorIndex = -1;
|
23
27
|
_this.dockLineX = 0;
|
24
28
|
_this.dockLineY = 0;
|
29
|
+
_this.data = Store.get(_this.generateStoreKey('topology-data'));
|
25
30
|
Store.set(_this.generateStoreKey('LT:HoverLayer'), _this);
|
26
31
|
return _this;
|
27
32
|
}
|
@@ -65,16 +70,14 @@ var HoverLayer = /** @class */ (function (_super) {
|
|
65
70
|
};
|
66
71
|
HoverLayer.prototype.render = function (ctx) {
|
67
72
|
var _this = this;
|
68
|
-
if(
|
69
|
-
var globalStore = commonStore[_this.TID];
|
70
|
-
if (globalStore.data.locked === Lock.NoEvent) {
|
73
|
+
if (this.data.locked === Lock.NoEvent) {
|
71
74
|
return;
|
72
75
|
}
|
73
|
-
ctx.fillStyle =
|
76
|
+
ctx.fillStyle = this.options.hoverColor;
|
74
77
|
ctx.save();
|
75
78
|
// anchors
|
76
|
-
if (
|
77
|
-
|
79
|
+
if (this.options.alwaysAnchor) {
|
80
|
+
this.data.pens.forEach(function (pen) {
|
78
81
|
if (pen.type === PenType.Line) {
|
79
82
|
return;
|
80
83
|
}
|
@@ -87,23 +90,23 @@ var HoverLayer = /** @class */ (function (_super) {
|
|
87
90
|
continue;
|
88
91
|
}
|
89
92
|
ctx.beginPath();
|
90
|
-
ctx.arc(anchor.x, anchor.y, anchor.radius ||
|
91
|
-
ctx.strokeStyle = anchor.strokeStyle ||
|
92
|
-
ctx.fillStyle = anchor.fillStyle ||
|
93
|
+
ctx.arc(anchor.x, anchor.y, anchor.radius || _this.options.anchorRadius, 0, Math.PI * 2);
|
94
|
+
ctx.strokeStyle = anchor.strokeStyle || _this.options.hoverColor;
|
95
|
+
ctx.fillStyle = anchor.fillStyle || _this.options.anchorFillStyle;
|
93
96
|
ctx.fill();
|
94
97
|
ctx.stroke();
|
95
98
|
}
|
96
99
|
});
|
97
100
|
}
|
98
101
|
ctx.restore();
|
99
|
-
if (this.node && !
|
102
|
+
if (this.node && !this.data.locked) {
|
100
103
|
if (!this.node.getTID()) {
|
101
104
|
this.node.setTID(this.TID);
|
102
105
|
}
|
103
106
|
this.root = this.getRoot(this.node) || this.node;
|
104
107
|
if (this.root) {
|
105
108
|
ctx.save();
|
106
|
-
ctx.strokeStyle =
|
109
|
+
ctx.strokeStyle = this.options.dragColor;
|
107
110
|
ctx.globalAlpha = 0.2;
|
108
111
|
if (this.root.rotate) {
|
109
112
|
ctx.translate(this.root.rect.center.x, this.root.rect.center.y);
|
@@ -114,20 +117,20 @@ var HoverLayer = /** @class */ (function (_super) {
|
|
114
117
|
ctx.strokeRect(this.root.rect.x, this.root.rect.y, this.root.rect.width, this.root.rect.height);
|
115
118
|
ctx.restore();
|
116
119
|
}
|
117
|
-
if (!
|
120
|
+
if (!this.options.hideAnchor) {
|
118
121
|
for (var i = 0; i < this.node.rotatedAnchors.length; ++i) {
|
119
122
|
if (this.node.locked ||
|
120
|
-
|
121
|
-
|
123
|
+
this.node.hideAnchor ||
|
124
|
+
(this.node.rotatedAnchors[i].hidden && this.hoverAnchorIndex !== i)) {
|
122
125
|
continue;
|
123
126
|
}
|
124
127
|
ctx.beginPath();
|
125
|
-
ctx.arc(this.node.rotatedAnchors[i].x, this.node.rotatedAnchors[i].y, this.node.rotatedAnchors[i].radius ||
|
128
|
+
ctx.arc(this.node.rotatedAnchors[i].x, this.node.rotatedAnchors[i].y, this.node.rotatedAnchors[i].radius || this.options.anchorRadius, 0, Math.PI * 2);
|
126
129
|
ctx.strokeStyle =
|
127
|
-
|
130
|
+
this.node.rotatedAnchors[i].strokeStyle || this.options.hoverColor;
|
128
131
|
ctx.fillStyle =
|
129
|
-
|
130
|
-
|
132
|
+
this.node.rotatedAnchors[i].fillStyle ||
|
133
|
+
this.options.anchorFillStyle;
|
131
134
|
ctx.fill();
|
132
135
|
ctx.stroke();
|
133
136
|
}
|
@@ -136,9 +139,9 @@ var HoverLayer = /** @class */ (function (_super) {
|
|
136
139
|
if (this.dockAnchor) {
|
137
140
|
ctx.save();
|
138
141
|
ctx.beginPath();
|
139
|
-
ctx.arc(this.dockAnchor.x, this.dockAnchor.y, this.dockAnchor.radius ||
|
140
|
-
ctx.strokeStyle =
|
141
|
-
ctx.fillStyle =
|
142
|
+
ctx.arc(this.dockAnchor.x, this.dockAnchor.y, this.dockAnchor.radius || this.options.anchorRadius, 0, Math.PI * 2);
|
143
|
+
ctx.strokeStyle = this.options.dockStrokeStyle;
|
144
|
+
ctx.fillStyle = this.options.dockFillStyle;
|
142
145
|
ctx.fill();
|
143
146
|
ctx.stroke();
|
144
147
|
ctx.restore();
|
@@ -148,7 +151,7 @@ var HoverLayer = /** @class */ (function (_super) {
|
|
148
151
|
ctx.arc(this.hoverLineCP.x, this.hoverLineCP.y, 5, 0, Math.PI * 2);
|
149
152
|
ctx.fill();
|
150
153
|
}
|
151
|
-
ctx.strokeStyle =
|
154
|
+
ctx.strokeStyle = this.options.hoverColor + '80';
|
152
155
|
ctx.lineWidth = 1;
|
153
156
|
if (this.dockLineX > 0) {
|
154
157
|
var size = Store.get(this.generateStoreKey('LT:size'));
|
@@ -166,8 +169,8 @@ var HoverLayer = /** @class */ (function (_super) {
|
|
166
169
|
}
|
167
170
|
// Select nodes by drag.
|
168
171
|
if (this.dragRect) {
|
169
|
-
ctx.fillStyle =
|
170
|
-
ctx.strokeStyle =
|
172
|
+
ctx.fillStyle = this.options.dragColor + '30';
|
173
|
+
ctx.strokeStyle = this.options.dragColor;
|
171
174
|
ctx.beginPath();
|
172
175
|
ctx.strokeRect(this.dragRect.x, this.dragRect.y, this.dragRect.width, this.dragRect.height);
|
173
176
|
ctx.fillRect(this.dragRect.x, this.dragRect.y, this.dragRect.width, this.dragRect.height);
|
@@ -177,7 +180,7 @@ var HoverLayer = /** @class */ (function (_super) {
|
|
177
180
|
if (!node.parentId) {
|
178
181
|
return null;
|
179
182
|
}
|
180
|
-
for (var _i = 0, _a =
|
183
|
+
for (var _i = 0, _a = this.data.pens; _i < _a.length; _i++) {
|
181
184
|
var item = _a[_i];
|
182
185
|
if (item instanceof Node && item.id === node.parentId) {
|
183
186
|
var n = this.getRoot(item);
|
@@ -193,4 +196,4 @@ var HoverLayer = /** @class */ (function (_super) {
|
|
193
196
|
return HoverLayer;
|
194
197
|
}(Layer));
|
195
198
|
export { HoverLayer };
|
196
|
-
//# sourceMappingURL=hoverLayer.js.map
|
199
|
+
//# sourceMappingURL=hoverLayer.js.map
|
@@ -1,4 +1,6 @@
|
|
1
|
-
import { Point
|
1
|
+
import { Point } from '../models';
|
2
|
+
import { Node } from '../models';
|
3
|
+
import { Line } from '../models';
|
2
4
|
export declare const drawNodeFns: any;
|
3
5
|
export declare const iconRectFns: any;
|
4
6
|
export declare const textRectFns: any;
|
@@ -1,52 +1,54 @@
|
|
1
|
-
import {
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
} from './
|
22
|
-
import {
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
} from './
|
40
|
-
import {
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
} from './
|
1
|
+
import { rectangle } from './nodes/rectangle';
|
2
|
+
import { circle } from './nodes/circle';
|
3
|
+
import { triangle } from './nodes/triangle';
|
4
|
+
import { diamond } from './nodes/diamond';
|
5
|
+
import { leftArrow, rightArrow, twowayArrow } from './nodes/arrow';
|
6
|
+
import { text } from './nodes/text';
|
7
|
+
import { line as nodeLine } from './nodes/line';
|
8
|
+
import { triangleAnchors } from './nodes/triangle.anchor';
|
9
|
+
import { arrowAnchors } from './nodes/arrow.anchor';
|
10
|
+
import { lineAnchors } from './nodes/line.anchor';
|
11
|
+
import { circleIconRect, circleTextRect } from './nodes/circle.rect';
|
12
|
+
import { triangleIconRect, triangleTextRect } from './nodes/triangle.rect';
|
13
|
+
import { diamondIconRect, diamondTextRect } from './nodes/diamond.rect';
|
14
|
+
import { twowayArrowIconRect, twowayArrowTextRect, leftArrowIconRect, leftArrowTextRect, rightArrowIconRect, rightArrowTextRect } from './nodes/arrow.rect';
|
15
|
+
import { lineIconRect, lineTextRect } from './nodes/line.rect';
|
16
|
+
import { line, lineControlPoints, calcLineControlPoints } from './lines/line';
|
17
|
+
import { polyline, polylineControlPoints, pointInPolyline, calcPolylineControlPoints, dockPolylineControlPoint } from './lines/polyline';
|
18
|
+
import { curve, curveControlPoints, pointInCurve, calcCurveControlPoints } from './lines/curve';
|
19
|
+
import { mind, calcMindControlPoints, mindControlPoints, pointInMind } from './lines/mind';
|
20
|
+
import { triangleSolid, triangle as arrowTriangle } from './arrows/triangle';
|
21
|
+
import { diamondSolid, diamond as arrowDiamond } from './arrows/diamond';
|
22
|
+
import { circleSolid, circle as arrowCircle } from './arrows/circle';
|
23
|
+
import { circleAnchors } from './nodes/circle.anchor';
|
24
|
+
import { lineUp, lineDown, line as arrowLine } from './arrows/line';
|
25
|
+
import { pentagon } from './nodes/pentagon';
|
26
|
+
import { pentagonIconRect, pentagonTextRect } from './nodes/pentagon.rect';
|
27
|
+
import { pentagonAnchors } from './nodes/pentagon.anchor';
|
28
|
+
import { hexagon } from './nodes/hexagon';
|
29
|
+
import { hexagonAnchors } from './nodes/hexagon.anchor';
|
30
|
+
import { hexagonIconRect, hexagonTextRect } from './nodes/hexagon.rect';
|
31
|
+
import { pentagram } from './nodes/pentagram';
|
32
|
+
import { pentagramAnchors } from './nodes/pentagram.anchor';
|
33
|
+
import { pentagramIconRect, pentagramTextRect } from './nodes/pentagram.rect';
|
34
|
+
import { cloud } from './nodes/cloud';
|
35
|
+
import { cloudAnchors } from './nodes/cloud.anchor';
|
36
|
+
import { cloudIconRect, cloudTextRect } from './nodes/cloud.rect';
|
37
|
+
import { message } from './nodes/message';
|
38
|
+
import { messageIconRect, messageTextRect } from './nodes/message.rect';
|
39
|
+
import { messageAnchors } from './nodes/message.anchor';
|
40
|
+
import { file } from './nodes/file';
|
41
|
+
import { imageIconRect, imageTextRect } from './nodes/image.rect';
|
42
|
+
import { cube } from './nodes/cube';
|
43
|
+
import { cubeAnchors } from './nodes/cube.anchor';
|
44
|
+
import { cubeIconRect, cubeTextRect } from './nodes/cube.rect';
|
45
|
+
import { people } from './nodes/people';
|
46
|
+
import { peopleIconRect, peopleTextRect } from './nodes/people.rect';
|
47
|
+
import { rectangleIconRect, rectangleTextRect } from './nodes/rectangle.rect';
|
48
|
+
import { arbitraryGraph } from './nodes/arbitrarygraph';
|
49
|
+
import { arbitraryGraphAnchors } from './nodes/arbitrarygraph.anchor';
|
50
|
+
import { formtable } from './nodes/formtable';
|
51
|
+
import { tablePagination } from './nodes/tablePagination';
|
50
52
|
// Functions of drawing a node.
|
51
53
|
export var drawNodeFns = {};
|
52
54
|
// Calc the occupy rect of icon.
|
@@ -62,8 +64,6 @@ export var drawArrowFns = {};
|
|
62
64
|
function init() {
|
63
65
|
console.log('Init middles.');
|
64
66
|
// ********Default nodes.*******
|
65
|
-
// iframe
|
66
|
-
drawNodeFns.iframe = iframePrimeval;
|
67
67
|
// tablePagination
|
68
68
|
drawNodeFns.tablePagination = tablePagination;
|
69
69
|
// formtable
|
@@ -1,4 +1,4 @@
|
|
1
|
-
import { Rect } from '../../models';
|
1
|
+
import { Rect } from '../../models/rect';
|
2
2
|
export function rectangleIconRect(node) {
|
3
3
|
node.iconRect = new Rect(node.rect.x + node.paddingLeftNum, node.rect.y + node.paddingTopNum, node.rect.height - node.paddingTopNum - node.paddingBottomNum, node.rect.height - node.paddingTopNum - node.paddingBottomNum);
|
4
4
|
node.fullIconRect = new Rect(node.rect.x + node.paddingLeftNum, node.rect.y + node.paddingTopNum, node.rect.width - node.paddingLeftNum - node.paddingRightNum, node.rect.height - node.paddingTopNum - node.paddingBottomNum);
|
@@ -0,0 +1,26 @@
|
|
1
|
+
import { Pen } from './pen';
|
2
|
+
import { Lock } from './status';
|
3
|
+
export declare class TopologyData {
|
4
|
+
pens: Pen[];
|
5
|
+
lineName: string;
|
6
|
+
fromArrowType: string;
|
7
|
+
toArrowType: string;
|
8
|
+
scale: number;
|
9
|
+
locked: Lock;
|
10
|
+
bkImage: string;
|
11
|
+
bkColor: string;
|
12
|
+
grid?: boolean;
|
13
|
+
websocket?: string;
|
14
|
+
mqttUrl?: string;
|
15
|
+
mqttOptions?: {
|
16
|
+
clientId?: string;
|
17
|
+
username?: string;
|
18
|
+
password?: string;
|
19
|
+
};
|
20
|
+
mqttTopics?: string;
|
21
|
+
manualCps?: boolean;
|
22
|
+
dataConstruct?: any;
|
23
|
+
data?: any;
|
24
|
+
bkImageRect?: any;
|
25
|
+
constructor(json?: any);
|
26
|
+
}
|
@@ -0,0 +1,77 @@
|
|
1
|
+
import { Node } from './node';
|
2
|
+
import { Line } from './line';
|
3
|
+
import { Lock } from './status';
|
4
|
+
import { s8 } from '../utils';
|
5
|
+
var TopologyData = /** @class */ (function () {
|
6
|
+
function TopologyData(json) {
|
7
|
+
this.pens = [];
|
8
|
+
this.lineName = 'curve';
|
9
|
+
this.fromArrowType = '';
|
10
|
+
this.toArrowType = 'triangleSolid';
|
11
|
+
this.scale = 1;
|
12
|
+
this.locked = Lock.None;
|
13
|
+
this.bkImageRect = null;
|
14
|
+
this.mqttOptions = {
|
15
|
+
clientId: s8()
|
16
|
+
};
|
17
|
+
this.dataConstruct = {};
|
18
|
+
if (json) {
|
19
|
+
this.pens = [];
|
20
|
+
json.dataConstruct = {};
|
21
|
+
for (var _i = 0, _a = json.pens; _i < _a.length; _i++) {
|
22
|
+
var item = _a[_i];
|
23
|
+
if (item.from) {
|
24
|
+
this.pens.push(new Line(item));
|
25
|
+
}
|
26
|
+
else {
|
27
|
+
if(item.name === 'formTable') {
|
28
|
+
json.dataConstruct[item.id] = {
|
29
|
+
id: item.id,
|
30
|
+
name: 'table'
|
31
|
+
}
|
32
|
+
}
|
33
|
+
this.pens.push(new Node(item));
|
34
|
+
}
|
35
|
+
}
|
36
|
+
this.lineName = json.lineName || 'curve';
|
37
|
+
this.fromArrowType = json.fromArrowType || '';
|
38
|
+
this.toArrowType = json.toArrowType || 'triangleSolid';
|
39
|
+
this.scale = json.scale || 1;
|
40
|
+
this.locked = json.locked || Lock.None;
|
41
|
+
this.bkImage = json.bkImage;
|
42
|
+
this.bkColor = json.bkColor;
|
43
|
+
this.grid = json.grid;
|
44
|
+
this.manualCps = json.manualCps;
|
45
|
+
this.websocket = json.websocket;
|
46
|
+
this.mqttUrl = json.mqttUrl;
|
47
|
+
this.bkImageRect = json.bkImageRect;
|
48
|
+
if (json.mqttOptions) {
|
49
|
+
var opts = '';
|
50
|
+
if (typeof json.mqttOptions === 'object') {
|
51
|
+
opts = JSON.stringify(json.mqttOptions);
|
52
|
+
}
|
53
|
+
else {
|
54
|
+
opts = json.mqttOptions + '';
|
55
|
+
}
|
56
|
+
this.mqttOptions = JSON.parse(opts);
|
57
|
+
}
|
58
|
+
else {
|
59
|
+
this.mqttOptions = { clientId: s8() };
|
60
|
+
}
|
61
|
+
this.dataConstruct = json.dataConstruct ? json.dataConstruct : {};
|
62
|
+
this.mqttTopics = json.mqttTopics;
|
63
|
+
if (typeof json.data === 'object') {
|
64
|
+
this.data = JSON.parse(JSON.stringify(json.data));
|
65
|
+
}
|
66
|
+
else {
|
67
|
+
this.data = json.data || '';
|
68
|
+
}
|
69
|
+
}
|
70
|
+
if (!this.mqttOptions) {
|
71
|
+
this.mqttOptions = { clientId: s8() };
|
72
|
+
}
|
73
|
+
}
|
74
|
+
return TopologyData;
|
75
|
+
}());
|
76
|
+
export { TopologyData };
|
77
|
+
//# sourceMappingURL=data.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"data.js","sourceRoot":"","sources":["../../../../packages/core/src/models/data.ts"],"names":[],"mappings":"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"}
|
package/core/src/models/index.js
CHANGED