diff --git a/src/views/mall/product/category/CategoryForm.vue b/src/views/mall/product/category/CategoryForm.vue index 8e89ae25b655b9b71f28a4e7c9a57b99086b3b1c..a702c661972e975b04b714d97a924482e750675d 100644 --- a/src/views/mall/product/category/CategoryForm.vue +++ b/src/views/mall/product/category/CategoryForm.vue @@ -8,15 +8,14 @@ v-loading="formLoading" > - - - - + @@ -50,6 +49,7 @@ import { DICT_TYPE, getIntDictOptions } from '@/utils/dict' import { CommonStatusEnum } from '@/utils/constants' import * as ProductCategoryApi from '@/api/mall/product/category' +import { defaultProps, handleTree } from "@/utils/tree"; defineOptions({ name: 'ProductCategory' }) @@ -69,12 +69,20 @@ const formData = ref({ const formRules = reactive({ parentId: [{ required: true, message: '请选择上级分类', trigger: 'blur' }], name: [{ required: true, message: '分类名称不能为空', trigger: 'blur' }], - picUrl: [{ required: true, message: '分类图片不能为空', trigger: 'blur' }], sort: [{ required: true, message: '分类排序不能为空', trigger: 'blur' }], status: [{ required: true, message: '开启状态不能为空', trigger: 'blur' }] }) const formRef = ref() // 表单 Ref -const categoryList = ref([]) // 分类树 +/** 获取下拉框[上级分类]的数据 */ +const categoryTree = ref([]) // 树形结构 + +const getCategoryTree = async () => { + categoryTree.value = [] + const res = await ProductCategoryApi.getCategoryList(null) + let category: Tree = {id: 0, name: '顶级分类', children: []} + category.children = handleTree(res) + categoryTree.value.push(category) +} /** 打开弹窗 */ const open = async (type: string, id?: number) => { @@ -92,7 +100,7 @@ const open = async (type: string, id?: number) => { } } // 获得分类树 - categoryList.value = await ProductCategoryApi.getCategoryList({ parentId: 0 }) + await getCategoryTree() } defineExpose({ open }) // 提供 open 方法,用于打开弹窗 diff --git a/src/views/mall/product/category/index.vue b/src/views/mall/product/category/index.vue index a47684b5c9c08d78d1aa234c3a1ab904085b79d7..2b51fd8627e2d50400daa0f77c62e445d4585b67 100644 --- a/src/views/mall/product/category/index.vue +++ b/src/views/mall/product/category/index.vue @@ -40,7 +40,7 @@