hrms-user/src/modules/10_registry/views/main.vue
2025-03-19 09:45:12 +07:00

347 lines
13 KiB
Vue

<script setup lang="ts">
import { ref } from "vue";
import { useCounterMixin } from "@/stores/mixin";
import { useDataStore } from "@/stores/data";
import { useRegistryInFormationStore } from "@/modules/10_registry/store/registry";
import genReport from "@/plugins/genreport";
//หน้าเมนู
import InformationPage from "@/modules/10_registry/tabs/01_information.vue";
import GovernmentPage from "@/modules/10_registry/tabs/02_government.vue";
import SalaryPage from "@/modules/10_registry/tabs/03_salary.vue";
import Certificate from "@/modules/10_registry/tabs/04_Achievement.vue";
import OtherPage from "@/modules/10_registry/tabs/05_other.vue";
import { useRouter } from "vue-router";
import http from "@/plugins/http";
import config from "@/app.config";
import { useQuasar } from "quasar";
const store = useRegistryInFormationStore();
const $q = useQuasar();
const dataStore = useDataStore();
const mixin = useCounterMixin();
const { messageError, showLoader, hideLoader } = mixin;
const router = useRouter();
const tab = ref<string>("information");
const sizeImg = ref<string>("");
function onResize(size: any) {
const width = size.width > 100 ? 100 : size.width;
sizeImg.value = `${width}px`;
}
function onMobile(type: string) {
router.push(`/registry/${type}`);
}
async function onClickDownloadKp7(type: string) {
showLoader();
const url =
type === "FULL"
? config.API.profileReportId(
store.profileId,
dataStore.officerType == "OFFICER" ? "profile" : "profile-employee"
)
: config.API.profileKp7ShortId(
store.profileId,
dataStore.officerType == "OFFICER" ? "profile" : "profile-employee"
);
const fileName = type === "FULL" ? "ก.พ.7/ก.ก.1" : "ประวัติแบบย่อ";
await http
.get(url)
.then(async (res) => {
const data = await res.data.result;
await genReport(data, fileName, "pdf");
})
.catch((err) => {
messageError($q, err);
})
.finally(() => {
hideLoader();
});
}
/**
* ฟังชั่นกลับหน้าหลัก
*/
const clickBack = () => {
router.push(`/`);
};
/**
* function redirect ไปหน้ารายการคำร้องขอแก้ไขข้อมูล
*/
function redirectToPagePetition() {
router.push(`/registry/request-edit`);
}
</script>
<template>
<div class="row justify-center">
<div class="col-xs-12 col-sm-12 col-md-11">
<div class="toptitle text-white col-12 row items-center">
<q-btn
icon="mdi-arrow-left"
unelevated
round
dense
flat
color="primary"
class="q-mr-sm"
@click="clickBack"
/>
อมลทะเบยนประว <q-space />
<q-btn
color="primary"
label="ยื่นคำร้องขอแก้ไขข้อมูล"
@click="redirectToPagePetition"
>
<q-tooltip>นคำรองขอแกไขขอม</q-tooltip>
</q-btn>
</div>
<div v-if="$q.screen.gt.xs" class="row q-col-gutter-md">
<div class="col-3">
<q-card bordered>
<q-resize-observer @resize="onResize" />
<q-card-section>
<div class="relative-position" style="height: 120px">
<div class="absolute-center">
<q-avatar size="120px" class="bg-grey-2">
<q-img :src="dataStore.profileImg" />
</q-avatar>
</div>
</div>
<div class="column text-center q-mt-md q-mb-sm">
<span class="text-teal text-weight-medium">{{
dataStore.formData.firstName
? `${
dataStore.formData.rank
? dataStore.formData.rank
: dataStore.formData.prefix
}${dataStore.formData.firstName} ${
dataStore.formData.lastName
}`
: "-"
}}</span>
<span class="text-grey text-weight-medium">{{
dataStore.officerType == "OFFICER"
? `ข้าราชการกรุงเทพมหานครสามัญ`
: dataStore.officerType == "PERM"
? "ลูกจ้างประจำกรุงเทพมหานคร"
: "ลูกจ้างชั่วคราว"
}}</span>
<span class="text-grey text-weight-medium">{{
dataStore.formData.position
? `${dataStore.formData.position}`
: "-"
}}</span>
<div class="text-grey">{{ dataStore.formData.posNo }}</div>
</div>
</q-card-section>
<q-list separator class="q-mt-md">
<!-- <q-separator />
<q-item>
<q-item-section class="text-grey-6">{{
dataStore.officerType == "OFFICER" ? "ตำแหน่งในสายงาน" : "ตำแหน่ง"
}}</q-item-section>
<q-item-section>{{ formData.posExecutiveName }}</q-item-section>
</q-item> -->
<q-item>
<q-item-section class="text-grey-6">{{
dataStore.officerType == "OFFICER"
? "ตำแหน่งประเภท"
: "กลุ่มงาน"
}}</q-item-section>
<q-item-section>{{
dataStore.formData.posTypeName
? dataStore.formData.posTypeName
: "-"
}}</q-item-section>
</q-item>
<q-item>
<q-item-section class="text-grey-6">{{
dataStore.officerType == "OFFICER" ? "ระดับ" : "ระดับชั้นงาน"
}}</q-item-section>
<q-item-section>{{
dataStore.formData.posLevelName
? dataStore.formData.posLevelName
: "-"
}}</q-item-section>
</q-item>
</q-list>
<q-card-section class="q-gutter-y-sm">
<q-btn
class="full-width"
unelevated
color="blue-6"
@click="onClickDownloadKp7('SHORT')"
><q-icon left size="2em" name="mdi-file-download-outline" />
<div>ดาวน์โหลดประวัติแบบย่อ</div></q-btn
>
<q-btn
class="full-width"
unelevated
color="primary"
@click="onClickDownloadKp7('FULL')"
><q-icon left size="2em" name="mdi-folder-download-outline" />
<div>ดาวน์โหลด ก.พ.7/ก.ก. 1</div></q-btn
>
</q-card-section>
</q-card>
</div>
<div class="col-9">
<q-card bordered>
<q-tabs
v-model="tab"
inline-label
active-color="blue-6"
class="bg-grey-1 text-grey-6 shadow-2"
align="left"
>
<q-tab
name="information"
label="ข้อมูลส่วนตัว"
class="bg-active"
/>
<q-tab name="government" label="ข้อมูลราชการ" />
<q-tab name="salary" label="ข้อมูลเงินเดือน/ค่าจ้าง" />
<q-tab name="insignia" label="ข้อมูลผลงาน" />
<q-tab name="other" label="ข้อมูลอื่นๆ" />
</q-tabs>
<q-separator />
<!-- รายการเเต่ละหน้า -->
<q-tab-panels v-model="tab" animated>
<q-tab-panel name="information">
<InformationPage />
</q-tab-panel>
<q-tab-panel name="government">
<GovernmentPage />
</q-tab-panel>
<q-tab-panel name="salary">
<SalaryPage />
</q-tab-panel>
<q-tab-panel name="insignia">
<Certificate />
</q-tab-panel>
<q-tab-panel name="other">
<OtherPage />
</q-tab-panel>
</q-tab-panels>
</q-card>
</div>
</div>
<div v-else>
<q-card bordered>
<q-resize-observer @resize="onResize" />
<q-card-section>
<div class="text-center q-mt-md">
<q-avatar :size="sizeImg">
<img
:src="dataStore.profileImg"
style="border-radius: 50%; object-fit: cover"
/>
</q-avatar>
</div>
<div class="column text-center q-mt-md q-mb-lg">
<span class="text-teal text-weight-medium">{{
dataStore.formData.firstName
? `${dataStore.formData.prefix}${dataStore.formData.firstName} ${dataStore.formData.lastName}`
: "-"
}}</span>
<span class="text-grey text-weight-medium">{{
dataStore.officerType == "OFFICER"
? `ข้าราชการกรุงเทพมหานครสามัญ`
: "ลูกจ้างประจำกรุงเทพมหานคร"
}}</span>
<span class="text-grey text-weight-medium">{{
dataStore.formData.position
? `${dataStore.formData.position}`
: "-"
}}</span>
<div class="text-grey">{{ dataStore.formData.posNo }}</div>
</div>
<div class="row justify-center q-gutter-x-lg">
<q-btn
color="light-blue-1"
dense
round
unelevated
text-color="light-blue-5"
size="14px"
icon="mdi-file-download-outline"
@click="onClickDownloadKp7('SHORT')"
>
<q-tooltip>ดาวนโหลดประวแบบย </q-tooltip></q-btn
>
<q-btn
color="teal-1"
text-color="primary"
dense
unelevated
round
size="14px"
icon="mdi-folder-download-outline"
@click="onClickDownloadKp7('FULL')"
>
<q-tooltip>ดาวนโหลด ..7/.. 1</q-tooltip>
</q-btn>
</div>
</q-card-section>
<q-list separator class="q-mt-md">
<q-item clickable v-ripple @click="onMobile('information')">
<q-item-section>อมลสวนต</q-item-section>
<q-item-section avatar>
<q-avatar text-color="info" icon="mdi-chevron-right" />
</q-item-section>
</q-item>
<q-item clickable v-ripple @click="onMobile('government')">
<q-item-section>อมลราชการ</q-item-section>
<q-item-section avatar>
<q-avatar text-color="info" icon="mdi-chevron-right" />
</q-item-section>
</q-item>
<q-item clickable v-ripple @click="onMobile('salary')">
<q-item-section>อมลเงนเดอน/าจาง</q-item-section>
<q-item-section avatar>
<q-avatar text-color="info" icon="mdi-chevron-right" />
</q-item-section>
</q-item>
<q-item clickable v-ripple @click="onMobile('achievement')">
<q-item-section>อมลผลงาน</q-item-section>
<q-item-section avatar>
<q-avatar text-color="info" icon="mdi-chevron-right" />
</q-item-section>
</q-item>
<q-item clickable v-ripple @click="onMobile('other')">
<q-item-section>อมลอนๆ</q-item-section>
<q-item-section avatar>
<q-avatar text-color="info" icon="mdi-chevron-right" />
</q-item-section>
</q-item>
<!-- <q-item clickable v-ripple disabled>
<q-item-section>เปลยนรหสผาน</q-item-section>
<q-item-section avatar>
<q-avatar text-color="info" icon="mdi-chevron-right" />
</q-item-section>
</q-item> -->
</q-list>
</q-card>
</div>
</div>
</div>
</template>