445 lines
15 KiB
Vue
445 lines
15 KiB
Vue
<!-- card ข้อมูลครอบครัว -->
|
|
<template>
|
|
<q-card flat bordered class="col-12 q-px-lg q-py-md q-mt-md text-dark">
|
|
<HeaderTop
|
|
v-model:edit="edit"
|
|
header="ข้อมูลครอบครัว"
|
|
icon="mdi-account-group"
|
|
:save="saveData"
|
|
:addData="true"
|
|
:editOnly="false"
|
|
:cancel="cancelData"
|
|
:changeBtn="changeBtn"
|
|
:editData="status == 'register' || status == 'rejectRegister'"
|
|
:disable="statusEdit"
|
|
/>
|
|
<q-form ref="myform" class="col-12">
|
|
<div class="row col-12 items-center q-col-gutter-x-xs q-col-gutter-y-xs">
|
|
<div class="col-xs-12 q-gutter-sm items-center flex q-my-sm">
|
|
<label class="text-weight-bold">• คู่สมรส</label>
|
|
<q-radio
|
|
v-model="familyData.same"
|
|
checked-icon="task_alt"
|
|
unchecked-icon="panorama_fish_eye"
|
|
val="1"
|
|
label="มี"
|
|
dense
|
|
:disable="!edit"
|
|
@update:model-value="selectRadio"
|
|
/>
|
|
<q-radio
|
|
v-model="familyData.same"
|
|
checked-icon="task_alt"
|
|
unchecked-icon="panorama_fish_eye"
|
|
val="0"
|
|
label="ไม่มี"
|
|
dense
|
|
:disable="!edit"
|
|
@update:model-value="selectRadio"
|
|
/>
|
|
</div>
|
|
<div class="col-xs-12 col-sm-2 col-md-2" v-if="familyData.same == '1'">
|
|
<q-select
|
|
hide-bottom-space
|
|
:class="getClass(edit)"
|
|
:readonly="!edit"
|
|
:borderless="!edit"
|
|
:rules="[(val) => !!val || `${'กรุณาเลือก คำนำหน้า'}`]"
|
|
:outlined="edit"
|
|
dense
|
|
lazy-rules
|
|
v-model="familyData.prefixIdC"
|
|
emit-value
|
|
map-options
|
|
option-label="name"
|
|
:options="prefixOptions"
|
|
option-value="id"
|
|
:label="`${'คำนำหน้า'}`"
|
|
/>
|
|
</div>
|
|
|
|
<div class="col-xs-6 col-sm-3 col-md-3" v-if="familyData.same == '1'">
|
|
<q-input
|
|
:class="getClass(edit)"
|
|
hide-bottom-space
|
|
:outlined="edit"
|
|
dense
|
|
lazy-rules
|
|
:readonly="!edit"
|
|
:borderless="!edit"
|
|
v-model="familyData.firstnameC"
|
|
:rules="[(val) => !!val || `${'กรุณากรอก ชื่อ'}`]"
|
|
:label="`${'ชื่อ'}`"
|
|
/>
|
|
</div>
|
|
<div class="col-xs-6 col-sm-3 col-md-3" v-if="familyData.same == '1'">
|
|
<q-input
|
|
:class="getClass(edit)"
|
|
hide-bottom-space
|
|
:outlined="edit"
|
|
dense
|
|
lazy-rules
|
|
:readonly="!edit"
|
|
:borderless="!edit"
|
|
v-model="familyData.lastnameC"
|
|
:rules="[(val) => !!val || `${'กรุณากรอก นามสกุล'}`]"
|
|
:label="`${'นามสกุล'}`"
|
|
/>
|
|
</div>
|
|
<div class="col-xs-12 col-sm-2 col-md-2" v-if="familyData.same == '1'">
|
|
<q-input
|
|
:class="getClass(edit)"
|
|
hide-bottom-space
|
|
:outlined="edit"
|
|
dense
|
|
lazy-rules
|
|
:readonly="!edit"
|
|
:borderless="!edit"
|
|
v-model="familyData.occupationC"
|
|
:rules="[(val) => !!val || `${'กรุณากรอก อาชีพ'}`]"
|
|
:label="`${'อาชีพ'}`"
|
|
/>
|
|
</div>
|
|
<div class="col-xs-12 col-sm-2 col-md-2" v-if="familyData.same == '1'">
|
|
<q-input
|
|
:class="getClass(edit)"
|
|
hide-bottom-space
|
|
:outlined="edit"
|
|
dense
|
|
lazy-rules
|
|
:readonly="!edit"
|
|
:borderless="!edit"
|
|
v-model="familyData.nationalityC"
|
|
:rules="[(val) => !!val || `${'กรุณากรอก สัญชาติ'}`]"
|
|
:label="`${'สัญชาติ'}`"
|
|
/>
|
|
</div>
|
|
|
|
<div class="col-xs-12 text-weight-bold">• บิดา</div>
|
|
<div class="col-xs-12 col-sm-2 col-md-2">
|
|
<q-select
|
|
hide-bottom-space
|
|
:class="getClass(edit)"
|
|
:readonly="!edit"
|
|
:borderless="!edit"
|
|
:rules="[(val) => !!val || `${'กรุณาเลือก คำนำหน้า'}`]"
|
|
:outlined="edit"
|
|
dense
|
|
lazy-rules
|
|
v-model="familyData.prefixIdM"
|
|
emit-value
|
|
map-options
|
|
option-label="name"
|
|
:options="prefixOptions"
|
|
option-value="id"
|
|
:label="`${'คำนำหน้า'}`"
|
|
/>
|
|
</div>
|
|
|
|
<div class="col-xs-6 col-sm-3 col-md-3">
|
|
<q-input
|
|
:class="getClass(edit)"
|
|
hide-bottom-space
|
|
:outlined="edit"
|
|
dense
|
|
lazy-rules
|
|
:readonly="!edit"
|
|
:borderless="!edit"
|
|
v-model="familyData.firstnameM"
|
|
:rules="[(val) => !!val || `${'กรุณากรอก ชื่อ'}`]"
|
|
:label="`${'ชื่อ'}`"
|
|
/>
|
|
</div>
|
|
<div class="col-xs-6 col-sm-3 col-md-3">
|
|
<q-input
|
|
:class="getClass(edit)"
|
|
hide-bottom-space
|
|
:outlined="edit"
|
|
dense
|
|
lazy-rules
|
|
:readonly="!edit"
|
|
:borderless="!edit"
|
|
v-model="familyData.lastnameM"
|
|
:rules="[(val) => !!val || `${'กรุณากรอก นามสกุล'}`]"
|
|
:label="`${'นามสกุล'}`"
|
|
/>
|
|
</div>
|
|
<div class="col-xs-12 col-sm-2 col-md-2">
|
|
<q-input
|
|
:class="getClass(edit)"
|
|
hide-bottom-space
|
|
:outlined="edit"
|
|
dense
|
|
lazy-rules
|
|
:readonly="!edit"
|
|
:borderless="!edit"
|
|
v-model="familyData.occupationM"
|
|
:rules="[(val) => !!val || `${'กรุณากรอก อาชีพ'}`]"
|
|
:label="`${'อาชีพ'}`"
|
|
/>
|
|
</div>
|
|
<div class="col-xs-12 col-sm-2 col-md-2">
|
|
<q-input
|
|
:class="getClass(edit)"
|
|
hide-bottom-space
|
|
:outlined="edit"
|
|
dense
|
|
lazy-rules
|
|
:readonly="!edit"
|
|
:borderless="!edit"
|
|
v-model="familyData.nationalityM"
|
|
:rules="[(val) => !!val || `${'กรุณากรอก สัญชาติ'}`]"
|
|
:label="`${'สัญชาติ'}`"
|
|
/>
|
|
</div>
|
|
|
|
<div class="col-xs-12 text-weight-bold">• มารดา</div>
|
|
<div class="col-xs-12 col-sm-2 col-md-2">
|
|
<q-select
|
|
hide-bottom-space
|
|
:class="getClass(edit)"
|
|
:readonly="!edit"
|
|
:borderless="!edit"
|
|
:rules="[(val) => !!val || `${'กรุณาเลือก คำนำหน้า'}`]"
|
|
:outlined="edit"
|
|
dense
|
|
lazy-rules
|
|
v-model="familyData.prefixIdF"
|
|
emit-value
|
|
map-options
|
|
option-label="name"
|
|
:options="prefixOptions"
|
|
option-value="id"
|
|
:label="`${'คำนำหน้า'}`"
|
|
/>
|
|
</div>
|
|
<div class="col-xs-6 col-sm-3 col-md-3">
|
|
<q-input
|
|
:class="getClass(edit)"
|
|
hide-bottom-space
|
|
:outlined="edit"
|
|
dense
|
|
lazy-rules
|
|
:readonly="!edit"
|
|
:borderless="!edit"
|
|
v-model="familyData.firstnameF"
|
|
:rules="[(val) => !!val || `${'กรุณากรอก ชื่อ'}`]"
|
|
:label="`${'ชื่อ'}`"
|
|
/>
|
|
</div>
|
|
<div class="col-xs-6 col-sm-3 col-md-3">
|
|
<q-input
|
|
:class="getClass(edit)"
|
|
hide-bottom-space
|
|
:outlined="edit"
|
|
dense
|
|
lazy-rules
|
|
:readonly="!edit"
|
|
:borderless="!edit"
|
|
v-model="familyData.lastnameF"
|
|
:rules="[(val) => !!val || `${'กรุณากรอก นามสกุล'}`]"
|
|
:label="`${'นามสกุล'}`"
|
|
/>
|
|
</div>
|
|
<div class="col-xs-12 col-sm-2 col-md-2">
|
|
<q-input
|
|
:class="getClass(edit)"
|
|
hide-bottom-space
|
|
:outlined="edit"
|
|
dense
|
|
lazy-rules
|
|
:readonly="!edit"
|
|
:borderless="!edit"
|
|
v-model="familyData.occupationF"
|
|
:rules="[(val) => !!val || `${'กรุณากรอก อาชีพ'}`]"
|
|
:label="`${'อาชีพ'}`"
|
|
/>
|
|
</div>
|
|
<div class="col-xs-12 col-sm-2 col-md-2">
|
|
<q-input
|
|
:class="getClass(edit)"
|
|
hide-bottom-space
|
|
:outlined="edit"
|
|
dense
|
|
lazy-rules
|
|
:readonly="!edit"
|
|
:borderless="!edit"
|
|
v-model="familyData.nationalityF"
|
|
:rules="[(val) => !!val || `${'กรุณากรอก สัญชาติ'}`]"
|
|
:label="`${'สัญชาติ'}`"
|
|
/>
|
|
</div>
|
|
</div>
|
|
</q-form>
|
|
</q-card>
|
|
<q-dialog :model-value="modalConsend" persistent>
|
|
<q-card style="min-width: 800px">
|
|
<Conference :ok="consendOk" :close="consenClose" />
|
|
</q-card>
|
|
</q-dialog>
|
|
</template>
|
|
<script setup lang="ts">
|
|
import { onMounted, ref, watch } from 'vue'
|
|
import { useQuasar } from 'quasar'
|
|
import { useCounterMixin } from '@/stores/mixin'
|
|
import type { PropType } from 'vue'
|
|
import http from '@/plugins/http'
|
|
import config from '@/app.config'
|
|
import { useExamDataStore } from '@/modules/01_exam/store'
|
|
import type { Family, DataOption } from '@/modules/01_exam/interface/index/Main'
|
|
import { defaultFamily } from '@/modules/01_exam/interface/index/Main'
|
|
import HeaderTop from '@/components/top.vue'
|
|
import Conference from '@/modules/01_exam/components/Conference.vue'
|
|
|
|
const props = defineProps({
|
|
prefixOptions: {
|
|
type: Array as PropType<DataOption[]>,
|
|
required: true
|
|
},
|
|
statusEdit: {
|
|
type: Boolean,
|
|
required: true
|
|
},
|
|
notiNoEdit: {
|
|
type: Function,
|
|
default: () => console.log('not function')
|
|
},
|
|
status: {
|
|
type: String,
|
|
required: true
|
|
}
|
|
})
|
|
|
|
const $q = useQuasar()
|
|
const mixin = useCounterMixin()
|
|
const store = useExamDataStore()
|
|
const { success } = mixin
|
|
const edit = ref<boolean>(false)
|
|
const myform = ref<any>()
|
|
const familyData = ref<Family>(defaultFamily)
|
|
const modalConsend = ref<boolean>(false)
|
|
const candidateId = ref<string>('2223ba53-2fb2-470b-8dc1-27e5471b0331')
|
|
const loader = ref<boolean>(false)
|
|
|
|
const emit = defineEmits(['update:statusEdit'])
|
|
|
|
onMounted(async () => {
|
|
await fetchData()
|
|
})
|
|
|
|
const fetchData = async () => {
|
|
loader.value = true
|
|
await http
|
|
.get(config.API.candidateFamily(candidateId.value))
|
|
.then((res) => {
|
|
const data = res.data.result
|
|
familyData.value.prefixIdC = data.marryPrefixId
|
|
familyData.value.firstnameC = data.marryFirstName
|
|
familyData.value.lastnameC = data.marryLastName
|
|
familyData.value.occupationC = data.marryOccupation
|
|
familyData.value.nationalityC = data.marryNationality
|
|
familyData.value.prefixIdM = data.fatherPrefixId
|
|
familyData.value.firstnameM = data.fatherFirstName
|
|
familyData.value.lastnameM = data.fatherLastName
|
|
familyData.value.occupationM = data.fatherOccupation
|
|
familyData.value.nationalityM = data.fatherNationality
|
|
familyData.value.prefixIdF = data.motherPrefixId
|
|
familyData.value.firstnameF = data.motherFirstName
|
|
familyData.value.lastnameF = data.motherLastName
|
|
familyData.value.occupationF = data.motherOccupation
|
|
familyData.value.nationalityF = data.motherNationality
|
|
familyData.value.same = data.marry == true ? '1' : data.marry == false ? '0' : null
|
|
})
|
|
.catch(() => {})
|
|
.finally(() => {
|
|
loader.value = false
|
|
})
|
|
}
|
|
|
|
const saveData = async () => {
|
|
await myform.value.validate().then(async (suc: boolean) => {
|
|
if (suc) {
|
|
if (store.consend == true) {
|
|
loader.value = true
|
|
await http
|
|
.post(config.API.candidateFamily(candidateId.value), {
|
|
marryPrefixId: familyData.value.prefixIdC,
|
|
marryFirstName: familyData.value.firstnameC,
|
|
marryLastName: familyData.value.lastnameC,
|
|
marryOccupation: familyData.value.occupationC,
|
|
marryNationality: familyData.value.nationalityC,
|
|
fatherPrefixId: familyData.value.prefixIdM,
|
|
fatherFirstName: familyData.value.firstnameM,
|
|
fatherLastName: familyData.value.lastnameM,
|
|
fatherOccupation: familyData.value.occupationM,
|
|
fatherNationality: familyData.value.nationalityM,
|
|
motherPrefixId: familyData.value.prefixIdF,
|
|
motherFirstName: familyData.value.firstnameF,
|
|
motherLastName: familyData.value.lastnameF,
|
|
motherOccupation: familyData.value.occupationF,
|
|
motherNationality: familyData.value.nationalityF,
|
|
marry: familyData.value.same == '1' ? true : familyData.value.same == '0' ? false : null
|
|
})
|
|
.then(() => {
|
|
success($q, 'บันทึกข้อมูลครอบครัวสำเร็จ')
|
|
edit.value = false
|
|
emit('update:statusEdit', false)
|
|
})
|
|
.catch(() => {
|
|
// modalError.value = true
|
|
// modalErrorTittle.value = 'ไม่สามารถบันทึกข้อมูลร่างได้'
|
|
// modalErrorDetail.value = e.response.data.message
|
|
// statusCode.value = e.response.data.status
|
|
})
|
|
.finally(async () => {
|
|
loader.value = false
|
|
await fetchData()
|
|
})
|
|
} else {
|
|
modalConsend.value = true
|
|
}
|
|
}
|
|
})
|
|
}
|
|
|
|
const changeBtn = async () => {
|
|
if (edit.value == true) {
|
|
if (props.statusEdit === true) {
|
|
edit.value = false
|
|
props.notiNoEdit()
|
|
} else {
|
|
emit('update:statusEdit', true)
|
|
}
|
|
} else {
|
|
emit('update:statusEdit', false)
|
|
}
|
|
}
|
|
|
|
const selectRadio = (e: boolean) => {
|
|
if (!e) {
|
|
familyData.value.prefixIdC = ''
|
|
familyData.value.firstnameC = ''
|
|
familyData.value.lastnameC = ''
|
|
familyData.value.occupationC = ''
|
|
}
|
|
}
|
|
|
|
const consenClose = () => {
|
|
modalConsend.value = false
|
|
}
|
|
|
|
const consendOk = async () => {
|
|
modalConsend.value = false
|
|
store.consend = true
|
|
saveData()
|
|
}
|
|
|
|
const cancelData = () => {}
|
|
|
|
const getClass = (val: boolean) => {
|
|
return {
|
|
'full-width inputgreen cursor-pointer': val,
|
|
'full-width cursor-pointer': !val
|
|
}
|
|
}
|
|
</script>
|