index.js 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. import {
  2. imgServerUrl
  3. } from '../../config/config.js'
  4. import $wuxCountDown from '../../utils/coutdown.js'
  5. import {
  6. sendPhoneCode
  7. } from '../../services/index.js'
  8. import {
  9. saveMinaPhone
  10. } from '../../services/wx.js'
  11. import {
  12. showToast
  13. } from '../../utils/tips.js'
  14. import { testPhone } from '../../utils/util'
  15. Page({
  16. /**
  17. * 页面的初始数据
  18. */
  19. data: {
  20. imgServerUrl: imgServerUrl,
  21. iphone: '',
  22. yzm: "",
  23. disabled: false,
  24. title: '绑定手机号码'
  25. },
  26. /**
  27. * 生命周期函数--监听页面加载
  28. */
  29. onLoad: function (options) {
  30. },
  31. // 清除输入
  32. clear() {
  33. this.setData({
  34. iphone: ''
  35. })
  36. },
  37. // 手机号输入
  38. bindPhoneInput(e) {
  39. this.setData({
  40. iphone: e.detail.value,
  41. disabled: testPhone(e.detail.value)
  42. })
  43. },
  44. // 导航至验证码页面
  45. toSend(e) {
  46. wx.navigateTo({
  47. url: `/pages/bind-phone/bind?phone=${e.detail.phone}`,
  48. })
  49. },
  50. // 验证码号输入
  51. bindYzmInput(e) {
  52. this.setData({
  53. yzm: e.detail.value
  54. })
  55. },
  56. // 验证码发送
  57. sendCode(e) {
  58. if (this.data.iphone.length != 11) {
  59. showToast('请输入11位手机号码!')
  60. return
  61. }
  62. if (this.data.djs && this.data.djs != '获取验证码') {
  63. return false;
  64. }
  65. sendPhoneCode({
  66. phone: this.data.iphone
  67. }).then(data => {
  68. })
  69. this.vcode()
  70. },
  71. //倒计时
  72. vcode() {
  73. if (this.djs && this.djs.interval) return !1
  74. this.djs = new $wuxCountDown({
  75. date: +(new Date) + 60000,
  76. onEnd() {
  77. this.setData({
  78. djs: '获取验证码',
  79. })
  80. },
  81. render(date) {
  82. const sec = this.leadingZeros(date.sec, 2) + ' 秒 '
  83. date.sec !== 0 && this.setData({
  84. djs: '剩余' + sec + '',
  85. })
  86. },
  87. })
  88. },
  89. //绑定手机号
  90. phone_login() {
  91. var self = this;
  92. if (self.data.iphone.length != 11) {
  93. return false;
  94. }
  95. if (self.data.yzm.length != 6) {
  96. return false;
  97. }
  98. if (!self.data.disabled) {
  99. self.setData({
  100. disabled: true
  101. })
  102. var openId = wx.getStorageSync('openId');
  103. var sessionKey = wx.getStorageSync('sessionKey');
  104. var unionId = wx.getStorageSync('unionId');
  105. let paramsObj = {
  106. phone: self.data.iphone,
  107. code: self.data.yzm,
  108. openId: openId,
  109. unionId: unionId,
  110. sessionKey: sessionKey
  111. }
  112. Object.assign(paramsObj);
  113. saveMinaPhone(paramsObj).then(data => {
  114. wx.setStorageSync("hpuser", data.data.hpUser);
  115. wx.setStorageSync("hpMember", data.data.hpMember);
  116. wx.setStorageSync("user_id", data.data.hpUser.id);
  117. wx.setStorageSync("member_id", data.data.hpMember.id);
  118. wx.setStorageSync("user_token", data.data.hpUser.userToken);
  119. wx.setStorageSync("phone", data.data.hpUser.phone);
  120. showToast("登录成功");
  121. setTimeout(function () {
  122. wx.navigateBack();
  123. }, 500)
  124. })
  125. }
  126. setTimeout(function () {
  127. self.setData({
  128. disabled: false
  129. })
  130. }, 1000)
  131. },
  132. })