feat: can + employee checkup and work history (include i18n)
This commit is contained in:
parent
7bbdc810a8
commit
16fcec3a54
6 changed files with 689 additions and 478 deletions
|
|
@ -1,11 +1,12 @@
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { onMounted, reactive } from 'vue';
|
import { onMounted, reactive, ref } from 'vue';
|
||||||
import { dateFormat } from 'src/utils/datetime';
|
import { dateFormat } from 'src/utils/datetime';
|
||||||
import useAddressStore, {
|
import useAddressStore, {
|
||||||
District,
|
District,
|
||||||
Province,
|
Province,
|
||||||
SubDistrict,
|
SubDistrict,
|
||||||
} from 'src/stores/address';
|
} from 'src/stores/address';
|
||||||
|
import { EmployeeCheckupCreate } from 'src/stores/employee/types';
|
||||||
|
|
||||||
const adrressStore = useAddressStore();
|
const adrressStore = useAddressStore();
|
||||||
|
|
||||||
|
|
@ -19,15 +20,9 @@ const addrOptions = reactive<{
|
||||||
subDistrictOps: [],
|
subDistrictOps: [],
|
||||||
});
|
});
|
||||||
|
|
||||||
const checkupResult = defineModel<string>('checkupResult');
|
const employeeCheckup = defineModel<EmployeeCheckupCreate[]>('employeeCheckup');
|
||||||
const checkupType = defineModel<string>('checkupType');
|
|
||||||
const provinceId = defineModel<string>('provinceId');
|
const tab = ref();
|
||||||
const hospitalName = defineModel<string>('hospitalName');
|
|
||||||
const remark = defineModel<string>('remark');
|
|
||||||
const medicalBenefitScheme = defineModel<string>('medicalBenefitScheme');
|
|
||||||
const insuranceCompany = defineModel<string>('insuranceCompany');
|
|
||||||
const coverageStartDate = defineModel<Date | null>('coverageStartDate');
|
|
||||||
const coverageExpireDate = defineModel<Date | null>('coverageExpireDate');
|
|
||||||
|
|
||||||
defineProps<{
|
defineProps<{
|
||||||
title?: string;
|
title?: string;
|
||||||
|
|
@ -44,214 +39,313 @@ async function fetchProvince() {
|
||||||
if (result) addrOptions.provinceOps = result;
|
if (result) addrOptions.provinceOps = result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function addData() {
|
||||||
|
employeeCheckup.value?.push({
|
||||||
|
coverageExpireDate: null,
|
||||||
|
coverageStartDate: null,
|
||||||
|
insuranceCompany: '',
|
||||||
|
medicalBenefitScheme: '',
|
||||||
|
remark: '',
|
||||||
|
hospitalName: '',
|
||||||
|
provinceId: '',
|
||||||
|
checkupResult: '',
|
||||||
|
checkupType: '',
|
||||||
|
});
|
||||||
|
if (employeeCheckup.value)
|
||||||
|
tab.value = `tab${employeeCheckup.value.length - 1}`;
|
||||||
|
}
|
||||||
|
|
||||||
|
function removeData(index: number) {
|
||||||
|
if (!employeeCheckup.value) return;
|
||||||
|
if (employeeCheckup.value.length === 1) return;
|
||||||
|
|
||||||
|
employeeCheckup.value.splice(index, 1);
|
||||||
|
|
||||||
|
if (index) if (tab.value === `tab${index}`) tab.value = `tab${index - 1}`;
|
||||||
|
if (tab.value === `tab${employeeCheckup.value.length}`)
|
||||||
|
tab.value = `tab${employeeCheckup.value.length - 1}`;
|
||||||
|
}
|
||||||
|
|
||||||
onMounted(async () => {
|
onMounted(async () => {
|
||||||
await fetchProvince();
|
await fetchProvince();
|
||||||
|
tab.value = 'tab0';
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<div class="col-3 app-text-muted">
|
<div class="bordered-b full-width">
|
||||||
• {{ $t(`formDialogTitleHealthCheck`) }}
|
<q-tabs
|
||||||
</div>
|
v-model="tab"
|
||||||
<div class="col-9 row q-col-gutter-md">
|
dense
|
||||||
<q-input
|
class="text-grey"
|
||||||
:dense="dense"
|
active-class="active-tab"
|
||||||
:outlined="!readonly"
|
indicator-color="transparent"
|
||||||
:readonly="readonly"
|
align="left"
|
||||||
:borderless="readonly"
|
:breakpoint="0"
|
||||||
hide-bottom-space
|
|
||||||
class="col-6"
|
|
||||||
:label="$t('formDialogInputCheckupRes')"
|
|
||||||
v-model="checkupResult"
|
|
||||||
/>
|
|
||||||
<q-select
|
|
||||||
id="select-province"
|
|
||||||
:dense="dense"
|
|
||||||
:readonly="readonly"
|
|
||||||
:outlined="readonly ? false : outlined"
|
|
||||||
:hide-dropdown-icon="readonly"
|
|
||||||
:borderless="readonly"
|
|
||||||
hide-bottom-space
|
|
||||||
emit-value
|
|
||||||
map-options
|
|
||||||
v-model="checkupType"
|
|
||||||
option-value="id"
|
|
||||||
option-label="name"
|
|
||||||
:label="$t('formDialogInputCheckupType')"
|
|
||||||
class="col-6"
|
|
||||||
:options="addrOptions.provinceOps"
|
|
||||||
lazy-rules
|
|
||||||
/>
|
|
||||||
<q-select
|
|
||||||
id="select-province"
|
|
||||||
:dense="dense"
|
|
||||||
:readonly="readonly"
|
|
||||||
:outlined="readonly ? false : outlined"
|
|
||||||
:hide-dropdown-icon="readonly"
|
|
||||||
:borderless="readonly"
|
|
||||||
hide-bottom-space
|
|
||||||
emit-value
|
|
||||||
map-options
|
|
||||||
v-model="provinceId"
|
|
||||||
option-value="id"
|
|
||||||
option-label="nameEN"
|
|
||||||
:label="$t('province')"
|
|
||||||
class="col-3"
|
|
||||||
:options="addrOptions.provinceOps"
|
|
||||||
lazy-rules
|
|
||||||
/>
|
|
||||||
<q-input
|
|
||||||
:dense="dense"
|
|
||||||
:outlined="!readonly"
|
|
||||||
:readonly="readonly"
|
|
||||||
:borderless="readonly"
|
|
||||||
hide-bottom-space
|
|
||||||
class="col-9"
|
|
||||||
:label="$t('formDialogInputHospital')"
|
|
||||||
v-model="hospitalName"
|
|
||||||
/>
|
|
||||||
<q-input
|
|
||||||
:label="$t('formDialogInputRemark')"
|
|
||||||
:dense="dense"
|
|
||||||
:outlined="!readonly"
|
|
||||||
:readonly="readonly"
|
|
||||||
:borderless="readonly"
|
|
||||||
hide-bottom-space
|
|
||||||
class="col-12"
|
|
||||||
v-model="remark"
|
|
||||||
type="textarea"
|
|
||||||
/>
|
|
||||||
<q-select
|
|
||||||
id="select-province"
|
|
||||||
:dense="dense"
|
|
||||||
:readonly="readonly"
|
|
||||||
:outlined="readonly ? false : outlined"
|
|
||||||
:hide-dropdown-icon="readonly"
|
|
||||||
:borderless="readonly"
|
|
||||||
hide-bottom-space
|
|
||||||
emit-value
|
|
||||||
map-options
|
|
||||||
v-model="medicalBenefitScheme"
|
|
||||||
option-value="id"
|
|
||||||
option-label="name"
|
|
||||||
:label="$t('formDialogInputMedicalBenefit')"
|
|
||||||
class="col-6"
|
|
||||||
:options="addrOptions.provinceOps"
|
|
||||||
lazy-rules
|
|
||||||
/>
|
|
||||||
<q-select
|
|
||||||
id="select-province"
|
|
||||||
:dense="dense"
|
|
||||||
:readonly="readonly"
|
|
||||||
:outlined="readonly ? false : outlined"
|
|
||||||
:hide-dropdown-icon="readonly"
|
|
||||||
:borderless="readonly"
|
|
||||||
hide-bottom-space
|
|
||||||
emit-value
|
|
||||||
map-options
|
|
||||||
v-model="insuranceCompany"
|
|
||||||
option-value="id"
|
|
||||||
option-label="name"
|
|
||||||
:label="$t('formDialogInputInsuranceCompany')"
|
|
||||||
class="col-6"
|
|
||||||
:options="addrOptions.provinceOps"
|
|
||||||
lazy-rules
|
|
||||||
/>
|
|
||||||
<VueDatePicker
|
|
||||||
utc
|
|
||||||
autoApply
|
|
||||||
:teleport="true"
|
|
||||||
v-model="coverageStartDate"
|
|
||||||
:locale="'th'"
|
|
||||||
:enableTimePicker="false"
|
|
||||||
:disabled="readonly"
|
|
||||||
class="col-3"
|
|
||||||
>
|
>
|
||||||
<template #year="{ value }">
|
<q-btn
|
||||||
{{ value + 543 }}
|
@click="addData"
|
||||||
</template>
|
flat
|
||||||
<template #trigger>
|
class="app-text-muted"
|
||||||
<q-input
|
style="background-color: var(--_body-bg)"
|
||||||
id="input-birth-date"
|
icon="mdi-plus"
|
||||||
:label="$t('formDialogInputCoverageStartDate')"
|
padding="8px 8px"
|
||||||
:dense="dense"
|
:disable="readonly"
|
||||||
:outlined="readonly ? false : outlined"
|
:color="$q.dark.isActive ? 'primary' : ''"
|
||||||
:readonly="readonly"
|
:class="tab !== 'tab0' ? 'bordered-r' : ''"
|
||||||
:borderless="readonly"
|
/>
|
||||||
:model-value="coverageStartDate ? dateFormat(coverageStartDate) : ''"
|
<q-tab
|
||||||
>
|
v-for="(tab, index) in employeeCheckup"
|
||||||
<template v-slot:prepend>
|
v-bind:key="index"
|
||||||
<q-icon
|
:name="`tab${index}`"
|
||||||
size="xs"
|
class="content-tab text-capitalize"
|
||||||
name="mdi-calendar-blank-outline"
|
style="z-index: 999"
|
||||||
class="cursor-pointer"
|
>
|
||||||
color="positive"
|
<div class="text-weight-medium row items-center">
|
||||||
/>
|
{{ $t('formDialogTabCheckup') + (index + 1) }}
|
||||||
</template>
|
<q-btn
|
||||||
<template v-slot:append>
|
v-if="!readonly && employeeCheckup?.length !== 1"
|
||||||
<q-icon
|
round
|
||||||
v-if="coverageStartDate && !readonly"
|
flat
|
||||||
name="mdi-close"
|
id="closeDialog"
|
||||||
class="cursor-pointer"
|
size="sm"
|
||||||
size="xs"
|
icon="mdi-close"
|
||||||
@click="coverageStartDate = undefined"
|
padding="xs"
|
||||||
/>
|
color="red"
|
||||||
</template>
|
:class="{ dark: $q.dark.isActive }"
|
||||||
</q-input>
|
@click.stop="removeData(index)"
|
||||||
</template>
|
/>
|
||||||
</VueDatePicker>
|
</div>
|
||||||
<VueDatePicker
|
</q-tab>
|
||||||
utc
|
</q-tabs>
|
||||||
autoApply
|
|
||||||
:teleport="true"
|
|
||||||
v-model="coverageExpireDate"
|
|
||||||
:locale="'th'"
|
|
||||||
:enableTimePicker="false"
|
|
||||||
:disabled="readonly"
|
|
||||||
class="col-3"
|
|
||||||
>
|
|
||||||
<template #year="{ value }">
|
|
||||||
{{ value + 543 }}
|
|
||||||
</template>
|
|
||||||
<template #trigger>
|
|
||||||
<q-input
|
|
||||||
id="input-birth-date"
|
|
||||||
:label="$t('formDialogInputCoverageExpiretDate')"
|
|
||||||
:dense="dense"
|
|
||||||
:outlined="readonly ? false : outlined"
|
|
||||||
:readonly="readonly"
|
|
||||||
:borderless="readonly"
|
|
||||||
:model-value="
|
|
||||||
coverageExpireDate ? dateFormat(coverageExpireDate) : ''
|
|
||||||
"
|
|
||||||
>
|
|
||||||
<template v-slot:prepend>
|
|
||||||
<q-icon
|
|
||||||
size="xs"
|
|
||||||
name="mdi-calendar-blank-outline"
|
|
||||||
class="cursor-pointer"
|
|
||||||
color="positive"
|
|
||||||
/>
|
|
||||||
</template>
|
|
||||||
<template v-slot:append>
|
|
||||||
<q-icon
|
|
||||||
v-if="coverageExpireDate && !readonly"
|
|
||||||
name="mdi-close"
|
|
||||||
class="cursor-pointer"
|
|
||||||
size="xs"
|
|
||||||
@click="coverageExpireDate = undefined"
|
|
||||||
/>
|
|
||||||
</template>
|
|
||||||
</q-input>
|
|
||||||
</template>
|
|
||||||
</VueDatePicker>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<q-separator
|
<q-tab-panels v-model="tab" style="padding-top: 0px">
|
||||||
v-if="separator"
|
<q-tab-panel
|
||||||
class="col-12 q-mt-xl q-mb-md"
|
v-for="(checkup, index) in employeeCheckup"
|
||||||
style="padding-block: 0.5px"
|
v-bind:key="index"
|
||||||
/>
|
:name="`tab${index}`"
|
||||||
|
class="row col-12 items-start"
|
||||||
|
style="overflow: auto; height: 50vh"
|
||||||
|
>
|
||||||
|
<div class="col-3 app-text-muted">
|
||||||
|
• {{ $t(`formDialogTitleHealthCheck`) }}
|
||||||
|
</div>
|
||||||
|
<div class="col-9 row q-col-gutter-md">
|
||||||
|
<q-input
|
||||||
|
:dense="dense"
|
||||||
|
:outlined="!readonly"
|
||||||
|
:readonly="readonly"
|
||||||
|
:borderless="readonly"
|
||||||
|
hide-bottom-space
|
||||||
|
class="col-6"
|
||||||
|
:label="$t('formDialogInputCheckupRes')"
|
||||||
|
v-model="checkup.checkupResult"
|
||||||
|
/>
|
||||||
|
<q-select
|
||||||
|
id="select-province"
|
||||||
|
:dense="dense"
|
||||||
|
:readonly="readonly"
|
||||||
|
:outlined="readonly ? false : outlined"
|
||||||
|
:hide-dropdown-icon="readonly"
|
||||||
|
:borderless="readonly"
|
||||||
|
hide-bottom-space
|
||||||
|
emit-value
|
||||||
|
map-options
|
||||||
|
v-model="checkup.checkupType"
|
||||||
|
option-value="id"
|
||||||
|
option-label="name"
|
||||||
|
:label="$t('formDialogInputCheckupType')"
|
||||||
|
class="col-6"
|
||||||
|
:options="addrOptions.provinceOps"
|
||||||
|
lazy-rules
|
||||||
|
/>
|
||||||
|
<q-select
|
||||||
|
id="select-province"
|
||||||
|
:dense="dense"
|
||||||
|
:readonly="readonly"
|
||||||
|
:outlined="readonly ? false : outlined"
|
||||||
|
:hide-dropdown-icon="readonly"
|
||||||
|
:borderless="readonly"
|
||||||
|
hide-bottom-space
|
||||||
|
emit-value
|
||||||
|
map-options
|
||||||
|
v-model="checkup.provinceId"
|
||||||
|
option-value="id"
|
||||||
|
option-label="nameEN"
|
||||||
|
:label="$t('province')"
|
||||||
|
class="col-3"
|
||||||
|
:options="addrOptions.provinceOps"
|
||||||
|
lazy-rules
|
||||||
|
/>
|
||||||
|
<q-input
|
||||||
|
:dense="dense"
|
||||||
|
:outlined="!readonly"
|
||||||
|
:readonly="readonly"
|
||||||
|
:borderless="readonly"
|
||||||
|
hide-bottom-space
|
||||||
|
class="col-9"
|
||||||
|
:label="$t('formDialogInputHospital')"
|
||||||
|
v-model="checkup.hospitalName"
|
||||||
|
/>
|
||||||
|
<q-input
|
||||||
|
:label="$t('formDialogInputRemark')"
|
||||||
|
:dense="dense"
|
||||||
|
:outlined="!readonly"
|
||||||
|
:readonly="readonly"
|
||||||
|
:borderless="readonly"
|
||||||
|
hide-bottom-space
|
||||||
|
class="col-12"
|
||||||
|
v-model="checkup.remark"
|
||||||
|
type="textarea"
|
||||||
|
/>
|
||||||
|
<q-select
|
||||||
|
id="select-province"
|
||||||
|
:dense="dense"
|
||||||
|
:readonly="readonly"
|
||||||
|
:outlined="readonly ? false : outlined"
|
||||||
|
:hide-dropdown-icon="readonly"
|
||||||
|
:borderless="readonly"
|
||||||
|
hide-bottom-space
|
||||||
|
emit-value
|
||||||
|
map-options
|
||||||
|
v-model="checkup.medicalBenefitScheme"
|
||||||
|
option-value="id"
|
||||||
|
option-label="name"
|
||||||
|
:label="$t('formDialogInputMedicalBenefit')"
|
||||||
|
class="col-6"
|
||||||
|
:options="addrOptions.provinceOps"
|
||||||
|
lazy-rules
|
||||||
|
/>
|
||||||
|
<q-select
|
||||||
|
id="select-province"
|
||||||
|
:dense="dense"
|
||||||
|
:readonly="readonly"
|
||||||
|
:outlined="readonly ? false : outlined"
|
||||||
|
:hide-dropdown-icon="readonly"
|
||||||
|
:borderless="readonly"
|
||||||
|
hide-bottom-space
|
||||||
|
emit-value
|
||||||
|
map-options
|
||||||
|
v-model="checkup.insuranceCompany"
|
||||||
|
option-value="id"
|
||||||
|
option-label="name"
|
||||||
|
:label="$t('formDialogInputInsuranceCompany')"
|
||||||
|
class="col-6"
|
||||||
|
:options="addrOptions.provinceOps"
|
||||||
|
lazy-rules
|
||||||
|
/>
|
||||||
|
<VueDatePicker
|
||||||
|
utc
|
||||||
|
autoApply
|
||||||
|
:teleport="true"
|
||||||
|
v-model="checkup.coverageStartDate"
|
||||||
|
:locale="'th'"
|
||||||
|
:enableTimePicker="false"
|
||||||
|
:disabled="readonly"
|
||||||
|
class="col-3"
|
||||||
|
>
|
||||||
|
<template #year="{ value }">
|
||||||
|
{{ value + 543 }}
|
||||||
|
</template>
|
||||||
|
<template #trigger>
|
||||||
|
<q-input
|
||||||
|
id="input-birth-date"
|
||||||
|
:label="$t('formDialogInputCoverageStartDate')"
|
||||||
|
:dense="dense"
|
||||||
|
:outlined="readonly ? false : outlined"
|
||||||
|
:readonly="readonly"
|
||||||
|
:borderless="readonly"
|
||||||
|
:model-value="
|
||||||
|
checkup.coverageStartDate
|
||||||
|
? dateFormat(checkup.coverageStartDate)
|
||||||
|
: ''
|
||||||
|
"
|
||||||
|
>
|
||||||
|
<template v-slot:prepend>
|
||||||
|
<q-icon
|
||||||
|
size="xs"
|
||||||
|
name="mdi-calendar-blank-outline"
|
||||||
|
class="cursor-pointer"
|
||||||
|
color="positive"
|
||||||
|
/>
|
||||||
|
</template>
|
||||||
|
<template v-slot:append>
|
||||||
|
<q-icon
|
||||||
|
v-if="checkup.coverageStartDate && !readonly"
|
||||||
|
name="mdi-close"
|
||||||
|
class="cursor-pointer"
|
||||||
|
size="xs"
|
||||||
|
@click="checkup.coverageStartDate = undefined"
|
||||||
|
/>
|
||||||
|
</template>
|
||||||
|
</q-input>
|
||||||
|
</template>
|
||||||
|
</VueDatePicker>
|
||||||
|
<VueDatePicker
|
||||||
|
utc
|
||||||
|
autoApply
|
||||||
|
:teleport="true"
|
||||||
|
v-model="checkup.coverageExpireDate"
|
||||||
|
:locale="'th'"
|
||||||
|
:enableTimePicker="false"
|
||||||
|
:disabled="readonly"
|
||||||
|
class="col-3"
|
||||||
|
>
|
||||||
|
<template #year="{ value }">
|
||||||
|
{{ value + 543 }}
|
||||||
|
</template>
|
||||||
|
<template #trigger>
|
||||||
|
<q-input
|
||||||
|
id="input-birth-date"
|
||||||
|
:label="$t('formDialogInputCoverageExpiretDate')"
|
||||||
|
:dense="dense"
|
||||||
|
:outlined="readonly ? false : outlined"
|
||||||
|
:readonly="readonly"
|
||||||
|
:borderless="readonly"
|
||||||
|
:model-value="
|
||||||
|
checkup.coverageExpireDate
|
||||||
|
? dateFormat(checkup.coverageExpireDate)
|
||||||
|
: ''
|
||||||
|
"
|
||||||
|
>
|
||||||
|
<template v-slot:prepend>
|
||||||
|
<q-icon
|
||||||
|
size="xs"
|
||||||
|
name="mdi-calendar-blank-outline"
|
||||||
|
class="cursor-pointer"
|
||||||
|
color="positive"
|
||||||
|
/>
|
||||||
|
</template>
|
||||||
|
<template v-slot:append>
|
||||||
|
<q-icon
|
||||||
|
v-if="checkup.coverageExpireDate && !readonly"
|
||||||
|
name="mdi-close"
|
||||||
|
class="cursor-pointer"
|
||||||
|
size="xs"
|
||||||
|
@click="checkup.coverageExpireDate = undefined"
|
||||||
|
/>
|
||||||
|
</template>
|
||||||
|
</q-input>
|
||||||
|
</template>
|
||||||
|
</VueDatePicker>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<q-separator
|
||||||
|
v-if="separator"
|
||||||
|
class="col-12 q-mt-xl q-mb-md"
|
||||||
|
style="padding-block: 0.5px"
|
||||||
|
/>
|
||||||
|
</q-tab-panel>
|
||||||
|
</q-tab-panels>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<style scoped></style>
|
<style scoped>
|
||||||
|
.active-tab {
|
||||||
|
color: var(--brand-1);
|
||||||
|
border-left: 1px solid var(--border-color);
|
||||||
|
border-right: 1px solid var(--border-color);
|
||||||
|
margin-bottom: -1.5px;
|
||||||
|
border-bottom: 3px solid var(--surface-1);
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
|
||||||
|
|
@ -1,11 +1,12 @@
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { onMounted, reactive } from 'vue';
|
import { onMounted, reactive, ref } from 'vue';
|
||||||
import { dateFormat } from 'src/utils/datetime';
|
import { dateFormat } from 'src/utils/datetime';
|
||||||
import useAddressStore, {
|
import useAddressStore, {
|
||||||
District,
|
District,
|
||||||
Province,
|
Province,
|
||||||
SubDistrict,
|
SubDistrict,
|
||||||
} from 'src/stores/address';
|
} from 'src/stores/address';
|
||||||
|
import { EmployeeWorkCreate } from 'src/stores/employee/types';
|
||||||
|
|
||||||
const adrressStore = useAddressStore();
|
const adrressStore = useAddressStore();
|
||||||
|
|
||||||
|
|
@ -19,15 +20,9 @@ const addrOptions = reactive<{
|
||||||
subDistrictOps: [],
|
subDistrictOps: [],
|
||||||
});
|
});
|
||||||
|
|
||||||
const ownerName = defineModel<string>('ownerName');
|
const employeeWork = defineModel<EmployeeWorkCreate[]>('employeeWork');
|
||||||
const positionName = defineModel<string>('positionName');
|
|
||||||
const jobType = defineModel<string>('jobType');
|
const tab = ref();
|
||||||
const workPlace = defineModel<string>('workPlace');
|
|
||||||
const remark = defineModel<string>('remark');
|
|
||||||
const workEndDate = defineModel<Date | null>('workEndDate');
|
|
||||||
const workPermitNo = defineModel<string>('workPermitNo');
|
|
||||||
const workPermitIssuDate = defineModel<Date | null>('workPermitIssuDate');
|
|
||||||
const workPermitExpireDate = defineModel<Date | null>('workPermitExpireDate');
|
|
||||||
|
|
||||||
defineProps<{
|
defineProps<{
|
||||||
title?: string;
|
title?: string;
|
||||||
|
|
@ -44,245 +39,343 @@ async function fetchProvince() {
|
||||||
if (result) addrOptions.provinceOps = result;
|
if (result) addrOptions.provinceOps = result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function addData() {
|
||||||
|
employeeWork.value?.push({
|
||||||
|
workEndDate: null,
|
||||||
|
workPermitExpireDate: null,
|
||||||
|
workPermitIssuDate: null,
|
||||||
|
workPermitNo: '',
|
||||||
|
workplace: '',
|
||||||
|
jobType: '',
|
||||||
|
positionName: '',
|
||||||
|
ownerName: '',
|
||||||
|
remark: '',
|
||||||
|
});
|
||||||
|
if (employeeWork.value) tab.value = `tab${employeeWork.value.length - 1}`;
|
||||||
|
}
|
||||||
|
|
||||||
|
function removeData(index: number) {
|
||||||
|
if (!employeeWork.value) return;
|
||||||
|
if (employeeWork.value.length === 1) return;
|
||||||
|
|
||||||
|
employeeWork.value.splice(index, 1);
|
||||||
|
|
||||||
|
if (index) if (tab.value === `tab${index}`) tab.value = `tab${index - 1}`;
|
||||||
|
if (tab.value === `tab${employeeWork.value.length}`)
|
||||||
|
tab.value = `tab${employeeWork.value.length - 1}`;
|
||||||
|
}
|
||||||
|
|
||||||
onMounted(async () => {
|
onMounted(async () => {
|
||||||
await fetchProvince();
|
await fetchProvince();
|
||||||
|
tab.value = 'tab0';
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<div class="col-3 app-text-muted">• {{ $t(`workHistory`) }}</div>
|
<div class="bordered-b full-width">
|
||||||
<div class="col-9 row q-col-gutter-md">
|
<q-tabs
|
||||||
<q-input
|
v-model="tab"
|
||||||
for="input-ownerName"
|
dense
|
||||||
:dense="dense"
|
class="text-grey"
|
||||||
:outlined="!readonly"
|
active-class="active-tab"
|
||||||
:readonly="readonly"
|
indicator-color="transparent"
|
||||||
:borderless="readonly"
|
align="left"
|
||||||
hide-bottom-space
|
:breakpoint="0"
|
||||||
class="col-6"
|
|
||||||
:label="$t('formDialogInputOwnerName')"
|
|
||||||
v-model="ownerName"
|
|
||||||
/>
|
|
||||||
<q-select
|
|
||||||
id="select-positionName"
|
|
||||||
:dense="dense"
|
|
||||||
:readonly="readonly"
|
|
||||||
:outlined="readonly ? false : outlined"
|
|
||||||
:hide-dropdown-icon="readonly"
|
|
||||||
:borderless="readonly"
|
|
||||||
hide-bottom-space
|
|
||||||
emit-value
|
|
||||||
map-options
|
|
||||||
v-model="positionName"
|
|
||||||
option-value="id"
|
|
||||||
option-label="name"
|
|
||||||
:label="$t('formDialogInputJobPosition')"
|
|
||||||
class="col-6"
|
|
||||||
:options="addrOptions.provinceOps"
|
|
||||||
lazy-rules
|
|
||||||
/>
|
|
||||||
<q-select
|
|
||||||
id="select-jobType"
|
|
||||||
:dense="dense"
|
|
||||||
:readonly="readonly"
|
|
||||||
:outlined="readonly ? false : outlined"
|
|
||||||
:hide-dropdown-icon="readonly"
|
|
||||||
:borderless="readonly"
|
|
||||||
hide-bottom-space
|
|
||||||
emit-value
|
|
||||||
map-options
|
|
||||||
v-model="jobType"
|
|
||||||
option-value="id"
|
|
||||||
option-label="nameEN"
|
|
||||||
:label="$t('formDialogInputJobType')"
|
|
||||||
class="col-6"
|
|
||||||
:options="addrOptions.provinceOps"
|
|
||||||
lazy-rules
|
|
||||||
/>
|
|
||||||
<q-select
|
|
||||||
id="select-province"
|
|
||||||
:dense="dense"
|
|
||||||
:readonly="readonly"
|
|
||||||
:outlined="readonly ? false : outlined"
|
|
||||||
:hide-dropdown-icon="readonly"
|
|
||||||
:borderless="readonly"
|
|
||||||
hide-bottom-space
|
|
||||||
emit-value
|
|
||||||
map-options
|
|
||||||
v-model="workPlace"
|
|
||||||
option-value="id"
|
|
||||||
option-label="nameEN"
|
|
||||||
:label="$t('formDialogInputWorkPlace')"
|
|
||||||
class="col-6"
|
|
||||||
:options="addrOptions.provinceOps"
|
|
||||||
lazy-rules
|
|
||||||
/>
|
|
||||||
<q-input
|
|
||||||
for="input-workEndDate"
|
|
||||||
:label="$t('formDialogInputRemark')"
|
|
||||||
:dense="dense"
|
|
||||||
:outlined="!readonly"
|
|
||||||
:readonly="readonly"
|
|
||||||
:borderless="readonly"
|
|
||||||
hide-bottom-space
|
|
||||||
class="col-12"
|
|
||||||
v-model="remark"
|
|
||||||
type="textarea"
|
|
||||||
/>
|
|
||||||
<VueDatePicker
|
|
||||||
id="date-picker-workEndDate"
|
|
||||||
utc
|
|
||||||
autoApply
|
|
||||||
:teleport="true"
|
|
||||||
v-model="workEndDate"
|
|
||||||
:locale="'th'"
|
|
||||||
:enableTimePicker="false"
|
|
||||||
:disabled="readonly"
|
|
||||||
class="col-6"
|
|
||||||
>
|
>
|
||||||
<template #year="{ value }">
|
<q-btn
|
||||||
{{ value + 543 }}
|
@click="addData"
|
||||||
</template>
|
flat
|
||||||
<template #trigger>
|
class="app-text-muted"
|
||||||
<q-input
|
style="background-color: var(--_body-bg)"
|
||||||
id="input-birth-date"
|
icon="mdi-plus"
|
||||||
:label="$t('formDialogInputWorkUntil')"
|
padding="8px 8px"
|
||||||
:dense="dense"
|
:disable="readonly"
|
||||||
:outlined="readonly ? false : outlined"
|
:color="$q.dark.isActive ? 'primary' : ''"
|
||||||
:readonly="readonly"
|
:class="tab !== 'tab0' ? 'bordered-r' : ''"
|
||||||
:borderless="readonly"
|
/>
|
||||||
:model-value="workEndDate ? dateFormat(workEndDate) : ''"
|
<q-tab
|
||||||
>
|
v-for="(tab, index) in employeeWork"
|
||||||
<template v-slot:prepend>
|
v-bind:key="index"
|
||||||
<q-icon
|
:name="`tab${index}`"
|
||||||
size="xs"
|
class="content-tab text-capitalize"
|
||||||
name="mdi-calendar-blank-outline"
|
style="z-index: 999"
|
||||||
class="cursor-pointer"
|
>
|
||||||
color="positive"
|
<div class="text-weight-medium row items-center">
|
||||||
/>
|
{{ $t('formDialogTabWork') + (index + 1) }}
|
||||||
</template>
|
<q-btn
|
||||||
<template v-slot:append>
|
v-if="!readonly && employeeWork?.length !== 1"
|
||||||
<q-icon
|
round
|
||||||
v-if="workEndDate && !readonly"
|
flat
|
||||||
name="mdi-close"
|
id="closeDialog"
|
||||||
class="cursor-pointer"
|
size="sm"
|
||||||
size="xs"
|
icon="mdi-close"
|
||||||
@click="workEndDate = undefined"
|
padding="xs"
|
||||||
/>
|
color="red"
|
||||||
</template>
|
:class="{ dark: $q.dark.isActive }"
|
||||||
</q-input>
|
@click.stop="removeData(index)"
|
||||||
</template>
|
/>
|
||||||
</VueDatePicker>
|
</div>
|
||||||
<q-input
|
</q-tab>
|
||||||
for="input-workPermitNo"
|
</q-tabs>
|
||||||
:dense="dense"
|
|
||||||
:outlined="!readonly"
|
|
||||||
:readonly="readonly"
|
|
||||||
:borderless="readonly"
|
|
||||||
hide-bottom-space
|
|
||||||
class="col-6"
|
|
||||||
:label="$t('formDialogInputWorkPermitNo')"
|
|
||||||
v-model="workPermitNo"
|
|
||||||
/>
|
|
||||||
<VueDatePicker
|
|
||||||
id="date-picker-workPermitIssuDate"
|
|
||||||
utc
|
|
||||||
autoApply
|
|
||||||
:teleport="true"
|
|
||||||
v-model="workPermitIssuDate"
|
|
||||||
:locale="'th'"
|
|
||||||
:enableTimePicker="false"
|
|
||||||
:disabled="readonly"
|
|
||||||
class="col-6"
|
|
||||||
>
|
|
||||||
<template #year="{ value }">
|
|
||||||
{{ value + 543 }}
|
|
||||||
</template>
|
|
||||||
<template #trigger>
|
|
||||||
<q-input
|
|
||||||
id="input-birth-date"
|
|
||||||
:label="$t('formDialogInputWorkPermitIssueDate')"
|
|
||||||
:dense="dense"
|
|
||||||
:outlined="readonly ? false : outlined"
|
|
||||||
:readonly="readonly"
|
|
||||||
:borderless="readonly"
|
|
||||||
:model-value="
|
|
||||||
workPermitIssuDate ? dateFormat(workPermitIssuDate) : ''
|
|
||||||
"
|
|
||||||
>
|
|
||||||
<template v-slot:prepend>
|
|
||||||
<q-icon
|
|
||||||
size="xs"
|
|
||||||
name="mdi-calendar-blank-outline"
|
|
||||||
class="cursor-pointer"
|
|
||||||
color="positive"
|
|
||||||
/>
|
|
||||||
</template>
|
|
||||||
<template v-slot:append>
|
|
||||||
<q-icon
|
|
||||||
v-if="workPermitIssuDate && !readonly"
|
|
||||||
name="mdi-close"
|
|
||||||
class="cursor-pointer"
|
|
||||||
size="xs"
|
|
||||||
@click="workPermitIssuDate = undefined"
|
|
||||||
/>
|
|
||||||
</template>
|
|
||||||
</q-input>
|
|
||||||
</template>
|
|
||||||
</VueDatePicker>
|
|
||||||
<VueDatePicker
|
|
||||||
id="date-picker-workPermitExpireDate"
|
|
||||||
utc
|
|
||||||
autoApply
|
|
||||||
:teleport="true"
|
|
||||||
v-model="workPermitExpireDate"
|
|
||||||
:locale="'th'"
|
|
||||||
:enableTimePicker="false"
|
|
||||||
:disabled="readonly"
|
|
||||||
class="col-6"
|
|
||||||
>
|
|
||||||
<template #year="{ value }">
|
|
||||||
{{ value + 543 }}
|
|
||||||
</template>
|
|
||||||
<template #trigger>
|
|
||||||
<q-input
|
|
||||||
id="input-birth-date"
|
|
||||||
:label="$t('formDialogInputWorkPermitExpireDate')"
|
|
||||||
:dense="dense"
|
|
||||||
:outlined="readonly ? false : outlined"
|
|
||||||
:readonly="readonly"
|
|
||||||
:borderless="readonly"
|
|
||||||
:model-value="
|
|
||||||
workPermitExpireDate ? dateFormat(workPermitExpireDate) : ''
|
|
||||||
"
|
|
||||||
>
|
|
||||||
<template v-slot:prepend>
|
|
||||||
<q-icon
|
|
||||||
size="xs"
|
|
||||||
name="mdi-calendar-blank-outline"
|
|
||||||
class="cursor-pointer"
|
|
||||||
color="positive"
|
|
||||||
/>
|
|
||||||
</template>
|
|
||||||
<template v-slot:append>
|
|
||||||
<q-icon
|
|
||||||
v-if="workPermitExpireDate && !readonly"
|
|
||||||
name="mdi-close"
|
|
||||||
class="cursor-pointer"
|
|
||||||
size="xs"
|
|
||||||
@click="workPermitExpireDate = undefined"
|
|
||||||
/>
|
|
||||||
</template>
|
|
||||||
</q-input>
|
|
||||||
</template>
|
|
||||||
</VueDatePicker>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<q-separator
|
<q-tab-panels v-model="tab" style="padding-top: 0px">
|
||||||
v-if="separator"
|
<q-tab-panel
|
||||||
class="col-12 q-mt-xl q-mb-md"
|
v-for="(work, index) in employeeWork"
|
||||||
style="padding-block: 0.5px"
|
v-bind:key="index"
|
||||||
/>
|
:name="`tab${index}`"
|
||||||
|
class="row col-12 items-start"
|
||||||
|
style="overflow: auto; height: 50vh"
|
||||||
|
>
|
||||||
|
<div class="col-3 app-text-muted">• {{ $t(`workHistory`) }}</div>
|
||||||
|
<div class="col-9 row q-col-gutter-md">
|
||||||
|
<q-input
|
||||||
|
for="input-ownerName"
|
||||||
|
:dense="dense"
|
||||||
|
:outlined="!readonly"
|
||||||
|
:readonly="readonly"
|
||||||
|
:borderless="readonly"
|
||||||
|
hide-bottom-space
|
||||||
|
class="col-6"
|
||||||
|
:label="$t('formDialogInputOwnerName')"
|
||||||
|
v-model="work.ownerName"
|
||||||
|
/>
|
||||||
|
<q-select
|
||||||
|
id="select-positionName"
|
||||||
|
:dense="dense"
|
||||||
|
:readonly="readonly"
|
||||||
|
:outlined="readonly ? false : outlined"
|
||||||
|
:hide-dropdown-icon="readonly"
|
||||||
|
:borderless="readonly"
|
||||||
|
hide-bottom-space
|
||||||
|
emit-value
|
||||||
|
map-options
|
||||||
|
v-model="work.positionName"
|
||||||
|
option-value="id"
|
||||||
|
option-label="name"
|
||||||
|
:label="$t('formDialogInputJobPosition')"
|
||||||
|
class="col-6"
|
||||||
|
:options="addrOptions.provinceOps"
|
||||||
|
lazy-rules
|
||||||
|
/>
|
||||||
|
<q-select
|
||||||
|
id="select-jobType"
|
||||||
|
:dense="dense"
|
||||||
|
:readonly="readonly"
|
||||||
|
:outlined="readonly ? false : outlined"
|
||||||
|
:hide-dropdown-icon="readonly"
|
||||||
|
:borderless="readonly"
|
||||||
|
hide-bottom-space
|
||||||
|
emit-value
|
||||||
|
map-options
|
||||||
|
v-model="work.jobType"
|
||||||
|
option-value="id"
|
||||||
|
option-label="nameEN"
|
||||||
|
:label="$t('formDialogInputJobType')"
|
||||||
|
class="col-6"
|
||||||
|
:options="addrOptions.provinceOps"
|
||||||
|
lazy-rules
|
||||||
|
/>
|
||||||
|
<q-select
|
||||||
|
id="select-province"
|
||||||
|
:dense="dense"
|
||||||
|
:readonly="readonly"
|
||||||
|
:outlined="readonly ? false : outlined"
|
||||||
|
:hide-dropdown-icon="readonly"
|
||||||
|
:borderless="readonly"
|
||||||
|
hide-bottom-space
|
||||||
|
emit-value
|
||||||
|
map-options
|
||||||
|
v-model="work.workplace"
|
||||||
|
option-value="id"
|
||||||
|
option-label="nameEN"
|
||||||
|
:label="$t('formDialogInputWorkPlace')"
|
||||||
|
class="col-6"
|
||||||
|
:options="addrOptions.provinceOps"
|
||||||
|
lazy-rules
|
||||||
|
/>
|
||||||
|
<q-input
|
||||||
|
for="input-workEndDate"
|
||||||
|
:label="$t('formDialogInputRemark')"
|
||||||
|
:dense="dense"
|
||||||
|
:outlined="!readonly"
|
||||||
|
:readonly="readonly"
|
||||||
|
:borderless="readonly"
|
||||||
|
hide-bottom-space
|
||||||
|
class="col-12"
|
||||||
|
v-model="work.remark"
|
||||||
|
type="textarea"
|
||||||
|
/>
|
||||||
|
<VueDatePicker
|
||||||
|
id="date-picker-workEndDate"
|
||||||
|
utc
|
||||||
|
autoApply
|
||||||
|
:teleport="true"
|
||||||
|
v-model="work.workEndDate"
|
||||||
|
:locale="'th'"
|
||||||
|
:enableTimePicker="false"
|
||||||
|
:disabled="readonly"
|
||||||
|
class="col-6"
|
||||||
|
>
|
||||||
|
<template #year="{ value }">
|
||||||
|
{{ value + 543 }}
|
||||||
|
</template>
|
||||||
|
<template #trigger>
|
||||||
|
<q-input
|
||||||
|
id="input-birth-date"
|
||||||
|
:label="$t('formDialogInputWorkUntil')"
|
||||||
|
:dense="dense"
|
||||||
|
:outlined="readonly ? false : outlined"
|
||||||
|
:readonly="readonly"
|
||||||
|
:borderless="readonly"
|
||||||
|
:model-value="
|
||||||
|
work.workEndDate ? dateFormat(work.workEndDate) : ''
|
||||||
|
"
|
||||||
|
>
|
||||||
|
<template v-slot:prepend>
|
||||||
|
<q-icon
|
||||||
|
size="xs"
|
||||||
|
name="mdi-calendar-blank-outline"
|
||||||
|
class="cursor-pointer"
|
||||||
|
color="positive"
|
||||||
|
/>
|
||||||
|
</template>
|
||||||
|
<template v-slot:append>
|
||||||
|
<q-icon
|
||||||
|
v-if="work.workEndDate && !readonly"
|
||||||
|
name="mdi-close"
|
||||||
|
class="cursor-pointer"
|
||||||
|
size="xs"
|
||||||
|
@click="work.workEndDate = undefined"
|
||||||
|
/>
|
||||||
|
</template>
|
||||||
|
</q-input>
|
||||||
|
</template>
|
||||||
|
</VueDatePicker>
|
||||||
|
<q-input
|
||||||
|
for="input-workPermitNo"
|
||||||
|
:dense="dense"
|
||||||
|
:outlined="!readonly"
|
||||||
|
:readonly="readonly"
|
||||||
|
:borderless="readonly"
|
||||||
|
hide-bottom-space
|
||||||
|
class="col-6"
|
||||||
|
:label="$t('formDialogInputWorkPermitNo')"
|
||||||
|
v-model="work.workPermitNo"
|
||||||
|
/>
|
||||||
|
<VueDatePicker
|
||||||
|
id="date-picker-workPermitIssuDate"
|
||||||
|
utc
|
||||||
|
autoApply
|
||||||
|
:teleport="true"
|
||||||
|
v-model="work.workPermitIssuDate"
|
||||||
|
:locale="'th'"
|
||||||
|
:enableTimePicker="false"
|
||||||
|
:disabled="readonly"
|
||||||
|
class="col-6"
|
||||||
|
>
|
||||||
|
<template #year="{ value }">
|
||||||
|
{{ value + 543 }}
|
||||||
|
</template>
|
||||||
|
<template #trigger>
|
||||||
|
<q-input
|
||||||
|
id="input-birth-date"
|
||||||
|
:label="$t('formDialogInputWorkPermitIssueDate')"
|
||||||
|
:dense="dense"
|
||||||
|
:outlined="readonly ? false : outlined"
|
||||||
|
:readonly="readonly"
|
||||||
|
:borderless="readonly"
|
||||||
|
:model-value="
|
||||||
|
work.workPermitIssuDate
|
||||||
|
? dateFormat(work.workPermitIssuDate)
|
||||||
|
: ''
|
||||||
|
"
|
||||||
|
>
|
||||||
|
<template v-slot:prepend>
|
||||||
|
<q-icon
|
||||||
|
size="xs"
|
||||||
|
name="mdi-calendar-blank-outline"
|
||||||
|
class="cursor-pointer"
|
||||||
|
color="positive"
|
||||||
|
/>
|
||||||
|
</template>
|
||||||
|
<template v-slot:append>
|
||||||
|
<q-icon
|
||||||
|
v-if="work.workPermitIssuDate && !readonly"
|
||||||
|
name="mdi-close"
|
||||||
|
class="cursor-pointer"
|
||||||
|
size="xs"
|
||||||
|
@click="work.workPermitIssuDate = undefined"
|
||||||
|
/>
|
||||||
|
</template>
|
||||||
|
</q-input>
|
||||||
|
</template>
|
||||||
|
</VueDatePicker>
|
||||||
|
<VueDatePicker
|
||||||
|
id="date-picker-workPermitExpireDate"
|
||||||
|
utc
|
||||||
|
autoApply
|
||||||
|
:teleport="true"
|
||||||
|
v-model="work.workPermitExpireDate"
|
||||||
|
:locale="'th'"
|
||||||
|
:enableTimePicker="false"
|
||||||
|
:disabled="readonly"
|
||||||
|
class="col-6"
|
||||||
|
>
|
||||||
|
<template #year="{ value }">
|
||||||
|
{{ value + 543 }}
|
||||||
|
</template>
|
||||||
|
<template #trigger>
|
||||||
|
<q-input
|
||||||
|
id="input-birth-date"
|
||||||
|
:label="$t('formDialogInputWorkPermitExpireDate')"
|
||||||
|
:dense="dense"
|
||||||
|
:outlined="readonly ? false : outlined"
|
||||||
|
:readonly="readonly"
|
||||||
|
:borderless="readonly"
|
||||||
|
:model-value="
|
||||||
|
work.workPermitExpireDate
|
||||||
|
? dateFormat(work.workPermitExpireDate)
|
||||||
|
: ''
|
||||||
|
"
|
||||||
|
>
|
||||||
|
<template v-slot:prepend>
|
||||||
|
<q-icon
|
||||||
|
size="xs"
|
||||||
|
name="mdi-calendar-blank-outline"
|
||||||
|
class="cursor-pointer"
|
||||||
|
color="positive"
|
||||||
|
/>
|
||||||
|
</template>
|
||||||
|
<template v-slot:append>
|
||||||
|
<q-icon
|
||||||
|
v-if="work.workPermitExpireDate && !readonly"
|
||||||
|
name="mdi-close"
|
||||||
|
class="cursor-pointer"
|
||||||
|
size="xs"
|
||||||
|
@click="work.workPermitExpireDate = undefined"
|
||||||
|
/>
|
||||||
|
</template>
|
||||||
|
</q-input>
|
||||||
|
</template>
|
||||||
|
</VueDatePicker>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<q-separator
|
||||||
|
v-if="separator"
|
||||||
|
class="col-12 q-mt-xl q-mb-md"
|
||||||
|
style="padding-block: 0.5px"
|
||||||
|
/>
|
||||||
|
</q-tab-panel>
|
||||||
|
</q-tab-panels>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<style scoped></style>
|
<style scoped>
|
||||||
|
.active-tab {
|
||||||
|
color: var(--brand-1);
|
||||||
|
border-left: 1px solid var(--border-color);
|
||||||
|
border-right: 1px solid var(--border-color);
|
||||||
|
margin-bottom: -1.5px;
|
||||||
|
border-bottom: 3px solid var(--surface-1);
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
|
||||||
|
|
@ -14,6 +14,7 @@ defineProps<{
|
||||||
badgeClass?: string;
|
badgeClass?: string;
|
||||||
noFooter?: boolean;
|
noFooter?: boolean;
|
||||||
noAppBox?: boolean;
|
noAppBox?: boolean;
|
||||||
|
noPaddingTab?: boolean;
|
||||||
maxWidth?: number;
|
maxWidth?: number;
|
||||||
employee?: boolean;
|
employee?: boolean;
|
||||||
noAddress?: boolean;
|
noAddress?: boolean;
|
||||||
|
|
@ -92,7 +93,6 @@ const tabsList = defineModel<{ name: string; label: string }[]>('tabsList');
|
||||||
dense
|
dense
|
||||||
class="app-text-muted cancel-overflow"
|
class="app-text-muted cancel-overflow"
|
||||||
v-model="employeeTab"
|
v-model="employeeTab"
|
||||||
content-class="content-tab"
|
|
||||||
active-class="active-tab"
|
active-class="active-tab"
|
||||||
indicator-color="transparent"
|
indicator-color="transparent"
|
||||||
>
|
>
|
||||||
|
|
@ -134,13 +134,21 @@ const tabsList = defineModel<{ name: string; label: string }[]>('tabsList');
|
||||||
<AppBox
|
<AppBox
|
||||||
v-if="!noAppBox"
|
v-if="!noAppBox"
|
||||||
bordered
|
bordered
|
||||||
|
:noPadding="noPaddingTab"
|
||||||
class="column full-height"
|
class="column full-height"
|
||||||
:class="`${$slots.prepend ? ($q.screen.gt.sm ? 'col-10' : 'col-12') : $slots.append ? 'col-6' : 'col-12'}`"
|
:class="`${$slots.prepend ? ($q.screen.gt.sm ? 'col-10' : 'col-12') : $slots.append ? 'col-6' : 'col-12'}`"
|
||||||
style="padding-right: 0; padding-bottom: 0"
|
style="padding-right: 0; padding-bottom: 0"
|
||||||
>
|
>
|
||||||
<div
|
<div
|
||||||
class="row col-12 q-col-gutter-y-md q-pr-md q-mb-md items-start"
|
class="row col-12 q-col-gutter-y-md q-mb-md items-start"
|
||||||
:style="$q.screen.gt.sm ? 'overflow-y: auto; height: 60vh' : ''"
|
:class="noPaddingTab ? '' : 'q-pr-md'"
|
||||||
|
:style="
|
||||||
|
$q.screen.gt.sm
|
||||||
|
? noPaddingTab
|
||||||
|
? 'height: 60vh'
|
||||||
|
: 'overflow-y: auto; height: 60vh'
|
||||||
|
: ''
|
||||||
|
"
|
||||||
>
|
>
|
||||||
<slot name="information"></slot>
|
<slot name="information"></slot>
|
||||||
<slot name="person"></slot>
|
<slot name="person"></slot>
|
||||||
|
|
|
||||||
|
|
@ -167,4 +167,7 @@ export default {
|
||||||
formDialogInputVisaStayUntil: 'Permitted to Stay Until',
|
formDialogInputVisaStayUntil: 'Permitted to Stay Until',
|
||||||
formDialogInputVisaTM6: 'TM.6 Number (Arrival)',
|
formDialogInputVisaTM6: 'TM.6 Number (Arrival)',
|
||||||
formDialogInputVisaEnter: 'Date of Entry into the Country',
|
formDialogInputVisaEnter: 'Date of Entry into the Country',
|
||||||
|
|
||||||
|
formDialogTabCheckup: 'Checkup ',
|
||||||
|
formDialogTabWork: 'Work ',
|
||||||
};
|
};
|
||||||
|
|
|
||||||
|
|
@ -166,4 +166,7 @@ export default {
|
||||||
formDialogInputVisaStayUntil: 'ให้อยู่ในราชอาณาจักรถึงวันที่',
|
formDialogInputVisaStayUntil: 'ให้อยู่ในราชอาณาจักรถึงวันที่',
|
||||||
formDialogInputVisaTM6: 'เลขที่ใบ ตม.6 (ใบขาเข้า)',
|
formDialogInputVisaTM6: 'เลขที่ใบ ตม.6 (ใบขาเข้า)',
|
||||||
formDialogInputVisaEnter: 'วันที่เดินทางเข้ามาในประเทศ',
|
formDialogInputVisaEnter: 'วันที่เดินทางเข้ามาในประเทศ',
|
||||||
|
|
||||||
|
formDialogTabCheckup: 'ครั้งที่ ',
|
||||||
|
formDialogTabWork: 'ครั้งที่ ',
|
||||||
};
|
};
|
||||||
|
|
|
||||||
|
|
@ -147,30 +147,30 @@ const formDataEmployee = ref<EmployeeCreate>({
|
||||||
provinceId: '',
|
provinceId: '',
|
||||||
|
|
||||||
employeeWork: [
|
employeeWork: [
|
||||||
// {
|
{
|
||||||
// workEndDate: undefined,
|
workEndDate: null,
|
||||||
// workPermitExpireDate: undefined,
|
workPermitExpireDate: null,
|
||||||
// workPermitIssuDate: undefined,
|
workPermitIssuDate: null,
|
||||||
// workPermitNo: '',
|
workPermitNo: '',
|
||||||
// workplace: '',
|
workplace: '',
|
||||||
// jobType: '',
|
jobType: '',
|
||||||
// positionName: '',
|
positionName: '',
|
||||||
// ownerName: '',
|
ownerName: '',
|
||||||
// remark: '',
|
remark: '',
|
||||||
// },
|
},
|
||||||
],
|
],
|
||||||
employeeCheckup: [
|
employeeCheckup: [
|
||||||
// {
|
{
|
||||||
// coverageExpireDate: undefined,
|
coverageExpireDate: null,
|
||||||
// coverageStartDate: undefined,
|
coverageStartDate: null,
|
||||||
// insuranceCompany: '',
|
insuranceCompany: '',
|
||||||
// medicalBenefitScheme: '',
|
medicalBenefitScheme: '',
|
||||||
// remark: '',
|
remark: '',
|
||||||
// hospitalName: '',
|
hospitalName: '',
|
||||||
// provinceId: '',
|
provinceId: '',
|
||||||
// checkupResult: '',
|
checkupResult: '',
|
||||||
// checkupType: '',
|
checkupType: '',
|
||||||
// },
|
},
|
||||||
],
|
],
|
||||||
employeeOtherInfo: {
|
employeeOtherInfo: {
|
||||||
birthPlace: '',
|
birthPlace: '',
|
||||||
|
|
@ -1170,10 +1170,14 @@ watch(fieldSelectedCustomer, async () => {
|
||||||
</FormDialog>
|
</FormDialog>
|
||||||
|
|
||||||
<FormDialog
|
<FormDialog
|
||||||
|
v-model:modal="dialogEmployee"
|
||||||
employee
|
employee
|
||||||
addressSeparator
|
addressSeparator
|
||||||
:noAddress="formDataEmployeeTab !== 'personalInfo'"
|
:noAddress="formDataEmployeeTab !== 'personalInfo'"
|
||||||
v-model:modal="dialogEmployee"
|
:noPaddingTab="
|
||||||
|
formDataEmployeeTab === 'healthCheck' ||
|
||||||
|
formDataEmployeeTab === 'workHistory'
|
||||||
|
"
|
||||||
v-model:tabs-list="employeeTab"
|
v-model:tabs-list="employeeTab"
|
||||||
v-model:employee-tab="formDataEmployeeTab"
|
v-model:employee-tab="formDataEmployeeTab"
|
||||||
v-model:same-with-employer="formDataEmployeeSameAddr"
|
v-model:same-with-employer="formDataEmployeeSameAddr"
|
||||||
|
|
@ -1227,15 +1231,21 @@ watch(fieldSelectedCustomer, async () => {
|
||||||
v-model:birthDate="formDataEmployee.dateOfBirth"
|
v-model:birthDate="formDataEmployee.dateOfBirth"
|
||||||
v-model:nationality="formDataEmployee.nationality"
|
v-model:nationality="formDataEmployee.nationality"
|
||||||
/>
|
/>
|
||||||
|
|
||||||
<FormEmployeeHealthCheck
|
<FormEmployeeHealthCheck
|
||||||
v-if="formDataEmployeeTab === 'healthCheck'"
|
v-if="
|
||||||
|
formDataEmployeeTab === 'healthCheck' &&
|
||||||
|
formDataEmployee.employeeCheckup
|
||||||
|
"
|
||||||
dense
|
dense
|
||||||
outlined
|
outlined
|
||||||
|
v-model:employee-checkup="formDataEmployee.employeeCheckup"
|
||||||
/>
|
/>
|
||||||
<FormEmployeeWorkHistory
|
<FormEmployeeWorkHistory
|
||||||
v-if="formDataEmployeeTab === 'workHistory'"
|
v-if="formDataEmployeeTab === 'workHistory'"
|
||||||
dense
|
dense
|
||||||
outlined
|
outlined
|
||||||
|
v-model:employee-work="formDataEmployee.employeeWork"
|
||||||
/>
|
/>
|
||||||
<FormEmployeeOther
|
<FormEmployeeOther
|
||||||
v-if="
|
v-if="
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue