- services/reimbursements.js: add reimbursement API service client - components/shared/ConfirmDialog.vue: add shared confirm dialog component
30 lines
950 B
JavaScript
30 lines
950 B
JavaScript
import { apiRequest } from './api.js'
|
|
|
|
export function fetchExpenseClaims() {
|
|
return apiRequest('/reimbursements/claims')
|
|
}
|
|
|
|
export function fetchExpenseClaimDetail(claimId) {
|
|
return apiRequest(`/reimbursements/claims/${encodeURIComponent(String(claimId || '').trim())}`)
|
|
}
|
|
|
|
export function updateExpenseClaimItem(claimId, itemId, payload) {
|
|
return apiRequest(`/reimbursements/claims/${encodeURIComponent(String(claimId || '').trim())}/items/${encodeURIComponent(String(itemId || '').trim())}`, {
|
|
method: 'PATCH',
|
|
body: JSON.stringify(payload)
|
|
})
|
|
}
|
|
|
|
export function submitExpenseClaim(claimId) {
|
|
return apiRequest(`/reimbursements/claims/${encodeURIComponent(String(claimId || '').trim())}/submit`, {
|
|
method: 'POST',
|
|
body: JSON.stringify({})
|
|
})
|
|
}
|
|
|
|
export function deleteExpenseClaim(claimId) {
|
|
return apiRequest(`/reimbursements/claims/${encodeURIComponent(String(claimId || '').trim())}`, {
|
|
method: 'DELETE'
|
|
})
|
|
}
|