123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236 |
- const { isMobile } = require('../../utils/validate')
- const { sendCode, miniPhoneLogin, miniLogin } = require('../../api/common')
- const { login, sessionStorageKey } = require('../../api/request')
- const app = getApp()
- Page({
- /**
- * 页面的初始数据
- */
- data: {
- form: {
- cellphone: '',
- code: ''
- },
- numCount: 60,
- checked: false,
- booLock: false
- },
- timer: null,
- wxCode: '',
- /**
- * 生命周期函数--监听页面加载
- */
- onLoad(options) {
- this.getWxCode()
- },
- /**
- * 生命周期函数--监听页面初次渲染完成
- */
- onReady() {
- },
- /**
- * 生命周期函数--监听页面显示
- */
- onShow() {
- },
- /**
- * 生命周期函数--监听页面隐藏
- */
- onHide() {
- },
- /**
- * 生命周期函数--监听页面卸载
- */
- onUnload() {
- clearInterval(this.timer)
- },
- bindTip() {
- wx.showToast({
- title: '请阅读并勾选协议',
- icon: 'none'
- })
- },
- bindChange() {
- this.setData({
- checked: !(this.data.checked)
- })
- },
- mobileEventhandle(e) {
- const val = e.detail.value.replace(/[^\d]$/, '').replace(/^0/, '').replace(/(\d{11}(.*))/, '$1')
- this.setData({
- 'form.cellphone': val
- })
- return {
- value: val
- }
- },
- codeEventhandle(e) {
- const val = e.detail.value.replace(/[^\d]$/, '').replace(/(\d{6}(.*))/, '$1')
- this.setData({
- 'form.code': val
- })
- return {
- value: val
- }
- },
- funCutDown() {
- let numCount = this.data.numCount
- this.timer = setInterval(() => {
- if (numCount === 0) {
- clearInterval(this.timer)
- this.setData({
- numCount: 0
- })
- return
- }
- numCount--
- this.setData({
- numCount: numCount
- })
- }, 1000)
- },
- async funGetCode() {
- const numCount = this.data.numCount
- const { cellphone } = this.data.form
- if (!isMobile(cellphone)) {
- wx.showToast({
- title: '请输入正确的手机号~',
- icon: 'none'
- })
- return
- }
- if (numCount < 60 && numCount > 0) {
- return
- }
- this.setData({
- numCount: 60,
- code: ''
- })
- this.funCutDown()
- try {
- const { status } = await sendCode({ phone: cellphone, type: 1 })
- let title = '验证码发送成功'
- if (status) {
- } else {
- title = '验证码发送失败'
- }
- wx.showToast({
- title: title,
- icon: 'none'
- })
- } catch (err) {}
- },
- async bindEvent() {
- const { cellphone, code } = this.data.form
- if (!this.data.checked) {
- this.bindTip()
- return
- }
- this.setData({
- booLock: true
- })
- try {
- const { status, data } = await miniPhoneLogin({
- wxCode: this.wxCode,
- cellphone,
- code
- })
- if (status) {
- try {
- wx.setStorageSync(sessionStorageKey, data.token)
- } catch (err) {}
- await app.fetchUserData()
- const pages = getCurrentPages()
- if (pages.length > 1) {
- const route = pages[pages.length - 2]
- wx.navigateBack({
- delta: 1
- })
- route.bindCallBack && route.bindCallBack()
- }
- } else {
- wx.showToast({
- title: '登录出错了,请重试',
- icon: 'none'
- })
- this.getWxCode()
- }
- } catch (err) {
- this.getWxCode()
- }
- this.setData({
- booLock: false
- })
- },
- async getPhoneNumber(e) {
- const { errMsg, encryptedData, iv } = e.detail
- if (errMsg === 'getPhoneNumber:ok') {
- this.setData({
- booLock: true
- })
- try {
- const { status, data } = await miniLogin({
- wxCode: this.wxCode,
- encryptedData,
- iv
- })
- if (status) {
- try {
- wx.setStorageSync(sessionStorageKey, data.token)
- } catch (err) {}
- await app.fetchUserData()
- const pages = getCurrentPages()
- if (pages.length > 1) {
- const route = pages[pages.length - 2]
- wx.navigateBack({
- delta: 1
- })
- route.bindCallBack && route.bindCallBack()
- }
- } else {
- wx.showToast({
- title: '登录出错了,请重试',
- icon: 'none'
- })
- this.getWxCode()
- }
- } catch (e) {
- this.getWxCode()
- }
- this.setData({
- booLock: false
- })
- }
- },
- async getWxCode() {
- try {
- this.wxCode = await login()
- } catch (e) {}
- }
- })
|