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