โครงสร้างอัตรากำลัง => ปรับการเพิ่มส่วนราชการ

This commit is contained in:
DESKTOP-1R2VSQH\Lenovo ThinkPad E490 2024-03-13 10:38:19 +07:00
parent 03439d7114
commit 3ea63a2244
5 changed files with 318 additions and 6 deletions

View file

@ -310,7 +310,12 @@ watch(
</q-card-section>
<q-separator />
<div class="text-right q-ma-sm">
<q-btn label="บันทึก" type="submit" color="secondary">
<q-btn
label="บันทึก"
type="submit"
color="secondary"
:disable="isReadonly"
>
<q-tooltip>นทกขอม</q-tooltip>
</q-btn>
</div>

View file

@ -1,6 +1,244 @@
<script setup lang="ts"></script>
<script setup lang="ts">
import { ref, reactive } from "vue";
/** importType*/
import type { QTableProps } from "quasar";
/** importStore*/
import { useCounterMixin } from "@/stores/mixin";
const {
date2Thai,
dialogRemove,
messageError,
showLoader,
hideLoader,
success,
} = useCounterMixin();
/** ข้อมูล Table*/
const columns = ref<QTableProps["columns"]>([
{
name: "no",
align: "left",
label: "ลำดับ",
sortable: true,
field: "name",
headerStyle: "font-size: 14px",
style: "font-size: 14px",
},
{
name: "groupPos",
align: "left",
label: "กลุ่มงานช่างตำแหน่ง",
sortable: true,
field: "groupPos",
headerStyle: "font-size: 14px",
style: "font-size: 14px",
},
{
name: "level",
align: "left",
label: "ระดับ",
sortable: true,
field: "level",
headerStyle: "font-size: 14px",
style: "font-size: 14px",
},
{
name: "minimumOld",
align: "left",
label: "อัตราค่าจ้าง ขั้นต่ำสุด",
sortable: true,
field: "minimumOld",
headerStyle: "font-size: 14px",
style: "font-size: 14px",
},
{
name: "groupOld",
align: "left",
label: "อัตราค่าจ้าง กลุ่มกบัญชีค่าจ่าง",
sortable: true,
field: "groupOld",
headerStyle: "font-size: 14px",
style: "font-size: 14px",
},
{
name: "maximumOld",
align: "left",
label: "อัตราค่าจ้าง ขั้นสูงสุดเดิม",
sortable: true,
field: "maximumOld",
headerStyle: "font-size: 14px",
style: "font-size: 14px",
},
{
name: "groupHigher",
align: "left",
label: "อัตราค่าจ้างสูงกว่า กลุ่มกบัญชีค่าจ่าง",
sortable: true,
field: "groupHigher",
headerStyle: "font-size: 14px",
style: "font-size: 14px",
},
{
name: "maximumNew",
align: "left",
label: "อัตราค่าจ้างสูงกว่า ขั้นสูงใหม่",
sortable: true,
field: "maximumNew",
headerStyle: "font-size: 14px",
style: "font-size: 14px",
},
{
name: "reson",
align: "left",
label: "อัตราค่าจ้างสูงกว่า ขั้นสูงใหม่",
sortable: true,
field: "maximumNew",
headerStyle: "font-size: 14px",
style: "font-size: 14px",
},
]);
const visibleColumns = ref<string[]>([
"no",
"groupPos",
"level",
"minimumOld",
"groupOld",
"maximumOld",
"groupHigher",
]);
const rows = ref<any>([
{
id: "1",
name: "ผังบัญชีโครงสร้างอัตราค่าจ้างลูกจ้าง 1",
group: 1,
date: new Date(),
isActive: true,
},
{
id: "2",
name: "ผังบัญชีโครงสร้างอัตราค่าจ้างลูกจ้าง 2",
group: 2,
date: new Date(),
isActive: false,
},
]);
const formFilter = reactive({
page: 1,
pageSize: 10,
keyword: "",
});
const pagination = ref({
page: formFilter.page,
rowsPerPage: formFilter.pageSize,
});
</script>
<template>
<div>2</div>
<d-table
flat
bordered
dense
:rows="rows"
:columns="columns"
row-key="name"
v-model:pagination="pagination"
:rows-per-page-options="[10, 20, 50, 100]"
:visible-columns="visibleColumns"
>
<template v-slot:header="props">
<q-tr :props="props">
<q-th v-for="col in props.cols" :key="col.name" :props="props">
<span class="text-weight-medium">{{ col.label }}</span>
</q-th>
<q-th auto-width />
</q-tr>
<q-separator />
</template>
<template v-slot:body="props">
<q-tr :props="props" class="cursor-pointer">
<q-td v-for="col in props.cols" :key="col.name" :props="props">
<div v-if="col.name === 'date'">
{{ col.value ? date2Thai(col.value) : "-" }}
</div>
<div v-else-if="col.name === 'group'">
{{ col.value ? `กลุ่มที่ (${col.value})` : "-" }}
</div>
<div v-else-if="col.name === 'isActive'">
<q-icon
:name="col.value ? 'done' : 'close'"
:color="col.value ? 'primary' : 'grey'"
size="24px"
></q-icon>
</div>
<div v-else>{{ col.value ? col.value : "-" }}</div>
</q-td>
<!-- <q-td>
<q-btn
flat
dense
icon="mdi-dots-vertical"
class="q-pa-none q-ml-xs"
color="grey-13"
size="12px"
>
<q-menu>
<q-list dense style="min-width: 200px">
<q-item
v-for="(item, index) in itemMenu"
:key="index"
clickable
v-close-popup
@click.stop="onClickAction(item.type, props.row)"
>
<q-item-section>
<div class="row items-center">
<q-icon
:color="item.color"
size="17px"
:name="item.icon"
/>
<div class="q-pl-md">{{ item.label }}</div>
</div>
</q-item-section>
</q-item>
<q-item
v-if="props.row.isActive == false"
clickable
v-close-popup
@click.stop="onClickDelete(props.row.id)"
>
<q-item-section>
<div class="row items-center">
<q-icon color="red" size="17px" name="delete" />
<div class="q-pl-md">ลบ</div>
</div>
</q-item-section>
</q-item>
</q-list>
</q-menu>
</q-btn>
</q-td> -->
</q-tr>
</template>
<!-- <template v-slot:pagination="scope">
<q-pagination
v-model="formFilter.page"
active-color="primary"
color="dark"
:max="1"
:max-pages="5"
size="sm"
boundary-links
direction-links
></q-pagination>
</template> -->
</d-table>
</template>
<style scoped></style>

View file

@ -106,7 +106,7 @@ const itemMenu = ref<ItemsMenu[]>([
type: "upload",
},
{
label: "อัตราเงินเดือน",
label: "อัตราค่าจ้าง",
icon: "mdi-format-list-bulleted-triangle",
color: "secondary",
type: "salaryRate",