fieldDialog.vue 5.3 KB
Newer Older
1 2
<template>
    <div>
3
        <span style="color:red">搜索时如果条件为LIKE只支持字符串</span>
4 5 6 7 8 9
        <el-form :model="dialogMiddle" ref="fieldDialogFrom" label-width="120px" label-position="left" :rules="rules">
            <el-form-item label="Field名称" prop="fieldName">
                <el-col :span="6">
                <el-input v-model="dialogMiddle.fieldName" autocomplete="off"></el-input>
                </el-col>
            </el-form-item>
10 11 12 13 14
            <el-form-item label="Field中文名" prop="fieldDesc">
                <el-col :span="6">
                <el-input v-model="dialogMiddle.fieldDesc" autocomplete="off"></el-input>
                </el-col>
            </el-form-item>
15 16 17 18 19 20 21 22 23 24
            <el-form-item label="FieldJSON" prop="fieldJson">
                <el-col :span="6">
                <el-input v-model="dialogMiddle.fieldJson" autocomplete="off"></el-input>
                </el-col>
            </el-form-item>
            <el-form-item label="数据库字段名" prop="columnName">
                <el-col :span="6">
                <el-input v-model="dialogMiddle.columnName" autocomplete="off"></el-input>
                </el-col>
            </el-form-item>
25 26 27 28 29
            <el-form-item label="数据库字段描述" prop="comment">
                <el-col :span="6">
                <el-input v-model="dialogMiddle.comment" autocomplete="off"></el-input>
                </el-col>
            </el-form-item>
30 31
            <el-form-item label="Field数据类型" prop="fieldType">
                <el-col :span="8">
Mr.奇淼('s avatar
Mr.奇淼( 已提交
32
            <el-select v-model="dialogMiddle.fieldType" placeholder="请选择field数据类型" @change="getDbfdOptions">
33 34 35 36 37 38 39 40 41
                <el-option
                    v-for="item in typeOptions"
                    :key="item.value"
                    :label="item.label"
                    :value="item.value">
                </el-option>
            </el-select>
                </el-col>
            </el-form-item>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
42 43 44 45 46 47 48 49 50 51 52 53 54

            <el-form-item label="数据库字段类型" prop="dbFieldType">
                <el-col :span="8">
            <el-select :disabled="!dialogMiddle.fieldType" v-model="dialogMiddle.dbFieldType" placeholder="请选择数据库字段类型">
                <el-option
                    v-for="item in dbfdOptions"
                    :key="item.label"
                    :label="item.label"
                    :value="item.label">
                </el-option>
            </el-select>
                </el-col>
            </el-form-item>
55 56
            <el-form-item label="Field查询条件" prop="fieldSearchType">
                <el-col :span="8">
Mr.奇淼('s avatar
Mr.奇淼( 已提交
57
            <el-select v-model="dialogMiddle.fieldSearchType" placeholder="请选择Field查询条件">
58 59 60 61 62 63 64 65 66
                <el-option
                    v-for="item in typeSearchOptions"
                    :key="item.value"
                    :label="item.label"
                    :value="item.value">
                </el-option>
            </el-select>
                </el-col>
            </el-form-item>
67 68 69 70
        </el-form>
    </div>
</template>
<script>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
71
import {getDict} from '@/utils/dictionary'
72 73 74 75 76 77 78 79 80 81 82 83
export default {
    name:"FieldDialog",
    props:{
        dialogMiddle:{
            type:Object,
            default:function(){
                return {}
            }
        }
    },
    data(){
        return{
Mr.奇淼('s avatar
Mr.奇淼( 已提交
84
            dbfdOptions:[],
85
            visible:false,
86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107
            typeSearchOptions:[
                {
                    label:"=",
                    value:"="
                },
                {
                    label:"<>",
                    value:"<>"
                },
                {
                    label:">",
                    value:">"
                },
                {
                    label:"<",
                    value:"<"
                },
                {
                    label:"LIKE",
                    value:"LIKE"
                },
            ],
108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131
            typeOptions:[
                {
                    label:"字符串",
                    value:"string"
                },
                {
                    label:"整型",
                    value:"int"
                },
                {
                    label:"布尔值",
                    value:"bool"
                },
                {
                    label:"浮点型",
                    value:"float64"
                },
                {
                    label:"时间",
                    value:"time.Time"
                },
            ],
            rules:{
                fieldName:[ { required: true, message: '请输入field英文名', trigger: 'blur' }],
132
                fieldDesc:[ { required: true, message: '请输入field中文名', trigger: 'blur' }],
133
                fieldJson:[ { required: true, message: '请输入field格式化json', trigger: 'blur' }],
134
                columnName:[{ required: true, message: '请输入数据库字段', trigger: 'blur' }],
135 136
                fieldType:[ { required: true, message: '请选择field数据类型', trigger: 'blur' }]
            }
137

138
        }
139
    },
Mr.奇淼('s avatar
Mr.奇淼( 已提交
140 141 142 143 144 145 146 147 148 149 150
    methods: {
        async getDbfdOptions(){
            if(this.dialogMiddle.fieldType){
                 const res = await getDict(this.dialogMiddle.fieldType)
                 this.dbfdOptions = res
            }
        }
    },
    created() {
        this.getDbfdOptions()
    },
151 152 153
}
</script>
<style lang="scss">
154 155

</style>