355 lines
8.3 KiB
Vue
355 lines
8.3 KiB
Vue
<!--
|
||
* @Descripttion:
|
||
* @version:
|
||
* @Author: 王三华
|
||
* @Date: 2023-05-18 14:42:53
|
||
-->
|
||
<template>
|
||
<view class="main">
|
||
<view class="changeLanguages"
|
||
v-if="getLanguageList.length>0">
|
||
<picker :range="getLanguageList"
|
||
:value="index"
|
||
range-key="label"
|
||
@change="bindPickerChange">
|
||
<view class="select-text">
|
||
<view class="texts">{{ getLanguageList[index].label }}</view>
|
||
<view class="">
|
||
<image class="selIcon"
|
||
src="../../static/images/drop-666.png"></image>
|
||
</view>
|
||
</view>
|
||
</picker>
|
||
</view>
|
||
<view class="title">
|
||
{{ $t('w_0007') }}
|
||
</view>
|
||
<u-form :model="loginForm"
|
||
labelWidth="auto"
|
||
ref="uForm">
|
||
<view class="view-class pa">
|
||
<!-- <view class="account-s">
|
||
|
||
</view> -->
|
||
<u-form-item label=""
|
||
prop="username">
|
||
<u-input v-model="loginForm.username"
|
||
clearable
|
||
placeholder-class="place-class"
|
||
class="border-color "
|
||
:placeholder="$t('w_0329')">
|
||
<image class="tou"
|
||
slot="prefix"
|
||
src="../../static/images/login/index-icon4.png"></image>
|
||
</u-input>
|
||
</u-form-item>
|
||
<!-- <view class="close-s"
|
||
v-if="loginForm.username!=''"
|
||
@click="clearAccount">
|
||
<image src="../../static/images/login/index-icon3.png"></image>
|
||
</view> -->
|
||
</view>
|
||
<view class="view-class">
|
||
<!-- <view class="account-s widths">
|
||
<image src="../../static/images/login/index-icon2.png"></image>
|
||
</view> -->
|
||
<u-form-item label=""
|
||
prop="password">
|
||
<u-input placeholder-style="color:#333"
|
||
:type="password"
|
||
class="border-color"
|
||
v-model="loginForm.password"
|
||
:placeholder="$t('w_0041')">
|
||
<image class="mm"
|
||
slot="prefix"
|
||
src="../../static/images/login/index-icon2.png"></image>
|
||
<view slot="suffix">
|
||
<view v-if="password=='text'"
|
||
@click="changeFlagTap('password')">
|
||
<image class="eye"
|
||
src="../../static/images/login/icon1.png"></image>
|
||
</view>
|
||
<view v-else
|
||
@click="changeFlagTap('text')">
|
||
<image class="eye"
|
||
src="../../static/images/login/icon2.png"></image>
|
||
</view>
|
||
</view>
|
||
</u-input>
|
||
</u-form-item>
|
||
|
||
</view>
|
||
<view class="view-class">
|
||
<!-- <view class="account-s yzm">
|
||
<image src="../../static/images/login/index-icon1.png"></image>
|
||
</view> -->
|
||
<u-form-item label=""
|
||
prop="code">
|
||
<u-input v-model="loginForm.code"
|
||
placeholder-class="place-class"
|
||
class="border-color"
|
||
:placeholder="$t('w_0043')">
|
||
<image class="mm"
|
||
slot="prefix"
|
||
src="../../static/images/login/index-icon1.png"></image>
|
||
<img :src="codeUrl"
|
||
slot="suffix"
|
||
style="height: 38px;"
|
||
@click="getVerifyCode" />
|
||
</u-input>
|
||
|
||
</u-form-item>
|
||
</view>
|
||
</u-form>
|
||
<u-button type="success"
|
||
shape="circle"
|
||
class="btn"
|
||
:loading="isLoading"
|
||
:loadingText="$t('w_0330')"
|
||
@click="toLogin">{{$t('w_0044')}}</u-button>
|
||
<view class="paswwrod_btn"
|
||
@click="submit">{{$t('w_0042')}}</view>
|
||
</view>
|
||
</template>
|
||
|
||
<script>
|
||
import * as api from '@/config/login.js'
|
||
import { setToken } from '@/config/auth.js'
|
||
import store from '@/store'
|
||
export default {
|
||
data() {
|
||
return {
|
||
password: 'password',
|
||
index: 0,
|
||
getList: [],
|
||
changeFlag: true,
|
||
isLoading: false,
|
||
loginForm: {
|
||
username: '',
|
||
password: '',
|
||
code: '',
|
||
uuid: '',
|
||
},
|
||
codeUrl: '',
|
||
getLanguageList: [],
|
||
}
|
||
},
|
||
onLoad() {
|
||
this.getVerifyCode()
|
||
this.loginForm.username = uni.getStorageSync('username')||''
|
||
// this.getLanguage()
|
||
},
|
||
methods: {
|
||
changeFlagTap(text) {
|
||
this.password = text
|
||
},
|
||
submit() {
|
||
uni.navigateTo({
|
||
url: '/pages/forgetPassword/index',
|
||
})
|
||
},
|
||
bindPickerChange(e) {
|
||
this.index = e.detail.value
|
||
},
|
||
clearAccount() {
|
||
this.loginForm.username = ''
|
||
},
|
||
getVerifyCode() {
|
||
api.captchaImage().then((res) => {
|
||
this.codeUrl = 'data:image/gif;base64,' + res.img
|
||
this.loginForm.uuid = res.uuid
|
||
})
|
||
},
|
||
getLanguage() {
|
||
api.getLanguages().then((res) => {
|
||
this.getLanguageList = res.data
|
||
})
|
||
},
|
||
toLogin() {
|
||
api.login(this.loginForm).then((res) => {
|
||
this.isLoading = false
|
||
if (!res) {
|
||
// uni.showToast({
|
||
// title: res.msg,
|
||
// icon: 'none',
|
||
// duration: 1500,
|
||
// })
|
||
this.getVerifyCode()
|
||
} else if (res.code == 500) {
|
||
this.getVerifyCode()
|
||
} else {
|
||
uni.setStorageSync('username', this.loginForm.username)
|
||
setToken(res.data.access_token, res.data.expires_in / 24 / 60)
|
||
this.getUseInfo()
|
||
}
|
||
})
|
||
},
|
||
urlToBase64(url) {
|
||
return new Promise((resolve, reject) => {
|
||
uni.request({
|
||
url: url,
|
||
method: 'GET',
|
||
responseType: 'arraybuffer',
|
||
success: (res) => {},
|
||
fail: (err) => {
|
||
reject(err)
|
||
},
|
||
})
|
||
})
|
||
},
|
||
getUseInfo() {
|
||
store.dispatch('GetInfo').then((res) => {
|
||
if (res.data.loginType == 1) {
|
||
uni.redirectTo({ url: '/pages/specialMember/index' })
|
||
} else {
|
||
if (res.data.registerFans == 0) {
|
||
uni.redirectTo({ url: '/pages/shareArea/index?specialArea=7' })
|
||
} else if (res.data.registerShare == 0) {
|
||
// uni.redirectTo({ url: '/pages/shareArea/haiNdex?specialArea=21 ' })
|
||
uni.switchTab({ url: '/pages/index/index' })
|
||
} else {
|
||
uni.switchTab({ url: '/pages/index/index' })
|
||
}
|
||
}
|
||
})
|
||
// api.getInfo().then((res) => {
|
||
// uni.setStorage('User', res.data)
|
||
|
||
// })
|
||
},
|
||
},
|
||
}
|
||
</script>
|
||
|
||
<style lang="scss" scoped>
|
||
page,
|
||
body {
|
||
background-color: #fff !important;
|
||
}
|
||
::placeholder {
|
||
color: #333;
|
||
}
|
||
.style-s {
|
||
height: 68rpx;
|
||
margin-left: 40rpx !important;
|
||
color: #333;
|
||
font-size: 28rpx;
|
||
border: none !important;
|
||
|
||
outline: none;
|
||
-webkit-appearance: button;
|
||
-webkit-appearance: none;
|
||
border-radius: 0;
|
||
background: none;
|
||
border: none;
|
||
}
|
||
.select-text {
|
||
display: flex;
|
||
}
|
||
.selIcon {
|
||
width: 40rpx;
|
||
height: 40rpx;
|
||
}
|
||
.changeLanguages {
|
||
position: absolute;
|
||
right: 30rpx;
|
||
top: 0;
|
||
}
|
||
.paswwrod_btn {
|
||
color: #666666;
|
||
font-size: 26rpx;
|
||
margin: 40rpx auto;
|
||
text-align: center;
|
||
}
|
||
.btn {
|
||
background-color: #fb3024;
|
||
border: none;
|
||
height: 92rpx;
|
||
line-height: 92rpx;
|
||
font-size: 36rpx;
|
||
margin: 110rpx auto 0 auto;
|
||
}
|
||
.close-s {
|
||
position: absolute;
|
||
top: 35rpx;
|
||
right: 40rpx;
|
||
image {
|
||
width: 25rpx;
|
||
height: 25rpx;
|
||
}
|
||
}
|
||
.right-s {
|
||
position: absolute;
|
||
top: 35rpx;
|
||
right: 40rpx;
|
||
image {
|
||
width: 45rpx;
|
||
height: 45rpx;
|
||
}
|
||
}
|
||
.place-class {
|
||
color: #333 !important;
|
||
}
|
||
.border-color {
|
||
background: none;
|
||
width: 100%;
|
||
border: none;
|
||
// margin-left: 30rpx;
|
||
}
|
||
.main {
|
||
padding: 20rpx 40rpx;
|
||
}
|
||
.title {
|
||
font-size: 52rpx;
|
||
font-weight: bold;
|
||
margin: 120rpx auto;
|
||
text-align: center;
|
||
}
|
||
.view-class {
|
||
// display: flex;
|
||
background: #f2f2f2;
|
||
border-radius: 46rpx;
|
||
padding: 0 20rpx;
|
||
// position: relative;
|
||
margin-bottom: 30rpx;
|
||
}
|
||
.widths {
|
||
image {
|
||
width: 28rpx !important;
|
||
}
|
||
}
|
||
.yzm {
|
||
image {
|
||
width: 26rpx !important;
|
||
height: 30rpx !important;
|
||
}
|
||
}
|
||
.account-s {
|
||
display: flex;
|
||
align-items: center;
|
||
// line-height: 50%;
|
||
height: 105rpx;
|
||
position: absolute;
|
||
// top: 38rpx;
|
||
image {
|
||
width: 34rpx;
|
||
height: 34rpx;
|
||
}
|
||
}
|
||
.tou {
|
||
width: 34rpx;
|
||
height: 34rpx;
|
||
}
|
||
.mm {
|
||
width: 34rpx !important;
|
||
height: 34rpx !important;
|
||
}
|
||
.eye {
|
||
width: 45rpx !important;
|
||
height: 45rpx !important;
|
||
padding-top: 10px;
|
||
}
|
||
.pa {
|
||
padding: 7px 20rpx;
|
||
}
|
||
</style> |