<template> <view class="container"> <cu-custom class="main-totextbar bg-main-oil" :isBack="true" bgColor="bg-main-oil"> <block slot="backText">返回</block> <block slot="content">新增商品</block> </cu-custom> <view id="chooseType" :class="currentBoxId == 'chooseType' ? 'show' : 'hidden'"> <uni-forms ref="productForm" :modelValue="productDate" :rules="rules" label-width="200rpx"> <uni-forms-item label="商品分类:" name="name"> <mulpicker v-model="productDate.demandRegion" :list="productList" rangekey="categoryName" code="id" pidkey="id" childkey="classificationTwoList" :emitPath="true" :level="2" :placeholder="'选择商品分类'" /> <uni-icons color="#666666" type="right" size="22" style="position: absolute;right: 0;top: 10rpx;"></uni-icons> </uni-forms-item> <uni-forms-item label="商品名称:" name="productName"> <input type="text" v-model="productDate.productName" placeholder="请输入商品名称" /> </uni-forms-item> <uni-forms-item label="关键词:" name="keyword"> <input type="text" v-model="productDate.keyword" placeholder="请输入关键词(空格分隔)" /> </uni-forms-item> <uni-forms-item label="商品品牌:" name="brandId"> <!-- <input type="text" v-model="productDate.brandId" placeholder="请输入商品品牌" /> --> <uni-data-select v-model="productDate.brandId" :localdata="brandIdList" placeholder="请选择商品品牌" ></uni-data-select> </uni-forms-item> <uni-forms-item label="商品售价:" name="price"> <input type="text" v-model="productDate.price" placeholder="请输入商品售价" /> </uni-forms-item> <uni-forms-item label="商品上架:" name="productStatus"> <switch v-model="productDate.productStatus" :checked="productDate.productStatus=='1'" color="#FE0606" @change="switchChange" style="transform:scale(0.7)" /> </uni-forms-item> <uni-forms-item label="商品推荐:" name="age"> <view class='checkbox-con'> <radio-group> <label :class="item.checked?'checkbox checked':'checkbox'" @click="checkbox(index)" v-for="(item, index) in radioItem" :key="item.value"> <checkbox :value="item.value" :checked="item.checked"/>{{item.name}} </label> </radio-group> </view> </uni-forms-item> </uni-forms> <view class="buttons"> <view @click="closed">取消</view> <view id="next" @click="changeBox">下一步</view> </view> </view> <view id="instruction" :class="currentBoxId == 'instruction' ? 'show' : 'hidden'"> <uni-forms :modelValue="productDate" label-width="200rpx"> <uni-forms-item label="属性类别:" > <uni-data-select v-model="productDate.attributesTypeId" :localdata="attributesTypeList" placeholder="请选择商品品牌" @change="attributesData" ></uni-data-select> </uni-forms-item> <view class="content" v-show="productDate.attributesTypeId"> <view style="margin: 10rpx 0;">商品类型:</view> <view> <uni-section type="line"> <view class="uni-px-5" v-for="(item,index) in attributesList"> <view style="display: inline-block;">{{item.attributeName}}:</view> <view style="display: inline-block;"> <uni-data-checkbox v-if="index==0" mode="tag" v-model="radioAttributes" :localdata="item.attributesList"></uni-data-checkbox> <uni-data-checkbox v-else-if="index!=0" mode="tag" multiple v-model="checkboxAttributes" :localdata="hobby"></uni-data-checkbox> </view> </view> </uni-section> </view> </view> <view> <view>批量填充:<text style="color: #999999;margin: 10rpx 0;">批量填充填入信息后,可以批量将内容填写到SKU 信息里</text></view> <view class="tagButton" @tap="changeChecked(item)" v-for="item in bottonList">{{item.label}}</view> <view class="redButton" @tap="addStockList">确定</view> </view> <view v-for="(items,index) in stockList"> <view style="margin: 10rpx 0;"> <text style="color: red;">*</text> <text>规格:</text> <text v-if="index==0">{{radioAttributes}}</text> <text v-if="index!=0">{{radioAttributes}}+{{checkboxAttributes[index]}}</text> </view> <view class="tagButton"> <input type="text" v-model="items.marketPrice" placeholder="市场价格" /> </view> <view class="tagButton"> <input type="text" v-model="items.sellPrice" placeholder="销售价格" /> </view> <view class="tagButton"> <input type="text" v-model="items.stock" placeholder="库存数量" /> </view> <view class="tagButton"> <input type="text" v-model="items.integral" placeholder="积分价值" /> </view> <view style="display: inline-block;vertical-align: top;margin-top: 10rpx;" @click="deleteCheckAll(index)">删除</view> </view> <view> <view style="margin: 10rpx 0;"> <text style="color: red;">*</text> 商品图片: <text style="color: #999999;">最多可上传10张图片</text> </view> <view class="imageList" v-for="(items,index) in productDate.images"> <view class="imageBlack" v-if="items.mainMark==1"> <image :src="items.url"></image> <view class="cameraText">商品主图</view> <uni-icons class="cameraClear" type="clear" size="20" @tap="clearImage(index)"></uni-icons> </view> <view class="imageBlack" v-else-if="items.mainMark!=1"> <image :src="items.url"></image> <view class="cameraText" @click="setMainImage(index)">设为主图</view> <uni-icons class="cameraClear" type="clear" size="20" @tap="clearImage(index)"></uni-icons> </view> </view> <view class="imageBlack" style="background-color: #fafafa;" @tap="srcFileImage"> <view style="margin-top: 46rpx;"> <uni-icons type="camera-filled" size="30"></uni-icons> </view> </view> </view> <!-- <view> <view>详情图片:<text style="color: #999999;">最多可上传10张图片</text></view> <view></view> </view> --> </uni-forms> <view class="buttons"> <view id="previous" @click="changeBox">上一步</view> <view @click="addCompleted">完成</view> </view> </view> </view> </template> <script> import utils from '@/utils/encode' import serve from '@/api/packageIntegral/productList.js' import mulpicker from '@/packageIntegral/components/mulpicker.vue' export default { components: { mulpicker }, data() { return { currentBoxId: 'chooseType', //当前显示的view的id isBoxShow: false, productDate:{ images:[] }, productList:[], brandIdList:[], radioItem:[{ name: '新品', checked: true }, { name: '推荐', checked: false }], rules:{ name:{rules:[{required: true,errorMessage: '请选择商品分类'}]}, productName:{rules:[{required: true,errorMessage: '请输入商品名称'}]}, brandId:{rules:[{required: true,errorMessage: '请输入商品品牌'}]}, price:{rules:[{required: true,errorMessage: '请输入商品售价'}]}, }, attributesTypeList:[], attributesList:[], bottonList:[ {label:'市场价格',value:'marketPrice',checked:false}, {label:'销售价格',value:'sellPrice',checked:false}, {label:'商品库存',value:'stock',checked:false}, {label:'兑换积分',value:'integral',checked:false} ], radioAttributes:'', checkboxAttributes:[], stockList:[] } }, onLoad() { this.classfication() this.getProductBrands() this.getAttributesType() }, watch:{ 'productDate.demandRegion'(val){ if(val){ this.productDate.categoryOneId = val.split(',')[0] this.productDate.categoryTwoId = val.split(',')[1] } } }, methods: { switchChange(e){ if(e.detail.value == true){ this.productDate.productStatus = '1' }else if(e.detail.value == false){ this.productDate.productStatus = '2' } }, classfication(){ serve.classification().then(res=>{ this.productList = res.data }) }, getProductBrands(){ this.brandIdList = [] serve.getProductBrands().then(res=>{ console.log(res) res.data.forEach(tab=>{ this.brandIdList.push({value:tab.id,text:tab.brandName}) }) }) }, checkbox (e) { var index = e;//获取当前点击的下标 var checkboxArr = this.radioItem;//选项集合 // if (checkboxArr[index].checked) return;//如果点击的当前已选中则返回 // checkboxArr.forEach(item => { // item.checked = false // }) if(checkboxArr[index].checked ==false){ checkboxArr[index].checked = true; //改变当前选中的checked值 }else { checkboxArr[index].checked = false; //改变当前选中的checked值 } if(checkboxArr[0].checked ==true){ this.productDate.newMark = 1 }else{ this.productDate.newMark = 2 } if(checkboxArr[1].checked ==true){ this.productDate.recommend = 1 }else{ this.productDate.recommend = 2 } }, changeBox(e){ let currentFlag = e.currentTarget.id; switch(currentFlag){ case 'next': this.currentBoxId = 'instruction' break; case 'previous': this.currentBoxId = 'chooseType' break; default: this.currentBoxId = 'viewInstruction' break; } if(currentFlag == 'next'){ this.getAttributesType() } }, getAttributesType(){ this.attributesTypeList = [] serve.getAttributesType().then(res=>{ res.data.forEach(tab=>{ this.attributesTypeList.push({ value:tab.id, text:tab.name, number:tab.number, attributesList:tab.attributesList }) }) }) }, attributesData(){ if(this.productDate.attributesTypeId){ this.attributesTypeList.forEach(tab=>{ if(tab.id = this.productDate.attributesTypeId){ this.attributesList = tab.attributesList this.attributesList.forEach(tab=>{ tab.attributesList = [] tab.attributeContent.split(',').forEach(item=>{ tab.attributesList.push({value:item,text:item}) }) }) } }) }else{ this.attributesList = [] } }, deleteCheckAll(i){ if(this.checkboxAttributes.length>1){ this.checkboxAttributes.splice(i,1) }else{ this.checkboxAttributes.splice(i,1) this.radioAttributes = '' } this.stockList.splice(i,1) }, deleteRadio(){ this.radioAttributes = '' }, changeChecked(item){ item.checked = !item.checked }, addStockList(){ this.stockList = [] let obj = { marketPrice:'', sellPrice:'', stock:'', integral:'' } if(this.attributesList.length ==1){ let data = {} let name = this.attributesList[0].attributeName let value = this.radioAttributes data[name] = value obj.attributeJson = JSON.stringify(data) this.stockList.push(obj) }else{ this.checkboxAttributes.forEach((tab,index)=>{ let name = this.attributesList[0].attributeName let value = this.radioAttributes let tabName = this.attributesList[index+1].attributeName let tabValue = tab data[name] = value data[tabName] = tabValue obj.attributeJson = JSON.stringify(data) this.stockList.push(obj) }) } }, //调起上传图片 srcFileImage() { let _that = this let imageUrl = '' uni.chooseImage({ count: 10, //默认9 sizeType: ['original', 'compressed'], //可以指定是原图还是压缩图,默认二者都有 sourceType: ['album'], //从相册选择 success: function(res) { console.log(res) console.log('进入1') const JSESSIONID = utils.uuid() uni.uploadFile({ url: 'http://uat.xingoil.com/adminapi/oil-oss/obejct/uploadFile', filePath: res.tempFilePaths[0], formData: { ossKey: 'xingyou', pathKey: 'publicxingyou', encrypt: 'PUBLIC', }, name: 'file', header: { "Content-Type": "multipart/form-data", "Authorization": uni.getStorageSync('Authorization'), 'dataSources': 'MP', "imei": uni.getStorageSync('unionid'), "openId": uni.getStorageSync('openid'), 'JSESSIONID': JSESSIONID, 'token': utils.md5Salt(JSESSIONID) }, success(e) { console.log('进入2') console.log(e) let obj = JSON.parse(e.data), imageUrl = obj.data.publicUrl _that.getImage(imageUrl) }, fail(err) { console.log(err) } }) },fail() { console.log('相机调用失败') } }) }, getImage(imageUrl){ if(JSON.stringify(this.productDate.images) == '[]'){ this.productDate.images.push({ url:imageUrl, mainMark:1 }) }else{ this.productDate.images.push({ url:imageUrl, mainMark:'' }) } }, setMainImage(index){ this.productDate.images.forEach((tab,i)=>{ if(i == index){ tab.mainMark = 1 }else{ tab.mainMark = '' } }) }, clearImage(index){ if(this.productDate.images[index].mainMark == 1){ this.productDate.images.splice(index,1) this.productDate.images[0].mainMark = 1 }else{ this.productDate.images.splice(index,1) } }, closed(){ uni.navigateTo({ url: '/pages/index/index' }) }, addCompleted(){ if(this.radioItem[0].checked =true){ this.productDate.newMark == '1' }else{ this.productDate.newMark == '2' } if(this.radioItem[1].checked =true){ this.productDate.recommend == '1' }else{ this.productDate.recommend == '2' } this.productDate.stockList = this.stockList serve.saveProduct(this.productDate).then(res=>{ console.log(res) }) } } } </script> <style lang="scss" scoped> .fadeBox{ width: 100%; margin-bottom: 20rpx; } #chooseType{ padding: 30rpx; mulpicker{ height: 72rpx; line-height: 72rpx; } /deep/ .uni-forms{ width: 100%; } .content{ font-size: 28rpx; font-weight: bold; } /deep/ .uni-forms-item{ width: 100%; } /deep/ .uni-forms-item__label{ color: #333 !important; font-size: 30rpx; font-weight: 700; } /deep/ .uni-forms-item__content{ width: 100%; input{ height: 72rpx; line-height: 72rpx; } } switch{ margin-top: 9rpx; } switch::before{ content: ''; } switch::after{ content: ''; } } #instruction{ padding: 30rpx; mulpicker{ height: 72rpx; line-height: 72rpx; } /deep/ .uni-forms{ width: 100%; } /deep/ .uni-forms-item{ width: 100%; } /deep/ .uni-forms-item__label{ color: #333 !important; font-size: 30rpx; font-weight: 700; } /deep/ .uni-forms-item__content{ width: 100%; input{ height: 72rpx; line-height: 72rpx; } } .tagButton{ display: inline-block; width: 133rpx; background: #f5f5f5; color: #666666; border-radius: 8rpx; line-height: 58rpx; text-align: center; margin: 8rpx; } .checkedTag{ background-color: #2979ff; color: #FFFFFF; } .redButton{ display: inline-block; width: 84rpx; height: 58rpx; background: red; color: #fff; border-radius: 10rpx; line-height: 58rpx; text-align: center; } .commodityImage{ display: inline-block; max-width: calc(100%-150rpx); } .imageList{ display: inline-block; width: 140rpx; margin: 0 10rpx; } .imageBlack{ display: inline-block; width: 140rpx; height: 140rpx; vertical-align: middle; text-align: center; position: relative; >image{ width: 100%; height: 100%; } .cameraText{ width: 140rpx; height: 30rpx; text-align: center; line-height: 30rpx; position: absolute; background-color: #333; opacity: 0.3; color: #FFFFFF; left: 0rpx; top: 110rpx; } .cameraClear{ position: absolute; left: 120rpx; top: -10rpx; z-index: 20; } } } .checkbox-con{ margin-top: 40rpx; text-align: center; position: relative; } .checkbox{ width: 180rpx; height: 76rpx; line-height: 76rpx; font-size: 30rpx; color: #666666; border: 1rpx solid #B6B6B6; border-radius: 5rpx; display: inline-block; margin: 0 10rpx 20rpx 0; position: absolute; top: 50rpx; &:nth-of-type(1){ left: -190rpx; } &:nth-of-type(2){ left: 50rpx; } } .checked{ color: #FFFFFF; background: #FE0606; border: 1rpx solid #FE0606; } .checkbox checkbox{ display: none } .buttons { width: 100%; display: flex; justify-content: space-evenly; margin-top: 180rpx; >view { width: 250rpx; height: 76rpx; text-align: center; line-height: 76rpx; border-radius: 10rpx; font-size: 28rpx; &:nth-of-type(1) { background: #FFFFFF; border: 1rpx solid #B6B6B6; color: #333; } &:nth-of-type(2) { background: #FE0505; color: #fff; } } } .show{ display: flex; flex-wrap: wrap; } .hidden{ display: none; } </style>