yangys
2025-08-16 f1b4ff31d9cb91fcda228a9781ddb8b3c792f8ba
src/views/basesetting/produceplan.vue
@@ -1,36 +1,48 @@
<!--
 * @Date: 2025-06-17 11:44:52
 * @LastEditors: gaoshp
 * @LastEditTime: 2025-08-13 22:22:49
 * @LastEditTime: 2025-08-13 22:30:53
 * @FilePath: /mdmweb/src/views/basesetting/produceplan.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" @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">
                <el-button type="primary" text size="default" v-if="permission.flow_model_update"
                    @click.stop="handleAction(scope.row, scope.index)">审批
                </el-button>
            </template> -->
        </avue-crud>
        <el-tabs v-model="activeName" type="card" class="demo-tabs" @tab-click="tabsClick">
            <el-tab-pane label="主制分工表" name="zhuzhi">
                <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" @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">
                        <el-button type="primary" text size="default" v-if="permission.flow_model_update"
                            @click.stop="handleAction(scope.row, scope.index)">审批
                        </el-button>
                    </template> -->
                </avue-crud>
            </el-tab-pane>
            <el-tab-pane label="勤哲分工表" name="qinzhe">
                <avue-crud :option="optionQz" :table-loading="loadingQz" :data="dataQz" v-model:page="pageQz"
                    @search-change="searchChangeQz" @search-reset="searchResetQz" @current-change="currentChangeQz"
                    @size-change="sizeChangeQz" @refresh-change="refreshChangeQz" @on-load="onLoadQz">
                </avue-crud>
            </el-tab-pane>
        </el-tabs>
        <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>
@@ -38,6 +50,7 @@
<script>
import { getList, remove,save,update } from '@/api/basesetting/produceplan';
import { getListQz } from '@/api/basesetting/qinzhefgb';
import { mapGetters } from 'vuex';
import { exportBlob } from '@/api/common';
import { getToken } from '@/utils/auth';
@@ -47,22 +60,12 @@
    name: 'ProducePlan',
    data() {
        return {
            activeName: "zhuzhi",
            // Define your data properties here
            excelOption: {
                submitBtn: false,
                emptyBtn: false,
                column: [
                    // {
                    //     label: '文件类型',
                    //     prop: 'fileType',
                    //     type: 'select',
                    //     span: 24,
                    //     clearable: false,
                    //     dicData: [
                    //         { label: '程序文件', value: 'program' },
                    //         { label: '其他文件', value: 'other' },
                    //     ],
                    // },
                    {
                        label: '文件导入',
                        prop: 'file',
@@ -76,7 +79,7 @@
                        data: {
                        },
                        tip: '',
                        action: '/blade-mdm/producedivision/download-template',
                        action: '/blade-mdm/producedivision/import-division',
                    },
                ],
            },
@@ -125,25 +128,13 @@
                        hide: true,
                        display: false,
                    },
                    // {
                    //     label: '序号',
                    //     prop: 'index',
                    //     type: 'index',
                    // },
               {
                        label: '图号',
                        prop: 'drawingNo',
                        type: 'input',
                        display: true,
                        span: 24,
                        rules: [{ required: true, message: '请输入图号', trigger: 'blur' }],
                    },
                    {
                        label: '专业组长',
                        prop: 'teamLeaderId',
                        type: 'select',
                        span: 24,
                        display: true,
                        filterable:true,
                        dicUrl: `/blade-mdm/flow/flow-user-list?deptId=0`,
                        props: {
                            label: 'name',
@@ -157,6 +148,7 @@
                        prop: 'programmerId',
                        type: 'select',
                        display: true,
                        filterable:true,
                        span: 24,
                        dicUrl: `/blade-mdm/flow/flow-user-list?deptId=0`,
                        props: {
@@ -171,6 +163,7 @@
                        prop: 'checkerId',
                        type: 'select',
                        display: true,
                        filterable:true,
                        span: 24,
                        dicUrl: `/blade-mdm/flow/flow-user-list?deptId=0`,
                        props: {
@@ -184,6 +177,7 @@
                        label: '审核',
                        prop: 'seniorId',
                        type: 'select',
                        filterable:true,
                        display: true,
                        span: 24,
                        dicUrl: `/blade-mdm/flow/flow-user-list?deptId=0`,
@@ -207,10 +201,67 @@
            },
            form: {}, // This will hold the form data
            query: {}, // This will hold the search query
            //勤哲页面数据
            dataQz:[],
            loadingQz:false,
            pageQz: {
                pageSize: 10,
                currentPage: 1,
                total: 0,
            },
            queryQz: {},
            optionQz: {
                // Define your Avue CRUD options here
                addBtn: false,
                editBtn: false,
                delBtn: false,
                columnBtn: false,
                tip: false,
                // simplePage: true,
                searchShow: true,
                searchMenuSpan: 6,
                // tree: true,
                border: true,
                index: true,
                menu: false,
                menuWidth: 320,
                dialogWidth: 500,
                dialogClickModal: false,
                column: [
                    {
                        label: '产品号',
                        prop: 'cph',
                        type: 'input',
                        display: true,
                        span: 24,
                    },
               {
                        label: '零组件号',
                        prop: 'ljh',
                        type: 'input',
                        search: true,
                        display: true,
                        span: 24,
                    },
                    {
                        label: '主管工艺',
                        prop: 'zggy',
                        type: 'input',
                        display: true,
                        span: 24
                    }
                ],
            },
        };
    },
    methods: {
        // Define your methods here
        tabsClick(tab,event) {
            //console.log('tab',tab)
            this.onLoad(this.page, this.query);
        },
        searchChange(params, done) {
            this.query = params;
            this.page.currentPage = 1;
@@ -252,10 +303,19 @@
            this.excelBox = true;
        },
        uploadAfter(res, done, loading, column) {
            window.console.log(column);
            this.onLoad(this.page);
            this.excelBox = false;
            done();
            //window.console.log(column);
            //console.log('res',res)
            if(res.success>0){
                //有成功的,关闭对话框
                this.excelBox = false;
                this.$message.success(res.message);
                this.onLoad(this.page);
                //done();
            }else{
                //0成功的,仅提示
                this.$message.success(res.message);
            }
        },
      downTemplateAction() {
            NProgress.start();
@@ -324,7 +384,40 @@
               window.console.log(error);
                }
            );
        }
        },
        sizeChangeQz() {
            this.pageQz.pageSize = pageSize;
        },
        searchChangeQz(params, done) {
            this.queryQz = params;
            this.pageQz.currentPage = 1;
            this.onLoadQz(this.pageQz, params);
            done();
        },
        searchResetQz() {
            this.queryQz = {};
            this.onLoadQz(this.pageQz);
        },
        currentChangeQz() {
            this.pageQz.currentPage = currentPage;
        },
        onLoadQz(page, params = {}) {
            const query = {
                ...this.queryQz,
                // category: params.category ? flowCategory(params.category) : null,
                mode: this.mode,
            };
            this.loadingQz = true;
            getListQz(page.currentPage, page.pageSize, Object.assign(params, query)).then(res => {
                const data = res.data.data;
                this.pageQz.total = data.total;
                this.dataQz = data.records;
                this.loadingQz = false;
            });
        },
        refreshChangeQz() {
            this.onLoadQz(this.pageQz, this.queryQz);
        },
    },
    mounted() {
        // Code to run when the component is mounted