You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

507 lines
16 KiB
Vue

1 month ago
<template>
<el-container class="container">
<el-aside class="leftSide">
<div class="well-data">
<div class="well-title">水平井直方图</div>
<div class="button-container">
<el-button type="primary" @click="showProjectDialog = true" :icon="DocumentAdd"
size="small">新建</el-button>
1 month ago
<el-button type="danger" @click="handleDelete(null)" :icon="Delete" size="small">删除</el-button>
1 month ago
</div>
<el-table ref="wellDataRef" :data="wellData" @selection-change="handleSelectionChange"
style="width: 100%;margin: 0;padding: 0;overflow-y: auto;overflow-x: hidden;" row-key="ID"
@row-click="handleRowClick">
<el-table-column type="selection" width="40"></el-table-column>
1 month ago
<el-table-column label="名称" prop="LayerName" width="*" show-overflow-tooltip>
<template #default="scope">
<el-link @click="handleOpenFile(scope.row)">
<div :style="{ padding: '0' }">{{ scope.row.LayerName }}</div>
</el-link>
</template>
</el-table-column>
1 month ago
<el-table-column label="操作" width="55">
<template #default="scope">
<el-tooltip content="删除" placement="top">
<Delete style="width: 1em;height: 1em;cursor: pointer;color:red;"
1 month ago
@click="handleDelete(scope.row)" />
1 month ago
</el-tooltip>
</template>
</el-table-column>
</el-table>
</div>
<div class="base-img">
<div class="button-container">
<el-button type="success" plain @click="showBaseDrawDialog = true" :icon="Management"
size="small">管理底图</el-button>
<el-button type="success" plain @click="handleApplyBaseDraw" :icon="DocumentCopy"
size="small">应用底图</el-button>
</div>
<el-table ref="baseDrawRef" :data="baseDrawData" @selection-change="handleBaseDrawSelectionChange"
style="width: 100%;margin: 0;padding: 0;overflow-y: auto;" row-key="MapID"
@row-click="handleBaseDrawRowClick">
<el-table-column type="selection" width="40"></el-table-column>
1 month ago
<el-table-column label="名称" prop="MapName" width="*"></el-table-column>
1 month ago
<!-- <el-table-column label="操作" width="60">
<template #default="scope">
<el-tooltip content="删除" placement="top" >
<Delete style="width: 1em;height: 1em;cursor: pointer;color:red;" @click="handleDelete" />
</el-tooltip>
</template>
</el-table-column> -->
</el-table>
</div>
</el-aside>
<el-main class="main">
<!-- <div class="scrollable-container"> -->
1 month ago
<WellRecommend :tokenKey="currentTokenKey" />
1 month ago
<!-- </div> -->
</el-main>
</el-container>
1 month ago
<ProjectEditDialog @changeShowDialog="handleChangeShowProjectDialog" :showDialog="showProjectDialog"
v-model="showProjectDialog" :moduleId="moduleId" />
<BaseImgDialog @changeShowDialog="handleChangeShowBaseDrawDialog" :showDialog="showBaseDrawDialog"
v-model="showBaseDrawDialog" :moduleId="moduleId" :dataId="10" />
<LoadingDialog v-model="loading" ref="loadingRef" :timeout="10000" message="正在应用底图……" @timeout="onTimeout" />
1 month ago
</template>
<script setup>
definePageMeta({
requiresAuth: true
});
import { ref, onMounted, onBeforeUnmount } from 'vue'
import { Refresh, Delete, Switch, DocumentAdd, Management, DocumentCopy } from "@element-plus/icons-vue";
import { fetchProjects, deleteProject, fetchProjectById } from '~/services/projectService'
import { fetchBaseDraws } from '~/services/baseDrawService'
import { addBaseMapData, fetchProjectBaseMapList } from '~/services/projectBaseMapService'
import { emitter } from "~/utils/eventBus";
import { ElMessageBox } from 'element-plus';
const { $toastMessage } = useNuxtApp();
import { generateGUID } from "~/utils/common";
1 month ago
import { EMIT_COMMAND } from '~/utils/commandTypes';
import { STORAGE_KEYS } from "~/utils/storageKeys"
// 当前页图件token的 key
const currentTokenKey = STORAGE_KEYS.HORIZONTAL_WELL_TOKEN;
1 month ago
1 month ago
const loading = ref(false);
const loadingRef = ref(null);
1 month ago
1 month ago
let moduleId = "51";
let currentProjectIdKey = "hw:currentProjectId";
1 month ago
const wellDataRef = ref(null);
const baseDrawRef = ref(null);
const wellData = ref([]);
const baseDrawData = ref([]);
const selectedWellRows = ref([]);
const selectedBaseDraws = ref([]);
const showBaseDrawDialog = ref(false);
const showProjectDialog = ref(false);
1 month ago
const currentToken = computed(() => localStorage.getItem(currentTokenKey));
1 month ago
/** 默认项目参数 */
const defaultProjectParameter = reactive({
/** 井轨迹 */
drawTrack: true,
/** 关节点 */
drawPoint: true,
/** 显示方式(柱子,曲线) */
drawGradient: false,
/** 分段 */
drawStage: true,
/** 参数值 */
drawParamText: true,
/** 名称大小 */
stageTextSize: 10,
/** 文字大小 */
paramTextSize: 5,
/** 分段宽度 */
stageWidth: 20,
/** 高度 */
columnHeighFactor: 10,
/** 宽度 */
pillarWidth: 10,
});
const currentProject = reactive({
Id: 0,
drawId: "",
layerName: "",
layerAlias: "",
drawerFileName: "",
/** 绘制参数配置 */
projectParameter: { ...defaultProjectParameter },
/** 工程权限 */
auth: {},
});
1 month ago
const onTimeout = (() => {
$toastMessage.error("应用底图超时!");
});
1 month ago
// 控制创建项目弹出框
const handleChangeShowProjectDialog = (val) => {
showProjectDialog.value = val;
}
const handleChangeShowBaseDrawDialog = (val) => {
showBaseDrawDialog.value = val;
};
const loadData = async () => {
try {
selectedWellRows.value = [];
const response = await fetchProjects(moduleId);
if (!response) {
// $toastMessage.error("获取井数据失败");
return;
}
1 month ago
console.log("获取的工程数据:", response);
1 month ago
wellData.value = response;
const projId = localStorage.getItem(currentProjectIdKey);
if (projId) {
const proj = wellData.value.find(w => w.ID == projId);
if (proj) {
wellDataRef.value.toggleRowSelection(proj, true);
}
}
} catch (error) {
1 month ago
console.error(`获取井数据异常:${error}`);
1 month ago
$toastMessage.error('获取井数据失败!');
}
};
// 加载底图数据
const loadBaseDraws = async () => {
try {
const response = await fetchBaseDraws(moduleId);
if (!response) {
return;
}
baseDrawData.value = response;
} catch (error) {
console.error('获取底图数据异常:', error);
$toastMessage.error('获取底图数据失败!');
}
};
// 加载项目所应用的底图数据
const loadProjectBaseDraws = async (projectId) => {
let baseDraws = await fetchProjectBaseMapList(moduleId, projectId);
if (!baseDraws) {
return;
}
baseDraws.forEach(item => {
// if (baseDrawData.value.some(d => d.MapID === item.MapId)) {
let data = baseDrawData.value.find(d => d.MapID === item.MapId);
if (data) {
baseDrawRef.value.toggleRowSelection(data, true);
};
});
};
// 获取选中项
const handleSelectionChange = (selection) => {
1 month ago
1 month ago
selectedWellRows.value = selection;
1 month ago
console.log("选中的数据:", selectedWellRows.value, selection);
1 month ago
}
const handleBaseDrawSelectionChange = (selection) => {
selectedBaseDraws.value = selection;
};
1 month ago
const handleRowClick = (row) => {
1 month ago
clearSelection("well");
1 month ago
wellDataRef.value.toggleRowSelection(row);
}
1 month ago
1 month ago
// 行点击
const handleOpenFile = async (item) => {
if (!item) {
return;
}
emitter.emit(EMIT_COMMAND.SOURCE_CHANGED);
handleRowClick(item);
// clearSelection("well");
emitter.emit(EMIT_COMMAND.EVT_TYPE, { type: EMIT_COMMAND.CLEAR_CANVAS, cmdID: currentTokenKey, data: JSON.stringify({ drawerToken: generateGUID() }) });
const fileUrl = `${item.LayerName}.kev`;
emitter.emit(EMIT_COMMAND.EVT_TYPE, { type: EMIT_COMMAND.OPEN_FILE, cmdID: currentTokenKey, data: JSON.stringify({ fileName: fileUrl, drawerToken: generateGUID() }) });
// wellDataRef.value.toggleRowSelection(item, true);
let data = await fetchProjectById("BaseMap", moduleId, item.ID);
currentProject.Id = data.ID;
currentProject.drawId = data.DrawId;
currentProject.drawerFileName = data.DrawerFileName;
currentProject.layerAlias = data.LayerAlias;
currentProject.layerName = data.LayerName;
currentProject.projectParameter.drawTrack = data.projectParameter.DrawTrack;
currentProject.projectParameter.drawPoint = data.projectParameter.DrawPoint;
currentProject.projectParameter.drawGradient = data.projectParameter.DrawGradient;
currentProject.projectParameter.drawStage = data.projectParameter.DrawStage;
currentProject.projectParameter.drawParamText = data.projectParameter.DrawParamText;
currentProject.projectParameter.stageTextSize = data.projectParameter.StageTextSize;
currentProject.projectParameter.paramTextSize = data.projectParameter.ParamTextSize;
currentProject.projectParameter.pillarWidth = data.projectParameter.PillarWidth;
currentProject.projectParameter.stageWidth = data.projectParameter.StageWidth;
currentProject.projectParameter.columnHeighFactor = data.projectParameter.ColumnHeighFactor;
if (data.ID) {
localStorage.setItem(currentProjectIdKey, data.ID);
1 month ago
}
1 month ago
clearSelection("basedraw");
// 选择对应的底图
await loadProjectBaseDraws(item.ID);
// TODO 打开对应的文件并显示对应的参数
emitter.emit(EMIT_COMMAND.PROJECT_PARAM, data);
1 month ago
};
const handleBaseDrawRowClick = async (item) => {
// clearSelection("basedraw");
baseDrawRef.value.toggleRowSelection(item);
};
// 清空所选
const clearSelection = (val) => {
switch (val) {
case "well":
if (selectedWellRows.value) {
selectedWellRows.value.forEach(item => {
wellDataRef.value.toggleRowSelection(item, false);
});
1 month ago
selectedWellRows.value = [];
1 month ago
}
break;
case "basedraw":
if (selectedBaseDraws.value) {
selectedBaseDraws.value.forEach(item => {
baseDrawRef.value.toggleRowSelection(item, false);
});
1 month ago
selectedBaseDraws.value = [];
1 month ago
}
break;
}
};
/** 应用底图 */
const handleApplyBaseDraw = async () => {
1 month ago
1 month ago
if (currentProject.Id > 0) {
let mapIds = [];
let mapNames = [];
selectedBaseDraws.value.forEach((item) => {
mapIds.push(item.MapID);
mapNames.push(item.MapName);
});
1 month ago
try {
loading.value = true;
let result = await addProjectBaseMap(mapIds.join(","), mapNames.join(","));
if (result) {
$toastMessage.success(`底图应用成功`);
}
else {
$toastMessage.warning(`底图应用出错了`);
}
emitter.emit(EMIT_COMMAND.EVT_TYPE, { type: EMIT_COMMAND.VIEW_ALL, cmdID: currentTokenKey, data: JSON.stringify({ drawerToken: currentToken.value }) });
} catch (error) {
$toastMessage.error(`底图应用出错了:${error}`);
} finally {
loadingRef.value.close();
1 month ago
}
} else {
$toastMessage.warning("未选择工程");
return;
}
};
/**
* 添加水平井项目底图
* @returns {Promise<void>}
*/
const addProjectBaseMap = async (mapId, mapName) => {
const projectMapParam = {
DrawId: currentToken.value,
ClientId: currentToken.value,
Module_Id: moduleId,
Project_Id: currentProject.Id,
Map_Id: mapId,
Map_Name: mapName
};
try {
let result = await addBaseMapData(projectMapParam);
if (!result) {
$toastMessage.error("添加底图失败");
return;
}
// await loadBaseDraws();
return result;
}
catch (error) {
console.error('添加底图失败:', error);
$toastMessage.error("添加底图失败");
return;
}
};
// 删除数据
1 month ago
const handleDelete = async (row) => {
if (row) {
// selectedWellRows.value = null;
// selectedWellRows.value.push(row);
console.log("选中的数据1", row);
handleRowClick(row);
}
1 month ago
if (selectedWellRows.value.length === 0) {
1 month ago
$toastMessage.warning("请选择要删除的项目!");
1 month ago
return;
}
1 month ago
console.log("选中的数据2", selectedWellRows.value);
1 month ago
ElMessageBox.confirm(`您确定要删除选中的数据吗?`, "删除确认", {
confirmButtonText: "确认删除",
cancelButtonText: "取消",
type: "warning"
})
.then(async () => {
const selectKeys = selectedWellRows.value.map(item => item.ID);
try {
const response = await deleteProject(moduleId, selectKeys.join(','));
1 month ago
if (response) {
1 month ago
await loadData();
1 month ago
emitter.emit(EMIT_COMMAND.CLEAR_CANVAS);
$toastMessage.success("删除数据成功!");
1 month ago
selectedWellRows.value = [];
} else {
$toastMessage.error("删除失败!");
}
} catch (error) {
$toastMessage.error("删除异常!");
console.error("删除异常:", error);
}
})
.catch(() => {
});
};
onMounted(async () => {
nextTick();
await loadData();
await loadBaseDraws();
handleConfirmAdd();
1 month ago
emitter.on(EMIT_COMMAND.UPDATE_BASE_DRAW, async () => {
1 month ago
await loadBaseDraws();
let projId = localStorage.getItem(currentProjectIdKey);
if (projId) {
await loadProjectBaseDraws(projId);
};
});
});
const handleConfirmAdd = () => {
1 month ago
emitter.on(EMIT_COMMAND.CONFIRM_ADD_PROJECT, async (data) => {
1 month ago
if (data.moduleId === moduleId) {
currentProject.drawId = data.token;
showProjectDialog.value = false;
await loadData();
};
});
};
onBeforeUnmount(() => {
1 month ago
emitter.off(EMIT_COMMAND.CONFIRM_ADD_PROJECT);
emitter.off(EMIT_COMMAND.UPDATE_BASE_DRAW);
1 month ago
})
</script>
<style scoped>
/* .el-container {
background-color: white;
color: black;
min-height: 800px;
height: calc(100vh - 80px);
margin: 0;
padding: 0;
overflow: hidden;
} */
.el-aside,
.el-main {
background-color: white;
margin: 0;
padding: 0;
overflow: hidden;
}
.scrollable-container {
height: calc(100vh - 100px);
overflow-y: auto;
/* border: 1px solid #ddd; */
width: 100%;
margin: 0;
padding: 0;
overflow-x: hidden;
}
.leftSide {
width: 260px;
height: calc(100vh - 55px);
border: none;
background-color: #333;
display: flex;
flex-direction: column;
}
.well-data {
width: 100%;
height: 50%;
display: flex;
flex-direction: column;
background-color: #fff;
1 month ago
border: solid 1px #f5f5f5;
1 month ago
padding: 5px;
}
.well-title {
color: #5399ff;
justify-content: center;
width: 100%;
height: 30px;
text-align: center;
}
.base-img {
width: 100%;
height: 50%;
display: flex;
flex-direction: column;
background-color: #fff;
1 month ago
border: solid 1px #f5f5f5;
1 month ago
padding: 5px;
}
.button-container {
display: flex;
margin-bottom: 5px;
}
.main {
width: 100%;
/* height: calc(100vh - 40px); */
overflow: auto;
margin: 0;
padding: 0;
}
.oper {
width: 100%;
height: 40px;
margin: 0;
padding-left: 10px;
}
</style>