@edgebound/bigcommerce 0.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 (45) hide show
  1. package/dist/bigcommerce.fetcher-D1TyK4y4.d.mts +90 -0
  2. package/dist/bigcommerce.fetcher-D1TyK4y4.d.ts +90 -0
  3. package/dist/chunk-7GBRYAQG.mjs +272 -0
  4. package/dist/chunk-7GBRYAQG.mjs.map +1 -0
  5. package/dist/chunk-CERZFSUE.mjs +20 -0
  6. package/dist/chunk-CERZFSUE.mjs.map +1 -0
  7. package/dist/companies.d.mts +2 -0
  8. package/dist/companies.d.ts +2 -0
  9. package/dist/companies.js +2 -0
  10. package/dist/companies.js.map +1 -0
  11. package/dist/companies.mjs +1 -0
  12. package/dist/companies.mjs.map +1 -0
  13. package/dist/currencies.d.mts +2 -0
  14. package/dist/currencies.d.ts +2 -0
  15. package/dist/currencies.js +2 -0
  16. package/dist/currencies.js.map +1 -0
  17. package/dist/currencies.mjs +1 -0
  18. package/dist/currencies.mjs.map +1 -0
  19. package/dist/customers.d.mts +65 -0
  20. package/dist/customers.d.ts +65 -0
  21. package/dist/customers.js +399 -0
  22. package/dist/customers.js.map +1 -0
  23. package/dist/customers.mjs +107 -0
  24. package/dist/customers.mjs.map +1 -0
  25. package/dist/index.d.mts +29 -0
  26. package/dist/index.d.ts +29 -0
  27. package/dist/index.js +304 -0
  28. package/dist/index.js.map +1 -0
  29. package/dist/index.mjs +37 -0
  30. package/dist/index.mjs.map +1 -0
  31. package/dist/orders.d.mts +416 -0
  32. package/dist/orders.d.ts +416 -0
  33. package/dist/orders.js +608 -0
  34. package/dist/orders.js.map +1 -0
  35. package/dist/orders.mjs +314 -0
  36. package/dist/orders.mjs.map +1 -0
  37. package/dist/products.d.mts +32 -0
  38. package/dist/products.d.ts +32 -0
  39. package/dist/products.js +409 -0
  40. package/dist/products.js.map +1 -0
  41. package/dist/products.mjs +119 -0
  42. package/dist/products.mjs.map +1 -0
  43. package/dist/validation.error-CHLpPYC_.d.mts +14 -0
  44. package/dist/validation.error-CHLpPYC_.d.ts +14 -0
  45. package/package.json +63 -0
package/dist/orders.js ADDED
@@ -0,0 +1,608 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+
30
+ // src/bigcommerce-entities/orders/index.ts
31
+ var orders_exports = {};
32
+ __export(orders_exports, {
33
+ OrderSchema: () => OrderSchema,
34
+ findOrders: () => findOrders,
35
+ getAllOrderProducts: () => getAllOrderProducts,
36
+ getAllOrdersBy: () => getAllOrdersBy,
37
+ getOrder: () => getOrder
38
+ });
39
+ module.exports = __toCommonJS(orders_exports);
40
+
41
+ // src/bigcommerce-entities/orders/find-orders.ts
42
+ var import_effect8 = require("effect");
43
+ var z6 = __toESM(require("zod"));
44
+
45
+ // src/constants.ts
46
+ var import_effect = require("effect");
47
+ var DEFAULT_TIMEOUT_MS = 3e4;
48
+ var API_BASE_URLS = {
49
+ B2B: "https://api-b2b.bigcommerce.com/api",
50
+ REGULAR: "https://api.bigcommerce.com/stores"
51
+ };
52
+ var GET_ORDER_BATCH_SIZE = 250;
53
+ var DEFAULT_RETRY_TIMES = 2;
54
+ var DEFAULT_RETRY_WAIT = 200;
55
+ var DEFAULT_RETRY_SCHEDULE = import_effect.Schedule.exponential(import_effect.Duration.millis(DEFAULT_RETRY_WAIT));
56
+ var RETRY_POLICY_WITH_BACKOFF = import_effect.Schedule.exponential(
57
+ import_effect.Duration.millis(DEFAULT_RETRY_WAIT),
58
+ 2
59
+ ).pipe(import_effect.Schedule.intersect(import_effect.Schedule.recurs(DEFAULT_RETRY_TIMES)));
60
+
61
+ // src/core/bigcommerce.error.ts
62
+ var import_effect2 = require("effect");
63
+ var BigCommerceUnprocessableEntityError = class extends import_effect2.Data.TaggedError(
64
+ "BigCommerceUnprocessableEntityError"
65
+ ) {
66
+ };
67
+ var BigCommerceUnauthorizedError = class extends import_effect2.Data.TaggedError(
68
+ "BigCommerceUnauthorizedError"
69
+ ) {
70
+ };
71
+ var BigCommerceForbiddenError = class extends import_effect2.Data.TaggedError("BigCommerceForbiddenError") {
72
+ };
73
+ var BigCommerceNotFoundError = class extends import_effect2.Data.TaggedError("BigCommerceNotFoundError") {
74
+ };
75
+ var BigCommerceConflictError = class extends import_effect2.Data.TaggedError("BigCommerceConflictError") {
76
+ };
77
+ var BigCommerceConnectionError = class extends import_effect2.Data.TaggedError("BigCommerceConnectionError") {
78
+ };
79
+ var BigCommerceUnknownError = class extends import_effect2.Data.TaggedError("BigCommerceUnknownError") {
80
+ };
81
+ var BigCommerceInvalidResponseError = class extends import_effect2.Data.TaggedError(
82
+ "BigCommerceInvalidResponseError"
83
+ ) {
84
+ };
85
+ var BigCommerceInvalidRequestError = class extends import_effect2.Data.TaggedError(
86
+ "BigCommerceInvalidRequestError"
87
+ ) {
88
+ };
89
+ var BigCommerceParseResponseError = class extends import_effect2.Data.TaggedError(
90
+ "BigCommerceParseResponseError"
91
+ ) {
92
+ };
93
+
94
+ // src/core/bigcommerce.fetcher.ts
95
+ var import_effect3 = require("effect");
96
+ var BigCommerceFetcher = class extends import_effect3.Context.Tag("BigCommerceFetcher")() {
97
+ };
98
+
99
+ // src/core/bigcommerce.fetcher.live.ts
100
+ var import_effect5 = require("effect");
101
+
102
+ // src/core/config.ts
103
+ var import_effect4 = require("effect");
104
+ var NoBigCommerceConfigError = class extends import_effect4.Data.TaggedError("NoBigCommerceConfigError") {
105
+ };
106
+ var BigCommerceConfig = class extends import_effect4.Context.Tag("BigCommerceConfig")() {
107
+ };
108
+ var getBigCommerceConfig = (key) => {
109
+ return import_effect4.Config.nested(import_effect4.Config.string(key), "BIGCOMMERCE").pipe(
110
+ import_effect4.Effect.mapError(() => new NoBigCommerceConfigError({ key }))
111
+ );
112
+ };
113
+ var getBigCommerceTimeout = () => {
114
+ return import_effect4.Config.nested(import_effect4.Config.number("TIMEOUT"), "BIGCOMMERCE").pipe(
115
+ import_effect4.Effect.mapError(() => new NoBigCommerceConfigError({ key: "TIMEOUT" })),
116
+ // Default to 30 seconds if not configured
117
+ import_effect4.Effect.orElse(() => import_effect4.Effect.succeed(DEFAULT_TIMEOUT_MS))
118
+ );
119
+ };
120
+ var BigCommerceConfigLive = import_effect4.Layer.effect(
121
+ BigCommerceConfig,
122
+ import_effect4.Effect.gen(function* () {
123
+ const [storeHash, clientId, clientSecret, accessToken, timeout] = yield* import_effect4.Effect.all([
124
+ getBigCommerceConfig("STORE_HASH"),
125
+ getBigCommerceConfig("CLIENT_ID"),
126
+ getBigCommerceConfig("CLIENT_SECRET"),
127
+ getBigCommerceConfig("ACCESS_TOKEN"),
128
+ getBigCommerceTimeout()
129
+ ]);
130
+ return {
131
+ getStoreHash: import_effect4.Effect.succeed(storeHash),
132
+ getClientId: import_effect4.Effect.succeed(clientId),
133
+ getClientSecret: import_effect4.Effect.succeed(clientSecret),
134
+ getAccessToken: import_effect4.Effect.succeed(accessToken),
135
+ getTimeout: import_effect4.Effect.succeed(timeout)
136
+ };
137
+ })
138
+ );
139
+ var BigCommerceConfigTest = import_effect4.Layer.succeed(BigCommerceConfig, {
140
+ getAccessToken: import_effect4.Effect.succeed("test"),
141
+ getClientId: import_effect4.Effect.succeed("test"),
142
+ getClientSecret: import_effect4.Effect.succeed("test"),
143
+ getStoreHash: import_effect4.Effect.succeed("test"),
144
+ getTimeout: import_effect4.Effect.succeed(DEFAULT_TIMEOUT_MS)
145
+ });
146
+
147
+ // src/core/bigcommerce.fetcher.live.ts
148
+ var BigCommerceStatusCodes = {
149
+ UNAUTHORIZED: 401,
150
+ CONFLICT: 409,
151
+ FORBIDDEN: 403,
152
+ NOT_FOUND: 404,
153
+ UNPROCESSABLE_ENTITY: 422,
154
+ INTERNAL_SERVER_ERROR: 500,
155
+ BAD_GATEWAY: 502,
156
+ SERVICE_UNAVAILABLE: 503,
157
+ GATEWAY_TIMEOUT: 504,
158
+ INVALID_REQUEST: 400
159
+ };
160
+ var BigCommerceFetcherLive = import_effect5.Layer.effect(
161
+ BigCommerceFetcher,
162
+ import_effect5.Effect.gen(function* () {
163
+ const config = yield* BigCommerceConfig;
164
+ const storeHash = yield* config.getStoreHash;
165
+ const accessToken = yield* config.getAccessToken;
166
+ const timeout = yield* config.getTimeout;
167
+ return {
168
+ fetch: (params) => {
169
+ const base = getBase(params);
170
+ const headers = {
171
+ Accept: "application/json",
172
+ "Content-Type": "application/json",
173
+ "x-auth-token": accessToken
174
+ };
175
+ if (params.isB2B) {
176
+ headers["x-store-hash"] = storeHash;
177
+ }
178
+ const url = applyParams(base.replace("[storeHash]", storeHash), params.query);
179
+ return import_effect5.Effect.tryPromise({
180
+ try: () => fetch(url, {
181
+ headers,
182
+ signal: AbortSignal.timeout(timeout),
183
+ method: params.method,
184
+ ...params.body && { body: JSON.stringify(params.body) }
185
+ }),
186
+ catch: (error) => {
187
+ if (error instanceof Error && error.name === "TimeoutError") {
188
+ return new BigCommerceConnectionError({
189
+ message: `Request timeout after ${timeout}ms`,
190
+ type: "timeout"
191
+ });
192
+ }
193
+ if (error instanceof Error && error.name === "AbortError") {
194
+ return new BigCommerceConnectionError({
195
+ message: `Request timeout after ${timeout}ms`,
196
+ type: "timeout"
197
+ });
198
+ }
199
+ return new BigCommerceUnknownError({ cause: error });
200
+ }
201
+ }).pipe(
202
+ import_effect5.Effect.tapError(
203
+ (error) => import_effect5.Effect.logError("Failed to fetch from BigCommerce API", error.cause)
204
+ ),
205
+ import_effect5.Effect.flatMap((response) => transformResponse(response, params.resultSchema))
206
+ );
207
+ }
208
+ };
209
+ })
210
+ );
211
+ var applyParams = (url, params) => {
212
+ const base = new URL(url);
213
+ if (!params) {
214
+ return base;
215
+ }
216
+ for (const [key, value] of Object.entries(params)) {
217
+ base.searchParams.append(key, `${value}`);
218
+ }
219
+ return base;
220
+ };
221
+ var getBase = ({
222
+ isB2B,
223
+ path,
224
+ version
225
+ }) => {
226
+ if (isB2B) {
227
+ return `${API_BASE_URLS.B2B}/${version}/io/${path}`;
228
+ }
229
+ return `${API_BASE_URLS.REGULAR}/[storeHash]/${version}/${path}`;
230
+ };
231
+ function processSuccessResponse(response, schema) {
232
+ return import_effect5.Effect.tryPromise({
233
+ try: () => response.json(),
234
+ catch: (error) => new BigCommerceInvalidResponseError({ cause: error })
235
+ }).pipe(
236
+ import_effect5.Effect.tapError(
237
+ (error) => import_effect5.Effect.logError("Error parsing response from BigCommerce API", error.cause)
238
+ ),
239
+ import_effect5.Effect.tryMap({
240
+ try: (json) => schema.parse(json),
241
+ catch: (error) => new BigCommerceParseResponseError({ error })
242
+ })
243
+ );
244
+ }
245
+ var processErrorResponse = (response) => {
246
+ const code = response.status;
247
+ return import_effect5.Effect.tryPromise({
248
+ try: () => response.json(),
249
+ catch: (error) => new BigCommerceInvalidResponseError({ cause: error })
250
+ }).pipe(
251
+ import_effect5.Effect.tapError((error) => import_effect5.Effect.logError("Error parsing error response", error.cause)),
252
+ import_effect5.Effect.flatMap(
253
+ (errorDetails) => import_effect5.Effect.fail(
254
+ import_effect5.Match.value(code).pipe(
255
+ import_effect5.Match.when(
256
+ BigCommerceStatusCodes.INVALID_REQUEST,
257
+ () => new BigCommerceInvalidRequestError({ errorDetails })
258
+ ),
259
+ import_effect5.Match.when(BigCommerceStatusCodes.UNAUTHORIZED, () => new BigCommerceUnauthorizedError()),
260
+ import_effect5.Match.when(BigCommerceStatusCodes.FORBIDDEN, () => new BigCommerceForbiddenError()),
261
+ import_effect5.Match.when(BigCommerceStatusCodes.NOT_FOUND, () => new BigCommerceNotFoundError()),
262
+ import_effect5.Match.when(
263
+ BigCommerceStatusCodes.CONFLICT,
264
+ () => new BigCommerceConflictError({ details: errorDetails })
265
+ ),
266
+ import_effect5.Match.when(
267
+ BigCommerceStatusCodes.UNPROCESSABLE_ENTITY,
268
+ () => new BigCommerceUnprocessableEntityError({ errorDetails })
269
+ ),
270
+ import_effect5.Match.when(
271
+ (code2) => code2 >= 500,
272
+ () => new BigCommerceConnectionError({
273
+ message: `Server error: ${code}`,
274
+ type: code === BigCommerceStatusCodes.INTERNAL_SERVER_ERROR ? "internalError" : code === BigCommerceStatusCodes.BAD_GATEWAY || code === BigCommerceStatusCodes.GATEWAY_TIMEOUT ? "timeout" : "internalError"
275
+ })
276
+ ),
277
+ import_effect5.Match.orElse(() => new BigCommerceUnknownError({ cause: errorDetails }))
278
+ )
279
+ )
280
+ )
281
+ );
282
+ };
283
+ var transformResponse = (response, schema) => {
284
+ if (response.ok) {
285
+ return processSuccessResponse(response, schema);
286
+ }
287
+ return processErrorResponse(response);
288
+ };
289
+
290
+ // src/validation/index.ts
291
+ var import_effect7 = require("effect");
292
+
293
+ // src/validation/validation.error.ts
294
+ var import_effect6 = require("effect");
295
+ var InputValidationError = class extends import_effect6.Data.TaggedError("InputValidationError") {
296
+ };
297
+
298
+ // src/validation/index.ts
299
+ var validateInput = (schema, data) => {
300
+ return import_effect7.Effect.try({
301
+ try: () => schema.parse(data),
302
+ catch: (error) => new InputValidationError({ input: data, error })
303
+ });
304
+ };
305
+
306
+ // src/bigcommerce-entities/orders/schemas/order.schema.ts
307
+ var z4 = __toESM(require("zod"));
308
+
309
+ // src/bigcommerce-entities/addresses/schemas/address.schema.ts
310
+ var z2 = __toESM(require("zod"));
311
+
312
+ // src/bigcommerce-entities/addresses/schemas/form-field.schema.ts
313
+ var z = __toESM(require("zod"));
314
+ var AddressFormFieldSchema = z.object({
315
+ name: z.string(),
316
+ value: z.string()
317
+ });
318
+
319
+ // src/bigcommerce-entities/addresses/schemas/address.schema.ts
320
+ var AddressSchema = z2.object({
321
+ first_name: z2.string(),
322
+ last_name: z2.string(),
323
+ company: z2.string(),
324
+ street_1: z2.string(),
325
+ street_2: z2.string(),
326
+ city: z2.string(),
327
+ state: z2.string(),
328
+ zip: z2.string(),
329
+ country: z2.string(),
330
+ country_iso2: z2.string(),
331
+ phone: z2.string(),
332
+ email: z2.string(),
333
+ form_fields: z2.array(AddressFormFieldSchema)
334
+ });
335
+
336
+ // src/bigcommerce-entities/orders/schemas/status.schema.ts
337
+ var z3 = __toESM(require("zod"));
338
+ var OrderStatusNameEnumSchema = z3.enum([
339
+ "Incomplete",
340
+ "Pending",
341
+ "Shipped",
342
+ "Partially Shipped",
343
+ "Refunded",
344
+ "Cancelled",
345
+ "Declined",
346
+ "Awaiting Payment",
347
+ "Awaiting Pickup",
348
+ "Awaiting Shipment",
349
+ "Completed",
350
+ "Awaiting Fulfillment",
351
+ "Manual Verification Required",
352
+ "Disputed",
353
+ "Partially Refunded"
354
+ ]);
355
+ var OrderStatusEnum = /* @__PURE__ */ ((OrderStatusEnum2) => {
356
+ OrderStatusEnum2[OrderStatusEnum2["Incomplete"] = 0] = "Incomplete";
357
+ OrderStatusEnum2[OrderStatusEnum2["Pending"] = 1] = "Pending";
358
+ OrderStatusEnum2[OrderStatusEnum2["Shipped"] = 2] = "Shipped";
359
+ OrderStatusEnum2[OrderStatusEnum2["PartiallyShipped"] = 3] = "PartiallyShipped";
360
+ OrderStatusEnum2[OrderStatusEnum2["Refunded"] = 4] = "Refunded";
361
+ OrderStatusEnum2[OrderStatusEnum2["Cancelled"] = 5] = "Cancelled";
362
+ OrderStatusEnum2[OrderStatusEnum2["Declined"] = 6] = "Declined";
363
+ OrderStatusEnum2[OrderStatusEnum2["AwaitingPayment"] = 7] = "AwaitingPayment";
364
+ OrderStatusEnum2[OrderStatusEnum2["AwaitingPickup"] = 8] = "AwaitingPickup";
365
+ OrderStatusEnum2[OrderStatusEnum2["AwaitingShipment"] = 9] = "AwaitingShipment";
366
+ OrderStatusEnum2[OrderStatusEnum2["Completed"] = 10] = "Completed";
367
+ OrderStatusEnum2[OrderStatusEnum2["AwaitingFulfillment"] = 11] = "AwaitingFulfillment";
368
+ OrderStatusEnum2[OrderStatusEnum2["ManualVerificationRequired"] = 12] = "ManualVerificationRequired";
369
+ OrderStatusEnum2[OrderStatusEnum2["Disputed"] = 13] = "Disputed";
370
+ OrderStatusEnum2[OrderStatusEnum2["PartiallyRefunded"] = 14] = "PartiallyRefunded";
371
+ return OrderStatusEnum2;
372
+ })(OrderStatusEnum || {});
373
+ var OrderStatusSchema = z3.enum(OrderStatusEnum);
374
+
375
+ // src/bigcommerce-entities/orders/schemas/order.schema.ts
376
+ var OrderSchema = z4.object({
377
+ id: z4.number(),
378
+ customer_id: z4.number(),
379
+ date_created: z4.string(),
380
+ is_tax_inclusive_pricing: z4.boolean(),
381
+ date_modified: z4.string(),
382
+ date_shipped: z4.string(),
383
+ status_id: z4.number(),
384
+ status: OrderStatusNameEnumSchema,
385
+ subtotal_ex_tax: z4.string(),
386
+ subtotal_inc_tax: z4.string(),
387
+ subtotal_tax: z4.string(),
388
+ base_shipping_cost: z4.string(),
389
+ shipping_cost_ex_tax: z4.string(),
390
+ shipping_cost_inc_tax: z4.string(),
391
+ shipping_cost_tax: z4.string(),
392
+ shipping_cost_tax_class_id: z4.number(),
393
+ base_handling_cost: z4.string(),
394
+ handling_cost_ex_tax: z4.string(),
395
+ handling_cost_inc_tax: z4.string(),
396
+ handling_cost_tax: z4.string(),
397
+ handling_cost_tax_class_id: z4.number(),
398
+ base_wrapping_cost: z4.string(),
399
+ wrapping_cost_ex_tax: z4.string(),
400
+ wrapping_cost_inc_tax: z4.string(),
401
+ wrapping_cost_tax: z4.string(),
402
+ wrapping_cost_tax_class_id: z4.number(),
403
+ total_ex_tax: z4.string(),
404
+ total_inc_tax: z4.string(),
405
+ total_tax: z4.string(),
406
+ items_total: z4.number(),
407
+ items_shipped: z4.number(),
408
+ payment_method: z4.string(),
409
+ payment_provider_id: z4.string(),
410
+ payment_status: z4.string(),
411
+ refunded_amount: z4.string(),
412
+ order_is_digital: z4.boolean(),
413
+ store_credit_amount: z4.string(),
414
+ gift_certificate_amount: z4.string(),
415
+ ip_address: z4.string(),
416
+ ip_address_v6: z4.string(),
417
+ geoip_country: z4.string(),
418
+ geoip_country_iso2: z4.string(),
419
+ currency_id: z4.number(),
420
+ currency_code: z4.string(),
421
+ currency_exchange_rate: z4.string(),
422
+ default_currency_id: z4.number(),
423
+ default_currency_code: z4.string(),
424
+ staff_notes: z4.string(),
425
+ customer_message: z4.string(),
426
+ discount_amount: z4.string(),
427
+ coupon_discount: z4.string(),
428
+ shipping_address_count: z4.number(),
429
+ is_deleted: z4.boolean(),
430
+ ebay_order_id: z4.string(),
431
+ cart_id: z4.string(),
432
+ billing_address: AddressSchema,
433
+ is_email_opt_in: z4.boolean(),
434
+ order_source: z4.string(),
435
+ channel_id: z4.number(),
436
+ external_source: z4.string(),
437
+ external_id: z4.string().nullable(),
438
+ tax_provider_id: z4.string(),
439
+ customer_locale: z4.string(),
440
+ external_order_id: z4.string().nullable(),
441
+ store_default_currency_code: z4.string(),
442
+ store_default_to_transactional_exchange_rate: z4.string(),
443
+ custom_status: z4.string()
444
+ });
445
+
446
+ // src/bigcommerce-entities/orders/schemas/find-orders.criteria.ts
447
+ var z5 = __toESM(require("zod"));
448
+ var FindOrdersCriteriaSchema = z5.object({
449
+ customer_id: z5.string().optional(),
450
+ email: z5.string().optional(),
451
+ status_id: z5.number().optional(),
452
+ cart_id: z5.string().optional(),
453
+ payment_method: z5.string().optional(),
454
+ min_date_created: z5.iso.datetime({ offset: true }).optional(),
455
+ max_date_created: z5.iso.datetime({ offset: true }).optional(),
456
+ min_date_modified: z5.iso.datetime({ offset: true }).optional(),
457
+ max_date_modified: z5.iso.datetime({ offset: true }).optional(),
458
+ page: z5.number().min(1).optional(),
459
+ limit: z5.number().min(1).max(GET_ORDER_BATCH_SIZE).optional(),
460
+ // Allowed: id | customer_id | date_created | date_modified | status_id | channel_id | external_id;
461
+ sort: z5.string().optional(),
462
+ channel_id: z5.int().optional()
463
+ });
464
+
465
+ // src/bigcommerce-entities/orders/find-orders.ts
466
+ var OrderArraySchema = z6.union([z6.array(OrderSchema), z6.literal(""), z6.literal(null)]);
467
+ var findOrders = (criteria) => {
468
+ return import_effect8.Effect.gen(function* () {
469
+ const fetcher = yield* BigCommerceFetcher;
470
+ const validatedResponse = yield* validateInput(FindOrdersCriteriaSchema, criteria ?? {});
471
+ const query = {};
472
+ for (const [key, value] of Object.entries(validatedResponse)) {
473
+ if (value !== void 0) {
474
+ query[key] = `${value}`;
475
+ }
476
+ }
477
+ const orders = yield* fetcher.fetch({
478
+ query,
479
+ isB2B: false,
480
+ method: "GET",
481
+ path: "orders",
482
+ version: "v2",
483
+ resultSchema: OrderArraySchema
484
+ });
485
+ return orders || [];
486
+ });
487
+ };
488
+ var getAllOrdersBy = (criteria) => {
489
+ return import_effect8.Effect.gen(function* () {
490
+ const allOrders = [];
491
+ let page = 1;
492
+ let hasMoreOrders = true;
493
+ while (hasMoreOrders) {
494
+ const orders = yield* findOrders({
495
+ ...criteria,
496
+ page,
497
+ limit: GET_ORDER_BATCH_SIZE
498
+ });
499
+ if (orders.length === 0) {
500
+ hasMoreOrders = false;
501
+ } else {
502
+ allOrders.push(...orders);
503
+ page++;
504
+ }
505
+ }
506
+ return allOrders;
507
+ });
508
+ };
509
+
510
+ // src/bigcommerce-entities/orders/get-order.ts
511
+ var import_effect9 = require("effect");
512
+ var getOrder = (orderId) => {
513
+ return import_effect9.Effect.gen(function* () {
514
+ const fetcher = yield* BigCommerceFetcher;
515
+ return yield* fetcher.fetch({
516
+ isB2B: false,
517
+ method: "GET",
518
+ path: `orders/${orderId}`,
519
+ resultSchema: OrderSchema,
520
+ version: "v2"
521
+ });
522
+ });
523
+ };
524
+
525
+ // src/bigcommerce-entities/orders/get-products.ts
526
+ var import_effect10 = require("effect");
527
+ var z8 = __toESM(require("zod"));
528
+
529
+ // src/bigcommerce-entities/orders/schemas/order-product.schema.ts
530
+ var z7 = __toESM(require("zod"));
531
+ var OrderProductSchema = z7.object({
532
+ id: z7.int(),
533
+ order_id: z7.int(),
534
+ product_id: z7.int(),
535
+ variant_id: z7.int(),
536
+ order_address_id: z7.int(),
537
+ sku: z7.string(),
538
+ type: z7.enum(["physical", "digital"]),
539
+ base_price: z7.coerce.number(),
540
+ price_ex_tax: z7.coerce.number(),
541
+ price_inc_tax: z7.coerce.number(),
542
+ price_tax: z7.coerce.number(),
543
+ base_total: z7.coerce.number(),
544
+ total_ex_tax: z7.coerce.number(),
545
+ total_inc_tax: z7.coerce.number(),
546
+ total_tax: z7.coerce.number(),
547
+ weight: z7.coerce.number(),
548
+ width: z7.coerce.number(),
549
+ height: z7.coerce.number(),
550
+ depth: z7.coerce.number(),
551
+ quantity: z7.int(),
552
+ base_cost_price: z7.coerce.number(),
553
+ cost_price_inc_tax: z7.coerce.number(),
554
+ cost_price_ex_tax: z7.coerce.number(),
555
+ cost_price_tax: z7.coerce.number()
556
+ });
557
+
558
+ // src/bigcommerce-entities/orders/get-products.ts
559
+ var getOrderProducts = ({
560
+ orderId,
561
+ limit = GET_ORDER_BATCH_SIZE,
562
+ page
563
+ }) => {
564
+ return import_effect10.Effect.gen(function* () {
565
+ const fetcher = yield* BigCommerceFetcher;
566
+ return yield* fetcher.fetch({
567
+ method: "GET",
568
+ path: `orders/${orderId}/products`,
569
+ isB2B: false,
570
+ version: "v2",
571
+ resultSchema: z8.union([z8.array(OrderProductSchema), z8.literal(""), z8.literal(null)]),
572
+ query: {
573
+ limit: `${limit}`,
574
+ page: `${page}`
575
+ }
576
+ });
577
+ }).pipe(import_effect10.Effect.map((arr) => arr || []));
578
+ };
579
+ var getAllOrderProducts = (orderId) => {
580
+ return import_effect10.Effect.gen(function* () {
581
+ const all = [];
582
+ let page = 1;
583
+ let hasMore = true;
584
+ while (hasMore) {
585
+ const result = yield* getOrderProducts({
586
+ orderId,
587
+ page,
588
+ limit: GET_ORDER_BATCH_SIZE
589
+ });
590
+ if (result.length) {
591
+ all.push(...result);
592
+ page++;
593
+ } else {
594
+ hasMore = false;
595
+ }
596
+ }
597
+ return all;
598
+ });
599
+ };
600
+ // Annotate the CommonJS export names for ESM import in node:
601
+ 0 && (module.exports = {
602
+ OrderSchema,
603
+ findOrders,
604
+ getAllOrderProducts,
605
+ getAllOrdersBy,
606
+ getOrder
607
+ });
608
+ //# sourceMappingURL=orders.js.map