index.vue 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. <template>
  2. <view>
  3. <view v-if="showLogin">
  4. <login :ocode="ocode" :appkey="appkey" scope="snsapi_userinfo" :visible="visible" @success="loginSuccess" @fail="loginFail" @cancel="loginCancel" />
  5. </view>
  6. </view>
  7. </template>
  8. <script>
  9. export default {
  10. data() {
  11. return {
  12. // 获取用户信息
  13. ocode: '1015730314',
  14. // 商户appkey
  15. appkey: 'EE28EE2C93296F4E',
  16. // 是否授权可见
  17. visible: false,
  18. // 是否启动授权
  19. showLogin: false,
  20. // 获取用户信息
  21. appid: 'wxd6f090391d410534',
  22. // 用户路由
  23. userListInfo: {
  24. routes: ['报修', '我的报修'],
  25. btns: []
  26. },
  27. // 师傅路由
  28. workerListInfo: {
  29. routes: ['首页', '工单管理', '待处理池'],
  30. btns: ['协作', '接单', '转单', '报价', '维修完成']
  31. },
  32. // 后勤路由
  33. logisticsListInfo: {
  34. routes: ['首页', '工单管理', '待处理池', '通讯录'],
  35. btns: ['表格编辑', '延时', '派单', '审核', '分段器按钮', '图表']
  36. },
  37. // 管理者路由
  38. adminListInfo: {
  39. routes: ['首页', '工单管理', '待处理池', '通讯录'],
  40. btns: ['首页分段器', '表格编辑', '工单管理分段器', '延时', '派单', '审核', '接单', '报价', '维修完成', '图表', '协作', '转单']
  41. }
  42. }
  43. },
  44. mounted() {
  45. this.hasUserInfo()
  46. },
  47. methods: {
  48. // 检查用户是否已经授权
  49. hasUserInfo() {
  50. const repairsUserInfo = uni.getStorageSync('repairsUserInfo')
  51. const openId = uni.getStorageSync('openId')
  52. const college = uni.getStorageSync('college')
  53. // console.log(repairsUserInfo)
  54. // console.log(openId)
  55. // console.log(college)
  56. if (repairsUserInfo && openId && college) {
  57. uni.setStorageSync('currentIndexRepairs', 0)
  58. uni.reLaunch({
  59. url: '/pagesRepairs/box/box'
  60. })
  61. } else {
  62. // console.log('重新授权')
  63. this.showLogin = true
  64. this.visible = true
  65. }
  66. },
  67. // 授权成功回调
  68. loginSuccess(res) {
  69. // console.log('成功')
  70. let wxcode = res.detail.wxcode
  71. // console.log(wxcode)
  72. // 获取wxcode后请求登录
  73. this.login(wxcode)
  74. },
  75. // 用户登陆获取个人信息
  76. async login(wxcode) {
  77. const res = await this.$myRequest_repairs({
  78. url: '/login/Openid',
  79. header: {},
  80. data: {
  81. wxcode
  82. }
  83. })
  84. // console.log(res)
  85. if (res.code === '200') {
  86. uni.setStorageSync('repairsUserInfo', res.data)
  87. uni.setStorageSync('college', res.data.college)
  88. uni.setStorageSync('currentIndexRepairs', 0)
  89. this.getOpenId()
  90. }
  91. },
  92. // 获取用户openId
  93. getOpenId() {
  94. // 获取code
  95. uni.login({
  96. //使用微信登录
  97. provider: 'weixin',
  98. success: async (res) => {
  99. const result = await this.$myRequest_repairs({
  100. url: '/login/XOpenid',
  101. data: {
  102. code: res.code,
  103. userId: uni.getStorageSync('repairsUserInfo').userId
  104. }
  105. })
  106. // console.log(result)
  107. if (result.code === '200') {
  108. uni.setStorageSync('openId', result.data.openId)
  109. uni.reLaunch({
  110. url: '/pagesRepairs/box/box'
  111. })
  112. }
  113. }
  114. })
  115. },
  116. // 授权失败回调
  117. loginFail() {
  118. // console.log("授权失败");
  119. uni.showModal({
  120. title: '提示',
  121. content: '授权:请先领取校园卡、并激活!',
  122. confirmText: '领取',
  123. success: (res) => {
  124. if (res.confirm) {
  125. uni.reLaunch({
  126. url: '/pages/qr_code/qr_code'
  127. })
  128. } else if (res.cancel) {
  129. uni.reLaunch({
  130. url: '/pagesClockIn/404/404'
  131. })
  132. }
  133. }
  134. })
  135. },
  136. // 授权取消回调
  137. loginCancel() {
  138. // console.log("取消");
  139. uni.showModal({
  140. title: '提示',
  141. content: '请先授权,否则无法使用该功能',
  142. confirmText: '授权',
  143. success: (res) => {
  144. if (res.confirm) {
  145. uni.reLaunch({
  146. url: '/pagesRepairs/index/index'
  147. })
  148. } else if (res.cancel) {
  149. uni.reLaunch({
  150. url: '/pagesClockIn/404/404'
  151. })
  152. }
  153. }
  154. })
  155. }
  156. }
  157. }
  158. </script>
  159. <style lang="scss"></style>