Merge branch 'development' of gitlab.com:mbugroup/lti-web-client into feat/FE/US-281/TASK-316-317-slicing-ui-and-integrate-api-daily-recording-growing-uniformity-page

This commit is contained in:
rstubryan
2025-12-29 14:15:29 +07:00
54 changed files with 4457 additions and 2464 deletions
-14
View File
@@ -15,20 +15,6 @@ import {
import { BaseApiResponse } from '@/types/api/api-general';
import { httpClient, httpClientFetcher } from '@/services/http/client';
import { ClosingSales } from '@/types/api/closing';
// TODO: delete these dummy data later
import {
dummyGetAllFetcher,
dummyGetSingle,
dummyGetAllIncomingSapronakFetcher,
dummyGetAllOutgoingSapronakFetcher,
dummyGetGeneralInfo,
dummyGetPerhitunganSapronak,
dummyGetOverhead,
dummyClosingProductionData,
} from '@/dummy/closing.dummy';
import { sleep } from '@/lib/helper';
export class ClosingApiService extends BaseApiService<Closing, null, null> {
constructor(basePath: string) {
super(basePath);
+193
View File
@@ -0,0 +1,193 @@
import axios from 'axios';
import { BaseApiService } from '@/services/api/base';
import { BaseApiResponse } from '@/types/api/api-general';
import { httpClient, httpClientFetcher } from '@/services/http/client';
import {
CreateFinancePayment,
CreateInitialBalance,
CreateInjection,
Finance,
UpdateFinancePayment,
UpdateInitialBalance,
UpdateInjection,
} from '@/types/api/finance/finance';
export class FinanceApiService extends BaseApiService<
Finance,
unknown,
unknown
> {
constructor(basePath: string) {
super(basePath);
}
async getSingle(id: number): Promise<BaseApiResponse<Finance>> {
return await httpClientFetcher<BaseApiResponse<Finance>>(
`${this.basePath}/transactions/${id}`
);
}
async create(payload: CreateFinancePayment) {
const isFormData =
typeof FormData !== 'undefined' && payload instanceof FormData;
try {
const headers = isFormData
? { ...(this.header ?? {}) }
: { 'Content-Type': 'application/json', ...(this.header ?? {}) };
const createRes = await httpClient<BaseApiResponse<Finance>>(
`${this.basePath}/payments`,
{
method: 'POST',
body: payload,
headers,
}
);
return createRes;
} catch (error: unknown) {
if (axios.isAxiosError<BaseApiResponse<Finance>>(error)) {
return error.response?.data;
}
return undefined;
}
}
async createInitialBalances(payload: CreateInitialBalance) {
const isFormData =
typeof FormData !== 'undefined' && payload instanceof FormData;
try {
const headers = isFormData
? { ...(this.header ?? {}) }
: { 'Content-Type': 'application/json', ...(this.header ?? {}) };
const createRes = await httpClient<BaseApiResponse<Finance>>(
`${this.basePath}/initial-balances`,
{
method: 'POST',
body: payload,
headers,
}
);
return createRes;
} catch (error: unknown) {
if (axios.isAxiosError<BaseApiResponse<Finance>>(error)) {
return error.response?.data;
}
return undefined;
}
}
async createInjections(payload: CreateInjection) {
const isFormData =
typeof FormData !== 'undefined' && payload instanceof FormData;
try {
const headers = isFormData
? { ...(this.header ?? {}) }
: { 'Content-Type': 'application/json', ...(this.header ?? {}) };
const createRes = await httpClient<BaseApiResponse<Finance>>(
`${this.basePath}/injections`,
{
method: 'POST',
body: payload,
headers,
}
);
return createRes;
} catch (error: unknown) {
if (axios.isAxiosError<BaseApiResponse<Finance>>(error)) {
return error.response?.data;
}
return undefined;
}
}
async update(id: number, payload: UpdateFinancePayment) {
const isFormData =
typeof FormData !== 'undefined' && payload instanceof FormData;
try {
const updatePath = `${this.basePath}/payments/${id}`;
const headers = isFormData
? { ...(this.header ?? {}) }
: { 'Content-Type': 'application/json', ...(this.header ?? {}) };
const updateRes = await httpClient<BaseApiResponse<Finance>>(updatePath, {
method: 'PATCH',
body: payload,
headers,
});
return updateRes;
} catch (error: unknown) {
if (axios.isAxiosError<BaseApiResponse<Finance>>(error)) {
return error.response?.data;
}
return undefined;
}
}
async updateInitialBalances(id: number, payload: UpdateInitialBalance) {
const isFormData =
typeof FormData !== 'undefined' && payload instanceof FormData;
try {
const updatePath = `${this.basePath}/initial-balances/${id}`;
const headers = isFormData
? { ...(this.header ?? {}) }
: { 'Content-Type': 'application/json', ...(this.header ?? {}) };
const updateRes = await httpClient<BaseApiResponse<Finance>>(updatePath, {
method: 'PATCH',
body: payload,
headers,
});
return updateRes;
} catch (error: unknown) {
if (axios.isAxiosError<BaseApiResponse<Finance>>(error)) {
return error.response?.data;
}
return undefined;
}
}
async updateInjections(id: number, payload: UpdateInjection) {
const isFormData =
typeof FormData !== 'undefined' && payload instanceof FormData;
try {
const updatePath = `${this.basePath}/injections/${id}`;
const headers = isFormData
? { ...(this.header ?? {}) }
: { 'Content-Type': 'application/json', ...(this.header ?? {}) };
const updateRes = await httpClient<BaseApiResponse<Finance>>(updatePath, {
method: 'PATCH',
body: payload,
headers,
});
return updateRes;
} catch (error: unknown) {
if (axios.isAxiosError<BaseApiResponse<Finance>>(error)) {
return error.response?.data;
}
return undefined;
}
}
async delete(id: number) {
try {
const deletePath = `${this.basePath}/transactions/${id}`;
const deleteRes = await httpClient<BaseApiResponse>(deletePath, {
method: 'DELETE',
});
return deleteRes;
} catch (error) {
if (axios.isAxiosError<BaseApiResponse>(error)) {
return error.response?.data;
}
return undefined;
}
}
}
export const FinanceApi = new FinanceApiService('/finance');
+7
View File
@@ -64,6 +64,7 @@ import {
Flock,
UpdateFlockPayload,
} from '@/types/api/master-data/flock';
import { ProductionStandard } from '@/types/api/master-data/production-standard';
export const UomApi = new BaseApiService<
Uom,
@@ -141,3 +142,9 @@ export const FlockApi = new BaseApiService<
CreateFlockPayload,
UpdateFlockPayload
>('/master-data/flocks');
export const ProductionStandardApi = new BaseApiService<
ProductionStandard,
unknown,
unknown
>('/master-data/production-standards');