From d4325ae343f7bfdaa8bc56b3ab72598d0072437e Mon Sep 17 00:00:00 2001
From: zhouwx <1175765986@qq.com>
Date: Thu, 30 Apr 2026 13:46:00 +0800
Subject: [PATCH] 增加复制功能

---
 src/views/work/selfProblems/mngAudit/mngAuditPlan/index.vue          |  151 +++++++-
 src/views/work/selfProblems/mngAudit/mngAuditMeeting/index.vue       |  144 +++++++
 src/api/selfProblems/plan.js                                         |    9 
 src/views/work/selfProblems/scenario/index.vue                       |  144 +++++++
 src/views/work/selfProblems/plan/index.vue                           |  141 +++++++
 src/api/innerReview/meetingReview.js                                 |   29 +
 src/api/selfProblems/scenario.js                                     |    9 
 src/views/work/selfProblems/internalAudit/innerReviewSheet/index.vue |  139 +++++++
 src/views/work/selfProblems/mngAudit/mngAuditInput/index.vue         |  144 +++++++
 src/views/work/selfProblems/mngAudit/mngAuditReport/index.vue        |  143 +++++++
 10 files changed, 966 insertions(+), 87 deletions(-)

diff --git a/src/api/innerReview/meetingReview.js b/src/api/innerReview/meetingReview.js
index ae20803..69666c8 100644
--- a/src/api/innerReview/meetingReview.js
+++ b/src/api/innerReview/meetingReview.js
@@ -198,4 +198,31 @@
     method: 'post',
     data: data
   })
-}
\ No newline at end of file
+}
+
+//复制-计划
+export function copyManagementPlan(data) {
+  return request({
+    url: '/system/managementPlan/copyManagementPlan',
+    method: 'get',
+    params: data
+  })
+}
+
+//复制-会议、输入、报告
+export function copyMeetReportInput(data) {
+  return request({
+    url: '/system/managementReview/copyManagementReview',
+    method: 'get',
+    params: data
+  })
+}
+
+//复制-内审检查表
+export function copyCheck(data) {
+  return request({
+    url: '/system/internalAuditCheck/copyInternalAuditCheck',
+    method: 'get',
+    params: data
+  })
+}
diff --git a/src/api/selfProblems/plan.js b/src/api/selfProblems/plan.js
index ad9c05b..c3a1875 100644
--- a/src/api/selfProblems/plan.js
+++ b/src/api/selfProblems/plan.js
@@ -33,4 +33,13 @@
     })
 }
 
+//复制
+export function copyPlan(data) {
+    return request({
+        url: '/internal/audit/carry/copy',
+        method: 'get',
+        params: data
+    })
+}
+
 
diff --git a/src/api/selfProblems/scenario.js b/src/api/selfProblems/scenario.js
index f103ea6..f42fe78 100644
--- a/src/api/selfProblems/scenario.js
+++ b/src/api/selfProblems/scenario.js
@@ -33,4 +33,11 @@
     })
 }
 
-
+//复制
+export function copyScenario(data) {
+    return request({
+        url: '/internal/audit/plan/copy',
+        method: 'get',
+        params: data
+    })
+}
diff --git a/src/views/work/selfProblems/internalAudit/innerReviewSheet/index.vue b/src/views/work/selfProblems/internalAudit/innerReviewSheet/index.vue
index d34adba..641bf08 100644
--- a/src/views/work/selfProblems/internalAudit/innerReviewSheet/index.vue
+++ b/src/views/work/selfProblems/internalAudit/innerReviewSheet/index.vue
@@ -21,15 +21,23 @@
             </el-option>
           </el-select>
         </el-form-item>
+        <el-form-item label="年份:" >
+          <el-date-picker
+              v-model="data.queryParams.year"
+              type="year"
+              value-format="YYYY"
+          />
+        </el-form-item>
         <el-form-item >
-          <el-button v-if="isAdmin" type="primary" @click="getList">查询</el-button>
-          <el-button v-if="isAdmin" type="primary" plain @click="reset">重置</el-button>
+          <el-button  type="primary" @click="getList">查询</el-button>
+          <el-button  type="primary" plain @click="reset">重置</el-button>
         </el-form-item>
         <el-form-item style="margin-left: -20px">
           <el-button
               type="primary"
               @click="exportData"
           >导出</el-button>
+          <el-button  type="primary" plain @click="copy">复制</el-button>
         </el-form-item>
       </el-form>
     </div>
@@ -61,6 +69,49 @@
     />
 
     <edit-dialog ref="dialogRef" @getList=getList></edit-dialog>
+    <el-dialog
+        v-model="copyVisible"
+        width="500px"
+        :before-close="handleCloseCopy"
+        :close-on-press-escape="false"
+        :close-on-click-modal="false"
+    >
+      <div v-if="data.isAdmin">
+        <span style="display:block;margin-bottom: 8px">单位名称:</span>
+        <el-select
+            v-model="queryParams.companyId"
+            filterable
+            style="width: 100%;margin-bottom: 8px"
+        >
+          <el-option
+              v-for="item in data.companyList"
+              :key="item.id"
+              :label="item.name"
+              :value="item.id"
+          />
+        </el-select>
+      </div>
+      <span style="display:block;margin-bottom: 8px">将以下年份数据:</span>
+      <el-date-picker
+          v-model="data.sourceYear"
+          type="year"
+          value-format="YYYY"
+          style="margin-bottom: 8px;width: 100%;"
+          placeholder="请选择"
+      />
+      <span style="display:block;margin-bottom: 8px">复制到:</span>
+      <el-date-picker
+          v-model="data.targetYear"
+          type="year"
+          value-format="YYYY"
+          style="margin-bottom: 8px;width: 100%"
+          placeholder="请选择"
+      />
+      <div class="dialog-footer" style="display: flex;justify-content: right">
+        <el-button @click="handleCloseCopy" size="default">取 消</el-button>
+        <el-button type="primary"  @click="onSubmitCopy" size="default" v-preReClick>确认</el-button>
+      </div>
+    </el-dialog>
   </div>
 </template>
 
@@ -74,6 +125,7 @@
 import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
 import { renderAsync } from "docx-preview";
 import {
+  copyCheck,
   delInternalAuditCheck,
   delMeetingsList,
   getInternalAuditCheck, getInternalAuditCheckInfo,
@@ -91,15 +143,19 @@
   queryParams: {
     pageNum: 1,
     pageSize: 10,
-    companyId: null
+    companyId: null,
+    year:''
   },
+  copyVisible: false,
+  targetYear:'',
+  sourceYear:'',
   total: 0,
   dataList: [],
   companyList: [],
   isAdmin: false
 });
 
-const { queryParams, total, dataList,companyList, isAdmin } = toRefs(data);
+const { queryParams, total, dataList,companyList, isAdmin,copyVisible } = toRefs(data);
 const userInfo = ref()
 onMounted(async ()=>{
   if(userStore.roles.includes('admin')){
@@ -110,8 +166,12 @@
     data.isAdmin = false
     data.queryParams.companyId = userStore.companyId
   }
+  await getNowYear()
   await getList()
 })
+const getNowYear = () =>{
+  data.queryParams.year = new Date().getFullYear().toString()
+}
 
 onUnmounted(()=>{
 
@@ -150,13 +210,25 @@
 
 /** 重置新增的表单以及其他数据  */
 const reset= async()=> {
-  data.queryParams = {
-    pageNum: 1,
-    pageSize: 10,
-    companyId: null
+  if(data.isAdmin){
+    data.queryParams = {
+      pageNum: 1,
+      pageSize: 10,
+      companyId: null,
+      year:''
+    }
+    data.companyList = [];
+    await getCompanyList()
+  }else {
+    data.queryParams = {
+      companyId: data.queryParams.companyId,
+      pageNum: 1,
+      pageSize: 10,
+      year: '',
+    }
   }
   choosedData.value = []
-  await getCompanyList()
+  await getNowYear()
   await getList()
 }
 const handleDelete = (val) => {
@@ -214,5 +286,54 @@
     }
   })
 }
+const handleCloseCopy = () => {
+  data.targetYear=''
+  data.sourceYear=''
+  data.copyVisible = false
+}
+const copy = () => {
+  data.copyVisible = true
+}
+const onSubmitCopy = async () => {
+  if(data.isAdmin && !data.queryParams.companyId){
+    ElMessage.warning('请先选择单位')
+    return
+  }
+  if(!data.sourceYear){
+    ElMessage.warning('请先选择要复制的年份')
+    return
+  }
+  if(!data.targetYear){
+    ElMessage.warning('请选择目标年份')
+    return
+  }
+  ElMessageBox.confirm(
+      '该操作将覆盖目标年份的数据,是否继续?',
+      '提示',
+      {
+        confirmButtonText: '确定',
+        cancelButtonText: '取消',
+        type: 'warning',
+      })
+      .then( async() => {
+        const param = {
+          companyId: data.queryParams.companyId,
+          sourceYear: data.sourceYear,
+          targetYear: data.targetYear
+        }
+        const res = await copyCheck(param);
+        if(res.code === 200){
+          ElMessage({
+            type: 'success',
+            message: res.data
+          });
+          await handleCloseCopy()
+          await getList();
+        }else{
+          ElMessage.warning(res.message)
+        }
+      }).catch(err => {
+  })
+}
 
 </script>
diff --git a/src/views/work/selfProblems/mngAudit/mngAuditInput/index.vue b/src/views/work/selfProblems/mngAudit/mngAuditInput/index.vue
index c69b0a3..740f9f8 100644
--- a/src/views/work/selfProblems/mngAudit/mngAuditInput/index.vue
+++ b/src/views/work/selfProblems/mngAudit/mngAuditInput/index.vue
@@ -21,9 +21,17 @@
             </el-option>
           </el-select>
         </el-form-item>
+        <el-form-item label="年份:" >
+          <el-date-picker
+              v-model="data.queryParams.year"
+              type="year"
+              value-format="YYYY"
+          />
+        </el-form-item>
         <el-form-item >
-          <el-button v-if="isAdmin" type="primary" @click="getList">查询</el-button>
-          <el-button v-if="isAdmin" type="primary" plain @click="reset">重置</el-button>
+          <el-button  type="primary" @click="getList">查询</el-button>
+          <el-button  plain @click="reset">重置</el-button>
+          <el-button  type="primary" plain @click="copy">复制</el-button>
         </el-form-item>
       </el-form>
     </div>
@@ -55,6 +63,49 @@
     />
 
     <edit-dialog ref="dialogRef" @getList=getList></edit-dialog>
+    <el-dialog
+        v-model="copyVisible"
+        width="500px"
+        :before-close="handleCloseCopy"
+        :close-on-press-escape="false"
+        :close-on-click-modal="false"
+    >
+      <div v-if="data.isAdmin">
+        <span style="display:block;margin-bottom: 8px">单位名称:</span>
+        <el-select
+            v-model="queryParams.companyId"
+            filterable
+            style="width: 100%;margin-bottom: 8px"
+        >
+          <el-option
+              v-for="item in data.companyList"
+              :key="item.id"
+              :label="item.name"
+              :value="item.id"
+          />
+        </el-select>
+      </div>
+      <span style="display:block;margin-bottom: 8px">将以下年份数据:</span>
+      <el-date-picker
+          v-model="data.sourceYear"
+          type="year"
+          value-format="YYYY"
+          style="margin-bottom: 8px;width: 100%;"
+          placeholder="请选择"
+      />
+      <span style="display:block;margin-bottom: 8px">复制到:</span>
+      <el-date-picker
+          v-model="data.targetYear"
+          type="year"
+          value-format="YYYY"
+          style="margin-bottom: 8px;width: 100%"
+          placeholder="请选择"
+      />
+      <div class="dialog-footer" style="display: flex;justify-content: right">
+        <el-button @click="handleCloseCopy" size="default">取 消</el-button>
+        <el-button type="primary"  @click="onSubmitCopy" size="default" v-preReClick>确认</el-button>
+      </div>
+    </el-dialog>
   </div>
 </template>
 
@@ -68,6 +119,7 @@
 import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
 import { renderAsync } from "docx-preview";
 import {
+  copyMeetReportInput,
   delMeetingsList,
   delSelectInconsistent, delSelectMeetings,
   getMeetingsList,
@@ -84,15 +136,19 @@
     pageNum: 1,
     pageSize: 10,
     companyId: null,
-    reviewType: 2
+    reviewType: 2,
+    year:''
   },
+  copyVisible: false,
+  targetYear:'',
+  sourceYear:'',
   total: 0,
   dataList: [],
   companyList: [],
   isAdmin: false
 });
 
-const { queryParams, total, dataList,companyList, isAdmin } = toRefs(data);
+const { queryParams, total, dataList,companyList, isAdmin,copyVisible} = toRefs(data);
 const userInfo = ref()
 onMounted(async ()=>{
   if(userStore.roles.includes('admin')){
@@ -102,12 +158,16 @@
     data.isAdmin = false
     data.queryParams.companyId = userStore.companyId
   }
+  await getNowYear()
   await getList()
 })
 
 onUnmounted(()=>{
 
 })
+const getNowYear = () =>{
+  data.queryParams.year = new Date().getFullYear().toString()
+}
 
 const getList = async () => {
   loading.value = true
@@ -188,13 +248,26 @@
 
 /** 重置新增的表单以及其他数据  */
 const reset= async()=> {
-  data.queryParams = {
-    pageNum: 1,
-    pageSize: 10,
-    companyId: null,
-    reviewType: 2
+  if(data.isAdmin){
+    data.queryParams = {
+      pageNum: 1,
+      pageSize: 10,
+      companyId: null,
+      reviewType: 2,
+      year:''
+    }
+    data.companyList = [];
+    await getCompanyList()
+  }else {
+    data.queryParams = {
+      companyId: data.queryParams.companyId,
+      pageNum: 1,
+      pageSize: 10,
+      reviewType: 2,
+      year:''
+    }
   }
-  await getCompanyList()
+  await getNowYear()
   await getList()
 }
 const handleDelete = (val) => {
@@ -216,5 +289,54 @@
         }
       })
 }
-
+const handleCloseCopy = () => {
+  data.targetYear=''
+  data.sourceYear=''
+  data.copyVisible = false
+}
+const copy = () => {
+  data.copyVisible = true
+}
+const onSubmitCopy = async () => {
+  if(data.isAdmin && !data.queryParams.companyId){
+    ElMessage.warning('请先选择单位')
+    return
+  }
+  if(!data.sourceYear){
+    ElMessage.warning('请先选择要复制的年份')
+    return
+  }
+  if(!data.targetYear){
+    ElMessage.warning('请选择目标年份')
+    return
+  }
+  ElMessageBox.confirm(
+      '该操作将覆盖目标年份的数据,是否继续?',
+      '提示',
+      {
+        confirmButtonText: '确定',
+        cancelButtonText: '取消',
+        type: 'warning',
+      })
+      .then( async() => {
+        const param = {
+          companyId: data.queryParams.companyId,
+          sourceYear: data.sourceYear,
+          targetYear: data.targetYear,
+          reviewType: 2
+        }
+        const res = await copyMeetReportInput(param);
+        if(res.code === 200){
+          ElMessage({
+            type: 'success',
+            message: res.data
+          });
+          await handleCloseCopy()
+          await getList();
+        }else{
+          ElMessage.warning(res.message)
+        }
+      }).catch(err => {
+  })
+}
 </script>
diff --git a/src/views/work/selfProblems/mngAudit/mngAuditMeeting/index.vue b/src/views/work/selfProblems/mngAudit/mngAuditMeeting/index.vue
index 98fe75b..b322db3 100644
--- a/src/views/work/selfProblems/mngAudit/mngAuditMeeting/index.vue
+++ b/src/views/work/selfProblems/mngAudit/mngAuditMeeting/index.vue
@@ -21,9 +21,17 @@
             </el-option>
           </el-select>
         </el-form-item>
+        <el-form-item label="年份:" >
+          <el-date-picker
+              v-model="data.queryParams.year"
+              type="year"
+              value-format="YYYY"
+          />
+        </el-form-item>
         <el-form-item >
-          <el-button v-if="isAdmin" type="primary" @click="getList">查询</el-button>
-          <el-button v-if="isAdmin" type="primary" plain @click="reset">重置</el-button>
+          <el-button  type="primary" @click="getList">查询</el-button>
+          <el-button  plain @click="reset">重置</el-button>
+          <el-button  type="primary" plain @click="copy">复制</el-button>
         </el-form-item>
       </el-form>
     </div>
@@ -55,6 +63,49 @@
     />
 
     <edit-dialog ref="dialogRef" @getList=getList></edit-dialog>
+    <el-dialog
+        v-model="copyVisible"
+        width="500px"
+        :before-close="handleCloseCopy"
+        :close-on-press-escape="false"
+        :close-on-click-modal="false"
+    >
+      <div v-if="data.isAdmin">
+        <span style="display:block;margin-bottom: 8px">单位名称:</span>
+        <el-select
+            v-model="queryParams.companyId"
+            filterable
+            style="width: 100%;margin-bottom: 8px"
+        >
+          <el-option
+              v-for="item in data.companyList"
+              :key="item.id"
+              :label="item.name"
+              :value="item.id"
+          />
+        </el-select>
+      </div>
+      <span style="display:block;margin-bottom: 8px">将以下年份数据:</span>
+      <el-date-picker
+          v-model="data.sourceYear"
+          type="year"
+          value-format="YYYY"
+          style="margin-bottom: 8px;width: 100%;"
+          placeholder="请选择"
+      />
+      <span style="display:block;margin-bottom: 8px">复制到:</span>
+      <el-date-picker
+          v-model="data.targetYear"
+          type="year"
+          value-format="YYYY"
+          style="margin-bottom: 8px;width: 100%"
+          placeholder="请选择"
+      />
+      <div class="dialog-footer" style="display: flex;justify-content: right">
+        <el-button @click="handleCloseCopy" size="default">取 消</el-button>
+        <el-button type="primary"  @click="onSubmitCopy" size="default" v-preReClick>确认</el-button>
+      </div>
+    </el-dialog>
   </div>
 </template>
 
@@ -68,6 +119,7 @@
 import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
 import { renderAsync } from "docx-preview";
 import {
+  copyMeetReportInput,
   delMeetingsList,
   delSelectInconsistent, delSelectMeetings,
   getMeetingsList,
@@ -84,15 +136,19 @@
     pageNum: 1,
     pageSize: 10,
     companyId: null,
-    reviewType: 1
+    reviewType: 1,
+    year:''
   },
+  copyVisible: false,
+  targetYear:'',
+  sourceYear:'',
   total: 0,
   dataList: [],
   companyList: [],
   isAdmin: false
 });
 
-const { queryParams, total, dataList,companyList, isAdmin } = toRefs(data);
+const { queryParams, total, dataList,companyList, isAdmin,copyVisible } = toRefs(data);
 const userInfo = ref()
 onMounted(async ()=>{
   if(userStore.roles.includes('admin')){
@@ -102,13 +158,16 @@
     data.isAdmin = false
     data.queryParams.companyId = userStore.companyId
   }
+  await getNowYear()
   await getList()
 })
 
 onUnmounted(()=>{
 
 })
-
+const getNowYear = () =>{
+  data.queryParams.year = new Date().getFullYear().toString()
+}
 const getList = async () => {
   loading.value = true
   const res = await getSelectMeetings(data.queryParams)
@@ -188,13 +247,26 @@
 
 /** 重置新增的表单以及其他数据  */
 const reset= async()=> {
-  data.queryParams = {
-    pageNum: 1,
-    pageSize: 10,
-    companyId: null,
-    reviewType: 1
+  if(data.isAdmin){
+    data.queryParams = {
+      pageNum: 1,
+      pageSize: 10,
+      companyId: null,
+      reviewType: 1,
+      year:null
+    }
+    data.companyList = [];
+    await getCompanyList()
+  }else {
+    data.queryParams = {
+      companyId: data.queryParams.companyId,
+      pageNum: 1,
+      pageSize: 10,
+      reviewType: 1,
+      year: null,
+    }
   }
-  await getCompanyList()
+  await getNowYear()
   await getList()
 }
 const handleDelete = (val) => {
@@ -216,5 +288,55 @@
         }
       })
 }
+const handleCloseCopy = () => {
+  data.targetYear=''
+  data.sourceYear=''
+  data.copyVisible = false
+}
+const copy = () => {
+  data.copyVisible = true
+}
+const onSubmitCopy = async () => {
+  if(data.isAdmin && !data.queryParams.companyId){
+    ElMessage.warning('请先选择单位')
+    return
+  }
+  if(!data.sourceYear){
+    ElMessage.warning('请先选择要复制的年份')
+    return
+  }
+  if(!data.targetYear){
+    ElMessage.warning('请选择目标年份')
+    return
+  }
+  ElMessageBox.confirm(
+      '该操作将覆盖目标年份的数据,是否继续?',
+      '提示',
+      {
+        confirmButtonText: '确定',
+        cancelButtonText: '取消',
+        type: 'warning',
+      })
+      .then( async() => {
+        const param = {
+          companyId: data.queryParams.companyId,
+          sourceYear: data.sourceYear,
+          targetYear: data.targetYear,
+          reviewType: 1
+        }
+        const res = await copyMeetReportInput(param);
+        if(res.code === 200){
+          ElMessage({
+            type: 'success',
+            message: res.data
+          });
+          await handleCloseCopy()
+          await getList();
+        }else{
+          ElMessage.warning(res.message)
+        }
+      }).catch(err => {
+  })
+}
 
 </script>
diff --git a/src/views/work/selfProblems/mngAudit/mngAuditPlan/index.vue b/src/views/work/selfProblems/mngAudit/mngAuditPlan/index.vue
index e77456d..b9fb1a5 100644
--- a/src/views/work/selfProblems/mngAudit/mngAuditPlan/index.vue
+++ b/src/views/work/selfProblems/mngAudit/mngAuditPlan/index.vue
@@ -21,19 +21,17 @@
             </el-option>
           </el-select>
         </el-form-item>
-        <el-form-item v-if="isAdmin" label="年份:" >
-          <el-select v-model="data.queryParams.year" placeholder="请选择" clearable>
-            <el-option
-                v-for="item in yearList"
-                :key="item.value"
-                :label="item.label"
-                :value="item.value">
-            </el-option>
-          </el-select>
+        <el-form-item label="年份:" >
+          <el-date-picker
+              v-model="data.queryParams.year"
+              type="year"
+              value-format="YYYY"
+          />
         </el-form-item>
         <el-form-item >
-          <el-button v-if="isAdmin" type="primary" @click="getList">查询</el-button>
-          <el-button v-if="isAdmin" type="primary" plain @click="reset">重置</el-button>
+          <el-button  type="primary" @click="getList">查询</el-button>
+          <el-button  plain @click="reset">重置</el-button>
+          <el-button  type="primary" plain @click="copy">复制</el-button>
         </el-form-item>
       </el-form>
     </div>
@@ -69,6 +67,49 @@
     />
 
     <edit-dialog ref="dialogRef" @getList=getList></edit-dialog>
+    <el-dialog
+        v-model="copyVisible"
+        width="500px"
+        :before-close="handleCloseCopy"
+        :close-on-press-escape="false"
+        :close-on-click-modal="false"
+    >
+      <div v-if="data.isAdmin">
+        <span style="display:block;margin-bottom: 8px">单位名称:</span>
+        <el-select
+            v-model="queryParams.companyId"
+            filterable
+            style="width: 100%;margin-bottom: 8px"
+        >
+          <el-option
+              v-for="item in data.companyList"
+              :key="item.id"
+              :label="item.name"
+              :value="item.id"
+          />
+        </el-select>
+      </div>
+      <span style="display:block;margin-bottom: 8px">将以下年份数据:</span>
+      <el-date-picker
+          v-model="data.sourceYear"
+          type="year"
+          value-format="YYYY"
+          style="margin-bottom: 8px;width: 100%;"
+          placeholder="请选择"
+      />
+      <span style="display:block;margin-bottom: 8px">复制到:</span>
+      <el-date-picker
+          v-model="data.targetYear"
+          type="year"
+          value-format="YYYY"
+          style="margin-bottom: 8px;width: 100%"
+          placeholder="请选择"
+      />
+      <div class="dialog-footer" style="display: flex;justify-content: right">
+        <el-button @click="handleCloseCopy" size="default">取 消</el-button>
+        <el-button type="primary"  @click="onSubmitCopy" size="default" v-preReClick>确认</el-button>
+      </div>
+    </el-dialog>
   </div>
 </template>
 
@@ -82,6 +123,7 @@
 import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
 import { renderAsync } from "docx-preview";
 import {
+  copyManagementPlan,
   delManagementPlan,
   delMeetingsList,
   delSelectInconsistent, getInternalAuditCheckInfo, getManagementPlan,
@@ -89,6 +131,7 @@
   getSelectInconsistent
 } from "@/api/innerReview/meetingReview";
 import {generateWordDocument} from "@/utils/exportWord";
+import {copyFactor} from "@/api/environment/factors";
 
 
 const userStore = useUserStore()
@@ -99,8 +142,12 @@
   queryParams: {
     pageNum: 1,
     pageSize: 10,
-    companyId: null
+    companyId: null,
+    year:''
   },
+  copyVisible: false,
+  targetYear:'',
+  sourceYear:'',
   total: 0,
   dataList: [],
   companyList: [],
@@ -114,7 +161,7 @@
   isAdmin: false
 });
 
-const { queryParams, total, dataList,companyList,yearList, isAdmin } = toRefs(data);
+const { queryParams, total, dataList,companyList,yearList, isAdmin,copyVisible } = toRefs(data);
 const userInfo = ref()
 onMounted(async ()=>{
   if(userStore.roles.includes('admin')){
@@ -124,13 +171,16 @@
     data.isAdmin = false
     data.queryParams.companyId = userStore.companyId
   }
+  await getNowYear()
   await getList()
 })
 
 onUnmounted(()=>{
 
 })
-
+const getNowYear = () =>{
+  data.queryParams.year = new Date().getFullYear().toString()
+}
 const getList = async () => {
   loading.value = true
   const res = await getManagementPlan(data.queryParams)
@@ -220,13 +270,26 @@
 }
 
 /** 重置新增的表单以及其他数据  */
+
 const reset= async()=> {
-  data.queryParams = {
-    pageNum: 1,
-    pageSize: 10,
-    companyId: null
+  if(data.isAdmin){
+    data.queryParams = {
+      pageNum: 1,
+      pageSize: 10,
+      companyId: null,
+      year:''
+    }
+    data.companyList = [];
+   await getCompanyList()
+  }else {
+    data.queryParams = {
+      companyId: data.queryParams.companyId,
+      pageNum: 1,
+      pageSize: 10,
+      year: '',
+    }
   }
-  await getCompanyList()
+  await getNowYear()
   await getList()
 }
 const handleDelete = (val) => {
@@ -248,5 +311,53 @@
         }
       })
 }
-
+const handleCloseCopy = () => {
+  data.targetYear=''
+  data.sourceYear=''
+  data.copyVisible = false
+}
+const copy = () => {
+  data.copyVisible = true
+}
+const onSubmitCopy = async () => {
+  if(data.isAdmin && !data.queryParams.companyId){
+    ElMessage.warning('请先选择单位')
+    return
+  }
+  if(!data.sourceYear){
+    ElMessage.warning('请先选择要复制的年份')
+    return
+  }
+  if(!data.targetYear){
+    ElMessage.warning('请选择目标年份')
+    return
+  }
+  ElMessageBox.confirm(
+      '该操作将覆盖目标年份的数据,是否继续?',
+      '提示',
+      {
+        confirmButtonText: '确定',
+        cancelButtonText: '取消',
+        type: 'warning',
+      })
+      .then( async() => {
+        const param = {
+          companyId: data.queryParams.companyId,
+          sourceYear: data.sourceYear,
+          targetYear: data.targetYear
+        }
+        const res = await copyManagementPlan(param);
+        if(res.code === 200){
+          ElMessage({
+            type: 'success',
+            message: res.data
+          });
+          await handleCloseCopy()
+          await getList();
+        }else{
+          ElMessage.warning(res.message)
+        }
+      }).catch(err => {
+  })
+}
 </script>
diff --git a/src/views/work/selfProblems/mngAudit/mngAuditReport/index.vue b/src/views/work/selfProblems/mngAudit/mngAuditReport/index.vue
index b8b2f81..0d15b14 100644
--- a/src/views/work/selfProblems/mngAudit/mngAuditReport/index.vue
+++ b/src/views/work/selfProblems/mngAudit/mngAuditReport/index.vue
@@ -21,9 +21,17 @@
             </el-option>
           </el-select>
         </el-form-item>
+        <el-form-item label="年份:" >
+          <el-date-picker
+              v-model="data.queryParams.year"
+              type="year"
+              value-format="YYYY"
+          />
+        </el-form-item>
         <el-form-item >
-          <el-button v-if="isAdmin" type="primary" @click="getList">查询</el-button>
-          <el-button v-if="isAdmin" type="primary" plain @click="reset">重置</el-button>
+          <el-button  type="primary" @click="getList">查询</el-button>
+          <el-button   plain @click="reset">重置</el-button>
+          <el-button  type="primary" plain @click="copy">复制</el-button>
         </el-form-item>
       </el-form>
     </div>
@@ -55,6 +63,49 @@
     />
 
     <edit-dialog ref="dialogRef" @getList=getList></edit-dialog>
+    <el-dialog
+        v-model="copyVisible"
+        width="500px"
+        :before-close="handleCloseCopy"
+        :close-on-press-escape="false"
+        :close-on-click-modal="false"
+    >
+      <div v-if="data.isAdmin">
+        <span style="display:block;margin-bottom: 8px">单位名称:</span>
+        <el-select
+            v-model="queryParams.companyId"
+            filterable
+            style="width: 100%;margin-bottom: 8px"
+        >
+          <el-option
+              v-for="item in data.companyList"
+              :key="item.id"
+              :label="item.name"
+              :value="item.id"
+          />
+        </el-select>
+      </div>
+      <span style="display:block;margin-bottom: 8px">将以下年份数据:</span>
+      <el-date-picker
+          v-model="data.sourceYear"
+          type="year"
+          value-format="YYYY"
+          style="margin-bottom: 8px;width: 100%;"
+          placeholder="请选择"
+      />
+      <span style="display:block;margin-bottom: 8px">复制到:</span>
+      <el-date-picker
+          v-model="data.targetYear"
+          type="year"
+          value-format="YYYY"
+          style="margin-bottom: 8px;width: 100%"
+          placeholder="请选择"
+      />
+      <div class="dialog-footer" style="display: flex;justify-content: right">
+        <el-button @click="handleCloseCopy" size="default">取 消</el-button>
+        <el-button type="primary"  @click="onSubmitCopy" size="default" v-preReClick>确认</el-button>
+      </div>
+    </el-dialog>
   </div>
 </template>
 
@@ -68,6 +119,7 @@
 import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
 import { renderAsync } from "docx-preview";
 import {
+  copyMeetReportInput,
   delMeetingsList,
   delSelectInconsistent, delSelectMeetings,
   getMeetingsList,
@@ -84,15 +136,19 @@
     pageNum: 1,
     pageSize: 10,
     companyId: null,
-    reviewType: 3
+    reviewType: 3,
+    year:''
   },
+  copyVisible: false,
+  targetYear:'',
+  sourceYear:'',
   total: 0,
   dataList: [],
   companyList: [],
   isAdmin: false
 });
 
-const { queryParams, total, dataList,companyList, isAdmin } = toRefs(data);
+const { queryParams, total, dataList,companyList, isAdmin,copyVisible } = toRefs(data);
 const userInfo = ref()
 onMounted(async ()=>{
   if(userStore.roles.includes('admin')){
@@ -102,12 +158,16 @@
     data.isAdmin = false
     data.queryParams.companyId = userStore.companyId
   }
+  await getNowYear()
   await getList()
 })
 
 onUnmounted(()=>{
 
 })
+const getNowYear = () =>{
+  data.queryParams.year = new Date().getFullYear().toString()
+}
 
 const getList = async () => {
   loading.value = true
@@ -188,13 +248,26 @@
 
 /** 重置新增的表单以及其他数据  */
 const reset= async()=> {
-  data.queryParams = {
-    pageNum: 1,
-    pageSize: 10,
-    companyId: null,
-    reviewType: 3
+  if(data.isAdmin){
+    data.queryParams = {
+      pageNum: 1,
+      pageSize: 10,
+      companyId: null,
+      reviewType: 3,
+      year:''
+    }
+    data.companyList = [];
+    await getCompanyList()
+  }else {
+    data.queryParams = {
+      companyId: data.queryParams.companyId,
+      pageNum: 1,
+      pageSize: 10,
+      reviewType: 3,
+      year: '',
+    }
   }
-  await getCompanyList()
+  await getNowYear()
   await getList()
 }
 const handleDelete = (val) => {
@@ -216,5 +289,55 @@
         }
       })
 }
+const handleCloseCopy = () => {
+  data.targetYear=''
+  data.sourceYear=''
+  data.copyVisible = false
+}
+const copy = () => {
+  data.copyVisible = true
+}
+const onSubmitCopy = async () => {
+  if(data.isAdmin && !data.queryParams.companyId){
+    ElMessage.warning('请先选择单位')
+    return
+  }
+  if(!data.sourceYear){
+    ElMessage.warning('请先选择要复制的年份')
+    return
+  }
+  if(!data.targetYear){
+    ElMessage.warning('请选择目标年份')
+    return
+  }
+  ElMessageBox.confirm(
+      '该操作将覆盖目标年份的数据,是否继续?',
+      '提示',
+      {
+        confirmButtonText: '确定',
+        cancelButtonText: '取消',
+        type: 'warning',
+      })
+      .then( async() => {
+        const param = {
+          companyId: data.queryParams.companyId,
+          sourceYear: data.sourceYear,
+          targetYear: data.targetYear,
+          reviewType: 3
+        }
+        const res = await copyMeetReportInput(param);
+        if(res.code === 200){
+          ElMessage({
+            type: 'success',
+            message: res.data
+          });
+          await handleCloseCopy()
+          await getList();
+        }else{
+          ElMessage.warning(res.message)
+        }
+      }).catch(err => {
+  })
+}
 
 </script>
diff --git a/src/views/work/selfProblems/plan/index.vue b/src/views/work/selfProblems/plan/index.vue
index d88cdc7..93a92dc 100644
--- a/src/views/work/selfProblems/plan/index.vue
+++ b/src/views/work/selfProblems/plan/index.vue
@@ -21,7 +21,14 @@
             </el-option>
           </el-select>
         </el-form-item>
-        <el-form-item v-if="data.isAdmin">
+        <el-form-item label="年份:" style="margin-left: 20px">
+          <el-date-picker
+              v-model="data.queryParams.year"
+              type="year"
+              value-format="YYYY"
+          />
+        </el-form-item>
+        <el-form-item>
           <el-button type="primary" style="margin-left: 30px" @click="searchClick">查询</el-button>
           <el-button plain @click="reset">重置</el-button>
         </el-form-item>
@@ -30,6 +37,7 @@
               type="primary"
               @click="exportData"
           >导出</el-button>
+          <el-button  type="primary" plain @click="copy">复制</el-button>
         </el-form-item>
 
       </el-form>
@@ -65,6 +73,49 @@
       />
     </div>
     <planDialog ref="noticeRef" @getList = "getList"></planDialog>
+    <el-dialog
+        v-model="copyVisible"
+        width="500px"
+        :before-close="handleCloseCopy"
+        :close-on-press-escape="false"
+        :close-on-click-modal="false"
+    >
+      <div v-if="data.isAdmin">
+        <span style="display:block;margin-bottom: 8px">单位名称:</span>
+        <el-select
+            v-model="queryParams.companyId"
+            filterable
+            style="width: 100%;margin-bottom: 8px"
+        >
+          <el-option
+              v-for="item in data.companyList"
+              :key="item.id"
+              :label="item.name"
+              :value="item.id"
+          />
+        </el-select>
+      </div>
+      <span style="display:block;margin-bottom: 8px">将以下年份数据:</span>
+      <el-date-picker
+          v-model="data.sourceYear"
+          type="year"
+          value-format="YYYY"
+          style="margin-bottom: 8px;width: 100%;"
+          placeholder="请选择"
+      />
+      <span style="display:block;margin-bottom: 8px">复制到:</span>
+      <el-date-picker
+          v-model="data.targetYear"
+          type="year"
+          value-format="YYYY"
+          style="margin-bottom: 8px;width: 100%"
+          placeholder="请选择"
+      />
+      <div class="dialog-footer" style="display: flex;justify-content: right">
+        <el-button @click="handleCloseCopy" size="default">取 消</el-button>
+        <el-button type="primary"  @click="onSubmitCopy" size="default" v-preReClick>确认</el-button>
+      </div>
+    </el-dialog>
   </div>
 </template>
 
@@ -76,7 +127,7 @@
 import Cookies from "js-cookie";
 import {generateWordDocument} from "@/utils/exportWord";
 import {delBasic, getBasic} from "@/api/companyInfo/basicInfo";
-import {delPlan, getPlanPage} from "@/api/selfProblems/plan";
+import {copyPlan, delPlan, getPlanPage} from "@/api/selfProblems/plan";
 import {getDept} from "@/api/qualityObjectives/object";
 
 const { proxy } = getCurrentInstance();
@@ -89,7 +140,11 @@
     pageNum: 1,
     pageSize: 10,
     companyId: null,
+    year:''
   },
+  copyVisible: false,
+  targetYear:'',
+  sourceYear:'',
   companyList: [],
   isAdmin: false,
   deptList: []
@@ -97,7 +152,7 @@
 const dataList = ref([]);
 const total = ref(0);
 
-const { queryParams } = toRefs(data);
+const { queryParams,copyVisible } = toRefs(data);
 
 onMounted(() => {
   const userInfo = JSON.parse(Cookies.get('userInfo'))
@@ -109,9 +164,13 @@
   }else {
     data.queryParams.companyId = userInfo.companyId
   }
+  getNowYear()
   getList();
   getDeptList()
 });
+const getNowYear = () =>{
+  data.queryParams.year = new Date().getFullYear().toString()
+}
 const getList = async () => {
   loading.value = true;
   const res = await getPlanPage(data.queryParams);
@@ -162,16 +221,27 @@
 }
 
 /** 重置新增的表单以及其他数据  */
-function reset() {
-  data.queryParams = {
-    companyId: '',
-    pageNum: 1,
-    pageSize: 10,
+const reset= async()=> {
+  if(data.isAdmin){
+    data.queryParams = {
+      pageNum: 1,
+      pageSize: 10,
+      companyId: null,
+      year:''
+    }
+    data.companyList = [];
+    await getCompanyList()
+  }else {
+    data.queryParams = {
+      companyId: data.queryParams.companyId,
+      pageNum: 1,
+      pageSize: 10,
+      year: '',
+    }
   }
   choosedData.value = []
-  data.companyList = [];
-  getList();
-  getCompanyList()
+  await getNowYear()
+  await getList()
 }
 const exportData = () => {
   if(choosedData.value && choosedData.value.length === 0){
@@ -258,6 +328,55 @@
         }
       })
 }
+const handleCloseCopy = () => {
+  data.targetYear=''
+  data.sourceYear=''
+  data.copyVisible = false
+}
+const copy = () => {
+  data.copyVisible = true
+}
+const onSubmitCopy = async () => {
+  if(data.isAdmin && !data.queryParams.companyId){
+    ElMessage.warning('请先选择单位')
+    return
+  }
+  if(!data.sourceYear){
+    ElMessage.warning('请先选择要复制的年份')
+    return
+  }
+  if(!data.targetYear){
+    ElMessage.warning('请选择目标年份')
+    return
+  }
+  ElMessageBox.confirm(
+      '该操作将覆盖目标年份的数据,是否继续?',
+      '提示',
+      {
+        confirmButtonText: '确定',
+        cancelButtonText: '取消',
+        type: 'warning',
+      })
+      .then( async() => {
+        const param = {
+          companyId: data.queryParams.companyId,
+          sourceYear: data.sourceYear,
+          targetYear: data.targetYear
+        }
+        const res = await copyPlan(param);
+        if(res.code === 200){
+          ElMessage({
+            type: 'success',
+            message: res.data
+          });
+          await handleCloseCopy()
+          await getList();
+        }else{
+          ElMessage.warning(res.message)
+        }
+      }).catch(err => {
+  })
+}
 
 </script>
 <style lang="scss">
diff --git a/src/views/work/selfProblems/scenario/index.vue b/src/views/work/selfProblems/scenario/index.vue
index 551ec09..c1e0fe8 100644
--- a/src/views/work/selfProblems/scenario/index.vue
+++ b/src/views/work/selfProblems/scenario/index.vue
@@ -21,17 +21,24 @@
             </el-option>
           </el-select>
         </el-form-item>
-        <el-form-item v-if="data.isAdmin">
+        <el-form-item label="年份:" style="margin-left: 20px">
+          <el-date-picker
+              v-model="data.queryParams.year"
+              type="year"
+              value-format="YYYY"
+          />
+        </el-form-item>
+        <el-form-item>
           <el-button type="primary" style="margin-left: 30px" @click="searchClick">查询</el-button>
           <el-button plain @click="reset">重置</el-button>
+
         </el-form-item>
-
-
         <el-form-item style="margin-left: 15px">
           <el-button
               type="primary"
               @click="exportData"
           >导出</el-button>
+          <el-button  type="primary" plain @click="copy">复制</el-button>
         </el-form-item>
 
       </el-form>
@@ -68,6 +75,49 @@
       />
     </div>
     <scenarioDialog ref="noticeRef" @getList = "getList"></scenarioDialog>
+    <el-dialog
+        v-model="copyVisible"
+        width="500px"
+        :before-close="handleCloseCopy"
+        :close-on-press-escape="false"
+        :close-on-click-modal="false"
+    >
+      <div v-if="data.isAdmin">
+        <span style="display:block;margin-bottom: 8px">单位名称:</span>
+        <el-select
+            v-model="queryParams.companyId"
+            filterable
+            style="width: 100%;margin-bottom: 8px"
+        >
+          <el-option
+              v-for="item in data.companyList"
+              :key="item.id"
+              :label="item.name"
+              :value="item.id"
+          />
+        </el-select>
+      </div>
+      <span style="display:block;margin-bottom: 8px">将以下年份数据:</span>
+      <el-date-picker
+          v-model="data.sourceYear"
+          type="year"
+          value-format="YYYY"
+          style="margin-bottom: 8px;width: 100%;"
+          placeholder="请选择"
+      />
+      <span style="display:block;margin-bottom: 8px">复制到:</span>
+      <el-date-picker
+          v-model="data.targetYear"
+          type="year"
+          value-format="YYYY"
+          style="margin-bottom: 8px;width: 100%"
+          placeholder="请选择"
+      />
+      <div class="dialog-footer" style="display: flex;justify-content: right">
+        <el-button @click="handleCloseCopy" size="default">取 消</el-button>
+        <el-button type="primary"  @click="onSubmitCopy" size="default" v-preReClick>确认</el-button>
+      </div>
+    </el-dialog>
   </div>
 </template>
 
@@ -79,7 +129,7 @@
 import Cookies from "js-cookie";
 import {generateWordDocument} from "@/utils/exportWord";
 import {delBasic, getBasic} from "@/api/companyInfo/basicInfo";
-import {delScenario, getScenarioPage} from "@/api/selfProblems/scenario";
+import {copyScenario, delScenario, getScenarioPage} from "@/api/selfProblems/scenario";
 
 const { proxy } = getCurrentInstance();
 const loading = ref(false);
@@ -91,14 +141,18 @@
     pageNum: 1,
     pageSize: 10,
     companyId: null,
+    year:''
   },
+  copyVisible: false,
+  targetYear:'',
+  sourceYear:'',
   companyList: [],
   isAdmin: false
 });
 const dataList = ref([]);
 const total = ref(0);
 
-const { queryParams } = toRefs(data);
+const { queryParams,copyVisible } = toRefs(data);
 
 onMounted(() => {
   const userInfo = JSON.parse(Cookies.get('userInfo'))
@@ -110,8 +164,12 @@
   }else {
     data.queryParams.companyId = userInfo.companyId
   }
+   getNowYear()
   getList();
 });
+const getNowYear = () =>{
+  data.queryParams.year = new Date().getFullYear().toString()
+}
 const getList = async () => {
   loading.value = true;
   const res = await getScenarioPage(data.queryParams);
@@ -155,16 +213,27 @@
 }
 
 /** 重置新增的表单以及其他数据  */
-function reset() {
-  data.queryParams = {
-    companyId: '',
-    pageNum: 1,
-    pageSize: 10,
+const reset= async()=> {
+  if(data.isAdmin){
+    data.queryParams = {
+      pageNum: 1,
+      pageSize: 10,
+      companyId: null,
+      year:''
+    }
+    data.companyList = [];
+    await getCompanyList()
+  }else {
+    data.queryParams = {
+      companyId: data.queryParams.companyId,
+      pageNum: 1,
+      pageSize: 10,
+      year: '',
+    }
   }
   choosedData.value = []
-  data.companyList = [];
-  getList();
-  getCompanyList()
+  await getNowYear()
+  await getList()
 }
 const exportData = () => {
   if(choosedData.value && choosedData.value.length === 0){
@@ -213,6 +282,55 @@
         }
       })
 }
+const handleCloseCopy = () => {
+  data.targetYear=''
+  data.sourceYear=''
+  data.copyVisible = false
+}
+const copy = () => {
+  data.copyVisible = true
+}
+const onSubmitCopy = async () => {
+  if(data.isAdmin && !data.queryParams.companyId){
+    ElMessage.warning('请先选择单位')
+    return
+  }
+  if(!data.sourceYear){
+    ElMessage.warning('请先选择要复制的年份')
+    return
+  }
+  if(!data.targetYear){
+    ElMessage.warning('请选择目标年份')
+    return
+  }
+  ElMessageBox.confirm(
+      '该操作将覆盖目标年份的数据,是否继续?',
+      '提示',
+      {
+        confirmButtonText: '确定',
+        cancelButtonText: '取消',
+        type: 'warning',
+      })
+      .then( async() => {
+        const param = {
+          companyId: data.queryParams.companyId,
+          sourceYear: data.sourceYear,
+          targetYear: data.targetYear
+        }
+        const res = await copyScenario(param);
+        if(res.code === 200){
+          ElMessage({
+            type: 'success',
+            message: res.data
+          });
+          await handleCloseCopy()
+          await getList();
+        }else{
+          ElMessage.warning(res.message)
+        }
+      }).catch(err => {
+  })
+}
 
 </script>
 <style lang="scss">

--
Gitblit v1.9.2