唐润平:解决了编辑模式bug

This commit is contained in:
trp
2023-12-30 13:23:30 +08:00
parent 3ce5582ea3
commit 5ac68dca37
5 changed files with 185 additions and 113 deletions

View File

@@ -1,53 +1,122 @@
import { defineStore } from "pinia";
import { ref } from "vue";
import { saveEquipment, initSceneData } from "../api/tunnelScene";
import { ElMessage } from "element-plus";
import { ref, toRaw } from "vue";
import { apiSaveEquipment, initSceneData } from "../api/tunnelScene";
export const useModelSceneStore = defineStore("modelSceneData", () => {
let equipmentList = ref([]);
let allEditList = ref({});
function initData(tunnelId = 1) {
initSceneData(tunnelId)
.then((res) => {
// equipmentList.value = res.data.tunnelThreeConfig;
console.log("初始化的数据");
})
.catch((Error) => {
ElMessage.error("场景初始化异常!");
});
}
//默认初始化1号隧道
function saveSceneData(data) {
equipmentList.value.push(data);
let requestOtherConfig = ref({});
return saveEquipment(constructionLength, tunnelId, equipmentList.value);
}
// 删除设备
function deleteEquipment(constructionLength, tunnelId, EquipmentId) {
let temp = JSON.parse(equipmentList.value);
temp = temp.filter(
(item) => item.chooseEquipment.equipmentId != EquipmentId
);
equipmentList.value = JSON.stringify(temp);
return saveEquipment(constructionLength, tunnelId, equipmentList.value);
}
function getEquipmentList(tunnelId = 1) {
function initModelData(tunnelId, otherConfig) {
return new Promise((resolve, reject) => {
handleSettingOtherConfig(otherConfig, requestOtherConfig);
initSceneData(tunnelId)
.then((res) => {
equipmentList.value = res.data.tunnelThreeConfig;
resolve(JSON.parse(equipmentList.value));
if (res.data.tunnelThreeConfig) {
equipmentList.value = JSON.parse(res.data.tunnelThreeConfig);
} else {
equipmentList.value = [];
}
resolve(toRaw(equipmentList.value));
})
.catch((Error) => {
// ElMessage.error("场景初始化异常!");
.catch((error) => {
reject();
});
});
}
function addEquipment(equipmentInfo, pointGap) {
return new Promise((resolve, reject) => {
if (hasEquipment(equipmentList.value, equipmentInfo.equipmentId)) {
reject(3000);
return;
}
equipmentList.value.push(equipmentInfo);
apiSaveEquipment({
constructionLength: autoComputeConstructionLength(
equipmentList.value,
pointGap
),
modelEquipmentList: toRaw(equipmentList.value),
...requestOtherConfig,
})
.then((res) => {
console.log("res", res);
resolve();
})
.catch((err) => {
console.log("res", err);
equipmentList.value.pop();
reject();
});
});
}
// 删除设备
function deleteEquipment(equipmentId, pointGap) {
let equipment = null;
equipmentList.value = equipmentList.value.filter((item) => {
if (item.equipmentId === equipmentId) {
equipment = item;
}
return item.equipmentId != equipmentId;
});
return new Promise((resolve, reject) => {
apiSaveEquipment({
constructionLength: autoComputeConstructionLength(
equipmentList.value,
pointGap
),
modelEquipmentList: toRaw(equipmentList.value),
...requestOtherConfig,
})
.then((res) => {
resolve();
})
.catch((err) => {
equipmentList.value.push(equipment);
reject();
});
});
}
return {
equipmentList,
initData,
saveSceneData,
initModelData,
addEquipment,
deleteEquipment,
getEquipmentList,
};
});
function handleSettingOtherConfig(otherConfig, requestOtherConfig) {
requestOtherConfig.isDefault = otherConfig.isDefault;
requestOtherConfig.remarks = otherConfig.remarks;
requestOtherConfig.serialNumber = otherConfig.serialNumber;
requestOtherConfig.tunnelId = otherConfig.tunnelId;
requestOtherConfig.tunnelLength = otherConfig.totalLength;
requestOtherConfig.tunnelName = otherConfig.tunnelName;
}
function autoComputeConstructionLength(modelEquipmentList, pointGap) {
let maxLength = 0;
modelEquipmentList.forEach((item) => {
const length =
Number(
item.position.substring(
item.position.indexOf("_") + 1,
item.position.lastIndexOf("_")
) - 1
) * pointGap;
if (length > maxLength) {
maxLength = length;
}
});
return maxLength;
}
function hasEquipment(equipmentList, equipmentId) {
let result = false;
equipmentList.forEach((item) => {
if (item.equipmentId === equipmentId) result = true;
});
return result;
}