123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157 |
- <template>
- <el-table ref="dragTable" :data="formData" row-key="columnId" :max-height="tableHeight">
- <el-table-column
- label="字段列名"
- prop="columnName"
- min-width="10%"
- :show-overflow-tooltip="true"
- />
- <el-table-column label="字段描述" min-width="10%">
- <template #default="scope">
- <el-input v-model="scope.row.columnComment" />
- </template>
- </el-table-column>
- <el-table-column
- label="物理类型"
- prop="dataType"
- min-width="10%"
- :show-overflow-tooltip="true"
- />
- <el-table-column label="Java类型" min-width="11%">
- <template #default="scope">
- <el-select v-model="scope.row.javaType">
- <el-option label="Long" value="Long" />
- <el-option label="String" value="String" />
- <el-option label="Integer" value="Integer" />
- <el-option label="Double" value="Double" />
- <el-option label="BigDecimal" value="BigDecimal" />
- <el-option label="LocalDateTime" value="LocalDateTime" />
- <el-option label="Boolean" value="Boolean" />
- </el-select>
- </template>
- </el-table-column>
- <el-table-column label="java属性" min-width="10%">
- <template #default="scope">
- <el-input v-model="scope.row.javaField" />
- </template>
- </el-table-column>
- <el-table-column label="插入" min-width="4%">
- <template #default="scope">
- <el-checkbox true-label="true" false-label="false" v-model="scope.row.createOperation" />
- </template>
- </el-table-column>
- <el-table-column label="编辑" min-width="4%">
- <template #default="scope">
- <el-checkbox true-label="true" false-label="false" v-model="scope.row.updateOperation" />
- </template>
- </el-table-column>
- <el-table-column label="列表" min-width="4%">
- <template #default="scope">
- <el-checkbox
- true-label="true"
- false-label="false"
- v-model="scope.row.listOperationResult"
- />
- </template>
- </el-table-column>
- <el-table-column label="查询" min-width="4%">
- <template #default="scope">
- <el-checkbox true-label="true" false-label="false" v-model="scope.row.listOperation" />
- </template>
- </el-table-column>
- <el-table-column label="查询方式" min-width="10%">
- <template #default="scope">
- <el-select v-model="scope.row.listOperationCondition">
- <el-option label="=" value="=" />
- <el-option label="!=" value="!=" />
- <el-option label=">" value=">" />
- <el-option label=">=" value=">=" />
- <el-option label="<" value="<>" />
- <el-option label="<=" value="<=" />
- <el-option label="LIKE" value="LIKE" />
- <el-option label="BETWEEN" value="BETWEEN" />
- </el-select>
- </template>
- </el-table-column>
- <el-table-column label="允许空" min-width="5%">
- <template #default="scope">
- <el-checkbox true-label="true" false-label="false" v-model="scope.row.nullable" />
- </template>
- </el-table-column>
- <el-table-column label="显示类型" min-width="12%">
- <template #default="scope">
- <el-select v-model="scope.row.htmlType">
- <el-option label="文本框" value="input" />
- <el-option label="文本域" value="textarea" />
- <el-option label="下拉框" value="select" />
- <el-option label="单选框" value="radio" />
- <el-option label="复选框" value="checkbox" />
- <el-option label="日期控件" value="datetime" />
- <el-option label="图片上传" value="imageUpload" />
- <el-option label="文件上传" value="fileUpload" />
- <el-option label="富文本控件" value="editor" />
- </el-select>
- </template>
- </el-table-column>
- <el-table-column label="字典类型" min-width="12%">
- <template #default="scope">
- <el-select v-model="scope.row.dictType" clearable filterable placeholder="请选择">
- <el-option
- v-for="dict in dictOptions"
- :key="dict.id"
- :label="dict.name"
- :value="dict.type"
- />
- </el-select>
- </template>
- </el-table-column>
- <el-table-column label="示例" min-width="10%">
- <template #default="scope">
- <el-input v-model="scope.row.example" />
- </template>
- </el-table-column>
- </el-table>
- </template>
- <script setup lang="ts">
- import { PropType } from 'vue'
- import { CodegenColumnVO } from '@/api/infra/codegen/types'
- import { DictTypeVO, listSimpleDictType } from '@/api/system/dict/dict.type'
- const emits = defineEmits(['update:columns'])
- const props = defineProps({
- columns: {
- type: Array as unknown as PropType<CodegenColumnVO[]>,
- default: () => null
- }
- })
- const formData = ref<CodegenColumnVO[]>([])
- const tableHeight = document.documentElement.scrollHeight - 350 + 'px'
- /** 查询字典下拉列表 */
- const dictOptions = ref<DictTypeVO[]>()
- const getDictOptions = async () => {
- dictOptions.value = await listSimpleDictType()
- }
- onMounted(async () => {
- await getDictOptions()
- })
- watch(
- () => props.columns,
- (columns) => {
- if (!columns) return
- formData.value = columns
- },
- {
- deep: true,
- immediate: true
- }
- )
- watch(
- () => formData.value,
- (val) => {
- emits('update:columns', val)
- }
- )
- </script>
|