110 lines
3.4 KiB
Vue
110 lines
3.4 KiB
Vue
![]() |
<template>
|
||
|
<el-card class="box-card" shadow="never">
|
||
|
<template #header>
|
||
|
<div>
|
||
|
<span>{{ $t('generate.code.title') }}</span>
|
||
|
</div>
|
||
|
</template>
|
||
|
<div class="w-full sm:w-[40%] mx-auto">
|
||
|
<el-form :model="gen" ref="form" label-width="100px">
|
||
|
<el-form-item
|
||
|
:label="$t('generate.code.module.name')"
|
||
|
prop="module"
|
||
|
:rules="[
|
||
|
{
|
||
|
required: true,
|
||
|
message: $t('generate.code.module.verify'),
|
||
|
},
|
||
|
]"
|
||
|
>
|
||
|
<Select v-model="gen.module" clearable :placeholder="$t('generate.code.module.placeholder')" api="modules" class="w-full" filterable />
|
||
|
</el-form-item>
|
||
|
<el-form-item
|
||
|
:label="$t('generate.code.controller.name')"
|
||
|
prop="controller"
|
||
|
:rules="[
|
||
|
{
|
||
|
required: true,
|
||
|
message: $t('generate.code.controller.verify'),
|
||
|
},
|
||
|
]"
|
||
|
>
|
||
|
<el-input v-model="gen.controller" clearable :placeholder="$t('generate.code.controller.placeholder')" />
|
||
|
</el-form-item>
|
||
|
<el-form-item :label="$t('generate.code.model.name')" prop="model">
|
||
|
<el-input v-model="gen.model" clearable :placeholder="$t('generate.code.model.placeholder')" />
|
||
|
</el-form-item>
|
||
|
|
||
|
<div class="flex">
|
||
|
<el-form-item :label="$t('generate.code.paginate')" prop="paginate">
|
||
|
<el-switch v-model="gen.paginate" inline-prompt :active-text="$t('system.yes')" :inactive-text="$t('system.no')" />
|
||
|
</el-form-item>
|
||
|
<el-form-item label-width="15px">
|
||
|
<div class="text-sm text-gray-300">控制列表是否使用分页功能</div>
|
||
|
</el-form-item>
|
||
|
</div>
|
||
|
</el-form>
|
||
|
</div>
|
||
|
<Structure />
|
||
|
<div class="w-full flex justify-center pt-5">
|
||
|
<router-link to="/develop/schemas">
|
||
|
<el-button>{{ $t('system.back') }}</el-button>
|
||
|
</router-link>
|
||
|
<el-button type="primary" @click="submitGenerate(form)" class="ml-5">{{ $t('system.finish') }}</el-button>
|
||
|
</div>
|
||
|
</el-card>
|
||
|
</template>
|
||
|
<script lang="ts" setup>
|
||
|
import { watch, onMounted, reactive, ref } from 'vue'
|
||
|
import { useGenerateStore } from './store'
|
||
|
import type { FormInstance } from 'element-plus'
|
||
|
import http from '/admin/support/http'
|
||
|
import Structure from './structure.vue'
|
||
|
import { useRouter } from 'vue-router'
|
||
|
const generateStore = useGenerateStore()
|
||
|
const gen = reactive(generateStore.getCodeGen)
|
||
|
|
||
|
const router = useRouter()
|
||
|
|
||
|
const schemaId = router.currentRoute.value.params.schema
|
||
|
|
||
|
onMounted(() => {
|
||
|
if (!generateStore.getSchemaId) {
|
||
|
generateStore.setSchemaId(schemaId)
|
||
|
getSchema()
|
||
|
} else {
|
||
|
if (schemaId !== generateStore.getSchemaId) {
|
||
|
generateStore.setSchemaId(schemaId)
|
||
|
generateStore.resetStructures()
|
||
|
getSchema()
|
||
|
}
|
||
|
}
|
||
|
})
|
||
|
|
||
|
const getSchema = () => {
|
||
|
http.get('schema/' + schemaId).then(r => {
|
||
|
gen.module = r.data.data.module
|
||
|
gen.schema = r.data.data.name
|
||
|
|
||
|
gen.model = r.data.data.name.replace(/\_(\w)/g, (value, letter) => {
|
||
|
return letter.toUpperCase()
|
||
|
})
|
||
|
|
||
|
generateStore.initStructures(r.data.data.columns)
|
||
|
})
|
||
|
}
|
||
|
const form = ref<FormInstance>()
|
||
|
const submitGenerate = (formEl: FormInstance | undefined) => {
|
||
|
if (!formEl) return
|
||
|
formEl.validate(valid => {
|
||
|
if (valid) {
|
||
|
http.post('generate', generateStore.$state).then(r => {})
|
||
|
//emits('next')
|
||
|
//generateStore.$reset()
|
||
|
} else {
|
||
|
return false
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
</script>
|