2023-12-13 15:24:59 +07:00
|
|
|
<script setup lang="ts">
|
2023-12-15 17:50:47 +07:00
|
|
|
import { ref, reactive, onMounted } from "vue";
|
2023-12-13 15:24:59 +07:00
|
|
|
import { useQuasar } from "quasar";
|
2023-12-19 10:56:51 +07:00
|
|
|
import evaluationFunctions from "@/modules/06_evaluate/stores/evaluationFunction";
|
2023-12-13 15:24:59 +07:00
|
|
|
|
2023-12-15 17:50:47 +07:00
|
|
|
import type {
|
|
|
|
|
FormCommand,
|
|
|
|
|
FormCommandRef,
|
|
|
|
|
} from "@/modules/06_evaluate/interface/evalute";
|
|
|
|
|
|
2023-12-14 14:49:27 +07:00
|
|
|
import Stepper from "@/modules/06_evaluate/components/Stepper.vue";
|
|
|
|
|
import Step1 from "@/modules/06_evaluate/components/step/step1.vue";
|
|
|
|
|
import Step2 from "@/modules/06_evaluate/components/step/step2.vue";
|
|
|
|
|
import Step3 from "@/modules/06_evaluate/components/step/step3.vue";
|
|
|
|
|
import Step4 from "@/modules/06_evaluate/components/step/step4.vue";
|
|
|
|
|
import Step5 from "@/modules/06_evaluate/components/step/step5.vue";
|
|
|
|
|
import Step6 from "@/modules/06_evaluate/components/step/step6.vue";
|
|
|
|
|
import Step7 from "@/modules/06_evaluate/components/step/step7.vue";
|
|
|
|
|
import Step8 from "@/modules/06_evaluate/components/step/step8.vue";
|
|
|
|
|
import Step9 from "@/modules/06_evaluate/components/step/step9.vue";
|
2023-12-13 15:24:59 +07:00
|
|
|
|
2023-12-14 14:49:27 +07:00
|
|
|
import ViewStep1 from "@/modules/06_evaluate/components/viewstep/viewStep1.vue";
|
|
|
|
|
import ViewStep3 from "@/modules/06_evaluate/components/viewstep/viewStep3.vue";
|
|
|
|
|
import ViewStep7 from "@/modules/06_evaluate/components/viewstep/viewStep7.vue";
|
2023-12-13 15:24:59 +07:00
|
|
|
|
2023-12-18 15:30:14 +07:00
|
|
|
import DialogMain from "@/modules/06_evaluate/components/directorandmeet/DialogMain.vue";
|
|
|
|
|
|
2023-12-14 14:49:27 +07:00
|
|
|
import { useEvaluateStore } from "@/modules/06_evaluate/store";
|
2023-12-13 15:24:59 +07:00
|
|
|
import { useCounterMixin } from "@/stores/mixin";
|
|
|
|
|
|
2023-12-14 14:49:27 +07:00
|
|
|
const store = useEvaluateStore();
|
2023-12-13 15:24:59 +07:00
|
|
|
const mixin = useCounterMixin();
|
|
|
|
|
const $q = useQuasar();
|
|
|
|
|
|
2023-12-19 10:56:51 +07:00
|
|
|
const { dialogConfirm, showLoader, hideLoader, messageError } = mixin;
|
|
|
|
|
const { fetchCheckStatus, saveEvaluation } = evaluationFunctions;
|
|
|
|
|
|
2023-12-14 15:12:27 +07:00
|
|
|
const externalLink =
|
|
|
|
|
"https://accreditation.ocsc.go.th/accreditation/search/curriculum";
|
|
|
|
|
|
2023-12-15 17:50:47 +07:00
|
|
|
const formCommand = reactive<FormCommand>({
|
|
|
|
|
elementaryFullName: "",
|
|
|
|
|
elementaryPosition: "",
|
|
|
|
|
abovelevelFullname: "",
|
|
|
|
|
abovelevelPosition: "",
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
const elementaryFullNameRef = ref<object | null>(null);
|
|
|
|
|
const elementaryPositonRef = ref<object | null>(null);
|
|
|
|
|
const abovelevelFullnameRef = ref<object | null>(null);
|
|
|
|
|
const abovelevelPositionRef = ref<object | null>(null);
|
|
|
|
|
|
|
|
|
|
const formCommandRef: FormCommandRef = {
|
|
|
|
|
elementaryFullName: elementaryFullNameRef,
|
|
|
|
|
elementaryPosition: elementaryPositonRef,
|
|
|
|
|
abovelevelFullname: abovelevelFullnameRef,
|
|
|
|
|
abovelevelPosition: abovelevelPositionRef,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
async function onCilckNextStep() {
|
|
|
|
|
const functionCreateDoc: (() => Promise<void>) | null =
|
|
|
|
|
store.step === 1
|
|
|
|
|
? await saveStep1
|
|
|
|
|
: store.step === 3
|
|
|
|
|
? await saveStep3
|
|
|
|
|
: store.step === 4
|
|
|
|
|
? await saveStep4
|
|
|
|
|
: store.step === 5
|
|
|
|
|
? await saveStep5
|
|
|
|
|
: store.step === 5
|
|
|
|
|
? await saveStep5
|
|
|
|
|
: store.step === 6
|
|
|
|
|
? await saveStep6
|
|
|
|
|
: store.step === 7
|
|
|
|
|
? await saveStep7
|
|
|
|
|
: store.step === 8
|
|
|
|
|
? await saveStep8
|
|
|
|
|
: store.step === 9
|
|
|
|
|
? await saveStep9
|
|
|
|
|
: null;
|
|
|
|
|
store.step === 2
|
|
|
|
|
? validateStep2()
|
|
|
|
|
: store.step < 9 &&
|
|
|
|
|
dialogConfirm(
|
|
|
|
|
$q,
|
|
|
|
|
() => {
|
|
|
|
|
functionCreateDoc?.();
|
|
|
|
|
store.step++;
|
|
|
|
|
},
|
|
|
|
|
"ยืนยันการดำเนินการ",
|
|
|
|
|
"ต้องการยืนยันการดำเนินการต่อใช่หรือไม่?"
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
// functionCreateDoc?.();
|
|
|
|
|
// store.step < 9 &&
|
2023-12-13 15:24:59 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function onCilckprPeviousStep() {
|
|
|
|
|
store.step > 1 &&
|
2023-12-13 18:06:21 +07:00
|
|
|
dialogConfirm(
|
|
|
|
|
$q,
|
|
|
|
|
() => {
|
|
|
|
|
store.step--;
|
|
|
|
|
},
|
|
|
|
|
"ยืนยันการย้อนกลับ",
|
|
|
|
|
"ต้องการย้อนกลับใช่หรือไม่?"
|
|
|
|
|
);
|
2023-12-13 15:24:59 +07:00
|
|
|
}
|
2023-12-13 16:56:43 +07:00
|
|
|
|
2023-12-15 17:50:47 +07:00
|
|
|
function updateformCommand(val: any, ref: any) {
|
|
|
|
|
formCommand.elementaryFullName = val.elementaryFullName;
|
|
|
|
|
formCommand.elementaryPosition = val.elementaryPosition;
|
|
|
|
|
formCommand.abovelevelFullname = val.abovelevelFullname;
|
|
|
|
|
formCommand.abovelevelPosition = val.abovelevelPosition;
|
|
|
|
|
|
|
|
|
|
elementaryFullNameRef.value = ref.elementaryFullNameRef;
|
|
|
|
|
elementaryPositonRef.value = ref.elementaryPositonRef;
|
|
|
|
|
abovelevelFullnameRef.value = ref.abovelevelFullnameRef;
|
|
|
|
|
abovelevelPositionRef.value = ref.abovelevelPositionRef;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
async function validateStep2() {
|
|
|
|
|
const hasError = [];
|
|
|
|
|
for (const key in formCommandRef) {
|
|
|
|
|
if (Object.prototype.hasOwnProperty.call(formCommandRef, key)) {
|
|
|
|
|
const property = formCommandRef[key];
|
|
|
|
|
if (property.value && typeof property.value.validate === "function") {
|
|
|
|
|
const isValid = property.value.validate();
|
|
|
|
|
hasError.push(isValid);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (hasError.every((result) => result === true)) {
|
|
|
|
|
saveStep2();
|
|
|
|
|
} else {
|
|
|
|
|
console.log("ไม่ผ่าน");
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-12-14 13:09:33 +07:00
|
|
|
|
|
|
|
|
async function saveStep1() {
|
2023-12-19 10:56:51 +07:00
|
|
|
saveEvaluation("test");
|
2023-12-14 13:09:33 +07:00
|
|
|
}
|
|
|
|
|
async function saveStep2() {
|
2023-12-15 17:50:47 +07:00
|
|
|
dialogConfirm(
|
|
|
|
|
$q,
|
|
|
|
|
() => {
|
|
|
|
|
store.step++;
|
|
|
|
|
},
|
|
|
|
|
"ยืนยันการดำเนินการ",
|
|
|
|
|
"ต้องการยืนยันการดำเนินการต่อใช่หรือไม่?"
|
|
|
|
|
);
|
2023-12-14 13:09:33 +07:00
|
|
|
}
|
|
|
|
|
async function saveStep3() {
|
|
|
|
|
console.log("Save 3");
|
|
|
|
|
}
|
|
|
|
|
async function saveStep4() {
|
|
|
|
|
console.log("Save 4");
|
|
|
|
|
}
|
|
|
|
|
async function saveStep5() {
|
|
|
|
|
console.log("Save 5");
|
|
|
|
|
}
|
|
|
|
|
async function saveStep6() {
|
|
|
|
|
console.log("Save 6");
|
|
|
|
|
}
|
|
|
|
|
async function saveStep7() {
|
|
|
|
|
console.log("Save 7");
|
|
|
|
|
}
|
|
|
|
|
async function saveStep8() {
|
|
|
|
|
console.log("Save 8");
|
|
|
|
|
}
|
|
|
|
|
async function saveStep9() {
|
|
|
|
|
console.log("Save 9");
|
|
|
|
|
}
|
|
|
|
|
|
2023-12-18 15:30:14 +07:00
|
|
|
const modalDirector = ref<boolean>(false);
|
|
|
|
|
|
|
|
|
|
function onClickDialogDirevtor() {
|
|
|
|
|
modalDirector.value = true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function closeDialogDirector() {
|
|
|
|
|
modalDirector.value = false;
|
|
|
|
|
}
|
|
|
|
|
function fetchDirector() {
|
|
|
|
|
console.log("ประเมินชำนาญการ:director");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function fetchMeeting() {
|
|
|
|
|
console.log("ประเมินชำนาญการ:meeting");
|
|
|
|
|
}
|
|
|
|
|
|
2023-12-19 10:56:51 +07:00
|
|
|
onMounted(async () => {
|
2023-12-13 16:56:43 +07:00
|
|
|
store.step = 1;
|
2023-12-19 10:56:51 +07:00
|
|
|
await fetchCheckStatus();
|
2023-12-13 16:56:43 +07:00
|
|
|
});
|
2023-12-13 15:24:59 +07:00
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<template>
|
|
|
|
|
<div class="row q-col-gutter-md">
|
|
|
|
|
<div class="col-xs-12 col-sm-3">
|
|
|
|
|
<div class="toptitle">ประเมินชำนาญการ</div>
|
|
|
|
|
<Stepper />
|
2023-12-18 15:30:14 +07:00
|
|
|
|
|
|
|
|
<div class="text-center">
|
|
|
|
|
<q-btn
|
|
|
|
|
unelevated
|
|
|
|
|
outline
|
|
|
|
|
label="รายชื่อกรรมการและการประชุม"
|
|
|
|
|
color="public"
|
|
|
|
|
@click="onClickDialogDirevtor"
|
|
|
|
|
/>
|
|
|
|
|
</div>
|
2023-12-13 15:24:59 +07:00
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<div class="col-xs-12 col-sm-9">
|
2023-12-14 14:49:27 +07:00
|
|
|
<div class="col-12 row">
|
|
|
|
|
<div class="col-9">
|
|
|
|
|
<div class="toptitle">
|
|
|
|
|
{{ store.step }}.{{ store.titel[store.step - 1] }}
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="col-3 text-right">
|
2023-12-14 16:43:32 +07:00
|
|
|
<q-btn
|
|
|
|
|
v-if="store.step === 1"
|
|
|
|
|
:href="externalLink"
|
|
|
|
|
target="_blank"
|
|
|
|
|
outline
|
|
|
|
|
color="blue"
|
|
|
|
|
no-caps
|
|
|
|
|
>
|
|
|
|
|
ตรวจสอบคุณสมบัติกับ ก.พ.
|
2023-12-14 15:12:27 +07:00
|
|
|
</q-btn>
|
2023-12-14 14:49:27 +07:00
|
|
|
</div>
|
2023-12-13 15:24:59 +07:00
|
|
|
</div>
|
2023-12-14 14:49:27 +07:00
|
|
|
|
2023-12-13 15:24:59 +07:00
|
|
|
<div class="row q-col-gutter-md col-12">
|
|
|
|
|
<div
|
|
|
|
|
:class="
|
2023-12-13 16:56:43 +07:00
|
|
|
store.step === 2 ||
|
|
|
|
|
store.step === 4 ||
|
|
|
|
|
store.step === 5 ||
|
|
|
|
|
store.step === 6 ||
|
|
|
|
|
store.step === 8 ||
|
|
|
|
|
store.step === 9
|
2023-12-13 15:24:59 +07:00
|
|
|
? 'col-xs-12 col-sm-12 row'
|
|
|
|
|
: 'col-xs-12 col-sm-5 row'
|
|
|
|
|
"
|
|
|
|
|
>
|
|
|
|
|
<q-card flat bordered class="col-12 q-pa-md">
|
|
|
|
|
<q-card-section>
|
|
|
|
|
<Step1 v-if="store.step === 1" />
|
2023-12-15 17:50:47 +07:00
|
|
|
<Step2 v-if="store.step === 2" @update:form="updateformCommand" />
|
2023-12-13 15:24:59 +07:00
|
|
|
<Step3 v-if="store.step === 3" />
|
|
|
|
|
<Step4 v-if="store.step === 4" />
|
|
|
|
|
<Step5 v-if="store.step === 5" />
|
|
|
|
|
<Step6 v-if="store.step === 6" />
|
|
|
|
|
<Step7 v-if="store.step === 7" />
|
|
|
|
|
<Step8 v-if="store.step === 8" />
|
|
|
|
|
<Step9 v-if="store.step === 9" />
|
|
|
|
|
</q-card-section>
|
|
|
|
|
</q-card>
|
|
|
|
|
</div>
|
2023-12-13 16:56:43 +07:00
|
|
|
<div
|
|
|
|
|
class="col-xs-12 col-sm-7 row"
|
|
|
|
|
v-if="store.step === 1 || store.step === 3 || store.step === 7"
|
|
|
|
|
>
|
2023-12-13 15:24:59 +07:00
|
|
|
<q-card flat bordered class="col-12">
|
|
|
|
|
<q-card-section>
|
|
|
|
|
<ViewStep1 v-if="store.step === 1" />
|
2023-12-13 16:56:43 +07:00
|
|
|
<ViewStep3 v-if="store.step === 3" />
|
|
|
|
|
<ViewStep7 v-if="store.step === 7" /> </q-card-section
|
2023-12-13 15:24:59 +07:00
|
|
|
></q-card>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="q-mt-md q-gutter-md" align="right">
|
|
|
|
|
<q-btn
|
|
|
|
|
v-if="store.step !== 1"
|
|
|
|
|
unelevated
|
|
|
|
|
outline
|
|
|
|
|
label="ย้อนกลับ"
|
|
|
|
|
color="public"
|
|
|
|
|
@click="onCilckprPeviousStep"
|
|
|
|
|
/>
|
|
|
|
|
<q-btn
|
|
|
|
|
unelevated
|
2023-12-13 18:06:21 +07:00
|
|
|
label="ดำเนินการต่อ"
|
2023-12-13 15:24:59 +07:00
|
|
|
color="public"
|
|
|
|
|
@click="onCilckNextStep"
|
|
|
|
|
/>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
2023-12-18 15:30:14 +07:00
|
|
|
|
|
|
|
|
<DialogMain
|
|
|
|
|
:modal="modalDirector"
|
|
|
|
|
:close="closeDialogDirector"
|
|
|
|
|
:fetchDirector="fetchDirector"
|
|
|
|
|
:fetchMeeting="fetchMeeting"
|
|
|
|
|
/>
|
2023-12-13 15:24:59 +07:00
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<style>
|
|
|
|
|
.q-stepper--vertical .q-stepper__step-inner {
|
|
|
|
|
padding: 0;
|
|
|
|
|
}
|
|
|
|
|
</style>
|