แบบสอบถาม Exit interview

This commit is contained in:
setthawutttty 2023-10-09 15:28:37 +07:00
parent 01fe8f97f4
commit 63e5abf7a0
3 changed files with 484 additions and 123 deletions

View file

@ -4,8 +4,8 @@ import { useQuasar } from "quasar";
import { useRouter } from "vue-router";
import { useCounterMixin } from "@/stores/mixin";
// import http from "@/plugins/http";
// import config from "@/app.config";
import http from "@/plugins/http";
import config from "@/app.config";
// import keycloak from "@/plugins/keycloak";
import type { QForm } from "quasar";
@ -14,7 +14,7 @@ const $q = useQuasar();
const router = useRouter();
const mixin = useCounterMixin();
const { messageError, showLoader, hideLoader } = mixin;
const { messageError, showLoader, hideLoader,dialogConfirm ,success} = mixin;
const myForm = ref<QForm | null>(null);
@ -22,28 +22,14 @@ const myForm = ref<QForm | null>(null);
const question1Desc = ref<string>(
"เหตุใดท่านจึงตัดสินใจร่วมงานกับกรุงเทพมหานคร (เลือกได้มากกว่า 1 ข้อ)"
);
const question1Score = ref<number>(5);
const question1Answer = ref<any>([
"ความมั่นคงในการทำงาน",
"สิทธิประโยชน์/สวัสดิการ",
"อัตราเงินเดือน",
"ลักษณะงาน",
"วัฒนธรรมการทำงานของข้าราชการ",
"นโยบายของหน่วยงาน",
"ระบบการทำงาน",
"สมดุลชีวิตการทำงาน",
"บรรยากาศในการทำงาน",
"การพัฒนาในสายอาชีพ",
"โอกาสความก้าวหน้า",
"การได้รับการยอมรับจากสังคม",
// " ()",
]);
const question1Score = ref<number>(0);
const question1Answer = ref<any>([]);
// set 2
const question2Desc = ref<string>(
"สำหรับการลาออกในครั้งนี ท่านได้คิดทบทวนอย่างจริงจังเป็นระยะเวลานานเท่าใด"
);
const question2Score = ref<number>(5);
const question2Score = ref<number>(0);
const question2Answer = ref<any>([
"น้อยกว่า 2 สัปดาห์",
"1 เดือน - 3 เดือน",
@ -55,7 +41,7 @@ const question2Answer = ref<any>([
const question3Desc = ref<string>(
"ปัจจัยใดที่ทำให้ท่านตัดสินใจลาออกจากราชการ (เลือกได้มากกว่า 1 ข้อ)"
);
const question3Score = ref<number>(5);
const question3Score = ref<number>(0);
const question3Answer = ref<any>([
"อัตราเงินเดือน",
"สวัสดิการ",
@ -78,7 +64,7 @@ const question3Answer = ref<any>([
const question4Desc = ref<string>(
"อะไรคือสิ่งที่ท่านเห็นว่าควรปรับปรุง (เลือกได้มากกว่า 1 ข้อ)"
);
const question4Score = ref<number>(5);
const question4Score = ref<number>(0);
const question4Answer = ref<any>([
"อัตราเงินเดือน ",
"สวัสดิการ",
@ -101,35 +87,38 @@ const question4Answer = ref<any>([
const question5Desc = ref<string>(
"โปรดระบุสาเหตุที่แท้จริง ที่ทำให้ท่านตัดสินใจลาออกจากการปฏิบัติราชการกับกรุงเทพมหานคร ?"
);
const question5Score = ref<number>(5);
const question5Answer = ref<any>([])
const question5Score = ref<number>(0);
// set 6
const question6Desc = ref<string>(
"ปัจจัยใดที่จะช่วยทำให้ท่านเปลี่ยนใจ ไม่อยากลาออกจากการปฏิบัติราชการกับกรุงเทพมหานคร"
);
const question6Score = ref<number>(5);
const question6Answer = ref<any>([])
const question6Score = ref<number>(0);
// set 7
const question7Desc = ref<string>(
"ท่านมีงานใหม่หรือไม่ ถ้ามี (โปรดระบุ ชื่อบริษัทเอกชน/หน่วยงานภาครัฐ) และอะไรคือสิ่งที่ที่ทำงานใหม่ให้กับท่าน ซึ่งท่านรู้สึกว่าเป็นที่น่าพอใจมากกว่าการปฏิบัติราชการกับกรุงเทพมหานคร"
);
const question7Score = ref<number>(5);
const question7Score = ref<number>(0);
const question7Answer = ref<any>(["มี (ระบุ)", "ไม่มี"]);
// set 8
const question8Desc = ref<string>(
"ท่านจะแนะนำเพื่อนให้มาร่วมงานกับกรุงเทพมหานครหรือไม่ (ถ้าไม่ โปรดระบุเหตุผล)"
);
const question8Score = ref<number>(5);
const question8Score = ref<number>(0);
const question8Answer = ref<any>(["แนะนำ", "ไม่แนะนำ (ระบุ)"]);
// set 9
const question9Desc = ref<string>(
"หากท่านมีโอกาสในอนาคต ท่านอยากกลับมาร่วมงานกับกรุงเทพมหานครหรือไม่ (ถ้าไม่ โปรดระบุเหตุผล)"
);
const question9Score = ref<number>(5);
const question9Score = ref<number>(0);
const question9Answer = ref<any>(["อยาก", "ไม่อยาก (ระบุ)"]);
// set 10
const question10Desc = ref<string>("ความคิดเห็นและข้อเสนอแนะอื่น ๆ");
const question10Score = ref<number>(5);
const question10Answer = ref<any>([])
const question10Score = ref<number>(0);
const exitFactor = ref<any>([]);
const reasonWork = ref<any>([]);
@ -183,41 +172,111 @@ onMounted(async () => {
//
const getData = async () => {
// showLoader();
// await http
// .get(config.API.xxx)
// .then((res: any) => {
// const data = res.data.result;
// avata.value = data.avatar ?? "";
// Position.value = data.position ?? "";
// PositionLevel.value = data.positionLevel ?? "";
// Org.value = data.org ?? "";
// fullname.value = data.fullname ?? "";
// prefix.value = data.prefix ?? "";
// reasonWork.value = data.reasonWork ?? [];
// reasonWorkOther.value = data.reasonWorkOther ?? "";
// timeThink.value = data.TimeThink ?? 0;
// exitFactor.value = data.exitFactor ?? [];
// exitFactorOther.value = data.exitFactorOther ?? 0;
// adjust.value = data.adjust ?? [];
// adjustOther.value = data.adjustOther ?? "";
// realReason.value = data.realReason ?? "";
// notExitFactor.value = data.notExitFactor ?? "";
// haveJob.value = data.havejob ?? null;
// haveJobReason.value = data.havejobReason ?? "";
// suggestFriends.value = data.suggestFriends ?? null;
// suggestFriendsReason.value = data.suggestFriendsReason ?? "";
// futureWork.value = data.futureWork ?? null;
// futureWorkReason.value = data.futureWorkReason ?? "";
// suggestion.value = data.suggestion ?? "";
// })
// .catch((e) => {
// messageError($q, e);
// })
// .finally(() => {
// hideLoader();
// });
showLoader();
await http
.get(config.API.questionExitInterview())
.then((res: any) => {
const data = res.data.result;
question1Score.value = data.question1Score ?? 0;
question2Score.value = data.question2Score ?? 0;
question3Score.value = data.question3Score ?? 0;
question4Score.value = data.question4Score ?? 0;
question5Score.value = data.question5Score ?? 0;
question6Score.value = data.question6Score ?? 0;
question7Score.value = data.question7Score ?? 0;
question8Score.value = data.question8Score ?? 0;
question9Score.value = data.question9Score ?? 0;
question10Score.value = data.question10Score ?? 0;
question1Desc.value = data.question1Desc
question1Answer.value = data.question1Answer
question2Desc.value = data.question1Desc
question2Answer.value = data.question1Answer
question3Desc.value = data.question1Desc
question3Answer.value = data.question1Answer
question4Desc.value = data.question1Desc
question4Answer.value = data.question1Answer
question5Desc.value = data.question1Desc
question5Answer.value = data.question1Answer
question6Desc.value = data.question1Desc
question6Answer.value = data.question1Answer
question7Desc.value = data.question1Desc
question7Answer.value = data.question1Answer
question8Desc.value = data.question1Desc
question8Answer.value = data.question1Answer
question9Desc.value = data.question1Desc
question9Answer.value = data.question1Answer
question10Desc.value = data.question1Desc
question10Answer.value = data.question1Answer
})
.catch((e) => {
messageError($q, e);
})
.finally(() => {
hideLoader();
});
};
const confirmClick = () =>{
dialogConfirm($q,()=>putData())
}
const putData = () => {
const body = {
question1Desc:question1Desc.value,
question1Score:question1Score.value,
question1Answer:question1Answer.value,
question2Desc:question2Desc.value,
question2Score:question2Score.value,
question2Answer:question2Answer.value,
question3Desc:question3Desc.value,
question3Score:question3Score.value,
question3Answer:question3Answer.value,
question4Desc:question4Desc.value,
question4Score:question4Score.value,
question4Answer:question4Answer.value,
question5Desc:question5Desc.value,
question5Score:question5Score.value,
question5Answer:question5Answer.value,
question6Desc:question6Desc.value,
question6Score:question6Score.value,
question6Answer:question6Answer.value,
question7Desc:question7Desc.value,
question7Score:question7Score.value,
question7Answer:question7Answer.value,
question8Desc:question8Desc.value,
question8Score:question8Score.value,
question8Answer:question8Answer.value,
question9Desc:question9Desc.value,
question9Score:question9Score.value,
question9Answer:question9Answer.value,
question10Desc:question10Desc.value,
question10Score:question10Score.value,
question10Answer:question10Answer.value,
};
showLoader();
http
.put(config.API.questionExitInterview(), body)
.then((res) => {
success($q, "บันทึกข้อมูลสำเร็จ");
})
.catch((e) => {
messageError($q, e);
})
.finally(async () => {
router.push(`/exit-Interview`)
});
}
</script>
<template>
<div class="toptitle text-dark col-12 row items-center">
@ -867,7 +926,7 @@ const getData = async () => {
<q-card-actions class="text-primary q-pa-md">
<q-space />
<q-btn unelevated label="บันทึก" color="public" @click=""> </q-btn>
<q-btn unelevated label="บันทึก" color="public" @click="confirmClick"> </q-btn>
</q-card-actions>
</q-form>
</q-card>

View file

@ -16,7 +16,14 @@ const router = useRouter();
const mixin = useCounterMixin();
const dataId = route.params.id.toString();
const { messageError, showLoader, hideLoader } = mixin;
const {
messageError,
showLoader,
hideLoader,
dialogConfirm,
success,
dialogMessageNotify,
} = mixin;
const myForm = ref<QForm | null>(null);
const roleAdmin = ref<boolean>(false);
@ -39,18 +46,18 @@ const futureWork = ref<any>();
const suggestion = ref<any>("");
const comment = ref<string>("");
const score = reactive([
{ no: 1, score: 0 },
{ no: 2, score: 0 },
{ no: 3, score: 0 },
{ no: 4, score: 0 },
{ no: 5, score: 0 },
{ no: 6, score: 0 },
{ no: 7, score: 0 },
{ no: 8, score: 0 },
{ no: 9, score: 0 },
{ no: 10, score: 0 },
{ no: 1, score: "" },
{ no: 2, score: "" },
{ no: 3, score: "" },
{ no: 4, score: "" },
{ no: 5, score: "" },
{ no: 6, score: "" },
{ no: 7, score: "" },
{ no: 8, score: "" },
{ no: 9, score: "" },
{ no: 10, score: "" },
]);
const scoreTotal = ref<number>(0);
const scoreTotal = ref<number|string>('');
const reasonWorkOther = ref("");
const reasonWork_option = ref<any>([
@ -164,6 +171,12 @@ const getData = async () => {
futureWork.value = data.futureWork ?? null;
futureWorkReason.value = data.futureWorkReason ?? "";
suggestion.value = data.suggestion ?? "";
score.forEach((item, index) => {
const scoreKey = `score${item.no}`;
item.score = data[scoreKey] ?? 0;
scoreTotal.value = data.scoreTotal ?? 0;
comment.value = data.comment;
});
})
.catch((e) => {
messageError($q, e);
@ -177,11 +190,66 @@ watch(score, () => {
scoreTotal.value = score.reduce((accumulator, object) => {
return accumulator + Number(object.score);
}, 0);
})
});
const saveClick = () => {
if (comment.value === "" ||
score[0].score === "" ||
score[1].score === "" ||
score[2].score === "" ||
score[3].score === "" ||
score[4].score === "" ||
score[5].score === "" ||
score[6].score === "" ||
score[7].score === "" ||
score[8].score === "" ||
score[9].score === "" ||
scoreTotal.value === "") {
dialogMessageNotify($q, "กรุณากรอกคะแนน เเละ ความคิดเห็น");
} else {
dialogConfirm($q, () => putData());
}
};
const putData = () => {
const body = {
score1: Number(score[0].score),
score2: Number(score[1].score),
score3: Number(score[2].score),
score4: Number(score[3].score),
score5: Number(score[4].score),
score6: Number(score[5].score),
score7: Number(score[6].score),
score8: Number(score[7].score),
score9: Number(score[8].score),
score10: Number(score[9].score),
scoreTotal: scoreTotal.value,
comment: comment.value,
};
showLoader();
http
.put(config.API.commentExitInterview(dataId), body)
.then((res) => {
success($q, "บันทึกข้อมูลสำเร็จ");
})
.catch((e) => {
messageError($q, e);
})
.finally(async () => {
router.push(`/exit-Interview`);
});
};
</script>
<template>
<div class="toptitle text-dark col-12 row items-center">
<q-btn icon="mdi-arrow-left" unelevated round dense flat color="primary" class="q-mr-sm" @click="router.go(-1)" />
<q-btn
icon="mdi-arrow-left"
unelevated
round
dense
flat
color="primary"
class="q-mr-sm"
@click="router.go(-1)"
/>
รายละเอยด Exit interview ของ {{ prefix }} {{ fullname }}
</div>
<q-card bordered class="row col-12 text-dark">
@ -238,7 +306,9 @@ watch(score, () => {
<div class="col-12 row q-col-gutter-md q-pa-md">
<div class="col-xs-12 col-sm-12">
<q-card bordered flat>
<div class="q-pa-xs bg-grey-2 row items-center q-py-sm q-px-md justify-center text-bold">
<div
class="q-pa-xs bg-grey-2 row items-center q-py-sm q-px-md justify-center text-bold"
>
แบบสอบถาม
</div>
<q-separator />
@ -248,16 +318,41 @@ watch(score, () => {
1 )
</div>
<div class="col-2 text-top0 items-center">
<q-input dense outlined v-model="score[0].score" label="คะแนนข้อ 1" type="number" />
<q-input
dense
outlined
v-model="score[0].score"
label="คะแนนข้อ 1"
type="number"
lazy-rules
:rules="[(val) => val !== '' || 'กรุณากรอกคะเเนน']"
/>
</div>
<q-option-group :options="reasonWork_option" type="checkbox" v-model="reasonWork" disable />
<q-option-group
:options="reasonWork_option"
type="checkbox"
v-model="reasonWork"
disable
/>
<div class="col-12 text-top0 items-center">
<q-item-label>
<q-input v-if="reasonWork.includes(12)" v-model="reasonWorkOther" disable label="กรอกข้อความ" dense
lazy-rules type="text" autogrow hide-bottom-space outlined class="bg-white" :rules="[
<q-input
v-if="reasonWork.includes(12)"
v-model="reasonWorkOther"
disable
label="กรอกข้อความ"
dense
lazy-rules
type="text"
autogrow
hide-bottom-space
outlined
class="bg-white"
:rules="[
(val) => (val && val.length > 0) || 'กรุณากรอกข้อความ',
]" />
]"
/>
</q-item-label>
</div>
<div class="col-10 text-top0 items-center">
@ -265,11 +360,24 @@ watch(score, () => {
านไดดทบทวนอยางจรงจงเปนระยะเวลานานเทาใด
</div>
<div class="col-2 text-top0 items-center">
<q-input dense outlined v-model="score[1].score" label="คะแนนข้อ 2" type="number" />
<q-input
dense
outlined
v-model="score[1].score"
label="คะแนนข้อ 2"
type="number"
lazy-rules
:rules="[(val) => val !== '' || 'กรุณากรอกคะเเนน']"
/>
</div>
<div class="col-12">
<q-option-group :options="timeThink_option" type="radio" v-model="timeThink" disable />
<q-option-group
:options="timeThink_option"
type="radio"
v-model="timeThink"
disable
/>
</div>
<div class="col-10 text-top0 items-center">
@ -278,17 +386,42 @@ watch(score, () => {
</div>
<div class="col-2 text-top0 items-center">
<q-input dense outlined v-model="score[2].score" label="คะแนนข้อ 3" type="number" />
<q-input
dense
outlined
v-model="score[2].score"
label="คะแนนข้อ 3"
type="number"
lazy-rules
:rules="[(val) => val !== '' || 'กรุณากรอกคะเเนน']"
/>
</div>
<q-option-group :options="exitFactor_option" type="checkbox" v-model="exitFactor" disable />
<q-option-group
:options="exitFactor_option"
type="checkbox"
v-model="exitFactor"
disable
/>
<div class="col-12 text-top0 items-center">
<q-item-label>
<q-input v-if="exitFactor.includes(15)" v-model="exitFactorOther" label="กรอกข้อความ" dense disable
lazy-rules type="text" autogrow hide-bottom-space outlined class="bg-white" :rules="[
<q-input
v-if="exitFactor.includes(15)"
v-model="exitFactorOther"
label="กรอกข้อความ"
dense
disable
lazy-rules
type="text"
autogrow
hide-bottom-space
outlined
class="bg-white"
:rules="[
(val) => (val && val.length > 0) || 'กรุณากรอกข้อความ',
]" />
]"
/>
</q-item-label>
</div>
@ -297,18 +430,43 @@ watch(score, () => {
</div>
<div class="col-2 text-top0 items-center">
<q-input dense outlined v-model="score[3].score" label="คะแนนข้อ 4" type="number" />
<q-input
dense
outlined
v-model="score[3].score"
label="คะแนนข้อ 4"
type="number"
lazy-rules
:rules="[(val) => val !== '' || 'กรุณากรอกคะเเนน']"
/>
</div>
<q-list>
<q-option-group :options="adjust_option" type="checkbox" v-model="adjust" disable />
<q-option-group
:options="adjust_option"
type="checkbox"
v-model="adjust"
disable
/>
</q-list>
<div class="col-12 text-top0 items-center">
<q-item-label>
<q-input v-if="adjust.includes(15)" v-model="adjustOther" label="กรอกอื่นๆ" dense disable lazy-rules
type="text" autogrow hide-bottom-space outlined class="bg-white" :rules="[
<q-input
v-if="adjust.includes(15)"
v-model="adjustOther"
label="กรอกอื่นๆ"
dense
disable
lazy-rules
type="text"
autogrow
hide-bottom-space
outlined
class="bg-white"
:rules="[
(val) => (val && val.length > 0) || 'กรุณากรอกข้อความ',
]" />
]"
/>
</q-item-label>
</div>
<div class="col-10 text-top0 items-center">
@ -316,20 +474,52 @@ watch(score, () => {
ทำใหานตดสนใจลาออกจากการปฏราชการกบกรงเทพมหานคร ?
</div>
<div class="col-2 text-top0 items-center">
<q-input dense outlined v-model="score[4].score" label="คะแนนข้อ 5" type="number" />
<q-input
dense
outlined
v-model="score[4].score"
label="คะแนนข้อ 5"
type="number"
lazy-rules
:rules="[(val) => val !== '' || 'กรุณากรอกคะเเนน']"
/>
</div>
<q-input class="col-12" dense disable outlined v-model="realReason" label=" " type="textarea" />
<q-input
class="col-12"
dense
disable
outlined
v-model="realReason"
label=" "
type="textarea"
/>
<div class="col-10 text-top0 items-center">
6. จจยใดทจะชวยทำใหานเปลยนใจ
ไมอยากลาออกจากการปฏราชการกบกรงเทพมหานคร
</div>
<div class="col-2 text-top0 items-center">
<q-input dense outlined v-model="score[5].score" label="คะแนนข้อ 6" type="number" />
<q-input
dense
outlined
v-model="score[5].score"
label="คะแนนข้อ 6"
type="number"
lazy-rules
:rules="[(val) => val !== '' || 'กรุณากรอกคะเเนน']"
/>
</div>
<q-input class="col-12" dense outlined disable v-model="notExitFactor" label=" " type="textarea" />
<q-input
class="col-12"
dense
outlined
disable
v-model="notExitFactor"
label=" "
type="textarea"
/>
<div class="col-10 text-top0 items-center">
7. านมงานใหมหรอไม าม (โปรดระบ
@ -339,16 +529,41 @@ watch(score, () => {
</div>
<div class="col-2 text-top0 items-center">
<q-input dense outlined v-model="score[6].score" label="คะแนนข้อ 7" type="number" />
<q-input
dense
outlined
v-model="score[6].score"
label="คะแนนข้อ 7"
type="number"
lazy-rules
:rules="[(val) => val !== '' || 'กรุณากรอกคะเเนน']"
/>
</div>
<q-option-group :options="haveJob_option" type="radio" v-model="haveJob" disable />
<q-option-group
:options="haveJob_option"
type="radio"
v-model="haveJob"
disable
/>
<div class="col-12 text-top0 items-center">
<q-item-label>
<q-input v-if="haveJob === true" v-model="haveJobReason" label="กรอกอื่นๆ" dense disable lazy-rules
type="text" autogrow hide-bottom-space outlined class="bg-white" :rules="[
<q-input
v-if="haveJob === true"
v-model="haveJobReason"
label="กรอกอื่นๆ"
dense
disable
lazy-rules
type="text"
autogrow
hide-bottom-space
outlined
class="bg-white"
:rules="[
(val) => (val && val.length > 0) || 'กรุณากรอกข้อความ',
]" />
]"
/>
</q-item-label>
</div>
<div class="col-10 text-top0 items-center">
@ -357,16 +572,41 @@ watch(score, () => {
</div>
<div class="col-2 text-top0 items-center">
<q-input dense outlined v-model="score[7].score" label="คะแนนข้อ 8" type="number" />
<q-input
dense
outlined
v-model="score[7].score"
label="คะแนนข้อ 8"
type="number"
lazy-rules
:rules="[(val) => val !== '' || 'กรุณากรอกคะเเนน']"
/>
</div>
<q-option-group :options="suggestFriends_option" type="radio" v-model="suggestFriends" disable />
<q-option-group
:options="suggestFriends_option"
type="radio"
v-model="suggestFriends"
disable
/>
<div class="col-12 text-top0 items-center">
<q-item-label>
<q-input v-if="suggestFriends === false" v-model="suggestFriendsReason" label="กรอกข้อความ" dense
lazy-rules disable type="text" autogrow hide-bottom-space outlined class="bg-white" :rules="[
<q-input
v-if="suggestFriends === false"
v-model="suggestFriendsReason"
label="กรอกข้อความ"
dense
lazy-rules
disable
type="text"
autogrow
hide-bottom-space
outlined
class="bg-white"
:rules="[
(val) => (val && val.length > 0) || 'กรุณากรอกข้อความ',
]" />
]"
/>
</q-item-label>
</div>
<div class="col-10 text-top0 items-center">
@ -375,16 +615,41 @@ watch(score, () => {
โปรดระบเหตผล)
</div>
<div class="col-2 text-top0 items-center">
<q-input dense outlined v-model="score[8].score" label="คะแนนข้อ 9" type="number" />
<q-input
dense
outlined
v-model="score[8].score"
label="คะแนนข้อ 9"
type="number"
lazy-rules
:rules="[(val) => val !== '' || 'กรุณากรอกคะเเนน']"
/>
</div>
<q-option-group :options="futureWork_option" type="radio" v-model="futureWork" disable />
<q-option-group
:options="futureWork_option"
type="radio"
v-model="futureWork"
disable
/>
<div class="col-12 text-top0 items-center">
<q-item-label>
<q-input v-if="futureWork === false" v-model="futureWorkReason" label="กรอกข้อความ" dense lazy-rules
type="text" autogrow hide-bottom-space outlined disable class="bg-white" :rules="[
<q-input
v-if="futureWork === false"
v-model="futureWorkReason"
label="กรอกข้อความ"
dense
lazy-rules
type="text"
autogrow
hide-bottom-space
outlined
disable
class="bg-white"
:rules="[
(val) => (val && val.length > 0) || 'กรุณากรอกข้อความ',
]" />
]"
/>
</q-item-label>
</div>
@ -392,26 +657,57 @@ watch(score, () => {
10. ความคดเหนและขอเสนอแนะอ
</div>
<div class="col-2 text-top0 items-center">
<q-input dense outlined v-model="score[9].score" label="คะแนนข้อ 10" type="number" />
<q-input
dense
outlined
v-model="score[9].score"
label="คะแนนข้อ 10"
type="number"
lazy-rules
:rules="[(val) => val !== '' || 'กรุณากรอกคะเเนน']"
/>
</div>
<q-input class="col-12" dense disable outlined v-model="suggestion" label=" " type="textarea" />
<q-input
class="col-12"
dense
disable
outlined
v-model="suggestion"
label=" "
type="textarea"
/>
</div>
</q-card>
<q-card bordered flat class="q-mt-md">
<div class="q-pa-xs bg-grey-2 row items-center q-py-sm q-px-md justify-center text-bold">
<div
class="q-pa-xs bg-grey-2 row items-center q-py-sm q-px-md justify-center text-bold"
>
ความคดเห
</div>
<q-separator />
<div class="col-12 row q-pa-sm q-col-gutter-sm">
<div class="row col-12 q-pa-sm q-col-gutter-sm">
<div class="col-10">
<q-input dense outlined v-model="comment" label="กรอกความคิดเห็น" type="textarea" />
<q-input
dense
lazy-rules
outlined
v-model="comment"
label="กรอกความคิดเห็น"
type="textarea"
:rules="[(val) => !!val || 'กรุณากรอกความคิดเห็น']"
/>
</div>
<div class="col-2 text-top0">
<q-input dense outlined v-model="scoreTotal" label="คะแนนรวม" />
<q-input
dense
outlined
readonly
v-model="scoreTotal"
label="คะแนนรวม"
type="number"
/>
</div>
</div>
@ -419,10 +715,14 @@ watch(score, () => {
<q-card-actions class="col-12 text-primary q-pa-md">
<q-space />
<q-btn unelevated label="บันทึก" color="public" @click="">
<q-btn
unelevated
label="บันทึก"
color="public"
@click="saveClick"
>
</q-btn>
</q-card-actions>
</div>
</q-card>
</div>