Refactoring code module 01_metadata => 04_calendar

This commit is contained in:
DESKTOP-1R2VSQH\Lenovo ThinkPad E490 2024-09-09 09:58:06 +07:00
parent 5074ee5ee1
commit cb1a5251a1
5 changed files with 742 additions and 771 deletions

View file

@ -1,203 +1,3 @@
<!-- tab ปฏ หนาปฏนวนหย -->
<template>
<div class="q-mt-md">
<div class="row q-gutter-sm q-pb-sm main-content">
<div class="demo-app-main">
<!-- แสดงปฏ -->
<FullCalendar
ref="fullCalendar"
class="demo-app-calendar"
:options="calendarOptions"
>
<template v-slot:eventContent="arg">
<b>{{ arg.timeText }}</b>
<i>{{ arg.event.title }}</i>
<q-tooltip style="font-size: 15px">{{ arg.event.title }}</q-tooltip>
</template>
</FullCalendar>
</div>
</div>
<div class="row q-col-gutter-md">
<div class="items-center row">
<q-icon color="blue" name="mdi-circle" class="q-mr-sm" />
นทำงาน 5
</div>
<div class="items-center row">
<q-icon color="orange" name="mdi-circle" class="q-mr-sm" />
นทำงาน 6
</div>
</div>
</div>
<!-- modal เพมวนหย -->
<q-dialog v-model="modalAdd" persistent>
<q-card style="min-width: 550px">
<q-form ref="formDate" @submit.prevent.stop="onSubmit">
<q-card-section class="row items-center q-pa-sm">
<div class="text-bold" v-if="showEdit">แก้ไขวันหยุด</div>
<div class="text-bold" v-else>เพิ่มวันหยุด</div>
<q-space />
<q-btn
icon="close"
unelevated
round
dense
v-close-popup
style="color: #ff8080; background-color: #ffdede"
/>
</q-card-section>
<q-separator />
<q-card-section class="q-p-md row q-gutter-y-md">
<div class="row col-12">
<div class="col-12" v-if="!showEdit">
{{ dateThaiRange(dateRange) }}
</div>
<datepicker
v-else
:readonly="!edit"
v-model="dateRange"
:locale="'th'"
autoApply
range
:enableTimePicker="false"
week-start="0"
>
<template #year="{ year }">
{{ year + 543 }}
</template>
<template #year-overlay-value="{ value }">
{{ parseInt(value + 543) }}
</template>
<template #trigger>
<q-input
:class="getClass(edit)"
hide-bottom-space
:outlined="edit"
dense
label="วันที่"
:borderless="!edit"
:model-value="dateThaiRange(dateRange)"
>
<template v-slot:prepend>
<q-icon
name="event"
class="cursor-pointer"
style="color: var(--q-primary)"
>
</q-icon>
</template>
</q-input>
</template>
</datepicker>
</div>
<q-input
:class="getClass(edit)"
hide-bottom-space
:outlined="edit"
label="คำอธิบาย"
dense
lazy-rules
:readonly="!edit"
:borderless="!edit"
v-model="name"
autogrow
:rules="[(val) => (val && val.length > 0) || '']"
/>
<q-option-group
v-if="showEdit == false"
v-model="category"
:options="categoryOptions"
color="primary"
inline
/>
</q-card-section>
<q-separator />
<q-card-actions align="right" class="text-primary">
<q-btn
v-if="showEdit && edit"
flat
color="red"
@click="cancelClick()"
label="ยกเลิกแก้ไข"
>
<!-- icon="mdi-undo"
<q-tooltip>ยกเล</q-tooltip> -->
</q-btn>
<q-btn
v-if="showEdit && edit"
unelevated
color="red"
@click="deleteClick()"
label="ลบวันหยุด"
>
<!-- icon="mdi-delete"
<q-tooltip>ลบ</q-tooltip> -->
</q-btn>
<q-btn
v-if="edit"
unelevated
color="public"
label="บันทึก"
type="submit"
>
<!-- icon="mdi-content-save-outline"
<q-tooltip>นท</q-tooltip> -->
</q-btn>
<q-btn
v-if="!edit"
outline
color="edit"
@click="editClick"
label="แก้ไขข้อมูล"
>
<!-- icon="mdi-pencil-outline"
<q-tooltip>แกไขขอม</q-tooltip> -->
</q-btn>
</q-card-actions>
</q-form>
</q-card>
</q-dialog>
<!-- modal ลบวนหย -->
<q-dialog v-model="modalDelete" persistent>
<q-card style="min-width: 550px">
<q-card-section class="row items-center q-pb-xs">
<div class="text-bold">องการลบขอมลนหรอไม?</div>
<q-space />
<q-btn
icon="close"
unelevated
round
dense
v-close-popup
style="color: #ff8080; background-color: #ffdede"
/>
</q-card-section>
<q-separator />
<q-card-section class="row items-center">
<div class="q-pr-md">
<q-avatar
icon="mdi-trash-can-outline"
font-size="25px"
size="lg"
color="red-1"
text-color="red"
/>
</div>
<div class="col text-dark">
<span>อมลทกำลงถกลบนจะมผลใชงานทนท</span>
</div>
</q-card-section>
<q-separator />
<q-card-actions align="right" class="bg-white text-teal">
<q-btn label="ยกเลิก" flat color="grey-8" @click="cancelClick" />
<q-btn label="ตกลง" color="primary" @click="deleteData" />
</q-card-actions>
</q-card>
</q-dialog>
</template>
<script setup lang="ts"> <script setup lang="ts">
import { onMounted, ref, watch } from "vue"; import { onMounted, ref, watch } from "vue";
import { useQuasar } from "quasar"; import { useQuasar } from "quasar";
@ -207,6 +7,7 @@ import timeGridPlugin from "@fullcalendar/timegrid";
import interactionPlugin from "@fullcalendar/interaction"; import interactionPlugin from "@fullcalendar/interaction";
import allLocales from "@fullcalendar/core/locales-all"; import allLocales from "@fullcalendar/core/locales-all";
import listPlugin from "@fullcalendar/list"; import listPlugin from "@fullcalendar/list";
import http from "@/plugins/http"; import http from "@/plugins/http";
import config from "@/app.config"; import config from "@/app.config";
@ -214,6 +15,7 @@ import type {
RequestItemsObject, RequestItemsObject,
DataDateRowObject, DataDateRowObject,
DataDateAddObject, DataDateAddObject,
Optionscategory,
} from "@/modules/01_metadata/interface/index/Calendar"; } from "@/modules/01_metadata/interface/index/Calendar";
import { useCounterMixin } from "@/stores/mixin"; import { useCounterMixin } from "@/stores/mixin";
@ -255,10 +57,9 @@ const isSpecial = ref<boolean>(true); //เช็ควันหยุด
const id = ref<string>(""); //id const id = ref<string>(""); //id
const fullCalendar = ref<any>(); //ref calendar const fullCalendar = ref<any>(); //ref calendar
const dateRange = ref<[Date, Date]>([new Date(), new Date()]); // const dateRange = ref<[Date, Date]>([new Date(), new Date()]); //
const formDate = ref<any>(); //ref validate
const category = ref<string>("all"); const category = ref<string>("all");
const categoryOptions = ref<any>([ const categoryOptions = ref<Optionscategory[]>([
{ {
label: "ทั้งหมด", label: "ทั้งหมด",
value: "all", value: "all",
@ -275,111 +76,6 @@ const categoryOptions = ref<any>([
const dataHistory = ref<RequestItemsObject[]>([]); const dataHistory = ref<RequestItemsObject[]>([]);
const dataNormalRaw = ref<RequestItemsObject[]>([]); const dataNormalRaw = ref<RequestItemsObject[]>([]);
const dataSixDaysRaw = ref<RequestItemsObject[]>([]); const dataSixDaysRaw = ref<RequestItemsObject[]>([]);
/**
* เรยกฟงกนทงหมดตอนเรยกใชไฟล
*/
onMounted(async () => {
hideLoader();
const calen = fullCalendar.value.getApi();
const date = new Date(props.dateYear, props.dateMonth);
calen.gotoDate(date);
await fetchData();
});
/**
* props(นเดอนปเลอก) ตอนอพเดท าฏนใหพเดทใหม
*/
watch(props, async (count, prevCount) => {
const calen = fullCalendar.value.getApi();
const date = new Date(props.dateYear, props.dateMonth);
calen.gotoDate(date);
await fetchData();
});
/**
* เลอกคาปฏนในชองวาง
* @param selectInfo าทเลอกในฏ
*/
const handleDateSelect = async (selectInfo: any) => {
edit.value = true;
category.value = "all";
selectInfo.start;
const checkNormalDate = dataNormalRaw.value.filter(
(r: RequestItemsObject) =>
dateToISO(new Date(r.holidayDate)) == dateToISO(selectInfo.start)
);
const checkSixDaysDate = dataSixDaysRaw.value.filter(
(r: RequestItemsObject) =>
dateToISO(new Date(r.holidayDate)) == dateToISO(selectInfo.start)
);
if (checkNormalDate.length == 0 || checkSixDaysDate.length == 0) {
name.value = "";
isSpecial.value = true;
dateRange.value = [
selectInfo.startStr,
new Date(
new Date(selectInfo.endStr).setDate(
new Date(selectInfo.endStr).getDate() - 1
)
),
];
showEdit.value = false;
modalAdd.value = true;
}
};
/**
* เลอกค event ในปฏ
* @param selectInfo าทเลอกในฏ
*/
const handleEventClick = async (selectInfo: any) => {
modalAdd.value = true;
edit.value = false;
showEdit.value = true;
name.value = selectInfo.event.title;
type.value = selectInfo.event.id;
isSpecial.value = true;
id.value = selectInfo.event.groupId;
dataHistory.value = selectInfo.event.extendedProps.dataRangeRow;
dateRange.value = [
selectInfo.event.startStr,
selectInfo.event.endStr == ""
? selectInfo.event.startStr
: dateToISO(
new Date(
new Date(selectInfo.event.endStr).setDate(
new Date(selectInfo.event.endStr).getDate() - 1
)
)
),
];
};
/**
* กดปมแกไขใหแสดง modal แกไข
*/
const editClick = async () => {
showEdit.value = true;
edit.value = true;
};
/**
* กดปมลบใหแสดง modal ลบ
*/
const deleteClick = async () => {
modalDelete.value = true;
};
/**
* มยกเลกใหอนกลบไป modal เลอกแกไขหรอลบ
*/
const cancelClick = async () => {
modalDelete.value = false;
modalAdd.value = true;
edit.value = false;
};
/** /**
* option calendar * option calendar
*/ */
@ -404,21 +100,104 @@ const calendarOptions = ref<any>({
firstDay: 0, firstDay: 0,
}); });
/**
* เลอกคาปฏนในชองวาง
* @param selectInfo าทเลอกในฏ
*/
async function handleDateSelect(selectInfo: any) {
edit.value = true;
category.value = "all";
selectInfo.start;
const checkNormalDate = dataNormalRaw.value.filter(
(r: RequestItemsObject) =>
dateToISO(new Date(r.holidayDate)) == dateToISO(selectInfo.start)
);
const checkSixDaysDate = dataSixDaysRaw.value.filter(
(r: RequestItemsObject) =>
dateToISO(new Date(r.holidayDate)) == dateToISO(selectInfo.start)
);
if (checkNormalDate.length == 0 || checkSixDaysDate.length == 0) {
name.value = "";
isSpecial.value = true;
dateRange.value = [
selectInfo.startStr,
new Date(
new Date(selectInfo.endStr).setDate(
new Date(selectInfo.endStr).getDate() - 1
)
),
];
showEdit.value = false;
modalAdd.value = true;
}
}
/**
* เลอกค event ในปฏ
* @param selectInfo าทเลอกในฏ
*/
async function handleEventClick(selectInfo: any) {
modalAdd.value = true;
edit.value = false;
showEdit.value = true;
name.value = selectInfo.event.title;
type.value = selectInfo.event.id;
isSpecial.value = true;
id.value = selectInfo.event.groupId;
dataHistory.value = selectInfo.event.extendedProps.dataRangeRow;
dateRange.value = [
selectInfo.event.startStr,
selectInfo.event.endStr == ""
? selectInfo.event.startStr
: dateToISO(
new Date(
new Date(selectInfo.event.endStr).setDate(
new Date(selectInfo.event.endStr).getDate() - 1
)
)
),
];
}
/**
* กดปมแกไขใหแสดง modal แกไข
*/
async function editClick() {
showEdit.value = true;
edit.value = true;
}
/**
* กดปมลบใหแสดง modal ลบ
*/
async function deleteClick() {
modalDelete.value = true;
}
/**
* มยกเลกใหอนกลบไป modal เลอกแกไขหรอลบ
*/
async function cancelClick() {
modalDelete.value = false;
modalAdd.value = true;
edit.value = false;
}
/** /**
* มบนทกขอมลวนหย * มบนทกขอมลวนหย
*/ */
const onSubmit = async () => { async function onSubmit() {
if (showEdit.value === true) { if (showEdit.value === true) {
await editData(); await editData();
} else { } else {
await addDate(); await addDate();
} }
}; }
/** /**
* fetch นหยดในปฏ * fetch นหยดในปฏ
*/ */
const fetchData = async () => { async function fetchData() {
calendarOptions.value.events = []; calendarOptions.value.events = [];
showLoader(); showLoader();
await http await http
@ -539,14 +318,12 @@ const fetchData = async () => {
.finally(async () => { .finally(async () => {
await props.fetchDataSummaryCalendar(); await props.fetchDataSummaryCalendar();
}); });
}; }
/** /**
* นทกแกไขวนหย * นทกแกไขวนหย
*/ */
const editData = async () => { async function editData() {
await formDate.value.validate().then(async (result: boolean) => {
if (result) {
const dataEdit = ref<DataDateAddObject[]>([]); const dataEdit = ref<DataDateAddObject[]>([]);
let i = 0; let i = 0;
const dateStart = ref<Date>(dateRange.value[0]); const dateStart = ref<Date>(dateRange.value[0]);
@ -559,9 +336,7 @@ const editData = async () => {
isSpecial: true, isSpecial: true,
}); });
dateStart.value = new Date( dateStart.value = new Date(
new Date(dateStart.value).setDate( new Date(dateStart.value).setDate(new Date(dateStart.value).getDate() + 1)
new Date(dateStart.value).getDate() + 1
)
); );
} while (new Date(dateStart.value) <= new Date(dateRange.value[1])); } while (new Date(dateStart.value) <= new Date(dateRange.value[1]));
@ -579,7 +354,7 @@ const editData = async () => {
history: _dataHistory.value, history: _dataHistory.value,
updated: dataEdit.value, updated: dataEdit.value,
}) })
.then((res) => { .then(() => {
modalAdd.value = false; modalAdd.value = false;
success($q, "แก้ไขข้อมูลสำเร็จ"); success($q, "แก้ไขข้อมูลสำเร็จ");
}) })
@ -589,16 +364,12 @@ const editData = async () => {
.finally(async () => { .finally(async () => {
await fetchData(); await fetchData();
}); });
} }
});
};
/** /**
* นทกเพมวนหย * นทกเพมวนหย
*/ */
const addDate = async () => { async function addDate() {
await formDate.value.validate().then(async (result: boolean) => {
if (result) {
const dataAdd = ref<DataDateAddObject[]>([]); const dataAdd = ref<DataDateAddObject[]>([]);
let i = 0; let i = 0;
const dateStart = ref<Date>(dateRange.value[0]); const dateStart = ref<Date>(dateRange.value[0]);
@ -611,15 +382,13 @@ const addDate = async () => {
isSpecial: true, isSpecial: true,
}); });
dateStart.value = new Date( dateStart.value = new Date(
new Date(dateStart.value).setDate( new Date(dateStart.value).setDate(new Date(dateStart.value).getDate() + 1)
new Date(dateStart.value).getDate() + 1
)
); );
} while (new Date(dateStart.value) <= new Date(dateRange.value[1])); } while (new Date(dateStart.value) <= new Date(dateRange.value[1]));
showLoader(); showLoader();
await http await http
.post(config.API.listHolidayHistoryAdd(category.value), dataAdd.value) .post(config.API.listHolidayHistoryAdd(category.value), dataAdd.value)
.then((res) => { .then(() => {
modalAdd.value = false; modalAdd.value = false;
success($q, "เพิ่มข้อมูลสำเร็จ"); success($q, "เพิ่มข้อมูลสำเร็จ");
}) })
@ -629,14 +398,12 @@ const addDate = async () => {
.finally(async () => { .finally(async () => {
await fetchData(); await fetchData();
}); });
} }
});
};
/** /**
* ลบขอมลวนหย * ลบขอมลวนหย
*/ */
const deleteData = async () => { async function deleteData() {
modalDelete.value = false; modalDelete.value = false;
const dataDelete = ref<DataDateAddObject[]>([]); const dataDelete = ref<DataDateAddObject[]>([]);
let i = 0; let i = 0;
@ -656,7 +423,7 @@ const deleteData = async () => {
showLoader(); showLoader();
await http await http
.post(config.API.listHolidayHistoryDelete(type.value), dataDelete.value) .post(config.API.listHolidayHistoryDelete(type.value), dataDelete.value)
.then((res) => { .then(() => {
success($q, "ลบข้อมูลสำเร็จ"); success($q, "ลบข้อมูลสำเร็จ");
}) })
.catch((e) => { .catch((e) => {
@ -666,29 +433,248 @@ const deleteData = async () => {
modalAdd.value = false; modalAdd.value = false;
await fetchData(); await fetchData();
}); });
}; }
/** /**
* แปลงชวงวนทา2คาเปนวนเดยวกนจะโชววนเดยวแตาไมเทากนจะแสดงเปนชวง * แปลงชวงวนทา2คาเปนวนเดยวกนจะโชววนเดยวแตาไมเทากนจะแสดงเปนชวง
* @param val วงวนท * @param val วงวนท
*/ */
const dateThaiRange = (val: [Date, Date]) => { function dateThaiRange(val: [Date, Date]) {
if (val === null) { if (val === null) {
} else if (date2Thai(val[0]) === date2Thai(val[1])) { } else if (date2Thai(val[0]) === date2Thai(val[1])) {
return `${date2Thai(val[0])}`; return `${date2Thai(val[0])}`;
} else { } else {
return `${date2Thai(val[0])} - ${date2Thai(val[1])} `; return `${date2Thai(val[0])} - ${date2Thai(val[1])} `;
} }
}; }
const getClass = (val: boolean) => { function getClass(val: boolean) {
return { return {
"full-width inputgreen cursor-pointer": val, "full-width inputgreen cursor-pointer": val,
"full-width cursor-pointer": !val, "full-width cursor-pointer": !val,
}; };
}; }
/**
* เรยกฟงกนทงหมดตอนเรยกใชไฟล
*/
onMounted(async () => {
const calen = fullCalendar.value.getApi();
const date = new Date(props.dateYear, props.dateMonth);
calen.gotoDate(date);
await fetchData();
});
/**
* props(นเดอนปเลอก) ตอนอพเดท าฏนใหพเดทใหม
*/
watch(props, async (count, prevCount) => {
const calen = fullCalendar.value.getApi();
const date = new Date(props.dateYear, props.dateMonth);
calen.gotoDate(date);
await fetchData();
});
</script> </script>
<template>
<div class="q-mt-md">
<div class="row q-gutter-sm q-pb-sm main-content">
<div class="demo-app-main">
<!-- แสดงปฏ -->
<FullCalendar
ref="fullCalendar"
class="demo-app-calendar"
:options="calendarOptions"
>
<template v-slot:eventContent="arg">
<b>{{ arg.timeText }}</b>
<i>{{ arg.event.title }}</i>
<q-tooltip style="font-size: 15px">{{ arg.event.title }}</q-tooltip>
</template>
</FullCalendar>
</div>
</div>
<div class="row q-col-gutter-md">
<div class="items-center row">
<q-icon color="blue" name="mdi-circle" class="q-mr-sm" />
นทำงาน 5
</div>
<div class="items-center row">
<q-icon color="orange" name="mdi-circle" class="q-mr-sm" />
นทำงาน 6
</div>
</div>
</div>
<!-- modal เพมวนหย -->
<q-dialog v-model="modalAdd" persistent>
<q-card style="min-width: 550px">
<q-form greedy @submit.prevent @validation-success="onSubmit()">
<q-card-section class="row items-center q-pa-sm">
<div class="text-bold" v-if="showEdit">แก้ไขวันหยุด</div>
<div class="text-bold" v-else>เพิ่มวันหยุด</div>
<q-space />
<q-btn
icon="close"
unelevated
round
dense
v-close-popup
style="color: #ff8080; background-color: #ffdede"
/>
</q-card-section>
<q-separator />
<q-card-section class="q-p-md row q-gutter-y-md">
<div class="row col-12">
<div class="col-12" v-if="!showEdit">
{{ dateThaiRange(dateRange) }}
</div>
<datepicker
v-else
:readonly="!edit"
v-model="dateRange"
:locale="'th'"
autoApply
range
:enableTimePicker="false"
week-start="0"
>
<template #year="{ year }">
{{ year + 543 }}
</template>
<template #year-overlay-value="{ value }">
{{ parseInt(value + 543) }}
</template>
<template #trigger>
<q-input
:class="getClass(edit)"
hide-bottom-space
:outlined="edit"
dense
label="วันที่"
:borderless="!edit"
:model-value="dateThaiRange(dateRange)"
>
<template v-slot:prepend>
<q-icon
name="event"
class="cursor-pointer"
style="color: var(--q-primary)"
>
</q-icon>
</template>
</q-input>
</template>
</datepicker>
</div>
<q-input
:class="getClass(edit)"
hide-bottom-space
:outlined="edit"
label="คำอธิบาย"
dense
lazy-rules
:readonly="!edit"
:borderless="!edit"
v-model="name"
autogrow
:rules="[(val:string) => (val && val.length > 0) || '']"
/>
<q-option-group
v-if="showEdit == false"
v-model="category"
:options="categoryOptions"
color="primary"
inline
/>
</q-card-section>
<q-separator />
<q-card-actions align="right" class="text-primary">
<q-btn
v-if="showEdit && edit"
flat
color="red"
@click="cancelClick()"
label="ยกเลิกแก้ไข"
>
<!-- icon="mdi-undo"
<q-tooltip>ยกเล</q-tooltip> -->
</q-btn>
<q-btn
v-if="showEdit && edit"
unelevated
color="red"
@click="deleteClick()"
label="ลบวันหยุด"
>
<!-- icon="mdi-delete"
<q-tooltip>ลบ</q-tooltip> -->
</q-btn>
<q-btn
v-if="edit"
unelevated
color="public"
label="บันทึก"
type="submit"
>
<!-- icon="mdi-content-save-outline"
<q-tooltip>นท</q-tooltip> -->
</q-btn>
<q-btn
v-if="!edit"
outline
color="edit"
@click="editClick"
label="แก้ไขข้อมูล"
>
<!-- icon="mdi-pencil-outline"
<q-tooltip>แกไขขอม</q-tooltip> -->
</q-btn>
</q-card-actions>
</q-form>
</q-card>
</q-dialog>
<!-- modal ลบวนหย -->
<q-dialog v-model="modalDelete" persistent>
<q-card style="min-width: 550px">
<q-card-section class="row items-center q-pb-xs">
<div class="text-bold">องการลบขอมลนหรอไม?</div>
<q-space />
<q-btn
icon="close"
unelevated
round
dense
v-close-popup
style="color: #ff8080; background-color: #ffdede"
/>
</q-card-section>
<q-separator />
<q-card-section class="row items-center">
<div class="q-pr-md">
<q-avatar
icon="mdi-trash-can-outline"
font-size="25px"
size="lg"
color="red-1"
text-color="red"
/>
</div>
<div class="col text-dark">
<span>อมลทกำลงถกลบนจะมผลใชงานทนท</span>
</div>
</q-card-section>
<q-separator />
<q-card-actions align="right" class="bg-white text-teal">
<q-btn label="ยกเลิก" flat color="grey-8" @click="cancelClick" />
<q-btn label="ตกลง" color="primary" @click="deleteData" />
</q-card-actions>
</q-card>
</q-dialog>
</template>
<style scope lang="scss"> <style scope lang="scss">
.main-content { .main-content {
height: 70vh; height: 70vh;
@ -719,16 +705,6 @@ const getClass = (val: boolean) => {
background-color: rgb(255, 255, 255) !important; background-color: rgb(255, 255, 255) !important;
} }
// .fc-day-sun {
// background-color: rgba(207, 205, 205, 0.177) !important;
// width: 80px;
// }
// .fc-day-sat {
// background-color: rgba(207, 205, 205, 0.177) !important;
// width: 80px;
// }
.fc-day-today .fc-daygrid-day-number { .fc-day-today .fc-daygrid-day-number {
display: flex; display: flex;
justify-content: center; justify-content: center;

View file

@ -1,8 +1,10 @@
<script setup lang="ts"> <script setup lang="ts">
import { onMounted, ref, watch } from "vue"; import { onMounted, ref, watch } from "vue";
import { useQuasar } from "quasar"; import { useQuasar, type QTableProps } from "quasar";
import http from "@/plugins/http"; import http from "@/plugins/http";
import config from "@/app.config"; import config from "@/app.config";
import { useCounterMixin } from "@/stores/mixin";
import type { import type {
RequestItemsObject, RequestItemsObject,
@ -12,7 +14,16 @@ import type {
TabsObject, TabsObject,
} from "@/modules/01_metadata/interface/index/Calendar"; } from "@/modules/01_metadata/interface/index/Calendar";
import { useCounterMixin } from "@/stores/mixin"; const $q = useQuasar(); // noti quasar
const {
success,
dateToISO,
dateMonth2Thai,
weekThai,
messageError,
showLoader,
dialogRemove,
} = useCounterMixin();
const props = defineProps({ const props = defineProps({
dateYear: { dateYear: {
@ -32,25 +43,12 @@ const props = defineProps({
}, },
}); });
const mixin = useCounterMixin(); //
const {
success,
dateToISO,
dateMonth2Thai,
weekThai,
messageError,
showLoader,
hideLoader,
dialogRemove,
} = mixin;
const $q = useQuasar(); // noti quasar
const calendarData = ref<DataDateListsObject[]>([]); //data const calendarData = ref<DataDateListsObject[]>([]); //data
const modalAdd = ref<boolean>(false); //modal const modalAdd = ref<boolean>(false); //modal
const name = ref<string>(""); // const name = ref<string>(""); //
const isSpecial = ref<boolean>(true); // const isSpecial = ref<boolean>(true); //
const dateAdd = ref<[Date, Date]>([new Date(), new Date()]); // const dateAdd = ref<[Date, Date]>([new Date(), new Date()]); //
const rowData = ref<DataDateListsObject>(); //data row const rowData = ref<DataDateListsObject>(); //data row
const formDate = ref<any>(); //ref validate
const currentTab = ref<string>("normal"); // tab const currentTab = ref<string>("normal"); // tab
const tabs = ref<TabsObject[]>([ const tabs = ref<TabsObject[]>([
@ -59,7 +57,7 @@ const tabs = ref<TabsObject[]>([
]); //tab ]); //tab
//columns //columns
const columns = ref<any>([ const columns = ref<QTableProps["columns"]>([
{ {
name: "week", name: "week",
align: "left", align: "left",
@ -86,45 +84,31 @@ const columns = ref<any>([
}, },
]); ]);
/**
* เรยกฟงกนทงหมดตอนเรยกใชไฟล
*/
onMounted(async () => {
await fetchData();
});
/**
* props(นปเลอก และเพมหรอแกไข) ตอนอพเดท าฏนใหพเดทใหม
*/
watch(props, async (count, prevCount) => {
await fetchData();
});
/** /**
* กดปมแกไขวนหย * กดปมแกไขวนหย
* @param val data นหยดท row * @param val data นหยดท row
*/ */
const editCalendar = async (val: DataDateListsObject) => { async function editCalendar(val: DataDateListsObject) {
rowData.value = val; rowData.value = val;
dateAdd.value = [val.dateRange[0], val.dateRange[1]]; dateAdd.value = [val.dateRange[0], val.dateRange[1]];
name.value = val.detail; name.value = val.detail;
isSpecial.value = true; isSpecial.value = true;
modalAdd.value = true; modalAdd.value = true;
}; }
/** /**
* กดปมลบวนหย * กดปมลบวนหย
* @param val data นหยดท row * @param val data นหยดท row
*/ */
const deleteClick = async (val: DataDateListsObject) => { async function deleteClick(val: DataDateListsObject) {
rowData.value = val; rowData.value = val;
dialogRemove($q, async () => deleteConfirm()); dialogRemove($q, async () => deleteConfirm());
}; }
/** /**
* fetch นหยดในรายการ * fetch นหยดในรายการ
*/ */
const fetchData = async () => { async function fetchData() {
calendarData.value = []; calendarData.value = [];
showLoader(); showLoader();
await http await http
@ -186,15 +170,15 @@ const fetchData = async () => {
.finally(async () => { .finally(async () => {
await props.fetchDataSummaryCalendar(); await props.fetchDataSummaryCalendar();
}); });
}; }
/** /**
* ลบขอมลวนหย * ลบขอมลวนหย
*/ */
const deleteConfirm = async () => { async function deleteConfirm() {
const dataDelete = ref<DataDateAddObject[]>([]); const dataDelete = ref<DataDateAddObject[]>([]);
if (rowData.value != null) { if (rowData.value != null) {
await rowData.value.dataRangeRow.map((e: DataDateRowObject) => { rowData.value.dataRangeRow.map((e: DataDateRowObject) => {
dataDelete.value.push({ dataDelete.value.push({
year: new Date(e.holidayDate).getFullYear(), year: new Date(e.holidayDate).getFullYear(),
holidayDate: dateToISO(e.holidayDate), holidayDate: dateToISO(e.holidayDate),
@ -211,7 +195,7 @@ const deleteConfirm = async () => {
config.API.listHolidayHistoryDelete(currentTab.value), config.API.listHolidayHistoryDelete(currentTab.value),
dataDelete.value dataDelete.value
) )
.then((res) => { .then(() => {
success($q, "ลบข้อมูลสำเร็จ"); success($q, "ลบข้อมูลสำเร็จ");
}) })
.catch((e) => { .catch((e) => {
@ -220,14 +204,12 @@ const deleteConfirm = async () => {
.finally(async () => { .finally(async () => {
await fetchData(); await fetchData();
}); });
}; }
/** /**
* นทกแกไขวนหย * นทกแกไขวนหย
*/ */
const editData = async () => { async function onSubmit() {
await formDate.value.validate().then(async (result: boolean) => {
if (result) {
const dataEdit = ref<DataDateAddObject[]>([]); const dataEdit = ref<DataDateAddObject[]>([]);
let i = 0; let i = 0;
const dateStart = ref<Date>(dateAdd.value[0]); const dateStart = ref<Date>(dateAdd.value[0]);
@ -240,23 +222,19 @@ const editData = async () => {
isSpecial: true, isSpecial: true,
}); });
dateStart.value = new Date( dateStart.value = new Date(
new Date(dateStart.value).setDate( new Date(dateStart.value).setDate(new Date(dateStart.value).getDate() + 1)
new Date(dateStart.value).getDate() + 1
)
); );
} while (new Date(dateStart.value) <= new Date(dateAdd.value[1])); } while (new Date(dateStart.value) <= new Date(dateAdd.value[1]));
const _dataHistory = ref<DataDateAddObject[]>([]); const _dataHistory = ref<DataDateAddObject[]>([]);
if (rowData.value != null) { if (rowData.value != null) {
rowData.value.dataRangeRow.map( rowData.value.dataRangeRow.map((e: DataDateRowObject, index: number) => {
(e: DataDateRowObject, index: number) => {
_dataHistory.value.push({ _dataHistory.value.push({
year: new Date(e.holidayDate).getFullYear(), year: new Date(e.holidayDate).getFullYear(),
holidayDate: dateToISO(e.holidayDate), holidayDate: dateToISO(e.holidayDate),
name: e.name, name: e.name,
isSpecial: true, isSpecial: true,
}); });
} });
);
} }
showLoader(); showLoader();
await http await http
@ -264,7 +242,7 @@ const editData = async () => {
history: _dataHistory.value, history: _dataHistory.value,
updated: dataEdit.value, updated: dataEdit.value,
}) })
.then((res) => { .then(() => {
modalAdd.value = false; modalAdd.value = false;
success($q, "แก้ไขข้อมูลสำเร็จ"); success($q, "แก้ไขข้อมูลสำเร็จ");
}) })
@ -274,25 +252,22 @@ const editData = async () => {
.finally(async () => { .finally(async () => {
await fetchData(); await fetchData();
}); });
} else { }
}
});
};
/** /**
* เปลยน tab นหยดตามประเภท * เปลยน tab นหยดตามประเภท
* @param tab tab ประเภทวนหยดทเลอก * @param tab tab ประเภทวนหยดทเลอก
*/ */
const changeTab = async (tab: string) => { async function changeTab(tab: string) {
currentTab.value = tab; currentTab.value = tab;
await fetchData(); await fetchData();
}; }
/** /**
* แปลงชวงวนทา2คาเปนวนเดยวกนจะโชววนเดยวแตาไมเทากนจะแสดงเปนชวง * แปลงชวงวนทา2คาเปนวนเดยวกนจะโชววนเดยวแตาไมเทากนจะแสดงเปนชวง
* @param val วงวนท * @param val วงวนท
*/ */
const dateThaiRange = (val: [Date, Date]) => { function dateThaiRange(val: [Date, Date]) {
if (val === null) { if (val === null) {
return ""; return "";
} else if (dateMonth2Thai(val[0], true) === dateMonth2Thai(val[1], true)) { } else if (dateMonth2Thai(val[0], true) === dateMonth2Thai(val[1], true)) {
@ -300,13 +275,13 @@ const dateThaiRange = (val: [Date, Date]) => {
} else { } else {
return `${dateMonth2Thai(val[0], true)} - ${dateMonth2Thai(val[1], true)}`; return `${dateMonth2Thai(val[0], true)} - ${dateMonth2Thai(val[1], true)}`;
} }
}; }
/** /**
* แปลงชวงวนทา2คาเปนวนเดยวกนจะโชววนเดยวแตาไมเทากนจะแสดงเปนชวง(เชนวนจนทร -นศกร) * แปลงชวงวนทา2คาเปนวนเดยวกนจะโชววนเดยวแตาไมเทากนจะแสดงเปนชวง(เชนวนจนทร -นศกร)
* @param val วงวนท * @param val วงวนท
*/ */
const dayThaiRange = (val: [Date, Date]) => { function dayThaiRange(val: [Date, Date]) {
if (val === null) { if (val === null) {
} else if (dateToISO(val[0]) == dateToISO(val[1])) { } else if (dateToISO(val[0]) == dateToISO(val[1])) {
return `${weekThai(new Date(val[0]).getDay())}`; return `${weekThai(new Date(val[0]).getDay())}`;
@ -315,7 +290,21 @@ const dayThaiRange = (val: [Date, Date]) => {
new Date(val[1]).getDay() new Date(val[1]).getDay()
)}`; )}`;
} }
}; }
/**
* เรยกฟงกนทงหมดตอนเรยกใชไฟล
*/
onMounted(async () => {
await fetchData();
});
/**
* props(นปเลอก และเพมหรอแกไข) ตอนอพเดท าฏนใหพเดทใหม
*/
watch(props, async (count, prevCount) => {
await fetchData();
});
</script> </script>
<!-- tab รายการ หนาปฏนวนหย --> <!-- tab รายการ หนาปฏนวนหย -->
@ -473,7 +462,7 @@ const dayThaiRange = (val: [Date, Date]) => {
<!-- modal เพมวนหย --> <!-- modal เพมวนหย -->
<q-dialog v-model="modalAdd" persistent> <q-dialog v-model="modalAdd" persistent>
<q-card style="min-width: 550px"> <q-card style="min-width: 550px">
<q-form ref="formDate" @submit.prevent.stop="editData"> <q-form greedy @submit.prevent @validation-success="onSubmit()">
<q-card-section class="row items-center q-pb-xs"> <q-card-section class="row items-center q-pb-xs">
<div class="text-bold">แกไขวนหย</div> <div class="text-bold">แกไขวนหย</div>
<q-space /> <q-space />
@ -537,7 +526,7 @@ const dayThaiRange = (val: [Date, Date]) => {
class="full-width datepicker q-pb-none" class="full-width datepicker q-pb-none"
v-model="name" v-model="name"
type="textarea" type="textarea"
:rules="[(val) => (val && val.length > 0) || '']" :rules="[(val:string) => (val && val.length > 0) || '']"
/> />
</div> </div>
</div> </div>
@ -545,8 +534,6 @@ const dayThaiRange = (val: [Date, Date]) => {
<q-separator /> <q-separator />
<q-card-actions align="right" class="text-primary"> <q-card-actions align="right" class="text-primary">
<q-btn unelevated label="บันทึก" color="public" type="submit"> <q-btn unelevated label="บันทึก" color="public" type="submit">
<!-- icon="mdi-content-save-outline"
<q-tooltip>นท</q-tooltip> -->
</q-btn> </q-btn>
</q-card-actions> </q-card-actions>
</q-form> </q-form>

View file

@ -1,4 +1,238 @@
<!-- page:ดการขอมลหล tab นหย --> <script setup lang="ts">
import { ref, watch, onMounted } from "vue";
import { useQuasar } from "quasar";
import http from "@/plugins/http";
import config from "@/app.config";
import { useCounterMixin } from "@/stores/mixin";
import type {
DataDateMonthObject,
DataDateAddObject,
} from "@/modules/01_metadata/interface/index/Calendar";
import subCalendarComponent from "@/modules/01_metadata/components/calendar/Calendar.vue"; //
import subCalendarListComponent from "@/modules/01_metadata/components/calendar/CalendarList.vue"; //
const $q = useQuasar(); // noti quasar
//
const {
success,
dateToISO,
monthYear2Thai,
date2Thai,
messageError,
dialogMessage,
showLoader,
hideLoader,
} = useCounterMixin();
/**
* props
*/
const props = defineProps({
dateYear: Number, // parent
fetchDataSummaryCalendar: {
//
type: Function,
default: () => console.log("not function"),
},
});
const emit = defineEmits(["update:dateYear"]);
const currentTab = ref<string>("calendar"); // tab calendar= list=
const modalAdd = ref<boolean>(false); // modal add calendar
const modalCopy = ref<boolean>(false); // modal copy calendar
const dateMonth = ref<DataDateMonthObject>({
month: new Date().getMonth(),
year: new Date().getFullYear(),
}); // tab
const dateYear = ref<number>(new Date().getFullYear()); // tab
const dateYearStart = ref<number>(new Date().getFullYear()); // copy
const dateYearEnd = ref<number>(new Date().getFullYear()); // copy
const dateAdd = ref<[Date, Date]>([new Date(), new Date()]); //
const formDate = ref<any>(); //ref validate
const name = ref<string>(""); //
const isSpecial = ref<boolean>(true); //
const category = ref<string>("all");
const categoryOptions = ref<any>([
{
label: "ทั้งหมด",
value: "all",
},
{
label: "ทำงาน 5 วัน",
value: "normal",
},
{
label: "ทำงาน 6 วัน",
value: "6days",
},
]);
const minDate = ref<Date>();
const refreshData = ref<boolean>(false); // component refresh data
/**
* าเดอนปกเลอกใน component ปฏนจะใหพเดทคาสรปวนหยดรวม
* @param e เลอกเดอนป tab ปฏ
*/
const updateMonth = async (e: DataDateMonthObject) => {
if (e != null) {
dateYear.value = e.year;
emit("update:dateYear", e.year);
await props.fetchDataSummaryCalendar();
}
};
/**
* าปกเลอกใน component รายการจะใหพเดทคาสรปวนหยดรวม
* @param e เลอกป tab รายการ
*/
const updateYear = async (e: number) => {
dateMonth.value = { month: 0, year: e };
emit("update:dateYear", dateYear.value);
await props.fetchDataSummaryCalendar();
};
/**
* งกนปมเพมวนหยดแบบเลอกวนได
*/
const addCalendar = () => {
dateAdd.value = [new Date(), new Date()];
name.value = "";
category.value = "all";
isSpecial.value = true;
modalAdd.value = true;
};
/**
* งก copy นหยดจากปงไปอกป
*/
const copyCalendar = () => {
modalCopy.value = true;
dateYearStart.value = new Date().getFullYear();
dateYearEnd.value = new Date().getFullYear() + 1;
};
/**
* งกนปมบนทกเพมวนหย
*/
const onSubmit = async () => {
await formDate.value.validate().then(async (result: boolean) => {
if (result) {
const dataAdd = ref<DataDateAddObject[]>([]);
let i = 0;
const dateStart = ref<Date>(dateAdd.value[0]);
do {
i = i + 1;
dataAdd.value.push({
year: new Date(dateStart.value).getFullYear(),
holidayDate: dateToISO(new Date(dateStart.value)),
name: name.value,
isSpecial: true,
});
dateStart.value = new Date(
new Date(dateStart.value).setDate(
new Date(dateStart.value).getDate() + 1
)
);
} while (new Date(dateStart.value) <= new Date(dateAdd.value[1]));
showLoader();
await http
.post(config.API.listHolidayHistoryAdd(category.value), dataAdd.value)
.then(() => {
modalAdd.value = false;
success($q, "เพิ่มวันหยุดสำเร็จ");
})
.catch((e) => {
messageError($q, e);
})
.finally(() => {
refreshData.value = !refreshData.value;
hideLoader();
});
}
});
await props.fetchDataSummaryCalendar();
};
/**
* งกนคดลอกวนหย
*/
const onSubmitCopy = async () => {
if (dateYearStart.value >= dateYearEnd.value) {
dialogMessage(
$q,
"ไม่สามารถคัดลอกวันหยุดได้",
"ปีที่เริ่มต้นคัดลอกต้องมากกว่าปีที่จะลงวันคัดลอก",
"warning",
undefined,
"orange",
undefined,
undefined,
true
);
return;
}
showLoader();
await http
.post(config.API.listHolidayCopy, {
fromYear: dateYearStart.value,
toYear: dateYearEnd.value,
})
.then(() => {
modalCopy.value = false;
success($q, "คัดลอกวันหยุดสำเร็จ");
})
.catch((e) => {
messageError($q, e);
})
.finally(async () => {
refreshData.value = !refreshData.value;
await props.fetchDataSummaryCalendar();
});
};
/**
* แปลง และเดอนเปนภาษาไทย
* @param val datepicker แบบเลอกปและเดอน
*/
const monthYearThai = (val: DataDateMonthObject) => {
if (val == null) return "";
else return monthYear2Thai(val.month, val.year);
};
/**
* แปลงชวงวนทา2คาเปนวนเดยวกนจะโชววนเดยวแตาไมเทากนจะแสดงเปนชวง
* @param val วงวนท
*/
const dateThaiRange = (val: [Date, Date] | []) => {
if (val.length === 0) {
} else if (date2Thai(val[0]) === date2Thai(val[1])) {
return `${date2Thai(val[0])}`;
} else {
return `${date2Thai(val[0])} - ${date2Thai(val[1])} `;
}
};
/**
* การเลอก datepicker ใหแปลงคาเป text แสดง
*/
watch(dateYearStart, () => {
dateYearEnd.value = dateYearStart.value + 1;
minDate.value = new Date(`${dateYearStart.value + 1}-01-01`);
});
/**
* เรยกฟงกนทงหมดตอนเรยกใชไฟล
*/
onMounted(async () => {
dateYearEnd.value = dateYearStart.value + 1;
minDate.value = new Date(`${dateYearStart.value + 1}-01-01`);
});
</script>
<template> <template>
<div> <div>
<div class="row col-12 q-col-gutter-sm"> <div class="row col-12 q-col-gutter-sm">
@ -147,6 +381,7 @@
/> />
</div> </div>
</div> </div>
<!-- modal เพมวนหย --> <!-- modal เพมวนหย -->
<q-dialog v-model="modalAdd" persistent> <q-dialog v-model="modalAdd" persistent>
<q-card style="min-width: 550px"> <q-card style="min-width: 550px">
@ -205,7 +440,7 @@
class="full-width datepicker q-pb-none" class="full-width datepicker q-pb-none"
v-model="name" v-model="name"
type="textarea" type="textarea"
:rules="[(val) => (val && val.length > 0) || '']" :rules="[(val:string) => (val && val.length > 0) || '']"
/> />
<q-option-group <q-option-group
dense dense
@ -320,238 +555,6 @@
</q-dialog> </q-dialog>
</template> </template>
<script setup lang="ts">
import { ref, watch, onMounted } from "vue";
import http from "@/plugins/http";
import config from "@/app.config";
import { useQuasar } from "quasar";
import type {
DataDateMonthObject,
DataDateAddObject,
} from "@/modules/01_metadata/interface/index/Calendar";
import subCalendarComponent from "@/modules/01_metadata/components/calendar/Calendar.vue";
import subCalendarListComponent from "@/modules/01_metadata/components/calendar/CalendarList.vue";
import { useCounterMixin } from "@/stores/mixin";
const props = defineProps({
dateYear: Number, // parent
fetchDataSummaryCalendar: {
//
type: Function,
default: () => console.log("not function"),
},
});
const $q = useQuasar(); // noti quasar
const mixin = useCounterMixin(); //
const {
success,
dateToISO,
monthYear2Thai,
date2Thai,
messageError,
dialogMessage,
showLoader,
hideLoader,
} = mixin;
const currentTab = ref<string>("calendar"); // tab calendar= list=
const modalAdd = ref<boolean>(false); // modal add calendar
const modalCopy = ref<boolean>(false); // modal copy calendar
const dateMonth = ref<DataDateMonthObject>({
month: new Date().getMonth(),
year: new Date().getFullYear(),
}); // tab
const dateYear = ref<number>(new Date().getFullYear()); // tab
const dateYearStart = ref<number>(new Date().getFullYear()); // copy
const dateYearEnd = ref<number>(new Date().getFullYear()); // copy
const dateAdd = ref<[Date, Date]>([new Date(), new Date()]); //
const formDate = ref<any>(); //ref validate
const name = ref<string>(""); //
const isSpecial = ref<boolean>(true); //
const category = ref<string>("all");
const categoryOptions = ref<any>([
{
label: "ทั้งหมด",
value: "all",
},
{
label: "ทำงาน 5 วัน",
value: "normal",
},
{
label: "ทำงาน 6 วัน",
value: "6days",
},
]);
const minDate = ref<Date>();
const refreshData = ref<boolean>(false); // component refresh data
const emit = defineEmits(["update:dateYear"]);
/**
* การเลอก datepicker ใหแปลงคาเป text แสดง
*/
watch(dateYearStart, () => {
dateYearEnd.value = dateYearStart.value + 1;
minDate.value = new Date(`${dateYearStart.value + 1}-01-01`);
});
/**
* เรยกฟงกนทงหมดตอนเรยกใชไฟล
*/
onMounted(async () => {
dateYearEnd.value = dateYearStart.value + 1;
minDate.value = new Date(`${dateYearStart.value + 1}-01-01`);
});
/**
* าเดอนปกเลอกใน component ปฏนจะใหพเดทคาสรปวนหยดรวม
* @param e เลอกเดอนป tab ปฏ
*/
const updateMonth = async (e: DataDateMonthObject) => {
if (e != null) {
dateYear.value = e.year;
emit("update:dateYear", e.year);
await props.fetchDataSummaryCalendar();
}
};
/**
* าปกเลอกใน component รายการจะใหพเดทคาสรปวนหยดรวม
* @param e เลอกป tab รายการ
*/
const updateYear = async (e: number) => {
dateMonth.value = { month: 0, year: e };
emit("update:dateYear", dateYear.value);
await props.fetchDataSummaryCalendar();
};
/**
* งกนปมเพมวนหยดแบบเลอกวนได
*/
const addCalendar = () => {
dateAdd.value = [new Date(), new Date()];
name.value = "";
category.value = "all";
isSpecial.value = true;
modalAdd.value = true;
};
/**
* งก copy นหยดจากปงไปอกป
*/
const copyCalendar = () => {
modalCopy.value = true;
dateYearStart.value = new Date().getFullYear();
dateYearEnd.value = new Date().getFullYear() + 1;
};
/**
* งกนปมบนทกเพมวนหย
*/
const onSubmit = async () => {
await formDate.value.validate().then(async (result: boolean) => {
if (result) {
const dataAdd = ref<DataDateAddObject[]>([]);
let i = 0;
const dateStart = ref<Date>(dateAdd.value[0]);
do {
i = i + 1;
dataAdd.value.push({
year: new Date(dateStart.value).getFullYear(),
holidayDate: dateToISO(new Date(dateStart.value)),
name: name.value,
isSpecial: true,
});
dateStart.value = new Date(
new Date(dateStart.value).setDate(
new Date(dateStart.value).getDate() + 1
)
);
} while (new Date(dateStart.value) <= new Date(dateAdd.value[1]));
showLoader();
await http
.post(config.API.listHolidayHistoryAdd(category.value), dataAdd.value)
.then(() => {
modalAdd.value = false;
success($q, "เพิ่มวันหยุดสำเร็จ");
})
.catch((e) => {
messageError($q, e);
})
.finally(() => {
refreshData.value = !refreshData.value;
hideLoader();
});
}
});
await props.fetchDataSummaryCalendar();
};
/**
* งกนคดลอกวนหย
*/
const onSubmitCopy = async () => {
if (dateYearStart.value >= dateYearEnd.value) {
dialogMessage(
$q,
"ไม่สามารถคัดลอกวันหยุดได้",
"ปีที่เริ่มต้นคัดลอกต้องมากกว่าปีที่จะลงวันคัดลอก",
"warning",
undefined,
"orange",
undefined,
undefined,
true
);
return;
}
showLoader();
await http
.post(config.API.listHolidayCopy, {
fromYear: dateYearStart.value,
toYear: dateYearEnd.value,
})
.then(() => {
modalCopy.value = false;
success($q, "คัดลอกวันหยุดสำเร็จ");
})
.catch((e) => {
messageError($q, e);
})
.finally(async () => {
refreshData.value = !refreshData.value;
await props.fetchDataSummaryCalendar();
});
};
/**
* แปลง และเดอนเปนภาษาไทย
* @param val datepicker แบบเลอกปและเดอน
*/
const monthYearThai = (val: DataDateMonthObject) => {
if (val == null) return "";
else return monthYear2Thai(val.month, val.year);
};
/**
* แปลงชวงวนทา2คาเปนวนเดยวกนจะโชววนเดยวแตาไมเทากนจะแสดงเปนชวง
* @param val วงวนท
*/
const dateThaiRange = (val: [Date, Date] | []) => {
if (val.length === 0) {
} else if (date2Thai(val[0]) === date2Thai(val[1])) {
return `${date2Thai(val[0])}`;
} else {
return `${date2Thai(val[0])} - ${date2Thai(val[1])} `;
}
};
</script>
<style scoped> <style scoped>
.my-menu-link { .my-menu-link {
color: black; color: black;

View file

@ -57,6 +57,11 @@ interface TabsObject {
value: string; value: string;
} }
interface Optionscategory {
label: string;
value: string;
}
export type { export type {
DataSumCalendarObject, DataSumCalendarObject,
DataDateMonthObject, DataDateMonthObject,
@ -65,4 +70,5 @@ export type {
DataDateRowObject, DataDateRowObject,
DataDateListsObject, DataDateListsObject,
TabsObject, TabsObject,
Optionscategory,
}; };

View file

@ -1,49 +1,48 @@
<script setup lang="ts"> <script setup lang="ts">
import { ref, onMounted } from "vue"; import { ref, onMounted } from "vue";
import { useQuasar } from "quasar"; import { useQuasar } from "quasar";
import http from "@/plugins/http"; import http from "@/plugins/http";
import config from "@/app.config"; import config from "@/app.config";
import { useCounterMixin } from "@/stores/mixin";
import type { DataSumCalendarObject } from "@/modules/01_metadata/interface/index/Calendar"; import type { DataSumCalendarObject } from "@/modules/01_metadata/interface/index/Calendar";
import calendarComponent from "@/modules/01_metadata/components/calendar/calendarMain.vue"; import calendarComponent from "@/modules/01_metadata/components/calendar/calendarMain.vue";
import { useCounterMixin } from "@/stores/mixin";
const mixin = useCounterMixin();
const $q = useQuasar(); const $q = useQuasar();
const { showLoader, hideLoader, messageError, genColor15 } = useCounterMixin();
const { showLoader, hideLoader, messageError, genColor15 } = mixin; const listsSumCalendar = ref<DataSumCalendarObject[]>([]); //
const year = ref<number>(new Date().getFullYear()); //
const listsSumCalendar = ref<DataSumCalendarObject[]>([]); /**
const year = ref<number>(new Date().getFullYear()); * งขอมลรายการสรปวนหยดในแตละเดอนประจำป
*/
/** function เรียกข้อมูลสรุปวันหยุด */
async function fetchDataSummaryCalendar() { async function fetchDataSummaryCalendar() {
showLoader(); showLoader();
await http await http
.get(config.API.summaryHolidayHistoryYear(year.value)) .get(config.API.summaryHolidayHistoryYear(year.value))
.then((res) => { .then(async (res) => {
let data = res.data.result; let data = await res.data.result;
listsSumCalendar.value = []; listsSumCalendar.value = data.map((e: DataSumCalendarObject) => ({
data.map((e: DataSumCalendarObject) => { ...e,
listsSumCalendar.value.push({
id: e.id,
monthFull: e.monthFull,
count: e.count,
color: genColor15(e.id), color: genColor15(e.id),
}); }));
});
}) })
.catch(async (e) => { .catch((err) => {
// await defaultListsSumCalendar; messageError($q, err);
messageError($q, e);
}) })
.finally(() => { .finally(() => {
hideLoader(); hideLoader();
}); });
} }
/**
* hook ทำงานเม Components กเรยกใชงาน
*
* จะทำการดงขอมลสรปวนหยดในแตละเดอนประจำป
*/
onMounted(async () => { onMounted(async () => {
await fetchDataSummaryCalendar(); await fetchDataSummaryCalendar();
}); });
@ -97,8 +96,8 @@ onMounted(async () => {
<div class="col-9"> <div class="col-9">
<q-card bordered class="q-pa-md"> <q-card bordered class="q-pa-md">
<calendarComponent <calendarComponent
v-model:dateYear="year" v-model:date-year="year"
:fetchDataSummaryCalendar="fetchDataSummaryCalendar" :fetch-dataSummaryCalendar="fetchDataSummaryCalendar"
/> />
</q-card> </q-card>
</div> </div>