yangys
2025-11-27 f97351a6f1fdc679f4956030d179dca843bbeb0c
src/views/basesetting/produceplan.vue
@@ -1,13 +1,13 @@
<!--
 * @Date: 2025-06-17 11:44:52
 * @LastEditors: gaoshp
 * @LastEditTime: 2025-08-13 22:30:53
 * @LastEditTime: 2025-09-05 17:57:29
 * @FilePath: /mdmweb/src/views/basesetting/produceplan.vue
-->
<template>
    <basic-container>
        <el-tabs v-model="activeName" type="card" class="demo-tabs" @tab-click="tabsClick">
            <el-tab-pane label="主制分工表" name="zhuzhi">
            <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"
@@ -28,9 +28,17 @@
                </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">
                    @size-change="sizeChangeQz" @refresh-change="refreshChangeQz" @on-load="onLoadQz" @row-del="rowDelQz" @row-update="rowUpdateQz">
                    <template #menu-left>
                        <el-button type="primary" plain @click="importActionQz">导入
                        </el-button>
                        <el-button type="primary" plain @click="downTemplateActionQz">下载导入模板
                        </el-button>
                    </template>
                </avue-crud>
            </el-tab-pane>
        </el-tabs>
@@ -45,12 +53,17 @@
                -->
            </avue-form>
        </el-dialog>
        <el-dialog title="" append-to-body v-model="excelBoxQz" width="555px">
            <avue-form :option="excelOptionQz" v-model="excelForm" :upload-after="uploadAfterQz">
            </avue-form>
        </el-dialog>
    </basic-container>
</template>
<script>
import { getList, remove,save,update } from '@/api/basesetting/produceplan';
import { getListQz } from '@/api/basesetting/qinzhefgb';
import { getListQz, removeQz,saveQz,updateQz } from '@/api/basesetting/qinzhefgb';
import { mapGetters } from 'vuex';
import { exportBlob } from '@/api/common';
import { getToken } from '@/utils/auth';
@@ -60,6 +73,7 @@
    name: 'ProducePlan',
    data() {
        return {
            getApproveList: [],
            activeName: "zhuzhi",
            // Define your data properties here
            excelOption: {
@@ -83,11 +97,33 @@
                    },
                ],
            },
            excelOptionQz: {
                submitBtn: false,
                emptyBtn: false,
                column: [
                    {
                        label: '文件导入',
                        prop: 'file',
                        type: 'upload',
                        drag: true,
                        loadText: '导入中,请稍后',
                        span: 24,
                        propsHttp: {
                            res: 'data',
                        },
                        data: {
                        },
                        tip: '',
                        action: '/blade-mdm/producedivision/import-qinzhe',
                    },
                ],
            },
            excelForm: {
                fileType: 'program',
                excelFile: [],
            },
            excelBox: false,
            excelBoxQz: false,
            option: {
                // Define your Avue CRUD options here
                addBtn: true,
@@ -95,29 +131,15 @@
                delBtn: true,
                columnBtn: false,
                tip: false,
                // simplePage: true,
                searchShow: true,
                searchMenuSpan: 6,
                // tree: true,
                searchEnter:true,
                border: true,
                index: true,
                // selection: true,
                // viewBtn: true,
                menuWidth: 320,
                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: 'name',
@@ -128,33 +150,7 @@
                        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',
                            value: 'id',
                        },
                        rules: [{ required: true, message: '请输入专业组长', trigger: 'blur' }],
                    },
                    {
                        label: '编制(工艺员)',
                        label: '编制',
@@ -163,7 +159,8 @@
                        display: true,
                        filterable:true,
                        span: 24,
                        dicUrl: `/blade-mdm/flow/flow-user-list?deptId=0`,
                        // dicUrl: `/blade-mdm/flow/flow-user-list?deptId=0`,
                        dicData: [],
                        props: {
                            label: 'name',
                            value: 'id',
@@ -178,12 +175,28 @@
                        display: true,
                        filterable:true,
                        span: 24,
                        dicUrl: `/blade-mdm/flow/flow-user-list?deptId=0`,
                        // dicUrl: `/blade-mdm/flow/flow-user-list?deptId=0`,
                        dicData: [],
                        props: {
                            label: 'name',
                            value: 'id',
                        },
                        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`,
                        dicData: [],
                        props: {
                            label: 'name',
                            value: 'id',
                        },
                        rules: [{ required: true, message: '请输入专业组长', trigger: 'blur' }],
                    },
                    {
                        label: '审核(高师)',
@@ -193,7 +206,8 @@
                        filterable:true,
                        display: true,
                        span: 24,
                        dicUrl: `/blade-mdm/flow/flow-user-list?deptId=0`,
                        // dicUrl: `/blade-mdm/flow/flow-user-list?deptId=0`,
                        dicData: [],
                        props: {
                            label: 'name',
                            value: 'id',
@@ -225,51 +239,87 @@
            },
            queryQz: {},
            optionQz: {
                // Define your Avue CRUD options here
                addBtn: false,
                editBtn: false,
                delBtn: false,
                editBtn: true,
                delBtn: true,
                columnBtn: false,
                tip: false,
                // simplePage: true,
                searchShow: true,
                searchMenuSpan: 6,
                // tree: true,
                searchEnter:true,
                border: true,
                index: true,
                menu: false,
                menuWidth: 320,
                dialogWidth: 500,
                dialogClickModal: false,
                column: [
                    {
                        label: '产品号',
                        label: '产品型号',
                        prop: 'cph',
                        type: 'input',
                        display: true,
                        span: 24,
                    },
               {
                    {
                        label: '零组件号',
                        prop: 'ljh',
                        type: 'input',
                        search: true,
                        display: true,
                        disabled:true,
                        span: 24,
                    },
                    {
                        label: '零组件名称',
                        prop: 'ljmc',
                        type: 'input',
                        search: false,
                        display: true,
                        disabled:true,
                        span: 24,
                    },
                    {
                        label: '主管工艺',
                        prop: 'zggy',
                        type: 'input',
                        search: true,
                        display: true,
                        span: 24
                    },
                    {
                        label: '数据来源',
                        prop: 'source',
                        type: 'input',
                        search: false,
                        display: false,
                        span: 24,
                  render: ({ row}) => {
                            console.log('val',row)
                            if(row.source == 'MDM'){
                                return "MDM"
                            }else{
                                return "勤哲"
                            }
                        }
                    }
                ],
            },
        };
    },
    methods: {
        getApprovers () {
            axios({
            url: '/blade-mdm/flow/flow-user-list?deptId=0',
            method: 'get',
            params: {}
          }).then(
            res => {
                this.option.column[1].dicData = res.data.data;
                this.option.column[2].dicData = res.data.data;
                this.option.column[3].dicData = res.data.data;
                this.option.column[4].dicData = res.data.data;
            });
        },
        // Define your methods here
        tabsClick(tab,event) {
            //console.log('tab',tab)
@@ -315,6 +365,11 @@
            // this.$message.success('导入功能尚未实现');
            this.excelBox = true;
        },
        importActionQz() {
            // Logic for importing data
            // this.$message.success('导入功能尚未实现');
            this.excelBoxQz = true;
        },
        uploadAfter(res, done, loading, column) {
            //window.console.log(column);
            //console.log('res',res)
@@ -330,12 +385,29 @@
            }
            
        },
        uploadAfterQz(res, done, loading, column) {
            //window.console.log(column);
           this.$message.success('导入完成');
           this.excelBoxQz = false;
            this.onLoadQz(this.pageQz);
        },
      downTemplateAction() {
            NProgress.start();
            exportBlob(
                `/blade-mdm/producedivision/download-template`
            ).then(res => {
                downloadXls(res.data, `主制分工表导入模版.xlsx`);
                NProgress.done();
            });
        },
        downTemplateActionQz() {
            NProgress.start();
            exportBlob(
                `/blade-mdm/producedivision/download-template-qz`
            ).then(res => {
                downloadXls(res.data, `勤哲分工表导入模版.xlsx`);
                NProgress.done();
            });
        },
@@ -356,6 +428,23 @@
                    });
                });
        },
        rowDelQz(row) {
            this.$confirm('确定将选择数据删除?', {
                confirmButtonText: '确定',
                cancelButtonText: '取消',
                type: 'warning',
            })
                .then(() => {
                    return removeQz({ljhs: [row.ljh].toString()});
                })
                .then(() => {
                    this.onLoadQz(this.pageQz);
                    this.$message({
                        type: 'success',
                        message: '操作成功!',
                    });
                });
        },
        rowUpdate (row, index, done, loading) {
            console.log('rowUpdate', row);
            
@@ -370,7 +459,27 @@
                    },
                    error => {
                      window.console.log(error);
                      loading();
                      //loading();
                      loadingZq();
                    }
                  );
        },
        rowUpdateQz (row, index, done, loading) {
            console.log('rowUpdateQz', row);
            updateQz(row).then(
                    () => {
                      this.onLoadQz(this.pageQz);
                      this.$message({
                        type: 'success',
                        message: '操作成功!',
                      });
                      done();
                    },
                    error => {
                      window.console.log(error);
                      //loading();
                      loadingZq();
                    }
                  );
        },
@@ -434,6 +543,7 @@
    },
    mounted() {
        // Code to run when the component is mounted
        this.getApprovers()
    },
}
</script>