feat : ajout des frais kms + alignment du style de l'application
Some checks failed
Auto Tag Develop / tag (push) Has been cancelled
Some checks failed
Auto Tag Develop / tag (push) Has been cancelled
This commit is contained in:
@@ -6,7 +6,7 @@ export const useEmployeeDetailPage = () => {
|
||||
const route = useRoute()
|
||||
const employee = ref<Employee | null>(null)
|
||||
const isLoading = ref(false)
|
||||
const activeTab = ref<'contract' | 'leave' | 'rtt'>('contract')
|
||||
const activeTab = ref<'contract' | 'leave' | 'rtt' | 'mileage'>('contract')
|
||||
|
||||
const showLeaveTab = computed(() => employee.value?.currentContractNature !== 'INTERIM')
|
||||
const showRttTab = computed(() => employee.value?.contract?.type !== CONTRACT_TYPES.FORFAIT)
|
||||
@@ -38,11 +38,14 @@ export const useEmployeeDetailPage = () => {
|
||||
|
||||
leave.resetLoaded()
|
||||
rtt.resetLoaded()
|
||||
mileage.resetLoaded()
|
||||
|
||||
if (activeTab.value === 'leave' && showLeaveTab.value) {
|
||||
await leave.loadLeaveData()
|
||||
} else if (activeTab.value === 'rtt' && showRttTab.value) {
|
||||
await rtt.loadRttData()
|
||||
} else if (activeTab.value === 'mileage') {
|
||||
await mileage.loadMileageData()
|
||||
}
|
||||
} finally {
|
||||
isLoading.value = false
|
||||
@@ -52,12 +55,15 @@ export const useEmployeeDetailPage = () => {
|
||||
const contract = useEmployeeContract(employee, loadEmployee)
|
||||
const leave = useEmployeeLeave(employee, loadEmployee)
|
||||
const rtt = useEmployeeRtt(employee, loadEmployee)
|
||||
const mileage = useEmployeeMileage(employee, loadEmployee)
|
||||
|
||||
watch(activeTab, (tab) => {
|
||||
if (tab === 'leave' && !leave.leaveDataLoaded.value && showLeaveTab.value) {
|
||||
leave.loadLeaveData()
|
||||
} else if (tab === 'rtt' && !rtt.rttDataLoaded.value && showRttTab.value) {
|
||||
rtt.loadRttData()
|
||||
} else if (tab === 'mileage' && !mileage.mileageDataLoaded.value) {
|
||||
mileage.loadMileageData()
|
||||
}
|
||||
})
|
||||
|
||||
@@ -75,6 +81,7 @@ export const useEmployeeDetailPage = () => {
|
||||
employeeContractWorkLabel,
|
||||
...contract,
|
||||
...leave,
|
||||
...rtt
|
||||
...rtt,
|
||||
...mileage
|
||||
}
|
||||
}
|
||||
|
||||
73
frontend/composables/useEmployeeMileage.ts
Normal file
73
frontend/composables/useEmployeeMileage.ts
Normal file
@@ -0,0 +1,73 @@
|
||||
import type { Ref } from 'vue'
|
||||
import type { MileageAllowance } from '~/services/dto/mileage-allowance'
|
||||
import type { Employee } from '~/services/dto/employee'
|
||||
import {
|
||||
listMileageAllowances,
|
||||
createMileageAllowance,
|
||||
updateMileageAllowance,
|
||||
deleteMileageAllowance,
|
||||
uploadReceipt
|
||||
} from '~/services/mileage-allowances'
|
||||
|
||||
export const useEmployeeMileage = (employee: Ref<Employee | null>, reloadEmployee: () => Promise<void>) => {
|
||||
const config = useRuntimeConfig()
|
||||
const apiBase = (config.public.apiBase as string) ?? '/api'
|
||||
|
||||
const mileageAllowances = ref<MileageAllowance[]>([])
|
||||
const isMileageLoading = ref(false)
|
||||
const mileageDataLoaded = ref(false)
|
||||
|
||||
const loadMileageData = async () => {
|
||||
if (!employee.value || isMileageLoading.value) return
|
||||
isMileageLoading.value = true
|
||||
try {
|
||||
mileageAllowances.value = await listMileageAllowances(employee.value.id)
|
||||
mileageDataLoaded.value = true
|
||||
} finally {
|
||||
isMileageLoading.value = false
|
||||
}
|
||||
}
|
||||
|
||||
const resetLoaded = () => {
|
||||
mileageDataLoaded.value = false
|
||||
}
|
||||
|
||||
const submitCreateMileage = async (data: { month: string; kilometers: number; comment?: string }, file?: File) => {
|
||||
if (!employee.value) return
|
||||
const result = await createMileageAllowance({
|
||||
employeeId: employee.value.id,
|
||||
month: data.month,
|
||||
kilometers: data.kilometers,
|
||||
comment: data.comment
|
||||
})
|
||||
if (file && result?.id) {
|
||||
await uploadReceipt(apiBase, result.id, file)
|
||||
}
|
||||
await reloadEmployee()
|
||||
}
|
||||
|
||||
const submitUpdateMileage = async (id: number, data: { month: string; kilometers: number; comment?: string }, file?: File) => {
|
||||
await updateMileageAllowance(id, data)
|
||||
if (file) {
|
||||
await uploadReceipt(apiBase, id, file)
|
||||
}
|
||||
await reloadEmployee()
|
||||
}
|
||||
|
||||
const submitDeleteMileage = async (id: number) => {
|
||||
await deleteMileageAllowance(id)
|
||||
await reloadEmployee()
|
||||
}
|
||||
|
||||
return {
|
||||
mileageAllowances,
|
||||
isMileageLoading,
|
||||
mileageDataLoaded,
|
||||
mileageApiBase: apiBase,
|
||||
loadMileageData,
|
||||
resetLoaded,
|
||||
submitCreateMileage,
|
||||
submitUpdateMileage,
|
||||
submitDeleteMileage
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user