|
@@ -2,7 +2,7 @@
|
|
|
<view class="pages">
|
|
|
<form @submit="formSubmit" @reset="formReset">
|
|
|
<view class="form-item-type nomal-top">
|
|
|
- <view class="form-item">
|
|
|
+ <view class="form-item required">
|
|
|
<view class="form-item-til">类目</view>
|
|
|
<view class="form-item-con">
|
|
|
<input type="text" disabled placeholder="商品类目" v-model="params.type" value="" />
|
|
@@ -16,76 +16,106 @@
|
|
|
</view> -->
|
|
|
</view>
|
|
|
<view class="form-item-type">
|
|
|
- <view class="form-item">
|
|
|
- <view class="form-item-til">标题</view>
|
|
|
+ <view class="form-item required">
|
|
|
+ <view class="form-item-til">名称</view>
|
|
|
<view class="form-item-con">
|
|
|
- <input type="text" placeholder="请输入发布产品标题" v-model="params.title" value="" />
|
|
|
+ <input type="text" placeholder="请输入发布产品名称" v-model="params.name" value="" />
|
|
|
</view>
|
|
|
</view>
|
|
|
- <view class="form-item">
|
|
|
+ <view class="form-item required arrow" @click="openbrand">
|
|
|
<view class="form-item-til">品牌</view>
|
|
|
<view class="form-item-con">
|
|
|
- <input type="text" placeholder="请输入品牌" v-model="params.brand" value="" />
|
|
|
+ <input type="text" placeholder="请输入品牌" v-model="params.brandName" value="" />
|
|
|
+ </view>
|
|
|
+ </view>
|
|
|
+ <view class="form-item required">
|
|
|
+ <view class="form-item-til">供应商</view>
|
|
|
+ <view class="form-item-con">
|
|
|
+ <input type="text" disabled placeholder="" v-model="params.compName" value="" />
|
|
|
</view>
|
|
|
</view>
|
|
|
- <view class="form-item">
|
|
|
- <view class="form-item-til">零售价</view>
|
|
|
+ <view class="form-item required arrow" @click="openplaceoforigin">
|
|
|
+ <view class="form-item-til">生产地</view>
|
|
|
<view class="form-item-con">
|
|
|
- <input type="text" placeholder="请输入零售价" v-model="params.price" value="" />
|
|
|
+ <input type="text" disabled="disabled" placeholder="" v-model="params.placeOfProduction" value="" />
|
|
|
</view>
|
|
|
</view>
|
|
|
- <view class="form-item">
|
|
|
- <view class="form-item-til">供应商</view>
|
|
|
+ <!-- <view class="form-item arrow" @click="openspec"> -->
|
|
|
+ <view class="form-item required">
|
|
|
+ <view class="form-item-til">规格</view>
|
|
|
<view class="form-item-con">
|
|
|
- <input type="text" disabled placeholder="" v-model="params.supplier" value="" />
|
|
|
+ <!-- <text v-for="(item,index) in params.spec">{{item}},</text> -->
|
|
|
+ <input type="text" placeholder="" v-model="params.spec" value="" />
|
|
|
</view>
|
|
|
</view>
|
|
|
- <view class="form-item arrow" @click="openplaceoforigin">
|
|
|
- <view class="form-item-til">生产地</view>
|
|
|
+ <view class="form-item">
|
|
|
+ <view class="form-item-til">零售价</view>
|
|
|
<view class="form-item-con">
|
|
|
- <input type="text" disabled="disabled" placeholder="" v-model="params.placeoforigin" value="" />
|
|
|
+ <input type="text" placeholder="请输入零售价" v-model="params.price" value="" />
|
|
|
</view>
|
|
|
</view>
|
|
|
- <view class="form-item arrow" @click="openspecifications">
|
|
|
- <view class="form-item-til">规格</view>
|
|
|
+ <view class="form-item">
|
|
|
+ <view class="form-item-til">市场价</view>
|
|
|
<view class="form-item-con">
|
|
|
- <text v-for="(item,index) in params.specifications">{{item}},</text>
|
|
|
- <!-- <input type="text" placeholder="" v-model="params.specifications" value="" /> -->
|
|
|
+ <input type="text" placeholder="请输入市场价" v-model="params.originalPrice" value="" />
|
|
|
</view>
|
|
|
</view>
|
|
|
<view class="form-item">
|
|
|
<view class="form-item-til">保质期</view>
|
|
|
<view class="form-item-con">
|
|
|
- <input type="text" placeholder="请输入保质期" v-model="params.shelflife" value="" />
|
|
|
+ <input type="text" placeholder="请输入保质期" v-model="params.qualityGuaranteePeriod" value="" />
|
|
|
</view>
|
|
|
</view>
|
|
|
<view class="form-item">
|
|
|
<view class="form-item-til">生产日期</view>
|
|
|
<view class="form-item-con">
|
|
|
- <picker mode="date" :value="params.date" :start="startDate" :end="endDate" @change="bindDateChange">
|
|
|
- <view class="uni-input">{{params.date}}</view>
|
|
|
+ <picker mode="date" :value="params.dateOfManufacture" :start="startDate" :end="endDate" @change="bindDateChange">
|
|
|
+ <view class="uni-input">{{params.dateOfManufacture}}</view>
|
|
|
</picker>
|
|
|
<!-- <input type="text" placeholder="请输入生产日期" v-model="params.productiondate" value="" /> -->
|
|
|
</view>
|
|
|
</view>
|
|
|
<view class="form-item">
|
|
|
- <view class="form-item-til">包装</view>
|
|
|
+ <view class="form-item-til">商品介绍</view>
|
|
|
+ <view class="form-item-con" style="text-align: left;">
|
|
|
+ <!-- <editor id="editor" class="ql-container" v-model="params.description" placeholder="请输入商品介绍" ></editor> -->
|
|
|
+ <textarea placeholder="请输入商品介绍" v-model="params.description" auto-height />
|
|
|
+ <!-- <input type="text" placeholder="请输入商品介绍" v-model="params.description" value="" /> -->
|
|
|
+ </view>
|
|
|
+ </view>
|
|
|
+ <view class="form-item">
|
|
|
+ <view class="form-item-til">商品货号</view>
|
|
|
<view class="form-item-con">
|
|
|
- <input type="text" placeholder="请输入包装" v-model="params.packaging" value="" />
|
|
|
+ <input type="text" placeholder="请输入商品货号" v-model="params.productSn" value="" />
|
|
|
</view>
|
|
|
</view>
|
|
|
<view class="form-item">
|
|
|
+ <view class="form-item-til">计量单位</view>
|
|
|
+ <view class="form-item-con">
|
|
|
+ <input type="text" placeholder="请输入计量单位" v-model="params.unit" value="" />
|
|
|
+ </view>
|
|
|
+ </view>
|
|
|
+ <!-- <view class="form-item">
|
|
|
<view class="form-item-til">标签</view>
|
|
|
<view class="form-item-con">
|
|
|
<input type="text" placeholder="请输入标签,用逗号隔开" v-model="params.productlabel" value="" />
|
|
|
</view>
|
|
|
+ </view> -->
|
|
|
+ <view class="form-item">
|
|
|
+ <view class="form-item-til">排序</view>
|
|
|
+ <view class="form-item-con">
|
|
|
+ <input type="text" placeholder="排序数字" v-model="params.sort" value="" />
|
|
|
+ </view>
|
|
|
</view>
|
|
|
</view>
|
|
|
<view class="form-item upfile">
|
|
|
- <view class="form-item-til">图片视频</view>
|
|
|
+ <view class="form-item-til">上传图片</view>
|
|
|
<view class="form-item-con">
|
|
|
<view class="form-item-chooseIMGs-wrap">
|
|
|
- <image v-for="(item,index) in params.media" :key="index" :src="item" class="choosedIMG" ></image>
|
|
|
+ <view class="img-item" v-for="(item,index) in pics" :key="index" >
|
|
|
+ <icon type="cancel" @click="delImg(index)" size="26"/>
|
|
|
+ <image :src="item" @click="previewPic(index)" class="choosedIMG" ></image>
|
|
|
+ </view>
|
|
|
</view>
|
|
|
<view class="chooseIMG-btn">
|
|
|
<image class="chooseIMG-btn-img" @click="chooseimg" src="/static/img/icon-upload.png"></image>
|
|
@@ -126,21 +156,36 @@
|
|
|
</view>
|
|
|
<!-- 搜索 结束 -->
|
|
|
<scroll-view class="simplepage-wrap" scroll-y="true">
|
|
|
- <view v-for="(item,index) in placeoforiginlist" :key="index" @click="placeoforiginclick(item.detailAddress)" class="simplepage-item">{{item.detailAddress}}</view>
|
|
|
+ <view v-for="(item,index) in placeoforiginlist" :key="index" @click="placeoforiginclick(item)" class="simplepage-item">{{item.detailAddress}}</view>
|
|
|
</scroll-view>
|
|
|
</view>
|
|
|
<!-- 产地结束 -->
|
|
|
+ <!-- 品牌开始 -->
|
|
|
+ <view class="placeoforigin-page fix-content translate" :class="{ 'open':brandopen }" >
|
|
|
+ <view class="search-wrap search-left-color">
|
|
|
+ <view class="search">
|
|
|
+ <view class="searchTxt">
|
|
|
+ <uni-search-bar placeholder="搜索品牌关键词" @confirm="searchbrand" @input="searchbrand" ></uni-search-bar>
|
|
|
+ </view>
|
|
|
+ </view>
|
|
|
+ </view>
|
|
|
+ <!-- 搜索 结束 -->
|
|
|
+ <scroll-view class="simplepage-wrap" scroll-y="true">
|
|
|
+ <view v-for="(item,index) in brandlist" :key="index" @click="brandclick(item)" class="simplepage-item">{{item.brandName}}</view>
|
|
|
+ </scroll-view>
|
|
|
+ </view>
|
|
|
+ <!-- 牌结束 -->
|
|
|
<!-- 规格开始 -->
|
|
|
- <view class="specifications-page fix-content translate" :class="{ 'open': specificationsopen }" >
|
|
|
- <view class="specifications-wrap wrap">
|
|
|
+ <view class="spec-page fix-content translate" :class="{ 'open': specopen }" >
|
|
|
+ <view class="spec-wrap wrap">
|
|
|
<checkbox-group @change="checkboxChange">
|
|
|
- <label v-for="(item,index) in specificationslist" :key="index" class="checkbox-style" >
|
|
|
+ <label v-for="(item,index) in speclist" :key="index" class="checkbox-style" >
|
|
|
<checkbox :value="item.value" :checked="item.checked" />{{item.name}}
|
|
|
</label>
|
|
|
</checkbox-group>
|
|
|
<view class="pecifications-btn-wrap">
|
|
|
<button type="default" class="big-btn big-btn-hollow" @click="resetcheckbox">重置</button>
|
|
|
- <button type="default" class="big-btn primary" @click="specificationsclick">确定</button>
|
|
|
+ <button type="default" class="big-btn primary" @click="specclick">确定</button>
|
|
|
</view>
|
|
|
</view>
|
|
|
</view>
|
|
@@ -184,22 +229,37 @@
|
|
|
tip: '暂无相关数据'
|
|
|
}
|
|
|
},
|
|
|
+ thetoken:'',
|
|
|
params: {
|
|
|
token: '',
|
|
|
type:'',
|
|
|
myposition:'',
|
|
|
- title:'',
|
|
|
- brand:'',
|
|
|
+ name:'',
|
|
|
+ brandName:'',
|
|
|
+ brandId:'',
|
|
|
price:'',
|
|
|
- supplier:'默认的供应商',//供应商
|
|
|
- placeoforigin:'',//产地
|
|
|
- specifications:[],//规格
|
|
|
- shelflife:'',//保质期
|
|
|
- date: currentDate,//生产日期 // productiondate:'',//生产日期
|
|
|
- packaging:'',//包装
|
|
|
+ originalPrice:'',//市场价
|
|
|
+ compName:'默认的供应商',//供应商
|
|
|
+ compId:'',
|
|
|
+ placeOfProduction:'',//产地
|
|
|
+ spec:'',//规格
|
|
|
+ qualityGuaranteePeriod:'',//保质期
|
|
|
+ dateOfManufacture: currentDate,//生产日期 // productiondate:'',//生产日期
|
|
|
+ unit:'',//包装
|
|
|
productlabel:'',//标签
|
|
|
- media:[],//图片视频
|
|
|
+ albumPics:'',//图片视频
|
|
|
+ pic:'',
|
|
|
+ productBigCategoryId:'',//大类ID
|
|
|
+ productCategoryId:'',//类别id
|
|
|
+ productCategoryName:'',//类别名称
|
|
|
+ productBigCategoryName:'',//大类名称
|
|
|
+ placeOfProductionId:0,
|
|
|
+ publishStatus:"0",
|
|
|
+ productSn:'',//商品货号
|
|
|
+ sort:'',//排序
|
|
|
+ description:'',
|
|
|
},
|
|
|
+ pics:[],
|
|
|
//表单检查结果
|
|
|
checkStatus:false,
|
|
|
//供应商
|
|
@@ -208,10 +268,13 @@
|
|
|
// 产地
|
|
|
placeoforiginopen:false,
|
|
|
placeoforiginlist:[],
|
|
|
+ brandopen:false,
|
|
|
+ brandlist:[],
|
|
|
places:[],//临时暂存
|
|
|
+ brands:[],
|
|
|
// 规格
|
|
|
- specificationsopen:false,
|
|
|
- specificationslist:[
|
|
|
+ specopen:false,
|
|
|
+ speclist:[
|
|
|
{value: '500g/提(250g/盒*2)',name: '500g/提(250g/盒*2)',checked: false},
|
|
|
{value: '10g/罐',name: '10g/罐',checked: false},
|
|
|
{value: '30g/盒',name: '30g/盒',checked: false},
|
|
@@ -240,6 +303,10 @@
|
|
|
if(Object.keys(bus.data).length>0){
|
|
|
console.log('bus.data',bus.data)
|
|
|
this.params.type = bus.data.name;
|
|
|
+ this.params.productBigCategoryId = bus.data.parentId;
|
|
|
+ this.params.productCategoryId = bus.data.id;
|
|
|
+ this.params.productBigCategoryName = bus.data.productBigCategoryName;
|
|
|
+ this.params.productCategoryName = bus.data.name;
|
|
|
// console.log(this.params.type);
|
|
|
};
|
|
|
// console.log(option);
|
|
@@ -261,12 +328,22 @@
|
|
|
});
|
|
|
|
|
|
//供应商详情
|
|
|
- let thetoken = this.params.tokenhead+this.params.token;
|
|
|
- this.$api.http.get(this.config.apiBaseurl+'/company/cp/detail',{header: {Authorization:thetoken},params:{compId:72}}).then(res =>{
|
|
|
+ this.thetoken = this.params.tokenhead+this.params.token;
|
|
|
+ uni.getStorage({
|
|
|
+ key:'userInfo',
|
|
|
+ success: function (res) {
|
|
|
+ self.params.compId = res.data.company.compId;
|
|
|
+ self.params.compName = res.data.company.compName;
|
|
|
+ // console.log(res.data);
|
|
|
+ }
|
|
|
+ });
|
|
|
+ this.$api.http.get(this.config.apiBaseurl+'/company/cp/detail',{header: {Authorization:this.thetoken},params:{compId:this.params.compId}}).then(res =>{
|
|
|
console.log('res',JSON.parse(JSON.stringify(res)));
|
|
|
this.placeoforiginlist = res.data.data.origines;
|
|
|
+ this.brandlist = res.data.data.products;
|
|
|
+ this.brands = res.data.data.products;
|
|
|
this.places = res.data.data.origines;
|
|
|
- this.params.supplier= res.data.data.compName;
|
|
|
+ this.params.compName= res.data.data.compName;
|
|
|
}).catch( err => {
|
|
|
console.log(err)
|
|
|
});
|
|
@@ -297,8 +374,8 @@
|
|
|
return `${year}-${month}-${day}`;
|
|
|
},
|
|
|
bindDateChange: function(e) {
|
|
|
- this.params.date = e.target.value
|
|
|
- // console.log(this.params.date);
|
|
|
+ this.params.dateOfManufacture = e.target.value
|
|
|
+ // console.log(this.params.dateOfManufacture);
|
|
|
},
|
|
|
/*mescroll组件初始化的回调,可获取到mescroll对象 (此处可删,mixins已默认)*/
|
|
|
mescrollInit(mescroll) {
|
|
@@ -358,94 +435,171 @@
|
|
|
chooseimg() {
|
|
|
let _self = this;
|
|
|
uni.chooseImage({
|
|
|
- count: 3,
|
|
|
+ // count: 3,
|
|
|
sizeType: ['original', 'compressed'], //可以指定是原图还是压缩图,默认二者都有
|
|
|
sourceType: ['album', 'camera'], //从相册选择
|
|
|
success: function(res) {
|
|
|
+ console.log('res111',res);
|
|
|
const tempFilePaths = res.tempFilePaths;
|
|
|
_self.image = tempFilePaths[0];
|
|
|
console.log("tempFilePaths[0]", tempFilePaths[0]) //能够打印出选中的图片
|
|
|
_self.iconcheck = 1; //点击后图片更改状态由0变成1
|
|
|
console.log('111', JSON.stringify(res.tempFilePaths));
|
|
|
- _self.params.media = res.tempFilePaths;
|
|
|
- console.log(_self.params.media);
|
|
|
+ // _self.pics = res.tempFilePaths;
|
|
|
+ // console.log(_self.pics);
|
|
|
|
|
|
- // 预览图片
|
|
|
- // uni.previewImage({
|
|
|
- // urls: res.tempFilePaths,
|
|
|
- // longPressActions: {
|
|
|
- // // itemList: [],
|
|
|
- // success: function(data) {
|
|
|
- // console.log('选中了第' + (data.tapIndex + 1) + '个按钮,第' + (data.index + 1) + '张图片');
|
|
|
- // },
|
|
|
- // fail: function(err) {
|
|
|
- // console.log(err.errMsg);
|
|
|
- // }
|
|
|
- // }
|
|
|
- // });
|
|
|
-
|
|
|
+ const isLt10M = res.tempFiles[0].size / 1024 / 1024 < 10;
|
|
|
+ if(!isLt10M) {
|
|
|
+ uni.showToast({
|
|
|
+ title: "上传文件大小不能超过 10MB!",
|
|
|
+ icon:'none'
|
|
|
+ })
|
|
|
+ return false;
|
|
|
+ };
|
|
|
+ const imgNumber = _self.pics.length<5;
|
|
|
+ if(!imgNumber) {
|
|
|
+ uni.showToast({
|
|
|
+ title: "图片不能超过5张!",
|
|
|
+ icon:'none'
|
|
|
+ })
|
|
|
+ return false;
|
|
|
+ };
|
|
|
+
|
|
|
+ //上传图片
|
|
|
+ let obj = new Object();
|
|
|
+ let file=[];
|
|
|
+ obj.name = "file";
|
|
|
+ obj.uri = res.tempFiles[0].path;
|
|
|
+ file.push(obj);
|
|
|
+ _self.uploadTheImg(file);
|
|
|
},
|
|
|
error: function(e) {
|
|
|
console.log(e);
|
|
|
}
|
|
|
});
|
|
|
},
|
|
|
+ uploadTheImg(imgFiles){
|
|
|
+ let _self = this;
|
|
|
+ //上传图片
|
|
|
+ uni.uploadFile({
|
|
|
+ url: _self.config.apiBaseurl + '/upload/fileImg', // 后端api接口
|
|
|
+ fileType: "image",
|
|
|
+ files:imgFiles,
|
|
|
+ // filePath: imgFiles[0], // uni.chooseImage函数调用后获取的本地文件路劲
|
|
|
+ name: 'file', //后端通过'file'获取上传的文件对象(字段)
|
|
|
+ formData: {
|
|
|
+ // file:_self.image,
|
|
|
+ // openid:_self.openid, //剩下的字段
|
|
|
+ },
|
|
|
+ header: {
|
|
|
+ // "Content-Type":"multipart/form-data",
|
|
|
+ // Accept:'application/json',
|
|
|
+ Accept:'*/*',
|
|
|
+ Authorization: 'Bearer '+ _self.params.token, //注意Bearer后面有一空格
|
|
|
+ },
|
|
|
+ success: (res) => {
|
|
|
+ console.log(JSON.parse(res.data))
|
|
|
+ let data = JSON.parse(res.data);
|
|
|
+ _self.pics.push(data.data);
|
|
|
+ if (res.statusCode == 200) {
|
|
|
+ uni.showToast({
|
|
|
+ icon: 'success',
|
|
|
+ title: "添加成功...",
|
|
|
+ })
|
|
|
+ }
|
|
|
+
|
|
|
+ },
|
|
|
+ error(error) {
|
|
|
+ uni.showToast({
|
|
|
+ title: "添加失败...",
|
|
|
+ })
|
|
|
+ }
|
|
|
+ });
|
|
|
+ },
|
|
|
+ previewPic(index){
|
|
|
+ // 预览图片
|
|
|
+ uni.previewImage({
|
|
|
+ urls: this.pics,
|
|
|
+ current:index,
|
|
|
+ longPressActions: {//长按图片显示操作菜单,如不填默认为保存相册
|
|
|
+ success: function(data) {
|
|
|
+ console.log('选中了第' + (data.tapIndex + 1) + '个按钮,第' + (data.index + 1) + '张图片');
|
|
|
+ },
|
|
|
+ fail: function(err) {
|
|
|
+ console.log(err.errMsg);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ });
|
|
|
+
|
|
|
+ },
|
|
|
+ //删除图片
|
|
|
+ delImg(index){
|
|
|
+ console.log('index',index);
|
|
|
+ console.log('t',this.pics);
|
|
|
+ this.pics.splice(index,1);
|
|
|
+ console.log('t',this.pics);
|
|
|
+ },
|
|
|
//发布
|
|
|
publish() {
|
|
|
+ this.params.albumPics = this.pics.toString();
|
|
|
+ this.params.pic = this.pics[0];
|
|
|
this.checkStatus = this.check_form();
|
|
|
if(this.checkStatus){
|
|
|
let _self = this;
|
|
|
- //上传图片
|
|
|
- // uni.uploadFile({
|
|
|
- // url: _self.httpUrl + '', // 后端api接口
|
|
|
- // filePath: _self.image, // uni.chooseImage函数调用后获取的本地文件路劲
|
|
|
- // name: 'EmployeeImage', //后端通过'file'获取上传的文件对象(字段)
|
|
|
- // formData: {
|
|
|
- // // openid:_self.openid, //剩下的字段
|
|
|
- // },
|
|
|
- // header: {
|
|
|
- // "Content-Type": "multipart/form-data"
|
|
|
- // },
|
|
|
- // success: (res) => {
|
|
|
- // console.log(res)
|
|
|
- // if (res.statusCode == 200) {
|
|
|
- // uni.showToast({
|
|
|
- // icon: 'success',
|
|
|
- // title: "添加成功...",
|
|
|
- // })
|
|
|
- // }
|
|
|
- // setTimeout(() => {
|
|
|
- // uni.navigateTo({
|
|
|
- // url: ''
|
|
|
- // })
|
|
|
- // }, 2000)
|
|
|
-
|
|
|
- // },
|
|
|
- // error(error) {
|
|
|
- // uni.showToast({
|
|
|
- // title: "添加失败...",
|
|
|
- // })
|
|
|
- // }
|
|
|
- // });
|
|
|
uni.showLoading({
|
|
|
title: '请稍等'
|
|
|
- });
|
|
|
- setTimeout(function () {
|
|
|
- uni.hideLoading();
|
|
|
- }, 2000);
|
|
|
+ });
|
|
|
+ this.$api.http.post(this.config.apiBaseurl+'/prod/pub/add',this.params,{
|
|
|
+ header: {
|
|
|
+ Accept:'application/json',
|
|
|
+ Authorization: 'Bearer '+ this.params.token, //注意Bearer后面有一空格
|
|
|
+ }
|
|
|
+ }).then(res => {
|
|
|
+ uni.hideLoading();
|
|
|
+ console.log('res',res);
|
|
|
+ if(res.data.message =='暂未登录或token已经过期'){
|
|
|
+ // let loginurl = `${this.config.apiBaseurl}/wechat/h5/authorize?returnUrl=/pages/publish/publish`
|
|
|
+ // console.log('loginurl',loginurl);
|
|
|
+ uni.showToast({
|
|
|
+ title:res.data.message,
|
|
|
+ duration: 2000
|
|
|
+ });
|
|
|
+ setTimeout(() => {
|
|
|
+ window.location.replace(this.config.loginUrl);
|
|
|
+ }, 2000);
|
|
|
+ };
|
|
|
+ uni.showToast({
|
|
|
+ icon:'success',
|
|
|
+ title:`发布成功,请等待审核!`,
|
|
|
+ duration: 2000
|
|
|
+ });
|
|
|
+ setTimeout(() => {
|
|
|
+ uni.redirectTo({
|
|
|
+ url:'/pages/publish/publishsuccess/publishsuccess'
|
|
|
+ })
|
|
|
+ }, 2000);
|
|
|
+ }).catch(err => {
|
|
|
+ uni.hideLoading();
|
|
|
+ console.log(err)
|
|
|
+ });
|
|
|
+
|
|
|
+
|
|
|
+ // setTimeout(function () {
|
|
|
+ // uni.hideLoading();
|
|
|
+ // }, 2000);
|
|
|
// setTimeout(()=>{
|
|
|
- // uni.showToast({
|
|
|
- // icon:'success',
|
|
|
- // title:`发布成功,请等待审核!`,
|
|
|
- // duration: 2000
|
|
|
- // });
|
|
|
+ // uni.showToast({
|
|
|
+ // icon:'success',
|
|
|
+ // title:`发布成功,请等待审核!`,
|
|
|
+ // duration: 2000
|
|
|
+ // });
|
|
|
// },2000);
|
|
|
|
|
|
- setTimeout(() => {
|
|
|
- uni.redirectTo({
|
|
|
- url:'/pages/publish/publishsuccess/publishsuccess'
|
|
|
- })
|
|
|
- }, 2000);
|
|
|
+ // setTimeout(() => {
|
|
|
+ // uni.redirectTo({
|
|
|
+ // url:'/pages/publish/publishsuccess/publishsuccess'
|
|
|
+ // })
|
|
|
+ // }, 2000);
|
|
|
}
|
|
|
|
|
|
},
|
|
@@ -453,7 +607,7 @@
|
|
|
check_form() {
|
|
|
console.log('this.params',this.params);
|
|
|
if(this.params.type.length <= 0) {
|
|
|
- uni.showToast({icon:'none',title:`请填写类别!`,duration: 2000});
|
|
|
+ uni.showToast({icon:'none',title:`请到'我要发布页'选择类别!`,duration: 2000});
|
|
|
return false;
|
|
|
}
|
|
|
// if(this.params.myposition.length <= 0) {
|
|
@@ -461,47 +615,47 @@
|
|
|
// uni.showToast({icon:'none',title:`请填写地理位置!`,duration: 2000});
|
|
|
// return false;
|
|
|
// }
|
|
|
- if(this.params.title.length <= 0) {
|
|
|
- uni.showToast({icon:'none',title:`请填写标题!`,duration: 2000});
|
|
|
+ if(this.params.name.length <= 0) {
|
|
|
+ uni.showToast({icon:'none',title:`请填写商品名称!`,duration: 2000});
|
|
|
return false;
|
|
|
}
|
|
|
- if(this.params.brand.length <= 0) {
|
|
|
+ if(this.params.brandName.length <= 0) {
|
|
|
uni.showToast({icon:'none',title:`请填写品牌!`,duration: 2000});
|
|
|
return false;
|
|
|
}
|
|
|
- if(this.params.price.length <= 0) {
|
|
|
- uni.showToast({icon:'none',title:`请填写零售价!`,duration: 2000});
|
|
|
- return false;
|
|
|
- }
|
|
|
- if(this.params.supplier.length <= 0) {
|
|
|
+ // if(this.params.price.length <= 0) {
|
|
|
+ // uni.showToast({icon:'none',title:`请填写零售价!`,duration: 2000});
|
|
|
+ // return false;
|
|
|
+ // }
|
|
|
+ if(this.params.compName.length <= 0) {
|
|
|
uni.showToast({icon:'none',title:`请填写供应商!`,duration: 2000});
|
|
|
return false;
|
|
|
}
|
|
|
- if(this.params.placeoforigin.length <= 0) {
|
|
|
+ if(this.params.placeOfProduction.length <= 0) {
|
|
|
uni.showToast({icon:'none',title:`请填写生产地!`,duration: 2000});
|
|
|
return false;
|
|
|
}
|
|
|
- if(this.params.specifications.length <= 0) {
|
|
|
+ if(this.params.spec.length <= 0) {
|
|
|
uni.showToast({icon:'none',title:`请填写规格!`,duration: 2000});
|
|
|
return false;
|
|
|
}
|
|
|
- if(this.params.shelflife.length <= 0) {
|
|
|
- uni.showToast({icon:'none',title:`请填写保质期!`,duration: 2000});
|
|
|
- return false;
|
|
|
- }
|
|
|
- if(this.params.date.length <= 0) {
|
|
|
- uni.showToast({icon:'none',title:`请填写生产日期!`,duration: 2000});
|
|
|
- return false;
|
|
|
- }
|
|
|
- if(this.params.packaging.length <= 0) {
|
|
|
- uni.showToast({icon:'none',title:`请填写包装!`,duration: 2000});
|
|
|
- return false;
|
|
|
- }
|
|
|
- if(this.params.productlabel.length <= 0) {
|
|
|
- uni.showToast({icon:'none',title:`请填写标签!`,duration: 2000});
|
|
|
- return false;
|
|
|
- }
|
|
|
- if(this.params.media.length <= 0) {
|
|
|
+ // if(this.params.qualityGuaranteePeriod.length <= 0) {
|
|
|
+ // uni.showToast({icon:'none',title:`请填写保质期!`,duration: 2000});
|
|
|
+ // return false;
|
|
|
+ // }
|
|
|
+ // if(this.params.dateOfManufacture.length <= 0) {
|
|
|
+ // uni.showToast({icon:'none',title:`请填写生产日期!`,duration: 2000});
|
|
|
+ // return false;
|
|
|
+ // }
|
|
|
+ // if(this.params.unit.length <= 0) {
|
|
|
+ // uni.showToast({icon:'none',title:`请填写计量单位!`,duration: 2000});
|
|
|
+ // return false;
|
|
|
+ // }
|
|
|
+ // if(this.params.productlabel.length <= 0) {
|
|
|
+ // uni.showToast({icon:'none',title:`请填写标签!`,duration: 2000});
|
|
|
+ // return false;
|
|
|
+ // }
|
|
|
+ if(this.params.albumPics.length <= 0) {
|
|
|
uni.showToast({icon:'none',title:`请上传图片!`,duration: 2000});
|
|
|
return false;
|
|
|
}
|
|
@@ -509,7 +663,7 @@
|
|
|
},
|
|
|
//选择供应商
|
|
|
// supplierclick(name){
|
|
|
- // this.params.supplier = name;
|
|
|
+ // this.params.compName = name;
|
|
|
// this.supplieropen = false;
|
|
|
// this.showback();
|
|
|
// },
|
|
@@ -523,8 +677,10 @@
|
|
|
// console.log(e);
|
|
|
// },
|
|
|
//选择生产地
|
|
|
- placeoforiginclick(name){
|
|
|
- this.params.placeoforigin = name;
|
|
|
+ placeoforiginclick(item){
|
|
|
+ console.log('placeoforiginclick',item);
|
|
|
+ this.params.placeOfProduction = item.detailAddress;
|
|
|
+ this.params.placeOfProductionId = item.id;
|
|
|
this.placeoforiginopen = false;
|
|
|
this.showback();
|
|
|
},
|
|
@@ -533,20 +689,33 @@
|
|
|
this.placeoforiginopen = true;
|
|
|
this.hideback();
|
|
|
},
|
|
|
+ //选择品牌
|
|
|
+ brandclick(brand){
|
|
|
+ // console.log('brand',brand);
|
|
|
+ this.params.brandName = brand.brandName;
|
|
|
+ this.params.brandId = brand.brandId;
|
|
|
+ this.brandopen = false;
|
|
|
+ this.showback();
|
|
|
+ },
|
|
|
+ //打开品牌弹出框
|
|
|
+ openbrand(){
|
|
|
+ this.brandopen = true;
|
|
|
+ this.hideback();
|
|
|
+ },
|
|
|
//选择规格
|
|
|
- specificationsclick(e){
|
|
|
- // this.params.specifications = name;
|
|
|
- this.specificationsopen = false;
|
|
|
+ specclick(e){
|
|
|
+ // this.params.spec = name;
|
|
|
+ this.specopen = false;
|
|
|
this.showback();
|
|
|
},
|
|
|
//打开规格弹出框
|
|
|
- openspecifications(){
|
|
|
- this.specificationsopen = true;
|
|
|
+ openspec(){
|
|
|
+ this.specopen = true;
|
|
|
this.hideback();
|
|
|
},
|
|
|
// 规格checkbox
|
|
|
checkboxChange: function (e) {
|
|
|
- var items = this.specificationslist,
|
|
|
+ var items = this.speclist,
|
|
|
values = e.detail.value;
|
|
|
for (var i = 0, lenI = items.length; i < lenI; ++i) {
|
|
|
const item = items[i]
|
|
@@ -556,17 +725,17 @@
|
|
|
this.$set(item,'checked',false)
|
|
|
}
|
|
|
}
|
|
|
- this.params.specifications = e.detail.value;
|
|
|
- console.log(this.params.specifications);
|
|
|
+ this.params.spec = e.detail.value;
|
|
|
+ console.log(this.params.spec);
|
|
|
},
|
|
|
resetcheckbox(){
|
|
|
- var items = this.specificationslist;
|
|
|
+ var items = this.speclist;
|
|
|
for (var i = 0, lenI = items.length; i < lenI; ++i) {
|
|
|
const item = items[i];
|
|
|
this.$set(item,'checked',false)
|
|
|
}
|
|
|
- this.params.specifications = [];
|
|
|
- // console.log(this.params.specifications);
|
|
|
+ this.params.spec = [];
|
|
|
+ // console.log(this.params.spec);
|
|
|
},
|
|
|
//隐藏返回按钮
|
|
|
hideback(){
|
|
@@ -580,11 +749,11 @@
|
|
|
// let backbtn = document.getElementsByClassName('uni-page-head-hd')[0];
|
|
|
// backbtn.style.display = 'block';
|
|
|
this.backtyep = 1;
|
|
|
- console.log(this.backtyep)
|
|
|
+ // console.log(this.backtyep)
|
|
|
},
|
|
|
// 导航返回按钮
|
|
|
onBackPress(e){
|
|
|
- console.log(this.backtyep)
|
|
|
+ // console.log(this.backtyep)
|
|
|
if(this.backtyep == 2){
|
|
|
this.placeoforiginopen = false;
|
|
|
this.backtyep = 1;
|
|
@@ -616,6 +785,20 @@
|
|
|
}else{
|
|
|
this.placeoforiginlist = this.places;
|
|
|
}
|
|
|
+ },
|
|
|
+ // 搜索品牌
|
|
|
+ searchbrand(e){
|
|
|
+ console.log('品牌',e);
|
|
|
+ if(e.value){
|
|
|
+ let brand = this.brandlist.filter(function (value) {
|
|
|
+ console.log(value);
|
|
|
+ return value.brandName.includes(e.value);
|
|
|
+ });
|
|
|
+ console.log('brand',brand);
|
|
|
+ this.brandlist = brand;
|
|
|
+ }else{
|
|
|
+ this.brandlist = this.brands;
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
|