|
@@ -4,8 +4,8 @@ import { onMounted, PropType, ref } from 'vue'
|
|
import { CodegenColumnVO } from '@/api/infra/codegen/types'
|
|
import { CodegenColumnVO } from '@/api/infra/codegen/types'
|
|
import { listSimpleDictTypeApi } from '@/api/system/dict/dict.type'
|
|
import { listSimpleDictTypeApi } from '@/api/system/dict/dict.type'
|
|
import { DictTypeVO } from '@/api/system/dict/types'
|
|
import { DictTypeVO } from '@/api/system/dict/types'
|
|
-defineProps({
|
|
|
|
- currentRow: {
|
|
|
|
|
|
+const props = defineProps({
|
|
|
|
+ info: {
|
|
type: Array as unknown as PropType<CodegenColumnVO[]>,
|
|
type: Array as unknown as PropType<CodegenColumnVO[]>,
|
|
default: () => null
|
|
default: () => null
|
|
}
|
|
}
|
|
@@ -20,18 +20,21 @@ const tableHeight = document.documentElement.scrollHeight - 245 + 'px'
|
|
onMounted(async () => {
|
|
onMounted(async () => {
|
|
await getDictOptions()
|
|
await getDictOptions()
|
|
})
|
|
})
|
|
|
|
+defineExpose({
|
|
|
|
+ info: props.info
|
|
|
|
+})
|
|
</script>
|
|
</script>
|
|
<template>
|
|
<template>
|
|
- <el-table ref="dragTable" :data="currentRow" row-key="columnId" :max-height="tableHeight">
|
|
|
|
|
|
+ <el-table ref="dragTable" :data="info" row-key="columnId" :max-height="tableHeight">
|
|
<el-table-column
|
|
<el-table-column
|
|
label="字段列名"
|
|
label="字段列名"
|
|
prop="columnName"
|
|
prop="columnName"
|
|
min-width="10%"
|
|
min-width="10%"
|
|
:show-overflow-tooltip="true"
|
|
:show-overflow-tooltip="true"
|
|
/>
|
|
/>
|
|
- <el-table-column label="字段描述" min-width="10%">
|
|
|
|
- <template #default="scope">
|
|
|
|
- <el-input v-model="scope.row.columnComment" />
|
|
|
|
|
|
+ <el-table-column label="字段描述" min-width="10%" prop="columnComment">
|
|
|
|
+ <template #default="{ row }">
|
|
|
|
+ <el-input v-model="row.columnComment" />
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table-column>
|
|
<el-table-column
|
|
<el-table-column
|
|
@@ -40,9 +43,9 @@ onMounted(async () => {
|
|
min-width="10%"
|
|
min-width="10%"
|
|
:show-overflow-tooltip="true"
|
|
:show-overflow-tooltip="true"
|
|
/>
|
|
/>
|
|
- <el-table-column label="Java类型" min-width="11%">
|
|
|
|
- <template #default="scope">
|
|
|
|
- <el-select v-model="scope.row.javaType">
|
|
|
|
|
|
+ <el-table-column label="Java类型" min-width="11%" prop="javaType">
|
|
|
|
+ <template #default="{ row }">
|
|
|
|
+ <el-select v-model="row.javaType">
|
|
<el-option label="Long" value="Long" />
|
|
<el-option label="Long" value="Long" />
|
|
<el-option label="String" value="String" />
|
|
<el-option label="String" value="String" />
|
|
<el-option label="Integer" value="Integer" />
|
|
<el-option label="Integer" value="Integer" />
|
|
@@ -53,38 +56,34 @@ onMounted(async () => {
|
|
</el-select>
|
|
</el-select>
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table-column>
|
|
- <el-table-column label="java属性" min-width="10%">
|
|
|
|
- <template #default="scope">
|
|
|
|
- <el-input v-model="scope.row.javaField" />
|
|
|
|
|
|
+ <el-table-column label="java属性" min-width="10%" prop="javaField">
|
|
|
|
+ <template #default="{ row }">
|
|
|
|
+ <el-input v-model="row.javaField" />
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</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" />
|
|
|
|
|
|
+ <el-table-column label="插入" min-width="4%" prop="createOperation">
|
|
|
|
+ <template #default="{ row }">
|
|
|
|
+ <el-checkbox true-label="true" false-label="false" v-model="row.createOperation" />
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</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" />
|
|
|
|
|
|
+ <el-table-column label="编辑" min-width="4%" prop="updateOperation">
|
|
|
|
+ <template #default="{ row }">
|
|
|
|
+ <el-checkbox true-label="true" false-label="false" v-model="row.updateOperation" />
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</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"
|
|
|
|
- />
|
|
|
|
|
|
+ <el-table-column label="列表" min-width="4%" prop="listOperationResult">
|
|
|
|
+ <template #default="{ row }">
|
|
|
|
+ <el-checkbox true-label="true" false-label="false" v-model="row.listOperationResult" />
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</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" />
|
|
|
|
|
|
+ <el-table-column label="查询" min-width="4%" prop="listOperation">
|
|
|
|
+ <template #default="{ row }">
|
|
|
|
+ <el-checkbox true-label="true" false-label="false" v-model="row.listOperation" />
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table-column>
|
|
- <el-table-column label="查询方式" min-width="10%">
|
|
|
|
- <template #default="scope">
|
|
|
|
- <el-select v-model="scope.row.listOperationCondition">
|
|
|
|
|
|
+ <el-table-column label="查询方式" min-width="10%" prop="listOperationCondition">
|
|
|
|
+ <template #default="{ row }">
|
|
|
|
+ <el-select v-model="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=">" />
|
|
@@ -96,14 +95,14 @@ onMounted(async () => {
|
|
</el-select>
|
|
</el-select>
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</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" />
|
|
|
|
|
|
+ <el-table-column label="允许空" min-width="5%" prop="nullable">
|
|
|
|
+ <template #default="{ row }">
|
|
|
|
+ <el-checkbox true-label="true" false-label="false" v-model="row.nullable" />
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table-column>
|
|
- <el-table-column label="显示类型" min-width="12%">
|
|
|
|
- <template #default="scope">
|
|
|
|
- <el-select v-model="scope.row.htmlType">
|
|
|
|
|
|
+ <el-table-column label="显示类型" min-width="12%" prop="htmlType">
|
|
|
|
+ <template #default="{ row }">
|
|
|
|
+ <el-select v-model="row.htmlType">
|
|
<el-option label="文本框" value="input" />
|
|
<el-option label="文本框" value="input" />
|
|
<el-option label="文本域" value="textarea" />
|
|
<el-option label="文本域" value="textarea" />
|
|
<el-option label="下拉框" value="select" />
|
|
<el-option label="下拉框" value="select" />
|
|
@@ -116,9 +115,9 @@ onMounted(async () => {
|
|
</el-select>
|
|
</el-select>
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table-column>
|
|
- <el-table-column label="字典类型" min-width="12%">
|
|
|
|
- <template #default="scope">
|
|
|
|
- <el-select v-model="scope.row.dictType" clearable filterable placeholder="请选择">
|
|
|
|
|
|
+ <el-table-column label="字典类型" min-width="12%" prop="dictType">
|
|
|
|
+ <template #default="{ row }">
|
|
|
|
+ <el-select v-model="row.dictType" clearable filterable placeholder="请选择">
|
|
<el-option
|
|
<el-option
|
|
v-for="dict in dictOptions"
|
|
v-for="dict in dictOptions"
|
|
:key="dict.id"
|
|
:key="dict.id"
|
|
@@ -128,9 +127,9 @@ onMounted(async () => {
|
|
</el-select>
|
|
</el-select>
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table-column>
|
|
- <el-table-column label="示例" min-width="10%">
|
|
|
|
- <template #default="scope">
|
|
|
|
- <el-input v-model="scope.row.example" />
|
|
|
|
|
|
+ <el-table-column label="示例" min-width="10%" prop="example">
|
|
|
|
+ <template #default="{ row }">
|
|
|
|
+ <el-input v-model="row.example" />
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table-column>
|
|
</el-table>
|
|
</el-table>
|