hrms-mgt/src/modules/05_placement/components/pass/TableDetail.vue

378 lines
14 KiB
Vue
Raw Normal View History

2023-06-12 09:42:31 +07:00
<script setup lang="ts">
import { ref, computed } from "vue";
2023-06-12 09:42:31 +07:00
import DialogHeader from "@/modules/05_placement/components/pass/DialogHeader.vue";
import { useQuasar } from 'quasar'
2023-06-12 09:42:31 +07:00
import DialogFooter from "@/modules/05_placement/components/pass/DialogFooter.vue";
2023-06-15 16:07:44 +07:00
import type { CheckboxItem } from "@/modules/05_placement/interface/index/Main";
import { useCounterMixin } from "@/stores/mixin";
const mixin = useCounterMixin(); //เรียกฟังก์ชันกลาง
const modal = ref<boolean>();
const { success } = mixin;
2023-06-13 10:52:53 +07:00
const save = ref<boolean>(true);
2023-06-12 09:42:31 +07:00
const props = defineProps({
Modal: Boolean,
close: {
type: Function,
default: () => console.log("not function"),
},
getdetail: {
type: Object,
required: true,
},
validate: {
type: Function,
default: () => console.log("not function"),
},
2023-06-12 09:42:31 +07:00
});
const myForm = ref<any>();
const checkValidate = ref<boolean>(false);
const selection = ref<number[]>([]);
2023-06-12 09:42:31 +07:00
const checkboxItems: CheckboxItem[] = [
{ id: 1, label: "ไม่เป็นผู้ดำรงตำแหน่งทางการเมือง" },
{
id: 2,
label:
"ไม่เป็นคนไร้ความสามารถ คนเสมือนไร้ความสามารถ คนวิกลจริตหรือจิตฟั่นเฟือน ไม่สมประกอบหรือเป็นโรคตามที่กำหนดในกฎ ก.พ.",
},
{
id: 3,
label:
"ไม่เป็นผู้อยู่ในระหว่างถูกสั่งพักราชการหรือถูกสั่งให้ออกจากราชการไว้ก่อนตามพระราชบัญญัตินี้ หรือตามกฎหมายอื่น",
},
{ id: 4, label: "ไม่เป็นผู้บกพร่องในศีลธรรมอันดีจนเป็นที่รังเกียจของสังคม" },
{
id: 5,
label:
"ไม่เป็นกรรมการหรือผู้ดำรงตำแหน่งที่รับผิดชอบในการบริหารพรรคการเมือง หรือเจ้าหน้าที่ในพรรคการเมือง",
},
{ id: 6, label: "ไม่เป็นบุคคลล้มละลาย" },
{
id: 7,
label:
"ไม่เป็นผู้เคยต้องรับโทษจำคุกโดยคำพิพากษาถึงที่สุดให้จำคุกเพราะกระทำความผิดทางอาญา เว้นแต่เป็นโทษสำหรับความผิดที่ใด้กระทำโดยประมาทหรือความผิดลหุโทษ",
},
{
id: 8,
label:
"ไม่เป็นผู้เคยถูกลงโทษให้ออก ปลดออก หรือไล่ออกจากรัฐวิสาหกิจ หรือ หน่วยงานอื่นของรัฐ",
},
{
id: 9,
label:
"เป็นผู้เคยถูลงโทษให้ออก หรือปลดออก เพราะกระทำผิตวินัยตามพระราชบัญญัตินี้ หรือตามกฎหมายอื่น",
},
{
id: 10,
label:
"เป็นผู้เคยถูกลงโทษไล่ออก เพราะกระทำผิดวินัยตามพระราชบัญญัตินี้ หรือตามกฎหมายอื่น",
},
{
id: 11,
label:
"เป็นผู้เคยกระทำการทุจริตในการสอบเข้ารับราชการ หรือเข้าปฏิบัติงานใน หน่วยงานของรัฐ",
},
2023-06-12 09:42:31 +07:00
];
const $q = useQuasar()
function isRequired(val: any): boolean | string {
return !!val || "กรุณาเลือกไฟล์เอกสารหลักฐาน";
}
const validateData = () => {
const selectedIds = selection.value;
const selectedItems = checkboxItems.filter((item) =>
selectedIds.includes(item.id)
);
return (
selectedItems.length > 0 && selectedItems.length === selectedIds.length
);
};
2023-06-12 09:42:31 +07:00
const ClickSave = () => {
const isValid = validateData();
if (isValid) {
console.log(selection.value);
console.log("rerer", props.Modal);
props.close();
props.validate();
selection.value = [];
} else {
success($q, "กรอกให้ครบ");
}
2023-06-12 09:42:31 +07:00
};
const close = async () => {
props.close();
selection.value = [];
};
2023-06-12 09:42:31 +07:00
</script>
<template>
<q-dialog v-model="props.Modal">
<q-card style="max-width: 100%; width: 80%">
<q-form ref="myForm">
<div class="row">
<DialogHeader
:title="`รายละเอียดของ ${props.getdetail.fullName}`"
@click="close"
/>
</div>
<q-separator />
2023-06-12 09:42:31 +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">
อมลทวไป
<span class="check-officer"
><q-icon name="mdi-check" /> าราชการฯ กทม</span
>
</div>
<div class="row q-pa-xs">
<div class="col-3 header-sub-text">
<div class="q-pb-md">เลขทประจำตวประชาชน</div>
<div class="q-pb-md">/เดอน/เก</div>
</div>
<div class="col-4 sub-text">
<div class="q-pb-md">
{{ props.getdetail.profileID }}
</div>
<div class="q-pb-md">
{{ props.getdetail.dateOfBirth }}
</div>
</div>
<div class="col-2 header-sub-text">
<div class="q-pb-md">-นามสก</div>
<div class="q-pb-md">เพศ</div>
</div>
<div class="col-3 sub-text">
<div class="q-pb-md">
{{ props.getdetail.fullName }}
</div>
<div class="q-pb-md">
{{ props.getdetail.gender }}
</div>
</div>
</div>
</q-card>
</div>
<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">
{{ props.getdetail.address }}
</div>
</div>
</q-card>
</div>
<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 class="q-pb-md">สถานศกษา</div>
<div class="q-pb-md">สาขาวชาเอก</div>
</div>
<div class="col-4 sub-text">
<div class="q-pb-md">
{{ props.getdetail.university }}
</div>
<div class="q-pb-md">
{{ props.getdetail.major }}
</div>
</div>
<div class="col-2 header-sub-text">
<div class="q-pb-md">การศกษา</div>
<div class="q-pb-md">นๆ</div>
</div>
<div class="col-3 sub-text">
<div class="q-pb-md">
{{ props.getdetail.degree ? props.getdetail.degree : "-" }}
</div>
<div class="q-pb-md">
{{ props.getdetail.remark ? props.getdetail.remark : "-" }}
</div>
</div>
</div>
</q-card>
</div>
<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-6">
<q-card class="card-exam q-pa-sm">
<div class="row">
<div class="col-4 q-pa-xs header-sub-text-exam">
<div>ประเภท</div>
<div>ภาค </div>
<div>ภาค </div>
<div>ภาค </div>
<div>รวมทงหมด</div>
</div>
<div class="col-4 q-pa-xs">
<div class="header-sub-text-exam-2">คะแนนทได</div>
<div class="sub-text-exam">
{{ props.getdetail.scoreResult.scoreAFull }}
</div>
<div class="sub-text-exam">
{{ props.getdetail.scoreResult.scoreBFull }}
</div>
<div class="sub-text-exam">
{{ props.getdetail.scoreResult.scoreCFull }}
</div>
<div class="sub-text-exam">
{{ props.getdetail.scoreResult.scoreSumFull }}
</div>
</div>
<div class="col-4 q-pa-xs header-sub-text-exam-2">
<div class="header-sub-text-exam-2">ผลการสอบ</div>
<div class="sub-text-exam">
{{ props.getdetail.scoreResult.scoreA }}
</div>
<div class="sub-text-exam">
{{ props.getdetail.scoreResult.scoreB }}
</div>
<div class="sub-text-exam">
{{ props.getdetail.scoreResult.scoreC }}
</div>
<div class="sub-text-exam">
{{ props.getdetail.scoreResult.scoreSum }}
</div>
</div>
2023-06-12 09:42:31 +07:00
</div>
</q-card>
</div>
<div class="col-1"></div>
<div class="col-5 q-pt-sm q-pl-lg">
<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>
<div class="col-5 sub-text-exam">
<div class="q-pb-sm">
{{ props.getdetail.scoreResult.examResult }}
</div>
<div class="q-pb-sm">{{ props.getdetail.number }}</div>
<div class="q-pb-sm">{{ props.getdetail.examCount }}</div>
2023-06-12 09:42:31 +07:00
</div>
</div>
2023-06-13 10:52:53 +07:00
</div>
</div>
</q-card>
</div>
<div class="contanier-box-mini">
<q-card bordered class="card-panding">
<div class="col-12 row items-center q-pa-sm header-text">
การคดกรองคณสมบ
</div>
<div v-for="item of checkboxItems" :key="item.id" class="q-pa-sm">
<q-checkbox
size="xs"
v-model="selection"
:val="item.id"
:label="item.label"
keep-color
color="teal"
:rules="[isRequired]"
class="checkbox-group"
/>
2023-06-13 10:52:53 +07:00
<q-separator />
</div>
</q-card>
</div>
</div>
<q-separator />
<div>
<DialogFooter
@click="ClickSave"
:model="props.Modal"
:editvisible="save"
:validate="validateData"
/>
</div>
</q-form>
</q-card>
</q-dialog>
2023-06-13 10:52:53 +07:00
</template>
<style lang="scss" scoped>
.icon-officer {
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 {
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 {
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 {
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 {
padding: 15px 21px 15px 21px;
2023-06-13 10:52:53 +07:00
}
.header-text {
font-size: 18px;
font-weight: 600;
color: #4f4f4f;
2023-06-13 10:52:53 +07:00
}
.header-sub-text {
font-size: 16px;
font-weight: 400;
line-height: 150%;
color: #818181;
2023-06-13 10:52:53 +07:00
}
.sub-text {
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 {
border-radius: 5px;
background: #fafafa;
2023-06-13 10:52:53 +07:00
}
.header-sub-text-exam {
font-size: 15px;
font-weight: 500;
line-height: 150%;
color: #818181;
2023-06-13 10:52:53 +07:00
}
.header-sub-text-exam-2 {
font-size: 15px;
font-weight: 500;
line-height: 150%;
color: #00aa86;
2023-06-13 10:52:53 +07:00
}
.sub-text-exam {
font-size: 15px;
font-weight: 500;
color: #000000;
2023-06-13 10:52:53 +07:00
}
.checkbox-group {
font-size: 16px;
font-weight: 400;
color: #35373c;
2023-06-13 10:52:53 +07:00
}
</style>