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
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>
|