You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1 line
80 KiB
1 line
80 KiB
{"remainingRequest":"D:\\mywork\\buycode\\code1\\springboot301400\\306\\aa\\admin\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!D:\\mywork\\buycode\\code1\\springboot301400\\306\\aa\\admin\\src\\views\\modules\\yonghu\\list.vue?vue&type=script&lang=js&","dependencies":[{"path":"D:\\mywork\\buycode\\code1\\springboot301400\\306\\aa\\admin\\src\\views\\modules\\yonghu\\list.vue","mtime":1649818275989},{"path":"D:\\mywork\\buycode\\code1\\springboot301400\\306\\aa\\admin\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1720078528573},{"path":"D:\\mywork\\buycode\\code1\\springboot301400\\306\\aa\\admin\\node_modules\\babel-loader\\lib\\index.js","mtime":1720078529261},{"path":"D:\\mywork\\buycode\\code1\\springboot301400\\306\\aa\\admin\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1720078528573},{"path":"D:\\mywork\\buycode\\code1\\springboot301400\\306\\aa\\admin\\node_modules\\vue-loader\\lib\\index.js","mtime":1720078529317}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64://
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//

import AddOrUpdate from "./add-or-update";
import styleJs from "../../../utils/style.js";
import utilsJs from "../../../utils/utils.js";

export default {
    data() {
    return {
        searchForm: {
            key: ""
        },
        sessionTable : "",//登录账户所在表名
        role : "",//权限
        userId:"",//当前登录人的id
//级联表下拉框搜索条件
//当前表下拉框搜索条件
          sexTypesSelectSearch : [],
        form:{
            id : null,
            username : null,
            password : null,
            yonghuName : null,
            yonghuPhoto : null,
            yonghuPhone : null,
            yonghuEmail : null,
            sexTypes : null,
            newMoney : null,
            yonghuDelete : null,
            createTime : null,
        },
        dataList: [],
        pageIndex: 1,
        pageSize: 10,
        totalPage: 0,
        dataListLoading: false,
        dataListSelections: [],
        showFlag: true,
        sfshVisiable: false,
        shForm: {},
        chartVisiable: false,
        echartsDate: new Date(),//echarts的时间查询字段
        addOrUpdateFlag:false,
        contents:null,
        layouts: '',

        //导出excel
        json_fields: {
            //级联表字段
            //本表字段
                 '账户': "username",
                 '用户姓名': "yonghuName",
                 '头像': "yonghuPhoto",
                 '手机号': "yonghuPhone",
                 '电子邮箱': "yonghuEmail",
                 '性别': "sexTypes",
                 '余额': "newMoney",
        },

        };
    },
    created() {
        this.contents = styleJs.listStyle();
        this.init();
        this.getDataList();
        this.contentStyleChange()
    },
    mounted() {
        //获取当前登录用户的信息
        this.sessionTable = this.$storage.get("sessionTable");
        this.role = this.$storage.get("role");
        this.userId = this.$storage.get("userId");

    },
    filters: {
        htmlfilter: function (val) {
            return val.replace(/<[^>]*>/g).replace(/undefined/g,'');
        }
    },
    components: {
        AddOrUpdate,
    },
    computed: {
    },
    methods: {
        chartDialog() {
            let _this = this;
            let params = {
                dateFormat :"%Y", //%Y-%m
                riqi :_this.echartsDate.getFullYear(),
                // riqi :_this.echartsDate.getFullYear()+"-"+(_this.echartsDate.getMonth() + 1 < 10 ? '0' + (_this.echartsDate.getMonth() + 1) : _this.echartsDate.getMonth() + 1),
                thisTable : {//当前表
                    tableName :'yonghu',//当前表表名,
                    sumColum : 'yonghu_number', //求和字段
                    date : 'insert_time',//分组日期字段
                    // string : 'yonghu_name',//分组字符串字段
                    // types : 'yonghu_types',//分组下拉框字段
                },
                // joinTable : {//级联表（可以不存在）
                //     tableName :'yonghu',//级联表表名
                //     // date : 'insert_time',//分组日期字段
                //     string : 'yonghu_name',//分组字符串字段
                //     // types : 'yonghu_types',//分组下拉框字段
                // }
            }
            _this.chartVisiable = true;
            _this.$nextTick(() => {
                var statistic = this.$echarts.init(document.getElementById("statistic"), 'macarons');
                this.$http({
                    url: "barSum",
                    method: "get",
                    params: params
                }).then(({data}) => {
                    if(data && data.code === 0){

                        //柱状图 求和 已成功使用
                        //start
                        let yAxisName = "数值";//根据查询数据具体改(单列要改,多列不改)
                        let xAxisName = "月份";
                        let series = [];//具体数据值
                        data.data.yAxis.forEach(function (item,index) {
                            let tempMap = {};
                            // tempMap.name= ["数值"];//根据查询数据具体改(单列要改,多列不改)
                            tempMap.name=data.data.legend[index];
                            tempMap.type='bar';
                            tempMap.data=item;
                            series.push(tempMap);

                        })

                        var option = {
                            tooltip: {
                                trigger: 'axis',
                                axisPointer: {
                                    type: 'cross',
                                    crossStyle: {
                                        color: '#999'
                                    }
                                }
                            },
                            toolbox: {
                                feature: {
                                    // dataView: { show: true, readOnly: false },  // 数据查看
                                    magicType: { show: true, type: ['line', 'bar'] },//切换图形展示方式
                                    // restore: { show: true }, // 刷新
                                    saveAsImage: { show: true }//保存
                                }
                            },
                            legend: {
                                data: data.data.legend//标题  可以点击导致某一列数据消失
                            },
                            xAxis: [
                                {
                                    type: 'category',
                                    name: xAxisName,
                                    data: data.data.xAxis,
                                    axisPointer: {
                                        type: 'shadow'
                                    }
                                }
                            ],
                            yAxis: [
                                {
                                    type: 'value',//不能改
                                    name: yAxisName,//y轴单位
                                    axisLabel: {
                                        formatter: '{value}' // 后缀
                                    }
                                }
                            ],
                            series:series//具体数据
                        };
                        // 使用刚指定的配置项和数据显示图表。
                        statistic.setOption(option,true);
                        //根据窗口的大小变动图表
                        window.onresize = function () {
                            statistic.resize();
                        };
                        //end
                    }else {
                        this.$message({
                            message: "报表未查询到数据",
                            type: "success",
                            duration: 1500,
                            onClose: () => {
                                this.search();
                            }
                        });
                    }
                });
            });
            ////饼状图
            //_this.chartVisiable = true;
            // this.$nextTick(()=>{
            //     var statistic = this.$echarts.init(document.getElementById("statistic"),'macarons');
            //     let params = {
            //         tableName: "yonghu",
            //         groupColumn: "yonghu_types",
            //     }
            //     this.$http({
            //         url: "newSelectGroupCount",
            //         method: "get",
            //         params: params
            //     }).then(({data}) => {
            //         if (data && data.code === 0) {
            //             let res = data.data;
            //             let xAxis = [];
            //             let yAxis = [];
            //             let pArray = []
            //             var option = {};
            //             for(let i=0;i<res.length;i++){
            //                 xAxis.push(res[i].name);
            //                 yAxis.push(res[i].value);
            //                 pArray.push({
            //                     value: res[i].value,
            //                     name: res[i].name
            //                 })
            //                 option = {
            //                     title: {
            //                         text: '保险合同类型统计',
            //                         left: 'center'
            //                     },
            //                     tooltip: {
            //                         trigger: 'item',
            //                         formatter: '{b} : {c} ({d}%)'
            //                     },
            //                     series: [
            //                         {
            //                             type: 'pie',
            //                             radius: '55%',
            //                             center: ['50%', '60%'],
            //                             data: pArray,
            //                             emphasis: {
            //                                 itemStyle: {
            //                                     shadowBlur: 10,
            //                                     shadowOffsetX: 0,
            //                                     shadowColor: 'rgba(0, 0, 0, 0.5)'
            //                                 }
            //                             }
            //                         }
            //                     ]
            //                 };
            //             }
            //                 statistic.setOption(option);
            //                 window.onresize = function() {
            //                     statistic.resize();
            //                 };
            //         }
            //     });
            // })
        },
        contentStyleChange() {
            this.contentSearchStyleChange()
            this.contentBtnAdAllStyleChange()
            this.contentSearchBtnStyleChange()
            this.contentTableBtnStyleChange()
            this.contentPageStyleChange()
        },
        contentSearchStyleChange() {
            this.$nextTick(() => {
                document.querySelectorAll('.form-content .slt .el-input__inner').forEach(el => {
                    let textAlign = 'left'
                    if(this.contents.inputFontPosition == 2)
                        textAlign = 'center'
                        if (this.contents.inputFontPosition == 3) textAlign = 'right'
                            el.style.textAlign = textAlign
                        el.style.height = this.contents.inputHeight
                        el.style.lineHeight = this.contents.inputHeight
                        el.style.color = this.contents.inputFontColor
                        el.style.fontSize = this.contents.inputFontSize
                        el.style.borderWidth = this.contents.inputBorderWidth
                        el.style.borderStyle = this.contents.inputBorderStyle
                        el.style.borderColor = this.contents.inputBorderColor
                        el.style.borderRadius = this.contents.inputBorderRadius
                        el.style.backgroundColor = this.contents.inputBgColor
                })
                if (this.contents.inputTitle) {
                    document.querySelectorAll('.form-content .slt .el-form-item__label').forEach(el => {
                        el.style.color = this.contents.inputTitleColor
                        el.style.fontSize = this.contents.inputTitleSize
                        el.style.lineHeight = this.contents.inputHeight
                    })
                }
                setTimeout(() => {
                    document.querySelectorAll('.form-content .slt .el-input__prefix').forEach(el => {
                        el.style.color = this.contents.inputIconColor
                        el.style.lineHeight = this.contents.inputHeight
                    })
                    document.querySelectorAll('.form-content .slt .el-input__suffix').forEach(el => {
                        el.style.color = this.contents.inputIconColor
                        el.style.lineHeight = this.contents.inputHeight
                    })
                    document.querySelectorAll('.form-content .slt .el-input__icon').forEach(el => {
                        el.style.lineHeight = this.contents.inputHeight
                    })
                }, 10 )
            })
        },
        // 搜索按钮
        contentSearchBtnStyleChange() {
            this.$nextTick(() => {
                document.querySelectorAll('.form-content .slt .el-button--success').forEach(el => {
                    el.style.height = this.contents.searchBtnHeight
                    el.style.color = this.contents.searchBtnFontColor
                    el.style.fontSize = this.contents.searchBtnFontSize
                    el.style.borderWidth = this.contents.searchBtnBorderWidth
                    el.style.borderStyle = this.contents.searchBtnBorderStyle
                    el.style.borderColor = this.contents.searchBtnBorderColor
                    el.style.borderRadius = this.contents.searchBtnBorderRadius
                    el.style.backgroundColor = this.contents.searchBtnBgColor
                })
            })
        },
        // 新增、批量删除
        contentBtnAdAllStyleChange() {
            this.$nextTick(() => {
                document.querySelectorAll('.form-content .ad .el-button--success').forEach(el => {
                    el.style.height = this.contents.btnAdAllHeight
                    el.style.color = this.contents.btnAdAllAddFontColor
                    el.style.fontSize = this.contents.btnAdAllFontSize
                    el.style.borderWidth = this.contents.btnAdAllBorderWidth
                    el.style.borderStyle = this.contents.btnAdAllBorderStyle
                    el.style.borderColor = this.contents.btnAdAllBorderColor
                    el.style.borderRadius = this.contents.btnAdAllBorderRadius
                    el.style.backgroundColor = this.contents.btnAdAllAddBgColor
                })
                document.querySelectorAll('.form-content .ad .el-button--danger').forEach(el => {
                    el.style.height = this.contents.btnAdAllHeight
                    el.style.color = this.contents.btnAdAllDelFontColor
                    el.style.fontSize = this.contents.btnAdAllFontSize
                    el.style.borderWidth = this.contents.btnAdAllBorderWidth
                    el.style.borderStyle = this.contents.btnAdAllBorderStyle
                    el.style.borderColor = this.contents.btnAdAllBorderColor
                    el.style.borderRadius = this.contents.btnAdAllBorderRadius
                    el.style.backgroundColor = this.contents.btnAdAllDelBgColor
                })
                document.querySelectorAll('.form-content .ad .el-button--warning').forEach(el => {
                    el.style.height = this.contents.btnAdAllHeight
                    el.style.color = this.contents.btnAdAllWarnFontColor
                    el.style.fontSize = this.contents.btnAdAllFontSize
                    el.style.borderWidth = this.contents.btnAdAllBorderWidth
                    el.style.borderStyle = this.contents.btnAdAllBorderStyle
                    el.style.borderColor = this.contents.btnAdAllBorderColor
                    el.style.borderRadius = this.contents.btnAdAllBorderRadius
                    el.style.backgroundColor = this.contents.btnAdAllWarnBgColor
                })
            })
        },
        // 表格
        rowStyle({row, rowIndex}) {
            if (rowIndex % 2 == 1) {
                if (this.contents.tableStripe) {
                    return {color: this.contents.tableStripeFontColor}
                }
            } else {
                return ''
            }
        },
        cellStyle({row, rowIndex}) {
            if (rowIndex % 2 == 1) {
                if (this.contents.tableStripe) {
                    return {backgroundColor: this.contents.tableStripeBgColor}
                }
            } else {
                return ''
            }
        },
        headerRowStyle({row, rowIndex}) {
            return {color: this.contents.tableHeaderFontColor}
        },
        headerCellStyle({row, rowIndex}) {
            return {backgroundColor: this.contents.tableHeaderBgColor}
        },
        // 表格按钮
        contentTableBtnStyleChange() {
            // this.$nextTick(()=>{
            //   setTimeout(()=>{
            //     document.querySelectorAll('.table-content .tables .el-table__body .el-button--success').forEach(el=>{
            //       el.style.height = this.contents.tableBtnHeight
            //       el.style.color = this.contents.tableBtnDetailFontColor
            //       el.style.fontSize = this.contents.tableBtnFontSize
            //       el.style.borderWidth = this.contents.tableBtnBorderWidth
            //       el.style.borderStyle = this.contents.tableBtnBorderStyle
            //       el.style.borderColor = this.contents.tableBtnBorderColor
            //       el.style.borderRadius = this.contents.tableBtnBorderRadius
            //       el.style.backgroundColor = this.contents.tableBtnDetailBgColor
            //     })
            //     document.querySelectorAll('.table-content .tables .el-table__body .el-button--primary').forEach(el=>{
            //       el.style.height = this.contents.tableBtnHeight
            //       el.style.color = this.contents.tableBtnEditFontColor
            //       el.style.fontSize = this.contents.tableBtnFontSize
            //       el.style.borderWidth = this.contents.tableBtnBorderWidth
            //       el.style.borderStyle = this.contents.tableBtnBorderStyle
            //       el.style.borderColor = this.contents.tableBtnBorderColor
            //       el.style.borderRadius = this.contents.tableBtnBorderRadius
            //       el.style.backgroundColor = this.contents.tableBtnEditBgColor
            //     })
            //     document.querySelectorAll('.table-content .tables .el-table__body .el-button--danger').forEach(el=>{
            //       el.style.height = this.contents.tableBtnHeight
            //       el.style.color = this.contents.tableBtnDelFontColor
            //       el.style.fontSize = this.contents.tableBtnFontSize
            //       el.style.borderWidth = this.contents.tableBtnBorderWidth
            //       el.style.borderStyle = this.contents.tableBtnBorderStyle
            //       el.style.borderColor = this.contents.tableBtnBorderColor
            //       el.style.borderRadius = this.contents.tableBtnBorderRadius
            //       el.style.backgroundColor = this.contents.tableBtnDelBgColor
            //     })

            //   }, 50)
            // })
        },
        // 分页
        contentPageStyleChange() {
            let arr = []
            if (this.contents.pageTotal) arr.push('total')
            if (this.contents.pageSizes) arr.push('sizes')
            if (this.contents.pagePrevNext) {
                arr.push('prev')
                if (this.contents.pagePager) arr.push('pager')
                arr.push('next')
            }
            if (this.contents.pageJumper) arr.push('jumper')
            this.layouts = arr.join()
            this.contents.pageEachNum = 10
        },

        init() {
        },
        search() {
            this.pageIndex = 1;
            this.getDataList();
        },
        // 获取数据列表
        getDataList() {
            this.dataListLoading = true;
            let params = {
                page: this.pageIndex,
                limit: this.pageSize,
                sort: 'id',
            }

                             
            if (this.searchForm.yonghuName!= '' && this.searchForm.yonghuName!= undefined) {
                params['yonghuName'] = '%' + this.searchForm.yonghuName + '%'
            }
                             
            if (this.searchForm.sexTypes!= '' && this.searchForm.sexTypes!= undefined) {
                params['sexTypes'] = this.searchForm.sexTypes
            }
                    
            params['yonghuDelete'] = 1// 逻辑删除字段 1 未删除 2 删除


            this.$http({
                url: "yonghu/page",
                method: "get",
                params: params
            }).then(({data}) => {
                if(data && data.code === 0){
                    this.dataList = data.data.list;
                    this.totalPage = data.data.total;
                }else{
                    this.dataList = [];
                    this.totalPage = 0;
                }
                this.dataListLoading = false;
            });

            //查询级联表搜索条件所有列表
            //查询当前表搜索条件所有列表
            //填充下拉框选项
            this.$http({
                url: "dictionary/page?dicCode=sex_types&page=1&limit=100",
                method: "get",
            }).then(({data}) => {
                if(data && data.code === 0){
                    this.sexTypesSelectSearch = data.data.list;
                }
            });
        },
        //每页数
        sizeChangeHandle(val) {
            this.pageSize = val;
            this.pageIndex = 1;
            this.getDataList();
        },
        // 当前页
        currentChangeHandle(val) {
            this.pageIndex = val;
            this.getDataList();
        },
        // 多选
        selectionChangeHandler(val) {
            this.dataListSelections = val;
        },
        // 添加/修改
        addOrUpdateHandler(id, type) {
            this.showFlag = false;
            this.addOrUpdateFlag = true;
            this.crossAddOrUpdateFlag = false;
            if (type != 'info') {
                type = 'else';
            }
            this.$nextTick(() => {
                this.$refs.addOrUpdate.init(id, type);
            });
        },
        // 下载
        download(file) {
            window.open(" ${file} ")
        },
        // 删除
        deleteHandler(id) {
            var ids = id ? [Number(id)] : this.dataListSelections.map(item => {
                return Number(item.id);
            });

            this.$confirm(`确定进行[${id ? "删除" : "批量删除"}]操作?`, "提示", {
                confirmButtonText: "确定",
                cancelButtonText: "取消",
                type: "warning"
            }).then(() => {
                this.$http({
                    url: "yonghu/delete",
                    method: "post",
                    data: ids
                }).then(({data}) => {
                    if(data && data.code === 0){
                        this.$message({
                            message: "操作成功",
                            type: "success",
                            duration: 1500,
                            onClose: () => {
                                this.search();
                            }
                        });
                    }else{
                        this.$message.error(data.msg);
                    }
                });
            });
        },
        resetPassword(id) {
            let _this = this;
            //重置密码
            this.$http({
                url: "yonghu/resetPassword?id=" + id,
                method: "get",
                // id:id
            }).then(({data}) => {
                if(data && data.code === 0){
                    _this.$message({
                        message: '重置成功,密码已重置为123456',
                        type: 'success'
                    });
                }
            });
        },
        // 导入功能上传文件成功后调用导入方法
        yonghuUploadSuccess(data){
            let _this = this;
            _this.$http({
                url: "yonghu/batchInsert?fileName=" + data.file,
                method: "get"
            }).then(({data}) => {
                if(data && data.code === 0){
                    _this.$message({
                        message: "导入用户数据成功",
                        type: "success",
                        duration: 1500,
                        onClose: () => {
                            _this.search();
                        }
                    });
                }else{
                    _this.$message.error(data.msg);
                }
            });

        },
        // 导入功能上传文件失败后调用导入方法
        yonghuUploadError(data){
            this.$message.error('上传失败');
        },
    }
};
"},{"version":3,"sources":["list.vue"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAgOA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA","file":"list.vue","sourceRoot":"src/views/modules/yonghu","sourcesContent":["<template>\r\n <div class=\"main-content\">\r\n\r\n <!-- 条件查询 -->\r\n <div v-if=\"showFlag\">\r\n <el-form :inline=\"true\" :model=\"searchForm\" class=\"form-content\">\r\n <el-row :gutter=\"20\" class=\"slt\" :style=\"{justifyContent:contents.searchBoxPosition=='1'?'flex-start':contents.searchBoxPosition=='2'?'center':'flex-end'}\">\r\n \r\n <el-form-item :label=\"contents.inputTitle == 1 ? '用户姓名' : ''\">\r\n <el-input prefix-icon=\"el-icon-search\" v-model=\"searchForm.yonghuName\" placeholder=\"用户姓名\" clearable></el-input>\r\n </el-form-item>\r\n \r\n <el-form-item :label=\"contents.inputTitle == 1 ? '性别' : ''\">\r\n <el-select v-model=\"searchForm.sexTypes\" placeholder=\"请选择性别\">\r\n <el-option label=\"=-请选择-=\" value=\"\"></el-option>\r\n <el-option\r\n v-for=\"(item,index) in sexTypesSelectSearch\"\r\n v-bind:key=\"index\"\r\n :label=\"item.indexName\"\r\n :value=\"item.codeIndex\">\r\n <!--lable是要展示的名称-->\r\n <!--value是值-->\r\n </el-option>\r\n </el-select>\r\n </el-form-item>\r\n\r\n \r\n\r\n\r\n <el-form-item>\r\n <el-button type=\"success\" @click=\"search()\">查询<i class=\"el-icon-search el-icon--right\"/></el-button>\r\n </el-form-item>\r\n </el-row>\r\n <el-row class=\"ad\" :style=\"{justifyContent:contents.btnAdAllBoxPosition=='1'?'flex-start':contents.btnAdAllBoxPosition=='2'?'center':'flex-end'}\">\r\n <el-form-item>\r\n <el-button\r\n v-if=\"isAuth('yonghu','新增')\"\r\n type=\"success\"\r\n icon=\"el-icon-plus\"\r\n @click=\"addOrUpdateHandler()\"\r\n >新增</el-button>\r\n \r\n <el-button\r\n v-if=\"isAuth('yonghu','删除')\"\r\n :disabled=\"dataListSelections.length <= 0\"\r\n type=\"danger\"\r\n icon=\"el-icon-delete\"\r\n @click=\"deleteHandler()\"\r\n >删除</el-button>\r\n \r\n <el-button\r\n v-if=\"isAuth('yonghu','报表')\"\r\n type=\"success\"\r\n icon=\"el-icon-pie-chart\"\r\n @click=\"chartDialog()\"\r\n >报表</el-button>\r\n \r\n <a style=\"text-decoration:none\" class=\"el-button el-button--success\"\r\n v-if=\"isAuth('yonghu','导入导出')\"\r\n icon=\"el-icon-download\"\r\n href=\"http://localhost:8080/minsuguanliw/upload/yonghuMuBan.xls\"\r\n >批量导入用户数据模板</a>\r\n \r\n <el-upload\r\n v-if=\"isAuth('yonghu','导入导出')\"\r\n style=\"display: inline-block\"\r\n action=\"minsuguanliw/file/upload\"\r\n :on-success=\"yonghuUploadSuccess\"\r\n :on-error=\"yonghuUploadError\"\r\n :show-file-list = false>\r\n <el-button\r\n v-if=\"isAuth('yonghu','导入导出')\"\r\n type=\"success\"\r\n icon=\"el-icon-upload2\"\r\n >批量导入用户数据</el-button>\r\n </el-upload>\r\n \r\n <!-- 导出excel -->\r\n <download-excel v-if=\"isAuth('yonghu','导入导出')\" style=\"display: inline-block\" class = \"export-excel-wrapper\" :data = \"dataList\" :fields = \"json_fields\" name = \"yonghu.xls\">\r\n <!-- 导出excel -->\r\n <el-button\r\n type=\"success\"\r\n icon=\"el-icon-download\"\r\n >导出</el-button>\r\n </download-excel>\r\n \r\n </el-form-item>\r\n </el-row>\r\n </el-form>\r\n <div class=\"table-content\">\r\n <el-table class=\"tables\" :size=\"contents.tableSize\" :show-header=\"contents.tableShowHeader\"\r\n :header-row-style=\"headerRowStyle\" :header-cell-style=\"headerCellStyle\"\r\n :border=\"contents.tableBorder\"\r\n :fit=\"contents.tableFit\"\r\n :stripe=\"contents.tableStripe\"\r\n :row-style=\"rowStyle\"\r\n :cell-style=\"cellStyle\"\r\n :style=\"{width: '100%',fontSize:contents.tableContentFontSize,color:contents.tableContentFontColor}\"\r\n v-if=\"isAuth('yonghu','查看')\"\r\n :data=\"dataList\"\r\n v-loading=\"dataListLoading\"\r\n @selection-change=\"selectionChangeHandler\">\r\n <el-table-column v-if=\"contents.tableSelection\"\r\n type=\"selection\"\r\n header-align=\"center\"\r\n align=\"center\"\r\n width=\"50\">\r\n </el-table-column>\r\n <el-table-column label=\"索引\" v-if=\"contents.tableIndex\" type=\"index\" width=\"50\" />\r\n\r\n <el-table-column :sortable=\"contents.tableSortable\" :align=\"contents.tableAlign\"\r\n prop=\"username\"\r\n header-align=\"center\"\r\n label=\"账户\">\r\n <template slot-scope=\"scope\">\r\n {{scope.row.username}}\r\n </template>\r\n </el-table-column>\r\n\r\n <el-table-column :sortable=\"contents.tableSortable\" :align=\"contents.tableAlign\"\r\n prop=\"yonghuName\"\r\n header-align=\"center\"\r\n label=\"用户姓名\">\r\n <template slot-scope=\"scope\">\r\n {{scope.row.yonghuName}}\r\n </template>\r\n </el-table-column>\r\n <el-table-column :sortable=\"contents.tableSortable\" :align=\"contents.tableAlign\" prop=\"yonghuPhoto\"\r\n header-align=\"center\"\r\n width=\"200\"\r\n label=\"头像\">\r\n <template slot-scope=\"scope\">\r\n <div v-if=\"scope.row.yonghuPhoto\">\r\n <img :src=\"scope.row.yonghuPhoto\" width=\"100\" height=\"100\">\r\n </div>\r\n <div v-else>无图片</div>\r\n </template>\r\n </el-table-column>\r\n\r\n <el-table-column :sortable=\"contents.tableSortable\" :align=\"contents.tableAlign\"\r\n prop=\"yonghuPhone\"\r\n header-align=\"center\"\r\n label=\"手机号\">\r\n <template slot-scope=\"scope\">\r\n {{scope.row.yonghuPhone}}\r\n </template>\r\n </el-table-column>\r\n\r\n <el-table-column :sortable=\"contents.tableSortable\" :align=\"contents.tableAlign\"\r\n prop=\"yonghuEmail\"\r\n header-align=\"center\"\r\n label=\"电子邮箱\">\r\n <template slot-scope=\"scope\">\r\n {{scope.row.yonghuEmail}}\r\n </template>\r\n </el-table-column>\r\n <el-table-column :sortable=\"contents.tableSortable\" :align=\"contents.tableAlign\"\r\n prop=\"sexTypes\"\r\n header-align=\"center\"\r\n label=\"性别\">\r\n <template slot-scope=\"scope\">\r\n {{scope.row.sexValue}}\r\n </template>\r\n </el-table-column>\r\n\r\n <el-table-column :sortable=\"contents.tableSortable\" :align=\"contents.tableAlign\"\r\n prop=\"newMoney\"\r\n header-align=\"center\"\r\n label=\"余额\">\r\n <template slot-scope=\"scope\">\r\n {{scope.row.newMoney}}\r\n </template>\r\n </el-table-column>\r\n\r\n <el-table-column width=\"300\" :align=\"contents.tableAlign\"\r\n header-align=\"center\"\r\n label=\"操作\">\r\n <template slot-scope=\"scope\">\r\n <el-button v-if=\"isAuth('yonghu','查看')\" type=\"success\" icon=\"el-icon-tickets\" size=\"mini\" @click=\"addOrUpdateHandler(scope.row.id,'info')\">详情</el-button>\r\n <el-button v-if=\"isAuth('yonghu','修改')\" type=\"primary\" icon=\"el-icon-edit\" size=\"mini\" @click=\"addOrUpdateHandler(scope.row.id)\">修改</el-button>\r\n\r\n <el-button v-if=\"isAuth('yonghu','删除')\" type=\"danger\" icon=\"el-icon-delete\" size=\"mini\" @click=\"deleteHandler(scope.row.id)\">删除</el-button>\r\n\r\n <el-button v-if=\"isAuth('yonghu','修改')\" type=\"success\" icon=\"el-icon-tickets\" size=\"mini\" @click=\"resetPassword(scope.row.id)\">重置密码</el-button>\r\n </template>\r\n </el-table-column>\r\n </el-table>\r\n <el-pagination\r\n clsss=\"pages\"\r\n :layout=\"layouts\"\r\n @size-change=\"sizeChangeHandle\"\r\n @current-change=\"currentChangeHandle\"\r\n :current-page=\"pageIndex\"\r\n :page-sizes=\"[10, 20, 50, 100]\"\r\n :page-size=\"Number(contents.pageEachNum)\"\r\n :total=\"totalPage\"\r\n :small=\"contents.pageStyle\"\r\n class=\"pagination-content\"\r\n :background=\"contents.pageBtnBG\"\r\n :style=\"{textAlign:contents.pagePosition==1?'left':contents.pagePosition==2?'center':'right'}\"\r\n ></el-pagination>\r\n </div>\r\n </div>\r\n <!-- 添加/修改页面 将父组件的search方法传递给子组件-->\r\n <add-or-update v-if=\"addOrUpdateFlag\" :parent=\"this\" ref=\"addOrUpdate\"></add-or-update>\r\n\r\n\r\n\r\n <el-dialog title=\"统计报表\" :visible.sync=\"chartVisiable\" width=\"800\">\r\n <el-date-picker\r\n v-model=\"echartsDate\"\r\n type=\"year\"\r\n placeholder=\"选择年\">\r\n </el-date-picker>\r\n <el-button @click=\"chartDialog()\">查询</el-button>\r\n <div id=\"statistic\" style=\"width:100%;height:600px;\"></div>\r\n <span slot=\"footer\" class=\"dialog-footer\">\r\n\t\t\t\t<el-button @click=\"chartVisiable = false\">关闭</el-button>\r\n\t\t\t</span>\r\n </el-dialog>\r\n\r\n </div>\r\n</template>\r\n<script>\r\n import AddOrUpdate from \"./add-or-update\";\r\n import styleJs from \"../../../utils/style.js\";\r\n import utilsJs from \"../../../utils/utils.js\";\r\n\r\n export default {\r\n data() {\r\n return {\r\n searchForm: {\r\n key: \"\"\r\n },\r\n sessionTable : \"\",//登录账户所在表名\r\n role : \"\",//权限\r\n userId:\"\",//当前登录人的id\r\n //级联表下拉框搜索条件\r\n //当前表下拉框搜索条件\r\n sexTypesSelectSearch : [],\r\n form:{\r\n id : null,\r\n username : null,\r\n password : null,\r\n yonghuName : null,\r\n yonghuPhoto : null,\r\n yonghuPhone : null,\r\n yonghuEmail : null,\r\n sexTypes : null,\r\n newMoney : null,\r\n yonghuDelete : null,\r\n createTime : null,\r\n },\r\n dataList: [],\r\n pageIndex: 1,\r\n pageSize: 10,\r\n totalPage: 0,\r\n dataListLoading: false,\r\n dataListSelections: [],\r\n showFlag: true,\r\n sfshVisiable: false,\r\n shForm: {},\r\n chartVisiable: false,\r\n echartsDate: new Date(),//echarts的时间查询字段\r\n addOrUpdateFlag:false,\r\n contents:null,\r\n layouts: '',\r\n\r\n //导出excel\r\n json_fields: {\r\n //级联表字段\r\n //本表字段\r\n '账户': \"username\",\r\n '用户姓名': \"yonghuName\",\r\n '头像': \"yonghuPhoto\",\r\n '手机号': \"yonghuPhone\",\r\n '电子邮箱': \"yonghuEmail\",\r\n '性别': \"sexTypes\",\r\n '余额': \"newMoney\",\r\n },\r\n\r\n };\r\n },\r\n created() {\r\n this.contents = styleJs.listStyle();\r\n this.init();\r\n this.getDataList();\r\n this.contentStyleChange()\r\n },\r\n mounted() {\r\n //获取当前登录用户的信息\r\n this.sessionTable = this.$storage.get(\"sessionTable\");\r\n this.role = this.$storage.get(\"role\");\r\n this.userId = this.$storage.get(\"userId\");\r\n\r\n },\r\n filters: {\r\n htmlfilter: function (val) {\r\n return val.replace(/<[^>]*>/g).replace(/undefined/g,'');\r\n }\r\n },\r\n components: {\r\n AddOrUpdate,\r\n },\r\n computed: {\r\n },\r\n methods: {\r\n chartDialog() {\r\n let _this = this;\r\n let params = {\r\n dateFormat :\"%Y\", //%Y-%m\r\n riqi :_this.echartsDate.getFullYear(),\r\n // riqi :_this.echartsDate.getFullYear()+\"-\"+(_this.echartsDate.getMonth() + 1 < 10 ? '0' + (_this.echartsDate.getMonth() + 1) : _this.echartsDate.getMonth() + 1),\r\n thisTable : {//当前表\r\n tableName :'yonghu',//当前表表名,\r\n sumColum : 'yonghu_number', //求和字段\r\n date : 'insert_time',//分组日期字段\r\n // string : 'yonghu_name',//分组字符串字段\r\n // types : 'yonghu_types',//分组下拉框字段\r\n },\r\n // joinTable : {//级联表(可以不存在)\r\n // tableName :'yonghu',//级联表表名\r\n // // date : 'insert_time',//分组日期字段\r\n // string : 'yonghu_name',//分组字符串字段\r\n // // types : 'yonghu_types',//分组下拉框字段\r\n // }\r\n }\r\n _this.chartVisiable = true;\r\n _this.$nextTick(() => {\r\n var statistic = this.$echarts.init(document.getElementById(\"statistic\"), 'macarons');\r\n this.$http({\r\n url: \"barSum\",\r\n method: \"get\",\r\n params: params\r\n }).then(({data}) => {\r\n if(data && data.code === 0){\r\n\r\n //柱状图 求和 已成功使用\r\n //start\r\n let yAxisName = \"数值\";//根据查询数据具体改(单列要改,多列不改)\r\n let xAxisName = \"月份\";\r\n let series = [];//具体数据值\r\n data.data.yAxis.forEach(function (item,index) {\r\n let tempMap = {};\r\n // tempMap.name= [\"数值\"];//根据查询数据具体改(单列要改,多列不改)\r\n tempMap.name=data.data.legend[index];\r\n tempMap.type='bar';\r\n tempMap.data=item;\r\n series.push(tempMap);\r\n\r\n })\r\n\r\n var option = {\r\n tooltip: {\r\n trigger: 'axis',\r\n axisPointer: {\r\n type: 'cross',\r\n crossStyle: {\r\n color: '#999'\r\n }\r\n }\r\n },\r\n toolbox: {\r\n feature: {\r\n // dataView: { show: true, readOnly: false }, // 数据查看\r\n magicType: { show: true, type: ['line', 'bar'] },//切换图形展示方式\r\n // restore: { show: true }, // 刷新\r\n saveAsImage: { show: true }//保存\r\n }\r\n },\r\n legend: {\r\n data: data.data.legend//标题 可以点击导致某一列数据消失\r\n },\r\n xAxis: [\r\n {\r\n type: 'category',\r\n name: xAxisName,\r\n data: data.data.xAxis,\r\n axisPointer: {\r\n type: 'shadow'\r\n }\r\n }\r\n ],\r\n yAxis: [\r\n {\r\n type: 'value',//不能改\r\n name: yAxisName,//y轴单位\r\n axisLabel: {\r\n formatter: '{value}' // 后缀\r\n }\r\n }\r\n ],\r\n series:series//具体数据\r\n };\r\n // 使用刚指定的配置项和数据显示图表。\r\n statistic.setOption(option,true);\r\n //根据窗口的大小变动图表\r\n window.onresize = function () {\r\n statistic.resize();\r\n };\r\n //end\r\n }else {\r\n this.$message({\r\n message: \"报表未查询到数据\",\r\n type: \"success\",\r\n duration: 1500,\r\n onClose: () => {\r\n this.search();\r\n }\r\n });\r\n }\r\n });\r\n });\r\n ////饼状图\r\n //_this.chartVisiable = true;\r\n // this.$nextTick(()=>{\r\n // var statistic = this.$echarts.init(document.getElementById(\"statistic\"),'macarons');\r\n // let params = {\r\n // tableName: \"yonghu\",\r\n // groupColumn: \"yonghu_types\",\r\n // }\r\n // this.$http({\r\n // url: \"newSelectGroupCount\",\r\n // method: \"get\",\r\n // params: params\r\n // }).then(({data}) => {\r\n // if (data && data.code === 0) {\r\n // let res = data.data;\r\n // let xAxis = [];\r\n // let yAxis = [];\r\n // let pArray = []\r\n // var option = {};\r\n // for(let i=0;i<res.length;i++){\r\n // xAxis.push(res[i].name);\r\n // yAxis.push(res[i].value);\r\n // pArray.push({\r\n // value: res[i].value,\r\n // name: res[i].name\r\n // })\r\n // option = {\r\n // title: {\r\n // text: '保险合同类型统计',\r\n // left: 'center'\r\n // },\r\n // tooltip: {\r\n // trigger: 'item',\r\n // formatter: '{b} : {c} ({d}%)'\r\n // },\r\n // series: [\r\n // {\r\n // type: 'pie',\r\n // radius: '55%',\r\n // center: ['50%', '60%'],\r\n // data: pArray,\r\n // emphasis: {\r\n // itemStyle: {\r\n // shadowBlur: 10,\r\n // shadowOffsetX: 0,\r\n // shadowColor: 'rgba(0, 0, 0, 0.5)'\r\n // }\r\n // }\r\n // }\r\n // ]\r\n // };\r\n // }\r\n // statistic.setOption(option);\r\n // window.onresize = function() {\r\n // statistic.resize();\r\n // };\r\n // }\r\n // });\r\n // })\r\n },\r\n contentStyleChange() {\r\n this.contentSearchStyleChange()\r\n this.contentBtnAdAllStyleChange()\r\n this.contentSearchBtnStyleChange()\r\n this.contentTableBtnStyleChange()\r\n this.contentPageStyleChange()\r\n },\r\n contentSearchStyleChange() {\r\n this.$nextTick(() => {\r\n document.querySelectorAll('.form-content .slt .el-input__inner').forEach(el => {\r\n let textAlign = 'left'\r\n if(this.contents.inputFontPosition == 2)\r\n textAlign = 'center'\r\n if (this.contents.inputFontPosition == 3) textAlign = 'right'\r\n el.style.textAlign = textAlign\r\n el.style.height = this.contents.inputHeight\r\n el.style.lineHeight = this.contents.inputHeight\r\n el.style.color = this.contents.inputFontColor\r\n el.style.fontSize = this.contents.inputFontSize\r\n el.style.borderWidth = this.contents.inputBorderWidth\r\n el.style.borderStyle = this.contents.inputBorderStyle\r\n el.style.borderColor = this.contents.inputBorderColor\r\n el.style.borderRadius = this.contents.inputBorderRadius\r\n el.style.backgroundColor = this.contents.inputBgColor\r\n })\r\n if (this.contents.inputTitle) {\r\n document.querySelectorAll('.form-content .slt .el-form-item__label').forEach(el => {\r\n el.style.color = this.contents.inputTitleColor\r\n el.style.fontSize = this.contents.inputTitleSize\r\n el.style.lineHeight = this.contents.inputHeight\r\n })\r\n }\r\n setTimeout(() => {\r\n document.querySelectorAll('.form-content .slt .el-input__prefix').forEach(el => {\r\n el.style.color = this.contents.inputIconColor\r\n el.style.lineHeight = this.contents.inputHeight\r\n })\r\n document.querySelectorAll('.form-content .slt .el-input__suffix').forEach(el => {\r\n el.style.color = this.contents.inputIconColor\r\n el.style.lineHeight = this.contents.inputHeight\r\n })\r\n document.querySelectorAll('.form-content .slt .el-input__icon').forEach(el => {\r\n el.style.lineHeight = this.contents.inputHeight\r\n })\r\n }, 10 )\r\n })\r\n },\r\n // 搜索按钮\r\n contentSearchBtnStyleChange() {\r\n this.$nextTick(() => {\r\n document.querySelectorAll('.form-content .slt .el-button--success').forEach(el => {\r\n el.style.height = this.contents.searchBtnHeight\r\n el.style.color = this.contents.searchBtnFontColor\r\n el.style.fontSize = this.contents.searchBtnFontSize\r\n el.style.borderWidth = this.contents.searchBtnBorderWidth\r\n el.style.borderStyle = this.contents.searchBtnBorderStyle\r\n el.style.borderColor = this.contents.searchBtnBorderColor\r\n el.style.borderRadius = this.contents.searchBtnBorderRadius\r\n el.style.backgroundColor = this.contents.searchBtnBgColor\r\n })\r\n })\r\n },\r\n // 新增、批量删除\r\n contentBtnAdAllStyleChange() {\r\n this.$nextTick(() => {\r\n document.querySelectorAll('.form-content .ad .el-button--success').forEach(el => {\r\n el.style.height = this.contents.btnAdAllHeight\r\n el.style.color = this.contents.btnAdAllAddFontColor\r\n el.style.fontSize = this.contents.btnAdAllFontSize\r\n el.style.borderWidth = this.contents.btnAdAllBorderWidth\r\n el.style.borderStyle = this.contents.btnAdAllBorderStyle\r\n el.style.borderColor = this.contents.btnAdAllBorderColor\r\n el.style.borderRadius = this.contents.btnAdAllBorderRadius\r\n el.style.backgroundColor = this.contents.btnAdAllAddBgColor\r\n })\r\n document.querySelectorAll('.form-content .ad .el-button--danger').forEach(el => {\r\n el.style.height = this.contents.btnAdAllHeight\r\n el.style.color = this.contents.btnAdAllDelFontColor\r\n el.style.fontSize = this.contents.btnAdAllFontSize\r\n el.style.borderWidth = this.contents.btnAdAllBorderWidth\r\n el.style.borderStyle = this.contents.btnAdAllBorderStyle\r\n el.style.borderColor = this.contents.btnAdAllBorderColor\r\n el.style.borderRadius = this.contents.btnAdAllBorderRadius\r\n el.style.backgroundColor = this.contents.btnAdAllDelBgColor\r\n })\r\n document.querySelectorAll('.form-content .ad .el-button--warning').forEach(el => {\r\n el.style.height = this.contents.btnAdAllHeight\r\n el.style.color = this.contents.btnAdAllWarnFontColor\r\n el.style.fontSize = this.contents.btnAdAllFontSize\r\n el.style.borderWidth = this.contents.btnAdAllBorderWidth\r\n el.style.borderStyle = this.contents.btnAdAllBorderStyle\r\n el.style.borderColor = this.contents.btnAdAllBorderColor\r\n el.style.borderRadius = this.contents.btnAdAllBorderRadius\r\n el.style.backgroundColor = this.contents.btnAdAllWarnBgColor\r\n })\r\n })\r\n },\r\n // 表格\r\n rowStyle({row, rowIndex}) {\r\n if (rowIndex % 2 == 1) {\r\n if (this.contents.tableStripe) {\r\n return {color: this.contents.tableStripeFontColor}\r\n }\r\n } else {\r\n return ''\r\n }\r\n },\r\n cellStyle({row, rowIndex}) {\r\n if (rowIndex % 2 == 1) {\r\n if (this.contents.tableStripe) {\r\n return {backgroundColor: this.contents.tableStripeBgColor}\r\n }\r\n } else {\r\n return ''\r\n }\r\n },\r\n headerRowStyle({row, rowIndex}) {\r\n return {color: this.contents.tableHeaderFontColor}\r\n },\r\n headerCellStyle({row, rowIndex}) {\r\n return {backgroundColor: this.contents.tableHeaderBgColor}\r\n },\r\n // 表格按钮\r\n contentTableBtnStyleChange() {\r\n // this.$nextTick(()=>{\r\n // setTimeout(()=>{\r\n // document.querySelectorAll('.table-content .tables .el-table__body .el-button--success').forEach(el=>{\r\n // el.style.height = this.contents.tableBtnHeight\r\n // el.style.color = this.contents.tableBtnDetailFontColor\r\n // el.style.fontSize = this.contents.tableBtnFontSize\r\n // el.style.borderWidth = this.contents.tableBtnBorderWidth\r\n // el.style.borderStyle = this.contents.tableBtnBorderStyle\r\n // el.style.borderColor = this.contents.tableBtnBorderColor\r\n // el.style.borderRadius = this.contents.tableBtnBorderRadius\r\n // el.style.backgroundColor = this.contents.tableBtnDetailBgColor\r\n // })\r\n // document.querySelectorAll('.table-content .tables .el-table__body .el-button--primary').forEach(el=>{\r\n // el.style.height = this.contents.tableBtnHeight\r\n // el.style.color = this.contents.tableBtnEditFontColor\r\n // el.style.fontSize = this.contents.tableBtnFontSize\r\n // el.style.borderWidth = this.contents.tableBtnBorderWidth\r\n // el.style.borderStyle = this.contents.tableBtnBorderStyle\r\n // el.style.borderColor = this.contents.tableBtnBorderColor\r\n // el.style.borderRadius = this.contents.tableBtnBorderRadius\r\n // el.style.backgroundColor = this.contents.tableBtnEditBgColor\r\n // })\r\n // document.querySelectorAll('.table-content .tables .el-table__body .el-button--danger').forEach(el=>{\r\n // el.style.height = this.contents.tableBtnHeight\r\n // el.style.color = this.contents.tableBtnDelFontColor\r\n // el.style.fontSize = this.contents.tableBtnFontSize\r\n // el.style.borderWidth = this.contents.tableBtnBorderWidth\r\n // el.style.borderStyle = this.contents.tableBtnBorderStyle\r\n // el.style.borderColor = this.contents.tableBtnBorderColor\r\n // el.style.borderRadius = this.contents.tableBtnBorderRadius\r\n // el.style.backgroundColor = this.contents.tableBtnDelBgColor\r\n // })\r\n\r\n // }, 50)\r\n // })\r\n },\r\n // 分页\r\n contentPageStyleChange() {\r\n let arr = []\r\n if (this.contents.pageTotal) arr.push('total')\r\n if (this.contents.pageSizes) arr.push('sizes')\r\n if (this.contents.pagePrevNext) {\r\n arr.push('prev')\r\n if (this.contents.pagePager) arr.push('pager')\r\n arr.push('next')\r\n }\r\n if (this.contents.pageJumper) arr.push('jumper')\r\n this.layouts = arr.join()\r\n this.contents.pageEachNum = 10\r\n },\r\n\r\n init() {\r\n },\r\n search() {\r\n this.pageIndex = 1;\r\n this.getDataList();\r\n },\r\n // 获取数据列表\r\n getDataList() {\r\n this.dataListLoading = true;\r\n let params = {\r\n page: this.pageIndex,\r\n limit: this.pageSize,\r\n sort: 'id',\r\n }\r\n\r\n \r\n if (this.searchForm.yonghuName!= '' && this.searchForm.yonghuName!= undefined) {\r\n params['yonghuName'] = '%' + this.searchForm.yonghuName + '%'\r\n }\r\n \r\n if (this.searchForm.sexTypes!= '' && this.searchForm.sexTypes!= undefined) {\r\n params['sexTypes'] = this.searchForm.sexTypes\r\n }\r\n \r\n params['yonghuDelete'] = 1// 逻辑删除字段 1 未删除 2 删除\r\n\r\n\r\n this.$http({\r\n url: \"yonghu/page\",\r\n method: \"get\",\r\n params: params\r\n }).then(({data}) => {\r\n if(data && data.code === 0){\r\n this.dataList = data.data.list;\r\n this.totalPage = data.data.total;\r\n }else{\r\n this.dataList = [];\r\n this.totalPage = 0;\r\n }\r\n this.dataListLoading = false;\r\n });\r\n\r\n //查询级联表搜索条件所有列表\r\n //查询当前表搜索条件所有列表\r\n //填充下拉框选项\r\n this.$http({\r\n url: \"dictionary/page?dicCode=sex_types&page=1&limit=100\",\r\n method: \"get\",\r\n }).then(({data}) => {\r\n if(data && data.code === 0){\r\n this.sexTypesSelectSearch = data.data.list;\r\n }\r\n });\r\n },\r\n //每页数\r\n sizeChangeHandle(val) {\r\n this.pageSize = val;\r\n this.pageIndex = 1;\r\n this.getDataList();\r\n },\r\n // 当前页\r\n currentChangeHandle(val) {\r\n this.pageIndex = val;\r\n this.getDataList();\r\n },\r\n // 多选\r\n selectionChangeHandler(val) {\r\n this.dataListSelections = val;\r\n },\r\n // 添加/修改\r\n addOrUpdateHandler(id, type) {\r\n this.showFlag = false;\r\n this.addOrUpdateFlag = true;\r\n this.crossAddOrUpdateFlag = false;\r\n if (type != 'info') {\r\n type = 'else';\r\n }\r\n this.$nextTick(() => {\r\n this.$refs.addOrUpdate.init(id, type);\r\n });\r\n },\r\n // 下载\r\n download(file) {\r\n window.open(\" ${file} \")\r\n },\r\n // 删除\r\n deleteHandler(id) {\r\n var ids = id ? [Number(id)] : this.dataListSelections.map(item => {\r\n return Number(item.id);\r\n });\r\n\r\n this.$confirm(`确定进行[${id ? \"删除\" : \"批量删除\"}]操作?`, \"提示\", {\r\n confirmButtonText: \"确定\",\r\n cancelButtonText: \"取消\",\r\n type: \"warning\"\r\n }).then(() => {\r\n this.$http({\r\n url: \"yonghu/delete\",\r\n method: \"post\",\r\n data: ids\r\n }).then(({data}) => {\r\n if(data && data.code === 0){\r\n this.$message({\r\n message: \"操作成功\",\r\n type: \"success\",\r\n duration: 1500,\r\n onClose: () => {\r\n this.search();\r\n }\r\n });\r\n }else{\r\n this.$message.error(data.msg);\r\n }\r\n });\r\n });\r\n },\r\n resetPassword(id) {\r\n let _this = this;\r\n //重置密码\r\n this.$http({\r\n url: \"yonghu/resetPassword?id=\" + id,\r\n method: \"get\",\r\n // id:id\r\n }).then(({data}) => {\r\n if(data && data.code === 0){\r\n _this.$message({\r\n message: '重置成功,密码已重置为123456',\r\n type: 'success'\r\n });\r\n }\r\n });\r\n },\r\n // 导入功能上传文件成功后调用导入方法\r\n yonghuUploadSuccess(data){\r\n let _this = this;\r\n _this.$http({\r\n url: \"yonghu/batchInsert?fileName=\" + data.file,\r\n method: \"get\"\r\n }).then(({data}) => {\r\n if(data && data.code === 0){\r\n _this.$message({\r\n message: \"导入用户数据成功\",\r\n type: \"success\",\r\n duration: 1500,\r\n onClose: () => {\r\n _this.search();\r\n }\r\n });\r\n }else{\r\n _this.$message.error(data.msg);\r\n }\r\n });\r\n\r\n },\r\n // 导入功能上传文件失败后调用导入方法\r\n yonghuUploadError(data){\r\n this.$message.error('上传失败');\r\n },\r\n }\r\n };\r\n</script>\r\n<style lang=\"scss\" scoped>\r\n.slt {\r\n margin: 0 !important;\r\n display: flex;\r\n }\r\n\r\n .ad {\r\n margin: 0 !important;\r\n display: flex;\r\n }\r\n\r\n .pages {\r\n & /deep/ el-pagination__sizes{\r\n & /deep/ el-input__inner {\r\n height: 22px;\r\n line-height: 22px;\r\n }\r\n }\r\n }\r\n \r\n\r\n .el-button+.el-button {\r\n margin:0;\r\n } \r\n\r\n .tables {\r\n\t& /deep/ .el-button--success {\r\n\t\theight: 40px;\r\n\t\tcolor: #333;\r\n\t\tfont-size: 14px;\r\n\t\tborder-width: 1px;\r\n\t\tborder-style: solid;\r\n\t\tborder-color: #DCDFE6;\r\n\t\tborder-radius: 4px;\r\n\t\tbackground-color: rgba(117, 113, 249, 1);\r\n\t}\r\n\t\r\n\t& /deep/ .el-button--primary {\r\n\t\theight: 40px;\r\n\t\tcolor: #333;\r\n\t\tfont-size: 14px;\r\n\t\tborder-width: 1px;\r\n\t\tborder-style: solid;\r\n\t\tborder-color: #DCDFE6;\r\n\t\tborder-radius: 4px;\r\n\t\tbackground-color: rgba(102, 204, 255, 1);\r\n\t}\r\n\t\r\n\t& /deep/ .el-button--danger {\r\n\t\theight: 40px;\r\n\t\tcolor: #333;\r\n\t\tfont-size: 14px;\r\n\t\tborder-width: 1px;\r\n\t\tborder-style: solid;\r\n\t\tborder-color: #DCDFE6;\r\n\t\tborder-radius: 4px;\r\n\t\tbackground-color: rgba(204, 255, 102, 1);\r\n\t}\r\n\r\n & /deep/ .el-button {\r\n margin: 4px;\r\n }\r\n }\r\n</style>\r\n\r\n\r\n"]}]} |