repzo-sap-absjo 1.0.10 → 1.0.12

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