| @ -0,0 +1,188 @@ | |||||
| <template> | |||||
| <uv-popup ref="popup" z-index="99999" :closeOnClickOverlay="false" | |||||
| :customStyle="{ backgroundColor: 'transparent' }"> | |||||
| <view class="privacyPopup"> | |||||
| <view class="icon"> | |||||
| <image src="@/static/image/PrivacyAgreementPoup/icon.png" mode="widthFix"></image> | |||||
| </view> | |||||
| <view class="title"> | |||||
| <view>协议与隐私政策</view> | |||||
| </view> | |||||
| <view class="content_pri"> | |||||
| <view class="text"> | |||||
| 请您务必审慎阅读、充分理解用户协议和隐私政策各条款,包括但不限于用户注意事项、用户行为规范以及为了向你提供服务而收集、使用、存储你个人信息的情况等。你可阅读<text | |||||
| class="blk" @tap="handleOpenPrivacyContract">《工程项目打卡平台用户服务协议》</text>和<text | |||||
| class="blk" @tap="handleOpenPrivacyContract">《工程项目打卡平台隐私权政策》</text>了解详细信息。如你同意,请点击下方按钮开始接受我们的服务。 | |||||
| </view> | |||||
| </view> | |||||
| <!-- <view class="config"> | |||||
| <uv-checkbox-group v-model="checkboxValue" shape="circle"> | |||||
| <view class="content"> | |||||
| <view style="display: flex;"> | |||||
| <uv-checkbox size="30rpx" :name="1"></uv-checkbox> | |||||
| 同意<text @tap="handleOpenPrivacyContract">《工程项目打卡平台用户服务协议》</text> | |||||
| </view> | |||||
| <view class=""> | |||||
| 以及<text @tap="handleOpenPrivacyContract">《工程项目打卡平台隐私权政策》</text> | |||||
| </view> | |||||
| </view> | |||||
| </uv-checkbox-group> | |||||
| </view> --> | |||||
| <view class="pri_btn"> | |||||
| <button class="confuse_btn" @click="confusePrivacy">拒绝</button> | |||||
| <button class="confirm_btn" id="agree-btn" open-type="agreePrivacyAuthorization" | |||||
| @agreeprivacyauthorization="handleAgreePrivacyAuthorization">同意</button> | |||||
| </view> | |||||
| </view> | |||||
| </uv-popup> | |||||
| </template> | |||||
| <script> | |||||
| export default { | |||||
| name: 'PrivacyAgreementPoup', | |||||
| data() { | |||||
| return { | |||||
| resolvePrivacyAuthorization: {}, | |||||
| checkboxValue: false | |||||
| } | |||||
| }, | |||||
| mounted() { | |||||
| if (wx.getPrivacySetting) { | |||||
| wx.getPrivacySetting({ | |||||
| success: res => { | |||||
| // console.log(res) | |||||
| if (res.needAuthorization) { | |||||
| // 需要弹出隐私协议 | |||||
| this.init() | |||||
| } | |||||
| }, | |||||
| fail: () => {} | |||||
| }) | |||||
| } | |||||
| }, | |||||
| methods: { | |||||
| //初始化 | |||||
| init(resolve) { | |||||
| this.$refs.popup.open('center') | |||||
| this.resolvePrivacyAuthorization = resolve | |||||
| }, | |||||
| // 打开隐私协议 | |||||
| goToPrivacy() { | |||||
| wx.openPrivacyContract({ | |||||
| success: () => { | |||||
| console.log('打开成功'); | |||||
| }, // 打开成功 | |||||
| fail: () => { | |||||
| uni.showToast({ | |||||
| title: '打开失败,稍后重试', | |||||
| icon: 'none' | |||||
| }) | |||||
| } // 打开失败 | |||||
| }) | |||||
| }, | |||||
| // 拒绝 | |||||
| confusePrivacy() { | |||||
| this.$refs.popup.close() | |||||
| this.resolvePrivacyAuthorization({ | |||||
| event: 'disagree' | |||||
| }) | |||||
| }, | |||||
| // 同意 | |||||
| handleAgreePrivacyAuthorization() { | |||||
| // 告知平台用户已经同意,参数传同意按钮的id | |||||
| this.resolvePrivacyAuthorization({ | |||||
| buttonId: 'agree-btn', | |||||
| event: 'agree' | |||||
| }) | |||||
| this.$refs.popup.close() | |||||
| }, | |||||
| handleOpenPrivacyContract() { | |||||
| // 打开隐私协议页面 | |||||
| wx.openPrivacyContract({ | |||||
| success: () => {}, // 打开成功 | |||||
| fail: () => {}, // 打开失败 | |||||
| complete: () => {} | |||||
| }) | |||||
| } | |||||
| } | |||||
| } | |||||
| </script> | |||||
| <style lang="scss" scoped> | |||||
| .privacyPopup { | |||||
| width: 90%; | |||||
| margin: 0rpx auto; | |||||
| background: white; | |||||
| border-radius: 20rpx; | |||||
| box-sizing: border-box; | |||||
| padding: 40rpx 30rpx; | |||||
| .icon { | |||||
| display: flex; | |||||
| justify-content: center; | |||||
| image { | |||||
| width: 100rpx; | |||||
| } | |||||
| } | |||||
| .title { | |||||
| text-align: center; | |||||
| font-size: 36rpx; | |||||
| margin: 30rpx 0rpx; | |||||
| } | |||||
| .content_pri { | |||||
| margin-bottom: 30rpx; | |||||
| font-size: 28rpx; | |||||
| color: #707070; | |||||
| .text { | |||||
| .blk { | |||||
| color: black; | |||||
| } | |||||
| } | |||||
| } | |||||
| .config { | |||||
| font-size: 28rpx; | |||||
| text-align: center; | |||||
| line-height: 40rpx; | |||||
| margin-bottom: 30rpx; | |||||
| text { | |||||
| color: #00aaff; | |||||
| } | |||||
| .content { | |||||
| display: flex; | |||||
| } | |||||
| } | |||||
| .pri_btn { | |||||
| display: flex; | |||||
| justify-content: space-around; | |||||
| flex-wrap: wrap; | |||||
| button { | |||||
| width: 40%; | |||||
| padding: 5rpx 0rpx; | |||||
| // background: $main-color; | |||||
| outline: none; | |||||
| color: white; | |||||
| font-size: 30rpx; | |||||
| &:nth-child(1){ | |||||
| background: #F2F2F2; | |||||
| color: #707070; | |||||
| } | |||||
| } | |||||
| } | |||||
| } | |||||
| </style> | |||||
| @ -0,0 +1,347 @@ | |||||
| <template> | |||||
| <view class="refundsOrExchange"> | |||||
| <navbar :title="titleList[titleIndex]" leftClick @leftClick="$utils.navigateBack" /> | |||||
| <view class="frame"> | |||||
| <!-- 登录和注册 --> | |||||
| <view class="loginRegister" v-if='titleIndex!=2'> | |||||
| <!-- 标题 --> | |||||
| <view class="title">{{titleList[titleIndex]}}</view> | |||||
| <!-- 头像 --> | |||||
| <view class="userIamge"> | |||||
| <view> | |||||
| <img src="/static/image/center/11.svg" alt="" style="width: 100%;height: 100%;"> | |||||
| </view> | |||||
| </view> | |||||
| <!-- 用户名&密码&隐私条款 --> | |||||
| <view class="form"> | |||||
| <view> | |||||
| <uv-input v-model="form.account" placeholder="请输入账号" border="surround" shape='circle' | |||||
| clearable :customStyle="{ backgroundColor: '#f6f6f6'}"></uv-input> | |||||
| </view> | |||||
| <view> | |||||
| <uv-input v-model="form.password" password placeholder="请输入密码" border="surround" shape='circle' | |||||
| clearable :customStyle="{ backgroundColor: '#f6f6f6'}"></uv-input> | |||||
| </view> | |||||
| <view> | |||||
| <uv-checkbox-group v-model="checkboxValue" shape="circle"> | |||||
| <view class="content"> | |||||
| <view style="display: flex;flex-wrap: wrap;"> | |||||
| <uv-checkbox size="30rpx" :name="1"></uv-checkbox> | |||||
| 请你阅读并同意我们的<span style="color: #fd5100" | |||||
| @click="$refs.popup.open('getPrivacyPolicy')">《隐私条款》</span>和<span | |||||
| style="color: #fd5100" | |||||
| @click="$refs.popup.open('getUserAgreement')">《服务协议》</span> | |||||
| </view> | |||||
| </view> | |||||
| </uv-checkbox-group> | |||||
| </view> | |||||
| </view> | |||||
| </view> | |||||
| <!-- 忘记密码 --> | |||||
| <view class='forgetPassword' v-if='titleIndex==2'> | |||||
| <!-- 标题 --> | |||||
| <view class="title">{{titleList[titleIndex]}}</view> | |||||
| <!-- 表单 --> | |||||
| <view class="form1"> | |||||
| <view class="userName"> | |||||
| <uv-input v-model="form1.userName" placeholder="请输入手机号/用户/邮箱" border="surround" shape='circle' | |||||
| clearable :customStyle="{ backgroundColor: '#f6f6f6'}"></uv-input> | |||||
| </view> | |||||
| <view class="code"> | |||||
| <view class="left"> | |||||
| <uv-input v-model="form1.code" placeholder="请输入验证码" border="surround" shape='circle' | |||||
| clearable :customStyle="{ backgroundColor: '#f6f6f6'}"></uv-input> | |||||
| </view> | |||||
| <view class="right"> | |||||
| <view> | |||||
| <uv-toast ref="toast"></uv-toast> | |||||
| <uv-code :seconds="seconds" @end="end" @start="start" ref="code" | |||||
| @change="codeChange"></uv-code> | |||||
| <uv-button @tap="getCode" iconSize='10rpx' color='#fd5100' | |||||
| shape='circle'>{{tips}}</uv-button> | |||||
| </view> | |||||
| </view> | |||||
| </view> | |||||
| <view class="password1"> | |||||
| <uv-input v-model="form1.password1" placeholder="设置您的新密码(6到50个字符)" password clearable | |||||
| border="surround" shape='circle' :customStyle="{ backgroundColor: '#f6f6f6'}"></uv-input> | |||||
| </view> | |||||
| <view class="password2"> | |||||
| <uv-input v-model="form1.password2" placeholder="重新确认密码" password clearable border="surround" | |||||
| shape='circle' :customStyle="{ backgroundColor: '#f6f6f6'}"></uv-input> | |||||
| </view> | |||||
| </view> | |||||
| </view> | |||||
| <!-- 按钮 --> | |||||
| <view class="btn" | |||||
| @click="submit"> | |||||
| <button class='a'>{{titleList[titleIndex]}}</button> | |||||
| </view> | |||||
| <!-- tab --> | |||||
| <!-- <view class="bottomTab"> | |||||
| <span :class="titleIndex==0 ? 'tabbarItemActive' : 'tabbarItemNoActive'" | |||||
| @click='changePage(0)'>注册账号</span> | |||||
| <span style="color: #9c9fa4">|</span> | |||||
| <span :class="titleIndex==1 ? 'tabbarItemActive' : 'tabbarItemNoActive'" | |||||
| @click='changePage(1)'>账号登录</span> | |||||
| <span style="color: #9c9fa4">|</span> | |||||
| <span :class="titleIndex==2 ? 'tabbarItemActive' : 'tabbarItemNoActive'" | |||||
| @click='changePage(2)'>忘记密码</span> | |||||
| </view> --> | |||||
| </view> | |||||
| <configPopup ref="popup"></configPopup> | |||||
| </view> | |||||
| </template> | |||||
| <script> | |||||
| import configPopup from '@/components/config/configPopup.vue'; | |||||
| export default { | |||||
| components: { | |||||
| configPopup | |||||
| }, | |||||
| onLoad(option) { | |||||
| this.titleIndex = option.index || 1 | |||||
| }, | |||||
| data() { | |||||
| return { | |||||
| titleIndex: 0, | |||||
| titleList: ['注册', '登录', '重置密码'], | |||||
| checkboxValue: [], | |||||
| form: { | |||||
| account: '13135294009', | |||||
| password: 'lzx123456', | |||||
| }, | |||||
| form1: { | |||||
| userName: '', | |||||
| code: '', | |||||
| password1: '', | |||||
| password2: '', | |||||
| }, | |||||
| tips: '获取验证码', | |||||
| seconds: 60, | |||||
| } | |||||
| }, | |||||
| methods: { | |||||
| submit(){ | |||||
| if(!this.checkboxValue.length){ | |||||
| return uni.showToast({ | |||||
| title: '请先同意隐私协议', | |||||
| icon:'none' | |||||
| }) | |||||
| } | |||||
| if(this.$utils.verificationAll(this.form, { | |||||
| account: '请输入账号', | |||||
| password: '请输入密码', | |||||
| })){ | |||||
| return | |||||
| } | |||||
| this.$store.commit('accountLogin', this.form) | |||||
| }, | |||||
| // 切换页面 | |||||
| changePage(index) { | |||||
| this.titleIndex = index | |||||
| }, | |||||
| confirm() { | |||||
| }, | |||||
| codeChange(text) { | |||||
| this.tips = text; | |||||
| }, | |||||
| getCode() { | |||||
| if (this.$refs.code.canGetCode) { | |||||
| // 模拟向后端请求验证码 | |||||
| uni.showLoading({ | |||||
| title: '正在获取验证码' | |||||
| }) | |||||
| setTimeout(() => { | |||||
| uni.hideLoading(); | |||||
| // 这里此提示会被this.start()方法中的提示覆盖 | |||||
| uni.$uv.toast('验证码已发送'); | |||||
| // 通知验证码组件内部开始倒计时 | |||||
| this.$refs.code.start(); | |||||
| }, 2000); | |||||
| } else { | |||||
| uni.$uv.toast('请勿重复发送'); | |||||
| } | |||||
| }, | |||||
| end() { | |||||
| // uni.$uv.toast('倒计时结束'); | |||||
| }, | |||||
| start() { | |||||
| // uni.$uv.toast('倒计时开始'); | |||||
| } | |||||
| } | |||||
| } | |||||
| </script> | |||||
| <style lang="scss" scoped> | |||||
| * { | |||||
| box-sizing: border-box; | |||||
| } | |||||
| .refundsOrExchange { | |||||
| background-color: #FFF; | |||||
| height: 100vh; | |||||
| .frame { | |||||
| background-color: #FFF; | |||||
| .loginRegister { | |||||
| display: flex; | |||||
| flex-direction: column; | |||||
| gap: 40rpx; | |||||
| .title { | |||||
| display: flex; | |||||
| justify-content: center; | |||||
| align-items: flex-end; | |||||
| height: 10vh; | |||||
| color: #000; | |||||
| font-size: 40rpx; | |||||
| font-weight: 700; | |||||
| } | |||||
| .userIamge { | |||||
| display: flex; | |||||
| justify-content: center; | |||||
| height: 10vh; | |||||
| >view:nth-of-type(1) { | |||||
| width: 25%; | |||||
| height: 100%; | |||||
| border-radius: 50%; | |||||
| overflow: hidden; | |||||
| } | |||||
| } | |||||
| .form { | |||||
| line-height: 50rpx; | |||||
| >view:nth-of-type(1) { | |||||
| padding: 20rpx 100rpx; | |||||
| } | |||||
| >view:nth-of-type(2) { | |||||
| padding: 0 100rpx; | |||||
| } | |||||
| >view:nth-of-type(3) { | |||||
| display: flex; | |||||
| padding: 30rpx 100rpx 0 100rpx; | |||||
| font-size: 22rpx | |||||
| } | |||||
| } | |||||
| } | |||||
| .btn { | |||||
| // height: 5vh; | |||||
| display: flex; | |||||
| justify-content: center; | |||||
| margin: 90rpx 0 0 0; | |||||
| .a { | |||||
| display: flex; | |||||
| justify-content: center; | |||||
| align-items: center; | |||||
| width: 70%; | |||||
| height: 80rpx; | |||||
| color: #FFF; | |||||
| background-color: $uni-color; | |||||
| border: 1px solid red; | |||||
| border-radius: 100rpx; | |||||
| font-size: 30rpx; | |||||
| } | |||||
| } | |||||
| .bottomTab { | |||||
| display: flex; | |||||
| justify-content: space-between; | |||||
| height: 10vh; | |||||
| padding: 0 80rpx; | |||||
| margin-top: 30rpx; | |||||
| .tabbarItemActive { | |||||
| color: $uni-color; | |||||
| } | |||||
| .tabbarItemNoActive { | |||||
| color: #9c9fa4; | |||||
| } | |||||
| } | |||||
| .forgetPassword { | |||||
| padding: 100rpx 40rpx 0 40rpx; | |||||
| .title { | |||||
| display: flex; | |||||
| justify-content: center; | |||||
| align-items: flex-end; | |||||
| height: 10vh; | |||||
| color: #000; | |||||
| font-size: 40rpx; | |||||
| font-weight: 700; | |||||
| } | |||||
| .form1 { | |||||
| display: flex; | |||||
| flex-direction: column; | |||||
| gap: 30rpx; | |||||
| margin-top: 20rpx; | |||||
| padding: 20rpx 80rpx; | |||||
| .userName { | |||||
| // padding: 20rpx 100 rpx; | |||||
| } | |||||
| .code { | |||||
| display: flex; | |||||
| width: 100%; | |||||
| .left { | |||||
| width: 55%; | |||||
| } | |||||
| .right { | |||||
| width: 45%; | |||||
| height: 100%; | |||||
| >view:nth-of-type(1) { | |||||
| display: flex; | |||||
| justify-content: center; | |||||
| align-items: center; | |||||
| width: 100%; | |||||
| } | |||||
| } | |||||
| } | |||||
| .password1 {} | |||||
| .password2 {} | |||||
| } | |||||
| } | |||||
| } | |||||
| } | |||||
| </style> | |||||
| @ -0,0 +1,118 @@ | |||||
| <template> | |||||
| <div class="login"> | |||||
| <!-- logo --> | |||||
| <div class="logo"> | |||||
| <image src="@/static/image/logo-img.jpg" mode=""></image> | |||||
| </div> | |||||
| <!-- 标题 --> | |||||
| <view class="login-title">vtrip</view> | |||||
| <!-- 登录按钮 --> | |||||
| <view @click="login" class="login-btn"> | |||||
| <uni-icons type="weixin" size="30" color="#fff"></uni-icons> | |||||
| <text class="wx">微信登录</text> | |||||
| </view> | |||||
| <!-- 隐私政策 --> | |||||
| <view class="privacy"> | |||||
| <uv-radio-group> | |||||
| <uv-checkbox-group v-model="consent"> | |||||
| <uv-checkbox :size="30" shape="circle" active-color="#05C160" :name="privacy"></uv-checkbox> | |||||
| </uv-checkbox-group> | |||||
| 已同意<text class="privacy-title">《隐私政策》</text> | |||||
| <text class="privacy-title">《服务条款》</text> | |||||
| </uv-radio-group> | |||||
| </view> | |||||
| <!-- 隐私政策弹框 --> | |||||
| <PrivacyAgreementPoup></PrivacyAgreementPoup> | |||||
| </div> | |||||
| </template> | |||||
| <script> | |||||
| import PrivacyAgreementPoup from '@/components/PrivacyAgreementPoup/PrivacyAgreementPoup.vue' | |||||
| export default { | |||||
| name : "wxLogin", | |||||
| components : { PrivacyAgreementPoup }, | |||||
| data() { | |||||
| return { | |||||
| consent : [] | |||||
| } | |||||
| }, | |||||
| methods: { | |||||
| login() { | |||||
| if(this.consent.length <= 0){ | |||||
| return uni.showToast({ | |||||
| icon: "none", | |||||
| title: "请勾选隐私协议" | |||||
| }) | |||||
| } | |||||
| this.$store.commit('login') | |||||
| } | |||||
| } | |||||
| } | |||||
| </script> | |||||
| <style lang="scss" scoped> | |||||
| .login { | |||||
| display: flex; | |||||
| flex-direction: column; | |||||
| justify-content: center; | |||||
| align-items: center; | |||||
| min-height: 100vh; | |||||
| background: white; | |||||
| // logo | |||||
| .logo { | |||||
| display: flex; | |||||
| align-items: center; | |||||
| justify-content: center; | |||||
| image { | |||||
| width: 200rpx; | |||||
| height: 200rpx; | |||||
| border-radius: 20rpx; | |||||
| } | |||||
| } | |||||
| // 标题 | |||||
| .login-title { | |||||
| font-size: 40rpx; | |||||
| font-weight: bold; | |||||
| margin: 20rpx 0rpx; | |||||
| } | |||||
| //登录按钮 | |||||
| .login-btn { | |||||
| display: flex; | |||||
| justify-content: center; | |||||
| align-items: center; | |||||
| width: 70%; | |||||
| background: #05C160; | |||||
| height: 90rpx; | |||||
| border-radius: 45rpx; | |||||
| color: white; | |||||
| margin-top: 200rpx; | |||||
| .wx { | |||||
| margin-left: 10rpx; | |||||
| } | |||||
| } | |||||
| //隐私政策 | |||||
| .privacy { | |||||
| display: flex; | |||||
| align-items: center; | |||||
| margin-top: 20rpx; | |||||
| &::v-deep .uv-checkbox-group { | |||||
| align-items: center !important; | |||||
| justify-content: center !important; | |||||
| flex-wrap : nowrap !important; | |||||
| } | |||||
| .privacy-title { | |||||
| color: #05C160; | |||||
| } | |||||
| } | |||||
| } | |||||
| </style> | |||||
| @ -0,0 +1,214 @@ | |||||
| <template> | |||||
| <view class="login"> | |||||
| <view class="logo"> | |||||
| <image src="@/static/image/logo-img.jpg" mode=""></image> | |||||
| </view> | |||||
| <view class="title"> | |||||
| vtrip | |||||
| </view> | |||||
| <view class="title"> | |||||
| 申请获取你的头像、昵称 | |||||
| </view> | |||||
| <button class="chooseAvatar" open-type="chooseAvatar" @chooseavatar="onChooseAvatar"> | |||||
| <view class="line"> | |||||
| <view class=""> | |||||
| 头像 | |||||
| </view> | |||||
| <view class=""> | |||||
| <image :src="userInfoForm.headImage" v-if="userInfoForm.headImage" style="width: 60rpx;height: 60rpx;" | |||||
| mode=""></image> | |||||
| <image src="../static/auth/headImage.png" v-else style="width: 50rpx;height: 50rpx;" mode=""></image> | |||||
| </view> | |||||
| </view> | |||||
| </button> | |||||
| <view class="line"> | |||||
| <view class=""> | |||||
| 昵称 | |||||
| </view> | |||||
| <view class=""> | |||||
| <input type="nickname" placeholder="请输入昵称" style="text-align: right;" id="nickName" | |||||
| v-model="userInfoForm.nickName" /> | |||||
| </view> | |||||
| </view> | |||||
| <view class="line"> | |||||
| <view class=""> | |||||
| 手机号 | |||||
| </view> | |||||
| <view class="" | |||||
| v-if="userInfoForm.phone"> | |||||
| <input placeholder="请输入手机号" style="text-align: right;" | |||||
| disabled | |||||
| v-model="userInfoForm.phone" /> | |||||
| </view> | |||||
| <view class="" | |||||
| v-else> | |||||
| <button | |||||
| class="getPhoneNumber" | |||||
| open-type="getPhoneNumber" | |||||
| @getphonenumber="getPhone"> | |||||
| 获取电话号码 | |||||
| </button> | |||||
| </view> | |||||
| </view> | |||||
| <view class="btn" @click="submit"> | |||||
| 确认 | |||||
| </view> | |||||
| </view> | |||||
| </template> | |||||
| <script> | |||||
| export default { | |||||
| data() { | |||||
| return { | |||||
| userInfoForm: { | |||||
| headImage: '', | |||||
| nickName: '', | |||||
| phone : '', | |||||
| } | |||||
| }; | |||||
| }, | |||||
| onShow() {}, | |||||
| onLoad() { | |||||
| this.userInfoForm.phone = this.userInfo.phone || '' | |||||
| this.userInfoForm.nickName = this.userInfo.nickName || '' | |||||
| this.userInfoForm.headImage = this.userInfo.headImage || '' | |||||
| }, | |||||
| computed: {}, | |||||
| methods: { | |||||
| onChooseAvatar(res) { | |||||
| let self = this | |||||
| self.$Oss.ossUpload(res.target.avatarUrl) | |||||
| .then(url => { | |||||
| self.userInfoForm.headImage = url | |||||
| }) | |||||
| }, | |||||
| getPhone(e){ | |||||
| console.log(e,'e') | |||||
| this.$api('bindPhone', { | |||||
| phoneCode : e.detail.code | |||||
| }, res => { | |||||
| if(res.code == 200){ | |||||
| let phoneObj = JSON.parse(res.result) | |||||
| if(phoneObj.errmsg == 'ok'){ | |||||
| this.userInfoForm.phone = phoneObj.phone_info.phoneNumber | |||||
| }else{ | |||||
| uni.showModal({ | |||||
| title: phoneObj.errmsg | |||||
| }) | |||||
| } | |||||
| console.log(phoneObj); | |||||
| } | |||||
| }) | |||||
| }, | |||||
| submit() { | |||||
| let self = this | |||||
| uni.createSelectorQuery().in(this) | |||||
| .select("#nickName") | |||||
| .fields({ | |||||
| properties: ["value"], | |||||
| }) | |||||
| .exec((res) => { | |||||
| const nickName = res?.[0]?.value | |||||
| self.userInfoForm.nickName = nickName | |||||
| if (self.$utils.verificationAll(self.userInfoForm, { | |||||
| headImage: '请选择头像', | |||||
| nickName: '请填写昵称', | |||||
| phone: '请填写昵称', | |||||
| })) { | |||||
| return | |||||
| } | |||||
| self.$api('updateInfo', { | |||||
| avatarUrl : self.userInfoForm.headImage, | |||||
| nickName : self.userInfoForm.nickName, | |||||
| phone : self.userInfoForm.phone, | |||||
| }, res => { | |||||
| if (res.code == 200) { | |||||
| this.$store.commit('getUserInfo') | |||||
| uni.reLaunch({ | |||||
| url:'/pages/index/index' | |||||
| }) | |||||
| } | |||||
| }) | |||||
| }) | |||||
| }, | |||||
| } | |||||
| } | |||||
| </script> | |||||
| <style lang="scss" scoped> | |||||
| .login { | |||||
| display: flex; | |||||
| flex-direction: column; | |||||
| justify-content: center; | |||||
| align-items: center; | |||||
| height: 100vh; | |||||
| background-color: #fff; | |||||
| .logo{ | |||||
| height: 140rpx; | |||||
| width: 140rpx; | |||||
| image{ | |||||
| height: 140rpx; | |||||
| width: 140rpx; | |||||
| border-radius: 30rpx; | |||||
| } | |||||
| margin-bottom: 20rpx; | |||||
| } | |||||
| .title { | |||||
| line-height: 45rpx; | |||||
| font-weight: 900; | |||||
| } | |||||
| .line { | |||||
| display: flex; | |||||
| justify-content: space-between; | |||||
| align-items: center; | |||||
| width: 80%; | |||||
| border-bottom: 1px solid #00000023; | |||||
| padding: 30rpx 0; | |||||
| margin: 0 auto; | |||||
| } | |||||
| .chooseAvatar { | |||||
| width: 100%; | |||||
| padding: 0; | |||||
| margin: 0; | |||||
| margin-top: 10vh; | |||||
| border: none; | |||||
| } | |||||
| .btn { | |||||
| // background: $uni-linear-gradient-btn-color; | |||||
| background: $uni-color; | |||||
| color: #fff; | |||||
| width: 80%; | |||||
| padding: 20rpx 0; | |||||
| text-align: center; | |||||
| border-radius: 15rpx; | |||||
| margin-top: 10vh; | |||||
| } | |||||
| .getPhoneNumber{ | |||||
| all: unset; | |||||
| display: flex; | |||||
| justify-content: center; | |||||
| align-items: center; | |||||
| // background: $uni-linear-gradient-btn-color; | |||||
| background: $uni-color; | |||||
| color: #fff; | |||||
| width: 200rpx; | |||||
| height: 60rpx; | |||||
| border-radius: 30rpx; | |||||
| font-size: 24rpx; | |||||
| } | |||||
| } | |||||
| </style> | |||||