repzo-sap-absjo 1.0.6 → 1.0.8

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 (80) hide show
  1. package/changelog.md +4 -0
  2. package/lib/actions/create_invoice.d.ts +13 -19
  3. package/lib/actions/create_invoice.js +216 -336
  4. package/lib/actions/create_payment.d.ts +1 -4
  5. package/lib/actions/create_payment.js +125 -171
  6. package/lib/actions/create_proforma.d.ts +1 -4
  7. package/lib/actions/create_proforma.js +165 -268
  8. package/lib/actions/create_return_invoice.d.ts +1 -4
  9. package/lib/actions/create_return_invoice.js +177 -295
  10. package/lib/actions/create_transfer.d.ts +1 -4
  11. package/lib/actions/create_transfer.js +143 -198
  12. package/lib/actions/index.js +15 -23
  13. package/lib/commands/adjust_inventory.d.ts +2 -4
  14. package/lib/commands/adjust_inventory.js +160 -290
  15. package/lib/commands/bank.d.ts +2 -4
  16. package/lib/commands/bank.js +157 -279
  17. package/lib/commands/basic.js +47 -66
  18. package/lib/commands/category.d.ts +1 -3
  19. package/lib/commands/category.js +104 -178
  20. package/lib/commands/channel.d.ts +1 -3
  21. package/lib/commands/channel.js +117 -198
  22. package/lib/commands/client.d.ts +32 -34
  23. package/lib/commands/client.js +244 -404
  24. package/lib/commands/client_disabled.d.ts +1 -3
  25. package/lib/commands/client_disabled.js +94 -163
  26. package/lib/commands/index.d.ts +11 -15
  27. package/lib/commands/index.js +60 -60
  28. package/lib/commands/join.js +66 -192
  29. package/lib/commands/measureunit.d.ts +14 -19
  30. package/lib/commands/measureunit.js +191 -289
  31. package/lib/commands/measureunit_family.d.ts +8 -10
  32. package/lib/commands/measureunit_family.js +138 -250
  33. package/lib/commands/payment_term.d.ts +1 -3
  34. package/lib/commands/payment_term.js +123 -202
  35. package/lib/commands/price_list.d.ts +15 -15
  36. package/lib/commands/price_list.js +327 -571
  37. package/lib/commands/product.d.ts +30 -32
  38. package/lib/commands/product.js +243 -425
  39. package/lib/commands/product_disabled.d.ts +1 -3
  40. package/lib/commands/product_disabled.js +94 -164
  41. package/lib/commands/rep.js +141 -221
  42. package/lib/commands/tag.js +109 -174
  43. package/lib/commands/tax.js +112 -177
  44. package/lib/commands/warehouse.d.ts +1 -3
  45. package/lib/commands/warehouse.js +119 -207
  46. package/lib/index.d.ts +12 -21
  47. package/lib/test/actions/create_invoice.js +188 -193
  48. package/lib/test/actions/create_payment.js +107 -112
  49. package/lib/test/actions/create_proforma.js +216 -220
  50. package/lib/test/actions/create_return_invoice.js +200 -205
  51. package/lib/test/actions/create_transfer.js +115 -120
  52. package/lib/test/commands/adjust_inventory.js +90 -90
  53. package/lib/test/commands/bank.js +90 -90
  54. package/lib/test/commands/basic.js +327 -328
  55. package/lib/test/commands/category.js +90 -90
  56. package/lib/test/commands/channel.js +90 -90
  57. package/lib/test/commands/client.js +353 -355
  58. package/lib/test/commands/client_disabled.js +90 -90
  59. package/lib/test/commands/join.js +327 -328
  60. package/lib/test/commands/measureunit.js +90 -90
  61. package/lib/test/commands/measureunit_family.js +90 -90
  62. package/lib/test/commands/payment_term.js +90 -90
  63. package/lib/test/commands/price_list.js +337 -90
  64. package/lib/test/commands/product.js +90 -90
  65. package/lib/test/commands/product_disabled.js +90 -90
  66. package/lib/test/commands/rep.js +344 -346
  67. package/lib/test/commands/tag.js +90 -90
  68. package/lib/test/commands/tax.js +90 -90
  69. package/lib/test/commands/warehouse.js +90 -90
  70. package/lib/types.d.ts +60 -83
  71. package/lib/util.d.ts +19 -70
  72. package/lib/util.js +144 -170
  73. package/package.json +1 -1
  74. package/src/actions/create_invoice.ts +35 -0
  75. package/src/actions/create_payment.ts +35 -0
  76. package/src/actions/create_proforma.ts +35 -0
  77. package/src/actions/create_return_invoice.ts +35 -0
  78. package/src/actions/create_transfer.ts +34 -0
  79. package/src/commands/price_list.ts +40 -4
  80. package/src/test/commands/price_list.ts +263 -13
package/changelog.md CHANGED
@@ -4,6 +4,8 @@
4
4
 
5
5
  ### Added
6
6
 
7
+ - [actions/***] add 2 keys in integration_meta: sync_to_sap_started & sync_to_sap_succeeded @maramalshen
8
+
7
9
  ### Changed
8
10
 
9
11
  - [commands/rep] delete hard code of rep.warehouse for reps start with: [WS, RET, MT] @maramalshen
@@ -12,6 +14,8 @@
12
14
  ### Fixed
13
15
 
14
16
  - [command/measureunit-family] use _.xor instead or _.difference @maramalshen
17
+ - [command/price_list] fix bug in priceList-item @maramalshen
18
+ - [actions/**] don't update integration_meta.sync_to_sap_succeeded if it is already true @maramalshen
15
19
 
16
20
  ### Removed
17
21
 
@@ -1,26 +1,20 @@
1
1
  import { EVENT, Config } from "../types";
2
2
  interface SAPOpenInvoice {
3
- CustomerNumber: string;
4
- FatherCode: string;
5
- DocDate: string;
6
- DocDueDate: string;
7
- InvoiceID: number;
8
- InvoiceNumber: string;
9
- InvoiceClientID: string;
10
- InvoiceFinalAmount: number;
11
- InvoiceRemainingAmount: number;
12
- InvoiceStatus: string;
3
+ CustomerNumber: string;
4
+ FatherCode: string;
5
+ DocDate: string;
6
+ DocDueDate: string;
7
+ InvoiceID: number;
8
+ InvoiceNumber: string;
9
+ InvoiceClientID: string;
10
+ InvoiceFinalAmount: number;
11
+ InvoiceRemainingAmount: number;
12
+ InvoiceStatus: string;
13
13
  }
14
- export declare const create_invoice: (
15
- event: EVENT,
16
- options: Config
17
- ) => Promise<any>;
18
- export declare const get_invoice_from_sap: (
19
- serviceEndPoint: string,
20
- query?: {
14
+ export declare const create_invoice: (event: EVENT, options: Config) => Promise<any>;
15
+ export declare const get_invoice_from_sap: (serviceEndPoint: string, query?: {
21
16
  updatedAt: string;
22
17
  Status: string;
23
18
  InvoiceId: string;
24
- }
25
- ) => Promise<SAPOpenInvoice[]>;
19
+ }) => Promise<SAPOpenInvoice[]>;
26
20
  export {};
@@ -3,347 +3,227 @@ import { _create } from "../util.js";
3
3
  import { v4 as uuid } from "uuid";
4
4
  import moment from "moment-timezone";
5
5
  export const create_invoice = async (event, options) => {
6
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
7
- const repzo = new Repzo(
8
- (_a = options.data) === null || _a === void 0 ? void 0 : _a.repzoApiKey,
9
- { env: options.env }
10
- );
11
- const action_sync_id =
12
- ((_b = event === null || event === void 0 ? void 0 : event.headers) ===
13
- null || _b === void 0
14
- ? void 0
15
- : _b.action_sync_id) || uuid();
16
- const actionLog = new Repzo.ActionLogs(repzo, action_sync_id);
17
- let body;
18
- try {
19
- // console.log("create_invoice");
20
- await actionLog.load(action_sync_id);
21
- body = event.body;
6
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
7
+ const repzo = new Repzo((_a = options.data) === null || _a === void 0 ? void 0 : _a.repzoApiKey, { env: options.env });
8
+ const action_sync_id = ((_b = event === null || event === void 0 ? void 0 : event.headers) === null || _b === void 0 ? void 0 : _b.action_sync_id) || uuid();
9
+ const actionLog = new Repzo.ActionLogs(repzo, action_sync_id);
10
+ let body;
22
11
  try {
23
- if (body) body = JSON.parse(body);
24
- } catch (e) {}
25
- const repzo_serial_number =
26
- (_c = body === null || body === void 0 ? void 0 : body.serial_number) ===
27
- null || _c === void 0
28
- ? void 0
29
- : _c.formatted;
30
- await actionLog
31
- .addDetail(
32
- `Invoice - ${repzo_serial_number} => ${
33
- body === null || body === void 0 ? void 0 : body.sync_id
34
- }`
35
- )
36
- .addDetail(
37
- `Repzo => SAP: Started Create Invoice - ${repzo_serial_number}`
38
- )
39
- .commit();
40
- const SAP_HOST_URL =
41
- (_d = options.data) === null || _d === void 0 ? void 0 : _d.sapHostUrl;
42
- if (!SAP_HOST_URL)
43
- throw `SAP Host Url is missing and Required: ${SAP_HOST_URL}`;
44
- const repzo_invoice = body;
45
- // Check if it is already exist in SAP
46
- const sap_open_invoices = await get_invoice_from_sap(SAP_HOST_URL, {
47
- updatedAt: "",
48
- Status: "",
49
- InvoiceId: repzo_serial_number,
50
- });
51
- const open_invoice =
52
- sap_open_invoices === null || sap_open_invoices === void 0
53
- ? void 0
54
- : sap_open_invoices.find(
55
- (inv) =>
56
- (inv === null || inv === void 0 ? void 0 : inv.InvoiceNumber) ===
57
- repzo_serial_number
58
- );
59
- if (open_invoice) {
60
- await actionLog
61
- .addDetail(`Checked Already in SAP `, open_invoice)
62
- .addDetail(`Invoice - ${repzo_serial_number} Checked Already in SAP`)
63
- .setStatus("success")
64
- .setBody(repzo_invoice)
65
- .commit();
66
- return {
67
- message: "Checked Already in SAP",
68
- result: open_invoice,
69
- };
70
- }
71
- // Check closed invoice in SAP
72
- const sap_closed_invoices = await get_invoice_from_sap(SAP_HOST_URL, {
73
- updatedAt: "",
74
- Status: "closed",
75
- InvoiceId: repzo_serial_number,
76
- });
77
- const closed_invoice =
78
- sap_closed_invoices === null || sap_closed_invoices === void 0
79
- ? void 0
80
- : sap_closed_invoices.find(
81
- (inv) =>
82
- (inv === null || inv === void 0 ? void 0 : inv.InvoiceNumber) ===
83
- repzo_serial_number
84
- );
85
- if (closed_invoice) {
86
- await actionLog
87
- .addDetail(`Checked Closed Already in SAP `, closed_invoice)
88
- .addDetail(
89
- `Invoice - ${repzo_serial_number} Checked Closed Already in SAP`
90
- )
91
- .setStatus("success")
92
- .setBody(repzo_invoice)
93
- .commit();
94
- return {
95
- message: "Checked Closed Already in SAP",
96
- result: closed_invoice,
97
- };
98
- }
99
- // Get Repzo Rep
100
- let repzo_rep;
101
- if (repzo_invoice.creator.type == "rep") {
102
- repzo_rep = await repzo.rep.get(
103
- (_e =
104
- repzo_invoice === null || repzo_invoice === void 0
105
- ? void 0
106
- : repzo_invoice.creator) === null || _e === void 0
107
- ? void 0
108
- : _e._id
109
- );
110
- if (!repzo_rep)
111
- throw `Rep with _id: ${repzo_invoice.creator._id} not found in Repzo`;
112
- }
113
- // Get Repzo Client
114
- const repzo_client = await repzo.client.get(
115
- repzo_invoice === null || repzo_invoice === void 0
116
- ? void 0
117
- : repzo_invoice.client_id
118
- );
119
- if (!repzo_client)
120
- throw `Client with _id: ${repzo_invoice.client_id} not found in Repzo`;
121
- // Get Repzo Warehouse
122
- const repzo_warehouse = await repzo.warehouse.get(
123
- repzo_invoice.origin_warehouse
124
- );
125
- if (!repzo_warehouse)
126
- throw `warehouse with _id: ${repzo_invoice.origin_warehouse} not found in Repzo`;
127
- const repzo_tax_ids = {};
128
- const repzo_measureunit_ids = {};
129
- const repzo_product_ids = {};
130
- (_f = repzo_invoice.items) === null || _f === void 0
131
- ? void 0
132
- : _f.forEach((item) => {
133
- var _a, _b, _c;
134
- if (item) {
135
- repzo_tax_ids[
136
- (_a = item.tax) === null || _a === void 0 ? void 0 : _a._id
137
- ] = true;
138
- repzo_measureunit_ids[
139
- (_b = item.measureunit) === null || _b === void 0
140
- ? void 0
141
- : _b._id
142
- ] = true;
143
- repzo_product_ids[
144
- (_c = item.variant) === null || _c === void 0
145
- ? void 0
146
- : _c.product_id
147
- ] = true;
148
- }
12
+ // console.log("create_invoice");
13
+ await actionLog.load(action_sync_id);
14
+ body = event.body;
15
+ try {
16
+ if (body)
17
+ body = JSON.parse(body);
18
+ }
19
+ catch (e) { }
20
+ const repzo_serial_number = (_c = body === null || body === void 0 ? void 0 : body.serial_number) === null || _c === void 0 ? void 0 : _c.formatted;
21
+ try {
22
+ if (body === null || body === void 0 ? void 0 : body._id) {
23
+ body.integration_meta = (body === null || body === void 0 ? void 0 : body.integration_meta) || {};
24
+ body.integration_meta.sync_to_sap_started = true;
25
+ body.integration_meta.sync_to_sap_succeeded =
26
+ body.integration_meta.sync_to_sap_succeeded || false;
27
+ await repzo.invoice.update(body._id, {
28
+ integration_meta: body.integration_meta,
29
+ });
30
+ }
31
+ }
32
+ catch (e) {
33
+ console.error(e);
34
+ await actionLog
35
+ .addDetail(`Failed updating integration_meta of Invoice: ${repzo_serial_number}`)
36
+ .commit();
37
+ }
38
+ await actionLog
39
+ .addDetail(`Invoice - ${repzo_serial_number} => ${body === null || body === void 0 ? void 0 : body.sync_id}`)
40
+ .addDetail(`Repzo => SAP: Started Create Invoice - ${repzo_serial_number}`)
41
+ .commit();
42
+ const SAP_HOST_URL = (_d = options.data) === null || _d === void 0 ? void 0 : _d.sapHostUrl;
43
+ if (!SAP_HOST_URL)
44
+ throw `SAP Host Url is missing and Required: ${SAP_HOST_URL}`;
45
+ const repzo_invoice = body;
46
+ // Check if it is already exist in SAP
47
+ const sap_open_invoices = await get_invoice_from_sap(SAP_HOST_URL, {
48
+ updatedAt: "",
49
+ Status: "",
50
+ InvoiceId: repzo_serial_number,
149
51
  });
150
- const repzo_taxes = await repzo.patchAction.create(
151
- {
152
- slug: "tax",
153
- readQuery: [
154
- {
155
- key: "_id",
156
- value: Object.keys(repzo_tax_ids),
157
- operator: "in",
158
- },
159
- ],
160
- },
161
- { per_page: 50000 }
162
- );
163
- const repzo_measureunits = await repzo.patchAction.create(
164
- {
165
- slug: "measureunits",
166
- readQuery: [
167
- {
168
- key: "_id",
169
- value: Object.keys(repzo_measureunit_ids),
170
- operator: "in",
171
- },
172
- ],
173
- },
174
- { per_page: 50000 }
175
- );
176
- const repzo_products = await repzo.patchAction.create(
177
- {
178
- slug: "product",
179
- readQuery: [
180
- {
181
- key: "_id",
182
- value: Object.keys(repzo_product_ids),
183
- operator: "in",
184
- },
185
- ],
186
- },
187
- { per_page: 50000 }
188
- );
189
- // Prepare SAP_invoice_items
190
- const items = [];
191
- for (
192
- let i = 0;
193
- i <
194
- ((_g =
195
- repzo_invoice === null || repzo_invoice === void 0
196
- ? void 0
197
- : repzo_invoice.items) === null || _g === void 0
198
- ? void 0
199
- : _g.length);
200
- i++
201
- ) {
202
- const item = repzo_invoice.items[i];
203
- // Get Repzo Tax
204
- const repzo_tax =
205
- (_h =
206
- repzo_taxes === null || repzo_taxes === void 0
207
- ? void 0
208
- : repzo_taxes.data) === null || _h === void 0
209
- ? void 0
210
- : _h.find((t) => {
211
- var _a, _b, _c;
212
- return (
213
- ((_a = t._id) === null || _a === void 0
214
- ? void 0
215
- : _a.toString()) ==
216
- ((_c =
217
- (_b = item.tax) === null || _b === void 0
218
- ? void 0
219
- : _b._id) === null || _c === void 0
220
- ? void 0
221
- : _c.toString())
222
- );
223
- });
224
- if (!repzo_tax) throw `Tax with _id: ${item.tax._id} not found in Repzo`;
225
- // Get Repzo UoM
226
- const repzo_measureunit =
227
- (_j =
228
- repzo_measureunits === null || repzo_measureunits === void 0
229
- ? void 0
230
- : repzo_measureunits.data) === null || _j === void 0
231
- ? void 0
232
- : _j.find((m) => {
233
- var _a, _b, _c;
234
- return (
235
- ((_a = m._id) === null || _a === void 0
236
- ? void 0
237
- : _a.toString()) ==
238
- ((_c =
239
- (_b = item.measureunit) === null || _b === void 0
240
- ? void 0
241
- : _b._id) === null || _c === void 0
242
- ? void 0
243
- : _c.toString())
244
- );
245
- });
246
- if (!repzo_measureunit)
247
- throw `Uom with _id: ${
248
- (_k = item.measureunit) === null || _k === void 0 ? void 0 : _k._id
249
- } not found in Repzo`;
250
- // Get Repzo Product
251
- const repzo_product =
252
- (_l =
253
- repzo_products === null || repzo_products === void 0
254
- ? void 0
255
- : repzo_products.data) === null || _l === void 0
256
- ? void 0
257
- : _l.find((p) => {
258
- var _a, _b, _c;
259
- return (
260
- ((_a = p._id) === null || _a === void 0
261
- ? void 0
262
- : _a.toString()) ==
263
- ((_c =
264
- (_b = item.variant) === null || _b === void 0
265
- ? void 0
266
- : _b.product_id) === null || _c === void 0
267
- ? void 0
268
- : _c.toString())
269
- );
52
+ const open_invoice = sap_open_invoices === null || sap_open_invoices === void 0 ? void 0 : sap_open_invoices.find((inv) => (inv === null || inv === void 0 ? void 0 : inv.InvoiceNumber) === repzo_serial_number);
53
+ if (open_invoice) {
54
+ await actionLog
55
+ .addDetail(`Checked Already in SAP `, open_invoice)
56
+ .addDetail(`Invoice - ${repzo_serial_number} Checked Already in SAP`)
57
+ .setStatus("success")
58
+ .setBody(repzo_invoice)
59
+ .commit();
60
+ return {
61
+ message: "Checked Already in SAP",
62
+ result: open_invoice,
63
+ };
64
+ }
65
+ // Check closed invoice in SAP
66
+ const sap_closed_invoices = await get_invoice_from_sap(SAP_HOST_URL, {
67
+ updatedAt: "",
68
+ Status: "closed",
69
+ InvoiceId: repzo_serial_number,
70
+ });
71
+ const closed_invoice = sap_closed_invoices === null || sap_closed_invoices === void 0 ? void 0 : sap_closed_invoices.find((inv) => (inv === null || inv === void 0 ? void 0 : inv.InvoiceNumber) === repzo_serial_number);
72
+ if (closed_invoice) {
73
+ await actionLog
74
+ .addDetail(`Checked Closed Already in SAP `, closed_invoice)
75
+ .addDetail(`Invoice - ${repzo_serial_number} Checked Closed Already in SAP`)
76
+ .setStatus("success")
77
+ .setBody(repzo_invoice)
78
+ .commit();
79
+ return {
80
+ message: "Checked Closed Already in SAP",
81
+ result: closed_invoice,
82
+ };
83
+ }
84
+ // Get Repzo Rep
85
+ let repzo_rep;
86
+ if (repzo_invoice.creator.type == "rep") {
87
+ repzo_rep = await repzo.rep.get((_e = repzo_invoice === null || repzo_invoice === void 0 ? void 0 : repzo_invoice.creator) === null || _e === void 0 ? void 0 : _e._id);
88
+ if (!repzo_rep)
89
+ throw `Rep with _id: ${repzo_invoice.creator._id} not found in Repzo`;
90
+ }
91
+ // Get Repzo Client
92
+ const repzo_client = await repzo.client.get(repzo_invoice === null || repzo_invoice === void 0 ? void 0 : repzo_invoice.client_id);
93
+ if (!repzo_client)
94
+ throw `Client with _id: ${repzo_invoice.client_id} not found in Repzo`;
95
+ // Get Repzo Warehouse
96
+ const repzo_warehouse = await repzo.warehouse.get(repzo_invoice.origin_warehouse);
97
+ if (!repzo_warehouse)
98
+ throw `warehouse with _id: ${repzo_invoice.origin_warehouse} not found in Repzo`;
99
+ const repzo_tax_ids = {};
100
+ const repzo_measureunit_ids = {};
101
+ const repzo_product_ids = {};
102
+ (_f = repzo_invoice.items) === null || _f === void 0 ? void 0 : _f.forEach((item) => {
103
+ var _a, _b, _c;
104
+ if (item) {
105
+ repzo_tax_ids[(_a = item.tax) === null || _a === void 0 ? void 0 : _a._id] = true;
106
+ repzo_measureunit_ids[(_b = item.measureunit) === null || _b === void 0 ? void 0 : _b._id] = true;
107
+ repzo_product_ids[(_c = item.variant) === null || _c === void 0 ? void 0 : _c.product_id] = true;
108
+ }
109
+ });
110
+ const repzo_taxes = await repzo.patchAction.create({
111
+ slug: "tax",
112
+ readQuery: [
113
+ {
114
+ key: "_id",
115
+ value: Object.keys(repzo_tax_ids),
116
+ operator: "in",
117
+ },
118
+ ],
119
+ }, { per_page: 50000 });
120
+ const repzo_measureunits = await repzo.patchAction.create({
121
+ slug: "measureunits",
122
+ readQuery: [
123
+ {
124
+ key: "_id",
125
+ value: Object.keys(repzo_measureunit_ids),
126
+ operator: "in",
127
+ },
128
+ ],
129
+ }, { per_page: 50000 });
130
+ const repzo_products = await repzo.patchAction.create({
131
+ slug: "product",
132
+ readQuery: [
133
+ {
134
+ key: "_id",
135
+ value: Object.keys(repzo_product_ids),
136
+ operator: "in",
137
+ },
138
+ ],
139
+ }, { per_page: 50000 });
140
+ // Prepare SAP_invoice_items
141
+ const items = [];
142
+ for (let i = 0; i < ((_g = repzo_invoice === null || repzo_invoice === void 0 ? void 0 : repzo_invoice.items) === null || _g === void 0 ? void 0 : _g.length); i++) {
143
+ const item = repzo_invoice.items[i];
144
+ // Get Repzo Tax
145
+ const repzo_tax = (_h = repzo_taxes === null || repzo_taxes === void 0 ? void 0 : repzo_taxes.data) === null || _h === void 0 ? void 0 : _h.find((t) => { var _a, _b, _c; return ((_a = t._id) === null || _a === void 0 ? void 0 : _a.toString()) == ((_c = (_b = item.tax) === null || _b === void 0 ? void 0 : _b._id) === null || _c === void 0 ? void 0 : _c.toString()); });
146
+ if (!repzo_tax)
147
+ throw `Tax with _id: ${item.tax._id} not found in Repzo`;
148
+ // Get Repzo UoM
149
+ const repzo_measureunit = (_j = repzo_measureunits === null || repzo_measureunits === void 0 ? void 0 : repzo_measureunits.data) === null || _j === void 0 ? void 0 : _j.find((m) => { var _a, _b, _c; return ((_a = m._id) === null || _a === void 0 ? void 0 : _a.toString()) == ((_c = (_b = item.measureunit) === null || _b === void 0 ? void 0 : _b._id) === null || _c === void 0 ? void 0 : _c.toString()); });
150
+ if (!repzo_measureunit)
151
+ throw `Uom with _id: ${(_k = item.measureunit) === null || _k === void 0 ? void 0 : _k._id} not found in Repzo`;
152
+ // Get Repzo Product
153
+ const repzo_product = (_l = repzo_products === null || repzo_products === void 0 ? void 0 : repzo_products.data) === null || _l === void 0 ? void 0 : _l.find((p) => { var _a, _b, _c; return ((_a = p._id) === null || _a === void 0 ? void 0 : _a.toString()) == ((_c = (_b = item.variant) === null || _b === void 0 ? void 0 : _b.product_id) === null || _c === void 0 ? void 0 : _c.toString()); });
154
+ if (!repzo_product)
155
+ throw `Product with _id: ${item.measureunit._id} not found in Repzo`;
156
+ items.push({
157
+ ItemCode: item.variant.variant_name,
158
+ Quantity: item.qty,
159
+ TaxCode: repzo_tax.integration_meta.TaxCode,
160
+ UnitPrice: (item.price * repzo_measureunit.factor) / 1000,
161
+ DiscountPerc: "0",
162
+ //@ts-ignore
163
+ LineTotal: item.total_before_tax / 1000,
164
+ UomCode: repzo_measureunit.integration_meta.ALTUOMID,
165
+ Brand: (_m = repzo_product.integration_meta) === null || _m === void 0 ? void 0 : _m.BRAND,
166
+ Department: ((_o = repzo_rep === null || repzo_rep === void 0 ? void 0 : repzo_rep.integration_meta) === null || _o === void 0 ? void 0 : _o.DEPARTMENTCODE) ||
167
+ ((_p = options.data) === null || _p === void 0 ? void 0 : _p.DepartmentCode), // "D2",
270
168
  });
271
- if (!repzo_product)
272
- throw `Product with _id: ${item.measureunit._id} not found in Repzo`;
273
- items.push({
274
- ItemCode: item.variant.variant_name,
275
- Quantity: item.qty,
276
- TaxCode: repzo_tax.integration_meta.TaxCode,
277
- UnitPrice: (item.price * repzo_measureunit.factor) / 1000,
278
- DiscountPerc: "0",
169
+ }
170
+ const sap_invoice = {
171
+ RefNum: repzo_invoice.serial_number.formatted,
172
+ SalPersCode: repzo_rep === null || repzo_rep === void 0 ? void 0 : repzo_rep.integration_id,
173
+ DocDate: moment(repzo_invoice.issue_date, "YYYY-MM-DD").format("YYYYMMDD"),
174
+ DocDueDate: moment(repzo_invoice.due_date, "YYYY-MM-DD").format("YYYYMMDD"),
175
+ ClientCode: repzo_client.client_code,
176
+ DiscountPerc: "0",
177
+ Note: repzo_invoice.comment,
178
+ WarehouseCode: repzo_warehouse.code,
179
+ LinesDetails: items,
180
+ };
181
+ // console.dir(sap_invoice, { depth: null });
182
+ await actionLog
183
+ .addDetail(`Repzo => SAP: Invoice - ${repzo_serial_number}`, sap_invoice)
184
+ .commit();
185
+ const result = await _create(SAP_HOST_URL, "/AddInvoice", sap_invoice);
186
+ // console.log(result);
187
+ try {
188
+ if (body === null || body === void 0 ? void 0 : body._id) {
189
+ body.integration_meta = (body === null || body === void 0 ? void 0 : body.integration_meta) || {};
190
+ body.integration_meta.sync_to_sap_succeeded = true;
191
+ await repzo.invoice.update(body._id, {
192
+ integration_meta: body.integration_meta,
193
+ });
194
+ }
195
+ }
196
+ catch (e) {
197
+ console.error(e);
198
+ await actionLog
199
+ .addDetail(`Failed updating integration_meta of Invoice: ${repzo_serial_number}`)
200
+ .commit();
201
+ }
202
+ await actionLog
203
+ .addDetail(`SAP Responded with `, result)
204
+ .addDetail(`Repzo => SAP: Invoice - ${repzo_serial_number}`)
205
+ .setStatus("success")
206
+ .setBody(repzo_invoice)
207
+ .commit();
208
+ return result;
209
+ }
210
+ catch (e) {
279
211
  //@ts-ignore
280
- LineTotal: item.total_before_tax / 1000,
281
- UomCode: repzo_measureunit.integration_meta.ALTUOMID,
282
- Brand:
283
- (_m = repzo_product.integration_meta) === null || _m === void 0
284
- ? void 0
285
- : _m.BRAND,
286
- Department:
287
- ((_o =
288
- repzo_rep === null || repzo_rep === void 0
289
- ? void 0
290
- : repzo_rep.integration_meta) === null || _o === void 0
291
- ? void 0
292
- : _o.DEPARTMENTCODE) ||
293
- ((_p = options.data) === null || _p === void 0
294
- ? void 0
295
- : _p.DepartmentCode), // "D2",
296
- });
212
+ console.error((e === null || e === void 0 ? void 0 : e.response) || e);
213
+ await actionLog.setStatus("fail", e).setBody(body).commit();
214
+ throw e;
297
215
  }
298
- const sap_invoice = {
299
- RefNum: repzo_invoice.serial_number.formatted,
300
- SalPersCode:
301
- repzo_rep === null || repzo_rep === void 0
302
- ? void 0
303
- : repzo_rep.integration_id,
304
- DocDate: moment(repzo_invoice.issue_date, "YYYY-MM-DD").format(
305
- "YYYYMMDD"
306
- ),
307
- DocDueDate: moment(repzo_invoice.due_date, "YYYY-MM-DD").format(
308
- "YYYYMMDD"
309
- ),
310
- ClientCode: repzo_client.client_code,
311
- DiscountPerc: "0",
312
- Note: repzo_invoice.comment,
313
- WarehouseCode: repzo_warehouse.code,
314
- LinesDetails: items,
315
- };
316
- // console.dir(sap_invoice, { depth: null });
317
- await actionLog
318
- .addDetail(`Repzo => SAP: Invoice - ${repzo_serial_number}`, sap_invoice)
319
- .commit();
320
- const result = await _create(SAP_HOST_URL, "/AddInvoice", sap_invoice);
321
- // console.log(result);
322
- await actionLog
323
- .addDetail(`SAP Responded with `, result)
324
- .addDetail(`Repzo => SAP: Invoice - ${repzo_serial_number}`)
325
- .setStatus("success")
326
- .setBody(repzo_invoice)
327
- .commit();
328
- return result;
329
- } catch (e) {
330
- //@ts-ignore
331
- console.error((e === null || e === void 0 ? void 0 : e.response) || e);
332
- await actionLog.setStatus("fail", e).setBody(body).commit();
333
- throw e;
334
- }
335
216
  };
336
217
  export const get_invoice_from_sap = async (serviceEndPoint, query) => {
337
- try {
338
- const sap_openInvoices = await _create(serviceEndPoint, "/OpenInvoices", {
339
- updatedAt: query === null || query === void 0 ? void 0 : query.updatedAt,
340
- Status: query === null || query === void 0 ? void 0 : query.Status,
341
- InvoiceId: query === null || query === void 0 ? void 0 : query.InvoiceId,
342
- });
343
- return sap_openInvoices === null || sap_openInvoices === void 0
344
- ? void 0
345
- : sap_openInvoices.OpenInvoices;
346
- } catch (e) {
347
- throw e;
348
- }
218
+ try {
219
+ const sap_openInvoices = await _create(serviceEndPoint, "/OpenInvoices", {
220
+ updatedAt: query === null || query === void 0 ? void 0 : query.updatedAt,
221
+ Status: query === null || query === void 0 ? void 0 : query.Status,
222
+ InvoiceId: query === null || query === void 0 ? void 0 : query.InvoiceId,
223
+ });
224
+ return sap_openInvoices === null || sap_openInvoices === void 0 ? void 0 : sap_openInvoices.OpenInvoices;
225
+ }
226
+ catch (e) {
227
+ throw e;
228
+ }
349
229
  };
@@ -1,5 +1,2 @@
1
1
  import { EVENT, Config } from "../types";
2
- export declare const create_payment: (
3
- event: EVENT,
4
- options: Config
5
- ) => Promise<any>;
2
+ export declare const create_payment: (event: EVENT, options: Config) => Promise<any>;