2025-08-07 17:02:44 +08:00

197 lines
5.3 KiB
Vue

<template>
<view>
<u-popup
v-model="showPop"
mode="bottom"
border-radius="14"
:safe-area-inset-bottom="true"
:maskCloseAble="false"
>
<view class="popup-content">
<view class="popup-header">
<image class="logo" mode="heightFix" :src="logo"></image>
<text class="title">{{ title }}</text>
</view>
<view class="popup-tips">
建议使用您的微信头像和昵称,以便获得更好的体验
</view>
<view class="popup-form">
<form @submit="handleSubmit">
<u-form-item required label="头像" :labelWidth="120">
<button
class="select-avatar"
hover-class="none"
open-type="chooseAvatar"
@chooseavatar="onChooseAvatar"
>
<image
class="avatar"
:src="avatar"
v-if="avatar"
/>
<div class="select-btn" v-else>
<u-icon name="plus" :size="30" />
添加图片
</div>
</button>
</u-form-item>
<u-form-item required label="昵称" :labelWidth="120">
<input
style="height: 60rpx"
:value="userInfo.nickname"
name="nickname"
type="nickname"
placeholder="请输入昵称"
/>
</u-form-item>
<button
class="submit-btn bg-primary"
form-type="submit"
>
确定
</button>
<view class="close-btn" @tap="onClose">暂不登录</view>
</form>
</view>
</view>
</u-popup>
</view>
</template>
<script>
import { uploadFile } from "@/utils/tools";
export default {
name: "mplogin-popup",
props: {
logo: {
type: String,
required: true
},
value: {
type: Boolean,
required: true
},
title: {
type: String,
required: true
}
},
data() {
return {
avatar: "",
};
},
methods: {
onChooseAvatar(e) {
const avatarUrl = e.detail.avatarUrl;
if (!avatarUrl) {
return;
}
uni.showLoading({
title: "正在上传中...",
mask: true,
});
uploadFile(avatarUrl)
.then((res) => {
uni.hideLoading();
this.avatar = res.url;
})
.catch(() => {
uni.hideLoading();
this.$toast({
title: "上传失败",
});
});
},
handleSubmit(e) {
const { nickname } = e.detail.value
const {avatar} = this
if(!avatar) return this.$toast({
title: '请添加头像'
})
if(!nickname) return this.$toast({
title: '请输入昵称'
})
this.$emit('update', {
avatar,
nickname
})
},
onClose() {
this.showPop = false
this.$emit('close')
}
},
computed: {
showPop: {
get() {
return this.value
},
set(val) {
this.$emit('input', val)
}
}
}
};
</script>
<style lang="scss">
.popup-content {
padding: 40rpx 40rpx 80rpx;
.popup-header {
display: flex;
align-items: center;
.title {
font-size: 38rpx;
font-weight: bold;
}
.logo {
flex: none;
height: 80rpx;
margin-right: 20rpx;
border-radius: 4rpx;
}
}
.popup-tips {
color: #999;
margin-top: 40rpx;
}
.popup-form {
margin-top: 55rpx;
.select-avatar {
width: 120rpx;
height: 120rpx;
color: #999;
.avatar {
width: 100%;
height: 100%;
}
.select-btn {
width: 100%;
height: 100%;
display: flex;
align-items: center;
justify-content: center;
flex-direction: column;
border: 1px dotted #ccc;
font-size: 22rpx;
border-radius: 4rpx;
}
}
.submit-btn {
height: 82rpx;
line-height: 82rpx;
border-radius: 41px;
color: #fff;
font-size: 30rpx;
margin: 80rpx 35rpx 60rpx;
}
.close-btn {
color: #999;
font-size: 30rpx;
text-align: center;
}
}
}
</style>