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 @@
-
+