<template>
|
<div class="app-container">
|
<el-container>
|
<el-header v-show="planRecordData && planRecordData.projectName" class="header-title">项目名称:{{ planRecordData.projectName }}</el-header>
|
<h4 v-show="planRecordData && planRecordData.projectCode" style="text-align: center">项目代码:{{ planRecordData.projectCode }}</h4>
|
<el-main>
|
<el-card shadow="hover">
|
<el-row :gutter="20">
|
<el-col :span="24" class="mb-4">
|
<div style="margin-bottom: 10px">
|
<span style="font-size: 20px; font-weight: bold;">月度计划</span>
|
<el-button type="primary" size="small" style="float: right" @click="handleAddMonthPlan">新增</el-button>
|
</div>
|
<el-table :data="monthRecords" border stripe style="width: 100%; margin-bottom: 20px">
|
<!-- 表头 -->
|
<el-table-column prop="id" label="序号" align="center" width="50"/>
|
<el-table-column prop="projectName" label="项目名称" align="center" />
|
<el-table-column prop="projectCode" label="项目代码" align="center" />
|
<el-table-column label="计划期" align="center">
|
<template slot-scope="scope">
|
<span>
|
{{ scope.row.planTime }}{{ scope.row.planTimeFlag === 0 ? '月度' : scope.row.planTimeFlag === 1 ? '季度' : '年度' }}
|
</span>
|
</template>
|
</el-table-column>
|
<el-table-column prop="createTime" label="创建时间" align="center" />
|
<el-table-column fixed="right" label="操作" align="center">
|
<template slot-scope="scope">
|
<el-button type="primary" size="small" :disabled="scope.row.reportStatus === 0" @click="handlePlanInfo(scope.row)">编辑上报</el-button>
|
<el-button type="danger" size="small" v-show="scope.row.reportStatus === 1" @click="handleDeletePlanRecord(scope.row.id)">删除</el-button>
|
<el-button type="danger" size="small" v-show="scope.row.reportStatus === 0" @click="handleCheckPlanInfo(scope.row)">查看</el-button>
|
</template>
|
</el-table-column>
|
</el-table>
|
</el-col>
|
<el-col :span="24" class="mb-4" style="margin-top: 20px">
|
<div style="margin-bottom: 10px">
|
<span style="font-size: 20px; font-weight: bold;">季度计划</span>
|
<el-button type="primary" size="small" style="float: right" @click="handleAddSeasonPlan">新增</el-button>
|
</div>
|
<el-table :data="seasonRecords" border stripe style="width: 100%; margin-bottom: 20px">
|
<!-- 表头 -->
|
<el-table-column prop="id" label="序号" align="center" width="50" />
|
<el-table-column prop="projectName" label="项目名称" align="center" />
|
<el-table-column prop="projectCode" label="项目代码" align="center" />
|
<el-table-column label="计划期" align="center">
|
<template slot-scope="scope">
|
<span>
|
{{ scope.row.planTime }}{{ scope.row.planTimeFlag === 0 ? '月度' : scope.row.planTimeFlag === 1 ? '季度' : '年度' }}
|
</span>
|
</template>
|
</el-table-column>
|
<el-table-column prop="createTime" label="创建时间" align="center" />
|
<el-table-column fixed="right" label="操作" align="center">
|
<template slot-scope="scope">
|
<el-button type="primary" size="small" :disabled="scope.row.reportStatus === 0" @click="handlePlanInfo(scope.row)">编辑上报</el-button>
|
<el-button type="danger" size="small" v-show="scope.row.reportStatus === 1" @click="handleDeletePlanRecord(scope.row.id)">删除</el-button>
|
<el-button type="danger" size="small" v-show="scope.row.reportStatus === 0" @click="handleCheckPlanInfo(scope.row)">查看</el-button>
|
</template>
|
</el-table-column>
|
</el-table>
|
</el-col>
|
<el-col :span="24" class="mb-4" style="margin-top: 20px">
|
<div style="margin-bottom: 10px">
|
<span style="font-size: 20px; font-weight: bold;">年度计划</span>
|
<el-button type="primary" size="small" style="float: right" @click="handleAddYearPlan">新增</el-button>
|
</div>
|
<el-table :data="yearRecords" border stripe style="width: 100%; margin-bottom: 20px">
|
<!-- 表头 -->
|
<el-table-column prop="id" label="序号" align="center" width="50" />
|
<el-table-column prop="projectName" label="项目名称" align="center" />
|
<el-table-column prop="projectCode" label="项目代码" align="center" />
|
<el-table-column label="计划期" align="center">
|
<template slot-scope="scope">
|
<span>
|
{{ scope.row.planTime }}{{ scope.row.planTimeFlag === 0 ? '月度' : scope.row.planTimeFlag === 1 ? '季度' : '年度' }}
|
</span>
|
</template>
|
</el-table-column>
|
<el-table-column prop="createTime" label="创建时间" align="center" />
|
<el-table-column fixed="right" label="操作" align="center">
|
<template slot-scope="scope">
|
<el-button type="primary" size="small" :disabled="scope.row.reportStatus === 0" @click="handlePlanInfo(scope.row)">编辑上报</el-button>
|
<el-button type="danger" size="small" v-show="scope.row.reportStatus === 1" @click="handleDeletePlanRecord(scope.row.id)">删除</el-button>
|
<el-button type="danger" size="small" v-show="scope.row.reportStatus === 0" @click="handleCheckPlanInfo(scope.row)">查看</el-button>
|
</template>
|
</el-table-column>
|
</el-table>
|
</el-col>
|
</el-row>
|
</el-card>
|
</el-main>
|
</el-container>
|
</div>
|
</template>
|
|
<script>
|
import {addRecord, getPlanRecordList, deletePlanRecord} from "@/api/projectPlan/index";
|
|
export default {
|
name: "PlanRecord",
|
data() {
|
return {
|
// 接收传递过来的项目计划数据
|
planRecordData: {},
|
// 月度计划数据
|
monthRecords: [],
|
// 季度计划数据
|
seasonRecords: [],
|
// 年度计划数据
|
yearRecords: [],
|
}
|
},
|
methods: {
|
// 页面加载
|
search() {
|
this.getPlanRecordData(this.planRecordData.id);
|
},
|
// 获取传递过来的项目计划详情
|
getPlanInfoData() {
|
// 从查询参数中获取数据
|
this.planRecordData = this.$route.query.data
|
this.getPlanRecordData(this.planRecordData.id);
|
},
|
// 获取项目计划记录数据
|
getPlanRecordData(id) {
|
getPlanRecordList(id).then(res => {
|
this.monthRecords = res.data.monthRecords;
|
// 获取季度计划数据
|
this.seasonRecords = res.data.seasonRecords;
|
// 获取年度计划数据
|
this.yearRecords = res.data.yearRecords;
|
})
|
},
|
// 新增月度计划记录
|
handleAddMonthPlan() {
|
let planRecordData = {
|
id: undefined,
|
projectInfoId: this.planRecordData.id,
|
planTimeFlag: 0
|
}
|
// 判断月度计划是否为空
|
if (this.monthRecords.length === 0){
|
planRecordData.id = 0;
|
}else {
|
planRecordData.id = this.monthRecords[this.monthRecords.length - 1].id;
|
}
|
// 新增一行记录
|
addRecord(planRecordData).then(res => {
|
this.search();
|
});
|
},
|
// 新增季度计划记录
|
handleAddSeasonPlan() {
|
let planRecordData = {
|
id: undefined,
|
projectInfoId: this.planRecordData.id,
|
planTimeFlag: 1
|
}
|
// 判断季度计划是否为空
|
if (this.seasonRecords.length === 0){
|
planRecordData.id = 0;
|
}else {
|
planRecordData.id = this.seasonRecords[this.seasonRecords.length - 1].id;
|
}
|
// 新增一行记录
|
addRecord(planRecordData).then(res => {
|
this.search();
|
});
|
},
|
// 新增年度计划记录
|
handleAddYearPlan() {
|
let planRecordData = {
|
id: undefined,
|
projectInfoId: this.planRecordData.id,
|
planTimeFlag: 2
|
}
|
// 判断年度计划是否为空
|
if (this.yearRecords.length === 0){
|
planRecordData.id = 0;
|
}else {
|
planRecordData.id = this.yearRecords[this.yearRecords.length - 1].id;
|
}
|
// 新增一行记录
|
addRecord(planRecordData).then(res => {
|
this.search();
|
});
|
},
|
/** 修改项目计划项 */
|
handlePlanInfo(row) {
|
this.$router.push({
|
path: '/projectManage/planInfo',
|
query: {
|
data: row,
|
planRecordData: this.planRecordData
|
}
|
})
|
},
|
// 删除项目计划记录
|
handleDeletePlanRecord(id) {
|
deletePlanRecord(id).then(res => {
|
this.search();
|
});
|
},
|
// 查看项目计划项
|
handleCheckPlanInfo(row) {
|
this.$router.push({
|
path: '/projectManage/planInfoCheck',
|
query: {
|
data: row,
|
planRecordData: this.planRecordData
|
}
|
})
|
}
|
},
|
created() {
|
this.getPlanInfoData();
|
},
|
};
|
</script>
|
|
<style scoped>
|
.header-title {
|
font-size: 24px; /* 根据需要调整字体大小 */
|
text-align: center; /* 居中对齐 */
|
line-height: 64px; /* 如果需要与 header 高度对齐 */
|
}
|
</style>
|