1
0

app-user-login.vue 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  1. <template>
  2. <view class="login dir-left-nowrap main-center cross-center" :class="showLoginModal ? 'show' : ''">
  3. <view class="login-content">
  4. <image :src="auth_page.pic_url" class="login-img"></image>
  5. <view>
  6. <app-hotspot :hotspot="auth_page.hotspot_cancel">
  7. <button class="login-btn" @click="cancel"></button>
  8. </app-hotspot>
  9. </view>
  10. <view>
  11. <app-hotspot :hotspot="auth_page.hotspot">
  12. <button class="login-btn"
  13. :open-type="openType"
  14. scope="userInfo"
  15. @getAuthorize="getUserInfo"
  16. @tap="getUserInfo"
  17. @click="getUserInfoClick"
  18. >
  19. </button>
  20. </app-hotspot>
  21. </view>
  22. </view>
  23. </view>
  24. </template>
  25. <script>
  26. import Vue from 'vue';
  27. import {mapState} from 'vuex';
  28. import appHotspot from '../../../basic-component/app-hotspot/app-hotspot.vue';
  29. export default {
  30. name: 'app-user-login',
  31. components: {
  32. appHotspot,
  33. },
  34. data() {
  35. return {};
  36. },
  37. computed: {
  38. openType() {
  39. // #ifdef MP-ALIPAY
  40. return 'getAuthorize';
  41. // #endif
  42. return 'getUserInfo';
  43. },
  44. ...mapState('mallConfig', {
  45. auth_page: state => state.auth_page,
  46. }),
  47. ...mapState({
  48. showLoginModal: state => state.user.showLoginModal,
  49. }),
  50. },
  51. created() {
  52. const vm = this;
  53. Vue.use({
  54. install(Vue, options) {
  55. Vue.prototype.$layout = {
  56. getUserInfo() {
  57. vm.showLoginModal = true;
  58. return new Promise((resolve, reject) => {
  59. vm.getUserInfo = (e) => {
  60. };
  61. });
  62. },
  63. };
  64. },
  65. });
  66. },
  67. methods: {
  68. cancel() {
  69. this.$store.commit('user/showLoginModal', false);
  70. this.$user.getUserInfoReject('getUserInfo fail: cancel.');
  71. let pages = getCurrentPages();
  72. let list = ['/pages/index/index', '/pages/user-center/user-center'];
  73. let url = this.$platDiff.route();
  74. if (list.includes(url)) {
  75. url = this.$platDiff.routeWithOption();
  76. uni.redirectTo({
  77. url: url
  78. });
  79. } else if (pages.length >= 2) {
  80. uni.navigateBack({
  81. delta: 1
  82. });
  83. } else {
  84. uni.redirectTo({
  85. url: '/pages/index/index'
  86. });
  87. }
  88. },
  89. getUserInfoClick(e) {
  90. // #ifdef MP-TOUTIAO
  91. this.getUserInfo(e);
  92. // #endif
  93. },
  94. getUserInfo(e) {
  95. this.$store.commit('user/showLoginModal', false);
  96. const resolve = this.$user.getUserInfoResolve;
  97. const reject = this.$user.getUserInfoReject;
  98. this.$event.on(this.$const.EVENT_USER_LOGIN, true).then(() => {
  99. this.$jump({
  100. open_type: 'reload'
  101. })
  102. });
  103. // #ifdef MP-WEIXIN
  104. wx.getUserProfile({
  105. desc: "用于完善用户资料",
  106. success: (res) => {
  107. if (res.errMsg !== 'getUserProfile:ok') {
  108. this.$store.commit('user/showLoginModal', true);
  109. return reject(res.errMsg);
  110. } else {
  111. return resolve({detail:res});
  112. }
  113. }
  114. })
  115. // #endif
  116. // #ifdef MP-ALIPAY
  117. my.getOpenUserInfo({
  118. success(openUserInfo) {
  119. const response = JSON.parse(openUserInfo.response);
  120. e.detail = {
  121. rawData: JSON.stringify(response.response),
  122. encryptedData: '',
  123. iv: '',
  124. signature: '',
  125. };
  126. return resolve(e);
  127. },
  128. fail(failE) {
  129. console.log('getOpenUserInfo:', failE);
  130. },
  131. });
  132. // #endif
  133. // #ifdef MP-BAIDU
  134. e.detail.rawData = JSON.stringify(e.detail.userInfo);
  135. e.detail.encryptedData = '';
  136. e.detail.iv = '';
  137. e.detail.signature = '';
  138. return resolve(e);
  139. // #endif
  140. // #ifdef MP-TOUTIAO
  141. uni.login({
  142. success() {
  143. uni.getUserInfo({
  144. success(result) {
  145. e.detail = {
  146. rawData: result.rawData,
  147. encryptedData: '',
  148. iv: '',
  149. signature: '',
  150. };
  151. return resolve(e);
  152. },
  153. fail(e) {
  154. console.log('getUserInfo fail:', e);
  155. },
  156. });
  157. },
  158. fail(e) {
  159. console.log('login fail:', e);
  160. },
  161. });
  162. // #endif
  163. },
  164. }
  165. }
  166. </script>
  167. <style scoped lang="scss">
  168. $login-padding: #{200rpx} #{50rpx};
  169. .login {
  170. box-sizing: border-box;
  171. position: fixed;
  172. top: 0;
  173. left: 0;
  174. z-index: 1502;
  175. width: 100%;
  176. height: 100%;
  177. background: rgba(0, 0, 0, .5);
  178. padding: $login-padding;
  179. visibility: hidden;
  180. opacity: 0;
  181. transition: opacity 200ms;
  182. .login-btn {
  183. display: block;
  184. width: 100%;
  185. height: 100%;
  186. opacity: 0;
  187. padding: 0;
  188. }
  189. .login-content {
  190. position: relative;
  191. width: #{650rpx};
  192. height: #{700rpx};
  193. }
  194. .login-img {
  195. width: #{650rpx};
  196. height: #{700rpx};
  197. }
  198. }
  199. .login.show {
  200. visibility: visible;
  201. opacity: 1;
  202. }
  203. </style>