master^2
parent
3bdb6185b6
commit
c9b9d03c9d
|
|
@ -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>
|
|
||||||
|
|
@ -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 formPanelIns = useTemplateRef<AFormPanelInstance>('formPanel')
|
||||||
const formData = Utils.resetAble(reactive<${ucc}Types.Search${ucc}Result>({}))
|
const status = ref<'add' | 'modify'>('add')
|
||||||
const rules = reactive<FormRules<${ucc}Types.Search${ucc}Result>>({
|
const formPanelProps = buildFormPanelProps<${ucc}Types.Search${ucc}Result>({
|
||||||
<%
|
title: status.value === 'add' ? '新建${table.comment}' : '修改${table.comment}信息',
|
||||||
for(column in table.columns) {
|
detailsLoader(id?: string) {
|
||||||
%>
|
if (Strings.isBlank(id)) {
|
||||||
${toCamelCase(column.name)}: [{ required: true, message: '请填写${column.comment}', trigger: 'blur' }],
|
status.value = 'add'
|
||||||
<%}%>
|
return Promise.resolve()
|
||||||
|
} else {
|
||||||
|
status.value = 'modify'
|
||||||
|
return ${ucc}Api
|
||||||
|
.detail(id!)
|
||||||
|
.then(res => res.data)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
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' }],
|
||||||
|
<%}%>
|
||||||
|
},
|
||||||
})
|
})
|
||||||
|
|
||||||
function dialogCloseHandler() {
|
|
||||||
formData.$reset()
|
|
||||||
}
|
|
||||||
|
|
||||||
function submitHandler() {
|
|
||||||
if (status.value === 'view') return
|
|
||||||
submiting.value = true
|
|
||||||
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 {
|
|
||||||
FormUtil.submit(${lcc}FormIns, () => ${ucc}Api.add(formData))
|
|
||||||
.then(() => {
|
|
||||||
ElMessage.success('添加成功')
|
|
||||||
emits('editSucc')
|
|
||||||
showDialog.value = false
|
|
||||||
})
|
|
||||||
.finally(() => {
|
|
||||||
submiting.value = false
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
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>
|
||||||
|
|
|
||||||
|
|
@ -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,64 +44,81 @@ 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',
|
{
|
||||||
label: '新建',
|
icon: 'Plus',
|
||||||
action() {
|
label: '新建',
|
||||||
${lcc}FormIns.value?.open()
|
action() {
|
||||||
|
${lcc}FormIns.value?.open()
|
||||||
|
},
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
table: {
|
||||||
|
actionColumn: {
|
||||||
|
tableActions: [
|
||||||
|
{
|
||||||
|
tooltip: '详情',
|
||||||
|
icon: 'Postcard',
|
||||||
|
type: 'info',
|
||||||
|
action({row}) {
|
||||||
|
${lcc}DetailIns.value?.open(row)
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
tooltip: '编辑',
|
||||||
|
icon: 'Edit',
|
||||||
|
type: 'primary',
|
||||||
|
action({row}) {
|
||||||
|
${lcc}FormIns.value?.open(row)
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
icon: 'Delete',
|
||||||
|
loading: false,
|
||||||
|
type: 'danger',
|
||||||
|
tooltip: '删除',
|
||||||
|
confirm: {
|
||||||
|
title: '是否删除当前数据',
|
||||||
|
},
|
||||||
|
action({row}) {
|
||||||
|
return ${ucc}Api.del([ row.id! ])
|
||||||
|
.then(() => {
|
||||||
|
ElMessage.success('删除成功')
|
||||||
|
return true
|
||||||
|
})
|
||||||
|
},
|
||||||
|
},
|
||||||
|
],
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
]
|
|
||||||
const actionColumn = reactive<ActionColumnType<${ucc}Types.Search${ucc}Result>>({
|
|
||||||
tableActions: [
|
|
||||||
{
|
|
||||||
tooltip: '编辑',
|
|
||||||
icon: 'Edit',
|
|
||||||
action({row}) {
|
|
||||||
${lcc}FormIns.value?.open(row)
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
icon: 'Delete',
|
|
||||||
loading: false,
|
|
||||||
type: 'danger',
|
|
||||||
tooltip: '删除',
|
|
||||||
confirm: {
|
|
||||||
title: '是否删除当前数据',
|
|
||||||
},
|
|
||||||
action({row}) {
|
|
||||||
return ${ucc}Api.del([ row.id! ])
|
|
||||||
.then(() => {
|
|
||||||
ElMessage.success('删除成功')
|
|
||||||
return true
|
|
||||||
})
|
|
||||||
},
|
|
||||||
},
|
|
||||||
],
|
|
||||||
})
|
})
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue