code review:商品管理
This commit is contained in:
parent
541b23c8c1
commit
158585670c
@ -306,11 +306,14 @@ export const handleTree2 = (data, id, parentId, children, rootId) => {
|
|||||||
})
|
})
|
||||||
return treeData !== '' ? treeData : data
|
return treeData !== '' ? treeData : data
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* 校验选中的节点,是否为指定 level
|
||||||
*
|
*
|
||||||
* @param tree 要操作的树结构数据
|
* @param tree 要操作的树结构数据
|
||||||
* @param nodeId 需要判断在什么层级的数据
|
* @param nodeId 需要判断在什么层级的数据
|
||||||
* @param level 检查的级别, 默认检查到二级
|
* @param level 检查的级别, 默认检查到二级
|
||||||
|
* @return true 是;false 否
|
||||||
*/
|
*/
|
||||||
export const checkSelectedNode = (tree: any[], nodeId: any, level = 2): boolean => {
|
export const checkSelectedNode = (tree: any[], nodeId: any, level = 2): boolean => {
|
||||||
if (typeof tree === 'undefined' || !Array.isArray(tree) || tree.length === 0) {
|
if (typeof tree === 'undefined' || !Array.isArray(tree) || tree.length === 0) {
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
<template>
|
<template>
|
||||||
|
<!-- 情况一:添加/修改 -->
|
||||||
<el-form
|
<el-form
|
||||||
v-if="!isDetail"
|
v-if="!isDetail"
|
||||||
ref="productSpuBasicInfoRef"
|
ref="productSpuBasicInfoRef"
|
||||||
@ -23,7 +24,7 @@
|
|||||||
class="w-1/1"
|
class="w-1/1"
|
||||||
node-key="id"
|
node-key="id"
|
||||||
placeholder="请选择商品分类"
|
placeholder="请选择商品分类"
|
||||||
@change="nodeClick"
|
@change="categoryNodeClick"
|
||||||
/>
|
/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
@ -126,8 +127,8 @@
|
|||||||
</el-col>
|
</el-col>
|
||||||
</el-row>
|
</el-row>
|
||||||
</el-form>
|
</el-form>
|
||||||
<ProductAttributesAddForm ref="attributesAddFormRef" :propertyList="propertyList" />
|
|
||||||
<!-- 详情跟表单放在一块可以共用已有功能,再抽离成组件有点过度封装的感觉 -->
|
<!-- 情况二:详情 -->
|
||||||
<Descriptions v-if="isDetail" :data="formData" :schema="allSchemas.detailSchema">
|
<Descriptions v-if="isDetail" :data="formData" :schema="allSchemas.detailSchema">
|
||||||
<template #categoryId="{ row }"> {{ categoryString(row.categoryId) }}</template>
|
<template #categoryId="{ row }"> {{ categoryString(row.categoryId) }}</template>
|
||||||
<template #brandId="{ row }">
|
<template #brandId="{ row }">
|
||||||
@ -163,6 +164,10 @@
|
|||||||
/>
|
/>
|
||||||
</template>
|
</template>
|
||||||
</Descriptions>
|
</Descriptions>
|
||||||
|
|
||||||
|
<!-- 商品属性添加 Form 表单 -->
|
||||||
|
<!-- TODO @puhui999: ProductPropertyAddForm 是不是更合适呀 -->
|
||||||
|
<ProductAttributesAddForm ref="attributesAddFormRef" :propertyList="propertyList" />
|
||||||
</template>
|
</template>
|
||||||
<script lang="ts" name="ProductSpuBasicInfoForm" setup>
|
<script lang="ts" name="ProductSpuBasicInfoForm" setup>
|
||||||
import { PropType } from 'vue'
|
import { PropType } from 'vue'
|
||||||
@ -257,7 +262,9 @@ watch(
|
|||||||
url: item
|
url: item
|
||||||
}))
|
}))
|
||||||
// 只有是多规格才处理
|
// 只有是多规格才处理
|
||||||
if (!formData.specType) return
|
if (!formData.specType) {
|
||||||
|
return
|
||||||
|
}
|
||||||
// 直接拿返回的 skus 属性逆向生成出 propertyList
|
// 直接拿返回的 skus 属性逆向生成出 propertyList
|
||||||
const properties = []
|
const properties = []
|
||||||
formData.skus.forEach((sku) => {
|
formData.skus.forEach((sku) => {
|
||||||
@ -340,7 +347,7 @@ const categoryList = ref([]) // 分类树
|
|||||||
/**
|
/**
|
||||||
* 选择分类时触发校验
|
* 选择分类时触发校验
|
||||||
*/
|
*/
|
||||||
const nodeClick = () => {
|
const categoryNodeClick = () => {
|
||||||
if (!checkSelectedNode(categoryList.value, formData.categoryId)) {
|
if (!checkSelectedNode(categoryList.value, formData.categoryId)) {
|
||||||
formData.categoryId = null
|
formData.categoryId = null
|
||||||
message.warning('必须选择二级及以下节点!!')
|
message.warning('必须选择二级及以下节点!!')
|
||||||
@ -348,6 +355,7 @@ const nodeClick = () => {
|
|||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* 获取分类的节点的完整结构
|
* 获取分类的节点的完整结构
|
||||||
|
*
|
||||||
* @param categoryId 分类id
|
* @param categoryId 分类id
|
||||||
*/
|
*/
|
||||||
const categoryString = (categoryId) => {
|
const categoryString = (categoryId) => {
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
<template>
|
<template>
|
||||||
|
<!-- 情况一:添加/修改 -->
|
||||||
<el-form
|
<el-form
|
||||||
v-if="!isDetail"
|
v-if="!isDetail"
|
||||||
ref="descriptionFormRef"
|
ref="descriptionFormRef"
|
||||||
@ -11,6 +12,8 @@
|
|||||||
<Editor v-model:modelValue="formData.description" />
|
<Editor v-model:modelValue="formData.description" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
|
|
||||||
|
<!-- 情况二:详情 -->
|
||||||
<Descriptions
|
<Descriptions
|
||||||
v-if="isDetail"
|
v-if="isDetail"
|
||||||
:data="formData"
|
:data="formData"
|
||||||
@ -30,10 +33,9 @@ import { PropType } from 'vue'
|
|||||||
import { propTypes } from '@/utils/propTypes'
|
import { propTypes } from '@/utils/propTypes'
|
||||||
import { copyValueToTarget } from '@/utils'
|
import { copyValueToTarget } from '@/utils'
|
||||||
import { descriptionSchema } from './spu.data'
|
import { descriptionSchema } from './spu.data'
|
||||||
|
const message = useMessage() // 消息弹窗
|
||||||
|
|
||||||
const { allSchemas } = useCrudSchemas(descriptionSchema)
|
const { allSchemas } = useCrudSchemas(descriptionSchema)
|
||||||
|
|
||||||
const message = useMessage() // 消息弹窗
|
|
||||||
const props = defineProps({
|
const props = defineProps({
|
||||||
propFormData: {
|
propFormData: {
|
||||||
type: Object as PropType<Spu>,
|
type: Object as PropType<Spu>,
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
<template>
|
<template>
|
||||||
|
<!-- 情况一:添加/修改 -->
|
||||||
<el-form
|
<el-form
|
||||||
v-if="!isDetail"
|
v-if="!isDetail"
|
||||||
ref="otherSettingsFormRef"
|
ref="otherSettingsFormRef"
|
||||||
@ -56,6 +57,8 @@
|
|||||||
</el-col>
|
</el-col>
|
||||||
</el-row>
|
</el-row>
|
||||||
</el-form>
|
</el-form>
|
||||||
|
|
||||||
|
<!-- 情况二:详情 -->
|
||||||
<Descriptions v-if="isDetail" :data="formData" :schema="allSchemas.detailSchema">
|
<Descriptions v-if="isDetail" :data="formData" :schema="allSchemas.detailSchema">
|
||||||
<template #recommendHot="{ row }">
|
<template #recommendHot="{ row }">
|
||||||
{{ row.recommendHot ? '是' : '否' }}
|
{{ row.recommendHot ? '是' : '否' }}
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
<template>
|
<template>
|
||||||
|
<!-- 情况一:添加/修改 -->
|
||||||
<el-table
|
<el-table
|
||||||
v-if="!isDetail"
|
v-if="!isDetail"
|
||||||
:data="isBatch ? skuList : formData!.skus"
|
:data="isBatch ? skuList : formData!.skus"
|
||||||
@ -109,6 +110,8 @@
|
|||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
</el-table>
|
</el-table>
|
||||||
|
|
||||||
|
<!-- 情况二:详情 -->
|
||||||
<el-table
|
<el-table
|
||||||
v-if="isDetail"
|
v-if="isDetail"
|
||||||
:data="formData!.skus"
|
:data="formData!.skus"
|
||||||
@ -132,7 +135,6 @@
|
|||||||
min-width="80"
|
min-width="80"
|
||||||
>
|
>
|
||||||
<template #default="{ row }">
|
<template #default="{ row }">
|
||||||
<!-- TODO puhui999:展示成蓝色,有点区分度哈 fix-->
|
|
||||||
<span style="font-weight: bold; color: #40aaff">
|
<span style="font-weight: bold; color: #40aaff">
|
||||||
{{ row.properties[index]?.valueName }}
|
{{ row.properties[index]?.valueName }}
|
||||||
</span>
|
</span>
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
import { CrudSchema } from '@/hooks/web/useCrudSchemas'
|
import { CrudSchema } from '@/hooks/web/useCrudSchemas'
|
||||||
|
|
||||||
|
// TODO @puhui999:如果只要 detail,可以不用 CrudSchema,只要描述的 Schema
|
||||||
export const basicInfoSchema = reactive<CrudSchema[]>([
|
export const basicInfoSchema = reactive<CrudSchema[]>([
|
||||||
{
|
{
|
||||||
label: '商品名称',
|
label: '商品名称',
|
||||||
|
@ -171,7 +171,6 @@
|
|||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column align="center" fixed="right" label="操作" min-width="200">
|
<el-table-column align="center" fixed="right" label="操作" min-width="200">
|
||||||
<template #default="{ row }">
|
<template #default="{ row }">
|
||||||
<!-- TODO @puhui999:【详情】,可以后面点做哈 fix-->
|
|
||||||
<el-button
|
<el-button
|
||||||
v-hasPermi="['product:spu:update']"
|
v-hasPermi="['product:spu:update']"
|
||||||
link
|
link
|
||||||
|
Loading…
Reference in New Issue
Block a user