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) }; } };