|
@@ -14,31 +14,59 @@
|
|
|
<image src="" mode="" style="width: 12rpx;height: 12rpx;"></image>
|
|
|
</view>
|
|
|
<view class="u-flex" style="margin-top: 24rpx;">
|
|
|
- <view :class="index==idx?'left':'right'" @click="good(idx)" style="margin-right: 20rpx;"
|
|
|
- v-for="(item,idx) in goods" :key="idx">{{item.name}}</view>
|
|
|
+ <view :class="index==idx?'left':'right'" @click="good(item,idx)" style="margin-right: 20rpx;"
|
|
|
+ v-for="(item,idx) in goods" :key="idx">{{item.label}}</view>
|
|
|
<!-- <view class="right" style="margin-left: 20rpx;">特殊商品</view> -->
|
|
|
</view>
|
|
|
</view>
|
|
|
<!-- 跨境物流 -->
|
|
|
<view class="logistics u-flex u-row-between">
|
|
|
<text style="font-weight: 600;">{{i18n.flow}}</text>
|
|
|
- <view class="u-flex" @click="logshow=true">
|
|
|
- <text class="change">{{i18n.selection}}</text>
|
|
|
+ <view class="u-flex" @click="changewu">
|
|
|
+ <text class="change">{{leftname?leftname+' | '+rightname : i18n.selection}}</text>
|
|
|
<u-icon name="arrow-right" size='16'></u-icon>
|
|
|
</view>
|
|
|
</view>
|
|
|
<!-- 商品重量 -->
|
|
|
- <view class="weight u-flex u-row-between">
|
|
|
- <text style="font-weight: 600;">{{i18n.Commodity}}</text>
|
|
|
- <u-number-box v-model="value">
|
|
|
- <view slot="minus" class="minus">
|
|
|
- <u-icon name="minus" size="12"></u-icon>
|
|
|
+ <view class="weight ">
|
|
|
+ <view class="u-flex u-row-between">
|
|
|
+ <text style="font-weight: 600;">{{i18n.Commodity}}</text>
|
|
|
+ <u-number-box v-model="value">
|
|
|
+ <view slot="minus" class="minus">
|
|
|
+ <u-icon name="minus" size="12"></u-icon>
|
|
|
+ </view>
|
|
|
+ <view slot="input"
|
|
|
+ style="width: 50px;text-align: center;height: 30px;line-height: 30px;background: #f5f5f5;"
|
|
|
+ class="input u-flex">
|
|
|
+ <input type="text" v-model="value" />
|
|
|
+ <text>kg</text>
|
|
|
+ </view>
|
|
|
+ <view slot="plus" class="plus">
|
|
|
+ <u-icon name="plus" size="12"></u-icon>
|
|
|
+ </view>
|
|
|
+ </u-number-box>
|
|
|
+ </view>
|
|
|
+ <view class="u-flex u-row-between" style="margin-top: 30rpx;">
|
|
|
+ <text style="font-weight: 600;">总体积</text>
|
|
|
+ <text style="font-size: 20rpx;
|
|
|
+color: rgba(34, 34, 34, 0.5);">补充体积预估费用更精确</text>
|
|
|
+ </view>
|
|
|
+ <view class="u-flex u-row-between" style="margin-top: 32rpx;">
|
|
|
+ <view class="vite u-flex">
|
|
|
+ <input type="text" placeholder="长" v-model="length" />
|
|
|
+ <text>cm</text>
|
|
|
</view>
|
|
|
- <text slot="input" style="width: 50px;text-align: center;display: block;height: 30px;line-height: 30px;background: #f5f5f5;" class="input">{{value}}kg</text>
|
|
|
- <view slot="plus" class="plus">
|
|
|
- <u-icon name="plus" size="12"></u-icon>
|
|
|
+ <view class="">*</view>
|
|
|
+ <view class="vite u-flex">
|
|
|
+ <input type="text" placeholder="宽" v-model="width" />
|
|
|
+ <text>cm</text>
|
|
|
</view>
|
|
|
- </u-number-box>
|
|
|
+ <view class="">*</view>
|
|
|
+ <view class="vite u-flex">
|
|
|
+ <input type="text" placeholder="高" v-model="height" />
|
|
|
+ <text>cm</text>
|
|
|
+ </view>
|
|
|
+ </view>
|
|
|
</view>
|
|
|
<!-- 获取价格 -->
|
|
|
<view @click="gain" :class="gat==1?'yuan':'price'">
|
|
@@ -47,25 +75,27 @@
|
|
|
<view class="gain" v-if="gatShow">
|
|
|
<view class="">
|
|
|
<text class='weigh'>{{i18n.Calculated}}:</text>
|
|
|
- <text class='weigh' style="color: rgba(34, 34, 34, 1);">30.00kg</text>
|
|
|
+ <text class='weigh' style="color: rgba(34, 34, 34, 1);">{{value}}kg</text>
|
|
|
</view>
|
|
|
<view class="u-flex u-row-between"
|
|
|
style="border-top: 2rpx solid #979797;margin-top: 32rpx;padding-top: 20rpx;">
|
|
|
<view class="">
|
|
|
<text class='weigh'>{{i18n.Estimated}}</text>
|
|
|
<text style="margin-left: 6rpx;" class='red'>¥</text>
|
|
|
- <text class='red' style="font-size: 32rpx;">3619</text>
|
|
|
+ <text class='red' style="font-size: 32rpx;">{{money}}</text>
|
|
|
<text class='red'>起</text>
|
|
|
</view>
|
|
|
<view class="info" @click="logistics">{{i18n.details}}</view>
|
|
|
</view>
|
|
|
</view>
|
|
|
<!-- 地址选择 -->
|
|
|
- <u-picker :show="show" ref="uPicker" :columns="columns" @confirm="confirm" @change="changeHandler"></u-picker>
|
|
|
+ <u-picker :show="show" ref="uPicker" keyName="name" :columns="columns" @confirm="confirm"
|
|
|
+ @change="changeHandler"></u-picker>
|
|
|
<!-- 跨境物流 -->
|
|
|
<u-popup round='28' :show="logshow" @close="close">
|
|
|
<view class="pop">
|
|
|
- <kj-flow @success='success' @close='logshow=false'></kj-flow>
|
|
|
+ <kj-flow :goodstype='goodstype' :province_id='province_id' ref="child" @success='success'
|
|
|
+ @close='logshow=false'></kj-flow>
|
|
|
</view>
|
|
|
</u-popup>
|
|
|
</view>
|
|
@@ -84,30 +114,40 @@
|
|
|
gat: 0,
|
|
|
gatShow: false,
|
|
|
columns: [
|
|
|
- ['中国', '美国'],
|
|
|
- ['深圳', '厦门', '上海', '拉萨']
|
|
|
+
|
|
|
],
|
|
|
columnData: [
|
|
|
- ['深圳', '厦门', '上海', '拉萨'],
|
|
|
- ['得州', '华盛顿', '纽约', '阿拉斯加']
|
|
|
+
|
|
|
],
|
|
|
goods: [],
|
|
|
- index: 0
|
|
|
+ index: 0,
|
|
|
+ domestic: 1,
|
|
|
+ province_id: '',
|
|
|
+ goodstype: 'normal',
|
|
|
+ container_id: '', //货柜id
|
|
|
+ leftname: '',
|
|
|
+ rightname: '',
|
|
|
+ money: '',
|
|
|
+ length: '',
|
|
|
+ width: '',
|
|
|
+ height: ''
|
|
|
};
|
|
|
},
|
|
|
onLoad() {
|
|
|
- this.goods = [{
|
|
|
- name: this.i18n.Normal
|
|
|
- },
|
|
|
- {
|
|
|
- name: this.i18n.special
|
|
|
- }
|
|
|
- ]
|
|
|
+ // this.goods = [{
|
|
|
+ // name: this.i18n.Normal
|
|
|
+ // },
|
|
|
+ // {
|
|
|
+ // name: this.i18n.special
|
|
|
+ // }
|
|
|
+ // ]
|
|
|
},
|
|
|
onShow() {
|
|
|
uni.setNavigationBarTitle({
|
|
|
- title:this.i18n.compute
|
|
|
+ title: this.i18n.compute
|
|
|
})
|
|
|
+ // this.getarea()
|
|
|
+ this.goodtype()
|
|
|
},
|
|
|
computed: {
|
|
|
i18n() {
|
|
@@ -115,14 +155,83 @@
|
|
|
}
|
|
|
},
|
|
|
methods: {
|
|
|
- success() {
|
|
|
+ //商品类型
|
|
|
+ goodtype() {
|
|
|
+ uni.$u.http.get('/api/express-goods-type', ).then((res) => {
|
|
|
+ console.log(res);
|
|
|
+ this.goods = res
|
|
|
+ }).catch(() => {
|
|
|
+
|
|
|
+ })
|
|
|
+ },
|
|
|
+ //物流选择
|
|
|
+ changewu() {
|
|
|
+ if (this.province_id) {
|
|
|
+ this.logshow = true
|
|
|
+ setTimeout(() => {
|
|
|
+ this.$refs.child.transport();
|
|
|
+ }, 800)
|
|
|
+ } else {
|
|
|
+ this.$u.toast('请先选择城市')
|
|
|
+ }
|
|
|
+ },
|
|
|
+ //物流计算器
|
|
|
+ calculate() {
|
|
|
+ if (this.container_id == '') {
|
|
|
+ this.$u.toast('请选择货柜')
|
|
|
+ return
|
|
|
+ }
|
|
|
+ uni.$u.http.get('/api/express-order/calculate', {
|
|
|
+ params: {
|
|
|
+ container_id: this.container_id, // 是 String 货柜ID
|
|
|
+ weight: this.value, // 是 String 重量(kg)
|
|
|
+ length: 1, // 是 String 长(m)
|
|
|
+ width: 1, // 是 String 宽(m)
|
|
|
+ height: 1, // 是 String 高(m)
|
|
|
+ type: this.goodstype, // 是 String 商品类型: normal. 普通商品, special.特殊商品
|
|
|
+ }
|
|
|
+ }).then((res) => {
|
|
|
+ console.log(res);
|
|
|
+ this.money = res
|
|
|
+ }).catch(() => {
|
|
|
+
|
|
|
+ })
|
|
|
+ },
|
|
|
+ //地区列表
|
|
|
+ getarea() {
|
|
|
+ this.columns = []
|
|
|
+ this.columnData = []
|
|
|
+ uni.$u.http.get('/api/area/tree', {
|
|
|
+ params: {
|
|
|
+ is_domestic: this.domestic,
|
|
|
+ pid: 0
|
|
|
+ }
|
|
|
+ }).then((res) => {
|
|
|
+ console.log(res)
|
|
|
+ // this.columns.splice(0,1, [{name:res[0].name}])
|
|
|
+ this.columns = [res]
|
|
|
+ this.columns[1] = res[0].children
|
|
|
+ // this.columnData[0] = res[0].children
|
|
|
+ res.forEach(item => {
|
|
|
+ this.columnData.push(item.children)
|
|
|
+ })
|
|
|
+ }).catch(() => {
|
|
|
+
|
|
|
+ })
|
|
|
+ },
|
|
|
+ success(msg) {
|
|
|
this.logshow = false
|
|
|
+ console.log(msg);
|
|
|
+ this.leftname = msg.leftname
|
|
|
+ this.container_id = msg.dateid
|
|
|
+ this.rightname = msg.rightname
|
|
|
},
|
|
|
close() {
|
|
|
this.logshow = false
|
|
|
},
|
|
|
//切换商品类型
|
|
|
- good(idx) {
|
|
|
+ good(item, idx) {
|
|
|
+ this.goodstype = item.value
|
|
|
this.index = idx
|
|
|
},
|
|
|
//物流详情
|
|
@@ -133,13 +242,25 @@
|
|
|
},
|
|
|
//获取价格
|
|
|
gain() {
|
|
|
- this.gat = 1
|
|
|
- this.gatShow = true
|
|
|
+ if (this.container_id == '') {
|
|
|
+ this.$u.toast('请选择货柜')
|
|
|
+ } else {
|
|
|
+ this.gat = 1
|
|
|
+ this.gatShow = true
|
|
|
+ this.calculate()
|
|
|
+ }
|
|
|
},
|
|
|
//开启地址选择器
|
|
|
change(type) {
|
|
|
this.type = type
|
|
|
this.show = true
|
|
|
+ if (type == 0) {
|
|
|
+ this.domestic = 1
|
|
|
+ this.getarea()
|
|
|
+ } else {
|
|
|
+ this.domestic = 0
|
|
|
+ this.getarea()
|
|
|
+ }
|
|
|
},
|
|
|
changeHandler(e) {
|
|
|
const {
|
|
@@ -161,10 +282,11 @@
|
|
|
console.log('confirm', e)
|
|
|
this.show = false
|
|
|
if (this.type == 0) {
|
|
|
- this.original = e.value[0] + '-' + e.value[1]
|
|
|
+ this.original = e.value[0].name + '-' + e.value[1].name
|
|
|
// console.log(e.value[0]);
|
|
|
} else {
|
|
|
- this.bourn = e.value[0] + '-' + e.value[1]
|
|
|
+ this.bourn = e.value[0].name + '-' + e.value[1].name
|
|
|
+ this.province_id = e.value[1].id
|
|
|
}
|
|
|
}
|
|
|
}
|
|
@@ -172,6 +294,15 @@
|
|
|
</script>
|
|
|
|
|
|
<style lang="scss" scoped>
|
|
|
+ .vite {
|
|
|
+ width: 198rpx;
|
|
|
+ height: 60rpx;
|
|
|
+ background: #F4F4F4;
|
|
|
+ border-radius: 36rpx;
|
|
|
+ padding: 12rpx 28rpx;
|
|
|
+ box-sizing: border-box;
|
|
|
+ }
|
|
|
+
|
|
|
.pop {
|
|
|
font-family: PingFangSC, PingFang SC;
|
|
|
font-weight: 500;
|
|
@@ -281,7 +412,7 @@
|
|
|
padding: 34rpx 20rpx;
|
|
|
box-sizing: border-box;
|
|
|
width: 702rpx;
|
|
|
- height: 108rpx;
|
|
|
+ // height: 108rpx;
|
|
|
background: #FFFFFF;
|
|
|
border-radius: 16rpx;
|
|
|
margin-top: 20rpx;
|
|
@@ -388,7 +519,7 @@
|
|
|
height: 144rpx;
|
|
|
background: #FFFFFF;
|
|
|
border-radius: 16rpx;
|
|
|
- padding: 50rpx 76rpx;
|
|
|
+ padding: 50rpx 8rpx;
|
|
|
box-sizing: border-box;
|
|
|
|
|
|
.address {
|