@edgebound/bigcommerce 0.1.3 → 0.2.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.
Files changed (61) hide show
  1. package/dist/addresses.d.mts +27 -0
  2. package/dist/addresses.d.ts +27 -0
  3. package/dist/addresses.js +69 -0
  4. package/dist/addresses.js.map +1 -0
  5. package/dist/addresses.mjs +9 -0
  6. package/dist/addresses.mjs.map +1 -0
  7. package/dist/{bigcommerce.fetcher-D1TyK4y4.d.mts → bigcommerce.fetcher-Ujztbs8P.d.mts} +2 -2
  8. package/dist/{bigcommerce.fetcher-D1TyK4y4.d.ts → bigcommerce.fetcher-Ujztbs8P.d.ts} +2 -2
  9. package/dist/{chunk-V2AKD2LM.mjs → chunk-2VMEIQCL.mjs} +63 -27
  10. package/dist/chunk-2VMEIQCL.mjs.map +1 -0
  11. package/dist/chunk-BWLQCNNX.mjs +30 -0
  12. package/dist/chunk-BWLQCNNX.mjs.map +1 -0
  13. package/dist/companies.d.mts +230 -1
  14. package/dist/companies.d.ts +230 -1
  15. package/dist/companies.js +723 -0
  16. package/dist/companies.js.map +1 -1
  17. package/dist/companies.mjs +367 -0
  18. package/dist/companies.mjs.map +1 -1
  19. package/dist/customers.d.mts +95 -2
  20. package/dist/customers.d.ts +95 -2
  21. package/dist/customers.js +245 -63
  22. package/dist/customers.js.map +1 -1
  23. package/dist/customers.mjs +172 -46
  24. package/dist/customers.mjs.map +1 -1
  25. package/dist/index.d.mts +2 -2
  26. package/dist/index.d.ts +2 -2
  27. package/dist/index.js +61 -17
  28. package/dist/index.js.map +1 -1
  29. package/dist/index.mjs +1 -1
  30. package/dist/orders.d.mts +1323 -2
  31. package/dist/orders.d.ts +1323 -2
  32. package/dist/orders.js +283 -181
  33. package/dist/orders.js.map +1 -1
  34. package/dist/orders.mjs +193 -166
  35. package/dist/orders.mjs.map +1 -1
  36. package/dist/payments.d.mts +28 -0
  37. package/dist/payments.d.ts +28 -0
  38. package/dist/payments.js +365 -0
  39. package/dist/payments.js.map +1 -0
  40. package/dist/payments.mjs +43 -0
  41. package/dist/payments.mjs.map +1 -0
  42. package/dist/priceLists.d.mts +81 -0
  43. package/dist/priceLists.d.ts +81 -0
  44. package/dist/priceLists.js +458 -0
  45. package/dist/priceLists.js.map +1 -0
  46. package/dist/priceLists.mjs +118 -0
  47. package/dist/priceLists.mjs.map +1 -0
  48. package/dist/products.d.mts +29 -7
  49. package/dist/products.d.ts +29 -7
  50. package/dist/products.js +114 -60
  51. package/dist/products.js.map +1 -1
  52. package/dist/products.mjs +26 -25
  53. package/dist/products.mjs.map +1 -1
  54. package/dist/salesStaff.d.mts +64 -0
  55. package/dist/salesStaff.d.ts +64 -0
  56. package/dist/salesStaff.js +419 -0
  57. package/dist/salesStaff.js.map +1 -0
  58. package/dist/salesStaff.mjs +82 -0
  59. package/dist/salesStaff.mjs.map +1 -0
  60. package/package.json +38 -15
  61. package/dist/chunk-V2AKD2LM.mjs.map +0 -1
@@ -0,0 +1,81 @@
1
+ import { I as InputValidationError } from './validation.error-CHLpPYC_.mjs';
2
+ import { S as SomeBigCommerceError, B as BigCommerceFetcher } from './bigcommerce.fetcher-Ujztbs8P.mjs';
3
+ import { Effect } from 'effect';
4
+ import * as z from 'zod';
5
+ import 'effect/Cause';
6
+ import 'effect/Types';
7
+
8
+ declare const CreatePriceListSchema: z.ZodObject<{
9
+ name: z.ZodString;
10
+ active: z.ZodBoolean;
11
+ }, z.core.$strip>;
12
+ declare const CreatePriceListResponseSchema: z.ZodObject<{
13
+ data: z.ZodObject<{
14
+ id: z.ZodInt;
15
+ }, z.core.$strip>;
16
+ }, z.core.$strip>;
17
+
18
+ declare const createPriceList: (data: z.input<typeof CreatePriceListSchema>) => Effect.Effect<{
19
+ data: {
20
+ id: number;
21
+ };
22
+ }, SomeBigCommerceError | InputValidationError, BigCommerceFetcher>;
23
+
24
+ declare const PriceListSchema: z.ZodObject<{
25
+ id: z.ZodInt;
26
+ name: z.ZodString;
27
+ date_created: z.ZodString;
28
+ date_modified: z.ZodString;
29
+ active: z.ZodBoolean;
30
+ }, z.core.$strip>;
31
+ declare const GetPriceListsResponseSchema: z.ZodObject<{
32
+ data: z.ZodArray<z.ZodObject<{
33
+ id: z.ZodInt;
34
+ name: z.ZodString;
35
+ date_created: z.ZodString;
36
+ date_modified: z.ZodString;
37
+ active: z.ZodBoolean;
38
+ }, z.core.$strip>>;
39
+ meta: z.ZodObject<{
40
+ pagination: z.ZodObject<{
41
+ total: z.ZodInt;
42
+ count: z.ZodInt;
43
+ per_page: z.ZodInt;
44
+ current_page: z.ZodInt;
45
+ total_pages: z.ZodInt;
46
+ }, z.core.$strip>;
47
+ }, z.core.$strip>;
48
+ }, z.core.$strip>;
49
+ declare const GetPriceListsCriteriaSchema: z.ZodObject<{
50
+ page: z.ZodOptional<z.ZodInt>;
51
+ limit: z.ZodOptional<z.ZodInt>;
52
+ 'id:in': z.ZodOptional<z.ZodPipe<z.ZodArray<z.ZodInt>, z.ZodTransform<string, number[]>>>;
53
+ }, z.core.$strip>;
54
+
55
+ declare const findPriceLists: (criteria?: z.input<typeof GetPriceListsCriteriaSchema>) => Effect.Effect<{
56
+ data: {
57
+ id: number;
58
+ name: string;
59
+ date_created: string;
60
+ date_modified: string;
61
+ active: boolean;
62
+ }[];
63
+ meta: {
64
+ pagination: {
65
+ total: number;
66
+ count: number;
67
+ per_page: number;
68
+ current_page: number;
69
+ total_pages: number;
70
+ };
71
+ };
72
+ }, SomeBigCommerceError | InputValidationError, BigCommerceFetcher>;
73
+ declare const getAllPriceListsBy: (criteria?: Omit<z.input<typeof GetPriceListsCriteriaSchema>, "limit" | "page">) => Effect.Effect<{
74
+ id: number;
75
+ name: string;
76
+ date_created: string;
77
+ date_modified: string;
78
+ active: boolean;
79
+ }[], SomeBigCommerceError | InputValidationError, BigCommerceFetcher>;
80
+
81
+ export { CreatePriceListResponseSchema, CreatePriceListSchema, GetPriceListsCriteriaSchema, GetPriceListsResponseSchema, PriceListSchema, createPriceList, findPriceLists, getAllPriceListsBy };
@@ -0,0 +1,81 @@
1
+ import { I as InputValidationError } from './validation.error-CHLpPYC_.js';
2
+ import { S as SomeBigCommerceError, B as BigCommerceFetcher } from './bigcommerce.fetcher-Ujztbs8P.js';
3
+ import { Effect } from 'effect';
4
+ import * as z from 'zod';
5
+ import 'effect/Cause';
6
+ import 'effect/Types';
7
+
8
+ declare const CreatePriceListSchema: z.ZodObject<{
9
+ name: z.ZodString;
10
+ active: z.ZodBoolean;
11
+ }, z.core.$strip>;
12
+ declare const CreatePriceListResponseSchema: z.ZodObject<{
13
+ data: z.ZodObject<{
14
+ id: z.ZodInt;
15
+ }, z.core.$strip>;
16
+ }, z.core.$strip>;
17
+
18
+ declare const createPriceList: (data: z.input<typeof CreatePriceListSchema>) => Effect.Effect<{
19
+ data: {
20
+ id: number;
21
+ };
22
+ }, SomeBigCommerceError | InputValidationError, BigCommerceFetcher>;
23
+
24
+ declare const PriceListSchema: z.ZodObject<{
25
+ id: z.ZodInt;
26
+ name: z.ZodString;
27
+ date_created: z.ZodString;
28
+ date_modified: z.ZodString;
29
+ active: z.ZodBoolean;
30
+ }, z.core.$strip>;
31
+ declare const GetPriceListsResponseSchema: z.ZodObject<{
32
+ data: z.ZodArray<z.ZodObject<{
33
+ id: z.ZodInt;
34
+ name: z.ZodString;
35
+ date_created: z.ZodString;
36
+ date_modified: z.ZodString;
37
+ active: z.ZodBoolean;
38
+ }, z.core.$strip>>;
39
+ meta: z.ZodObject<{
40
+ pagination: z.ZodObject<{
41
+ total: z.ZodInt;
42
+ count: z.ZodInt;
43
+ per_page: z.ZodInt;
44
+ current_page: z.ZodInt;
45
+ total_pages: z.ZodInt;
46
+ }, z.core.$strip>;
47
+ }, z.core.$strip>;
48
+ }, z.core.$strip>;
49
+ declare const GetPriceListsCriteriaSchema: z.ZodObject<{
50
+ page: z.ZodOptional<z.ZodInt>;
51
+ limit: z.ZodOptional<z.ZodInt>;
52
+ 'id:in': z.ZodOptional<z.ZodPipe<z.ZodArray<z.ZodInt>, z.ZodTransform<string, number[]>>>;
53
+ }, z.core.$strip>;
54
+
55
+ declare const findPriceLists: (criteria?: z.input<typeof GetPriceListsCriteriaSchema>) => Effect.Effect<{
56
+ data: {
57
+ id: number;
58
+ name: string;
59
+ date_created: string;
60
+ date_modified: string;
61
+ active: boolean;
62
+ }[];
63
+ meta: {
64
+ pagination: {
65
+ total: number;
66
+ count: number;
67
+ per_page: number;
68
+ current_page: number;
69
+ total_pages: number;
70
+ };
71
+ };
72
+ }, SomeBigCommerceError | InputValidationError, BigCommerceFetcher>;
73
+ declare const getAllPriceListsBy: (criteria?: Omit<z.input<typeof GetPriceListsCriteriaSchema>, "limit" | "page">) => Effect.Effect<{
74
+ id: number;
75
+ name: string;
76
+ date_created: string;
77
+ date_modified: string;
78
+ active: boolean;
79
+ }[], SomeBigCommerceError | InputValidationError, BigCommerceFetcher>;
80
+
81
+ export { CreatePriceListResponseSchema, CreatePriceListSchema, GetPriceListsCriteriaSchema, GetPriceListsResponseSchema, PriceListSchema, createPriceList, findPriceLists, getAllPriceListsBy };
@@ -0,0 +1,458 @@
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/price-lists/index.ts
31
+ var price_lists_exports = {};
32
+ __export(price_lists_exports, {
33
+ CreatePriceListResponseSchema: () => CreatePriceListResponseSchema,
34
+ CreatePriceListSchema: () => CreatePriceListSchema,
35
+ GetPriceListsCriteriaSchema: () => GetPriceListsCriteriaSchema,
36
+ GetPriceListsResponseSchema: () => GetPriceListsResponseSchema,
37
+ PriceListSchema: () => PriceListSchema,
38
+ createPriceList: () => createPriceList,
39
+ findPriceLists: () => findPriceLists,
40
+ getAllPriceListsBy: () => getAllPriceListsBy
41
+ });
42
+ module.exports = __toCommonJS(price_lists_exports);
43
+
44
+ // src/bigcommerce-entities/price-lists/create-price-list.ts
45
+ var import_effect8 = require("effect");
46
+
47
+ // src/bigcommerce-entities/price-lists/schemas/create-price-lists.schema.ts
48
+ var z = __toESM(require("zod"));
49
+ var CreatePriceListSchema = z.object({
50
+ name: z.string(),
51
+ active: z.boolean()
52
+ });
53
+ var CreatePriceListResponseSchema = z.object({
54
+ data: z.object({
55
+ id: z.int()
56
+ })
57
+ });
58
+
59
+ // src/constants.ts
60
+ var import_effect = require("effect");
61
+ var DEFAULTS = {
62
+ retry: {
63
+ policy: import_effect.Schedule.exponential(import_effect.Duration.millis(200), 2).pipe(
64
+ import_effect.Schedule.intersect(import_effect.Schedule.recurs(3))
65
+ )
66
+ },
67
+ timeout: {
68
+ ms: 3e4
69
+ },
70
+ bigcommerceUrls: {
71
+ b2b: "https://api-b2b.bigcommerce.com/api",
72
+ regular: "https://api.bigcommerce.com/stores"
73
+ },
74
+ customers: {
75
+ getBatchSize: 250
76
+ },
77
+ salesStaff: {
78
+ getBatchSize: 250
79
+ },
80
+ companies: {
81
+ salesStaffAssignments: {
82
+ assignBatchSize: 10,
83
+ concurrency: 2
84
+ },
85
+ extraFields: {
86
+ getBatchSize: 250
87
+ },
88
+ roles: {
89
+ getBatchSize: 250
90
+ }
91
+ },
92
+ products: {
93
+ updateBatchSize: 5,
94
+ updateConcurrency: 2,
95
+ inventory: {
96
+ updateBatchSize: 2e3,
97
+ updateConcurrency: 2
98
+ }
99
+ },
100
+ orders: {
101
+ getAllBatchSize: 250,
102
+ shippingAddresses: {
103
+ getAllBatchSize: 250
104
+ },
105
+ products: {
106
+ getAllBatchSize: 250
107
+ }
108
+ },
109
+ priceLists: {
110
+ getAllBatchSize: 250
111
+ }
112
+ };
113
+
114
+ // src/core/bigcommerce.error.ts
115
+ var import_effect2 = require("effect");
116
+ var BigCommerceUnprocessableEntityError = class extends import_effect2.Data.TaggedError(
117
+ "BigCommerceUnprocessableEntityError"
118
+ ) {
119
+ };
120
+ var BigCommerceUnauthorizedError = class extends import_effect2.Data.TaggedError(
121
+ "BigCommerceUnauthorizedError"
122
+ ) {
123
+ };
124
+ var BigCommerceForbiddenError = class extends import_effect2.Data.TaggedError("BigCommerceForbiddenError") {
125
+ };
126
+ var BigCommerceNotFoundError = class extends import_effect2.Data.TaggedError("BigCommerceNotFoundError") {
127
+ };
128
+ var BigCommerceConflictError = class extends import_effect2.Data.TaggedError("BigCommerceConflictError") {
129
+ };
130
+ var BigCommerceConnectionError = class extends import_effect2.Data.TaggedError("BigCommerceConnectionError") {
131
+ };
132
+ var BigCommerceUnknownError = class extends import_effect2.Data.TaggedError("BigCommerceUnknownError") {
133
+ };
134
+ var BigCommerceInvalidResponseError = class extends import_effect2.Data.TaggedError(
135
+ "BigCommerceInvalidResponseError"
136
+ ) {
137
+ };
138
+ var BigCommerceInvalidRequestError = class extends import_effect2.Data.TaggedError(
139
+ "BigCommerceInvalidRequestError"
140
+ ) {
141
+ };
142
+ var BigCommerceParseResponseError = class extends import_effect2.Data.TaggedError(
143
+ "BigCommerceParseResponseError"
144
+ ) {
145
+ };
146
+
147
+ // src/core/bigcommerce.fetcher.ts
148
+ var import_effect3 = require("effect");
149
+ var BigCommerceFetcher = class extends import_effect3.Context.Tag("BigCommerceFetcher")() {
150
+ };
151
+
152
+ // src/core/bigcommerce.fetcher.live.ts
153
+ var import_effect5 = require("effect");
154
+
155
+ // src/core/config.ts
156
+ var import_effect4 = require("effect");
157
+ var NoBigCommerceConfigError = class extends import_effect4.Data.TaggedError("NoBigCommerceConfigError") {
158
+ };
159
+ var BigCommerceConfig = class extends import_effect4.Context.Tag("BigCommerceConfig")() {
160
+ };
161
+ var getBigCommerceConfig = (key) => {
162
+ return import_effect4.Config.nested(import_effect4.Config.string(key), "BIGCOMMERCE").pipe(
163
+ import_effect4.Effect.mapError(() => new NoBigCommerceConfigError({ key }))
164
+ );
165
+ };
166
+ var getBigCommerceTimeout = () => {
167
+ return import_effect4.Config.nested(import_effect4.Config.number("TIMEOUT"), "BIGCOMMERCE").pipe(
168
+ import_effect4.Effect.mapError(() => new NoBigCommerceConfigError({ key: "TIMEOUT" })),
169
+ // Default to 30 seconds if not configured
170
+ import_effect4.Effect.orElse(() => import_effect4.Effect.succeed(DEFAULTS.timeout.ms))
171
+ );
172
+ };
173
+ var BigCommerceConfigLive = import_effect4.Layer.effect(
174
+ BigCommerceConfig,
175
+ import_effect4.Effect.gen(function* () {
176
+ const [storeHash, clientId, clientSecret, accessToken, timeout] = yield* import_effect4.Effect.all([
177
+ getBigCommerceConfig("STORE_HASH"),
178
+ getBigCommerceConfig("CLIENT_ID"),
179
+ getBigCommerceConfig("CLIENT_SECRET"),
180
+ getBigCommerceConfig("ACCESS_TOKEN"),
181
+ getBigCommerceTimeout()
182
+ ]);
183
+ return {
184
+ getStoreHash: import_effect4.Effect.succeed(storeHash),
185
+ getClientId: import_effect4.Effect.succeed(clientId),
186
+ getClientSecret: import_effect4.Effect.succeed(clientSecret),
187
+ getAccessToken: import_effect4.Effect.succeed(accessToken),
188
+ getTimeout: import_effect4.Effect.succeed(timeout)
189
+ };
190
+ })
191
+ );
192
+ var BigCommerceConfigTest = import_effect4.Layer.succeed(BigCommerceConfig, {
193
+ getAccessToken: import_effect4.Effect.succeed("test"),
194
+ getClientId: import_effect4.Effect.succeed("test"),
195
+ getClientSecret: import_effect4.Effect.succeed("test"),
196
+ getStoreHash: import_effect4.Effect.succeed("test"),
197
+ getTimeout: import_effect4.Effect.succeed(DEFAULTS.timeout.ms)
198
+ });
199
+
200
+ // src/core/bigcommerce.fetcher.live.ts
201
+ var BigCommerceStatusCodes = {
202
+ UNAUTHORIZED: 401,
203
+ CONFLICT: 409,
204
+ FORBIDDEN: 403,
205
+ NOT_FOUND: 404,
206
+ UNPROCESSABLE_ENTITY: 422,
207
+ INTERNAL_SERVER_ERROR: 500,
208
+ BAD_GATEWAY: 502,
209
+ SERVICE_UNAVAILABLE: 503,
210
+ GATEWAY_TIMEOUT: 504,
211
+ INVALID_REQUEST: 400
212
+ };
213
+ var BigCommerceFetcherLive = import_effect5.Layer.effect(
214
+ BigCommerceFetcher,
215
+ import_effect5.Effect.gen(function* () {
216
+ const config = yield* BigCommerceConfig;
217
+ const storeHash = yield* config.getStoreHash;
218
+ const accessToken = yield* config.getAccessToken;
219
+ const timeout = yield* config.getTimeout;
220
+ return {
221
+ fetch: (params) => {
222
+ const base = getBase(params);
223
+ const headers = {
224
+ Accept: "application/json",
225
+ "Content-Type": "application/json",
226
+ "x-auth-token": accessToken
227
+ };
228
+ if (params.isB2B) {
229
+ headers["x-store-hash"] = storeHash;
230
+ }
231
+ const url = applyParams(base.replace("[storeHash]", storeHash), params.query);
232
+ return import_effect5.Effect.tryPromise({
233
+ try: () => fetch(url, {
234
+ headers,
235
+ signal: AbortSignal.timeout(timeout),
236
+ method: params.method,
237
+ ...params.body && { body: JSON.stringify(params.body) }
238
+ }),
239
+ catch: (error) => {
240
+ if (error instanceof Error && error.name === "TimeoutError") {
241
+ return new BigCommerceConnectionError({
242
+ message: `Request timeout after ${timeout}ms`,
243
+ type: "timeout"
244
+ });
245
+ }
246
+ if (error instanceof Error && error.name === "AbortError") {
247
+ return new BigCommerceConnectionError({
248
+ message: `Request timeout after ${timeout}ms`,
249
+ type: "timeout"
250
+ });
251
+ }
252
+ return new BigCommerceUnknownError({ cause: error });
253
+ }
254
+ }).pipe(
255
+ import_effect5.Effect.tapError(
256
+ (error) => import_effect5.Effect.logError("Failed to fetch from BigCommerce API", error.cause)
257
+ ),
258
+ import_effect5.Effect.flatMap((response) => transformResponse(response, params.resultSchema))
259
+ );
260
+ }
261
+ };
262
+ })
263
+ );
264
+ var applyParams = (url, params) => {
265
+ const base = new URL(url);
266
+ if (!params) {
267
+ return base;
268
+ }
269
+ if (typeof params === "string") {
270
+ base.search = params;
271
+ } else {
272
+ for (const [key, value] of Object.entries(params)) {
273
+ base.searchParams.append(key, `${value}`);
274
+ }
275
+ }
276
+ return base;
277
+ };
278
+ var getBase = ({
279
+ isB2B,
280
+ path,
281
+ version
282
+ }) => {
283
+ if (isB2B) {
284
+ return `${DEFAULTS.bigcommerceUrls.b2b}/${version}/io/${path}`;
285
+ }
286
+ return `${DEFAULTS.bigcommerceUrls.regular}/[storeHash]/${version}/${path}`;
287
+ };
288
+ function processSuccessResponse(response, schema) {
289
+ return import_effect5.Effect.tryPromise({
290
+ try: () => response.json(),
291
+ catch: (error) => new BigCommerceInvalidResponseError({ cause: error })
292
+ }).pipe(
293
+ import_effect5.Effect.tapError(
294
+ (error) => import_effect5.Effect.logError("Error parsing response from BigCommerce API", error.cause)
295
+ ),
296
+ import_effect5.Effect.tryMap({
297
+ try: (json) => schema.parse(json),
298
+ catch: (error) => new BigCommerceParseResponseError({ error })
299
+ })
300
+ );
301
+ }
302
+ var processErrorResponse = (response) => {
303
+ const code = response.status;
304
+ return import_effect5.Effect.tryPromise({
305
+ try: () => response.json(),
306
+ catch: (error) => new BigCommerceInvalidResponseError({ cause: error })
307
+ }).pipe(
308
+ import_effect5.Effect.tapError((error) => import_effect5.Effect.logError("Error parsing error response", error.cause)),
309
+ import_effect5.Effect.flatMap(
310
+ (errorDetails) => import_effect5.Effect.fail(
311
+ import_effect5.Match.value(code).pipe(
312
+ import_effect5.Match.when(
313
+ BigCommerceStatusCodes.INVALID_REQUEST,
314
+ () => new BigCommerceInvalidRequestError({ errorDetails })
315
+ ),
316
+ import_effect5.Match.when(BigCommerceStatusCodes.UNAUTHORIZED, () => new BigCommerceUnauthorizedError()),
317
+ import_effect5.Match.when(BigCommerceStatusCodes.FORBIDDEN, () => new BigCommerceForbiddenError()),
318
+ import_effect5.Match.when(BigCommerceStatusCodes.NOT_FOUND, () => new BigCommerceNotFoundError()),
319
+ import_effect5.Match.when(
320
+ BigCommerceStatusCodes.CONFLICT,
321
+ () => new BigCommerceConflictError({ details: errorDetails })
322
+ ),
323
+ import_effect5.Match.when(
324
+ BigCommerceStatusCodes.UNPROCESSABLE_ENTITY,
325
+ () => new BigCommerceUnprocessableEntityError({ errorDetails })
326
+ ),
327
+ import_effect5.Match.when(
328
+ (code2) => code2 >= 500,
329
+ () => new BigCommerceConnectionError({
330
+ message: `Server error: ${code}`,
331
+ type: code === BigCommerceStatusCodes.INTERNAL_SERVER_ERROR ? "internalError" : code === BigCommerceStatusCodes.BAD_GATEWAY || code === BigCommerceStatusCodes.GATEWAY_TIMEOUT ? "timeout" : "internalError"
332
+ })
333
+ ),
334
+ import_effect5.Match.orElse(() => new BigCommerceUnknownError({ cause: errorDetails }))
335
+ )
336
+ )
337
+ )
338
+ );
339
+ };
340
+ var transformResponse = (response, schema) => {
341
+ if (response.ok) {
342
+ return processSuccessResponse(response, schema);
343
+ }
344
+ return processErrorResponse(response);
345
+ };
346
+
347
+ // src/validation/index.ts
348
+ var import_effect7 = require("effect");
349
+
350
+ // src/validation/validation.error.ts
351
+ var import_effect6 = require("effect");
352
+ var InputValidationError = class extends import_effect6.Data.TaggedError("InputValidationError") {
353
+ };
354
+
355
+ // src/validation/index.ts
356
+ var validateInput = (schema, data) => {
357
+ return import_effect7.Effect.try({
358
+ try: () => schema.parse(data),
359
+ catch: (error) => new InputValidationError({ input: data, error })
360
+ });
361
+ };
362
+
363
+ // src/bigcommerce-entities/price-lists/create-price-list.ts
364
+ var createPriceList = (data) => import_effect8.Effect.gen(function* () {
365
+ const fetcher = yield* BigCommerceFetcher;
366
+ const validatedData = yield* validateInput(CreatePriceListSchema, data);
367
+ return yield* import_effect8.Effect.retry(
368
+ fetcher.fetch({
369
+ body: validatedData,
370
+ isB2B: false,
371
+ method: "POST",
372
+ path: "pricelists",
373
+ resultSchema: CreatePriceListResponseSchema,
374
+ version: "v3"
375
+ }),
376
+ DEFAULTS.retry.policy
377
+ );
378
+ });
379
+
380
+ // src/bigcommerce-entities/price-lists/get-price-lists.ts
381
+ var import_effect9 = require("effect");
382
+ var import_qs = __toESM(require("qs"));
383
+
384
+ // src/bigcommerce-entities/price-lists/schemas/get-prices-lists.schema.ts
385
+ var z2 = __toESM(require("zod"));
386
+ var PriceListSchema = z2.object({
387
+ id: z2.int(),
388
+ name: z2.string(),
389
+ date_created: z2.string(),
390
+ date_modified: z2.string(),
391
+ active: z2.boolean()
392
+ });
393
+ var GetPriceListsResponseSchema = z2.object({
394
+ data: PriceListSchema.array(),
395
+ meta: z2.object({
396
+ pagination: z2.object({
397
+ total: z2.int(),
398
+ count: z2.int(),
399
+ per_page: z2.int(),
400
+ current_page: z2.int(),
401
+ total_pages: z2.int()
402
+ })
403
+ })
404
+ });
405
+ var GetPriceListsCriteriaSchema = z2.object({
406
+ page: z2.int().optional(),
407
+ limit: z2.int().optional(),
408
+ "id:in": z2.int().array().transform((value) => value.join(",")).optional()
409
+ });
410
+
411
+ // src/bigcommerce-entities/price-lists/get-price-lists.ts
412
+ var findPriceLists = (criteria) => import_effect9.Effect.gen(function* () {
413
+ const fetcher = yield* BigCommerceFetcher;
414
+ const validatedCriteria = yield* validateInput(GetPriceListsCriteriaSchema, criteria ?? {});
415
+ return yield* import_effect9.Effect.retry(
416
+ fetcher.fetch({
417
+ isB2B: false,
418
+ method: "GET",
419
+ query: import_qs.default.stringify(validatedCriteria),
420
+ path: "pricelists",
421
+ resultSchema: GetPriceListsResponseSchema,
422
+ version: "v3"
423
+ }),
424
+ DEFAULTS.retry.policy
425
+ );
426
+ });
427
+ var getAllPriceListsBy = (criteria) => import_effect9.Effect.gen(function* () {
428
+ let hasMore = true;
429
+ let page = 1;
430
+ const limit = DEFAULTS.priceLists.getAllBatchSize;
431
+ const data = [];
432
+ while (hasMore) {
433
+ const response = yield* findPriceLists({
434
+ ...criteria,
435
+ limit,
436
+ page
437
+ });
438
+ if (response.data.length) {
439
+ page += 1;
440
+ data.push(...response.data);
441
+ } else {
442
+ hasMore = false;
443
+ }
444
+ }
445
+ return data;
446
+ });
447
+ // Annotate the CommonJS export names for ESM import in node:
448
+ 0 && (module.exports = {
449
+ CreatePriceListResponseSchema,
450
+ CreatePriceListSchema,
451
+ GetPriceListsCriteriaSchema,
452
+ GetPriceListsResponseSchema,
453
+ PriceListSchema,
454
+ createPriceList,
455
+ findPriceLists,
456
+ getAllPriceListsBy
457
+ });
458
+ //# sourceMappingURL=priceLists.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/bigcommerce-entities/price-lists/index.ts","../src/bigcommerce-entities/price-lists/create-price-list.ts","../src/bigcommerce-entities/price-lists/schemas/create-price-lists.schema.ts","../src/constants.ts","../src/core/bigcommerce.error.ts","../src/core/bigcommerce.fetcher.ts","../src/core/bigcommerce.fetcher.live.ts","../src/core/config.ts","../src/validation/index.ts","../src/validation/validation.error.ts","../src/bigcommerce-entities/price-lists/get-price-lists.ts","../src/bigcommerce-entities/price-lists/schemas/get-prices-lists.schema.ts"],"sourcesContent":["export * from './create-price-list';\nexport * from './get-price-lists';\nexport * from './schemas';\n","import { Effect } from 'effect';\nimport {\n CreatePriceListResponseSchema,\n CreatePriceListSchema,\n} from './schemas/create-price-lists.schema';\n\nimport * as z from 'zod';\nimport { DEFAULTS } from '../../constants';\nimport { BigCommerceFetcher } from '../../core';\nimport { validateInput } from '../../validation';\nexport const createPriceList = (data: z.input<typeof CreatePriceListSchema>) =>\n Effect.gen(function* () {\n const fetcher = yield* BigCommerceFetcher;\n const validatedData = yield* validateInput(CreatePriceListSchema, data);\n return yield* Effect.retry(\n fetcher.fetch({\n body: validatedData,\n isB2B: false,\n method: 'POST',\n path: 'pricelists',\n resultSchema: CreatePriceListResponseSchema,\n version: 'v3',\n }),\n DEFAULTS.retry.policy,\n );\n });\n","import * as z from 'zod';\nexport const CreatePriceListSchema = z.object({\n name: z.string(),\n active: z.boolean(),\n});\nexport const CreatePriceListResponseSchema = z.object({\n data: z.object({\n id: z.int(),\n }),\n});\n","import { Duration, Schedule } from 'effect';\n\nexport const DEFAULTS = {\n retry: {\n policy: Schedule.exponential(Duration.millis(200), 2).pipe(\n Schedule.intersect(Schedule.recurs(3)),\n ),\n },\n timeout: {\n ms: 30000,\n },\n bigcommerceUrls: {\n b2b: 'https://api-b2b.bigcommerce.com/api',\n regular: 'https://api.bigcommerce.com/stores',\n },\n customers: {\n getBatchSize: 250,\n },\n salesStaff: {\n getBatchSize: 250,\n },\n companies: {\n salesStaffAssignments: {\n assignBatchSize: 10,\n concurrency: 2,\n },\n extraFields: {\n getBatchSize: 250,\n },\n roles: {\n getBatchSize: 250,\n },\n },\n products: {\n updateBatchSize: 5,\n updateConcurrency: 2,\n inventory: {\n updateBatchSize: 2000,\n updateConcurrency: 2,\n },\n },\n orders: {\n getAllBatchSize: 250,\n shippingAddresses: {\n getAllBatchSize: 250,\n },\n products: {\n getAllBatchSize: 250,\n },\n },\n priceLists: {\n getAllBatchSize: 250,\n },\n} as const;\n","import { Data } from 'effect';\nimport * as z from 'zod';\nexport class BigCommerceUnprocessableEntityError extends Data.TaggedError(\n 'BigCommerceUnprocessableEntityError',\n)<{\n readonly errorDetails: unknown;\n}> {}\n\nexport class BigCommerceUnauthorizedError extends Data.TaggedError(\n 'BigCommerceUnauthorizedError',\n) {}\n\nexport class BigCommerceForbiddenError extends Data.TaggedError('BigCommerceForbiddenError') {}\n\nexport class BigCommerceNotFoundError extends Data.TaggedError('BigCommerceNotFoundError') {}\n\nexport class BigCommerceConflictError extends Data.TaggedError('BigCommerceConflictError')<{\n readonly details: unknown;\n}> {}\n\nexport class BigCommerceConnectionError extends Data.TaggedError('BigCommerceConnectionError')<{\n readonly message: string;\n readonly type: 'timeout' | 'internalError' | 'unknown';\n}> {}\n\nexport class BigCommerceUnknownError extends Data.TaggedError('BigCommerceUnknownError')<{\n cause: unknown;\n}> {}\n\nexport class BigCommerceInvalidResponseError extends Data.TaggedError(\n 'BigCommerceInvalidResponseError',\n)<{\n cause: unknown;\n}> {}\n\nexport class BigCommerceInvalidRequestError extends Data.TaggedError(\n 'BigCommerceInvalidRequestError',\n)<{\n readonly errorDetails: unknown;\n}> {}\n\nexport class BigCommerceParseResponseError extends Data.TaggedError(\n 'BigCommerceParseResponseError',\n)<{\n readonly error: z.ZodError;\n}> {}\n\nexport type SomeBigCommerceError =\n | BigCommerceUnprocessableEntityError\n | BigCommerceUnauthorizedError\n | BigCommerceForbiddenError\n | BigCommerceNotFoundError\n | BigCommerceConflictError\n | BigCommerceConnectionError\n | BigCommerceUnknownError\n | BigCommerceInvalidResponseError\n | BigCommerceInvalidRequestError\n | BigCommerceParseResponseError;\n","import { Context, Effect } from 'effect';\nimport * as z from 'zod';\nimport { type SomeBigCommerceError } from './bigcommerce.error';\nexport type BigCommerceFetchMethods = 'GET' | 'POST' | 'PUT' | 'DELETE';\nexport interface BigCommerceFetchParams<\n // Always send json for now, maybe later send a Blob\n Body extends Record<string, unknown> | Array<Record<string, unknown>>,\n Query extends Record<string, string> | string,\n Result extends z.ZodType,\n> {\n readonly body?: Body;\n readonly query?: Query;\n readonly method: BigCommerceFetchMethods;\n readonly path: string;\n readonly headers?: Record<string, string>;\n readonly isB2B: boolean;\n readonly version: 'v3' | 'v2';\n readonly resultSchema: Result;\n}\n\nexport class BigCommerceFetcher extends Context.Tag('BigCommerceFetcher')<\n BigCommerceFetcher,\n {\n readonly fetch: <\n Body extends Record<string, unknown> | Array<Record<string, unknown>>,\n Query extends Record<string, string> | string,\n Result extends z.ZodType,\n >(\n params: BigCommerceFetchParams<Body, Query, Result>,\n ) => Effect.Effect<z.output<Result>, SomeBigCommerceError>;\n }\n>() {}\n","import { Effect, Layer, Match } from 'effect';\nimport * as z from 'zod';\nimport { DEFAULTS } from '../constants';\nimport {\n BigCommerceConflictError,\n BigCommerceConnectionError,\n BigCommerceForbiddenError,\n BigCommerceInvalidRequestError,\n BigCommerceInvalidResponseError,\n BigCommerceNotFoundError,\n BigCommerceParseResponseError,\n BigCommerceUnauthorizedError,\n BigCommerceUnknownError,\n BigCommerceUnprocessableEntityError,\n type SomeBigCommerceError,\n} from './bigcommerce.error';\nimport { BigCommerceFetcher } from './bigcommerce.fetcher';\nimport { BigCommerceConfig, type NoBigCommerceConfigError } from './config';\n\nconst BigCommerceStatusCodes = {\n UNAUTHORIZED: 401,\n CONFLICT: 409,\n FORBIDDEN: 403,\n NOT_FOUND: 404,\n UNPROCESSABLE_ENTITY: 422,\n INTERNAL_SERVER_ERROR: 500,\n BAD_GATEWAY: 502,\n SERVICE_UNAVAILABLE: 503,\n GATEWAY_TIMEOUT: 504,\n INVALID_REQUEST: 400,\n} as const;\n\nexport const BigCommerceFetcherLive: Layer.Layer<\n BigCommerceFetcher,\n NoBigCommerceConfigError,\n BigCommerceConfig\n> = Layer.effect(\n BigCommerceFetcher,\n Effect.gen(function* () {\n const config = yield* BigCommerceConfig;\n const storeHash = yield* config.getStoreHash;\n const accessToken = yield* config.getAccessToken;\n const timeout = yield* config.getTimeout;\n\n return {\n fetch: (params) => {\n const base = getBase(params);\n const headers: Record<string, string> = {\n Accept: 'application/json',\n 'Content-Type': 'application/json',\n 'x-auth-token': accessToken,\n };\n\n if (params.isB2B) {\n headers['x-store-hash'] = storeHash;\n }\n const url = applyParams(base.replace('[storeHash]', storeHash), params.query);\n\n return Effect.tryPromise({\n try: () =>\n fetch(url, {\n headers,\n signal: AbortSignal.timeout(timeout),\n method: params.method,\n ...(params.body && { body: JSON.stringify(params.body) }),\n }),\n catch: (error) => {\n if (error instanceof Error && error.name === 'TimeoutError') {\n return new BigCommerceConnectionError({\n message: `Request timeout after ${timeout}ms`,\n type: 'timeout',\n });\n }\n if (error instanceof Error && error.name === 'AbortError') {\n return new BigCommerceConnectionError({\n message: `Request timeout after ${timeout}ms`,\n type: 'timeout',\n });\n }\n return new BigCommerceUnknownError({ cause: error });\n },\n }).pipe(\n Effect.tapError((error) =>\n Effect.logError('Failed to fetch from BigCommerce API', error.cause),\n ),\n Effect.flatMap((response) => transformResponse(response, params.resultSchema)),\n );\n },\n };\n }),\n);\nconst applyParams = (url: string, params?: Record<string, string | number> | string): URL => {\n const base = new URL(url);\n if (!params) {\n return base;\n }\n if (typeof params === 'string') {\n base.search = params;\n } else {\n for (const [key, value] of Object.entries(params)) {\n base.searchParams.append(key, `${value}`);\n }\n }\n return base;\n};\n\nconst getBase = ({\n isB2B,\n path,\n version,\n}: {\n isB2B: boolean;\n path: string;\n version: 'v3' | 'v2';\n}): string => {\n if (isB2B) {\n return `${DEFAULTS.bigcommerceUrls.b2b}/${version}/io/${path}`;\n }\n return `${DEFAULTS.bigcommerceUrls.regular}/[storeHash]/${version}/${path}`;\n};\nfunction processSuccessResponse<Schema extends z.ZodTypeAny>(response: Response, schema: Schema) {\n return Effect.tryPromise({\n try: () => response.json(),\n catch: (error) => new BigCommerceInvalidResponseError({ cause: error }),\n }).pipe(\n Effect.tapError((error) =>\n Effect.logError('Error parsing response from BigCommerce API', error.cause),\n ),\n Effect.tryMap({\n try: (json) => schema.parse(json),\n catch: (error) => new BigCommerceParseResponseError({ error: error as z.ZodError }),\n }),\n );\n}\nconst processErrorResponse = (response: Response) => {\n const code = response.status;\n return Effect.tryPromise({\n try: () => response.json(),\n catch: (error) => new BigCommerceInvalidResponseError({ cause: error }),\n }).pipe(\n Effect.tapError((error) => Effect.logError('Error parsing error response', error.cause)),\n Effect.flatMap((errorDetails) =>\n Effect.fail(\n Match.value(code).pipe(\n Match.when(\n BigCommerceStatusCodes.INVALID_REQUEST,\n () => new BigCommerceInvalidRequestError({ errorDetails }),\n ),\n Match.when(BigCommerceStatusCodes.UNAUTHORIZED, () => new BigCommerceUnauthorizedError()),\n Match.when(BigCommerceStatusCodes.FORBIDDEN, () => new BigCommerceForbiddenError()),\n Match.when(BigCommerceStatusCodes.NOT_FOUND, () => new BigCommerceNotFoundError()),\n Match.when(\n BigCommerceStatusCodes.CONFLICT,\n () => new BigCommerceConflictError({ details: errorDetails }),\n ),\n Match.when(\n BigCommerceStatusCodes.UNPROCESSABLE_ENTITY,\n () => new BigCommerceUnprocessableEntityError({ errorDetails }),\n ),\n Match.when(\n (code) => code >= 500,\n () =>\n new BigCommerceConnectionError({\n message: `Server error: ${code}`,\n type:\n code === BigCommerceStatusCodes.INTERNAL_SERVER_ERROR\n ? 'internalError'\n : code === BigCommerceStatusCodes.BAD_GATEWAY ||\n code === BigCommerceStatusCodes.GATEWAY_TIMEOUT\n ? 'timeout'\n : 'internalError',\n }),\n ),\n Match.orElse(() => new BigCommerceUnknownError({ cause: errorDetails })),\n ),\n ),\n ),\n );\n};\n\nconst transformResponse = <Schema extends z.ZodTypeAny>(\n response: Response,\n schema: Schema,\n): Effect.Effect<z.output<Schema>, SomeBigCommerceError> => {\n if (response.ok) {\n return processSuccessResponse(response, schema);\n }\n return processErrorResponse(response);\n};\n\n// type PendingErrors = Exclude<\n// SomeBigCommerceError,\n// Effect.Effect.Error<ReturnType<typeof processErrorResponse>> | BigCommerceParseResponseError\n// >;\n","import { Config, Context, Data, Effect, Layer } from 'effect';\nimport { DEFAULTS } from '../constants';\n\n// Define a custom error type using Data.TaggedError\nexport class NoBigCommerceConfigError extends Data.TaggedError('NoBigCommerceConfigError')<{\n readonly key: string;\n}> {}\n\nexport class BigCommerceConfig extends Context.Tag('BigCommerceConfig')<\n BigCommerceConfig,\n {\n readonly getStoreHash: Effect.Effect<string, NoBigCommerceConfigError>;\n readonly getClientId: Effect.Effect<string, NoBigCommerceConfigError>;\n readonly getClientSecret: Effect.Effect<string, NoBigCommerceConfigError>;\n readonly getAccessToken: Effect.Effect<string, NoBigCommerceConfigError>;\n readonly getTimeout: Effect.Effect<number, NoBigCommerceConfigError>;\n }\n>() {}\n\nconst getBigCommerceConfig = (key: string) => {\n return Config.nested(Config.string(key), 'BIGCOMMERCE').pipe(\n Effect.mapError(() => new NoBigCommerceConfigError({ key })),\n );\n};\n\nconst getBigCommerceTimeout = () => {\n return Config.nested(Config.number('TIMEOUT'), 'BIGCOMMERCE').pipe(\n Effect.mapError(() => new NoBigCommerceConfigError({ key: 'TIMEOUT' })),\n // Default to 30 seconds if not configured\n Effect.orElse(() => Effect.succeed(DEFAULTS.timeout.ms)),\n );\n};\n\nexport const BigCommerceConfigLive = Layer.effect(\n BigCommerceConfig,\n Effect.gen(function* () {\n const [storeHash, clientId, clientSecret, accessToken, timeout] = yield* Effect.all([\n getBigCommerceConfig('STORE_HASH'),\n getBigCommerceConfig('CLIENT_ID'),\n getBigCommerceConfig('CLIENT_SECRET'),\n getBigCommerceConfig('ACCESS_TOKEN'),\n getBigCommerceTimeout(),\n ]);\n\n return {\n getStoreHash: Effect.succeed(storeHash),\n getClientId: Effect.succeed(clientId),\n getClientSecret: Effect.succeed(clientSecret),\n getAccessToken: Effect.succeed(accessToken),\n getTimeout: Effect.succeed(timeout),\n };\n }),\n);\n\nexport const BigCommerceConfigTest = Layer.succeed(BigCommerceConfig, {\n getAccessToken: Effect.succeed('test'),\n getClientId: Effect.succeed('test'),\n getClientSecret: Effect.succeed('test'),\n getStoreHash: Effect.succeed('test'),\n getTimeout: Effect.succeed(DEFAULTS.timeout.ms),\n});\n\nexport const validateBigCommerceConfig = () =>\n Effect.gen(function* () {\n const config = yield* BigCommerceConfig;\n const [storeHash, clientId, clientSecret, accessToken, timeout] = yield* Effect.all([\n config.getStoreHash,\n config.getClientId,\n config.getClientSecret,\n config.getAccessToken,\n config.getTimeout,\n ]);\n\n return {\n storeHash,\n clientId,\n clientSecret,\n accessToken,\n timeout,\n };\n });\n","import { Effect } from 'effect';\nimport * as z from 'zod';\nimport { InputValidationError } from './validation.error';\nexport const validateInput = <Schema extends z.ZodType>(schema: Schema, data: z.input<Schema>) => {\n return Effect.try({\n try: () => schema.parse(data),\n catch: (error) => new InputValidationError({ input: data, error: error as z.ZodError }),\n });\n};\n","import { Data } from 'effect';\nimport * as z from 'zod';\nexport class InputValidationError extends Data.TaggedError('InputValidationError')<{\n input: unknown;\n error: z.ZodError;\n}> {}\n","import { Effect } from 'effect';\nimport qs from 'qs';\nimport * as z from 'zod';\nimport { DEFAULTS } from '../../constants';\nimport { BigCommerceFetcher } from '../../core';\nimport { validateInput } from '../../validation';\nimport {\n GetPriceListsCriteriaSchema,\n GetPriceListsResponseSchema,\n} from './schemas/get-prices-lists.schema';\nexport const findPriceLists = (criteria?: z.input<typeof GetPriceListsCriteriaSchema>) =>\n Effect.gen(function* () {\n const fetcher = yield* BigCommerceFetcher;\n const validatedCriteria = yield* validateInput(GetPriceListsCriteriaSchema, criteria ?? {});\n return yield* Effect.retry(\n fetcher.fetch({\n isB2B: false,\n method: 'GET',\n query: qs.stringify(validatedCriteria),\n path: 'pricelists',\n resultSchema: GetPriceListsResponseSchema,\n version: 'v3',\n }),\n DEFAULTS.retry.policy,\n );\n });\n\nexport const getAllPriceListsBy = (\n criteria?: Omit<z.input<typeof GetPriceListsCriteriaSchema>, 'limit' | 'page'>,\n) =>\n Effect.gen(function* () {\n let hasMore = true;\n let page = 1;\n const limit = DEFAULTS.priceLists.getAllBatchSize;\n const data: z.infer<typeof GetPriceListsResponseSchema>['data'] = [];\n while (hasMore) {\n const response = yield* findPriceLists({\n ...criteria,\n limit,\n page,\n });\n if (response.data.length) {\n page += 1;\n data.push(...response.data);\n } else {\n hasMore = false;\n }\n }\n return data;\n });\n","import * as z from 'zod';\nexport const PriceListSchema = z.object({\n id: z.int(),\n name: z.string(),\n date_created: z.string(),\n date_modified: z.string(),\n active: z.boolean(),\n});\n\nexport const GetPriceListsResponseSchema = z.object({\n data: PriceListSchema.array(),\n meta: z.object({\n pagination: z.object({\n total: z.int(),\n count: z.int(),\n per_page: z.int(),\n current_page: z.int(),\n total_pages: z.int(),\n }),\n }),\n});\n\nexport const GetPriceListsCriteriaSchema = z.object({\n page: z.int().optional(),\n limit: z.int().optional(),\n 'id:in': z\n .int()\n .array()\n .transform((value) => value.join(','))\n .optional(),\n});\n"],"mappings":"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","names":["import_effect","import_effect","import_effect","import_effect","import_effect","code","import_effect","import_effect","import_effect","z","qs"]}