shareneus 1.0.5

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 (125) hide show
  1. package/dist/aggregation/aggregation.js +60 -0
  2. package/dist/enums/cache-enums.js +37 -0
  3. package/dist/enums/code-enums.js +288 -0
  4. package/dist/enums/enums.js +362 -0
  5. package/dist/enums/industry-enums.js +24 -0
  6. package/dist/excel-files/GSTR-RO-excel.service.js +935 -0
  7. package/dist/excel-files/GSTR1-excel.service.js +295 -0
  8. package/dist/excel-files/GSTR2-excel.service.js +295 -0
  9. package/dist/excel-files/analysis-excel.service.js +297 -0
  10. package/dist/excel-files/category-wise-item-excel.service.js +274 -0
  11. package/dist/excel-files/cust-balance-excel.service.js +287 -0
  12. package/dist/excel-files/cust-wise-sales-details.js +320 -0
  13. package/dist/excel-files/cust-wise-sales-summary-excel.service.js +302 -0
  14. package/dist/excel-files/expiring-drugs-excel.service.js +292 -0
  15. package/dist/excel-files/insurance-expire-excel.service.js +301 -0
  16. package/dist/excel-files/invoice-wise-excel.service.js +857 -0
  17. package/dist/excel-files/item-wise-doctor-sale-excel.service.js +258 -0
  18. package/dist/excel-files/item-wise-mout-details.js +292 -0
  19. package/dist/excel-files/item-wise-mout-summary.js +286 -0
  20. package/dist/excel-files/items-wise-sales-excel.service.js +314 -0
  21. package/dist/excel-files/manf-wise-sales-excel.service.js +276 -0
  22. package/dist/excel-files/operator-wise-details.js +265 -0
  23. package/dist/excel-files/operator-wise-summary.js +266 -0
  24. package/dist/excel-files/payment-receive-excel.service.js +225 -0
  25. package/dist/excel-files/payments-made-excel.service.js +302 -0
  26. package/dist/excel-files/repair-orders-excel.service.js +255 -0
  27. package/dist/excel-files/sa-wise-labor-sales-excel.service.js +232 -0
  28. package/dist/excel-files/sa-wise-part-sales-excel.service.js +232 -0
  29. package/dist/excel-files/sale-summary-excel.service.js +326 -0
  30. package/dist/excel-files/sales-by-service-details-excel.service.js +1 -0
  31. package/dist/excel-files/sales-by-service-summary-excel.service.js +422 -0
  32. package/dist/excel-files/scheduled-drug-summary-excel.service.js +367 -0
  33. package/dist/excel-files/scheduled-drugs-excel.service.js +366 -0
  34. package/dist/excel-files/spares-issue-excel.service.js +492 -0
  35. package/dist/excel-files/stock-excel.service.js +283 -0
  36. package/dist/excel-files/tally-sales-import.service.js +765 -0
  37. package/dist/excel-files/ven-balance-excel.service.js +293 -0
  38. package/dist/index.js +237 -0
  39. package/dist/services/analysis-pdf.service.js +105 -0
  40. package/dist/services/appointment-total.service.js +253 -0
  41. package/dist/services/auto-sales-receipt-pdf.service.js +539 -0
  42. package/dist/services/category-wise-item-pdf.service.js +98 -0
  43. package/dist/services/checklist-pdf.js +140 -0
  44. package/dist/services/checklists-pdf.js +124 -0
  45. package/dist/services/cn-print.service.js +211 -0
  46. package/dist/services/consultation-fee-receipt.service.js +378 -0
  47. package/dist/services/consultation-full-pdf.service.js +220 -0
  48. package/dist/services/consultation-pdf.service.js +360 -0
  49. package/dist/services/credit-note-pdf.service.js +578 -0
  50. package/dist/services/credit-note-totals.service.js +328 -0
  51. package/dist/services/cust-wise-sales-details-pdf.service.js +118 -0
  52. package/dist/services/cust-wise-sales-summary-pdf.service.js +111 -0
  53. package/dist/services/customer-balances-pdf.service.js +169 -0
  54. package/dist/services/dc-landscape-pdf.service.js +903 -0
  55. package/dist/services/dc-landscape-without-price-pdf.service.js +853 -0
  56. package/dist/services/dc-without-price-pdf.service.js +489 -0
  57. package/dist/services/debit-note-pdf.service.js +673 -0
  58. package/dist/services/debit-note-print.service.js +234 -0
  59. package/dist/services/debit-note-totals.service.js +293 -0
  60. package/dist/services/delivery-challan-pdf.service.js +434 -0
  61. package/dist/services/delivery-challan-print.service.js +177 -0
  62. package/dist/services/delivery-challan-totals.js +339 -0
  63. package/dist/services/equipment-design-pdf.service.js +144 -0
  64. package/dist/services/est.print-service.js +1053 -0
  65. package/dist/services/expiring-drugs-pdf.service.js +156 -0
  66. package/dist/services/hc-inv-pdf.service.js +837 -0
  67. package/dist/services/insurance-expire-pdf.service.js +99 -0
  68. package/dist/services/inv-pdf.service.js +785 -0
  69. package/dist/services/inv-print.service.js +415 -0
  70. package/dist/services/invoice-landscape-pdf.service.js +909 -0
  71. package/dist/services/invoice-total.service.js +659 -0
  72. package/dist/services/issue-parts-pdf.service.js +763 -0
  73. package/dist/services/item-detais-pdf.js +136 -0
  74. package/dist/services/item-wise-doctor-sale-pdf.service.js +164 -0
  75. package/dist/services/item-wise-mout-details-pdf.js +107 -0
  76. package/dist/services/item-wise-mout-summary-pdf.js +99 -0
  77. package/dist/services/item-wise-sales-pdf.service.js +178 -0
  78. package/dist/services/manf-wise-sales-pdf.service.js +173 -0
  79. package/dist/services/meeting-pdf.js +369 -0
  80. package/dist/services/mout-pdf.service.js +503 -0
  81. package/dist/services/operator-wise-details-pdf.service.js +103 -0
  82. package/dist/services/operator-wise-summary-pdf.js +101 -0
  83. package/dist/services/pack-ship-pdf.service.js +105 -0
  84. package/dist/services/pack-ship-print.service.js +167 -0
  85. package/dist/services/payment-pdf.service.js +373 -0
  86. package/dist/services/payment-report-pdf.service.js +106 -0
  87. package/dist/services/po-totals.service.js +279 -0
  88. package/dist/services/pos-receipt-pdf.js +438 -0
  89. package/dist/services/purchase-order-pdf.service.js +924 -0
  90. package/dist/services/purchase-order-print.service.js +150 -0
  91. package/dist/services/purchase-order-totals.service.js +280 -0
  92. package/dist/services/receipt-print.service.js +50 -0
  93. package/dist/services/reorder-point-pdf.service.js +151 -0
  94. package/dist/services/repair-orders-pdf.service.js +172 -0
  95. package/dist/services/ro-pdf.service.js +1764 -0
  96. package/dist/services/ro-print-service.js +737 -0
  97. package/dist/services/ro-totals.service.js +1241 -0
  98. package/dist/services/sales-by-service-pdf.service.js +116 -0
  99. package/dist/services/sales-pdf.service.js +630 -0
  100. package/dist/services/sales-print.service.js +305 -0
  101. package/dist/services/sales-receipt-pdf.service.js +611 -0
  102. package/dist/services/sales-receipt-print.service.js +425 -0
  103. package/dist/services/sales-totals.service.js +339 -0
  104. package/dist/services/scheduled-drug-pdf.service.js +176 -0
  105. package/dist/services/scheduled-drug-summary-pdf.service.js +188 -0
  106. package/dist/services/separate-wo-print.service.js +351 -0
  107. package/dist/services/shared-inv-pdf.service.js +763 -0
  108. package/dist/services/shared-pdf.service.js +2569 -0
  109. package/dist/services/shared-print.service.js +885 -0
  110. package/dist/services/task-pdf.service.js +220 -0
  111. package/dist/services/task-reports-pdf.service.js +296 -0
  112. package/dist/services/technician-pdf.service.js +238 -0
  113. package/dist/services/technician-print.service.js +87 -0
  114. package/dist/services/transfer-order-pdf.service.js +139 -0
  115. package/dist/services/vendor-balances-pdf.service.js +101 -0
  116. package/dist/services/vendor-credit-note-pdf.service.js +1007 -0
  117. package/dist/services/vendor-credit-note-print.service.js +104 -0
  118. package/dist/services/vendor-credit-note-totals.service.js +327 -0
  119. package/dist/services/vendor-debit-note-pdf.service.js +561 -0
  120. package/dist/services/vendor-debit-note-print.service.js +245 -0
  121. package/dist/services/vendor-debit-note-totals.service.js +305 -0
  122. package/dist/utils/my-date.js +652 -0
  123. package/dist/utils/tr-utils.js +354 -0
  124. package/package.json +24 -0
  125. package/tsconfig.json +109 -0
@@ -0,0 +1,287 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.CustBalanceXlsxFileService = void 0;
27
+ const XLSX = __importStar(require("xlsx"));
28
+ const tr_utils_1 = require("../utils/tr-utils");
29
+ class CustBalanceXlsxFileService {
30
+ static GetInvoiceWiseExcelData(MainData, isPhar, WOTypes) {
31
+ this.wb = {};
32
+ this.ws = {};
33
+ this.Row = 0;
34
+ this.range = { s: { c: 0, r: 0 }, e: { c: 0, r: 0 } };
35
+ this.MergeArray = [];
36
+ let ws_name = 'OUT STANDING REPORT';
37
+ this.wb.Sheets = {};
38
+ this.wb.Props = {};
39
+ this.wb.SSF = {};
40
+ this.wb.SheetNames = [];
41
+ if (!tr_utils_1.TrUtils.IsNull(WOTypes) && (WOTypes === null || WOTypes === void 0 ? void 0 : WOTypes.length) !== 0) {
42
+ MainData = this.GetTotals(MainData, WOTypes);
43
+ }
44
+ this.setHeadingInCell(isPhar);
45
+ this.setInvoiceDetailsInCell(MainData, isPhar);
46
+ this.ws['!ref'] = XLSX.utils.encode_range(this.range);
47
+ this.ws['!merges'] = this.MergeArray;
48
+ this.ws["!cols"] = [{ wch: 10 }, { wch: 15 }, { wch: 15 }, { wch: 35 }, { wch: 15 }, { wch: 15 }, { wch: 20 }, { wch: 15 }, { wch: 15 }, { wch: 20 }];
49
+ this.wb.SheetNames.push(ws_name);
50
+ this.wb.Sheets[ws_name] = this.ws;
51
+ return this.wb;
52
+ }
53
+ static GetTotals(MainData, WOTypes) {
54
+ MainData.forEach((InvoiceInfo) => {
55
+ // if (InvoiceInfo.VIN == null) {
56
+ // InvoiceInfo.VIN = '';
57
+ // }
58
+ // if (InvoiceInfo.Name == null) {
59
+ // InvoiceInfo.Name = '';
60
+ // }
61
+ // if (InvoiceInfo.TeNa == null) {
62
+ // InvoiceInfo.TeNa = '';
63
+ // }
64
+ // if (InvoiceInfo.Type == null) {
65
+ // InvoiceInfo.TypeName = '';
66
+ // } else {
67
+ InvoiceInfo.TypeName = this.GetWOTypeName(InvoiceInfo.Type, WOTypes);
68
+ // }
69
+ // InvoiceInfo.GSTAmount =
70
+ // InvoiceInfo.ItemsCGST + InvoiceInfo.ItemsSGST + InvoiceInfo.ItemsIGST;
71
+ // InvoiceInfo.TotalAmount = InvoiceInfo.GSTAmount + InvoiceInfo.ItemsNetAmt;
72
+ // InvoiceInfo.OpsGSTAmount =
73
+ // InvoiceInfo.OpsCGST + InvoiceInfo.OpsSGST + InvoiceInfo.OpsIGST;
74
+ // InvoiceInfo.TotalOpsAmount =
75
+ // InvoiceInfo.OpsGSTAmount + InvoiceInfo.OpsNetAmt;
76
+ });
77
+ return MainData;
78
+ }
79
+ static GetWOTypeName(Type, WOTypes) {
80
+ let Index = WOTypes.findIndex((wotype) => {
81
+ return Type === wotype._id;
82
+ });
83
+ if (Index !== -1) {
84
+ return WOTypes[Index].Name;
85
+ }
86
+ else {
87
+ return '';
88
+ }
89
+ }
90
+ static setHeadingInCell(isPhar) {
91
+ let MainHeadings = [
92
+ {
93
+ text: 'SNo',
94
+ ColRange: 1,
95
+ bold: true,
96
+ ChildHeadings: [],
97
+ },
98
+ {
99
+ text: 'Date',
100
+ ColRange: 1,
101
+ bold: true,
102
+ ChildHeadings: [],
103
+ },
104
+ {
105
+ text: isPhar ? 'Counter Sale No.' : 'Invoice No.',
106
+ ColRange: 1,
107
+ bold: true,
108
+ ChildHeadings: [],
109
+ },
110
+ {
111
+ text: 'Customer Name',
112
+ ColRange: 1,
113
+ bold: true,
114
+ ChildHeadings: [],
115
+ },
116
+ {
117
+ text: 'Amount',
118
+ ColRange: 1,
119
+ bold: true,
120
+ ChildHeadings: [],
121
+ },
122
+ // {
123
+ // text: 'Due',
124
+ // ColRange: 1,
125
+ // bold: true,
126
+ // ChildHeadings: [
127
+ // ],
128
+ // },
129
+ ];
130
+ if (!isPhar) {
131
+ MainHeadings.splice(4, 0, {
132
+ text: 'Vehicle Reg No',
133
+ ColRange: 1,
134
+ bold: true,
135
+ ChildHeadings: [],
136
+ }, {
137
+ text: 'Model',
138
+ ColRange: 1,
139
+ bold: true,
140
+ ChildHeadings: [],
141
+ }, {
142
+ text: 'Advisor Name',
143
+ ColRange: 1,
144
+ bold: true,
145
+ ChildHeadings: [],
146
+ }, {
147
+ text: 'RO NO.',
148
+ ColRange: 1,
149
+ bold: true,
150
+ ChildHeadings: [],
151
+ }, {
152
+ text: 'RO Type',
153
+ ColRange: 1,
154
+ bold: true,
155
+ ChildHeadings: [],
156
+ });
157
+ }
158
+ let MainColStart = 0;
159
+ MainHeadings.forEach((MainHeader) => {
160
+ this.SetDataInCell(MainHeader.text, MainColStart, this.Row);
161
+ this.MergeArray.push({
162
+ s: { r: this.Row, c: MainColStart },
163
+ e: { r: this.Row, c: MainColStart + MainHeader.ColRange - 1 },
164
+ });
165
+ MainColStart += MainHeader.ColRange;
166
+ });
167
+ this.Row += 1;
168
+ }
169
+ static setInvoiceDetailsInCell(MainData, isPhar) {
170
+ MainData.forEach((Record, index) => {
171
+ // this.setHeading1InCell(Record.Name);
172
+ // this.setHeadingInCell();
173
+ this.SetInvoiceDataInExcel(Record, index, isPhar);
174
+ // Record.Invoices.forEach((Invoice:any, index:any)=>{
175
+ // this.SetInvoiceDataInExcel(Invoice, index);
176
+ // if (Record.Invoices.length === (index + 1)) {
177
+ // this.setInvoiceFinalRowInCell(Record.Balance);
178
+ // }
179
+ // });
180
+ // this.Row += 1;
181
+ });
182
+ }
183
+ static SetInvoiceDataInExcel(InvoiceInfo, index, isPhar) {
184
+ var _a, _b, _c;
185
+ // InvoiceInfo.CrDate = this.ConvertDateToReadableFormat(InvoiceInfo.CrDate);
186
+ InvoiceInfo.CrDate = this.ConvertDateToReadableFormat(InvoiceInfo.CrDate);
187
+ let InvoiceData = [
188
+ { text: index + 1, ColRange: 1, IsString: true },
189
+ { text: InvoiceInfo.CrDate, ColRange: 1, IsString: true },
190
+ { text: InvoiceInfo.Code, ColRange: 1, IsString: true },
191
+ { text: (_a = InvoiceInfo.BillTo) === null || _a === void 0 ? void 0 : _a.Name, ColRange: 1, IsString: true },
192
+ { text: tr_utils_1.TrUtils.FixPriceValue(InvoiceInfo.Total), ColRange: 1, IsString: false },
193
+ // { text: InvoiceInfo.Due, ColRange: 1, IsString: false },
194
+ ];
195
+ if (!isPhar) {
196
+ InvoiceData.splice(4, 0, { text: (_b = InvoiceInfo.Prod) === null || _b === void 0 ? void 0 : _b.RegNo, ColRange: 1, IsString: true }, { text: (_c = InvoiceInfo.Prod) === null || _c === void 0 ? void 0 : _c.Model, ColRange: 1, IsString: true }, { text: InvoiceInfo.Name, ColRange: 1, IsString: true }, { text: InvoiceInfo.WCode, ColRange: 1, IsString: true }, { text: InvoiceInfo.TypeName, ColRange: 1, IsString: true });
197
+ }
198
+ let ColStart = 0;
199
+ InvoiceData.forEach((InvData) => {
200
+ InvData.text = this.ConvertToString(InvData.text, InvData.IsString);
201
+ this.SetDataInCell(InvData.text, ColStart, this.Row);
202
+ this.MergeArray.push({
203
+ s: { r: this.Row, c: ColStart },
204
+ e: { r: this.Row, c: ColStart + InvData.ColRange - 1 },
205
+ });
206
+ ColStart += InvData.ColRange;
207
+ });
208
+ this.Row += 1;
209
+ }
210
+ static ConvertToString(Text, IsString) {
211
+ if (IsString) {
212
+ if (Text == null) {
213
+ Text = '';
214
+ }
215
+ }
216
+ else {
217
+ if (Text == null) {
218
+ Text = 0;
219
+ }
220
+ }
221
+ if (typeof Text === 'number') {
222
+ return Number(tr_utils_1.TrUtils.FixedTo(Text));
223
+ }
224
+ else {
225
+ return Text;
226
+ }
227
+ }
228
+ static SetDataInCell(Data, ColRange, RowNum) {
229
+ var cell = { v: Data };
230
+ var cell_ref = XLSX.utils.encode_cell({ c: ColRange, r: RowNum });
231
+ if (this.range.e.c < ColRange) {
232
+ this.range.e.c = ColRange;
233
+ }
234
+ if (this.range.e.r < RowNum) {
235
+ this.range.e.r = RowNum;
236
+ }
237
+ cell = this.getcelltype(cell);
238
+ this.ws[cell_ref] = cell;
239
+ }
240
+ static getcelltype(cell) {
241
+ if (typeof cell.v === 'number')
242
+ cell.t = 'n';
243
+ else if (typeof cell.v === 'boolean')
244
+ cell.t = 'b';
245
+ else
246
+ cell.t = 's';
247
+ return cell;
248
+ }
249
+ static ConvertDateToReadableFormat(DateObject) {
250
+ if (!tr_utils_1.TrUtils.IsEmpty(DateObject)) {
251
+ let date = new Date(DateObject);
252
+ let Month;
253
+ let Day;
254
+ let MonthName = new Array();
255
+ MonthName[0] = 'Jan';
256
+ MonthName[1] = 'Feb';
257
+ MonthName[2] = 'Mar';
258
+ MonthName[3] = 'Apr';
259
+ MonthName[4] = 'May';
260
+ MonthName[5] = 'Jun';
261
+ MonthName[6] = 'Jul';
262
+ MonthName[7] = 'Aug';
263
+ MonthName[8] = 'Sept';
264
+ MonthName[9] = 'Oct';
265
+ MonthName[10] = 'Nov';
266
+ MonthName[11] = 'Dec';
267
+ Month = MonthName[date.getMonth()];
268
+ if (date.getDate() < 10) {
269
+ Day = '0' + date.getDate();
270
+ }
271
+ else {
272
+ Day = date.getDate();
273
+ }
274
+ date = Day + '-' + Month + '-' + date.getFullYear();
275
+ return date;
276
+ }
277
+ else {
278
+ return null;
279
+ }
280
+ }
281
+ }
282
+ exports.CustBalanceXlsxFileService = CustBalanceXlsxFileService;
283
+ CustBalanceXlsxFileService.wb = {};
284
+ CustBalanceXlsxFileService.Row = 2;
285
+ CustBalanceXlsxFileService.MergeArray = [];
286
+ CustBalanceXlsxFileService.range = { s: { c: 0, r: 0 }, e: { c: 0, r: 0 } };
287
+ CustBalanceXlsxFileService.ws = {};
@@ -0,0 +1,320 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.CustWiseSalesXlsxFileService = void 0;
27
+ const XLSX = __importStar(require("xlsx"));
28
+ const my_date_1 = require("../utils/my-date");
29
+ const tr_utils_1 = require("../utils/tr-utils");
30
+ class CustWiseSalesXlsxFileService {
31
+ static GetCustWiseSalesDetailsExcelData(MainData, isSale, searchValue) {
32
+ this.wb = {};
33
+ this.ws = {};
34
+ this.Row = 0;
35
+ this.range = { s: { c: 0, r: 0 }, e: { c: 0, r: 0 } };
36
+ this.MergeArray = [];
37
+ let ws_name = isSale ? 'Customer Wise Sales Details' : 'Vendor Wise Purchases Details';
38
+ this.wb.Sheets = {};
39
+ this.wb.Props = {};
40
+ this.wb.SSF = {};
41
+ this.wb.SheetNames = [];
42
+ // MainData = this.GetTotals(MainData);
43
+ let showSearch = [];
44
+ for (const key in searchValue) {
45
+ if (!tr_utils_1.TrUtils.IsNull(searchValue[key]) && key !== 'Date' && key !== 'CustCntrlId') {
46
+ showSearch.push([{
47
+ text: (key === 'StDate') ? 'Start Date' : (key === 'EnDate') ? 'End Date' : (key === 'CustCntrl') ? isSale ? 'Customer' : 'Vendor' : key,
48
+ ColRange: 1,
49
+ bold: true,
50
+ ChildHeadings: [
51
+ // { text: 'Central Tax', ColRange: 1 },
52
+ // { text: 'State Tax', ColRange: 1 },
53
+ // { text: 'IGST Tax', ColRange: 1 },
54
+ ],
55
+ }, {
56
+ text: (key === 'StDate') ? my_date_1.MyDate.ConvertUTCDateToReadable(searchValue[key]) : (key === 'EnDate') ? my_date_1.MyDate.ConvertUTCDateToReadable(searchValue[key]) : searchValue[key],
57
+ ColRange: 7,
58
+ bold: true,
59
+ ChildHeadings: [
60
+ // { text: 'Central Tax', ColRange: 1 },
61
+ // { text: 'State Tax', ColRange: 1 },
62
+ // { text: 'IGST Tax', ColRange: 1 },
63
+ ],
64
+ }]);
65
+ }
66
+ // console.log(`${key}: ${searchValue[key]}`);
67
+ }
68
+ this.setHeadingInCell(isSale, showSearch);
69
+ this.setInvoiceDetailsInCell(MainData, isSale);
70
+ this.ws['!ref'] = XLSX.utils.encode_range(this.range);
71
+ this.ws['!merges'] = this.MergeArray;
72
+ this.ws["!cols"] = [{ wch: 10 }, { wch: 15 }, { wch: 50 }, { wch: 10 }, { wch: 15 }, { wch: 15 }, { wch: 15 }, { wch: 15 }, { wch: 20 }];
73
+ this.wb.SheetNames.push(ws_name);
74
+ this.wb.Sheets[ws_name] = this.ws;
75
+ return this.wb;
76
+ }
77
+ static GetTotals(MainData) {
78
+ MainData.forEach((InvoiceInfo) => {
79
+ // InvoiceInfo.Tax =
80
+ // InvoiceInfo.ItemsCGST + InvoiceInfo.ItemsSGST + InvoiceInfo.ItemsIGST;
81
+ InvoiceInfo.TotalAmount = InvoiceInfo.Tax + InvoiceInfo.NetAmt;
82
+ });
83
+ return MainData;
84
+ }
85
+ static setHeadingInCell(isSale, showSearch) {
86
+ let MainHeadings = [
87
+ // {
88
+ // text: 'SNo',
89
+ // ColRange: 1,
90
+ // bold: true,
91
+ // ChildHeadings: []
92
+ // },
93
+ {
94
+ text: 'Transaction #',
95
+ ColRange: 1,
96
+ bold: true,
97
+ ChildHeadings: [
98
+ // { text: 'No', ColRange: 1 },
99
+ // { text: 'Date', ColRange: 1 },
100
+ // { text: 'Invoice Total', ColRange: 1 }
101
+ ],
102
+ },
103
+ {
104
+ text: 'Date',
105
+ ColRange: 1,
106
+ bold: true,
107
+ ChildHeadings: [],
108
+ },
109
+ {
110
+ text: 'Name',
111
+ ColRange: 1,
112
+ bold: true,
113
+ ChildHeadings: [
114
+ // { text: 'Central Tax', ColRange: 1 },
115
+ // { text: 'State Tax', ColRange: 1 },
116
+ // { text: 'IGST Tax', ColRange: 1 },
117
+ ],
118
+ },
119
+ {
120
+ text: 'SubTotal',
121
+ ColRange: 1,
122
+ bold: true,
123
+ ChildHeadings: [
124
+ // { text: 'Central Tax', ColRange: 1 },
125
+ // { text: 'State Tax', ColRange: 1 },
126
+ // { text: 'IGST Tax', ColRange: 1 },
127
+ ],
128
+ },
129
+ {
130
+ text: 'Discount',
131
+ ColRange: 1,
132
+ bold: true,
133
+ ChildHeadings: [
134
+ // { text: 'Central Tax', ColRange: 1 },
135
+ // { text: 'State Tax', ColRange: 1 },
136
+ // { text: 'IGST Tax', ColRange: 1 },
137
+ ],
138
+ },
139
+ {
140
+ text: 'Tax',
141
+ ColRange: 1,
142
+ bold: true,
143
+ ChildHeadings: [
144
+ // { text: 'Central Tax', ColRange: 1 },
145
+ // { text: 'State Tax', ColRange: 1 },
146
+ // { text: 'IGST Tax', ColRange: 1 },
147
+ ],
148
+ },
149
+ {
150
+ text: 'Adjustment',
151
+ ColRange: 1,
152
+ bold: true,
153
+ ChildHeadings: [
154
+ // { text: 'Central Tax', ColRange: 1 },
155
+ // { text: 'State Tax', ColRange: 1 },
156
+ // { text: 'IGST Tax', ColRange: 1 },
157
+ ],
158
+ },
159
+ {
160
+ text: 'Round Off',
161
+ ColRange: 1,
162
+ bold: true,
163
+ ChildHeadings: [
164
+ // { text: 'Central Tax', ColRange: 1 },
165
+ // { text: 'State Tax', ColRange: 1 },
166
+ // { text: 'IGST Tax', ColRange: 1 },
167
+ ],
168
+ },
169
+ {
170
+ text: 'Total',
171
+ ColRange: 1,
172
+ bold: true,
173
+ ChildHeadings: [
174
+ // { text: 'Central Tax', ColRange: 1 },
175
+ // { text: 'State Tax', ColRange: 1 },
176
+ // { text: 'IGST Tax', ColRange: 1 },
177
+ ],
178
+ },
179
+ ];
180
+ this.SetDataInCell(isSale ? 'Customer Wise Sales Details' : 'Vendor Wise Purchases Details', 0, this.Row);
181
+ this.MergeArray.push({
182
+ s: { r: this.Row, c: 0 },
183
+ e: { r: this.Row, c: 0 + 5 - 1 },
184
+ });
185
+ this.Row += 2;
186
+ // console.log('showSearch', showSearch);
187
+ showSearch.forEach((search) => {
188
+ let ColStart = 0;
189
+ // console.log('search', search, ColStart);
190
+ search.forEach((item) => {
191
+ // console.log('text', oyo.text, ColStart);
192
+ this.SetDataInCell(item.text, ColStart, this.Row);
193
+ this.MergeArray.push({
194
+ s: { r: this.Row, c: ColStart },
195
+ e: { r: this.Row, c: ColStart + item.ColRange - 1 },
196
+ });
197
+ ColStart += item.ColRange;
198
+ });
199
+ this.Row += 1;
200
+ });
201
+ this.Row += 1;
202
+ let MainColStart = 0;
203
+ MainHeadings.forEach((MainHeader) => {
204
+ this.SetDataInCell(MainHeader.text, MainColStart, this.Row);
205
+ this.MergeArray.push({
206
+ s: { r: this.Row, c: MainColStart },
207
+ e: { r: this.Row, c: MainColStart + MainHeader.ColRange - 1 },
208
+ });
209
+ MainColStart += MainHeader.ColRange;
210
+ });
211
+ this.Row += 2;
212
+ }
213
+ static setInvoiceDetailsInCell(MainData, isSale) {
214
+ MainData.forEach((InvoiceList) => {
215
+ this.SetInvoiceDataInExcel(InvoiceList, isSale);
216
+ });
217
+ }
218
+ static SetInvoiceDataInExcel(InvoiceInfo, isSale) {
219
+ InvoiceInfo.CrDate = this.ConvertDateToReadableFormat(InvoiceInfo.CrDate);
220
+ let InvoiceData = [
221
+ { text: isSale ? InvoiceInfo.Code : InvoiceInfo.BNo, ColRange: 1, IsString: true },
222
+ { text: InvoiceInfo.CrDate, ColRange: 1, IsString: true },
223
+ { text: isSale ? InvoiceInfo.CustName : InvoiceInfo.VendName, ColRange: 1, IsString: true },
224
+ { text: InvoiceInfo.SubTotal, ColRange: 1, IsString: false },
225
+ { text: InvoiceInfo.Disc, ColRange: 1, IsString: false },
226
+ { text: InvoiceInfo.Tax, ColRange: 1, IsString: false },
227
+ { text: InvoiceInfo.Adjust, ColRange: 1, IsString: false },
228
+ { text: InvoiceInfo.Round, ColRange: 1, IsString: false },
229
+ { text: InvoiceInfo.Total, ColRange: 1, IsString: false }
230
+ ];
231
+ let ColStart = 0;
232
+ InvoiceData.forEach((InvData) => {
233
+ InvData.text = this.ConvertToString(InvData.text, InvData.IsString);
234
+ this.SetDataInCell(InvData.text, ColStart, this.Row);
235
+ this.MergeArray.push({
236
+ s: { r: this.Row, c: ColStart },
237
+ e: { r: this.Row, c: ColStart + InvData.ColRange - 1 },
238
+ });
239
+ ColStart += InvData.ColRange;
240
+ });
241
+ this.Row += 1;
242
+ }
243
+ static ConvertToString(Text, IsString) {
244
+ if (IsString) {
245
+ if (Text == null) {
246
+ Text = '';
247
+ }
248
+ }
249
+ else {
250
+ if (Text == null) {
251
+ Text = 0;
252
+ }
253
+ }
254
+ if (typeof Text === 'number') {
255
+ return Number(tr_utils_1.TrUtils.FixedTo(Text));
256
+ }
257
+ else {
258
+ return Text;
259
+ }
260
+ }
261
+ static SetDataInCell(Data, ColRange, RowNum) {
262
+ var cell = { v: Data };
263
+ var cell_ref = XLSX.utils.encode_cell({ c: ColRange, r: RowNum });
264
+ if (this.range.e.c < ColRange) {
265
+ this.range.e.c = ColRange;
266
+ }
267
+ if (this.range.e.r < RowNum) {
268
+ this.range.e.r = RowNum;
269
+ }
270
+ cell = this.getcelltype(cell);
271
+ this.ws[cell_ref] = cell;
272
+ }
273
+ static getcelltype(cell) {
274
+ if (typeof cell.v === 'number')
275
+ cell.t = 'n';
276
+ else if (typeof cell.v === 'boolean')
277
+ cell.t = 'b';
278
+ else
279
+ cell.t = 's';
280
+ return cell;
281
+ }
282
+ static ConvertDateToReadableFormat(DateObject) {
283
+ if (!tr_utils_1.TrUtils.IsEmpty(DateObject)) {
284
+ let date = new Date(DateObject);
285
+ let Month;
286
+ let Day;
287
+ let MonthName = new Array();
288
+ MonthName[0] = 'Jan';
289
+ MonthName[1] = 'Feb';
290
+ MonthName[2] = 'Mar';
291
+ MonthName[3] = 'Apr';
292
+ MonthName[4] = 'May';
293
+ MonthName[5] = 'Jun';
294
+ MonthName[6] = 'Jul';
295
+ MonthName[7] = 'Aug';
296
+ MonthName[8] = 'Sept';
297
+ MonthName[9] = 'Oct';
298
+ MonthName[10] = 'Nov';
299
+ MonthName[11] = 'Dec';
300
+ Month = MonthName[date.getMonth()];
301
+ if (date.getDate() < 10) {
302
+ Day = '0' + date.getDate();
303
+ }
304
+ else {
305
+ Day = date.getDate();
306
+ }
307
+ date = Day + '-' + Month + '-' + date.getFullYear();
308
+ return date;
309
+ }
310
+ else {
311
+ return null;
312
+ }
313
+ }
314
+ }
315
+ exports.CustWiseSalesXlsxFileService = CustWiseSalesXlsxFileService;
316
+ CustWiseSalesXlsxFileService.wb = {};
317
+ CustWiseSalesXlsxFileService.Row = 2;
318
+ CustWiseSalesXlsxFileService.MergeArray = [];
319
+ CustWiseSalesXlsxFileService.range = { s: { c: 0, r: 0 }, e: { c: 0, r: 0 } };
320
+ CustWiseSalesXlsxFileService.ws = {};