|
|
|
|
@ -0,0 +1,952 @@
|
|
|
|
|
<template>
|
|
|
|
|
<div style="margin-top: 50px">
|
|
|
|
|
<el-form :model="value" ref="productAttrForm" label-width="120px" class="form-inner-container" size="small">
|
|
|
|
|
<el-form-item label="属性类型:">
|
|
|
|
|
<el-select v-model="value.productAttributeCategoryId"
|
|
|
|
|
placeholder="请选择属性类型"
|
|
|
|
|
@change="handleProductAttrChange">
|
|
|
|
|
<el-option
|
|
|
|
|
v-for="item in productAttributeCategoryOptions"
|
|
|
|
|
:key="item.value"
|
|
|
|
|
:label="item.label"
|
|
|
|
|
:value="item.value">
|
|
|
|
|
</el-option>
|
|
|
|
|
</el-select>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item label="商品规格:">
|
|
|
|
|
<el-card shadow="never" class="cardBg">
|
|
|
|
|
<div v-for="(productAttr,idx) in selectProductAttr">
|
|
|
|
|
{{productAttr.name}}:
|
|
|
|
|
<el-checkbox-group v-if="productAttr.handAddStatus===0" v-model="selectProductAttr[idx].values">
|
|
|
|
|
<el-checkbox v-for="item in getInputListArr(productAttr.inputList)" :label="item" :key="item"
|
|
|
|
|
class="littleMarginLeft"></el-checkbox>
|
|
|
|
|
</el-checkbox-group>
|
|
|
|
|
<div v-else>
|
|
|
|
|
<el-checkbox-group v-model="selectProductAttr[idx].values">
|
|
|
|
|
<div v-for="(item,index) in selectProductAttr[idx].options" style="display: inline-block"
|
|
|
|
|
class="littleMarginLeft">
|
|
|
|
|
<el-checkbox :label="item" :key="item"></el-checkbox>
|
|
|
|
|
<el-button type="text" class="littleMarginLeft" @click="handleRemoveProductAttrValue(idx,index)">删除
|
|
|
|
|
</el-button>
|
|
|
|
|
</div>
|
|
|
|
|
</el-checkbox-group>
|
|
|
|
|
<el-input v-model="addProductAttrValue" style="width: 160px;margin-left: 10px" clearable></el-input>
|
|
|
|
|
<el-button class="littleMarginLeft" @click="handleAddProductAttrValue(idx)">增加</el-button>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</el-card>
|
|
|
|
|
<el-table style="width: 100%;margin-top: 20px"
|
|
|
|
|
:data="value.skuStockList"
|
|
|
|
|
border>
|
|
|
|
|
<el-table-column
|
|
|
|
|
v-for="(item,index) in selectProductAttr"
|
|
|
|
|
:label="item.name"
|
|
|
|
|
:key="item.id"
|
|
|
|
|
align="center">
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
{{getProductSkuSp(scope.row,index)}}
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
<el-table-column
|
|
|
|
|
label="销售价格"
|
|
|
|
|
width="100"
|
|
|
|
|
align="center">
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<el-input v-model="scope.row.price"></el-input>
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
<el-table-column
|
|
|
|
|
label="促销价格"
|
|
|
|
|
width="100"
|
|
|
|
|
align="center">
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<el-input v-model="scope.row.promotionPrice"></el-input>
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
<el-table-column
|
|
|
|
|
label="商品库存"
|
|
|
|
|
width="80"
|
|
|
|
|
align="center">
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<el-input v-model="scope.row.stock"></el-input>
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
<el-table-column
|
|
|
|
|
label="库存预警值"
|
|
|
|
|
width="80"
|
|
|
|
|
align="center">
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<el-input v-model="scope.row.lowStock"></el-input>
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
<el-table-column
|
|
|
|
|
label="SKU编号"
|
|
|
|
|
width="160"
|
|
|
|
|
align="center">
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<el-input v-model="scope.row.skuCode"></el-input>
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
<el-table-column
|
|
|
|
|
label="操作"
|
|
|
|
|
width="80"
|
|
|
|
|
align="center">
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<el-button
|
|
|
|
|
type="text"
|
|
|
|
|
@click="handleRemoveProductSku(scope.$index, scope.row)">删除
|
|
|
|
|
</el-button>
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
</el-table>
|
|
|
|
|
<el-button
|
|
|
|
|
type="primary"
|
|
|
|
|
style="margin-top: 20px"
|
|
|
|
|
@click="handleRefreshProductSkuList">刷新列表
|
|
|
|
|
</el-button>
|
|
|
|
|
<el-button
|
|
|
|
|
type="primary"
|
|
|
|
|
style="margin-top: 20px"
|
|
|
|
|
@click="handleSyncProductSkuPrice">同步价格
|
|
|
|
|
</el-button>
|
|
|
|
|
<el-button
|
|
|
|
|
type="primary"
|
|
|
|
|
style="margin-top: 20px"
|
|
|
|
|
@click="handleSyncProductSkuStock">同步库存
|
|
|
|
|
</el-button>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item label="属性图片:" v-if="hasAttrPic">
|
|
|
|
|
<el-card shadow="never" class="cardBg">
|
|
|
|
|
<div v-for="(item,index) in selectProductAttrPics">
|
|
|
|
|
<span>{{item.name}}:</span>
|
|
|
|
|
<single-upload v-model="item.pic"
|
|
|
|
|
style="width: 300px;display: inline-block;margin-left: 10px"></single-upload>
|
|
|
|
|
</div>
|
|
|
|
|
</el-card>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item label="商品参数:">
|
|
|
|
|
<el-card shadow="never" class="cardBg">
|
|
|
|
|
<div v-for="(item,index) in selectProductParam" :class="{littleMarginTop:index!==0}">
|
|
|
|
|
<div class="paramInputLabel">{{item.name}}:</div>
|
|
|
|
|
<el-select v-if="item.inputType===1" class="paramInput" v-model="selectProductParam[index].value">
|
|
|
|
|
<el-option
|
|
|
|
|
v-for="item in getParamInputList(item.inputList)"
|
|
|
|
|
:key="item"
|
|
|
|
|
:label="item"
|
|
|
|
|
:value="item">
|
|
|
|
|
</el-option>
|
|
|
|
|
</el-select>
|
|
|
|
|
<el-input v-else class="paramInput" v-model="selectProductParam[index].value"></el-input>
|
|
|
|
|
</div>
|
|
|
|
|
</el-card>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item label="商品相册:">
|
|
|
|
|
<multi-upload v-model="selectProductPics"></multi-upload>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item label="商品详情:">
|
|
|
|
|
<el-tabs v-model="activeHtmlName" type="card">
|
|
|
|
|
<el-tab-pane label="电脑端详情" name="pc">
|
|
|
|
|
<tinymce :width="595" :height="300" v-model="value.detailHtml"></tinymce>
|
|
|
|
|
</el-tab-pane>
|
|
|
|
|
<el-tab-pane label="移动端详情" name="mobile">
|
|
|
|
|
<tinymce :width="595" :height="300" v-model="value.detailMobileHtml"></tinymce>
|
|
|
|
|
</el-tab-pane>
|
|
|
|
|
</el-tabs>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item style="text-align: center">
|
|
|
|
|
<el-button size="medium" @click="handlePrev">上一步,填写商品促销</el-button>
|
|
|
|
|
<el-button type="primary" size="medium" @click="handleNext">下一步,选择商品关联</el-button>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
</el-form>
|
|
|
|
|
</div>
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script>
|
|
|
|
|
import {fetchList as fetchProductAttrCateList} from '@/api/productAttrCate'
|
|
|
|
|
import {fetchList as fetchProductAttrList} from '@/api/productAttr'
|
|
|
|
|
import SingleUpload from '@/components/Upload/singleUpload'
|
|
|
|
|
import MultiUpload from '@/components/Upload/multiUpload'
|
|
|
|
|
import Tinymce from '@/components/Tinymce'
|
|
|
|
|
|
|
|
|
|
export default {
|
|
|
|
|
name: "ProductAttrDetail",
|
|
|
|
|
components: {SingleUpload, MultiUpload, Tinymce},
|
|
|
|
|
props: {
|
|
|
|
|
value: Object,
|
|
|
|
|
isEdit: {
|
|
|
|
|
type: Boolean,
|
|
|
|
|
default: false
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
data() {
|
|
|
|
|
return {
|
|
|
|
|
//编辑模式时是否初始化成功
|
|
|
|
|
hasEditCreated:false,
|
|
|
|
|
//商品属性分类下拉选项
|
|
|
|
|
productAttributeCategoryOptions: [],
|
|
|
|
|
//选中的商品属性
|
|
|
|
|
selectProductAttr: [],
|
|
|
|
|
//选中的商品参数
|
|
|
|
|
selectProductParam: [],
|
|
|
|
|
//选中的商品属性图片
|
|
|
|
|
selectProductAttrPics: [],
|
|
|
|
|
//可手动添加的商品属性
|
|
|
|
|
addProductAttrValue: '',
|
|
|
|
|
//商品富文本详情激活类型
|
|
|
|
|
activeHtmlName: 'pc'
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
computed: {
|
|
|
|
|
//是否有商品属性图片
|
|
|
|
|
hasAttrPic() {
|
|
|
|
|
if (this.selectProductAttrPics.length < 1) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
return true;
|
|
|
|
|
},
|
|
|
|
|
//商品的编号
|
|
|
|
|
productId(){
|
|
|
|
|
return this.value.id;
|
|
|
|
|
},
|
|
|
|
|
//商品的主图和画册图片
|
|
|
|
|
selectProductPics:{
|
|
|
|
|
get:function () {
|
|
|
|
|
let pics=[];
|
|
|
|
|
if(this.value.pic===undefined||this.value.pic==null||this.value.pic===''){
|
|
|
|
|
return pics;
|
|
|
|
|
}
|
|
|
|
|
pics.push(this.value.pic);
|
|
|
|
|
if(this.value.albumPics===undefined||this.value.albumPics==null||this.value.albumPics===''){
|
|
|
|
|
return pics;
|
|
|
|
|
}
|
|
|
|
|
let albumPics = this.value.albumPics.split(',');
|
|
|
|
|
for(let i=0;i<albumPics.length;i++){
|
|
|
|
|
pics.push(albumPics[i]);
|
|
|
|
|
}
|
|
|
|
|
return pics;
|
|
|
|
|
},
|
|
|
|
|
set:function (newValue) {
|
|
|
|
|
if (newValue == null || newValue.length === 0) {
|
|
|
|
|
this.value.pic = null;
|
|
|
|
|
this.value.albumPics = null;
|
|
|
|
|
} else {
|
|
|
|
|
this.value.pic = newValue[0];
|
|
|
|
|
this.value.albumPics = '';
|
|
|
|
|
if (newValue.length > 1) {
|
|
|
|
|
for (let i = 1; i < newValue.length; i++) {
|
|
|
|
|
this.value.albumPics += newValue[i];
|
|
|
|
|
if (i !== newValue.length - 1) {
|
|
|
|
|
this.value.albumPics += ',';
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
created() {
|
|
|
|
|
this.getProductAttrCateList();
|
|
|
|
|
},
|
|
|
|
|
watch: {
|
|
|
|
|
productId:function (newValue) {
|
|
|
|
|
if(!this.isEdit)return;
|
|
|
|
|
if(this.hasEditCreated)return;
|
|
|
|
|
if(newValue===undefined||newValue==null||newValue===0)return;
|
|
|
|
|
this.handleEditCreated();
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
methods: {
|
|
|
|
|
handleEditCreated() {
|
|
|
|
|
//根据商品属性分类id获取属性和参数
|
|
|
|
|
if(this.value.productAttributeCategoryId!=null){
|
|
|
|
|
this.handleProductAttrChange(this.value.productAttributeCategoryId);
|
|
|
|
|
}
|
|
|
|
|
this.hasEditCreated=true;
|
|
|
|
|
},
|
|
|
|
|
getProductAttrCateList() {
|
|
|
|
|
let param = {pageNum: 1, pageSize: 100};
|
|
|
|
|
fetchProductAttrCateList(param).then(response => {
|
|
|
|
|
this.productAttributeCategoryOptions = [];
|
|
|
|
|
let list = response.data.list;
|
|
|
|
|
for (let i = 0; i < list.length; i++) {
|
|
|
|
|
this.productAttributeCategoryOptions.push({label: list[i].name, value: list[i].id});
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
getProductAttrList(type, cid) {
|
|
|
|
|
let param = {pageNum: 1, pageSize: 100, type: type};
|
|
|
|
|
fetchProductAttrList(cid, param).then(response => {
|
|
|
|
|
let list = response.data.list;
|
|
|
|
|
if (type === 0) {
|
|
|
|
|
this.selectProductAttr = [];
|
|
|
|
|
for (let i = 0; i < list.length; i++) {
|
|
|
|
|
let options = [];
|
|
|
|
|
let values = [];
|
|
|
|
|
if (this.isEdit) {
|
|
|
|
|
if (list[i].handAddStatus === 1) {
|
|
|
|
|
//编辑状态下获取手动添加编辑属性
|
|
|
|
|
options = this.getEditAttrOptions(list[i].id);
|
|
|
|
|
}
|
|
|
|
|
//编辑状态下获取选中属性
|
|
|
|
|
values = this.getEditAttrValues(i);
|
|
|
|
|
}
|
|
|
|
|
this.selectProductAttr.push({
|
|
|
|
|
id: list[i].id,
|
|
|
|
|
name: list[i].name,
|
|
|
|
|
handAddStatus: list[i].handAddStatus,
|
|
|
|
|
inputList: list[i].inputList,
|
|
|
|
|
values: values,
|
|
|
|
|
options: options
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
if(this.isEdit){
|
|
|
|
|
//编辑模式下刷新商品属性图片
|
|
|
|
|
this.refreshProductAttrPics();
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
this.selectProductParam = [];
|
|
|
|
|
for (let i = 0; i < list.length; i++) {
|
|
|
|
|
let value=null;
|
|
|
|
|
if(this.isEdit){
|
|
|
|
|
//编辑模式下获取参数属性
|
|
|
|
|
value= this.getEditParamValue(list[i].id);
|
|
|
|
|
}
|
|
|
|
|
this.selectProductParam.push({
|
|
|
|
|
id: list[i].id,
|
|
|
|
|
name: list[i].name,
|
|
|
|
|
value: value,
|
|
|
|
|
inputType: list[i].inputType,
|
|
|
|
|
inputList: list[i].inputList
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
//获取设置的可手动添加属性值
|
|
|
|
|
getEditAttrOptions(id) {
|
|
|
|
|
let options = [];
|
|
|
|
|
for (let i = 0; i < this.value.productAttributeValueList.length; i++) {
|
|
|
|
|
let attrValue = this.value.productAttributeValueList[i];
|
|
|
|
|
if (attrValue.productAttributeId === id) {
|
|
|
|
|
let strArr = attrValue.value.split(',');
|
|
|
|
|
for (let j = 0; j < strArr.length; j++) {
|
|
|
|
|
options.push(strArr[j]);
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return options;
|
|
|
|
|
},
|
|
|
|
|
//获取选中的属性值
|
|
|
|
|
getEditAttrValues(index) {
|
|
|
|
|
let values = new Set();
|
|
|
|
|
if (index === 0) {
|
|
|
|
|
for (let i = 0; i < this.value.skuStockList.length; i++) {
|
|
|
|
|
let sku = this.value.skuStockList[i];
|
|
|
|
|
let spData = JSON.parse(sku.spData);
|
|
|
|
|
if (spData!= null && spData.length>=1) {
|
|
|
|
|
values.add(spData[0].value);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
} else if (index === 1) {
|
|
|
|
|
for (let i = 0; i < this.value.skuStockList.length; i++) {
|
|
|
|
|
let sku = this.value.skuStockList[i];
|
|
|
|
|
let spData = JSON.parse(sku.spData);
|
|
|
|
|
if (spData!= null && spData.length>=2) {
|
|
|
|
|
values.add(spData[1].value);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
for (let i = 0; i < this.value.skuStockList.length; i++) {
|
|
|
|
|
let sku = this.value.skuStockList[i];
|
|
|
|
|
let spData = JSON.parse(sku.spData);
|
|
|
|
|
if (spData!= null && spData.length>=3) {
|
|
|
|
|
values.add(spData[2].value);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return Array.from(values);
|
|
|
|
|
},
|
|
|
|
|
//获取属性的值
|
|
|
|
|
getEditParamValue(id){
|
|
|
|
|
for(let i=0;i<this.value.productAttributeValueList.length;i++){
|
|
|
|
|
if(id===this.value.productAttributeValueList[i].productAttributeId){
|
|
|
|
|
return this.value.productAttributeValueList[i].value;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
handleProductAttrChange(value) {
|
|
|
|
|
this.getProductAttrList(0, value);
|
|
|
|
|
this.getProductAttrList(1, value);
|
|
|
|
|
},
|
|
|
|
|
getInputListArr(inputList) {
|
|
|
|
|
return inputList.split(',');
|
|
|
|
|
},
|
|
|
|
|
handleAddProductAttrValue(idx) {
|
|
|
|
|
let options = this.selectProductAttr[idx].options;
|
|
|
|
|
if (this.addProductAttrValue == null || this.addProductAttrValue == '') {
|
|
|
|
|
this.$message({
|
|
|
|
|
message: '属性值不能为空',
|
|
|
|
|
type: 'warning',
|
|
|
|
|
duration: 1000
|
|
|
|
|
});
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
if (options.indexOf(this.addProductAttrValue) !== -1) {
|
|
|
|
|
this.$message({
|
|
|
|
|
message: '属性值不能重复',
|
|
|
|
|
type: 'warning',
|
|
|
|
|
duration: 1000
|
|
|
|
|
});
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
this.selectProductAttr[idx].options.push(this.addProductAttrValue);
|
|
|
|
|
this.addProductAttrValue = null;
|
|
|
|
|
},
|
|
|
|
|
handleRemoveProductAttrValue(idx, index) {
|
|
|
|
|
this.selectProductAttr[idx].options.splice(index, 1);
|
|
|
|
|
},
|
|
|
|
|
getProductSkuSp(row, index) {
|
|
|
|
|
let spData = JSON.parse(row.spData);
|
|
|
|
|
if(spData!=null&&index<spData.length){
|
|
|
|
|
return spData[index].value;
|
|
|
|
|
}else{
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
handleRefreshProductSkuList() {
|
|
|
|
|
this.$confirm('刷新列表将导致sku信息重新生成,是否要刷新', '提示', {
|
|
|
|
|
confirmButtonText: '确定',
|
|
|
|
|
cancelButtonText: '取消',
|
|
|
|
|
type: 'warning'
|
|
|
|
|
}).then(() => {
|
|
|
|
|
this.refreshProductAttrPics();
|
|
|
|
|
this.refreshProductSkuList();
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
handleSyncProductSkuPrice(){
|
|
|
|
|
this.$confirm('将同步第一个sku的价格到所有sku,是否继续', '提示', {
|
|
|
|
|
confirmButtonText: '确定',
|
|
|
|
|
cancelButtonText: '取消',
|
|
|
|
|
type: 'warning'
|
|
|
|
|
}).then(() => {
|
|
|
|
|
if(this.value.skuStockList!==null&&this.value.skuStockList.length>0){
|
|
|
|
|
let tempSkuList = [];
|
|
|
|
|
tempSkuList = tempSkuList.concat(tempSkuList,this.value.skuStockList);
|
|
|
|
|
let price=this.value.skuStockList[0].price;
|
|
|
|
|
for(let i=0;i<tempSkuList.length;i++){
|
|
|
|
|
tempSkuList[i].price=price;
|
|
|
|
|
}
|
|
|
|
|
this.value.skuStockList=[];
|
|
|
|
|
this.value.skuStockList=this.value.skuStockList.concat(this.value.skuStockList,tempSkuList);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
handleSyncProductSkuStock(){
|
|
|
|
|
this.$confirm('将同步第一个sku的库存到所有sku,是否继续', '提示', {
|
|
|
|
|
confirmButtonText: '确定',
|
|
|
|
|
cancelButtonText: '取消',
|
|
|
|
|
type: 'warning'
|
|
|
|
|
}).then(() => {
|
|
|
|
|
if(this.value.skuStockList!==null&&this.value.skuStockList.length>0){
|
|
|
|
|
let tempSkuList = [];
|
|
|
|
|
tempSkuList = tempSkuList.concat(tempSkuList,this.value.skuStockList);
|
|
|
|
|
let stock=this.value.skuStockList[0].stock;
|
|
|
|
|
let lowStock=this.value.skuStockList[0].lowStock;
|
|
|
|
|
for(let i=0;i<tempSkuList.length;i++){
|
|
|
|
|
tempSkuList[i].stock=stock;
|
|
|
|
|
tempSkuList[i].lowStock=lowStock;
|
|
|
|
|
}
|
|
|
|
|
this.value.skuStockList=[];
|
|
|
|
|
this.value.skuStockList=this.value.skuStockList.concat(this.value.skuStockList,tempSkuList);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
refreshProductSkuList() {
|
|
|
|
|
this.value.skuStockList = [];
|
|
|
|
|
let skuList = this.value.skuStockList;
|
|
|
|
|
//只有一个属性时
|
|
|
|
|
if (this.selectProductAttr.length === 1) {
|
|
|
|
|
let attr = this.selectProductAttr[0];
|
|
|
|
|
for (let i = 0; i < attr.values.length; i++) {
|
|
|
|
|
skuList.push({
|
|
|
|
|
spData: JSON.stringify([{key:attr.name,value:attr.values[i]}])
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
} else if (this.selectProductAttr.length === 2) {
|
|
|
|
|
let attr0 = this.selectProductAttr[0];
|
|
|
|
|
let attr1 = this.selectProductAttr[1];
|
|
|
|
|
for (let i = 0; i < attr0.values.length; i++) {
|
|
|
|
|
if (attr1.values.length === 0) {
|
|
|
|
|
skuList.push({
|
|
|
|
|
spData: JSON.stringify([{key:attr0.name,value:attr0.values[i]}])
|
|
|
|
|
});
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
for (let j = 0; j < attr1.values.length; j++) {
|
|
|
|
|
let spData = [];
|
|
|
|
|
spData.push({key:attr0.name,value:attr0.values[i]});
|
|
|
|
|
spData.push({key:attr1.name,value:attr1.values[j]});
|
|
|
|
|
skuList.push({
|
|
|
|
|
spData: JSON.stringify(spData)
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
let attr0 = this.selectProductAttr[0];
|
|
|
|
|
let attr1 = this.selectProductAttr[1];
|
|
|
|
|
let attr2 = this.selectProductAttr[2];
|
|
|
|
|
for (let i = 0; i < attr0.values.length; i++) {
|
|
|
|
|
if (attr1.values.length === 0) {
|
|
|
|
|
skuList.push({
|
|
|
|
|
spData: JSON.stringify([{key:attr0.name,value:attr0.values[i]}])
|
|
|
|
|
});
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
for (let j = 0; j < attr1.values.length; j++) {
|
|
|
|
|
if (attr2.values.length === 0) {
|
|
|
|
|
let spData = [];
|
|
|
|
|
spData.push({key:attr0.name,value:attr0.values[i]});
|
|
|
|
|
spData.push({key:attr1.name,value:attr1.values[j]});
|
|
|
|
|
skuList.push({
|
|
|
|
|
spData: JSON.stringify(spData)
|
|
|
|
|
});
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
for (let k = 0; k < attr2.values.length; k++) {
|
|
|
|
|
let spData = [];
|
|
|
|
|
spData.push({key:attr0.name,value:attr0.values[i]});
|
|
|
|
|
spData.push({key:attr1.name,value:attr1.values[j]});
|
|
|
|
|
spData.push({key:attr2.name,value:attr2.values[k]});
|
|
|
|
|
skuList.push({
|
|
|
|
|
spData: JSON.stringify(spData)
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
refreshProductAttrPics() {
|
|
|
|
|
this.selectProductAttrPics = [];
|
|
|
|
|
if (this.selectProductAttr.length >= 1) {
|
|
|
|
|
let values = this.selectProductAttr[0].values;
|
|
|
|
|
for (let i = 0; i < values.length; i++) {
|
|
|
|
|
let pic=null;
|
|
|
|
|
if(this.isEdit){
|
|
|
|
|
//编辑状态下获取图片
|
|
|
|
|
pic=this.getProductSkuPic(values[i]);
|
|
|
|
|
}
|
|
|
|
|
this.selectProductAttrPics.push({name: values[i], pic: pic})
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
//获取商品相关属性的图片
|
|
|
|
|
getProductSkuPic(name){
|
|
|
|
|
for(let i=0;i<this.value.skuStockList.length;i++){
|
|
|
|
|
let spData = JSON.parse(this.value.skuStockList[i].spData);
|
|
|
|
|
if(name===spData[0].value){
|
|
|
|
|
return this.value.skuStockList[i].pic;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return null;
|
|
|
|
|
},
|
|
|
|
|
//合并商品属性
|
|
|
|
|
mergeProductAttrValue() {
|
|
|
|
|
this.value.productAttributeValueList = [];
|
|
|
|
|
for (let i = 0; i < this.selectProductAttr.length; i++) {
|
|
|
|
|
let attr = this.selectProductAttr[i];
|
|
|
|
|
if (attr.handAddStatus === 1 && attr.options != null && attr.options.length > 0) {
|
|
|
|
|
this.value.productAttributeValueList.push({
|
|
|
|
|
productAttributeId: attr.id,
|
|
|
|
|
value: this.getOptionStr(attr.options)
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
for (let i = 0; i < this.selectProductParam.length; i++) {
|
|
|
|
|
let param = this.selectProductParam[i];
|
|
|
|
|
this.value.productAttributeValueList.push({
|
|
|
|
|
productAttributeId: param.id,
|
|
|
|
|
value: param.value
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
//合并商品属性图片
|
|
|
|
|
mergeProductAttrPics() {
|
|
|
|
|
for (let i = 0; i < this.selectProductAttrPics.length; i++) {
|
|
|
|
|
for (let j = 0; j < this.value.skuStockList.length; j++) {
|
|
|
|
|
let spData = JSON.parse(this.value.skuStockList[j].spData);
|
|
|
|
|
if (spData[0].value === this.selectProductAttrPics[i].name) {
|
|
|
|
|
this.value.skuStockList[j].pic = this.selectProductAttrPics[i].pic;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
getOptionStr(arr) {
|
|
|
|
|
let str = '';
|
|
|
|
|
for (let i = 0; i < arr.length; i++) {
|
|
|
|
|
str += arr[i];
|
|
|
|
|
if (i != arr.length - 1) {
|
|
|
|
|
str += ',';
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return str;
|
|
|
|
|
},
|
|
|
|
|
handleRemoveProductSku(index, row) {
|
|
|
|
|
let list = this.value.skuStockList;
|
|
|
|
|
if (list.length === 1) {
|
|
|
|
|
list.pop();
|
|
|
|
|
} else {
|
|
|
|
|
list.splice(index, 1);
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
getParamInputList(inputList) {
|
|
|
|
|
return inputList.split(',');
|
|
|
|
|
},
|
|
|
|
|
handlePrev() {
|
|
|
|
|
this.$emit('prevStep')
|
|
|
|
|
},
|
|
|
|
|
handleNext() {
|
|
|
|
|
this.mergeProductAttrValue();
|
|
|
|
|
this.mergeProductAttrPics();
|
|
|
|
|
this.$emit('nextStep')
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<style scoped>
|
|
|
|
|
.littleMarginLeft {
|
|
|
|
|
margin-left: 10px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.littleMarginTop {
|
|
|
|
|
margin-top: 10px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.paramInput {
|
|
|
|
|
width: 250px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.paramInputLabel {
|
|
|
|
|
display: inline-block;
|
|
|
|
|
width: 100px;
|
|
|
|
|
text-align: right;
|
|
|
|
|
padding-right: 10px
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.cardBg {
|
|
|
|
|
background: #F8F9FC;
|
|
|
|
|
}
|
|
|
|
|
</style>
|
|
|
|
|
|
|
|
|
|
#abc
|
|
|
|
|
<template>
|
|
|
|
|
<!-- 整体的外层 div,设置了距离顶部 50px 的 margin,用于页面布局上的间隔 -->
|
|
|
|
|
<div style="margin-top: 50px">
|
|
|
|
|
<!-- el-form 表单组件,绑定数据模型为 value,设置了表单引用名、标签宽度、类名以及尺寸为小,用于收集和展示商品相关信息 -->
|
|
|
|
|
<el-form :model="value" ref="productAttrForm" label-width="120px" class="form-inner-container" size="small">
|
|
|
|
|
<!-- 表单项,标签显示为“属性类型:” -->
|
|
|
|
|
<el-form-item label="属性类型:">
|
|
|
|
|
<!-- el-select 下拉选择框组件,绑定 v-model 为 value.productAttributeCategoryId,有占位提示文字,并且监听 change 事件 -->
|
|
|
|
|
<el-select v-model="value.productAttributeCategoryId"
|
|
|
|
|
placeholder="请选择属性类型"
|
|
|
|
|
@change="handleProductAttrChange">
|
|
|
|
|
<!-- 通过循环生成下拉选项,每个选项的标签和值根据 productAttributeCategoryOptions 数组中的元素来确定 -->
|
|
|
|
|
<el-option
|
|
|
|
|
v-for="item in productAttributeCategoryOptions"
|
|
|
|
|
:key="item.value"
|
|
|
|
|
:label="item.label"
|
|
|
|
|
:value="item.value">
|
|
|
|
|
</el-option>
|
|
|
|
|
</el-select>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<!-- 表单项,标签显示为“商品规格:”,用于展示和操作商品规格相关内容 -->
|
|
|
|
|
<el-form-item label="商品规格:">
|
|
|
|
|
<!-- el-card 卡片组件,设置阴影效果为无,添加了自定义类名 cardBg,用于对商品规格部分进行布局划分 -->
|
|
|
|
|
<el-card shadow="never" class="cardBg">
|
|
|
|
|
<!-- 循环遍历 selectProductAttr 数组,展示每个商品属性相关内容 -->
|
|
|
|
|
<div v-for="(productAttr,idx) in selectProductAttr">
|
|
|
|
|
<!-- 显示商品属性的名称 -->
|
|
|
|
|
{{productAttr.name}}:
|
|
|
|
|
<!-- 根据商品属性的 handAddStatus 判断使用不同的复选框组展示方式,当为 0 时使用固定的输入列表生成复选框 -->
|
|
|
|
|
<el-checkbox-group v-if="productAttr.handAddStatus===0" v-model="selectProductAttr[idx].values">
|
|
|
|
|
<el-checkbox v-for="item in getInputListArr(productAttr.inputList)" :label="item" :key="item"
|
|
|
|
|
class="littleMarginLeft"></el-checkbox>
|
|
|
|
|
</el-checkbox-group>
|
|
|
|
|
<!-- 当 handAddStatus 不为 0 时,展示可动态操作的复选框组,包含添加、删除选项等功能 -->
|
|
|
|
|
<div v-else>
|
|
|
|
|
<el-checkbox-group v-model="selectProductAttr[idx].values">
|
|
|
|
|
<div v-for="(item,index) in selectProductAttr[idx].options" style="display: inline-block"
|
|
|
|
|
class="littleMarginLeft">
|
|
|
|
|
<el-checkbox :label="item" :key="item"></el-checkbox>
|
|
|
|
|
<el-button type="text" class="littleMarginLeft" @click="handleRemoveProductAttrValue(idx,index)">删除
|
|
|
|
|
</el-button>
|
|
|
|
|
</div>
|
|
|
|
|
</el-checkbox-group>
|
|
|
|
|
<el-input v-model="addProductAttrValue" style="width: 160px;margin-left: 10px" clearable></el-input>
|
|
|
|
|
<el-button class="littleMarginLeft" @click="handleAddProductAttrValue(idx)">增加</el-button>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</el-card>
|
|
|
|
|
<!-- el-table 表格组件,设置宽度为 100%,绑定数据为 value.skuStockList,设置边框,用于展示商品 SKU 相关信息 -->
|
|
|
|
|
<el-table style="width: 100%;margin-top: 20px"
|
|
|
|
|
:data="value.skuStockList"
|
|
|
|
|
border>
|
|
|
|
|
<!-- 循环生成表格列,根据 selectProductAttr 数组中的每个商品属性生成对应列,用于展示每个 SKU 对应的属性值 -->
|
|
|
|
|
<el-table-column
|
|
|
|
|
v-for="(item,index) in selectProductAttr"
|
|
|
|
|
:label="item.name"
|
|
|
|
|
:key="item.id"
|
|
|
|
|
align="center">
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
{{getProductSkuSp(scope.row,index)}}
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
<!-- 表格列,标签显示为“销售价格”,宽度为 100px,内容居中对齐,内部使用输入框展示和编辑价格 -->
|
|
|
|
|
<el-table-column
|
|
|
|
|
label="销售价格"
|
|
|
|
|
width="100"
|
|
|
|
|
align="center">
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<el-input v-model="scope.row.price"></el-input>
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
<!-- 表格列,标签显示为“促销价格”,宽度为 100px,内容居中对齐,内部使用输入框展示和编辑促销价格 -->
|
|
|
|
|
<el-table-column
|
|
|
|
|
label="促销价格"
|
|
|
|
|
width="100"
|
|
|
|
|
align="center">
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<el-input v-model="scope.row.promotionPrice"></el-input>
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
<!-- 表格列,标签显示为“商品库存”,宽度为 80px,内容居中对齐,内部使用输入框展示和编辑库存数量 -->
|
|
|
|
|
<el-table-column
|
|
|
|
|
label="商品库存"
|
|
|
|
|
width="80"
|
|
|
|
|
align="center">
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<el-input v-model="scope.row.stock"></el-input>
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
<!-- 表格列,标签显示为“库存预警值”,宽度为 80px,内容居中对齐,内部使用输入框展示和编辑库存预警值 -->
|
|
|
|
|
<el-table-column
|
|
|
|
|
label="库存预警值"
|
|
|
|
|
width="80"
|
|
|
|
|
align="center">
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<el-input v-model="scope.row.lowStock"></el-input>
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
<!-- 表格列,标签显示为“SKU 编号”,宽度为 160px,内容居中对齐,内部使用输入框展示和编辑 SKU 编号 -->
|
|
|
|
|
<el-table-column
|
|
|
|
|
label="SKU 编号"
|
|
|
|
|
width="160"
|
|
|
|
|
align="center">
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<el-input v-model="scope.row.skuCode"></el-input>
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
<!-- 表格列,标签显示为“操作”,宽度为 80px,内容居中对齐,内部包含删除按钮,点击可删除对应行的 SKU 数据 -->
|
|
|
|
|
<el-table-column
|
|
|
|
|
label="操作"
|
|
|
|
|
width="80"
|
|
|
|
|
align="center">
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<el-button
|
|
|
|
|
type="text"
|
|
|
|
|
@click="handleRemoveProductSku(scope.$index, scope.row)">删除
|
|
|
|
|
</el-button>
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
</el-table>
|
|
|
|
|
<!-- el-button 按钮组件,类型为主要按钮,点击时触发 handleRefreshProductSkuList 方法,用于刷新商品 SKU 列表 -->
|
|
|
|
|
<el-button
|
|
|
|
|
type="primary"
|
|
|
|
|
style="margin-top: 20px"
|
|
|
|
|
@click="handleRefreshProductSkuList">刷新列表
|
|
|
|
|
</el-button>
|
|
|
|
|
<!-- el-button 按钮组件,类型为主要按钮,点击时触发 handleSyncProductSkuPrice 方法,用于同步商品 SKU 的价格 -->
|
|
|
|
|
<el-button
|
|
|
|
|
type="primary"
|
|
|
|
|
style="margin-top: 20px"
|
|
|
|
|
@click="handleSyncProductSkuPrice">同步价格
|
|
|
|
|
</el-button>
|
|
|
|
|
<!-- el-button 按钮组件,类型为主要按钮,点击时触发 handleSyncProductSkuStock 方法,用于同步商品 SKU 的库存 -->
|
|
|
|
|
<el-button
|
|
|
|
|
type="primary"
|
|
|
|
|
style="margin-top: 20px"
|
|
|
|
|
@click="handleSyncProductSkuStock">同步库存
|
|
|
|
|
</el-button>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<!-- 根据 hasAttrPic 计算属性判断是否显示商品属性图片相关内容,只有当有属性图片时才展示 -->
|
|
|
|
|
<el-form-item label="属性图片:" v-if="hasAttrPic">
|
|
|
|
|
<!-- el-card 卡片组件,设置阴影效果为无,添加了自定义类名 cardBg,用于对商品属性图片部分进行布局划分 -->
|
|
|
|
|
<el-card shadow="never" class="cardBg">
|
|
|
|
|
<!-- 循环遍历 selectProductAttrPics 数组,展示每个商品属性图片相关内容,使用 single-upload 组件上传图片 -->
|
|
|
|
|
<div v-for="(item,index) in selectProductAttrPics">
|
|
|
|
|
<span>{{item.name}}:</span>
|
|
|
|
|
<single-upload v-model="item.pic"
|
|
|
|
|
style="width: 300px;display: inline-block;margin-left: 10px"></single-upload>
|
|
|
|
|
</div>
|
|
|
|
|
</el-card>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<!-- 表单项,标签显示为“商品参数:”,用于展示和编辑商品参数相关内容 -->
|
|
|
|
|
<el-form-item label="商品参数:">
|
|
|
|
|
<!-- el-card 卡片组件,设置阴影效果为无,添加了自定义类名 cardBg,用于对商品参数部分进行布局划分 -->
|
|
|
|
|
<el-card shadow="never" class="cardBg">
|
|
|
|
|
<!-- 循环遍历 selectProductParam 数组,展示每个商品参数相关内容,根据输入类型选择不同的输入组件展示和编辑参数值 -->
|
|
|
|
|
<div v-for="(item,index) in selectProductParam" :class="{littleMarginTop:index!==0}">
|
|
|
|
|
<div class="paramInputLabel">{{item.name}}:</div>
|
|
|
|
|
<el-select v-if="item.inputType===1" class="paramInput" v-model="selectProductParam[index].value">
|
|
|
|
|
<el-option
|
|
|
|
|
v-for="item in getParamInputList(item.inputList)"
|
|
|
|
|
:key="item"
|
|
|
|
|
:label="item"
|
|
|
|
|
:value="item">
|
|
|
|
|
</el-option>
|
|
|
|
|
</el-select>
|
|
|
|
|
<el-input v-else class="paramInput" v-model="selectProductParam[index].value"></el-input>
|
|
|
|
|
</div>
|
|
|
|
|
</el-card>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<!-- 表单项,标签显示为“商品相册:”,使用 multi-upload 组件用于上传商品的相册图片 -->
|
|
|
|
|
<el-form-item label="商品相册:">
|
|
|
|
|
<multi-upload v-model="selectProductPics"></multi-upload>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<!-- 表单项,标签显示为“商品详情:”,使用 el-tabs 选项卡组件展示电脑端和移动端的商品详情,分别使用 tinymce 富文本编辑器进行编辑 -->
|
|
|
|
|
<el-form-item label="商品详情:">
|
|
|
|
|
<el-tabs v-model="activeHtmlName" type="card">
|
|
|
|
|
<el-tab-pane label="电脑端详情" name="pc">
|
|
|
|
|
<tinymce :width="595" :height="300" v-model="value.detailHtml"></tinymce>
|
|
|
|
|
</el-tab-pane>
|
|
|
|
|
<el-tab-pane label="移动端详情" name="mobile">
|
|
|
|
|
<tinymce :width="595" :height="300" v-model="value.detailMobileHtml"></tinymce>
|
|
|
|
|
</el-tab-pane>
|
|
|
|
|
</el-tabs>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<!-- 表单项,用于放置操作按钮,设置文本居中对齐,包含“上一步”和“下一步”按钮,点击分别触发对应的方法 -->
|
|
|
|
|
<el-form-item style="text-align: center">
|
|
|
|
|
<el-button size="medium" @click="handlePrev">上一步,填写商品促销</el-button>
|
|
|
|
|
<el-button type="primary" size="medium" @click="handleNext">下一步,选择商品关联</el-button>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
</el-form>
|
|
|
|
|
</div>
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script>
|
|
|
|
|
// 从 @/api/productAttrCate 模块中导入名为 fetchList 的函数,并将其重命名为 fetchProductAttrCateList,用于获取商品属性分类列表数据
|
|
|
|
|
import {fetchList as fetchProductAttrCateList} from '@/api/productAttrCate'
|
|
|
|
|
// 从 @/api/productAttr 模块中导入名为 fetchList 的函数,并将其重命名为 fetchProductAttrList,用于获取商品属性列表数据等相关操作
|
|
|
|
|
import {fetchList as fetchProductAttrList} from '@/api/productAttr'
|
|
|
|
|
// 导入 SingleUpload 组件,用于单个文件上传,可能是用于上传商品相关的单个图片等功能
|
|
|
|
|
import SingleUpload from '@/api/SingleUpload'
|
|
|
|
|
// 导入 MultiUpload 组件,用于多个文件上传,比如上传商品相册图片
|
|
|
|
|
import MultiUpload from '@/api/MultiUpload'
|
|
|
|
|
// 导入 Tinymce 组件,用于展示和编辑富文本内容,这里用于商品详情的编辑
|
|
|
|
|
import Tinymce from '@/api/Tinymce'
|
|
|
|
|
|
|
|
|
|
export default
|
|
|
|
|
name: "ProductAttrDetail",
|
|
|
|
|
components: {SingleUpload, MultiUpload, Tinymce},
|
|
|
|
|
props: {
|
|
|
|
|
// 接收一个名为 value 的对象类型属性,用于绑定表单数据等相关信息
|
|
|
|
|
value: Object,
|
|
|
|
|
// 接收一个名为 isEdit 的布尔类型属性,默认值为 false,用于判断当前是否处于编辑模式
|
|
|
|
|
isEdit: {
|
|
|
|
|
type: Boolean,
|
|
|
|
|
default: false
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
data() {
|
|
|
|
|
return {
|
|
|
|
|
// 编辑模式时是否初始化成功的标志,初始值为 false
|
|
|
|
|
hasEditCreated: false,
|
|
|
|
|
// 用于存储商品属性分类下拉选项的数组,初始为空,后续会填充从接口获取的数据
|
|
|
|
|
productAttributeCategoryOptions: [],
|
|
|
|
|
// 用于存储选中的商品属性的数组,每个元素包含属性的各种相关信息,初始为空
|
|
|
|
|
selectProductAttr: [],
|
|
|
|
|
// 用于存储选中的商品参数的数组,每个元素包含参数的各种相关信息,初始为空
|
|
|
|
|
selectProductParam: [],
|
|
|
|
|
// 用于存储选中的商品属性图片的数组,每个元素包含图片相关信息,初始为空
|
|
|
|
|
selectProductAttrPics: [],
|
|
|
|
|
// 用于临时存储可手动添加的商品属性值,初始为空字符串
|
|
|
|
|
addProductAttrValue: '',
|
|
|
|
|
// 用于指定商品富文本详情激活的选项卡名称,初始值为 'pc',表示电脑端详情
|
|
|
|
|
activeHtmlName: 'pc'
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
computed: {
|
|
|
|
|
// 计算属性,根据 selectProductAttrPics 数组长度判断是否有商品属性图片,返回布尔值
|
|
|
|
|
hasAttrPic() {
|
|
|
|
|
if (this.selectProductAttrPics.length < 1) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
return true;
|
|
|
|
|
},
|
|
|
|
|
// 计算属性,返回商品的编号,从 value 对象中获取
|
|
|
|
|
productId() {
|
|
|
|
|
return this.value.id;
|
|
|
|
|
},
|
|
|
|
|
// 计算属性,用于获取和设置商品的主图和画册图片,通过对 value 中的相关属性进行处理,实现图片数据的双向绑定
|
|
|
|
|
selectProductPics: {
|
|
|
|
|
get: function () {
|
|
|
|
|
let pics = [];
|
|
|
|
|
if (this.value.pic === undefined || this.value.pic == null || this.value.pic === '') {
|
|
|
|
|
return pics;
|
|
|
|
|
}
|
|
|
|
|
pics.push(this.value.pic);
|
|
|
|
|
if (this.value.albumPics === undefined || this.value.albumPics == null || this.value.albumPics === '') {
|
|
|
|
|
return pics;
|
|
|
|
|
}
|
|
|
|
|
let albumPics = this.value.albumPics.split(',');
|
|
|
|
|
for (let i = 0; i < albumPics.length; i++) {
|
|
|
|
|
pics.push(albumPics[i]);
|
|
|
|
|
}
|
|
|
|
|
return pics;
|
|
|
|
|
},
|
|
|
|
|
set: function (newValue) {
|
|
|
|
|
if (newValue == null || newValue.length === 0) {
|
|
|
|
|
this.value.pic = null;
|
|
|
|
|
this.value.albumPics = null;
|
|
|
|
|
} else {
|
|
|
|
|
this.value.pic = newValue[0];
|
|
|
|
|
this.value.albumPics = '';
|
|
|
|
|
if (newValue.length > 1) {
|
|
|
|
|
for (let i = 1; i < newValue.length; i++) {
|
|
|
|
|
this.value.albumPics += newValue[i];
|
|
|
|
|
if (i!== newValue.length - 1) {
|
|
|
|
|
this.value.albumPics += ',';
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
created() {
|
|
|
|
|
// 在组件创建时调用 getProductAttrCateList 方法,用于获取商品属性分类列表数据
|
|
|
|
|
this.getProductAttrCateList();
|
|
|
|
|
},
|
|
|
|
|
watch: {
|
|
|
|
|
productId: function (newValue) {
|
|
|
|
|
// 如果不是编辑模式,直接返回,不进行后续操作
|
|
|
|
|
if (!this.isEdit) return;
|
|
|
|
|
// 如果已经初始化成功,直接返回,避免重复操作
|
|
|
|
|
if (this.hasEditCreated) return;
|
|
|
|
|
// 如果新值为 undefined、null 或者 0,直接返回
|
|
|
|
|
if (newValue === undefined || newValue == null || newValue === 0) return;
|
|
|
|
|
// 调用 handleEditCreated 方法进行编辑模式下的初始化操作
|
|
|
|
|
this.handleEditCreated();
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
methods:
|
|
|
|
|
handleEditCreated() {
|
|
|
|
|
// 如果商品属性分类 id 不为空,根据该 id 获取商品属性和参数信息
|
|
|
|
|
if (this.value.productAttributeCategoryId!= null) {
|
|
|
|
|
this.handleProductAttrChange(this.value.productAttributeCategoryId);
|
|
|
|
|
}
|
|
|
|
|
// 将编辑模式初始化成功标志设置为 true
|
|
|
|
|
this.hasEditCreated = true;
|
|
|
|
|
},
|
|
|
|
|
getProductAttrCateList()
|