2023-10-26 17:35:21 +07:00
|
|
|
import { defineStore } from "pinia";
|
|
|
|
|
import { ref } from "vue";
|
2023-11-10 13:28:42 +07:00
|
|
|
import type {
|
|
|
|
|
dataRowRound,
|
|
|
|
|
roundShow,
|
|
|
|
|
} from "@/modules/09_leave/interface/response/round.ts";
|
2023-10-26 17:35:21 +07:00
|
|
|
import type { QTableProps } from "quasar";
|
|
|
|
|
|
|
|
|
|
// store ลา >> รอบการปฏิบัติงาน
|
2023-11-10 13:28:42 +07:00
|
|
|
export const useRoundDataStore = defineStore("roundWorkStore", () => {
|
|
|
|
|
/** ค้นหา คอลัมน์ คอลัมน์ที่แสดง */
|
|
|
|
|
const visibleColumns = ref<string[]>([
|
|
|
|
|
"round",
|
|
|
|
|
"morningRound",
|
|
|
|
|
"afternoonRound",
|
|
|
|
|
"isActive",
|
|
|
|
|
]);
|
2023-10-26 17:35:21 +07:00
|
|
|
|
2023-11-10 13:28:42 +07:00
|
|
|
/** หัวตาราง */
|
|
|
|
|
const columns = ref<QTableProps["columns"]>([
|
|
|
|
|
{
|
|
|
|
|
name: "round",
|
|
|
|
|
align: "left",
|
|
|
|
|
label: "รอบ",
|
|
|
|
|
sortable: true,
|
|
|
|
|
field: "round",
|
|
|
|
|
headerStyle: "font-size: 14px",
|
|
|
|
|
style: "font-size: 14px",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "morningRound",
|
|
|
|
|
align: "left",
|
|
|
|
|
label: "ช่วงเช้า",
|
|
|
|
|
sortable: true,
|
|
|
|
|
field: "morningRound",
|
|
|
|
|
headerStyle: "font-size: 14px",
|
|
|
|
|
style: "font-size: 14px",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "afternoonRound",
|
|
|
|
|
align: "left",
|
|
|
|
|
label: "ช่วงบ่าย",
|
|
|
|
|
sortable: true,
|
|
|
|
|
field: "afternoonRound",
|
|
|
|
|
headerStyle: "font-size: 14px",
|
|
|
|
|
style: "font-size: 14px",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "isActive",
|
|
|
|
|
align: "center",
|
|
|
|
|
label: "สถานะการใช้งาน",
|
|
|
|
|
sortable: true,
|
|
|
|
|
field: "isActive",
|
|
|
|
|
headerStyle: "font-size: 14px",
|
|
|
|
|
style: "font-size: 14px",
|
|
|
|
|
},
|
|
|
|
|
]);
|
2023-10-26 17:35:21 +07:00
|
|
|
|
2023-11-10 13:28:42 +07:00
|
|
|
/** ข้อมูลในตาราง */
|
|
|
|
|
const rows = ref<dataRowRound[]>([]);
|
|
|
|
|
/**
|
|
|
|
|
* Function รับข้อมูลจาก API map
|
|
|
|
|
* @param data รับข้อมูลจาก API
|
|
|
|
|
*/
|
|
|
|
|
function fetchData(data: dataRowRound[]) {
|
|
|
|
|
let datalist: roundShow[] = data.map((e: dataRowRound) => {
|
|
|
|
|
return {
|
|
|
|
|
id: e.id,
|
|
|
|
|
round: `${e.startTimeMorning}-${e.endTimeAfternoon}`,
|
|
|
|
|
morningRound: `${e.startTimeMorning}-${e.endTimeMorning}`,
|
|
|
|
|
afternoonRound: `${e.startTimeAfternoon}-${e.endTimeAfternoon}`,
|
|
|
|
|
createdAt: e.createdAt,
|
|
|
|
|
createdFullName: e.createdFullName,
|
|
|
|
|
createdUserId: e.createdUserId,
|
|
|
|
|
description: e.description,
|
|
|
|
|
endTimeAfternoon: e.endTimeAfternoon,
|
|
|
|
|
endTimeMorning: e.endTimeMorning,
|
|
|
|
|
startTimeMorning: e.startTimeMorning,
|
|
|
|
|
startTimeAfternoon: e.startTimeAfternoon,
|
|
|
|
|
lastUpdateFullName: e.lastUpdateFullName,
|
|
|
|
|
lastUpdateUserId: e.lastUpdateUserId,
|
|
|
|
|
lastUpdatedAt: e.lastUpdatedAt,
|
|
|
|
|
isActive: e.isActive,
|
|
|
|
|
isDefault: e.isDefault,
|
|
|
|
|
};
|
2023-10-27 15:52:47 +07:00
|
|
|
});
|
|
|
|
|
rows.value = datalist;
|
2023-10-26 17:35:21 +07:00
|
|
|
}
|
2023-11-10 13:28:42 +07:00
|
|
|
|
|
|
|
|
return {
|
|
|
|
|
visibleColumns,
|
|
|
|
|
columns,
|
|
|
|
|
rows,
|
|
|
|
|
fetchData,
|
|
|
|
|
};
|
|
|
|
|
});
|