306 lines
10 KiB
Vue
306 lines
10 KiB
Vue
<template>
|
|
<div class="warning-page" v-if="!showScreen">
|
|
<div class="table-box">
|
|
<div class="table">
|
|
<ProTable
|
|
ref="proTable"
|
|
title="项目审批"
|
|
:columns="columns"
|
|
:requestApi="getTableList"
|
|
:dataCallback="dataCallback"
|
|
:tool-button="false"
|
|
:pagination="true"
|
|
background
|
|
:isShowSearch="true"
|
|
>
|
|
<template #formButton="scope">
|
|
<el-button v-auth="'pre_project_add'" class="btnStyle" @click="handleAddItem">新增</el-button>
|
|
</template>
|
|
<template #operation="{ row }">
|
|
<!-- <el-button type="primary" v-auth="'pre_file_list'" link @click="onFileList(row)"
|
|
><img src="@/assets/images/tableIcon/look.png" alt="" class="configureIcon" /><span>文件列表</span></el-button
|
|
> -->
|
|
<el-button type="primary" link @click="onSee(row)"
|
|
><img src="@/assets/images/tableIcon/look.png" alt="" class="configureIcon" /><span>查看</span></el-button
|
|
>
|
|
<el-button v-auth="'pre_project_update'" type="primary" link @click="onEdit(row)"
|
|
><img src="@/assets/images/tableIcon/updateIcon.png" alt="" class="configureIcon" /><span>编辑</span></el-button
|
|
>
|
|
<!-- <el-button v-auth="'pre_project_update'" type="primary" link @click="toScreen(row)"
|
|
><img src="@/assets/images/tableIcon/look.png" alt="" class="configureIcon" /><span>项目大屏</span></el-button
|
|
> -->
|
|
<!-- <el-button type="primary" link @click="openMap(row)"
|
|
><img src="@/assets/images/tableIcon/修正定位.png" alt="" class="configureIcon" /><span>修正定位</span></el-button
|
|
>
|
|
<el-button v-if="row.examineState === 3" type="primary" link @click="onState(row)"
|
|
><img src="@/assets/images/tableIcon/修改状态.png" alt="" class="configureIcon" /><span>修改状态</span></el-button
|
|
> -->
|
|
</template>
|
|
</ProTable>
|
|
<!-- 盒子嵌入版 -->
|
|
<divDialogComponent v-model:visible="detailsDialog" class="add-edit-box">
|
|
<template #topContent>
|
|
<div class="title-detail">
|
|
<span>{{ approvalTitle }}</span>
|
|
<el-icon>
|
|
<close @click="detailsDialog = false" />
|
|
</el-icon>
|
|
</div>
|
|
</template>
|
|
<template #centerContent>
|
|
<ProjectSupervisionDiv @confirm="confirmReform"></ProjectSupervisionDiv>
|
|
</template>
|
|
</divDialogComponent>
|
|
<!-- 查看 -->
|
|
<divDialogComponent v-model:visible="ennMEssageVisible" class="add-edit-box">
|
|
<template #topContent>
|
|
<div class="title-detail">
|
|
<span>查看项目信息</span>
|
|
<el-icon>
|
|
<close @click="ennMEssageVisible = false" />
|
|
</el-icon>
|
|
</div>
|
|
</template>
|
|
<template #centerContent>
|
|
<readonlyDialogDiv :relativeId="relativeId"></readonlyDialogDiv>
|
|
</template>
|
|
</divDialogComponent>
|
|
<!-- 项目列表 -->
|
|
<divDialogComponent v-model:visible="fileListVisible" class="add-edit-box">
|
|
<template #topContent>
|
|
<div class="title-detail">
|
|
<span>查看文件列表</span>
|
|
<el-icon>
|
|
<close @click="fileListVisible = false" />
|
|
</el-icon>
|
|
</div>
|
|
</template>
|
|
<template #centerContent>
|
|
<fileListDialogDiv
|
|
:relativeId="relativeId"
|
|
:engineeringSn="engineeringSn"
|
|
@confirm="childrenDataUpdate"
|
|
></fileListDialogDiv>
|
|
</template>
|
|
</divDialogComponent>
|
|
<!-- 弹窗版 -->
|
|
<!-- <ProjectSupervision
|
|
v-model:detailsDialog="detailsDialog"
|
|
:title="approvalTitle"
|
|
@confirm="confirmReform"
|
|
></ProjectSupervision> -->
|
|
<!-- 查看 -->
|
|
<!-- <readonlyDialog v-model:ennMEssageVisible="ennMEssageVisible" :relativeId="relativeId"></readonlyDialog> -->
|
|
<!-- 编辑 -->
|
|
<!-- <editDialog
|
|
v-model:editennMEssageVisible="editennMEssageVisible"
|
|
:relativeId="relativeId"
|
|
@confirm="childrenDataUpdate"
|
|
></editDialog> -->
|
|
<!-- 项目列表 -->
|
|
<!-- <fileListDialog
|
|
v-model:fileListVisible="fileListVisible"
|
|
:relativeId="relativeId"
|
|
:engineeringSn="engineeringSn"
|
|
@confirm="childrenDataUpdate"
|
|
></fileListDialog> -->
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<largeScreen v-if="showScreen" :engineeringSn="engineeringSn" @change="toScreen"></largeScreen>
|
|
</template>
|
|
|
|
<script setup lang="tsx" name="ProjectSupervisionRecord">
|
|
import { ref, onMounted, onBeforeMount, reactive } from "vue";
|
|
import { useRoute, useRouter } from "vue-router";
|
|
import { ColumnProps } from "@/components/ProTable/interface";
|
|
import ProTable from "@/components/ProTable/index.vue";
|
|
import ProjectSupervision from "./components/ProjectSupervision/index.vue";
|
|
import ProjectSupervisionDiv from "./components/ProjectSupervisionDiv/index.vue";
|
|
import readonlyDialog from "./components/readonlyDialog/index.vue";
|
|
import readonlyDialogDiv from "./components/readonlyDialogDiv/index.vue";
|
|
import editDialog from "./components/editDialog/index.vue";
|
|
import fileListDialog from "./components/fileListDialog/index.vue";
|
|
import fileListDialogDiv from "./components/fileListDialogDiv/index.vue";
|
|
import {
|
|
getPreEngineeringApproveList,
|
|
getEngineeringApproveArea,
|
|
getPreIdEngApproveList,
|
|
getQueryUnSubmitApi
|
|
} from "@/api/modules/goverment";
|
|
import { getDicList } from "@/api/modules/jxjview";
|
|
import { GlobalStore } from "@/stores";
|
|
import largeScreen from "../../../hz-enterprise/largeScreen/largeScreenOne/index.vue";
|
|
import { sendIframeMessage } from "@/utils/util";
|
|
import divDialogComponent from "@/components/divDialogComponent/index.vue";
|
|
const showScreen = ref(false);
|
|
const route = useRoute();
|
|
const router = useRouter();
|
|
const fileListVisible = ref(false);
|
|
const editennMEssageVisible = ref(false);
|
|
const ennMEssageVisible = ref(false);
|
|
const DicStatusList = ref([]);
|
|
const DicPurposeList = ref([]);
|
|
const DicTypeList = ref([]);
|
|
const engineeringArea = ref([]);
|
|
const store = GlobalStore();
|
|
const engineeringSn = ref("");
|
|
// 表格配置项
|
|
const columns: ColumnProps[] = [
|
|
{ type: "index", label: "序号", width: 80 },
|
|
{
|
|
prop: "engineeringName",
|
|
label: "项目名称",
|
|
search: { el: "input", props: { clearable: true } }
|
|
},
|
|
{
|
|
prop: "engineeringCode",
|
|
label: "项目ID",
|
|
search: { el: "input" }
|
|
},
|
|
{
|
|
prop: "engineeringType",
|
|
label: "项目类型",
|
|
enum: DicTypeList.value,
|
|
search: { el: "select", props: { filterable: true } },
|
|
fieldNames: { label: "dictValue", value: "dictLabel" }
|
|
},
|
|
{
|
|
prop: "engineeringUse",
|
|
label: "项目用途",
|
|
enum: DicPurposeList,
|
|
search: { el: "select", props: { filterable: true, clearable: true } },
|
|
fieldNames: { label: "dictValue", value: "dictLabel" }
|
|
},
|
|
{
|
|
prop: "createTime",
|
|
label: "提交时间",
|
|
search: {
|
|
el: "date-picker",
|
|
props: {
|
|
type: "daterange",
|
|
format: "YYYY-MM-DD",
|
|
valueFormat: "YYYY-MM-DD"
|
|
// defaultTime: defaultTime2
|
|
}
|
|
}
|
|
},
|
|
{ prop: "operation", label: "操作", fixed: "right", width: 240 }
|
|
];
|
|
const relativeId = ref("");
|
|
const detailsDialog = ref(false);
|
|
const approvalTitle = ref("");
|
|
// 获取 ProTable 元素,调用其获取刷新数据方法(还能获取到当前查询参数,方便导出携带参数)
|
|
const proTable = ref();
|
|
const childrenDataUpdate = () => {
|
|
console.log(666);
|
|
proTable.value.getTableList();
|
|
};
|
|
// 查看文件列表
|
|
const onFileList = (row: any) => {
|
|
engineeringSn.value = row.engineeringSn;
|
|
relativeId.value = row.id;
|
|
fileListVisible.value = true;
|
|
};
|
|
const onSee = row => {
|
|
relativeId.value = row.id;
|
|
ennMEssageVisible.value = true;
|
|
};
|
|
const toScreen = row => {
|
|
if (row) {
|
|
engineeringSn.value = row.engineeringSn;
|
|
}
|
|
showScreen.value = !showScreen.value;
|
|
};
|
|
const getDicPurposeList = async () => {
|
|
const { result } = await getDicList({ dictType: "engineering_purpose" });
|
|
DicPurposeList.value.length = 0;
|
|
|
|
DicPurposeList.value.push(...result);
|
|
};
|
|
const getDicStatusList = async () => {
|
|
const { result } = await getDicList({ dictType: "engineering_state" });
|
|
DicStatusList.value.length = 0;
|
|
|
|
DicStatusList.value.push(...result);
|
|
};
|
|
const getDicTypeList = async () => {
|
|
const { result } = await getDicList({ dictType: "engineering_type" });
|
|
DicTypeList.value.length = 0;
|
|
DicTypeList.value.push(...result);
|
|
};
|
|
const getAreaList = async () => {
|
|
const { result } = await getEngineeringApproveArea();
|
|
engineeringArea.value.length = 0;
|
|
engineeringArea.value.push(...result);
|
|
};
|
|
// 整改完成,全部已提交审核
|
|
const confirmReform = () => {
|
|
proTable.value.getTableList();
|
|
console.log("我爱你");
|
|
detailsDialog.value = false;
|
|
};
|
|
// 新增项目
|
|
const handleAddItem = async () => {
|
|
store.Message = null;
|
|
store.isDraft = true;
|
|
const res: any = await getQueryUnSubmitApi({});
|
|
console.info(res, "----res---");
|
|
if (res.result) {
|
|
store.Message = res.result;
|
|
}
|
|
approvalTitle.value = "新增";
|
|
detailsDialog.value = true;
|
|
};
|
|
// 编辑项目
|
|
const onEdit = async (row: any) => {
|
|
const res: any = await getPreIdEngApproveList({ id: row.id });
|
|
store.Message = res.result;
|
|
store.isDraft = false;
|
|
approvalTitle.value = "编辑";
|
|
detailsDialog.value = true;
|
|
// relativeId.value = row.id;
|
|
// editennMEssageVisible.value = true;
|
|
};
|
|
const getTableList = (params: any) => {
|
|
let newParams = JSON.parse(JSON.stringify(params));
|
|
console.log(newParams);
|
|
if (newParams.createTime) {
|
|
newParams.createTime_begin = newParams.createTime[0];
|
|
newParams.createTime_end = newParams.createTime[1];
|
|
delete newParams.createTime;
|
|
}
|
|
return getPreEngineeringApproveList(newParams);
|
|
};
|
|
// dataCallback 是对于返回的表格数据做处理,如果你后台返回的数据不是 list && total && pageNum && pageSize 这些字段,那么你可以在这里进行处理成这些字段
|
|
// 或者直接去 hooks/useTable.ts 文件中把字段改为你后端对应的就行
|
|
const dataCallback = (data: any) => {
|
|
// console.log(data);
|
|
return {
|
|
list: data.records,
|
|
total: Number(data.total),
|
|
pageNo: Number(data.current),
|
|
pageSize: Number(data.size)
|
|
};
|
|
};
|
|
onBeforeMount(() => {
|
|
if (route.query.projectName) {
|
|
columns[1].search.defaultValue = route.query.projectName;
|
|
}
|
|
});
|
|
onMounted(async () => {
|
|
getAreaList();
|
|
getDicTypeList();
|
|
getDicStatusList();
|
|
getDicPurposeList();
|
|
await sendIframeMessage({ obj: { path: route.path } }, 2, undefined);
|
|
if (route.query.engineeringSn) {
|
|
engineeringSn.value = route.query.engineeringSn;
|
|
showScreen.value = true;
|
|
}
|
|
});
|
|
</script>
|
|
<style scoped lang="scss">
|
|
@import "./index.scss";
|
|
</style>
|