You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
289 lines
7.3 KiB
289 lines
7.3 KiB
5 months ago
|
<template>
|
||
|
<!-- 添加新地址 -->
|
||
|
<view :style="colorStyle">
|
||
|
<form @submit="formSubmit">
|
||
|
<view class='addAddress'>
|
||
|
<view class="input-wrapper">
|
||
|
<view class='list'>
|
||
|
<view class='item acea-row row-between-wrapper'>
|
||
|
<view class='name'>姓名</view>
|
||
|
<input type='text' placeholder='请输入姓名' name='real_name' :value="userAddress.real_name" placeholder-class='placeholder'></input>
|
||
|
</view>
|
||
|
<view class='item acea-row row-between-wrapper'>
|
||
|
<view class='name'>联系电话</view>
|
||
|
<input type='number' maxlength="11" placeholder='请输入联系电话' name="phone" :value='userAddress.phone' placeholder-class='placeholder' pattern="\d*"></input>
|
||
|
</view>
|
||
|
<view class='item acea-row row-between-wrapper'>
|
||
|
<view class='name'>所在地区</view>
|
||
|
<view class="address acea-row row-between-wrapper">
|
||
|
<view class="addressCon acea-row" @click="changeRegion">
|
||
|
<text class="picker color-add" v-if="!addressInfo.length">请选择地址</text>
|
||
|
<view v-else>
|
||
|
<text class="picker">{{addressText}}</text>
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class="location1" @click="chooseLocation">
|
||
|
<text class="iconfont icon-ic_location1 text-primary"></text>定位
|
||
|
</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class='item acea-row row-between-wrapper'>
|
||
|
<view class='name'>详细地址</view>
|
||
|
<view class="address">
|
||
|
<input type='text' placeholder='请填写具体地址' name='detail' placeholder-class='placeholder' :value='userAddress.detail' class="detail"></input>
|
||
|
</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
<button class='keepBnt' form-type="submit">立即保存</button>
|
||
|
</view>
|
||
|
</form>
|
||
|
<areaWindow ref="areaWindow" :display="display" :address="addressInfo" @submit="OnChangeAddress" @changeClose="changeClose"></areaWindow>
|
||
|
</view>
|
||
|
</template>
|
||
|
|
||
|
<script>
|
||
|
import {getGeocoder,getCityList} from '@/api/user.js';
|
||
|
import {mapGetters} from "vuex";
|
||
|
import colors from '@/mixins/color.js';
|
||
|
import areaWindow from '@/components/areaWindow';
|
||
|
import AddressParse from '../components/zh-address-parse.min.js'
|
||
|
export default {
|
||
|
components: {
|
||
|
areaWindow,
|
||
|
},
|
||
|
mixins: [colors],
|
||
|
data() {
|
||
|
return {
|
||
|
id: 0, //地址id
|
||
|
userAddress: {}, //地址详情
|
||
|
district: [],
|
||
|
display: false,
|
||
|
addressInfo: [],
|
||
|
addressVal: '',
|
||
|
latitude: '',
|
||
|
longitude: '',
|
||
|
city_id: 0,
|
||
|
addressValue: "",
|
||
|
};
|
||
|
},
|
||
|
computed: {
|
||
|
...mapGetters(['isLogin']),
|
||
|
addressText() {
|
||
|
return this.addressInfo.map(v => v.label).join('/');
|
||
|
}
|
||
|
},
|
||
|
onLoad(options) {
|
||
|
|
||
|
},
|
||
|
methods: {
|
||
|
changeRegion() {
|
||
|
this.display = true;
|
||
|
},
|
||
|
OnChangeAddress(address) {
|
||
|
this.latitude = ''
|
||
|
this.longitude = ''
|
||
|
this.addressInfo = address;
|
||
|
},
|
||
|
// 关闭地址弹窗;
|
||
|
changeClose: function() {
|
||
|
this.display = false;
|
||
|
},
|
||
|
// 获取选中位置
|
||
|
chooseLocation: function() {
|
||
|
let self = this;
|
||
|
uni.chooseLocation({
|
||
|
success: (res) => {
|
||
|
let latitude, longitude;
|
||
|
latitude = res.latitude.toString();
|
||
|
longitude = res.longitude.toString();
|
||
|
this.latitude = res.latitude
|
||
|
this.longitude = res.longitude
|
||
|
getGeocoder({
|
||
|
lat: latitude,
|
||
|
long: longitude
|
||
|
}).then(res => {
|
||
|
const data = res.data;
|
||
|
getCityList(data.address_component.province + '/' + data.address_component.city + '/' + data.address_component.district + '/' + (!data
|
||
|
.address_reference.town ? '' : data.address_reference.town.title)).then(res => {
|
||
|
self.addressInfo = res.data;
|
||
|
self.userAddress.detail = data.formatted_addresses.recommend;
|
||
|
}).catch(err => {
|
||
|
self.$util.Tips({
|
||
|
title: err
|
||
|
});
|
||
|
});
|
||
|
})
|
||
|
},
|
||
|
fail: (err) => {
|
||
|
console.log(err)
|
||
|
}
|
||
|
})
|
||
|
},
|
||
|
/**
|
||
|
* 提交用户添加地址
|
||
|
*
|
||
|
*/
|
||
|
formSubmit: function(e) {
|
||
|
let that = this,
|
||
|
value = e.detail.value;
|
||
|
if (!value.real_name) return that.$util.Tips({
|
||
|
title: '请填写收货人姓名'
|
||
|
});
|
||
|
if (!value.phone) return that.$util.Tips({
|
||
|
title: '请填写联系电话'
|
||
|
});
|
||
|
if (!/^1(3|4|5|7|8|9|6)\d{9}$/i.test(value.phone)) return that.$util.Tips({
|
||
|
title: '请输入正确的手机号码'
|
||
|
});
|
||
|
if (!that.addressInfo.length) return that.$util.Tips({
|
||
|
title: '请选择所在地区'
|
||
|
});
|
||
|
if (that.addressInfo.length < 3) return that.$util.Tips({
|
||
|
title: '请补全所在地区信息'
|
||
|
});
|
||
|
if (!value.detail) return that.$util.Tips({
|
||
|
title: '请填写详细地址'
|
||
|
});
|
||
|
value.id = 0;
|
||
|
let regionArray = that.addressInfo;
|
||
|
value.address = {
|
||
|
province: regionArray[0].label,
|
||
|
city: regionArray[1].label,
|
||
|
district: regionArray[2].label,
|
||
|
street: regionArray[3] ? regionArray[3].label : '',
|
||
|
city_id: regionArray[regionArray.length - 1].id ? regionArray[regionArray.length - 1].id : that.city_id,
|
||
|
};
|
||
|
uni.$emit("refresh", value)
|
||
|
uni.navigateBack()
|
||
|
},
|
||
|
identify() {
|
||
|
const options = {
|
||
|
type: 0, // 哪种方式解析,0:正则,1:树查找
|
||
|
textFilter: [], // 预清洗的字段
|
||
|
nameMaxLength: 4, // 查找最大的中文名字长度
|
||
|
}
|
||
|
const parseResult = AddressParse(this.addressValue.trim(), options)
|
||
|
// type参数0表示使用正则解析,1表示采用树查找, textFilter地址预清洗过滤字段。
|
||
|
if (this.addressValue.trim()) {
|
||
|
getCityList(parseResult.province + '/' + parseResult.city + '/' + parseResult.area).then(res => {
|
||
|
this.addressInfo = res.data;
|
||
|
this.userAddress.phone = parseResult.phone;
|
||
|
this.userAddress.real_name = parseResult.name;
|
||
|
this.userAddress.detail = parseResult.detail;
|
||
|
}).catch(err => {
|
||
|
return this.$util.Tips({
|
||
|
title: err
|
||
|
});
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
</script>
|
||
|
|
||
|
<style scoped lang="scss">
|
||
|
.color-add {
|
||
|
color: #cdcdcd;
|
||
|
}
|
||
|
|
||
|
.location1 {
|
||
|
.iconfont {
|
||
|
margin-right: 8rpx;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.text-primary {
|
||
|
color: $primary-admin;
|
||
|
}
|
||
|
|
||
|
.addAddress {
|
||
|
padding: 24rpx 20rpx;
|
||
|
}
|
||
|
|
||
|
.addAddress .input-wrapper {
|
||
|
margin-bottom: 20rpx;
|
||
|
}
|
||
|
|
||
|
.addAddress .list {
|
||
|
padding: 8rpx 0;
|
||
|
border-radius: 16rpx;
|
||
|
background-color: #fff;
|
||
|
}
|
||
|
|
||
|
.addAddress .list .item {
|
||
|
padding: 32rpx 24rpx;
|
||
|
position: relative;
|
||
|
}
|
||
|
|
||
|
.addAddress .list .item .detail {
|
||
|
width: 368rpx;
|
||
|
}
|
||
|
|
||
|
.addAddress .list .item .location {
|
||
|
position: absolute;
|
||
|
right: 46rpx;
|
||
|
top: 50%;
|
||
|
margin-top: -40rpx !important;
|
||
|
font-size: 24rpx;
|
||
|
text-align: center;
|
||
|
}
|
||
|
|
||
|
.addAddress .list .item .icon-dizhi {
|
||
|
font-size: 36rpx !important;
|
||
|
}
|
||
|
|
||
|
.addAddress .list .item .name {
|
||
|
width: 195rpx;
|
||
|
font-size: 30rpx;
|
||
|
color: #333;
|
||
|
}
|
||
|
|
||
|
.addAddress .list .item .address {
|
||
|
// width: 412rpx;
|
||
|
flex: 1;
|
||
|
// margin-left: 20rpx;
|
||
|
}
|
||
|
|
||
|
.addAddress .list .item .address .addressCon {
|
||
|
width: 360rpx;
|
||
|
}
|
||
|
|
||
|
.addAddress .list .item .address .addressCon .tip {
|
||
|
font-size: 21rpx;
|
||
|
margin-top: 4rpx;
|
||
|
}
|
||
|
|
||
|
.addAddress .list .item input {
|
||
|
flex: 1;
|
||
|
font-size: 30rpx;
|
||
|
}
|
||
|
|
||
|
.placeholder {
|
||
|
color: #ccc;
|
||
|
}
|
||
|
|
||
|
.addAddress .list .item .picker {
|
||
|
width: 430rpx;
|
||
|
font-size: 30rpx;
|
||
|
}
|
||
|
|
||
|
.addAddress .list .item .iconfont {
|
||
|
font-size: 30rpx;
|
||
|
margin-top: 4rpx;
|
||
|
}
|
||
|
|
||
|
.addAddress .keepBnt {
|
||
|
position: fixed;
|
||
|
right: 20rpx;
|
||
|
bottom: 40rpx;
|
||
|
left: 20rpx;
|
||
|
height: 80rpx;
|
||
|
border-radius: 40rpx;
|
||
|
text-align: center;
|
||
|
line-height: 80rpx;
|
||
|
font-size: 28rpx;
|
||
|
color: #fff;
|
||
|
background-color: $primary-admin;
|
||
|
}
|
||
|
</style>
|