login.vue 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304
  1. <template>
  2. <div class="ilogin-layout">
  3. <div class="input-con login-input-con">
  4. <template v-if="!isCodeLogin">
  5. <div :key="'login'" class="input"><input autocomplete="off" v-model="phone" oninput="value=value.replace(/[^\d]/g,'')" maxlength='11' :placeholder="languagelAside.phone.placeholder" type="text"></div>
  6. <div class="input"><input autocomplete="off" @keyup.enter="login" v-model="password" :placeholder="languagelAside.password.placeholder" maxlength='16' type="password"></div>
  7. </template>
  8. <template v-else>
  9. <div class="input phone-select" ref="quhaoMenu" >
  10. <div @click="showSelect=!showSelect">
  11. <span>{{codeActive[1]}}</span>
  12. <img :src="`${$cdn}images/quhao-jiantou.png`" >
  13. </div>
  14. <ul v-show="showSelect" >
  15. <li @click="selectItem(item)" v-for="(item,i) in selectCall" :key="i">
  16. {{language==='en'?item[2]:item[0]}}{{item[1]}}
  17. </li>
  18. </ul>
  19. <input :key="'codelogin'" readonly onfocus="this.removeAttribute('readonly')" autocomplete="off" v-model="phone" oninput="value=value.replace(/[^\d]/g,'')" maxlength='11' :placeholder="languagelAside.phone.placeholder" type="text">
  20. </div>
  21. <div class="verification input codeLogin">
  22. <input :key="'authCode'" v-model="authCode" autocomplete="off" :placeholder="languagelAside.code.placeholder" oninput="value=value.replace(/[^\d]/g,'')" maxlength='6'>
  23. <span v-if="!jishi" @click="getAuthCode">{{languagelAside.code.txt}}</span>
  24. <span v-else>{{language==='en'?`Resend after ${interTime}s`:`${interTime}s后重新发送`}}</span>
  25. </div>
  26. </template>
  27. <div class="sub-con">
  28. <div class="remember" :style="{'visibility':!isCodeLogin?'visible':'hidden'}" @click="rememberMe=~rememberMe">
  29. <span>
  30. <img v-if="rememberMe" :src="`${$cdn}images/icon-click.png`" alt="">
  31. </span>
  32. <span>{{rememberName[language]}}</span>
  33. </div>
  34. <div class="changeCode" @click="changeLoginType">{{loginName[language]}}</div>
  35. </div>
  36. <div class="forget-font" @click="$bus.$emit('changName', {
  37. name: '密码重置',
  38. enName: 'Password Reset',
  39. id: 'iforget'
  40. })">{{forgetName[language]}}</div>
  41. <div class="login-con">
  42. <div class="temp-btn" @click="login">{{languagelAside.login}}</div>
  43. <div class="login-dec">{{languagelAside.loginsub1}}<span @click="$bus.$emit('changName', {
  44. name: '立即注册',
  45. enName: 'Sign in',
  46. id: 'iregister'
  47. })">{{languagelAside.loginsub2}}</span></div>
  48. </div>
  49. </div>
  50. <!-- <div class="qrcode">
  51. <img v-if="codeImg" :src="codeImg?`${$serverName}${codeImg}`:''" alt="">
  52. <div class="qrcode-con">
  53. <img class="scan-img" :src="`${$cdn}images/icon-qrcode.png`" alt="">
  54. <div class="login-dec">打开四维看看app扫一扫登录</div>
  55. </div>
  56. </div> -->
  57. </div>
  58. </template>
  59. <script>
  60. import {mapState} from 'vuex'
  61. import selectCall from '@/util/country.js'
  62. import { reg, encodeStr } from '@/util'
  63. import { Base64 } from 'js-base64'
  64. export default {
  65. props: ['active', 'current'],
  66. computed: {
  67. ...mapState({
  68. language: state => state.language.current,
  69. langToast: state => state.language.home.toast,
  70. languagelAside: state => state.language.home.home.loginAside,
  71. token: state => state.user.token
  72. })
  73. },
  74. data () {
  75. let remember = localStorage.getItem('remember') || ''
  76. let username = localStorage.getItem('username')
  77. let password = localStorage.getItem('password')
  78. return {
  79. phone: username,
  80. password: password,
  81. rememberMe: remember,
  82. codeImg: '',
  83. isFirst: true,
  84. t1: null,
  85. showSelect: false,
  86. codeActive: ['中国', '+86', 'China'],
  87. selectCall,
  88. authCode: '',
  89. isCodeLogin: false,
  90. interTime: 60,
  91. jishi: false,
  92. interl: null,
  93. rememberName: {
  94. '中': '记住密码',
  95. en: 'Remember password'
  96. },
  97. forgetName: {
  98. '中': '忘记密码',
  99. en: 'Forgot password'
  100. },
  101. loginName: {
  102. '中': '验证码登录',
  103. en: 'Verification code login'
  104. }
  105. }
  106. },
  107. mounted () {
  108. document.addEventListener('click', (e) => {
  109. if (this.$refs.quhaoMenu) {
  110. if (!this.$refs.quhaoMenu.contains(e.target)) {
  111. this.showSelect = false
  112. }
  113. }
  114. })
  115. },
  116. watch: {
  117. active (newVal) {
  118. setTimeout(() => {
  119. this.isCodeLogin = false
  120. this.loginName = {
  121. '中': '验证码登录',
  122. en: 'Verification code login'
  123. }
  124. }, 700)
  125. }
  126. },
  127. beforeDestroy () {
  128. clearInterval(this.t1)
  129. this.t1 = null
  130. },
  131. methods: {
  132. selectItem (item) {
  133. this.showSelect = false
  134. this.codeActive = item
  135. },
  136. changeLoginType () {
  137. this.isCodeLogin = !this.isCodeLogin
  138. this.loginName = !this.isCodeLogin ? {
  139. '中': '验证码登录',
  140. en: 'Verification code login'
  141. } : {
  142. '中': '账号密码登录',
  143. en: 'Password login'
  144. }
  145. },
  146. async getAuthCode () {
  147. if (!reg.phone.test(this.phone)) {
  148. return
  149. }
  150. let resp = await this.$http
  151. .post('/sso/user/checkUser', {phoneNum: this.phone})
  152. if (resp.data.code !== 0) {
  153. return this.$toast.show('warn', this.langToast[resp.data.code])
  154. }
  155. let res = await this.$store.dispatch('getAuthCode', {
  156. phone: this.phone,
  157. code: Number(this.codeActive[1].substr(1))
  158. })
  159. if (res) {
  160. this.interl && clearInterval(this.interl)
  161. this.interl = null
  162. this.jishi = true
  163. this.interl = setInterval(() => {
  164. this.interTime--
  165. if (this.interTime <= 0) {
  166. this.jishi = false
  167. this.interTime = 60
  168. clearInterval(this.interl)
  169. this.interl = null
  170. }
  171. }, 1000)
  172. }
  173. },
  174. async login () {
  175. let params = ''
  176. if (this.isCodeLogin) {
  177. await this.submit()
  178. } else {
  179. let check = value => {
  180. for (let i = 0, len = value.length; i < len; i++) {
  181. if (!value[i].val) {
  182. return this.$toast.show('warn', (this.language === 'en' ? value[i].En : value[i].name) + this.langToast['7'])
  183. }
  184. }
  185. return true
  186. }
  187. let checkStr = [
  188. {
  189. name: '手机',
  190. En: 'Phone number',
  191. val: this.phone
  192. },
  193. {
  194. name: '密码',
  195. En: 'Password',
  196. val: this.password
  197. }
  198. ]
  199. if (!check(checkStr)) {
  200. return
  201. }
  202. localStorage.setItem('remember', this.rememberMe)
  203. if (this.rememberMe) {
  204. localStorage.setItem('username', this.phone)
  205. localStorage.setItem('password', this.password)
  206. } else {
  207. localStorage.setItem('username', '')
  208. localStorage.setItem('password', '')
  209. }
  210. params = {
  211. phoneNum: this.phone,
  212. password: encodeStr(Base64.encode(this.password)),
  213. randomcode: '1234',
  214. rememberMe: Boolean(this.rememberMe)
  215. }
  216. await this.$store.dispatch('login', params)
  217. }
  218. clearInterval(this.t1)
  219. this.t1 = null
  220. if (this.token) {
  221. this.$bus.$emit('hideAside')
  222. this.$bus.$emit('hasLogin')
  223. }
  224. },
  225. async submit () {
  226. let check = value => {
  227. for (let i = 0, len = value.length; i < len; i++) {
  228. if (!value[i].val) {
  229. return this.$toast.show('warn', (this.language === 'en' ? value[i].En : value[i].name) + this.langToast['7'])
  230. }
  231. }
  232. return true
  233. }
  234. let checkStr = [
  235. {
  236. name: '手机',
  237. En: 'Phone number',
  238. val: this.phone
  239. },
  240. {
  241. name: '验证码',
  242. En: 'Verification code',
  243. val: this.authCode
  244. }
  245. ]
  246. if (!check(checkStr)) {
  247. return
  248. }
  249. // let country = Number(this.codeActive[1].substr(1))
  250. let params = {
  251. phoneNum: this.phone,
  252. msgAuthCode: this.authCode
  253. }
  254. await this.$store.dispatch('codeLogin', params)
  255. },
  256. async getQrCode () {
  257. let res = await this.$http({
  258. method: 'get',
  259. url: '/sso/user/createLoginQrCode'
  260. })
  261. this.codeImg = res.data.data.url
  262. this.isFirst = false
  263. let params = {
  264. uuid: res.data.data.uuid
  265. }
  266. this.t1 = setInterval(async () => {
  267. let data = await this.$http({
  268. method: 'post',
  269. data: params,
  270. url: '/sso/user/sendUserInfo'
  271. })
  272. let response = data.data
  273. if (response.code === 0) {
  274. let {token, childName = '', to = ''} = response.data
  275. this.$store.commit('saveToken', token)
  276. if (token && to !== 0) {
  277. this.$store.commit('DEVICELOGIN', childName)
  278. this.$bus.$emit('hideAside')
  279. this.$router.replace({name: 'scene', query: {first: true}})
  280. } else {
  281. this.$bus.$emit('hideAside')
  282. this.$bus.$emit('hasLogin')
  283. this.$store.commit('DEVICELOGIN', '')
  284. this.$store.dispatch('getInfo', {url: '/user/getUserInfo', name: 'info'})
  285. this.$store.dispatch('getCart')
  286. }
  287. return false
  288. }
  289. }, 3000)
  290. }
  291. }
  292. }
  293. </script>
  294. <style lang="scss" scoped>
  295. @import './style.scss';
  296. </style>