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.
 
 
 
 
 
zhishifufei_uniapp/pages/my/address.vue

292 lines
9.0 KiB

<template>
<BaseContainer class="address-list">
<NavBar title="地址管理" />
<view class="list" v-if="address && address.length">
<view class="list-item flex flex-center-x" v-for="(item, index) in address" :key="index">
<view class="head">
<view>{{ item.real_name }} {{ item.phone }} <view v-if="item.is_default">默认</view> </view>
<view>
{{ item.province }} {{ item.city }} {{ item.district }}{{ item.detail }}
</view>
</view>
<image src="@/static/images/my/edit.png" mode="aspectFill" @click="editAddress(item.id)"></image>
<!-- <view class="foot flex flex-center-x">
<view class="label">
<view
class="checked-icon"
@click="setDefault(item.id)"
:class="{ active: item.is_default }"
>设为默认</view
>
</view>
<view class="flex-auto flex flex-right">
<navigator :url="`/pages/my/edit_address?id=${item.id}`" class="edit-btn">
<image
:src="getImgPath('/wap/first/zsff/images/editor.png')"
mode="aspectFit"
/>编辑
</navigator>
<view @click="remove(item.id)" class="del-btn">
<image :src="getImgPath('/wap/first/zsff/images/trash.png')" />删除
</view>
</view>
</view> -->
</view>
</view>
<image
v-else
class="nothing"
:src="getImgPath('/wap/first/zsff/images/no_address.png')"
/>
<view class="footer">
<navigator url="/pages/my/edit_address">
<text>添加地址</text>
</navigator>
<!-- #ifdef MP -->
<!-- <view v-if="isWechat" @click="getWxAddress">
<image :src="getImgPath('/wap/first/zsff/images/weixin.png')" />
<text>导入微信地址</text>
</view> -->
<!-- #endif -->
</view>
</BaseContainer>
</template>
<script>
import { getAddress, removeUserAddress, setDefaultAddress } from "@/api/user";
export default {
data() {
return {
address: [],
isWechat: false,
};
},
onShow() {
this.getAddress();
},
methods: {
getAddress() {
getAddress().then(({ data }) => {
this.address = data.address;
});
},
setDefault(id) {
setDefaultAddress(id).then((res) => {
this.$util.showMsg("设为默认成功");
for (let item of this.address) {
item.is_default = item.id === id;
}
});
},
editAddress(id) {
uni.navigateTo({
url: `/pages/my/edit_address?id=${id}`,
});
},
remove(id) {
uni.showModal({
title: "提示",
content: "是否删除该地址?",
success: async ({ confirm }) => {
if (!confirm) return;
uni.showModal({ mask: true });
try {
await removeUserAddress(id);
uni.hideLoading();
uni.showMsg("删除成功!");
this.address = this.address.filter((value) => value.id !== id);
} catch (err) {
uni.hideLoading();
this.$util.showMsg(err.msg);
}
},
});
},
// #ifdef MP
getWxAddress: function () {
mapleWx($jssdk(), function () {
this.openAddress(
function (res) {
$h.loadFFF();
api.basePost(
$h.U({ c: "auth_api", a: "edit_user_address" }),
{
id: "",
real_name: res.userName,
phone: res.telNumber,
address: {
province: res.provinceName,
city: res.cityName,
district: res.countryName,
},
detail: res.detailInfo,
is_default: false,
},
function () {
location.reload();
}.bind(this),
function (err) {
$h.loadClear();
}
);
},
function (err) {
$h.pushMsg("导入微信地址失败");
}
);
});
},
// #endif
},
};
</script>
<style>
page {
padding-bottom: 118rpx;
background-color: #f5f5f5;
}
</style>
<style scoped lang="scss">
.nothing {
position: absolute;
top: 30%;
left: 50%;
width: 414rpx;
height: 336rpx;
transform: translate(-50%, -50%);
}
.address-list .list-item {
padding: 34rpx 42rpx 38rpx 30rpx;
background-color: #ffffff;
width: 690rpx;
margin: 20rpx auto 0 ;
border-radius: 10rpx;
image {
height: 34rpx;
width: 34rpx;
margin-left: auto;
}
}
.address-list .head {
width: 410rpx;
font-size: 28rpx;
color: #666;
}
.address-list .head>view:first-child {
margin-bottom: 8rpx;
font-size: 34rpx;
color: #333;
display: flex;
align-items: center;
view {
height: 38rpx;
background: #FEE1E1;
font-size: 20rpx;
color: #FF5C6B;
text-align: center;
line-height: 38rpx;
border-radius: 6rpx;
margin-left: 20rpx;
padding: 0 14rpx;
}
}
.address-list .foot {
height: 82rpx;
border-top: 1px solid #eee;
font-size: 28rpx;
color: #282828;
}
.address-list .foot navigator {
color: #282828;
}
.address-list .foot .label view {
padding-left: 48rpx;
background: url("")
left center/38rpx 38rpx no-repeat;
}
.address-list .foot .checked-icon.active {
background-image: url("");
}
.address-list .foot .del-btn {
margin-left: 50rpx;
}
.address-list .foot {
.edit-btn,
.del-btn {
image {
width: 38rpx;
height: 38rpx;
vertical-align: middle;
object-fit: cover;
pointer-events: none;
}
}
}
.address-list .footer {
position: fixed;
bottom: 44rpx;
left: 30rpx;
z-index: 9;
display: flex;
width: 690rpx;
align-items: center;
}
.address-list .footer navigator {
flex: 1;
height: 76rpx;
border-radius: 38rpx;
background: linear-gradient(0deg, #0F74BB 0%, #3293FF 100%);;
vertical-align: middle;
font-size: 30rpx;
line-height: 76rpx;
text-align: center;
color: #ffffff;
}
.address-list .footer a:nth-child(2) {
margin-left: 30rpx;
background-color: #feb720;
}
.address-list .footer image {
width: 36rpx;
height: 36rpx;
margin-right: 10rpx;
vertical-align: middle;
object-fit: cover;
pointer-events: none;
}
.address-list .footer a:nth-child(2) image {
width: auto;
}
.address-list .footer text {
vertical-align: middle;
}
.address-list .nothing {
display: block;
width: 414rpx;
margin: 30rpx auto;
pointer-events: none;
-webkit-touch-callout: none;
}
</style>