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