<template>
|
<el-form
|
class="login-form"
|
status-icon
|
:rules="loginRules"
|
ref="loginForm"
|
:model="loginForm"
|
label-width="0"
|
>
|
<el-form-item v-if="tenantMode" prop="tenantId">
|
<el-input
|
@keyup.enter="handleLogin"
|
v-model="loginForm.tenantId"
|
auto-complete="off"
|
:placeholder="$t('login.tenantId')"
|
>
|
<template #prefix>
|
<i class="icon-quanxian" />
|
</template>
|
</el-input>
|
</el-form-item>
|
<el-form-item prop="username">
|
<el-input
|
@keyup.enter="handleLogin"
|
v-model="loginForm.username"
|
auto-complete="off"
|
:placeholder="$t('login.username')"
|
>
|
<template #prefix>
|
<i class="icon-yonghu" />
|
</template>
|
</el-input>
|
</el-form-item>
|
<el-form-item prop="password">
|
<el-input
|
@keyup.enter="handleLogin"
|
type="password"
|
show-password
|
v-model="loginForm.password"
|
auto-complete="off"
|
:placeholder="$t('login.password')"
|
>
|
<template #prefix>
|
<i class="icon-mima" />
|
</template>
|
</el-input>
|
</el-form-item>
|
<el-form-item prop="code" class="login-code" v-if="captchaMode">
|
<el-input
|
@keyup.enter="handleLogin"
|
v-model="loginForm.code"
|
auto-complete="off"
|
:placeholder="$t('login.code')"
|
>
|
<template #prefix>
|
<i class="icon-yanzhengma"></i>
|
</template>
|
<template #append>
|
<div class="login-code-box">
|
<img :src="loginForm.image" class="login-code-img" @click="refreshCode" />
|
</div>
|
</template>
|
</el-input>
|
</el-form-item>
|
<el-form-item>
|
<el-button type="primary" @click.prevent="handleLogin" class="login-submit"
|
>{{ $t('login.submit') }}
|
</el-button>
|
<el-button
|
v-if="this.registerMode"
|
type="danger"
|
@click.prevent="handleRegister"
|
class="register-submit"
|
>{{ $t('login.register') }}
|
</el-button>
|
</el-form-item>
|
<el-dialog title="请选择身份信息后登录" append-to-body v-model="userBox" width="400px">
|
<avue-form :option="userOption" v-model="userForm" @submit="submitLogin" />
|
</el-dialog>
|
</el-form>
|
</template>
|
|
<script>
|
import { mapGetters } from 'vuex';
|
import { info } from '@/api/system/tenant';
|
import { getCaptcha } from '@/api/user';
|
import { getTopUrl } from '@/utils/util';
|
import { validatenull } from '@/utils/validate';
|
|
export default {
|
name: 'userlogin',
|
data() {
|
return {
|
tenantMode: this.website.tenantMode,
|
captchaMode: this.website.captchaMode,
|
registerMode: this.website.oauth2.registerMode,
|
loginForm: {
|
//租户ID
|
tenantId: '000000',
|
//部门ID
|
deptId: '',
|
//角色ID
|
roleId: '',
|
//用户名
|
username: 'admin',
|
//密码
|
password: 'admin',
|
//账号类型
|
type: 'account',
|
//验证码的值
|
code: '',
|
//验证码的索引
|
key: '',
|
//预加载白色背景
|
image: '',
|
},
|
loginRules: {
|
tenantId: [{ required: false, message: '请输入租户ID', trigger: 'blur' }],
|
username: [{ required: true, message: '请输入用户名', trigger: 'blur' }],
|
password: [
|
{ required: true, message: '请输入密码', trigger: 'blur' },
|
{ min: 1, message: '密码长度最少为6位', trigger: 'blur' },
|
],
|
},
|
passwordType: 'password',
|
userBox: false,
|
userForm: {
|
deptId: '',
|
roleId: '',
|
},
|
userOption: {
|
labelWidth: 70,
|
submitBtn: true,
|
emptyBtn: false,
|
submitText: '登 录',
|
column: [
|
{
|
label: '角色',
|
prop: 'roleId',
|
type: 'select',
|
props: {
|
label: 'roleName',
|
value: 'id',
|
},
|
dicUrl: '/blade-system/role/select',
|
filterable: true,
|
span: 24,
|
display: false,
|
rules: [
|
{
|
required: true,
|
message: '请选择角色',
|
trigger: 'blur',
|
},
|
],
|
},
|
{
|
label: '部门',
|
prop: 'deptId',
|
type: 'select',
|
props: {
|
label: 'deptName',
|
value: 'id',
|
},
|
dicUrl: '/blade-system/dept/select',
|
filterable: true,
|
span: 24,
|
display: false,
|
rules: [
|
{
|
required: true,
|
message: '请选择部门',
|
trigger: 'blur',
|
},
|
],
|
},
|
],
|
},
|
};
|
},
|
created() {
|
this.getTenant();
|
this.refreshCode();
|
},
|
mounted() {
|
this.$nextTick(() => {});
|
},
|
watch: {
|
'loginForm.deptId'() {
|
const column = this.findObject(this.userOption.column, 'deptId');
|
if (this.loginForm.deptId.includes(',')) {
|
column.dicUrl = `/blade-system/dept/select?deptId=${this.loginForm.deptId}`;
|
column.display = true;
|
} else {
|
column.dicUrl = '';
|
}
|
},
|
'loginForm.roleId'() {
|
const column = this.findObject(this.userOption.column, 'roleId');
|
if (this.loginForm.roleId.includes(',')) {
|
column.dicUrl = `/blade-system/role/select?roleId=${this.loginForm.roleId}`;
|
column.display = true;
|
} else {
|
column.dicUrl = '';
|
}
|
},
|
},
|
computed: {
|
...mapGetters(['tagWel', 'userInfo']),
|
},
|
props: [],
|
methods: {
|
refreshCode() {
|
if (this.website.captchaMode) {
|
getCaptcha().then(res => {
|
const data = res.data;
|
this.loginForm.key = data.key;
|
this.loginForm.image = data.image;
|
});
|
}
|
},
|
submitLogin(form, done) {
|
if (!validatenull(form.deptId)) {
|
this.loginForm.deptId = form.deptId;
|
}
|
if (!validatenull(form.roleId)) {
|
this.loginForm.roleId = form.roleId;
|
}
|
this.handleLogin();
|
done();
|
},
|
handleLogin() {
|
this.$refs.loginForm.validate(valid => {
|
if (valid) {
|
const loading = this.$loading({
|
lock: true,
|
text: '登录中,请稍后',
|
background: 'rgba(0, 0, 0, 0.7)',
|
});
|
this.$store
|
.dispatch('LoginByUsername', this.loginForm)
|
.then(() => {
|
if (this.website.switchMode) {
|
const deptId = this.userInfo.deptId;
|
const roleId = this.userInfo.roleId;
|
if (deptId.includes(',') || roleId.includes(',')) {
|
this.loginForm.deptId = deptId;
|
this.loginForm.roleId = roleId;
|
this.userBox = true;
|
this.$store.dispatch('LogOut').then(() => {
|
loading.close();
|
});
|
return false;
|
}
|
}
|
loading.close();
|
//加载工作流路由集
|
this.loadFlowRoutes();
|
this.$router.push(this.tagWel);
|
})
|
.catch(err => {
|
console.log(err);
|
loading.close();
|
this.refreshCode();
|
});
|
}
|
});
|
},
|
handleRegister() {
|
this.$parent.activeName = 'register';
|
},
|
loadFlowRoutes() {
|
this.$store.dispatch('FlowRoutes').then(() => {});
|
},
|
getTenant() {
|
let domain = getTopUrl();
|
// 临时指定域名,方便测试
|
//domain = "https://bladex.cn";
|
info(domain).then(res => {
|
const data = res.data;
|
if (data.success && data.data.tenantId) {
|
this.tenantMode = false;
|
this.loginForm.tenantId = data.data.tenantId;
|
this.$parent.$refs.login.style.backgroundImage = `url(${data.data.backgroundUrl})`;
|
}
|
});
|
},
|
},
|
};
|
</script>
|
|
<style></style>
|