153 lines
5.1 KiB
JavaScript
153 lines
5.1 KiB
JavaScript
import { requestJson } from './apiClient';
|
|
|
|
function normalizeItems(items) {
|
|
if (Array.isArray(items)) return items;
|
|
if (items && typeof items === 'object') return [items];
|
|
return [];
|
|
}
|
|
|
|
export const FinanceService = {
|
|
async listWithdrawals({ page, limit, id, tenant_id, tenant_code, tenant_name, user_id, username, status, created_at_from, created_at_to, paid_at_from, paid_at_to, amount_paid_min, amount_paid_max, sortField, sortOrder } = {}) {
|
|
const iso = (d) => {
|
|
if (!d) return undefined;
|
|
const date = d instanceof Date ? d : new Date(d);
|
|
if (Number.isNaN(date.getTime())) return undefined;
|
|
return date.toISOString();
|
|
};
|
|
|
|
const query = {
|
|
page,
|
|
limit,
|
|
id,
|
|
tenant_id,
|
|
tenant_code,
|
|
tenant_name,
|
|
user_id,
|
|
username,
|
|
status,
|
|
created_at_from: iso(created_at_from),
|
|
created_at_to: iso(created_at_to),
|
|
paid_at_from: iso(paid_at_from),
|
|
paid_at_to: iso(paid_at_to),
|
|
amount_paid_min,
|
|
amount_paid_max
|
|
};
|
|
if (sortField && sortOrder) {
|
|
if (sortOrder === 1) query.asc = sortField;
|
|
if (sortOrder === -1) query.desc = sortField;
|
|
}
|
|
|
|
const data = await requestJson('/super/v1/withdrawals', { query });
|
|
return {
|
|
page: data?.page ?? page ?? 1,
|
|
limit: data?.limit ?? limit ?? 10,
|
|
total: data?.total ?? 0,
|
|
items: normalizeItems(data?.items)
|
|
};
|
|
},
|
|
async approveWithdrawal(id) {
|
|
if (!id) throw new Error('id is required');
|
|
return requestJson(`/super/v1/withdrawals/${id}/approve`, { method: 'POST' });
|
|
},
|
|
async rejectWithdrawal(id, { reason } = {}) {
|
|
if (!id) throw new Error('id is required');
|
|
return requestJson(`/super/v1/withdrawals/${id}/reject`, {
|
|
method: 'POST',
|
|
body: { reason }
|
|
});
|
|
},
|
|
async listLedgers({ page, limit, id, tenant_id, tenant_code, tenant_name, user_id, username, order_id, type, amount_min, amount_max, created_at_from, created_at_to, sortField, sortOrder } = {}) {
|
|
const iso = (d) => {
|
|
if (!d) return undefined;
|
|
const date = d instanceof Date ? d : new Date(d);
|
|
if (Number.isNaN(date.getTime())) return undefined;
|
|
return date.toISOString();
|
|
};
|
|
|
|
const query = {
|
|
page,
|
|
limit,
|
|
id,
|
|
tenant_id,
|
|
tenant_code,
|
|
tenant_name,
|
|
user_id,
|
|
username,
|
|
order_id,
|
|
type,
|
|
amount_min,
|
|
amount_max,
|
|
created_at_from: iso(created_at_from),
|
|
created_at_to: iso(created_at_to)
|
|
};
|
|
if (sortField && sortOrder) {
|
|
if (sortOrder === 1) query.asc = sortField;
|
|
if (sortOrder === -1) query.desc = sortField;
|
|
}
|
|
|
|
const data = await requestJson('/super/v1/finance/ledgers', { query });
|
|
return {
|
|
page: data?.page ?? page ?? 1,
|
|
limit: data?.limit ?? limit ?? 10,
|
|
total: data?.total ?? 0,
|
|
items: normalizeItems(data?.items)
|
|
};
|
|
},
|
|
async listBalanceAnomalies({ page, limit, user_id, username, issue, sortField, sortOrder } = {}) {
|
|
const query = {
|
|
page,
|
|
limit,
|
|
user_id,
|
|
username,
|
|
issue
|
|
};
|
|
if (sortField && sortOrder) {
|
|
if (sortOrder === 1) query.asc = sortField;
|
|
if (sortOrder === -1) query.desc = sortField;
|
|
}
|
|
|
|
const data = await requestJson('/super/v1/finance/anomalies/balances', { query });
|
|
return {
|
|
page: data?.page ?? page ?? 1,
|
|
limit: data?.limit ?? limit ?? 10,
|
|
total: data?.total ?? 0,
|
|
items: normalizeItems(data?.items)
|
|
};
|
|
},
|
|
async listOrderAnomalies({ page, limit, id, tenant_id, tenant_code, tenant_name, user_id, username, type, issue, created_at_from, created_at_to, sortField, sortOrder } = {}) {
|
|
const iso = (d) => {
|
|
if (!d) return undefined;
|
|
const date = d instanceof Date ? d : new Date(d);
|
|
if (Number.isNaN(date.getTime())) return undefined;
|
|
return date.toISOString();
|
|
};
|
|
|
|
const query = {
|
|
page,
|
|
limit,
|
|
id,
|
|
tenant_id,
|
|
tenant_code,
|
|
tenant_name,
|
|
user_id,
|
|
username,
|
|
type,
|
|
issue,
|
|
created_at_from: iso(created_at_from),
|
|
created_at_to: iso(created_at_to)
|
|
};
|
|
if (sortField && sortOrder) {
|
|
if (sortOrder === 1) query.asc = sortField;
|
|
if (sortOrder === -1) query.desc = sortField;
|
|
}
|
|
|
|
const data = await requestJson('/super/v1/finance/anomalies/orders', { query });
|
|
return {
|
|
page: data?.page ?? page ?? 1,
|
|
limit: data?.limit ?? limit ?? 10,
|
|
total: data?.total ?? 0,
|
|
items: normalizeItems(data?.items)
|
|
};
|
|
}
|
|
};
|