From ac0d23872423d6815c2e996de198677dff619a78 Mon Sep 17 00:00:00 2001
From: gaoshp <291585735@qq.com>
Date: 星期一, 07 七月 2025 22:08:09 +0800
Subject: [PATCH] 导出DNC

---
 src/views/flowmgr/programexport.vue        |  186 ++++++++++++++++++++++++++++++++++++++++++++++
 src/api/flowmgr/programexport.js           |   18 ++++
 src/views/flow/components/TodolistLeft.vue |    4 
 3 files changed, 206 insertions(+), 2 deletions(-)

diff --git a/src/api/flowmgr/programexport.js b/src/api/flowmgr/programexport.js
new file mode 100644
index 0000000..27a90f2
--- /dev/null
+++ b/src/api/flowmgr/programexport.js
@@ -0,0 +1,18 @@
+/*
+ * @Date: 2025-06-12 22:38:05
+ * @LastEditors: gaoshp
+ * @LastEditTime: 2025-07-07 21:49:01
+ * @FilePath: /mdmweb/src/api/flowmgr/programexport.js
+ */
+import request from '@/axios';
+export const getList = (current, size, params) => {
+  return request({
+    url: '/blade-mdm/program/exchange/export-dnc-page',
+    method: 'get',
+    params: {
+      ...params,
+      current,
+      size,
+    },
+  })
+};
\ No newline at end of file
diff --git a/src/views/flow/components/TodolistLeft.vue b/src/views/flow/components/TodolistLeft.vue
index 3c58832..82f50cd 100644
--- a/src/views/flow/components/TodolistLeft.vue
+++ b/src/views/flow/components/TodolistLeft.vue
@@ -1,7 +1,7 @@
 <!--
  * @Date: 2025-07-01 20:45:15
  * @LastEditors: gaoshp
- * @LastEditTime: 2025-07-07 19:51:14
+ * @LastEditTime: 2025-07-07 20:00:11
  * @FilePath: /mdmweb/src/views/flow/components/TodolistLeft.vue
 -->
 <template>
@@ -163,7 +163,7 @@
 }
 .app-content {
     background-color: #fffee1;
-    padding: 10px;
+    padding: 10px 30px;
     min-height: 100px;
     overflow: auto;
     max-height: 400px;
diff --git a/src/views/flowmgr/programexport.vue b/src/views/flowmgr/programexport.vue
new file mode 100644
index 0000000..97ac594
--- /dev/null
+++ b/src/views/flowmgr/programexport.vue
@@ -0,0 +1,186 @@
+<!--
+ * @Date: 2025-06-20 20:48:17
+ * @LastEditors: gaoshp
+ * @LastEditTime: 2025-07-07 22:02:49
+ * @FilePath: /mdmweb/src/views/flowmgr/programexport.vue
+-->
+<template>
+    <basic-container>
+        <avue-crud :option="option" :table-loading="loading" :data="data" v-model:page="page" v-model="form" ref="crud" @current-change="currentChange"
+            @size-change="sizeChange" @refresh-change="refreshChange" @on-load="onLoad" @search-change="searchChange" @search-reset="searchReset">
+            <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)">澶勭悊鎰忚
+                </el-button> -->
+            </template>
+        </avue-crud>
+    </basic-container>
+</template>
+
+<script>
+    import { getList } from '@/api/flowmgr/programexport.js';
+    import NProgress from 'nprogress';
+    import { exportBlob } from '@/api/common';
+    import { getToken } from '@/utils/auth';
+    export default {
+    name: 'programexport',
+    data() {
+        return {
+            // Define your data properties here
+            page: {
+                pageSize: 10,
+                currentPage: 1,
+                total: 0,
+            },
+            form: {},
+            query: {},
+            loading: true,
+            data: [],
+            option: {
+                addBtn: false,
+                editBtn: false,
+                delBtn: false,
+                viewBtn: true,
+                columnBtn: false,
+                tip: false,
+                // simplePage: true,
+                searchShow: true,
+                searchMenuSpan: 6,
+                dialogWidth: '60%',
+                // tree: true,
+                border: true,
+                index: true,
+                selection: true,
+                // viewBtn: true,
+                menuWidth: 200,
+                menu: false,
+                dialogClickModal: false,
+                column: [
+                    {
+                        label: '鍥惧彿',
+                        prop: '',
+                    },
+                    {
+                        label: '鍥惧彿鐗堟',
+                        prop: '',
+                    },
+                    {
+                        label: '宸ュ簭鍚嶇О',
+                        prop: '',
+                    },
+                    {
+                        label: '绋嬪簭鍚嶇О',
+                        prop: 'name',
+                        search: true,
+                    },
+                    {
+                        label: '閫氳繃鏃堕棿',
+                        prop: 'updateTime',
+                    },
+                    {
+                        label: '瀹屾垚鏃堕棿',
+                        prop: 'passTime',
+                        search: true,
+                        hide: true,
+                        type: 'datetime',
+                        format: 'YYYY-MM-DD HH:mm:ss',
+                        valueFormat: 'YYYY-MM-DD HH:mm:ss',
+                        searchRange: true,
+                        searchSpan: 8,
+                    },
+                ],
+            }
+        };
+    },
+    methods: {
+        // Define your methods here
+        currentChange(currentPage) {
+            this.page.currentPage = currentPage;
+            // this.onLoad();
+        },
+        sizeChange(pageSize) {
+            this.page.pageSize = pageSize;
+        },
+        refreshChange() {
+            this.onLoad(this.page, this.query);
+        },
+        searchChange(params, done) {
+            let data = {}
+            this.query = params;
+            this.page.currentPage = 1;
+            console.log('searchChange', params);
+            params.passTimeBegin = params?.passTime?.[0] || '';
+            params.passTimeEnd = params?.passTime?.[1] || '';
+            console.log(params);
+            data = {
+                createTimeBegin: params.passTimeBegin,
+                createTimeEnd: params.passTimeEnd,
+                name: params.name || ''
+            }
+            this.query = data
+            this.onLoad(this.page, data);
+            done();
+        },
+        searchReset() {
+            this.query = {};
+            this.onLoad(this.page);
+        },
+        /** * 椤甸潰鍔犺浇鏃惰幏鍙栨暟鎹�
+         */
+        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;
+            });
+        },
+        exportExcel() {
+            this.$confirm('鏄惁瀵煎嚭?', '鎻愮ず', {
+                confirmButtonText: '纭畾',
+                cancelButtonText: '鍙栨秷',
+                type: 'warning',
+            }).then(() => {
+                NProgress.start();
+                exportBlob(
+                    `/blade-mdm/program/exchange/export-dnc?${this.website.tokenHeader}=${getToken()}`
+                ).then(res => {
+                    downloadXls(res.data, `瀵煎嚭鏈哄簥鍥炰紶绋嬪簭${this.$dayjs().format('YYYY-MM-DD HH:mm:ss')}.xlsx`);
+                    NProgress.done();
+                });
+            });
+        },
+    },
+    mounted() {
+
+    }
+}
+</script>
+
+<style lang="scss" scoped>
+
+</style>
\ No newline at end of file

--
Gitblit v1.9.3