From 87cdebbfaf95a872368dd45264dc825e98436422 Mon Sep 17 00:00:00 2001
From: gaoshp <291585735@qq.com>
Date: 星期日, 20 七月 2025 12:36:09 +0800
Subject: [PATCH] 新增页面
---
src/views/tasks/machinereturnfileop.vue | 21 +++
src/api/tasks/dncreturnfiles.js | 38 ++++++
src/views/tasks/dncreturnfiles.vue | 252 ++++++++++++++++++++++++++++++++++++++++++
3 files changed, 308 insertions(+), 3 deletions(-)
diff --git a/src/api/tasks/dncreturnfiles.js b/src/api/tasks/dncreturnfiles.js
new file mode 100644
index 0000000..05e86de
--- /dev/null
+++ b/src/api/tasks/dncreturnfiles.js
@@ -0,0 +1,38 @@
+/*
+ * @Date: 2025-06-12 22:38:05
+ * @LastEditors: gaoshp
+ * @LastEditTime: 2025-07-20 12:33:42
+ * @FilePath: /mdmweb/src/api/tasks/dncreturnfiles.js
+ */
+import request from '@/axios';
+export const getList = (current, size, params) => {
+ return request({
+ url: '/blade-mdm/program/file/page',
+ method: 'get',
+ params: {
+ ...params,
+ current,
+ size,
+ },
+ })
+};
+// 鎷掔粷
+export const reject = data => {
+ return request({
+ url: '/blade-mdm/program/file/reject',
+ method: 'post',
+ params: {
+ ...data,
+ },
+ })
+};
+// 鎺ュ彈
+export const accept = data => {
+ return request({
+ url: '/blade-mdm/program/file/accept',
+ method: 'post',
+ params: {
+ ...data,
+ },
+ })
+};
\ No newline at end of file
diff --git a/src/views/tasks/dncreturnfiles.vue b/src/views/tasks/dncreturnfiles.vue
new file mode 100644
index 0000000..f70e9dd
--- /dev/null
+++ b/src/views/tasks/dncreturnfiles.vue
@@ -0,0 +1,252 @@
+<!--
+ * @Date: 2025-06-18 09:17:09
+ * @LastEditors: gaoshp
+ * @LastEditTime: 2025-07-20 12:34:42
+ * @FilePath: /mdmweb/src/views/tasks/dncreturnfiles.vue
+-->
+<template>
+ <basic-container>
+ <avue-crud :option="option" :table-loading="loading" :data="data" v-model:page="page" v-model="form" ref="crud"
+ @search-change="searchChange" @search-reset="searchReset" @current-change="currentChange"
+ @size-change="sizeChange" @refresh-change="refreshChange" @on-load="onLoad" @selection-change="selectionChange">
+ <template #menu-left>
+ <el-button type="primary" plain @click="exportWebSite">瀵煎嚭鍥炰紶娑夊瘑缃�</el-button>
+ <el-button type="primary" plain @click="reassign">鎸傝浇杞﹀簥绋嬪簭搴�</el-button>
+ <el-button type="primary" plain @click="exportExcel">瀵煎嚭鍒癊XCEL</el-button>
+ </template>
+ <template #menu="scope">
+ <el-button type="primary" text size="default"
+ @click.stop="handleAction(scope.row, scope.index, 1)">鎺ュ彈
+ </el-button>
+ <el-button type="danger" text size="default"
+ @click.stop="handleAction(scope.row, scope.index, 0)">鎷掔粷
+ </el-button>
+ </template>
+ </avue-crud>
+ </basic-container>
+</template>
+
+<script>
+import { getList, reject, accept } from '@/api/tasks/dncreturnfiles.js';
+import { exportBlob } from '@/api/common';
+import { getToken } from '@/utils/auth';
+import NProgress from 'nprogress';
+import { downloadXls } from '@/utils/util';
+import 'nprogress/nprogress.css';
+export default {
+ name: 'MachineReturnFileOp',
+ data() {
+ return {
+ page: {
+ pageSize: 10,
+ currentPage: 1,
+ total: 0,
+ },
+ form: {},
+ query: {},
+ loading: true,
+ data: [],
+ option: {
+ addBtn: false,
+ editBtn: false,
+ delBtn: false,
+ columnBtn: false,
+ tip: false,
+ // simplePage: true,
+ searchShow: true,
+ searchMenuSpan: 6,
+ dialogWidth: '60%',
+ // tree: true,
+ border: true,
+ index: true,
+ selection: true,
+ viewBtn: false,
+ menuWidth: 200,
+ // menu: false,
+ dialogClickModal: false,
+ column: [
+ {
+ label: '纭鏃堕棿',
+ prop: 'confirmTime',
+ type: 'datetime',
+ format: 'YYYY-MM-DD HH:mm:ss',
+ valueFormat: 'YYYY-MM-DD HH:mm:ss',
+ search: true,
+ searchRange: true,
+ searchSpan: 8,
+ hide: true,
+ },
+
+ {
+ label: '绋嬪簭缂栧彿',
+ prop: 'code',
+ },
+ {
+ label: '鍥炰紶鏈哄簥',
+ prop: 'machineCode',
+ },
+
+ {
+ label: '鏂囦欢鍚嶇О',
+ prop: 'name'
+ },
+ {
+ label: '鏂囦欢鍥哄寲鐘舵��',
+ prop: 'isCured',
+ formatter: (val, value, label) => {
+ return `${val==0?'鏈浐鍖�':"宸插浐鍖�"}`;
+ },
+ },
+ {
+ label: '鏂囦欢鍒拌揪鏃堕棿',
+ prop: 'arrivedTime',
+ type: 'datetime',
+ format: 'YYYY-MM-DD HH:mm:ss',
+ valueFormat: 'YYYY-MM-DD HH:mm:ss',
+ }
+ ],
+ selectedList: [],
+ }
+ }
+ },
+ methods: {
+ handleAction (row, index, flag) {
+ // 澶勭悊鎺ュ彈鎴栨嫆缁濇搷浣�
+ let ids = [row.id].toString();
+ if(flag) {
+ accept({ ids }).then(() => {
+ this.$message.success(`鎿嶄綔鎴愬姛: ${row.name}`);
+ }).catch(() => {
+ this.$message.error(`鎿嶄綔澶辫触: ${row.name}`);
+ this.$refs.crud.refreshChange();
+ });
+ } else {
+ reject({ ids }).then(() => {
+ this.$message.success(`鎿嶄綔鎴愬姛: ${row.name}`);
+ }).catch(() => {
+ this.$message.error(`鎿嶄綔澶辫触: ${row.name}`);
+ this.$refs.crud.refreshChange();
+ });
+ }
+ },
+ selectionChange (list) {
+ this.selectedList = list;
+ },
+ exportWebSite() {
+ if (this.selectedList.length === 0) {
+ this.$message.warning('璇峰厛閫夋嫨闇�瑕佸鍑虹殑鏁版嵁');
+ return;
+ }
+ this.$confirm('鏄惁瀵煎嚭?', '鎻愮ず', {
+ confirmButtonText: '纭畾',
+ cancelButtonText: '鍙栨秷',
+ type: 'warning',
+ }).then(() => {
+ NProgress.start();
+ exportBlob(
+ `/blade-mdm/machineback/filehandle/export-to-inner`,
+ {
+ ids: this.selectedList.map(item => item.id).join(','),
+ }
+ ).then(res => {
+ downloadXls(res.data, `瀵煎嚭鍥炰紶娑夊瘑缃�${this.$dayjs().format('YYYY-MM-DD HH:mm:ss')}.xlsx`);
+ NProgress.done();
+ });
+ });
+ },
+ exportExcel() {
+ if (this.selectedList.length === 0) {
+ this.$message.warning('璇峰厛閫夋嫨闇�瑕佸鍑虹殑鏁版嵁');
+ return;
+ }
+ this.$confirm('鏄惁瀵煎嚭?', '鎻愮ず', {
+ confirmButtonText: '纭畾',
+ cancelButtonText: '鍙栨秷',
+ type: 'warning',
+ }).then(() => {
+ NProgress.start();
+ exportBlob(
+ `/blade-mdm/machineback/filehandle/export-excel?${this.website.tokenHeader}=${getToken()}`
+ ).then(res => {
+ downloadXls(res.data, `瀵煎嚭鏈哄簥鍥炰紶绋嬪簭${this.$dayjs().format('YYYY-MM-DD HH:mm:ss')}.xlsx`);
+ NProgress.done();
+ });
+ });
+ },
+ searchChange(params, done) {
+ let data = {}
+ this.query = params;
+ this.page.currentPage = 1;
+ console.log('searchChange', params);
+ params.confirmTimeBegin = params?.confirmTime?.[0] || '';
+ params.confirmTimeEnd = params?.confirmTime?.[1] || '';
+ console.log(params);
+ // data = {
+ // createTimeBegin: dayjs(params.createTimeBegin).isValid() ? dayjs(params.createTimeBegin).format('YYYY-MM-DD') : '',
+ // createTimeEnd: dayjs(params.createTimeEnd).isValid() ? dayjs(params.createTimeEnd).format('YYYY-MM-DD') : '',
+ // keyword: params.keyword || ''
+ // }
+ data = {
+ confirmTimeBegin: params.confirmTimeBegin,
+ confirmTimeEnd: params.confirmTimeEnd,
+ }
+ this.query = data
+ this.onLoad(this.page, data);
+ done();
+ },
+ searchReset() {
+ let data = {}
+ this.query = params;
+ this.page.currentPage = 1;
+ data = {
+ createTimeBegin: params.createTimeBegin,
+ createTimeEnd: params.createTimeEnd,
+ keyword: params.keyword || ''
+ }
+ this.onLoad(this.page, data);
+ done();
+ },
+ currentChange(currentPage) {
+ this.page.currentPage = currentPage;
+ // this.onLoad();
+ },
+ sizeChange(pageSize) {
+ this.page.pageSize = pageSize;
+ },
+ refreshChange() {
+ this.onLoad(this.page, this.query);
+ },
+ /** * 椤甸潰鍔犺浇鏃惰幏鍙栨暟鎹�
+ */
+ onLoad(page, params = {}) {
+ console.log('onLoad', page, params);
+ const query = {
+ ...this.query,
+ // category: params.category ? flowCategory(params.category) : null,
+ mode: this.mode,
+ };
+ try {
+ delete query.confirmTime; // 鍒犻櫎涓嶅繀瑕佺殑鏌ヨ鏉′欢
+ } catch (error) {
+ console.error('鏃ユ湡鏍煎紡鍖栭敊璇�', error);
+ }
+
+ this.loading = true;
+ getList(page.currentPage, page.pageSize, Object.assign(query, params)).then(res => {
+ const data = res.data.data;
+ this.page.total = data.total;
+ this.data = data.records;
+ this.loading = false;
+ }, () => {
+ this.data = [];
+ this.loading = false;
+ }).catch(err => {
+ this.data = [];
+ this.loading = false;
+ });
+ }
+ }
+};
+</script>
+
+<style lang="scss" scoped></style>
\ No newline at end of file
diff --git a/src/views/tasks/machinereturnfileop.vue b/src/views/tasks/machinereturnfileop.vue
index 5daf5d9..c066d5e 100644
--- a/src/views/tasks/machinereturnfileop.vue
+++ b/src/views/tasks/machinereturnfileop.vue
@@ -1,14 +1,14 @@
<!--
* @Date: 2025-06-18 09:17:09
* @LastEditors: gaoshp
- * @LastEditTime: 2025-06-20 20:58:07
+ * @LastEditTime: 2025-07-20 12:27:48
* @FilePath: /mdmweb/src/views/tasks/machinereturnfileop.vue
-->
<template>
<basic-container>
<avue-crud :option="option" :table-loading="loading" :data="data" v-model:page="page" v-model="form" ref="crud"
@search-change="searchChange" @search-reset="searchReset" @current-change="currentChange"
- @size-change="sizeChange" @refresh-change="refreshChange" @on-load="onLoad">
+ @size-change="sizeChange" @refresh-change="refreshChange" @on-load="onLoad" @selection-change="selectionChange">
<template #menu-left>
<el-button type="primary" plain @click="exportWebSite">瀵煎嚭鍥炰紶娑夊瘑缃�</el-button>
<el-button type="primary" plain @click="reassign">鎸傝浇杞﹀簥绋嬪簭搴�</el-button>
@@ -102,11 +102,19 @@
valueFormat: 'YYYY-MM-DD HH:mm:ss',
}
],
+ selectedList: [],
}
}
},
methods: {
+ selectionChange (list) {
+ this.selectedList = list;
+ },
exportWebSite() {
+ if (this.selectedList.length === 0) {
+ this.$message.warning('璇峰厛閫夋嫨闇�瑕佸鍑虹殑鏁版嵁');
+ return;
+ }
this.$confirm('鏄惁瀵煎嚭?', '鎻愮ず', {
confirmButtonText: '纭畾',
cancelButtonText: '鍙栨秷',
@@ -114,7 +122,10 @@
}).then(() => {
NProgress.start();
exportBlob(
- `/blade-mdm/machineback/filehandle/export-to-inner?${this.website.tokenHeader}=${getToken()}`
+ `/blade-mdm/machineback/filehandle/export-to-inner`,
+ {
+ ids: this.selectedList.map(item => item.id).join(','),
+ }
).then(res => {
downloadXls(res.data, `瀵煎嚭鍥炰紶娑夊瘑缃�${this.$dayjs().format('YYYY-MM-DD HH:mm:ss')}.xlsx`);
NProgress.done();
@@ -122,6 +133,10 @@
});
},
exportExcel() {
+ if (this.selectedList.length === 0) {
+ this.$message.warning('璇峰厛閫夋嫨闇�瑕佸鍑虹殑鏁版嵁');
+ return;
+ }
this.$confirm('鏄惁瀵煎嚭?', '鎻愮ず', {
confirmButtonText: '纭畾',
cancelButtonText: '鍙栨秷',
--
Gitblit v1.9.3