2023-12-13 15:24:59 +07:00
|
|
|
<script setup lang="ts">
|
2023-12-22 16:00:05 +07:00
|
|
|
import { ref, onMounted } from "vue";
|
2023-12-21 17:51:13 +07:00
|
|
|
import http from "@/plugins/http";
|
|
|
|
|
import config from "@/app.config";
|
|
|
|
|
import { useQuasar } from "quasar";
|
|
|
|
|
import axios from "axios";
|
2023-12-13 15:24:59 +07:00
|
|
|
|
|
|
|
|
import { useCounterMixin } from "@/stores/mixin";
|
2023-12-14 14:49:27 +07:00
|
|
|
import { useEvaluateStore } from "@/modules/06_evaluate/store";
|
2023-12-13 15:24:59 +07:00
|
|
|
|
2023-12-21 17:51:13 +07:00
|
|
|
const $q = useQuasar();
|
2023-12-14 14:49:27 +07:00
|
|
|
const store = useEvaluateStore();
|
2023-12-13 15:24:59 +07:00
|
|
|
const mixin = useCounterMixin();
|
2023-12-22 16:00:05 +07:00
|
|
|
const { showLoader, hideLoader, messageError } = mixin;
|
2023-12-21 17:51:13 +07:00
|
|
|
|
|
|
|
|
const props = defineProps({
|
|
|
|
|
evaluateId: {
|
|
|
|
|
type: String,
|
|
|
|
|
},
|
|
|
|
|
});
|
|
|
|
|
const emit = defineEmits(["update:file"]);
|
2023-12-13 15:24:59 +07:00
|
|
|
|
|
|
|
|
const selectedItem = ref(1);
|
2023-12-21 17:51:13 +07:00
|
|
|
const fileName = ref([
|
|
|
|
|
"1-แบบพิจารณาคุณสมบัติบุคคล",
|
|
|
|
|
"2-แบบแสดงรายละเอียดการเสนอผลงาน",
|
|
|
|
|
"3-แบบตรวจสอบความถูกต้องครบถ้วนของข้อมูลเพื่อประกอบการคัดเลือกบุคคล (เอกสารแบบ ก.)",
|
|
|
|
|
"4-แบบประเมินคุณลักษณะบุคคล",
|
|
|
|
|
"5-แบบสรุปข้อมูลของผู้ขอรับการคัดเลือก (เอกสารหมายเลข 9)",
|
|
|
|
|
"6-ผลงานที่จะส่งประเมิน (เอกสารหมายเลข 11)",
|
|
|
|
|
]);
|
2023-12-13 15:24:59 +07:00
|
|
|
|
|
|
|
|
function handleItemClick(itemNumber: number) {
|
|
|
|
|
store.tabPanels = itemNumber.toString();
|
|
|
|
|
selectedItem.value = itemNumber;
|
2023-12-21 17:51:13 +07:00
|
|
|
fetchDocument(fileName.value[itemNumber - 1]);
|
|
|
|
|
}
|
|
|
|
|
async function fetchDocument(fileName: string) {
|
2023-12-22 16:00:05 +07:00
|
|
|
// showLoader();
|
2023-12-21 17:51:13 +07:00
|
|
|
props.evaluateId &&
|
|
|
|
|
(await http
|
|
|
|
|
.get(config.API.loadFileDocument("เล่ม 1", props.evaluateId, fileName))
|
|
|
|
|
.then((res) => {
|
|
|
|
|
downloadFile(res.data.downloadUrl);
|
|
|
|
|
})
|
|
|
|
|
.catch((err) => {
|
|
|
|
|
messageError($q, err);
|
|
|
|
|
}));
|
2023-12-13 15:24:59 +07:00
|
|
|
}
|
2023-12-21 17:51:13 +07:00
|
|
|
|
|
|
|
|
async function downloadFile(url: string) {
|
|
|
|
|
await axios
|
|
|
|
|
.get(url, {
|
|
|
|
|
responseType: "blob",
|
|
|
|
|
headers: {
|
|
|
|
|
"Content-Type": "application/json",
|
|
|
|
|
},
|
|
|
|
|
})
|
|
|
|
|
.then((res) => {
|
|
|
|
|
const blob = new Blob([res.data]);
|
|
|
|
|
const objectUrl = URL.createObjectURL(blob);
|
|
|
|
|
|
|
|
|
|
emit("update:file", objectUrl);
|
|
|
|
|
})
|
|
|
|
|
.catch((err) => {
|
|
|
|
|
messageError($q, err);
|
|
|
|
|
})
|
|
|
|
|
.finally(() => {
|
|
|
|
|
hideLoader();
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
onMounted(async () => {
|
|
|
|
|
await fetchDocument(fileName.value[selectedItem.value - 1]);
|
|
|
|
|
});
|
2023-12-13 15:24:59 +07:00
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<template>
|
|
|
|
|
<q-list separator>
|
|
|
|
|
<q-item
|
|
|
|
|
clickable
|
|
|
|
|
v-ripple
|
|
|
|
|
:active="selectedItem === 1 ? true : false"
|
|
|
|
|
active-class="text-primary"
|
|
|
|
|
@click="handleItemClick(1)"
|
|
|
|
|
>
|
|
|
|
|
<q-item-section>แบบพิจารณาคุณสมบัติบุคคล</q-item-section>
|
|
|
|
|
</q-item>
|
|
|
|
|
<q-item
|
|
|
|
|
clickable
|
|
|
|
|
v-ripple
|
|
|
|
|
:active="selectedItem === 2 ? true : false"
|
|
|
|
|
active-class="text-primary"
|
|
|
|
|
@click="handleItemClick(2)"
|
|
|
|
|
>
|
|
|
|
|
<q-item-section>แบบแสดงรายละเอียดการเสนอผลงาน</q-item-section>
|
|
|
|
|
</q-item>
|
|
|
|
|
<q-item
|
|
|
|
|
clickable
|
|
|
|
|
v-ripple
|
|
|
|
|
:active="selectedItem === 3 ? true : false"
|
|
|
|
|
active-class="text-primary"
|
|
|
|
|
@click="handleItemClick(3)"
|
|
|
|
|
>
|
|
|
|
|
<q-item-section
|
2023-12-20 14:23:27 +07:00
|
|
|
>แบบตรวจสอบความถูกต้องครบถ้วนของข้อมูลเพื่อประกอบการคัดเลือกบุคคล
|
|
|
|
|
(เอกสารแบบ ก.)</q-item-section
|
2023-12-13 15:24:59 +07:00
|
|
|
>
|
|
|
|
|
</q-item>
|
|
|
|
|
<q-item
|
|
|
|
|
clickable
|
|
|
|
|
v-ripple
|
|
|
|
|
:active="selectedItem === 4 ? true : false"
|
|
|
|
|
active-class="text-primary"
|
|
|
|
|
@click="handleItemClick(4)"
|
|
|
|
|
>
|
|
|
|
|
<q-item-section> แบบประเมินคุณลักษณะบุคคล </q-item-section>
|
|
|
|
|
</q-item>
|
|
|
|
|
<q-item
|
|
|
|
|
clickable
|
|
|
|
|
v-ripple
|
|
|
|
|
:active="selectedItem === 5 ? true : false"
|
|
|
|
|
active-class="text-primary"
|
|
|
|
|
@click="handleItemClick(5)"
|
|
|
|
|
>
|
2023-12-20 14:23:27 +07:00
|
|
|
<q-item-section>
|
|
|
|
|
แบบสรุปข้อมูลของผู้ขอรับการคัดเลือก (เอกสารหมายเลข 9)
|
|
|
|
|
</q-item-section>
|
2023-12-13 15:24:59 +07:00
|
|
|
</q-item>
|
|
|
|
|
<q-item
|
|
|
|
|
clickable
|
|
|
|
|
v-ripple
|
|
|
|
|
:active="selectedItem === 6 ? true : false"
|
|
|
|
|
active-class="text-primary"
|
|
|
|
|
@click="handleItemClick(6)"
|
|
|
|
|
>
|
2023-12-20 14:23:27 +07:00
|
|
|
<q-item-section> ผลงานที่จะส่งประเมิน (เอกสารหมายเลข 11) </q-item-section>
|
2023-12-13 15:24:59 +07:00
|
|
|
</q-item>
|
|
|
|
|
</q-list>
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<style scoped></style>
|