ระบบการพัฒนา => รายการโครงการปรับการแสดงผลแบบฟอร์ม
This commit is contained in:
parent
41a0d80b64
commit
20e99fe23b
13 changed files with 1791 additions and 1319 deletions
|
|
@ -5,36 +5,41 @@ import { useRoute } from "vue-router";
|
|||
import http from "@/plugins/http";
|
||||
import config from "@/app.config";
|
||||
|
||||
/**
|
||||
* importType
|
||||
*/
|
||||
import type { DataOption } from "@/modules/15_development/interface/index/Main";
|
||||
import type { FormData } from "@/modules/15_development/interface/request/Other";
|
||||
import type { FormBudget } from "@/modules/15_development/interface/request/Main";
|
||||
|
||||
/**
|
||||
* importstor
|
||||
*/
|
||||
import { useCounterMixin } from "@/stores/mixin";
|
||||
|
||||
/**
|
||||
* use
|
||||
*/
|
||||
const $q = useQuasar();
|
||||
const {
|
||||
showLoader,
|
||||
hideLoader,
|
||||
diffDay,
|
||||
date2Thai,
|
||||
messageError,
|
||||
dialogConfirm,
|
||||
success,
|
||||
} = useCounterMixin();
|
||||
const { showLoader, hideLoader, messageError } = useCounterMixin();
|
||||
const route = useRoute();
|
||||
const projectId = ref<string>(route.params.id.toLocaleString());
|
||||
|
||||
/**
|
||||
* props
|
||||
*/
|
||||
const status = defineModel<string>("status", { required: true });
|
||||
const isChangeData = defineModel<boolean>("isChangeData", { required: true });
|
||||
const props = defineProps({
|
||||
prevStep: { type: Function, required: true },
|
||||
nextStep: { type: Function, required: true },
|
||||
onCheckChangeData: { type: Function, required: true },
|
||||
});
|
||||
const projectId = ref<string>(route.params.id.toLocaleString());
|
||||
|
||||
const checkRoutePermission = ref<boolean>(
|
||||
route.name == "developmentDetailPage"
|
||||
);
|
||||
const props = defineProps({
|
||||
prevStep: { type: Function, required: true },
|
||||
nextStep: { type: Function, required: true },
|
||||
});
|
||||
const step = ref<string>("");
|
||||
|
||||
const provinceOp = ref<DataOption[]>([]);
|
||||
const provinceOpMain = ref<DataOption[]>([]);
|
||||
const budgetOp = ref<DataOption[]>([
|
||||
{
|
||||
id: "REGULATIONBUDGET",
|
||||
|
|
@ -64,149 +69,42 @@ const budgetSubOp = ref<DataOption[]>([
|
|||
},
|
||||
]);
|
||||
|
||||
/** ดึงข้อมูล จังหวัด */
|
||||
const getProvince = async () => {
|
||||
showLoader();
|
||||
http
|
||||
.get(config.API.province)
|
||||
.then((res) => {
|
||||
const data = res.data.result;
|
||||
|
||||
provinceOp.value = data.map((item: DataOption) => ({
|
||||
id: item.id,
|
||||
name: item.name,
|
||||
}));
|
||||
provinceOpMain.value = provinceOp.value;
|
||||
})
|
||||
.catch((e) => {
|
||||
messageError($q, e);
|
||||
})
|
||||
.finally(() => {
|
||||
hideLoader();
|
||||
});
|
||||
};
|
||||
|
||||
/** ตัวแปร */
|
||||
const formData = reactive<FormData>({
|
||||
dateStart: null, //วันที่เริ่มต้น
|
||||
dateEnd: null, //วันที่สิ้นสุด
|
||||
totalDate: null, //รวมระยะเวลา (วัน)
|
||||
developmentAddresss: [{ address: "", provinceId: "" }], //ที่อยู่ ,จังหวัด
|
||||
budget: "", //ประเภทงบประมาณ(งบตามข้อบัญญัติ->REGULATIONBUDGET, งบประมาณกรุงเทพมหานคร->BANGKOKBUDGET, เงินนอกงบประมาณ->OUTSIDEBUDGET)
|
||||
const formData = reactive<FormBudget>({
|
||||
budget: "",
|
||||
budgetSub: "",
|
||||
accept: null, //จํานวนงบประมาณที่ขอรับการจัดสรรฯ
|
||||
receive: null, //จํานวนงบประมาณที่ได้รับการจัดสรรฯ
|
||||
approved: null, //จํานวนงบประมาณที่ได้รับอนุมัติ
|
||||
budgetPay: null, //จํานวนงบประมาณที่จ่ายจริง
|
||||
issues: "", //ประเด็นความเสี่ยง
|
||||
chance: null, //โอกาสที่จะเกิด
|
||||
effects: null, //ผลกระทบจากการเกิด
|
||||
riskLevel: "", //ระดับความเสี่ยง
|
||||
riskManagement: "", //เเนวทางการบริหารความเสี่ยง
|
||||
expect: "", //ประโยชน์ที่คาดว่าจะได้รับ
|
||||
topicAcademic: "", //หัวข้อ/ประเด็นการฝึกอบรม ศึกษาดูงาน
|
||||
addressAcademic: "", //สถานที่ฝึกอบรม ศึกษาดูงาน
|
||||
provinceActualId: "", //จังหวัด(ข้อมูลวิชาการ)
|
||||
accept: null,
|
||||
receive: null,
|
||||
approved: null,
|
||||
budgetPay: null,
|
||||
});
|
||||
|
||||
/** ดึงข้อมูล */
|
||||
function fetchData() {
|
||||
showLoader();
|
||||
http
|
||||
.get(config.API.developmentMainTab("tab5", projectId.value))
|
||||
.get(config.API.developmentMainTab("tab7", projectId.value))
|
||||
.then((res) => {
|
||||
const data = res.data.result;
|
||||
formData.dateStart = data.dateStart;
|
||||
formData.dateEnd = data.dateEnd;
|
||||
formData.totalDate = data.totalDate;
|
||||
formData.developmentAddresss = data.developmentAddresss.map((e: any) => ({
|
||||
address: e.address,
|
||||
provinceId: e.provinceId,
|
||||
}));
|
||||
formData.budget = data.budget;
|
||||
formData.budgetSub = data.budgetSub;
|
||||
formData.accept = data.accept;
|
||||
formData.receive = data.receive;
|
||||
formData.approved = data.approved;
|
||||
formData.budgetPay = data.budgetPay;
|
||||
formData.issues = data.issues;
|
||||
formData.chance = Number(data.chance);
|
||||
formData.effects = Number(data.effects);
|
||||
formData.riskLevel = data.riskLevel;
|
||||
formData.riskManagement = data.riskManagement;
|
||||
formData.expect = data.expect;
|
||||
formData.topicAcademic = data.topicAcademic;
|
||||
formData.addressAcademic = data.addressAcademic;
|
||||
formData.provinceActualId = data.provinceActualId;
|
||||
})
|
||||
.catch((err) => {
|
||||
messageError($q, err);
|
||||
})
|
||||
.finally(() => {
|
||||
hideLoader();
|
||||
isChangeData.value = false;
|
||||
});
|
||||
}
|
||||
|
||||
/** ฟังชั่นเคลียค่าวันสิ้นสุดเมื่อวันสิ้นสุดมากกว่าวันเริ่ม */
|
||||
function changeDateStart() {
|
||||
if (formData.dateStart !== null && formData.dateEnd !== null) {
|
||||
const startDate = new Date(formData.dateStart);
|
||||
const endDate = new Date(formData.dateEnd);
|
||||
if (startDate > endDate) {
|
||||
formData.dateEnd = null;
|
||||
formData.totalDate = null;
|
||||
} else {
|
||||
formData.totalDate = diffDay(formData.dateStart, formData.dateEnd);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/** ฟังชั่น เก็บค่า ระยะกี่วันจากวันเริ่ม */
|
||||
function changeDateEnd() {
|
||||
formData.totalDate = diffDay(formData.dateStart, formData.dateEnd);
|
||||
}
|
||||
|
||||
/**
|
||||
* Fuction Filter จังหวัด
|
||||
* @param val ค่าตัวพิมพ์ค้นหา
|
||||
* @param update ทุกครั้งที่พิมพ์ค่า
|
||||
*/
|
||||
const filterSelector = (val: string, update: Function) => {
|
||||
update(() => {
|
||||
provinceOp.value = provinceOpMain.value.filter(
|
||||
(v: DataOption) => v.name.indexOf(val) > -1
|
||||
);
|
||||
});
|
||||
};
|
||||
|
||||
/** ระดับความเสี่ยงของโครงการ option */
|
||||
async function calRiskLevel() {
|
||||
if (formData.chance && formData.effects) {
|
||||
const riskLevel =
|
||||
(await Number(formData.chance)) * Number(formData.effects);
|
||||
formData.riskLevel =
|
||||
riskLevel == 1
|
||||
? "น้อยมาก"
|
||||
: riskLevel == 2
|
||||
? "น้อย"
|
||||
: riskLevel == 3 || riskLevel == 4 || riskLevel == 6
|
||||
? "ปานกลาง"
|
||||
: riskLevel == 5 || riskLevel == 8 || riskLevel == 9 || riskLevel == 10
|
||||
? "สูง"
|
||||
: riskLevel == 12 ||
|
||||
riskLevel == 15 ||
|
||||
riskLevel == 16 ||
|
||||
riskLevel == 20 ||
|
||||
riskLevel == 25
|
||||
? "สูงมาก"
|
||||
: "";
|
||||
}
|
||||
}
|
||||
|
||||
/** บันทึกข้อมูล */
|
||||
function onSubmit() {
|
||||
// dialogConfirm($q, async () => {
|
||||
showLoader();
|
||||
formData.totalDate = Number(formData.totalDate);
|
||||
formData.accept =
|
||||
typeof formData.accept === "string"
|
||||
? Number(formData.accept.replace(/,/g, ""))
|
||||
|
|
@ -223,32 +121,42 @@ function onSubmit() {
|
|||
typeof formData.budgetPay === "string"
|
||||
? Number(formData.budgetPay.replace(/,/g, ""))
|
||||
: formData.budgetPay;
|
||||
|
||||
http
|
||||
.put(config.API.developmentMainTab("tab5", projectId.value), formData)
|
||||
.then(() => {
|
||||
// fetchData();
|
||||
// success($q, "บันทึกข้อมูลสำเร็จ");
|
||||
step.value == "next" ? props.nextStep() : props.prevStep();
|
||||
})
|
||||
.put(config.API.developmentMainTab("tab7", projectId.value), formData)
|
||||
.then(() => {})
|
||||
.catch((err) => {
|
||||
messageError($q, err);
|
||||
})
|
||||
.finally(() => {
|
||||
hideLoader();
|
||||
isChangeData.value = false;
|
||||
});
|
||||
// });
|
||||
}
|
||||
|
||||
/** ดึงข้อมูลเมื่อคอมโพเนนต์โหลดเสร็จสมบูรณ์ */
|
||||
/**
|
||||
* function ไปยัง Tab ค่อไป
|
||||
*/
|
||||
function onNextTab() {
|
||||
step.value == "next" ? props.nextStep() : props.prevStep();
|
||||
}
|
||||
|
||||
/**
|
||||
* ดึงข้อมูลเมื่อคอมโพเนนต์โหลดเสร็จสมบูรณ์
|
||||
*/
|
||||
onMounted(() => {
|
||||
fetchData();
|
||||
getProvince();
|
||||
});
|
||||
|
||||
/**
|
||||
* เรียก function ไปใช่หน้าหลัก
|
||||
*/
|
||||
defineExpose({
|
||||
onSubmit,
|
||||
});
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<q-form greedy @submit.prevent @validation-success="onSubmit">
|
||||
<q-form greedy @submit.prevent @validation-success="onNextTab">
|
||||
<div class="row q-pa-md q-col-gutter-sm">
|
||||
<div class="col-3">
|
||||
<q-select
|
||||
|
|
@ -263,6 +171,9 @@ onMounted(() => {
|
|||
emit-value
|
||||
map-options
|
||||
class="inputgreen"
|
||||
@update:model-value="
|
||||
props.onCheckChangeData(), (formData.budgetSub = '')
|
||||
"
|
||||
/>
|
||||
</div>
|
||||
<div class="col-2">
|
||||
|
|
@ -279,6 +190,7 @@ onMounted(() => {
|
|||
emit-value
|
||||
map-options
|
||||
class="inputgreen"
|
||||
@update:model-value="props.onCheckChangeData()"
|
||||
/>
|
||||
</div>
|
||||
<div class="col-12">
|
||||
|
|
@ -293,6 +205,7 @@ onMounted(() => {
|
|||
label="จํานวนงบประมาณที่ขอรับการจัดสรร ฯ"
|
||||
mask="###,###,###,###,###"
|
||||
reverse-fill-mask
|
||||
@update:model-value="props.onCheckChangeData()"
|
||||
/>
|
||||
</div>
|
||||
<div class="col-3">
|
||||
|
|
@ -305,6 +218,7 @@ onMounted(() => {
|
|||
mask="###,###,###,###,###"
|
||||
reverse-fill-mask
|
||||
label="จํานวนงบประมาณที่ได้รับการจัดสรร ฯ"
|
||||
@update:model-value="props.onCheckChangeData()"
|
||||
/>
|
||||
</div>
|
||||
<div v-if="status == 'FINISH'" class="col-3">
|
||||
|
|
@ -318,6 +232,7 @@ onMounted(() => {
|
|||
mask="###,###,###,###,###"
|
||||
label="จํานวนงบประมาณที่ได้รับอนุมัติ"
|
||||
reverse-fill-mask
|
||||
@update:model-value="props.onCheckChangeData()"
|
||||
/>
|
||||
</div>
|
||||
<div v-if="status == 'FINISH'" class="col-3">
|
||||
|
|
@ -330,6 +245,7 @@ onMounted(() => {
|
|||
mask="###,###,###,###,###"
|
||||
reverse-fill-mask
|
||||
label="จํานวนงบประมาณที่จ่ายจริง"
|
||||
@update:model-value="props.onCheckChangeData()"
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue