update workflow

This commit is contained in:
DESKTOP-1R2VSQH\Lenovo ThinkPad E490 2024-10-17 18:06:31 +07:00
parent 5d9131d5b7
commit b4c7ee8129
5 changed files with 1266 additions and 1197 deletions

File diff suppressed because it is too large Load diff

View file

@ -28,6 +28,7 @@ import FormLeaveToTraining from "@/modules/09_leave/components/2_Leave/formDetai
import FormLeaveToWorkInternational from "@/modules/09_leave/components/2_Leave/formDetail/formLeaveToWorkInternational.vue"; //
import FormSpouse from "@/modules/09_leave/components/2_Leave/formDetail/formSpouse.vue"; //
import FormVocationalRehabilitation from "@/modules/09_leave/components/2_Leave/formDetail/formVocationalRehabilitation.vue"; //
import WorkFlow from "@/components/Workflow/Main.vue";
/** use */
const $q = useQuasar();
@ -131,8 +132,7 @@ async function fetchDetailLeave(paramsId: string) {
await http
.get(config.API.leaveListById(paramsId))
.then(async (res) => {
const data = res.data.result;
const data = await res.data.result;
formData.id = data.id;
formData.reasonCommander = data.reasonCommander
? data.reasonCommander
@ -350,16 +350,18 @@ function sendToCommand() {
dialogConfirm(
$q,
async () => {
showLoader();
await http
.get(config.API.leaveApproveToComander(formData.id))
.then(() => {
.then(async () => {
await fetchDetailLeave(paramsId);
success($q, "บันทึกข้อมูลสำเร็จ");
})
.catch((err) => {
messageError($q, err);
})
.finally(async () => {
await fetchDetailLeave(paramsId);
hideLoader();
});
},
"ยืนยันการส่งไปผู้บังคับบัญชา",
@ -377,17 +379,19 @@ function clickSave(reason: string) {
dialogConfirm(
$q,
async () => {
showLoader();
await http
.put(config.API.leaveApprove(formData.id), body)
.then(() => {
.then(async () => {
await fetchDetailLeave(paramsId);
success($q, "บันทึกข้อมูลสำเร็จ");
modalApprove.value = false;
})
.catch((err) => {
messageError($q, err);
})
.finally(async () => {
await fetchDetailLeave(paramsId);
modalApprove.value = false;
hideLoader();
});
},
"ยืนยันอนุมัติ",
@ -399,17 +403,19 @@ function clickSave(reason: string) {
dialogConfirm(
$q,
async () => {
showLoader();
await http
.put(config.API.leaveReject(formData.id), body)
.then(() => {
.then(async () => {
await fetchDetailLeave(paramsId);
success($q, "บันทึกข้อมูลสำเร็จ");
modalApprove.value = false;
})
.catch((err) => {
messageError($q, err);
})
.finally(async () => {
await fetchDetailLeave(paramsId);
modalApprove.value = false;
hideLoader();
});
},
"ยืนยันไม่อนุมัติ",
@ -420,17 +426,19 @@ function clickSave(reason: string) {
dialogConfirm(
$q,
async () => {
showLoader();
await http
.put(config.API.leaveComanderApprove(formData.id), body)
.then(() => {
.then(async () => {
await fetchDetailLeave(paramsId);
success($q, "บันทึกข้อมูลสำเร็จ");
modalApprove.value = false;
})
.catch((err) => {
messageError($q, err);
})
.finally(async () => {
await fetchDetailLeave(paramsId);
modalApprove.value = false;
hideLoader();
});
},
"ยืนยันการส่งไปยังผู้มีอำนาจ",
@ -460,12 +468,12 @@ function formattedNumber(x: number) {
}
onMounted(async () => {
// showLoader();
if (paramsId) {
await fetchDetailLeave(paramsId);
}
});
</script>
<template>
<div class="toptitle text-dark col-12 row items-center">
<div class="row col-12 q-col-gutter-sm q-mb-sm">
@ -480,7 +488,7 @@ onMounted(async () => {
class="q-mr-sm"
@click="router.push(`/leave`)"
/>
รายละเอยดการลาของ {{ formData.fullName }}
รายละเอยดการลาของ{{ formData.fullName }}
</div>
<div>
<q-btn class="q-mr-sm" icon="mdi-download" round color="primary" flat>
@ -534,269 +542,291 @@ onMounted(async () => {
<q-space />
</div>
</div>
<q-card flat bordered class="col-12 q-mt-sm">
<div class="col-12 row q-py-md q-pl-md">
<div class="col-12 q-col-gutter-md">
<div class="row col-12">
<q-card bordered class="bg-grey-1 q-pa-md col-12">
<div class="row q-col-gutter-md col-12">
<div class="col-xs-12 col-sm-5 row items-center q-my-xs">
<div class="col-12 row">
<div class="col-xs-5 col-sm-3 text-grey-8">ประเภทการลา</div>
<div class="col text-primary">
{{
checkForm !== "FormUpasom" && checkForm !== "FormHajj"
? formData.leaveTypeName
: formData.hajjDayStatus
? "ลาประกอบพิธีฮัจญ์"
: "ลาอุปสมบท"
}}
<div class="q-pa-sm">
<q-card flat bordered class="col-12 q-mt-sm">
<div class="col-12 row q-py-md q-pl-md">
<div class="col-12 q-col-gutter-md">
<!-- ประเภทการลา -->
<div class="row col-12">
<q-card bordered class="bg-grey-1 q-pa-md col-12">
<div class="row q-col-gutter-md col-12">
<div class="col-xs-12 col-sm-5 row items-center q-my-xs">
<div class="col-12 row">
<div class="col-xs-5 col-sm-3 text-grey-8">ประเภทการลา</div>
<div class="col text-primary">
{{
checkForm !== "FormUpasom" && checkForm !== "FormHajj"
? formData.leaveTypeName
: formData.hajjDayStatus
? "ลาประกอบพิธีฮัจญ์"
: "ลาอุปสมบท"
}}
</div>
</div>
<div class="col-12 row">
<div class="col-xs-5 col-sm-3 text-grey-8">
- นามสก
</div>
<div class="col text-weight-medium">
{{ formData.fullName }}
</div>
</div>
</div>
<div class="col-12 row">
<div class="col-xs-5 col-sm-3 text-grey-8">
- นามสก
</div>
<div class="col text-weight-medium">
{{ formData.fullName }}
</div>
</div>
</div>
<div class="col-xs-12 col-sm-7 row">
<div class="row col-12 q-gutter-md">
<div
v-if="formData.leaveTypeName == 'ลาพักผ่อน'"
class="col-3"
>
<q-card bordered class="items-center row col-12 q-pa-md">
<div class="text-h6 text-weight-bold text-blue-10">
{{ formData.leaveLimit }}
</div>
<div class="col-12 text-subtitle2 text-weight-regular">
<span class="gt-xs">ได</span>
</div>
</q-card>
</div>
<div class="col-3">
<q-card bordered class="items-center row col-12 q-pa-md">
<div class="text-h6 text-weight-bold text-light-blue-6">
{{ formData.leaveSummary }}
</div>
<div class="col-12 text-subtitle2 text-weight-regular">
<span class="gt-xs">ใชไป</span>
</div>
</q-card>
</div>
<div
v-if="formData.leaveTypeName == 'ลาพักผ่อน'"
class="col-3"
>
<q-card bordered class="items-center row col-12 q-pa-md">
<div class="text-h6 text-weight-bold text-indigo-7">
{{ formData.leaveRemain }}
</div>
<div class="col-12 text-subtitle2 text-weight-regular">
<span class="gt-xs">คงเหล</span>
</div>
</q-card>
<div class="col-xs-12 col-sm-7 row">
<div class="row col-12 q-gutter-md">
<div
v-if="formData.leaveTypeName == 'ลาพักผ่อน'"
class="col-3"
>
<q-card bordered class="items-center row col-12 q-pa-md">
<div class="text-h6 text-weight-bold text-blue-10">
{{ formData.leaveLimit }}
</div>
<div class="col-12 text-subtitle2 text-weight-regular">
<span class="gt-xs">ได</span>
</div>
</q-card>
</div>
<div class="col-3">
<q-card bordered class="items-center row col-12 q-pa-md">
<div class="text-h6 text-weight-bold text-light-blue-6">
{{ formData.leaveSummary }}
</div>
<div class="col-12 text-subtitle2 text-weight-regular">
<span class="gt-xs">ใชไป</span>
</div>
</q-card>
</div>
<div
v-if="formData.leaveTypeName == 'ลาพักผ่อน'"
class="col-3"
>
<q-card bordered class="items-center row col-12 q-pa-md">
<div class="text-h6 text-weight-bold text-indigo-7">
{{ formData.leaveRemain }}
</div>
<div class="col-12 text-subtitle2 text-weight-regular">
<span class="gt-xs">คงเหล</span>
</div>
</q-card>
</div>
</div>
</div>
</div>
</q-card>
</div>
<!-- อมลการลา -->
<div class="row q-col-gutter-md col-12">
<!-- อมลซาย -->
<div class="col-xs-12 col-sm-5 row">
<!-- card าย -->
<q-card flat bordered class="col-12">
<FormMain :data="formData" :checkForm="checkForm" />
</q-card>
</div>
</q-card>
</div>
<div class="row q-col-gutter-md col-12">
<div class="col-xs-12 col-sm-5 row">
<!-- card าย -->
<q-card flat bordered class="col-12">
<FormMain :data="formData" :checkForm="checkForm" />
</q-card>
</div>
<div class="col-xs-12 col-sm-7 row">
<q-card flat bordered class="col-12">
<!-- ลาปวย ลาคลอดบตร และลากจสวนต -->
<FormLeave v-if="checkForm === 'FormLeave'" :data="formData" />
<!-- อมลขวา -->
<div class="col-xs-12 col-sm-7 row">
<q-card flat bordered class="col-12">
<!-- ลาปวย ลาคลอดบตร และลากจสวนต -->
<FormLeave v-if="checkForm === 'FormLeave'" :data="formData" />
<!-- ลาไปชวยเหลอภรยาทคลอดบตร -->
<FormChildbirth
v-else-if="checkForm === 'FormChildbirth'"
:data="formData"
/>
<!-- ลาไปชวยเหลอภรยาทคลอดบตร -->
<FormChildbirth
v-else-if="checkForm === 'FormChildbirth'"
:data="formData"
/>
<!-- ลาพกผอน -->
<FormHoliday
v-else-if="checkForm === 'FormHoliday'"
:data="formData"
/>
<!-- ลาพกผอน -->
<FormHoliday
v-else-if="checkForm === 'FormHoliday'"
:data="formData"
/>
<!-- ลาอปสมบท -->
<FormUpasom
v-else-if="checkForm === 'FormUpasom'"
:data="formData"
/>
<!-- ลาอปสมบท -->
<FormUpasom
v-else-if="checkForm === 'FormUpasom'"
:data="formData"
/>
<!-- ลาประกอบพจญ -->
<FormHajj v-else-if="checkForm === 'FormHajj'" :data="formData" />
<!-- ลาประกอบพจญ -->
<FormHajj
v-else-if="checkForm === 'FormHajj'"
:data="formData"
/>
<!-- ลาเขารบการตรวจเลอกหรอเขารบการเตรยมพล -->
<FormCheckSelect
v-else-if="checkForm === 'FormCheckSelect'"
:data="formData"
/>
<!-- ลาเขารบการตรวจเลอกหรอเขารบการเตรยมพล -->
<FormCheckSelect
v-else-if="checkForm === 'FormCheckSelect'"
:data="formData"
/>
<!-- ลาไปศกษา -->
<FormStudy
v-else-if="checkForm === 'FormStudy'"
:data="formData"
/>
<!-- ลาไปศกษา -->
<FormStudy
v-else-if="checkForm === 'FormStudy'"
:data="formData"
/>
<!-- ลาไปฝกอบรม ปฏการว หรอดงาน -->
<FormLeaveToTraining
v-else-if="checkForm === 'FormLeaveToTraining'"
:data="formData"
/>
<!-- ลาไปฝกอบรม ปฏการว หรอดงาน -->
<FormLeaveToTraining
v-else-if="checkForm === 'FormLeaveToTraining'"
:data="formData"
/>
<!-- ลาไปปฏงานในองคการระหวางประเทศ -->
<FormLeaveToWorkInternational
v-else-if="checkForm === 'FormLeaveToWorkInternational'"
:data="formData"
/>
<!-- ลาไปปฏงานในองคการระหวางประเทศ -->
<FormLeaveToWorkInternational
v-else-if="checkForm === 'FormLeaveToWorkInternational'"
:data="formData"
/>
<!-- ลาตดตามคสมรส -->
<FormSpouse
v-else-if="checkForm === 'FormSpouse'"
:data="formData"
/>
<!-- ลาตดตามคสมรส -->
<FormSpouse
v-else-if="checkForm === 'FormSpouse'"
:data="formData"
/>
<!-- ลาไปฟนฟสมรรถภาพดานอาช -->
<FormVocationalRehabilitation
v-else-if="checkForm === 'FormVocationalRehabilitation'"
:data="formData"
/>
</q-card>
</div>
<div class="col-xs-12 col-sm-12 row">
<q-card
bordered
class="row col-12 text-dark q-mt-sm"
<!-- ลาไปฟนฟสมรรถภาพดานอาช -->
<FormVocationalRehabilitation
v-else-if="checkForm === 'FormVocationalRehabilitation'"
:data="formData"
/>
</q-card>
</div>
<!-- ความคดเหนของผงคบบญชา -->
<div
class="col-xs-12 col-sm-12 row"
v-if="
formData.approveStep === 'st3' ||
formData.approveStep === 'st4' ||
formData.approveStep === 'st5'
"
>
<div
class="bg-grey-1 q-pa-sm col-12 row items-center text-primary"
>
<div class="q-pl-sm text-weight-bold text-dark">
ความคดเหนของผงคบบญชา
<q-card bordered class="row col-12 text-dark q-mt-sm">
<div
class="bg-grey-1 q-pa-sm col-12 row items-center text-primary"
>
<div class="q-pl-sm text-weight-bold text-dark">
ความคดเหนของผงคบบญชา
</div>
</div>
</div>
<q-separator />
<div class="row col-12 q-pa-md">
<div class="col-12 row bg-white q-col-gutter-md">
<div class="col-xs-6 row items-start">
<div class="col-12 text-detail">
{{ formData.reasonCommander }}
<q-separator />
<div class="row col-12 q-pa-md">
<div class="col-12 row bg-white q-col-gutter-md">
<div class="col-xs-6 row items-start">
<div class="col-12 text-detail">
{{ formData.reasonCommander }}
</div>
</div>
</div>
</div>
</div>
</q-card>
</div>
<div class="col-xs-12 col-sm-12 row">
<q-card
bordered
class="row col-12 text-dark q-mt-sm"
</q-card>
</div>
<!-- ความคดเหนของผอำนาจ -->
<div
class="col-xs-12 col-sm-12 row"
v-if="
formData.approveStep === 'st4' || formData.approveStep === 'st5'
"
>
<div
class="bg-grey-1 q-pa-sm col-12 row items-center text-primary"
>
<div class="q-pl-sm text-weight-bold text-dark">
ความคดเหนของผอำนาจ
</div>
</div>
<q-separator />
<div class="row col-12 q-pa-md">
<div class="col-12 row bg-white q-col-gutter-md">
<div class="col-xs-6 row items-start">
<div class="col-12 text-weight-bold text-top">
ผลการพจารณา
</div>
<div class="col-12 text-detail">{{ formData.status }}</div>
<q-card bordered class="row col-12 text-dark q-mt-sm">
<div
class="bg-grey-1 q-pa-sm col-12 row items-center text-primary"
>
<div class="q-pl-sm text-weight-bold text-dark">
ความคดเหนของผอำนาจ
</div>
<div class="col-xs-6 row items-start">
<div class="col-12 text-weight-bold text-top">
ความคดเห
</div>
<q-separator />
<div class="row col-12 q-pa-md">
<div class="col-12 row bg-white q-col-gutter-md">
<div class="col-xs-6 row items-start">
<div class="col-12 text-weight-bold text-top">
ผลการพจารณา
</div>
<div class="col-12 text-detail">
{{ formData.status }}
</div>
</div>
<div class="col-12 text-detail">
{{ formData.reasonOligarch }}
<div class="col-xs-6 row items-start">
<div class="col-12 text-weight-bold text-top">
ความคดเห
</div>
<div class="col-12 text-detail">
{{ formData.reasonOligarch }}
</div>
</div>
</div>
</div>
</div>
</q-card>
</q-card>
</div>
</div>
<!-- Workflow -->
<div class="col-xs-12 col-sm-12">
<WorkFlow ref="workflowRef" :id="paramsId" sys-name="LEAVE_LIST" />
</div>
</div>
</div>
</div>
<q-separator v-if="checkPermission($route)?.attrIsUpdate" />
<div class="row q-pa-md q-gutter-md justify-end">
<q-btn
v-if="
formData.approveStep === 'st1' &&
formData.status !== 'ยกเลิก' &&
checkPermission($route)?.attrIsUpdate
"
unelevated
color="orange-5"
label="ส่งไปยังผู้บังคับบัญชา"
@click="sendToCommand"
><q-tooltip>งไปยงผงคบบญชา</q-tooltip>
</q-btn>
<q-btn
v-if="
formData.approveStep === 'st2' &&
formData.status !== 'ยกเลิก' &&
checkPermission($route)?.attrIsUpdate
"
unelevated
color="orange-5"
label="ส่งไปยังผู้มีอำนาจ"
@click="openModal('authority')"
><q-tooltip>งไปยงผอำนาจ</q-tooltip>
</q-btn>
<q-separator v-if="checkPermission($route)?.attrIsUpdate" />
<div class="row q-pa-md q-gutter-md justify-end">
<q-btn
v-if="
formData.approveStep === 'st1' &&
formData.status !== 'ยกเลิก' &&
checkPermission($route)?.attrIsUpdate
"
unelevated
color="orange-5"
label="ส่งไปยังผู้บังคับบัญชา"
@click="sendToCommand"
><q-tooltip>งไปยงผงคบบญชา</q-tooltip>
</q-btn>
<q-btn
v-if="
formData.approveStep === 'st2' &&
formData.status !== 'ยกเลิก' &&
checkPermission($route)?.attrIsUpdate
"
unelevated
color="orange-5"
label="ส่งไปยังผู้มีอำนาจ"
@click="openModal('authority')"
><q-tooltip>งไปยงผอำนาจ</q-tooltip>
</q-btn>
<q-btn
v-if="
formData.approveStep === 'st3' &&
formData.status !== 'ยกเลิก' &&
checkPermission($route)?.attrIsUpdate
"
unelevated
color="orange-5"
label="ไม่อนุมัติ"
@click="openModal('UnApprove')"
><q-tooltip>ไมอน</q-tooltip>
</q-btn>
<q-btn
v-if="
formData.approveStep === 'st3' &&
formData.status !== 'ยกเลิก' &&
checkPermission($route)?.attrIsUpdate
"
unelevated
color="primary"
label="อนุมัติ"
@click="openModal('approve')"
><q-tooltip>อน</q-tooltip>
</q-btn>
</div>
</q-card>
</div>
<q-btn
v-if="
formData.approveStep === 'st3' &&
formData.status !== 'ยกเลิก' &&
checkPermission($route)?.attrIsUpdate
"
unelevated
color="orange-5"
label="ไม่อนุมัติ"
@click="openModal('UnApprove')"
><q-tooltip>ไมอน</q-tooltip>
</q-btn>
<q-btn
v-if="
formData.approveStep === 'st3' &&
formData.status !== 'ยกเลิก' &&
checkPermission($route)?.attrIsUpdate
"
unelevated
color="primary"
label="อนุมัติ"
@click="openModal('approve')"
><q-tooltip>อน</q-tooltip>
</q-btn>
</div>
</q-card>
<DialogReason
v-model:modal="modalApprove"
:title="dialogTitle"

View file

@ -31,6 +31,7 @@ import FormLeaveToTraining from "@/modules/09_leave/components/2_Leave/formDetai
import FormLeaveToWorkInternational from "@/modules/09_leave/components/2_Leave/formDetail/formLeaveToWorkInternational.vue"; //
import FormSpouse from "@/modules/09_leave/components/2_Leave/formDetail/formSpouse.vue"; //
import FormVocationalRehabilitation from "@/modules/09_leave/components/2_Leave/formDetail/formVocationalRehabilitation.vue"; //
import WorkFlow from "@/components/Workflow/Main.vue";
/** use */
const $q = useQuasar();
@ -150,8 +151,13 @@ const formData = reactive<FremData>({
onMounted(async () => {
if (paramsId) {
await fetchDetailDeleteLeave(paramsId);
await fetchDetailLeave(paramsId);
showLoader();
Promise.all([
fetchDetailDeleteLeave(paramsId),
fetchDetailLeave(paramsId),
]).finally(() => {
hideLoader();
});
}
});
@ -160,7 +166,6 @@ onMounted(async () => {
* @param paramsId ID จาก paramID
*/
async function fetchDetailDeleteLeave(paramsId: string) {
showLoader();
await http
.get(config.API.leaveListDeleteByid(paramsId))
.then((res) => {
@ -183,18 +188,14 @@ async function fetchDetailDeleteLeave(paramsId: string) {
})
.catch((err) => {
messageError($q, err);
})
.finally(() => {
hideLoader();
});
}
async function fetchDetailLeave(paramsId: string) {
showLoader();
await http
.get(config.API.leaveListById(paramsId))
.then(async (res) => {
const data = res.data.result;
const data = await res.data.result;
formData.id = data.id;
formData.reasonCommander = data.reasonCommander;
formData.reasonOligarch = data.reasonOligarch;
@ -278,9 +279,6 @@ async function fetchDetailLeave(paramsId: string) {
})
.catch((err) => {
messageError($q, err);
})
.finally(() => {
hideLoader();
});
}
@ -413,6 +411,7 @@ async function onClickDownloadFile(id: string, fileName: string, type: string) {
});
}
</script>
<template>
<div class="toptitle text-dark col-12 row items-center">
<div class="row col-12 q-col-gutter-sm q-mb-sm">
@ -473,257 +472,275 @@ async function onClickDownloadFile(id: string, fileName: string, type: string) {
<q-space />
</div>
</div>
<q-card flat bordered class="col-12 q-mt-sm">
<div class="col-12 row q-py-md q-pl-md">
<div class="col-12 q-col-gutter-md">
<div class="col-xs-12 col-sm-12 row">
<q-card bordered class="row col-12 text-dark q-mt-sm">
<div class="bg-grey-1 q-pa-sm col-12 row items-center text-primary">
<div class="q-pl-sm text-weight-bold text-dark">
รายละเอยดการขอยกเล
</div>
</div>
<q-separator />
<div class="row col-12 q-pa-md">
<div class="col-12 row bg-white q-col-gutter-md">
<div class="col-xs-3 row items-start">
<div class="col-12 text-weight-bold text-top">เขยนท</div>
<div class="col-12 text-detail">
{{ formDataReject.leaveWrote }}
</div>
</div>
<div class="col-xs-3 row items-start">
<div class="col-12 text-weight-bold text-top">นท</div>
<div class="col-12 text-detail">
{{ date2Thai(formDataReject.leaveStartDate) }}
</div>
</div>
<div class="col-xs-3 row items-start">
<div class="col-12 text-weight-bold text-top">เหตผล</div>
<div class="col-12 text-detail">
{{ formDataReject.leaveReasonDelete }}
</div>
</div>
<div class="col-xs-3 row items-start">
<div class="col-12 text-weight-bold text-top">
เอกสารประกอบ
</div>
<div class="col-12 text-detail">
<q-btn
v-if="formDataReject.leaveDocDelete"
:href="formDataReject.leaveDocDelete"
target="_blank"
outline
color="blue"
label="ดาวน์โหลด"
size="12px"
>
<q-tooltip>ดาวนโหลดไฟล</q-tooltip></q-btn
>
<span v-else>-</span>
</div>
</div>
</div>
</div>
</q-card>
</div>
<div class="row col-12">
<q-card bordered class="bg-grey-1 q-pa-md col-12">
<div class="row q-col-gutter-md col-12">
<div class="col-xs-12 col-sm-5 row items-center q-my-xs">
<div class="col-12 row">
<div class="col-xs-5 col-sm-3 text-grey-8">ประเภทการลา</div>
<div class="col text-primary">
{{ formData.leaveTypeName }}
</div>
</div>
<div class="col-12 row">
<div class="col-xs-5 col-sm-3 text-grey-8">
- นามสก
</div>
<div class="col text-weight-medium">
{{ formData.fullName }}
</div>
</div>
</div>
<div class="col-xs-12 col-sm-7 row">
<div class="row col-12 q-gutter-md">
<div
v-if="formData.leaveTypeName == 'ลาพักผ่อน'"
class="col-3"
>
<q-card bordered class="items-center row col-12 q-pa-md">
<div class="text-h6 text-weight-bold text-blue-10">
{{ formData.leaveLimit }}
</div>
<div class="col-12 text-subtitle2 text-weight-regular">
<span class="gt-xs">ได</span>
</div>
</q-card>
</div>
<div class="col-3">
<q-card bordered class="items-center row col-12 q-pa-md">
<div class="text-h6 text-weight-bold text-light-blue-6">
{{ formData.leaveSummary }}
</div>
<div class="col-12 text-subtitle2 text-weight-regular">
<span class="gt-xs">ใชไป</span>
</div>
</q-card>
</div>
<div
v-if="formData.leaveTypeName == 'ลาพักผ่อน'"
class="col-3"
>
<q-card bordered class="items-center row col-12 q-pa-md">
<div class="text-h6 text-weight-bold text-indigo-7">
{{ formData.leaveRemain }}
</div>
<div class="col-12 text-subtitle2 text-weight-regular">
<span class="gt-xs">คงเหล</span>
</div>
</q-card>
</div>
</div>
</div>
</div>
</q-card>
</div>
<div class="row q-col-gutter-md col-12">
<div class="col-xs-12 col-sm-5 row">
<!-- card าย -->
<q-card flat bordered class="col-12">
<FormMain :data="formData" />
</q-card>
</div>
<div class="col-xs-12 col-sm-7 row">
<q-card flat bordered class="col-12">
<!-- ลาปวย ลาคลอดบตร และลากจสวนต -->
<FormLeave v-if="checkForm === 'FormLeave'" :data="formData" />
<!-- ลาไปชวยเหลอภรยาทคลอดบตร -->
<FormChildbirth
v-else-if="checkForm === 'FormChildbirth'"
:data="formData"
/>
<!-- ลาพกผอน -->
<FormHoliday
v-else-if="checkForm === 'FormHoliday'"
:data="formData"
/>
<!-- ลาอปสมบท -->
<FormUpasom
v-else-if="checkForm === 'FormUpasom'"
:data="formData"
/>
<!-- ลาประกอบพจญ -->
<FormHajj v-else-if="checkForm === 'FormHajj'" :data="formData" />
<!-- ลาเขารบการตรวจเลอกหรอเขารบการเตรยมพล -->
<FormCheckSelect
v-else-if="checkForm === 'FormCheckSelect'"
:data="formData"
/>
<!-- ลาไปศกษา -->
<FormStudy
v-else-if="checkForm === 'FormStudy'"
:data="formData"
/>
<!-- ลาไปฝกอบรม ปฏการว หรอดงาน -->
<FormLeaveToTraining
v-else-if="checkForm === 'FormLeaveToTraining'"
:data="formData"
/>
<!-- ลาไปปฏงานในองคการระหวางประเทศ -->
<FormLeaveToWorkInternational
v-else-if="checkForm === 'FormLeaveToWorkInternational'"
:data="formData"
/>
<!-- ลาตดตามคสมรส -->
<FormSpouse
v-else-if="checkForm === 'FormSpouse'"
:data="formData"
/>
<!-- ลาไปฟนฟสมรรถภาพดานอาช -->
<FormVocationalRehabilitation
v-else-if="checkForm === 'FormVocationalRehabilitation'"
:data="formData"
/>
</q-card>
</div>
<div class="q-pa-sm">
<q-card flat bordered class="col-12">
<div class="col-12 row q-py-md q-pl-md">
<div class="col-12 q-col-gutter-md">
<div class="col-xs-12 col-sm-12 row">
<q-card
bordered
class="row col-12 text-dark q-mt-sm"
v-if="formDataReject.status !== 'NEW'"
>
<q-card bordered class="row col-12 text-dark q-mt-sm">
<div
class="bg-grey-1 q-pa-sm col-12 row items-center text-primary"
>
<div class="q-pl-sm text-weight-bold text-dark">
ความคดเหนของผอำนาจ
รายละเอยดการขอยกเล
</div>
</div>
<q-separator />
<div class="row col-12 q-pa-md">
<div class="col-12 row bg-white q-col-gutter-md">
<div class="col-xs-6 row items-start">
<div class="col-12 text-weight-bold text-top">
ผลการพจารณา
</div>
<div class="col-xs-3 row items-start">
<div class="col-12 text-weight-bold text-top">เขยนท</div>
<div class="col-12 text-detail">
{{ stores.convertSatatus(formDataReject.status) }}
{{ formDataReject.leaveWrote }}
</div>
</div>
<div class="col-xs-6 row items-start">
<div class="col-12 text-weight-bold text-top">
ความคดเห
<div class="col-xs-3 row items-start">
<div class="col-12 text-weight-bold text-top">นท</div>
<div class="col-12 text-detail">
{{ date2Thai(formDataReject.leaveStartDate) }}
</div>
</div>
<div class="col-xs-3 row items-start">
<div class="col-12 text-weight-bold text-top">เหตผล</div>
<div class="col-12 text-detail">
{{ formDataReject.leaveReasonDelete }}
</div>
</div>
<div class="col-xs-3 row items-start">
<div class="col-12 text-weight-bold text-top">
เอกสารประกอบ
</div>
<div class="col-12 text-detail">
<q-btn
v-if="formDataReject.leaveDocDelete"
:href="formDataReject.leaveDocDelete"
target="_blank"
outline
color="blue"
label="ดาวน์โหลด"
size="12px"
>
<q-tooltip>ดาวนโหลดไฟล</q-tooltip></q-btn
>
<span v-else>-</span>
</div>
</div>
</div>
</div>
</q-card>
</div>
<div class="row col-12">
<q-card bordered class="bg-grey-1 q-pa-md col-12">
<div class="row q-col-gutter-md col-12">
<div class="col-xs-12 col-sm-5 row items-center q-my-xs">
<div class="col-12 row">
<div class="col-xs-5 col-sm-3 text-grey-8">ประเภทการลา</div>
<div class="col text-primary">
{{ formData.leaveTypeName }}
</div>
</div>
<div class="col-12 row">
<div class="col-xs-5 col-sm-3 text-grey-8">
- นามสก
</div>
<div class="col text-weight-medium">
{{ formData.fullName }}
</div>
</div>
</div>
<div class="col-xs-12 col-sm-7 row">
<div class="row col-12 q-gutter-md">
<div
v-if="formData.leaveTypeName == 'ลาพักผ่อน'"
class="col-3"
>
<q-card bordered class="items-center row col-12 q-pa-md">
<div class="text-h6 text-weight-bold text-blue-10">
{{ formData.leaveLimit }}
</div>
<div class="col-12 text-subtitle2 text-weight-regular">
<span class="gt-xs">ได</span>
</div>
</q-card>
</div>
<div class="col-3">
<q-card bordered class="items-center row col-12 q-pa-md">
<div class="text-h6 text-weight-bold text-light-blue-6">
{{ formData.leaveSummary }}
</div>
<div class="col-12 text-subtitle2 text-weight-regular">
<span class="gt-xs">ใชไป</span>
</div>
</q-card>
</div>
<div
v-if="formData.leaveTypeName == 'ลาพักผ่อน'"
class="col-3"
>
<q-card bordered class="items-center row col-12 q-pa-md">
<div class="text-h6 text-weight-bold text-indigo-7">
{{ formData.leaveRemain }}
</div>
<div class="col-12 text-subtitle2 text-weight-regular">
<span class="gt-xs">คงเหล</span>
</div>
</q-card>
</div>
</div>
</div>
</div>
</q-card>
</div>
<div class="row q-col-gutter-md col-12">
<div class="col-xs-12 col-sm-5 row">
<!-- card าย -->
<q-card flat bordered class="col-12">
<FormMain :data="formData" />
</q-card>
</div>
<!-- อมลการลา -->
<div class="col-xs-12 col-sm-7 row">
<q-card flat bordered class="col-12">
<!-- ลาปวย ลาคลอดบตร และลากจสวนต -->
<FormLeave v-if="checkForm === 'FormLeave'" :data="formData" />
<!-- ลาไปชวยเหลอภรยาทคลอดบตร -->
<FormChildbirth
v-else-if="checkForm === 'FormChildbirth'"
:data="formData"
/>
<!-- ลาพกผอน -->
<FormHoliday
v-else-if="checkForm === 'FormHoliday'"
:data="formData"
/>
<!-- ลาอปสมบท -->
<FormUpasom
v-else-if="checkForm === 'FormUpasom'"
:data="formData"
/>
<!-- ลาประกอบพจญ -->
<FormHajj
v-else-if="checkForm === 'FormHajj'"
:data="formData"
/>
<!-- ลาเขารบการตรวจเลอกหรอเขารบการเตรยมพล -->
<FormCheckSelect
v-else-if="checkForm === 'FormCheckSelect'"
:data="formData"
/>
<!-- ลาไปศกษา -->
<FormStudy
v-else-if="checkForm === 'FormStudy'"
:data="formData"
/>
<!-- ลาไปฝกอบรม ปฏการว หรอดงาน -->
<FormLeaveToTraining
v-else-if="checkForm === 'FormLeaveToTraining'"
:data="formData"
/>
<!-- ลาไปปฏงานในองคการระหวางประเทศ -->
<FormLeaveToWorkInternational
v-else-if="checkForm === 'FormLeaveToWorkInternational'"
:data="formData"
/>
<!-- ลาตดตามคสมรส -->
<FormSpouse
v-else-if="checkForm === 'FormSpouse'"
:data="formData"
/>
<!-- ลาไปฟนฟสมรรถภาพดานอาช -->
<FormVocationalRehabilitation
v-else-if="checkForm === 'FormVocationalRehabilitation'"
:data="formData"
/>
</q-card>
</div>
<!-- ความคดเหนของผอำนาจ -->
<div
class="col-xs-12 col-sm-12 row"
v-if="formDataReject.status !== 'NEW'"
>
<q-card bordered class="row col-12 text-dark q-mt-sm">
<div
class="bg-grey-1 q-pa-sm col-12 row items-center text-primary"
>
<div class="q-pl-sm text-weight-bold text-dark">
ความคดเหนของผอำนาจ
</div>
</div>
<q-separator />
<div class="row col-12 q-pa-md">
<div class="col-12 row bg-white q-col-gutter-md">
<div class="col-xs-6 row items-start">
<div class="col-12 text-weight-bold text-top">
ผลการพจารณา
</div>
<div class="col-12 text-detail">
{{ stores.convertSatatus(formDataReject.status) }}
</div>
</div>
<div class="col-xs-6 row items-start">
<div class="col-12 text-weight-bold text-top">
ความคดเห
</div>
<div class="col-12 text-detail">
{{ formDataReject.leaveReasonDelete }}
</div>
</div>
</div>
</div>
</q-card>
</div>
</div>
<!-- Workflow -->
<div class="col-xs-12 col-sm-12">
<WorkFlow ref="workflowRef" :id="paramsId" sys-name="LEAVE_LIST" />
</div>
</div>
</div>
</div>
<q-separator v-if="checkPermission($route)?.attrIsUpdate" />
<div class="row q-pa-md q-gutter-md justify-end">
<q-btn
v-if="
formDataReject.status === 'NEW' &&
checkPermission($route)?.attrIsUpdate
"
unelevated
color="orange-5"
label="ไม่อนุมัติการยกเลิก"
@click="openModal('UnApprove')"
><q-tooltip>ไมอนการยกเล</q-tooltip>
</q-btn>
<q-btn
v-if="
formDataReject.status === 'NEW' &&
checkPermission($route)?.attrIsUpdate
"
unelevated
color="primary"
label="อนุมัติการยกเลิก"
@click="openModal('approve')"
><q-tooltip>อนการยกเล</q-tooltip>
</q-btn>
</div>
</q-card>
<q-separator v-if="checkPermission($route)?.attrIsUpdate" />
<div class="row q-pa-md q-gutter-md justify-end">
<q-btn
v-if="
formDataReject.status === 'NEW' &&
checkPermission($route)?.attrIsUpdate
"
unelevated
color="orange-5"
label="ไม่อนุมัติการยกเลิก"
@click="openModal('UnApprove')"
><q-tooltip>ไมอนการยกเล</q-tooltip>
</q-btn>
<q-btn
v-if="
formDataReject.status === 'NEW' &&
checkPermission($route)?.attrIsUpdate
"
unelevated
color="primary"
label="อนุมัติการยกเลิก"
@click="openModal('approve')"
><q-tooltip>อนการยกเล</q-tooltip>
</q-btn>
</div>
</q-card>
</div>
<DialogReason
v-model:modal="modalApprove"
:title="dialogTitle"

View file

@ -36,6 +36,7 @@ const totalList = ref<number>(0);
//** API*/
async function fecthLeaveList() {
leaveStore.rows = [];
querySting.status = await (querySting.status == null
? "ALL"
: querySting.status);

View file

@ -36,6 +36,7 @@ const totalList = ref<number>(0);
//** API*/
async function fecthLeaveList() {
leaveStore.rows = [];
querySting.status = await (querySting.status == null
? "ALL"
: querySting.status);