Files
Caramel-CRM/resources/js/services/TimesheetService.ts
T
2026-02-17 10:35:03 +01:00

106 lines
3.4 KiB
TypeScript

// resources/js/services/TimesheetService.ts
import axios, { AxiosResponse } from 'axios';
import { Timesheet, TimesheetEntry } from '@/types';
import { update } from '@/routes/password';
const API_URL = '/api/timesheets';
const ENTRY_API_URL = '/api/timesheet-entries';
export default {
/**
* Retrieves all timesheets
* @returns Promise<Timesheet[]>
*/
async getAllTimesheets(): Promise<Timesheet[]> {
const response = await axios.get<Timesheet[]>(API_URL);
return response.data;
},
/**
* Creates a new timesheet
* @param timesheet - The timesheet data to create
* @returns Promise<Timesheet>
*/
async createTimesheet(timesheet: Partial<Timesheet>): Promise<Timesheet> {
const response = await axios.post<Timesheet>(API_URL, timesheet);
return response.data;
},
/**
* Update an existing timesheet
* @param timesheet - The Timesheet object to update
* @returns
*/
async updateTimesheet(timesheet: Partial<Timesheet>): Promise<Timesheet> {
const response = await axios.put<Timesheet>(`${API_URL}/${timesheet.id}`, timesheet);
return response.data;
},
/**
* Deletes a timesheet by ID
* @param timesheetId - The id of the timesheet to delete
* @returns Promise<AxiosResponse>
*/
async deleteTimesheet(timesheetId: number): Promise<AxiosResponse> {
const response = await axios.delete(`${API_URL}/${timesheetId}`);
return response.data;
},
/**
* Retrieves all entries for a specific timesheet
* @param timesheetId - The ID of the timesheet
* @returns Promise<TimesheetEntry[]>
*/
async getTimesheetEntries(timesheetId: number): Promise<TimesheetEntry[]> {
const response = await axios.get<TimesheetEntry[]>(`${API_URL}/${timesheetId}/entries`);
return response.data;
},
/**
* Retrieves all timesheet entries
* @returns Promise<TimesheetEntry[]>
*/
async getAllEntries(): Promise<TimesheetEntry[]> {
const response = await axios.get<TimesheetEntry[]>(ENTRY_API_URL);
return response.data;
},
/**
* Creates a new timesheet entry
* @param entry - The entry data to create
* @returns Promise<TimesheetEntry>
*/
async createEntry(entry: Partial<TimesheetEntry>): Promise<TimesheetEntry> {
const response = await axios.post<TimesheetEntry>(ENTRY_API_URL, entry);
return response.data;
},
/**
* Updates an existing timesheet entry
* @param entry - The TimesheetEntry object to update
* @returns Promise<TimesheetEntry>
*/
async updateEntry(entry: Partial<TimesheetEntry>): Promise<TimesheetEntry> {
const response = await axios.put<TimesheetEntry>(`${ENTRY_API_URL}/${entry.id}`, entry);
return response.data;
},
/**
* Toggles the billed status of a timesheet entry
* @param entryId - The ID of the entry to toggle
* @returns Promise<TimesheetEntry>
*/
async toggleBilled(entryId: number): Promise<TimesheetEntry> {
const response = await axios.patch<TimesheetEntry>(`${ENTRY_API_URL}/${entryId}/toggle-billed`);
return response.data;
},
/**
* Deletes a timesheet entry
* @param entryId - The ID of the entry to delete
* @returns Promise<void>
*/
async deleteEntry(entryId: number): Promise<void> {
await axios.delete(`${ENTRY_API_URL}/${entryId}`);
}
};