<template>
<BasicModal v-bind="config" @register="registerModal" :title="currTitle" wrapClassName="loginSelectModal" v-model:visible="visible">
<a-form ref="formRef" :model="formState" :rules="rules" v-bind="layout" :colon="false" class="loginSelectForm">
<!--多租户选择-->
<a-form-item v-if="isMultiTenant" name="tenantId" :validate-status="validate_status">
<!--label内容-->
<template #label>
<a-tooltip placement="topLeft">
<template #title>
<span>您隶属于多租户,请选择登录租户</span>
</template>
<a-avatar style="background-color: #87d068" :size="30"> 租户 </a-avatar>
</a-tooltip>
</template>
<template #extra v-if="validate_status == 'error'">
<span style="color: #ed6f6f">请选择登录租户</span>
</template>
<!--租户下拉内容-->
<a-select
v-model:value="formState.tenantId"
@change="handleTenantChange"
placeholder="请选择登录租户"
:class="{ 'valid-error': validate_status == 'error' }"
>
<template v-for="tenant in tenantList" :key="tenant.id">
<a-select-option :value="tenant.id">{{ tenant.name }}</a-select-option>
</template>
</a-select>
</a-form-item>
<!--多部门选择-->
<a-form-item v-if="isMultiDepart" :validate-status="validate_status1" :colon="false">
<!--label内容-->
<template #label>
<a-tooltip placement="topLeft">
<template #title>
<span>您隶属于多部门,请选择登录部门</span>
</template>
<a-avatar style="background-color: rgb(104, 208, 203)" :size="30"> 部门 </a-avatar>
</a-tooltip>
</template>
<template #extra v-if="validate_status1 == 'error'">
<span style="color: #ed6f6f">请选择登录部门</span>
</template>
<!--部门下拉内容-->
<a-select
v-model:value="formState.orgCode"
@change="handleDepartChange"
placeholder="请选择登录部门"
:class="{ 'valid-error': validate_status1 == 'error' }"
>
<template v-for="depart in departList" :key="depart.orgCode">
<a-select-option :value="depart.orgCode">{{ depart.departName }}</a-select-option>
</template>
</a-select>
</a-form-item>
</a-form>
<template #footer>
<a-button @click="handleSubmit" type="primary">确认</a-button>
</template>
</BasicModal>
</template>
<script lang="ts">
import { defineComponent, ref, computed, watch, unref, reactive, UnwrapRef } from 'vue';
import { Avatar } from 'ant-design-vue';
import { BasicModal, useModalInner } from '/@/components/Modal';
import { useMessage } from '/@/hooks/web/useMessage';
import { useUserStore } from '/@/store/modules/user';
import { defHttp } from '/@/utils/http/axios';
interface FormState {
orgCode: string | undefined;
tenantId: number;
}
export default defineComponent({
name: 'loginSelect',
components: {
Avatar,
BasicModal,
},
emits: ['success', 'register'],
setup(props, { emit }) {
const userStore = useUserStore();
const { notification } = useMessage();
//租户配置
const isMultiTenant = ref(false);
const tenantList = ref([]);
const validate_status = ref('');
//部门配置
const isMultiDepart = ref(false);
const departList = ref([]);
const validate_status1 = ref('');
//弹窗显隐
const visible = ref(false);
//登录用户
const username = ref('');
//表单
const formRef = ref();
//选择的租户部门信息
const formState: UnwrapRef<FormState> = reactive({
orgCode: undefined,
tenantId: null,
});
const config = {
maskClosable: false,
closable: false,
canFullscreen: false,
width: '500px',
minHeight: 20,
maxHeight: 20,
};
//弹窗操作
const [registerModal, { closeModal }] = useModalInner();
//当前标题
const currTitle = computed(() => {
if (unref(isMultiDepart) && unref(isMultiTenant)) {
return '请选择租户和部门';
} else if (unref(isMultiDepart) && !unref(isMultiTenant)) {
return '请选择部门';
} else if (!unref(isMultiDepart) && unref(isMultiTenant)) {
return '请选择租户';
}
});
const rules = ref({
tenantId: [{ required: unref(isMultiTenant), type: 'number', message: '请选择租户', trigger: 'change' }],
orgCode: [{ required: unref(isMultiDepart), message: '请选择部门', trigger: 'change' }],
});
const layout = {
labelCol: { span: 4 },
wrapperCol: { span: 18 },
};
/**
* 处理部门情况
*/
function bizDepart(loginResult) {
//如果登录接口返回了用户上次登录租户ID,则不需要重新选择
if(loginResult.userInfo?.orgCode && loginResult.userInfo?.orgCode!==''){
isMultiDepart.value = false;
return;
}
let multi_depart = loginResult.multi_depart;
//0:无部门 1:一个部门 2:多个部门
if (multi_depart == 0) {
// notification.warn({
// message: '提示',
// description: `您尚未归属部门,请确认账号信息`,
// duration: 3,
// });
isMultiDepart.value = false;
} else if (multi_depart == 2) {
isMultiDepart.value = true;
departList.value = loginResult.departs;
} else {
isMultiDepart.value = false;
}
}
/**
* 处理租户情况
*/
function bizTenantList(loginResult) {
//如果登录接口返回了用户上次登录租户ID,则不需要重新选择
if(loginResult.userInfo?.loginTenantId && loginResult.userInfo?.loginTenantId!==0){
isMultiTenant.value = false;
return;
}
let tenantArr = loginResult.tenantList;
if (Array.isArray(tenantArr)) {
if (tenantArr.length === 0) {
isMultiTenant.value = false;
userStore.setTenant(formState.tenantId);
} else if (tenantArr.length === 1) {
formState.tenantId = tenantArr[0].id;
isMultiTenant.value = false;
userStore.setTenant(formState.tenantId);
} else {
isMultiTenant.value = true;
tenantList.value = tenantArr;
}
}
}
/**
* 确认选中的租户和部门信息
*/
function handleSubmit() {
if (unref(isMultiTenant) && !formState.tenantId) {
validate_status.value = 'error';
return false;
}
if (unref(isMultiDepart) && !formState.orgCode) {
validate_status1.value = 'error';
return false;
}
formRef.value
.validate()
.then(() => {
departResolve()
.then(() => {
userStore.setTenant(formState.tenantId);
emit('success');
})
.catch((e) => {
console.log('登录选择出现问题', e);
})
.finally(() => {
close();
});
})
.catch((err) => {
console.log('表单校验未通过error', err);
});
}
/**
*切换选择部门
*/
function departResolve() {
return new Promise((resolve, reject) => {
if (!unref(isMultiDepart) && !unref(isMultiTenant)) {
resolve();
} else {
let params = { orgCode: formState.orgCode,loginTenantId: formState.tenantId, username: unref(username) };
defHttp.put({ url: '/sys/selectDepart', params }).then((res) => {
if (res.userInfo) {
userStore.setUserInfo(res.userInfo);
resolve();
} else {
requestFailed(res);
userStore.logout();
reject();
}
});
}
});
}
/**
* 请求失败处理
*/
function requestFailed(err) {
notification.error({
message: '登录失败',
description: ((err.response || {}).data || {}).message || err.message || '请求出现错误,请稍后再试',
duration: 4,
});
}
/**
* 关闭model
*/
function close() {
closeModal();
reset();
}
/**
* 弹窗打开前处理
*/
async function show(loginResult) {
if (loginResult) {
username.value = userStore.username;
await reset();
await bizDepart(loginResult);
await bizTenantList(loginResult);
if (!unref(isMultiDepart) && !unref(isMultiTenant)) {
emit('success', userStore.getUserInfo);
} else {
visible.value = true;
}
}
//登录弹窗完成后,将登录的标识设置成false
loginResult.isLogin = false;
userStore.setLoginInfo(loginResult);
}
/**
*重置数据
*/
function reset() {
tenantList.value = [];
validate_status.value = '';
departList.value = [];
validate_status1.value = '';
}
function handleTenantChange(e) {
validate_status.value = '';
}
function handleDepartChange(e) {
validate_status1.value = '';
}
return {
registerModal,
visible,
tenantList,
isMultiTenant,
validate_status,
isMultiDepart,
departList,
validate_status1,
formState,
rules,
layout,
formRef,
currTitle,
config,
handleTenantChange,
handleDepartChange,
show,
handleSubmit,
};
},
});
</script>
<style lang="less" scoped>
.loginSelectForm {
margin-bottom: -20px;
}
.loginSelectModal {
top: 10px;
}
</style>