REVIEW 租户套餐
parent
216ad84938
commit
84ab75b475
|
@ -33,7 +33,6 @@
|
||||||
<el-tree
|
<el-tree
|
||||||
ref="treeRef"
|
ref="treeRef"
|
||||||
node-key="id"
|
node-key="id"
|
||||||
:check-strictly="!menuCheckStrictly"
|
|
||||||
show-checkbox
|
show-checkbox
|
||||||
:props="defaultProps"
|
:props="defaultProps"
|
||||||
:data="menuOptions"
|
:data="menuOptions"
|
||||||
|
@ -91,7 +90,6 @@ const formRules = reactive({
|
||||||
})
|
})
|
||||||
const formRef = ref() // 表单 Ref
|
const formRef = ref() // 表单 Ref
|
||||||
const menuOptions = ref<any[]>([]) // 树形结构数据
|
const menuOptions = ref<any[]>([]) // 树形结构数据
|
||||||
const menuCheckStrictly = ref(false) // 在显示复选框的情况下,是否严格的遵循父子不互相关联的做法,默认为 true
|
|
||||||
const menuExpand = ref(false) // 展开/折叠
|
const menuExpand = ref(false) // 展开/折叠
|
||||||
const treeRef = ref<InstanceType<typeof ElTree>>() // 树组件Ref
|
const treeRef = ref<InstanceType<typeof ElTree>>() // 树组件Ref
|
||||||
const treeNodeAll = ref(false) // 全选/全不选
|
const treeNodeAll = ref(false) // 全选/全不选
|
||||||
|
@ -102,6 +100,8 @@ const open = async (type: string, id?: number) => {
|
||||||
modelTitle.value = t('action.' + type)
|
modelTitle.value = t('action.' + type)
|
||||||
formType.value = type
|
formType.value = type
|
||||||
resetForm()
|
resetForm()
|
||||||
|
// 加载 Menu 列表。注意,必须放在前面,不然下面 setChecked 没数据节点
|
||||||
|
menuOptions.value = handleTree(await MenuApi.getSimpleMenusList())
|
||||||
// 修改时,设置数据
|
// 修改时,设置数据
|
||||||
if (id) {
|
if (id) {
|
||||||
formLoading.value = true
|
formLoading.value = true
|
||||||
|
@ -110,15 +110,13 @@ const open = async (type: string, id?: number) => {
|
||||||
// 设置选中
|
// 设置选中
|
||||||
formData.value = res
|
formData.value = res
|
||||||
// 设置选中
|
// 设置选中
|
||||||
res.menuIds?.forEach((item: any) => {
|
res.menuIds.forEach((menuId: number) => {
|
||||||
treeRef.value?.setChecked(item, true, false)
|
treeRef.value.setChecked(menuId, true, false)
|
||||||
})
|
})
|
||||||
} finally {
|
} finally {
|
||||||
formLoading.value = false
|
formLoading.value = false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// 加载Menu列表
|
|
||||||
menuOptions.value = handleTree(await MenuApi.getSimpleMenusList())
|
|
||||||
}
|
}
|
||||||
defineExpose({ open }) // 提供 open 方法,用于打开弹窗
|
defineExpose({ open }) // 提供 open 方法,用于打开弹窗
|
||||||
|
|
||||||
|
@ -134,8 +132,8 @@ const submitForm = async () => {
|
||||||
try {
|
try {
|
||||||
const data = formData.value as unknown as TenantPackageApi.TenantPackageVO
|
const data = formData.value as unknown as TenantPackageApi.TenantPackageVO
|
||||||
data.menuIds = [
|
data.menuIds = [
|
||||||
...(treeRef.value!.getCheckedKeys(false) as unknown as Array<number>),
|
...(treeRef.value!.getCheckedKeys(false) as unknown as Array<number>), // 获得当前选中节点
|
||||||
...(treeRef.value!.getHalfCheckedKeys() as unknown as Array<number>)
|
...(treeRef.value!.getHalfCheckedKeys() as unknown as Array<number>) // 获得半选中的父节点
|
||||||
]
|
]
|
||||||
if (formType.value === 'create') {
|
if (formType.value === 'create') {
|
||||||
await TenantPackageApi.createTenantPackage(data)
|
await TenantPackageApi.createTenantPackage(data)
|
||||||
|
@ -154,6 +152,10 @@ const submitForm = async () => {
|
||||||
|
|
||||||
/** 重置表单 */
|
/** 重置表单 */
|
||||||
const resetForm = () => {
|
const resetForm = () => {
|
||||||
|
// 重置选项
|
||||||
|
treeNodeAll.value = false
|
||||||
|
menuExpand.value = false
|
||||||
|
// 重置表单
|
||||||
formData.value = {
|
formData.value = {
|
||||||
id: null,
|
id: null,
|
||||||
name: null,
|
name: null,
|
||||||
|
@ -162,10 +164,6 @@ const resetForm = () => {
|
||||||
status: CommonStatusEnum.ENABLE
|
status: CommonStatusEnum.ENABLE
|
||||||
}
|
}
|
||||||
treeRef.value?.setCheckedNodes([])
|
treeRef.value?.setCheckedNodes([])
|
||||||
treeNodeAll.value = false
|
|
||||||
menuExpand.value = false
|
|
||||||
// 设置为非严格,继续使用半选中
|
|
||||||
menuCheckStrictly.value = false
|
|
||||||
formRef.value?.resetFields()
|
formRef.value?.resetFields()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -173,6 +171,7 @@ const resetForm = () => {
|
||||||
const handleCheckedTreeNodeAll = () => {
|
const handleCheckedTreeNodeAll = () => {
|
||||||
treeRef.value!.setCheckedNodes(treeNodeAll.value ? menuOptions.value : [])
|
treeRef.value!.setCheckedNodes(treeNodeAll.value ? menuOptions.value : [])
|
||||||
}
|
}
|
||||||
|
|
||||||
// 全部(展开/折叠)TODO:for循环全部展开和折叠树组件数据
|
// 全部(展开/折叠)TODO:for循环全部展开和折叠树组件数据
|
||||||
const handleCheckedTreeExpand = () => {
|
const handleCheckedTreeExpand = () => {
|
||||||
const nodes = treeRef.value?.store.nodesMap
|
const nodes = treeRef.value?.store.nodesMap
|
||||||
|
|
Loading…
Reference in New Issue