master^2
lzq 2026-01-31 19:46:04 +08:00
parent 3bdb6185b6
commit c9b9d03c9d
3 changed files with 152 additions and 165 deletions

View File

@ -12,10 +12,10 @@ var apiTsName = dc + "-api.ts";
var dTsName = dc + ".d.ts"; var dTsName = dc + ".d.ts";
%> %>
<template> <template>
<ElDialog v-model="showDialog" <ADetailPanel
destroy-on-close ref="detailPanel"
width="fit-content" v-bind="detailPanelProps">
@close="dialogCloseHandler"> <template #default="detailData">
<ElDescriptions title="${table.comment}" border> <ElDescriptions title="${table.comment}" border>
<% <%
for(column in table.columns) { for(column in table.columns) {
@ -26,35 +26,26 @@ var dTsName = dc + ".d.ts";
</ElDescriptionsItem> </ElDescriptionsItem>
<%}%> <%}%>
</ElDescriptions> </ElDescriptions>
<template #footer>
<ElButton @click="showDialog = false" type="primary">关闭</ElButton>
</template> </template>
</ElDialog> </ADetailPanel>
</template> </template>
<script lang="ts" setup> <script lang="ts" setup>
import ${ucc}Api from '@/pages/${moduleName}<%if(subModuleName != null){%>/${subModuleName}<%}%>/${apiTsName}' import ${ucc}Api from '@/pages/${moduleName}<%if(subModuleName != null){%>/${subModuleName}<%}%>/${apiTsName}'
import Utils from '@/common/utils' import ADetailPanel, {
type ADetailPanelInstance,
buildDetailPanelProps,
} from '@/components/a-detail-panel/ADetailPanel.tsx'
const showDialog = ref(false) const detailPanelIns = useTemplateRef<ADetailPanelInstance<${ucc}Types.Search${ucc}Result>>('detailPanel')
const detailPanelProps = buildDetailPanelProps<${ucc}Types.Search${ucc}Result>({
const detailData = Utils.resetAble(reactive<${ucc}Types.Search${ucc}Result>({})) title: '${table.comment}详情',
detailsLoader: ${ucc}Api.detail,
function dialogCloseHandler() { })
detailData.$reset()
}
defineExpose({ defineExpose({
open(data: ${ucc}Types.Search${ucc}Result) { open(data: ${ucc}Types.Search${ucc}Result) {
showDialog.value = true detailPanelIns.value?.open(data)
${ucc}Api.detail(data.id!) },
.then(res => {
detailData.$reset(res.data)
})
}
}) })
</script> </script>
<style lang="stylus" scoped>
</style>

View File

@ -11,111 +11,83 @@ var apiTsName = dc + "-api.ts";
var dTsName = dc + ".d.ts"; var dTsName = dc + ".d.ts";
%> %>
<template> <template>
<ElDialog v-model="showDialog" <AFormPanel
:close-on-click-modal="false" ref="formPanel"
destroy-on-close v-bind="formPanelProps">
width="fit-content" <template #default="formData">
@close="dialogCloseHandler"> <div class="form-items">
<ElForm :model="formData"
:rules="rules"
ref="${lcc}Form"
class="form-panel"
label-width="auto">
<% <%
for(column in table.columns) { for(column in table.columns) {
var map = tsType(column.dataType); var map = tsType(column.dataType);
%> %>
<ElFormItem label="${column.comment}" prop="${toCamelCase(column.name)}"> <ElFormItem label="${column.comment}" prop="${toCamelCase(column.name)}">
<ElInput <ElInput placeholder="${column.comment}" v-model="formData.${toCamelCase(column.name)}" />
v-model="formData.${toCamelCase(column.name)}"
:disabled="status === 'view'"
placeholder="${column.comment}"/>
</ElFormItem> </ElFormItem>
<%}%> <%}%>
</ElForm> </div>
<template #footer>
<ElButton @click="showDialog = false">{{ status === 'view' ? '关闭' : '取消' }}</ElButton>
<ElButton v-if="status !== 'view'" :loading="submiting" type="primary" @click="submitHandler">提交</ElButton>
</template> </template>
</ElDialog> </AFormPanel>
</template> </template>
<script lang="ts" setup> <script lang="ts" setup>
import ${ucc}Api from '@/pages/${moduleName}<%if(subModuleName != null){%>/${subModuleName}<%}%>/${apiTsName}' import ${ucc}Api from '@/pages/${moduleName}<%if(subModuleName != null){%>/${subModuleName}<%}%>/${apiTsName}'
import AFormPanel, {
type AFormPanelInstance,
buildFormPanelProps,
} from '@/components/a-form-panel/AFormPanel.tsx'
import Strings from '@/common/utils/strings.ts' import Strings from '@/common/utils/strings.ts'
import FormUtil from '@/common/utils/formUtil.ts'
import Utils from '@/common/utils'
import {
ElMessage,
type FormInstance,
type FormRules,
} from 'element-plus'
const emits = defineEmits(['editSucc']) const props = withDefaults(defineProps<{
const showDialog = ref(false) research?: () => void
const submiting = ref(false) }>(), {
const status = ref<'add' | 'view' | 'modify'>('add') research: () => {
},
const ${lcc}FormIns = useTemplateRef<FormInstance>('${lcc}Form')
const formData = Utils.resetAble(reactive<${ucc}Types.Search${ucc}Result>({}))
const rules = reactive<FormRules<${ucc}Types.Search${ucc}Result>>({
<%
for(column in table.columns) {
%>
${toCamelCase(column.name)}: [{ required: true, message: '请填写${column.comment}', trigger: 'blur' }],
<%}%>
}) })
const formPanelIns = useTemplateRef<AFormPanelInstance>('formPanel')
function dialogCloseHandler() { const status = ref<'add' | 'modify'>('add')
formData.$reset() const formPanelProps = buildFormPanelProps<${ucc}Types.Search${ucc}Result>({
} title: status.value === 'add' ? '新建${table.comment}' : '修改${table.comment}信息',
detailsLoader(id?: string) {
function submitHandler() { if (Strings.isBlank(id)) {
if (status.value === 'view') return status.value = 'add'
submiting.value = true return Promise.resolve()
if (formData.id != null) {
FormUtil.submit(${lcc}FormIns, () => ${ucc}Api.modify(formData))
.then(() => {
ElMessage.success('修改成功')
emits('editSucc')
showDialog.value = false
})
.finally(() => {
submiting.value = false
})
} else { } else {
FormUtil.submit(${lcc}FormIns, () => ${ucc}Api.add(formData)) status.value = 'modify'
.then(() => { return ${ucc}Api
ElMessage.success('添加成功') .detail(id!)
emits('editSucc') .then(res => res.data)
showDialog.value = false
})
.finally(() => {
submiting.value = false
})
} }
} },
doSubmit(data) {
if (status.value === 'add') {
return ${ucc}Api
.add(data)
.then(props.research)
} else {
return ${ucc}Api
.modify(data)
.then(props.research)
}
},
rules: {
<%
for(column in table.columns) {
%>
${toCamelCase(column.name)}: [{ required: true, message: '请填写${column.comment}', trigger: 'blur' }],
<%}%>
},
})
defineExpose({ defineExpose({
open(data: ${ucc}Types.Search${ucc}Result = {}) { open(data?: ${ucc}Types.Search${ucc}Result) {
showDialog.value = true formPanelIns.value?.open(data?.id)
if (!Strings.isBlank(data.id)) { },
status.value = 'modify'
${ucc}Api.detail(data.id!)
.then(res => {
formData.$reset(res.data)
})
} else {
status.value = 'add'
formData.$reset(data)
}
}
}) })
</script> </script>
<style lang="stylus" scoped> <style lang="stylus" scoped>
.form-panel { .form-items {
padding 20px grid-template-columns: 1fr 1fr;
} }
</style> </style>

View File

@ -6,25 +6,32 @@ var dc = toDashCase(lcc);
var pageVueName = ucc + ".vue"; var pageVueName = ucc + ".vue";
var formVueName = ucc + "Form.vue"; var formVueName = ucc + "Form.vue";
var detailVueName = ucc + "Detail.vue";
var pageTsName = "page.ts"; var pageTsName = "page.ts";
var apiTsName = dc + "-api.ts"; var apiTsName = dc + "-api.ts";
var dTsName = dc + ".d.ts"; var dTsName = dc + ".d.ts";
%> %>
<template> <template>
<FormPage <ATablePage
ref="formPage" ref="tablePage"
:action-column="actionColumn" v-bind="tablePageProps">
:left-tools="leftTools" <template #highFormItem="formData">
:paging="paging">
<template #searchFormItem="{ searchForm }">
<% <%
for(column in table.columns) { for(column in table.columns) {
var map = tsType(column.dataType); var map = tsType(column.dataType);
%> %>
<ElFormItem label="${column.comment}"> <ElFormItem label="${column.comment}">
<ElInput <ElInput placeholder="${column.comment}" v-model="formData.${toCamelCase(column.name)}"/>
v-model="searchForm.${toCamelCase(column.name)}" </ElFormItem>
placeholder="${column.comment}"/> <%}%>
</template>
<template #simpleFormItem="formData">
<%
for(column in table.columns) {
var map = tsType(column.dataType);
%>
<ElFormItem>
<ElInput placeholder="${column.comment}" v-model="formData.${toCamelCase(column.name)}"/>
</ElFormItem> </ElFormItem>
<%}%> <%}%>
</template> </template>
@ -37,31 +44,34 @@ var dTsName = dc + ".d.ts";
<ElTableColumn label="${column.comment}" prop="${toCamelCase(column.name)}"/> <ElTableColumn label="${column.comment}" prop="${toCamelCase(column.name)}"/>
<%}%> <%}%>
</template> </template>
<${ucc}Form ref="${lcc}Form" @edit-succ="research"/> <${ucc}Form ref="${lcc}Form" :research="research"/>
</Page> <${ucc}Detail ref="${lcc}Detail"/>
</ATablePage>
</template> </template>
<script lang="ts" setup> <script lang="ts" setup>
import ${ucc}Api from '@/pages/${moduleName}<%if(subModuleName != null){%>/${subModuleName}<%}%>/${apiTsName}' import ${ucc}Api from '@/pages/${moduleName}<%if(subModuleName != null){%>/${subModuleName}<%}%>/${apiTsName}'
import ${ucc}Form from '@/pages/${moduleName}<%if(subModuleName != null){%>/${subModuleName}<%}%>/${formVueName}' import ${ucc}Form from '@/pages/${moduleName}<%if(subModuleName != null){%>/${subModuleName}<%}%>/${formVueName}'
import FormPage, { import ${ucc}Detail from '@/pages/${moduleName}<%if(subModuleName != null){%>/${subModuleName}<%}%>/${detailVueName}'
type ActionColumnType, import ATablePage, {
type ToolType, type ATablePageInstance,
} from '@/components/page/FormPage.vue' buildTablePageProps,
import type { ComponentExposed } from 'vue-component-type-helpers' } from '@/components/a-page/a-table-page/ATablePage.tsx'
const formPageIns = useTemplateRef<ComponentExposed<typeof FormPage>>('formPage') const tablePageIns = useTemplateRef<ATablePageInstance>('tablePage')
const ${lcc}FormIns = useTemplateRef<InstanceType<typeof ${ucc}Form>>('${lcc}Form') const ${lcc}FormIns = useTemplateRef<InstanceType<typeof ${ucc}Form>>('${lcc}Form')
const ${lcc}DetailIns = useTemplateRef<InstanceType<typeof ${ucc}Detail>>('${lcc}Detail')
function research() { function research() {
formPageIns.value?.doSearch() tablePageIns.value?.doSearch()
} }
function paging(params: ${ucc}Types.Search${ucc}Param) { const tablePageProps = buildTablePageProps<${ucc}Types.Search${ucc}Param, ${ucc}Types.Search${ucc}Result>({
return ${ucc}Api.paging(params) searchForm: {
} paging: ${ucc}Api.paging,
},
const leftTools: ToolType[] = [ toolBar: {
leftTools: [
{ {
icon: 'Plus', icon: 'Plus',
label: '新建', label: '新建',
@ -69,12 +79,23 @@ const leftTools: ToolType[] = [
${lcc}FormIns.value?.open() ${lcc}FormIns.value?.open()
}, },
}, },
] ],
const actionColumn = reactive<ActionColumnType<${ucc}Types.Search${ucc}Result>>({ },
table: {
actionColumn: {
tableActions: [ tableActions: [
{
tooltip: '详情',
icon: 'Postcard',
type: 'info',
action({row}) {
${lcc}DetailIns.value?.open(row)
},
},
{ {
tooltip: '编辑', tooltip: '编辑',
icon: 'Edit', icon: 'Edit',
type: 'primary',
action({row}) { action({row}) {
${lcc}FormIns.value?.open(row) ${lcc}FormIns.value?.open(row)
}, },
@ -96,5 +117,8 @@ const actionColumn = reactive<ActionColumnType<${ucc}Types.Search${ucc}Result>>(
}, },
}, },
], ],
},
},
}) })
</script> </script>