修复生成vue3界面

This commit is contained in:
yubaolee 2024-11-13 17:45:11 +08:00
parent 6dfac7128d
commit f2665731aa

View File

@ -2,142 +2,87 @@
* @Author: yubaolee <yubaolee@163.com> | ahfu~ <954478625@qq.com> * @Author: yubaolee <yubaolee@163.com> | ahfu~ <954478625@qq.com>
* @Description: 代码生成界面,采用的是固定头部结构 * @Description: 代码生成界面,采用的是固定头部结构
* @ * @
* @Copyright (c) 2022 by yubaolee | ahfu~ , All Rights Reserved. * @Copyright (c) 2024 by yubaolee | ahfu~ , All Rights Reserved.
--> -->
<template> <template>
<div class="flex-column"> <div class="flex-column flex">
<sticky> <sticky>
<el-input <div class="search-box">
style="width: 200px" <el-input @keyup.enter="handleFilter" size="small" class="w-200 custom-input" :placeholder="'名称'"
class="filter-item" v-model="firstQuery.key"></el-input>
:placeholder="'名称'" <el-button class="filter-item custom-button" icon="el-icon-search" size="small" @click="handleFilter">
v-model="firstQuery.key"></el-input> 搜索
<el-button </el-button>
class="filter-item" </div>
icon="el-icon-search"
@click="handleFilter">
搜索
</el-button>
<permission-btn v-on:btn-event="onBtnClicked"></permission-btn> <permission-btn v-on:btn-event="onBtnClicked"></permission-btn>
</sticky> </sticky>
<el-card shadow="nerver" class="flex-item"> <div class="flex-item flex flex-column main-context">
<auth-table <el-card shadow="never" class="custom-card flex-item flex flex-column">
style="height: calc(100% - 52px)" <auth-table size="small" ref="mainTable" :select-type="'radio'" :table-fields="firstHeaderList" :data="mainList"
ref="mainTable" :v-loading="listLoading" @row-click="rowClickFirstTable"></auth-table>
:table-fields="firstHeaderList" </el-card>
:data="mainList" <div class="flex flex-direction-r b-w p-r-10 p-t-10 p-b-10">
:v-loading="listLoading" <el-pagination v-show="firstTotal > 0" :total="firstTotal" v-model:currentPage="firstQuery.page"
@row-click="rowClickFirstTable" v-model:page-size="firstQuery.limit" @current-change="handleCurrentChange" />
@selection-change="handleSelChangeFirstTable"></auth-table> </div>
<el-pagination <div class="flex-item flex">
v-show="firstTotal > 0" <div v-if="showTitleDialog" class="flex flex-column" style="width: 500px;">
:total="firstTotal" <el-card shadow="never" class="demo-card custom-card fh">
v-model:currentPage="firstQuery.page" <template #header>
v-model:page-size="firstQuery.limit" <div>
@current-change="handleCurrentChange" /> <span v-if="radio == ''" class="f-12 f-b">表信息</span>
</el-card> <span v-else class="f-12 f-b">{{ tableName }}表信息</span>
<el-row class="flex-item"> </div>
<el-col :span="showTitleDialog ? 8 : 0" class="fh form-card"> </template>
<el-card shadow="nerver" class="demo-card fh"> <auth-form ref="dataForm" :rules="mainRules" :edit-model="editModel" :form-fields="firstHeaderList"
<template #header> v-model="firstTemp" :data="firstTemp" :col-num="2"></auth-form>
<div> </el-card>
<span v-if="radio == ''">详情</span> </div>
<span v-else>{{ tableName }}详情</span> <div class="flex-item flex flex-column">
</div> <el-card shadow="never" class="custom-card flex-item flex flex-column" id="secondCard">
</template> <template #header>
<auth-form <div class="flex flex-center">
ref="dataForm" <el-icon v-if="showTitleDialog" @click="showTitleDialog = !showTitleDialog" :size="14">
:rules="mainRules"
:edit-model="editModel"
:form-fields="firstHeaderList"
v-model="firstTemp"
:data="firstTemp"
:col-num="2"></auth-form>
</el-card>
</el-col>
<!-- 第二部分多选 -->
<el-col :span="!showTitleDialog ? 24 : 16" class="fh detail-card">
<el-card shadow="nerver" class="demo-card fh" id="secondCard">
<template #header>
<el-row>
<el-col :span="2">
<el-icon
v-if="showTitleDialog"
@click="showTitleDialog = !showTitleDialog"
:size="20">
<ArrowLeftBold /> <ArrowLeftBold />
</el-icon> </el-icon>
<el-icon <el-icon v-else @click="showTitleDialog = !showTitleDialog" :size="14">
v-else
@click="showTitleDialog = !showTitleDialog"
:size="20">
<ArrowRightBold /> <ArrowRightBold />
</el-icon> </el-icon>
</el-col> <span v-if="radio == ''" class="flex-item f-12 f-b">
<el-col :span="18"> 表字段信息(修改后,编辑框内回车生效)
<span v-if="radio == ''" class="flex-item">
明细列表(修改后,编辑框内回车生效)
</span> </span>
<span v-else class="flex-item"> <span v-else class="flex-item f-12 f-b">
{{ tableName }}明细列表(修改后,编辑框内回车生效) {{ tableName }}表字段信息(修改后,编辑框内回车生效)
</span> </span>
</el-col> <el-button size="small" v-if="editModel" :icon="Delete" @click="onBtnClicked('btnDelDetail')">
<el-col :span="2">
<el-button
v-if="editModel"
:icon="Plus"
@click="onBtnClicked('btnAddDetail')">
添加
</el-button>
</el-col>
<el-col :span="2">
<el-button
v-if="editModel"
:icon="Delete"
@click="onBtnClicked('btnDelDetail')">
删除 删除
</el-button> </el-button>
</el-col> </div>
</el-row> </template>
</template> <auth-table size="small" ref="secondTable" :editModel="editModel" :table-fields="secondHeaderList"
<auth-table :data="secondList" @row-click="rowClickSecondTable" @selection-change="selChangeSecondTable"
style="height: calc(100% - 52px - 34px)" @item-change="handleUpdateDetail"></auth-table>
ref="secondTable" </el-card>
:editModel="editModel" <div class="flex flex-direction-r p-r-10 b-w p-b-5 p-t-5">
:table-fields="secondHeaderList" <el-pagination v-show="secondTotal > 0" :total="secondTotal" v-model:page="secondQuery.page"
:data="secondList" v-model:limit="secondQuery.limit" @current-change="handleSecondPage" />
@row-click="rowClickSecondTable" </div>
@selection-change="selChangeSecondTable" </div>
@item-change="handleUpdateDetail"></auth-table> </div>
<el-pagination <div v-if="editModel" class="p-t-5 p-b-5 t-r b-w p-r-10 border-t-2">
v-show="secondTotal > 0" <el-button @click="editModel = false">取消</el-button>
:total="secondTotal" <el-button v-if="dialogStatus == 'create'" type="primary" @click="createData">
v-model:page="secondQuery.page" 确认
v-model:limit="secondQuery.limit" </el-button>
@current-change="handleSecondPage" /> <el-button v-else type="primary" @click="updateData">确认</el-button>
</el-card> </div>
</el-col> </div>
</el-row>
<el-affix position="bottom" v-if="editModel" style="text-align: end">
<el-row style="background-color: white">
<el-col :span="24">
<el-button @click="editModel = false">取消</el-button>
<el-button
v-if="dialogStatus == 'create'"
type="primary"
@click="createData">
确认
</el-button>
<el-button v-else type="primary" @click="updateData">确认</el-button>
</el-col>
</el-row>
</el-affix>
</div> </div>
</template> </template>
<script setup> <script setup>
//引入核心框架 //引入核心框架
import { ElMessage, ElNotification } from 'element-plus' import { ElMessage, ElNotification } from 'element-plus'
import { Plus, Delete } from '@element-plus/icons-vue' import { Refresh, Delete } from '@element-plus/icons-vue'
import { onMounted, ref, reactive, nextTick, computed } from 'vue' import { onMounted, ref, reactive, nextTick, computed } from 'vue'
import { mapGetters, useStore } from 'vuex' import { mapGetters, useStore } from 'vuex'
//引入API共用方法 //引入API共用方法
@ -152,7 +97,6 @@
import permissionBtn from '@/components/PermissionBtn/index.vue' import permissionBtn from '@/components/PermissionBtn/index.vue'
import AuthForm from '../../components/Base/AuthForm.vue' import AuthForm from '../../components/Base/AuthForm.vue'
import AuthTable from '../../components/Base/AuthTable.vue' import AuthTable from '../../components/Base/AuthTable.vue'
const firstHeaderList = ref([]) //列表头 const firstHeaderList = ref([]) //列表头
const secondHeaderList = ref([]) //明细列表头 const secondHeaderList = ref([]) //明细列表头
const multipleSelection = ref([]) //明细中checkbox选中的值 const multipleSelection = ref([]) //明细中checkbox选中的值
@ -181,27 +125,24 @@
customerKey: undefined, customerKey: undefined,
}) })
const showTitleDialog = ref(true) //是否显示左下主列表详情值 const showTitleDialog = ref(true) //是否显示左下主列表详情值
const mainRules = reactive({ //添加自己的表单验证规则 const mainRules = reactive({
Id: [ Id: [
{ {
required: true, required: true,
message: 'id不能为空' message: 'id不能为空'
}, },
], ],
}) })
//组件refs //组件refs
const mainTable = ref(null) const mainTable = ref(null)
const dataForm = ref(null) const dataForm = ref(null)
const secondTable = ref(null) const secondTable = ref(null)
const store = useStore() const store = useStore()
const defaultorgid = computed(() => store.getters.defaultorgid) const defaultorgid = computed(() => store.getters.defaultorgid)
onMounted(() => { onMounted(() => {
initCfg() initCfg()
getList() getList()
}) })
const initCfg = function () { const initCfg = function () {
firstHeaderList.value = [ firstHeaderList.value = [
{FirstHeaderList} {FirstHeaderList}
@ -211,9 +152,9 @@
] ]
} }
// ------------------------通用处理函数------------------------------------- // ------------------------通用处理函数-------------------------------------
const onBtnClicked = (domId, callback) => { const onBtnClicked = function (domId, callback) {
switch (domId) { switch (domId) {
case 'btnAdd': // 添加 case 'btnAdd': // 添加新记录
resetFirstTemp() resetFirstTemp()
secondList.value = [] secondList.value = []
dialogStatus.value = 'create' dialogStatus.value = 'create'
@ -224,7 +165,7 @@
dataForm.value.clearValidate() dataForm.value.clearValidate()
}) })
break break
case 'btnEdit': // 编辑 case 'btnEdit': // 编辑
Object.assign(firstTemp, selectRow) Object.assign(firstTemp, selectRow)
if (firstTemp.id === '') { if (firstTemp.id === '') {
editModel.value = false editModel.value = false
@ -241,7 +182,7 @@
dataForm.value.clearValidate() dataForm.value.clearValidate()
}) })
break break
case 'btnDel': // 删除 case 'btnDel': // 删除主表
if (firstTemp.id === '') { if (firstTemp.id === '') {
ElMessage({ ElMessage({
message: '请选择要删除的项', message: '请选择要删除的项',
@ -264,7 +205,7 @@
} }
handleSecondDel(multipleSelection.value) handleSecondDel(multipleSelection.value)
break break
case 'btnExport': //导出 case 'btnExport':
mainTable.value.exportExcel(`表结构${parseTime(new Date())}`, callback) mainTable.value.exportExcel(`表结构${parseTime(new Date())}`, callback)
break break
default: default:
@ -273,7 +214,7 @@
} }
// ------------------------主数据列表处理------------------------------------ // ------------------------主数据列表处理------------------------------------
const getList = () => { const getList = function () {
listLoading.value = true listLoading.value = true
{FirstTableName}s.getList(firstQuery).then(response => { {FirstTableName}s.getList(firstQuery).then(response => {
mainList.value = response.data mainList.value = response.data
@ -284,72 +225,34 @@
listLoading.value = false listLoading.value = false
}) })
} }
const rowClickFirstTable = row => { const rowClickFirstTable = function (row) {
// 点击行 // 点击行
mainTable.value.clearSelection()
mainTable.value.toggleRowSelection(row)
radio.value = row.id radio.value = row.id
tableName.value = row.id tableName.value = row.tableName
secondQuery.page = 1 secondQuery.page = 1
secondQuery.limit = 10 secondQuery.limit = 10
querySecondList(radio.value) querySecondList(radio.value)
showTitleDetail(row) showTitleDetail(row)
} }
const handleFilter = function () {
const handleSelChangeFirstTable = function (val) {
// multipleSelection.value = val
}
const handleFilter = () => {
firstQuery.page = 1 firstQuery.page = 1
getList() getList()
} }
const handleSizeChange = val => { const handleSizeChange = function (val) {
firstQuery.limit = val firstQuery.limit = val
getList() getList()
} }
const handleCurrentChange = val => { const handleCurrentChange = function (val) {
firstQuery.page = val firstQuery.page = val
getList() getList()
} }
const resetFirstTemp = () => { const resetFirstTemp = function () {
firstHeaderList.value.forEach(item => { firstHeaderList.value.forEach(item => {
firstTemp[item.columnName] = defaultVal(item.entityType) firstTemp[item.columnName] = defaultVal(item.entityType)
}) })
firstTemp.namespace = 'OpenAuth.Repository.Domain' firstTemp.namespace = 'OpenAuth.Repository.Domain'
} }
const createData = () => {
// 保存提交
dataForm.value.validate(() => {
let tempData = Object.assign({}, firstTemp)
tempData = setDetails(tempData)
tempData.OrgId = defaultorgid.value
{FirstTableName}s.add(tempData).then(resp => {
if (resp.result != undefined) {
//如果服务器返回生成的ID
tempData.id = resp.result
}
mainList.value.unshift(tempData)
editModel.value = false
rowClickFirstTable(tempData)
ElNotification({
title: '成功',
message: '创建成功',
type: 'success',
duration: 2000,
})
})
})
}
const showTitleDetail = row => {
// 弹出编辑框
Object.assign(selectRow, row) // 新增订单时保存当前选中行
Object.assign(firstTemp, row) // copy obj
nextTick(() => {
dataForm.value.clearValidate()
})
}
const setDetails = tempData => { const setDetails = tempData => {
// 处理明细 // 处理明细
tempData.{SecondTableName}Reqs = [] tempData.{SecondTableName}Reqs = []
@ -366,7 +269,36 @@
}) })
return tempData return tempData
} }
const updateData = () => {
const createData = function () {
// 保存提交
dataForm.value.validate(() => {
let tempData = Object.assign({}, firstTemp)
tempData = setDetails(tempData)
tempData.OrgId = defaultorgid.value
{FirstTableName}s.add(tempData).then(resp => {
tempData.id = resp.result
mainList.value.unshift(tempData)
editModel.value = false
rowClickFirstTable(tempData)
ElNotification({
title: '成功',
message: '创建成功',
type: 'success',
duration: 2000,
})
})
})
}
const showTitleDetail = function (row) {
// 弹出编辑框
Object.assign(selectRow, row) // 新增订单时保存当前选中行
Object.assign(firstTemp, row) // copy obj
nextTick(() => {
dataForm.value.clearValidate()
})
}
const updateData = function () {
// 更新提交 // 更新提交
dataForm.value.validate(() => { dataForm.value.validate(() => {
let tempData = Object.assign({}, firstTemp) let tempData = Object.assign({}, firstTemp)
@ -389,8 +321,8 @@
}) })
}) })
} }
const handleFirstDel = row => { const handleFirstDel = function (row) {
// 主表删除处理 // 删除头
{FirstTableName}s.del([row.id]).then(() => { {FirstTableName}s.del([row.id]).then(() => {
ElNotification({ ElNotification({
title: '成功', title: '成功',
@ -410,7 +342,7 @@
}) })
} }
// ------------------------明细列表处理------------------------------------- // ------------------------明细列表处理-------------------------------------
const handleSecondPage = e => { const handleSecondPage = function (e) {
secondQuery.page = e secondQuery.page = e
querySecondList(radio.value) querySecondList(radio.value)
} }
@ -427,7 +359,7 @@
secondList.value = res.data secondList.value = res.data
}) })
} }
const rowClickSecondTable = row => { const rowClickSecondTable = function (row) {
// 行点击事件 // 行点击事件
secondTable.value.clearSelection() secondTable.value.clearSelection()
secondTable.value.toggleRowSelection(row) secondTable.value.toggleRowSelection(row)
@ -445,22 +377,12 @@
}) })
}) })
} }
const selChangeSecondTable = val => { const selChangeSecondTable = function (val) {
// 明细选中事件 // 明细选中事件
multipleSelection.value = val multipleSelection.value = val
} }
const handleAddOrderDetail = () => { const handleUpdateDetail = function (item) {
// 添加明细 // 同步表数据结构
const obj = {}
secondHeaderList.value.forEach(header => {
obj[header.columnName] = defaultVal(header.entityType)
})
obj.{ParentTableId} = firstTemp.id
secondList.value.push(Object.assign({}, obj))
}
const handleUpdateDetail = item => {
// 回车保存明细
{SecondTableName}s.update(item).then(() => { {SecondTableName}s.update(item).then(() => {
ElNotification({ ElNotification({
title: '成功', title: '成功',
@ -470,4 +392,4 @@
}) })
}) })
} }
</script> </script>