Commit a810697e authored by 李纪文's avatar 李纪文

fix: 组态增加展示方式

parent 4fe79a8e
...@@ -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;
}); });
......
...@@ -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;
}); });
......
...@@ -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}
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment