index.vue 4.05 KB
<template>
	<view class="address-container">
		<view class="address-box">
			<view class="item" v-for="(res, index) in siteList" :key="res.id">
				<view class="top" @click="handleClickChangeCurrentAddress(res)">
					<view class="name">{{ res.garUserContactName }}</view>
					<view class="phone">{{ res.garUserContactTel }}</view>
					<view class="tag">
						<text v-if="res.garUserDefault == 1" :class="{ red: res.garUserDefault == 1 }">
							{{ res.garUserDefault == 1 ? "默认地址" : "" }}
						</text>
					</view>
				</view>
				<view class="bottom" >
				<view @click="handleClickChangeCurrentAddress(res)">
					{{ res.garUserAddress + res.garRemark }}
				</view>
					
					<u-icon name="edit-pen" @click="handleUpdateAddress(res)" :size="40" color="#999999" v-if="updateFlag"></u-icon>
				</view>
			</view>

		</view>
		<view class="addSite" @click.stop="toAddSite" hover-class="click-box">
			<view class="add">添加地址</view>
		</view>
	</view>
</template>

<script setup>
import { queryAddress, updateAddress } from "@/apis/address.js";
import { onShow } from '@dcloudio/uni-app';
import { useMainStore } from '@/stores/index.js';
import { ref,computed } from 'vue';
const store = useMainStore();
const userType = computed(() => store.userType)

const siteList = ref([]);
const updateFlag = ref(true);

/**
 * 初始话数据
 */
const getData = () => {
	queryAddress("ALL").then(res => {
		siteList.value = res.data.data;
	})
}

// 编辑地址
const handleUpdateAddress = (res) => {
	let addressObj = JSON.stringify(res);
	uni.navigateTo({
		url: `/pages/home-info/address/addSite?addressObj=${addressObj}`
	});
}

const handleClickChangeCurrentAddress = (res) => {
	if (res.garUserDefault == 1) {
		return
	}
	updateAddress({
		addressArea: res.garUserAddress,
		contactPerson: res.garUserContactName,
		contactIphoneNumber: res.garUserContactTel,
		defaultFlag: true,
		addressDetail: res.garRemark,
		garAddressId: res.garAddressId,
		garLongitude: res.garLongitude,
		garLatitude: res.garLatitude,
		garCoordinate: res.garCoordinate
	}).then(res => {
		getData();
		uni.$u.toast(res.data.msg)
	})
}

const toAddSite = () => {
	uni.navigateTo({
		url: '/pages/home-info/address/addSite'
	});
}
onShow(() => {
	getData();
	if (userType.value == '处置场所负责人') {
		updateFlag.value=false;
	}
})
</script>

<style lang="scss" scoped>
.address-container {
	height: 100%;
	width: 100%;
	background: linear-gradient(to bottom, #19a97c, $u-info-light, $u-info-light, $u-info-light, $u-info-light, #ffffff);
	padding: 20rpx;
	box-sizing: border-box;
	display: flex;
	justify-content: center;

	.address-box {
		height: calc(100% - 130rpx);
		width: 100%;
		overflow-y: scroll;
		box-sizing: border-box;

		.item {
			padding: 40rpx 20rpx;
			background-color: #ffffff;
			border-radius: 20rpx;
			margin-bottom: 10rpx;
			box-sizing: border-box;

			.top {
				display: flex;
				font-weight: bold;
				font-size: 30rpx;
				color: $u-main-color;

				.phone {
					margin-left: 60rpx;
				}

				.tag {
					display: flex;
					font-weight: normal;
					align-items: center;
					background-color: #ffffff;

					text {
						display: block;
						width: auto;
						box-sizing: border-box;
						height: 36rpx;
						line-height: 36rpx;
						color: #ffffff;
						font-size: 28rpx;
						display: flex;
						align-items: center;
						border-radius: 6rpx;
						text-align: center;
						margin-left: 30rpx;
						padding: 5rpx 10rpx;
						background-color: rgb(49, 145, 253);
					}

					.red {
						padding: 5rpx  10rpx;
						background-color: #19a97c
					}
				}
			}

			.bottom {
				display: flex;
				margin-top: 20rpx;
				font-size: 28rpx;
				justify-content: space-between;
				color: #999999;
			}
		}


	}

	.addSite {
		position: absolute;
		display: flex;
		justify-content: center;
		align-content: center;
		width: 80%;
		line-height: 100rpx;
		position: absolute;
		bottom: 30rpx;
		background-color: #19a97c;
		border-radius: 60rpx;
		font-size: 30rpx;

		.add {
			display: flex;
			align-items: center;
			color: #ffffff;
		}
	}
}

.click-box {
	@include handleClick;
}
</style>