|
|
|
@ -43,7 +43,9 @@ |
|
|
|
|
<el-button @click="onUndo">撤回</el-button> |
|
|
|
|
<el-button @click="onRedo">恢复</el-button> |
|
|
|
|
<el-button @click="clearLocalStorage">清除缓存</el-button> |
|
|
|
|
<el-button @click="onSave">运行</el-button> |
|
|
|
|
<el-button @click="onSave">{{ |
|
|
|
|
useSettingStore.experimentPreservation ? "运行" : "保存" |
|
|
|
|
}}</el-button> |
|
|
|
|
<el-button @click="onTip">提示</el-button> |
|
|
|
|
</div> |
|
|
|
|
<div class="tip-view"> |
|
|
|
@ -80,8 +82,11 @@ import settingStore from "@/store/modules/setting"; |
|
|
|
|
import Yibiao from "./components/yibiao.vue"; |
|
|
|
|
import { ElMessage } from "element-plus"; |
|
|
|
|
import tipView from "@/assets/images/chengxv.png"; |
|
|
|
|
|
|
|
|
|
import { useRouter } from "vue-router"; |
|
|
|
|
import { setStepEvent } from "@/utils/setStep"; |
|
|
|
|
import { formatDate } from "@/utils"; |
|
|
|
|
const useSettingStore = settingStore(); |
|
|
|
|
const router = useRouter(); |
|
|
|
|
// console.log(useSettingStore.qw); |
|
|
|
|
|
|
|
|
|
// 为了协助代码演示 |
|
|
|
@ -189,14 +194,20 @@ onMounted(() => { |
|
|
|
|
// 点击节点时显示编辑框 |
|
|
|
|
graph.on("node:click", ({ cell }: any) => { |
|
|
|
|
// console.log(cell.store.previous.name); |
|
|
|
|
// console.log(cell); |
|
|
|
|
|
|
|
|
|
console.log(cell); |
|
|
|
|
if (!useSettingStore.saveRoute) { |
|
|
|
|
ElMessage({ |
|
|
|
|
message: "请先完成配置", |
|
|
|
|
type: "warning", |
|
|
|
|
}); |
|
|
|
|
return; |
|
|
|
|
} |
|
|
|
|
if ( |
|
|
|
|
cell.shape === "deom" || |
|
|
|
|
cell.shape === "yibiao" || |
|
|
|
|
cell.shape === "rect" || |
|
|
|
|
cell.store.previous.name === "wdsz" || |
|
|
|
|
cell.store.previous.name === "sdsz" |
|
|
|
|
cell.shape === "custom-text-wdsz" || |
|
|
|
|
cell.shape === "custom-text-sdsz" |
|
|
|
|
) |
|
|
|
|
return; |
|
|
|
|
// if (cell.store.previous.name === "qw") { |
|
|
|
@ -220,7 +231,7 @@ onMounted(() => { |
|
|
|
|
// ]); |
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
graph.on("node:added", ({ node }:any) => { |
|
|
|
|
graph.on("node:added", ({ node }: any) => { |
|
|
|
|
const data = { |
|
|
|
|
type: "add", |
|
|
|
|
node: node.toJSON(), |
|
|
|
@ -229,7 +240,7 @@ onMounted(() => { |
|
|
|
|
saveToLocalStorage(data); |
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
graph.on("node:removed", ({ node }:any) => { |
|
|
|
|
graph.on("node:removed", ({ node }: any) => { |
|
|
|
|
const data = { |
|
|
|
|
type: "remove", |
|
|
|
|
id: node.id, |
|
|
|
@ -1057,7 +1068,40 @@ const saveNodeData = () => { |
|
|
|
|
if (falg.value) { |
|
|
|
|
const value = Number(selectedNodeData.value.label); |
|
|
|
|
// useSettingStore.setqw(value); |
|
|
|
|
useSettingStore.setValue(value, selectedNodeData.value.name); |
|
|
|
|
console.log(value, selectedNodeData.value.name); |
|
|
|
|
switch (node.shape) { |
|
|
|
|
case "custom-text": |
|
|
|
|
useSettingStore.setValue(parseInt(node.label), "qw"); //初始温度 |
|
|
|
|
break; |
|
|
|
|
case "custom-text-zl": |
|
|
|
|
useSettingStore.setValue(parseInt(node.label), "zl"); // 质量 |
|
|
|
|
break; |
|
|
|
|
case "custom-text-srmj": |
|
|
|
|
useSettingStore.setValue(parseInt(node.label), "srmj"); // 散热面积 |
|
|
|
|
break; |
|
|
|
|
case "custom-text-jrgl": |
|
|
|
|
useSettingStore.setValue(parseInt(node.label), "jrgl"); // 加热功率 |
|
|
|
|
break; |
|
|
|
|
case "custom-text-jrmj": |
|
|
|
|
useSettingStore.setValue(parseInt(node.label), "jrmj"); // 加热面积 |
|
|
|
|
break; |
|
|
|
|
case "custom-text-prot": |
|
|
|
|
useSettingStore.setValue(node.label, "port"); // 端口 |
|
|
|
|
break; |
|
|
|
|
case "custom-text-IP": |
|
|
|
|
useSettingStore.setValue(node.label, "ip"); // IP |
|
|
|
|
break; |
|
|
|
|
case "custom-text-cssd": |
|
|
|
|
useSettingStore.setValue(parseInt(node.label), "cssd"); // 初始湿度 |
|
|
|
|
break; |
|
|
|
|
case "custom-text-jsgl": |
|
|
|
|
useSettingStore.setValue(parseInt(node.label), "jsgl"); // 加湿功率 |
|
|
|
|
break; |
|
|
|
|
case "custom-text-jsmj": |
|
|
|
|
useSettingStore.setValue(parseInt(node.label), "jsmj"); // 加湿面积 |
|
|
|
|
break; |
|
|
|
|
} |
|
|
|
|
// useSettingStore.setValue(value, selectedNodeData.value.name); |
|
|
|
|
graph.getNodes().forEach((node: any) => { |
|
|
|
|
// console.log(node.label); |
|
|
|
|
|
|
|
|
@ -1140,42 +1184,6 @@ const onRedo = () => { |
|
|
|
|
}; |
|
|
|
|
const sdsz = ref<any>(null); |
|
|
|
|
const onSave = () => { |
|
|
|
|
// console.log(graph.toJSON()); |
|
|
|
|
graph.toJSON().cells.forEach((item: any) => { |
|
|
|
|
console.log(item); |
|
|
|
|
|
|
|
|
|
switch (item.shape) { |
|
|
|
|
case "custom-text": |
|
|
|
|
useSettingStore.setValue(parseInt(item.attrs.text.text),item.name, ); |
|
|
|
|
break; |
|
|
|
|
case "custom-text-zl": |
|
|
|
|
useSettingStore.setValue(parseInt(item.attrs.text.text),item.name, ); |
|
|
|
|
break; |
|
|
|
|
case "custom-text-srmj": |
|
|
|
|
useSettingStore.setValue(parseInt(item.attrs.text.text),item.name, ); |
|
|
|
|
break; |
|
|
|
|
case "custom-text-jrgl": |
|
|
|
|
useSettingStore.setValue(parseInt(item.attrs.text.text),item.name, ); |
|
|
|
|
break; |
|
|
|
|
case "custom-text-prot": |
|
|
|
|
useSettingStore.setValue(parseInt(item.attrs.text.text),item.name, ); |
|
|
|
|
break; |
|
|
|
|
case "custom-text-cssd": |
|
|
|
|
useSettingStore.setValue(parseInt(item.attrs.text.text),item.name, ); |
|
|
|
|
break; |
|
|
|
|
} |
|
|
|
|
}); |
|
|
|
|
// return; |
|
|
|
|
clearLocalStorage(); |
|
|
|
|
const data = graph.toJSON().cells.map((item: any) => { |
|
|
|
|
return { |
|
|
|
|
node: item, |
|
|
|
|
type: "add", |
|
|
|
|
}; |
|
|
|
|
}); |
|
|
|
|
console.log(data); |
|
|
|
|
|
|
|
|
|
localStorage.setItem(SESSION_KEY, JSON.stringify(data)); |
|
|
|
|
if ( |
|
|
|
|
!hasExactNames(graph.getNodes(), [ |
|
|
|
|
"custom-text", |
|
|
|
@ -1196,6 +1204,156 @@ const onSave = () => { |
|
|
|
|
message: "请填写完整信息", |
|
|
|
|
}); |
|
|
|
|
} |
|
|
|
|
if (!useSettingStore.experimentPreservation) { |
|
|
|
|
useSettingStore.setValue(true, "experimentPreservation"); |
|
|
|
|
router.push("/designRoute"); |
|
|
|
|
return; |
|
|
|
|
} |
|
|
|
|
graph.toJSON().cells.forEach((item: any) => { |
|
|
|
|
switch (item.shape) { |
|
|
|
|
case "custom-text": |
|
|
|
|
// console.log(parseInt(item.attrs.text.text)); |
|
|
|
|
if (!parseInt(item.attrs.text.text)) { |
|
|
|
|
ElMessage({ |
|
|
|
|
type: "warning", |
|
|
|
|
message: "请请填写初始温度信息", |
|
|
|
|
}); |
|
|
|
|
return; |
|
|
|
|
} |
|
|
|
|
useSettingStore.setValue(parseInt(item.attrs.text.text), item.name); |
|
|
|
|
break; |
|
|
|
|
case "custom-text-zl": |
|
|
|
|
// console.log(parseInt(item.attrs.text.text)); |
|
|
|
|
if (!parseInt(item.attrs.text.text)) { |
|
|
|
|
ElMessage({ |
|
|
|
|
type: "warning", |
|
|
|
|
message: "请请填写质量信息", |
|
|
|
|
}); |
|
|
|
|
return; |
|
|
|
|
} |
|
|
|
|
useSettingStore.setValue(parseInt(item.attrs.text.text), item.name); |
|
|
|
|
break; |
|
|
|
|
case "custom-text-srmj": |
|
|
|
|
// console.log(parseInt(item.attrs.text.text)); |
|
|
|
|
if (!parseInt(item.attrs.text.text)) { |
|
|
|
|
ElMessage({ |
|
|
|
|
type: "warning", |
|
|
|
|
message: "请请填写散热面积信息", |
|
|
|
|
}); |
|
|
|
|
return; |
|
|
|
|
} |
|
|
|
|
useSettingStore.setValue(parseInt(item.attrs.text.text), item.name); |
|
|
|
|
break; |
|
|
|
|
case "custom-text-jrgl": |
|
|
|
|
if (!parseInt(item.attrs.text.text)) { |
|
|
|
|
ElMessage({ |
|
|
|
|
type: "warning", |
|
|
|
|
message: "请请填写加热功率信息", |
|
|
|
|
}); |
|
|
|
|
return; |
|
|
|
|
} |
|
|
|
|
useSettingStore.setValue(parseInt(item.attrs.text.text), item.name); |
|
|
|
|
break; |
|
|
|
|
// case "custom-text-prot": |
|
|
|
|
// useSettingStore.setValue(parseInt(item.attrs.text.text), item.name); |
|
|
|
|
// break; |
|
|
|
|
case "custom-text-cssd": |
|
|
|
|
// console.log(parseInt(item.attrs.text.text)); |
|
|
|
|
if (!parseInt(item.attrs.text.text)) { |
|
|
|
|
ElMessage({ |
|
|
|
|
type: "warning", |
|
|
|
|
message: "请请填写初始湿度信息", |
|
|
|
|
}); |
|
|
|
|
return; |
|
|
|
|
} |
|
|
|
|
useSettingStore.setValue(parseInt(item.attrs.text.text), item.name); |
|
|
|
|
break; |
|
|
|
|
case "custom-text-jsgl": |
|
|
|
|
// console.log(parseInt(item.attrs.text.text)); |
|
|
|
|
if (!parseInt(item.attrs.text.text)) { |
|
|
|
|
ElMessage({ |
|
|
|
|
type: "warning", |
|
|
|
|
message: "请请填写加湿功率信息", |
|
|
|
|
}); |
|
|
|
|
return; |
|
|
|
|
} |
|
|
|
|
useSettingStore.setValue(parseInt(item.attrs.text.text), item.name); |
|
|
|
|
break; |
|
|
|
|
case "custom-text-jsmj": |
|
|
|
|
// console.log(parseInt(item.attrs.text.text)); |
|
|
|
|
if (!parseInt(item.attrs.text.text)) { |
|
|
|
|
ElMessage({ |
|
|
|
|
type: "warning", |
|
|
|
|
message: "请请填写加湿面积信息", |
|
|
|
|
}); |
|
|
|
|
return; |
|
|
|
|
} |
|
|
|
|
useSettingStore.setValue(parseInt(item.attrs.text.text), item.name); |
|
|
|
|
break; |
|
|
|
|
case "custom-text-IP": |
|
|
|
|
// console.log(parseInt(item.attrs.text.text)); |
|
|
|
|
if (!parseInt(item.attrs.text.text)) { |
|
|
|
|
ElMessage({ |
|
|
|
|
type: "warning", |
|
|
|
|
message: "请请填写ip设置信息", |
|
|
|
|
}); |
|
|
|
|
return; |
|
|
|
|
} |
|
|
|
|
useSettingStore.setValue(parseInt(item.attrs.text.text), item.name); |
|
|
|
|
break; |
|
|
|
|
case "custom-text-prot": |
|
|
|
|
// console.log(parseInt(item.attrs.text.text)); |
|
|
|
|
if (!parseInt(item.attrs.text.text)) { |
|
|
|
|
ElMessage({ |
|
|
|
|
type: "warning", |
|
|
|
|
message: "请请填写设定温度信息", |
|
|
|
|
}); |
|
|
|
|
return; |
|
|
|
|
} |
|
|
|
|
useSettingStore.setValue(parseInt(item.attrs.text.text), item.name); |
|
|
|
|
break; |
|
|
|
|
} |
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
if (useSettingStore.experimentPreservation) { |
|
|
|
|
const arr = [ |
|
|
|
|
useSettingStore.qw, |
|
|
|
|
useSettingStore.zl, |
|
|
|
|
useSettingStore.srmj, |
|
|
|
|
useSettingStore.jrgl, |
|
|
|
|
useSettingStore.port, |
|
|
|
|
useSettingStore.cssd, |
|
|
|
|
useSettingStore.jsmj, |
|
|
|
|
useSettingStore.jsgl, |
|
|
|
|
useSettingStore.ip, |
|
|
|
|
]; |
|
|
|
|
console.log( |
|
|
|
|
arr, |
|
|
|
|
arr.every((item) => item !== 0 && item !== "") |
|
|
|
|
); |
|
|
|
|
|
|
|
|
|
// 判断全部不能为空 |
|
|
|
|
if (!arr.every((item) => item !== 0 && item !== "")) { |
|
|
|
|
return ElMessage({ |
|
|
|
|
type: "warning", |
|
|
|
|
message: "请完善配置信息", |
|
|
|
|
}); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// console.log(graph.toJSON()); |
|
|
|
|
|
|
|
|
|
// return; |
|
|
|
|
clearLocalStorage(); |
|
|
|
|
const data = graph.toJSON().cells.map((item: any) => { |
|
|
|
|
return { |
|
|
|
|
node: item, |
|
|
|
|
type: "add", |
|
|
|
|
}; |
|
|
|
|
}); |
|
|
|
|
console.log(data); |
|
|
|
|
|
|
|
|
|
localStorage.setItem(SESSION_KEY, JSON.stringify(data)); |
|
|
|
|
} |
|
|
|
|
csedNode.value = graph |
|
|
|
|
.getNodes() |
|
|
|
|
.find((node: any) => node.shape === "custom-text-wdsz"); |
|
|
|
@ -1205,7 +1363,10 @@ const onSave = () => { |
|
|
|
|
console.log(csedNode.value); |
|
|
|
|
sdsz.value.label = useSettingStore.cssd; |
|
|
|
|
// useSettingStore.openHeating(); |
|
|
|
|
useSettingStore.calculateTemperature(); |
|
|
|
|
// useSettingStore.calculateTemperature(); |
|
|
|
|
useSettingStore.simulateHeatingAndHumidifying(); |
|
|
|
|
setStepEvent(4, formatDate(new Date())); |
|
|
|
|
|
|
|
|
|
// const data = graph.toJSON(); |
|
|
|
|
// console.log(data); |
|
|
|
|
// const edges = graph.getEdges(); |
|
|
|
@ -1213,15 +1374,19 @@ const onSave = () => { |
|
|
|
|
}; |
|
|
|
|
function hasExactNames(arr: any, names: any) { |
|
|
|
|
// 提取数组中所有的 name 值 |
|
|
|
|
const nameList = arr.map((obj:any) => obj.shape); |
|
|
|
|
const nameList = arr.map((obj: any) => obj.shape); |
|
|
|
|
console.log( |
|
|
|
|
nameList, |
|
|
|
|
names, |
|
|
|
|
names.every((name:any) => nameList.filter((n:any) => n === name).length === 1) |
|
|
|
|
names.every( |
|
|
|
|
(name: any) => nameList.filter((n: any) => n === name).length === 1 |
|
|
|
|
) |
|
|
|
|
); |
|
|
|
|
|
|
|
|
|
// 检查 names 里的所有元素是否都在 nameList 中,且仅出现一次 |
|
|
|
|
return names.every((name:any) => nameList.filter((n:any) => n === name).length === 1); |
|
|
|
|
return names.every( |
|
|
|
|
(name: any) => nameList.filter((n: any) => n === name).length === 1 |
|
|
|
|
); |
|
|
|
|
} |
|
|
|
|
watch( |
|
|
|
|
() => useSettingStore.qw, |
|
|
|
@ -1234,10 +1399,22 @@ watch( |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
); |
|
|
|
|
watch( |
|
|
|
|
() => useSettingStore.cssd, |
|
|
|
|
(newValue: number) => { |
|
|
|
|
console.log(newValue, "newValue"); |
|
|
|
|
console.log(sdsz.value, "sdsz.value"); |
|
|
|
|
|
|
|
|
|
if (sdsz.value) { |
|
|
|
|
sdsz.value.label = newValue; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
); |
|
|
|
|
const SESSION_KEY = "graph_operations"; |
|
|
|
|
|
|
|
|
|
function saveToLocalStorage(data:any) { |
|
|
|
|
const operations = JSON.parse(localStorage.getItem(SESSION_KEY) as string) || []; |
|
|
|
|
function saveToLocalStorage(data: any) { |
|
|
|
|
const operations = |
|
|
|
|
JSON.parse(localStorage.getItem(SESSION_KEY) as string) || []; |
|
|
|
|
operations.push(data); |
|
|
|
|
localStorage.setItem(SESSION_KEY, JSON.stringify(operations)); |
|
|
|
|
} |
|
|
|
@ -1253,7 +1430,7 @@ function clearLocalStorage() { |
|
|
|
|
function restoreGraph() { |
|
|
|
|
const operations = loadFromLocalStorage(); |
|
|
|
|
|
|
|
|
|
operations.forEach((op:any) => { |
|
|
|
|
operations.forEach((op: any) => { |
|
|
|
|
if (op.type === "add") { |
|
|
|
|
graph.addNode(op.node); |
|
|
|
|
} else if (op.type === "remove") { |
|
|
|
|