@instockng/api-client 1.0.0 → 1.0.1

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.
Files changed (86) hide show
  1. package/dist/backend-types.d.ts +10 -0
  2. package/dist/backend-types.js +10 -0
  3. package/dist/client.d.ts +20 -0
  4. package/dist/client.js +40 -0
  5. package/dist/fetchers/carts.d.ts +2330 -0
  6. package/dist/fetchers/carts.js +167 -0
  7. package/dist/fetchers/delivery-zones.d.ts +28 -0
  8. package/{src/fetchers/delivery-zones.ts → dist/fetchers/delivery-zones.js} +9 -12
  9. package/{src/fetchers/index.ts → dist/fetchers/index.d.ts} +0 -1
  10. package/dist/fetchers/index.js +21 -0
  11. package/dist/fetchers/orders.d.ts +282 -0
  12. package/dist/fetchers/orders.js +44 -0
  13. package/dist/fetchers/products.d.ts +384 -0
  14. package/dist/fetchers/products.js +42 -0
  15. package/dist/hooks/admin/abandoned-carts.d.ts +533 -0
  16. package/dist/hooks/admin/abandoned-carts.js +79 -0
  17. package/dist/hooks/admin/brands.d.ts +75 -0
  18. package/dist/hooks/admin/brands.js +103 -0
  19. package/dist/hooks/admin/customers.d.ts +277 -0
  20. package/dist/hooks/admin/customers.js +25 -0
  21. package/dist/hooks/admin/delivery-zones.d.ts +266 -0
  22. package/dist/hooks/admin/delivery-zones.js +168 -0
  23. package/dist/hooks/admin/discount-codes.d.ts +294 -0
  24. package/dist/hooks/admin/discount-codes.js +157 -0
  25. package/{src/hooks/admin/index.ts → dist/hooks/admin/index.d.ts} +0 -1
  26. package/dist/hooks/admin/index.js +16 -0
  27. package/dist/hooks/admin/inventory.d.ts +224 -0
  28. package/dist/hooks/admin/inventory.js +102 -0
  29. package/dist/hooks/admin/orders.d.ts +1375 -0
  30. package/dist/hooks/admin/orders.js +169 -0
  31. package/dist/hooks/admin/products.d.ts +372 -0
  32. package/dist/hooks/admin/products.js +84 -0
  33. package/dist/hooks/admin/stats.d.ts +276 -0
  34. package/dist/hooks/admin/stats.js +24 -0
  35. package/dist/hooks/admin/variants.d.ts +115 -0
  36. package/dist/hooks/admin/variants.js +121 -0
  37. package/dist/hooks/admin/warehouses.d.ts +276 -0
  38. package/dist/hooks/admin/warehouses.js +103 -0
  39. package/dist/hooks/public/carts.d.ts +2398 -0
  40. package/dist/hooks/public/carts.js +213 -0
  41. package/dist/hooks/public/delivery-zones.d.ts +34 -0
  42. package/{src/hooks/public/delivery-zones.ts → dist/hooks/public/delivery-zones.js} +6 -12
  43. package/{src/hooks/public/index.ts → dist/hooks/public/index.d.ts} +0 -1
  44. package/dist/hooks/public/index.js +9 -0
  45. package/dist/hooks/public/orders.d.ts +301 -0
  46. package/{src/hooks/public/orders.ts → dist/hooks/public/orders.js} +12 -28
  47. package/dist/hooks/public/products.d.ts +396 -0
  48. package/{src/hooks/public/products.ts → dist/hooks/public/products.js} +12 -22
  49. package/dist/hooks/use-query-unwrapped.d.ts +20 -0
  50. package/dist/hooks/use-query-unwrapped.js +22 -0
  51. package/dist/hooks/useApiConfig.d.ts +11 -0
  52. package/dist/hooks/useApiConfig.js +14 -0
  53. package/dist/index.d.ts +20 -0
  54. package/{src/index.ts → dist/index.js} +0 -17
  55. package/dist/provider.d.ts +33 -0
  56. package/dist/provider.js +52 -0
  57. package/dist/rpc-client.d.ts +8966 -0
  58. package/dist/rpc-client.js +79 -0
  59. package/{src/rpc-types.ts → dist/rpc-types.d.ts} +35 -80
  60. package/dist/rpc-types.js +7 -0
  61. package/{src/types.ts → dist/types.d.ts} +0 -6
  62. package/dist/types.js +16 -0
  63. package/dist/utils/query-keys.d.ts +102 -0
  64. package/dist/utils/query-keys.js +104 -0
  65. package/package.json +20 -13
  66. package/src/client.ts +0 -57
  67. package/src/fetchers/carts.ts +0 -202
  68. package/src/fetchers/orders.ts +0 -48
  69. package/src/fetchers/products.ts +0 -46
  70. package/src/hooks/admin/abandoned-carts.ts +0 -102
  71. package/src/hooks/admin/brands.ts +0 -134
  72. package/src/hooks/admin/customers.ts +0 -31
  73. package/src/hooks/admin/delivery-zones.ts +0 -236
  74. package/src/hooks/admin/discount-codes.ts +0 -222
  75. package/src/hooks/admin/inventory.ts +0 -137
  76. package/src/hooks/admin/orders.ts +0 -229
  77. package/src/hooks/admin/products.ts +0 -116
  78. package/src/hooks/admin/stats.ts +0 -30
  79. package/src/hooks/admin/variants.ts +0 -173
  80. package/src/hooks/admin/warehouses.ts +0 -143
  81. package/src/hooks/public/carts.ts +0 -298
  82. package/src/hooks/use-query-unwrapped.ts +0 -30
  83. package/src/hooks/useApiConfig.ts +0 -22
  84. package/src/provider.tsx +0 -89
  85. package/src/rpc-client.ts +0 -106
  86. package/src/utils/query-keys.ts +0 -121
@@ -0,0 +1,167 @@
1
+ /**
2
+ * Cart fetcher functions
3
+ *
4
+ * These are the actual data-fetching functions used by hooks.
5
+ * They can also be imported directly in Server Components.
6
+ *
7
+ * API URL is hardcoded to https://oms-api.instock.ng
8
+ */
9
+ import { createRpcClients } from '../rpc-client';
10
+ const API_URL = 'https://oms-api.instock.ng';
11
+ /**
12
+ * Fetch a cart by ID
13
+ *
14
+ * @param cartId - Cart UUID
15
+ * @returns Cart with items, brand, and delivery zone
16
+ */
17
+ export async function fetchCart(cartId) {
18
+ const clients = createRpcClients(API_URL);
19
+ const res = await clients.carts[':id'].$get({
20
+ param: { id: cartId },
21
+ });
22
+ if (!res.ok) {
23
+ throw new Error(`Failed to fetch cart: ${res.statusText}`);
24
+ }
25
+ return res.json();
26
+ }
27
+ /**
28
+ * Create a new cart
29
+ *
30
+ * @param brandSlug - Brand slug
31
+ * @returns Newly created cart
32
+ */
33
+ export async function createCart(brandSlug) {
34
+ const clients = createRpcClients(API_URL);
35
+ const res = await clients.carts.index.$post({
36
+ json: { brandSlug },
37
+ });
38
+ if (!res.ok) {
39
+ throw new Error(`Failed to create cart: ${res.statusText}`);
40
+ }
41
+ return res.json();
42
+ }
43
+ /**
44
+ * Update a cart
45
+ *
46
+ * @param cartId - Cart UUID
47
+ * @param data - Cart update data (customer info, deliveryZoneId, etc.)
48
+ * @returns Updated cart
49
+ */
50
+ export async function updateCart(cartId, data) {
51
+ const clients = createRpcClients(API_URL);
52
+ const res = await clients.carts[':id'].$patch({
53
+ param: { id: cartId },
54
+ json: data,
55
+ });
56
+ if (!res.ok) {
57
+ throw new Error(`Failed to update cart: ${res.statusText}`);
58
+ }
59
+ return res.json();
60
+ }
61
+ /**
62
+ * Add an item to cart
63
+ *
64
+ * @param cartId - Cart UUID
65
+ * @param sku - Product variant SKU
66
+ * @param quantity - Quantity to add
67
+ * @returns Updated cart
68
+ */
69
+ export async function addCartItem(cartId, sku, quantity) {
70
+ const clients = createRpcClients(API_URL);
71
+ const res = await clients.carts[':id'].items.$post({
72
+ param: { id: cartId },
73
+ json: { sku, quantity },
74
+ });
75
+ if (!res.ok) {
76
+ throw new Error(`Failed to add item to cart: ${res.statusText}`);
77
+ }
78
+ return res.json();
79
+ }
80
+ /**
81
+ * Update a cart item quantity
82
+ *
83
+ * @param cartId - Cart UUID
84
+ * @param itemId - Cart item UUID
85
+ * @param quantity - New quantity
86
+ * @returns Updated cart
87
+ */
88
+ export async function updateCartItem(cartId, itemId, quantity) {
89
+ const clients = createRpcClients(API_URL);
90
+ const res = await clients.carts[':id'].items[':itemId'].$patch({
91
+ param: { id: cartId, itemId },
92
+ json: { quantity },
93
+ });
94
+ if (!res.ok) {
95
+ throw new Error(`Failed to update cart item: ${res.statusText}`);
96
+ }
97
+ return res.json();
98
+ }
99
+ /**
100
+ * Remove an item from cart
101
+ *
102
+ * @param cartId - Cart UUID
103
+ * @param itemId - Cart item UUID
104
+ * @returns Updated cart
105
+ */
106
+ export async function removeCartItem(cartId, itemId) {
107
+ const clients = createRpcClients(API_URL);
108
+ const res = await clients.carts[':id'].items[':itemId'].$delete({
109
+ param: { id: cartId, itemId },
110
+ });
111
+ if (!res.ok) {
112
+ throw new Error(`Failed to remove cart item: ${res.statusText}`);
113
+ }
114
+ return res.json();
115
+ }
116
+ /**
117
+ * Apply a discount code to cart
118
+ *
119
+ * @param cartId - Cart UUID
120
+ * @param code - Discount code
121
+ * @returns Updated cart
122
+ */
123
+ export async function applyDiscount(cartId, code) {
124
+ const clients = createRpcClients(API_URL);
125
+ const res = await clients.carts[':id']['apply-discount'].$post({
126
+ param: { id: cartId },
127
+ json: { code },
128
+ });
129
+ if (!res.ok) {
130
+ throw new Error(`Failed to apply discount: ${res.statusText}`);
131
+ }
132
+ return res.json();
133
+ }
134
+ /**
135
+ * Remove discount from cart
136
+ *
137
+ * @param cartId - Cart UUID
138
+ * @returns Updated cart
139
+ */
140
+ export async function removeDiscount(cartId) {
141
+ const clients = createRpcClients(API_URL);
142
+ const res = await clients.carts[':id']['remove-discount'].$post({
143
+ param: { id: cartId },
144
+ });
145
+ if (!res.ok) {
146
+ throw new Error(`Failed to remove discount: ${res.statusText}`);
147
+ }
148
+ return res.json();
149
+ }
150
+ /**
151
+ * Checkout a cart
152
+ *
153
+ * @param cartId - Cart UUID
154
+ * @param checkoutData - Checkout information (customer details, delivery, payment)
155
+ * @returns Created order
156
+ */
157
+ export async function checkoutCart(cartId, checkoutData) {
158
+ const clients = createRpcClients(API_URL);
159
+ const res = await clients.carts[':id'].checkout.$post({
160
+ param: { id: cartId },
161
+ json: checkoutData,
162
+ });
163
+ if (!res.ok) {
164
+ throw new Error(`Failed to checkout cart: ${res.statusText}`);
165
+ }
166
+ return res.json();
167
+ }
@@ -0,0 +1,28 @@
1
+ /**
2
+ * Delivery zone fetcher functions
3
+ *
4
+ * These are the actual data-fetching functions used by hooks.
5
+ * They can also be imported directly in Server Components.
6
+ *
7
+ * API URL is hardcoded to https://oms-api.instock.ng
8
+ */
9
+ /**
10
+ * Fetch delivery zones
11
+ *
12
+ * @param brandId - Optional brand UUID to filter brand-specific zones
13
+ * @returns List of delivery zones with states
14
+ */
15
+ export declare function fetchDeliveryZones(brandId?: string): Promise<{
16
+ id: string;
17
+ name: string;
18
+ zones: {
19
+ id: string;
20
+ name: string;
21
+ deliveryCost: number;
22
+ freeShippingThreshold: number;
23
+ allowCOD: boolean;
24
+ allowOnline: boolean;
25
+ waybillOnly: boolean;
26
+ estimatedDays: number;
27
+ }[];
28
+ }[]>;
@@ -6,24 +6,21 @@
6
6
  *
7
7
  * API URL is hardcoded to https://oms-api.instock.ng
8
8
  */
9
-
10
9
  import { createRpcClients } from '../rpc-client';
11
-
12
10
  const API_URL = 'https://oms-api.instock.ng';
13
-
14
11
  /**
15
12
  * Fetch delivery zones
16
13
  *
17
14
  * @param brandId - Optional brand UUID to filter brand-specific zones
18
15
  * @returns List of delivery zones with states
19
16
  */
20
- export async function fetchDeliveryZones(brandId?: string) {
21
- const clients = createRpcClients(API_URL);
22
- const res = await clients.deliveryZones.index.$get({
23
- query: brandId ? { brandId } : {},
24
- });
25
- if (!res.ok) {
26
- throw new Error(`Failed to fetch delivery zones: ${res.statusText}`);
27
- }
28
- return res.json();
17
+ export async function fetchDeliveryZones(brandId) {
18
+ const clients = createRpcClients(API_URL);
19
+ const res = await clients.deliveryZones.index.$get({
20
+ query: brandId ? { brandId } : {},
21
+ });
22
+ if (!res.ok) {
23
+ throw new Error(`Failed to fetch delivery zones: ${res.statusText}`);
24
+ }
25
+ return res.json();
29
26
  }
@@ -15,7 +15,6 @@
15
15
  * }
16
16
  * ```
17
17
  */
18
-
19
18
  export * from './products';
20
19
  export * from './carts';
21
20
  export * from './orders';
@@ -0,0 +1,21 @@
1
+ /**
2
+ * Data fetcher functions for Server Components
3
+ *
4
+ * These functions can be used directly in Next.js Server Components
5
+ * without needing React hooks. They use the same underlying logic
6
+ * as the client-side hooks, ensuring no code duplication.
7
+ *
8
+ * @example Server Component
9
+ * ```tsx
10
+ * import { fetchProductBySlug, fetchCart } from '@oms/api-client/fetchers';
11
+ *
12
+ * export default async function ProductPage({ params }) {
13
+ * const product = await fetchProductBySlug(params.slug);
14
+ * return <div>{product.name}</div>;
15
+ * }
16
+ * ```
17
+ */
18
+ export * from './products';
19
+ export * from './carts';
20
+ export * from './orders';
21
+ export * from './delivery-zones';
@@ -0,0 +1,282 @@
1
+ /**
2
+ * Order fetcher functions
3
+ *
4
+ * These are the actual data-fetching functions used by hooks.
5
+ * They can also be imported directly in Server Components.
6
+ *
7
+ * API URL is hardcoded to https://oms-api.instock.ng
8
+ */
9
+ /**
10
+ * Fetch an order by ID and token
11
+ *
12
+ * @param orderId - Order UUID
13
+ * @param token - User action token
14
+ * @returns Order with items, delivery zone, and brand
15
+ */
16
+ export declare function fetchOrder(orderId: string, token: string): Promise<{
17
+ canConfirm: boolean;
18
+ confirmationMessage: string;
19
+ subtotal: number;
20
+ deliveryCharge: number;
21
+ totalPrice: number;
22
+ discountAmount: number;
23
+ createdAt: string;
24
+ updatedAt: string;
25
+ deletedAt: string;
26
+ prospectSince: string;
27
+ lastRecoveryAttemptAt: string;
28
+ brand: {
29
+ createdAt: string;
30
+ updatedAt: string;
31
+ deletedAt: string;
32
+ name: string;
33
+ id: string;
34
+ slug: string;
35
+ logoUrl: string | null;
36
+ siteUrl: string;
37
+ domain: string;
38
+ };
39
+ deliveryZone: {
40
+ deliveryCost: number;
41
+ freeShippingThreshold: number;
42
+ createdAt: string;
43
+ updatedAt: string;
44
+ deletedAt: string;
45
+ state: {
46
+ createdAt: string;
47
+ updatedAt: string;
48
+ deletedAt: string;
49
+ name: string;
50
+ id: string;
51
+ isActive: boolean;
52
+ };
53
+ name: string;
54
+ id: string;
55
+ brandId: string | null;
56
+ stateId: string;
57
+ allowCOD: boolean;
58
+ allowOnline: boolean;
59
+ waybillOnly: boolean;
60
+ estimatedDays: number | null;
61
+ isActive: boolean;
62
+ };
63
+ items: {
64
+ priceAtPurchase: number;
65
+ variant: {
66
+ price: number;
67
+ createdAt: string;
68
+ updatedAt: string;
69
+ deletedAt: string;
70
+ product: {
71
+ createdAt: string;
72
+ updatedAt: string;
73
+ deletedAt: string;
74
+ name: string;
75
+ id: string;
76
+ slug: string;
77
+ brandId: string;
78
+ isActive: boolean;
79
+ description: string | null;
80
+ thumbnailUrl: string | null;
81
+ quantityDiscounts: string | number | boolean | {
82
+ [x: string]: string | number | boolean | /*elided*/ any | {
83
+ [x: number]: string | number | boolean | /*elided*/ any | /*elided*/ any;
84
+ length: number;
85
+ toString: never;
86
+ toLocaleString: never;
87
+ pop: never;
88
+ push: never;
89
+ concat: never;
90
+ join: never;
91
+ reverse: never;
92
+ shift: never;
93
+ slice: never;
94
+ sort: never;
95
+ splice: never;
96
+ unshift: never;
97
+ indexOf: never;
98
+ lastIndexOf: never;
99
+ every: never;
100
+ some: never;
101
+ forEach: never;
102
+ map: never;
103
+ filter: never;
104
+ reduce: never;
105
+ reduceRight: never;
106
+ find: never;
107
+ findIndex: never;
108
+ fill: never;
109
+ copyWithin: never;
110
+ entries: never;
111
+ keys: never;
112
+ values: never;
113
+ includes: never;
114
+ flatMap: never;
115
+ flat: never;
116
+ [Symbol.iterator]: never;
117
+ readonly [Symbol.unscopables]: {
118
+ [x: number]: boolean;
119
+ length?: boolean;
120
+ toString?: boolean;
121
+ toLocaleString?: boolean;
122
+ pop?: boolean;
123
+ push?: boolean;
124
+ concat?: boolean;
125
+ join?: boolean;
126
+ reverse?: boolean;
127
+ shift?: boolean;
128
+ slice?: boolean;
129
+ sort?: boolean;
130
+ splice?: boolean;
131
+ unshift?: boolean;
132
+ indexOf?: boolean;
133
+ lastIndexOf?: boolean;
134
+ every?: boolean;
135
+ some?: boolean;
136
+ forEach?: boolean;
137
+ map?: boolean;
138
+ filter?: boolean;
139
+ reduce?: boolean;
140
+ reduceRight?: boolean;
141
+ find?: boolean;
142
+ findIndex?: boolean;
143
+ fill?: boolean;
144
+ copyWithin?: boolean;
145
+ entries?: boolean;
146
+ keys?: boolean;
147
+ values?: boolean;
148
+ includes?: boolean;
149
+ flatMap?: boolean;
150
+ flat?: boolean;
151
+ };
152
+ };
153
+ } | {
154
+ [x: number]: string | number | boolean | {
155
+ [x: string]: string | number | boolean | /*elided*/ any | /*elided*/ any;
156
+ } | /*elided*/ any;
157
+ length: number;
158
+ toString: never;
159
+ toLocaleString: never;
160
+ pop: never;
161
+ push: never;
162
+ concat: never;
163
+ join: never;
164
+ reverse: never;
165
+ shift: never;
166
+ slice: never;
167
+ sort: never;
168
+ splice: never;
169
+ unshift: never;
170
+ indexOf: never;
171
+ lastIndexOf: never;
172
+ every: never;
173
+ some: never;
174
+ forEach: never;
175
+ map: never;
176
+ filter: never;
177
+ reduce: never;
178
+ reduceRight: never;
179
+ find: never;
180
+ findIndex: never;
181
+ fill: never;
182
+ copyWithin: never;
183
+ entries: never;
184
+ keys: never;
185
+ values: never;
186
+ includes: never;
187
+ flatMap: never;
188
+ flat: never;
189
+ [Symbol.iterator]: never;
190
+ readonly [Symbol.unscopables]: {
191
+ [x: number]: boolean;
192
+ length?: boolean;
193
+ toString?: boolean;
194
+ toLocaleString?: boolean;
195
+ pop?: boolean;
196
+ push?: boolean;
197
+ concat?: boolean;
198
+ join?: boolean;
199
+ reverse?: boolean;
200
+ shift?: boolean;
201
+ slice?: boolean;
202
+ sort?: boolean;
203
+ splice?: boolean;
204
+ unshift?: boolean;
205
+ indexOf?: boolean;
206
+ lastIndexOf?: boolean;
207
+ every?: boolean;
208
+ some?: boolean;
209
+ forEach?: boolean;
210
+ map?: boolean;
211
+ filter?: boolean;
212
+ reduce?: boolean;
213
+ reduceRight?: boolean;
214
+ find?: boolean;
215
+ findIndex?: boolean;
216
+ fill?: boolean;
217
+ copyWithin?: boolean;
218
+ entries?: boolean;
219
+ keys?: boolean;
220
+ values?: boolean;
221
+ includes?: boolean;
222
+ flatMap?: boolean;
223
+ flat?: boolean;
224
+ };
225
+ };
226
+ };
227
+ name: string | null;
228
+ id: string;
229
+ isActive: boolean;
230
+ thumbnailUrl: string | null;
231
+ productId: string;
232
+ sku: string;
233
+ trackInventory: boolean;
234
+ lowStockThreshold: number | null;
235
+ };
236
+ warehouse: {
237
+ createdAt: string;
238
+ updatedAt: string;
239
+ deletedAt: string;
240
+ name: string;
241
+ id: string;
242
+ isActive: boolean;
243
+ address: string | null;
244
+ city: string | null;
245
+ state: string | null;
246
+ };
247
+ id: string;
248
+ orderId: string;
249
+ variantId: string;
250
+ warehouseId: string | null;
251
+ quantity: number;
252
+ }[];
253
+ id: string;
254
+ email: string | null;
255
+ brandId: string;
256
+ deliveryZoneId: string;
257
+ recoveryAttempts: number;
258
+ recoveryDiscountCodeId: string | null;
259
+ wasRecovered: boolean;
260
+ estimatedDays: number | null;
261
+ orderNumber: number;
262
+ firstName: string;
263
+ lastName: string;
264
+ phone: string;
265
+ address: string;
266
+ city: string;
267
+ discountCodeId: string | null;
268
+ paymentMethod: import("@prisma/client").$Enums.PaymentMethod;
269
+ paystackReference: string | null;
270
+ status: import("@prisma/client").$Enums.OrderStatus;
271
+ cancellationReason: string | null;
272
+ prospectReason: import("@prisma/client").$Enums.ProspectReason | null;
273
+ userActionToken: string;
274
+ }>;
275
+ /**
276
+ * Confirm a prospect order
277
+ *
278
+ * @param orderId - Order UUID
279
+ * @param token - User action token
280
+ * @returns Confirmed order
281
+ */
282
+ export declare function confirmOrder(orderId: string, token: string): Promise<unknown>;
@@ -0,0 +1,44 @@
1
+ /**
2
+ * Order fetcher functions
3
+ *
4
+ * These are the actual data-fetching functions used by hooks.
5
+ * They can also be imported directly in Server Components.
6
+ *
7
+ * API URL is hardcoded to https://oms-api.instock.ng
8
+ */
9
+ import { createRpcClients } from '../rpc-client';
10
+ const API_URL = 'https://oms-api.instock.ng';
11
+ /**
12
+ * Fetch an order by ID and token
13
+ *
14
+ * @param orderId - Order UUID
15
+ * @param token - User action token
16
+ * @returns Order with items, delivery zone, and brand
17
+ */
18
+ export async function fetchOrder(orderId, token) {
19
+ const clients = createRpcClients(API_URL);
20
+ const res = await clients.orders[':id'][':token'].$get({
21
+ param: { id: orderId, token },
22
+ });
23
+ if (!res.ok) {
24
+ throw new Error(`Failed to fetch order: ${res.statusText}`);
25
+ }
26
+ return res.json();
27
+ }
28
+ /**
29
+ * Confirm a prospect order
30
+ *
31
+ * @param orderId - Order UUID
32
+ * @param token - User action token
33
+ * @returns Confirmed order
34
+ */
35
+ export async function confirmOrder(orderId, token) {
36
+ const clients = createRpcClients(API_URL);
37
+ const res = await clients.orders.confirm.$post({
38
+ json: { orderId, token },
39
+ });
40
+ if (!res.ok) {
41
+ throw new Error(`Failed to confirm order: ${res.statusText}`);
42
+ }
43
+ return res.json();
44
+ }