@shushed/helpers 0.0.226-fix-erp-631-20260105165305 → 0.0.226

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 (42) hide show
  1. package/dist/cjs/contracts/index.js +5 -1
  2. package/dist/cjs/contracts/product-draft.schema.json +159 -5
  3. package/dist/cjs/contracts/purchase-orderline.schema.json +135 -0
  4. package/dist/cjs/contracts/stock-movement.schema.json +144 -0
  5. package/dist/cjs/dist-dereferenced/index.js +5 -1
  6. package/dist/cjs/dist-dereferenced/messages/product-draft.js +1 -1
  7. package/dist/cjs/dist-dereferenced/product-draft.js +1 -1
  8. package/dist/cjs/dist-dereferenced/purchase-orderline.js +4 -0
  9. package/dist/cjs/dist-dereferenced/stock-movement.js +4 -0
  10. package/dist/cjs/dist-types/purchase-orderline.js +2 -0
  11. package/dist/cjs/dist-types/stock-movement.js +2 -0
  12. package/dist/cjs/src-public/airtable.js +96 -59
  13. package/dist/cjs/src-public/bcOrder.js +60 -77
  14. package/dist/cjs/src-public/centra.js +56 -5
  15. package/dist/cjs/src-public/env.js +1 -1
  16. package/dist/cjs/src-public/index.js +3 -1
  17. package/dist/cjs/src-public/pubsub.js +35 -10
  18. package/dist/cjs/src-public/runtime.js +48 -9
  19. package/dist/cjs/src-public/sitoo.js +349 -0
  20. package/dist/cjs/src-public/utils.js +3 -0
  21. package/dist/package.json +3 -2
  22. package/dist/types/contracts/index.d.ts +2 -0
  23. package/dist/types/dist-dereferenced/index.d.ts +2 -0
  24. package/dist/types/dist-dereferenced/messages/product-draft.d.ts +148 -1
  25. package/dist/types/dist-dereferenced/product-draft.d.ts +148 -1
  26. package/dist/types/dist-dereferenced/purchase-orderline.d.ts +114 -0
  27. package/dist/types/dist-dereferenced/stock-movement.d.ts +110 -0
  28. package/dist/types/dist-types/index.d.ts +2 -0
  29. package/dist/types/dist-types/messages/product-draft.d.ts +23 -4
  30. package/dist/types/dist-types/product-draft.d.ts +23 -4
  31. package/dist/types/dist-types/purchase-orderline.d.ts +31 -0
  32. package/dist/types/dist-types/stock-movement.d.ts +30 -0
  33. package/dist/types/src-public/airtable.d.ts +0 -9
  34. package/dist/types/src-public/centra.d.ts +3 -0
  35. package/dist/types/src-public/env.d.ts +1 -1
  36. package/dist/types/src-public/index.d.ts +1 -0
  37. package/dist/types/src-public/pubsub.d.ts +4 -1
  38. package/dist/types/src-public/runtime.d.ts +17 -4
  39. package/dist/types/src-public/sitoo.d.ts +254 -0
  40. package/dist/types/src-public/types.d.ts +6 -0
  41. package/dist/types/src-public/utils.d.ts +1 -1
  42. package/package.json +4 -3
@@ -1,6 +1,10 @@
1
1
  "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
2
5
  Object.defineProperty(exports, "__esModule", { value: true });
3
6
  exports.Logging = void 0;
7
+ const lodash_pick_1 = __importDefault(require("lodash.pick"));
4
8
  const DEFAULT_BRANCH = 'migratedprod';
5
9
  const getCircularReplacer = () => {
6
10
  const seen = new WeakSet();
@@ -59,34 +63,50 @@ exports.Logging = Logging;
59
63
  class Runtime {
60
64
  workflowId;
61
65
  triggerId;
66
+ triggerName;
67
+ triggerVersion;
62
68
  envName;
63
69
  pubSubPrefix;
64
70
  systemEnvName;
65
71
  runtimeUrl;
66
72
  logging;
67
- workflowRoot = null;
73
+ triggerDataProperties = undefined;
74
+ triggerConfigProperties = undefined;
75
+ triggerConfig = undefined;
76
+ workflowRoot;
68
77
  constructor(opts) {
69
78
  if (opts instanceof Runtime) {
70
79
  this.workflowRoot = opts.workflowRoot;
71
80
  this.workflowId = opts.workflowId;
72
81
  this.triggerId = opts.triggerId;
82
+ this.triggerName = opts.triggerName;
83
+ this.triggerVersion = opts.triggerVersion;
73
84
  this.systemEnvName = opts.systemEnvName;
74
85
  this.runtimeUrl = opts.runtimeUrl;
75
86
  this.pubSubPrefix = opts.pubSubPrefix;
76
87
  this.envName = opts.envName;
77
88
  this.logging = opts.logging || new Logging(this.workflowId, this.triggerId, this.systemEnvName);
89
+ this.triggerName = opts.triggerName;
90
+ this.triggerVersion = opts.triggerVersion;
91
+ this.triggerDataProperties = opts.triggerDataProperties;
92
+ this.triggerConfigProperties = opts.triggerConfigProperties;
93
+ this.triggerConfig = opts.triggerConfig;
78
94
  }
79
95
  else {
80
- if (opts.root) {
81
- this.workflowRoot = opts.root;
82
- }
96
+ this.workflowRoot = opts.root || {};
83
97
  this.workflowId = opts.workflowId || opts.workflow?.id || '';
84
- this.triggerId = opts.triggerId || opts.trigger?.id || '';
85
- if (!this.triggerId && opts.session) {
86
- this.triggerId = Object.values(opts.session?.executedNodes || {}).find(e => e.nodeType === 'trigger')?.nodeId ?? 'unknown';
98
+ if (opts.trigger?.label) {
99
+ this.triggerId = opts.trigger.id || '00000000-0000-0000-0000-000000000000';
100
+ this.triggerName = opts.trigger.label.split(/\sv\d/)[0].trim() || this.workflowId;
101
+ this.triggerVersion = buildSemver((opts.trigger.label.split(/\sv\d/)[1]?.trim() || 'v0').replace(/^v/, ''));
102
+ this.triggerDataProperties = opts.trigger.data?.properties;
103
+ this.triggerConfigProperties = opts.trigger.config?.properties;
87
104
  }
88
- else if (!this.triggerId) {
89
- this.triggerId = 'unknown';
105
+ else {
106
+ this.triggerId = Object.values(opts.session?.executedNodes || {}).find(e => e.nodeType === 'trigger')?.nodeId ?? '00000000-0000-0000-0000-000000000000';
107
+ this.triggerName = this.workflowRoot[this.triggerId]?.triggerName || this.workflowId;
108
+ this.triggerVersion = this.workflowRoot[this.triggerId]?.triggerVersion || '0.0.0';
109
+ this.triggerConfig = this.workflowRoot[this.triggerId]?.triggerConfig;
90
110
  }
91
111
  this.systemEnvName = this.getSystemEnvName(opts);
92
112
  this.envName = this.systemEnvName === DEFAULT_BRANCH ? 'prod' : this.systemEnvName;
@@ -95,6 +115,18 @@ class Runtime {
95
115
  this.logging = opts.logging || new Logging(this.workflowId, this.triggerId, this.systemEnvName);
96
116
  }
97
117
  }
118
+ enhanceWorkflowReturn(triggerReturn, triggerConfig) {
119
+ const keys = Object.keys(this.triggerDataProperties || {});
120
+ return Object.assign((0, lodash_pick_1.default)({
121
+ workflowId: this.workflowId,
122
+ triggerId: this.triggerId,
123
+ triggerName: this.triggerName,
124
+ triggerVersion: this.triggerVersion,
125
+ systemEnvName: this.systemEnvName,
126
+ envName: this.envName,
127
+ triggerConfig: (0, lodash_pick_1.default)(triggerConfig, Object.entries(this.triggerConfigProperties || {}).filter(([_, value]) => !value.buildship?.sensitive).map(([key]) => key))
128
+ }, keys), triggerReturn);
129
+ }
98
130
  getRuntimeUrl(options) {
99
131
  if (options.runtimeUrl && this.isDeployment) {
100
132
  return options.runtimeUrl;
@@ -143,3 +175,10 @@ class Runtime {
143
175
  }
144
176
  exports.default = Runtime;
145
177
  ;
178
+ function buildSemver(version) {
179
+ const parts = version.split(/\./).map(x => parseInt(x, 10));
180
+ for (let i = parts.length; i < 3; i++) {
181
+ parts.push(0);
182
+ }
183
+ return parts.join('.');
184
+ }
@@ -0,0 +1,349 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.SitooOrderItemType = exports.SitooPaymentState = exports.SitooOrderType = exports.SitooOrderState = void 0;
7
+ const crypto_1 = __importDefault(require("crypto"));
8
+ const lodash_groupby_1 = __importDefault(require("lodash.groupby"));
9
+ const env_1 = __importDefault(require("./env"));
10
+ const SITOO_TR_TYPE_MANUAL_IN = 10;
11
+ const SITOO_TR_TYPE_MANUAL_OUT = 20;
12
+ var SitooOrderState;
13
+ (function (SitooOrderState) {
14
+ SitooOrderState[SitooOrderState["Abandoned"] = -1] = "Abandoned";
15
+ SitooOrderState[SitooOrderState["Open"] = 0] = "Open";
16
+ SitooOrderState[SitooOrderState["Closed"] = 10] = "Closed";
17
+ SitooOrderState[SitooOrderState["Cancelled"] = 20] = "Cancelled";
18
+ })(SitooOrderState || (exports.SitooOrderState = SitooOrderState = {}));
19
+ var SitooOrderType;
20
+ (function (SitooOrderType) {
21
+ SitooOrderType[SitooOrderType["Order"] = 10] = "Order";
22
+ SitooOrderType[SitooOrderType["Booking"] = 100] = "Booking";
23
+ SitooOrderType[SitooOrderType["POSParked"] = 110] = "POSParked";
24
+ })(SitooOrderType || (exports.SitooOrderType = SitooOrderType = {}));
25
+ var SitooPaymentState;
26
+ (function (SitooPaymentState) {
27
+ SitooPaymentState[SitooPaymentState["None"] = 0] = "None";
28
+ SitooPaymentState[SitooPaymentState["Pending"] = 10] = "Pending";
29
+ SitooPaymentState[SitooPaymentState["Reserved"] = 15] = "Reserved";
30
+ SitooPaymentState[SitooPaymentState["Successful"] = 20] = "Successful";
31
+ SitooPaymentState[SitooPaymentState["Cancelled"] = 30] = "Cancelled";
32
+ SitooPaymentState[SitooPaymentState["Failed"] = 40] = "Failed";
33
+ })(SitooPaymentState || (exports.SitooPaymentState = SitooPaymentState = {}));
34
+ var SitooOrderItemType;
35
+ (function (SitooOrderItemType) {
36
+ SitooOrderItemType[SitooOrderItemType["Product"] = 10] = "Product";
37
+ SitooOrderItemType[SitooOrderItemType["Discount"] = 20] = "Discount";
38
+ })(SitooOrderItemType || (exports.SitooOrderItemType = SitooOrderItemType = {}));
39
+ const BATCH_SIZE = 900;
40
+ class SitooHelper extends env_1.default {
41
+ opts;
42
+ shaToken;
43
+ baseUrl;
44
+ siteId;
45
+ constructor(options, opts) {
46
+ super(options);
47
+ this.opts = opts;
48
+ this.shaToken = crypto_1.default.createHash('sha256').update(opts.accessToken).digest('hex').slice(0, 8);
49
+ this.baseUrl = opts.sitooBaseUrl.replace(/\/$/, '');
50
+ this.siteId = opts.sitooSiteId;
51
+ }
52
+ async getAllOrders(options) {
53
+ const allOrders = [];
54
+ const pageSize = 100;
55
+ let start = 0;
56
+ let hasMore = true;
57
+ while (hasMore) {
58
+ const queryParams = new URLSearchParams();
59
+ queryParams.set('num', pageSize.toString());
60
+ queryParams.set('start', start.toString());
61
+ queryParams.set('sort', 'orderid');
62
+ if (options?.fromTimestamp !== undefined) {
63
+ queryParams.set('orderdatefrom', options.fromTimestamp.toString());
64
+ }
65
+ if (options?.untilTimestamp !== undefined) {
66
+ queryParams.set('orderdateto', options.untilTimestamp.toString());
67
+ }
68
+ if (options?.filterByState !== undefined) {
69
+ queryParams.set('orderstate', options.filterByState.toString());
70
+ }
71
+ const url = `${this.baseUrl}/sites/${this.siteId}/orders.json?${queryParams.toString()}`;
72
+ const response = await fetch(url, {
73
+ method: 'GET',
74
+ headers: {
75
+ 'Authorization': `Basic ${this.opts.accessToken}`,
76
+ 'Content-Type': 'application/json',
77
+ },
78
+ });
79
+ if (!response.ok) {
80
+ const errorText = await response.text().catch(() => 'Unknown error');
81
+ throw new Error(`Sitoo API error: ${response.status} ${response.statusText} - ${errorText}`);
82
+ }
83
+ const envelope = await response.json();
84
+ allOrders.push(...envelope.items);
85
+ if (envelope.items.length < pageSize) {
86
+ hasMore = false;
87
+ }
88
+ else {
89
+ start += envelope.items.length;
90
+ }
91
+ }
92
+ return allOrders;
93
+ }
94
+ async getSitooWarehouses() {
95
+ const url = `${this.baseUrl}/sites/${this.siteId}/warehouses.json`;
96
+ const response = await fetch(url, {
97
+ method: 'GET',
98
+ headers: {
99
+ 'Authorization': `Basic ${this.opts.accessToken}`,
100
+ 'Content-Type': 'application/json',
101
+ },
102
+ });
103
+ if (!response.ok) {
104
+ const errorText = await response.text().catch(() => 'Unknown error');
105
+ throw new Error(`Sitoo API error: ${response.status} ${response.statusText} - ${errorText}`);
106
+ }
107
+ const data = await response.json();
108
+ const nameToId = {};
109
+ const warehouses = {};
110
+ for (const warehouse of data.items) {
111
+ nameToId[warehouse.name] = warehouse.warehouseid;
112
+ warehouses[warehouse.warehouseid] = warehouse;
113
+ }
114
+ return { nameToId, warehouses };
115
+ }
116
+ async fetchWarehouseTransactionsWithFilter(params) {
117
+ const queryParams = new URLSearchParams();
118
+ queryParams.set('num', (params.num || 100).toString());
119
+ if (params.transactiontype !== undefined) {
120
+ queryParams.set('transactiontype', params.transactiontype.toString());
121
+ }
122
+ if (params.datecreatedfrom !== undefined) {
123
+ queryParams.set('datecreatedfrom', params.datecreatedfrom.toString());
124
+ }
125
+ if (params.start !== undefined) {
126
+ queryParams.set('start', params.start.toString());
127
+ }
128
+ queryParams.set('sort', params.ascending ? 'warehousetransactionid' : '-warehousetransactionid');
129
+ const url = `${this.baseUrl}/sites/${this.siteId}/warehouses/${params.warehouseid}/warehousetransactions.json?${queryParams.toString()}`;
130
+ const response = await fetch(url, {
131
+ method: 'GET',
132
+ headers: {
133
+ 'Authorization': `Basic ${this.opts.accessToken}`,
134
+ 'Content-Type': 'application/json',
135
+ },
136
+ });
137
+ if (!response.ok) {
138
+ const errorText = await response.text().catch(() => 'Unknown error');
139
+ throw new Error(`Sitoo API error: ${response.status} ${response.statusText} - ${errorText}`);
140
+ }
141
+ return await response.json();
142
+ }
143
+ async searchTransactionsInApi(warehouseId, entryNosToFind, transactionType, datecreatedfrom) {
144
+ const found = new Map();
145
+ let lowestTransactionId = undefined;
146
+ if (entryNosToFind.size === 0) {
147
+ return { found, lowestTransactionId };
148
+ }
149
+ let hasMore = true;
150
+ const pageSize = 100;
151
+ const currentDateFrom = datecreatedfrom;
152
+ let currentStart = 0;
153
+ while (hasMore && found.size < entryNosToFind.size) {
154
+ const envelope = await this.fetchWarehouseTransactionsWithFilter({
155
+ warehouseid: warehouseId,
156
+ datecreatedfrom: currentDateFrom,
157
+ transactiontype: transactionType,
158
+ ascending: false,
159
+ num: pageSize,
160
+ start: currentStart,
161
+ });
162
+ const transactions = envelope.items;
163
+ if (transactions.length === 0) {
164
+ hasMore = false;
165
+ break;
166
+ }
167
+ for (const transaction of transactions) {
168
+ if (lowestTransactionId === undefined || transaction.warehousetransactionid < lowestTransactionId) {
169
+ lowestTransactionId = transaction.warehousetransactionid;
170
+ }
171
+ if (transaction.description) {
172
+ for (const entryNo of entryNosToFind) {
173
+ if (!found.has(entryNo) && transaction.description.includes(`'${entryNo}'`)) {
174
+ found.set(entryNo, transaction);
175
+ }
176
+ }
177
+ }
178
+ if (found.size === entryNosToFind.size) {
179
+ break;
180
+ }
181
+ }
182
+ currentStart = currentStart ? currentStart + transactions.length : transactions.length;
183
+ if (transactions.length < pageSize) {
184
+ hasMore = false;
185
+ }
186
+ }
187
+ return { found, lowestTransactionId };
188
+ }
189
+ async batchAddWarehouseTransactions(transactions) {
190
+ if (transactions.length === 0)
191
+ return [];
192
+ if (transactions.length > BATCH_SIZE) {
193
+ throw new Error(`Batch size exceeds maximum of ${BATCH_SIZE}. Got ${transactions.length}`);
194
+ }
195
+ const url = `${this.baseUrl}/sites/${this.siteId}/warehousetransactions.json`;
196
+ const response = await fetch(url, {
197
+ method: 'POST',
198
+ headers: {
199
+ 'Authorization': `Basic ${this.opts.accessToken}`,
200
+ 'Content-Type': 'application/json',
201
+ },
202
+ body: JSON.stringify(transactions),
203
+ });
204
+ if (!response.ok) {
205
+ const errorText = await response.text().catch(() => 'Unknown error');
206
+ throw new Error(`Sitoo API error: ${response.status} ${response.statusText} - ${errorText}`);
207
+ }
208
+ const result = await response.json();
209
+ return result;
210
+ }
211
+ async syncWarehouseTransactions(items, options) {
212
+ if (items.length === 0) {
213
+ return [];
214
+ }
215
+ const locationCodeToWarehouse = (await this.getSitooWarehouses()).nameToId;
216
+ const foundEntryNos = new Map();
217
+ const results = {};
218
+ const entryNoToIdx = {};
219
+ const entriesByWarehouseAndTransactionType = new Map();
220
+ for (let i = 0; i < items.length; i++) {
221
+ const entry = items[i];
222
+ const warehouseId = locationCodeToWarehouse[entry.location_code];
223
+ const transactionType = entry.type === 'transfer' ? (entry.quantity > 0 ? SITOO_TR_TYPE_MANUAL_IN : SITOO_TR_TYPE_MANUAL_OUT) : undefined;
224
+ entryNoToIdx[entry.entry_no] = i;
225
+ if (transactionType === undefined) {
226
+ results[i] = {
227
+ error: false,
228
+ message: `Not supported transaction type: ${entry.type}`,
229
+ };
230
+ continue;
231
+ }
232
+ if (warehouseId === undefined) {
233
+ results[i] = {
234
+ error: false,
235
+ message: `Not supported warehouse in Sitoo: ${entry.location_code}`,
236
+ };
237
+ continue;
238
+ }
239
+ const key = `${warehouseId}-${transactionType}`;
240
+ if (!entriesByWarehouseAndTransactionType.has(key)) {
241
+ entriesByWarehouseAndTransactionType.set(key, []);
242
+ }
243
+ entriesByWarehouseAndTransactionType.get(key).push(entry);
244
+ }
245
+ for (const [_, warehouseEntries] of entriesByWarehouseAndTransactionType) {
246
+ if (warehouseEntries.length > 0) {
247
+ let datecreatedfrom = undefined;
248
+ for (const entry of warehouseEntries) {
249
+ const entryCreatedAt = Math.floor(new Date(entry.created_at).getTime() / 1000);
250
+ if (datecreatedfrom === undefined || entryCreatedAt < datecreatedfrom) {
251
+ datecreatedfrom = entryCreatedAt;
252
+ }
253
+ }
254
+ const { found: apiFound } = await this.searchTransactionsInApi(locationCodeToWarehouse[warehouseEntries[0].location_code], new Set(warehouseEntries.map(e => e.entry_no.toString())), warehouseEntries[0].quantity > 0 ? SITOO_TR_TYPE_MANUAL_IN : SITOO_TR_TYPE_MANUAL_OUT, datecreatedfrom);
255
+ for (const [entryNo, transaction] of apiFound) {
256
+ foundEntryNos.set(entryNo, transaction.warehousetransactionid);
257
+ }
258
+ }
259
+ }
260
+ for (const [entryNo, transactionId] of foundEntryNos) {
261
+ const idx = entryNoToIdx[entryNo];
262
+ results[idx] = {
263
+ error: false,
264
+ message: `Found transaction in Sitoo: ${transactionId} for the entry ${entryNo}`,
265
+ };
266
+ }
267
+ const batches = [[]];
268
+ for (const [_, warehouseEntries] of entriesByWarehouseAndTransactionType) {
269
+ for (let i = 0; i < warehouseEntries.length; i += 1) {
270
+ if (!foundEntryNos.has(warehouseEntries[i].entry_no)) {
271
+ if ((batches[batches.length - 1].length + 1) >= BATCH_SIZE) {
272
+ batches.push([]);
273
+ }
274
+ batches[batches.length - 1].push(warehouseEntries[i]);
275
+ }
276
+ }
277
+ }
278
+ const hasMissingEntries = batches[0].length > 0;
279
+ if (!options?.preview && hasMissingEntries) {
280
+ for (let i = 0; i < batches.length; i++) {
281
+ const warehouseEntities = (0, lodash_groupby_1.default)(batches[i], e => `${locationCodeToWarehouse[e.location_code]}-${e.quantity > 0 ? 'positive' : 'negative'}`);
282
+ const entryNosInBatches = {};
283
+ const transactionsToCreate = [];
284
+ for (const k in warehouseEntities) {
285
+ const entriesToCreate = warehouseEntities[k];
286
+ const warehouseId = locationCodeToWarehouse[entriesToCreate[0].location_code];
287
+ const entryType = entriesToCreate[0].quantity > 0 ? SITOO_TR_TYPE_MANUAL_IN : SITOO_TR_TYPE_MANUAL_OUT;
288
+ entryNosInBatches[transactionsToCreate.length] = entriesToCreate.map(e => e.entry_no);
289
+ transactionsToCreate.push({
290
+ warehouseid: warehouseId,
291
+ transactiontype: entryType,
292
+ description: entriesToCreate.map(e => `'${e.entry_no}'`).join(', '),
293
+ items: entriesToCreate.map(e => ({
294
+ sku: [e.style_id, e.colour_id, e.size_code].filter(Boolean).join('-'),
295
+ decimalquantity: `${e.quantity.toFixed(3)}`,
296
+ moneypricein: (((e.unit_cost?.value ?? 0) / 100) * e.quantity).toFixed(2),
297
+ })),
298
+ });
299
+ }
300
+ try {
301
+ const createdIds = await this.batchAddWarehouseTransactions(transactionsToCreate);
302
+ for (let j = 0; j < transactionsToCreate.length; j++) {
303
+ const transactionId = createdIds[j];
304
+ for (let k = 0; k < entryNosInBatches[j].length; k += 1) {
305
+ const entryNo = entryNosInBatches[j][k];
306
+ const idx = entryNoToIdx[entryNo];
307
+ results[idx] = {
308
+ entryNo: entryNo,
309
+ transactionId: transactionId,
310
+ };
311
+ }
312
+ }
313
+ }
314
+ catch (error) {
315
+ for (const entry of batches[i]) {
316
+ const idx = entryNoToIdx[entry.entry_no];
317
+ results[idx] = error;
318
+ }
319
+ }
320
+ }
321
+ }
322
+ else {
323
+ for (let i = 0; i < batches.length; i++) {
324
+ for (let j = 0; j < batches[i].length; j += 1) {
325
+ const entry = batches[i][j];
326
+ const idx = entryNoToIdx[entry.entry_no];
327
+ const warehouseId = locationCodeToWarehouse[entry.location_code];
328
+ const transactionType = entry.quantity > 0 ? SITOO_TR_TYPE_MANUAL_IN : SITOO_TR_TYPE_MANUAL_OUT;
329
+ results[idx] = {
330
+ error: false,
331
+ message: `In Preview Mode. ${entry.entry_no} scheduled to be created as transction type: ${transactionType} in the warehouse: ${warehouseId}. Batch: ${i}`
332
+ };
333
+ }
334
+ }
335
+ }
336
+ const resultsAsArray = [];
337
+ for (let i = 0; i < items.length; i += 1) {
338
+ const result = results[i];
339
+ if (!result) {
340
+ resultsAsArray.push(new Error(`${items[i].entry_no} got missed in processing`));
341
+ }
342
+ else {
343
+ resultsAsArray.push(result);
344
+ }
345
+ }
346
+ return resultsAsArray;
347
+ }
348
+ }
349
+ exports.default = SitooHelper;
@@ -264,6 +264,9 @@ function setRetryAfterVariable(value, options) {
264
264
  global.functionsCache = global.functionsCache || {};
265
265
  exports.FUNCTION_EXPR_ERROR = Symbol('function');
266
266
  function createFunction(expression) {
267
+ if (typeof expression === 'function') {
268
+ return expression;
269
+ }
267
270
  if (!global.functionsCache[expression]) {
268
271
  global.functionsCache[expression] = new Function('symbol', 'payload', 'try { return ' + expression + ' } catch (err) { return symbol; }');
269
272
  }
package/dist/package.json CHANGED
@@ -5,6 +5,7 @@
5
5
  "license": "UNLICENSED",
6
6
  "description": "",
7
7
  "dependencies": {
8
+ "@google-cloud/firestore": "^7.11.1",
8
9
  "@hackylabs/deep-redact": "^2.2.1",
9
10
  "ajv": "^8.17.1",
10
11
  "ajv-formats": "^3.0.1",
@@ -12,15 +13,15 @@
12
13
  "jose": "^6.0.11",
13
14
  "lodash.chunk": "^4.2.0",
14
15
  "lodash.clonedeep": "^4.5.0",
16
+ "lodash.groupby": "^4.6.0",
15
17
  "lodash.isequal": "^4.5.0",
16
18
  "lodash.omit": "^4.5.0",
17
19
  "lodash.pick": "^4.4.0",
18
20
  "mime-types": "^3.0.1",
19
21
  "p-limit": "^7.1.1",
20
22
  "rate-limiter-flexible": "^7.2.0",
21
- "uuid": "^11.1.0",
22
23
  "redis": "^5.6.0",
23
- "@google-cloud/firestore": "^7.11.1"
24
+ "uuid": "^11.1.0"
24
25
  },
25
26
  "files": [
26
27
  "dist"
@@ -10,6 +10,8 @@ export { default as DevelopmentColour } from './development-colour.schema.json';
10
10
  export { default as Asset } from './asset.schema.json';
11
11
  export { default as CustomerSegment } from './customer-segment.schema.json';
12
12
  export { default as MarketingPref } from './marketing-preferences.schema.json';
13
+ export { default as StockMovement } from './stock-movement.schema.json';
14
+ export { default as PurchaseOrderline } from './purchase-orderline.schema.json';
13
15
  export * from './order';
14
16
  export { default as Order } from './order.schema.json';
15
17
  export * from './messages';
@@ -10,6 +10,8 @@ export { default as Price } from './price';
10
10
  export { default as ProductCategory } from './product-category';
11
11
  export { default as ProductDraft } from './product-draft';
12
12
  export { default as Product } from './product';
13
+ export { default as PurchaseOrderline } from './purchase-orderline';
14
+ export { default as StockMovement } from './stock-movement';
13
15
  export { default as Stock } from './stock';
14
16
  export { default as Total } from './total';
15
17
  export * as Messages from './messages';