yangys
2025-09-22 b14bf62abb3480d95beee8314fcb08c0d893813b
src/views/tasks/machinereturnfileop.vue
@@ -1,25 +1,28 @@
<!--
 * @Date: 2025-06-18 09:17:09
 * @LastEditors: gaoshp
 * @LastEditTime: 2025-07-20 12:27:48
 * @LastEditTime: 2025-08-13 21:23:34
 * @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"
        <avue-crud :option="option" :search="query" :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" :disabled="this.selectedList.length==0" plain @click="exportWebSite">导出回传涉密网</el-button>
                <!--<el-button type="primary" plain @click="reassign">挂载车床程序库</el-button>-->
                <el-button type="primary" plain @click="exportExcel">导出到EXCEL</el-button>
                <el-button type="primary" :disabled="this.selectedList.length==0" plain @click="exportExcel">导出到EXCEL</el-button>
            </template>
            <template #menu="scope">
                <el-button type="primary" text size="default" v-if="permission.flow_model_update"
                    @click.stop="handleAction(scope.row, scope.index)">审批
                </el-button>
                <el-button type="primary" text size="default" @click.stop="showContent(scope.row)">查看</el-button>
                <el-button type="primary" text size="default" @click.stop="download(scope.row, scope.index)">下载</el-button>
            </template>
        </avue-crud>
        <el-dialog title="程序内容" append-to-body v-model="fileViewModel">
            <div v-html="appContent" class="app-content"></div>
        </el-dialog>
    </basic-container>
</template>
@@ -28,7 +31,7 @@
import { exportBlob } from '@/api/common';
import { getToken } from '@/utils/auth';
import NProgress from 'nprogress';
import { downloadXls } from '@/utils/util';
import { downloadXls,downloadFile } from '@/utils/util';
import 'nprogress/nprogress.css';
export default {
    name: 'MachineReturnFileOp',
@@ -40,77 +43,137 @@
                total: 0,
            },
            form: {},
            query: {},
            query: {status:1},
            loading: true,
            data: [],
            fileViewModel:false,
            appContent:'',
            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: true,
                menuWidth: 100,
                menu: false,
                menuWidth: 110,
                menu: true,
                dialogClickModal: false,
                column: [
                    
               {
                        label: '文件名称',
                        prop: 'name'
                        prop: 'name',
                        search:true,
                        searchSpan:4
                    },
                    {
                        label: '导出状态',
                        prop: 'status',
                        search:true,
                        type:'select',
                        searchSpan:4,
                        dicData:[
                            {
                                label: '未导出',
                                value:1
                            },
                            {
                                label: '已导出',
                                value:2
                            }
                        ]
                    },
                    {
                        label: '回传机床',
                        prop: 'machineCode',
                    },
                    {
                        label: '文件固化状态',
                        prop: 'isCured',
                        formatter: (val, value, label) => {
                            return `${val==0?'未固化':"已固化"}`;
                        },
                        label: '程序状态',
                        prop: 'programStatus',
                        render: ({ row,value }) => {
                            var txt = '未知';
                            switch(row.programStatus){
                                case 1:
                                txt = '试切';
                                break;
                                case 2:
                                txt = '固化';
                                break;
                                case 3:
                                txt = '偏离';
                                break;
                                default:
                                txt = '未知';
                            }
                            return txt;
                        }
                    },
                    {
                        label: '文件到达时间',
                        prop: 'arrivedTime',
                        prop: 'fileCreateTime',
                        type: 'datetime',
                        format: 'YYYY-MM-DD HH:mm:ss',
                        valueFormat: 'YYYY-MM-DD HH:mm:ss',
                    },
               {
                        label: '确认时间',
                        prop: 'determineTime',
                        prop: 'createTime',
                        type: 'datetime',
                        format: 'YYYY-MM-DD HH:mm:ss',
                        valueFormat: 'YYYY-MM-DD HH:mm:ss',
                        search: true,
                        searchRange: true,
                        searchSpan: 8,
                        searchSpan: 10,
                        hide: false,
                    }/*,
                    {
                        label: '接收x时间',
                        prop: 'determineTime',
                    },
               {
                        label: '导出时间',
                        prop: 'exportTime',
                        type: 'datetime',
                        format: 'YYYY-MM-DD HH:mm:ss',
                        valueFormat: 'YYYY-MM-DD HH:mm:ss',
                    }*/
                    }
                ],
                selectedList: [],
            }
            },
            selectedList: [],
        }
    },
    methods: {
        showContent(row) {
            this.fileViewModel = true;
            this.appContent = '';
            axios({
                url: '/blade-mdm/ossfile/file-content',
                method: 'get',
                params: {ossFileName: row.ossName}
            }).then(
                res => {
                    console.log(res)
                    if(res.data.code === 200) {
                        this.appContent = res.data.data;
                    } else {
                        this.appContent = '程序内容加载失败'
                    }
            });
        },
        download(row){
            exportBlob(
            `/blade-mdm/machinefile/filehandle/download-by-id?id=${row.id}&${this.website.tokenHeader}=${getToken()}`,
            ).then(res => {
                let name = res.headers['content-disposition'].split('filename=')[1]
                //console.log(res.headers['content-disposition'].split('filename=')[1]);
                name = decodeURI(name)
                downloadFile(res.data, `${name}`);
                NProgress.done();
            });
        },
        selectionChange (list) {
            this.selectedList = list;
        },
@@ -126,12 +189,13 @@
            }).then(() => {
                NProgress.start();
                exportBlob(
                    `/blade-mdm/machineback/filehandle/export-to-inner`,
                    `/blade-mdm/machinefile/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')}.zip`);
                    this.onLoad(this.page, {});
                    NProgress.done();
                });
            });
@@ -148,7 +212,7 @@
            }).then(() => {
                NProgress.start();
                exportBlob(
                    `/blade-mdm/machineback/filehandle/export-excel?${this.website.tokenHeader}=${getToken()}`
                    `/blade-mdm/machinefile/filehandle/export-excel?${this.website.tokenHeader}=${getToken()}`
                ).then(res => {
                    downloadXls(res.data, `机床回传程序列表${this.$dayjs().format('YYYY-MM-DD HH:mm:ss')}.xlsx`);
                    NProgress.done();
@@ -160,17 +224,14 @@
            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 || ''
            // }
            params.confirmTimeBegin = params?.determineTime?.[0] || '';
            params.confirmTimeEnd = params?.determineTime?.[1] || '';
            data = {
                confirmTimeBegin: params.confirmTimeBegin,
                confirmTimeEnd: params.confirmTimeEnd,
                name: params.name,
                status: this.query.status,
            }
            this.query = data
            this.onLoad(this.page, data);
@@ -181,8 +242,8 @@
            this.query = params;
            this.page.currentPage = 1;
            data = {
                createTimeBegin: params.createTimeBegin,
                createTimeEnd: params.createTimeEnd,
                createTimeBegin: params.confirmTimeBegin,
                createTimeEnd: params.confirmTimeEnd,
                keyword: params.keyword || ''
            }
            this.onLoad(this.page, data);
@@ -204,7 +265,6 @@
            console.log('onLoad', page, params);
            const query = {
                ...this.query,
                // category: params.category ? flowCategory(params.category) : null,
                mode: this.mode,
            };
            try {