hrms-landing/src/views/home.vue
DESKTOP-1R2VSQH\Lenovo ThinkPad E490 141a7cbd31 ui home
2024-12-17 13:11:18 +07:00

336 lines
10 KiB
Vue

<script setup lang="ts">
import { deleteCookie, getCookie, setCookie } from "@/plugins/cookie";
import router from "@/router";
import { computed, onMounted, ref } from "vue";
import { useQuasar } from "quasar";
import axios from "axios";
import CustomComponent from "@/components/CustomDialog.vue";
const $q = useQuasar();
const urlAdmin = import.meta.env.VITE_URL_ADMIN ?? "";
const urlUser = import.meta.env.VITE_URL_USER ?? "";
const urlMgt = import.meta.env.VITE_URL_MGT ?? "";
const urlCheckin = import.meta.env.VITE_URL_CHECKIN ?? "";
const token = ref<any>("");
const refreshToken = ref<any>("");
const fullname = computed(() => {
if (token.value) {
const base64Url = token.value.split(".")[1];
// แปลงจาก Base64 URL-safe เป็น Base64 ปกติ
const base64 = base64Url.replace(/-/g, "+").replace(/_/g, "/");
// ถอดรหัส Base64
const decoded = atob(base64);
const decodedData = JSON.parse(decoded);
// ดึงชื่อผู้ใช้
return decodeURIComponent(escape(decodedData.name));
} else return "";
});
async function goPage(sys: string, url: string) {
// แยกส่วน Payload ของ JWT (ส่วนที่ 2)
const base64Url = token.value.split(".")[1];
// แปลงจาก Base64 URL-safe เป็น Base64 ปกติ
const base64 = base64Url.replace(/-/g, "+").replace(/_/g, "/");
// ถอดรหัส Base64
const decoded = atob(base64);
// กำหนด requiredRole ตามค่าของ sys
let requiredRole: string[] = [];
if (sys === "user" || sys === "checkin") {
requiredRole = ["USER"];
} else if (sys === "mgt") {
requiredRole = ["STAFF"]; // ถ้า sys เป็นค่าว่าง ให้ใช้ "ADMIN"
} else if (sys === "admin") {
requiredRole = ["ADMIN", "SUPER_ADMIN"];
}
console.log("requiredRole===>", requiredRole);
console.log("decoded===>", JSON.parse(decoded).realm_access.roles);
// ตรวจสอบว่า payload.role มีค่าหรือไม่ และว่ามี role ที่ต้องการหรือไม่
if (
requiredRole.some((role) =>
JSON.parse(decoded).realm_access.roles.includes(role)
)
) {
window.location.href = `${url}/auth?token=${token.value}&accessToken=${refreshToken.value}`;
} else {
// alert("คุณไม่มีสิทธิ์เข้าใช้งานระบบนี้");
$q.dialog({
component: CustomComponent,
componentProps: {
title: `แจ้งเตือน`,
message: "คุณไม่มีสิทธิ์เข้าใช้งานระบบนี้",
icon: "warning",
color: "red",
onlycancel: true,
},
});
}
}
async function logout() {
await deleteCookie("BMAHRIS_KEYCLOAK_IDENTITY");
await deleteCookie("BMAHRIS_KEYCLOAK_REFRESH");
router.push("/sso");
}
onMounted(async () => {
token.value = await getCookie("BMAHRIS_KEYCLOAK_IDENTITY");
refreshToken.value = await getCookie("BMAHRIS_KEYCLOAK_REFRESH");
deleteCookie("BMAHRISADM_KEYCLOAK_IDENTITY");
deleteCookie("BMAHRISCKI_KEYCLOAK_IDENTITY");
deleteCookie("BMAHRISUSER_KEYCLOAK_IDENTITY");
const checkToken = (await token.value) ?? null;
if (!checkToken && !token.value) {
await axios
.post(
`${import.meta.env.VITE_URL_SSO}/kcauth`,
{},
{
headers: {
"Content-Type": "application/json",
},
withCredentials: true, // Include cookies with the request
}
)
.then((res: any) => {
console.log("res===>", res);
if (res.status === 200) {
setCookie("BMAHRIS_KEYCLOAK_IDENTITY", res.data.access_token, 1);
setCookie("BMAHRIS_KEYCLOAK_REFRESH", res.data.refresh_token, 1);
}
})
.catch((err: any) => {
router.push("/sso");
});
}
});
const cards = ref<any[]>([
{
label: "ระบบบริการเจ้าของข้อมูล",
img: "https://bma-sso.frappet.synology.me/images/screen1.png",
page: "user",
url: "urlUser",
},
{
label: "ระบบลงเวลาปฏิบัติราชการ",
img: "https://bma-sso.frappet.synology.me/images/screen2.png",
page: "checkin",
url: "urlCheckin",
},
{
label: "ระบบบริหารจัดการ",
img: "https://bma-sso.frappet.synology.me/images/screen3.png",
page: "mgt",
url: "urlMgt",
},
{
label: "ระบบแอดมิน",
img: "https://bma-sso.frappet.synology.me/images/screen4.png",
page: "admin",
url: "urlAdmin",
},
]);
</script>
<template>
<!-- Background Image -->
<div class="bg-img h-50 fixed-top" style="z-index: -1">
<img
alt=""
src="https://bma-sso.frappet.synology.me/images/line2.png"
class="img_absolute_line"
/>
</div>
<div class="row justify-center">
<div class="col-9">
<q-toolbar style="padding: 0px">
<div class="row items-center q-px-md q-py-sm">
<q-img
src="https://bma-sso.frappet.synology.me/images/sso.png"
style="width: 80px"
/>
<div class="text-white q-ml-md">
<div class="text-grey-5 text-caption">
Bangkok Metropolitan Administration
</div>
<div class="text-bold">Single Sign-On</div>
</div>
</div>
<q-space />
<div class="row items-center">
<div class="text-white q-mr-md">{{ fullname }}</div>
<q-btn @click="logout()" class="btn_logout">
ออกจากระบบ <i class="mdi mdi-logout"></i>
</q-btn>
</div>
</q-toolbar>
<!-- Title Section -->
<div class="text-white text-center q-mt-lg">
<div class="text-h5 text-bold">
ระบบบรหารทรพยากรบคคลของกรงเทพมหานคร
</div>
<div class="text-caption q-mt-sm">
Human Resource Management System (HRMS)
</div>
</div>
<!-- Card Section justify-center-->
<div class="q-mt-xl">
<div class="row q-col-gutter-md">
<div class="col" v-for="(card, index) in cards" :key="index">
<q-card
bordered
class="my-card"
:class="index % 2 === 0 ? 'my-card' : 'my-card card-right'"
>
<q-img :src="card.img" />
<q-card-section>
<div class="row col-12">
<q-btn
outline
class="full-width"
color="primary"
:label="card.label"
@click="
goPage(
card.page,
card.page === 'user'
? urlUser
: card.page === 'checkin'
? urlCheckin
: card.page === 'mgt'
? urlMgt
: card.page === 'admin'
? urlAdmin
: ''
)
"
/>
</div>
</q-card-section>
</q-card>
</div>
</div>
</div>
</div>
</div>
<!-- <div class="q-ma-md">
<div class="row">
{{ fullname }}
<q-btn @click="logout()" class="btn_logout">
ออกจากระบบ <i class="mdi mdi-logout"></i>
</q-btn>
</div>
<div class="row">
<div class="col-4">
<img src="@/assets/screen1.png" style="width: 100%" />
<div class="h-100 py-3">
<a @click="goPage('user', urlUser)" class="link">
ระบบบรการเจาของขอม
</a>
</div>
</div>
<div class="col-4">
<img src="@/assets/screen2.png" style="width: 100%" />
<div class="h-100 py-3">
<a @click="goPage('checkin', urlCheckin)" class="link">
ระบบลงเวลาปฏราชการ
</a>
</div>
</div>
<div class="col-4">
<img src="@/assets/screen3.png" style="width: 100%" />
<div class="h-100 py-3">
<a @click="goPage('mgt', urlMgt)" class="link"> ระบบบรหารจดการ </a>
</div>
</div>
<div class="col-4">
<img src="@/assets/screen4.png" style="width: 100%" />
<div class="h-100 py-3">
<a @click="goPage('admin', urlAdmin)" class="link"> ระบบแอดม </a>
</div>
</div>
</div>
</div> -->
</template>
<style lang="scss" scoped>
.my-card {
width: 100%;
border: 1px solid rgb(255, 255, 255);
border-radius: 12px; /* มุมโค้งมน */
transition: all 0.3s ease; /* ทำให้การเปลี่ยนแปลงดูนุ่มนวล */
box-shadow: 0 8px 16px rgba(0, 0, 0, 0.3); /* เพิ่มเงาเมื่อ hover */
}
.card-left {
transform: translateY(-5px);
}
.card-right {
transform: translateY(30px); /* เลื่อนการ์ดลงเล็กน้อย */
}
.btn_logout {
text-align: center;
text-decoration: none;
background-color: rgba(255, 255, 255, 0.2);
cursor: pointer;
border: 0;
padding: 8px 10px 8px 10px;
border-radius: 50px;
color: #fff;
font-size: 16px;
font-weight: 400;
width: 250px;
}
.btn_logout:hover {
color: #fff;
background-color: #00ffc8a1;
transition: 0.8s;
box-shadow: rgba(255, 255, 255, 0.16) 0px 10px 36px 0px,
rgba(255, 255, 255, 0.06) 0px 0px 0px 1px;
}
.img_absolute_line {
position: absolute;
height: 100%;
width: auto;
left: 0;
bottom: 0;
}
.bg-img {
background: rgb(30, 50, 49);
background: linear-gradient(
90deg,
rgba(30, 50, 49, 1) 0%,
rgba(20, 120, 99, 1) 100%
);
min-height: 480px;
}
</style>