zxl
2025-03-25 6ae0fcef149ddbe614746023a58a3885b3ac4bde
src/views/projectManage/plan/planInfoCheck.vue
@@ -1,8 +1,8 @@
<template>
  <div class="app-container">
    <el-container>
      <el-header v-show="planRecordData && planRecordData.projectName" class="header-title">项目名称:{{ planRecordData.projectName }} {{ planRecordData.planTimeFlag === 0 ? '(月度计划)' : planRecordData.planTimeFlag === 1 ? '(季度计划)' : '(年度计划)' }}</el-header>
      <h4 v-show="planRecordData && planRecordData.projectCode" style="text-align: center">项目代码:{{ planRecordData.projectCode }}</h4>
      <el-header class="header-title">项目名称:{{ planInfoData.projectName }} ({{ planInfoData.planTime}} {{ planInfoData.planTimeFlag === 0 ? '月度计划' : planInfoData.planTimeFlag === 1 ? '季度计划' : '年度计划' }})</el-header>
      <h4 style="text-align: center">项目代码:{{ planInfoData.projectCode }}</h4>
      <el-main>
        <el-card shadow="hover">
          <el-row :gutter="20">
@@ -16,34 +16,74 @@
                </el-table-column>
                <el-table-column prop="taskName" label="事项名称" width="500" align="center">
                  <template #default="scope">
                    <el-input type="textarea" v-model="scope.row.title" placeholder="请输入" rows="3" />
                    <el-input type="textarea" v-model="scope.row.title" placeholder="请输入" rows="3" :readonly="scope.row.planStatus !== 1" />
                  </template>
                </el-table-column>
                <el-table-column prop="startTime" label="计划开始时间" width="160" align="center">
                <el-table-column prop="startTime" label="计划开始时间" width="160" align="center" >
                  <template #default="scope">
                    <el-date-picker v-model="scope.row.startTime" type="date" placeholder="选择日期" size="small" style="width: 130px"/>
                    <el-date-picker
                      v-model="scope.row.startTime"
                      type="date"
                      placeholder="选择日期"
                      value-format="yyyy-MM-dd HH:mm:ss"
                      size="medium"
                      style="width: 130px"
                      :readonly="projectInfoData.managerFlag"/>
                  </template>
                </el-table-column>
                <el-table-column prop="endTime" label="计划完成时间" width="160" align="center">
                <el-table-column prop="endTime" label="计划完成时间" width="160" align="center" >
                  <template #default="scope">
                    <el-date-picker v-model="scope.row.endTime" type="date" placeholder="选择日期" size="small" style="width: 130px"/>
                    <el-date-picker
                      v-model="scope.row.endTime"
                      type="date"
                      placeholder="选择日期"
                      value-format="yyyy-MM-dd HH:mm:ss"
                      size="medium"
                      style="width: 130px"
                      :readonly="projectInfoData.managerFlag"  />
                  </template>
                </el-table-column>
                <el-table-column :label="planRecordData.planTimeFlag === 0 ? '月度' : planRecordData.planTimeFlag === 1 ? '季度' : '年度' " width="100" align="center">
                <el-table-column :label="planInfoData.planTimeFlag === 0 ? '月度' : planInfoData.planTimeFlag === 1 ? '季度' : '年度' " align="center">
                    {{ planInfoData.planTime }}{{ planInfoData.planTimeFlag === 0 ? '月度' : planInfoData.planTimeFlag === 1 ? '季度' : '年度' }}
                </el-table-column>
                <el-table-column prop="planStatus" label="状态" width="100" align="center">
                  <template #default="scope">
                    <span>{{ planRecordData.planTime }}{{ planRecordData.planTimeFlag === 0 ? '月度' : planRecordData.planTimeFlag === 1 ? '季度' : '年度' }}</span>
                    {{ scope.row.planStatus === 1 ? '已驳回' : scope.row.planStatus === 2 ? '已通过' : '未审核' }}
                  </template>
                </el-table-column>
                <el-table-column fixed="right" label="操作" align="center">
                  <template #default="scope">
                    <el-button size="small" @click="handleDelay(scope.$index)">延期</el-button>
                    <el-button size="small" type="danger" @click="handleReset(scope.$index)">重置</el-button>
                  </template>
                </el-table-column>
                <div v-if="!projectInfoData.managerFlag">
                  <el-table-column fixed="right" label="操作" align="center">
                    <template #default="scope">
                      <!-- 状态为未审核 -->
                      <div v-if="scope.row.planStatus === 0"></div>
                      <!-- 状态为已驳回 -->
                      <div v-if="scope.row.planStatus === 1">
                        <el-button
                          size="medium"
                          type="text"
                          icon="el-icon-upload2"
                          @click="handleResubmit(scope.row)">重新上报</el-button>
                        <el-button
                          size="medium"
                          type="text"
                          icon="el-icon-refresh-left"
                          @click="handleReset(scope.$index)">重置</el-button>
                      </div>
                      <!-- 状态为已通过 -->
                      <div v-if="scope.row.planStatus === 2">
                        <el-button
                          size="medium"
                          type="text"
                          icon="el-icon-edit"
                          @click="handleDelay(scope.$index)">延期</el-button>
                      </div>
                    </template>
                  </el-table-column>
                </div>
              </el-table>
              <div style="display: flex; align-items: center;">
                <h1 style="margin: 0;">
                  截止本计划进度完成投资(万元):
                  计划投资金额(万元):
                </h1>
                <el-input
                  placeholder="请输入投资金额"
@@ -51,7 +91,8 @@
                  v-model="actualInvest"
                  clearable
                  :type="number"
                  @input="handleInput">
                  @input="handleInput"
                  readonly>
                </el-input>
              </div>
@@ -66,32 +107,110 @@
                  </template>
                </el-table-column>
                <el-table-column prop="title" label="事项名称" width="200" align="center" />
                <el-table-column prop="departmentExamine" label="上级审核" width="100" align="center">
                <el-table-column prop="departmentExamine" label="上级审核" width="130" align="center">
                  <template #default="scope">
                    {{ scope.row.departmentExamine === 0 ? '同意' : scope.row.departmentExamine === 1 ? '驳回' : '未审核' }}
                    <div v-if="projectInfoData.managerFlag">
                      <el-select
                        v-model="scope.row.departmentExamine"
                        :disabled="scope.row.planStatus === 2 || scope.row.planStatus === 1"
                        placeholder="请选择"
                        size="medium"
                        clearable>
                        <el-option label="同意" :value="0"></el-option>
                        <el-option label="驳回" :value="1"></el-option>
                      </el-select>
                    </div>
                    <div v-if="!projectInfoData.managerFlag">
                      {{ scope.row.departmentExamine === 0 ? '同意' : scope.row.departmentExamine === 1 ? '驳回' : '未审核' }}
                    </div>
                  </template>
                </el-table-column>
                <el-table-column prop="departmentApproval" label="批复内容" width="160" align="center" />
                <el-table-column prop="departmentApproval" label="批复内容" width="160" align="center">
                  <template v-if="projectInfoData.managerFlag" #default="scope">
                    <el-input
                      type="textarea"
                      v-model="scope.row.departmentApproval"
                      :readonly="scope.row.planStatus === 2 || scope.row.planStatus === 1"
                      placeholder="请输入"
                      rows="3" />
                  </template>
                </el-table-column>
                <el-table-column prop="departmentApprovalReply" label="批复回复" width="160" align="center">
                  <template #default="scope">
                    <el-input type="textarea" v-model="scope.row.departmentApprovalReply" placeholder="请输入" rows="3" />
                  <template #default="scope" v-if="!projectInfoData.managerFlag">
                    <el-input
                      type="textarea"
                      v-model="scope.row.departmentApprovalReply"
                      :readonly="scope.row.planStatus === 0"
                      placeholder="请输入"
                      rows="3" />
                  </template>
                </el-table-column>
                <el-table-column prop="manageExamine" label="主管部门审核" width="100" align="center" >
                <el-table-column prop="manageExamine" label="主管部门审核" width="130" align="center" >
                  <template #default="scope">
                    {{ scope.row.manageExamine === 0 ? '同意' : scope.row.manageExamine === 1 ? '驳回' : '未审核' }}
                    <div v-if="!projectInfoData.managerFlag">
                      {{ scope.row.manageExamine === 0 ? '同意' : scope.row.manageExamine === 1 ? '驳回' : '未审核' }}
                    </div>
                    <div v-if="projectInfoData.managerFlag">
                      <el-select
                        v-model="scope.row.manageExamine"
                        :disabled="scope.row.planStatus === 2 || scope.row.planStatus === 1"
                        placeholder="请选择"
                        size="medium"
                        clearable>
                        <el-option label="同意" :value="0"></el-option>
                        <el-option label="驳回" :value="1"></el-option>
                      </el-select>
                    </div>
                  </template>
                </el-table-column>
                <el-table-column prop="manageApproval" label="批复内容" width="160" align="center" />
                <el-table-column prop="manageApproval" label="批复内容" width="160" align="center">
                  <template v-if="projectInfoData.managerFlag" #default="scope">
                    <el-input
                      type="textarea"
                      v-model="scope.row.manageApproval"
                      :readonly="scope.row.planStatus === 2 || scope.row.planStatus === 1"
                      placeholder="请输入"
                      rows="3" />
                  </template>
                </el-table-column>
                <el-table-column prop="manageApprovalReply" label="批复回复" width="160" align="center">
                  <template #default="scope">
                    <el-input type="textarea" v-model="scope.row.manageApprovalReply" placeholder="请输入" rows="3" />
                  <template #default="scope" v-if="!projectInfoData.managerFlag">
                    <el-input
                      type="textarea"
                      v-model="scope.row.manageApprovalReply"
                      :readonly="scope.row.planStatus === 0"
                      placeholder="请输入"
                      rows="3" />
                  </template>
                </el-table-column>
                <el-table-column fixed="right" label="操作" align="center">
                <el-table-column prop="planStatus" label="状态" width="200" align="center" >
                  <template #default="scope">
                    <el-button size="small" @click="handleReply(scope.$index)">回复</el-button>
                    <el-button size="small" type="danger" @click="handleReset(scope.$index)">重置</el-button>
                    {{ scope.row.planStatus === 1 ? '已驳回' : scope.row.planStatus === 2 ? '已通过' : '未审核' }}
                  </template>
                </el-table-column>
                <el-table-column fixed="right" label="操作" align="center" width="200">
                  <template #default="scope">
                    <div v-if="!projectInfoData.managerFlag">
                      <el-button
                        size="medium"
                        type="text"
                        icon="el-icon-reply"
                        @click="handleReply(scope.$index)"
                        :disabled="scope.row.planStatus === 0">回复</el-button>
                      <el-button
                        size="medium"
                        type="text"
                        icon="el-icon-refresh-left"
                        @click="handleReset(scope.$index)"
                        :disabled="scope.row.planStatus === 0">重置</el-button>
                    </div>
                    <div v-if="projectInfoData.managerFlag">
                      <el-button
                        size="medium"
                        type="text"
                        @click="handleExamine(scope.$index)"
                        v-if="scope.row.planStatus === 0">审核</el-button>
                    </div>
                  </template>
                </el-table-column>
              </el-table>
@@ -133,7 +252,7 @@
</template>
<script>
import { getPlanInfoData, delayPlanInfo, getDepartmentApproval, getPlanLog, replyDepartmentApproval } from "@/api/projectPlan/index";
import { getPlanInfoData, delayPlanInfo, getDepartmentApproval, getPlanLog, replyExamine, saveExamine, resubmitPlanInfo } from "@/api/projectPlan/index";
export default {
  name: "planInfoCheck",
@@ -141,8 +260,8 @@
    return {
      loading: true,
      // 接收传递过来的项目计划数据
      planRecordData: {},
      planInfoData: {},
      projectInfoData: {},
      // 计划项数据
      tableData: [
        {
@@ -169,17 +288,15 @@
  methods: {
    // 页面加载
    search() {
      this.getPlanInfoData(this.planRecordData.id); // 获取项目计划项
      this.getDepartmentApproval(this.planRecordData.id); // 获取上级批复
      this.getPlanLog(this.planRecordData.id); // 获取计划日志
      this.getPlanInfoData(this.planInfoData.id); // 获取项目计划项
      this.getDepartmentApproval(this.planInfoData.id); // 获取上级批复
      this.getPlanLog(this.planInfoData.id); // 获取计划日志
    },
    // 获取传递过来的项目计划详情
    getPlanRecordData() {
      // 从查询参数中获取数据
      if (this.$route.query.data) {
        this.planRecordData = JSON.parse(this.$route.query.data)
      }
      this.planInfoData = this.$route.query.planInfoData
      this.projectInfoData = JSON.parse(this.$route.query.projectInfoData)
      this.planInfoData = JSON.parse(this.$route.query.data)
      this.search();
    },
    // 获取项目计划项
@@ -191,6 +308,13 @@
        } else {
          this.tableData = response.data.list;
        }
      });
    },
    // 用户重新上报计划项
    handleResubmit(data) {
      resubmitPlanInfo(data).then(response => {
        this.$message.success('重新上报成功');
        this.search()
      });
    },
    // 延期
@@ -206,14 +330,20 @@
        this.departmentApprovalData = response.data;
      });
    },
    // 回复
    // 回复审批
    handleReply(index) {
      replyDepartmentApproval(this.departmentApprovalData[index]).then(response => {
      replyExamine(this.departmentApprovalData[index]).then(response => {
        this.$message.success('回复成功');
        this.search()
      });
    },
    // 保存审批
    handleExamine(index) {
      saveExamine(this.departmentApprovalData[index]).then(response => {
        this.$message.success('审批成功');
        this.search()
      });
    },
    // 获取计划日志
    getPlanLog(projectPlanRecordId) {
      getPlanLog(projectPlanRecordId).then(response => {
@@ -225,15 +355,6 @@
      this.tableData[index].title = '';
      this.tableData[index].startTime = '';
      this.tableData[index].endTime = '';
    },
    /** 返回项目计划记录页面 */
    handlePlanRecord(planInfoData) {
      this.$router.push({
        name: '/projectManage/planRecord',
        query: {
          data: JSON.stringify(planInfoData)
        }
      })
    },
  },
  created() {