hrms-mgt/src/modules/11_discipline/store/ComplaintsStore.ts

126 lines
4.3 KiB
TypeScript
Raw Normal View History

import { defineStore } from "pinia";
import { ref } from "vue";
import { useCounterMixin } from "@/stores/mixin";
2023-10-19 15:39:18 +07:00
import type { DataOption } from "@/modules/11_discipline/interface/index/Main";
import type { DataList, DataListRow, DataAdd, DataAddResponse } from "@/modules/11_discipline/interface/response/complaint"
2023-10-20 10:31:07 +07:00
import type { QTableProps } from "quasar";
const mixin = useCounterMixin()
const { date2Thai } = mixin
// id
// cardId
// prefix
// firstName
// lastName
// position
// level
// oc
2023-10-19 15:39:18 +07:00
export const useComplainstDataStore = defineStore("DisciplineComplainst", () => {
const rows = ref<DataListRow[]>([])
const rowsAdd = ref<DataAdd[]>([])
2023-10-20 10:31:07 +07:00
const visibleColumns = ref<string[]>([]);
const columns = ref<QTableProps["columns"]>([]);
function fetchComplainstAdd(data: DataAddResponse[]) {
let datalist = data.map((e: DataAddResponse) => ({
id: e.id,
idcard: e.idcard,
name: e.name,
position: e.position,
positionLevel: e.positionLevel,
educationQualification: e.educationQualification,
organization: e.organization,
}))
rowsAdd.value = datalist
}
2023-10-19 15:39:18 +07:00
function fetchComplainst(data: DataList[]) {
let datalist: DataListRow[] = data.map((e: DataList) => ({
id: e.id,
title: e.title,
description: e.description,
respondent: e.respondent,
descMistake: e.descMistake,
createdAt: date2Thai(e.createdAt)!,
devLevel: e.devLevel,
considerationDate: date2Thai(e.considerationDate)!,
complaintStatus: statusTothai(e.complaintStatus),
}));
rows.value = datalist;
}
2023-10-20 10:31:07 +07:00
// filter options
const complainantoptionsMain = ref<DataOption[]>([
{ id: "PERSON", name: "บุคคล" },
{ id: "ORGANIZATION", name: "หน่วยงาน" },
{ id: "BANGKOK", name: "กรุงเทพมหานคร" },
]);
const complainantoptions = ref<DataOption[]>(complainantoptionsMain.value)
const consideredAgencytoptions = ref<DataOption[]>([
{ id: "0", name: "หน่ายงานเอ" },
{ id: "1", name: "หน่ายงานบี" },
{ id: "2", name: "หน่ายงานชี" },
]);
const officeOp = ref<DataOption[]>([
{ id: "0", name: "สำนักงาน1" },
{ id: "1", name: "สำนักงาน2" },
{ id: "2", name: "สำนักงาน3" },
]);
const statusTothai = (val: string) => {
switch (val) {
case 'NEW': return "ใหม่";
case 'STOP': return "ยุติเรื่อง";
case 'SEND_INVESTIGATE': return "มีมูลส่งไปสืบสวนแล้ว";
default: return "-";
}
};
const agencytoptions = ref<DataOption[]>(consideredAgencytoptions.value)
const optionListNameMain = ref<DataOption[]>([])
const optionListName = ref<DataOption[]>([])
function selectComplainantTpye(list: any) {
optionListNameMain.value = list
optionListName.value = list
}
2023-10-19 15:39:18 +07:00
function filterSelector(val: string, update: Function, type: string) {
update(() => {
const needle = val.toLowerCase();
if (type === "filtercomplainantType") {
complainantoptions.value = complainantoptionsMain.value.filter(
(v: any) => v.name.toLowerCase().indexOf(needle) > -1
);
} else if (type === "filteragencytoptions") {
agencytoptions.value = consideredAgencytoptions.value.filter(
(v: any) => v.name.toLowerCase().indexOf(needle) > -1
);
} else if (type === "filtercomplainantOP") {
optionListName.value = optionListNameMain.value.filter(
(v: any) => v.name.toLowerCase().indexOf(needle) > -1
);
}
});
}
2023-10-20 10:31:07 +07:00
return {
rows,
rowsAdd,
2023-10-20 10:31:07 +07:00
visibleColumns,
columns,
2023-10-19 15:39:18 +07:00
fetchComplainst,
selectComplainantTpye,
filterSelector,
complainantoptions,
consideredAgencytoptions,
2023-10-20 10:31:07 +07:00
optionListName,
fetchComplainstAdd,
officeOp
2023-10-20 10:31:07 +07:00
}
})