代码生成,支持设置前端的模版

pull/119/head
YunaiV 2023-04-13 00:21:32 +08:00
parent ebbf47f509
commit f3c6249600
5 changed files with 41 additions and 25 deletions

View File

@ -21,7 +21,7 @@ export interface DictDataType {
} }
export const getDictOptions = (dictType: string) => { export const getDictOptions = (dictType: string) => {
return dictStore.getDictByType(dictType) return dictStore.getDictByType(dictType) || []
} }
export const getIntDictOptions = (dictType: string) => { export const getIntDictOptions = (dictType: string) => {
@ -117,6 +117,7 @@ export enum DICT_TYPE {
INFRA_API_ERROR_LOG_PROCESS_STATUS = 'infra_api_error_log_process_status', INFRA_API_ERROR_LOG_PROCESS_STATUS = 'infra_api_error_log_process_status',
INFRA_CONFIG_TYPE = 'infra_config_type', INFRA_CONFIG_TYPE = 'infra_config_type',
INFRA_CODEGEN_TEMPLATE_TYPE = 'infra_codegen_template_type', INFRA_CODEGEN_TEMPLATE_TYPE = 'infra_codegen_template_type',
INFRA_CODEGEN_FRONT_TYPE = 'infra_codegen_front_type',
INFRA_CODEGEN_SCENE = 'infra_codegen_scene', INFRA_CODEGEN_SCENE = 'infra_codegen_scene',
INFRA_FILE_STORAGE = 'infra_file_storage', INFRA_FILE_STORAGE = 'infra_file_storage',

View File

@ -15,7 +15,7 @@
v-loading="loading" v-loading="loading"
element-loading-text="生成文件目录中..." element-loading-text="生成文件目录中..."
> >
<el-scrollbar height="calc(100vh - 88px - 40px - 50px)"> <el-scrollbar height="calc(100vh - 88px - 40px)">
<el-tree <el-tree
ref="treeRef" ref="treeRef"
node-key="id" node-key="id"

View File

@ -13,6 +13,19 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="12">
<el-form-item prop="frontType" label="前端类型">
<el-select v-model="formData.frontType">
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.INFRA_CODEGEN_FRONT_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12"> <el-col :span="12">
<el-form-item prop="scene" label="生成场景"> <el-form-item prop="scene" label="生成场景">
<el-select v-model="formData.scene"> <el-select v-model="formData.scene">
@ -25,6 +38,26 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="12">
<el-form-item>
<template #label>
<span>
上级菜单
<el-tooltip content="分配到指定菜单下,例如 系统管理" placement="top">
<Icon icon="ep:question-filled" />
</el-tooltip>
</span>
</template>
<el-tree-select
v-model="formData.parentMenuId"
placeholder="请选择系统菜单"
node-key="id"
check-strictly
:data="menus"
:props="menuTreeProps"
/>
</el-form-item>
</el-col>
<!-- <el-col :span="12">--> <!-- <el-col :span="12">-->
<!-- <el-form-item prop="packageName">--> <!-- <el-form-item prop="packageName">-->
@ -115,27 +148,6 @@
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="12">
<el-form-item>
<template #label>
<span>
上级菜单
<el-tooltip content="分配到指定菜单下,例如 系统管理" placement="top">
<Icon icon="ep:question-filled" />
</el-tooltip>
</span>
</template>
<el-tree-select
v-model="formData.parentMenuId"
placeholder="请选择系统菜单"
node-key="id"
check-strictly
:data="menus"
:props="menuTreeProps"
/>
</el-form-item>
</el-col>
<el-col :span="24" v-if="formData.genType === '1'"> <el-col :span="24" v-if="formData.genType === '1'">
<el-form-item prop="genPath"> <el-form-item prop="genPath">
<template #label> <template #label>
@ -297,6 +309,7 @@ const props = defineProps({
const formRef = ref() const formRef = ref()
const formData = ref({ const formData = ref({
templateType: null, templateType: null,
frontType: null,
scene: null, scene: null,
moduleName: '', moduleName: '',
businessName: '', businessName: '',
@ -315,6 +328,7 @@ const formData = ref({
const rules = reactive({ const rules = reactive({
templateType: [required], templateType: [required],
frontType: [required],
scene: [required], scene: [required],
moduleName: [required], moduleName: [required],
businessName: [required], businessName: [required],

View File

@ -115,11 +115,12 @@ const colorTypeOptions = readonly([
]) ])
/** 打开弹窗 */ /** 打开弹窗 */
const open = async (type: string, id?: number) => { const open = async (type: string, id?: number, dictType?: string) => {
dialogVisible.value = true dialogVisible.value = true
dialogTitle.value = t('action.' + type) dialogTitle.value = t('action.' + type)
formType.value = type formType.value = type
resetForm() resetForm()
formData.value.dictType = dictType
// //
if (id) { if (id) {
formLoading.value = true formLoading.value = true

View File

@ -167,7 +167,7 @@ const resetQuery = () => {
/** 添加/修改操作 */ /** 添加/修改操作 */
const formRef = ref() const formRef = ref()
const openForm = (type: string, id?: number) => { const openForm = (type: string, id?: number) => {
formRef.value.open(type, id) formRef.value.open(type, id, queryParams.dictType)
} }
/** 删除按钮操作 */ /** 删除按钮操作 */