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.

397 lines
9.3 KiB

4 years ago
<template>
<view class="index-box">
<view class="upload-img-box">
<view class="label-box">
<view class="label-l acea-row-nowrap row-middle">
<text class="label">工作照</text>
<text class="sm-word">请上传正面免冠半身照图像大小不超过200kb</text>
</view>
<view class="label-r acea-row row-middle">
<view class="img-box" @tap="chooseImage">
<image :src="form.imgPath == '' ? '../../static/default-headerimg.png' : form.imgPath " mode=""></image>
</view>
<!-- <text class="iconfont icon-jiantou"></text> -->
4 years ago
</view>
</view>
</view>
<view class="form-box">
<view class="form-item acea-row row-middle row-between">
<view class="label">姓名</view>
<view class="input-box acea-row row-middle">
<input type="text" v-model="form.realName" placeholder="请输入真实姓名" />
<!-- <text class="iconfont icon-jiantou"></text> -->
4 years ago
</view>
</view>
<view class="form-item acea-row row-middle row-between">
<view class="label">公司分区</view>
4 years ago
<view class="input-box acea-row row-middle">
<picker mode="selector" :range="region" @change="regionChange">
<view>{{region[0]}}</view>
</picker>
4 years ago
<text class="iconfont icon-jiantou"></text>
</view>
</view>
<view class="form-item acea-row row-middle row-between ">
<view class="label">性别</view>
<view class="input-box acea-row row-middle">
<radio-group @change="radioChange">
<label class="radio">
4 years ago
<radio value="0" color="#F99C10" :checked="form.gender == 0" /><text></text>
4 years ago
</label>
<label class="radio">
4 years ago
<radio value="1" color="#F99C10" :checked="form.gender == 1" /><text></text>
4 years ago
</label>
</radio-group>
</view>
</view>
<view class="form-item acea-row row-middle row-between">
<view class="label">手机号</view>
<view class="input-box acea-row row-middle">
<input type="text" v-model="form.phone" maxlength="11" @blur="editPhone(form.phone)" placeholder="请输入手机号" />
<button open-type="getPhoneNumber" @getphonenumber="getPhoneNumber" class="binding">
<text>一键授权手机号</text>
</button>
4 years ago
</view>
</view>
<view class="form-item acea-row row-middle row-between no-border">
<view class="label">验证码</view>
<view class="acea-row row-middle ">
<view class="input-box acea-row row-middle">
<input type="text" v-model="form.verifyCode" maxlength="6" placeholder="请输入短信验证码" />
</view>
<view class="countdown" :class="disabled ? 'default' : ''" @click="sendCode">
{{disabled ? second + '秒后重新发送' : '发送验证码'}}
</view>
</view>
</view>
</view>
<view class="submit-btn" @click="submitClick">{{userInfo.isPromoter == 1 ? '保存修改' : '保存'}}</view>
</view>
</template>
<script>
import { chooseImage } from "@/utils";
import { editSelfData , getVerificationCode } from "@/api/serverTeacher"
import { mapState, mapGetters, mapMutations, mapActions } from 'vuex'
export default{
computed: {
msg(){
return this.$store.state.msg
},
...mapGetters(['userInfo','isAuthorization'])
},
4 years ago
data(){
return {
disabled: false,
second: 60,
time:null,
form: {
imgPath:'',
realName:'',
code:'',
gender: 0,
phone: '',
verifyCode:''
},
region: ['请选择'],
4 years ago
}
},
onLoad(){
// if(!this.isAuthorization){
// uni.navigateTo({
// url: "/pages/authorization/index"
// })
// return
// }
4 years ago
if(this.userInfo.phone){
this.form.phone = this.userInfo.phone;
}
4 years ago
if(this.userInfo.isPromoter == 1){
let info = this.userInfo;
this.form.imgPath = info.workPhoto;
this.form.realName = info.realName;
this.form.gender = info.gender;
this.form.phone = info.phone;
}
},
methods:{
getPhoneNumber: function(e) {
let thit = this
// 判断一下这里是不是小程序 如果是小程序,走获取微信手机号进行绑定
if (e.mp.detail.errMsg == 'getPhoneNumber:ok') {
uni.showLoading({
title: '绑定中',
})
wxappBindingPhone({
encryptedData: e.mp.detail.encryptedData,
iv: e.mp.detail.iv,
}).then(res => {
// this.User();
if(res.success){
thit.$store.dispatch('userInfo', true)
uni.hideLoading()
uni.showToast({
title: res.msg,
icon: 'success',
duration: 2000,
})
} else{
uni.hideLoading()
uni.showModal({
title:'提示!',
content:'授权已过期,请重新授权后绑定手机号',
success:function(res){
if(res.confirm){
thit.$store.commit('logout')
}
},
})
}
})
} else {
uni.showToast({
title: '已拒绝授权',
icon: 'none',
duration: 2000,
})
}
},
4 years ago
sendCode(){
var reg=/^1[3456789]\d{9}$/;
if (this.form.phone === '') {
uni.showToast({
4 years ago
title: '手机号码不能为空',
icon: 'none',
duration:2000
4 years ago
});
return
} else if(!reg.test(this.form.phone)){
uni.showToast({
4 years ago
title: '请输入有效的手机号码',
icon: 'none'
4 years ago
});
return
} else{
getVerificationCode({phone:this.form.phone}).then((res)=>{
if(res.success){
uni.showToast({
title:'短信已发送!'
})
if(this.disabled == false){
clearInterval(this.timer)
this.disabled = true;
this.timer = setInterval(()=>{ //设置延迟执行
this.timeup()
},1000);
}
} else{
uni.showToast({
title:res.msg,
icon:'none'
})
}
})
}
},
timeup(){
this.second = this.second - 1;
if (this.second == 0) {
this.second = 60;
this.disabled = false
clearInterval(this.timer)
return;
}
},
chooseImage() {
chooseImage((img) => {
this.form.imgPath = img;
});
},
radioChange(e){
// console.log(e)
this.form.gender = e.detail.value
},
editPhone(phone){
if (phone === '') {
uni.showModal({
title: '手机号码不能为空',
type: 'none'
});
}
else {
if (phone !== '') {
var reg=/^1[3456789]\d{9}$/;
if(!reg.test(phone)){
uni.showModal({
title: '请输入有效的手机号码',
type: 'none'
});
}
}
}
},
submitClick(){
if(this.form.imgPath == ''){
uni.showModal({
title: '请上传工作照',
type: 'none'
});
return
} else if(this.form.realName == ''){
uni.showModal({
title: '请输入真实姓名',
type: 'none'
});
return
} else if(this.form.code == ''){
uni.showModal({
title: '请输入注册口令',
type: 'none'
});
return
} else if(this.form.phone == ''){
uni.showModal({
title: '请输入手机号',
type: 'none'
});
return
} else if(!(/^1[3456789]\d{9}$/.test(this.form.phone))){
uni.showModal({
title: '请输入正确手机号',
type: 'none'
});
return
} else if(this.form.verifyCode == ''){
uni.showModal({
title: '请输入手机短信验证码',
type: 'none'
});
return
}
editSelfData(this.form).then((res)=>{
if(res.success){
this.$store.dispatch("userInfo", true);
uni.showToast({
title: res.msg,
icon: "none",
duration: 2000,
});
setTimeout(()=>{
this.$yrouter.back();
},2000)
} else{
uni.showToast({
title:res.msg,
icon:'none',
duration:2000
})
}
})
},
}
}
</script>
<style lang="less" scoped>
4 years ago
.index-box{
width: 100%;
height: 100vh;
background-color: #fff;
padding: 0 30rpx;
font-size: 28rpx;
4 years ago
color: #222;
.upload-img-box{
width: 100%;
padding: 40rpx 0;
}
.label-box{
display: flex;
justify-content: space-between;
.label{
width: 110rpx;
}
.sm-word{
width: 270rpx;
font-size: 24rpx;
color: #999;
margin-left: 12rpx;
}
}
.label-r{
.img-box{
border-radius: 50px;
overflow: hidden;
image{
width: 116rpx;
height: 116rpx;
border-radius: 50px;
}
}
}
.iconfont{
color: #000;
margin-left: 12rpx;
transform: rotate(90deg);
4 years ago
}
.form-box{
.form-item{
padding: 30rpx 0;
border-bottom: 1px solid #ececec;
.input-box{
input{
text-align: right;
margin-right: 12rpx;
}
.radio{
margin-left: 20rpx;
}
}
}
.no-border{
border: none;
}
.countdown{
min-width: 140rpx;
height: 70rpx;
padding: 0 10rpx;
font-size: 24rpx;
background-color: #E2B35D;
color: #fff;
line-height: 70rpx;
text-align: center;
border-radius: 10rpx;
}
.default{
background: #999;
color: #fff;
}
}
.binding {
display: inline-block;
padding: 0 10rpx;
height: 70rpx;
background-color: #E2B35D;
font-size: 24rpx;
line-height: 70rpx;
color: #ffffff;
}
4 years ago
.submit-btn{
width: 646rpx;
height: 80rpx;
text-align: center;
line-height: 80rpx;
background: #F4C076;
border-radius: 44rpx;
color: #fff;
position: absolute;
bottom: 100rpx;
left: 50%;
margin-left: -320rpx;
}
}
</style>