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.
226 lines
5.4 KiB
226 lines
5.4 KiB
<template>
|
|
<view id="address-list">
|
|
<lf-nav title="地址管理" :showIcon="true" bgColor="#fff"></lf-nav>
|
|
<view class="list-box">
|
|
<view class="list-item" :data-info="JSON.stringify(item)" :data-id="item.id" v-for="(item, index) in list" :key="index">
|
|
<!-- <view class="user">
|
|
<view class="name">
|
|
<text>{{item.accept_name}}</text>
|
|
<text class="phone">{{item.mobile}}</text>
|
|
</view>
|
|
<view class="default" v-if="item.is_default">
|
|
默认
|
|
</view>
|
|
</view>
|
|
<view class="address">{{item.address_name}} {{item.address}}</view> -->
|
|
|
|
<view class="lf-font-28 user-item">
|
|
<text class="lf-color-black lf-font-bold">{{item.accept_name}}</text>
|
|
<text class="lf-color-777 lf-m-l-20">{{item.mobile}}</text>
|
|
</view>
|
|
<view class="address-item lf-line-2">
|
|
<text>{{item.address_name}}</text>
|
|
<text>{{item.address}}</text>
|
|
</view>
|
|
<view class="menu-item lf-row-between lf-m-t-30">
|
|
<view class="lf-row-center">
|
|
<radio-group @change="radioChange">
|
|
<radio :checked="item.is_default" :value="index"></radio>
|
|
</radio-group>
|
|
<text class="lf-m-l-15 lf-font-24 lf-color-777">默认地址</text>
|
|
</view>
|
|
<view class="lf-row-between">
|
|
<view @tap="setInfo(item)">
|
|
<text class="lf-iconfont icon--1"></text>
|
|
<text class="lf-m-l-10">编辑</text>
|
|
</view>
|
|
<view class="lf-m-l-50" @click="deleteAddress(item)">
|
|
<text class="lf-iconfont icon--1"></text>
|
|
<text class="lf-m-l-10">删除</text>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<view style="height: 230rpx;"></view>
|
|
<view class="add-address" @tap="add">
|
|
<view class="small-btn">
|
|
<text class="lf-iconfont icon--2"></text>
|
|
<text class="lf-m-l-10">新增收货地址</text>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
|
|
</template>
|
|
<script>
|
|
import {pageLogin, getUrl,config,is} from '@/common/js/utils.js';
|
|
|
|
export default {
|
|
data() {
|
|
return {
|
|
list: [],
|
|
order_no: '',
|
|
url: '',
|
|
id:''
|
|
};
|
|
},
|
|
|
|
onShow() {
|
|
this.queryAddressList(); // let app =getApp(); 暂时注释
|
|
|
|
// app.isBirthday().then(()=>{
|
|
// if(this.$cookieStorage.get("birthday_gift")){
|
|
// var giftData=this.$cookieStorage.get("birthday_gift").data;
|
|
// new app.ToastPannel().__page.showText(giftData);
|
|
// }
|
|
// });
|
|
},
|
|
|
|
onLoad(e) {
|
|
// 暂时注释
|
|
// pageLogin(getUrl());
|
|
this.setData({
|
|
order_no: e.order_no,
|
|
url: e.url
|
|
});
|
|
},
|
|
|
|
components: {},
|
|
props: {},
|
|
methods: {
|
|
// 删除收货地址
|
|
deleteAddress(item){
|
|
console.log("item", item)
|
|
this.$http.ajax({
|
|
api: '/api/address/'+ item.id,
|
|
method: 'DELETE',
|
|
header: {
|
|
Authorization: this.getToken()
|
|
}
|
|
}).then(res => {
|
|
console.log("删除地址", res);
|
|
})
|
|
},
|
|
// 切换默认地址
|
|
radioChange(e){
|
|
let current = e.target.value;
|
|
this.list.forEach((item, index) => {
|
|
if(current == index){
|
|
item.is_default = 1;
|
|
}else{
|
|
item.is_default = 0;
|
|
}
|
|
})
|
|
},
|
|
setInfo(e) {
|
|
// var from = e.currentTarget.dataset.info;
|
|
var from = e;
|
|
var data = this.$cookieStorage.get('order_form');
|
|
// var from=JSON.parse(from);
|
|
|
|
if (!data) {
|
|
return this.view(from.id);
|
|
}
|
|
|
|
var order_no = this.order_no;
|
|
|
|
if (order_no && data.order_no === order_no) {
|
|
data.address = from;
|
|
this.$cookieStorage.set('order_form', data);
|
|
wx.navigateBack({
|
|
url: '/' + this.url
|
|
});
|
|
} else {
|
|
return this.view(from.id);
|
|
}
|
|
},
|
|
|
|
view(id) {
|
|
wx.navigateTo({
|
|
url: '/pages/address/add/add?id=' + id
|
|
});
|
|
},
|
|
|
|
add() {
|
|
wx.navigateTo({
|
|
url: '/pages/address/add/add'
|
|
});
|
|
},
|
|
|
|
// 查询收货地址列表
|
|
queryAddressList() {
|
|
var token = this.$cookieStorage.get('user_token');
|
|
this.$http.get({
|
|
api: 'api/address',
|
|
header: {
|
|
Authorization: token || this.getToken()
|
|
}
|
|
}).then(res => {
|
|
if (res.statusCode == 200) {
|
|
res = res.data;
|
|
|
|
if (res.status) {
|
|
this.setData({
|
|
list: res.data
|
|
});
|
|
} else {
|
|
wx.showToast({
|
|
title: res.message,
|
|
image: '../../../static/error.png'
|
|
});
|
|
}
|
|
} else {
|
|
wx.showToast({
|
|
title: '获取信息失败',
|
|
image: '../../../static/error.png'
|
|
});
|
|
}
|
|
});
|
|
},
|
|
|
|
setData: function (obj) {
|
|
let that = this;
|
|
let keys = [];
|
|
let val, data;
|
|
Object.keys(obj).forEach(function (key) {
|
|
keys = key.split('.');
|
|
val = obj[key];
|
|
data = that.$data;
|
|
keys.forEach(function (key2, index) {
|
|
if (index + 1 == keys.length) {
|
|
that.$set(data, key2, val);
|
|
} else {
|
|
if (!data[key2]) {
|
|
that.$set(data, key2, {});
|
|
}
|
|
}
|
|
|
|
data = data[key2];
|
|
});
|
|
});
|
|
}
|
|
},
|
|
computed: {},
|
|
watch: {}
|
|
};
|
|
</script>
|
|
|
|
<style>
|
|
page{
|
|
background-color: #F8F8F8;
|
|
}
|
|
</style>
|
|
<style rel="stylesheet/less" lang="less">
|
|
@import "list";
|
|
|
|
.user-item, .menu-item{
|
|
height: 50rpx;
|
|
width: 100%;
|
|
}
|
|
.address-item{
|
|
width: 100%;
|
|
margin-top: 10rpx;
|
|
font-size: 28rpx;
|
|
color: #333333;
|
|
}
|
|
</style>
|