store.js 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. import Vue from 'vue' //引入 Vue
  2. import Vuex from 'vuex' //引入 Vuex
  3. import ajax from './common/js/ajax.js' //引入封装好的 request 方法
  4. import { //引入 api
  5. api_onLaunch
  6. } from './api.js'
  7. Vue.use(Vuex) //套路
  8. const store = new Vuex.Store({
  9. state: { //状态
  10. N401: 0,
  11. gotLocation: false,
  12. id: uni.getStorageSync('id'),
  13. openid: uni.getStorageSync('openid'),
  14. networkType: '', //网络状态信息
  15. userWeixinInfo: {}, //用户微信信息,包括微信名,微信头像等
  16. userServerInfo: {}, //用户服务器信息,包括 token,用户名,等级等
  17. showVerify: false, //是否显示手机短信验证弹窗
  18. showWarn: false, //是否显示警告用户弹窗
  19. showGetUserInfoButton: false //是否显示获取用户信息button
  20. },
  21. mutations: {
  22. CHANGENETWORKSTATUS (state, payload) { //修改网络类型
  23. state.networkType = payload
  24. },
  25. GETUSERWEIXININFO (state, payload) { //获取到用户微信信息之后的操作
  26. console.log(payload)
  27. state.userWeixinInfo = payload
  28. },
  29. GETUSERSERVERINFO (state, payload) { //获取到用户服务器信息之后的操作
  30. if (!state.openid) {
  31. uni.setStorageSync('openid', payload.openid)
  32. state.openid = payload.openid
  33. }
  34. if (!state.id) {
  35. uni.setStorageSync('id', payload.id)
  36. state.openid = payload.openid
  37. }
  38. console.log(payload)
  39. payload.cha_nickname = 'TEST1211313123'
  40. payload.signuped = true
  41. payload.type = 2
  42. payload.level_name = '代理公司'
  43. // payload.money = 1
  44. state.userServerInfo = payload //把获取到的用户服务器信息,保存到 vuex 中
  45. },
  46. HIDEVERIFY (state) { //关闭手机号码验证弹窗
  47. state.showVerify = false
  48. },
  49. SHOWVERIFY (state) { //打开手机号码验证弹窗
  50. state.showVerify = true
  51. },
  52. HIDEWARN (state) { //关闭警告用户弹窗
  53. state.showWarn = false
  54. },
  55. SHOWWARN (state) { //打开警告用户弹窗
  56. state.showWarn = true
  57. },
  58. SHOWGETUSERINFOBUTTON (state) { //显示获取用户信息按钮
  59. state.showGetUserInfoButton = true
  60. },
  61. HIDEGETUSERINFOBUTTON (state) { //隐藏获取用户信息按钮
  62. state.showGetUserInfoButton = false
  63. },
  64. SIGNUP (state) { // 用户报名成功改变状态
  65. state.userServerInfo.signuped = true
  66. },
  67. GETLOCALTION(state) { // 获取位置信息
  68. state.gotLocation = true
  69. },
  70. READCHALLENGE(state) { // 已读挑战消息
  71. state.userServerInfo.cha_nickname = ''
  72. }
  73. },
  74. actions: {
  75. onLaunch ({ commit, state }) { //初始化后进行的一些异步操作
  76. return new Promise(async (resolve, reject) => {
  77. uni.showLoading({ title: '加载中', mask: true }) //显示loading
  78. const [getUserWeixinInfoErr, userWeixinInfo] = await uni.getUserInfo() //首先获取用户微信信息
  79. if (getUserWeixinInfoErr) { //获取用户微信信息失败后,提示用户,同时展示透明按钮
  80. uni.$emit('MESSAGE', '获取微信授权信息失败,请点击屏幕允许 大卫博士争霸赛获取您的公开信息(昵称、头像、地区及性别)', 864000000)
  81. uni.hideLoading() //取消loading
  82. commit('SHOWGETUSERINFOBUTTON')
  83. } else { // 获取用户微信信息成功后,继续进行下一步
  84. uni.$emit('HIDEMESSAGE') // 隐藏信息提示框
  85. commit('GETUSERWEIXININFO', userWeixinInfo.userInfo) //将获取到的用户微信信息存在 store 里
  86. let CODE = '123'
  87. if (!state.openid) {
  88. const [ , { code }] = await uni.login() //获取 code,并将code 连同用户头像/昵称/openid一同发给后台
  89. CODE = code
  90. }
  91. let latitude = '' // 经度
  92. let longitude = '' // 维度
  93. const location = await uni.getLocation({ type: 'gcj02' }) // 获取地理位置信息
  94. uni.hideLoading() //取消loading
  95. const login = () => {
  96. uni.showLoading({ title: '加载中', mask: true }) //显示loading
  97. this.$ajax.get(`${api_onLaunch}?id=${state.id}&sex=${state.userWeixinInfo.gender}&latitude=${latitude}&longitude=${longitude}&code=${CODE}&avatar=${state.userWeixinInfo.avatarUrl}&openid=${state.openid ? state.openid : '123'}&nickname=${state.userWeixinInfo.nickName}`).then(([ , { data: res }]) => {
  98. if (res.code === 200) { //当前微信用户已经绑定手机号了
  99. state.N401 = 0
  100. commit('GETUSERSERVERINFO', res.data)
  101. uni.hideLoading() //异步操作结束,停止 loading
  102. resolve()
  103. } else if (res.code === 300) { //当前微信用户没有绑定手机号,弹出验证码框 // 401 表示 code 过期/失效 openid 获取不到等
  104. uni.hideLoading() //异步操作结束,停止 loadin
  105. commit('SHOWVERIFY')
  106. resolve()
  107. } else if (res.code === 401) {
  108. uni.hideLoading() // 异步操作结束,停止 loading
  109. reject(500)
  110. } else { //其他边界情况,提示用户下拉刷新
  111. uni.hideLoading() // 异步操作结束,停止 loading
  112. reject(500)
  113. }
  114. })
  115. }
  116. const checkLocation = async () => {
  117. if (!state.gotLocation) {
  118. const [, { cancel, confirm }] = await uni.showModal({
  119. title: '提示',
  120. content: '获取您的位置信息失败,会导致您无法上传图片',
  121. showCancel: false,
  122. confirmText: '重新获取'
  123. })
  124. if (confirm) {
  125. const settings = await new Promise(resolve => wx.openSetting({
  126. success (res) {
  127. resolve(res.authSetting)
  128. }
  129. }))
  130. if (settings['scope.userLocation']) {
  131. commit('GETLOCALTION')
  132. login()
  133. } else {
  134. checkLocation()
  135. }
  136. } else {
  137. checkLocation()
  138. }
  139. }
  140. }
  141. if (location.length == 2) {
  142. commit('GETLOCALTION')
  143. latitude = location[1].latitude
  144. longitude = location[1].longitude
  145. login()
  146. } else {
  147. checkLocation()
  148. }
  149. }
  150. })
  151. }
  152. }
  153. })
  154. Vuex.Store.prototype.$ajax = ajax(store)
  155. export default store