Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wisdom-components
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
ReactWeb5
wisdom-components
Commits
a810697e
Commit
a810697e
authored
Apr 25, 2023
by
李纪文
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fix: 组态增加展示方式
parent
4fe79a8e
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
100 additions
and
26 deletions
+100
-26
HistoryModel.js
...xtend-components/EC_ConfigurationView/src/HistoryModel.js
+47
-10
RealModel.js
...s/extend-components/EC_ConfigurationView/src/RealModel.js
+47
-10
Basic1.tsx
...tend-components/EC_ConfigurationView/src/demos/Basic1.tsx
+6
-6
No files found.
packages/extend-components/EC_ConfigurationView/src/HistoryModel.js
View file @
a810697e
...
@@ -125,7 +125,11 @@ const ConfigurationView = (props) => {
...
@@ -125,7 +125,11 @@ const ConfigurationView = (props) => {
switch
(
node
.
category
)
{
switch
(
node
.
category
)
{
case
'svgCase'
:
// 图片模型
case
'svgCase'
:
// 图片模型
shRule
=
ruleOperation
(
node
,
realVal
);
shRule
=
ruleOperation
(
node
,
realVal
);
myDiagram
.
model
.
setDataProperty
(
node
,
'imgSrc'
,
shRule
?
shRule
.
attr
:
node
.
dtImgSrc
);
if
(
node
.
shType
===
'模型切换'
)
{
myDiagram
.
model
.
setDataProperty
(
node
,
'imgSrc'
,
shRule
?
shRule
.
attr
:
node
.
dtImgSrc
);
}
else
if
(
node
.
shType
===
'显隐展示'
)
{
myDiagram
.
model
.
setDataProperty
(
node
,
'visible'
,
shRule
?
shRule
.
visible
:
true
);
}
break
;
break
;
case
'nameCase'
:
// 名称模型
case
'nameCase'
:
// 名称模型
if
(
node
.
shType
===
'文本变化'
)
{
if
(
node
.
shType
===
'文本变化'
)
{
...
@@ -151,6 +155,12 @@ const ConfigurationView = (props) => {
...
@@ -151,6 +155,12 @@ const ConfigurationView = (props) => {
}
else
{
}
else
{
myDiagram
.
model
.
setDataProperty
(
node
,
'showVal'
,
realVal
);
myDiagram
.
model
.
setDataProperty
(
node
,
'showVal'
,
realVal
);
}
}
shRule
=
ruleOperation
(
node
,
realVal
);
myDiagram
.
model
.
setDataProperty
(
node
,
'fontStroke'
,
shRule
?
shRule
.
attr
:
node
.
fontStroke
,
);
break
;
break
;
case
'waterCase'
:
// 水池模型
case
'waterCase'
:
// 水池模型
const
height
=
node
.
height
-
node
.
strokeWidth
*
2
;
const
height
=
node
.
height
-
node
.
strokeWidth
*
2
;
...
@@ -215,15 +225,39 @@ const ConfigurationView = (props) => {
...
@@ -215,15 +225,39 @@ const ConfigurationView = (props) => {
break
;
break
;
case
'modelCase'
:
// 模板块模型
case
'modelCase'
:
// 模板块模型
shRule
=
ruleOperation
(
node
,
realVal
);
shRule
=
ruleOperation
(
node
,
realVal
);
myDiagram
.
model
.
setDataProperty
(
node
,
'zOrder'
,
shRule
?
shRule
.
text
:
node
.
dtzOrder
);
if
(
node
.
shType
===
'层级展示'
)
{
myDiagram
.
model
.
setDataProperty
(
node
,
'zOrder'
,
shRule
?
shRule
.
text
*
1
||
node
.
dtzOrder
:
node
.
dtzOrder
,
);
}
else
if
(
node
.
shType
===
'显隐展示'
)
{
myDiagram
.
model
.
setDataProperty
(
node
,
'visible'
,
shRule
?
shRule
.
visible
:
true
);
}
break
;
break
;
case
'ellipseCase'
:
// 圆形模型
case
'ellipseCase'
:
// 圆形模型
shRule
=
ruleOperation
(
node
,
realVal
);
shRule
=
ruleOperation
(
node
,
realVal
);
myDiagram
.
model
.
setDataProperty
(
if
(
node
.
shType
===
'层级展示'
)
{
node
,
myDiagram
.
model
.
setDataProperty
(
'zOrder'
,
node
,
shRule
?
shRule
.
text
*
1
||
0
:
node
.
dtzOrder
,
'zOrder'
,
);
shRule
?
shRule
.
text
*
1
||
node
.
dtzOrder
:
node
.
dtzOrder
,
);
}
else
if
(
node
.
shType
===
'显隐展示'
)
{
myDiagram
.
model
.
setDataProperty
(
node
,
'visible'
,
shRule
?
shRule
.
visible
:
true
);
}
break
;
case
'imgCase'
:
// 图片模型
shRule
=
ruleOperation
(
node
,
realVal
);
if
(
node
.
shType
===
'层级展示'
)
{
myDiagram
.
model
.
setDataProperty
(
node
,
'zOrder'
,
shRule
?
shRule
.
text
*
1
||
node
.
dtzOrder
:
node
.
dtzOrder
,
);
}
else
if
(
node
.
shType
===
'显隐展示'
)
{
myDiagram
.
model
.
setDataProperty
(
node
,
'visible'
,
shRule
?
shRule
.
visible
:
true
);
}
break
;
break
;
default
:
default
:
break
;
break
;
...
@@ -948,6 +982,7 @@ const ConfigurationView = (props) => {
...
@@ -948,6 +982,7 @@ const ConfigurationView = (props) => {
new go.Binding('cursor', 'cursor').makeTwoWay(),
new go.Binding('cursor', 'cursor').makeTwoWay(),
new go.Binding('location', 'loc', go.Point.parse).makeTwoWay(go.Point.stringify),
new go.Binding('location', 'loc', go.Point.parse).makeTwoWay(go.Point.stringify),
new go.Binding('angle').makeTwoWay(),
new go.Binding('angle').makeTwoWay(),
roleVisibleBinding(), // 绑定角色可见
// the main object is a Panel that surrounds a TextBlock with a Shape ~图形:Panel包围着TextBlock
// the main object is a Panel that surrounds a TextBlock with a Shape ~图形:Panel包围着TextBlock
goJS(
goJS(
...
@@ -957,7 +992,7 @@ const ConfigurationView = (props) => {
...
@@ -957,7 +992,7 @@ const ConfigurationView = (props) => {
name: 'PANEL',
name: 'PANEL',
},
},
new go.Binding('desiredSize', 'size', go.Size.parse).makeTwoWay(go.Size.stringify),
new go.Binding('desiredSize', 'size', go.Size.parse).makeTwoWay(go.Size.stringify),
new go.Binding('visible', 'visible').makeTwoWay(),
goJS(
goJS(
go.Picture,
go.Picture,
{
{
...
@@ -1025,7 +1060,7 @@ const ConfigurationView = (props) => {
...
@@ -1025,7 +1060,7 @@ const ConfigurationView = (props) => {
name: 'PANEL',
name: 'PANEL',
},
},
new go.Binding('desiredSize', 'size', go.Size.parse).makeTwoWay(go.Size.stringify),
new go.Binding('desiredSize', 'size', go.Size.parse).makeTwoWay(go.Size.stringify),
new go.Binding('visible', 'visible').makeTwoWay(),
goJS(
goJS(
go.Picture,
go.Picture,
{ name: 'animateSvg', width: 56, height: 56, column: 0, scale: 1, source: '' },
{ name: 'animateSvg', width: 56, height: 56, column: 0, scale: 1, source: '' },
...
@@ -1079,6 +1114,7 @@ const ConfigurationView = (props) => {
...
@@ -1079,6 +1114,7 @@ const ConfigurationView = (props) => {
go.Shape,
go.Shape,
'RoundedRectanglePlus',
'RoundedRectanglePlus',
{ name: 'SHAPE', fill: 'rgba(128,128,128,0.2)', stroke: 'gray', parameter1: 0 },
{ name: 'SHAPE', fill: 'rgba(128,128,128,0.2)', stroke: 'gray', parameter1: 0 },
new go.Binding('visible', 'visible').makeTwoWay(),
new go.Binding('parameter1', 'radius').makeTwoWay(),
new go.Binding('parameter1', 'radius').makeTwoWay(),
new go.Binding('fill', 'fillColor').makeTwoWay(),
new go.Binding('fill', 'fillColor').makeTwoWay(),
new go.Binding('stroke').makeTwoWay(),
new go.Binding('stroke').makeTwoWay(),
...
@@ -1109,6 +1145,7 @@ const ConfigurationView = (props) => {
...
@@ -1109,6 +1145,7 @@ const ConfigurationView = (props) => {
go.Shape,
go.Shape,
'Ellipse',
'Ellipse',
{ name: 'SHAPE', fill: 'rgba(128,128,128,0.2)', stroke: 'gray' },
{ name: 'SHAPE', fill: 'rgba(128,128,128,0.2)', stroke: 'gray' },
new go.Binding('visible', 'visible').makeTwoWay(),
new go.Binding('fill', 'fillColor').makeTwoWay(),
new go.Binding('fill', 'fillColor').makeTwoWay(),
new go.Binding('stroke').makeTwoWay(),
new go.Binding('stroke').makeTwoWay(),
new go.Binding('strokeWidth').makeTwoWay(),
new go.Binding('strokeWidth').makeTwoWay(),
...
@@ -1892,7 +1929,7 @@ const ConfigurationView = (props) => {
...
@@ -1892,7 +1929,7 @@ const ConfigurationView = (props) => {
if (item.category === 'modelCase' || item.category === 'ellipseCase') {
if (item.category === 'modelCase' || item.category === 'ellipseCase') {
item.dtzOrder = item.zOrder;
item.dtzOrder = item.zOrder;
}
}
if (item.category == 'deviceCase' && deviceName && deviceName.length) {
if (item.category == 'deviceCase' &&
item.shType &&
deviceName && deviceName.length) {
var device = deviceName.find(function (arr, index) {
var device = deviceName.find(function (arr, index) {
return '设备' + stationList[index] == item.stationName;
return '设备' + stationList[index] == item.stationName;
});
});
...
...
packages/extend-components/EC_ConfigurationView/src/RealModel.js
View file @
a810697e
...
@@ -155,7 +155,11 @@ const ConfigurationView = (props) => {
...
@@ -155,7 +155,11 @@ const ConfigurationView = (props) => {
switch
(
node
.
category
)
{
switch
(
node
.
category
)
{
case
'svgCase'
:
// 图片模型
case
'svgCase'
:
// 图片模型
shRule
=
ruleOperation
(
node
,
realVal
);
shRule
=
ruleOperation
(
node
,
realVal
);
myDiagram
.
model
.
setDataProperty
(
node
,
'imgSrc'
,
shRule
?
shRule
.
attr
:
node
.
dtImgSrc
);
if
(
node
.
shType
===
'模型切换'
)
{
myDiagram
.
model
.
setDataProperty
(
node
,
'imgSrc'
,
shRule
?
shRule
.
attr
:
node
.
dtImgSrc
);
}
else
if
(
node
.
shType
===
'显隐展示'
)
{
myDiagram
.
model
.
setDataProperty
(
node
,
'visible'
,
shRule
?
shRule
.
visible
:
true
);
}
break
;
break
;
case
'nameCase'
:
// 名称模型
case
'nameCase'
:
// 名称模型
if
(
node
.
shType
===
'文本变化'
)
{
if
(
node
.
shType
===
'文本变化'
)
{
...
@@ -181,6 +185,12 @@ const ConfigurationView = (props) => {
...
@@ -181,6 +185,12 @@ const ConfigurationView = (props) => {
}
else
{
}
else
{
myDiagram
.
model
.
setDataProperty
(
node
,
'showVal'
,
realVal
);
myDiagram
.
model
.
setDataProperty
(
node
,
'showVal'
,
realVal
);
}
}
shRule
=
ruleOperation
(
node
,
realVal
);
myDiagram
.
model
.
setDataProperty
(
node
,
'fontStroke'
,
shRule
?
shRule
.
attr
:
node
.
fontStroke
,
);
break
;
break
;
case
'waterCase'
:
// 水池模型
case
'waterCase'
:
// 水池模型
const
height
=
node
.
height
-
node
.
strokeWidth
*
2
;
const
height
=
node
.
height
-
node
.
strokeWidth
*
2
;
...
@@ -245,15 +255,39 @@ const ConfigurationView = (props) => {
...
@@ -245,15 +255,39 @@ const ConfigurationView = (props) => {
break
;
break
;
case
'modelCase'
:
// 模板块模型
case
'modelCase'
:
// 模板块模型
shRule
=
ruleOperation
(
node
,
realVal
);
shRule
=
ruleOperation
(
node
,
realVal
);
myDiagram
.
model
.
setDataProperty
(
node
,
'zOrder'
,
shRule
?
shRule
.
text
:
node
.
dtzOrder
);
if
(
node
.
shType
===
'层级展示'
)
{
myDiagram
.
model
.
setDataProperty
(
node
,
'zOrder'
,
shRule
?
shRule
.
text
*
1
||
node
.
dtzOrder
:
node
.
dtzOrder
,
);
}
else
if
(
node
.
shType
===
'显隐展示'
)
{
myDiagram
.
model
.
setDataProperty
(
node
,
'visible'
,
shRule
?
shRule
.
visible
:
true
);
}
break
;
break
;
case
'ellipseCase'
:
// 圆形模型
case
'ellipseCase'
:
// 圆形模型
shRule
=
ruleOperation
(
node
,
realVal
);
shRule
=
ruleOperation
(
node
,
realVal
);
myDiagram
.
model
.
setDataProperty
(
if
(
node
.
shType
===
'层级展示'
)
{
node
,
myDiagram
.
model
.
setDataProperty
(
'zOrder'
,
node
,
shRule
?
shRule
.
text
*
1
||
0
:
node
.
dtzOrder
,
'zOrder'
,
);
shRule
?
shRule
.
text
*
1
||
node
.
dtzOrder
:
node
.
dtzOrder
,
);
}
else
if
(
node
.
shType
===
'显隐展示'
)
{
myDiagram
.
model
.
setDataProperty
(
node
,
'visible'
,
shRule
?
shRule
.
visible
:
true
);
}
break
;
case
'imgCase'
:
// 图片模型
shRule
=
ruleOperation
(
node
,
realVal
);
if
(
node
.
shType
===
'层级展示'
)
{
myDiagram
.
model
.
setDataProperty
(
node
,
'zOrder'
,
shRule
?
shRule
.
text
*
1
||
node
.
dtzOrder
:
node
.
dtzOrder
,
);
}
else
if
(
node
.
shType
===
'显隐展示'
)
{
myDiagram
.
model
.
setDataProperty
(
node
,
'visible'
,
shRule
?
shRule
.
visible
:
true
);
}
break
;
break
;
default
:
default
:
break
;
break
;
...
@@ -1366,6 +1400,7 @@ const ConfigurationView = (props) => {
...
@@ -1366,6 +1400,7 @@ const ConfigurationView = (props) => {
new go.Binding('cursor', 'cursor').makeTwoWay(),
new go.Binding('cursor', 'cursor').makeTwoWay(),
new go.Binding('location', 'loc', go.Point.parse).makeTwoWay(go.Point.stringify),
new go.Binding('location', 'loc', go.Point.parse).makeTwoWay(go.Point.stringify),
new go.Binding('angle').makeTwoWay(),
new go.Binding('angle').makeTwoWay(),
roleVisibleBinding(), // 绑定角色可见
// the main object is a Panel that surrounds a TextBlock with a Shape ~图形:Panel包围着TextBlock
// the main object is a Panel that surrounds a TextBlock with a Shape ~图形:Panel包围着TextBlock
goJS(
goJS(
...
@@ -1375,7 +1410,7 @@ const ConfigurationView = (props) => {
...
@@ -1375,7 +1410,7 @@ const ConfigurationView = (props) => {
name: 'PANEL',
name: 'PANEL',
},
},
new go.Binding('desiredSize', 'size', go.Size.parse).makeTwoWay(go.Size.stringify),
new go.Binding('desiredSize', 'size', go.Size.parse).makeTwoWay(go.Size.stringify),
new go.Binding('visible', 'visible').makeTwoWay(),
goJS(
goJS(
go.Picture,
go.Picture,
{
{
...
@@ -1445,7 +1480,7 @@ const ConfigurationView = (props) => {
...
@@ -1445,7 +1480,7 @@ const ConfigurationView = (props) => {
name: 'PANEL',
name: 'PANEL',
},
},
new go.Binding('desiredSize', 'size', go.Size.parse).makeTwoWay(go.Size.stringify),
new go.Binding('desiredSize', 'size', go.Size.parse).makeTwoWay(go.Size.stringify),
new go.Binding('visible', 'visible').makeTwoWay(),
goJS(
goJS(
go.Picture,
go.Picture,
{ name: 'animateSvg', width: 56, height: 56, column: 0, scale: 1, source: '' },
{ name: 'animateSvg', width: 56, height: 56, column: 0, scale: 1, source: '' },
...
@@ -1511,6 +1546,7 @@ const ConfigurationView = (props) => {
...
@@ -1511,6 +1546,7 @@ const ConfigurationView = (props) => {
go.Shape,
go.Shape,
'RoundedRectanglePlus',
'RoundedRectanglePlus',
{ name: 'SHAPE', fill: 'rgba(128,128,128,0.2)', stroke: 'gray', parameter1: 0 },
{ name: 'SHAPE', fill: 'rgba(128,128,128,0.2)', stroke: 'gray', parameter1: 0 },
new go.Binding('visible', 'visible').makeTwoWay(),
new go.Binding('parameter1', 'radius').makeTwoWay(),
new go.Binding('parameter1', 'radius').makeTwoWay(),
new go.Binding('fill', 'fillColor').makeTwoWay(),
new go.Binding('fill', 'fillColor').makeTwoWay(),
new go.Binding('stroke').makeTwoWay(),
new go.Binding('stroke').makeTwoWay(),
...
@@ -1541,6 +1577,7 @@ const ConfigurationView = (props) => {
...
@@ -1541,6 +1577,7 @@ const ConfigurationView = (props) => {
go.Shape,
go.Shape,
'Ellipse',
'Ellipse',
{ name: 'SHAPE', fill: 'rgba(128,128,128,0.2)', stroke: 'gray' },
{ name: 'SHAPE', fill: 'rgba(128,128,128,0.2)', stroke: 'gray' },
new go.Binding('visible', 'visible').makeTwoWay(),
new go.Binding('fill', 'fillColor').makeTwoWay(),
new go.Binding('fill', 'fillColor').makeTwoWay(),
new go.Binding('stroke').makeTwoWay(),
new go.Binding('stroke').makeTwoWay(),
new go.Binding('strokeWidth').makeTwoWay(),
new go.Binding('strokeWidth').makeTwoWay(),
...
@@ -2352,7 +2389,7 @@ const ConfigurationView = (props) => {
...
@@ -2352,7 +2389,7 @@ const ConfigurationView = (props) => {
if (item.category === 'modelCase' || item.category === 'ellipseCase') {
if (item.category === 'modelCase' || item.category === 'ellipseCase') {
item.dtzOrder = item.zOrder;
item.dtzOrder = item.zOrder;
}
}
if (item.category == 'deviceCase' && deviceName && deviceName.length) {
if (item.category == 'deviceCase' &&
item.shType &&
deviceName && deviceName.length) {
var device = deviceName.find(function (arr, index) {
var device = deviceName.find(function (arr, index) {
return '设备' + stationList[index] == item.stationName;
return '设备' + stationList[index] == item.stationName;
});
});
...
...
packages/extend-components/EC_ConfigurationView/src/demos/Basic1.tsx
View file @
a810697e
...
@@ -21,14 +21,14 @@ const Demo = () => {
...
@@ -21,14 +21,14 @@ const Demo = () => {
<>
<>
<
div
style=
{
{
width
:
'100%'
,
height
:
'600px'
,
background
:
'#242835'
}
}
>
<
div
style=
{
{
width
:
'100%'
,
height
:
'600px'
,
background
:
'#242835'
}
}
>
<
PandaHistoryConfiguration
<
PandaHistoryConfiguration
// name={'水厂工艺流程段'}
name=
{
'水厂工艺流程段'
}
// devices={'EQZT00000008,EQZT00000007,CPDA00000001,JYBZ00000003,JYBZ00000005,JYBZ00000004'.split(
devices=
{
'EQZT00000008,EQZT00000007,CPDA00000001,JYBZ00000003,JYBZ00000005,JYBZ00000004'
.
split
(
// ',',
// )}
name=
{
'崇左丽江水厂原水泵房'
}
devices=
{
'EQZT00000007,CPBA00000001,CPAA00000001,EQZT00000008,CPDA00000001,CPAD00000001'
.
split
(
','
,
','
,
)
}
)
}
// name={'崇左丽江水厂原水泵房'}
// devices={'EQZT00000007,CPBA00000001,CPAA00000001,EQZT00000008,CPDA00000001,CPAD00000001'.split(
// ',',
// )}
// name={'丽江水厂原水提升泵D单元'}
// name={'丽江水厂原水提升泵D单元'}
// devices={'CPAA00000001, CPAD00000001, LJSC00000002'.split(',')}
// devices={'CPAA00000001, CPAD00000001, LJSC00000002'.split(',')}
config=
{
globalConfig
}
config=
{
globalConfig
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment