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