irc_web/.svn/pristine/c7/c7fcec556d5702fd974967c89a2...

433 lines
11 KiB
Plaintext

<template>
<div class="login-container">
<div class="login-header">
<!-- <img src="@/assets/login-logo.png" class="login-logo"> -->
</div>
<div class="login-body">
<div class="login-l">
<div class="login-logo">
<img src="@/assets/zzlogo2.png" v-if="language === 'zh'" alt="">
<img src="@/assets/zzlogo3.png" v-else alt="">
</div>
<div class="login-image">
<img src="@/assets/login-bg.png">
</div>
</div>
<div class="login-r">
<div class="title-container">
<!-- IRC Management System -->
<div class="title">{{ $t('login:title:system') }}</div>
</div>
<el-form
ref="loginForm"
:model="loginForm"
:rules="loginRules"
class="login-form"
auto-complete="on"
label-position="left"
>
<el-form-item prop="username" :rules="[
{ required: true, message: this.$t('login:formRule:userName'), trigger: 'blur' }
]">
<span class="svg-container">
<svg-icon icon-class="user" />
</span>
<!-- User Name -->
<el-input
ref="username"
v-model="loginForm.username"
size="small"
:placeholder="$t('login:form:userName')"
name="username"
type="text"
tabindex="1"
/>
</el-form-item>
<el-form-item prop="password" :rules="[
{ required: true, message: this.$t('login:formRule:password'), trigger: 'blur' }
]">
<span class="svg-container">
<svg-icon icon-class="password" />
</span>
<!-- password -->
<el-input
:key="passwordType"
ref="password"
v-model="loginForm.password"
size="small"
:type="passwordType"
:placeholder="$t('login:form:password')"
name="password"
tabindex="2"
@keyup.enter.native="handleLogin"
/>
<span class="show-pwd" @click="showPwd">
<svg-icon :icon-class="passwordType === 'password' ? 'eye' : 'eye-open'" />
</span>
</el-form-item>
<!-- Login -->
<el-button
:loading="loading"
type="primary"
style="width:100%;margin-bottom:10px;"
size="medium"
@click.native.prevent="handleLogin"
>
{{ $t('login:button:login') }}
</el-button>
<div style="text-align: right;">
<TopLang></TopLang>
<!-- Forget password? -->
<el-button type="text" size="medium" @click.native.prevent="handleResetPwd">
{{ $t('login:button:forgetPassword') }}
</el-button>
</div>
</el-form>
</div>
</div>
<div class="login-footer" v-if="language === 'zh'">
<span>Copyright © 2022 上海展影医疗科技有限公司 版权所有</span>
<span> | </span>
<a target="_blank" href="https://beian.miit.gov.cn/">
<span>
沪ICP备2021037850-2
</span>
</a>
<span> | </span>
<a target="_blank" href="http://www.beian.gov.cn/portal/registerSystemInfo?recordcode=31011002005859">
<img src="@/assets/filing.png">
<span>沪公网安备 31011002005859号</span>
</a>
</div>
</div>
</template>
<script>
import {mapGetters, mapMutations} from 'vuex'
import TopLang from './topLang'
import NoticeMarquee from "../trials/trials-layout/components/noticeMarquee";
export default {
name: 'Login',
components: { TopLang },
data() {
return {
loginForm: {
username: '',
password: ''
},
loginRules: {
username: [
{ required: true, message: this.$t('login:formRule:userName'), trigger: 'blur' },
{ max: 20, message: this.$t('common:ruleMessage:maxLength') }
],
password: [
// {
// required: true,
// trigger: "blur",
// validator: this.$validatePassword
// },
{ required: true, message: this.$t('login:formRule:password'), trigger: 'blur' },
{ max: 20, message: this.$t('common:ruleMessage:maxLength') }
]
},
loading: false,
passwordType: 'password',
loginType: null,
location: null
}
},
computed: {
...mapGetters([
'asyncRoutes',
'routes',
'language'
])
},
mounted() {
this.loginType = this.$route.query.loginType
this.location = this.$route.query.location
zzSessionStorage.setItem('loginType', this.loginType)
localStorage.setItem('location', this.location)
if (this.location === 'USA') {
this.$i18n.locale = 'en'
this.setLanguage('en')
this.$updateDictionary()
} else {
this.$i18n.locale = 'zh'
this.setLanguage('zh')
this.$updateDictionary()
}
// this.$i18n.locale = 'en'
// this.setLanguage('en')
// this.$updateDictionary()
},
methods: {
...mapMutations({ setLanguage: 'lang/setLanguage' }),
showPwd() {
if (this.passwordType === 'password') {
this.passwordType = ''
} else {
this.passwordType = 'password'
}
this.$nextTick(() => {
this.$refs.password.focus()
})
},
handleLogin() {
this.loginType = this.$route.query.loginType
this.$refs.loginForm.validate(valid => {
if (valid) {
this.loading = true
this.$store.dispatch('user/login', this.loginForm).then((res) => {
if (!res) {
// 当前用户为首次登录,请先修改密码之后再次登录
this.$message.success(this.$t('login:message:login1'))
setTimeout(() => {
this.$router.push({ path: `/recompose?userName=${this.loginForm.username}` })
}, 500)
return
}
this.$store.dispatch('permission/generateRoutes').then(res => {
this.loading = false
if (res && res.length > 0) {
this.$store.dispatch('global/getNoticeList')
this.$router.addRoutes(res)
if (this.loginType === 'DevOps') {
this.$router.replace({ path: res[0].path })
return
}
console.log(res)
if (this.hasPermi(['role:air'])) {
this.$router.replace({ path: '/trials/trials-list' })
} else {
this.$router.replace({ path: '/trials' })
}
} else {
// 此账户暂未配置菜单权限,请联系管理员处理后再登录。
this.$message.warning(this.$t('login:message:login2'))
}
})
})
.catch(() => {
this.loading = false
})
} else {
// console.log('error submit!!')
return false
}
})
},
handleResetPwd() {
this.$router.push({ name: 'Resetpassword' })
}
}
}
</script>
<style lang="scss">
/* 修复input 背景不协调 和光标变色 */
$bg: #283443;
$light_gray: #909399;
$cursor: #fff;
// @supports (-webkit-mask: none) and (not (cater-color: $cursor)) {
// .login-container .el-input input {
// // color: #fff;
// }
// }
/* reset element-ui css */
.login-container {
.el-input {
display: inline-block;
height: 47px;
width: 85%;
input {
background: #f4f4f5;
border: 0px;
-webkit-appearance: none;
border-radius: 0px;
padding: 12px 5px 12px 15px;
// color: $light_gray;
height: 47px;
// caret-color: $cursor;
// &:-webkit-autofill {
// box-shadow: 0 0 0px 1000px $bg inset !important;
// -webkit-text-fill-color: $cursor !important;
// }
}
}
.el-form-item {
border: 1px solid rgba(255, 255, 255, 0.1);
background: #f4f4f5;
border-radius: 5px;
color: #454545;
}
}
</style>
<style lang="scss" scoped>
$bg:#2d3a4b;
$dark_gray:#889aa4;
$light_gray:#606266;
.login-container {
position: relative;
width: 100%;
height: 100%;
overflow: auto;
background: rgb(249, 249, 249);
.login-header {
margin: 10px 0px 20px 10px;
height: 3rem;
width: 720px;
.login-logo {
height: 100%;
}
}
.login-body {
position: absolute;
left: 50%;
top: 50%;
transform: translate(-50%,-50%);
// margin-top: -230px;
// margin-left: -400px;
width: 1200px;
height: 600px;
// margin: 30px auto;
box-sizing: border-box;
background: rgb(255, 255, 255);
border-radius: 10px 0px 0px 10px;
.login-l {
position: relative;
float: left;
width: 50%;
height: 100%;
.login-logo{
position: absolute;
top:35px;
left: 50px;
img{
height: 40px;
}
}
.login-image{
position: absolute;
top:10px;
left: 0px;
// transform: translateY(-50%);
height: 100%;
img {
height: 100%;
}
}
}
.login-r {
position: relative;
float: left;
width: 50%;
height: 100%;
.login-form {
position: absolute;
top: 50%;
// transform: translateY(-50%);
left: 50%;
transform:translate(-50%,-50%);
width: 80%;
padding: 10px;
margin: 0 auto;
overflow: hidden;
}
.title-container {
// margin-bottom: 50px;
margin-top: 15%;
.title {
font-size: 35px;
color: $light_gray;
text-align: center;
font-weight: bold;
}
}
.tips {
font-size: 14px;
color: #fff;
margin-bottom: 10px;
span {
&:first-of-type {
margin-right: 16px;
}
}
}
.svg-container {
padding: 6px 5px 6px 15px;
color: $dark_gray;
vertical-align: middle;
width: 30px;
display: inline-block;
}
.show-pwd {
position: absolute;
right: 10px;
top: 7px;
font-size: 16px;
color: $dark_gray;
cursor: pointer;
user-select: none;
}
}
}
.login-footer{
position: absolute;
bottom: 50px;
left: 0px;
width: 100%;
text-align: center;
line-height: 20px;
font-size: 14px;
display: flex;
justify-content: center;
align-items: center;
// color: rgb(180, 190, 199);
color: #909399;
a{
display:inline-block;
text-decoration:none;
height:20px;
line-height:20px;
display: flex;
justify-content: center;
}
span{
margin: 0 2px;
}
img{
height:20px;
line-height:20px;
}
// p{
// display: inline-block;
// height:20px;
// line-height:20px;
// margin: 0px 0px 0px 5px;
// color:#939393;
// }
}
}
</style>