@classytic/commerce-sdk 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of @classytic/commerce-sdk might be problematic. Click here for more details.
- package/LICENSE +14 -0
- package/README.md +104 -0
- package/dist/adjustment-DTSLM7AN.js +5 -0
- package/dist/adjustment-DTSLM7AN.js.map +1 -0
- package/dist/analytics/index.d.ts +27 -0
- package/dist/analytics/index.js +6 -0
- package/dist/analytics/index.js.map +1 -0
- package/dist/analytics-DMcD-o8w.d.ts +76 -0
- package/dist/api-factory-B_h4RKBm.d.ts +280 -0
- package/dist/auth/index.d.ts +39 -0
- package/dist/auth/index.js +5 -0
- package/dist/auth/index.js.map +1 -0
- package/dist/catalog/index.d.ts +479 -0
- package/dist/catalog/index.js +9 -0
- package/dist/catalog/index.js.map +1 -0
- package/dist/chunk-4ZQK3FFN.js +40 -0
- package/dist/chunk-4ZQK3FFN.js.map +1 -0
- package/dist/chunk-5L6EXDGH.js +465 -0
- package/dist/chunk-5L6EXDGH.js.map +1 -0
- package/dist/chunk-5ZFW3FEI.js +183 -0
- package/dist/chunk-5ZFW3FEI.js.map +1 -0
- package/dist/chunk-66OQAZSL.js +94 -0
- package/dist/chunk-66OQAZSL.js.map +1 -0
- package/dist/chunk-6RYGA6MF.js +123 -0
- package/dist/chunk-6RYGA6MF.js.map +1 -0
- package/dist/chunk-B6MPVOV7.js +328 -0
- package/dist/chunk-B6MPVOV7.js.map +1 -0
- package/dist/chunk-BDA2WSJA.js +148 -0
- package/dist/chunk-BDA2WSJA.js.map +1 -0
- package/dist/chunk-EIVYT3HM.js +126 -0
- package/dist/chunk-EIVYT3HM.js.map +1 -0
- package/dist/chunk-EPQN7ZKZ.js +27 -0
- package/dist/chunk-EPQN7ZKZ.js.map +1 -0
- package/dist/chunk-FA7QFJ2G.js +177 -0
- package/dist/chunk-FA7QFJ2G.js.map +1 -0
- package/dist/chunk-I5TIKUIQ.js +261 -0
- package/dist/chunk-I5TIKUIQ.js.map +1 -0
- package/dist/chunk-ILQUH444.js +135 -0
- package/dist/chunk-ILQUH444.js.map +1 -0
- package/dist/chunk-IXMWZJLV.js +616 -0
- package/dist/chunk-IXMWZJLV.js.map +1 -0
- package/dist/chunk-KZIGRIQG.js +75 -0
- package/dist/chunk-KZIGRIQG.js.map +1 -0
- package/dist/chunk-OF5M6R2S.js +769 -0
- package/dist/chunk-OF5M6R2S.js.map +1 -0
- package/dist/chunk-PYYLHUV6.js +3 -0
- package/dist/chunk-PYYLHUV6.js.map +1 -0
- package/dist/chunk-QO5AGZFP.js +159 -0
- package/dist/chunk-QO5AGZFP.js.map +1 -0
- package/dist/chunk-QUMTBLNE.js +76 -0
- package/dist/chunk-QUMTBLNE.js.map +1 -0
- package/dist/chunk-R5Z7NYLH.js +126 -0
- package/dist/chunk-R5Z7NYLH.js.map +1 -0
- package/dist/chunk-SZYWG5IB.js +75 -0
- package/dist/chunk-SZYWG5IB.js.map +1 -0
- package/dist/chunk-U3XT35GZ.js +202 -0
- package/dist/chunk-U3XT35GZ.js.map +1 -0
- package/dist/chunk-UGELTUIZ.js +830 -0
- package/dist/chunk-UGELTUIZ.js.map +1 -0
- package/dist/chunk-VR36QVX2.js +122 -0
- package/dist/chunk-VR36QVX2.js.map +1 -0
- package/dist/chunk-WUOQK7BO.js +13 -0
- package/dist/chunk-WUOQK7BO.js.map +1 -0
- package/dist/chunk-X6PV5MHG.js +582 -0
- package/dist/chunk-X6PV5MHG.js.map +1 -0
- package/dist/chunk-ZWLMFLLH.js +534 -0
- package/dist/chunk-ZWLMFLLH.js.map +1 -0
- package/dist/content/index.d.ts +309 -0
- package/dist/content/index.js +6 -0
- package/dist/content/index.js.map +1 -0
- package/dist/core/index.d.ts +107 -0
- package/dist/core/index.js +5 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/react.d.ts +107 -0
- package/dist/core/react.js +5 -0
- package/dist/core/react.js.map +1 -0
- package/dist/coupon-CHFcw7cd.d.ts +632 -0
- package/dist/coupon-zGkvO-Xx.d.ts +129 -0
- package/dist/crud.factory-DyKaPHcU.d.ts +181 -0
- package/dist/finance/index.d.ts +81 -0
- package/dist/finance/index.js +5 -0
- package/dist/finance/index.js.map +1 -0
- package/dist/finance-BJdfKRw0.d.ts +135 -0
- package/dist/index.d.ts +31 -0
- package/dist/index.js +29 -0
- package/dist/index.js.map +1 -0
- package/dist/inventory/index.d.ts +512 -0
- package/dist/inventory/index.js +16 -0
- package/dist/inventory/index.js.map +1 -0
- package/dist/inventory-DCiIZh8P.d.ts +742 -0
- package/dist/logistics/index.d.ts +226 -0
- package/dist/logistics/index.js +7 -0
- package/dist/logistics/index.js.map +1 -0
- package/dist/logistics-V8a9lUN3.d.ts +428 -0
- package/dist/media-CNLJK93J.d.ts +721 -0
- package/dist/movement-7MV3ADY5.js +5 -0
- package/dist/movement-7MV3ADY5.js.map +1 -0
- package/dist/payment-BRboLqvU.d.ts +127 -0
- package/dist/payments/index.d.ts +55 -0
- package/dist/payments/index.js +6 -0
- package/dist/payments/index.js.map +1 -0
- package/dist/platform/index.d.ts +645 -0
- package/dist/platform/index.js +8 -0
- package/dist/platform/index.js.map +1 -0
- package/dist/pos-D1jkkFl0.d.ts +885 -0
- package/dist/product-p09zXkXB.d.ts +260 -0
- package/dist/purchase-24BGT2HA.js +5 -0
- package/dist/purchase-24BGT2HA.js.map +1 -0
- package/dist/request-652PS6VR.js +5 -0
- package/dist/request-652PS6VR.js.map +1 -0
- package/dist/sales/index.d.ts +585 -0
- package/dist/sales/index.js +9 -0
- package/dist/sales/index.js.map +1 -0
- package/dist/server.d.ts +120 -0
- package/dist/server.js +27 -0
- package/dist/server.js.map +1 -0
- package/dist/size-guide-DgjzjM5P.d.ts +554 -0
- package/dist/stock-DEApGC-w.d.ts +632 -0
- package/dist/stock-OOUW57VQ.js +5 -0
- package/dist/stock-OOUW57VQ.js.map +1 -0
- package/dist/supplier-OC6JAWV6.js +5 -0
- package/dist/supplier-OC6JAWV6.js.map +1 -0
- package/dist/transaction/index.d.ts +104 -0
- package/dist/transaction/index.js +8 -0
- package/dist/transaction/index.js.map +1 -0
- package/dist/transaction-BTmoHpWh.d.ts +428 -0
- package/dist/transaction-u5oaNuav.d.ts +84 -0
- package/dist/transfer-7SYSH3RG.js +5 -0
- package/dist/transfer-7SYSH3RG.js.map +1 -0
- package/dist/user-data-DdLjAGwO.d.ts +132 -0
- package/package.json +146 -0
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
import { BaseApi } from './chunk-I5TIKUIQ.js';
|
|
2
|
+
import { createCrudHooks } from './chunk-B6MPVOV7.js';
|
|
3
|
+
import { useQuery } from '@tanstack/react-query';
|
|
4
|
+
|
|
5
|
+
// src/transaction/types/transaction.ts
|
|
6
|
+
var TransactionFlow = /* @__PURE__ */ ((TransactionFlow2) => {
|
|
7
|
+
TransactionFlow2["INFLOW"] = "inflow";
|
|
8
|
+
TransactionFlow2["OUTFLOW"] = "outflow";
|
|
9
|
+
return TransactionFlow2;
|
|
10
|
+
})(TransactionFlow || {});
|
|
11
|
+
var TransactionStatus = /* @__PURE__ */ ((TransactionStatus2) => {
|
|
12
|
+
TransactionStatus2["PENDING"] = "pending";
|
|
13
|
+
TransactionStatus2["PAYMENT_INITIATED"] = "payment_initiated";
|
|
14
|
+
TransactionStatus2["PROCESSING"] = "processing";
|
|
15
|
+
TransactionStatus2["REQUIRES_ACTION"] = "requires_action";
|
|
16
|
+
TransactionStatus2["VERIFIED"] = "verified";
|
|
17
|
+
TransactionStatus2["COMPLETED"] = "completed";
|
|
18
|
+
TransactionStatus2["FAILED"] = "failed";
|
|
19
|
+
TransactionStatus2["CANCELLED"] = "cancelled";
|
|
20
|
+
TransactionStatus2["EXPIRED"] = "expired";
|
|
21
|
+
TransactionStatus2["REFUNDED"] = "refunded";
|
|
22
|
+
TransactionStatus2["PARTIALLY_REFUNDED"] = "partially_refunded";
|
|
23
|
+
return TransactionStatus2;
|
|
24
|
+
})(TransactionStatus || {});
|
|
25
|
+
var TransactionCategory = /* @__PURE__ */ ((TransactionCategory2) => {
|
|
26
|
+
TransactionCategory2["ORDER_PURCHASE"] = "order_purchase";
|
|
27
|
+
TransactionCategory2["ORDER_SUBSCRIPTION"] = "order_subscription";
|
|
28
|
+
TransactionCategory2["WHOLESALE_SALE"] = "wholesale_sale";
|
|
29
|
+
TransactionCategory2["PLATFORM_SUBSCRIPTION"] = "platform_subscription";
|
|
30
|
+
TransactionCategory2["CREATOR_SUBSCRIPTION"] = "creator_subscription";
|
|
31
|
+
TransactionCategory2["ENROLLMENT_PURCHASE"] = "enrollment_purchase";
|
|
32
|
+
TransactionCategory2["ENROLLMENT_SUBSCRIPTION"] = "enrollment_subscription";
|
|
33
|
+
TransactionCategory2["INVENTORY_PURCHASE"] = "inventory_purchase";
|
|
34
|
+
TransactionCategory2["PURCHASE_RETURN"] = "purchase_return";
|
|
35
|
+
TransactionCategory2["INVENTORY_LOSS"] = "inventory_loss";
|
|
36
|
+
TransactionCategory2["INVENTORY_ADJUSTMENT"] = "inventory_adjustment";
|
|
37
|
+
TransactionCategory2["COGS"] = "cogs";
|
|
38
|
+
TransactionCategory2["REFUND"] = "refund";
|
|
39
|
+
TransactionCategory2["SUBSCRIPTION"] = "subscription";
|
|
40
|
+
TransactionCategory2["PURCHASE"] = "purchase";
|
|
41
|
+
TransactionCategory2["RENT"] = "rent";
|
|
42
|
+
TransactionCategory2["UTILITIES"] = "utilities";
|
|
43
|
+
TransactionCategory2["EQUIPMENT"] = "equipment";
|
|
44
|
+
TransactionCategory2["SUPPLIES"] = "supplies";
|
|
45
|
+
TransactionCategory2["MAINTENANCE"] = "maintenance";
|
|
46
|
+
TransactionCategory2["MARKETING"] = "marketing";
|
|
47
|
+
TransactionCategory2["OTHER_EXPENSE"] = "other_expense";
|
|
48
|
+
TransactionCategory2["CAPITAL_INJECTION"] = "capital_injection";
|
|
49
|
+
TransactionCategory2["RETAINED_EARNINGS"] = "retained_earnings";
|
|
50
|
+
TransactionCategory2["TIP_INCOME"] = "tip_income";
|
|
51
|
+
TransactionCategory2["OTHER_INCOME"] = "other_income";
|
|
52
|
+
return TransactionCategory2;
|
|
53
|
+
})(TransactionCategory || {});
|
|
54
|
+
var TransactionType = /* @__PURE__ */ ((TransactionType2) => {
|
|
55
|
+
TransactionType2["INCOME"] = "income";
|
|
56
|
+
TransactionType2["EXPENSE"] = "expense";
|
|
57
|
+
return TransactionType2;
|
|
58
|
+
})(TransactionType || {});
|
|
59
|
+
|
|
60
|
+
// src/transaction/api/transaction.ts
|
|
61
|
+
var TransactionApi = class extends BaseApi {
|
|
62
|
+
/**
|
|
63
|
+
* Get Profit & Loss Report
|
|
64
|
+
* Returns income (inflow), expenses (outflow), and net profit for a date range
|
|
65
|
+
*/
|
|
66
|
+
async getProfitLoss(params = {}, options = {}) {
|
|
67
|
+
return this.request("GET", `${this.baseUrl}/reports/profit-loss`, {
|
|
68
|
+
params,
|
|
69
|
+
...options
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* Get Cash Flow Report
|
|
74
|
+
* Returns monthly inflow, outflow, and net trend
|
|
75
|
+
*/
|
|
76
|
+
async getCashFlow(params = {}, options = {}) {
|
|
77
|
+
return this.request("GET", `${this.baseUrl}/reports/cash-flow`, {
|
|
78
|
+
params,
|
|
79
|
+
...options
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Get Category Breakdown
|
|
84
|
+
* Returns top spending/income categories for a date range
|
|
85
|
+
* Filter by flow='inflow' for income categories, flow='outflow' for expense categories
|
|
86
|
+
*/
|
|
87
|
+
async getCategoryReport(params = {}, options = {}) {
|
|
88
|
+
return this.request("GET", `${this.baseUrl}/reports/categories`, {
|
|
89
|
+
params,
|
|
90
|
+
...options
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Get Statement Export
|
|
95
|
+
* Accountant-friendly export with branch + VAT invoice references
|
|
96
|
+
*
|
|
97
|
+
* @param params.format - 'csv' (default) or 'json'
|
|
98
|
+
* @returns CSV blob (format=csv) or StatementResponse (format=json)
|
|
99
|
+
*/
|
|
100
|
+
async getStatement(params = {}, options = {}) {
|
|
101
|
+
if (params.format === "json") {
|
|
102
|
+
return this.request("GET", `${this.baseUrl}/statement`, {
|
|
103
|
+
params,
|
|
104
|
+
...options
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
return this.request("GET", `${this.baseUrl}/statement`, {
|
|
108
|
+
params: { ...params, format: "csv" },
|
|
109
|
+
options: { responseType: "blob", ...options }
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
};
|
|
113
|
+
var transactionApi = new TransactionApi("transactions");
|
|
114
|
+
var transaction_default = transactionApi;
|
|
115
|
+
var TRANSACTION_KEYS = {
|
|
116
|
+
all: ["transactions"],
|
|
117
|
+
lists: () => [...TRANSACTION_KEYS.all, "list"],
|
|
118
|
+
list: (params) => [...TRANSACTION_KEYS.lists(), params],
|
|
119
|
+
details: () => [...TRANSACTION_KEYS.all, "detail"],
|
|
120
|
+
detail: (id) => [...TRANSACTION_KEYS.details(), id],
|
|
121
|
+
// Report keys
|
|
122
|
+
reports: () => [...TRANSACTION_KEYS.all, "reports"],
|
|
123
|
+
profitLoss: (params) => [...TRANSACTION_KEYS.reports(), "profit-loss", params],
|
|
124
|
+
cashFlow: (params) => [...TRANSACTION_KEYS.reports(), "cash-flow", params],
|
|
125
|
+
categories: (params) => [...TRANSACTION_KEYS.reports(), "categories", params],
|
|
126
|
+
statement: (params) => [...TRANSACTION_KEYS.reports(), "statement", params]
|
|
127
|
+
};
|
|
128
|
+
var transactionHooks = createCrudHooks({
|
|
129
|
+
api: transactionApi,
|
|
130
|
+
entityKey: "transactions",
|
|
131
|
+
singular: "Transaction",
|
|
132
|
+
plural: "Transactions",
|
|
133
|
+
defaults: {
|
|
134
|
+
staleTime: 1 * 60 * 1e3
|
|
135
|
+
// 1 minute (transactions change frequently)
|
|
136
|
+
}
|
|
137
|
+
});
|
|
138
|
+
var {
|
|
139
|
+
useList: useTransactions,
|
|
140
|
+
useDetail: useTransactionDetail,
|
|
141
|
+
useActions: useTransactionActions,
|
|
142
|
+
useNavigation: useTransactionNavigation
|
|
143
|
+
} = transactionHooks;
|
|
144
|
+
function useProfitLoss(params, options = {}) {
|
|
145
|
+
return useQuery({
|
|
146
|
+
queryKey: TRANSACTION_KEYS.profitLoss(params),
|
|
147
|
+
queryFn: () => transactionApi.getProfitLoss(params),
|
|
148
|
+
enabled: options.enabled !== false,
|
|
149
|
+
staleTime: options.staleTime ?? 5 * 60 * 1e3
|
|
150
|
+
// 5 minutes
|
|
151
|
+
});
|
|
152
|
+
}
|
|
153
|
+
function useCashFlow(params = {}, options = {}) {
|
|
154
|
+
return useQuery({
|
|
155
|
+
queryKey: TRANSACTION_KEYS.cashFlow(params),
|
|
156
|
+
queryFn: () => transactionApi.getCashFlow(params),
|
|
157
|
+
enabled: options.enabled !== false,
|
|
158
|
+
staleTime: options.staleTime ?? 5 * 60 * 1e3
|
|
159
|
+
// 5 minutes
|
|
160
|
+
});
|
|
161
|
+
}
|
|
162
|
+
function useCategoryReport(params = {}, options = {}) {
|
|
163
|
+
return useQuery({
|
|
164
|
+
queryKey: TRANSACTION_KEYS.categories(params),
|
|
165
|
+
queryFn: () => transactionApi.getCategoryReport(params),
|
|
166
|
+
enabled: options.enabled !== false,
|
|
167
|
+
staleTime: options.staleTime ?? 5 * 60 * 1e3
|
|
168
|
+
// 5 minutes
|
|
169
|
+
});
|
|
170
|
+
}
|
|
171
|
+
function useStatement(params, options = {}) {
|
|
172
|
+
return useQuery({
|
|
173
|
+
queryKey: TRANSACTION_KEYS.statement(params),
|
|
174
|
+
queryFn: () => transactionApi.getStatement({ ...params, format: "json" }),
|
|
175
|
+
enabled: !!params.startDate && !!params.endDate && options.enabled !== false,
|
|
176
|
+
staleTime: options.staleTime ?? 5 * 60 * 1e3
|
|
177
|
+
// 5 minutes
|
|
178
|
+
});
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
export { TRANSACTION_KEYS, TransactionApi, TransactionCategory, TransactionFlow, TransactionStatus, TransactionType, transactionApi, transactionHooks, transaction_default, useCashFlow, useCategoryReport, useProfitLoss, useStatement, useTransactionActions, useTransactionDetail, useTransactionNavigation, useTransactions };
|
|
182
|
+
//# sourceMappingURL=chunk-5ZFW3FEI.js.map
|
|
183
|
+
//# sourceMappingURL=chunk-5ZFW3FEI.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/transaction/types/transaction.ts","../src/transaction/api/transaction.ts","../src/transaction/hooks/transaction.ts"],"names":["TransactionFlow","TransactionStatus","TransactionCategory","TransactionType"],"mappings":"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","file":"chunk-5ZFW3FEI.js","sourcesContent":["/**\n * Transaction Types\n *\n * Transactions track cashflow events across the system.\n * Used by: Orders, POS, Inventory, CRM, HRM, and manual entries.\n *\n * Sources:\n * - modules/transaction/transaction.model.js\n * - common/revenue/enums.js\n * - @classytic/revenue library\n *\n * Key concepts:\n * - `flow`: Direction of money ('inflow' = income, 'outflow' = expense)\n * - `type`: Category of transaction (order_purchase, refund, rent, etc.)\n * - Amounts in smallest unit (paisa for BDT)\n */\n\n// ============================================\n// PAYMENT ENUMS\n// ============================================\n\n/**\n * Payment methods supported by the system\n */\nexport type PaymentMethod =\n | 'cash'\n | 'bkash'\n | 'nagad'\n | 'rocket'\n | 'upay'\n | 'bank_transfer'\n | 'card'\n | 'online'\n | 'manual'\n | 'split'\n | 'cod';\n\nexport type PaymentGatewayType =\n | 'manual'\n | 'stripe'\n | 'sslcommerz'\n | 'bkash'\n | 'nagad';\n\n// ============================================\n// TRANSACTION FLOW (Money Direction)\n// ============================================\n\n/**\n * Transaction Flow - Direction of money movement\n * - inflow: Money coming in (sales, income, capital injection)\n * - outflow: Money going out (expenses, refunds, purchases)\n */\nexport enum TransactionFlow {\n INFLOW = 'inflow',\n OUTFLOW = 'outflow',\n}\n\nexport type TransactionFlowType = 'inflow' | 'outflow';\n\n// ============================================\n// TRANSACTION STATUS\n// ============================================\n\n/**\n * Transaction Status - Payment lifecycle states\n */\nexport enum TransactionStatus {\n PENDING = 'pending',\n PAYMENT_INITIATED = 'payment_initiated',\n PROCESSING = 'processing',\n REQUIRES_ACTION = 'requires_action',\n VERIFIED = 'verified',\n COMPLETED = 'completed',\n FAILED = 'failed',\n CANCELLED = 'cancelled',\n EXPIRED = 'expired',\n REFUNDED = 'refunded',\n PARTIALLY_REFUNDED = 'partially_refunded',\n}\n\nexport type TransactionStatusType =\n | 'pending'\n | 'payment_initiated'\n | 'processing'\n | 'requires_action'\n | 'verified'\n | 'completed'\n | 'failed'\n | 'cancelled'\n | 'expired'\n | 'refunded'\n | 'partially_refunded';\n\n// ============================================\n// TRANSACTION CATEGORIES (type field values)\n// ============================================\n\n/**\n * Transaction Categories\n *\n * The `type` field stores the category for reporting/grouping.\n * Flow is determined by `flow` field, not by category.\n *\n * ┌─────────────────────────────────────────────────────────────────┐\n * │ INFLOW (Income) │ OUTFLOW (Expense) │\n * ├─────────────────────────────────┼───────────────────────────────┤\n * │ order_purchase (POS/Web sales) │ inventory_purchase (stock) │\n * │ wholesale_sale (B2B sales) │ purchase_return (refund recv) │\n * │ capital_injection │ cogs (cost of goods sold) │\n * │ retained_earnings │ rent, utilities, equipment... │\n * │ other_income │ inventory_loss │\n * │ tip_income (optional) │ marketing, maintenance... │\n * │ │ refund (customer refunds) │\n * └─────────────────────────────────┴───────────────────────────────┘\n */\nexport enum TransactionCategory {\n // ============ REVENUE CATEGORIES (INFLOW) ============\n ORDER_PURCHASE = 'order_purchase',\n ORDER_SUBSCRIPTION = 'order_subscription',\n WHOLESALE_SALE = 'wholesale_sale',\n PLATFORM_SUBSCRIPTION = 'platform_subscription',\n CREATOR_SUBSCRIPTION = 'creator_subscription',\n ENROLLMENT_PURCHASE = 'enrollment_purchase',\n ENROLLMENT_SUBSCRIPTION = 'enrollment_subscription',\n\n // ============ INVENTORY CATEGORIES ============\n INVENTORY_PURCHASE = 'inventory_purchase',\n PURCHASE_RETURN = 'purchase_return',\n INVENTORY_LOSS = 'inventory_loss',\n INVENTORY_ADJUSTMENT = 'inventory_adjustment',\n COGS = 'cogs',\n\n // ============ REFUNDS (OUTFLOW) ============\n REFUND = 'refund',\n SUBSCRIPTION = 'subscription',\n PURCHASE = 'purchase',\n\n // ============ OPERATIONAL EXPENSES (OUTFLOW) ============\n RENT = 'rent',\n UTILITIES = 'utilities',\n EQUIPMENT = 'equipment',\n SUPPLIES = 'supplies',\n MAINTENANCE = 'maintenance',\n MARKETING = 'marketing',\n OTHER_EXPENSE = 'other_expense',\n\n // ============ OPERATIONAL INCOME (INFLOW) ============\n CAPITAL_INJECTION = 'capital_injection',\n RETAINED_EARNINGS = 'retained_earnings',\n TIP_INCOME = 'tip_income',\n OTHER_INCOME = 'other_income',\n}\n\nexport type TransactionCategoryType =\n | 'order_purchase'\n | 'order_subscription'\n | 'wholesale_sale'\n | 'platform_subscription'\n | 'creator_subscription'\n | 'enrollment_purchase'\n | 'enrollment_subscription'\n | 'refund'\n | 'subscription'\n | 'purchase'\n | 'inventory_purchase'\n | 'purchase_return'\n | 'inventory_loss'\n | 'inventory_adjustment'\n | 'cogs'\n | 'rent'\n | 'utilities'\n | 'equipment'\n | 'supplies'\n | 'maintenance'\n | 'marketing'\n | 'other_expense'\n | 'capital_injection'\n | 'retained_earnings'\n | 'tip_income'\n | 'other_income';\n\n// ============================================\n// NESTED TYPES\n// ============================================\n\n/**\n * Transaction Split Payment - Individual payment in a split transaction\n * Different from POS SplitPaymentEntry which has additional UI state fields\n */\nexport interface TransactionSplitPayment {\n method: PaymentMethod;\n amount: number;\n reference?: string;\n details?: Record<string, unknown>;\n}\n\n/**\n * Payment Details - For manual/split payments\n */\nexport interface TransactionPaymentDetails {\n walletNumber?: string;\n walletType?: 'personal' | 'merchant';\n trxId?: string;\n bankName?: string;\n accountNumber?: string;\n accountName?: string;\n proofUrl?: string;\n /** Split payment entries (when method is 'split') */\n payments?: TransactionSplitPayment[];\n}\n\n/**\n * Tax type for transactions\n */\nexport type TaxType = 'vat' | 'gst' | 'sales_tax' | 'income_tax' | 'withholding_tax' | 'none';\n\n/**\n * Tax Details for VAT/GST/Sales Tax tracking\n */\nexport interface TransactionTaxDetails {\n /** Tax type: vat, gst, sales_tax, etc. */\n type?: TaxType;\n /** Tax rate as decimal (0.15 = 15%) */\n rate?: number;\n /** Whether prices include tax (BD default: true) */\n isInclusive?: boolean;\n /** Tax jurisdiction code (e.g., 'BD' for Bangladesh) */\n jurisdiction?: string;\n}\n\n/**\n * Gateway Details - Payment provider info\n */\nexport interface TransactionGateway {\n type: PaymentGatewayType | string;\n provider?: string;\n paymentUrl?: string;\n transactionId?: string;\n sessionId?: string;\n paymentIntentId?: string;\n metadata?: Record<string, unknown>;\n}\n\n/**\n * Commission tracking for gateway/marketplace payments\n */\nexport interface TransactionCommission {\n /** Commission rate as decimal */\n rate?: number;\n /** Gross commission amount */\n grossAmount?: number;\n /** Gateway fee rate as decimal */\n gatewayFeeRate?: number;\n /** Gateway fee amount */\n gatewayFeeAmount?: number;\n /** Net commission amount (grossAmount - gatewayFeeAmount) */\n netAmount?: number;\n /** Commission status */\n status?: 'pending' | 'due' | 'paid' | 'waived' | 'reversed';\n /** Commission due date (ISO 8601) */\n dueDate?: string;\n}\n\n/**\n * Webhook tracking\n */\nexport interface TransactionWebhook {\n eventId?: string;\n eventType?: string;\n receivedAt?: string;\n processedAt?: string;\n payload?: Record<string, unknown>;\n}\n\n/**\n * Reconciliation tracking\n */\nexport interface TransactionReconciliation {\n isReconciled?: boolean;\n reconciledAt?: string;\n reconciledBy?: string;\n bankStatementRef?: string;\n}\n\n// ============================================\n// TRANSACTION DOCUMENT\n// ============================================\n\n/**\n * Transaction Document\n *\n * Key fields:\n * - flow: Direction of money (inflow/outflow)\n * - type: Category of transaction (order_purchase, refund, etc.)\n * - amount: Gross amount in smallest unit (paisa)\n * - fee: Platform/gateway fees deducted\n * - tax: VAT/tax portion (informational)\n * - net: amount - fee - tax (derived)\n */\nexport interface Transaction {\n _id: string;\n organizationId?: string;\n\n // ===== CLASSIFICATION =====\n /**\n * Flow direction: 'inflow' (money in) or 'outflow' (money out)\n * Use this for Income/Expense classification in UI\n */\n flow: TransactionFlowType;\n\n /**\n * Transaction category (e.g. 'order_purchase', 'refund', 'rent', 'cogs')\n * Note: Backend stores category in the 'type' field\n */\n type: TransactionCategoryType | string;\n\n /** Transaction status */\n status: TransactionStatusType | string;\n\n // ===== AMOUNTS (in smallest currency unit - paisa for BDT) =====\n /** Gross money that moved (in smallest unit, e.g. paisa) */\n amount: number;\n\n /** Currency code (default: 'BDT') */\n currency?: string;\n\n /** Platform/gateway fees deducted */\n fee?: number;\n\n /** VAT/tax portion (informational, for VAT reporting) */\n tax?: number;\n\n /** Net amount: amount - fee - tax */\n net?: number;\n\n /** Tax details for VAT/GST reporting */\n taxDetails?: TransactionTaxDetails;\n\n // ===== PARTIES =====\n customerId?: string | null;\n handledBy?: string | null;\n\n // ===== PAYMENT =====\n method: PaymentMethod | string;\n gateway?: TransactionGateway;\n paymentDetails?: TransactionPaymentDetails;\n\n // ===== REFERENCES =====\n /** Source model type (Order, Purchase, Manual) - polymorphic reference */\n sourceModel?: 'Order' | 'Purchase' | 'Manual' | string;\n /** Source document ID */\n sourceId?: string;\n /** Related transaction (for refunds linking to original) */\n relatedTransactionId?: string;\n\n // ===== SOURCE & BRANCH =====\n /** Source channel: where the transaction originated */\n source: 'web' | 'pos' | 'api';\n /** Branch reference ID */\n branch?: string;\n /** Branch code for display */\n branchCode?: string;\n\n // ===== COMMISSION & SPLITS =====\n /** Commission tracking for gateway payments */\n commission?: TransactionCommission;\n /** Revenue splits (for marketplace use) */\n splits?: Array<{\n recipientId?: string;\n recipientType?: string;\n type?: string;\n amount?: number;\n status?: string;\n paidAt?: string;\n }>;\n\n // ===== METADATA =====\n metadata?: Record<string, unknown>;\n description?: string;\n notes?: string;\n idempotencyKey?: string;\n webhook?: TransactionWebhook;\n\n // ===== TIMESTAMPS =====\n /** Actual transaction date (when it occurred) */\n date?: string;\n\n // Verification\n verifiedBy?: string;\n verifiedAt?: string;\n\n // Status timestamps\n initiatedAt?: string;\n completedAt?: string;\n paidAt?: string;\n failedAt?: string;\n failureReason?: string;\n\n // Refund tracking\n refundedAt?: string;\n refundedAmount?: number;\n refundReason?: string;\n\n // Reconciliation\n reconciliation?: TransactionReconciliation;\n\n // Standard timestamps\n createdAt: string;\n updatedAt: string;\n\n // ===== VIRTUALS =====\n isPaid?: boolean;\n amountInUnits?: number;\n}\n\n// ============================================\n// PAYLOADS\n// ============================================\n\n/**\n * Payload to create a Manual Transaction (OpEx, CapEx, etc.)\n * Most transactions are system-managed via order/POS flows.\n */\nexport interface CreateTransactionPayload {\n flow: TransactionFlowType;\n type: TransactionCategoryType | string;\n amount: number;\n method?: PaymentMethod | string;\n source?: 'web' | 'pos' | 'api';\n branch?: string;\n branchCode?: string;\n date?: string;\n notes?: string;\n description?: string;\n paymentDetails?: TransactionPaymentDetails;\n taxDetails?: TransactionTaxDetails;\n metadata?: Record<string, unknown>;\n}\n\n/**\n * Payload to update a Transaction (limited fields)\n * Editable correction fields (permissioned)\n */\nexport interface UpdateTransactionPayload {\n flow?: TransactionFlowType;\n type?: TransactionCategoryType | string;\n amount?: number;\n fee?: number;\n tax?: number;\n net?: number;\n method?: PaymentMethod | string;\n paymentDetails?: TransactionPaymentDetails;\n taxDetails?: TransactionTaxDetails;\n branch?: string;\n branchCode?: string;\n source?: 'web' | 'pos' | 'api';\n notes?: string;\n description?: string;\n metadata?: Record<string, unknown>;\n}\n\n// ============================================\n// PAYMENT INTENT (returned with monetization-managed transactions)\n// ============================================\n\n/**\n * Payment Intent - Returned with order/POS transactions\n */\nexport interface PaymentIntent {\n id: string;\n provider: PaymentGatewayType | string;\n status: 'pending' | 'processing' | 'succeeded' | 'failed' | 'cancelled';\n /** Manual payment instructions */\n instructions?: {\n bkash?: string;\n nagad?: string;\n bank?: string;\n reference?: string;\n note?: string;\n };\n /** Stripe SDK client secret */\n clientSecret?: string | null;\n /** Redirect URL for hosted payment pages */\n paymentUrl?: string | null;\n metadata?: Record<string, unknown>;\n}\n\n// ============================================\n// REPORT TYPES\n// ============================================\n\n/**\n * Financial Report Response (Profit & Loss)\n * Uses flow-based totals: inflow (income) vs outflow (expense)\n */\nexport interface FinancialReport {\n /** Total inflow (income) */\n income: number;\n /** Total outflow (expense) */\n expense: number;\n /** Net profit (income - expense) */\n net: number;\n /** Breakdown by category (type field) */\n breakdown: Record<string, number>;\n}\n\n/**\n * Cash Flow Report Response\n * Monthly trend of inflow vs outflow\n */\nexport interface CashFlowReport {\n months: Array<{\n month: string;\n /** Total inflow (income) for the month */\n inflow: number;\n /** Total outflow (expense) for the month */\n outflow: number;\n /** Net cash flow (inflow - outflow) */\n net: number;\n }>;\n}\n\n/**\n * Category Report Response\n */\nexport interface CategoryReport {\n categories: Array<{\n category: string;\n total: number;\n count: number;\n }>;\n}\n\n/**\n * Statement Row (for CSV/JSON export)\n */\nexport interface StatementRow {\n transactionId: string;\n transactionDate: string | null;\n createdAt: string | null;\n status: string;\n /** Flow direction: inflow/outflow */\n flow: string;\n /** Transaction category (type field) */\n type: string;\n source: string;\n branchCode: string | null;\n branchId: string | null;\n method: string;\n /** Gross amount in BDT (converted from paisa) */\n amountBdt: number;\n /** Fee amount in BDT */\n feeBdt?: number;\n /** Tax amount in BDT */\n taxBdt?: number;\n /** Net amount in BDT (amount - fee - tax) */\n netBdt?: number;\n currency: string;\n /** Source model (Order, Purchase, Manual) */\n sourceModel?: string;\n /** Source document ID */\n sourceId?: string | null;\n orderId: string | null;\n orderCustomerName: string | null;\n vatInvoiceNumber: string | null;\n vatSellerBin: string | null;\n paymentReference: string | null;\n narration: string | null;\n}\n\n/**\n * Statement Export Response (JSON format)\n */\nexport interface StatementResponse {\n success: boolean;\n count: number;\n data: StatementRow[];\n}\n\n// ============================================\n// DEPRECATED TYPES (for backwards compatibility)\n// ============================================\n\n/**\n * @deprecated Use TransactionFlow instead. Backend uses flow (inflow/outflow).\n */\nexport enum TransactionType {\n INCOME = 'income',\n EXPENSE = 'expense',\n}\n","/**\n * Transaction API Client\n *\n * Transactions track cashflow events (money in/out) across the system.\n * Used by: Orders, POS, Inventory, CRM, HRM, and manual entries.\n *\n * CRUD (via BaseApi):\n * - getAll(params) - List transactions\n * - getById(id) - Get transaction\n * - create(payload) - Create manual transaction (staff only)\n * - update(id, payload) - Update transaction (limited fields)\n * - delete(id) - Delete transaction (admin/superadmin only)\n *\n * Reports:\n * - getProfitLoss(params) - P&L statement\n * - getCashFlow(params) - Monthly trend\n * - getCategoryReport(params) - Category breakdown\n *\n * Export:\n * - getStatement(params) - CSV/JSON export for accountants\n */\n\nimport { BaseApi } from '../../core/api-factory';\nimport type {\n Transaction,\n CreateTransactionPayload,\n UpdateTransactionPayload,\n FinancialReport,\n CashFlowReport,\n CategoryReport,\n StatementResponse,\n} from '../types/transaction';\n\n/**\n * Statement Query Params\n */\nexport interface StatementParams {\n startDate?: string;\n endDate?: string;\n branchId?: string;\n source?: 'web' | 'pos' | 'api';\n status?: string;\n format?: 'csv' | 'json';\n [key: string]: unknown;\n}\n\n/**\n * Report Query Params\n */\nexport interface ReportParams {\n startDate?: string;\n endDate?: string;\n branchId?: string;\n [key: string]: unknown;\n}\n\nexport interface CashFlowParams {\n months?: number; // 1-12, default: 6\n branchId?: string;\n [key: string]: unknown;\n}\n\nexport interface CategoryParams extends ReportParams {\n flow?: 'inflow' | 'outflow';\n limit?: number; // default: 10\n}\n\nclass TransactionApi extends BaseApi<Transaction, CreateTransactionPayload, UpdateTransactionPayload> {\n\n /**\n * Get Profit & Loss Report\n * Returns income (inflow), expenses (outflow), and net profit for a date range\n */\n async getProfitLoss(params: ReportParams = {}, options = {}) {\n return this.request<FinancialReport>('GET', `${this.baseUrl}/reports/profit-loss`, {\n params,\n ...options,\n });\n }\n\n /**\n * Get Cash Flow Report\n * Returns monthly inflow, outflow, and net trend\n */\n async getCashFlow(params: CashFlowParams = {}, options = {}) {\n return this.request<CashFlowReport>('GET', `${this.baseUrl}/reports/cash-flow`, {\n params,\n ...options,\n });\n }\n\n /**\n * Get Category Breakdown\n * Returns top spending/income categories for a date range\n * Filter by flow='inflow' for income categories, flow='outflow' for expense categories\n */\n async getCategoryReport(params: CategoryParams = {}, options = {}) {\n return this.request<CategoryReport>('GET', `${this.baseUrl}/reports/categories`, {\n params,\n ...options,\n });\n }\n\n /**\n * Get Statement Export\n * Accountant-friendly export with branch + VAT invoice references\n *\n * @param params.format - 'csv' (default) or 'json'\n * @returns CSV blob (format=csv) or StatementResponse (format=json)\n */\n async getStatement(params: StatementParams = {}, options = {}) {\n if (params.format === 'json') {\n return this.request<StatementResponse>('GET', `${this.baseUrl}/statement`, {\n params,\n ...options,\n });\n }\n // For CSV, caller should handle blob response\n return this.request<Blob>('GET', `${this.baseUrl}/statement`, {\n params: { ...params, format: 'csv' },\n options: { responseType: 'blob', ...options },\n });\n }\n}\n\nexport const transactionApi = new TransactionApi('transactions');\nexport { TransactionApi };\nexport default transactionApi;\n","\"use client\";\n\n/**\n * Transaction Hooks\n *\n * React hooks for transaction CRUD operations and reports.\n * Transactions are used across the system for cashflow tracking.\n */\n\nimport { useQuery } from \"@tanstack/react-query\";\nimport { createCrudHooks, type CrudApi } from \"../../core/react\";\nimport { transactionApi } from \"../api/transaction\";\nimport type { Transaction, CreateTransactionPayload, UpdateTransactionPayload } from \"../types/transaction\";\nimport type {\n FinancialReport,\n CashFlowReport,\n CategoryReport,\n StatementResponse,\n} from \"../types/transaction\";\nimport type {\n ReportParams,\n CashFlowParams,\n CategoryParams,\n StatementParams,\n} from \"../api/transaction\";\n\n// Type helper for API compatibility\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype AnyApi = CrudApi<any, any, any>;\n\n// ============================================\n// Query Keys\n// ============================================\n\nexport const TRANSACTION_KEYS = {\n all: [\"transactions\"] as const,\n lists: () => [...TRANSACTION_KEYS.all, \"list\"] as const,\n list: (params: Record<string, unknown>) => [...TRANSACTION_KEYS.lists(), params] as const,\n details: () => [...TRANSACTION_KEYS.all, \"detail\"] as const,\n detail: (id: string) => [...TRANSACTION_KEYS.details(), id] as const,\n // Report keys\n reports: () => [...TRANSACTION_KEYS.all, \"reports\"] as const,\n profitLoss: (params: ReportParams) => [...TRANSACTION_KEYS.reports(), \"profit-loss\", params] as const,\n cashFlow: (params: CashFlowParams) => [...TRANSACTION_KEYS.reports(), \"cash-flow\", params] as const,\n categories: (params: CategoryParams) => [...TRANSACTION_KEYS.reports(), \"categories\", params] as const,\n statement: (params: StatementParams) => [...TRANSACTION_KEYS.reports(), \"statement\", params] as const,\n};\n\n// ============================================\n// CRUD Hooks (via factory)\n// ============================================\n\n/**\n * Transaction CRUD hooks using createCrudHooks factory\n *\n * Provides:\n * - useTransactions: List transactions with filtering/pagination\n * - useTransactionDetail: Get single transaction\n * - useTransactionActions: Create, update, delete mutations\n * - useTransactionNavigation: Navigation between transactions\n */\nexport const transactionHooks = createCrudHooks<Transaction, CreateTransactionPayload, UpdateTransactionPayload>({\n api: transactionApi as AnyApi,\n entityKey: \"transactions\",\n singular: \"Transaction\",\n plural: \"Transactions\",\n defaults: {\n staleTime: 1 * 60 * 1000, // 1 minute (transactions change frequently)\n },\n});\n\nexport const {\n useList: useTransactions,\n useDetail: useTransactionDetail,\n useActions: useTransactionActions,\n useNavigation: useTransactionNavigation,\n} = transactionHooks;\n\n// ============================================\n// Report Hooks\n// ============================================\n\ninterface QueryOptions {\n enabled?: boolean;\n staleTime?: number;\n}\n\n/**\n * Fetch Profit & Loss report\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useProfitLoss({\n * startDate: '2024-01-01',\n * endDate: '2024-12-31',\n * });\n *\n * return (\n * <div>\n * <p>Income: {data?.income}</p>\n * <p>Expense: {data?.expense}</p>\n * <p>Net: {data?.net}</p>\n * </div>\n * );\n * ```\n */\nexport function useProfitLoss(params: ReportParams, options: QueryOptions = {}) {\n return useQuery<FinancialReport>({\n queryKey: TRANSACTION_KEYS.profitLoss(params),\n queryFn: () => transactionApi.getProfitLoss(params),\n enabled: options.enabled !== false,\n staleTime: options.staleTime ?? 5 * 60 * 1000, // 5 minutes\n });\n}\n\n/**\n * Fetch Cash Flow report (monthly trend)\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useCashFlow({ months: 6 });\n *\n * return (\n * <BarChart data={data?.months} />\n * );\n * ```\n */\nexport function useCashFlow(params: CashFlowParams = {}, options: QueryOptions = {}) {\n return useQuery<CashFlowReport>({\n queryKey: TRANSACTION_KEYS.cashFlow(params),\n queryFn: () => transactionApi.getCashFlow(params),\n enabled: options.enabled !== false,\n staleTime: options.staleTime ?? 5 * 60 * 1000, // 5 minutes\n });\n}\n\n/**\n * Fetch Category breakdown report\n *\n * @example\n * ```tsx\n * // Get expense categories\n * const { data } = useCategoryReport({ flow: 'outflow', limit: 10 });\n *\n * return (\n * <PieChart data={data?.categories} />\n * );\n * ```\n */\nexport function useCategoryReport(params: CategoryParams = {}, options: QueryOptions = {}) {\n return useQuery<CategoryReport>({\n queryKey: TRANSACTION_KEYS.categories(params),\n queryFn: () => transactionApi.getCategoryReport(params),\n enabled: options.enabled !== false,\n staleTime: options.staleTime ?? 5 * 60 * 1000, // 5 minutes\n });\n}\n\n/**\n * Fetch Statement export (JSON format)\n *\n * @example\n * ```tsx\n * const { data } = useStatement({\n * startDate: '2024-01-01',\n * endDate: '2024-12-31',\n * format: 'json',\n * });\n *\n * return (\n * <DataTable data={data?.data} />\n * );\n * ```\n */\nexport function useStatement(params: StatementParams, options: QueryOptions = {}) {\n return useQuery<StatementResponse>({\n queryKey: TRANSACTION_KEYS.statement(params),\n queryFn: () => transactionApi.getStatement({ ...params, format: 'json' }) as Promise<StatementResponse>,\n enabled: !!params.startDate && !!params.endDate && options.enabled !== false,\n staleTime: options.staleTime ?? 5 * 60 * 1000, // 5 minutes\n });\n}\n"]}
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import { BaseApi } from './chunk-I5TIKUIQ.js';
|
|
2
|
+
|
|
3
|
+
// src/sales/api/pos.ts
|
|
4
|
+
var PosApi = class extends BaseApi {
|
|
5
|
+
/**
|
|
6
|
+
* Browse products with branch-specific stock
|
|
7
|
+
* GET /api/v1/pos/products
|
|
8
|
+
*/
|
|
9
|
+
async getProducts(options) {
|
|
10
|
+
const { token, ...params } = options;
|
|
11
|
+
return this.request("GET", `${this.config.basePath}/pos/products`, {
|
|
12
|
+
params,
|
|
13
|
+
token
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Fast Lookup by Barcode/SKU
|
|
18
|
+
* GET /api/v1/pos/lookup
|
|
19
|
+
*/
|
|
20
|
+
async lookup(options) {
|
|
21
|
+
const { token, ...params } = options;
|
|
22
|
+
return this.request("GET", `${this.config.basePath}/pos/lookup`, {
|
|
23
|
+
params,
|
|
24
|
+
token
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Create POS Order
|
|
29
|
+
* POST /api/v1/pos/orders
|
|
30
|
+
*/
|
|
31
|
+
async createOrder(options) {
|
|
32
|
+
const { token, data } = options;
|
|
33
|
+
return this.request("POST", `${this.config.basePath}/pos/orders`, {
|
|
34
|
+
data,
|
|
35
|
+
token
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* Get Receipt Data
|
|
40
|
+
* GET /api/v1/pos/orders/:orderId/receipt
|
|
41
|
+
*/
|
|
42
|
+
async getReceipt(options) {
|
|
43
|
+
const { token, orderId } = options;
|
|
44
|
+
return this.request("GET", `${this.config.basePath}/pos/orders/${orderId}/receipt`, {
|
|
45
|
+
token
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Adjust Stock (Quick Adjustment from POS)
|
|
50
|
+
* POST /api/v1/pos/stock/adjust
|
|
51
|
+
*/
|
|
52
|
+
async adjustStock(options) {
|
|
53
|
+
const { token, data } = options;
|
|
54
|
+
return this.request("POST", `${this.config.basePath}/pos/stock/adjust`, {
|
|
55
|
+
data,
|
|
56
|
+
token
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Set stock level directly (POS adjustment alias)
|
|
61
|
+
* POST /api/v1/pos/stock/adjust
|
|
62
|
+
*/
|
|
63
|
+
async setStock(options) {
|
|
64
|
+
const { token, productId, data } = options;
|
|
65
|
+
return this.request("POST", `${this.config.basePath}/pos/stock/adjust`, {
|
|
66
|
+
data: {
|
|
67
|
+
productId,
|
|
68
|
+
quantity: data.quantity,
|
|
69
|
+
variantSku: data.variantSku,
|
|
70
|
+
branchId: data.branchId,
|
|
71
|
+
mode: "set",
|
|
72
|
+
reason: data.reason ?? data.notes
|
|
73
|
+
},
|
|
74
|
+
token
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Bulk adjustments (POS adjustment alias)
|
|
79
|
+
* POST /api/v1/pos/stock/adjust
|
|
80
|
+
*/
|
|
81
|
+
async bulkAdjust(options) {
|
|
82
|
+
const { token, data } = options;
|
|
83
|
+
return this.request("POST", `${this.config.basePath}/pos/stock/adjust`, {
|
|
84
|
+
data,
|
|
85
|
+
token
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
};
|
|
89
|
+
var posApi = new PosApi("pos");
|
|
90
|
+
var pos_default = posApi;
|
|
91
|
+
|
|
92
|
+
export { posApi, pos_default };
|
|
93
|
+
//# sourceMappingURL=chunk-66OQAZSL.js.map
|
|
94
|
+
//# sourceMappingURL=chunk-66OQAZSL.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/sales/api/pos.ts"],"names":[],"mappings":"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","file":"chunk-66OQAZSL.js","sourcesContent":["/**\r\n * POS API Client\r\n *\r\n * Follows BaseApi pattern: all methods accept { token, ...params/data }\r\n */\r\n\r\nimport { BaseApi } from '../../core/api-factory';\r\nimport type {\r\n PosProductsResponse,\r\n PosLookupResponse,\r\n PosOrderPayload,\r\n} from '../types/pos';\r\nimport type {\r\n CreateAdjustmentPayload,\r\n BulkAdjustmentPayload,\r\n} from '../../inventory/types';\r\n\r\nclass PosApi extends BaseApi {\r\n\r\n /**\r\n * Browse products with branch-specific stock\r\n * GET /api/v1/pos/products\r\n */\r\n async getProducts(options: {\r\n token: string;\r\n branchId?: string;\r\n /** Filter by category slug (matches both parent and child categories) */\r\n category?: string;\r\n search?: string;\r\n inStockOnly?: boolean;\r\n lowStockOnly?: boolean;\r\n sort?: string;\r\n after?: string;\r\n limit?: number;\r\n }) {\r\n const { token, ...params } = options;\r\n return this.request<PosProductsResponse>('GET', `${this.config.basePath}/pos/products`, {\r\n params,\r\n token\r\n });\r\n }\r\n\r\n /**\r\n * Fast Lookup by Barcode/SKU\r\n * GET /api/v1/pos/lookup\r\n */\r\n async lookup(options: {\r\n token: string;\r\n code: string;\r\n branchId?: string;\r\n }) {\r\n const { token, ...params } = options;\r\n return this.request<PosLookupResponse>('GET', `${this.config.basePath}/pos/lookup`, {\r\n params,\r\n token\r\n });\r\n }\r\n\r\n /**\r\n * Create POS Order\r\n * POST /api/v1/pos/orders\r\n */\r\n async createOrder(options: {\r\n token: string;\r\n data: PosOrderPayload;\r\n }) {\r\n const { token, data } = options;\r\n return this.request('POST', `${this.config.basePath}/pos/orders`, {\r\n data: data as unknown as Record<string, unknown>,\r\n token\r\n });\r\n }\r\n\r\n /**\r\n * Get Receipt Data\r\n * GET /api/v1/pos/orders/:orderId/receipt\r\n */\r\n async getReceipt(options: {\r\n token: string;\r\n orderId: string;\r\n }) {\r\n const { token, orderId } = options;\r\n return this.request('GET', `${this.config.basePath}/pos/orders/${orderId}/receipt`, {\r\n token\r\n });\r\n }\r\n\r\n /**\r\n * Adjust Stock (Quick Adjustment from POS)\r\n * POST /api/v1/pos/stock/adjust\r\n */\r\n async adjustStock(options: {\r\n token: string;\r\n data: CreateAdjustmentPayload;\r\n }) {\r\n const { token, data } = options;\r\n return this.request('POST', `${this.config.basePath}/pos/stock/adjust`, {\r\n data: data as unknown as Record<string, unknown>,\r\n token\r\n });\r\n }\r\n\r\n /**\r\n * Set stock level directly (POS adjustment alias)\r\n * POST /api/v1/pos/stock/adjust\r\n */\r\n async setStock(options: {\r\n token: string;\r\n productId: string;\r\n data: {\r\n quantity: number;\r\n branchId?: string;\r\n variantSku?: string;\r\n reason?: string;\r\n notes?: string;\r\n };\r\n }) {\r\n const { token, productId, data } = options;\r\n return this.request('POST', `${this.config.basePath}/pos/stock/adjust`, {\r\n data: {\r\n productId,\r\n quantity: data.quantity,\r\n variantSku: data.variantSku,\r\n branchId: data.branchId,\r\n mode: 'set',\r\n reason: data.reason ?? data.notes,\r\n },\r\n token,\r\n });\r\n }\r\n\r\n /**\r\n * Bulk adjustments (POS adjustment alias)\r\n * POST /api/v1/pos/stock/adjust\r\n */\r\n async bulkAdjust(options: {\r\n token: string;\r\n data: BulkAdjustmentPayload;\r\n }) {\r\n const { token, data } = options;\r\n return this.request('POST', `${this.config.basePath}/pos/stock/adjust`, {\r\n data: data as unknown as Record<string, unknown>,\r\n token,\r\n });\r\n }\r\n}\r\n\r\nexport const posApi = new PosApi('pos');\r\nexport default posApi;\r\n"]}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import { BaseApi } from './chunk-I5TIKUIQ.js';
|
|
2
|
+
import { handleApiRequest } from './chunk-VR36QVX2.js';
|
|
3
|
+
|
|
4
|
+
// src/inventory/api/purchase.ts
|
|
5
|
+
var PurchaseApi = class extends BaseApi {
|
|
6
|
+
constructor(config = {}) {
|
|
7
|
+
super("inventory/purchases", config);
|
|
8
|
+
}
|
|
9
|
+
// ==================== Actions (Stripe Pattern) ====================
|
|
10
|
+
/**
|
|
11
|
+
* Perform a purchase action (receive/pay/cancel)
|
|
12
|
+
* POST /inventory/purchases/:id/action
|
|
13
|
+
*/
|
|
14
|
+
async action({
|
|
15
|
+
token,
|
|
16
|
+
id,
|
|
17
|
+
action,
|
|
18
|
+
data = {},
|
|
19
|
+
options = {}
|
|
20
|
+
}) {
|
|
21
|
+
if (!id) {
|
|
22
|
+
throw new Error("Purchase ID is required");
|
|
23
|
+
}
|
|
24
|
+
return handleApiRequest("POST", `${this.baseUrl}/${id}/action`, {
|
|
25
|
+
token,
|
|
26
|
+
body: { action, ...data },
|
|
27
|
+
cache: this.config.cache,
|
|
28
|
+
...options
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Receive a purchase (auto-approves draft and creates stock movements)
|
|
33
|
+
* POST /inventory/purchases/:id/action { action: 'receive' }
|
|
34
|
+
*/
|
|
35
|
+
async receive({
|
|
36
|
+
token,
|
|
37
|
+
id,
|
|
38
|
+
options = {}
|
|
39
|
+
}) {
|
|
40
|
+
return this.action({ token, id, action: "receive", options });
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Record payment for a purchase
|
|
44
|
+
* POST /inventory/purchases/:id/action { action: 'pay', amount, method, reference }
|
|
45
|
+
*/
|
|
46
|
+
async pay({
|
|
47
|
+
token,
|
|
48
|
+
id,
|
|
49
|
+
amount,
|
|
50
|
+
method,
|
|
51
|
+
reference,
|
|
52
|
+
accountNumber,
|
|
53
|
+
walletNumber,
|
|
54
|
+
bankName,
|
|
55
|
+
accountName,
|
|
56
|
+
proofUrl,
|
|
57
|
+
transactionDate,
|
|
58
|
+
notes,
|
|
59
|
+
options = {}
|
|
60
|
+
}) {
|
|
61
|
+
return this.action({
|
|
62
|
+
token,
|
|
63
|
+
id,
|
|
64
|
+
action: "pay",
|
|
65
|
+
data: {
|
|
66
|
+
amount,
|
|
67
|
+
method,
|
|
68
|
+
reference,
|
|
69
|
+
accountNumber,
|
|
70
|
+
walletNumber,
|
|
71
|
+
bankName,
|
|
72
|
+
accountName,
|
|
73
|
+
proofUrl,
|
|
74
|
+
transactionDate,
|
|
75
|
+
notes
|
|
76
|
+
},
|
|
77
|
+
options
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Cancel a purchase (draft or approved only)
|
|
82
|
+
* POST /inventory/purchases/:id/action { action: 'cancel', reason }
|
|
83
|
+
*/
|
|
84
|
+
async cancel({
|
|
85
|
+
token,
|
|
86
|
+
id,
|
|
87
|
+
reason,
|
|
88
|
+
options = {}
|
|
89
|
+
}) {
|
|
90
|
+
return this.action({
|
|
91
|
+
token,
|
|
92
|
+
id,
|
|
93
|
+
action: "cancel",
|
|
94
|
+
data: { reason },
|
|
95
|
+
options
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
// ==================== Legacy Methods (Backward Compatibility) ====================
|
|
99
|
+
/**
|
|
100
|
+
* Record a stock purchase (legacy method)
|
|
101
|
+
* Creates and optionally auto-receives a purchase
|
|
102
|
+
*
|
|
103
|
+
* @deprecated Use create() with autoReceive: true instead
|
|
104
|
+
*/
|
|
105
|
+
async recordPurchase({
|
|
106
|
+
token,
|
|
107
|
+
data,
|
|
108
|
+
options = {}
|
|
109
|
+
}) {
|
|
110
|
+
const payload = { ...data, autoReceive: true };
|
|
111
|
+
return handleApiRequest("POST", this.baseUrl, {
|
|
112
|
+
token,
|
|
113
|
+
body: payload,
|
|
114
|
+
cache: this.config.cache,
|
|
115
|
+
...options
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
};
|
|
119
|
+
var purchaseApi = new PurchaseApi();
|
|
120
|
+
|
|
121
|
+
export { PurchaseApi, purchaseApi };
|
|
122
|
+
//# sourceMappingURL=chunk-6RYGA6MF.js.map
|
|
123
|
+
//# sourceMappingURL=chunk-6RYGA6MF.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/inventory/api/purchase.ts"],"names":[],"mappings":"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","file":"chunk-6RYGA6MF.js","sourcesContent":["/**\r\n * Purchase API - Supplier Invoices & Stock Entry\r\n *\r\n * Base path: /api/v1/inventory/purchases\r\n *\r\n * Purchases are the only official way to bring new inventory into the system.\r\n * They are Head Office only and drive COGS (weighted average cost).\r\n *\r\n * Standard CRUD:\r\n * - create({ token, data }) - Create purchase invoice (draft)\r\n * - getAll({ token, params }) - List purchases with filtering\r\n * - getById({ token, id }) - Get purchase by ID\r\n * - update({ token, id, data }) - Update draft purchase\r\n *\r\n * Actions (Stripe pattern):\r\n * - receive({ token, id }) - Receive purchase (creates stock movements)\r\n * - pay({ token, id, amount, method, reference }) - Record payment\r\n * - cancel({ token, id, reason }) - Cancel draft/approved purchase\r\n */\r\n\r\nimport { BaseApi, type ApiResponse, type PaginatedResponse, type RequestOptions } from \"../../core/api-factory\";\r\nimport { handleApiRequest } from \"../../core/api-handler\";\r\nimport type {\r\n Purchase,\r\n CreatePurchasePayload,\r\n UpdatePurchasePayload,\r\n PurchaseActionType,\r\n StockMovement,\r\n StockEntry,\r\n} from \"../types\";\r\n\r\ntype FetchOptions = Omit<RequestOptions, \"token\" | \"organizationId\">;\r\n\r\nclass PurchaseApi extends BaseApi<Purchase, CreatePurchasePayload, UpdatePurchasePayload> {\r\n constructor(config = {}) {\r\n super(\"inventory/purchases\", config);\r\n }\r\n\r\n // ==================== Actions (Stripe Pattern) ====================\r\n\r\n /**\r\n * Perform a purchase action (receive/pay/cancel)\r\n * POST /inventory/purchases/:id/action\r\n */\r\n async action({\r\n token,\r\n id,\r\n action,\r\n data = {},\r\n options = {},\r\n }: {\r\n token: string;\r\n id: string;\r\n action: PurchaseActionType;\r\n data?: Record<string, unknown>;\r\n options?: FetchOptions;\r\n }): Promise<ApiResponse<Purchase>> {\r\n if (!id) {\r\n throw new Error(\"Purchase ID is required\");\r\n }\r\n\r\n return handleApiRequest(\"POST\", `${this.baseUrl}/${id}/action`, {\r\n token,\r\n body: { action, ...data },\r\n cache: this.config.cache,\r\n ...options,\r\n });\r\n }\r\n\r\n /**\r\n * Receive a purchase (auto-approves draft and creates stock movements)\r\n * POST /inventory/purchases/:id/action { action: 'receive' }\r\n */\r\n async receive({\r\n token,\r\n id,\r\n options = {},\r\n }: {\r\n token: string;\r\n id: string;\r\n options?: FetchOptions;\r\n }): Promise<ApiResponse<Purchase>> {\r\n return this.action({ token, id, action: \"receive\", options });\r\n }\r\n\r\n /**\r\n * Record payment for a purchase\r\n * POST /inventory/purchases/:id/action { action: 'pay', amount, method, reference }\r\n */\r\n async pay({\r\n token,\r\n id,\r\n amount,\r\n method,\r\n reference,\r\n accountNumber,\r\n walletNumber,\r\n bankName,\r\n accountName,\r\n proofUrl,\r\n transactionDate,\r\n notes,\r\n options = {},\r\n }: {\r\n token: string;\r\n id: string;\r\n amount: number;\r\n method: string;\r\n reference?: string;\r\n accountNumber?: string;\r\n walletNumber?: string;\r\n bankName?: string;\r\n accountName?: string;\r\n proofUrl?: string;\r\n transactionDate?: string;\r\n notes?: string;\r\n options?: FetchOptions;\r\n }): Promise<ApiResponse<Purchase>> {\r\n return this.action({\r\n token,\r\n id,\r\n action: \"pay\",\r\n data: {\r\n amount,\r\n method,\r\n reference,\r\n accountNumber,\r\n walletNumber,\r\n bankName,\r\n accountName,\r\n proofUrl,\r\n transactionDate,\r\n notes,\r\n },\r\n options,\r\n });\r\n }\r\n\r\n /**\r\n * Cancel a purchase (draft or approved only)\r\n * POST /inventory/purchases/:id/action { action: 'cancel', reason }\r\n */\r\n async cancel({\r\n token,\r\n id,\r\n reason,\r\n options = {},\r\n }: {\r\n token: string;\r\n id: string;\r\n reason?: string;\r\n options?: FetchOptions;\r\n }): Promise<ApiResponse<Purchase>> {\r\n return this.action({\r\n token,\r\n id,\r\n action: \"cancel\",\r\n data: { reason },\r\n options,\r\n });\r\n }\r\n\r\n // ==================== Legacy Methods (Backward Compatibility) ====================\r\n\r\n /**\r\n * Record a stock purchase (legacy method)\r\n * Creates and optionally auto-receives a purchase\r\n *\r\n * @deprecated Use create() with autoReceive: true instead\r\n */\r\n async recordPurchase({\r\n token,\r\n data,\r\n options = {},\r\n }: {\r\n token: string;\r\n data: CreatePurchasePayload;\r\n options?: FetchOptions;\r\n }): Promise<\r\n ApiResponse<{\r\n stockEntries: StockEntry[];\r\n movements: StockMovement[];\r\n }>\r\n > {\r\n // Set autoReceive to maintain backward compatibility\r\n const payload = { ...data, autoReceive: true };\r\n return handleApiRequest(\"POST\", this.baseUrl, {\r\n token,\r\n body: payload,\r\n cache: this.config.cache,\r\n ...options,\r\n });\r\n }\r\n}\r\n\r\nexport const purchaseApi = new PurchaseApi();\r\nexport { PurchaseApi };\r\n"]}
|