Browse Source

项目试运行优化

gcz 4 years ago
parent
commit
58b9bd8319

+ 29 - 2
common/css/common.css

@@ -5,10 +5,11 @@ input{outline: 0!important;}
 uni-button[type=primary]{background-color: #6BBC6D;}
 
 .wrap{margin: 0 40rpx;}
+.wrap24{margin: 0 24rpx;}
 .page-wrap{padding: 24rpx;}
 
 /* 轮播 */
-.appAdv{height:400rpx;}
+.appAdv{position: relative;height:400rpx;background-color: #fff;}
 .appAdv .adv-item{height:100%;}
 .appAdv .adv-item .pic{width:750rpx;height:100%;}
 .appAdv .swiper{height:100%;}
@@ -146,4 +147,30 @@ uni-button[type=primary]{background-color: #6BBC6D;}
 .bill-product-unit{font-size: 24rpx;color: #999;}
 .bill-product-number{font-size: 24rpx;color: #999;}
 .bill-info .form-item:last-of-type{border-bottom: 0;}
-.bill-info .amount{color: #FF5030;font-weight: bold;}
+.bill-info .amount{color: #FF5030;font-weight: bold;}
+
+.main-body{margin-bottom: 24rpx;background-color: #fff;border-radius: 16rpx;}
+.main-body-til{display: flex;justify-content: space-between;align-items: center;padding: 24rpx;border-bottom: 1px solid #ddd;}
+.main-body-til.color .til,
+.main-body-til.color .con
+{color: #6BBC6D;}
+.main-body-til.noborder{border-bottom: 0;}
+.main-body-til .til{font-size: 30rpx;font-weight: 600;color: #333;}
+.main-body-til .con{display: flex;align-items: center;font-size: 24rpx;color: #666;}
+
+/*图片铺满从中间显示*/
+.cover-img >>> div{background-size: cover!important;background-position: center!important;}
+
+/* 搜索结果页 专题列表 */
+.results-item{display: flex;margin-bottom: 24rpx;padding-bottom: 29rpx;border-bottom: 1px solid #eee;}
+.results-item:last-of-type{border-bottom: 0;}
+.results-item-img-wrap{width: 220rpx;height: 220rpx;margin-right: 24rpx;overflow: hidden;border-radius: 12rpx;}
+.results-item-img-wrap .results-item-img{width: 100%;height: 100%;}
+.results-item-info{flex: 1;}
+.results-item-info-til{margin-bottom: 10rpx;}
+.results-item-info-brand{color: #999;margin-bottom: 10rpx;}
+.results-item-info-addr{color: #666;margin-bottom: 10rpx;font-size: 24rpx;}
+.results-item-info-label .postage{height: 24rpx;padding: 0 14rpx;margin-left: 16rpx;line-height: 24rpx;display: inline-block;font-size: 20rpx;background-color: #E1F2E2;border-radius: 12rpx;}
+.results-item-info-price .rmb{font-size: 28rpx;font-weight: 500;color: #FF5030;line-height: 40rpx;}
+.results-item-info-price .price{font-size: 36rpx;font-weight: 500;color: #FF5030;line-height: 50rpx;}
+.results-item-info-price .minsell{font-size: 24rpx;font-weight: 400;color: #999999;line-height: 33rpx;}

+ 5 - 3
config/config.js

@@ -6,6 +6,7 @@ const config = {
 	// apiBaseurl:'http://172.16.90.3:9098/forest-portal',//邱波
 	// apiBaseurl:'http://wx.hw.hongweisoft.com/zddtest/forest-portal',//东东
 	// apiBaseurl:'http://wx.hw.hongweisoft.com/zddapi/forest-portal',//东东
+	apiBaseurl:'http://wx.hw.hongweisoft.com/fqb/forest-portal',//东东
 		
 	//本地图片
 	// imgUrl:'http://'+window.location.host,
@@ -14,7 +15,8 @@ const config = {
 	
 	// loginUrl:'http://tanhui.hongweisoft.com/forest-portal/wechat/h5/authorize?returnUrl=/',//登录后跳转到测试链接
 	// loginUrl:'http://forest.hw.hongweisoft.com/data/forest-portal/wechat/h5/authorize?returnUrl=http://forest.hw.hongweisoft.com/#/',//登录后跳转链接
-	// loginUrl:'http://wx.hw.hongweisoft.com/zddapi/forest-portal/wechat/h5/authorize?returnUrl=http://172.16.90.25:8081/#/',//登录后跳转到测试链接 东东
+	// loginUrl:'http://wx.hw.hongweisoft.com/zddtest/forest-portal/wechat/h5/authorize?returnUrl=http://172.16.90.25:8080/#/',//登录后跳转到测试链接 东东
+	loginUrl:'http://wx.hw.hongweisoft.com/fqb/forest-portal/wechat/h5/authorize?returnUrl=http://172.16.90.25:8080/#/',//登录后跳转到测试链接 东东
 	// loginUrl:'http://wx.hw.hongweisoft.com/zddtest/forest-portal/wechat/h5/authorize?returnUrl=http://foresth5test.hw.hongweisoft.com/#/',//登录后跳转到测试链接 东东
 	// loginUrl:'http://wx.hw.hongweisoft.com/zddtest/forest-portal/wechat/h5/authorize?returnUrl=http://wx.hw.hongweisoft.com/gcz/#/',//登录后跳转到测试链接 东东
 
@@ -24,8 +26,8 @@ const config = {
 	
 	
 	//online 线上配置
-	loginUrl:'http://wxh5.gzqlyx.com/api/forest-portal/wechat/h5/authorize?returnUrl=http://wxh5.gzqlyx.com/#/',//登录后跳转链接
-	apiBaseurl:'http://wxh5.gzqlyx.com/api/forest-portal',
+	// loginUrl:'http://wxh5.gzqlyx.com/api/forest-portal/wechat/h5/authorize?returnUrl=http://wxh5.gzqlyx.com/#/',//登录后跳转链接
+	// apiBaseurl:'http://wxh5.gzqlyx.com/api/forest-portal',
 
 	
 	

+ 3 - 0
main.js

@@ -98,6 +98,9 @@ Vue.prototype.$wxApi = $wxApi;
 import $pay from "./pay.js";
 Vue.prototype.$pay = $pay
 
+import isTime from "utils/isTimes.js"
+Vue.prototype.isTime = isTime
+
 Vue.prototype.$api = {msg,http,setNavbarTitle}
 Vue.prototype.$getimg = config.imgUrl
 Vue.prototype.$placeImg = config.placeImg

+ 6 - 0
pages.json

@@ -56,6 +56,12 @@
 				"navigationBarTitleText": "贵州林产品-搜索结果"
 			}
 		},
+		{
+			"path": "pages/subject/subject",
+			"style": {
+				"navigationBarTitleText": "贵州林产品"
+			}
+		},
 		{
 			"path": "pages/product/product",
 			"style": {

+ 33 - 14
pages/index/index.css

@@ -1,17 +1,19 @@
+page{background-color: #F6F7F8;}
 /* 搜索修改 */
-.search-wrap{padding: 10rpx 8rpx;background-color: #fff;}
-.index >>> .uni-searchbar__box{justify-content: left;border: 0;background-color: #F1F1F2!important;}
+.search-wrap{padding: 10rpx 8rpx;background-color: #F6F7F8;}
+.index >>> .uni-searchbar__box{justify-content: left;border: 0;background-color: #ECEDEE!important;}
+.index >>> .uni-searchbar{background-color: #F6F7F8;}
 
 .index >>> .mescroll-downwarp{z-index: -1;}
 .mescroll-body{overflow: visible;}
 
-.appAdv{height:300rpx;}
+.appAdv{height:300rpx;background-color: #F6F7F8;}
 .appAdv .adv-item .pic{width: 100%;}
 .appAdv .adv-item{border-radius: 24rpx;overflow: hidden;transform: scale(0.9);transition: all .3s;}
 .appAdv .adv-item.active{transform: scale(1);}
 
 /* 快速导航 */
-.quick-links{display: flex;flex-wrap: wrap;padding: 0;justify-content: space-between;}
+/* .quick-links{display: flex;flex-wrap: wrap;padding: 0;justify-content: space-between;}
 .quick-links-item{width: 48%;margin-bottom: 24rpx;position: relative;}
 .quick-links .quick-links-item:nth-child(1){color: #4A90E2;}
 .quick-links .quick-links-item:nth-child(2){color: #397B53;}
@@ -20,15 +22,21 @@
 .quick-links-item-til{position: absolute;left: 16rpx;top: 16rpx;z-index: 10;font-size: 24rpx;font-weight: bold;}
 .quick-links-item-subtil{position: absolute;left: 16rpx;top: 53rpx;z-index: 10;font-size: 16rpx;}
 .quick-links-item-img{width: 100%;height: 160rpx;overflow: hidden;border-radius: 10rpx;}
-.quick-links-item-img image{width: 100%;height: 100%;}
+.quick-links-item-img image{width: 100%;height: 100%;} */
+
+.subject{margin-bottom: 24rpx;display: flex;justify-content: space-between;padding: 0 50rpx;}
+.subject-item{width: 100rpx;text-align: center;}
+.subject-item-img{margin: 0 auto 8rpx;width: 78rpx;height: 78rpx;}
+.subject-item-img .img{width: 100%;height: 100%;}
+.subject-item-til{font-size: 24rpx;color: #417505;line-height: 33rpx;}
 
 /* 分类链接 */
 .category{display: flex;align-items: end;height: 88rpx;line-height: 88rpx;background-color: #fff;}
 .category .category-item{position: relative;height: 100%;text-align: center;overflow: hidden;white-space: nowrap;text-overflow: ellipsis;font-size: 32rpx;color: #666;}
 .category .category-item.active{font-size: 36rpx;color: #6BBC6D;}
 .category .category-item.active::after{content: '';width: 100%;height: 6rpx;background-color: #6BBC6D;border-radius: 3rpx;position: absolute;left: 0;bottom: 0;}
-.category .category-item-more{color: #6BBC6D;width: 100rpx;padding-right: 10rpx;margin-right: 10rpx;}
-.category .category-item-more::after{content: '';width: 20rpx;height: 20rpx;position: absolute;right: 10rpx;top: 50%;margin-top: -10rpx;border-top: 1px solid #6BBC6D;border-right: 1px solid #6BBC6D;transform: rotate(45deg);}
+.category .category-item-more{font-size: 24rpx;color: #6BBC6D;padding-left: 24rpx;margin-right: 10rpx;}
+/* .category .category-item-more::after{content: '';width: 20rpx;height: 20rpx;position: absolute;right: 10rpx;top: 50%;margin-top: -10rpx;border-top: 1px solid #6BBC6D;border-right: 1px solid #6BBC6D;transform: rotate(45deg);} */
 .category .category-item-all{margin-left: 40rpx;}
 .category-scroll-view{flex: 1;overflow: hidden;white-space: nowrap;padding-left: 23rpx;}
 .category-scroll-view .category-item{display: inline-block;margin: 0 23rpx;}
@@ -47,12 +55,12 @@
 .indexproduct .item-wrap .item{box-shadow: 0px 0px 14px -4px rgba(0, 0, 0, 0.3);border-radius: 18rpx;}
 .indexproduct .item-wrap:nth-child(odd) .item{margin-right: 11rpx;}
 .indexproduct .item-wrap:nth-child(even) .item{margin-left: 11rpx;}
-.indexproduct .item-img-wrap{overflow: hidden;width: 100%;height: 322rpx;margin-bottom: 15rpx;border-top-left-radius: 18rpx;border-top-right-radius: 18rpx;}
+.indexproduct .item-img-wrap{overflow: hidden;width: 100%;height: 322rpx;margin-bottom: 12rpx;border-top-left-radius: 18rpx;border-top-right-radius: 18rpx;}
 .indexproduct .item-img{width: 100%;height: 100%;}
-.indexproduct .item-text-wrap{padding:  0 24rpx 25rpx;padding-right: 0;box-sizing: border-box;height: 192rpx;}
-.indexproduct .merchant{line-height: 33rpx;margin-bottom: 5rpx;color: #6BBC6D;}
+.indexproduct .item-text-wrap{padding:  0 24rpx 25rpx;padding-right: 0;box-sizing: border-box;height: 150rpx;}
+.indexproduct .merchant{line-height: 33rpx;color: #6BBC6D;font-size: 24rpx;}
 .indexproduct .merchant .postage{height: 24rpx;padding: 0 14rpx;margin-left: 16rpx;line-height: 24rpx;display: inline-block;font-size: 20rpx;background-color: #E1F2E2;border-radius: 12rpx;}
-.indexproduct .item-til{font-size: 32rpx;font-weight: 500;color: #333;line-height: 45rpx;margin-bottom: 5rpx;}
+.indexproduct .item-til{font-size: 32rpx;font-weight: 500;color: #333;line-height: 45rpx;}
 .indexproduct .item-addr{font-size: 24rpx;font-weight: 400;color: #666;line-height: 33rpx;margin-bottom: 5rpx;}
 .indexproduct .item-price-info .rmb{font-size: 28rpx;font-weight: 500;color: #FF5030;line-height: 40rpx;}
 .indexproduct .item-price-info .price{font-size: 36rpx;font-weight: 500;color: #FF5030;line-height: 50rpx;}
@@ -60,8 +68,19 @@
 .indexproduct .item-price-info .unit{font-size: 24rpx;font-weight: 400;color: #999999;line-height: 33rpx;}
 
 
+.index >>> .u-notice-bar-wrap .iconfont{color: #feaa36;}
+.index >>> .uni-popup .fade-out:first-of-type{background-color: rgba(0, 0, 0, 0.75)!important;}
+.uni-popup{z-index: 999;}
+.promotion{width: 100vw;position: relative;text-align: center;}
+.promotion .image{width:625rpx;height: 962rpx;display: block;margin: 0 auto 32rpx;}
+.close-wrap{}
+.promotion .imgclose{width: 60rpx;height: 60rpx;}
 
+/* .supplier-list{padding: 0 16rpx 24rpx;} */
+.suppliers{display: flex;}
+.supplier-list-item{flex-shrink: 0;width: 142rpx;margin-right: 20rpx;display: inline-block;}
+.supplier-list-item-img{display: block;width: 100%;height: 108rpx;margin-bottom: 7rpx;}
+.supplier-list-item-img .img{width: 100%;height: 100%;}
+.supplier-list-item-til{font-size: 24rpx;color: #666;line-height: 33rpx;height: 64rpx;overflow: hidden;}
 
-
-
-
+.rollbuy{position: absolute;top: 89rpx;left: 0;height: 54rpx;line-height: 54rpx;background-color: rgba(0,0,0,0.47);color: #fff;border-top-right-radius: 50rpx;border-bottom-right-radius: 50rpx;font-size: 24rpx;padding: 0 30rpx 0 16rpx;}

+ 166 - 10
pages/index/index.vue

@@ -1,5 +1,6 @@
 <template>
 	<view class="pages index">
+		<!-- <u-notice-bar mode="vertical" type="success" bg-color="#fdf6ec" color="#feaa36" :list="rollbuylist"></u-notice-bar> -->
 		<view class="search-wrap">
 			<view class="search">
 				<view class="searchTxt">
@@ -17,9 +18,11 @@
 					</view>
 				</swiper-item>
 			</swiper>
+			<view class="rollbuy" v-if="rollbuytext">{{rollbuytext}}</view>
 		</view>
 		<!-- 轮播结束 -->
-		<view class="quick-links wrap write-radius nomal-bottom">
+		<!-- <view class="quick-links wrap write-radius nomal-bottom">
+			
 			<navigator class="quick-links-item" url="/pages/supplier/supplier">
 				<view class="quick-links-item-til">供应商</view>
 				<view class="quick-links-item-subtil">保供稳价</view>
@@ -43,14 +46,44 @@
 				<view class="quick-links-item-subtil">全国走货</view>
 				<view class="quick-links-item-img"><image src="/static/img/quick-links-01.png" mode="scaleToFill"></image></view>				
 			</navigator>
+		</view> -->
+		<view class="subject">
+			<view class="subject-item" v-for="(item,index) in subjectList" @click="gosubject(item.id,item.title)">
+				<view class="subject-item-img"><image :src="item.pic" class="img" mode="scaleToFill"></image></view>
+				<view class="subject-item-til">{{item.title}}</view>
+			</view>
 		</view>
 		<!-- 快速导航 结束 -->
+		<view class="main-body wrap24">
+			<view class="main-body-til noborder color">
+				<view class="til">供应商</view>
+				<view class="con">
+					<navigator class="quick-links-item" url="/pages/supplier/supplier">
+						更多&gt;			
+					</navigator>
+				</view>
+			</view>			
+			<scroll-view class="supplier-list" scroll-x="true">
+				<view class="" style="padding: 0 16rpx 24rpx;">
+				<view class="suppliers">
+					<view class="supplier-list-item" v-for="(item,index) in supplierList" @click="supplierclick(item.id)" >
+						<view class="supplier-list-item-img">
+							<image v-if="item.files[0]" :src="item.files[0].fileUrl ||'/static/img/defaultsupplierlogo.png'" class="img" mode="aspectFit"></image>
+							<image v-else src="/static/img/defaultsupplierlogo.png" class="img" mode="scaleToFill"></image>
+						</view>
+						<view class="supplier-list-item-til">{{item.compName}}</view>
+					</view>
+				</view>	
+				</view>
+			</scroll-view>
+		</view>		
+		<!-- 供应商结束 -->
 		<view class="category nomal-bottom">
 			<view class="category-item category-item-all" @click="category()" :class="{active:categoryall==true}">全部</view>
 			<scroll-view scroll-x="true" class="scroll-X category-scroll-view">
 				<view v-for="(item,index) in categorylink" :key="index" @click="categoryclick(index)" :class="{active:index==ins && notall==true}" class="category-item">{{item.name}}</view>
 			</scroll-view>			
-			<navigator class="category-item category-item-more" url="/pages/productcategory/productcategory">更多</navigator>
+			<navigator class="category-item category-item-more" url="/pages/productcategory/productcategory">更多&gt;</navigator>
 			<!-- <navigator v-for="(item,index) in categorylink" :key="index" class="category-item" :url="'pages/searchresults/searchresults?type=' + item">{{item}}</navigator> -->
 		</view>
 		<!-- 分类链接结束 -->	
@@ -59,7 +92,7 @@
 				 <view class="item-wrap" v-for="(item,index) in mescrollList" :key="index">
 					<view class="item" :data-id="item.id" @click="jumpDetails(item.id)">
 						<view class="item-img-wrap">
-							<image :src="$getimg+item.pic|miniImg(50)+'/thumbnail/358x354'||'/static/img/inbuild.png'" class="item-img" mode="aspectFit"></image>
+							<image :src="$getimg+item.pic|miniImg(50)+'/thumbnail/358x354'||'/static/img/inbuild.png'" class="item-img cover-img" mode="scaleToFill"></image>
 						</view>
 						<view class="item-text-wrap">
 							<view class="merchant f-ellipsis">
@@ -82,7 +115,15 @@
 		<!-- 商品展示结束 -->
 		
 		
-		
+		<uni-popup ref="promotionPopup" type="center">
+			<view class="promotion" v-if="promotion.pic">				
+				<image class="image" :src="promotion.pic" mode="aspectFit" @click="jumLink(promotion.url)"></image>
+				<view class="close-wrap">
+					<!-- <text class="iconfont iconjiahao close" @click="closePromotion()"></text> -->
+					<image src="../../static/img/close.png" class="imgclose" mode="scaleToFill" @click="closePromotion()"></image>
+				</view>
+			</view>
+		</uni-popup>
 	</view>
 </template>
 
@@ -95,11 +136,18 @@
 	import MescrollMixin from "@/components/mescroll-uni/mescroll-mixins.js";	
 	// 引入mescroll-body组件 (如已在main.js注册全局组件,则省略此步骤)
 	import MescrollBody from "@/components/mescroll-uni/mescroll-body.vue"; // 注意.vue后缀不能省
+	
+	// import uNoticeBar from '@/components/u-notice-bar/u-notice-bar.vue'
+	import uniPopup from '@/components/uni-popup/uni-popup.vue'
+	import { debounce } from '@/utils/util.js'
+	let timer = null;
 	export default {
 		mixins: [MescrollMixin], // 使用mixin
 		components: {
 			MescrollBody,
 			uniSearchBar,
+			// uNoticeBar,
+			uniPopup
 		},
 		data() {
 			return {
@@ -110,6 +158,7 @@
 					productCategoryId:'',
 					// productCategoryName:'',
 				},
+				rollbuylist:[],
 				//轮播数据
 				advertiseList:[],
 				swiper: {
@@ -145,6 +194,14 @@
 				categoryall:true,
 				notall:false,
 				thispage:'',
+				//专题列表
+				subjectList:[],
+				//推广弹窗
+				promotion:new Object(),
+				supplierList:[],
+				supplierparams:Object.assign({},{pageNum:1,pageSize:5}),
+				buylistparams:Object.assign({},{pageNum:1,pageSize:100}),
+				rollbuytext:'',//购买弹出的内容
 				
 			}
 		},
@@ -236,13 +293,23 @@
 			}).catch(err => {
 				console.log(err)
 			});
-		
-		},
-		onShow() {
 			
 			
+			//首页内容页信息展示
+			this.gethomecontent();
+			//供应商列表
+			// this.getsupplierlist()
+			
+		},
+		mounted() {
 			
-		},		
+		},
+		onShow() {
+			this.getrollbuylist();//获取购买滚动信息
+		},
+		onHide() {
+			clearInterval(timer);
+		},
 		methods: {
 			// #ifdef H5
 			...mapMutations(['setLogin']),
@@ -278,7 +345,7 @@
 						// 	url:'/pages/login/login?backpage=/pages/index/index'+'&backtype='+2,
 						// });							
 					};
-					console.log(data);
+					// console.log(data);
 					// 接口返回的当前页数据列表 (数组)
 					let curPageData = data.data.data.list; 
 					// console.log('curPageData',curPageData);
@@ -369,13 +436,102 @@
 			//swiperchange
 			swiperchange(e){
 				this.currentswiper = e.detail.current;
+			},
+			//获取购买滚动信息
+			getrollbuylist(){
+				this.$api.http.get(this.config.apiBaseurl+'/home/roll-buy', {header: {Authorization:this.params.tokenhead+this.params.token},params: this.buylistparams}).then(res => {
+					// console.log('getrollbuylist',res.data.data.list);
+					let list = res.data.data.list;
+					this.rollbuylist = [];
+					for(let item in list){
+						// console.log('item',list[item])
+						this.rollbuylist.push(list[item].memberName.replace(/.(?=.)/g, '*')+' 购买了 '+list[item].productName+' 价值 '+list[item].money+'元')
+					}
+					this.showbuy();
+					// console.log('this.rollbuylist',this.rollbuylist)
+					// this.rollbuylist = res.data.data.rollbuylist;
+				}).catch(err => {
+					console.log(err)
+				});
+			},
+			showbuy(){
+				// console.log('this.rollbuylist',this.rollbuylist);
+				let self = this;
+				var i = 0;
+				timer = setInterval(function(){
+					// console.log(self.rollbuylist[i]);
+					self.rollbuytext = self.rollbuylist[i];
+					setTimeout(function(){self.rollbuytext = ''},2000);
+					i++;
+					if(i > self.rollbuylist.length-1){
+						i=0
+						// clearInterval(timer);
+						// self.getrollbuylist();
+					}
+				},4000);
+			},		
+			//首页内容页信息展示			
+			gethomecontent(){
+				this.$api.http.get(this.config.apiBaseurl+'/home/content', {header: {Authorization:this.params.tokenhead+this.params.token}}).then(res => {
+					console.log('首页内容页信息展示gethomecontent',res.data);
+					let homecontent = res.data.data;
+					//获取专题列表
+					this.subjectList = homecontent.subjectList;
+					// console.log('this.subjectList',this.subjectList);
+					//获取专题列表 end
+					//推广弹窗
+					// this.isTime();
+					// this.$refs.promotionPopup.open();//推广弹窗
+					if(homecontent.promote){
+						this.promotion = homecontent.promote[0];
+						this.$refs.promotionPopup.open();
+						
+					}					
+					// console.log('this.promotion',this.promotion)
+					//推广弹窗 end
+					//供应商列表
+					this.supplierList =homecontent.companyInfos;
+				}).catch(err => {
+					console.log(err)
+				});
+			},
+			//产品跳转链接
+			gosubject(id,title){
+				uni.navigateTo({
+					url:`/pages/subject/subject?subjectId=${id}&title=${title}`,
+					fail(err) {
+						console.log(err)
+					}
+				})				
+			},
+			//供应商跳转详情
+			supplierclick(id){
+				console.log(id);
+				uni.navigateTo({
+					url:`/pages/supplier/supplierdetail/supplierdetail?id=${id}`
+				})
+			},
+			//供应商列表
+			// getsupplierlist(){
+			// 	this.$api.http.get(this.config.apiBaseurl+'/company/cp/page', {header: {Authorization:this.params.tokenhead+this.params.token},params: this.supplierparams}).then(res => {
+			// 		// console.log('供应商列表getsupplierlist',res.data);
+			// 		// let supplierlist = res.data.data;
+			// 		this.supplierList = res.data.data;
+			// 		console.log('供应商列表getsupplierlist',JSON.parse(JSON.stringify(this.supplierList)))
+			// 	}).catch(err => {
+			// 		console.log(err)
+			// 	});
+			// },
+			//关闭推广弹窗
+			closePromotion(){
+				this.$refs.promotionPopup.close();
 			}
 
 		}
 	}
 </script>
 
-<style scoped>
+<style>
 @import url("./index.css");
 
 </style>

+ 21 - 1
pages/product/product.css

@@ -1,4 +1,6 @@
-.product-info-wrap{background-color: #fff;padding: 0 40rpx 46rpx;}
+page{background-color: #F6F7F8;}
+.wrap{margin:0 24rpx;}
+.product-info-wrap{background-color: #fff;padding: 24rpx 40rpx 46rpx;margin-bottom: 24rpx;}
 .product-info-til{margin-bottom: 13rpx;font-size: 32rpx;font-weight: 500;color: #333333;line-height: 45rpx;font-weight: bold;}
 .product-info-brand{margin-bottom: 8rpx;font-size: 24rpx;font-weight: 400;color: #6BBC6D;line-height: 33rpx;}
 .product-info-brand .postage{margin-left: 16rpx;padding: 2rpx 14rpx;border-radius: 24rpx;font-size: 20rpx;font-weight: 400;color: #6BBC6D;line-height: 28rpx;background-color: #E1F2E2;}
@@ -23,6 +25,7 @@
 
 .placeoforigin-addr{font-size: 34rpx;font-weight: 400;color: #6BBC6D;line-height: 48rpx;}
 
+.introduce{margin-bottom: 24rpx;}
 .introduce-table{display: flex;margin-bottom: 24rpx;}
 .introduce-table-til{font-size: 30rpx;font-weight: 400;color: #333;line-height: 42px;margin-right: 25rpx;}
 .introduce-table-con{flex:1;background-color: #FAFAFA;border: 1px solid #E8E8E8;border-bottom: 0;font-size: 20rpx;color: #666;}
@@ -39,5 +42,22 @@
 .bottom-flex-btn{border: 0;}
 .bottom-flex-btn::after{border: 0;}
 
+.recommend-list{display: flex;justify-content: space-between;flex-wrap: wrap;}
+.recommend-list::after{content: '';width: 200rpx;}
+.recommend-item{margin-bottom: 24rpx;width: 200rpx;height: 308rpx;overflow: hidden;box-shadow: 0px 0px 14rpx -4rpx rgba(0, 0, 0, 0.12);border-radius: 12rpx;}
+.recommend-item-img{width: 100%;height: 160rpx;}
+.recommend-item-til{padding: 0 13rpx;margin-bottom: 4rpx;font-size: 24rpx;color: #333;line-height: 33rpx;height: 66rpx;overflow: hidden;}
+.recommend-list .product-info-price{padding: 0 9rpx;}
+
+
+
+
+
+
+
+
+
+
+
 
 

+ 40 - 2
pages/product/product.vue

@@ -1,6 +1,6 @@
 <template>
 	<view class="pages">
-		<view class="appAdv nomal-bottom">
+		<view class="appAdv">
 			<swiper class="swiper" :indicator-dots="swiper.indicatorDots" :autoplay="swiper.autoplay" :interval="swiper.interval" :duration="swiper.duration">
 				<!-- <swiper-item v-for="(item,index) in albumPics" :key="index"> -->
 				<swiper-item>
@@ -83,6 +83,24 @@
 			</view>			
 		</view>
 		<!-- 产品介绍 end -->
+		<!-- 推荐产品 end -->
+		<view class="write-radius recommend wrap">
+			<view class="block-til">
+				<view class="block-til-left">推荐产品</view>
+			</view>
+			<view class="recommend-list">
+				<view class="recommend-item" v-for="(item,index) in recommendList" @click="productdetails(item.id)">
+					<image class="recommend-item-img" :src="item.pic" mode="aspectFit"></image>
+					<view class="recommend-item-til">{{item.name}}</view>
+					<view class="product-info-price">
+						<text class="rmb" v-if="item.price">¥</text>
+						<text class="price" :class="!item.price?'noprice':''">{{item.price||"暂无价格"}}</text>
+						<text class="unit" v-if="item.price&&item.unit">/{{item.unit}}</text>
+					</view>
+				</view>
+			</view>
+		</view>
+		
 		<view class="bottom-flex-btn-wrap">
 			<view class="bottom-flex-btn-content">
 				<button type="default" :disabled="isPred==0?false:true"  class="bottom-flex-btn" @click="focuse(params.productid)">有意向</button>
@@ -138,6 +156,7 @@
 					visibleModal: false
 				},
 				addrsList:[],
+				recommendList:[],
 			}
 		},
 		onShow() {
@@ -201,6 +220,9 @@
 				console.log(err)
 			});
 			
+			//获取推广商品
+			this.getrecommend();
+			
 
 		},
 		methods: {
@@ -322,11 +344,27 @@
 					// console.log('err', err)
 				})
 			},
+			//获取推广商品
+			getrecommend(){
+				this.$api.http.get(this.config.apiBaseurl+'/home/better-select', {header: {Authorization:this.params.tokenhead+this.params.token}}).then(res => {
+					// console.log('getrecommend',res)
+					this.recommendList = res.data.data.list;
+					console.log('this.recommendList',JSON.parse(JSON.stringify(this.recommendList)));
+				}).catch(err => {
+					console.log(err)
+				});
+			},
+			//跳转详情
+			productdetails(id){
+				uni.navigateTo({
+					url:`/pages/product/product?id=${id}`
+				})				
+			},
 
 		}
 	}
 </script>
 
-<style scoped>
+<style>
 	@import url("./product.css");
 </style>

+ 2 - 2
pages/searchresults/searchresults.css

@@ -2,7 +2,7 @@
 .search-wrap{padding: 10rpx 8rpx;background-color: #fff;}
 .search-wrap >>> .uni-searchbar__box{justify-content: left;border: 0;background-color: #F1F1F2!important;}
 
-.results-item{display: flex;margin-bottom: 24rpx;border-bottom: 1px solid #eee;}
+/* .results-item{display: flex;margin-bottom: 24rpx;border-bottom: 1px solid #eee;}
 .results-item-img-wrap{width: 220rpx;height: 220rpx;margin-right: 24rpx;overflow: hidden;border-radius: 12rpx;}
 .results-item-img-wrap .results-item-img{width: 100%;height: 100%;}
 .results-item-info{flex: 1;}
@@ -12,4 +12,4 @@
 .results-item-info-label .postage{height: 24rpx;padding: 0 14rpx;margin-left: 16rpx;line-height: 24rpx;display: inline-block;font-size: 20rpx;background-color: #E1F2E2;border-radius: 12rpx;}
 .results-item-info-price .rmb{font-size: 28rpx;font-weight: 500;color: #FF5030;line-height: 40rpx;}
 .results-item-info-price .price{font-size: 36rpx;font-weight: 500;color: #FF5030;line-height: 50rpx;}
-.results-item-info-price .minsell{font-size: 24rpx;font-weight: 400;color: #999999;line-height: 33rpx;}
+.results-item-info-price .minsell{font-size: 24rpx;font-weight: 400;color: #999999;line-height: 33rpx;} */

+ 1 - 1
pages/searchresults/searchresults.vue

@@ -12,7 +12,7 @@
 		<mescroll-body class="wrap" ref="mescrollRef" @init="mescrollInit" @down="downCallback" @up="upCallback" :down="downOption" :up="upOption">
 			<view class="results write-radius">
 				<view v-for="(item,index) in dataList" :key="index" @click="productdetails(item.id)" class="results-item">
-					<view class="results-item-img-wrap"><image :src="$getimg+item.pic|miniImg(50)+'/thumbnail/358x358'" mode="aspectFit" class="results-item-img"></image></view>				
+					<view class="results-item-img-wrap"><image :src="$getimg+item.pic|miniImg(50)+'/thumbnail/358x358'" mode="scaleToFill" class="results-item-img"></image></view>				
 					<view class="results-item-info">
 						<view class="results-item-info-til">{{item.name}}</view>
 						<view class="results-item-info-brand">{{item.brandName}}</view>

+ 16 - 0
pages/subject/subject.css

@@ -0,0 +1,16 @@
+/* 搜索修改 */
+.search-wrap{padding: 10rpx 8rpx;background-color: #fff;}
+.search-wrap >>> .uni-searchbar__box{justify-content: left;border: 0;background-color: #F1F1F2!important;}
+
+/* .results-item{display: flex;margin-bottom: 24rpx;padding-bottom: 29rpx;border-bottom: 1px solid #eee;}
+.results-item:last-of-type{border-bottom: 0;}
+.results-item-img-wrap{width: 220rpx;height: 220rpx;margin-right: 24rpx;overflow: hidden;border-radius: 12rpx;}
+.results-item-img-wrap .results-item-img{width: 100%;height: 100%;}
+.results-item-info{flex: 1;}
+.results-item-info-til{margin-bottom: 10rpx;}
+.results-item-info-brand{color: #999;margin-bottom: 10rpx;}
+.results-item-info-addr{color: #666;margin-bottom: 10rpx;font-size: 24rpx;}
+.results-item-info-label .postage{height: 24rpx;padding: 0 14rpx;margin-left: 16rpx;line-height: 24rpx;display: inline-block;font-size: 20rpx;background-color: #E1F2E2;border-radius: 12rpx;}
+.results-item-info-price .rmb{font-size: 28rpx;font-weight: 500;color: #FF5030;line-height: 40rpx;}
+.results-item-info-price .price{font-size: 36rpx;font-weight: 500;color: #FF5030;line-height: 50rpx;}
+.results-item-info-price .minsell{font-size: 24rpx;font-weight: 400;color: #999999;line-height: 33rpx;} */

+ 187 - 0
pages/subject/subject.vue

@@ -0,0 +1,187 @@
+<template>
+	<view class="pages">
+		
+		<!-- <view class="search-wrap nomal-bottom">
+			<view class="search">
+				<view class="searchTxt">
+					<uni-search-bar :placeholder="searchtxt" @confirm="search" @input="search" ></uni-search-bar>
+				</view>
+			</view>	
+		</view> -->
+		<!-- 搜索 结束 -->
+		<mescroll-body class="wrap" ref="mescrollRef" @init="mescrollInit" @down="downCallback" @up="upCallback" :down="downOption" :up="upOption">
+			<view class="results write-radius">
+				<view v-for="(item,index) in dataList" :key="index" @click="productdetails(item.id)" class="results-item">
+					<view class="results-item-img-wrap"><image :src="$getimg+item.pic|miniImg(50)+'/thumbnail/358x358'" mode="scaleToFill" class="results-item-img cover-img"></image></view>				
+					<view class="results-item-info">
+						<view class="results-item-info-til">{{item.name}}</view>
+						<view class="results-item-info-brand">{{item.brandName}}</view>
+						<!-- <view class="results-item-info-addr">{{item.placeOfProduction}}</view> -->						
+						<view class="results-item-info-label">
+							<text v-if="item.postage" class="postage">包邮</text>
+						</view>
+						<view class="results-item-info-company">{{item.umsCompanyInfo}}</view>
+						<view class="results-item-info-price">
+							<text class="rmb">¥</text>
+							<text class="price">{{item.price}}</text>
+							<text class="unit">/{{item.unit}}</text>
+							<!-- <text class="minsell">4000斤起售</text> -->
+						</view>						
+					</view>
+				</view>			
+			</view>		 
+		</mescroll-body>	
+	</view>
+</template>
+
+<script>
+	// 引入mescroll-mixins.js
+	import MescrollMixin from "@/components/mescroll-uni/mescroll-mixins.js";	
+	// 引入mescroll-body组件 (如已在main.js注册全局组件,则省略此步骤)
+	import MescrollBody from "@/components/mescroll-uni/mescroll-body.vue"; // 注意.vue后缀不能省
+	
+	import uniSearchBar from '@/components/uni-search-bar/uni-search-bar.vue'
+	export default {
+		mixins: [MescrollMixin], // 使用mixin
+		components: {
+			MescrollBody,
+			uniSearchBar,
+			
+		
+		},
+		data() {
+			return {
+				title:'',
+				searchtxt:'产品名称',
+				params:{
+					token:'',
+					keyword:'',
+					subjectId:'',
+				},
+				mescroll: null, // mescroll实例对象 (此行可删,mixins已默认)
+				// 下拉刷新的配置(可选, 绝大部分情况无需配置)
+				downOption: { 
+					// ...
+				},
+				// 上拉加载的配置(可选, 绝大部分情况无需配置)
+				upOption: {
+					page: {
+						size: 10 // 每页数据的数量,默认10
+					},
+					noMoreSize: 5, // 配置列表的总数量要大于等于5条才显示'-- END --'的提示
+					empty: {
+						tip: '暂无相关数据'
+					}
+				},
+				// 列表数据
+				dataList:[],
+				
+			}
+		},
+		onShow() {
+			let serf = this;
+			//检查登录,获取token
+			// let loginRes = this.checkLogin('/pages/index/index', '2');
+			// if(!loginRes){return false;}
+			// serf.params.token=loginRes[0];			
+		},
+		onReady() {
+			uni.setNavigationBarTitle({
+			    title: this.title
+			});
+		},
+		onLoad(option) {
+			console.log('option',option);
+			if(option.subjectId){
+				this.params.subjectId = option.subjectId;
+				this.searchtxt = option.name;
+			}
+			if(option.title){
+				this.title = option.title
+			}
+			// if(option.keyword){
+			// 	this.params.keyword = option.keyword;
+			// 	this.searchtxt = option.keyword;
+			// }
+			// console.log(this.params.keyword);
+
+		},
+		methods: {
+			//搜索
+			search(e) {
+				console.log(e);
+				this.params.keyword = e.value;
+				this.params.subjectId = '';
+				this.searchtxt = e.value;
+				this.downCallback();
+				// this.poorList = [];
+				// this.params.farmerName = e.value;
+				// this.pagination = Object.assign(this.pagination,{"farmerName":e.value});
+				// this.pagination.pageNo = 1;
+				// this.getPoorList(this.pagination)
+			},
+			
+			/*mescroll组件初始化的回调,可获取到mescroll对象 (此处可删,mixins已默认)*/
+			mescrollInit(mescroll) {
+				this.mescroll = mescroll;
+			},
+			downCallback(){
+				this.mescroll.resetUpScroll(); // 重置列表为第一页 (自动执行 page.num=1, 再触发upCallback方法 )
+			},
+			/*上拉加载的回调*/
+			upCallback(page) {
+				let pageNum = page.num; // 页码, 默认从1开始
+				let pageSize = page.size; // 页长, 默认每页10条
+				this.params = Object.assign(this.params,{pageNum:pageNum,pageSize:pageSize});
+				this.$api.http.get(this.config.apiBaseurl+'/home/subjectProductList',{params: this.params}).then(data => {
+					if(data.data.code=='1001'){
+						// uni.redirectTo({
+						// 	url:'/pages/login/login?backpage=/pages/index/index'+'&backtype='+2,
+						// });							
+					};
+					console.log('data',JSON.parse(JSON.stringify(data)));
+					// 接口返回的当前页数据列表 (数组)
+					let curPageData = data.data.data;
+					console.log('curPageData',JSON.parse(JSON.stringify(curPageData)));
+					// 接口返回的当前页数据长度 (如列表有26个数据,当前页返回8个,则curPageLen=8)
+					let curPageLen = curPageData.length; 
+					// 接口返回的总页数 (如列表有26个数据,每页10条,共3页; 则totalPage=3)
+					let totalPage =  data.data.data.totalPage; 
+					// 接口返回的总数据量(如列表有26个数据,每页10条,共3页; 则totalSize=26)
+					let totalSize = data.data.data.total; 
+					// 接口返回的是否有下一页 (true/false)
+					// let hasNext = data.xxx; 
+					console.log('totalPage',totalPage,'curPageLen',curPageLen);
+					//设置列表数据
+					if(page.num == 1) this.dataList = []; //如果是第一页需手动置空列表
+					this.dataList = this.dataList.concat(curPageData); //追加新数据
+					// 请求成功,隐藏加载状态
+					//方法一(推荐): 后台接口有返回列表的总页数 totalPage
+					this.mescroll.endByPage(curPageLen, totalPage); 
+					//方法二(推荐): 后台接口有返回列表的总数据量 totalSize
+					// this.mescroll.endBySize(curPageLen, totalSize); 
+			
+					// setTimeout(()=>{
+					// 	this.mescroll.endSuccess(curPageLen)
+					// },20)
+				
+				}).catch(err => {
+					this.mescroll.endErr()
+					console.log(err)
+				
+				});								
+			},
+			//跳转详情
+			productdetails(id){
+				uni.navigateTo({
+					url:`/pages/product/product?id=${id}`
+				})				
+			},
+
+		}
+	}
+</script>
+
+<style scoped>
+	@import url("./subject.css");
+</style>

+ 2 - 2
pages/supplier/supplierdetail/supplierdetail.vue

@@ -13,7 +13,7 @@
 				</view>				
 			</view>
 			<!-- base-info end -->
-			<view class="shop write-radius wrap" v-if="shops.length>0">
+			<!-- <view class="shop write-radius wrap" v-if="shops.length>0">
 				<view class="block-til">
 					<view class="block-til-left">店铺</view>
 				</view>
@@ -27,7 +27,7 @@
 						<view class="shop-name" v-else>自营商城</view>
 					</view>
 				</view>				
-			</view>
+			</view> -->
 			<!-- shop end -->
 			<view class="write-radius supplier wrap">
 				<view class="block-til">

BIN
static/img/close.png


BIN
static/img/defaultsupplierlogo.png


+ 9 - 0
utils/isTimes.js

@@ -0,0 +1,9 @@
+export function isTime(time1,time2){
+    var time = Date.parse( new Date());
+    var date1 = Date.parse(new Date(time1.replace(/-/g, '/')));
+    var date2 = Date.parse(new Date(time2.replace(/-/g, '/')));
+    if (date1<time&&date2>time) {
+        return true;
+    };
+    return false;
+}