dataMobile.vue 3.73 KB
<template>
    <el-dialog :title="title" :visible.sync="open" v-if="open" width="600px" append-to-body>
        <el-form ref="form" :model="form" :rules="rules" label-width="130px">
            <el-form-item label="数据源名称" prop="name">
                <el-input v-model="form.name" placeholder="请输入数据源名称" :disabled='disabled' />
            </el-form-item>
            <el-form-item label="数据源接口" prop="interFace">
                <el-input v-model="form.interFace" placeholder="请输入数据源接口" :disabled='disabled' />
            </el-form-item>
            <el-form-item label="应用规则" prop="ruleList">
                <el-checkbox-group v-model="checkList">
                    <el-checkbox v-for="(item,index) in dict.type.index_rule_type" :key="index" :label="Number(item.value)" name="type">{{item.label}}</el-checkbox>
                </el-checkbox-group>
            </el-form-item>
            <el-form-item label="备注" prop="remarks">
                <el-input v-model="form.remarks" type="textarea" placeholder="请输入备注" :disabled='disabled' />
            </el-form-item>
        </el-form>
        <div slot="footer" class="dialog-footer">
            <el-button type="primary" @click="submitForm">确 定</el-button>
            <el-button @click="cancel">取 消</el-button>
        </div>
    </el-dialog>
</template>

<script>
import { dataSourceSave, dataSourceEdit } from "@/api/postList/list";
export default {
    name: 'dataMobile',
    dicts: ['sys_normal_disable','index_rule_type'],
    data() {
        return {
            imageUrl: '',
            disabled: true,
            open: false,
            // 弹出层标题
            title: "",
            // 表单参数
            form: {
                ruleList:[]
            },
            id:'',
            checkList: [],
            // 表单校验
            rules: {
                name: [
                    { required: true, message: "数据源名称不能为空", trigger: "blur" }
                ],
                interFace: [
                    { required: true, message: "数据源接口不能为空", trigger: "blur" }
                ],
                // ruleList:[
                //     { required: true, message: "应用规则不能为空", trigger: "blur" }
                // ],
            }
        }
    },
    methods: {
        // 取消按钮
        cancel() {
            this.open = false;
            this.form = {}
        },
        add() {
            this.open = true;
            this.title = "添加风控申请";
            this.form = {},
            this.id = ""
        },
        edit(res) {
            this.form = res
            // this.form.rule = ['准入']
            this.open = true;
            this.id = res.id
        },
        handleAvatarSuccess(res, file) {
            this.imageUrl = URL.createObjectURL(file.raw);
        },
        /** 提交按钮 */
        submitForm: function () {
            this.$refs["form"].validate(valid => {
                this.form.ruleList = this.checkList
                if (valid) {
                    if (this.id) {
                        dataSourceEdit(this.form).then(response => {
                            this.$modal.msgSuccess("修改成功");
                            this.open = false;
                            this.$emit("getList")
                        });
                    } else {
                        dataSourceSave(this.form).then(response => {
                            this.$modal.msgSuccess("新增成功");
                            this.open = false;
                            this.$emit("getList")
                        });
                    }
                }
            });
        },
    }
}
</script>

<style>
</style>