You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

277 lines
5.0 KiB

<template>
<div class="total">
<div
class="box"
:class="{ 'box-animaToR': isAnimating, 'box-animaToL': !isAnimating }"
@click="startAnimation1"
>
<div v-if="!isTextAnimating">
<span class="title" :class="{ 'title-animaT': isAnimating }"
>管理员登录</span
>
<el-icon
class="right"
:class="{ 'arrow-anima': !isAnimating, 'title-animaT': isAnimating }"
>
<Right />
</el-icon>
</div>
<div v-else>
<span class="title" :class="{ 'title-animaT': !isAnimating }"
>用户登录</span
>
<el-icon
class="left"
:class="{ 'arrow-anima': isAnimating, 'title-animaT': !isAnimating }"
>
<Back />
</el-icon>
</div>
</div>
<div class="login admin">
<div class="loginTitle">管理员登录</div>
<el-form :model="userInfo" label-width="auto" style="max-width: 600px">
<el-form-item label="账号">
<el-input v-model="userInfo.username" />
</el-form-item>
<el-form-item label="密码">
<el-input v-model="userInfo.password" />
</el-form-item>
<el-form-item>
<el-button type="success" style="width: 100%" @click="login()"
>登录</el-button
>
</el-form-item>
</el-form>
</div>
</div>
</template>
<script setup>
import { ref, onMounted } from "vue";
import axios from "axios";
import API from "@/util/http";
import { useRouter } from "vue-router";
import { ElMessage, ElMessageBox } from "element-plus";
const router = useRouter();
const firstAnimating = ref(false);
const isAnimating = ref(false);
const isTextAnimating = ref(false);
const startAnimation = () => {
isAnimating.value = !isAnimating.value;
setTimeout(() => {
isTextAnimating.value = !isTextAnimating.value;
}, 400);
};
const userInfo = ref({
username: "12345678",
password: "123456",
});
const getQueryVariable = (variable) => {
const href = window.location.href;
const query = href.split("?")[1];
console.log("query", query);
const vars = query.split("&");
for (let i = 0; i < vars.length; i++) {
const pair = vars[i].split("=");
if (pair[0] === variable) {
return pair[1];
}
}
return "";
};
const login = async function () {
const machineId = getQueryVariable("machineId");
console.log(machineId);
try {
const result = await axios.post(`http://18.143.76.3:10704/admin/login`, {
account: userInfo.value.username,
password: userInfo.value.password,
machineId: machineId,
});
// const result = await API({
// url: "/admin/login",
// data: {
// account: userInfo.username,
// password: userInfo.password,
// machineId: "",
// },
// });
console.log("请求成功", result);
if (result.data.code == 200) {
ElMessage.success('登录成功');
router.push({
name: "workspace",
});
} else {
ElMessage.error(result.data.msg);
}
} catch (error) {
console.log("请求失败", error);
}
};
</script>
<style scoped>
.login {
position: absolute;
z-index: 1;
width: 30%;
}
.loginTitle {
font-size: 48px;
font-weight: bold;
margin-bottom: 20px;
text-align: center;
}
.user {
top: 30%;
left: 10%;
}
.admin {
top: 30%;
left: 55%;
}
.total {
width: 100%;
height: 100%;
display: flex;
}
.title {
position: absolute;
font-size: 48px;
font-weight: bold;
top: 40%;
left: 30%;
z-index: 2;
}
.title-animaT {
animation: textAnimaT 0.7s forwards;
}
.title-animaF {
animation: textAnimaF 0.7s forwards;
}
@keyframes textAnimaF {
0% {
opacity: 1;
}
50% {
opacity: 0;
}
100% {
opacity: 0;
}
}
@keyframes textAnimaT {
0% {
opacity: 1;
}
50% {
opacity: 0;
}
100% {
opacity: 0;
}
}
.box {
width: 50%;
height: 100%;
margin: 0;
background: linear-gradient(90deg, #ffae00, #ffffff);
border-radius: 5%;
z-index: 99;
}
.box-animaToR {
animation: animaToR 1s forwards;
}
.box-animaToL {
animation: animaToL 1s forwards;
}
@keyframes animaToR {
0% {
transform: translateX(0) scaleX(1);
background: linear-gradient(90deg, #ffffff, #29e6ff);
}
/* 50% {
transform: translateX(50%) scaleX(2);
} */
100% {
transform: translateX(100%) scaleX(1);
background: linear-gradient(90deg, #ffffff, #29e6ff);
}
}
@keyframes animaToL {
0% {
transform: translateX(100%) scaleX(1);
}
/* 50% {
transform: translateX(50%) scaleX(2);
} */
100% {
transform: translateX(0%) scaleX(1);
background: linear-gradient(90deg, #ffae00, #ffffff);
}
}
.right {
position: absolute;
right: 10%;
top: 40%;
font-size: 72px;
}
.left {
position: absolute;
left: 10%;
top: 40%;
font-size: 72px;
z-index: 2;
}
.arrow-anima {
animation: arrowAnima 1s infinite;
}
@keyframes arrowAnima {
0% {
transform: translateX(0);
}
50% {
transform: translateX(10px);
}
100% {
transform: translateX(0);
}
}
</style>