fix
gaoshp
2025-08-13 c1e9856dfd1c75e0b34bf61af1c31d3b7517bce4
src/views/basesetting/produceplan.vue
@@ -1,7 +1,7 @@
<!--
 * @Date: 2025-06-17 11:44:52
 * @LastEditors: gaoshp
 * @LastEditTime: 2025-06-17 20:46:18
 * @LastEditTime: 2025-08-13 22:30:53
 * @FilePath: /mdmweb/src/views/basesetting/produceplan.vue
-->
<template>
@@ -11,8 +11,11 @@
            @size-change="sizeChange" @refresh-change="refreshChange" @on-load="onLoad" @row-del="rowDel"
            @row-save="save"
            @row-update="rowUpdate">
            <template #menu-left>
                <el-button type="primary" plain @click="importAction">导入
                </el-button>
            <el-button type="primary" plain @click="downTemplateAction">下载导入模板
                </el-button>
            </template>
            <!-- <template #menu="scope">
@@ -21,17 +24,56 @@
                </el-button>
            </template> -->
        </avue-crud>
        <el-dialog title="" append-to-body v-model="excelBox" width="555px">
            <avue-form :option="excelOption" v-model="excelForm" :upload-after="uploadAfter">
                <template #excelTemplate>
                    <el-button type="primary" @click="handleTemplate">
                        确定
                    </el-button>
                </template>
            </avue-form>
        </el-dialog>
    </basic-container>
</template>
<script>
import { getList, remove,save,update } from '@/api/basesetting/produceplan';
import { mapGetters } from 'vuex';
import { exportBlob } from '@/api/common';
import { getToken } from '@/utils/auth';
import NProgress from 'nprogress';
import { downloadXls } from '@/utils/util';
export default {
    name: 'ProducePlan',
    data() {
        return {
            // Define your data properties here
            excelOption: {
                submitBtn: false,
                emptyBtn: false,
                column: [
                    {
                        label: '文件导入',
                        prop: 'file',
                        type: 'upload',
                        drag: true,
                        loadText: '导入中,请稍后',
                        span: 24,
                        propsHttp: {
                            res: 'data',
                        },
                        data: {
                        },
                        tip: '',
                        action: '/blade-mdm/producedivision/download-template',
                    },
                ],
            },
            excelForm: {
                fileType: 'program',
                excelFile: [],
            },
            excelBox: false,
            option: {
                // Define your Avue CRUD options here
                addBtn: true,
@@ -51,17 +93,17 @@
                dialogWidth: 500,
                dialogClickModal: false,
                column: [
                    {
                        label: '程序名称',
                        prop: 'programName',
                        type: 'input',
                        search: false,
                        searchRange: true,
                        searchSpan: 8,
                        hide: true,
                        span: 24,
                        rules: [{ required: true, message: '请输入程序名称', trigger: 'blur' }],
                    },
                    // {
                    //     label: '程序名称',
                    //     prop: 'programName',
                    //     type: 'input',
                    //     search: false,
                    //     searchRange: true,
                    //     searchSpan: 8,
                    //     hide: true,
                    //     span: 24,
                    //     rules: [{ required: true, message: '请输入程序名称', trigger: 'blur' }],
                    // },
                    {
                        label: '人员名称',
                        prop: 'name',
@@ -77,6 +119,14 @@
                    //     prop: 'index',
                    //     type: 'index',
                    // },
               {
                        label: '图号',
                        prop: 'drawingNo',
                        type: 'input',
                        display: true,
                        span: 24,
                        rules: [{ required: true, message: '请输入图号', trigger: 'blur' }],
                    },
                    {
                        label: '专业组长',
                        prop: 'teamLeaderId',
@@ -132,6 +182,7 @@
                        },
                        rules: [{ required: true, message: '请输入审核(高师)', trigger: 'blur' }],
                    },
                    // Add more columns as needed
                ],
@@ -186,7 +237,23 @@
        },
        importAction() {
            // Logic for importing data
            this.$message.success('导入功能尚未实现');
            // this.$message.success('导入功能尚未实现');
            this.excelBox = true;
        },
        uploadAfter(res, done, loading, column) {
            window.console.log(column);
            this.onLoad(this.page);
            this.excelBox = false;
            done();
        },
      downTemplateAction() {
            NProgress.start();
            exportBlob(
                `/blade-mdm/producedivision/download-template`
            ).then(res => {
                downloadXls(res.data, `主制分工表导入模版.xlsx`);
                NProgress.done();
            });
        },
        rowDel(row) {
            this.$confirm('确定将选择数据删除?', {
@@ -226,17 +293,24 @@
        save (row, done, loading) {
            console.log('save', row);
            save(row).then(
                () => {
                this.onLoad(this.page);
                this.$message({
                    type: 'success',
                    message: '操作成功!',
                });
                done();
                (res) => {
               if(res.data.code !== 200) {
                  this.$message.error(res.data.msg);
                        loading()
                  //done();//关闭窗口
                  return;
               }
               this.onLoad(this.page);
               this.$message({
                  type: 'success',
                  message: '操作成功!',
               });
               done();
                },
                error => {
                loading();
                window.console.log(error);
               loading();
               window.console.log(error);
                }
            );
        }