refactor(FE-174): enhance RecordingApi by adding approve and reject methods for better approval handling

This commit is contained in:
rstubryan
2025-11-03 09:00:49 +07:00
parent b976600099
commit c26e174885
3 changed files with 55 additions and 42 deletions
+39 -2
View File
@@ -1,4 +1,5 @@
import { BaseApiService } from './base';
import { BaseApiResponse } from '@/types/api/api-general';
import {
CreateProjectFlockPayload,
ProjectFlock,
@@ -20,11 +21,47 @@ export const ProjectFlockApi = new BaseApiService<
CreateProjectFlockPayload,
UpdateProjectFlockPayload
>('/production/project_flocks');
export const RecordingApi = new BaseApiService<
export class RecordingService extends BaseApiService<
Recording,
CreateRecordingPayload,
UpdateRecordingPayload
>('/production/recordings');
> {
constructor(basePath: string = '') {
super(basePath);
}
async approve(
idOrIds: number | number[],
notes: string = 'Approved via Form'
): Promise<BaseApiResponse<Recording[]> | undefined> {
const approvable_ids = Array.isArray(idOrIds) ? idOrIds : [idOrIds];
return await this.customRequest<BaseApiResponse<Recording[]>>('approvals', {
method: 'POST',
payload: {
action: 'APPROVED',
approvable_ids,
notes,
},
});
}
async reject(
idOrIds: number | number[],
notes: string = 'Rejected via Form'
): Promise<BaseApiResponse<Recording[]> | undefined> {
const approvable_ids = Array.isArray(idOrIds) ? idOrIds : [idOrIds];
return await this.customRequest<BaseApiResponse<Recording[]>>('approvals', {
method: 'POST',
payload: {
action: 'REJECTED',
approvable_ids,
notes,
},
});
}
}
export const RecordingApi = new RecordingService('/production/recordings');
export const ChickinApi = new BaseApiService<
Chickin,
CreateChickinPayload,