2023-06-12 09:42:31 +07:00
|
|
|
<script setup lang="ts">
|
2023-07-11 17:58:24 +07:00
|
|
|
import { ref, watch } from "vue";
|
2023-06-30 09:28:49 +07:00
|
|
|
import { useQuasar } from "quasar";
|
2023-11-13 13:32:26 +07:00
|
|
|
|
2024-09-19 15:02:44 +07:00
|
|
|
import { useCounterMixin } from "@/stores/mixin";
|
2023-07-11 17:58:24 +07:00
|
|
|
import http from "@/plugins/http";
|
|
|
|
|
import config from "@/app.config";
|
2023-11-13 13:32:26 +07:00
|
|
|
|
2024-09-19 15:02:44 +07:00
|
|
|
import type { QTableProps } from "quasar";
|
|
|
|
|
import type { DataEducation } from "@/modules/05_placement/interface/index/Main";
|
|
|
|
|
import type {
|
|
|
|
|
DataPerson,
|
|
|
|
|
Education,
|
|
|
|
|
} from "@/modules/05_placement/interface/response/Main";
|
|
|
|
|
|
|
|
|
|
import DialogHeader from "@/components/DialogHeader.vue";
|
|
|
|
|
|
2023-11-13 13:32:26 +07:00
|
|
|
const $q = useQuasar();
|
2023-06-30 09:15:47 +07:00
|
|
|
const mixin = useCounterMixin(); //เรียกฟังก์ชันกลาง
|
2023-09-21 14:21:26 +07:00
|
|
|
const { showLoader, hideLoader, date2Thai, messageError } = mixin;
|
2023-07-11 18:04:54 +07:00
|
|
|
|
2023-11-13 13:32:26 +07:00
|
|
|
/** รับค่ามาจากหน้าหลัก */
|
2023-06-12 09:42:31 +07:00
|
|
|
const props = defineProps({
|
2023-06-30 09:15:47 +07:00
|
|
|
Modal: Boolean,
|
|
|
|
|
close: {
|
|
|
|
|
type: Function,
|
|
|
|
|
default: () => console.log("not function"),
|
|
|
|
|
},
|
2023-07-12 14:50:35 +07:00
|
|
|
personalId: {
|
|
|
|
|
type: String,
|
2023-07-24 15:26:22 +07:00
|
|
|
default: "",
|
2023-06-30 09:15:47 +07:00
|
|
|
},
|
|
|
|
|
validate: {
|
|
|
|
|
type: Function,
|
|
|
|
|
default: () => console.log("not function"),
|
|
|
|
|
},
|
2023-06-12 09:42:31 +07:00
|
|
|
});
|
2023-07-04 09:41:24 +07:00
|
|
|
|
2024-09-19 15:02:44 +07:00
|
|
|
const rows = ref<DataEducation[]>([]);
|
|
|
|
|
const personalForm = ref<DataPerson>();
|
|
|
|
|
|
2023-11-13 13:32:26 +07:00
|
|
|
/**หัวตาราง */
|
2023-06-30 14:14:44 +07:00
|
|
|
const columns = ref<QTableProps["columns"]>([
|
|
|
|
|
{
|
|
|
|
|
name: "university",
|
|
|
|
|
align: "center",
|
|
|
|
|
label: "สถานศึกษา",
|
|
|
|
|
sortable: true,
|
|
|
|
|
field: "university",
|
|
|
|
|
headerStyle: "font-size: 14px",
|
|
|
|
|
style: "font-size: 14px",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "degree",
|
|
|
|
|
align: "center",
|
|
|
|
|
label: "วุฒิการศึกษา",
|
|
|
|
|
sortable: true,
|
|
|
|
|
field: "degree",
|
|
|
|
|
headerStyle: "font-size: 14px",
|
|
|
|
|
style: "font-size: 14px",
|
|
|
|
|
sort: (a: string, b: string) =>
|
|
|
|
|
a.localeCompare(b, undefined, { numeric: true, sensitivity: "base" }),
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "major",
|
|
|
|
|
align: "center",
|
|
|
|
|
label: "สาขาวิชาเอก",
|
|
|
|
|
sortable: true,
|
|
|
|
|
field: "major",
|
|
|
|
|
headerStyle: "font-size: 14px",
|
|
|
|
|
style: "font-size: 14px",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "graduation",
|
|
|
|
|
align: "center",
|
|
|
|
|
label: "วันที่สำเร็จการศึกษา",
|
|
|
|
|
sortable: true,
|
|
|
|
|
field: "graduation",
|
|
|
|
|
headerStyle: "font-size: 14px",
|
|
|
|
|
style: "font-size: 14px",
|
|
|
|
|
sort: (a: string, b: string) =>
|
|
|
|
|
a.localeCompare(b, undefined, { numeric: true, sensitivity: "base" }),
|
|
|
|
|
},
|
|
|
|
|
]);
|
2023-11-13 13:32:26 +07:00
|
|
|
|
2024-09-19 15:02:44 +07:00
|
|
|
/**
|
|
|
|
|
* ฟังก์ชันดึงข้อมูลรายละเอียด
|
|
|
|
|
*/
|
2024-06-12 13:12:12 +07:00
|
|
|
async function fetchData() {
|
2023-07-11 17:58:24 +07:00
|
|
|
showLoader();
|
|
|
|
|
await http
|
2023-07-12 14:50:35 +07:00
|
|
|
.get(config.API.getDatapersonal(props.personalId))
|
2023-07-11 17:58:24 +07:00
|
|
|
.then((res) => {
|
|
|
|
|
personalForm.value = res.data.result;
|
2024-09-19 15:02:44 +07:00
|
|
|
personalForm.value?.education.map((e: Education) => {
|
2023-07-11 17:58:24 +07:00
|
|
|
rows.value.push({
|
2024-09-19 15:02:44 +07:00
|
|
|
university: e.institute,
|
2023-07-11 17:58:24 +07:00
|
|
|
degree: e.degree,
|
|
|
|
|
major: e.field,
|
2023-07-28 17:05:09 +07:00
|
|
|
graduation: date2Thai(e.finishDate),
|
2023-07-11 17:58:24 +07:00
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
})
|
|
|
|
|
.catch((e) => {
|
2023-09-21 14:21:26 +07:00
|
|
|
messageError($q, e);
|
2023-07-11 17:58:24 +07:00
|
|
|
})
|
|
|
|
|
.finally(() => {
|
|
|
|
|
hideLoader();
|
|
|
|
|
});
|
2024-06-12 13:12:12 +07:00
|
|
|
}
|
2023-07-28 17:05:09 +07:00
|
|
|
|
2023-11-13 13:32:26 +07:00
|
|
|
/**
|
2024-09-19 15:02:44 +07:00
|
|
|
* ฟังก์ชันแปลงประเภทข้าราชการ เป็นไทย
|
|
|
|
|
* @param val ประเภทข้าราชการ
|
2023-11-13 13:32:26 +07:00
|
|
|
*/
|
2024-06-12 13:12:12 +07:00
|
|
|
function formBmaofficer(val: string) {
|
2023-07-11 17:58:24 +07:00
|
|
|
switch (val) {
|
2023-07-14 10:34:40 +07:00
|
|
|
case "OFFICER":
|
2023-07-11 17:58:24 +07:00
|
|
|
return "ขรก.กทม. สามัญ";
|
2023-07-14 10:34:40 +07:00
|
|
|
case "EMPLOYEE_PERM":
|
2023-07-11 17:58:24 +07:00
|
|
|
return "ลูกจ้างประจำ";
|
2023-07-14 10:34:40 +07:00
|
|
|
case "EMPLOYEE_TEMP":
|
2023-07-11 17:58:24 +07:00
|
|
|
return "ลูกจ้างชั่วคราว";
|
|
|
|
|
default:
|
2023-07-14 10:34:40 +07:00
|
|
|
return "";
|
2023-06-30 09:15:47 +07:00
|
|
|
}
|
2024-06-12 13:12:12 +07:00
|
|
|
}
|
2023-11-13 13:32:26 +07:00
|
|
|
|
2024-09-19 15:02:44 +07:00
|
|
|
/**
|
|
|
|
|
* ปิด POPUP ข้อมูล
|
|
|
|
|
*/
|
2024-06-12 13:12:12 +07:00
|
|
|
async function close() {
|
2023-06-30 09:15:47 +07:00
|
|
|
props.close();
|
2023-07-11 17:58:24 +07:00
|
|
|
rows.value = [];
|
2024-06-12 13:12:12 +07:00
|
|
|
}
|
2023-11-13 13:32:26 +07:00
|
|
|
|
2024-09-19 15:02:44 +07:00
|
|
|
/**
|
|
|
|
|
* เมื่อ props.Modal เป็น true จะเรียกข้อมูลการศึกษา
|
|
|
|
|
*/
|
2023-11-13 13:32:26 +07:00
|
|
|
watch(props, () => {
|
|
|
|
|
if (props.Modal === true) {
|
|
|
|
|
fetchData();
|
|
|
|
|
}
|
|
|
|
|
});
|
2023-06-12 09:42:31 +07:00
|
|
|
</script>
|
|
|
|
|
<template>
|
2023-09-20 15:27:03 +07:00
|
|
|
<q-dialog v-model="props.Modal" persistent>
|
2023-06-30 09:15:47 +07:00
|
|
|
<q-card style="max-width: 100%; width: 80%">
|
2024-09-19 15:02:44 +07:00
|
|
|
<q-form>
|
2024-06-24 18:43:01 +07:00
|
|
|
<DialogHeader
|
2024-09-19 15:02:44 +07:00
|
|
|
:tittle="`รายละเอียดของ ${personalForm?.fullName}`"
|
2024-06-24 18:43:01 +07:00
|
|
|
:close="close"
|
|
|
|
|
/>
|
2023-11-13 13:32:26 +07:00
|
|
|
|
2023-06-30 09:15:47 +07:00
|
|
|
<q-separator />
|
2023-06-12 09:42:31 +07:00
|
|
|
|
2023-06-30 09:15:47 +07:00
|
|
|
<div class="contanier-box-main">
|
|
|
|
|
<div class="contanier-box-mini">
|
|
|
|
|
<q-card bordered class="card-panding">
|
|
|
|
|
<div class="row items-center q-pa-xs header-text">
|
|
|
|
|
ข้อมูลทั่วไป
|
2023-07-24 15:26:22 +07:00
|
|
|
<span
|
2024-09-19 15:02:44 +07:00
|
|
|
v-if="personalForm?.bmaOfficer != null"
|
2023-07-24 15:26:22 +07:00
|
|
|
class="check-officer"
|
|
|
|
|
>
|
|
|
|
|
<q-icon name="mdi-check" />
|
|
|
|
|
{{ formBmaofficer(personalForm.bmaOfficer) }}
|
|
|
|
|
</span>
|
2023-06-30 09:15:47 +07:00
|
|
|
</div>
|
2023-11-13 13:32:26 +07:00
|
|
|
|
2023-06-30 09:15:47 +07:00
|
|
|
<div class="row q-pa-xs">
|
|
|
|
|
<div class="col-3 header-sub-text">
|
2023-09-19 10:24:56 +07:00
|
|
|
<div class="q-pb-md">เลขประจำตัวประชาชน</div>
|
2023-06-30 09:28:49 +07:00
|
|
|
<div>วัน/เดือน/ปีเกิด</div>
|
2023-06-30 09:15:47 +07:00
|
|
|
</div>
|
2023-11-13 13:32:26 +07:00
|
|
|
|
2023-06-30 09:15:47 +07:00
|
|
|
<div class="col-4 sub-text">
|
|
|
|
|
<div class="q-pb-md">
|
2024-09-19 15:02:44 +07:00
|
|
|
{{ personalForm?.idCard }}
|
2023-06-30 09:15:47 +07:00
|
|
|
</div>
|
2023-06-30 09:28:49 +07:00
|
|
|
<div>
|
2024-09-19 15:02:44 +07:00
|
|
|
{{ date2Thai(personalForm?.dateOfBirth) }}
|
2023-06-30 09:15:47 +07:00
|
|
|
</div>
|
|
|
|
|
</div>
|
2023-11-13 13:32:26 +07:00
|
|
|
|
2023-06-30 09:15:47 +07:00
|
|
|
<div class="col-2 header-sub-text">
|
|
|
|
|
<div class="q-pb-md">ชื่อ-นามสกุล</div>
|
2023-06-30 09:28:49 +07:00
|
|
|
<div>เพศ</div>
|
2023-06-30 09:15:47 +07:00
|
|
|
</div>
|
|
|
|
|
<div class="col-3 sub-text">
|
|
|
|
|
<div class="q-pb-md">
|
2024-09-19 15:02:44 +07:00
|
|
|
{{ personalForm?.fullName }}
|
2023-06-30 09:15:47 +07:00
|
|
|
</div>
|
2023-06-30 09:28:49 +07:00
|
|
|
<div>
|
2024-09-19 15:02:44 +07:00
|
|
|
{{ personalForm?.gender }}
|
2023-06-30 09:15:47 +07:00
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</q-card>
|
|
|
|
|
</div>
|
2023-11-13 13:32:26 +07:00
|
|
|
|
2023-06-30 09:15:47 +07:00
|
|
|
<div class="contanier-box-mini">
|
|
|
|
|
<q-card bordered class="card-panding">
|
|
|
|
|
<div class="row items-center q-pa-xs header-text">ภูมิลำเนา</div>
|
|
|
|
|
<div class="row q-pa-xs">
|
|
|
|
|
<div class="col-3 header-sub-text">ที่อยู่</div>
|
|
|
|
|
<div class="col-9 sub-text">
|
2024-09-19 15:02:44 +07:00
|
|
|
{{ personalForm?.registAddress }}
|
2023-06-30 09:15:47 +07:00
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</q-card>
|
|
|
|
|
</div>
|
2023-11-13 13:32:26 +07:00
|
|
|
|
2023-06-30 09:15:47 +07:00
|
|
|
<div class="contanier-box-mini">
|
|
|
|
|
<q-card bordered class="card-panding">
|
|
|
|
|
<div class="row items-center q-pa-xs header-text">การศึกษา</div>
|
2023-07-24 15:26:22 +07:00
|
|
|
<q-table
|
|
|
|
|
ref="table"
|
|
|
|
|
:rows="rows"
|
|
|
|
|
:columns="columns"
|
|
|
|
|
flat
|
|
|
|
|
bordered
|
|
|
|
|
class="custom-header-table"
|
|
|
|
|
virtual-scroll
|
|
|
|
|
:virtual-scroll-sticky-size-start="48"
|
|
|
|
|
dense
|
|
|
|
|
hide-bottom
|
|
|
|
|
>
|
2023-06-30 14:14:44 +07:00
|
|
|
</q-table>
|
2023-06-30 09:15:47 +07:00
|
|
|
</q-card>
|
|
|
|
|
</div>
|
2024-06-12 13:12:12 +07:00
|
|
|
|
2023-06-30 09:15:47 +07:00
|
|
|
<div class="contanier-box-mini">
|
|
|
|
|
<q-card bordered class="card-panding">
|
|
|
|
|
<div class="row items-center q-pa-xs header-text">การสอบ</div>
|
|
|
|
|
<div class="row q-pa-xs">
|
2023-10-06 17:32:08 +07:00
|
|
|
<div class="col-6 q-pt-sm q-pl-lg">
|
2023-06-30 09:15:47 +07:00
|
|
|
<div class="row">
|
|
|
|
|
<div class="col-7 header-sub-text">
|
|
|
|
|
<div class="q-pb-sm">ผลการสอบ</div>
|
|
|
|
|
<div class="q-pb-sm">ลำดับที่สอบได้</div>
|
|
|
|
|
<div class="q-pb-sm">จำนวนครั้งที่สมัครสอบ</div>
|
2023-06-12 09:42:31 +07:00
|
|
|
</div>
|
2023-06-30 09:15:47 +07:00
|
|
|
<div class="col-5 sub-text-exam">
|
|
|
|
|
<div class="q-pb-sm">
|
2024-09-19 15:02:44 +07:00
|
|
|
{{ personalForm?.pass }}
|
2023-06-30 09:15:47 +07:00
|
|
|
</div>
|
2024-09-19 15:02:44 +07:00
|
|
|
<div class="q-pb-sm">{{ personalForm?.examNumber }}</div>
|
|
|
|
|
<div class="q-pb-sm">{{ personalForm?.examRound }}</div>
|
2023-06-12 09:42:31 +07:00
|
|
|
</div>
|
2023-06-30 09:15:47 +07:00
|
|
|
</div>
|
2023-06-13 10:52:53 +07:00
|
|
|
</div>
|
2023-06-30 09:15:47 +07:00
|
|
|
</div>
|
|
|
|
|
</q-card>
|
|
|
|
|
</div>
|
2023-08-28 11:15:04 +07:00
|
|
|
</div>
|
2023-06-30 09:15:47 +07:00
|
|
|
</q-form>
|
|
|
|
|
</q-card>
|
|
|
|
|
</q-dialog>
|
2023-06-13 10:52:53 +07:00
|
|
|
</template>
|
|
|
|
|
<style lang="scss" scoped>
|
|
|
|
|
.icon-officer {
|
2023-06-30 09:15:47 +07:00
|
|
|
color: #00aa86;
|
|
|
|
|
padding-left: 20px;
|
2023-06-13 10:52:53 +07:00
|
|
|
}
|
2023-06-12 09:42:31 +07:00
|
|
|
|
2023-06-13 10:52:53 +07:00
|
|
|
.check-officer {
|
2023-06-30 09:15:47 +07:00
|
|
|
font-size: 17px;
|
|
|
|
|
font-weight: 500;
|
|
|
|
|
line-height: 26px;
|
|
|
|
|
color: #00aa86;
|
|
|
|
|
padding-left: 20px;
|
2023-06-13 10:52:53 +07:00
|
|
|
}
|
2023-06-12 09:42:31 +07:00
|
|
|
|
2023-06-13 10:52:53 +07:00
|
|
|
.contanier-box-main {
|
2023-06-30 09:15:47 +07:00
|
|
|
padding: 10px 21px 10px 21px;
|
2023-06-13 10:52:53 +07:00
|
|
|
}
|
2023-06-12 09:42:31 +07:00
|
|
|
|
2023-06-13 10:52:53 +07:00
|
|
|
.contanier-box-mini {
|
2023-06-30 09:15:47 +07:00
|
|
|
padding: 10px 0px 10px 0px;
|
2023-06-13 10:52:53 +07:00
|
|
|
}
|
2023-06-12 09:42:31 +07:00
|
|
|
|
2023-06-13 10:52:53 +07:00
|
|
|
.card-panding {
|
2023-06-30 09:15:47 +07:00
|
|
|
padding: 15px 21px 15px 21px;
|
2023-06-13 10:52:53 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.header-text {
|
2023-06-30 09:15:47 +07:00
|
|
|
font-size: 18px;
|
|
|
|
|
font-weight: 600;
|
|
|
|
|
color: #4f4f4f;
|
2023-06-13 10:52:53 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.header-sub-text {
|
2023-06-30 09:15:47 +07:00
|
|
|
font-size: 16px;
|
|
|
|
|
font-weight: 400;
|
|
|
|
|
line-height: 150%;
|
|
|
|
|
color: #818181;
|
2023-06-13 10:52:53 +07:00
|
|
|
}
|
2023-07-13 14:20:28 +07:00
|
|
|
|
2023-06-13 10:52:53 +07:00
|
|
|
.sub-text {
|
2023-06-30 09:15:47 +07:00
|
|
|
font-weight: 400;
|
|
|
|
|
font-size: 16px;
|
|
|
|
|
line-height: 22px;
|
|
|
|
|
letter-spacing: 0.0025em;
|
|
|
|
|
color: #35373c;
|
2023-06-13 10:52:53 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.card-exam {
|
2023-06-30 09:15:47 +07:00
|
|
|
border-radius: 5px;
|
|
|
|
|
background: #fafafa;
|
2023-06-13 10:52:53 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.header-sub-text-exam {
|
2023-06-30 09:15:47 +07:00
|
|
|
font-size: 15px;
|
|
|
|
|
font-weight: 500;
|
|
|
|
|
line-height: 150%;
|
|
|
|
|
color: #818181;
|
2023-06-13 10:52:53 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.header-sub-text-exam-2 {
|
2023-06-30 09:15:47 +07:00
|
|
|
font-size: 15px;
|
|
|
|
|
font-weight: 500;
|
|
|
|
|
line-height: 150%;
|
|
|
|
|
color: #00aa86;
|
2023-06-13 10:52:53 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.sub-text-exam {
|
2023-06-30 09:15:47 +07:00
|
|
|
font-size: 15px;
|
|
|
|
|
font-weight: 500;
|
|
|
|
|
color: #000000;
|
2023-06-13 10:52:53 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.checkbox-group {
|
2023-06-30 09:15:47 +07:00
|
|
|
font-size: 16px;
|
|
|
|
|
font-weight: 400;
|
|
|
|
|
color: #35373c;
|
2023-06-13 10:52:53 +07:00
|
|
|
}
|
2023-06-30 09:15:47 +07:00
|
|
|
</style>
|