hrms-mgt/src/modules/09_leave/stores/WorkStore.ts

107 lines
3.6 KiB
TypeScript
Raw Normal View History

2023-10-06 13:32:54 +07:00
import { defineStore } from "pinia";
import { ref } from "vue";
import { useCounterMixin } from "@/stores/mixin";
2023-10-20 16:57:32 +07:00
import type { QTableProps } from "quasar";
2023-10-09 09:31:01 +07:00
import type { DataOption } from "@/modules/09_leave/interface/index/Main"
2023-10-20 16:57:32 +07:00
import type { TableRows } from "@/modules/09_leave/interface/response/work"
2023-10-06 13:32:54 +07:00
const mixin = useCounterMixin();
const { date2Thai } = mixin;
export const useWorklistDataStore = defineStore("work", () => {
// ข้อมูลในตาราง
2023-10-20 16:57:32 +07:00
const rows = ref<TableRows[]>([])
const columns = ref<QTableProps["columns"]>([]);
const visibleColumns = ref<string[]>([]);
const dataMain = ref<TableRows[]>([])
function fetchList(data: TableRows[]) {
let datalist = data.map((e: TableRows) => ({
2023-10-06 13:32:54 +07:00
fullName: e.fullName,
timeIn: e.timeIn,
coordinatesIn: e.coordinatesIn,
latIn: e.latIn,
longIn: e.longIn,
timeOut: e.timeOut,
coordinatesOut: e.coordinatesOut,
latOut: e.latOut,
longOut: e.longOut,
status: convertSatatus(e.status)
}))
dataMain.value = datalist
2023-10-09 09:31:01 +07:00
fetchOption()
2023-10-06 13:32:54 +07:00
searchDataFn(selectDate.value, selectStatus.value)
}
//ค้นหาข้อมูล
const filterTable = ref<string>('')
const selectDate = ref<Date | null>(null);
const selectStatus = ref<String>('all')
2023-10-09 09:31:01 +07:00
const optionStatusMain = ref<DataOption[]>([])
const optionStatus = ref<DataOption[]>([])
2023-10-06 13:32:54 +07:00
function searchDataFn(searchDate: any, srarchStatus: any) {
srarchStatus = srarchStatus || "all";
if (searchDate == null && srarchStatus == "all") {
rows.value = dataMain.value
} else if (searchDate == null && srarchStatus !== "all") {
rows.value = dataMain.value.filter((e: any) => e.status === convertSatatus(srarchStatus))
}
}
2023-10-09 09:31:01 +07:00
//
function fetchOption() {
const double_status = [
...new Set(dataMain.value.map((item: any) => item.status)),
];
optionStatusMain.value = [{ id: "all", name: "ทั้งหมด" }];
for (let i = 1; i <= double_status.length; i++) {
const status = double_status[i - 1];
if (typeof status === 'string') {
const listtype: DataOption = {
id: status,
name: status,
};
optionStatusMain.value.push(listtype)
optionStatus.value = optionStatusMain.value
}
}
}
2023-10-20 16:57:32 +07:00
function filterFn(val: string, update: Function) {
2023-10-09 09:31:01 +07:00
if (val == "") {
update(() => {
optionStatus.value = optionStatusMain.value;
});
} else {
update(() => {
optionStatus.value = optionStatusMain.value.filter(
(e: any) => e.name.search(val) !== -1
);
});
}
}
2023-10-06 13:32:54 +07:00
// convertSatatus
function convertSatatus(val: string) {
switch (val) {
case "1":
return "ลงเวลาเรียบร้อย"
case "2":
return "สายทำงานครบ"
default:
return "ยังไม่ได้ลงเวลา"
}
}
return {
//ข้อมูลในตาราง
rows,
2023-10-20 16:57:32 +07:00
columns,
visibleColumns,
2023-10-19 15:39:18 +07:00
fetchList,
2023-10-06 13:32:54 +07:00
//ค้นหาข้อมูล
filterTable,
selectDate,
selectStatus,
optionStatus,
searchDataFn,
2023-10-09 09:31:01 +07:00
filterFn,
2023-10-06 13:32:54 +07:00
convertSatatus
};
})