商品管理: 调整相关组件优化逻辑,完成表单保存和数据回显

(cherry picked from commit 9ee35fc165)
pull/173/head
puhui999 2023-05-03 02:28:35 +08:00 committed by shizhong
parent 2152573c5e
commit 263ca68ff1
9 changed files with 112 additions and 37 deletions

View File

@ -13,3 +13,7 @@ export const createSpu = (data: SpuType) => {
export const updateSpu = (data: SpuType) => {
return request.put({ url: '/product/spu/update', data })
}
// 获得商品spu
export const getSpu = (id: number) => {
return request.get({ url: `/product/spu/get-detail?id=${id}` })
}

View File

@ -11,6 +11,10 @@ export interface Property {
* {@link ProductPropertyValueDO#getId()}
*/
valueId?: number
/**
*
*/
valueName?: string
}
export interface SkuType {

View File

@ -1,6 +1,7 @@
import { SkuType } from './skuType'
export interface SpuType {
id?: number
name?: string // 商品名称
categoryId?: number | null // 商品分类
keyword?: string // 关键字
@ -11,7 +12,7 @@ export interface SpuType {
deliveryTemplateId?: number // 运费模版
specType?: boolean // 商品规格
subCommissionType?: boolean // 分销类型
skus?: SkuType[] // sku数组
skus: SkuType[] // sku数组
description?: string // 商品详情
sort?: string // 商品排序
giveIntegral?: number // 赠送积分

View File

@ -71,8 +71,8 @@ export const getPropertyList = (params: any) => {
}
// 获得属性项列表
export const getPropertyListAndValue = (params: any) => {
return request.get({ url: '/product/property/get-value-list', params })
export const getPropertyListAndValue = (data: any) => {
return request.post({ url: '/product/property/get-value-list', data })
}
// ------------------------ 属性值 -------------------

View File

@ -36,6 +36,7 @@ import { useTagsViewStore } from '@/store/modules/tagsView'
import { BasicInfoForm, DescriptionForm, OtherSettingsForm } from './components'
import type { SpuType } from '@/api/mall/product/management/type/spuType' // api
import * as managementApi from '@/api/mall/product/management/spu'
import * as PropertyApi from '@/api/mall/product/property'
const { t } = useI18n() //
const message = useMessage() //
@ -122,8 +123,20 @@ const formData = ref<SpuType>({
/** 获得详情 */
const getDetail = async () => {
const id = query.id as unknown as number
if (!id) {
return
if (id) {
formLoading.value = true
try {
const res = (await managementApi.getSpu(id)) as SpuType
formData.value = res
// id
const propertyIds = res.skus[0]?.properties.map((item) => item.propertyId)
const PropertyS = await PropertyApi.getPropertyListAndValue({ propertyIds })
await nextTick()
//
BasicInfoRef.value.addAttribute(PropertyS)
} finally {
formLoading.value = false
}
}
}
@ -145,7 +158,7 @@ const submitForm = async () => {
// skusvalue
if (formData.value.specType) {
item.properties.forEach((item2) => {
delete item2.value
delete item2.valueName
})
}
})

View File

@ -131,6 +131,10 @@ const ProductManagementBasicInfoRef = ref() // 表单Ref
const attributeList = ref([]) //
/** 添加商品属性 */
const addAttribute = (property: any) => {
if (Array.isArray(property)) {
attributeList.value = property
return
}
attributeList.value.push(property)
}
const formData = reactive<SpuType>({
@ -191,7 +195,7 @@ const validate = async () => {
}
})
}
defineExpose({ validate })
defineExpose({ validate, addAttribute })
//
const changeSubCommissionType = () => {
@ -203,7 +207,6 @@ const changeSubCommissionType = () => {
}
//
const onChangeSpec = () => {
console.log(111)
//
attributeList.value = []
// sku

View File

@ -1,5 +1,11 @@
<template>
<el-table :data="isBatch ? SkuData : formData.skus" border class="tabNumWidth" size="small">
<el-table
:data="isBatch ? SkuData : formData.skus"
border
class="tabNumWidth"
max-height="500"
size="small"
>
<el-table-column align="center" fixed="left" label="图片" min-width="100">
<template #default="{ row }">
<UploadImg v-model="row.picUrl" height="80px" width="100%" />
@ -15,7 +21,7 @@
min-width="120"
>
<template #default="{ row }">
{{ row.properties[index].value }}
{{ row.properties[index]?.valueName }}
</template>
</el-table-column>
</template>
@ -190,15 +196,28 @@ const generateTableData = (data: any[]) => {
for (const item of data) {
const objList = []
for (const v of item.values) {
const obj = { propertyId: 0, valueId: 0, value: '' }
const obj = { propertyId: 0, valueId: 0, valueName: '' }
obj.propertyId = item.id
obj.valueId = v.id
obj.value = v.name
obj.valueName = v.name
objList.push(obj)
}
propertiesItemList.push(objList)
}
build(propertiesItemList).forEach((item) => {
const buildList = build(propertiesItemList)
// sku,
console.log(
buildList.length === formData.value.skus.length || data.some((item) => item.values.length === 0)
)
if (
buildList.length === formData.value.skus.length ||
data.some((item) => item.values.length === 0)
) {
return
}
//
formData.value!.skus = []
buildList.forEach((item) => {
const row = {
properties: [],
price: 0,
@ -212,6 +231,7 @@ const generateTableData = (data: any[]) => {
subCommissionFirstPrice: 0,
subCommissionSecondPrice: 0
}
//
if (Array.isArray(item)) {
row.properties = item
} else {
@ -269,8 +289,6 @@ watch(
if (JSON.stringify(data) === '[]') return
//
tableHeaderList.value = []
//
formData.value!.skus = []
//
data.forEach((item, index) => {
// nameindex

View File

@ -87,7 +87,7 @@
<el-image
:src="row.picUrl"
style="width: 36px; height: 36px"
@click="imgViewVisible = true"
@click="imagePreview(row.picUrl)"
/>
</div>
</template>
@ -106,11 +106,38 @@
/>
<el-table-column fixed="right" label="状态" min-width="80">
<template #default="{ row }">
<!--TODO 暂时用COMMON_STATUS占位一下使其不报错 -->
<dict-tag :type="DICT_TYPE.PRODUCT_SPU_STATUS" :value="row.status" />
<el-switch
v-model="row.status"
:active-value="0"
:disabled="Number(row.status) < 0"
:inactive-value="1"
active-text="上架"
inactive-text="下架"
inline-prompt
@change="changeStatus(row)"
/>
</template>
</el-table-column>
<el-table-column align="center" fixed="right" label="操作" min-width="150">
<template #default="{ row }">
<el-button
v-hasPermi="['product:spu:query']"
link
type="primary"
@click="openForm(row.id)"
>
修改
</el-button>
<el-button
v-hasPermi="['product:spu:update']"
link
type="primary"
@click="changeStatus(row)"
>
加入回收站
</el-button>
</template>
</el-table-column>
<el-table-column align="center" fixed="right" label="操作" min-width="150" />
</el-table>
<!-- 分页 -->
<Pagination
@ -123,9 +150,7 @@
<!-- 必须在表格外面展示不然单元格会遮挡图层 -->
<el-image-viewer
v-if="imgViewVisible"
:url-list="[
'http://127.0.0.1:48080/admin-api/infra/file/4/get/6ffdf8f5dfc03f7ceec1ff1ebc138adb8b721a057d505ccfb0e61a8783af1371.png'
]"
:url-list="imageViewerList"
@close="imgViewVisible = false"
/>
</template>
@ -166,7 +191,8 @@ const headerNum = ref([
type: 5
}
])
const imgViewVisible = ref(false)
const imgViewVisible = ref(false) //
const imageViewerList = ref<string[]>([]) //
const queryParams = reactive({
pageNo: 1,
pageSize: 10
@ -184,7 +210,21 @@ const getList = async () => {
loading.value = false
}
}
/**
* 更改SPU状态
* @param row
*/
const changeStatus = (row) => {
console.log(row)
}
/**
* 商品图预览
* @param imgUrl
*/
const imagePreview = (imgUrl: string) => {
imageViewerList.value = [imgUrl]
imgViewVisible.value = true
}
/** 搜索按钮操作 */
const handleQuery = () => {
getList()
@ -196,26 +236,18 @@ const resetQuery = () => {
handleQuery()
}
/**
* 新增或修改
* @param id
*/
const openForm = (id?: number) => {
if (typeof id === 'number') {
push('/product/productManagementAdd?id=' + id)
return
}
push('/product/productManagementAdd')
}
/** 删除按钮操作 */
// const handleDelete = async (id: number) => {
// try {
// //
// await message.delConfirm()
// //
// await ProductBrandApi.deleteBrand(id)
// message.success(t('common.delSuccess'))
// //
// await getList()
// } catch {}
// }
/** 初始化 **/
onMounted(() => {
getList()