ezlibrary_v2 0.0.1

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 (113) hide show
  1. package/esm2020/ezlibrary_v2.mjs +5 -0
  2. package/esm2020/lib/admin-service/admin-service.service.mjs +36 -0
  3. package/esm2020/lib/analysis-search/analysis-search.component.mjs +1083 -0
  4. package/esm2020/lib/assort-service/assort-service.service.mjs +31 -0
  5. package/esm2020/lib/attribute-definition/attribute-definition.component.mjs +231 -0
  6. package/esm2020/lib/auth/auth.guard.mjs +40 -0
  7. package/esm2020/lib/bi-service/bi.service.mjs +58 -0
  8. package/esm2020/lib/call-info/callinfo.component.mjs +126 -0
  9. package/esm2020/lib/comman-service/comman-service.service.mjs +679 -0
  10. package/esm2020/lib/comman-service/share-data-service.service.mjs +23 -0
  11. package/esm2020/lib/contact-search/contact-search.component.mjs +679 -0
  12. package/esm2020/lib/contact-service/contact-service.service.mjs +47 -0
  13. package/esm2020/lib/ezheader/header.component.mjs +383 -0
  14. package/esm2020/lib/ezlib.module.mjs +220 -0
  15. package/esm2020/lib/file-upload/fileupload.component.mjs +920 -0
  16. package/esm2020/lib/file-upload-log/file-upload-log.component.mjs +175 -0
  17. package/esm2020/lib/fileupload-module/fileupload-dashboard/fileupload-dashboard.component.mjs +14 -0
  18. package/esm2020/lib/fileupload-module/fileupload-routing.module.mjs +28 -0
  19. package/esm2020/lib/footer/footer.component.mjs +18 -0
  20. package/esm2020/lib/globle/common-pdf.service.mjs +28 -0
  21. package/esm2020/lib/globle/globle-env.service.mjs +45 -0
  22. package/esm2020/lib/globle/memo-report.service.mjs +2800 -0
  23. package/esm2020/lib/globle/pdf-service.service.mjs +18848 -0
  24. package/esm2020/lib/globle/shared-services.service.mjs +27 -0
  25. package/esm2020/lib/globle/upload-service.service.mjs +69 -0
  26. package/esm2020/lib/header/header.component.mjs +179 -0
  27. package/esm2020/lib/invalid/invalid.component.mjs +71 -0
  28. package/esm2020/lib/logout/logout.component.mjs +107 -0
  29. package/esm2020/lib/menu-right/menu-right.component.mjs +252 -0
  30. package/esm2020/lib/pipes/number-with-commas.pipe.mjs +24 -0
  31. package/esm2020/lib/pipes/order-by-pipe.pipe.mjs +17 -0
  32. package/esm2020/lib/pipes/selectedCount.mjs +19 -0
  33. package/esm2020/lib/pipes/sum.pipe.mjs +16 -0
  34. package/esm2020/lib/pkt-data/pkt-data.component.mjs +1107 -0
  35. package/esm2020/lib/pricing-service/pricing.service.mjs +58 -0
  36. package/esm2020/lib/qa-analysis/qa-analysis.component.mjs +1035 -0
  37. package/esm2020/lib/report-format/report-format.component.mjs +400 -0
  38. package/esm2020/lib/sessionend/session-end.guard.mjs +28 -0
  39. package/esm2020/lib/stock-service/lazyload.service.mjs +21 -0
  40. package/esm2020/lib/stock-service/stock-service.service.mjs +62 -0
  41. package/esm2020/lib/system-module/subform/subform.component.mjs +2481 -0
  42. package/esm2020/lib/system-module/system/system.component.mjs +959 -0
  43. package/esm2020/lib/system-module/system-service/system-service.service.mjs +85 -0
  44. package/esm2020/lib/system-module/system-service/upload-file.service.mjs +86 -0
  45. package/esm2020/lib/utility/app-no-dbl-click.directive.mjs +23 -0
  46. package/esm2020/lib/utility/constants.mjs +5 -0
  47. package/esm2020/lib/utility/contact-table-search.pipe.mjs +25 -0
  48. package/esm2020/lib/utility/formate-num-field.pipe.mjs +19 -0
  49. package/esm2020/lib/utility/search-pipe.pipe.mjs +26 -0
  50. package/esm2020/lib/utility/selective-preloading-strategy.mjs +23 -0
  51. package/esm2020/lib/utility/table-search.pipe.mjs +25 -0
  52. package/esm2020/lib/utility/tranform.directive.mjs +27 -0
  53. package/esm2020/lib/websearch-history/websearch-history.component.mjs +273 -0
  54. package/esm2020/public_api.mjs +57 -0
  55. package/ezlibrary_v2.d.ts +5 -0
  56. package/fesm2015/ezlibrary_v2.mjs +33543 -0
  57. package/fesm2015/ezlibrary_v2.mjs.map +1 -0
  58. package/fesm2020/ezlibrary_v2.mjs +33533 -0
  59. package/fesm2020/ezlibrary_v2.mjs.map +1 -0
  60. package/lib/admin-service/admin-service.service.d.ts +13 -0
  61. package/lib/analysis-search/analysis-search.component.d.ts +122 -0
  62. package/lib/assort-service/assort-service.service.d.ts +12 -0
  63. package/lib/attribute-definition/attribute-definition.component.d.ts +47 -0
  64. package/lib/auth/auth.guard.d.ts +16 -0
  65. package/lib/bi-service/bi.service.d.ts +20 -0
  66. package/lib/call-info/callinfo.component.d.ts +30 -0
  67. package/lib/comman-service/comman-service.service.d.ts +111 -0
  68. package/lib/comman-service/share-data-service.service.d.ts +10 -0
  69. package/lib/contact-search/contact-search.component.d.ts +115 -0
  70. package/lib/contact-service/contact-service.service.d.ts +15 -0
  71. package/lib/ezheader/header.component.d.ts +61 -0
  72. package/lib/ezlib.module.d.ts +47 -0
  73. package/lib/file-upload/fileupload.component.d.ts +131 -0
  74. package/lib/file-upload-log/file-upload-log.component.d.ts +53 -0
  75. package/lib/fileupload-module/fileupload-dashboard/fileupload-dashboard.component.d.ts +8 -0
  76. package/lib/fileupload-module/fileupload-routing.module.d.ts +7 -0
  77. package/lib/footer/footer.component.d.ts +9 -0
  78. package/lib/globle/common-pdf.service.d.ts +9 -0
  79. package/lib/globle/globle-env.service.d.ts +16 -0
  80. package/lib/globle/memo-report.service.d.ts +107 -0
  81. package/lib/globle/pdf-service.service.d.ts +459 -0
  82. package/lib/globle/shared-services.service.d.ts +12 -0
  83. package/lib/globle/upload-service.service.d.ts +20 -0
  84. package/lib/header/header.component.d.ts +45 -0
  85. package/lib/invalid/invalid.component.d.ts +12 -0
  86. package/lib/logout/logout.component.d.ts +21 -0
  87. package/lib/menu-right/menu-right.component.d.ts +47 -0
  88. package/lib/pipes/number-with-commas.pipe.d.ts +7 -0
  89. package/lib/pipes/order-by-pipe.pipe.d.ts +7 -0
  90. package/lib/pipes/selectedCount.d.ts +7 -0
  91. package/lib/pipes/sum.pipe.d.ts +7 -0
  92. package/lib/pkt-data/pkt-data.component.d.ts +189 -0
  93. package/lib/pricing-service/pricing.service.d.ts +20 -0
  94. package/lib/qa-analysis/qa-analysis.component.d.ts +99 -0
  95. package/lib/report-format/report-format.component.d.ts +74 -0
  96. package/lib/sessionend/session-end.guard.d.ts +10 -0
  97. package/lib/stock-service/lazyload.service.d.ts +7 -0
  98. package/lib/stock-service/stock-service.service.d.ts +19 -0
  99. package/lib/system-module/subform/subform.component.d.ts +227 -0
  100. package/lib/system-module/system/system.component.d.ts +113 -0
  101. package/lib/system-module/system-service/system-service.service.d.ts +23 -0
  102. package/lib/system-module/system-service/upload-file.service.d.ts +12 -0
  103. package/lib/utility/app-no-dbl-click.directive.d.ts +7 -0
  104. package/lib/utility/constants.d.ts +4 -0
  105. package/lib/utility/contact-table-search.pipe.d.ts +7 -0
  106. package/lib/utility/formate-num-field.pipe.d.ts +7 -0
  107. package/lib/utility/search-pipe.pipe.d.ts +7 -0
  108. package/lib/utility/selective-preloading-strategy.d.ts +9 -0
  109. package/lib/utility/table-search.pipe.d.ts +7 -0
  110. package/lib/utility/tranform.directive.d.ts +10 -0
  111. package/lib/websearch-history/websearch-history.component.d.ts +62 -0
  112. package/package.json +48 -0
  113. package/public_api.d.ts +52 -0
@@ -0,0 +1,1107 @@
1
+ import { ToastrService } from 'ngx-toastr';
2
+ import { NgxSpinnerService } from "ngx-spinner";
3
+ import { BiService } from './../bi-service/bi.service';
4
+ import { CommanServiceService } from '../comman-service/comman-service.service';
5
+ import { Component, ViewChild } from '@angular/core';
6
+ import { Router, ActivatedRoute } from '@angular/router';
7
+ import { Cookie } from 'ng2-cookies/ng2-cookies';
8
+ import * as _ from 'lodash';
9
+ import { BaseChartDirective } from 'ng2-charts';
10
+ import * as pluginDataLabels from 'chartjs-plugin-labels';
11
+ import { HttpHeaders } from '@angular/common/http';
12
+ // import * as Rx from 'rxjs/Rx';
13
+ import { from } from 'rxjs';
14
+ import { groupBy, toArray, map, mergeMap } from 'rxjs/operators';
15
+ import * as i0 from "@angular/core";
16
+ import * as i1 from "../comman-service/comman-service.service";
17
+ import * as i2 from "./../bi-service/bi.service";
18
+ import * as i3 from "ngx-spinner";
19
+ import * as i4 from "ngx-toastr";
20
+ import * as i5 from "@angular/router";
21
+ import * as i6 from "ng-select";
22
+ import * as i7 from "@angular/common";
23
+ import * as i8 from "@angular/forms";
24
+ import * as i9 from "ngx-infinite-scroll";
25
+ import * as i10 from "ng2-charts";
26
+ import * as i11 from "../utility/app-no-dbl-click.directive";
27
+ import * as i12 from "../utility/table-search.pipe";
28
+ // import { sumBy } from 'lodash';
29
+ export class PktDataComponent {
30
+ constructor(cs, bis, _spinnerService, toastr, router, route) {
31
+ this.cs = cs;
32
+ this.bis = bis;
33
+ this._spinnerService = _spinnerService;
34
+ this.toastr = toastr;
35
+ this.router = router;
36
+ this.route = route;
37
+ this.pkts = [];
38
+ this.headerKey = [];
39
+ this.header = [];
40
+ this.totalWeight = 0;
41
+ this.scrollDistance = 1;
42
+ this.scrollUpDistance = 2;
43
+ this.startIndex = 0;
44
+ this.endIndex = 30;
45
+ this.groupstartIndex = 0;
46
+ this.groupendIndex = 30;
47
+ this.loadResult = [];
48
+ this.resultlength = 0;
49
+ this.totAvg = 0;
50
+ this.totDis = 0;
51
+ this.selectedItm = [];
52
+ this.selectwt = 0;
53
+ this.selectAvg = 0;
54
+ this.selectDis = 0;
55
+ this.selectAmt = 0;
56
+ this.sttWiseSummary = new Map();
57
+ // anaAllGrpStt = ['asrt', 'lab', 'mkt', 'sold'];
58
+ this.anaAllGrpStt = [];
59
+ this.legendList = [];
60
+ this.newwindow = "YES";
61
+ this.staticLov = [];
62
+ this.defaultGrpList = [];
63
+ this.stObj = {};
64
+ this.totAmt = 0;
65
+ this.nodata = true;
66
+ this.viewdisType = "group";
67
+ this.summaryList = [];
68
+ this.coPuattributeStr = [];
69
+ this.groupBypktList = [];
70
+ this.loadgroupBypktList = [];
71
+ this.sttwise = false;
72
+ this.grp = [];
73
+ this.GrpVals = [];
74
+ this.finalGrpVal = {};
75
+ this.finalSummaryDtl = {};
76
+ this.data = [];
77
+ this.summaryDtl = {};
78
+ this.headList = [];
79
+ this.GrpValsPie = [];
80
+ this.grpPie = [];
81
+ this.finalGrpValPie = {};
82
+ this.summaryDtlPie = {};
83
+ this.byrvalGrp = []; //{};
84
+ this.isBuyerwise = false;
85
+ this.isGrpwise = false;
86
+ this.grpWiseQty = [];
87
+ this.dataType = "";
88
+ this.dynamicColors = [];
89
+ this.byrValArr = [];
90
+ this.pieChartPlugins = [pluginDataLabels];
91
+ this.doughnutChartType = 'pie';
92
+ this.doughnutChartLabels = [];
93
+ this.doughnutChartData = [];
94
+ this.pieChartColors = [];
95
+ this.pieChartLegend = true;
96
+ this.chartColors = [
97
+ {
98
+ backgroundColor: this.generate(),
99
+ fillColor: this.generate(),
100
+ strokeColor: this.generate()
101
+ //["#000080", "#0020C2", "#1569C7", "#357EC7", "#368BC1","659EC7"]
102
+ }
103
+ ];
104
+ this.labels = {
105
+ labels: {
106
+ render: 'percentage',
107
+ //     fontColor: ['green', 'white', 'red'],
108
+ precision: 2
109
+ }
110
+ };
111
+ this.chartOptions = {
112
+ plugins: {
113
+ labels: {
114
+ render: 'percentage',
115
+ }
116
+ },
117
+ legend: {
118
+ position: 'right',
119
+ labels: {
120
+ fontColor: 'black',
121
+ boxWidth: 10,
122
+ padding: 10,
123
+ fontSize: 10,
124
+ render: 'percentage',
125
+ }
126
+ },
127
+ };
128
+ this.pieChartOptions = {
129
+ //legend: {position: 'left',fontColor:'white'},
130
+ //plugins: {labels: { render: 'percentage',position: 'border', textMargin: 4}}
131
+ legend: {
132
+ position: 'right',
133
+ labels: {
134
+ fontColor: 'black',
135
+ boxWidth: 10,
136
+ padding: 10,
137
+ fontSize: 10,
138
+ render: 'percentage'
139
+ }
140
+ },
141
+ plugins: {
142
+ datalabels: {
143
+ formatter: (value, ctx) => {
144
+ const label = ctx.chart.data.labels[ctx.dataIndex];
145
+ return label;
146
+ },
147
+ },
148
+ }
149
+ };
150
+ this.pie = {
151
+ legend: { position: 'left', fontColor: 'white' },
152
+ plugins: {
153
+ labels: {
154
+ // render 'label', 'value', 'percentage', 'image' or custom function, default is 'percentage'
155
+ render: 'percentage',
156
+ precision: 0,
157
+ arc: true,
158
+ showActualPercentages: true,
159
+ position: 'outside'
160
+ }
161
+ },
162
+ tooltips: {
163
+ mode: 'label',
164
+ callbacks: {
165
+ label: function (tooltipItem, data) {
166
+ // let label = data.datasets[tooltipItem.datasetIndex].label;
167
+ // let value = data.datasets[tooltipItem.datasetIndex].data[tooltipItem.index];
168
+ return [data.labels[tooltipItem.index]
169
+ ];
170
+ }
171
+ }
172
+ }
173
+ };
174
+ this.TotAvgObj = {};
175
+ this.anaSttLbl = [];
176
+ }
177
+ lpad(lStr, ln) {
178
+ let str = lStr;
179
+ while (str.length < ln) {
180
+ str = '0' + str;
181
+ }
182
+ return str;
183
+ }
184
+ getSearchResult() {
185
+ this.cObj = {};
186
+ this.groupBypktList = [];
187
+ this._spinnerService.show();
188
+ this.pkts = [];
189
+ this.grp = [];
190
+ this.headerKey = [];
191
+ this.legendList = [];
192
+ this.viewdisType = "group";
193
+ let reqObj = {};
194
+ this.formname = this.route.snapshot.params['frmnme'];
195
+ reqObj['searchIdnList'] = localStorage.getItem('srcIdns').split(',');
196
+ reqObj['formNme'] = this.route.snapshot.params['frmnme'];
197
+ console.log(JSON.stringify(reqObj));
198
+ this.startIndex = 0;
199
+ this.endIndex = 30;
200
+ this.loadResult = [];
201
+ this.bis.data(reqObj, 'search', 'marketing/search')
202
+ .subscribe(data => {
203
+ if (data.status == 'SUCCESS') {
204
+ let res = data.result;
205
+ console.log("res", res);
206
+ this.pageDefination = res.pageDefination || {};
207
+ this.links = this.pageDefination.link || [];
208
+ this.pkts = res.searchResultDtl || [];
209
+ this.anaAllGrpStt = Array.from(new Set(this.pkts.map(element => element.dsp_stt)));
210
+ this.resultlength = this.pkts.length;
211
+ this.coPuattributeStr = res.copuStructureDtl || [];
212
+ this.headerKey = res.resultView;
213
+ this.header = res.resultViewDtl;
214
+ this.legendList = res.legendList;
215
+ this.totalWeight = this.cs.splitToTwoDecimal(this.pkts.reduce((a, b) => +a + +parseFloat(b.crtwt), 0));
216
+ let rapVal = this.cs.splitToTwoDecimal(this.pkts.reduce((a, b) => +a + +parseFloat(b.rap_vlu), 0));
217
+ let totAmt = 0;
218
+ this.pkts.forEach(element => {
219
+ if (element.grp_stt == 'sold') {
220
+ totAmt += parseFloat(element['sal_rte']) * parseFloat(element['crtwt']);
221
+ }
222
+ else {
223
+ totAmt += parseFloat(element['rte']) * parseFloat(element['crtwt']);
224
+ }
225
+ });
226
+ this.totAmt = this.cs.splitToTwoDecimal(totAmt);
227
+ this.totAvg = this.cs.splitToTwoDecimal(this.totAmt / this.totalWeight);
228
+ this.totDis = this.cs.splitToTwoDecimal(((totAmt * 100) / parseFloat(rapVal)) - 100);
229
+ if (this.endIndex > this.resultlength)
230
+ this.endIndex = this.resultlength;
231
+ this.addItems();
232
+ debugger;
233
+ // this.totAvg = this.cs.splitToTwoDecimal(totAmt / parseFloat(totweight));
234
+ // this.totDis = this.cs.splitToTwoDecimal(((totAmt * 100) / parseFloat(totrapVal)) - 100);
235
+ this.getSummary(this.pkts);
236
+ // this.createGrp(this.pkts, this.defaultGrpList);
237
+ // localStorage.setItem('BI-PKT_GROUP_BY',JSON.stringify(res.pageDefination.form_field[0].lov_qry))
238
+ // let GRPby = JSON.parse(localStorage.getItem('BI-PKT_GROUP_BY'));
239
+ this.getStaticKV(res.pageDefination.form_field[0].lov_qry);
240
+ let avgFields = res.pageDefination.tabs[0].lov_qry.split(',');
241
+ this.getTotals(avgFields, this.pkts);
242
+ let ttlFields = res.pageDefination.others[0].lov_qry.split(',');
243
+ this.getTotalsTtl(ttlFields, this.pkts);
244
+ this._spinnerService.hide();
245
+ }
246
+ else {
247
+ this._spinnerService.hide();
248
+ this.toastr.error(data.message);
249
+ }
250
+ }, error => {
251
+ this._spinnerService.hide();
252
+ this.toastr.error(error);
253
+ });
254
+ }
255
+ selectRow(pktId) {
256
+ var checkboxId = "cb_" + pktId;
257
+ document.getElementById(checkboxId).click();
258
+ }
259
+ checkedRow(obj, stockidn, status) {
260
+ let cbId = 'cb_' + obj.stock_idn;
261
+ if (status == false) {
262
+ var element = document.getElementById(cbId); //pktId
263
+ element.parentElement.parentElement.classList.remove("selectedRow");
264
+ element.parentElement.parentElement.classList.add("notselectedRow");
265
+ this.selectedItm.forEach((e, index) => {
266
+ if (e.stock_idn == stockidn) {
267
+ this.selectedItm.splice(index, 1);
268
+ }
269
+ });
270
+ }
271
+ else {
272
+ var element = document.getElementById(cbId); //pktId
273
+ element.parentElement.parentElement.classList.remove("notselectedRow");
274
+ element.parentElement.parentElement.classList.add("selectedRow");
275
+ this.selectedItm.push(obj);
276
+ }
277
+ this.selectwt = this.cs.splitToTwoDecimal(this.selectedItm.reduce((a, b) => +a + +parseFloat(b.crtwt), 0));
278
+ // let totAmt = this.cs.splitToTwoDecimal(this.selectedItm.reduce((a, b) => +a + +b.sal_amount, 0));
279
+ let totweight = this.cs.splitToTwoDecimal(this.selectedItm.reduce((a, b) => +a + +parseFloat(b.crtwt), 0));
280
+ let totrapVal = this.cs.splitToTwoDecimal(this.selectedItm.reduce((a, b) => +a + +b.rap_vlu, 0));
281
+ let totAmt = 0;
282
+ this.selectedItm.forEach(element => {
283
+ if (element.grp_stt == 'sold') {
284
+ totAmt += parseFloat(element['sal_rte'] || 0) * parseFloat(element['crtwt']);
285
+ }
286
+ else {
287
+ totAmt += parseFloat(element['rte'] || 0) * parseFloat(element['crtwt']);
288
+ }
289
+ });
290
+ this.selectAvg = this.cs.splitToTwoDecimal(totAmt / parseFloat(totweight));
291
+ this.selectDis = this.cs.splitToTwoDecimal((totAmt / parseFloat(totrapVal) * 100) - 100);
292
+ this.selectAmt = this.cs.splitToTwoDecimal(totAmt);
293
+ }
294
+ statusWiseDisplay(e, m) {
295
+ debugger;
296
+ this.sttwise = true;
297
+ let gArr = [];
298
+ for (let key in m) {
299
+ if (m[key] == true) {
300
+ debugger;
301
+ let pk = this.pkts.filter(e => e.grp_stt == key);
302
+ gArr = gArr.concat(pk);
303
+ }
304
+ else {
305
+ let pk = gArr.filter(e => e.grp_stt != key);
306
+ }
307
+ }
308
+ debugger;
309
+ this.finalGrpVal[""] = gArr;
310
+ this.loadResult = gArr;
311
+ if (this.finalGrpVal[""].length > 0) {
312
+ this.totalWeight = this.cs.splitToTwoDecimal(this.finalGrpVal[""].reduce((a, b) => +a + +parseFloat(b.crtwt), 0));
313
+ let totweight = this.cs.splitToTwoDecimal(this.finalGrpVal[""].reduce((a, b) => +a + +parseFloat(b.crtwt), 0));
314
+ let totrapVal = this.cs.splitToTwoDecimal(this.finalGrpVal[""].reduce((a, b) => +a + +b.rap_vlu, 0));
315
+ let totAmt = 0;
316
+ this.finalGrpVal[""].forEach(element => {
317
+ if (element.grp_stt == 'sold') {
318
+ totAmt += parseFloat(element['sal_rte']) * parseFloat(element['crtwt']);
319
+ }
320
+ else {
321
+ totAmt += parseFloat(element['rte']) * parseFloat(element['crtwt']);
322
+ }
323
+ });
324
+ this.totAmt = this.cs.splitToTwoDecimal(totAmt);
325
+ this.totAvg = this.cs.splitToTwoDecimal(totAmt / parseFloat(totweight));
326
+ this.totDis = this.cs.splitToTwoDecimal(((totAmt * 100) / parseFloat(totrapVal)) - 100);
327
+ }
328
+ // let grpBy = e.target.value;
329
+ // if (e.target.checked) {
330
+ // let pk = this.pkts.filter(e => e.grp_stt == grpBy);
331
+ // this.finalGrpVal[""] = pk;
332
+ // }
333
+ // else {
334
+ // let pk = this.pkts.filter(e => e.grp_stt !== grpBy);
335
+ // this.finalGrpVal[""] = pk;
336
+ // }
337
+ console.log(this.finalGrpVal);
338
+ }
339
+ OnLinkClick(lnk, pktdtl) {
340
+ if (lnk.form_field == 'priceupdate') {
341
+ this.cObj = pktdtl;
342
+ document.getElementById("bidMdBBtn").click();
343
+ }
344
+ }
345
+ calculatRteDis(objdtl, typ) {
346
+ debugger;
347
+ if (typ == 'rte') {
348
+ let dis = this.cs.splitToTwoDecimal(((parseFloat(objdtl.new_rte) * 100) / parseFloat(objdtl.rap_rte)) - 100);
349
+ objdtl["new_rap_dis"] = dis;
350
+ }
351
+ if (typ == 'dis') {
352
+ let rte = this.cs.splitToTwoDecimal((parseFloat(objdtl.rap_rte) * (100 + parseFloat(objdtl.new_rap_dis)) / 100));
353
+ objdtl["new_rte"] = rte;
354
+ }
355
+ }
356
+ ChangesPrice() {
357
+ let nmeIdn = JSON.parse(localStorage.getItem('nmeIdn'));
358
+ let pktDataList = [];
359
+ let updateObj = {};
360
+ updateObj["id"] = this.cObj.pkt_code;
361
+ updateObj["issue"] = { "rte": "" };
362
+ updateObj["rtn"] = { "rte": this.cObj.new_rte };
363
+ updateObj["emp"] = {};
364
+ pktDataList.push(updateObj);
365
+ let reqObj = {};
366
+ reqObj['formNme'] = this.route.snapshot.params['frmnme']; //'bulkUpdateForm';
367
+ reqObj['attr'] = "rte";
368
+ reqObj['reissue'] = 'Y';
369
+ reqObj['empIdn'] = nmeIdn;
370
+ reqObj['grp'] = "bulkupdate";
371
+ reqObj['processName'] = "bulkMemPriceUpdate"; //'bulkPrepertiesUpdate';
372
+ reqObj['pktDataList'] = pktDataList;
373
+ console.log(JSON.stringify(reqObj));
374
+ this.reqheader['method'] = 'returnIssue';
375
+ let options = ({ headers: new HttpHeaders(this.reqheader) });
376
+ this.cs.load(reqObj, options, 'preMarketing/issueReturn').then((response) => {
377
+ if (response.status == 'SUCCESS') {
378
+ this.cObj.rte = this.cObj.new_rte;
379
+ this.cObj.rap_dis = this.cObj.new_rap_dis;
380
+ this.getSummary(this.pkts);
381
+ this.toastr.success(response.message);
382
+ this._spinnerService.hide();
383
+ }
384
+ else {
385
+ this._spinnerService.hide();
386
+ this.toastr.error(response.message);
387
+ }
388
+ }).catch((err) => {
389
+ this._spinnerService.hide();
390
+ this.toastr.error(err.message);
391
+ });
392
+ }
393
+ addItems() {
394
+ for (let i = this.startIndex; i < this.endIndex; i++) {
395
+ this.loadResult[i] = this.pkts[i];
396
+ }
397
+ this.startIndex = this.endIndex;
398
+ this.endIndex = this.endIndex + 30;
399
+ if (this.endIndex > this.resultlength) {
400
+ this.endIndex = this.resultlength;
401
+ }
402
+ }
403
+ onScrollDown() {
404
+ if (this.endIndex <= this.resultlength)
405
+ this.addItems();
406
+ document.getElementById("wrap").addEventListener("scroll", function () {
407
+ var translate = "translate(0," + this.scrollTop + "px)";
408
+ this.querySelector("thead").style.transform = translate;
409
+ });
410
+ }
411
+ createGrp(datas, selected) {
412
+ this._spinnerService.show();
413
+ this.data = [...datas];
414
+ // let grpvalues = "pu";
415
+ // let grpvaluesArr = grpvalues.split(',');
416
+ // let resutArr = [];
417
+ let grpvaluesArr = selected;
418
+ var final = [];
419
+ var output = _.groupBy(this.data, function (entry) {
420
+ var strs = '';
421
+ for (let i = 0; i < grpvaluesArr.length; i++) {
422
+ strs += entry[grpvaluesArr[i]] + '#';
423
+ }
424
+ return strs;
425
+ // return entry[grpvaluesArr[0]] + '#' + entry[grpvaluesArr[1]];// + '#' + entry.pu;
426
+ });
427
+ // console.log(output);
428
+ final.push(output);
429
+ console.log(final);
430
+ var Keys = Object.keys(final[0]);
431
+ console.log(Keys);
432
+ var Vals = Object.values(final[0]);
433
+ console.log(Vals);
434
+ let grpNamearr = [];
435
+ Keys.map(ele => {
436
+ grpNamearr.push(ele.split('#').filter(e => e != undefined).join(' / '));
437
+ });
438
+ this.grp = grpNamearr;
439
+ this.GrpVals = Vals;
440
+ for (let i = 0; i < grpNamearr.length; i++) {
441
+ var grpNme = grpNamearr[i];
442
+ this.finalGrpVal[grpNme] = Vals[i];
443
+ console.log(this.finalGrpVal[grpNme]);
444
+ }
445
+ this.getTotal();
446
+ this.grp.sort();
447
+ this._spinnerService.hide();
448
+ }
449
+ onGrpSelect(selected) {
450
+ if (this.viewdisType == 'group')
451
+ this.groupPktsList(this.pkts, selected);
452
+ else
453
+ this.summaryDetails(selected);
454
+ }
455
+ groupPktsList(pkts, selected) {
456
+ if (selected.length == 1) {
457
+ let attr = selected[0];
458
+ // this.finalGrpVal = _.groupBy(pkts, attr);
459
+ //this.grp = Object.keys(this.finalGrpVal);
460
+ from(pkts).pipe(groupBy(x => x[attr]), mergeMap(group => group.pipe(toArray())), map(g => {
461
+ return {
462
+ value: g[0][attr],
463
+ pktList: g,
464
+ count: _.sumBy(g, 'qty_on_handint'),
465
+ rapvlu: this.cs.splitToTwoDecimal(_.sumBy(g, 'rap_vlu')),
466
+ crtwt: this.cs.splitToTwoDecimal(_.sumBy(g, 'crtwtint')),
467
+ vlu: this.cs.splitToTwoDecimal(_.sumBy(g, 'amountint')),
468
+ salvlu: this.cs.splitToTwoDecimal(_.sumBy(g, 'sal_amountint')),
469
+ avg: this.cs.splitToTwoDecimal(_.sumBy(g, 'amountint') / _.sumBy(g, 'crtwtint')),
470
+ salavg: this.cs.splitToTwoDecimal(_.sumBy(g, 'sal_amountint') / _.sumBy(g, 'crtwtint')),
471
+ dis: this.cs.splitToTwoDecimal(((_.sumBy(g, 'amountint') * 100) / (_.sumBy(g, 'rap_vlu'))) - 100),
472
+ saldis: this.cs.splitToTwoDecimal(((_.sumBy(g, 'sal_amountint') * 100) / (_.sumBy(g, 'rap_vlu'))) - 100)
473
+ };
474
+ }), toArray())
475
+ .subscribe(d => {
476
+ this.groupBypktList = d;
477
+ this.groupstartIndex = 0;
478
+ this.groupendIndex = this.groupBypktList.length;
479
+ this.groupaddItems();
480
+ });
481
+ }
482
+ else {
483
+ this.startIndex = 0;
484
+ this.endIndex = 30;
485
+ this.loadResult = [];
486
+ this.groupBypktList = [];
487
+ if (this.endIndex > this.resultlength)
488
+ this.endIndex = this.resultlength;
489
+ this.addItems();
490
+ }
491
+ }
492
+ groupaddItems() {
493
+ let pktcnt = 0;
494
+ for (let i = this.groupstartIndex; i < this.groupendIndex; i++) {
495
+ debugger;
496
+ this.loadgroupBypktList[i] = this.groupBypktList[i];
497
+ let pktlist = this.groupBypktList[i]['pktList'] || [];
498
+ pktcnt = pktcnt + pktlist.length;
499
+ if (pktcnt > 30) {
500
+ this.groupstartIndex = i + 1;
501
+ break;
502
+ }
503
+ }
504
+ }
505
+ grouponScrollDown() {
506
+ if (this.groupstartIndex < this.groupendIndex)
507
+ this.groupaddItems();
508
+ document.getElementById("wrap").addEventListener("scroll", function () {
509
+ var translate = "translate(0," + this.scrollTop + "px)";
510
+ this.querySelector("thead").style.transform = translate;
511
+ });
512
+ }
513
+ summaryDetails(selected) {
514
+ if (selected.length == 1) {
515
+ this.headList = [];
516
+ let summaryData = [];
517
+ let attribue = selected[0];
518
+ from(this.pkts).pipe(groupBy(x => x[attribue] + "#" + x['dsp_stt']), mergeMap(group => group.pipe(toArray())), map(g => {
519
+ return {
520
+ key: g[0][attribue] + "#" + g[0]['dsp_stt'],
521
+ value: g[0][attribue],
522
+ sort: g[0][attribue + "_srt"] || 10000,
523
+ dspstt: g[0]['dsp_stt'],
524
+ count: _.sumBy(g, 'qty_on_handint'),
525
+ rapvlu: this.cs.splitToTwoDecimal(_.sumBy(g, 'rap_vlu')),
526
+ crtwt: this.cs.splitToTwoDecimal(_.sumBy(g, 'crtwtint')),
527
+ vlurte: this.cs.splitToTwoDecimal(_.sumBy(g, 'amountint')),
528
+ vlu: this.cs.splitToTwoDecimal(_.sumBy(g, 'sal_amountint')),
529
+ };
530
+ }), toArray())
531
+ .subscribe(d => {
532
+ summaryData = d;
533
+ });
534
+ let summaryMap = {};
535
+ let sideList = [];
536
+ let headList = [];
537
+ summaryData.forEach(element => {
538
+ summaryMap[element.key] = element;
539
+ let value = element.value || '';
540
+ let dspstt = element.dspstt;
541
+ if ((selected == 'sal_byr' || selected == 'sal_emp') && dspstt != 'sold')
542
+ value = '';
543
+ if (value != '') {
544
+ if (headList.indexOf(dspstt) == -1)
545
+ headList.push(dspstt);
546
+ if (sideList.indexOf(value) == -1)
547
+ sideList.push(value);
548
+ }
549
+ });
550
+ this.summaryList = [];
551
+ sideList.forEach(side => {
552
+ let summry = {};
553
+ headList.forEach(head => {
554
+ let summryData = summaryMap[side + "#" + head] || '';
555
+ if (summryData != '') {
556
+ let stt = summryData['dspstt'];
557
+ let vlu = parseFloat(summryData.vlurte || 0);
558
+ let rapvlu = parseFloat(summryData.rapvlu || 0);
559
+ let crtwt = parseFloat(summryData.crtwt || 0);
560
+ summry['value'] = side;
561
+ summry['valueSort'] = summryData.sort;
562
+ summry['count_' + stt] = summryData.count;
563
+ summry['crtwt_' + stt] = summryData.crtwt;
564
+ summry['vlu_' + stt] = summryData.vlurte;
565
+ summry['avg_' + stt] = this.cs.splitToTwoDecimal(vlu / crtwt);
566
+ summry['dis_' + stt] = this.cs.splitToTwoDecimal(((vlu * 100) / rapvlu) - 100);
567
+ if (stt == 'sold') {
568
+ vlu = parseFloat(summryData.vlu || 0);
569
+ summry['vlu_' + stt] = vlu;
570
+ summry['avg_' + stt] = this.cs.splitToTwoDecimal(vlu / crtwt);
571
+ summry['dis_' + stt] = this.cs.splitToTwoDecimal(((vlu * 100) / rapvlu) - 100);
572
+ }
573
+ }
574
+ });
575
+ this.summaryList.push(summry);
576
+ });
577
+ if (selected == 'sal_byr' || selected == 'sal_emp') {
578
+ this.summaryList.sort((val1, val2) => {
579
+ return (val2['vlu_sold']) - (val1['vlu_sold']);
580
+ });
581
+ }
582
+ else {
583
+ console.log("this.summaryList", this.summaryList);
584
+ this.summaryList.sort((val1, val2) => {
585
+ return (val1['valueSort']) - (val2['valueSort']);
586
+ });
587
+ console.log("this.summaryList", this.summaryList);
588
+ }
589
+ this.headList = headList;
590
+ }
591
+ else {
592
+ if (selected.length > 1) {
593
+ this.toastr.error("Summary need only one attribute");
594
+ }
595
+ }
596
+ }
597
+ exportToCSVSummary() {
598
+ let modifiedObjArr = [];
599
+ this.summaryList.forEach((data, index) => {
600
+ let obj = {};
601
+ obj["Sr. No"] = index + 1;
602
+ obj["Attribute"] = data.value || '';
603
+ this.headList.forEach(hdr => {
604
+ obj["Qty(" + hdr + ")"] = data["count_" + hdr] || '';
605
+ obj["Carat(" + hdr + ")"] = data["crtwt_" + hdr] || '';
606
+ obj["Avg(" + hdr + ")"] = data["avg_" + hdr] || '';
607
+ obj["Dis(" + hdr + ")"] = data["dis_" + hdr] || '';
608
+ obj["Value(" + hdr + ")"] = data["vlu_" + hdr] || '';
609
+ });
610
+ modifiedObjArr.push(obj);
611
+ });
612
+ this.cs.CSVConvertor(modifiedObjArr, "Summary_details", true);
613
+ }
614
+ getTotal() {
615
+ let indexVal = 0;
616
+ let qs = 0;
617
+ this.GrpVals.forEach(element => {
618
+ let totAmt = 0;
619
+ let totweight = this.cs.splitToTwoDecimal(element.reduce((a, b) => +a + +parseFloat(b.crtwt), 0));
620
+ let rapVal = _.sumBy(element, 'rap_vlu');
621
+ element.forEach(pkt => {
622
+ if (pkt.grp_stt == 'sold') {
623
+ totAmt += parseFloat(pkt['sal_rte'] || 0) * parseFloat(pkt['crtwt']);
624
+ }
625
+ else {
626
+ totAmt += parseFloat(pkt['rte'] || 0) * parseFloat(pkt['crtwt']);
627
+ }
628
+ });
629
+ totAmt = this.cs.splitToTwoDecimal(totAmt);
630
+ var key = this.grp[indexVal];
631
+ this.summaryDtl[key + "_CTS"] = this.cs.splitToTwoDecimal(totweight);
632
+ this.summaryDtl[key + "_AMT"] = this.cs.splitToTwoDecimal(totAmt);
633
+ this.summaryDtl[key + "_RTE"] = this.cs.splitToTwoDecimal(totAmt / totweight);
634
+ this.summaryDtl[key + "_DIS"] = this.cs.splitToTwoDecimal(((totAmt * 100) / rapVal) - 100);
635
+ indexVal++;
636
+ });
637
+ }
638
+ generatePie(Datatype, ChartType) {
639
+ if (ChartType == 'qty') {
640
+ document.getElementById('btnQty').classList.remove('btn-default');
641
+ document.getElementById('btnQty').classList.add('active');
642
+ document.getElementById('btnVal').classList.remove('active');
643
+ document.getElementById('btnVal').classList.add('btn-default');
644
+ }
645
+ else {
646
+ document.getElementById('btnVal').classList.remove('btn-default');
647
+ document.getElementById('btnVal').classList.add('active');
648
+ document.getElementById('btnQty').classList.remove('active');
649
+ document.getElementById('btnQty').classList.add('btn-default');
650
+ }
651
+ this.grpWiseQty = [];
652
+ this.byrvalGrp = [];
653
+ this.dataType = Datatype;
654
+ this._spinnerService.show();
655
+ this.finalGrpValPie = {};
656
+ this.byrvalGrp = [];
657
+ this.data = [...this.pkts];
658
+ this.data = this.data.filter(x => x.grp_stt == 'sold');
659
+ let grpvalues;
660
+ let grpvaluesArr;
661
+ let resutArr = [];
662
+ // type = 'qty';
663
+ if (Datatype == 'buyer') {
664
+ this.type = "Buyer";
665
+ this.isBuyerwise = true;
666
+ this.isGrpwise = false;
667
+ grpvalues = "sal_byr";
668
+ grpvaluesArr = grpvalues.split(',');
669
+ resutArr = [];
670
+ }
671
+ else {
672
+ this.type = this.defaultGrpList;
673
+ this.isBuyerwise = false;
674
+ this.isGrpwise = true;
675
+ grpvaluesArr = this.defaultGrpList; //selected;
676
+ }
677
+ //let grpvaluesArr = selected;
678
+ var final = [];
679
+ var output = _.groupBy(this.data, function (entry) {
680
+ var strs = '';
681
+ for (let i = 0; i < grpvaluesArr.length; i++) {
682
+ strs += entry[grpvaluesArr[i]] + '#';
683
+ }
684
+ return strs;
685
+ // return entry[grpvaluesArr[0]] + '#' + entry[grpvaluesArr[1]];// + '#' + entry.pu;
686
+ });
687
+ // console.log(output);
688
+ final.push(output);
689
+ var Keys = Object.keys(final[0]);
690
+ var Vals = Object.values(final[0]);
691
+ let grpNamearr = [];
692
+ Keys.map(ele => {
693
+ grpNamearr.push(ele.split('#').filter(e => e != undefined).join(' / '));
694
+ });
695
+ this.grpPie = grpNamearr;
696
+ this.GrpValsPie = Vals;
697
+ for (let i = 0; i < grpNamearr.length; i++) {
698
+ var grpNme = grpNamearr[i];
699
+ this.finalGrpValPie[grpNme] = Vals[i];
700
+ let totAmt = this.cs.splitToTwoDecimal(this.finalGrpValPie[grpNme].reduce((a, b) => +a + +parseFloat(b.sal_amountint), 0));
701
+ let byrObj = {};
702
+ byrObj['k'] = grpNme;
703
+ byrObj['v'] = parseFloat(totAmt); //this.byrvalGrp[grpNme].length;
704
+ this.byrvalGrp.push(byrObj);
705
+ byrObj = {};
706
+ // this.byrvalGrp[grpNme] = totAmt;
707
+ let qtyObj = {};
708
+ qtyObj['k'] = grpNme;
709
+ qtyObj['v'] = this.finalGrpValPie[grpNme].length;
710
+ this.grpWiseQty.push(qtyObj);
711
+ qtyObj = {};
712
+ // this.grpWiseQty[grpNme] = this.finalGrpValPie[grpNme].length;
713
+ }
714
+ console.log(this.grpWiseQty);
715
+ if (ChartType == 'qty') {
716
+ this.drawPie(this.grpWiseQty, ChartType, Datatype);
717
+ }
718
+ else {
719
+ this.drawPie(this.byrvalGrp, ChartType, Datatype);
720
+ }
721
+ // this.getTotalPie();
722
+ // this.grpPie.sort();
723
+ }
724
+ generate() {
725
+ this.dynamicColors = [];
726
+ for (var i = 1; i < 7; i++) {
727
+ // this.LightenDarkenColor("7cb5ec", i * 10);
728
+ let col = 'c6e896';
729
+ let amt = (i * 20) * -1;
730
+ var usePound = false;
731
+ if (col[0] == "#") {
732
+ col = col.slice(1);
733
+ usePound = true;
734
+ }
735
+ var num = parseInt(col, 16);
736
+ var r = (num >> 16) + amt;
737
+ if (r > 255)
738
+ r = 255;
739
+ else if (r < 0)
740
+ r = 0;
741
+ var b = ((num >> 8) & 0x00FF) + amt;
742
+ if (b > 255)
743
+ b = 255;
744
+ else if (b < 0)
745
+ b = 0;
746
+ var g = (num & 0x0000FF) + amt;
747
+ if (g > 255)
748
+ g = 255;
749
+ else if (g < 0)
750
+ g = 0;
751
+ // return (usePound ? "#" : "") + (g | (b << 8) | (r << 16)).toString(16);
752
+ this.dynamicColors.push((usePound ? "#" : "#") + (g | (b << 8) | (r << 16)).toString(16));
753
+ }
754
+ console.log(this.dynamicColors);
755
+ return this.dynamicColors;
756
+ }
757
+ getTotalPie() {
758
+ let indexVal = 0;
759
+ let AmtArr = [];
760
+ this.GrpValsPie.forEach(element => {
761
+ let byrwiseVal = {};
762
+ let totAmt = 0;
763
+ let totweight = 0;
764
+ totweight = this.cs.splitToTwoDecimal(element.reduce((a, b) => +a + +parseFloat(b.crtwt), 0));
765
+ totAmt = this.cs.splitToTwoDecimal(element.reduce((a, b) => +a + +parseFloat(b.sal_amountint), 0));
766
+ AmtArr.push(totAmt);
767
+ var key = this.grp[indexVal];
768
+ // this.summaryDtl[key + "_QTY"] = this.cs.splitToTwoDecimal(qty);
769
+ this.summaryDtlPie[key + "_CTS"] = this.cs.splitToTwoDecimal(totweight);
770
+ this.summaryDtlPie[key + "_AMT"] = this.cs.splitToTwoDecimal(totAmt);
771
+ indexVal++;
772
+ if (indexVal == 1) {
773
+ byrwiseVal[this.grp[indexVal]] = totAmt;
774
+ this.byrValArr.push(byrwiseVal);
775
+ byrwiseVal = {};
776
+ }
777
+ // console.log(qs);
778
+ // console.log(amount);
779
+ });
780
+ console.log(this.byrValArr);
781
+ AmtArr = AmtArr.map(function (x) {
782
+ return parseFloat(x);
783
+ });
784
+ AmtArr.sort(function (a, b) { return a - b; });
785
+ console.log(AmtArr);
786
+ AmtArr.reverse();
787
+ // this.drawPie(AmtArr);
788
+ }
789
+ drawPie(salesData, type, ChartType) {
790
+ this.doughnutChartData = [];
791
+ this.doughnutChartLabels = [];
792
+ let AmtArr = salesData.sort((a, b) => (a.v > b.v) ? 1 : -1).reverse();
793
+ if (ChartType == "buyer") {
794
+ this.doughnutChartData = AmtArr.slice(0, 5).map(a => a.v);
795
+ this.doughnutChartLabels = AmtArr.slice(0, 5).map(a => a.k);
796
+ let sums = 0;
797
+ let otherSum = this.cs.splitToTwoDecimal(this.sttWiseSummary.get('sold').get('rate'));
798
+ if (type == 'qty')
799
+ otherSum = this.cs.splitToTwoDecimal(this.sttWiseSummary.get('sold').get('count'));
800
+ let tArr = [];
801
+ tArr = AmtArr.slice(0, 5).map(function (x) {
802
+ return parseFloat(x.v);
803
+ });
804
+ sums = _.sumBy(tArr);
805
+ let maxinArr = Math.max(Math.max(...this.doughnutChartData));
806
+ debugger;
807
+ let otherval = this.cs.splitToTwoDecimal(otherSum - sums) || 0;
808
+ if (maxinArr > otherval) {
809
+ this.doughnutChartData.push(otherval);
810
+ this.doughnutChartLabels.push('Other');
811
+ }
812
+ else {
813
+ this.doughnutChartData.unshift(otherval);
814
+ this.doughnutChartLabels.unshift('Other');
815
+ }
816
+ }
817
+ else {
818
+ this.doughnutChartData = AmtArr.map(a => a.v);
819
+ this.doughnutChartLabels = AmtArr.map(a => a.k);
820
+ console.log("this.doughnutChartData", this.doughnutChartData);
821
+ let sums = 0;
822
+ let otherSum = this.cs.splitToTwoDecimal(this.sttWiseSummary.get('sold').get('rate'));
823
+ sums = _.sumBy(Object.values(AmtArr), 'v');
824
+ }
825
+ // this.doughnutChartData.sort(function (a, b) { return a - b; });
826
+ // this.doughnutChartData = this.doughnutChartData.reverse();
827
+ for (let i = 0; i < this.doughnutChartLabels.length; i++) {
828
+ this.doughnutChartLabels[i] = this.doughnutChartLabels[i] + " " + this.doughnutChartData[i].toString();
829
+ }
830
+ // console.log(this.doughnutChartLabels);
831
+ this.refreshChart(ChartType);
832
+ this.doughnutChartType = 'pie';
833
+ // document.getElementById('PiechartModelBtn').click();
834
+ this._spinnerService.hide();
835
+ }
836
+ refreshChart(ChartType) {
837
+ this.isBuyerwise = false;
838
+ this.isGrpwise = false;
839
+ setTimeout(() => {
840
+ if (ChartType == "buyer") {
841
+ this.isBuyerwise = true;
842
+ }
843
+ else {
844
+ this.isGrpwise = true;
845
+ }
846
+ }, 1);
847
+ }
848
+ sortBy(key, g) {
849
+ this.sorted = this.sorted == 'desc' ? 'asc' : 'desc';
850
+ console.log(this.sorted);
851
+ let srted = _.orderBy(this.finalGrpVal[g], key, [this.sorted]);
852
+ this.finalGrpVal[g] = srted;
853
+ this.sortOn = g;
854
+ this.clmn = key;
855
+ }
856
+ exportToCSV(FileName) {
857
+ let d = this.cs.cDate, month = '' + (d.getMonth() + 1), day = '' + d.getDate(), year = d.getFullYear();
858
+ let dt = [day, month, year].join('-');
859
+ let fileNme = FileName + '__' + dt;
860
+ this.headerKey = ["dsp_stt", ...this.headerKey];
861
+ let modifiedObjArr = this.cs.modifyDataByHeader(this.pkts, this.headerKey, this.header);
862
+ this.cs.CSVConvertor(modifiedObjArr, fileNme, true);
863
+ }
864
+ getSummary(p) {
865
+ let summary;
866
+ p.forEach(element => {
867
+ // let stt = '';
868
+ // if (element.grp_stt == 'sold') {
869
+ // stt = 'Sold';
870
+ // }
871
+ // else if (element.grp_stt == 'mkt') {
872
+ // stt = 'Marketing';
873
+ // }
874
+ // else if (element.grp_stt == 'lab') {
875
+ // stt = 'Lab';
876
+ // }
877
+ // else {
878
+ // stt = element.grp_stt;
879
+ // }
880
+ // summary = this.sttWiseSummary.get(element.grp_stt);
881
+ summary = this.sttWiseSummary.get(element.grp_stt); //stt
882
+ let count = 0;
883
+ let gridWt = 0;
884
+ let gridavg = 0;
885
+ let disc = 0;
886
+ let gridRate = 0;
887
+ let totAmt = 0;
888
+ let gridRap = 0;
889
+ // this.totAvg = this.cs.splitToTwoDecimal(parseFloat(totAmt) / parseFloat(totweight));
890
+ // this.totDis = this.cs.splitToTwoDecimal(((parseFloat(totAmt) * 100) / parseFloat(totrapVal)) - 100);
891
+ let wt = parseFloat(element.crtwt);
892
+ let rate = 0;
893
+ let rapval = parseFloat(element.rap_vlu);
894
+ if (element.grp_stt == 'sold') {
895
+ rate = parseFloat((element.sal_rte == undefined || element.sal_rte == "") ? element.rte : element.sal_rte) * parseFloat(element.crtwt);
896
+ }
897
+ else {
898
+ rate = parseFloat(element.rte) * parseFloat(element.crtwt);
899
+ }
900
+ if (summary != null) {
901
+ count = parseInt(summary.get('count'));
902
+ gridWt = parseFloat(summary.get('wt'));
903
+ gridRate = parseFloat(summary.get('rate'));
904
+ gridRap = parseFloat(summary.get('rap'));
905
+ }
906
+ else {
907
+ summary = new Map();
908
+ }
909
+ summary.set('count', count + 1);
910
+ summary.set('wt', gridWt + wt);
911
+ summary.set('rate', gridRate + rate);
912
+ summary.set('rap', gridRap + rapval);
913
+ // this.sttWiseSummary.set(element.grp_stt == 'sold' ? 'Sold' : element.grp_stt, summary);
914
+ this.sttWiseSummary.set(element.grp_stt, summary); //stt
915
+ });
916
+ console.log('@presum:', this.sttWiseSummary);
917
+ this.anaAllGrpStt.forEach(ele => {
918
+ console.log(ele);
919
+ let count = 0;
920
+ let gridWt = 0;
921
+ let gridavg = 0;
922
+ let disc = 0;
923
+ let gridRate = 0;
924
+ let totAmt = 0;
925
+ let rap = 0;
926
+ let gridRap = 0;
927
+ //if (ele == 'Marketing' || ele == 'Sold') {
928
+ // ele = (ele == 'Marketing' || ele == 'Sold') ? ele : ele.toLowerCase();
929
+ let summary = this.sttWiseSummary.get(ele) || new Map();
930
+ count = parseInt(summary.get('count')) || 0;
931
+ gridWt = parseFloat(summary.get('wt')) || 0.00;
932
+ gridRate = parseFloat(summary.get('rate')) || 0;
933
+ gridRap = parseFloat(summary.get('rap')) || 1;
934
+ disc = this.cs.splitToTwoDecimal(((gridRate * 100) / gridRap) - 100);
935
+ gridavg = this.cs.splitToTwoDecimal(gridRate / gridWt);
936
+ summary.set('disc', disc);
937
+ summary.set('avg', gridavg);
938
+ this.sttWiseSummary.set(ele, summary);
939
+ //}
940
+ });
941
+ console.log(this.sttWiseSummary);
942
+ }
943
+ getTotals(fields, pkts) {
944
+ debugger;
945
+ fields.forEach(element => {
946
+ debugger;
947
+ let tavg = 0;
948
+ let total = 0;
949
+ if (element.trim() == 'age') {
950
+ total = this.cs.splitToTwoDecimal(pkts.reduce((a, b) => +a + +b.age, 0));
951
+ }
952
+ else {
953
+ total = _.sumBy(pkts, item => Number(item[element.trim()]));
954
+ }
955
+ let zeroVals = pkts.filter(x => (x[element.trim()] === "0" || 0)).length;
956
+ if (element.trim() != 'age') {
957
+ tavg = total / _.sumBy(pkts, item => Number(item['crtwt']));
958
+ tavg = this.cs.numbertofixed(tavg, 2);
959
+ }
960
+ else {
961
+ tavg = total / pkts.length;
962
+ }
963
+ this.TotAvgObj[element.trim()] = tavg;
964
+ });
965
+ console.log(this.TotAvgObj);
966
+ }
967
+ getTotalsTtl(fields, pkts) {
968
+ debugger;
969
+ fields.forEach(element => {
970
+ debugger;
971
+ let total = 0;
972
+ total = _.sumBy(pkts, item => Number(item[element.trim()]));
973
+ this.TotAvgObj[element.trim()] = this.cs.numbertofixed(total, 2);
974
+ });
975
+ }
976
+ modifySearch() {
977
+ localStorage.setItem('BIcall', 'BImodify');
978
+ this.router.navigate([this.modulename + '/analysis-search/' + this.route.snapshot.params['frmnme']]);
979
+ }
980
+ ngOnInit() {
981
+ // this.LightenDarkenColor("7cb5ec", 10);
982
+ let mdlk = JSON.parse(localStorage.getItem('mdlKey'));
983
+ this.cObj = {};
984
+ this.cUrl = this.router.url;
985
+ this.reqheader = {
986
+ 'clientkey': Cookie.get('_ck'),
987
+ 'Content-Type': 'application/json',
988
+ 'modulekey': mdlk[this.cUrl.split('/')[1]],
989
+ 'loginid': Cookie.get('_logid'),
990
+ 'source': 'qs'
991
+ };
992
+ this.viewdisType = "group";
993
+ this.newwindow = "YES";
994
+ this.grp = [];
995
+ this.loadResult = [];
996
+ this.startIndex = 0;
997
+ this.endIndex = 30;
998
+ this.cUrl = this.router.url;
999
+ this.modulename = this.cUrl.split('/')[1];
1000
+ this.ck = encodeURIComponent(Cookie.get('_ck'));
1001
+ this.route.params.subscribe(map => {
1002
+ this.loadDefination();
1003
+ let viewType = localStorage.getItem('viewType');
1004
+ let anaArr = JSON.parse(localStorage.getItem('BIanaStt'));
1005
+ let anasttLbl = JSON.parse(localStorage.getItem('BIanaSttLBL'));
1006
+ if (anaArr != null) {
1007
+ this.anaAllGrpStt = JSON.parse(localStorage.getItem('BIanaStt'));
1008
+ this.anaSttLbl = JSON.parse(localStorage.getItem('BIanaSttLBL'));
1009
+ this.anaAllGrpStt.forEach(element => {
1010
+ this.stObj[element] = true;
1011
+ });
1012
+ }
1013
+ if (viewType == 'listView') {
1014
+ this.getSearchResult();
1015
+ }
1016
+ else {
1017
+ let pkts = JSON.parse(localStorage.getItem('pktData'));
1018
+ this.headerKey = JSON.parse(localStorage.getItem('resultView'));
1019
+ this.header = JSON.parse(localStorage.getItem('resultViewDtl'));
1020
+ this.header = JSON.parse(localStorage.getItem('resultViewDtl'));
1021
+ let legends = JSON.parse(localStorage.getItem('BILegends'));
1022
+ if (legends != null && legends != undefined && legends != "") {
1023
+ this.legendList = legends;
1024
+ }
1025
+ this.pkts = [...pkts];
1026
+ this.totalWeight = this.cs.splitToTwoDecimal(this.pkts.reduce((a, b) => +a + +parseFloat(b.crtwt), 0));
1027
+ this.getSummary(this.pkts);
1028
+ // let totAmt = this.cs.splitToTwoDecimal(this.pkts.reduce((a, b) => +a + +b.sal_rec_rte * parseFloat(b.crtwt), 0));
1029
+ let totweight = this.cs.splitToTwoDecimal(this.pkts.reduce((a, b) => +a + +parseFloat(b.crtwt), 0));
1030
+ let totrapVal = this.cs.splitToTwoDecimal(this.pkts.reduce((a, b) => +a + +b.rap_vlu, 0));
1031
+ let totAmt = 0;
1032
+ this.pkts.forEach(element => {
1033
+ if (element.grp_stt == 'sold') {
1034
+ totAmt += parseFloat(element['sal_rte']) * parseFloat(element['crtwt']);
1035
+ }
1036
+ else {
1037
+ totAmt += parseFloat(element['rte']) * parseFloat(element['crtwt']);
1038
+ }
1039
+ });
1040
+ this.totAvg = this.cs.splitToTwoDecimal(totAmt / parseFloat(totweight));
1041
+ this.totDis = this.cs.splitToTwoDecimal(((totAmt * 100) / parseFloat(totrapVal)) - 100);
1042
+ this.resultlength = this.pkts.length;
1043
+ if (this.endIndex > this.resultlength)
1044
+ this.endIndex = this.resultlength;
1045
+ this.addItems();
1046
+ }
1047
+ });
1048
+ let GRPby = JSON.parse(localStorage.getItem('BI-PKT_GROUP_BY')) || '';
1049
+ this.getStaticKV(GRPby);
1050
+ // this.createGrp(this.pkts, this.defaultGrpList);
1051
+ let avgFields = JSON.parse(localStorage.getItem('BI-gridAvg')) || '';
1052
+ if (avgFields != '')
1053
+ this.getTotals(avgFields, this.pkts);
1054
+ }
1055
+ getStaticKV(qry) {
1056
+ this.staticLov = [];
1057
+ let arrkv = qry.split(',');
1058
+ let obj = {}, staticLov = [];
1059
+ for (let i = 0; i < arrkv.length; i += 2) {
1060
+ let key = arrkv[i], value = arrkv[i + 1];
1061
+ obj['k'] = key;
1062
+ obj['v'] = value;
1063
+ // if (i == 0) {
1064
+ // qry.default_value = value;//key
1065
+ // }
1066
+ this.staticLov.push(obj);
1067
+ obj = {};
1068
+ }
1069
+ this.staticLov = this.staticLov.map(option => ({
1070
+ value: option.v,
1071
+ label: option.k
1072
+ }));
1073
+ console.log(this.staticLov);
1074
+ }
1075
+ loadDefination() {
1076
+ this._spinnerService.show();
1077
+ let reqObj = {};
1078
+ reqObj['formNme'] = this.route.snapshot.params['frmnme']; //'searchDtlDscrForm';
1079
+ this.reqheader['method'] = 'loadDefination';
1080
+ let options = ({ headers: new HttpHeaders(this.reqheader) });
1081
+ this.cs.load(reqObj, options, 'marketing/search').then((response) => {
1082
+ if (response.status == 'SUCCESS') {
1083
+ let result = response.result;
1084
+ this.pageDefination = result.pageDefination || {};
1085
+ this.links = this.pageDefination.link || [];
1086
+ this._spinnerService.hide();
1087
+ }
1088
+ else {
1089
+ this._spinnerService.hide();
1090
+ this.toastr.error(response.message);
1091
+ }
1092
+ }).catch((err) => {
1093
+ this._spinnerService.hide();
1094
+ this.toastr.error(err.message);
1095
+ });
1096
+ }
1097
+ }
1098
+ /** @nocollapse */ /** @nocollapse */ PktDataComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: PktDataComponent, deps: [{ token: i1.CommanServiceService }, { token: i2.BiService }, { token: i3.NgxSpinnerService }, { token: i4.ToastrService }, { token: i5.Router }, { token: i5.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Component });
1099
+ /** @nocollapse */ /** @nocollapse */ PktDataComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: PktDataComponent, selector: "app-pkt-data", viewQueries: [{ propertyName: "chart", first: true, predicate: BaseChartDirective, descendants: true }], ngImport: i0, template: "<div class=\"mt\">\r\n <div class=\"panel panel-default\">\r\n <div class=\"panel-heading\">\r\n <h3 class=\"panel-title\">\r\n <span class=\"fa fa-chevron-left cp\" (click)=\"cs.pageBck();\"> Back</span>&nbsp;&nbsp;&nbsp; Packet List\r\n <span class=\"f-12\">({{cs.cDate | date: 'medium'}})</span>\r\n </h3>\r\n </div>\r\n </div>\r\n <div class=\"content-frame\">\r\n <div class=\"innerD\">\r\n <div class=\"content-frame-left\" *ngIf=\"false\">\r\n <div class=\"panel panel-default\">\r\n <div class=\"panel-body\">\r\n <!-- <div class=\"list-group border-bottom\">\r\n <a href=\"javascript:void(0)\" class=\"list-group-item\" [ngClass]=\"{'active' :i == cLink}\" *ngFor=\"let nav of navigation;let i=index\"\r\n (click)=\"navigationFun(nav,i);\">{{nav.form_field_title}} </a>\r\n </div> -->\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"content-frame-body\" style=\"margin-left:0\">\r\n <div class=\"panel panel-default custom-panel\">\r\n <div class=\"panel-body\" style=\"padding:0;\">\r\n <div class=\"infoSec\">\r\n <div class=\"row\">\r\n <div class=\"col-sm-6\">\r\n <form class=\"form-inline pull-left\">\r\n </form>\r\n </div>\r\n <div class=\"col-sm-6\">\r\n <div class=\"dropdown text-right\">\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-4\">\r\n <div class=\"\" style=\"margin-bottom: 10px;\">\r\n <table class=\"displayTable\">\r\n <thead>\r\n <tr>\r\n <th>Status</th>\r\n <th>Count</th>\r\n <th>Cts</th>\r\n <th>Avg</th>\r\n <th *ngIf=\"formname!='mixAnalysisReportForm'\">Disc</th>\r\n <th>Amount</th>\r\n\r\n </thead>\r\n <tbody>\r\n <ng-container *ngFor=\"let st of anaAllGrpStt;let i = index;\">\r\n <tr>\r\n <td>\r\n <!-- <label for=\"{{st}}\" class=\"text-capitalize\">S</label> -->\r\n <!-- *ngIf=\"defaultGrpList.length==0\" -->\r\n <input *ngIf=\"defaultGrpList.length==0\" type=\"checkbox\" id=\"{{st}}\" value=\"{{st}}\"\r\n name=\"{{st}}\" [(ngModel)]=\"stObj[st]\" [checked]=\"true\"\r\n (change)=\"statusWiseDisplay($event,stObj)\" />\r\n {{anaSttLbl[i]||st}}\r\n </td>\r\n <!-- anaSttLbl -->\r\n <td> {{sttWiseSummary?.get(st)?.get('count')}}</td>\r\n <td> {{this.cs.splitToTwoDecimal(sttWiseSummary?.get(st)?.get('wt'))}}</td>\r\n <td> {{this.cs.splitToTwoDecimal(sttWiseSummary?.get(st)?.get('avg'))}}</td>\r\n <td *ngIf=\"formname!='mixAnalysisReportForm'\"> {{this.cs.splitToTwoDecimal(sttWiseSummary?.get(st)?.get('disc'))}}</td>\r\n <td> {{this.cs.splitToTwoDecimal(sttWiseSummary?.get(st)?.get('rate'))}}</td>\r\n\r\n </tr>\r\n </ng-container>\r\n </tbody>\r\n </table>\r\n </div>\r\n </div>\r\n\r\n \r\n \r\n <div class=\"col-md-3\">\r\n <div class=\"form-group w-100\">\r\n <div class=\"col-md-5\">\r\n \r\n <select class=\"formcontrol\" name=\"viewdisType\" (change)=\"onGrpSelect(defaultGrpList)\" [(ngModel)]=\"viewdisType\">\r\n <option value=\"group\">Group By</option>\r\n <option value=\"summary\">Summary By</option>\r\n \r\n </select>\r\n </div>\r\n <div class=\"col-md-7\">\r\n <div class=\"input-group w-100\">\r\n <ng-select placeholder=\"Select Group\" [options]=\"staticLov\" [(ngModel)]=\"defaultGrpList\"\r\n name=\"status\" [multiple]=\"true\" [allowClear]=\"true\" (selected)=\"onGrpSelect(defaultGrpList)\"\r\n (deselected)=\"onGrpSelect(defaultGrpList)\">\r\n <ng-template #optionTemplate let-option=\"option\">\r\n <div class=\"famfamfam-flags {{option?.value.toLowerCase()}}\"></div>\r\n {{option?.label}}\r\n </ng-template>\r\n </ng-select>\r\n </div>\r\n\r\n </div>\r\n\r\n </div>\r\n <p>\r\n <b>Buyer Pie chart</b>\r\n <i title=\"Buyer wise pie chart\"\r\n style=\"cursor: pointer;padding: 5px;margin-left: 10px; text-align: center;font-size: 20px;color: #3a5898;\"\r\n type=\"button\" class=\"fa fa-pie-chart\" aria-hidden=\"true\" data-toggle=\"modal\"\r\n data-target=\"#PiechartModel\" (click)=\"generatePie('buyer','value')\"></i>\r\n </p>\r\n </div>\r\n\r\n \r\n <div class=\"col-md-2\">\r\n <p *ngIf=\"defaultGrpList.length>0\">\r\n <i title=\"Group wise chart\"\r\n style=\"cursor: pointer;padding: 5px;margin-left: 10px; text-align: center;font-size: 20px;color: #3a5898;\"\r\n type=\"button\" class=\"fa fa-pie-chart\" aria-hidden=\"true\" data-toggle=\"modal\"\r\n data-target=\"#PiechartModel\" (click)=\"generatePie('group','value')\"></i>\r\n </p>\r\n <ul class=\"cul\">\r\n <li *ngFor=\"let legend of legendList\">\r\n <p\r\n [ngStyle]=\"{'background-color': legend.k ,'height':'9px', 'width':'9px', 'margin': '0', 'display' : 'inline-block'}\">\r\n </p>\r\n {{legend.v}}\r\n </li>\r\n </ul>\r\n </div>\r\n <div class=\"col-md-3 pull-right\">\r\n <form class=\"form-inline pull-right\">\r\n <div class=\"form-group\">\r\n <label for=\"exampleInputName2\">Search &nbsp;&nbsp;</label>\r\n <input type=\"text\" class=\"form-control\" id=\"exampleInputName2\" name=\"schtxt\" [(ngModel)]=\"searchF\" />\r\n </div>\r\n <button class=\"btn btn-default\" style=\"padding: 4px 15px 4px 20px;margin-left: 10px;float: right;\"\r\n data-toggle=\"tooltip\" data-placement=\"left\" title=\"Download Excel\"\r\n (click)=\"exportToCSV('Packet list');\">\r\n <span class=\"fa fa-file-excel-o\" style=\"color:green;\"></span>\r\n </button>\r\n\r\n </form>\r\n </div>\r\n\r\n </div>\r\n \r\n \r\n\r\n <!-- <div class=\"col-md-2\">\r\n <div class=\"form-group\">\r\n <button class=\"btn btn-success\" style=\"margin-left: 5px;\" (click)=\"modifySearch()\">Modify\r\n Search</button>\r\n </div>\r\n <ul class=\"cul\">\r\n <li *ngFor=\"let legend of legendList\">\r\n <p\r\n [ngStyle]=\"{'background-color': legend.k ,'height':'9px', 'width':'9px', 'margin': '0', 'display' : 'inline-block'}\">\r\n </p>\r\n {{legend.v}}\r\n </li>\r\n </ul> \r\n </div>\r\n </div>\r\n -->\r\n <div class=\"row\">\r\n <ng-container *ngIf=\"viewdisType=='group'\">\r\n <div *ngIf=\"groupBypktList.length >0\" class=\"table-responsive\" id=\"wrap\" style=\"overflow: auto;width: 100%;height: calc(100vh - 250px);\"\r\n infinite-scroll [infiniteScrollDistance]=\"scrollDistance\" [infiniteScrollUpDistance]=\"scrollUpDistance\"\r\n [infiniteScrollThrottle]=\"50\" (scrolled)=\"grouponScrollDown()\" [scrollWindow]=\"false\">\r\n <table class=\"displayTable\">\r\n <thead>\r\n <tr class=\"posrel\">\r\n <th class=\"cTh\" style=\"width:75px;\" *ngIf=\"formname!='mixAnalysisReportForm'\">\r\n DNA</th>\r\n <th style=\"text-align: center;\">Status</th>\r\n <th (click)=\"sortBy(hrdKey,g)\" style=\"text-align: center;\" *ngFor=\"let hrdKey of headerKey\">\r\n {{header[hrdKey]}}\r\n \r\n </th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n \r\n <ng-container *ngFor=\"let groupdtl of loadgroupBypktList let j=index;\">\r\n <tr>\r\n <td [attr.colspan]=\"headerKey.length+1\" style=\"font-weight:bold;text-align: left; \">\r\n {{groupdtl.value}} &nbsp; &nbsp;\r\n Qty : {{groupdtl['count']}} &nbsp; &nbsp; Carats :\r\n {{groupdtl['crtwt']}}\r\n &nbsp; &nbsp; Avg :{{groupdtl['salavg']}}\r\n &nbsp; &nbsp; Dis% : {{groupdtl['saldis']}}\r\n\r\n &nbsp;&nbsp; Amount : {{groupdtl['salvlu']}} \r\n </td>\r\n </tr> \r\n <!-- <tr *ngIf=\"sttwise\" >\r\n <td [attr.colspan]=\"headerKey.length+1\" style=\"font-weight:bold;text-align: left; \">\r\n {{g}} &nbsp; &nbsp;\r\n Qty : {{finalGrpVal[g].length}} &nbsp; &nbsp; Carats :\r\n {{totalWeight}}\r\n\r\n &nbsp;&nbsp; Amount :{{totAmt}}\r\n </td>\r\n </tr> -->\r\n\r\n\r\n\r\n <tr *ngFor=\"let pktdtl of groupdtl['pktList'] | tableSearch:searchF:pkts;let pkti = index\"\r\n [ngClass]=\"{'even':pkti%2==0,'odd':pkti%2==1}\">\r\n <td style=\"width:75px;position: relative;\" *ngIf=\"formname!='mixAnalysisReportForm'\">\r\n <a href=\"https://kapugems.com/kweb/#/dna/{{pktdtl.stock_idn}}/?key={{ck}}\" target=\"_blank\">\r\n <i class=\"fa fa-diamond\" aria-hidden=\"true\"></i>\r\n </a>\r\n <input type=\"checkbox\" value=\"{{pktdtl.stock_idn}}\" [hidden]=\"true\" id=\"cb_{{pktdtl.stock_idn}}\"\r\n (click)=\"checkedRow(pktdtl,pktdtl.stock_idn,$event.target.checked)\">\r\n </td>\r\n <td style=\"text-align: center;\" [ngStyle]=\"{'color': pktdtl.dsp_stt}\">{{pktdtl.dsp_stt}}</td>\r\n <ng-container *ngFor=\"let hrdKey of headerKey\">\r\n <td *ngIf=\"hrdKey!='co' && hrdKey!='pu'\" style=\"text-align: center\" (click)=\"selectRow(pktdtl.stock_idn);\"\r\n [ngStyle]=\"{'color': pktdtl.dsp_stt_color == '#FFFFFF' ? 'black':pktdtl.dsp_stt_color}\">\r\n {{pktdtl[hrdKey]}}</td>\r\n\r\n <td style=\"text-align: center\" *ngIf=\"hrdKey=='co'\" (click)=\"selectRow(pktdtl.stock_idn);\"\r\n [ngStyle]=\"{'color': pktdtl.dsp_stt_color == '#FFFFFF' ? 'black':pktdtl.dsp_stt_color}\">\r\n {{pktdtl[hrdKey+\"_p\"]}}</td>\r\n\r\n\r\n\r\n <td style=\"text-align: center\" *ngIf=\"hrdKey=='pu'\" (click)=\"selectRow(pktdtl.stock_idn);\"\r\n [ngStyle]=\"{'color': pktdtl.dsp_stt_color == '#FFFFFF' ? 'black':pktdtl.dsp_stt_color}\">\r\n {{pktdtl[hrdKey+\"_p\"]}}</td>\r\n </ng-container>\r\n </tr>\r\n </ng-container>\r\n </tbody>\r\n </table>\r\n </div>\r\n\r\n\r\n \r\n \r\n <div *ngIf=\"pkts.length > 0 && groupBypktList.length==0 \" class=\"table-responsive\" id=\"wrap\" style=\"overflow: auto;width: 100%;height: calc(100vh - 250px);\"\r\n infinite-scroll [infiniteScrollDistance]=\"scrollDistance\" [infiniteScrollUpDistance]=\"scrollUpDistance\"\r\n [infiniteScrollThrottle]=\"50\" (scrolled)=\"onScrollDown()\" [scrollWindow]=\"false\">\r\n <table class=\"displayTable\">\r\n <thead>\r\n <tr class=\"posrel\">\r\n <th class=\"cTh\" style=\"width:75px;\" *ngIf=\"formname!='mixAnalysisReportForm'\">\r\n DNA</th>\r\n <th> \r\n Actions\r\n </th>\r\n <th style=\"text-align: center;\">Status</th>\r\n <th style=\"text-align: center;\" *ngFor=\"let hrdKey of headerKey\">{{header[hrdKey]}}</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr>\r\n <td></td>\r\n <td></td>\r\n <td><b>Average </b></td>\r\n <ng-container *ngFor=\"let hrdKey of headerKey\">\r\n <td>\r\n <b>{{cs.splitToTwoDecimal(TotAvgObj[hrdKey])}}</b>\r\n </td>\r\n \r\n </ng-container>\r\n \r\n </tr>\r\n <tr *ngFor=\"let pktdtl of loadResult | tableSearch:searchF:pkts;let pkti = index\"\r\n [ngClass]=\"{'even':pkti%2==0,'odd':pkti%2==1}\">\r\n <td style=\"width:75px;position: relative;\" *ngIf=\"formname!='mixAnalysisReportForm'\">\r\n <a href=\"https://kapugems.com/kweb/#/dna/{{pktdtl.stock_idn}}/?key={{ck}}\" target=\"_blank\">\r\n <i class=\"fa fa-diamond\" aria-hidden=\"true\"></i>\r\n </a>\r\n <input type=\"checkbox\" value=\"{{pktdtl.stock_idn}}\" [hidden]=\"true\" id=\"cb_{{pktdtl.stock_idn}}\"\r\n (click)=\"checkedRow(pktdtl,pktdtl.stock_idn,$event.target.checked)\">\r\n </td>\r\n <td> \r\n <ng-container *ngFor=\"let lnk of links\">\r\n <i class=\"{{lnk.form_field_icon}}\" *ngIf=\"pktdtl.dsp_stt!='sold'\" (click)=\"OnLinkClick(lnk,pktdtl)\" aria-hidden=\"true\"></i>\r\n &nbsp;\r\n </ng-container>\r\n \r\n </td>\r\n\r\n <td style=\"text-align: center;\" [ngStyle]=\"{'color': pktdtl.dsp_stt}\">{{pktdtl.dsp_stt}}</td>\r\n <ng-container *ngFor=\"let hrdKey of headerKey\">\r\n <td *ngIf=\"hrdKey!='co' && hrdKey!='pu'\" style=\"text-align: center\" (click)=\"selectRow(pktdtl.stock_idn);\"\r\n [ngStyle]=\"{'color': pktdtl.dsp_stt_color == '#FFFFFF' ? 'black':pktdtl.dsp_stt_color}\">\r\n {{pktdtl[hrdKey]}}</td>\r\n\r\n <td style=\"text-align: center\" *ngIf=\"hrdKey=='co'\" (click)=\"selectRow(pktdtl.stock_idn);\"\r\n [ngStyle]=\"{'color': pktdtl.dsp_stt_color == '#FFFFFF' ? 'black':pktdtl.dsp_stt_color}\">\r\n {{pktdtl[hrdKey+\"_p\"]}}</td>\r\n\r\n\r\n <td style=\"text-align: center\" *ngIf=\"hrdKey=='pu'\" (click)=\"selectRow(pktdtl.stock_idn);\"\r\n [ngStyle]=\"{'color': pktdtl.dsp_stt_color == '#FFFFFF' ? 'black':pktdtl.dsp_stt_color}\">\r\n {{pktdtl[hrdKey+\"_p\"]}}</td>\r\n </ng-container>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"viewdisType=='summary' && summaryList.length>0\">\r\n <div class=\"row\">\r\n <div class=\"col-md-12\"> <button class=\"btn btn-default\"\r\n style=\"padding: 4px 15px 4px 20px;margin-left: 10px;\" data-toggle=\"tooltip\" data-placement=\"right\"\r\n title=\"Download Excel\" (click)=\"exportToCSVSummary();\">\r\n <span class=\"fa fa-file-excel-o\" style=\"color:green;\"></span>\r\n </button></div>\r\n </div>\r\n <div class=\"row\">\r\n <table class=\"displayTable\" style=\"text-align: center;padding:10px ;\">\r\n <thead>\r\n <tr class=\"posrel\">\r\n <th style=\"text-align: center;\">Sr. No</th>\r\n <th style=\"text-align: center;\">Attribute</th>\r\n <ng-container *ngFor=\"let hdr of headList\">\r\n <th style=\"text-align: center;\" colspan=\"5\">{{hdr}}</th>\r\n </ng-container>\r\n </tr>\r\n <tr class=\"posrel\">\r\n <td style=\"text-align: center;\"></td>\r\n <ng-container *ngFor=\"let hdr of headList\">\r\n <td style=\"text-align: center;\">Qty</td>\r\n <td style=\"text-align: center;\">Carat</td>\r\n <td style=\"text-align: center;\">Avg</td>\r\n <td style=\"text-align: center;\" *ngIf=\"formname!='mixAnalysisReportForm'\">Dis</td>\r\n <td style=\"text-align: center;\">Value</td>\r\n </ng-container>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let summaryDtl of summaryList | tableSearch:searchF:pkts;let pkti = index\"\r\n [ngClass]=\"{'even':pkti%2==0,'odd':pkti%2==1}\">\r\n <td style=\"text-align: center;\">{{pkti+1}}</td>\r\n <td style=\"text-align: center;\">{{summaryDtl['value']}}</td>\r\n <ng-container *ngFor=\"let hdr of headList\">\r\n <td style=\"text-align: center;\">{{summaryDtl['count_'+hdr]}}</td>\r\n <td style=\"text-align: center;\">{{summaryDtl['crtwt_'+hdr]}}</td>\r\n <td style=\"text-align: center;\">{{summaryDtl['avg_'+hdr]}}</td>\r\n <td style=\"text-align: center;\" *ngIf=\"formname!='mixAnalysisReportForm'\">{{summaryDtl['dis_'+hdr]}}</td>\r\n <td style=\"text-align: center;\">{{summaryDtl['vlu_'+hdr]}}</td>\r\n </ng-container>\r\n </tr> \r\n\r\n </tbody>\r\n </table>\r\n </div>\r\n </ng-container>\r\n</div>\r\n\r\n \r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"actionFooter\">\r\n <div class=\"row\">\r\n <div class=\"calsec pull-left\" style=\"padding: 5px;\">\r\n <table>\r\n <tr>\r\n <td style=\"text-align: center;\">\r\n <strong> Total: &nbsp; </strong>\r\n </td>\r\n <td style=\"text-align: center;\">\r\n {{finalGrpVal[\"\"]?.length>0 ? finalGrpVal[\"\"]?.length : pkts?.length}}&nbsp;&nbsp;&nbsp;</td>\r\n <td style=\"text-align: center;\">\r\n <strong> Weight:&nbsp;</strong>\r\n </td>\r\n <td style=\"text-align: center;\"> {{totalWeight}}&nbsp;&nbsp;&nbsp;</td>\r\n <td style=\"text-align: center;\">\r\n <strong> Avg:&nbsp;</strong> </td>\r\n <td style=\"text-align: center;\"> {{totAvg}}&nbsp;&nbsp;&nbsp;</td>\r\n\r\n <td style=\"text-align: center;\" *ngIf=\"formname!='mixAnalysisReportForm'\">\r\n <strong> Dis:&nbsp;</strong> </td>\r\n <td style=\"text-align: center;\"> {{totDis}}&nbsp;&nbsp;&nbsp;</td>\r\n\r\n <td style=\"text-align: center;\">\r\n <strong> Amount:&nbsp;</strong> </td>\r\n <td style=\"text-align: center;\"> {{totAmt}}</td>\r\n\r\n <td style=\"text-align: center;\">\r\n <strong> &nbsp;&nbsp;&nbsp;| &nbsp;&nbsp;Selected Pkts : </strong> </td>\r\n <td style=\"text-align: center;\"> {{selectedItm?.length}}&nbsp;&nbsp;&nbsp;</td>\r\n\r\n <td style=\"text-align: center;\">\r\n <strong> Weight:&nbsp;</strong>\r\n </td>\r\n <td style=\"text-align: center;\"> {{selectwt}}&nbsp;&nbsp;&nbsp;</td>\r\n\r\n <td style=\"text-align: center;\">\r\n <strong> Avg:&nbsp;</strong>\r\n </td>\r\n <td style=\"text-align: center;\"> {{selectAvg}}&nbsp;&nbsp;&nbsp;</td>\r\n\r\n <td style=\"text-align: center;\" *ngIf=\"formname!='mixAnalysisReportForm'\">\r\n <strong> Disc:&nbsp;</strong>\r\n </td>\r\n <td style=\"text-align: center;\"> {{selectDis}}&nbsp;&nbsp;&nbsp;</td>\r\n <td style=\"text-align: center;\">\r\n <strong> Amount:&nbsp;</strong>\r\n </td>\r\n <td style=\"text-align: center;\"> {{selectAmt}}</td>\r\n\r\n </tr>\r\n </table>\r\n </div>\r\n\r\n <div>\r\n <button class=\"btn btn-success\" style=\"margin-right: 80px;\" (click)=\"modifySearch()\">Modify\r\n Search</button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n\r\n\r\n\r\n\r\n <div class=\"modal fade\" id=\"PiechartModel\" tabindex=\"-1\" role=\"dialog\" aria-labelledby=\"exampleModalLabel\"\r\n aria-hidden=\"true\">\r\n <div class=\"modal-dialog modal-lg\" role=\"document\" >\r\n <div class=\"modal-content\">\r\n <div class=\"modal-header\">\r\n <button type=\"button\" class=\"close\" data-dismiss=\"modal\" >\r\n <span aria-hidden=\"true\">&times;</span>\r\n <span class=\"sr-only\">Close</span>\r\n </button>\r\n <h4 class=\"modal-title\" id=\"mailModalHead\">Top {{type}} Pie Chart</h4>\r\n </div>\r\n <div class=\"modal-body\" >\r\n <div class=\"row\">\r\n <div class=\"col-md-3 pull-right\">\r\n <div class=\"form-group\">\r\n <button id=\"btnQty\" class=\"btn btn-default\" type=\"button\" (click)=\"generatePie(dataType,'qty')\">QTY </button>\r\n <button id=\"btnVal\" class=\"btn btn-default\" type=\"button\" (click)=\"generatePie(dataType,'value')\">VALUE </button>\r\n </div>\r\n </div>\r\n </div>\r\n \r\n\r\n <div class=\"card-footer row\" *ngIf=\"isBuyerwise\" >\r\n <label class=\"control-label\"><b>&nbsp;&nbsp; &nbsp;Total sold value:\r\n {{this.cs.splitToTwoDecimal(sttWiseSummary?.get('sold')?.get('rate'))}}</b></label>\r\n <canvas baseChart [data]=\"doughnutChartData\" [labels]=\"doughnutChartLabels\" [legend]=\"pieChartLegend\"\r\n [colors]=\"chartColors\" [chartType]=\"doughnutChartType\" [options]=\"pie\"></canvas>\r\n </div>\r\n \r\n \r\n\r\n <div class=\"card-footer row\" *ngIf=\"isGrpwise\" >\r\n <label class=\"control-label\"><b>&nbsp;&nbsp; &nbsp;Total sold value:\r\n {{this.cs.splitToTwoDecimal(sttWiseSummary?.get('sold')?.get('rate'))}}</b></label>\r\n <canvas baseChart [data]=\"doughnutChartData\" [labels]=\"doughnutChartLabels\" [legend]=\"pieChartLegend\"\r\n [chartType]=\"doughnutChartType\" [options]=\"pie\"></canvas>\r\n </div>\r\n \r\n\r\n <!-- <div class=\"card-footer row\" *ngIf=\"isQtyWise\">\r\n <label class=\"control-label\"><b>&nbsp;&nbsp; &nbsp;Total sold value:\r\n {{this.cs.splitToTwoDecimal(sttWiseSummary?.get('sold')?.get('count'))}}</b></label>\r\n <canvas baseChart [data]=\"doughnutChartData\" [labels]=\"doughnutChartLabels\" [legend]=\"pieChartLegend\"\r\n [chartType]=\"doughnutChartType\" [options]=\"pie\"></canvas>\r\n </div> -->\r\n\r\n </div>\r\n <div class=\"modal-footer\">\r\n <button type=\"button\" class=\"btn btn-secondary btn-sm\" data-dismiss=\"modal\">Close</button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"modal fade\" id=\"bidMd\" tabindex=\"-1\" style=\"z-index: 1400\" role=\"dialog\"\r\n aria-labelledby=\"exampleModalLabel\" aria-hidden=\"true\">\r\n <div class=\"modal-dialog\" role=\"document\">\r\n <form name=\"appForm\">\r\n <div class=\"modal-content\">\r\n <div class=\"modal-header\">\r\n <h5 class=\"modal-title text-uppercase\" id=\"exampleModalLabel\">\r\n Price Change</h5>\r\n <button type=\"button\" class=\"close\" data-dismiss=\"modal\" >\r\n <span aria-hidden=\"true\">&times;</span>\r\n <span class=\"sr-only\">Close</span>\r\n </button>\r\n </div>\r\n <div class=\"modal-body\">\r\n \r\n <div class=\"row\" style=\"padding:10px\">\r\n <div class=\"col-md-12\">\r\n <span style=\"font-size: 16px;font-weight:bold\">{{cObj?.pkt_code}} {{cObj?.sh}} {{cObj?.crtwt}} {{cObj?.co}} {{cObj?.pu}} {{cObj?.ct}} {{cObj?.po}} {{cObj?.sy}} {{cObj?.fl}}</span>\r\n \r\n\r\n </div>\r\n \r\n </div>\r\n <div class=\"row\" style=\"padding-left: 20px;padding-top: 3px\">\r\n <div class=\"col-md-2\">\r\n <label class=\"clbl\" > Rap: </label>\r\n </div>\r\n <div class=\"col-md-3\"><span class=\"clbl\">{{cObj?.benchmark_rte}}</span></div>\r\n <div class=\"col-md-7\">&nbsp;</div>\r\n </div>\r\n <div class=\"row\" style=\"padding-left: 20px;padding-top: 3px\">\r\n \r\n <div class=\"col-md-2\">\r\n <label class=\"clbl\" >Discount:</label>\r\n </div>\r\n <div class=\"col-md-3\">\r\n <span class=\"clbl\">{{cObj?.rap_dis}}</span>\r\n </div>\r\n <div class=\"col-md-5\" style=\"text-align: left;\">\r\n <input type=\"text\" (change)=\"calculatRteDis(cObj,'dis')\" style=\"width:100px\" class=\"form-control\" name=\"new_rap_dis\" [(ngModel)]=\"cObj['new_rap_dis']\" />\r\n\r\n </div>\r\n </div>\r\n <div class=\"row\" style=\"padding-left: 20px;padding-top: 3px\">\r\n <div class=\"col-md-2\">\r\n <label class=\"clbl\" style=\"text-align: right;\">Price:</label>\r\n </div>\r\n <div class=\"col-md-3\">\r\n <span class=\"clbl\">{{cObj?.rte}}</span>\r\n </div>\r\n <div class=\"col-md-5\">\r\n <input type=\"text\" (change)=\"calculatRteDis(cObj,'rte')\" style=\"width:100px\" class=\"form-control\" name=\"new_rte\" [(ngModel)]=\"cObj['new_rte']\" />\r\n\r\n </div>\r\n \r\n </div>\r\n \r\n </div>\r\n <div class=\"modal-footer\">\r\n <button type=\"button\" class=\"btn btn-default\" data-dismiss=\"modal\" >Close</button>\r\n <button type=\"button\" class=\"btn btn-success\" data-dismiss=\"modal\" appAppNoDblClick\r\n (click)=\"ChangesPrice()\">Update Price</button>\r\n </div>\r\n </div>\r\n </form>\r\n </div>\r\n</div> \r\n<button id=\"bidMdBBtn\" [hidden]=\"true\" data-toggle=\"modal\" data-target=\"#bidMd\"></button>\r\n\r\n <button id=\"PiechartModelBtn\" [hidden]=\"true\" data-toggle=\"modal\" data-target=\"#PiechartModel\"></button>\r\n\r\n\r\n</div>", styles: [".actionFooter{position:fixed;bottom:0;width:100%;text-align:right;padding:10px 10px 10px 0;background:#1b1e24}.calsec table{color:#fff}.selectedRow{background-color:#3c59983b!important}.notselectedRow{background-color:#fff!important}.legendsList{list-style:none;font-size:14px;padding:5px;display:flex;margin:0 0 0 80px}.formcontrol{height:30px;font-size:12px;line-height:18px;box-shadow:none;padding:5px 12px;border:1px solid #D5D5D5;background:#F9F9F9;background-color:#fff;background-image:none;border:1px solid #ccc;border-radius:4px;box-shadow:inset 0 1px 1px #00000013;transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s}\n"], components: [{ type: i6.SelectComponent, selector: "ng-select", inputs: ["options", "allowClear", "disabled", "multiple", "noFilter", "notFoundMsg", "placeholder", "filterPlaceholder", "label", "highlightColor", "highlightTextColor"], outputs: ["opened", "closed", "selected", "deselected", "focus", "blur", "noOptionsFound", "filterInputChanged"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i8.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i8.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i8.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i8.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i8.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { type: i8.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i8.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i7.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i9.InfiniteScrollDirective, selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }, { type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i10.BaseChartDirective, selector: "canvas[baseChart]", inputs: ["options", "data", "datasets", "labels", "chartType", "colors", "legend", "plugins"], outputs: ["chartClick", "chartHover"], exportAs: ["base-chart"] }, { type: i11.AppNoDblClickDirective, selector: "[appAppNoDblClick]" }], pipes: { "date": i7.DatePipe, "tableSearch": i12.TableSearchPipe } });
1100
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: PktDataComponent, decorators: [{
1101
+ type: Component,
1102
+ args: [{ selector: 'app-pkt-data', template: "<div class=\"mt\">\r\n <div class=\"panel panel-default\">\r\n <div class=\"panel-heading\">\r\n <h3 class=\"panel-title\">\r\n <span class=\"fa fa-chevron-left cp\" (click)=\"cs.pageBck();\"> Back</span>&nbsp;&nbsp;&nbsp; Packet List\r\n <span class=\"f-12\">({{cs.cDate | date: 'medium'}})</span>\r\n </h3>\r\n </div>\r\n </div>\r\n <div class=\"content-frame\">\r\n <div class=\"innerD\">\r\n <div class=\"content-frame-left\" *ngIf=\"false\">\r\n <div class=\"panel panel-default\">\r\n <div class=\"panel-body\">\r\n <!-- <div class=\"list-group border-bottom\">\r\n <a href=\"javascript:void(0)\" class=\"list-group-item\" [ngClass]=\"{'active' :i == cLink}\" *ngFor=\"let nav of navigation;let i=index\"\r\n (click)=\"navigationFun(nav,i);\">{{nav.form_field_title}} </a>\r\n </div> -->\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"content-frame-body\" style=\"margin-left:0\">\r\n <div class=\"panel panel-default custom-panel\">\r\n <div class=\"panel-body\" style=\"padding:0;\">\r\n <div class=\"infoSec\">\r\n <div class=\"row\">\r\n <div class=\"col-sm-6\">\r\n <form class=\"form-inline pull-left\">\r\n </form>\r\n </div>\r\n <div class=\"col-sm-6\">\r\n <div class=\"dropdown text-right\">\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-4\">\r\n <div class=\"\" style=\"margin-bottom: 10px;\">\r\n <table class=\"displayTable\">\r\n <thead>\r\n <tr>\r\n <th>Status</th>\r\n <th>Count</th>\r\n <th>Cts</th>\r\n <th>Avg</th>\r\n <th *ngIf=\"formname!='mixAnalysisReportForm'\">Disc</th>\r\n <th>Amount</th>\r\n\r\n </thead>\r\n <tbody>\r\n <ng-container *ngFor=\"let st of anaAllGrpStt;let i = index;\">\r\n <tr>\r\n <td>\r\n <!-- <label for=\"{{st}}\" class=\"text-capitalize\">S</label> -->\r\n <!-- *ngIf=\"defaultGrpList.length==0\" -->\r\n <input *ngIf=\"defaultGrpList.length==0\" type=\"checkbox\" id=\"{{st}}\" value=\"{{st}}\"\r\n name=\"{{st}}\" [(ngModel)]=\"stObj[st]\" [checked]=\"true\"\r\n (change)=\"statusWiseDisplay($event,stObj)\" />\r\n {{anaSttLbl[i]||st}}\r\n </td>\r\n <!-- anaSttLbl -->\r\n <td> {{sttWiseSummary?.get(st)?.get('count')}}</td>\r\n <td> {{this.cs.splitToTwoDecimal(sttWiseSummary?.get(st)?.get('wt'))}}</td>\r\n <td> {{this.cs.splitToTwoDecimal(sttWiseSummary?.get(st)?.get('avg'))}}</td>\r\n <td *ngIf=\"formname!='mixAnalysisReportForm'\"> {{this.cs.splitToTwoDecimal(sttWiseSummary?.get(st)?.get('disc'))}}</td>\r\n <td> {{this.cs.splitToTwoDecimal(sttWiseSummary?.get(st)?.get('rate'))}}</td>\r\n\r\n </tr>\r\n </ng-container>\r\n </tbody>\r\n </table>\r\n </div>\r\n </div>\r\n\r\n \r\n \r\n <div class=\"col-md-3\">\r\n <div class=\"form-group w-100\">\r\n <div class=\"col-md-5\">\r\n \r\n <select class=\"formcontrol\" name=\"viewdisType\" (change)=\"onGrpSelect(defaultGrpList)\" [(ngModel)]=\"viewdisType\">\r\n <option value=\"group\">Group By</option>\r\n <option value=\"summary\">Summary By</option>\r\n \r\n </select>\r\n </div>\r\n <div class=\"col-md-7\">\r\n <div class=\"input-group w-100\">\r\n <ng-select placeholder=\"Select Group\" [options]=\"staticLov\" [(ngModel)]=\"defaultGrpList\"\r\n name=\"status\" [multiple]=\"true\" [allowClear]=\"true\" (selected)=\"onGrpSelect(defaultGrpList)\"\r\n (deselected)=\"onGrpSelect(defaultGrpList)\">\r\n <ng-template #optionTemplate let-option=\"option\">\r\n <div class=\"famfamfam-flags {{option?.value.toLowerCase()}}\"></div>\r\n {{option?.label}}\r\n </ng-template>\r\n </ng-select>\r\n </div>\r\n\r\n </div>\r\n\r\n </div>\r\n <p>\r\n <b>Buyer Pie chart</b>\r\n <i title=\"Buyer wise pie chart\"\r\n style=\"cursor: pointer;padding: 5px;margin-left: 10px; text-align: center;font-size: 20px;color: #3a5898;\"\r\n type=\"button\" class=\"fa fa-pie-chart\" aria-hidden=\"true\" data-toggle=\"modal\"\r\n data-target=\"#PiechartModel\" (click)=\"generatePie('buyer','value')\"></i>\r\n </p>\r\n </div>\r\n\r\n \r\n <div class=\"col-md-2\">\r\n <p *ngIf=\"defaultGrpList.length>0\">\r\n <i title=\"Group wise chart\"\r\n style=\"cursor: pointer;padding: 5px;margin-left: 10px; text-align: center;font-size: 20px;color: #3a5898;\"\r\n type=\"button\" class=\"fa fa-pie-chart\" aria-hidden=\"true\" data-toggle=\"modal\"\r\n data-target=\"#PiechartModel\" (click)=\"generatePie('group','value')\"></i>\r\n </p>\r\n <ul class=\"cul\">\r\n <li *ngFor=\"let legend of legendList\">\r\n <p\r\n [ngStyle]=\"{'background-color': legend.k ,'height':'9px', 'width':'9px', 'margin': '0', 'display' : 'inline-block'}\">\r\n </p>\r\n {{legend.v}}\r\n </li>\r\n </ul>\r\n </div>\r\n <div class=\"col-md-3 pull-right\">\r\n <form class=\"form-inline pull-right\">\r\n <div class=\"form-group\">\r\n <label for=\"exampleInputName2\">Search &nbsp;&nbsp;</label>\r\n <input type=\"text\" class=\"form-control\" id=\"exampleInputName2\" name=\"schtxt\" [(ngModel)]=\"searchF\" />\r\n </div>\r\n <button class=\"btn btn-default\" style=\"padding: 4px 15px 4px 20px;margin-left: 10px;float: right;\"\r\n data-toggle=\"tooltip\" data-placement=\"left\" title=\"Download Excel\"\r\n (click)=\"exportToCSV('Packet list');\">\r\n <span class=\"fa fa-file-excel-o\" style=\"color:green;\"></span>\r\n </button>\r\n\r\n </form>\r\n </div>\r\n\r\n </div>\r\n \r\n \r\n\r\n <!-- <div class=\"col-md-2\">\r\n <div class=\"form-group\">\r\n <button class=\"btn btn-success\" style=\"margin-left: 5px;\" (click)=\"modifySearch()\">Modify\r\n Search</button>\r\n </div>\r\n <ul class=\"cul\">\r\n <li *ngFor=\"let legend of legendList\">\r\n <p\r\n [ngStyle]=\"{'background-color': legend.k ,'height':'9px', 'width':'9px', 'margin': '0', 'display' : 'inline-block'}\">\r\n </p>\r\n {{legend.v}}\r\n </li>\r\n </ul> \r\n </div>\r\n </div>\r\n -->\r\n <div class=\"row\">\r\n <ng-container *ngIf=\"viewdisType=='group'\">\r\n <div *ngIf=\"groupBypktList.length >0\" class=\"table-responsive\" id=\"wrap\" style=\"overflow: auto;width: 100%;height: calc(100vh - 250px);\"\r\n infinite-scroll [infiniteScrollDistance]=\"scrollDistance\" [infiniteScrollUpDistance]=\"scrollUpDistance\"\r\n [infiniteScrollThrottle]=\"50\" (scrolled)=\"grouponScrollDown()\" [scrollWindow]=\"false\">\r\n <table class=\"displayTable\">\r\n <thead>\r\n <tr class=\"posrel\">\r\n <th class=\"cTh\" style=\"width:75px;\" *ngIf=\"formname!='mixAnalysisReportForm'\">\r\n DNA</th>\r\n <th style=\"text-align: center;\">Status</th>\r\n <th (click)=\"sortBy(hrdKey,g)\" style=\"text-align: center;\" *ngFor=\"let hrdKey of headerKey\">\r\n {{header[hrdKey]}}\r\n \r\n </th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n \r\n <ng-container *ngFor=\"let groupdtl of loadgroupBypktList let j=index;\">\r\n <tr>\r\n <td [attr.colspan]=\"headerKey.length+1\" style=\"font-weight:bold;text-align: left; \">\r\n {{groupdtl.value}} &nbsp; &nbsp;\r\n Qty : {{groupdtl['count']}} &nbsp; &nbsp; Carats :\r\n {{groupdtl['crtwt']}}\r\n &nbsp; &nbsp; Avg :{{groupdtl['salavg']}}\r\n &nbsp; &nbsp; Dis% : {{groupdtl['saldis']}}\r\n\r\n &nbsp;&nbsp; Amount : {{groupdtl['salvlu']}} \r\n </td>\r\n </tr> \r\n <!-- <tr *ngIf=\"sttwise\" >\r\n <td [attr.colspan]=\"headerKey.length+1\" style=\"font-weight:bold;text-align: left; \">\r\n {{g}} &nbsp; &nbsp;\r\n Qty : {{finalGrpVal[g].length}} &nbsp; &nbsp; Carats :\r\n {{totalWeight}}\r\n\r\n &nbsp;&nbsp; Amount :{{totAmt}}\r\n </td>\r\n </tr> -->\r\n\r\n\r\n\r\n <tr *ngFor=\"let pktdtl of groupdtl['pktList'] | tableSearch:searchF:pkts;let pkti = index\"\r\n [ngClass]=\"{'even':pkti%2==0,'odd':pkti%2==1}\">\r\n <td style=\"width:75px;position: relative;\" *ngIf=\"formname!='mixAnalysisReportForm'\">\r\n <a href=\"https://kapugems.com/kweb/#/dna/{{pktdtl.stock_idn}}/?key={{ck}}\" target=\"_blank\">\r\n <i class=\"fa fa-diamond\" aria-hidden=\"true\"></i>\r\n </a>\r\n <input type=\"checkbox\" value=\"{{pktdtl.stock_idn}}\" [hidden]=\"true\" id=\"cb_{{pktdtl.stock_idn}}\"\r\n (click)=\"checkedRow(pktdtl,pktdtl.stock_idn,$event.target.checked)\">\r\n </td>\r\n <td style=\"text-align: center;\" [ngStyle]=\"{'color': pktdtl.dsp_stt}\">{{pktdtl.dsp_stt}}</td>\r\n <ng-container *ngFor=\"let hrdKey of headerKey\">\r\n <td *ngIf=\"hrdKey!='co' && hrdKey!='pu'\" style=\"text-align: center\" (click)=\"selectRow(pktdtl.stock_idn);\"\r\n [ngStyle]=\"{'color': pktdtl.dsp_stt_color == '#FFFFFF' ? 'black':pktdtl.dsp_stt_color}\">\r\n {{pktdtl[hrdKey]}}</td>\r\n\r\n <td style=\"text-align: center\" *ngIf=\"hrdKey=='co'\" (click)=\"selectRow(pktdtl.stock_idn);\"\r\n [ngStyle]=\"{'color': pktdtl.dsp_stt_color == '#FFFFFF' ? 'black':pktdtl.dsp_stt_color}\">\r\n {{pktdtl[hrdKey+\"_p\"]}}</td>\r\n\r\n\r\n\r\n <td style=\"text-align: center\" *ngIf=\"hrdKey=='pu'\" (click)=\"selectRow(pktdtl.stock_idn);\"\r\n [ngStyle]=\"{'color': pktdtl.dsp_stt_color == '#FFFFFF' ? 'black':pktdtl.dsp_stt_color}\">\r\n {{pktdtl[hrdKey+\"_p\"]}}</td>\r\n </ng-container>\r\n </tr>\r\n </ng-container>\r\n </tbody>\r\n </table>\r\n </div>\r\n\r\n\r\n \r\n \r\n <div *ngIf=\"pkts.length > 0 && groupBypktList.length==0 \" class=\"table-responsive\" id=\"wrap\" style=\"overflow: auto;width: 100%;height: calc(100vh - 250px);\"\r\n infinite-scroll [infiniteScrollDistance]=\"scrollDistance\" [infiniteScrollUpDistance]=\"scrollUpDistance\"\r\n [infiniteScrollThrottle]=\"50\" (scrolled)=\"onScrollDown()\" [scrollWindow]=\"false\">\r\n <table class=\"displayTable\">\r\n <thead>\r\n <tr class=\"posrel\">\r\n <th class=\"cTh\" style=\"width:75px;\" *ngIf=\"formname!='mixAnalysisReportForm'\">\r\n DNA</th>\r\n <th> \r\n Actions\r\n </th>\r\n <th style=\"text-align: center;\">Status</th>\r\n <th style=\"text-align: center;\" *ngFor=\"let hrdKey of headerKey\">{{header[hrdKey]}}</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr>\r\n <td></td>\r\n <td></td>\r\n <td><b>Average </b></td>\r\n <ng-container *ngFor=\"let hrdKey of headerKey\">\r\n <td>\r\n <b>{{cs.splitToTwoDecimal(TotAvgObj[hrdKey])}}</b>\r\n </td>\r\n \r\n </ng-container>\r\n \r\n </tr>\r\n <tr *ngFor=\"let pktdtl of loadResult | tableSearch:searchF:pkts;let pkti = index\"\r\n [ngClass]=\"{'even':pkti%2==0,'odd':pkti%2==1}\">\r\n <td style=\"width:75px;position: relative;\" *ngIf=\"formname!='mixAnalysisReportForm'\">\r\n <a href=\"https://kapugems.com/kweb/#/dna/{{pktdtl.stock_idn}}/?key={{ck}}\" target=\"_blank\">\r\n <i class=\"fa fa-diamond\" aria-hidden=\"true\"></i>\r\n </a>\r\n <input type=\"checkbox\" value=\"{{pktdtl.stock_idn}}\" [hidden]=\"true\" id=\"cb_{{pktdtl.stock_idn}}\"\r\n (click)=\"checkedRow(pktdtl,pktdtl.stock_idn,$event.target.checked)\">\r\n </td>\r\n <td> \r\n <ng-container *ngFor=\"let lnk of links\">\r\n <i class=\"{{lnk.form_field_icon}}\" *ngIf=\"pktdtl.dsp_stt!='sold'\" (click)=\"OnLinkClick(lnk,pktdtl)\" aria-hidden=\"true\"></i>\r\n &nbsp;\r\n </ng-container>\r\n \r\n </td>\r\n\r\n <td style=\"text-align: center;\" [ngStyle]=\"{'color': pktdtl.dsp_stt}\">{{pktdtl.dsp_stt}}</td>\r\n <ng-container *ngFor=\"let hrdKey of headerKey\">\r\n <td *ngIf=\"hrdKey!='co' && hrdKey!='pu'\" style=\"text-align: center\" (click)=\"selectRow(pktdtl.stock_idn);\"\r\n [ngStyle]=\"{'color': pktdtl.dsp_stt_color == '#FFFFFF' ? 'black':pktdtl.dsp_stt_color}\">\r\n {{pktdtl[hrdKey]}}</td>\r\n\r\n <td style=\"text-align: center\" *ngIf=\"hrdKey=='co'\" (click)=\"selectRow(pktdtl.stock_idn);\"\r\n [ngStyle]=\"{'color': pktdtl.dsp_stt_color == '#FFFFFF' ? 'black':pktdtl.dsp_stt_color}\">\r\n {{pktdtl[hrdKey+\"_p\"]}}</td>\r\n\r\n\r\n <td style=\"text-align: center\" *ngIf=\"hrdKey=='pu'\" (click)=\"selectRow(pktdtl.stock_idn);\"\r\n [ngStyle]=\"{'color': pktdtl.dsp_stt_color == '#FFFFFF' ? 'black':pktdtl.dsp_stt_color}\">\r\n {{pktdtl[hrdKey+\"_p\"]}}</td>\r\n </ng-container>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"viewdisType=='summary' && summaryList.length>0\">\r\n <div class=\"row\">\r\n <div class=\"col-md-12\"> <button class=\"btn btn-default\"\r\n style=\"padding: 4px 15px 4px 20px;margin-left: 10px;\" data-toggle=\"tooltip\" data-placement=\"right\"\r\n title=\"Download Excel\" (click)=\"exportToCSVSummary();\">\r\n <span class=\"fa fa-file-excel-o\" style=\"color:green;\"></span>\r\n </button></div>\r\n </div>\r\n <div class=\"row\">\r\n <table class=\"displayTable\" style=\"text-align: center;padding:10px ;\">\r\n <thead>\r\n <tr class=\"posrel\">\r\n <th style=\"text-align: center;\">Sr. No</th>\r\n <th style=\"text-align: center;\">Attribute</th>\r\n <ng-container *ngFor=\"let hdr of headList\">\r\n <th style=\"text-align: center;\" colspan=\"5\">{{hdr}}</th>\r\n </ng-container>\r\n </tr>\r\n <tr class=\"posrel\">\r\n <td style=\"text-align: center;\"></td>\r\n <ng-container *ngFor=\"let hdr of headList\">\r\n <td style=\"text-align: center;\">Qty</td>\r\n <td style=\"text-align: center;\">Carat</td>\r\n <td style=\"text-align: center;\">Avg</td>\r\n <td style=\"text-align: center;\" *ngIf=\"formname!='mixAnalysisReportForm'\">Dis</td>\r\n <td style=\"text-align: center;\">Value</td>\r\n </ng-container>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let summaryDtl of summaryList | tableSearch:searchF:pkts;let pkti = index\"\r\n [ngClass]=\"{'even':pkti%2==0,'odd':pkti%2==1}\">\r\n <td style=\"text-align: center;\">{{pkti+1}}</td>\r\n <td style=\"text-align: center;\">{{summaryDtl['value']}}</td>\r\n <ng-container *ngFor=\"let hdr of headList\">\r\n <td style=\"text-align: center;\">{{summaryDtl['count_'+hdr]}}</td>\r\n <td style=\"text-align: center;\">{{summaryDtl['crtwt_'+hdr]}}</td>\r\n <td style=\"text-align: center;\">{{summaryDtl['avg_'+hdr]}}</td>\r\n <td style=\"text-align: center;\" *ngIf=\"formname!='mixAnalysisReportForm'\">{{summaryDtl['dis_'+hdr]}}</td>\r\n <td style=\"text-align: center;\">{{summaryDtl['vlu_'+hdr]}}</td>\r\n </ng-container>\r\n </tr> \r\n\r\n </tbody>\r\n </table>\r\n </div>\r\n </ng-container>\r\n</div>\r\n\r\n \r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"actionFooter\">\r\n <div class=\"row\">\r\n <div class=\"calsec pull-left\" style=\"padding: 5px;\">\r\n <table>\r\n <tr>\r\n <td style=\"text-align: center;\">\r\n <strong> Total: &nbsp; </strong>\r\n </td>\r\n <td style=\"text-align: center;\">\r\n {{finalGrpVal[\"\"]?.length>0 ? finalGrpVal[\"\"]?.length : pkts?.length}}&nbsp;&nbsp;&nbsp;</td>\r\n <td style=\"text-align: center;\">\r\n <strong> Weight:&nbsp;</strong>\r\n </td>\r\n <td style=\"text-align: center;\"> {{totalWeight}}&nbsp;&nbsp;&nbsp;</td>\r\n <td style=\"text-align: center;\">\r\n <strong> Avg:&nbsp;</strong> </td>\r\n <td style=\"text-align: center;\"> {{totAvg}}&nbsp;&nbsp;&nbsp;</td>\r\n\r\n <td style=\"text-align: center;\" *ngIf=\"formname!='mixAnalysisReportForm'\">\r\n <strong> Dis:&nbsp;</strong> </td>\r\n <td style=\"text-align: center;\"> {{totDis}}&nbsp;&nbsp;&nbsp;</td>\r\n\r\n <td style=\"text-align: center;\">\r\n <strong> Amount:&nbsp;</strong> </td>\r\n <td style=\"text-align: center;\"> {{totAmt}}</td>\r\n\r\n <td style=\"text-align: center;\">\r\n <strong> &nbsp;&nbsp;&nbsp;| &nbsp;&nbsp;Selected Pkts : </strong> </td>\r\n <td style=\"text-align: center;\"> {{selectedItm?.length}}&nbsp;&nbsp;&nbsp;</td>\r\n\r\n <td style=\"text-align: center;\">\r\n <strong> Weight:&nbsp;</strong>\r\n </td>\r\n <td style=\"text-align: center;\"> {{selectwt}}&nbsp;&nbsp;&nbsp;</td>\r\n\r\n <td style=\"text-align: center;\">\r\n <strong> Avg:&nbsp;</strong>\r\n </td>\r\n <td style=\"text-align: center;\"> {{selectAvg}}&nbsp;&nbsp;&nbsp;</td>\r\n\r\n <td style=\"text-align: center;\" *ngIf=\"formname!='mixAnalysisReportForm'\">\r\n <strong> Disc:&nbsp;</strong>\r\n </td>\r\n <td style=\"text-align: center;\"> {{selectDis}}&nbsp;&nbsp;&nbsp;</td>\r\n <td style=\"text-align: center;\">\r\n <strong> Amount:&nbsp;</strong>\r\n </td>\r\n <td style=\"text-align: center;\"> {{selectAmt}}</td>\r\n\r\n </tr>\r\n </table>\r\n </div>\r\n\r\n <div>\r\n <button class=\"btn btn-success\" style=\"margin-right: 80px;\" (click)=\"modifySearch()\">Modify\r\n Search</button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n\r\n\r\n\r\n\r\n <div class=\"modal fade\" id=\"PiechartModel\" tabindex=\"-1\" role=\"dialog\" aria-labelledby=\"exampleModalLabel\"\r\n aria-hidden=\"true\">\r\n <div class=\"modal-dialog modal-lg\" role=\"document\" >\r\n <div class=\"modal-content\">\r\n <div class=\"modal-header\">\r\n <button type=\"button\" class=\"close\" data-dismiss=\"modal\" >\r\n <span aria-hidden=\"true\">&times;</span>\r\n <span class=\"sr-only\">Close</span>\r\n </button>\r\n <h4 class=\"modal-title\" id=\"mailModalHead\">Top {{type}} Pie Chart</h4>\r\n </div>\r\n <div class=\"modal-body\" >\r\n <div class=\"row\">\r\n <div class=\"col-md-3 pull-right\">\r\n <div class=\"form-group\">\r\n <button id=\"btnQty\" class=\"btn btn-default\" type=\"button\" (click)=\"generatePie(dataType,'qty')\">QTY </button>\r\n <button id=\"btnVal\" class=\"btn btn-default\" type=\"button\" (click)=\"generatePie(dataType,'value')\">VALUE </button>\r\n </div>\r\n </div>\r\n </div>\r\n \r\n\r\n <div class=\"card-footer row\" *ngIf=\"isBuyerwise\" >\r\n <label class=\"control-label\"><b>&nbsp;&nbsp; &nbsp;Total sold value:\r\n {{this.cs.splitToTwoDecimal(sttWiseSummary?.get('sold')?.get('rate'))}}</b></label>\r\n <canvas baseChart [data]=\"doughnutChartData\" [labels]=\"doughnutChartLabels\" [legend]=\"pieChartLegend\"\r\n [colors]=\"chartColors\" [chartType]=\"doughnutChartType\" [options]=\"pie\"></canvas>\r\n </div>\r\n \r\n \r\n\r\n <div class=\"card-footer row\" *ngIf=\"isGrpwise\" >\r\n <label class=\"control-label\"><b>&nbsp;&nbsp; &nbsp;Total sold value:\r\n {{this.cs.splitToTwoDecimal(sttWiseSummary?.get('sold')?.get('rate'))}}</b></label>\r\n <canvas baseChart [data]=\"doughnutChartData\" [labels]=\"doughnutChartLabels\" [legend]=\"pieChartLegend\"\r\n [chartType]=\"doughnutChartType\" [options]=\"pie\"></canvas>\r\n </div>\r\n \r\n\r\n <!-- <div class=\"card-footer row\" *ngIf=\"isQtyWise\">\r\n <label class=\"control-label\"><b>&nbsp;&nbsp; &nbsp;Total sold value:\r\n {{this.cs.splitToTwoDecimal(sttWiseSummary?.get('sold')?.get('count'))}}</b></label>\r\n <canvas baseChart [data]=\"doughnutChartData\" [labels]=\"doughnutChartLabels\" [legend]=\"pieChartLegend\"\r\n [chartType]=\"doughnutChartType\" [options]=\"pie\"></canvas>\r\n </div> -->\r\n\r\n </div>\r\n <div class=\"modal-footer\">\r\n <button type=\"button\" class=\"btn btn-secondary btn-sm\" data-dismiss=\"modal\">Close</button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"modal fade\" id=\"bidMd\" tabindex=\"-1\" style=\"z-index: 1400\" role=\"dialog\"\r\n aria-labelledby=\"exampleModalLabel\" aria-hidden=\"true\">\r\n <div class=\"modal-dialog\" role=\"document\">\r\n <form name=\"appForm\">\r\n <div class=\"modal-content\">\r\n <div class=\"modal-header\">\r\n <h5 class=\"modal-title text-uppercase\" id=\"exampleModalLabel\">\r\n Price Change</h5>\r\n <button type=\"button\" class=\"close\" data-dismiss=\"modal\" >\r\n <span aria-hidden=\"true\">&times;</span>\r\n <span class=\"sr-only\">Close</span>\r\n </button>\r\n </div>\r\n <div class=\"modal-body\">\r\n \r\n <div class=\"row\" style=\"padding:10px\">\r\n <div class=\"col-md-12\">\r\n <span style=\"font-size: 16px;font-weight:bold\">{{cObj?.pkt_code}} {{cObj?.sh}} {{cObj?.crtwt}} {{cObj?.co}} {{cObj?.pu}} {{cObj?.ct}} {{cObj?.po}} {{cObj?.sy}} {{cObj?.fl}}</span>\r\n \r\n\r\n </div>\r\n \r\n </div>\r\n <div class=\"row\" style=\"padding-left: 20px;padding-top: 3px\">\r\n <div class=\"col-md-2\">\r\n <label class=\"clbl\" > Rap: </label>\r\n </div>\r\n <div class=\"col-md-3\"><span class=\"clbl\">{{cObj?.benchmark_rte}}</span></div>\r\n <div class=\"col-md-7\">&nbsp;</div>\r\n </div>\r\n <div class=\"row\" style=\"padding-left: 20px;padding-top: 3px\">\r\n \r\n <div class=\"col-md-2\">\r\n <label class=\"clbl\" >Discount:</label>\r\n </div>\r\n <div class=\"col-md-3\">\r\n <span class=\"clbl\">{{cObj?.rap_dis}}</span>\r\n </div>\r\n <div class=\"col-md-5\" style=\"text-align: left;\">\r\n <input type=\"text\" (change)=\"calculatRteDis(cObj,'dis')\" style=\"width:100px\" class=\"form-control\" name=\"new_rap_dis\" [(ngModel)]=\"cObj['new_rap_dis']\" />\r\n\r\n </div>\r\n </div>\r\n <div class=\"row\" style=\"padding-left: 20px;padding-top: 3px\">\r\n <div class=\"col-md-2\">\r\n <label class=\"clbl\" style=\"text-align: right;\">Price:</label>\r\n </div>\r\n <div class=\"col-md-3\">\r\n <span class=\"clbl\">{{cObj?.rte}}</span>\r\n </div>\r\n <div class=\"col-md-5\">\r\n <input type=\"text\" (change)=\"calculatRteDis(cObj,'rte')\" style=\"width:100px\" class=\"form-control\" name=\"new_rte\" [(ngModel)]=\"cObj['new_rte']\" />\r\n\r\n </div>\r\n \r\n </div>\r\n \r\n </div>\r\n <div class=\"modal-footer\">\r\n <button type=\"button\" class=\"btn btn-default\" data-dismiss=\"modal\" >Close</button>\r\n <button type=\"button\" class=\"btn btn-success\" data-dismiss=\"modal\" appAppNoDblClick\r\n (click)=\"ChangesPrice()\">Update Price</button>\r\n </div>\r\n </div>\r\n </form>\r\n </div>\r\n</div> \r\n<button id=\"bidMdBBtn\" [hidden]=\"true\" data-toggle=\"modal\" data-target=\"#bidMd\"></button>\r\n\r\n <button id=\"PiechartModelBtn\" [hidden]=\"true\" data-toggle=\"modal\" data-target=\"#PiechartModel\"></button>\r\n\r\n\r\n</div>", styles: [".actionFooter{position:fixed;bottom:0;width:100%;text-align:right;padding:10px 10px 10px 0;background:#1b1e24}.calsec table{color:#fff}.selectedRow{background-color:#3c59983b!important}.notselectedRow{background-color:#fff!important}.legendsList{list-style:none;font-size:14px;padding:5px;display:flex;margin:0 0 0 80px}.formcontrol{height:30px;font-size:12px;line-height:18px;box-shadow:none;padding:5px 12px;border:1px solid #D5D5D5;background:#F9F9F9;background-color:#fff;background-image:none;border:1px solid #ccc;border-radius:4px;box-shadow:inset 0 1px 1px #00000013;transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s}\n"] }]
1103
+ }], ctorParameters: function () { return [{ type: i1.CommanServiceService }, { type: i2.BiService }, { type: i3.NgxSpinnerService }, { type: i4.ToastrService }, { type: i5.Router }, { type: i5.ActivatedRoute }]; }, propDecorators: { chart: [{
1104
+ type: ViewChild,
1105
+ args: [BaseChartDirective]
1106
+ }] } });
1107
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pkt-data.component.js","sourceRoot":"","sources":["../../../../../projects/ezlib/src/lib/pkt-data/pkt-data.component.ts","../../../../../projects/ezlib/src/lib/pkt-data/pkt-data.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ToastrService } from 'ngx-toastr';\r\nimport { NgxSpinnerService } from \"ngx-spinner\";\r\nimport { BiService } from './../bi-service/bi.service';\r\nimport { CommanServiceService } from '../comman-service/comman-service.service';\r\nimport { Component, OnInit, ViewChild } from '@angular/core';\r\nimport { Router, ActivatedRoute } from '@angular/router';\r\nimport { Cookie } from 'ng2-cookies/ng2-cookies';\r\nimport * as _ from 'lodash';\r\nimport { BaseChartDirective } from 'ng2-charts';\r\nimport * as pluginDataLabels from 'chartjs-plugin-labels';\r\nimport { HttpHeaders  } from '@angular/common/http';\r\n// import * as Rx from 'rxjs/Rx';\r\nimport { Observable, from } from 'rxjs';\r\nimport { groupBy , toArray, map, mergeMap } from 'rxjs/operators';\r\n// import { sumBy } from 'lodash';\r\n\r\n@Component({\r\n  selector: 'app-pkt-data',\r\n  templateUrl: './pkt-data.component.html',\r\n  styleUrls: ['./pkt-data.component.css']\r\n})\r\nexport class PktDataComponent implements OnInit {\r\n\r\n  pkts = [];\r\n  headerKey = [];\r\n  header = [];\r\n  ck;\r\n  totalWeight = 0;\r\n  reqheader;\r\n  scrollDistance = 1;\r\n  scrollUpDistance = 2;\r\n  startIndex = 0;\r\n  endIndex = 30;\r\n  groupstartIndex = 0;\r\n  groupendIndex = 30;\r\n  loadResult = [];\r\n  resultlength = 0;\r\n  totAvg = 0;\r\n  totDis = 0;\r\n  selectedItm = [];\r\n  selectwt = 0;\r\n  selectAvg = 0;\r\n  selectDis = 0;\r\n  selectAmt = 0;\r\n  searchF;\r\n  dropdownSettings;\r\n  sttWiseSummary = new Map();\r\n  // anaAllGrpStt = ['asrt', 'lab', 'mkt', 'sold'];\r\n  anaAllGrpStt = [];\r\n  g;\r\n\r\n  legendList = [];\r\n  newwindow = \"YES\";\r\n  pageDefination;\r\n  sorted;\r\n  sortOn;\r\n  clmn;\r\n  staticLov = [];\r\n  defaultGrpList = [];\r\n  stObj = {};\r\n  totAmt = 0;\r\n  nodata = true;\r\n  viewdisType = \"group\";\r\n  summaryList = [];\r\n  coPuattributeStr = [];\r\n  formname;\r\n  modulename;\r\n  cUrl;\r\n  links;\r\n  cObj;\r\n  groupBypktList = [];\r\n  loadgroupBypktList = [];\r\n\r\n\r\n  @ViewChild(BaseChartDirective)\r\n  public chart: BaseChartDirective;\r\n\r\n  constructor(\r\n    public cs: CommanServiceService,\r\n    private bis: BiService,\r\n    private _spinnerService: NgxSpinnerService ,\r\n    private toastr: ToastrService,\r\n    private router: Router,\r\n    private route: ActivatedRoute\r\n  ) { }\r\n\r\n  lpad(lStr, ln) {\r\n    let str = lStr;\r\n    while (str.length < ln) { str = '0' + str; }\r\n    return str;\r\n  }\r\n\r\n  getSearchResult() {\r\n    this.cObj = {};\r\n    this.groupBypktList = [];\r\n    this._spinnerService.show();\r\n    this.pkts = [];\r\n    this.grp = [];\r\n    this.headerKey = [];\r\n    this.legendList = [];\r\n    this.viewdisType = \"group\";\r\n    let reqObj = {};\r\n    this.formname = this.route.snapshot.params['frmnme'];\r\n    reqObj['searchIdnList'] = localStorage.getItem('srcIdns').split(',');\r\n    reqObj['formNme'] = this.route.snapshot.params['frmnme'];\r\n    console.log(JSON.stringify(reqObj));\r\n    this.startIndex = 0;\r\n    this.endIndex = 30;\r\n    this.loadResult = [];\r\n    this.bis.data(reqObj, 'search', 'marketing/search')\r\n      .subscribe(data => {\r\n        if (data.status == 'SUCCESS') {\r\n          let res = data.result;\r\n          console.log(\"res\", res);\r\n          this.pageDefination = res.pageDefination || {};\r\n          this.links = this.pageDefination.link || [];\r\n          this.pkts = res.searchResultDtl || [];\r\n          this.anaAllGrpStt = Array.from(new Set(this.pkts.map(element => element.dsp_stt)));\r\n          this.resultlength = this.pkts.length;\r\n          this.coPuattributeStr = res.copuStructureDtl || [];\r\n          this.headerKey = res.resultView;\r\n          this.header = res.resultViewDtl;\r\n          this.legendList = res.legendList;\r\n          this.totalWeight = this.cs.splitToTwoDecimal(this.pkts.reduce((a, b) => +a + +parseFloat(b.crtwt), 0));\r\n          let rapVal = this.cs.splitToTwoDecimal(this.pkts.reduce((a, b) => +a + +parseFloat(b.rap_vlu), 0));\r\n          let totAmt = 0;\r\n          this.pkts.forEach(element => {\r\n            if (element.grp_stt == 'sold') {\r\n              totAmt += parseFloat(element['sal_rte']) * parseFloat(element['crtwt']);\r\n            }\r\n            else {\r\n              totAmt += parseFloat(element['rte']) * parseFloat(element['crtwt']);\r\n            }\r\n          });\r\n\r\n          this.totAmt = this.cs.splitToTwoDecimal(totAmt);\r\n          this.totAvg = this.cs.splitToTwoDecimal(this.totAmt / this.totalWeight);\r\n          this.totDis = this.cs.splitToTwoDecimal(((totAmt * 100) / parseFloat(rapVal)) - 100);\r\n          if (this.endIndex > this.resultlength)\r\n            this.endIndex = this.resultlength\r\n          this.addItems();\r\n          debugger\r\n          //   this.totAvg = this.cs.splitToTwoDecimal(totAmt / parseFloat(totweight));\r\n          //  this.totDis = this.cs.splitToTwoDecimal(((totAmt * 100) / parseFloat(totrapVal)) - 100);\r\n          this.getSummary(this.pkts);\r\n          // this.createGrp(this.pkts, this.defaultGrpList);\r\n          // localStorage.setItem('BI-PKT_GROUP_BY',JSON.stringify(res.pageDefination.form_field[0].lov_qry))\r\n          // let GRPby = JSON.parse(localStorage.getItem('BI-PKT_GROUP_BY'));\r\n          this.getStaticKV(res.pageDefination.form_field[0].lov_qry);\r\n          let avgFields = res.pageDefination.tabs[0].lov_qry.split(',');\r\n          this.getTotals(avgFields, this.pkts);\r\n          let ttlFields = res.pageDefination.others[0].lov_qry.split(',');\r\n          this.getTotalsTtl(ttlFields, this.pkts);\r\n\r\n\r\n\r\n          this._spinnerService.hide();\r\n\r\n        } else {\r\n          this._spinnerService.hide();\r\n          this.toastr.error(data.message);\r\n        }\r\n      }, error => {\r\n        this._spinnerService.hide();\r\n        this.toastr.error(error);\r\n      });\r\n  }\r\n  selectRow(pktId) {\r\n    var checkboxId = \"cb_\" + pktId;\r\n    document.getElementById(checkboxId).click();\r\n  }\r\n\r\n  checkedRow(obj, stockidn, status) {\r\n    let cbId = 'cb_' + obj.stock_idn;\r\n    if (status == false) {\r\n      var element = document.getElementById(cbId);//pktId\r\n      element.parentElement.parentElement.classList.remove(\"selectedRow\");\r\n      element.parentElement.parentElement.classList.add(\"notselectedRow\");\r\n      this.selectedItm.forEach((e, index) => {\r\n        if (e.stock_idn == stockidn) {\r\n          this.selectedItm.splice(index, 1);\r\n        }\r\n      });\r\n    } else {\r\n      var element = document.getElementById(cbId);//pktId\r\n      element.parentElement.parentElement.classList.remove(\"notselectedRow\");\r\n      element.parentElement.parentElement.classList.add(\"selectedRow\");\r\n      this.selectedItm.push(obj);\r\n    }\r\n    this.selectwt = this.cs.splitToTwoDecimal(this.selectedItm.reduce((a, b) => +a + +parseFloat(b.crtwt), 0));\r\n\r\n    // let totAmt = this.cs.splitToTwoDecimal(this.selectedItm.reduce((a, b) => +a + +b.sal_amount, 0));\r\n    let totweight = this.cs.splitToTwoDecimal(this.selectedItm.reduce((a, b) => +a + +parseFloat(b.crtwt), 0));\r\n    let totrapVal = this.cs.splitToTwoDecimal(this.selectedItm.reduce((a, b) => +a + +b.rap_vlu, 0));\r\n\r\n\r\n    let totAmt = 0;\r\n    this.selectedItm.forEach(element => {\r\n      if (element.grp_stt == 'sold') {\r\n        totAmt += parseFloat(element['sal_rte'] || 0) * parseFloat(element['crtwt']);\r\n      }\r\n      else {\r\n        totAmt += parseFloat(element['rte'] || 0) * parseFloat(element['crtwt']);\r\n      }\r\n    });\r\n\r\n    this.selectAvg = this.cs.splitToTwoDecimal(totAmt / parseFloat(totweight));\r\n    this.selectDis = this.cs.splitToTwoDecimal((totAmt / parseFloat(totrapVal) * 100) - 100);\r\n    this.selectAmt = this.cs.splitToTwoDecimal(totAmt);\r\n\r\n  }\r\n\r\n  sttwise = false;\r\n  statusWiseDisplay(e, m) {\r\n    debugger\r\n    this.sttwise = true;\r\n    let gArr = [];\r\n    for (let key in m) {\r\n      if (m[key] == true) {\r\n        debugger\r\n        let pk = this.pkts.filter(e => e.grp_stt == key);\r\n        gArr = gArr.concat(pk);\r\n      }\r\n      else {\r\n        let pk = gArr.filter(e => e.grp_stt != key);\r\n      }\r\n    }\r\n    debugger\r\n    this.finalGrpVal[\"\"] = gArr;\r\n    this.loadResult = gArr;\r\n\r\n    if (this.finalGrpVal[\"\"].length > 0) {\r\n      this.totalWeight = this.cs.splitToTwoDecimal(this.finalGrpVal[\"\"].reduce((a, b) => +a + +parseFloat(b.crtwt), 0));\r\n\r\n      let totweight = this.cs.splitToTwoDecimal(this.finalGrpVal[\"\"].reduce((a, b) => +a + +parseFloat(b.crtwt), 0));\r\n      let totrapVal = this.cs.splitToTwoDecimal(this.finalGrpVal[\"\"].reduce((a, b) => +a + +b.rap_vlu, 0));\r\n\r\n      let totAmt = 0;\r\n      this.finalGrpVal[\"\"].forEach(element => {\r\n        if (element.grp_stt == 'sold') {\r\n          totAmt += parseFloat(element['sal_rte']) * parseFloat(element['crtwt']);\r\n        }\r\n        else {\r\n          totAmt += parseFloat(element['rte']) * parseFloat(element['crtwt']);\r\n        }\r\n      });\r\n      this.totAmt = this.cs.splitToTwoDecimal(totAmt);\r\n\r\n      this.totAvg = this.cs.splitToTwoDecimal(totAmt / parseFloat(totweight));\r\n      this.totDis = this.cs.splitToTwoDecimal(((totAmt * 100) / parseFloat(totrapVal)) - 100);\r\n\r\n    }\r\n\r\n\r\n\r\n\r\n\r\n\r\n    // let grpBy = e.target.value;\r\n    // if (e.target.checked) {\r\n    //   let pk = this.pkts.filter(e => e.grp_stt == grpBy);\r\n    //   this.finalGrpVal[\"\"] = pk;\r\n    // }\r\n    // else {\r\n    //   let pk = this.pkts.filter(e => e.grp_stt !== grpBy);\r\n    //   this.finalGrpVal[\"\"] = pk;\r\n    // }\r\n    console.log(this.finalGrpVal);\r\n\r\n  }\r\n  OnLinkClick(lnk, pktdtl) {\r\n\r\n    if (lnk.form_field == 'priceupdate') {\r\n      this.cObj = pktdtl;\r\n      document.getElementById(\"bidMdBBtn\").click();\r\n    }\r\n  }\r\n\r\n  calculatRteDis(objdtl, typ) {\r\n    debugger\r\n    if (typ == 'rte') {\r\n      let dis = this.cs.splitToTwoDecimal(((parseFloat(objdtl.new_rte) * 100) / parseFloat(objdtl.rap_rte)) - 100);\r\n      objdtl[\"new_rap_dis\"] = dis;\r\n    }\r\n\r\n    if (typ == 'dis') {\r\n      let rte = this.cs.splitToTwoDecimal((parseFloat(objdtl.rap_rte) * (100 + parseFloat(objdtl.new_rap_dis)) / 100));\r\n      objdtl[\"new_rte\"] = rte;\r\n    }\r\n\r\n  }\r\n\r\n  ChangesPrice() {\r\n\r\n\r\n    let nmeIdn = JSON.parse(localStorage.getItem('nmeIdn'));\r\n    let pktDataList = [];\r\n    let updateObj = {};\r\n    updateObj[\"id\"] = this.cObj.pkt_code;\r\n    updateObj[\"issue\"] = { \"rte\": \"\" };\r\n    updateObj[\"rtn\"] = { \"rte\": this.cObj.new_rte };\r\n    updateObj[\"emp\"] = {};\r\n    pktDataList.push(updateObj);\r\n\r\n    let reqObj = {};\r\n    reqObj['formNme'] = this.route.snapshot.params['frmnme'];//'bulkUpdateForm';\r\n    reqObj['attr'] = \"rte\";\r\n    reqObj['reissue'] = 'Y';\r\n    reqObj['empIdn'] = nmeIdn;\r\n    reqObj['grp'] = \"bulkupdate\";\r\n    reqObj['processName'] = \"bulkMemPriceUpdate\"//'bulkPrepertiesUpdate';\r\n    reqObj['pktDataList'] = pktDataList;\r\n    console.log(JSON.stringify(reqObj));\r\n    this.reqheader['method'] = 'returnIssue';\r\n    let options = ({ headers: new HttpHeaders(this.reqheader) });\r\n    this.cs.load(reqObj, options, 'preMarketing/issueReturn').then((response: any) => {\r\n      if (response.status == 'SUCCESS') {\r\n\r\n        this.cObj.rte = this.cObj.new_rte;\r\n        this.cObj.rap_dis = this.cObj.new_rap_dis;\r\n        this.getSummary(this.pkts);\r\n        this.toastr.success(response.message);\r\n        this._spinnerService.hide();\r\n      } else {\r\n\r\n        this._spinnerService.hide();\r\n        this.toastr.error(response.message);\r\n      }\r\n    }).catch((err: any) => {\r\n      this._spinnerService.hide();\r\n      this.toastr.error(err.message);\r\n    });\r\n\r\n  }\r\n\r\n  addItems() {\r\n    for (let i = this.startIndex; i < this.endIndex; i++) {\r\n      this.loadResult[i] = this.pkts[i];\r\n    }\r\n    this.startIndex = this.endIndex;\r\n    this.endIndex = this.endIndex + 30;\r\n    if (this.endIndex > this.resultlength) {\r\n      this.endIndex = this.resultlength;\r\n    }\r\n  }\r\n\r\n  onScrollDown() {\r\n\r\n    if (this.endIndex <= this.resultlength)\r\n      this.addItems()\r\n    document.getElementById(\"wrap\").addEventListener(\"scroll\", function () {\r\n      var translate = \"translate(0,\" + this.scrollTop + \"px)\";\r\n      this.querySelector(\"thead\").style.transform = translate;\r\n    });\r\n  }\r\n  grp = [];\r\n  GrpVals = [];\r\n  finalGrpVal = {}\r\n  finalSummaryDtl = {};\r\n  data = [];\r\n  summaryDtl = {};\r\n\r\n  createGrp(datas, selected) {\r\n    this._spinnerService.show();\r\n    this.data = [...datas];\r\n    // let grpvalues = \"pu\";\r\n    // let grpvaluesArr = grpvalues.split(',');\r\n    // let resutArr = [];\r\n\r\n    let grpvaluesArr = selected;\r\n\r\n    var final = [];\r\n    var output = _.groupBy(this.data, function (entry) {\r\n      var strs = '';\r\n      for (let i = 0; i < grpvaluesArr.length; i++) {\r\n        strs += entry[grpvaluesArr[i]] + '#';\r\n      }\r\n\r\n      return strs;\r\n      // return entry[grpvaluesArr[0]] + '#' + entry[grpvaluesArr[1]];// + '#' + entry.pu;\r\n    });\r\n    // console.log(output);\r\n\r\n    final.push(output);\r\n    console.log(final);\r\n\r\n    var Keys = Object.keys(final[0]);\r\n    console.log(Keys);\r\n\r\n    var Vals = Object.values(final[0]);\r\n    console.log(Vals);\r\n\r\n    let grpNamearr = [];\r\n    Keys.map(ele => {\r\n      grpNamearr.push(ele.split('#').filter(e => e != undefined).join('  /  '));\r\n    });\r\n\r\n    this.grp = grpNamearr;\r\n    this.GrpVals = Vals;\r\n    for (let i = 0; i < grpNamearr.length; i++) {\r\n      var grpNme = grpNamearr[i];\r\n      this.finalGrpVal[grpNme] = Vals[i];\r\n\r\n      console.log(this.finalGrpVal[grpNme]);\r\n\r\n    }\r\n\r\n    this.getTotal();\r\n    this.grp.sort();\r\n\r\n    this._spinnerService.hide();\r\n\r\n  }\r\n\r\n\r\n  onGrpSelect(selected) {\r\n    if (this.viewdisType == 'group')\r\n      this.groupPktsList(this.pkts, selected);\r\n    else\r\n      this.summaryDetails(selected);\r\n  }\r\n  headList = [];\r\n  groupPktsList(pkts, selected) {\r\n    if (selected.length == 1) {\r\n      let attr = selected[0];\r\n      // this.finalGrpVal = _.groupBy(pkts, attr);\r\n      //this.grp = Object.keys(this.finalGrpVal);\r\n      from(pkts).pipe(\r\n        groupBy(x => x[attr]),\r\n        mergeMap(group => group.pipe(toArray())),\r\n        map(g => {\r\n          return {\r\n            value: g[0][attr],\r\n            pktList: g,\r\n            count: _.sumBy(g, 'qty_on_handint'),\r\n            rapvlu: this.cs.splitToTwoDecimal(_.sumBy(g, 'rap_vlu')),\r\n            crtwt: this.cs.splitToTwoDecimal(_.sumBy(g, 'crtwtint')),\r\n            vlu: this.cs.splitToTwoDecimal(_.sumBy(g, 'amountint')),\r\n            salvlu: this.cs.splitToTwoDecimal(_.sumBy(g, 'sal_amountint')),\r\n            avg: this.cs.splitToTwoDecimal(_.sumBy(g, 'amountint') / _.sumBy(g, 'crtwtint')),\r\n            salavg: this.cs.splitToTwoDecimal(_.sumBy(g, 'sal_amountint') / _.sumBy(g, 'crtwtint')),\r\n            dis: this.cs.splitToTwoDecimal(((_.sumBy(g, 'amountint') * 100) / (_.sumBy(g, 'rap_vlu'))) - 100),\r\n            saldis: this.cs.splitToTwoDecimal(((_.sumBy(g, 'sal_amountint') * 100) / (_.sumBy(g, 'rap_vlu'))) - 100)\r\n\r\n          }\r\n        }),\r\n        toArray())\r\n        .subscribe(d => {\r\n          this.groupBypktList = d;\r\n          this.groupstartIndex = 0;\r\n          this.groupendIndex = this.groupBypktList.length;\r\n          this.groupaddItems();\r\n        });\r\n\r\n    } else {\r\n      this.startIndex = 0;\r\n      this.endIndex = 30;\r\n      this.loadResult = [];\r\n      this.groupBypktList = [];\r\n      if (this.endIndex > this.resultlength)\r\n        this.endIndex = this.resultlength\r\n      this.addItems();\r\n\r\n    }\r\n  }\r\n\r\n\r\n  groupaddItems() {\r\n    let pktcnt = 0;\r\n    for (let i = this.groupstartIndex; i < this.groupendIndex; i++) {\r\n      debugger\r\n      this.loadgroupBypktList[i] = this.groupBypktList[i];\r\n      let pktlist = this.groupBypktList[i]['pktList'] || [];\r\n      pktcnt = pktcnt + pktlist.length;\r\n      if (pktcnt > 30) {\r\n        this.groupstartIndex = i + 1;\r\n        break;\r\n      }\r\n    }\r\n\r\n  }\r\n\r\n  grouponScrollDown() {\r\n\r\n    if (this.groupstartIndex < this.groupendIndex)\r\n      this.groupaddItems()\r\n    document.getElementById(\"wrap\").addEventListener(\"scroll\", function () {\r\n      var translate = \"translate(0,\" + this.scrollTop + \"px)\";\r\n      this.querySelector(\"thead\").style.transform = translate;\r\n    });\r\n  }\r\n\r\n  summaryDetails(selected) {\r\n\r\n\r\n    if (selected.length == 1) {\r\n\r\n      this.headList = [];\r\n      let summaryData = [];\r\n      let attribue = selected[0];\r\n\r\n      from(this.pkts).pipe(\r\n        groupBy(x => x[attribue] + \"#\" + x['dsp_stt']),\r\n        mergeMap(group => group.pipe(toArray())),\r\n        map(g => {\r\n          return {\r\n            key: g[0][attribue] + \"#\" + g[0]['dsp_stt'],\r\n            value: g[0][attribue],\r\n            sort: g[0][attribue + \"_srt\"] || 10000,\r\n            dspstt: g[0]['dsp_stt'],\r\n            count: _.sumBy(g, 'qty_on_handint'),\r\n            rapvlu: this.cs.splitToTwoDecimal(_.sumBy(g, 'rap_vlu')),\r\n            crtwt: this.cs.splitToTwoDecimal(_.sumBy(g, 'crtwtint')),\r\n            vlurte: this.cs.splitToTwoDecimal(_.sumBy(g, 'amountint')),\r\n            vlu: this.cs.splitToTwoDecimal(_.sumBy(g, 'sal_amountint')),\r\n\r\n          }\r\n        }),\r\n        toArray())\r\n        .subscribe(d => {\r\n          summaryData = d;\r\n        });\r\n\r\n      let summaryMap = {};\r\n      let sideList = [];\r\n      let headList = [];\r\n      summaryData.forEach(element => {\r\n        summaryMap[element.key] = element;\r\n        let value = element.value || '';\r\n        let dspstt = element.dspstt;\r\n        if ((selected == 'sal_byr' || selected == 'sal_emp') && dspstt != 'sold')\r\n          value = '';\r\n        if (value != '') {\r\n\r\n\r\n          if (headList.indexOf(dspstt) == -1)\r\n            headList.push(dspstt);\r\n          if (sideList.indexOf(value) == -1)\r\n            sideList.push(value);\r\n        }\r\n      })\r\n\r\n      this.summaryList = [];\r\n      sideList.forEach(side => {\r\n        let summry = {};\r\n        headList.forEach(head => {\r\n          let summryData = summaryMap[side + \"#\" + head] || '';\r\n          if (summryData != '') {\r\n            let stt = summryData['dspstt'];\r\n\r\n            let vlu = parseFloat(summryData.vlurte || 0);\r\n            let rapvlu = parseFloat(summryData.rapvlu || 0);\r\n            let crtwt = parseFloat(summryData.crtwt || 0);\r\n            summry['value'] = side;\r\n            summry['valueSort'] = summryData.sort;\r\n            summry['count_' + stt] = summryData.count;\r\n            summry['crtwt_' + stt] = summryData.crtwt;\r\n            summry['vlu_' + stt] = summryData.vlurte;\r\n            summry['avg_' + stt] = this.cs.splitToTwoDecimal(vlu / crtwt);\r\n            summry['dis_' + stt] = this.cs.splitToTwoDecimal(((vlu * 100) / rapvlu) - 100);\r\n            if (stt == 'sold') {\r\n              vlu = parseFloat(summryData.vlu || 0);\r\n              summry['vlu_' + stt] = vlu;\r\n              summry['avg_' + stt] = this.cs.splitToTwoDecimal(vlu / crtwt);\r\n              summry['dis_' + stt] = this.cs.splitToTwoDecimal(((vlu * 100) / rapvlu) - 100);\r\n            }\r\n          }\r\n\r\n        });\r\n\r\n        this.summaryList.push(summry);\r\n      });\r\n\r\n      if (selected == 'sal_byr' || selected == 'sal_emp') {\r\n        this.summaryList.sort((val1, val2) => {\r\n          return (val2['vlu_sold']) - (val1['vlu_sold']);\r\n        });\r\n      } else {\r\n        console.log(\"this.summaryList\", this.summaryList);\r\n        this.summaryList.sort((val1, val2) => {\r\n          return (val1['valueSort']) - (val2['valueSort']);\r\n        });\r\n        console.log(\"this.summaryList\", this.summaryList);\r\n      }\r\n\r\n      this.headList = headList;\r\n\r\n    } else {\r\n      if (selected.length > 1) {\r\n        this.toastr.error(\"Summary need only one attribute\");\r\n      }\r\n    }\r\n  }\r\n\r\n  exportToCSVSummary() {\r\n\r\n    let modifiedObjArr = [];\r\n\r\n    this.summaryList.forEach((data, index) => {\r\n      let obj = {};\r\n      obj[\"Sr. No\"] = index + 1;\r\n      obj[\"Attribute\"] = data.value || '';\r\n      this.headList.forEach(hdr => {\r\n        obj[\"Qty(\" + hdr + \")\"] = data[\"count_\" + hdr] || '';\r\n        obj[\"Carat(\" + hdr + \")\"] = data[\"crtwt_\" + hdr] || '';\r\n        obj[\"Avg(\" + hdr + \")\"] = data[\"avg_\" + hdr] || '';\r\n        obj[\"Dis(\" + hdr + \")\"] = data[\"dis_\" + hdr] || '';\r\n        obj[\"Value(\" + hdr + \")\"] = data[\"vlu_\" + hdr] || '';\r\n      });\r\n\r\n      modifiedObjArr.push(obj);\r\n\r\n    });\r\n    this.cs.CSVConvertor(modifiedObjArr, \"Summary_details\", true)\r\n  }\r\n\r\n  getTotal() {\r\n    let indexVal = 0;\r\n    let qs = 0;\r\n\r\n    this.GrpVals.forEach(element => {\r\n      let totAmt = 0;\r\n      let totweight = this.cs.splitToTwoDecimal(element.reduce((a, b) => +a + +parseFloat(b.crtwt), 0));\r\n      let rapVal = _.sumBy(element, 'rap_vlu');\r\n      element.forEach(pkt => {\r\n\r\n        if (pkt.grp_stt == 'sold') {\r\n          totAmt += parseFloat(pkt['sal_rte'] || 0) * parseFloat(pkt['crtwt']);\r\n        }\r\n        else {\r\n          totAmt += parseFloat(pkt['rte'] || 0) * parseFloat(pkt['crtwt']);\r\n        }\r\n      });\r\n\r\n      totAmt = this.cs.splitToTwoDecimal(totAmt);\r\n\r\n      var key = this.grp[indexVal];\r\n      this.summaryDtl[key + \"_CTS\"] = this.cs.splitToTwoDecimal(totweight);\r\n      this.summaryDtl[key + \"_AMT\"] = this.cs.splitToTwoDecimal(totAmt);\r\n      this.summaryDtl[key + \"_RTE\"] = this.cs.splitToTwoDecimal(totAmt / totweight);\r\n      this.summaryDtl[key + \"_DIS\"] = this.cs.splitToTwoDecimal(((totAmt * 100) / rapVal) - 100);\r\n      indexVal++;\r\n\r\n    });\r\n\r\n  }\r\n\r\n\r\n  GrpValsPie = [];\r\n  grpPie = [];\r\n  finalGrpValPie = {};\r\n  summaryDtlPie = {};\r\n  byrvalGrp = [];//{};\r\n  isBuyerwise = false;\r\n  isGrpwise = false;\r\n  type;\r\n  grpWiseQty = [];\r\n  dataType = \"\";\r\n  generatePie(Datatype, ChartType) {\r\n    if (ChartType == 'qty') {\r\n      document.getElementById('btnQty').classList.remove('btn-default');\r\n      document.getElementById('btnQty').classList.add('active');\r\n      document.getElementById('btnVal').classList.remove('active');\r\n      document.getElementById('btnVal').classList.add('btn-default');\r\n    }\r\n    else {\r\n      document.getElementById('btnVal').classList.remove('btn-default');\r\n      document.getElementById('btnVal').classList.add('active');\r\n      document.getElementById('btnQty').classList.remove('active');\r\n      document.getElementById('btnQty').classList.add('btn-default');\r\n    }\r\n    this.grpWiseQty = [];\r\n    this.byrvalGrp = [];\r\n\r\n    this.dataType = Datatype;\r\n    this._spinnerService.show();\r\n    this.finalGrpValPie = {};\r\n    this.byrvalGrp = [];\r\n    this.data = [...this.pkts];\r\n    this.data = this.data.filter(x => x.grp_stt == 'sold');\r\n    let grpvalues;\r\n    let grpvaluesArr;\r\n    let resutArr = [];\r\n    // type = 'qty';\r\n    if (Datatype == 'buyer') {\r\n      this.type = \"Buyer\";\r\n      this.isBuyerwise = true;\r\n      this.isGrpwise = false;\r\n      grpvalues = \"sal_byr\";\r\n      grpvaluesArr = grpvalues.split(',');\r\n      resutArr = [];\r\n    } else {\r\n      this.type = this.defaultGrpList;\r\n      this.isBuyerwise = false;\r\n      this.isGrpwise = true;\r\n      grpvaluesArr = this.defaultGrpList;//selected;\r\n\r\n    }\r\n\r\n    //let grpvaluesArr = selected;\r\n\r\n    var final = [];\r\n    var output = _.groupBy(this.data, function (entry) {\r\n      var strs = '';\r\n      for (let i = 0; i < grpvaluesArr.length; i++) {\r\n        strs += entry[grpvaluesArr[i]] + '#';\r\n      }\r\n\r\n      return strs;\r\n      // return entry[grpvaluesArr[0]] + '#' + entry[grpvaluesArr[1]];// + '#' + entry.pu;\r\n    });\r\n    // console.log(output);\r\n\r\n    final.push(output);\r\n\r\n    var Keys = Object.keys(final[0]);\r\n\r\n    var Vals = Object.values(final[0]);\r\n\r\n    let grpNamearr = [];\r\n    Keys.map(ele => {\r\n      grpNamearr.push(ele.split('#').filter(e => e != undefined).join('  /  '));\r\n    });\r\n\r\n    this.grpPie = grpNamearr;\r\n    this.GrpValsPie = Vals;\r\n    for (let i = 0; i < grpNamearr.length; i++) {\r\n      var grpNme = grpNamearr[i];\r\n\r\n      this.finalGrpValPie[grpNme] = Vals[i];\r\n\r\n      let totAmt = this.cs.splitToTwoDecimal(this.finalGrpValPie[grpNme].reduce((a, b) => +a + +parseFloat(b.sal_amountint), 0));\r\n\r\n      let byrObj = {};\r\n      byrObj['k'] = grpNme;\r\n      byrObj['v'] = parseFloat(totAmt);//this.byrvalGrp[grpNme].length;\r\n      this.byrvalGrp.push(byrObj);\r\n      byrObj = {};\r\n      // this.byrvalGrp[grpNme] = totAmt;\r\n\r\n      let qtyObj = {};\r\n      qtyObj['k'] = grpNme;\r\n      qtyObj['v'] = this.finalGrpValPie[grpNme].length;\r\n      this.grpWiseQty.push(qtyObj);\r\n      qtyObj = {};\r\n\r\n      // this.grpWiseQty[grpNme] = this.finalGrpValPie[grpNme].length;\r\n\r\n    }\r\n    console.log(this.grpWiseQty);\r\n\r\n    if (ChartType == 'qty') {\r\n      this.drawPie(this.grpWiseQty, ChartType, Datatype);\r\n    }\r\n    else {\r\n      this.drawPie(this.byrvalGrp, ChartType, Datatype);\r\n    }\r\n\r\n    // this.getTotalPie();\r\n    // this.grpPie.sort();\r\n\r\n  }\r\n\r\n  dynamicColors = [];\r\n  generate() {\r\n    this.dynamicColors = [];\r\n    for (var i = 1; i < 7; i++) {\r\n      // this.LightenDarkenColor(\"7cb5ec\", i * 10);\r\n      let col = 'c6e896';\r\n      let amt = (i * 20) * -1;\r\n      var usePound = false;\r\n\r\n      if (col[0] == \"#\") {\r\n        col = col.slice(1);\r\n        usePound = true;\r\n      }\r\n\r\n      var num = parseInt(col, 16);\r\n\r\n      var r = (num >> 16) + amt;\r\n\r\n      if (r > 255) r = 255;\r\n      else if (r < 0) r = 0;\r\n\r\n      var b = ((num >> 8) & 0x00FF) + amt;\r\n\r\n      if (b > 255) b = 255;\r\n      else if (b < 0) b = 0;\r\n\r\n      var g = (num & 0x0000FF) + amt;\r\n\r\n      if (g > 255) g = 255;\r\n      else if (g < 0) g = 0;\r\n\r\n      // return (usePound ? \"#\" : \"\") + (g | (b << 8) | (r << 16)).toString(16);\r\n      this.dynamicColors.push((usePound ? \"#\" : \"#\") + (g | (b << 8) | (r << 16)).toString(16));\r\n    }\r\n    console.log(this.dynamicColors);\r\n\r\n    return this.dynamicColors;\r\n  }\r\n  byrValArr = [];\r\n  getTotalPie() {\r\n    let indexVal = 0;\r\n    let AmtArr = [];\r\n    this.GrpValsPie.forEach(element => {\r\n      let byrwiseVal = {};\r\n      let totAmt = 0;\r\n      let totweight = 0;\r\n      totweight = this.cs.splitToTwoDecimal(element.reduce((a, b) => +a + +parseFloat(b.crtwt), 0));\r\n      totAmt = this.cs.splitToTwoDecimal(element.reduce((a, b) => +a + +parseFloat(b.sal_amountint), 0));\r\n      AmtArr.push(totAmt);\r\n      var key = this.grp[indexVal];\r\n      // this.summaryDtl[key + \"_QTY\"] = this.cs.splitToTwoDecimal(qty);\r\n      this.summaryDtlPie[key + \"_CTS\"] = this.cs.splitToTwoDecimal(totweight);\r\n      this.summaryDtlPie[key + \"_AMT\"] = this.cs.splitToTwoDecimal(totAmt);\r\n\r\n      indexVal++;\r\n\r\n      if (indexVal == 1) {\r\n        byrwiseVal[this.grp[indexVal]] = totAmt;\r\n        this.byrValArr.push(byrwiseVal);\r\n        byrwiseVal = {};\r\n      }\r\n      // console.log(qs);\r\n      // console.log(amount);\r\n\r\n    });\r\n\r\n    console.log(this.byrValArr);\r\n\r\n    AmtArr = AmtArr.map(function (x) {\r\n      return parseFloat(x);\r\n    });\r\n\r\n    AmtArr.sort(function (a, b) { return a - b; });\r\n    console.log(AmtArr);\r\n    AmtArr.reverse();\r\n\r\n    // this.drawPie(AmtArr);\r\n\r\n  }\r\n  public pieChartPlugins = [pluginDataLabels];\r\n  doughnutChartType = 'pie';\r\n  doughnutChartLabels = [];\r\n  doughnutChartData = [];\r\n  pieChartColors = [];\r\n  pieChartLegend = true;\r\n\r\n\r\n  public chartColors: any[] = [\r\n    {\r\n      backgroundColor: this.generate(),\r\n      fillColor: this.generate(),\r\n      strokeColor: this.generate()\r\n      //[\"#000080\", \"#0020C2\", \"#1569C7\", \"#357EC7\", \"#368BC1\",\"659EC7\"] \r\n    }];\r\n  labels = {\r\n    labels: {\r\n      render: 'percentage',\r\n      //     fontColor: ['green', 'white', 'red'],\r\n      precision: 2\r\n    }\r\n  }\r\n  chartOptions = {\r\n    plugins: {\r\n      labels: {\r\n        render: 'percentage',\r\n      }\r\n    },\r\n    legend: {\r\n      position: 'right',\r\n      labels: {\r\n        fontColor: 'black',\r\n        boxWidth: 10,\r\n        padding: 10,\r\n        fontSize: 10,\r\n        render: 'percentage',\r\n\r\n      }\r\n    },\r\n\r\n\r\n\r\n  }\r\n  pieChartOptions = {\r\n    //legend: {position: 'left',fontColor:'white'},\r\n    //plugins: {labels: { render: 'percentage',position: 'border', textMargin: 4}}\r\n\r\n    legend: {\r\n      position: 'right',\r\n      labels: {\r\n        fontColor: 'black',\r\n        boxWidth: 10,\r\n        padding: 10,\r\n        fontSize: 10,\r\n        render: 'percentage'\r\n      }\r\n\r\n    },\r\n    plugins: {\r\n      datalabels: {\r\n        formatter: (value, ctx) => {\r\n          const label = ctx.chart.data.labels[ctx.dataIndex];\r\n          return label;\r\n        },\r\n      },\r\n    }\r\n  };\r\n  pie = {\r\n    legend: { position: 'left', fontColor: 'white' },\r\n    plugins: {\r\n      labels: {\r\n        // render 'label', 'value', 'percentage', 'image' or custom function, default is 'percentage'\r\n        render: 'percentage',\r\n        precision: 0,\r\n        arc: true,\r\n        showActualPercentages: true,\r\n        position: 'outside'\r\n      }\r\n    },\r\n    tooltips: {\r\n      mode: 'label',\r\n      callbacks: {\r\n        label: function (tooltipItem, data) {\r\n          //  let label = data.datasets[tooltipItem.datasetIndex].label;\r\n          //  let value = data.datasets[tooltipItem.datasetIndex].data[tooltipItem.index];\r\n          return [data.labels[tooltipItem.index]\r\n          ];\r\n        }\r\n      }\r\n    }\r\n  }\r\n  drawPie(salesData, type, ChartType) {\r\n    this.doughnutChartData = [];\r\n    this.doughnutChartLabels = [];\r\n\r\n    let AmtArr = salesData.sort((a, b) => (a.v > b.v) ? 1 : -1).reverse();\r\n\r\n\r\n    if (ChartType == \"buyer\") {\r\n      this.doughnutChartData = AmtArr.slice(0, 5).map(a => a.v);\r\n      this.doughnutChartLabels = AmtArr.slice(0, 5).map(a => a.k);\r\n      let sums = 0;\r\n      let otherSum = this.cs.splitToTwoDecimal(this.sttWiseSummary.get('sold').get('rate'));\r\n      if (type == 'qty')\r\n        otherSum = this.cs.splitToTwoDecimal(this.sttWiseSummary.get('sold').get('count'));\r\n\r\n      let tArr = [];\r\n      tArr = AmtArr.slice(0, 5).map(function (x) {\r\n        return parseFloat(x.v);\r\n      });\r\n      sums = _.sumBy(tArr);\r\n      let maxinArr = Math.max(Math.max(...this.doughnutChartData));\r\n      debugger\r\n      let otherval = this.cs.splitToTwoDecimal(otherSum - sums) || 0;\r\n      if (maxinArr > otherval) {\r\n        this.doughnutChartData.push(otherval);\r\n        this.doughnutChartLabels.push('Other');\r\n      }\r\n      else {\r\n        this.doughnutChartData.unshift(otherval);\r\n        this.doughnutChartLabels.unshift('Other');\r\n      }\r\n\r\n    }\r\n    else {\r\n      this.doughnutChartData = AmtArr.map(a => a.v);\r\n      this.doughnutChartLabels = AmtArr.map(a => a.k);\r\n      console.log(\"this.doughnutChartData\", this.doughnutChartData);\r\n      let sums = 0;\r\n      let otherSum = this.cs.splitToTwoDecimal(this.sttWiseSummary.get('sold').get('rate'));\r\n      sums = _.sumBy(Object.values(AmtArr), 'v');\r\n    }\r\n\r\n    // this.doughnutChartData.sort(function (a, b) { return a - b; });\r\n    // this.doughnutChartData = this.doughnutChartData.reverse();\r\n\r\n    for (let i = 0; i < this.doughnutChartLabels.length; i++) {\r\n      this.doughnutChartLabels[i] = this.doughnutChartLabels[i] + \" \" + this.doughnutChartData[i].toString();\r\n    }\r\n\r\n    // console.log(this.doughnutChartLabels);\r\n    this.refreshChart(ChartType);\r\n    this.doughnutChartType = 'pie';\r\n    // document.getElementById('PiechartModelBtn').click();\r\n    this._spinnerService.hide();\r\n\r\n  }\r\n\r\n  refreshChart(ChartType) {\r\n    this.isBuyerwise = false;\r\n    this.isGrpwise = false;\r\n    setTimeout(() => {\r\n      if (ChartType == \"buyer\") {\r\n        this.isBuyerwise = true;\r\n      }\r\n      else {\r\n        this.isGrpwise = true;\r\n      }\r\n\r\n    }, 1);\r\n  }\r\n\r\n  sortBy(key, g) {\r\n    this.sorted = this.sorted == 'desc' ? 'asc' : 'desc';\r\n    console.log(this.sorted);\r\n    let srted = _.orderBy(this.finalGrpVal[g], key, [this.sorted]);\r\n    this.finalGrpVal[g] = srted;\r\n    this.sortOn = g;\r\n    this.clmn = key;\r\n  }\r\n  exportToCSV(FileName) {\r\n    let d = this.cs.cDate,\r\n      month = '' + (d.getMonth() + 1),\r\n      day = '' + d.getDate(),\r\n      year = d.getFullYear();\r\n    let dt = [day, month, year].join('-');\r\n    let fileNme = FileName + '__' + dt;\r\n    this.headerKey = [\"dsp_stt\", ...this.headerKey];\r\n    let modifiedObjArr = this.cs.modifyDataByHeader(this.pkts, this.headerKey, this.header);\r\n    this.cs.CSVConvertor(modifiedObjArr, fileNme, true);\r\n  }\r\n  getSummary(p) {\r\n    let summary;\r\n    p.forEach(element => {\r\n      // let stt = '';\r\n      // if (element.grp_stt == 'sold') {\r\n      //   stt = 'Sold';\r\n      // }\r\n      // else if (element.grp_stt == 'mkt') {\r\n      //   stt = 'Marketing';\r\n      // }\r\n      // else if (element.grp_stt == 'lab') {\r\n      //   stt = 'Lab';\r\n      // }\r\n\r\n      // else {\r\n      //   stt = element.grp_stt;\r\n      // }\r\n\r\n      // summary = this.sttWiseSummary.get(element.grp_stt);\r\n      summary = this.sttWiseSummary.get(element.grp_stt);//stt\r\n\r\n      let count = 0;\r\n      let gridWt = 0;\r\n      let gridavg = 0;\r\n      let disc = 0;\r\n      let gridRate = 0;\r\n      let totAmt = 0;\r\n      let gridRap = 0;\r\n\r\n      // this.totAvg = this.cs.splitToTwoDecimal(parseFloat(totAmt) / parseFloat(totweight));\r\n      // this.totDis = this.cs.splitToTwoDecimal(((parseFloat(totAmt) * 100) / parseFloat(totrapVal)) - 100);\r\n\r\n\r\n      let wt = parseFloat(element.crtwt);\r\n      let rate = 0;\r\n      let rapval = parseFloat(element.rap_vlu);\r\n      if (element.grp_stt == 'sold') {\r\n        rate = parseFloat((element.sal_rte == undefined || element.sal_rte == \"\") ? element.rte : element.sal_rte) * parseFloat(element.crtwt);\r\n      }\r\n      else {\r\n        rate = parseFloat(element.rte) * parseFloat(element.crtwt);\r\n      }\r\n\r\n      if (summary != null) {\r\n        count = parseInt(summary.get('count'));\r\n        gridWt = parseFloat(summary.get('wt'));\r\n        gridRate = parseFloat(summary.get('rate'));\r\n        gridRap = parseFloat(summary.get('rap'));\r\n      } else {\r\n        summary = new Map();\r\n      }\r\n      summary.set('count', count + 1);\r\n      summary.set('wt', gridWt + wt);\r\n      summary.set('rate', gridRate + rate);\r\n      summary.set('rap', gridRap + rapval);\r\n\r\n      // this.sttWiseSummary.set(element.grp_stt == 'sold' ? 'Sold' : element.grp_stt, summary);\r\n      this.sttWiseSummary.set(element.grp_stt, summary);//stt\r\n\r\n    });\r\n    console.log('@presum:', this.sttWiseSummary);\r\n\r\n    this.anaAllGrpStt.forEach(ele => {\r\n      console.log(ele);\r\n      let count = 0;\r\n      let gridWt = 0;\r\n      let gridavg = 0;\r\n      let disc = 0;\r\n      let gridRate = 0;\r\n      let totAmt = 0;\r\n      let rap = 0;\r\n      let gridRap = 0;\r\n\r\n\r\n      //if (ele == 'Marketing' || ele == 'Sold') {\r\n      // ele = (ele == 'Marketing' || ele == 'Sold') ? ele : ele.toLowerCase();\r\n      let summary = this.sttWiseSummary.get(ele) || new Map();\r\n\r\n      count = parseInt(summary.get('count')) || 0;\r\n      gridWt = parseFloat(summary.get('wt')) || 0.00;\r\n      gridRate = parseFloat(summary.get('rate')) || 0;\r\n      gridRap = parseFloat(summary.get('rap')) || 1;\r\n\r\n      disc = this.cs.splitToTwoDecimal(((gridRate * 100) / gridRap) - 100);\r\n\r\n      gridavg = this.cs.splitToTwoDecimal(gridRate / gridWt);\r\n\r\n      summary.set('disc', disc);\r\n      summary.set('avg', gridavg);\r\n\r\n      this.sttWiseSummary.set(ele, summary);\r\n      //}\r\n\r\n    })\r\n    console.log(this.sttWiseSummary);\r\n\r\n  }\r\n\r\n  TotAvgObj = {};\r\n  getTotals(fields, pkts) {\r\n    debugger\r\n    fields.forEach(element => {\r\n      debugger\r\n      let tavg = 0;\r\n      let total = 0;\r\n      if (element.trim() == 'age') {\r\n        total = this.cs.splitToTwoDecimal(pkts.reduce((a, b) => +a + +b.age, 0));\r\n      }\r\n      else {\r\n        total = _.sumBy(pkts, item => Number(item[element.trim()]));\r\n      }\r\n\r\n      let zeroVals = pkts.filter(x => (x[element.trim()] === \"0\" || 0)).length;\r\n      if (element.trim() != 'age') {\r\n        tavg = total / _.sumBy(pkts, item => Number(item['crtwt']));\r\n        tavg = this.cs.numbertofixed(tavg, 2)\r\n      }\r\n      else {\r\n        tavg = total / pkts.length;\r\n      }\r\n      this.TotAvgObj[element.trim()] = tavg;\r\n    });\r\n    console.log(this.TotAvgObj);\r\n  }\r\n\r\n  getTotalsTtl(fields, pkts) {\r\n    debugger\r\n    fields.forEach(element => {\r\n      debugger\r\n      let total = 0;\r\n\r\n      total = _.sumBy(pkts, item => Number(item[element.trim()]));\r\n\r\n      this.TotAvgObj[element.trim()] = this.cs.numbertofixed(total, 2);\r\n    });\r\n  }\r\n  modifySearch() {\r\n    localStorage.setItem('BIcall', 'BImodify');\r\n    this.router.navigate([this.modulename + '/analysis-search/' + this.route.snapshot.params['frmnme']]);\r\n  }\r\n  anaSttLbl = [];\r\n  ngOnInit() {\r\n    // this.LightenDarkenColor(\"7cb5ec\", 10);\r\n    let mdlk = JSON.parse(localStorage.getItem('mdlKey'));\r\n    this.cObj = {};\r\n    this.cUrl = this.router.url;\r\n\r\n    this.reqheader = {\r\n      'clientkey': Cookie.get('_ck'),\r\n      'Content-Type': 'application/json',\r\n      'modulekey': mdlk[this.cUrl.split('/')[1]],\r\n      'loginid': Cookie.get('_logid'),\r\n      'source': 'qs'\r\n    };\r\n    this.viewdisType = \"group\";\r\n    this.newwindow = \"YES\";\r\n    this.grp = [];\r\n    this.loadResult = [];\r\n    this.startIndex = 0;\r\n    this.endIndex = 30;\r\n    this.cUrl = this.router.url;\r\n    this.modulename = this.cUrl.split('/')[1];\r\n    this.ck = encodeURIComponent(Cookie.get('_ck'));\r\n    this.route.params.subscribe(map => {\r\n      this.loadDefination();\r\n      let viewType = localStorage.getItem('viewType');\r\n      let anaArr = JSON.parse(localStorage.getItem('BIanaStt'));\r\n      let anasttLbl = JSON.parse(localStorage.getItem('BIanaSttLBL'));\r\n      if (anaArr != null) {\r\n        this.anaAllGrpStt = JSON.parse(localStorage.getItem('BIanaStt'));\r\n        this.anaSttLbl = JSON.parse(localStorage.getItem('BIanaSttLBL'));\r\n        this.anaAllGrpStt.forEach(element => {\r\n          this.stObj[element] = true;\r\n        });\r\n      }\r\n      if (viewType == 'listView') {\r\n        this.getSearchResult();\r\n      }\r\n      else {\r\n        let pkts = JSON.parse(localStorage.getItem('pktData'));\r\n        this.headerKey = JSON.parse(localStorage.getItem('resultView'));\r\n        this.header = JSON.parse(localStorage.getItem('resultViewDtl'));\r\n        this.header = JSON.parse(localStorage.getItem('resultViewDtl'));\r\n        let legends = JSON.parse(localStorage.getItem('BILegends'));\r\n        if (legends != null && legends != undefined && legends != \"\") {\r\n          this.legendList = legends;\r\n        }\r\n        this.pkts = [...pkts];\r\n\r\n        this.totalWeight = this.cs.splitToTwoDecimal(this.pkts.reduce((a, b) => +a + +parseFloat(b.crtwt), 0));\r\n\r\n        this.getSummary(this.pkts);\r\n\r\n        //  let totAmt = this.cs.splitToTwoDecimal(this.pkts.reduce((a, b) => +a + +b.sal_rec_rte * parseFloat(b.crtwt), 0));\r\n        let totweight = this.cs.splitToTwoDecimal(this.pkts.reduce((a, b) => +a + +parseFloat(b.crtwt), 0));\r\n        let totrapVal = this.cs.splitToTwoDecimal(this.pkts.reduce((a, b) => +a + +b.rap_vlu, 0));\r\n\r\n        let totAmt = 0;\r\n        this.pkts.forEach(element => {\r\n          if (element.grp_stt == 'sold') {\r\n            totAmt += parseFloat(element['sal_rte']) * parseFloat(element['crtwt']);\r\n          }\r\n          else {\r\n            totAmt += parseFloat(element['rte']) * parseFloat(element['crtwt']);\r\n          }\r\n        });\r\n\r\n\r\n\r\n        this.totAvg = this.cs.splitToTwoDecimal(totAmt / parseFloat(totweight));\r\n        this.totDis = this.cs.splitToTwoDecimal(((totAmt * 100) / parseFloat(totrapVal)) - 100);\r\n\r\n\r\n        this.resultlength = this.pkts.length;\r\n        if (this.endIndex > this.resultlength)\r\n          this.endIndex = this.resultlength\r\n        this.addItems();\r\n\r\n\r\n      }\r\n\r\n    });\r\n    let GRPby = JSON.parse(localStorage.getItem('BI-PKT_GROUP_BY')) || '';\r\n    this.getStaticKV(GRPby);\r\n    //  this.createGrp(this.pkts, this.defaultGrpList);\r\n    let avgFields = JSON.parse(localStorage.getItem('BI-gridAvg')) || '';\r\n    if (avgFields != '')\r\n      this.getTotals(avgFields, this.pkts);\r\n  }\r\n  getStaticKV(qry) {\r\n    this.staticLov = [];\r\n    let arrkv = qry.split(',');\r\n    let obj = {}, staticLov = [];\r\n    for (let i = 0; i < arrkv.length; i += 2) {\r\n      let key = arrkv[i], value = arrkv[i + 1];\r\n      obj['k'] = key;\r\n      obj['v'] = value;\r\n      // if (i == 0) {\r\n      //   qry.default_value = value;//key\r\n      // }\r\n      this.staticLov.push(obj);\r\n      obj = {};\r\n    }\r\n    this.staticLov = this.staticLov.map(option => ({\r\n      value: option.v,\r\n      label: option.k\r\n    }));\r\n    console.log(this.staticLov);\r\n  }\r\n\r\n  loadDefination() {\r\n\r\n    this._spinnerService.show();\r\n    let reqObj = {};\r\n    reqObj['formNme'] = this.route.snapshot.params['frmnme'];//'searchDtlDscrForm';\r\n    this.reqheader['method'] = 'loadDefination';\r\n    let options = ({ headers: new HttpHeaders(this.reqheader) });\r\n    this.cs.load(reqObj, options, 'marketing/search').then((response: any) => {\r\n      if (response.status == 'SUCCESS') {\r\n        let result = response.result;\r\n        this.pageDefination = result.pageDefination || {};\r\n        this.links = this.pageDefination.link || [];\r\n\r\n        this._spinnerService.hide();\r\n      } else {\r\n        this._spinnerService.hide();\r\n        this.toastr.error(response.message);\r\n      }\r\n    }).catch((err: any) => {\r\n      this._spinnerService.hide();\r\n      this.toastr.error(err.message);\r\n    });\r\n  }\r\n\r\n}\r\n\r\n","<div class=\"mt\">\r\n  <div class=\"panel panel-default\">\r\n    <div class=\"panel-heading\">\r\n      <h3 class=\"panel-title\">\r\n        <span class=\"fa fa-chevron-left cp\" (click)=\"cs.pageBck();\"> Back</span>&nbsp;&nbsp;&nbsp; Packet List\r\n        <span class=\"f-12\">({{cs.cDate | date: 'medium'}})</span>\r\n      </h3>\r\n    </div>\r\n  </div>\r\n  <div class=\"content-frame\">\r\n    <div class=\"innerD\">\r\n      <div class=\"content-frame-left\" *ngIf=\"false\">\r\n        <div class=\"panel panel-default\">\r\n          <div class=\"panel-body\">\r\n            <!-- <div class=\"list-group border-bottom\">\r\n              <a href=\"javascript:void(0)\" class=\"list-group-item\" [ngClass]=\"{'active' :i == cLink}\" *ngFor=\"let nav of navigation;let i=index\"\r\n                (click)=\"navigationFun(nav,i);\">{{nav.form_field_title}} </a>\r\n            </div> -->\r\n          </div>\r\n        </div>\r\n      </div>\r\n      <div class=\"content-frame-body\" style=\"margin-left:0\">\r\n        <div class=\"panel panel-default custom-panel\">\r\n          <div class=\"panel-body\" style=\"padding:0;\">\r\n            <div class=\"infoSec\">\r\n              <div class=\"row\">\r\n                <div class=\"col-sm-6\">\r\n                  <form class=\"form-inline pull-left\">\r\n                  </form>\r\n                </div>\r\n                <div class=\"col-sm-6\">\r\n                  <div class=\"dropdown text-right\">\r\n                  </div>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n          <div class=\"row\">\r\n            <div class=\"col-md-4\">\r\n              <div class=\"\" style=\"margin-bottom: 10px;\">\r\n                <table class=\"displayTable\">\r\n                  <thead>\r\n                    <tr>\r\n                      <th>Status</th>\r\n                      <th>Count</th>\r\n                      <th>Cts</th>\r\n                      <th>Avg</th>\r\n                      <th *ngIf=\"formname!='mixAnalysisReportForm'\">Disc</th>\r\n                      <th>Amount</th>\r\n\r\n                  </thead>\r\n                  <tbody>\r\n                    <ng-container *ngFor=\"let st of anaAllGrpStt;let i = index;\">\r\n                      <tr>\r\n                        <td>\r\n                          <!-- <label for=\"{{st}}\" class=\"text-capitalize\">S</label> -->\r\n                          <!-- *ngIf=\"defaultGrpList.length==0\" -->\r\n                          <input *ngIf=\"defaultGrpList.length==0\" type=\"checkbox\" id=\"{{st}}\" value=\"{{st}}\"\r\n                            name=\"{{st}}\" [(ngModel)]=\"stObj[st]\" [checked]=\"true\"\r\n                            (change)=\"statusWiseDisplay($event,stObj)\" />\r\n                          {{anaSttLbl[i]||st}}\r\n                        </td>\r\n                        <!-- anaSttLbl -->\r\n                        <td> {{sttWiseSummary?.get(st)?.get('count')}}</td>\r\n                        <td> {{this.cs.splitToTwoDecimal(sttWiseSummary?.get(st)?.get('wt'))}}</td>\r\n                        <td> {{this.cs.splitToTwoDecimal(sttWiseSummary?.get(st)?.get('avg'))}}</td>\r\n                        <td *ngIf=\"formname!='mixAnalysisReportForm'\"> {{this.cs.splitToTwoDecimal(sttWiseSummary?.get(st)?.get('disc'))}}</td>\r\n                        <td> {{this.cs.splitToTwoDecimal(sttWiseSummary?.get(st)?.get('rate'))}}</td>\r\n\r\n                      </tr>\r\n                    </ng-container>\r\n                  </tbody>\r\n                </table>\r\n              </div>\r\n            </div>\r\n\r\n          \r\n          \r\n            <div class=\"col-md-3\">\r\n              <div class=\"form-group w-100\">\r\n                <div class=\"col-md-5\">\r\n                  \r\n                  <select class=\"formcontrol\" name=\"viewdisType\" (change)=\"onGrpSelect(defaultGrpList)\" [(ngModel)]=\"viewdisType\">\r\n                    <option value=\"group\">Group By</option>\r\n                    <option value=\"summary\">Summary By</option>\r\n                   \r\n                </select>\r\n                </div>\r\n                <div class=\"col-md-7\">\r\n                  <div class=\"input-group w-100\">\r\n                    <ng-select placeholder=\"Select Group\" [options]=\"staticLov\" [(ngModel)]=\"defaultGrpList\"\r\n                      name=\"status\" [multiple]=\"true\" [allowClear]=\"true\" (selected)=\"onGrpSelect(defaultGrpList)\"\r\n                      (deselected)=\"onGrpSelect(defaultGrpList)\">\r\n                      <ng-template #optionTemplate let-option=\"option\">\r\n                        <div class=\"famfamfam-flags {{option?.value.toLowerCase()}}\"></div>\r\n                        {{option?.label}}\r\n                      </ng-template>\r\n                    </ng-select>\r\n                  </div>\r\n\r\n                </div>\r\n\r\n              </div>\r\n              <p>\r\n                <b>Buyer Pie chart</b>\r\n                <i title=\"Buyer wise pie chart\"\r\n                  style=\"cursor: pointer;padding: 5px;margin-left: 10px; text-align: center;font-size: 20px;color: #3a5898;\"\r\n                  type=\"button\" class=\"fa fa-pie-chart\" aria-hidden=\"true\" data-toggle=\"modal\"\r\n                  data-target=\"#PiechartModel\" (click)=\"generatePie('buyer','value')\"></i>\r\n              </p>\r\n            </div>\r\n\r\n          \r\n            <div class=\"col-md-2\">\r\n              <p *ngIf=\"defaultGrpList.length>0\">\r\n                <i title=\"Group wise chart\"\r\n                  style=\"cursor: pointer;padding: 5px;margin-left: 10px; text-align: center;font-size: 20px;color: #3a5898;\"\r\n                  type=\"button\" class=\"fa fa-pie-chart\" aria-hidden=\"true\" data-toggle=\"modal\"\r\n                  data-target=\"#PiechartModel\" (click)=\"generatePie('group','value')\"></i>\r\n              </p>\r\n              <ul class=\"cul\">\r\n                <li *ngFor=\"let legend of legendList\">\r\n                  <p\r\n                    [ngStyle]=\"{'background-color': legend.k ,'height':'9px', 'width':'9px', 'margin': '0', 'display' : 'inline-block'}\">\r\n                  </p>\r\n                  {{legend.v}}\r\n                </li>\r\n              </ul>\r\n            </div>\r\n            <div class=\"col-md-3 pull-right\">\r\n              <form class=\"form-inline pull-right\">\r\n                <div class=\"form-group\">\r\n                  <label for=\"exampleInputName2\">Search &nbsp;&nbsp;</label>\r\n                  <input type=\"text\" class=\"form-control\" id=\"exampleInputName2\" name=\"schtxt\" [(ngModel)]=\"searchF\" />\r\n                </div>\r\n                <button class=\"btn btn-default\" style=\"padding: 4px 15px 4px 20px;margin-left: 10px;float: right;\"\r\n                  data-toggle=\"tooltip\" data-placement=\"left\" title=\"Download Excel\"\r\n                  (click)=\"exportToCSV('Packet list');\">\r\n                  <span class=\"fa fa-file-excel-o\" style=\"color:green;\"></span>\r\n                </button>\r\n\r\n              </form>\r\n            </div>\r\n\r\n          </div>\r\n          \r\n          \r\n\r\n            <!-- <div class=\"col-md-2\">\r\n              <div class=\"form-group\">\r\n                <button class=\"btn btn-success\" style=\"margin-left: 5px;\" (click)=\"modifySearch()\">Modify\r\n                  Search</button>\r\n              </div>\r\n               <ul class=\"cul\">\r\n                <li *ngFor=\"let legend of legendList\">\r\n                  <p\r\n                    [ngStyle]=\"{'background-color': legend.k ,'height':'9px', 'width':'9px', 'margin': '0', 'display' : 'inline-block'}\">\r\n                  </p>\r\n                  {{legend.v}}\r\n                </li>\r\n              </ul> \r\n            </div>\r\n          </div>\r\n          -->\r\n          <div class=\"row\">\r\n          <ng-container *ngIf=\"viewdisType=='group'\">\r\n              <div *ngIf=\"groupBypktList.length >0\" class=\"table-responsive\" id=\"wrap\" style=\"overflow: auto;width: 100%;height: calc(100vh - 250px);\"\r\n                  infinite-scroll [infiniteScrollDistance]=\"scrollDistance\" [infiniteScrollUpDistance]=\"scrollUpDistance\"\r\n                  [infiniteScrollThrottle]=\"50\" (scrolled)=\"grouponScrollDown()\" [scrollWindow]=\"false\">\r\n              <table class=\"displayTable\">\r\n                <thead>\r\n                  <tr class=\"posrel\">\r\n                    <th class=\"cTh\" style=\"width:75px;\" *ngIf=\"formname!='mixAnalysisReportForm'\">\r\n                      DNA</th>\r\n                    <th style=\"text-align: center;\">Status</th>\r\n                    <th (click)=\"sortBy(hrdKey,g)\" style=\"text-align: center;\" *ngFor=\"let hrdKey of headerKey\">\r\n                      {{header[hrdKey]}}\r\n                     \r\n                    </th>\r\n                  </tr>\r\n                </thead>\r\n                <tbody>\r\n                \r\n                  <ng-container *ngFor=\"let groupdtl of loadgroupBypktList let j=index;\">\r\n                  <tr>\r\n                      <td [attr.colspan]=\"headerKey.length+1\" style=\"font-weight:bold;text-align: left; \">\r\n                        {{groupdtl.value}} &nbsp; &nbsp;\r\n                         Qty : {{groupdtl['count']}} &nbsp; &nbsp; Carats :\r\n                        {{groupdtl['crtwt']}}\r\n                        &nbsp; &nbsp; Avg :{{groupdtl['salavg']}}\r\n                        &nbsp; &nbsp; Dis% : {{groupdtl['saldis']}}\r\n\r\n                        &nbsp;&nbsp; Amount : {{groupdtl['salvlu']}} \r\n                      </td>\r\n                    </tr> \r\n                    <!-- <tr *ngIf=\"sttwise\" >\r\n                      <td [attr.colspan]=\"headerKey.length+1\" style=\"font-weight:bold;text-align: left; \">\r\n                        {{g}} &nbsp; &nbsp;\r\n                        Qty : {{finalGrpVal[g].length}} &nbsp; &nbsp; Carats :\r\n                        {{totalWeight}}\r\n\r\n                        &nbsp;&nbsp; Amount :{{totAmt}}\r\n                      </td>\r\n                    </tr> -->\r\n\r\n\r\n\r\n                    <tr *ngFor=\"let pktdtl of groupdtl['pktList'] | tableSearch:searchF:pkts;let pkti = index\"\r\n                      [ngClass]=\"{'even':pkti%2==0,'odd':pkti%2==1}\">\r\n                      <td style=\"width:75px;position: relative;\" *ngIf=\"formname!='mixAnalysisReportForm'\">\r\n                        <a href=\"https://kapugems.com/kweb/#/dna/{{pktdtl.stock_idn}}/?key={{ck}}\" target=\"_blank\">\r\n                          <i class=\"fa fa-diamond\" aria-hidden=\"true\"></i>\r\n                        </a>\r\n                        <input type=\"checkbox\" value=\"{{pktdtl.stock_idn}}\" [hidden]=\"true\" id=\"cb_{{pktdtl.stock_idn}}\"\r\n                          (click)=\"checkedRow(pktdtl,pktdtl.stock_idn,$event.target.checked)\">\r\n                      </td>\r\n                      <td style=\"text-align: center;\" [ngStyle]=\"{'color': pktdtl.dsp_stt}\">{{pktdtl.dsp_stt}}</td>\r\n                      <ng-container *ngFor=\"let hrdKey of headerKey\">\r\n                        <td *ngIf=\"hrdKey!='co' && hrdKey!='pu'\" style=\"text-align: center\" (click)=\"selectRow(pktdtl.stock_idn);\"\r\n                          [ngStyle]=\"{'color': pktdtl.dsp_stt_color == '#FFFFFF' ? 'black':pktdtl.dsp_stt_color}\">\r\n                          {{pktdtl[hrdKey]}}</td>\r\n\r\n                          <td style=\"text-align: center\" *ngIf=\"hrdKey=='co'\" (click)=\"selectRow(pktdtl.stock_idn);\"\r\n                          [ngStyle]=\"{'color': pktdtl.dsp_stt_color == '#FFFFFF' ? 'black':pktdtl.dsp_stt_color}\">\r\n                          {{pktdtl[hrdKey+\"_p\"]}}</td>\r\n\r\n\r\n\r\n                          <td style=\"text-align: center\" *ngIf=\"hrdKey=='pu'\" (click)=\"selectRow(pktdtl.stock_idn);\"\r\n                          [ngStyle]=\"{'color': pktdtl.dsp_stt_color == '#FFFFFF' ? 'black':pktdtl.dsp_stt_color}\">\r\n                          {{pktdtl[hrdKey+\"_p\"]}}</td>\r\n                      </ng-container>\r\n                    </tr>\r\n                  </ng-container>\r\n                </tbody>\r\n              </table>\r\n             </div>\r\n\r\n\r\n         \r\n           \r\n            <div *ngIf=\"pkts.length > 0 && groupBypktList.length==0 \" class=\"table-responsive\" id=\"wrap\" style=\"overflow: auto;width: 100%;height: calc(100vh - 250px);\"\r\n              infinite-scroll [infiniteScrollDistance]=\"scrollDistance\" [infiniteScrollUpDistance]=\"scrollUpDistance\"\r\n              [infiniteScrollThrottle]=\"50\" (scrolled)=\"onScrollDown()\" [scrollWindow]=\"false\">\r\n              <table class=\"displayTable\">\r\n                <thead>\r\n                  <tr class=\"posrel\">\r\n                    <th class=\"cTh\" style=\"width:75px;\" *ngIf=\"formname!='mixAnalysisReportForm'\">\r\n                      DNA</th>\r\n                      <th> \r\n                        Actions\r\n                      </th>\r\n                    <th style=\"text-align: center;\">Status</th>\r\n                    <th style=\"text-align: center;\" *ngFor=\"let hrdKey of headerKey\">{{header[hrdKey]}}</th>\r\n                  </tr>\r\n                </thead>\r\n                <tbody>\r\n                    <tr>\r\n                       <td></td>\r\n                        <td></td>\r\n                        <td><b>Average </b></td>\r\n                        <ng-container *ngFor=\"let hrdKey of headerKey\">\r\n                          <td>\r\n                            <b>{{cs.splitToTwoDecimal(TotAvgObj[hrdKey])}}</b>\r\n                          </td>\r\n    \r\n                        </ng-container>\r\n    \r\n                      </tr>\r\n                  <tr *ngFor=\"let pktdtl of loadResult | tableSearch:searchF:pkts;let pkti = index\"\r\n                    [ngClass]=\"{'even':pkti%2==0,'odd':pkti%2==1}\">\r\n                    <td style=\"width:75px;position: relative;\" *ngIf=\"formname!='mixAnalysisReportForm'\">\r\n                      <a href=\"https://kapugems.com/kweb/#/dna/{{pktdtl.stock_idn}}/?key={{ck}}\" target=\"_blank\">\r\n                        <i class=\"fa fa-diamond\" aria-hidden=\"true\"></i>\r\n                      </a>\r\n                      <input type=\"checkbox\" value=\"{{pktdtl.stock_idn}}\" [hidden]=\"true\" id=\"cb_{{pktdtl.stock_idn}}\"\r\n                        (click)=\"checkedRow(pktdtl,pktdtl.stock_idn,$event.target.checked)\">\r\n                    </td>\r\n                    <td> \r\n                      <ng-container  *ngFor=\"let lnk of links\">\r\n                          <i class=\"{{lnk.form_field_icon}}\" *ngIf=\"pktdtl.dsp_stt!='sold'\" (click)=\"OnLinkClick(lnk,pktdtl)\" aria-hidden=\"true\"></i>\r\n                          &nbsp;\r\n                      </ng-container>\r\n                      \r\n                    </td>\r\n\r\n                    <td style=\"text-align: center;\" [ngStyle]=\"{'color': pktdtl.dsp_stt}\">{{pktdtl.dsp_stt}}</td>\r\n                    <ng-container *ngFor=\"let hrdKey of headerKey\">\r\n                      <td *ngIf=\"hrdKey!='co' && hrdKey!='pu'\" style=\"text-align: center\" (click)=\"selectRow(pktdtl.stock_idn);\"\r\n                        [ngStyle]=\"{'color': pktdtl.dsp_stt_color == '#FFFFFF' ? 'black':pktdtl.dsp_stt_color}\">\r\n                        {{pktdtl[hrdKey]}}</td>\r\n\r\n                        <td style=\"text-align: center\" *ngIf=\"hrdKey=='co'\" (click)=\"selectRow(pktdtl.stock_idn);\"\r\n                        [ngStyle]=\"{'color': pktdtl.dsp_stt_color == '#FFFFFF' ? 'black':pktdtl.dsp_stt_color}\">\r\n                        {{pktdtl[hrdKey+\"_p\"]}}</td>\r\n\r\n\r\n                        <td style=\"text-align: center\"  *ngIf=\"hrdKey=='pu'\" (click)=\"selectRow(pktdtl.stock_idn);\"\r\n                        [ngStyle]=\"{'color': pktdtl.dsp_stt_color == '#FFFFFF' ? 'black':pktdtl.dsp_stt_color}\">\r\n                        {{pktdtl[hrdKey+\"_p\"]}}</td>\r\n                    </ng-container>\r\n                  </tr>\r\n                </tbody>\r\n              </table>\r\n            </div>\r\n          </ng-container>\r\n          <ng-container *ngIf=\"viewdisType=='summary' && summaryList.length>0\">\r\n              <div class=\"row\">\r\n                  <div class=\"col-md-12\"> <button  class=\"btn btn-default\"\r\n                    style=\"padding: 4px 15px 4px 20px;margin-left: 10px;\" data-toggle=\"tooltip\" data-placement=\"right\"\r\n                    title=\"Download Excel\" (click)=\"exportToCSVSummary();\">\r\n                    <span class=\"fa fa-file-excel-o\" style=\"color:green;\"></span>\r\n                  </button></div>\r\n              </div>\r\n            <div class=\"row\">\r\n              <table class=\"displayTable\" style=\"text-align: center;padding:10px ;\">\r\n                  <thead>\r\n                      <tr class=\"posrel\">\r\n                          <th style=\"text-align: center;\">Sr. No</th>\r\n                          <th style=\"text-align: center;\">Attribute</th>\r\n                          <ng-container *ngFor=\"let hdr of headList\">\r\n                              <th style=\"text-align: center;\" colspan=\"5\">{{hdr}}</th>\r\n                          </ng-container>\r\n                      </tr>\r\n                    <tr class=\"posrel\">\r\n                        <td style=\"text-align: center;\"></td>\r\n                        <ng-container *ngFor=\"let hdr of headList\">\r\n                        <td style=\"text-align: center;\">Qty</td>\r\n                        <td style=\"text-align: center;\">Carat</td>\r\n                        <td style=\"text-align: center;\">Avg</td>\r\n                        <td style=\"text-align: center;\" *ngIf=\"formname!='mixAnalysisReportForm'\">Dis</td>\r\n                        <td style=\"text-align: center;\">Value</td>\r\n                      </ng-container>\r\n                    </tr>\r\n                  </thead>\r\n                <tbody>\r\n                    <tr *ngFor=\"let summaryDtl of summaryList | tableSearch:searchF:pkts;let pkti = index\"\r\n                    [ngClass]=\"{'even':pkti%2==0,'odd':pkti%2==1}\">\r\n                    <td style=\"text-align: center;\">{{pkti+1}}</td>\r\n                    <td style=\"text-align: center;\">{{summaryDtl['value']}}</td>\r\n                    <ng-container *ngFor=\"let hdr of headList\">\r\n                    <td style=\"text-align: center;\">{{summaryDtl['count_'+hdr]}}</td>\r\n                    <td style=\"text-align: center;\">{{summaryDtl['crtwt_'+hdr]}}</td>\r\n                    <td style=\"text-align: center;\">{{summaryDtl['avg_'+hdr]}}</td>\r\n                    <td style=\"text-align: center;\" *ngIf=\"formname!='mixAnalysisReportForm'\">{{summaryDtl['dis_'+hdr]}}</td>\r\n                    <td style=\"text-align: center;\">{{summaryDtl['vlu_'+hdr]}}</td>\r\n                  </ng-container>\r\n                    </tr> \r\n\r\n                </tbody>\r\n              </table>\r\n            </div>\r\n           </ng-container>\r\n</div>\r\n\r\n          \r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div class=\"actionFooter\">\r\n      <div class=\"row\">\r\n        <div class=\"calsec pull-left\" style=\"padding: 5px;\">\r\n          <table>\r\n            <tr>\r\n              <td style=\"text-align: center;\">\r\n                <strong> Total: &nbsp; </strong>\r\n              </td>\r\n              <td style=\"text-align: center;\">\r\n                {{finalGrpVal[\"\"]?.length>0 ? finalGrpVal[\"\"]?.length : pkts?.length}}&nbsp;&nbsp;&nbsp;</td>\r\n              <td style=\"text-align: center;\">\r\n                <strong> Weight:&nbsp;</strong>\r\n              </td>\r\n              <td style=\"text-align: center;\"> {{totalWeight}}&nbsp;&nbsp;&nbsp;</td>\r\n              <td style=\"text-align: center;\">\r\n                <strong> Avg:&nbsp;</strong> </td>\r\n              <td style=\"text-align: center;\"> {{totAvg}}&nbsp;&nbsp;&nbsp;</td>\r\n\r\n              <td style=\"text-align: center;\" *ngIf=\"formname!='mixAnalysisReportForm'\">\r\n                <strong> Dis:&nbsp;</strong> </td>\r\n              <td style=\"text-align: center;\"> {{totDis}}&nbsp;&nbsp;&nbsp;</td>\r\n\r\n              <td style=\"text-align: center;\">\r\n                <strong> Amount:&nbsp;</strong> </td>\r\n              <td style=\"text-align: center;\"> {{totAmt}}</td>\r\n\r\n              <td style=\"text-align: center;\">\r\n                <strong> &nbsp;&nbsp;&nbsp;| &nbsp;&nbsp;Selected Pkts : </strong> </td>\r\n              <td style=\"text-align: center;\"> {{selectedItm?.length}}&nbsp;&nbsp;&nbsp;</td>\r\n\r\n              <td style=\"text-align: center;\">\r\n                <strong> Weight:&nbsp;</strong>\r\n              </td>\r\n              <td style=\"text-align: center;\"> {{selectwt}}&nbsp;&nbsp;&nbsp;</td>\r\n\r\n              <td style=\"text-align: center;\">\r\n                <strong> Avg:&nbsp;</strong>\r\n              </td>\r\n              <td style=\"text-align: center;\"> {{selectAvg}}&nbsp;&nbsp;&nbsp;</td>\r\n\r\n              <td style=\"text-align: center;\" *ngIf=\"formname!='mixAnalysisReportForm'\">\r\n                <strong> Disc:&nbsp;</strong>\r\n              </td>\r\n              <td style=\"text-align: center;\"> {{selectDis}}&nbsp;&nbsp;&nbsp;</td>\r\n              <td style=\"text-align: center;\">\r\n                <strong> Amount:&nbsp;</strong>\r\n              </td>\r\n              <td style=\"text-align: center;\"> {{selectAmt}}</td>\r\n\r\n            </tr>\r\n          </table>\r\n        </div>\r\n\r\n        <div>\r\n          <button class=\"btn btn-success\" style=\"margin-right: 80px;\" (click)=\"modifySearch()\">Modify\r\n            Search</button>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n\r\n\r\n\r\n\r\n  <div class=\"modal fade\" id=\"PiechartModel\" tabindex=\"-1\" role=\"dialog\" aria-labelledby=\"exampleModalLabel\"\r\n    aria-hidden=\"true\">\r\n    <div class=\"modal-dialog modal-lg\" role=\"document\"  >\r\n      <div class=\"modal-content\">\r\n        <div class=\"modal-header\">\r\n          <button type=\"button\" class=\"close\" data-dismiss=\"modal\" >\r\n            <span aria-hidden=\"true\">&times;</span>\r\n            <span class=\"sr-only\">Close</span>\r\n          </button>\r\n          <h4 class=\"modal-title\" id=\"mailModalHead\">Top {{type}} Pie Chart</h4>\r\n        </div>\r\n        <div class=\"modal-body\" >\r\n          <div class=\"row\">\r\n            <div class=\"col-md-3 pull-right\">\r\n              <div class=\"form-group\">\r\n                <button id=\"btnQty\" class=\"btn btn-default\" type=\"button\" (click)=\"generatePie(dataType,'qty')\">QTY </button>\r\n                <button id=\"btnVal\" class=\"btn btn-default\" type=\"button\" (click)=\"generatePie(dataType,'value')\">VALUE </button>\r\n              </div>\r\n            </div>\r\n          </div>\r\n         \r\n\r\n          <div class=\"card-footer row\" *ngIf=\"isBuyerwise\" >\r\n            <label class=\"control-label\"><b>&nbsp;&nbsp; &nbsp;Total sold value:\r\n                {{this.cs.splitToTwoDecimal(sttWiseSummary?.get('sold')?.get('rate'))}}</b></label>\r\n            <canvas baseChart [data]=\"doughnutChartData\"  [labels]=\"doughnutChartLabels\"  [legend]=\"pieChartLegend\"\r\n              [colors]=\"chartColors\"  [chartType]=\"doughnutChartType\" [options]=\"pie\"></canvas>\r\n          </div>\r\n         \r\n         \r\n\r\n          <div class=\"card-footer row\" *ngIf=\"isGrpwise\"  >\r\n            <label class=\"control-label\"><b>&nbsp;&nbsp; &nbsp;Total sold value:\r\n                {{this.cs.splitToTwoDecimal(sttWiseSummary?.get('sold')?.get('rate'))}}</b></label>\r\n            <canvas baseChart [data]=\"doughnutChartData\" [labels]=\"doughnutChartLabels\" [legend]=\"pieChartLegend\"\r\n              [chartType]=\"doughnutChartType\" [options]=\"pie\"></canvas>\r\n          </div>\r\n         \r\n\r\n          <!-- <div class=\"card-footer row\" *ngIf=\"isQtyWise\">\r\n            <label class=\"control-label\"><b>&nbsp;&nbsp; &nbsp;Total sold value:\r\n                {{this.cs.splitToTwoDecimal(sttWiseSummary?.get('sold')?.get('count'))}}</b></label>\r\n            <canvas baseChart [data]=\"doughnutChartData\" [labels]=\"doughnutChartLabels\" [legend]=\"pieChartLegend\"\r\n              [chartType]=\"doughnutChartType\" [options]=\"pie\"></canvas>\r\n          </div> -->\r\n\r\n        </div>\r\n        <div class=\"modal-footer\">\r\n          <button type=\"button\" class=\"btn btn-secondary btn-sm\" data-dismiss=\"modal\">Close</button>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n  <div class=\"modal fade\" id=\"bidMd\" tabindex=\"-1\" style=\"z-index: 1400\" role=\"dialog\"\r\n  aria-labelledby=\"exampleModalLabel\" aria-hidden=\"true\">\r\n  <div class=\"modal-dialog\" role=\"document\">\r\n    <form name=\"appForm\">\r\n      <div class=\"modal-content\">\r\n        <div class=\"modal-header\">\r\n          <h5 class=\"modal-title text-uppercase\" id=\"exampleModalLabel\">\r\n          Price Change</h5>\r\n          <button type=\"button\" class=\"close\" data-dismiss=\"modal\" >\r\n            <span aria-hidden=\"true\">&times;</span>\r\n            <span class=\"sr-only\">Close</span>\r\n          </button>\r\n        </div>\r\n        <div class=\"modal-body\">\r\n      \r\n          <div class=\"row\" style=\"padding:10px\">\r\n              <div class=\"col-md-12\">\r\n            <span  style=\"font-size: 16px;font-weight:bold\">{{cObj?.pkt_code}} {{cObj?.sh}} {{cObj?.crtwt}} {{cObj?.co}} {{cObj?.pu}} {{cObj?.ct}} {{cObj?.po}}  {{cObj?.sy}}  {{cObj?.fl}}</span>\r\n          \r\n\r\n            </div>\r\n           \r\n          </div>\r\n          <div class=\"row\" style=\"padding-left: 20px;padding-top: 3px\">\r\n              <div class=\"col-md-2\">\r\n                  <label class=\"clbl\" > Rap:  </label>\r\n               </div>\r\n               <div class=\"col-md-3\"><span class=\"clbl\">{{cObj?.benchmark_rte}}</span></div>\r\n               <div class=\"col-md-7\">&nbsp;</div>\r\n          </div>\r\n          <div class=\"row\" style=\"padding-left: 20px;padding-top: 3px\">\r\n           \r\n            <div class=\"col-md-2\">\r\n              <label class=\"clbl\" >Discount:</label>\r\n            </div>\r\n            <div class=\"col-md-3\">\r\n              <span class=\"clbl\">{{cObj?.rap_dis}}</span>\r\n            </div>\r\n            <div class=\"col-md-5\" style=\"text-align: left;\">\r\n                <input  type=\"text\"  (change)=\"calculatRteDis(cObj,'dis')\" style=\"width:100px\" class=\"form-control\" name=\"new_rap_dis\" [(ngModel)]=\"cObj['new_rap_dis']\" />\r\n\r\n            </div>\r\n          </div>\r\n          <div class=\"row\" style=\"padding-left: 20px;padding-top: 3px\">\r\n            <div class=\"col-md-2\">\r\n              <label class=\"clbl\" style=\"text-align: right;\">Price:</label>\r\n            </div>\r\n            <div class=\"col-md-3\">\r\n              <span class=\"clbl\">{{cObj?.rte}}</span>\r\n            </div>\r\n            <div class=\"col-md-5\">\r\n                <input  type=\"text\"  (change)=\"calculatRteDis(cObj,'rte')\" style=\"width:100px\" class=\"form-control\" name=\"new_rte\" [(ngModel)]=\"cObj['new_rte']\" />\r\n\r\n            </div>\r\n           \r\n          </div>\r\n      \r\n        </div>\r\n        <div class=\"modal-footer\">\r\n          <button type=\"button\" class=\"btn btn-default\" data-dismiss=\"modal\" >Close</button>\r\n          <button type=\"button\" class=\"btn btn-success\" data-dismiss=\"modal\" appAppNoDblClick\r\n              (click)=\"ChangesPrice()\">Update Price</button>\r\n         </div>\r\n      </div>\r\n    </form>\r\n  </div>\r\n</div> \r\n<button id=\"bidMdBBtn\" [hidden]=\"true\" data-toggle=\"modal\" data-target=\"#bidMd\"></button>\r\n\r\n  <button id=\"PiechartModelBtn\" [hidden]=\"true\" data-toggle=\"modal\" data-target=\"#PiechartModel\"></button>\r\n\r\n\r\n</div>"]}