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.

161 lines
3.7 KiB

9 months ago
<template>
<view class="address">
<view class="address-type">用户信息</view>
<view
class="address-item ss-flex ss-row-between ss-col-center"
:class="[{ 'border-bottom': props.hasBorderBottom }]"
>
<view class="item-left">
<view class="person-text">自取时间</view>
<view class="area-text ss-flex ss-col-center">
<uni-datetime-picker v-model="state.zititime" type="daterange" @change="onChangeTime" :end="state.today">
<button class="ss-reset-button date-btn">
<text>{{ !dateFilterText || dateFilterText.length === 0 ? '请选择自取时间' : dateFilterText }}</text>
<text class="cicon-drop-down ss-seldate-icon"></text>
</button>
</uni-datetime-picker>
</view>
</view>
<view class="item-right">
<view class="item-right-label">预留电话</view>
<view class="item-right-value">
<uni-easyinput
placeholder="请输入预留电话"
v-model="state.mobile"
:inputBorder="false"
type="text">
</uni-easyinput>
</view>
</view>
</view>
</view>
</template>
<script setup>
import { onLoad } from '@dcloudio/uni-app';
import dayjs from 'dayjs';
import { computed, reactive } from 'vue';
import sheep from '@/sheep';
import { isEmpty } from 'lodash';
const userInfo = computed(() => sheep.$store('user').userInfo);
const dateFilterText = computed(() => {
if (state.zititime[0] === state.zititime[1]) {
return state.zititime[0];
} else {
return state.zititime.join('~');
}
});
const props = defineProps({
hasBorderBottom: {
type: Boolean,
defult: true,
},
});
const state = reactive({
zititime: [],
today: '',
mobile: '',
});
function onChangeTime(e) {
console.log(e, 'onChangeTime');
state.zititime[0] = e[0];
state.zititime[1] = e[e.length - 1];
}
onLoad(async (options) => {
state.today = dayjs().format('YYYY-MM-DD');
state.zititime = [state.today, state.today];
state.mobile = userInfo.mobile;
});
</script>
<style lang="scss" scoped>
.address {
border-top: 10rpx solid #f2f2f2;
padding: 39rpx 0 0;
}
.address-type {
padding-left: 30rpx;
font-size: 26rpx;
font-weight: bold;
color: #333333;
}
.address-item {
padding: 24rpx 30rpx;
font-size: 24rpx;
.item-left, .item-right {
flex: 1;
}
.area-text {
font-weight: 400;
color: $dark-9;
font-size: 24rpx;
color: #000000;
margin-top: 10rpx;
}
.address-text {
font-size: 32rpx;
font-weight: 500;
color: #333333;
line-height: 48rpx;
}
.person-text {
display: flex;
align-items: center;
font-size: 26rpx;
color: #000000;
.name {
font-weight: 500;
}
.phone {
font-weight: 400;
display: inline-block;
margin-left: 15rpx;
margin-right: 10rpx;
}
.default-address {
display: inline-block;
padding: 3rpx 20rpx;
text-align: center;
background: var(--ui-BG-Main);
border-radius: 14rpx 14rpx 14rpx 14rpx;
font-weight: 400;
font-size: 18rpx;
color: #FFFFFF;
}
}
}
.edit-btn {
width: 46rpx;
height: 46rpx;
.edit-icon {
width: 46rpx;
height: 46rpx;
}
}
image {
width: 100%;
height: 100%;
}
.date-btn {
background-color: $white;
line-height: 54rpx;
border-radius: 27rpx;
font-size: 24rpx;
font-weight: 500;
color: $dark-6;
.ss-seldate-icon {
font-size: 50rpx;
color: $dark-9;
}
}
</style>