ส่งออกคำสั่ง ==> โครงสร้าง

This commit is contained in:
DESKTOP-1R2VSQH\Lenovo ThinkPad E490 2024-10-16 11:30:09 +07:00
parent fcb444db77
commit c6efe264b0
3 changed files with 296 additions and 72 deletions

View file

@ -8,7 +8,12 @@ import { useRouter } from "vue-router";
import { useCounterMixin } from "@/stores/mixin";
import { useCommandMainStore } from "@/modules/18_command/store/Main";
import type { ListCommand } from "@/modules/18_command/interface/index/Main";
/** importType*/
import type { QTableProps } from "quasar";
import type {
ListCommand,
DataOption,
} from "@/modules/18_command/interface/index/Main";
import DialogHeader from "@/components/DialogHeader.vue";
@ -28,6 +33,7 @@ const {
const modal = defineModel<boolean>("modal", { required: true });
const props = defineProps({
commandTypeCode: String, //
orgPublishDate: { type: Date, defult: undefined },
});
const commandOp = ref<ListCommand[]>([]); //
@ -36,33 +42,100 @@ const commandNo = ref<string>(""); //คำสั่งเลขที่
const commandYear = ref<number>(new Date().getFullYear());
const commandAffectDate = ref<Date | null>(null); //
const commandExcecuteDate = ref<Date | null>(null); //
const group = ref<string>(""); //
const isCheckOrgPublishDate = ref<boolean>(false); //
const groupOp = ref<DataOption[]>([]);
const groupDataOp = ref<DataOption[]>([
{
id: "1.1",
name: "กลุ่มที่ 1.1 : ปฏิบัติงาน ชำนาญงาน ปฏิบัติการ ชำนาญการ",
},
{
id: "1.2",
name: "กลุ่มที่ 1.2 : อาวุโส ชำนาญการพิเศษ อำนวยการต้น",
},
{
id: "2",
name: "กลุ่มที่ 2 : ทักษะพิเศษ เชี่ยวชาญ ทรงคุณวุฒิ อำนวยการสูง บริหารต้น บริหารสูง",
},
]);
//Table
const rows = ref<any[]>([]);
const selected = ref<any[]>([]);
const columns = ref<QTableProps["columns"]>([
{
name: "posMasterNo",
align: "left",
label: "ตำแหน่งเลขที่",
sortable: false,
field: "posMasterNo",
headerStyle: "font-size: 14px",
style: "font-size: 14px",
},
{
name: "positionName",
align: "left",
label: "ตำแหน่งในสายงาน",
field: "positionName",
sortable: false,
headerStyle: "font-size: 14px",
style: "font-size: 14px",
},
{
name: "posTypeName",
align: "left",
label: "ประเภทตำแหน่ง",
sortable: false,
field: "posTypeName",
headerStyle: "font-size: 14px",
style: "font-size: 14px",
},
{
name: "posLevelName",
align: "left",
label: "ระดับตำแหน่ง",
sortable: false,
field: "posLevelName",
headerStyle: "font-size: 14px",
style: "font-size: 14px",
},
{
name: "positionIsSelected",
align: "left",
label: "คนครอง",
sortable: false,
field: "positionIsSelected",
headerStyle: "font-size: 14px",
style: "font-size: 14px",
},
]);
/** ฟังก์ชันบันทึกและไปยังหน้าคำสั่ง*/
function onSubmit() {
dialogConfirm($q, async () => {
showLoader();
const body = {
commandYear: commandYear.value,
commandNo: commandNo.value,
commandTypeId: commandType.value,
commandAffectDate: commandAffectDate.value,
commandExcecuteDate: commandExcecuteDate.value,
persons: [],
};
await http
.post(config.API.command + `/person`, body)
.then(async (res) => {
const id = await res.data.result;
router.push(`/command/edit/${id}`);
modal.value = false;
})
.catch((e) => {
messageError($q, e);
})
.finally(() => {
hideLoader();
});
// showLoader();
// const body = {
// commandYear: commandYear.value,
// commandNo: commandNo.value,
// commandTypeId: commandType.value,
// commandAffectDate: commandAffectDate.value,
// commandExcecuteDate: commandExcecuteDate.value,
// persons: [],
// };
// await http
// .post(config.API.command + `/person`, body)
// .then(async (res) => {
// const id = await res.data.result;
// router.push(`/command/edit/${id}`);
// modal.value = false;
// })
// .catch((e) => {
// messageError($q, e);
// })
// .finally(() => {
// hideLoader();
// });
});
}
@ -76,6 +149,10 @@ function closeModal() {
commandYear.value = new Date().getFullYear();
commandAffectDate.value = null;
commandExcecuteDate.value = null;
group.value = "";
isCheckOrgPublishDate.value = false;
rows.value = [];
selected.value = [];
}
/** ฟังก์ชันดึงข้อมูลคำสั่ง */
@ -88,9 +165,66 @@ async function fetchCommandType() {
commandType.value = commandOp.value[0].id;
}
/**
* งกนตนหาขอมลของ Option ขอสถานะ
* @param val าทองการฟลเตอร
* @param update พเดทค
* @param refData ดาตาทองการฟลเตอร
*/
function filterOption(val: string, update: Function) {
update(() => {
group.value = val ? "" : group.value;
groupOp.value = groupDataOp.value.filter(
(v: DataOption) => v.name.indexOf(val) > -1
);
});
}
/**
* งกนเลอกกล
* @param val กลมทองการคนหา
*/
function updateGroup(val: string) {
const data = [
{
id: "1",
posMasterNo: "สกก.1",
positionName: "นักบริหาร",
posTypeName: "บริหาร",
posLevelName: "ปฏิบัติงาน",
positionIsSelected: "นายศรัณย์ ศิลาดี",
group: "1.1",
},
{
id: "2",
posMasterNo: "สกก.2",
positionName: "นักบริหาร",
posTypeName: "บริหาร",
posLevelName: "อำนวยการต้น",
positionIsSelected: "นางสาวพรทิพย์ กาญจนา",
group: "1.2",
},
{
id: "3",
posMasterNo: "สกก.3",
positionName: "นักบริหาร",
posTypeName: "บริหาร",
posLevelName: "อำนวยการสูง",
positionIsSelected: "",
group: "2",
},
];
rows.value = data.filter((e: any) => e.group === val);
}
watch(modal, () => {
if (modal.value) {
fetchCommandType();
if (props.orgPublishDate) {
commandExcecuteDate.value = props.orgPublishDate;
isCheckOrgPublishDate.value = true;
}
}
});
</script>
@ -128,6 +262,8 @@ watch(modal, () => {
</template>
</q-select>
</div>
<!-- คำสงเลขท -->
<div class="col-6">
<q-input
class="inputgreen"
@ -140,7 +276,7 @@ watch(modal, () => {
<label class="col-1 flex justify-center items-center text-bold"
>/</label
>
<!-- . -->
<div class="col-5">
<datepicker
menu-class-name="modalfix"
@ -179,6 +315,7 @@ watch(modal, () => {
</datepicker>
</div>
<!-- นทลงนาม -->
<div class="col-6">
<datepicker
clearable
@ -222,6 +359,7 @@ watch(modal, () => {
</datepicker>
</div>
<!-- นทคำสงมผล -->
<div class="col-6">
<datepicker
clearable
@ -230,7 +368,8 @@ watch(modal, () => {
:locale="'th'"
autoApply
:enableTimePicker="false"
class="inputgreen"
:class="!isCheckOrgPublishDate ? 'inputgreen' : ''"
:readonly="isCheckOrgPublishDate"
>
<template #year="{ year }">
{{ year + 543 }}
@ -240,11 +379,12 @@ watch(modal, () => {
</template>
<template #trigger>
<q-input
:readonly="isCheckOrgPublishDate"
clearable
dense
outlined
hide-bottom-space
class="inputgreen"
:class="!isCheckOrgPublishDate ? 'inputgreen' : ''"
:model-value="
commandExcecuteDate == null
? null
@ -265,6 +405,111 @@ watch(modal, () => {
</template>
</datepicker>
</div>
<!-- กล -->
<div class="col-12">
<q-select
v-model="group"
:label="`${'กลุ่ม'}`"
option-label="name"
:options="groupOp"
option-value="id"
class="inputgreen"
dense
emit-value
map-options
lazy-rules
use-input
hide-bottom-space
outlined
@update:model-value="updateGroup"
@filter="(inputValue:any,doneFn:Function) => filterOption(inputValue, doneFn) "
>
<template v-slot:no-option>
<q-item>
<q-item-section class="text-grey">
ไมอม
</q-item-section>
</q-item>
</template>
</q-select>
</div>
<!-- TABLE -->
<div class="col-12">
<d-table
ref="table"
:columns="columns"
:rows="rows"
:paging="true"
row-key="id"
flat
bordered
dense
:rows-per-page-options="[10, 25, 50, 100]"
selection="multiple"
v-model:selected="selected"
>
<template v-slot:header-selection="scope">
<q-checkbox
keep-color
color="primary"
dense
v-model="scope.selected"
/>
</template>
<template v-slot:body="props">
<q-tr :props="props">
<q-td>
<q-checkbox
keep-color
color="primary"
dense
v-model="props.selected"
/>
</q-td>
<q-td
v-for="col in props.cols"
:key="col.name"
:props="props"
>
<div v-if="col.name === 'posMasterNo'">
{{
props.row.isSit
? col.value + " " + "(นั่งทับตำแหน่ง)"
: col.value
}}
</div>
<div v-else-if="col.name === 'posLevelName'">
{{
props.row.posLevelName
? props.row.isSpecial == true
? `${props.row.posLevelName} (ฉ)`
: props.row.posLevelName
: "-"
}}
</div>
<div v-else>
{{ col.value ? col.value : "-" }}
</div>
</q-td>
</q-tr>
</template>
<!-- <template v-slot:pagination="scope">
<q-pagination
v-model="reqMaster.page"
active-color="primary"
color="dark"
:max="totalPage"
:max-pages="5"
size="sm"
boundary-links
direction-links
></q-pagination>
</template> -->
</d-table>
</div>
</div>
</q-card-section>
@ -272,8 +517,8 @@ watch(modal, () => {
<q-card-actions align="right">
<q-btn
label="บันทึกและไปยังหน้าคำสั่ง"
:disable="commandType == ''"
label="ส่งไปออกคำสั่ง"
:disable="commandType == '' || selected.length === 0"
type="submit"
color="public"
>