Kaynağa Gözat

订单接口

zhaogongxue 8 ay önce
ebeveyn
işleme
230365df0a

+ 94 - 91
manifest.json

@@ -1,93 +1,96 @@
 {
-	"name": "wx",
-	"appid": "__UNI__EF90963",
-	"description": "",
-	"versionName": "1.0.0",
-	"versionCode": "100",
-	"transformPx": false,
-	/* 5+App特有相关 */
-	"app-plus": {
-		"usingComponents": true,
-		"nvueStyleCompiler": "uni-app",
-		"compilerVersion": 3,
-		"splashscreen": {
-			"alwaysShowBeforeRender": true,
-			"waiting": true,
-			"autoclose": true,
-			"delay": 0
-		},
-		/* 模块配置 */
-		"modules": {},
-		/* 应用发布信息 */
-		"distribute": {
-			/* android打包配置 */
-			"android": {
-				"permissions": [
-					"<uses-permission android:name=\"android.permission.CHANGE_NETWORK_STATE\"/>",
-					"<uses-permission android:name=\"android.permission.MOUNT_UNMOUNT_FILESYSTEMS\"/>",
-					"<uses-permission android:name=\"android.permission.VIBRATE\"/>",
-					"<uses-permission android:name=\"android.permission.READ_LOGS\"/>",
-					"<uses-permission android:name=\"android.permission.ACCESS_WIFI_STATE\"/>",
-					"<uses-feature android:name=\"android.hardware.camera.autofocus\"/>",
-					"<uses-permission android:name=\"android.permission.ACCESS_NETWORK_STATE\"/>",
-					"<uses-permission android:name=\"android.permission.CAMERA\"/>",
-					"<uses-permission android:name=\"android.permission.GET_ACCOUNTS\"/>",
-					"<uses-permission android:name=\"android.permission.READ_PHONE_STATE\"/>",
-					"<uses-permission android:name=\"android.permission.CHANGE_WIFI_STATE\"/>",
-					"<uses-permission android:name=\"android.permission.WAKE_LOCK\"/>",
-					"<uses-permission android:name=\"android.permission.FLASHLIGHT\"/>",
-					"<uses-feature android:name=\"android.hardware.camera\"/>",
-					"<uses-permission android:name=\"android.permission.WRITE_SETTINGS\"/>"
-				]
-			},
-			/* ios打包配置 */
-			"ios": {},
-			/* SDK配置 */
-			"sdkConfigs": {}
-		}
-	},
-	/* 快应用特有相关 */
-	"quickapp": {},
-	/* 小程序特有相关 */
-	"mp-weixin": {
-		"appid": "",
-		"setting": {
-			"urlCheck": false
-		},
-		"usingComponents": true,
-		"optimization": {
-			"subPackages": true
-		}
-	},
-	"mp-alipay": {
-		"usingComponents": true
-	},
-	"mp-baidu": {
-		"usingComponents": true
-	},
-	"mp-toutiao": {
-		"usingComponents": true
-	},
-	"uniStatistics": {
-		"enable": false
-	},
-	"vueVersion": "2",
-	"h5": {
-		"title": "",
-		"domain": "wx-qhb",
-		"devServer": {
-			"disableHostCheck": true,
-			"port": 8000,
-			"proxy": {
-				"/api": {
-					"target": "https://cbec.hdlkeji.com",
-					"changeOrigin": true,
-					"pathRewrite": {
-						"^/api": ""
-					}
-				}
-			}
-		}
-	}
+    "name" : "wx",
+    "appid" : "__UNI__EF90963",
+    "description" : "",
+    "versionName" : "1.0.0",
+    "versionCode" : "100",
+    "transformPx" : false,
+    /* 5+App特有相关 */
+    "app-plus" : {
+        "usingComponents" : true,
+        "nvueStyleCompiler" : "uni-app",
+        "compilerVersion" : 3,
+        "splashscreen" : {
+            "alwaysShowBeforeRender" : true,
+            "waiting" : true,
+            "autoclose" : true,
+            "delay" : 0
+        },
+        /* 模块配置 */
+        "modules" : {},
+        /* 应用发布信息 */
+        "distribute" : {
+            /* android打包配置 */
+            "android" : {
+                "permissions" : [
+                    "<uses-permission android:name=\"android.permission.CHANGE_NETWORK_STATE\"/>",
+                    "<uses-permission android:name=\"android.permission.MOUNT_UNMOUNT_FILESYSTEMS\"/>",
+                    "<uses-permission android:name=\"android.permission.VIBRATE\"/>",
+                    "<uses-permission android:name=\"android.permission.READ_LOGS\"/>",
+                    "<uses-permission android:name=\"android.permission.ACCESS_WIFI_STATE\"/>",
+                    "<uses-feature android:name=\"android.hardware.camera.autofocus\"/>",
+                    "<uses-permission android:name=\"android.permission.ACCESS_NETWORK_STATE\"/>",
+                    "<uses-permission android:name=\"android.permission.CAMERA\"/>",
+                    "<uses-permission android:name=\"android.permission.GET_ACCOUNTS\"/>",
+                    "<uses-permission android:name=\"android.permission.READ_PHONE_STATE\"/>",
+                    "<uses-permission android:name=\"android.permission.CHANGE_WIFI_STATE\"/>",
+                    "<uses-permission android:name=\"android.permission.WAKE_LOCK\"/>",
+                    "<uses-permission android:name=\"android.permission.FLASHLIGHT\"/>",
+                    "<uses-feature android:name=\"android.hardware.camera\"/>",
+                    "<uses-permission android:name=\"android.permission.WRITE_SETTINGS\"/>"
+                ]
+            },
+            /* ios打包配置 */
+            "ios" : {
+                "dSYMs" : false
+            },
+            /* SDK配置 */
+            "sdkConfigs" : {
+                "ad" : {}
+            }
+        }
+    },
+    /* 快应用特有相关 */
+    "quickapp" : {},
+    /* 小程序特有相关 */
+    "mp-weixin" : {
+        "appid" : "",
+        "setting" : {
+            "urlCheck" : false
+        },
+        "usingComponents" : true,
+        "optimization" : {
+            "subPackages" : true
+        }
+    },
+    "mp-alipay" : {
+        "usingComponents" : true
+    },
+    "mp-baidu" : {
+        "usingComponents" : true
+    },
+    "mp-toutiao" : {
+        "usingComponents" : true
+    },
+    "uniStatistics" : {
+        "enable" : false
+    },
+    "vueVersion" : "2",
+    "h5" : {
+        "title" : "",
+        "domain" : "wx-qhb",
+        "devServer" : {
+            "disableHostCheck" : true,
+            "port" : 8000,
+            "proxy" : {
+                "/api" : {
+                    "target" : "https://cbec.hdlkeji.com",
+                    "changeOrigin" : true,
+                    "pathRewrite" : {
+                        "^/api" : ""
+                    }
+                }
+            }
+        }
+    }
 }
-

+ 189 - 47
pageA/order.vue

@@ -3,12 +3,12 @@
 		<!-- 地址 -->
 		<view class="address" @click="toadd">
 			<view class="u-flex u-row-between">
-				<view class="add">102 Huangjiao Road,</view>
+				<view class="add" v-if="addinfo">{{addinfo.full_address}}</view>
 				<u-icon name="arrow-right" size='16'></u-icon>
 			</view>
-			<view class="info">
-				<text>Curtis Morris</text>
-				<text style="margin-left: 20rpx;">041***8314</text>
+			<view class="info" v-if="addinfo">
+				<text>{{addinfo.name}}</text>
+				<text style="margin-left: 20rpx;">{{replacePhoneToStar(addinfo.mobile)}}</text>
 			</view>
 		</view>
 		<!-- 商品 -->
@@ -29,14 +29,15 @@
 						<view class="">
 							<text class="money">¥</text>
 							<text class="money"
-								style="font-size: 34rpx;">{{goodinfo.is_discount==1? Number(sku_info.price)*Number(value):Number(sku_info.discount_price)*Number(value)}}</text>
+								style="font-size: 34rpx;">{{goodinfo.is_discount==1? (Number(sku_info.price*1000)*Number(value*1000))/1000000:(Number(sku_info.discount_price*1000)*Number(value)*1000)/1000000}}</text>
 						</view>
 						<u-number-box v-model="value">
 							<!-- <view class="bu"> -->
 							<view slot="minus" class="">
 								<u-icon name="minus" size="12"></u-icon>
 							</view>
-							<text slot="input" style="width: 40px;text-align: center;" class="input">{{value}}</text>
+							<input slot="input" v-model="value" style="width: 40px;text-align: center;"
+								class="input"></input>
 							<view slot="plus" class="">
 								<u-icon name="plus" size="12"></u-icon>
 							</view>
@@ -50,7 +51,7 @@
 		<view class="logistics u-flex u-row-between">
 			<text style="font-weight: 600;">{{i18n.flow}}</text>
 			<view class="u-flex" @click="show = true">
-				<text class="change">{{i18n.selection}}</text>
+				<text class="change">{{containname1?type1+' | '+containname1 :i18n.selection}}</text>
 				<u-icon name="arrow-right" size='16'></u-icon>
 			</view>
 		</view>
@@ -79,7 +80,8 @@
 							</view>
 							<view class="money" style="color: #F83224;font-size: 20rpx;">
 								<text>¥</text>
-								<text  style="font-size: 28rpx;">{{item.is_discount==0?item.discount_price.slice(0,-3):item.price.slice(0,-3)}}</text>
+								<text
+									style="font-size: 28rpx;">{{item.is_discount==0?item.discount_price.slice(0,-3):item.price.slice(0,-3)}}</text>
 								<text>{{item.is_discount==0?item.discount_price.slice(-3):item.price.slice(-3)}}</text>
 							</view>
 						</view>
@@ -92,47 +94,52 @@
 			<view class="u-flex u-row-between" style='margin-bottom:40rpx'>
 				<view class="name">{{i18n.Commodityamount}}</view>
 				<view class="money">
-					¥{{goodinfo.is_discount==1? Number(sku_info.price)*Number(value):Number(sku_info.discount_price)*Number(value)}}
+					¥{{goodinfo.is_discount==1? (Number(sku_info.price*100)*Number(value*100))/10000:(Number(sku_info.discount_price*100)*Number(value*100))/10000}}
 				</view>
 			</view>
 			<view class="u-flex u-row-between">
 				<view class="name">{{i18n.Grosscommodityweight}}</view>
 				<view class="money">{{Number(sku_info.weight)*value}}kg</view>
 			</view>
-			<view class="back u-flex">
+			<view class="back u-flex" v-if="containname1">
 				<image src="static/images/warning.png" style="width: 32rpx;height: 32rpx;" mode=""></image>
-				<text style="margin-left: 12rpx;">{{i18n.buy}}378-380kg{{i18n.price}}¥21,{{i18n.morefavorable}}</text>
+				<text
+					style="margin-left: 12rpx;">{{i18n.buy}}{{min_weight}}-{{max_weight}}kg{{i18n.price}}¥{{unit_fee}},{{i18n.morefavorable}}</text>
 			</view>
-			<view class="u-flex u-row-between" style='margin-bottom:40rpx'>
+			<view class="u-flex u-row-between" style='margin-bottom:40rpx;margin-top: 20rpx;'>
 				<view class="name">{{i18n.Costperkilogram}}</view>
-				<view class="money">需先选择货运方式</view>
+				<view class="money">{{containname1?unit_price:'需先选择货运方式'}}</view>
 			</view>
 			<view class="u-flex u-row-between">
 				<view class="name">{{i18n.freight}}</view>
-				<view class="money">需先选择货运方式</view>
+				<view class="money">{{containname1?sum:'需先选择货运方式'}}</view>
 			</view>
 			<view class="zong u-flex u-row-right">
 				<view class="">
 					<text class="small">{{i18n.subtotal}}</text>
 					<text class="mon">¥</text>
-					<text class="mon" style="font-size: 40rpx;">2642.5</text>
+					<text class="mon"
+						style="font-size: 40rpx;">{{goodinfo.is_discount==1? (Number(sku_info.price*100)*Number(value*100))/10000:(Number(sku_info.discount_price*100)*Number(value*100))/10000}}</text>
 				</view>
 			</view>
 		</view>
 		<view class="" style="height: 166rpx;"></view>
 		<view class="btn u-flex u-row-right">
 			<view class="">
-				<text class="kg">{{i18n.Atotalof}}39kg,</text>
+				<text class="kg">{{i18n.Atotalof}}{{Number(sku_info.weight) * value}}kg,</text>
 				<text>{{i18n.total}}:</text>
 				<text class="money" style="font-size: 28rpx;">¥</text>
-				<text class="money" style="font-weight: bold;">2792.5</text>
+				<text class="money" v-if="goodinfo.is_discount==1"
+					style="font-weight: bold;">{{(Number(sum*10000+ Number(sku_info.price)*Number(value)*10000))/10000}}</text>
+				<text class="money" v-if="goodinfo.is_discount==0"
+					style="font-weight: bold;">{{(Number(sum*10000+ Number(sku_info.discount_price)*Number(value)*10000))/10000}}</text>
 			</view>
 			<view class="order" @click="topay">
 				{{i18n.Submitorder}}
 			</view>
 		</view>
 		<!-- 跨境物流 -->
-		<u-popup :show="show" @close="close" @open="open" mode="bottom" closeIconPos='top-right' round='28'>
+		<u-popup :show="show" @close="close" mode="bottom" closeIconPos='top-right' round='28'>
 			<view style="padding: 40rpx 28rpx;box-sizing:border-box;">
 				<view class="u-flex u-row-between">
 					<view class="" style="width: 28px;height: 28px;"></view>
@@ -143,7 +150,7 @@
 				</view>
 				<view class="u-flex u-row-between" style="margin-top: 60rpx;flex-wrap: wrap;">
 					<view :class="index==idx?'active':'unactive'" v-for="(item,idx) in containerList"
-						@click="change(idx)"
+						@click="change(item,idx)"
 						style="display: flex;flex-direction: column;align-items: center;justify-content: center;margin-bottom: 28rpx;position: relative;">
 						<image v-if="index==idx" src="static/images/change.png"
 							style="width: 36rpx;height: 32rpx;position: absolute;top: 0;right: 0;" mode=""></image>
@@ -151,15 +158,16 @@
 						<view class="logname" v-if="language =='en-US'">{{item.name_en}}</view>
 						<view class="logname" v-if="language =='es-ES'">{{item.name_es}}</view>
 						<view class="logname" v-if="language =='it-IT'">{{item.name_ita}}</view>
-						<view class="wei">¥{{goodinfo.cate==0?item.normal_delivery_fee:item.special_delivery_fee}}/kg</view>
+						<!-- 						<view class="wei">¥{{goodinfo.cate==0?item.normal_delivery_fee:item.special_delivery_fee}}/kg</view> -->
+						<view class="wei">¥{{item.unit_price}}/kg</view>
 					</view>
 				</view>
 				<view class="nextto" @click="next">{{i18n.next}}</view>
 			</view>
 		</u-popup>
 		<!-- 跨境物流下一步 -->
-		<u-popup :safeAreaInsetTop='true' :show="show1" @close="close" @open="open" mode="bottom"
-			closeIconPos='top-right' round='28' bgColor='#F4F4F4'>
+		<u-popup :safeAreaInsetTop='true' :show="show1" @close="close" mode="bottom" closeIconPos='top-right' round='28'
+			bgColor='#F4F4F4'>
 			<view style="padding: 40rpx 28rpx;box-sizing:border-box;position: relative;">
 				<view class="u-flex u-row-between">
 					<view class="" style="width: 28px;height: 28px;"></view>
@@ -169,9 +177,10 @@
 					<u-icon name="close" @click="close" color="background: #333333;" size="28"></u-icon>
 				</view>
 				<scroll-view :scroll-y="true" style="500rpx">
-					<view class="transport" style="margin-top: 32rpx;" @click="activea(idx)" v-for="(item,idx) in 5">
+					<view class="transport" style="margin-top: 32rpx;" @click="activea(item,idx)"
+						v-for="(item,idx) in containlist" v-if="item.sum !=0">
 						<view class="u-flex u-row-between">
-							<text class="yundate">{{i18n.Shipmentdate}} 2023-12-09</text>
+							<text class="yundate">{{i18n.Shipmentdate}} {{item.begin_date}}</text>
 							<image v-if="datechan==idx" src="/pageA/static/images/active.png"
 								style="width: 36rpx;height: 36rpx;" mode=""></image>
 							<image v-else src="/pageA/static/images/unactive.png" style="width: 36rpx;height: 36rpx;"
@@ -179,13 +188,16 @@
 						</view>
 						<view class="u-flex u-row-between" style="margin-top: 28rpx;">
 							<view class="chest">
-								<text>2号海运柜</text>
+								<text v-if="language =='zh-CN'">{{item.name_cn}}</text>
+								<text v-if="language =='en-US'">{{item.name_en}}</text>
+								<text v-if="language =='es-ES'">{{item.name_es}}</text>
+								<text v-if="language =='it-IT'">{{item.name_ita}}</text>
 								<text style="margin: 0 16rpx;">|</text>
-								<text>{{i18n.Estimatedtimeofarrival}}22{{i18n.Workingday}}</text>
+								<text>{{i18n.Estimatedtimeofarrival}}{{item.transport_days}}{{i18n.Workingday}}</text>
 							</view>
 							<view class="mone">
 								<text>¥</text>
-								<text style="font-size: 32rpx;">1820</text>
+								<text style="font-size: 32rpx;">{{item.sum}}</text>
 							</view>
 						</view>
 					</view>
@@ -214,14 +226,29 @@
 				swiptlist: [], //推荐列表
 				language: 'zh-CN',
 				containerList: [], //列表
-				province_id:'',
-				transport_type_id:''
+				province_id: '',
+				transport_type_id: '',
+				containlist: [],
+				containid: '', //货柜id
+				containname: '', //货柜名称
+				type: '', //货运方式名称
+				containname1: '',
+				type1: '',
+				sum: '',
+				unit_price: '',
+				recommend_weight: '',
+				sum1: '',
+				unit_price1: '',
+				recommend_weight1: '',
+				max_weight: '',
+				min_weight: '',
+				unit_fee: '',
 			};
 		},
 		computed: {
 			i18n() {
 				return this.$t('index')
-			}
+			},
 		},
 		onLoad(options) {
 			// url: '/pageA/order?sku=' + this.sku_info + '&value=' + this.value+'&goodinfo='+this.goodinfo
@@ -237,46 +264,114 @@
 				this.language = uni.getStorageSync('language')
 			}
 			this.recommend()
-			this.container()
+			// this.container()
 		},
 		methods: {
+			//正则匹配手机号
+			replacePhoneToStar: function(phone) {
+				if (phone) {
+					return phone.replace(/(\d{3})\d{4}(\d{4})/, '$1****$2');
+				}
+			},
+			//推荐重量
+			recommendweight() {
+				uni.$u.http.get('/api/express-order/recommend-container', {
+					params: {
+						container_id: this.containid,
+						type: this.goodinfo.cate == 0 ? 'normal' : 'special'
+					}
+				}).then((res) => {
+					console.log(res);
+					this.max_weight = res.max_weight
+					this.min_weight = res.min_weight
+					this.unit_fee = res.unit_fee
+				}).catch(() => {
+
+				})
+			},
 			//货运类型列表
-			container() {
+			transport() {
 				uni.$u.http.get('/api/transport-type', {
 					params: {
 						province_id: this.province_id,
 					}
 				}).then((res) => {
 					this.containerList = res
-					this.transport_type_id = res.id
+					this.transport_type_id = res[0].id
+					if (this.language == 'zh-CN') {
+						this.type = res[0].name_cn
+					}
+					if (this.language == 'en-US') {
+						this.type = res[0].name_en
+					}
+					if (this.language == 'es-ES') {
+						this.type = res[0].name_es
+					}
+					if (this.language == 'it-IT') {
+						this.type = res[0].name_ita
+					}
 				}).catch(() => {
-			
+
 				})
 			},
 			//跳转到填写地址
-			toadd(){
+			toadd() {
+				var that = this
 				uni.navigateTo({
-					url:'/pageC/addressManagement/addressManagement'
+					url: '/pageC/addressManagement/addressManagement',
+					events: {
+						getadd(res) {
+							console.log(res);
+							that.addinfo = res
+							that.province_id = res.province_id
+							// console.log(res);
+							that.transport()
+						}
+					}
 				})
 			},
 			//货柜列表
 			container() {
-				uni.$u.http.get('/api/container', {
+				uni.$u.http.get('/api/container-base', {
 					params: {
 						is_page: 0,
 						province_id: this.province_id,
-						transport_type_id:this.transport_type_id
+						transport_type_id: this.transport_type_id,
+						weight: Number(this.sku_info.weight) * this.value,
+						type: this.goodinfo.cate == 0 ? 'normal' : 'special'
 					}
 				}).then((res) => {
-
+					// this.containlist = res
+					this.containlist = []
+					res.forEach((item) => {
+						if (item.sum != 0) {
+							this.containlist.push(item)
+						}
+					})
+					this.sum = this.containlist[0].sum
+					this.unit_price = this.containlist[0].unit_price
+					this.recommend_weight = this.containlist[0].recommend_weight
+					this.containid = this.containlist[0].id
+					if (this.language == 'zh-CN') {
+						this.containname = this.containlist[0].name_cn
+					}
+					if (this.language == 'en-US') {
+						this.containname = this.containlist[0].name_en
+					}
+					if (this.language == 'es-ES') {
+						this.containname = this.containlist[0].name_es
+					}
+					if (this.language == 'it-IT') {
+						this.containname = this.containlist[0].name_ita
+					}
 				}).catch(() => {
 
 				})
 			},
 			//商品推荐
 			recommend() {
-				uni.$u.http.post('/api/goods/recommend',{
-					keyword:''
+				uni.$u.http.post('/api/goods/recommend', {
+					keyword: ''
 				}).then((res) => {
 					// this.swiptlist = res.reduce((a, b) => {
 					// 	let lastIndex = a.length - 1
@@ -294,19 +389,51 @@
 
 				})
 			},
-			change(index) {
+			change(item, index) {
+				this.transport_type_id = item.id
 				this.index = index
+				if (this.language == 'zh-CN') {
+					this.type = item.name_cn
+				}
+				if (this.language == 'en-US') {
+					this.type = item.name_en
+				}
+				if (this.language == 'es-ES') {
+					this.type = item.name_es
+				}
+				if (this.language == 'it-IT') {
+					this.type = item.name_ita
+				}
 			},
 			next() {
 				this.show = false
 				this.show1 = true
+				this.type1 = this.type
+				this.container()
 			},
-			activea(idx) {
+			activea(item, idx) {
 				this.datechan = idx
+				this.sum = item.sum
+				this.unit_price = item.unit_price
+				this.recommend_weight = item.recommend_weight
+				if (this.language == 'zh-CN') {
+					this.containname = item.name_cn
+				}
+				if (this.language == 'en-US') {
+					this.containname = item.name_en
+				}
+				if (this.language == 'es-ES') {
+					this.containname = item.name_es
+				}
+				if (this.language == 'it-IT') {
+					this.containname = item.name_ita
+				}
 			},
 			//确定
 			confirm() {
 				this.show1 = false
+				this.containname1 = this.containname
+				this.recommendweight()
 			},
 			// 取消
 			close() {
@@ -315,8 +442,22 @@
 			},
 			//提交订单
 			topay() {
-				uni.navigateTo({
-					url: '/pageA/payorder'
+				uni.$u.http.post('/api/order', {
+					address_id: this.addinfo.id, //3	是	String	地址ID
+					goods_id: this.goodinfo.id, //65	是	String	商品id
+					goods_num: this.value, //2	是	String	商品数量
+					sku_item_id: this.sku_info.id, //60	是	String	规格id
+					cart_ids: '', //8,9	是	String	购物车id
+					remark: '', //备注	是	String	备注
+					merchant_goods_id: this.goodinfo.merchant_goods_id, //39	是	String	团长商品id
+					container_id: this.containid, //1	是	String	货柜id
+					share_merchant_id: '', //	是	String	分享团长id 分享商品的时候传
+					belong: 0 //0	是	String	商品归属 0团长 1平台自营 2团长发布或者分享的平台自营商品、供应链商品
+				}).then((res) => {
+					uni.navigateTo({
+						url: '/pageA/payorder?sum=' + this.sum
+					})
+				}).catch(() => {
 				})
 			}
 		}
@@ -441,9 +582,10 @@
 		text-align: right;
 		font-style: normal;
 		overflow: hidden;
-		width: 220rpx ;
+		width: 220rpx;
 		white-space: nowrap;
 		text-overflow: ellipsis;
+		text-align: center;
 	}
 
 	.wei {
@@ -577,7 +719,7 @@
 				padding: 22rpx 16rpx;
 				box-sizing: border-box;
 				margin-top: 10rpx;
-				margin-bottom: 20rpx;
+				// margin-bottom: 20rpx;
 			}
 
 			.name {

+ 7 - 3
pageA/payorder.vue

@@ -8,7 +8,7 @@
 				</view>
 				<view class="state" v-if="stateshow">
 					<view @click="statechange(item,idx)" :class="state_id==idx?'stateac':'unstate'"
-						style="margin-bottom: 20rpx;" v-for="(item,idx) in array">{{item.name}}</view>
+						style="margin-bottom: 20rpx;font-size: 24rpx;" v-for="(item,idx) in array">{{item.name}}</view>
 				</view>
 			</view>
 			<view class="u-row-center"
@@ -16,7 +16,7 @@
 				<view class="paysum">{{i18n.Actual}}</view>
 				<view class="numbe" style="margin-top: 40rpx;">
 					<text>¥</text>
-					<text style="font-size: 60rpx;font-weight: 500;">2792.5</text>
+					<text style="font-size: 60rpx;font-weight: 500;">{{sum}}</text>
 				</view>
 				<!-- 				<view class="">
 					<text>支付剩余时间 13:50</text>
@@ -93,9 +93,13 @@
 					name: '欧元'
 				}, {
 					name: '美元'
-				}]
+				}],
+				sum:''
 			};
 		},
+		onLoad(options) {
+			this.sum = options.sum
+		},
 		computed: {
 			i18n() {
 				return this.$t('index')

+ 3 - 4
pageA/subsidy.vue

@@ -144,7 +144,6 @@
 			},
 			//标签切换
 			changetab(e) {
-				console.log(e);
 				if (this.show == 1) {
 					this.subsid(e.id) //百万补贴
 				}
@@ -200,7 +199,7 @@
 			//海外包邮接口
 			shipp(id) {
 				uni.$u.http.post('api/goods/shipping', {
-					category_id: id
+					parent_id: id
 				}).then((res) => {
 					this.list = res
 				}).catch(() => {
@@ -210,7 +209,7 @@
 			//拼包好物接口
 			pack(id) {
 				uni.$u.http.post('/api/goods/pack', {
-					category_id: id
+					parent_id: id
 				}).then((res) => {
 					this.list = res
 				}).catch(() => {
@@ -220,7 +219,7 @@
 			//百万补贴接口
 			subsid(id) {
 				uni.$u.http.post('/api/goods/subsidy', {
-					category_id: id
+					parent_id: id
 				}).then((res) => {
 					this.list = res
 				}).catch(() => {

+ 30 - 1
pageB/myPackage.vue

@@ -68,7 +68,8 @@
 		data() {
 			return {
 				current: 0, //tab切换
-				list1: []
+				list1: [],
+				status: '', //状态
 			};
 		},
 		onLoad(options) {
@@ -81,6 +82,13 @@
 			}]
 			console.log(options);
 			this.current = options.index
+			if (this.current == 0) {
+				this.status = 'to_transit'
+			} else if (this.current == 1) {
+				this.status = 'transit_receipt'
+			} else {
+				this.status = 'to_overseas'
+			}
 		},
 		computed: {
 			i18n() {
@@ -91,11 +99,32 @@
 			uni.setNavigationBarTitle({
 				title: this.i18n.mine + this.i18n.parcel
 			})
+			this.getlist()
 		},
 		methods: {
+			//获取列表
+			getlist() {
+				uni.$u.http.get('/api/express-order?', {
+					params: {
+						container_id: '',
+						status_collection: this.status
+					}
+				}).then((res) => {
+					console.log(res);
+				}).catch(() => {
+
+				})
+			},
 			click(item) {
 				console.log('item', item);
 				this.current = item.index
+				if (this.current == 0) {
+					this.status = 'to_transit'
+				} else if (this.current == 1) {
+					this.status = 'transit_receipt'
+				} else {
+					this.status = 'to_overseas'
+				}
 			}
 		},
 		mounted() {

+ 184 - 194
pageC/addressManagement/addressManagement.vue

@@ -1,209 +1,199 @@
 <template>
-  <view>
-    <view class="top-tab">
-      <view :class="{ select: manage == 1 }" @click="switchTab(1)">
-        {{ i18n.inland }}
-      </view>
-      <view :class="{ select: manage == 0 }" @click="switchTab(0)">
-        {{ i18n.international }}
-      </view>
-    </view>
-    <view class="content" v-if="addressList.length != 0">
-      <addressVue
-        @deleteAddress="deleteAddress"
-        @setDefault="setDefault"
-        @toDetail="toDetail"
-        @goBack="goBack"
-        v-for="item in addressList"
-        :itemInfo="item"
-        :key="item.id"
-      />
-    </view>
-    <view class="empty" v-else> 空空如也~ </view>
-    <view class="footer" v-if="manage == 1">
-      <button class="wx">{{ i18n.wx }}</button>
-      <button
-        class="add"
-        @click="toAddRess('/pageC/addEditAddress/addEditAddress')"
-      >
-        {{ i18n.add }}
-      </button>
-    </view>
-    <view class="footer" v-else>
-      <button
-        class="add-international"
-        @click="toAddRess('/pageC/internationalAddress/internationalAddress')"
-      >
-        {{ i18n.add }}
-      </button>
-    </view>
-  </view>
+	<view>
+		<view class="top-tab">
+			<view :class="{ select: manage == 1 }" @click="switchTab(1)">
+				{{ i18n.inland }}
+			</view>
+			<view :class="{ select: manage == 0 }" @click="switchTab(0)">
+				{{ i18n.international }}
+			</view>
+		</view>
+		<view class="content" v-if="addressList.length != 0">
+			<addressVue @deleteAddress="deleteAddress" @setDefault="setDefault" @toDetail="toDetail"
+				@goBack="goBack(item)" v-for="item in addressList" :itemInfo="item" :key="item.id" />
+		</view>
+		<view class="empty" v-else> 空空如也~ </view>
+		<view class="footer" v-if="manage == 1">
+			<button class="wx">{{ i18n.wx }}</button>
+			<button class="add" @click="toAddRess('/pageC/addEditAddress/addEditAddress')">
+				{{ i18n.add }}
+			</button>
+		</view>
+		<view class="footer" v-else>
+			<button class="add-international" @click="toAddRess('/pageC/internationalAddress/internationalAddress')">
+				{{ i18n.add }}
+			</button>
+		</view>
+	</view>
 </template>
 
 <script>
-import addressVue from "./component/address.vue";
-export default {
-  components: {
-    addressVue,
-  },
-  data() {
-    return {
-      manage: 1,
-      addressList: [],
-    };
-  },
-  computed: {
-    i18n() {
-      return this.$t("index");
-    },
-  },
-  methods: {
-    goBack() {
-      uni.$emit("isRefresh", this.index);
-      uni.navigateBack({
-        delta: 1,
-      });
-    },
+	import addressVue from "./component/address.vue";
+	export default {
+		components: {
+			addressVue,
+		},
+		data() {
+			return {
+				manage: 1,
+				addressList: [],
+			};
+		},
+		computed: {
+			i18n() {
+				return this.$t("index");
+			},
+		},
+		methods: {
+			goBack(item) {
+				const eventChannel = this.getOpenerEventChannel()
+				eventChannel.emit('getadd',item)
+				uni.$emit("isRefresh", this.index);
+				uni.navigateBack({
+					delta: 1,
+				});
+			},
 
-    switchTab(num) {
-      this.manage = num;
-      this.getAddressList(num);
-    },
-    //设置默认地址
-    setDefault(value) {
-      uni.$u.http
-        .post(`/api/address/default/${value.id}`)
-        .then((res) => {
-          this.getAddressList(this.manage);
-        })
-        .catch(() => {});
-    },
-    //跳转地址详情页
-    toDetail(id) {
-      if (this.manage) {
-        uni.navigateTo({
-          url: `/pageC/addEditAddress/addEditAddress?id=${id}`,
-        });
-      } else {
-        uni.navigateTo({
-          url: `/pageC/internationalAddress/internationalAddress?id=${id}`,
-        });
-      }
-    },
-    //删除地址
-    deleteAddress(value) {
-      uni.$u.http.delete(`/api/address/${value.id}`).then((res) => {
-        this.getAddressList(this.manage);
-      });
-    },
-    toAddRess(url) {
-      uni.navigateTo({
-        url,
-      });
-    },
-    getAddressList(num) {
-      uni.$u.http
-        .get(
-          `/api/address?is_page=0&page=1&limit=10&is_domestic=${num}&is_default=`
-        )
-        .then((res) => {
-          this.addressList = res;
-        });
-    },
-  },
-  onShow() {
-    this.getAddressList(this.manage);
-  },
-  mounted() {
-    // this.getAddressList(1);
-    uni.setNavigationBarTitle({
-      title: this.i18n.address,
-    });
-  },
-};
+			switchTab(num) {
+				this.manage = num;
+				this.getAddressList(num);
+			},
+			//设置默认地址
+			setDefault(value) {
+				uni.$u.http
+					.post(`/api/address/default/${value.id}`)
+					.then((res) => {
+						this.getAddressList(this.manage);
+					})
+					.catch(() => {});
+			},
+			//跳转地址详情页
+			toDetail(id) {
+				if (this.manage) {
+					uni.navigateTo({
+						url: `/pageC/addEditAddress/addEditAddress?id=${id}`,
+					});
+				} else {
+					uni.navigateTo({
+						url: `/pageC/internationalAddress/internationalAddress?id=${id}`,
+					});
+				}
+			},
+			//删除地址
+			deleteAddress(value) {
+				uni.$u.http.delete(`/api/address/${value.id}`).then((res) => {
+					this.getAddressList(this.manage);
+				});
+			},
+			toAddRess(url) {
+				uni.navigateTo({
+					url,
+				});
+			},
+			getAddressList(num) {
+				uni.$u.http
+					.get(
+						`/api/address?is_page=0&page=1&limit=10&is_domestic=${num}&is_default=`
+					)
+					.then((res) => {
+						this.addressList = res;
+					});
+			},
+		},
+		onShow() {
+			this.getAddressList(this.manage);
+		},
+		mounted() {
+			// this.getAddressList(1);
+			uni.setNavigationBarTitle({
+				title: this.i18n.address,
+			});
+		},
+	};
 </script>
 
 <style scoped lang="scss">
-.top-tab {
-  display: flex;
-  font-size: 32rpx;
-  color: rgba(34, 34, 34, 0.8);
-  justify-content: space-around;
-  background-color: #fff;
-  height: 80rpx;
-  align-items: center;
+	.top-tab {
+		display: flex;
+		font-size: 32rpx;
+		color: rgba(34, 34, 34, 0.8);
+		justify-content: space-around;
+		background-color: #fff;
+		height: 80rpx;
+		align-items: center;
 
-  .select {
-    position: relative;
-    font-weight: 600;
-  }
+		.select {
+			position: relative;
+			font-weight: 600;
+		}
 
-  .select::before {
-    content: "";
-    display: block;
-    width: 50%;
-    height: 4rpx;
-    background-color: #f83224;
-    position: absolute;
-    bottom: -20rpx;
-    left: 50%;
-    transform: translate(-50%, -50%);
-  }
-}
+		.select::before {
+			content: "";
+			display: block;
+			width: 50%;
+			height: 4rpx;
+			background-color: #f83224;
+			position: absolute;
+			bottom: -20rpx;
+			left: 50%;
+			transform: translate(-50%, -50%);
+		}
+	}
 
-.content {
-  padding: 20rpx 24rpx;
-  padding-bottom: 200rpx;
-}
+	.content {
+		padding: 20rpx 24rpx;
+		padding-bottom: 200rpx;
+	}
 
-.empty {
-  font-size: 28rpx;
-  display: flex;
-  justify-content: center;
-  align-items: center;
-  color: rgba(51, 51, 51, 0.7);
-  margin-top: 200rpx;
-}
-.footer {
-  position: fixed;
-  bottom: 0;
-  background-color: #fff;
-  display: flex;
-  justify-content: space-around;
-  width: 750rpx;
-  padding: 20rpx 0 66rpx;
+	.empty {
+		font-size: 28rpx;
+		display: flex;
+		justify-content: center;
+		align-items: center;
+		color: rgba(51, 51, 51, 0.7);
+		margin-top: 200rpx;
+	}
 
-  .wx {
-    width: 338rpx;
-    background-color: #fff;
-    border-radius: 40rpx;
-    height: 80rpx;
-    font-size: 32rpx;
-    color: #222;
-    padding: 0;
-    margin: 0;
-    border: 2rpx solid #979797;
-  }
+	.footer {
+		position: fixed;
+		bottom: 0;
+		background-color: #fff;
+		display: flex;
+		justify-content: space-around;
+		width: 750rpx;
+		padding: 20rpx 0 66rpx;
 
-  .add {
-    width: 338rpx;
-    background-color: #f83224;
-    border-radius: 40rpx;
-    height: 80rpx;
-    font-size: 32rpx;
-    color: #fff;
-    padding: 0;
-    margin: 0;
-  }
+		.wx {
+			width: 338rpx;
+			background-color: #fff;
+			border-radius: 40rpx;
+			height: 80rpx;
+			font-size: 32rpx;
+			color: #222;
+			padding: 0;
+			margin: 0;
+			border: 2rpx solid #979797;
+		}
 
-  .add-international {
-    width: 702rpx;
-    background-color: #f83224;
-    border-radius: 40rpx;
-    height: 80rpx;
-    font-size: 32rpx;
-    color: #fff;
-    margin: 0 auto;
-  }
-}
-</style>
+		.add {
+			width: 338rpx;
+			background-color: #f83224;
+			border-radius: 40rpx;
+			height: 80rpx;
+			font-size: 32rpx;
+			color: #fff;
+			padding: 0;
+			margin: 0;
+		}
+
+		.add-international {
+			width: 702rpx;
+			background-color: #f83224;
+			border-radius: 40rpx;
+			height: 80rpx;
+			font-size: 32rpx;
+			color: #fff;
+			margin: 0 auto;
+		}
+	}
+</style>

+ 14 - 12
pages/express/express.vue

@@ -116,18 +116,18 @@
 				<view class="u-flex u-row-around" style="margin-top: 44rpx;">
 					<view class="flexc" style="position: relative;" @click="pack(0)">
 						<!-- <view class="" style="position: absolute;top: 0;right: 0;"> -->
-						<u-badge :absolute='true' :offset="[0,10]" :type="type" max="99" :value="value"></u-badge>
+						<u-badge :absolute='true' :offset="[0,10]" :type="type" max="99" :value="transit"></u-badge>
 						<!-- </view> -->
 						<image src="/static/express/address.png" style='width:68rpx;height:68rpx' mode=""></image>
 						<text style='margin-top:16rpx'>{{i18n.deliver}}</text>
 					</view>
 					<view class="flexc" style="position: relative;" @click="pack(1)">
-						<u-badge :absolute='true' :offset="[0,10]" :type="type" max="99" :value="value"></u-badge>
+						<u-badge :absolute='true' :offset="[0,10]" :type="type" max="99" :value="receipt"></u-badge>
 						<image src="/static/express/sign.png" style='width:68rpx;height:68rpx' mode=""></image>
 						<text style='margin-top:16rpx'>{{i18n.Sign}}</text>
 					</view>
 					<view class="flexc" style="position: relative;" @click="pack(2)">
-						<u-badge :absolute='true' :offset="[0,10]" :type="type" max="99" :value="value"></u-badge>
+						<u-badge :absolute='true' :offset="[0,10]" :type="type" max="99" :value="overseas"></u-badge>
 						<image src="../../static/express/send.png" style='width:68rpx;height:68rpx' mode=""></image>
 						<text style='margin-top:16rpx'>{{i18n.overseas}}</text>
 					</view>
@@ -212,10 +212,12 @@
 				list: [],
 				current: 0,
 				type: "error",
-				value: 1, //徽标数量
 				percentage: 50, //进度条
 				logshow: false, //物流选择
 				status_collection:'',//我的包裹选择值
+				transit:0,//发往中转点
+				receipt:0,//中转已签收
+				overseas:0,//正发往海外
 			}
 		},
 		onLoad(options) {
@@ -223,6 +225,7 @@
 			if (options.current) {
 				this.current = options.current
 			}
+			
 		},
 		onShow() {
 			this.list[0] = this.i18n.border
@@ -230,6 +233,7 @@
 			uni.setNavigationBarTitle({
 				title: this.i18n.setup
 			})
+			this.express()//获取包裹数量
 		},
 		computed: {
 			i18n() {
@@ -238,15 +242,13 @@
 		},
 		methods: {
 			//我的包裹
-			express(id) {
-				uni.$u.http.get('/api/express-order', {
-					params: {
-						container_id:'',
-						status_collection:''
-					}
+			express() {
+				uni.$u.http.get('/api/express-order/status-count', {
 				}).then((res) => {
-					this.recomlist = this.recomlist.concat(res.data)
-					this.last_page = res.last_page
+					console.log(res);
+					this.overseas = res.to_overseas
+					this.receipt = res.transit_receipt
+					this.transit = res.to_transit
 				}).catch(() => {
 
 				})

+ 121 - 32
pages/shopping/shopping.vue

@@ -5,36 +5,66 @@
 		</view>
 		<u-navbar bgColor="#FE2E2E" :safeAreaInsetTop="true" :placeholder='true'>
 			<view class="u-nav-slot" slot="left">
-				<image src="../../static/shopping/title.png" style="width: 390rpx;height: 48rpx;" mode=""></image>
+				<image v-if="language =='zh-CN'" src="../../static/shopping/title.png" style="width: 390rpx;height: 48rpx;" mode=""></image>
+				<image v-else src="../../static/shopping/title1.png" style="width: 390rpx;height: 48rpx;" mode=""></image>
 			</view>
 		</u-navbar>
 		<view class="input u-flex u-row-between" style="margin-top: 16rpx;">
 			<view class="u-flex">
 				<image src="../../static/shopping/search.png" style="width: 32rpx;height: 32rpx;" mode=""></image>
-				<input type="text" placeholder="请输入商品名称搜索" style="width: 500rpx;margin-left: 14rpx;" />
+				<input v-model="keyword" type="text" placeholder="请输入商品名称搜索"
+					style="width: 500rpx;margin-left: 14rpx;" />
 			</view>
-			<view class="search">搜索</view>
+			<view class="search" @click="search">搜索</view>
 		</view>
 		<view class="content">
 			<view class="">
-				<u-tabs lineColor="#f56c6c" :activeStyle="{
+				<!-- 	<u-tabs lineColor="#f56c6c" :activeStyle="{
             color: 'rgba(248, 53, 39, 1)',
             fontWeight: 'bold',
             transform: 'scale(1.05)'
-        }" :list="list1" @click="click"></u-tabs>
+        }" :list="list1" @click="click"></u-tabs> -->
+				<u-tabs :activeStyle="{
+		    color: 'rgba(248, 53, 39, 1)',
+		    fontWeight: 'bold',
+		    transform: 'scale(1.05)'
+		}" :list="list1" lineColor='rgba(248, 53, 39, 1)' @change='changetab'></u-tabs>
 			</view>
 			<view class="u-flex u-row-between" style="margin-top: 24rpx;flex-wrap: wrap;">
-				<view class="item" v-for="(item,idx) in 6" :key="idx" style="margin-bottom: 20rpx;">
-					<image src="/static/images/logo.png" style="width: 340rpx;height: 340rpx;" mode=""></image>
+				<view @click="todetail(item.id)" class="item" v-for="(item,idx) in list" :key="idx" style="margin-bottom: 20rpx;">
+					<image :src="item.goods.image" style="width: 340rpx;height: 340rpx;" mode=""></image>
 					<view class="" style="padding: 20rpx;box-sizing: border-box;">
-						<text class="title">可心柔 V9系列婴儿保wadhbiuawd</text>
+						<!-- <text class="title">可心柔 V9系列婴儿保wadhbiuawd</text> -->
+						<text class="titl" v-if="language =='zh-CN'">
+							{{item.goods.name_cn}}
+						</text>
+						<view class="titl" v-if="language =='en-US'">
+							{{item.goods.name_en}}
+						</view>
+						<view class="titl" v-if="language =='es-ES'">
+							{{item.goods.name_es}}
+						</view>
+						<view class="titl" v-if="language =='it-IT'">
+							{{item.goods.name_ita}}
+						</view>
 						<view class="u-flex" style="margin-top: 12rpx;flex-wrap: wrap;column-gap: 12rpx;">
-							<view class="tabsa" v-for="(item,index) in 3">
-								{{i18n.orderpaysforitself}}
+							<view class="tabsa" v-for="(child,idx) in item.goods.label_arr" :key="idx">
+								<text class="titl" v-if="language =='zh-CN'">
+									{{child.name_cn}}
+								</text>
+								<view class="titl" v-if="language =='en-US'">
+									{{child.name_en}}
+								</view>
+								<view class="titl" v-if="language =='es-ES'">
+									{{child.name_es}}
+								</view>
+								<view class="titl" v-if="language =='it-IT'">
+									{{child.name_ita}}
+								</view>
 							</view>
 						</view>
 						<view class="num">
-							{{i18n.Soldout}}5000+{{i18n.piece}}
+							{{i18n.Soldout}}{{item.goods.sale_num}}{{i18n.piece}}
 						</view>
 						<view class="" style="margin-top: 16rpx;position: relative;">
 							<image src="/static/shopping/btn.png"
@@ -43,7 +73,7 @@
 								style="padding:10rpx 20rpx 0 26rpx;width: 85%;position: relative;z-index: 1;">
 								<view class="" style="margin-top: 10rpx;">
 									<text class="money">¥</text>
-									<text class="money" style="font-size: 40rpx;">13.2</text>
+									<text class="money" style="font-size: 40rpx;">{{item.goods.price}}</text>
 								</view>
 								<image src="../../static/shopping/shop.png" style="width: 82rpx;height: 38rpx;" mode="">
 								</image>
@@ -63,30 +93,89 @@
 	export default {
 		data() {
 			return {
-				list1: [{
-					name: '关注',
-				}, {
-					name: '推荐',
-				}, {
-					name: '电影'
-				}, {
-					name: '科技'
-				}, {
-					name: '音乐'
-				}, {
-					name: '美食'
-				}, {
-					name: '文化'
-				}, {
-					name: '财经'
-				}, {
-					name: '手工'
-				}]
+				list1: [],
+				language: 'zh-CN', //语言
+				list: [],
+				keyword: '',
+				parent_id: ''
 			};
 		},
+		onShow() {
+			if (uni.getStorageSync('language') != '') {
+				this.language = uni.getStorageSync('language')
+			}
+			this.category()
+			this.shipp()
+		},
 		methods: {
-			click(item) {
+			//跳转详情
+			todetail(id){
+				uni.navigateTo({
+					url:'/pageA/productdetails?id='+id
+				})
+			},
+			//搜索
+			search() {
+				this.shipp(this.parent_id)
+			},
+			//10元购
+			shipp() {
+				uni.$u.http.post('/api/goods/ten_yuan_goods', {
+					parent_id: this.parent_id,
+					keyword: this.keyword
+				}).then((res) => {
+					this.list = res.data
+				}).catch(() => {
+
+				})
+			},
+			//商品分类列表
+			category() {
+				uni.$u.http.get('/api/goods/category', {
+					params: {
+						parent_id: 0,
+					}
+				}).then((res) => {
+					const categoryArr = res
+					this.list1 = [{
+						name: '',
+						category_id: ''
+					}]
+					if (this.language == 'en-US') {
+						categoryArr.forEach(item => {
+							item.name = item.name_en
+						})
+						this.list1[0].name = 'selection'
+					}
+					if (this.language == 'es-ES') {
+						categoryArr.forEach(item => {
+							item.name = item.name_es
+						})
+						this.list1[0].name = 'Una selección de'
+					}
+					if (this.language == 'it-IT') {
+						categoryArr.forEach(item => {
+							item.name = item.name_ita
+						})
+						this.list1[0].name = 'selezionate'
+					}
+
+					if (this.language == 'zh-CN') {
+						categoryArr.forEach(item => {
+							item.name = item.name_cn
+						})
+						this.list1[0].name = '精选'
+					}
+					this.list1 = this.list1.concat(categoryArr)
+					console.log(this.list1);
+				}).catch(() => {
+
+				})
+			},
+			changetab(item) {
+				this.parent_id = item.id
 				console.log('item', item);
+				this.shipp(item.id)
 			}
 		},
 		computed: {

BIN
static/shopping/title1.png