|
@@ -9,24 +9,24 @@
|
|
|
label-width="120px"
|
|
label-width="120px"
|
|
|
size="large"
|
|
size="large"
|
|
|
>
|
|
>
|
|
|
- <el-row class="mx-[-10px]">
|
|
|
|
|
- <el-col :span="24" class="px-10px">
|
|
|
|
|
|
|
+ <el-row style="margin-right: -10px; margin-left: -10px">
|
|
|
|
|
+ <el-col :span="24" style="padding-right: 10px; padding-left: 10px">
|
|
|
<el-form-item>
|
|
<el-form-item>
|
|
|
- <LoginFormTitle class="w-full" />
|
|
|
|
|
|
|
+ <LoginFormTitle style="width: 100%" />
|
|
|
</el-form-item>
|
|
</el-form-item>
|
|
|
</el-col>
|
|
</el-col>
|
|
|
- <el-col :span="24" class="px-10px">
|
|
|
|
|
- <el-form-item v-if="loginData.tenantEnable === 'true'" prop="tenantName">
|
|
|
|
|
- <el-input
|
|
|
|
|
- v-model="loginData.loginForm.tenantName"
|
|
|
|
|
- :placeholder="t('login.tenantNamePlaceholder')"
|
|
|
|
|
- :prefix-icon="iconHouse"
|
|
|
|
|
- link
|
|
|
|
|
- type="primary"
|
|
|
|
|
- />
|
|
|
|
|
- </el-form-item>
|
|
|
|
|
- </el-col>
|
|
|
|
|
- <el-col :span="24" class="px-10px">
|
|
|
|
|
|
|
+ <!-- <el-col :span="24" style="padding-right: 10px; padding-left: 10px">-->
|
|
|
|
|
+ <!-- <el-form-item v-if="loginData.tenantEnable === 'true'" prop="tenantName">-->
|
|
|
|
|
+ <!-- <el-input-->
|
|
|
|
|
+ <!-- v-model="loginData.loginForm.tenantName"-->
|
|
|
|
|
+ <!-- :placeholder="t('login.tenantNamePlaceholder')"-->
|
|
|
|
|
+ <!-- :prefix-icon="iconHouse"-->
|
|
|
|
|
+ <!-- link-->
|
|
|
|
|
+ <!-- type="primary"-->
|
|
|
|
|
+ <!-- />-->
|
|
|
|
|
+ <!-- </el-form-item>-->
|
|
|
|
|
+ <!-- </el-col>-->
|
|
|
|
|
+ <el-col :span="24" style="padding-right: 10px; padding-left: 10px; margin-top: 30px">
|
|
|
<el-form-item prop="username">
|
|
<el-form-item prop="username">
|
|
|
<el-input
|
|
<el-input
|
|
|
v-model="loginData.loginForm.username"
|
|
v-model="loginData.loginForm.username"
|
|
@@ -35,7 +35,7 @@
|
|
|
/>
|
|
/>
|
|
|
</el-form-item>
|
|
</el-form-item>
|
|
|
</el-col>
|
|
</el-col>
|
|
|
- <el-col :span="24" class="px-10px">
|
|
|
|
|
|
|
+ <el-col :span="24" style="padding-right: 10px; padding-left: 10px; margin-top: 15px">
|
|
|
<el-form-item prop="password">
|
|
<el-form-item prop="password">
|
|
|
<el-input
|
|
<el-input
|
|
|
v-model="loginData.loginForm.password"
|
|
v-model="loginData.loginForm.password"
|
|
@@ -47,7 +47,10 @@
|
|
|
/>
|
|
/>
|
|
|
</el-form-item>
|
|
</el-form-item>
|
|
|
</el-col>
|
|
</el-col>
|
|
|
- <el-col :span="24" class="px-10px mt-[-20px] mb-[-20px]">
|
|
|
|
|
|
|
+ <el-col
|
|
|
|
|
+ :span="24"
|
|
|
|
|
+ style="padding-right: 10px; padding-left: 10px; margin-top: -10px; margin-bottom: -20px"
|
|
|
|
|
+ >
|
|
|
<el-form-item>
|
|
<el-form-item>
|
|
|
<el-row justify="space-between" style="width: 100%">
|
|
<el-row justify="space-between" style="width: 100%">
|
|
|
<el-col :span="6">
|
|
<el-col :span="6">
|
|
@@ -57,7 +60,7 @@
|
|
|
</el-col>
|
|
</el-col>
|
|
|
<el-col :offset="6" :span="12">
|
|
<el-col :offset="6" :span="12">
|
|
|
<el-link
|
|
<el-link
|
|
|
- class="float-right"
|
|
|
|
|
|
|
+ style="float: right"
|
|
|
type="primary"
|
|
type="primary"
|
|
|
@click="setLoginState(LoginStateEnum.RESET_PASSWORD)"
|
|
@click="setLoginState(LoginStateEnum.RESET_PASSWORD)"
|
|
|
>
|
|
>
|
|
@@ -67,12 +70,12 @@
|
|
|
</el-row>
|
|
</el-row>
|
|
|
</el-form-item>
|
|
</el-form-item>
|
|
|
</el-col>
|
|
</el-col>
|
|
|
- <el-col :span="24" class="px-10px">
|
|
|
|
|
|
|
+ <el-col :span="24" style="padding-right: 10px; padding-left: 10px">
|
|
|
<el-form-item>
|
|
<el-form-item>
|
|
|
<XButton
|
|
<XButton
|
|
|
:loading="loginLoading"
|
|
:loading="loginLoading"
|
|
|
:title="t('login.login')"
|
|
:title="t('login.login')"
|
|
|
- class="w-full"
|
|
|
|
|
|
|
+ class="w-[100%]"
|
|
|
type="primary"
|
|
type="primary"
|
|
|
@click="getCode()"
|
|
@click="getCode()"
|
|
|
/>
|
|
/>
|
|
@@ -86,64 +89,33 @@
|
|
|
mode="pop"
|
|
mode="pop"
|
|
|
@success="handleLogin"
|
|
@success="handleLogin"
|
|
|
/>
|
|
/>
|
|
|
- <el-col :span="24" class="px-10px">
|
|
|
|
|
|
|
+ <el-col :span="24" style="padding-right: 10px; padding-left: 10px">
|
|
|
<el-form-item>
|
|
<el-form-item>
|
|
|
<el-row :gutter="5" justify="space-between" style="width: 100%">
|
|
<el-row :gutter="5" justify="space-between" style="width: 100%">
|
|
|
- <el-col :span="8">
|
|
|
|
|
- <XButton
|
|
|
|
|
- :title="t('login.btnMobile')"
|
|
|
|
|
- class="w-full"
|
|
|
|
|
- @click="setLoginState(LoginStateEnum.MOBILE)"
|
|
|
|
|
- />
|
|
|
|
|
- </el-col>
|
|
|
|
|
- <el-col :span="8">
|
|
|
|
|
|
|
+ <!-- <el-col :span="8">-->
|
|
|
|
|
+ <!-- <XButton-->
|
|
|
|
|
+ <!-- :title="t('login.btnMobile')"-->
|
|
|
|
|
+ <!-- class="w-[100%]"-->
|
|
|
|
|
+ <!-- @click="setLoginState(LoginStateEnum.MOBILE)"-->
|
|
|
|
|
+ <!-- />-->
|
|
|
|
|
+ <!-- </el-col>-->
|
|
|
|
|
+ <el-col :span="24">
|
|
|
<XButton
|
|
<XButton
|
|
|
:title="t('login.btnQRCode')"
|
|
:title="t('login.btnQRCode')"
|
|
|
- class="w-full"
|
|
|
|
|
|
|
+ class="w-[100%]"
|
|
|
@click="setLoginState(LoginStateEnum.QR_CODE)"
|
|
@click="setLoginState(LoginStateEnum.QR_CODE)"
|
|
|
/>
|
|
/>
|
|
|
</el-col>
|
|
</el-col>
|
|
|
- <el-col :span="8">
|
|
|
|
|
- <XButton
|
|
|
|
|
- :title="t('login.btnRegister')"
|
|
|
|
|
- class="w-full"
|
|
|
|
|
- @click="setLoginState(LoginStateEnum.REGISTER)"
|
|
|
|
|
- />
|
|
|
|
|
- </el-col>
|
|
|
|
|
|
|
+ <!-- <el-col :span="12">-->
|
|
|
|
|
+ <!-- <XButton-->
|
|
|
|
|
+ <!-- :title="t('login.btnRegister')"-->
|
|
|
|
|
+ <!-- class="w-[100%]"-->
|
|
|
|
|
+ <!-- @click="setLoginState(LoginStateEnum.REGISTER)"-->
|
|
|
|
|
+ <!-- />-->
|
|
|
|
|
+ <!-- </el-col>-->
|
|
|
</el-row>
|
|
</el-row>
|
|
|
</el-form-item>
|
|
</el-form-item>
|
|
|
</el-col>
|
|
</el-col>
|
|
|
- <el-divider content-position="center">{{ t('login.otherLogin') }}</el-divider>
|
|
|
|
|
- <el-col :span="24" class="px-10px">
|
|
|
|
|
- <el-form-item>
|
|
|
|
|
- <div class="w-full flex justify-between">
|
|
|
|
|
- <Icon
|
|
|
|
|
- v-for="(item, key) in socialList"
|
|
|
|
|
- :key="key"
|
|
|
|
|
- :icon="item.icon"
|
|
|
|
|
- :size="30"
|
|
|
|
|
- class="anticon cursor-pointer"
|
|
|
|
|
- color="#999"
|
|
|
|
|
- @click="doSocialLogin(item.type)"
|
|
|
|
|
- />
|
|
|
|
|
- </div>
|
|
|
|
|
- </el-form-item>
|
|
|
|
|
- </el-col>
|
|
|
|
|
- <el-divider content-position="center">萌新必读</el-divider>
|
|
|
|
|
- <el-col :span="24" class="px-10px">
|
|
|
|
|
- <el-form-item>
|
|
|
|
|
- <div class="w-full flex justify-between">
|
|
|
|
|
- <el-link href="https://doc.iocoder.cn/" target="_blank">📚开发指南</el-link>
|
|
|
|
|
- <el-link href="https://doc.iocoder.cn/video/" target="_blank">🔥视频教程</el-link>
|
|
|
|
|
- <el-link href="https://www.iocoder.cn/Interview/good-collection/" target="_blank">
|
|
|
|
|
- ⚡面试手册
|
|
|
|
|
- </el-link>
|
|
|
|
|
- <el-link href="http://static.yudao.iocoder.cn/mp/Aix9975.jpeg" target="_blank">
|
|
|
|
|
- 🤝外包咨询
|
|
|
|
|
- </el-link>
|
|
|
|
|
- </div>
|
|
|
|
|
- </el-form-item>
|
|
|
|
|
- </el-col>
|
|
|
|
|
</el-row>
|
|
</el-row>
|
|
|
</el-form>
|
|
</el-form>
|
|
|
</template>
|
|
</template>
|
|
@@ -174,7 +146,7 @@ const permissionStore = usePermissionStore()
|
|
|
const redirect = ref<string>('')
|
|
const redirect = ref<string>('')
|
|
|
const loginLoading = ref(false)
|
|
const loginLoading = ref(false)
|
|
|
const verify = ref()
|
|
const verify = ref()
|
|
|
-const captchaType = ref('blockPuzzle') // blockPuzzle 滑块 clickWord 点击文字 pictureWord 文字验证码
|
|
|
|
|
|
|
+const captchaType = ref('blockPuzzle') // blockPuzzle 滑块 clickWord 点击文字
|
|
|
|
|
|
|
|
const getShow = computed(() => unref(getLoginState) === LoginStateEnum.LOGIN)
|
|
const getShow = computed(() => unref(getLoginState) === LoginStateEnum.LOGIN)
|
|
|
|
|
|
|
@@ -189,10 +161,10 @@ const loginData = reactive({
|
|
|
tenantEnable: import.meta.env.VITE_APP_TENANT_ENABLE,
|
|
tenantEnable: import.meta.env.VITE_APP_TENANT_ENABLE,
|
|
|
loginForm: {
|
|
loginForm: {
|
|
|
tenantName: import.meta.env.VITE_APP_DEFAULT_LOGIN_TENANT || '',
|
|
tenantName: import.meta.env.VITE_APP_DEFAULT_LOGIN_TENANT || '',
|
|
|
- username: import.meta.env.VITE_APP_DEFAULT_LOGIN_USERNAME || '',
|
|
|
|
|
- password: import.meta.env.VITE_APP_DEFAULT_LOGIN_PASSWORD || '',
|
|
|
|
|
|
|
+ // username: import.meta.env.VITE_APP_DEFAULT_LOGIN_USERNAME || '',
|
|
|
|
|
+ // password: import.meta.env.VITE_APP_DEFAULT_LOGIN_PASSWORD || '',
|
|
|
captchaVerification: '',
|
|
captchaVerification: '',
|
|
|
- rememberMe: true // 默认记录我。如果不需要,可手动修改
|
|
|
|
|
|
|
+ rememberMe: false // 默认记录我。如果不需要,可手动修改
|
|
|
}
|
|
}
|
|
|
})
|
|
})
|
|
|
|
|
|
|
@@ -218,6 +190,7 @@ const getCode = async () => {
|
|
|
const getTenantId = async () => {
|
|
const getTenantId = async () => {
|
|
|
if (loginData.tenantEnable === 'true') {
|
|
if (loginData.tenantEnable === 'true') {
|
|
|
const res = await LoginApi.getTenantIdByName(loginData.loginForm.tenantName)
|
|
const res = await LoginApi.getTenantIdByName(loginData.loginForm.tenantName)
|
|
|
|
|
+ debugger
|
|
|
authUtil.setTenantId(res)
|
|
authUtil.setTenantId(res)
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
@@ -227,22 +200,20 @@ const getLoginFormCache = () => {
|
|
|
if (loginForm) {
|
|
if (loginForm) {
|
|
|
loginData.loginForm = {
|
|
loginData.loginForm = {
|
|
|
...loginData.loginForm,
|
|
...loginData.loginForm,
|
|
|
- username: loginForm.username ? loginForm.username : loginData.loginForm.username,
|
|
|
|
|
- password: loginForm.password ? loginForm.password : loginData.loginForm.password,
|
|
|
|
|
- rememberMe: loginForm.rememberMe,
|
|
|
|
|
|
|
+ // username: loginForm.username ? loginForm.username : loginData.loginForm.username,
|
|
|
|
|
+ // password: loginForm.password ? loginForm.password : loginData.loginForm.password,
|
|
|
|
|
+ // rememberMe: loginForm.rememberMe,
|
|
|
tenantName: loginForm.tenantName ? loginForm.tenantName : loginData.loginForm.tenantName
|
|
tenantName: loginForm.tenantName ? loginForm.tenantName : loginData.loginForm.tenantName
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
// 根据域名,获得租户信息
|
|
// 根据域名,获得租户信息
|
|
|
const getTenantByWebsite = async () => {
|
|
const getTenantByWebsite = async () => {
|
|
|
- if (loginData.tenantEnable === 'true') {
|
|
|
|
|
- const website = location.host
|
|
|
|
|
- const res = await LoginApi.getTenantByWebsite(website)
|
|
|
|
|
- if (res) {
|
|
|
|
|
- loginData.loginForm.tenantName = res.name
|
|
|
|
|
- authUtil.setTenantId(res.id)
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ const website = location.host
|
|
|
|
|
+ const res = await LoginApi.getTenantByWebsite(website)
|
|
|
|
|
+ if (res) {
|
|
|
|
|
+ loginData.loginForm.tenantName = res.name
|
|
|
|
|
+ authUtil.setTenantId(res.id)
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
const loading = ref() // ElLoading.service 返回的实例
|
|
const loading = ref() // ElLoading.service 返回的实例
|
|
@@ -258,14 +229,16 @@ const handleLogin = async (params: any) => {
|
|
|
const loginDataLoginForm = { ...loginData.loginForm }
|
|
const loginDataLoginForm = { ...loginData.loginForm }
|
|
|
loginDataLoginForm.captchaVerification = params.captchaVerification
|
|
loginDataLoginForm.captchaVerification = params.captchaVerification
|
|
|
const res = await LoginApi.login(loginDataLoginForm)
|
|
const res = await LoginApi.login(loginDataLoginForm)
|
|
|
- if (!res) {
|
|
|
|
|
- return
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ // if (!res) {
|
|
|
|
|
+ // return
|
|
|
|
|
+ // }
|
|
|
|
|
+ console.log('res :>> ', res)
|
|
|
loading.value = ElLoading.service({
|
|
loading.value = ElLoading.service({
|
|
|
lock: true,
|
|
lock: true,
|
|
|
text: '正在加载系统中...',
|
|
text: '正在加载系统中...',
|
|
|
background: 'rgba(0, 0, 0, 0.7)'
|
|
background: 'rgba(0, 0, 0, 0.7)'
|
|
|
})
|
|
})
|
|
|
|
|
+ console.log('loginDataLoginForm.rememberMe :>> ', loginDataLoginForm.rememberMe)
|
|
|
if (loginDataLoginForm.rememberMe) {
|
|
if (loginDataLoginForm.rememberMe) {
|
|
|
authUtil.setLoginForm(loginDataLoginForm)
|
|
authUtil.setLoginForm(loginDataLoginForm)
|
|
|
} else {
|
|
} else {
|