gamma-app-controller 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +24 -0
- package/esm2020/gamma-app-controller.mjs +2 -0
- package/esm2020/lib/application-controller/app.http.service.mjs +24 -0
- package/esm2020/lib/application-controller/application-content.service.mjs +482 -0
- package/esm2020/lib/application-controller/application-controller.module.mjs +324 -0
- package/esm2020/lib/application-controller/application-dataset-call.service.mjs +321 -0
- package/esm2020/lib/application-controller/application-dataset-component/application-dataset/application-dataset.component.mjs +390 -0
- package/esm2020/lib/application-controller/application-dataset-component/create-dataset/create-dataset.component.mjs +349 -0
- package/esm2020/lib/application-controller/application-dataset-component/create-dataset-json/create-dataset-json.component.mjs +148 -0
- package/esm2020/lib/application-controller/application-dataset-component/create-dataset-sql/create-dataset-sql.component.mjs +167 -0
- package/esm2020/lib/application-controller/application-dataset-component/create-dataset-sql/sqlFormatter.mjs +17 -0
- package/esm2020/lib/application-controller/application-dataset-component/dataset-mongo/dataset-mongo.component.mjs +57 -0
- package/esm2020/lib/application-controller/application-dataset-component/dataset-query-bulder/dataset-query-bulder.component.mjs +409 -0
- package/esm2020/lib/application-controller/application-dataset-component/dataset-rest-api/dataset-rest-api.component.mjs +61 -0
- package/esm2020/lib/application-controller/application-filter/application-filter.component.mjs +186 -0
- package/esm2020/lib/application-controller/application-view-components/application-views/application-views.component.mjs +134 -0
- package/esm2020/lib/application-controller/application-view-components/create-comp-view/create-comp-view.component.mjs +559 -0
- package/esm2020/lib/application-controller/common-header/common-header.component.mjs +33 -0
- package/esm2020/lib/application-controller/common.mjs +1207 -0
- package/esm2020/lib/application-controller/environment.mjs +26 -0
- package/esm2020/lib/application-controller/kpi-comon-service.mjs +537 -0
- package/esm2020/lib/application-controller/kpi-service.mjs +108 -0
- package/esm2020/lib/application-controller/loading/loading.component.mjs +16 -0
- package/esm2020/lib/application-controller/loading/loadingModule.mjs +28 -0
- package/esm2020/lib/application-controller/moment-helper.mjs +4 -0
- package/esm2020/lib/application-controller/page-controller/page-config/page-config.component.mjs +977 -0
- package/esm2020/lib/application-controller/page-controller/page-controller/page-controller.component.mjs +172 -0
- package/esm2020/lib/application-controller/page-templates/cdr-config/cdr-config.component.mjs +227 -0
- package/esm2020/lib/application-controller/page-templates/dynamic-route-service.mjs +22 -0
- package/esm2020/lib/application-controller/shared/advanced-component/advance-widget-header-filter/advance-widget-header-filter.component.mjs +118 -0
- package/esm2020/lib/application-controller/shared/advanced-component/app-advance-header/app-header.component.mjs +181 -0
- package/esm2020/lib/application-controller/shared/advanced-component/gamm-single-number-card/gamm-single-number-card.component.mjs +71 -0
- package/esm2020/lib/application-controller/shared/advanced-component/gamma-advance-chart/gamma-advance-chart.component.mjs +266 -0
- package/esm2020/lib/application-controller/shared/advanced-component/gamma-advance-operator-table/gamma-advance-operator-table.component.mjs +159 -0
- package/esm2020/lib/application-controller/shared/advanced-component/gamma-table-clumn-bar-chart/gamma-table-clumn-bar-chart.component.mjs +144 -0
- package/esm2020/lib/application-controller/shared/advanced-component/gamma-table-with-percentage/contentSafeHtml.mjs +20 -0
- package/esm2020/lib/application-controller/shared/advanced-component/gamma-table-with-percentage/gamma-table-with-percentage.component.mjs +168 -0
- package/esm2020/lib/application-controller/shared/advanced-component/gamma-today-previous/gamma-today-previous.component.mjs +74 -0
- package/esm2020/lib/application-controller/shared/advanced-component/google-geo-map/google-geo-map.component.mjs +118 -0
- package/esm2020/lib/application-controller/shared/api.service.mjs +117 -0
- package/esm2020/lib/application-controller/shared/app-title/app-title.component.mjs +67 -0
- package/esm2020/lib/application-controller/shared/gamam-widget/gamam-widget.component.mjs +37 -0
- package/esm2020/lib/application-controller/shared/gamma-advance-filter/gamma-advance-filter.component.mjs +229 -0
- package/esm2020/lib/application-controller/shared/gamma-bread-crumbs/bread-crumbs.component.mjs +144 -0
- package/esm2020/lib/application-controller/shared/kpi-comon-service.mjs +537 -0
- package/esm2020/lib/application-controller/shared/loader/loader.component.mjs +14 -0
- package/esm2020/lib/application-controller/shared/loading/loading.component.mjs +16 -0
- package/esm2020/lib/application-controller/shared/loading/loadingModule.mjs +28 -0
- package/esm2020/lib/application-controller/shared/safeHtmlPipe.mjs +20 -0
- package/esm2020/lib/application-controller/support-components/dash-chart/dash-chart.component.mjs +294 -0
- package/esm2020/lib/application-controller/support-components/dash-table/dash-table.component.mjs +287 -0
- package/esm2020/lib/application-controller/support-components/geo-map/geo-map.component.mjs +255 -0
- package/esm2020/lib/application-controller/support-components/table-with-bar/table-with-bar.component.mjs +269 -0
- package/esm2020/lib/gamma-app-controller.component.mjs +16 -0
- package/esm2020/lib/gamma-app-controller.module.mjs +43 -0
- package/esm2020/lib/gamma-app-controller.service.mjs +20 -0
- package/esm2020/lib/icons.module.mjs +23 -0
- package/esm2020/public-api.mjs +49 -0
- package/fesm2015/gamma-app-controller.mjs +10250 -0
- package/fesm2015/gamma-app-controller.mjs.map +1 -0
- package/fesm2020/gamma-app-controller.mjs +10248 -0
- package/fesm2020/gamma-app-controller.mjs.map +1 -0
- package/index.d.ts +2 -0
- package/lib/application-controller/app.http.service.d.ts +15 -0
- package/lib/application-controller/application-content.service.d.ts +79 -0
- package/lib/application-controller/application-controller.module.d.ts +51 -0
- package/lib/application-controller/application-dataset-call.service.d.ts +20 -0
- package/lib/application-controller/application-dataset-component/application-dataset/application-dataset.component.d.ts +55 -0
- package/lib/application-controller/application-dataset-component/create-dataset/create-dataset.component.d.ts +121 -0
- package/lib/application-controller/application-dataset-component/create-dataset-json/create-dataset-json.component.d.ts +38 -0
- package/lib/application-controller/application-dataset-component/create-dataset-sql/create-dataset-sql.component.d.ts +42 -0
- package/lib/application-controller/application-dataset-component/create-dataset-sql/sqlFormatter.d.ts +7 -0
- package/lib/application-controller/application-dataset-component/dataset-mongo/dataset-mongo.component.d.ts +21 -0
- package/lib/application-controller/application-dataset-component/dataset-query-bulder/dataset-query-bulder.component.d.ts +62 -0
- package/lib/application-controller/application-dataset-component/dataset-rest-api/dataset-rest-api.component.d.ts +22 -0
- package/lib/application-controller/application-filter/application-filter.component.d.ts +36 -0
- package/lib/application-controller/application-view-components/application-views/application-views.component.d.ts +47 -0
- package/lib/application-controller/application-view-components/create-comp-view/create-comp-view.component.d.ts +73 -0
- package/lib/application-controller/common-header/common-header.component.d.ts +15 -0
- package/lib/application-controller/common.d.ts +148 -0
- package/lib/application-controller/environment.d.ts +25 -0
- package/lib/application-controller/kpi-comon-service.d.ts +14 -0
- package/lib/application-controller/kpi-service.d.ts +6 -0
- package/lib/application-controller/loading/loading.component.d.ts +9 -0
- package/lib/application-controller/loading/loadingModule.d.ts +10 -0
- package/lib/application-controller/moment-helper.d.ts +3 -0
- package/lib/application-controller/page-controller/page-config/page-config.component.d.ts +188 -0
- package/lib/application-controller/page-controller/page-controller/page-controller.component.d.ts +47 -0
- package/lib/application-controller/page-templates/cdr-config/cdr-config.component.d.ts +44 -0
- package/lib/application-controller/page-templates/dynamic-route-service.d.ts +8 -0
- package/lib/application-controller/shared/advanced-component/advance-widget-header-filter/advance-widget-header-filter.component.d.ts +33 -0
- package/lib/application-controller/shared/advanced-component/app-advance-header/app-header.component.d.ts +43 -0
- package/lib/application-controller/shared/advanced-component/gamm-single-number-card/gamm-single-number-card.component.d.ts +20 -0
- package/lib/application-controller/shared/advanced-component/gamma-advance-chart/gamma-advance-chart.component.d.ts +51 -0
- package/lib/application-controller/shared/advanced-component/gamma-advance-operator-table/gamma-advance-operator-table.component.d.ts +32 -0
- package/lib/application-controller/shared/advanced-component/gamma-table-clumn-bar-chart/gamma-table-clumn-bar-chart.component.d.ts +31 -0
- package/lib/application-controller/shared/advanced-component/gamma-table-with-percentage/contentSafeHtml.d.ts +10 -0
- package/lib/application-controller/shared/advanced-component/gamma-table-with-percentage/gamma-table-with-percentage.component.d.ts +26 -0
- package/lib/application-controller/shared/advanced-component/gamma-today-previous/gamma-today-previous.component.d.ts +21 -0
- package/lib/application-controller/shared/advanced-component/google-geo-map/google-geo-map.component.d.ts +29 -0
- package/lib/application-controller/shared/api.service.d.ts +26 -0
- package/lib/application-controller/shared/app-title/app-title.component.d.ts +28 -0
- package/lib/application-controller/shared/gamam-widget/gamam-widget.component.d.ts +20 -0
- package/lib/application-controller/shared/gamma-advance-filter/gamma-advance-filter.component.d.ts +45 -0
- package/lib/application-controller/shared/gamma-bread-crumbs/bread-crumbs.component.d.ts +32 -0
- package/lib/application-controller/shared/kpi-comon-service.d.ts +14 -0
- package/lib/application-controller/shared/loader/loader.component.d.ts +8 -0
- package/lib/application-controller/shared/loading/loading.component.d.ts +9 -0
- package/lib/application-controller/shared/loading/loadingModule.d.ts +10 -0
- package/lib/application-controller/shared/safeHtmlPipe.d.ts +10 -0
- package/lib/application-controller/support-components/dash-chart/dash-chart.component.d.ts +83 -0
- package/lib/application-controller/support-components/dash-table/dash-table.component.d.ts +67 -0
- package/lib/application-controller/support-components/geo-map/geo-map.component.d.ts +70 -0
- package/lib/application-controller/support-components/table-with-bar/table-with-bar.component.d.ts +70 -0
- package/lib/gamma-app-controller.component.d.ts +5 -0
- package/lib/gamma-app-controller.module.d.ts +10 -0
- package/lib/gamma-app-controller.service.d.ts +7 -0
- package/lib/icons.module.d.ts +11 -0
- package/package.json +33 -0
- package/public-api.d.ts +48 -0
|
@@ -0,0 +1,409 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../../common";
|
|
4
|
+
import * as i2 from "ngx-toastr";
|
|
5
|
+
import * as i3 from "../../application-content.service";
|
|
6
|
+
import * as i4 from "@angular/common";
|
|
7
|
+
import * as i5 from "devextreme-angular/ui/check-box";
|
|
8
|
+
import * as i6 from "devextreme-angular/ui/select-box";
|
|
9
|
+
import * as i7 from "devextreme-angular/ui/text-box";
|
|
10
|
+
import * as i8 from "@angular/forms";
|
|
11
|
+
export class DatasetQueryBulderComponent {
|
|
12
|
+
constructor(commonService, toastr, service) {
|
|
13
|
+
this.commonService = commonService;
|
|
14
|
+
this.toastr = toastr;
|
|
15
|
+
this.service = service;
|
|
16
|
+
this.reqFieldsDataSource = [];
|
|
17
|
+
this.isreqFields = false;
|
|
18
|
+
this.iscdrParams = false;
|
|
19
|
+
this.cdrFieldsDataSource = [];
|
|
20
|
+
this.kpi_function = ["sum", "count", "avg", "max", "min", "stddev", "count_distinct"];
|
|
21
|
+
this.kpi_operator = ["eq", "gte", "lte", "ne", "in", "notIn", "contains", "startsWith", "endsWith"];
|
|
22
|
+
this.kpi_enrichment_name = [];
|
|
23
|
+
this.reqShortDataSource = [];
|
|
24
|
+
this.filterMapingDatasource = [];
|
|
25
|
+
this.isModelVisible = false;
|
|
26
|
+
this.isSqlCopiedText = false;
|
|
27
|
+
this.isReconColume = false;
|
|
28
|
+
this.getQueryBulbderDataSet = new EventEmitter();
|
|
29
|
+
this.reconColumeDatasource = [];
|
|
30
|
+
this.isQueryTypeSelect = false;
|
|
31
|
+
}
|
|
32
|
+
set bulderDataset(value) {
|
|
33
|
+
if (value.queryConfig.reqFields && value.queryConfig.reqFields.length < 2) {
|
|
34
|
+
this.reqFieldsDataSource = [
|
|
35
|
+
{
|
|
36
|
+
"name": "pageNumber",
|
|
37
|
+
"value": 1,
|
|
38
|
+
},
|
|
39
|
+
{
|
|
40
|
+
"name": "pageSize",
|
|
41
|
+
"value": 2010,
|
|
42
|
+
},
|
|
43
|
+
{
|
|
44
|
+
"name": "dbConfig",
|
|
45
|
+
"value": "",
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
"name": "databaseName",
|
|
49
|
+
"value": "",
|
|
50
|
+
},
|
|
51
|
+
{
|
|
52
|
+
"name": "tableName",
|
|
53
|
+
"value": "",
|
|
54
|
+
},
|
|
55
|
+
{
|
|
56
|
+
"name": "paginationRequired",
|
|
57
|
+
"value": "false",
|
|
58
|
+
}
|
|
59
|
+
];
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
this.reqFieldsDataSource = this.processParamsformatData(value.queryConfig.reqFields);
|
|
63
|
+
this.selectedDataSource = value.queryConfig.reqFields.find(item => item.dbConfig !== undefined)?.dbConfig;
|
|
64
|
+
this.isQueryTypeSelect = true;
|
|
65
|
+
}
|
|
66
|
+
if (value.queryConfig.mapedFilters == undefined) {
|
|
67
|
+
value.queryConfig.mapedFilters = [];
|
|
68
|
+
value.queryConfig.mapedFilters.push({ "localColumn": "", "serverColumn": "", "operatorName": "", "defaultValue": "", "dataType": "" });
|
|
69
|
+
}
|
|
70
|
+
if (value.queryConfig.sorters == undefined) {
|
|
71
|
+
value.queryConfig.sorters = [];
|
|
72
|
+
value.queryConfig.sorters.push({ "columnName": "", "descending": false });
|
|
73
|
+
}
|
|
74
|
+
if (value.queryConfig.columns == undefined) {
|
|
75
|
+
value.queryConfig.columns = [];
|
|
76
|
+
let obj = {
|
|
77
|
+
"measures": true,
|
|
78
|
+
"dataField": "",
|
|
79
|
+
"columnName": "",
|
|
80
|
+
"functionName": "",
|
|
81
|
+
"enrichFunction": "",
|
|
82
|
+
"advancedColumn": "",
|
|
83
|
+
"caption": "",
|
|
84
|
+
};
|
|
85
|
+
value.queryConfig.columns.push(obj);
|
|
86
|
+
}
|
|
87
|
+
if (value.queryConfig.havings == undefined) {
|
|
88
|
+
value.queryConfig.havings = [];
|
|
89
|
+
}
|
|
90
|
+
this.queryBulderDataset = value;
|
|
91
|
+
}
|
|
92
|
+
ngOnInit() {
|
|
93
|
+
this.service.listColumnEnrichmentFunctions().subscribe(data => {
|
|
94
|
+
this.kpi_enrichment_name = data;
|
|
95
|
+
});
|
|
96
|
+
this.reconColumeDatasource = [
|
|
97
|
+
{
|
|
98
|
+
"dataField": "",
|
|
99
|
+
"enrichFunction": "",
|
|
100
|
+
"columeOne": "",
|
|
101
|
+
"columeTwo": "",
|
|
102
|
+
"reconType": "",
|
|
103
|
+
"caption": ""
|
|
104
|
+
}
|
|
105
|
+
];
|
|
106
|
+
}
|
|
107
|
+
processParamsformatData(data) {
|
|
108
|
+
const formatted_data = data.map(item => {
|
|
109
|
+
const [name, value] = Object.entries(item)[0];
|
|
110
|
+
return {
|
|
111
|
+
name,
|
|
112
|
+
value: name === 'paginationRequired' ? value.toString() : value
|
|
113
|
+
};
|
|
114
|
+
});
|
|
115
|
+
return formatted_data;
|
|
116
|
+
}
|
|
117
|
+
addColumns() {
|
|
118
|
+
let obj = {
|
|
119
|
+
"measures": true,
|
|
120
|
+
"dataField": "",
|
|
121
|
+
"columnName": "",
|
|
122
|
+
"functionName": "",
|
|
123
|
+
"advancedColumn": "",
|
|
124
|
+
"enrichFunction": "",
|
|
125
|
+
"caption": "",
|
|
126
|
+
};
|
|
127
|
+
this.queryBulderDataset.queryConfig.columns.push(obj);
|
|
128
|
+
}
|
|
129
|
+
deleteColumns(i) {
|
|
130
|
+
this.queryBulderDataset.queryConfig.columns.splice(i, 1);
|
|
131
|
+
}
|
|
132
|
+
addReconColume() {
|
|
133
|
+
let obj = {
|
|
134
|
+
"dataField": "",
|
|
135
|
+
"columeOne": "",
|
|
136
|
+
"columeTwo": "",
|
|
137
|
+
"enrichFunction": "",
|
|
138
|
+
"reconType": "",
|
|
139
|
+
"caption": ""
|
|
140
|
+
};
|
|
141
|
+
this.reconColumeDatasource.push(obj);
|
|
142
|
+
}
|
|
143
|
+
deleteReconColume(i) {
|
|
144
|
+
this.reconColumeDatasource.splice(i, 1);
|
|
145
|
+
}
|
|
146
|
+
saveReconsColume() {
|
|
147
|
+
this.reconColumeDatasource.forEach(element => {
|
|
148
|
+
if (element.reconType == "variance") {
|
|
149
|
+
let columeString = "{'$subtract': ['$" + element.columeOne + "','$" + element.columeTwo + "']}";
|
|
150
|
+
let node = {
|
|
151
|
+
"measures": true,
|
|
152
|
+
"dataField": element.dataField,
|
|
153
|
+
"columnName": element.dataField,
|
|
154
|
+
"functionName": "",
|
|
155
|
+
"advancedColumn": columeString,
|
|
156
|
+
"enrichFunction": element.enrichFunction,
|
|
157
|
+
"caption": element.caption,
|
|
158
|
+
'deriveField': true
|
|
159
|
+
};
|
|
160
|
+
this.queryBulderDataset.queryConfig.columns.push(node);
|
|
161
|
+
console.log(columeString);
|
|
162
|
+
}
|
|
163
|
+
else if (element.reconType == "percentage") {
|
|
164
|
+
let columeString = "{'$cond': { if: { $eq: [ '$" + element.columeOne + "', 0 ] }, then: 0, else: {'$divide':[{'$subtract': ['$" + element.columeOne + "','$" + element.columeTwo + "']},'$" + element.columeOne + "']} }}";
|
|
165
|
+
let node = {
|
|
166
|
+
"measures": true,
|
|
167
|
+
"dataField": element.dataField,
|
|
168
|
+
"columnName": element.dataField,
|
|
169
|
+
"functionName": "",
|
|
170
|
+
"advancedColumn": columeString,
|
|
171
|
+
"enrichFunction": element.enrichFunction,
|
|
172
|
+
"caption": element.caption,
|
|
173
|
+
'deriveField': true
|
|
174
|
+
};
|
|
175
|
+
this.queryBulderDataset.queryConfig.columns.push(node);
|
|
176
|
+
}
|
|
177
|
+
else if (element.reconType == "absolute") {
|
|
178
|
+
let columeString = "{'$abs': {'$cond': { if: { $eq: [ '$" + element.columeOne + "', 0 ] }, then: 0, else: {'$divide': [{'$subtract': ['$" + element.columeOne + "', '$" + element.columeTwo + "']}, '$" + element.columeOne + "']}}}}";
|
|
179
|
+
let node = {
|
|
180
|
+
"measures": true,
|
|
181
|
+
"dataField": element.dataField,
|
|
182
|
+
"columnName": element.dataField,
|
|
183
|
+
"functionName": "",
|
|
184
|
+
"advancedColumn": columeString,
|
|
185
|
+
"enrichFunction": element.enrichFunction,
|
|
186
|
+
"caption": element.caption,
|
|
187
|
+
'deriveField': true
|
|
188
|
+
};
|
|
189
|
+
this.queryBulderDataset.queryConfig.columns.push(node);
|
|
190
|
+
}
|
|
191
|
+
});
|
|
192
|
+
}
|
|
193
|
+
saveColumnsAndMasures() {
|
|
194
|
+
this.queryBulderDataset.queryConfig.measures = [];
|
|
195
|
+
this.queryBulderDataset.queryConfig.dimensions = [];
|
|
196
|
+
this.queryBulderDataset.queryConfig.columns.forEach(element => {
|
|
197
|
+
const advancedColumnValue = element.advancedColumn === "" ? null : element.advancedColumn;
|
|
198
|
+
if (element.measures) {
|
|
199
|
+
let obj = {
|
|
200
|
+
columnName: element.columnName,
|
|
201
|
+
functionName: element.functionName,
|
|
202
|
+
enrichFunction: element.enrichFunction,
|
|
203
|
+
advancedColumn: advancedColumnValue,
|
|
204
|
+
aliasName: element.dataField,
|
|
205
|
+
};
|
|
206
|
+
if (element.deriveField) {
|
|
207
|
+
obj['deriveField'] = element.deriveField;
|
|
208
|
+
}
|
|
209
|
+
this.queryBulderDataset.queryConfig.measures.push(obj);
|
|
210
|
+
}
|
|
211
|
+
else {
|
|
212
|
+
let obj = {
|
|
213
|
+
columnName: element.columnName,
|
|
214
|
+
enrichFunction: element.enrichFunction,
|
|
215
|
+
aliasName: element.dataField,
|
|
216
|
+
};
|
|
217
|
+
this.queryBulderDataset.queryConfig.dimensions.push(obj);
|
|
218
|
+
}
|
|
219
|
+
});
|
|
220
|
+
this.toastr.success('Columns Saved Successfully');
|
|
221
|
+
}
|
|
222
|
+
saveDataToStore() {
|
|
223
|
+
const buildDate = localStorage.getItem('querybuilder');
|
|
224
|
+
if (buildDate) {
|
|
225
|
+
localStorage.removeItem(buildDate);
|
|
226
|
+
}
|
|
227
|
+
localStorage.setItem('querybuilder', JSON.stringify(this.queryBulderDataset));
|
|
228
|
+
}
|
|
229
|
+
transformColumnsForMesurs(inputColumns) {
|
|
230
|
+
const measure = [];
|
|
231
|
+
inputColumns.forEach(col => {
|
|
232
|
+
});
|
|
233
|
+
return measure;
|
|
234
|
+
}
|
|
235
|
+
addFilter() {
|
|
236
|
+
let obj = {
|
|
237
|
+
"type": "",
|
|
238
|
+
"value": "",
|
|
239
|
+
"key": "",
|
|
240
|
+
"display": "",
|
|
241
|
+
"placeholder": ""
|
|
242
|
+
};
|
|
243
|
+
this.queryBulderDataset.queryConfig.filter.push(obj);
|
|
244
|
+
}
|
|
245
|
+
deleteFilter(i) {
|
|
246
|
+
this.queryBulderDataset.queryConfig.filter.splice(i, 1);
|
|
247
|
+
}
|
|
248
|
+
addParams() {
|
|
249
|
+
let obj = {
|
|
250
|
+
"name": "",
|
|
251
|
+
"value": "",
|
|
252
|
+
};
|
|
253
|
+
this.reqFieldsDataSource.push(obj);
|
|
254
|
+
}
|
|
255
|
+
deleteParams(i) {
|
|
256
|
+
this.reqFieldsDataSource.splice(i, 1);
|
|
257
|
+
}
|
|
258
|
+
addShortColumns() {
|
|
259
|
+
this.queryBulderDataset.queryConfig.sorters.push({ "columnName": "", "descending": false });
|
|
260
|
+
}
|
|
261
|
+
deleteShortColumns(i) {
|
|
262
|
+
this.queryBulderDataset.queryConfig.sorters.splice(i, 1);
|
|
263
|
+
}
|
|
264
|
+
saveParams() {
|
|
265
|
+
let paginationRequiredExists = false;
|
|
266
|
+
this.queryBulderDataset.queryConfig.reqFields = this.reqFieldsDataSource.map(item => {
|
|
267
|
+
const newObj = {};
|
|
268
|
+
if (item.name === "paginationRequired") {
|
|
269
|
+
paginationRequiredExists = true;
|
|
270
|
+
newObj[item.name] = item.value === "true";
|
|
271
|
+
}
|
|
272
|
+
else if (typeof item.value === "string" && !isNaN(item.value) && item.value.trim() !== "") {
|
|
273
|
+
newObj[item.name] = Number(item.value);
|
|
274
|
+
}
|
|
275
|
+
else {
|
|
276
|
+
newObj[item.name] = item.value;
|
|
277
|
+
}
|
|
278
|
+
return newObj;
|
|
279
|
+
});
|
|
280
|
+
if (!paginationRequiredExists) {
|
|
281
|
+
this.queryBulderDataset.queryConfig.reqFields.push({ paginationRequired: "false" });
|
|
282
|
+
}
|
|
283
|
+
this.toastr.success('Pagination Request Params Saved Successfully');
|
|
284
|
+
}
|
|
285
|
+
addFilterMapingColumns() {
|
|
286
|
+
let obj = { "localColumn": "", "serverColumn": "", "operatorName": "", "defaultValue": "", "dataType": "" };
|
|
287
|
+
this.queryBulderDataset.queryConfig.mapedFilters.push(obj);
|
|
288
|
+
}
|
|
289
|
+
deleteFilterMapingColumns(i) {
|
|
290
|
+
this.queryBulderDataset.queryConfig.mapedFilters.splice(i, 1);
|
|
291
|
+
}
|
|
292
|
+
moveItemForColumns(index, direction) {
|
|
293
|
+
if (index < 0 || index >= this.queryBulderDataset.queryConfig.mapedFilters.length)
|
|
294
|
+
return;
|
|
295
|
+
const newPosition = direction === 'up' ? index - 1 : index + 1;
|
|
296
|
+
if (newPosition < 0 || newPosition >= this.queryBulderDataset.queryConfig.mapedFilters.length)
|
|
297
|
+
return;
|
|
298
|
+
const itemToMove = this.queryBulderDataset.queryConfig.mapedFilters[index];
|
|
299
|
+
this.queryBulderDataset.queryConfig.mapedFilters.splice(index, 1);
|
|
300
|
+
this.queryBulderDataset.queryConfig.mapedFilters.splice(newPosition, 0, itemToMove);
|
|
301
|
+
}
|
|
302
|
+
moveItemForMeasuresColumns(index, direction) {
|
|
303
|
+
if (index < 0 || index >= this.queryBulderDataset.queryConfig.columns.length)
|
|
304
|
+
return;
|
|
305
|
+
const newPosition = direction === 'up' ? index - 1 : index + 1;
|
|
306
|
+
if (newPosition < 0 || newPosition >= this.queryBulderDataset.queryConfig.columns.length)
|
|
307
|
+
return;
|
|
308
|
+
const itemToMove = this.queryBulderDataset.queryConfig.columns[index];
|
|
309
|
+
this.queryBulderDataset.queryConfig.columns.splice(index, 1);
|
|
310
|
+
this.queryBulderDataset.queryConfig.columns.splice(newPosition, 0, itemToMove);
|
|
311
|
+
}
|
|
312
|
+
checkForQuery() {
|
|
313
|
+
let transformedObject = {};
|
|
314
|
+
for (let item of this.queryBulderDataset.queryConfig.reqFields) {
|
|
315
|
+
const key = Object.keys(item)[0];
|
|
316
|
+
const value = Object.values(item)[0];
|
|
317
|
+
if (key === 'startDate') {
|
|
318
|
+
transformedObject.recordDate = value;
|
|
319
|
+
}
|
|
320
|
+
else {
|
|
321
|
+
transformedObject[key] = value;
|
|
322
|
+
}
|
|
323
|
+
}
|
|
324
|
+
transformedObject['dimensions'] = this.queryBulderDataset.queryConfig.dimensions;
|
|
325
|
+
transformedObject['measures'] = this.queryBulderDataset.queryConfig.measures;
|
|
326
|
+
transformedObject['filters'] = this.transformDataForMFilter(this.queryBulderDataset.queryConfig.mapedFilters);
|
|
327
|
+
;
|
|
328
|
+
transformedObject['sorters'] = this.queryBulderDataset.queryConfig.sorters;
|
|
329
|
+
transformedObject["paginationRequired"] = true;
|
|
330
|
+
console.log(transformedObject);
|
|
331
|
+
this.service.validateAggregatePaginatedQuery(transformedObject).subscribe(data => {
|
|
332
|
+
console.log(data);
|
|
333
|
+
this.query_data = data.query;
|
|
334
|
+
this.isModelVisible = true;
|
|
335
|
+
}, err => {
|
|
336
|
+
this.toastr.error('Unexpected Server Exception. Please contact System Admin.');
|
|
337
|
+
});
|
|
338
|
+
}
|
|
339
|
+
closeModalVisibleModal() {
|
|
340
|
+
this.isModelVisible = false;
|
|
341
|
+
this.query_data = '';
|
|
342
|
+
}
|
|
343
|
+
transformDataForMFilter(mapfilter) {
|
|
344
|
+
let result = [];
|
|
345
|
+
mapfilter.forEach(mapping => {
|
|
346
|
+
let resultObj = {
|
|
347
|
+
columnName: mapping.serverColumn,
|
|
348
|
+
dataType: mapping.dataType,
|
|
349
|
+
operator: mapping.operatorName,
|
|
350
|
+
value: mapping.defaultValue
|
|
351
|
+
};
|
|
352
|
+
result.push(resultObj);
|
|
353
|
+
});
|
|
354
|
+
return result;
|
|
355
|
+
}
|
|
356
|
+
copySqlFromModal() {
|
|
357
|
+
const listener = (e) => {
|
|
358
|
+
e.clipboardData.setData('text/plain', this.query_data);
|
|
359
|
+
e.preventDefault();
|
|
360
|
+
};
|
|
361
|
+
this.isSqlCopiedText = true;
|
|
362
|
+
document.addEventListener('copy', listener);
|
|
363
|
+
document.execCommand('copy');
|
|
364
|
+
document.removeEventListener('copy', listener);
|
|
365
|
+
}
|
|
366
|
+
createDataSet() {
|
|
367
|
+
this.getQueryBulbderDataSet.emit(this.queryBulderDataset);
|
|
368
|
+
}
|
|
369
|
+
getQueryForDetailsData(e) {
|
|
370
|
+
if (e.value == 'Basic') {
|
|
371
|
+
this.queryBulderDataset.api = '/kpi/genericDetailDataResponse';
|
|
372
|
+
this.queryBulderDataset.queryConfig.columns = [];
|
|
373
|
+
}
|
|
374
|
+
else {
|
|
375
|
+
this.queryBulderDataset.api = '/kpi/genericAggregatePaginatedKpiServiceResponse';
|
|
376
|
+
}
|
|
377
|
+
}
|
|
378
|
+
getDataConfig(e) {
|
|
379
|
+
if (e.event) {
|
|
380
|
+
this.selectedDataSource = e.value;
|
|
381
|
+
this.isQueryTypeSelect = true;
|
|
382
|
+
}
|
|
383
|
+
}
|
|
384
|
+
addHavingsColume() {
|
|
385
|
+
let obj = {
|
|
386
|
+
"columnName": "",
|
|
387
|
+
"advancedColumn": "",
|
|
388
|
+
"dataType": "",
|
|
389
|
+
"operator": "",
|
|
390
|
+
"value": ""
|
|
391
|
+
};
|
|
392
|
+
this.queryBulderDataset.queryConfig.havings.push(obj);
|
|
393
|
+
}
|
|
394
|
+
deleteHavingsColume(i) {
|
|
395
|
+
this.queryBulderDataset.queryConfig.havings.splice(i, 1);
|
|
396
|
+
}
|
|
397
|
+
}
|
|
398
|
+
DatasetQueryBulderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: DatasetQueryBulderComponent, deps: [{ token: i1.CommonService }, { token: i2.ToastrService }, { token: i3.ApplicationContentService }], target: i0.ɵɵFactoryTarget.Component });
|
|
399
|
+
DatasetQueryBulderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.3", type: DatasetQueryBulderComponent, selector: "app-dataset-query-bulder", inputs: { bulderDataset: "bulderDataset" }, outputs: { getQueryBulbderDataSet: "getQueryBulbderDataSet" }, ngImport: i0, template: "<div class=\"m-2\">\n <div class=\"flex flex-row mb-2\">\n <div class=\"mx-2 w-1/3\">\n <div class=\"text-md mb-2\">End Point</div>\n <dx-text-box [(ngModel)]=\"queryBulderDataset.api\"></dx-text-box>\n </div>\n <div class=\"mx-2 w-1/3\">\n <div class=\"text-md mb-2\">Query Type</div>\n <dx-select-box [dataSource]=\"['Aggregate','Basic']\" (onValueChanged)=\"getQueryForDetailsData($event)\">\n </dx-select-box>\n </div>\n <div class=\"mx-2 w-1/3 mt-6\" *ngIf=\"selectedDataSource == 'mongo'\">\n <dx-check-box [(ngModel)]=\"isReconColume\" text='Recon Column'>\n </dx-check-box>\n </div>\n </div>\n\n <div class=\"flex flex-col flex-auto min-w-0 my-3\">\n <div class=\"text-lg py-2 font-extrabold border-b bg-gray-700 text-white px-2\"> Request Params\n </div>\n <div class=\"pt-2 border-x border-b \">\n <div class=\"grid grid-cols-2 gap-4 w-full p-2\">\n <div class=\"my-2 flex flex-row px-2 border-r\" *ngFor=\"let item of reqFieldsDataSource; let i = index;\">\n <div class=\"px-2 mb-2\">\n <div class=\"text-md mb-2\"> Params Name</div>\n <dx-text-box [(ngModel)]=\"item.name\"></dx-text-box>\n\n </div>\n <div class=\"px-2 mb-2\">\n <div class=\"text-md mb-2\"> Params Value </div>\n <ng-container *ngIf=\"item.name == 'dbConfig'\">\n <dx-select-box [items]=\"['mongo','impala','postgres','mysql','bigquery']\"\n (onValueChanged)=\"getDataConfig($event)\" [(ngModel)]=\"item.value\"></dx-select-box>\n </ng-container>\n <ng-container *ngIf=\"item.name !== 'dbConfig'\">\n <dx-text-box [(ngModel)]=\"item.value\"></dx-text-box>\n </ng-container>\n\n </div>\n <div class=\"px-2 mb-2\">\n <div class=\"text-center mt-8\">\n <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\" (click)=\"deleteParams(i)\"><i\n class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"flex flex-row my-2 justify-end\">\n <p class=\"text-sm italic text-gray-300 mr-6\">** Please Save Request Params Before Submit\n Dataset\n </p>\n <button class=\"{{commonService.btn_success_sm}} cursor-pointer\" (click)=\"saveParams()\">Save\n Params</button>\n <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\" (click)=\"addParams()\">Add\n Params</button>\n\n </div>\n </div>\n </div>\n\n <ng-container *ngIf=\"isQueryTypeSelect\">\n <div class=\"flex flex-col flex-auto min-w-0 my-2\">\n <div class=\"text-lg py-2 font-extrabold border-b bg-gray-700 text-white px-2\"> Columns and Measures\n </div>\n <div class=\"pt-2 border-x border-b \">\n <div class=\"my-2 flex justify-between\"\n *ngFor=\"let item of queryBulderDataset.queryConfig.columns; let i = index;\">\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Measures</div>\n <dx-check-box [value]=\"item.measures\" [(ngModel)]=\"item.measures\"></dx-check-box>\n </div>\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Value Field(aliasName)</div>\n <dx-text-box [(ngModel)]=\"item.dataField\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Server Column Name</div>\n <dx-text-box [(ngModel)]=\"item.columnName\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Function Name</div>\n <dx-select-box [searchEnabled]=\"true\" [items]=\"kpi_function\"\n [(ngModel)]=\"item.functionName\"></dx-select-box>\n </div>\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Enrich Name</div>\n <dx-select-box [searchEnabled]=\"true\" [items]=\"kpi_enrichment_name\"\n [(ngModel)]=\"item.enrichFunction\"></dx-select-box>\n </div>\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Advanced Column</div>\n <dx-text-box [(ngModel)]=\"item.advancedColumn\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Caption</div>\n <dx-text-box [(ngModel)]=\"item.caption\"></dx-text-box>\n </div>\n <div class=\"px-1 mt-8\">\n <div class=\"flex flex-row\">\n <button *ngIf=\"i !== 0\" class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n (click)=\"moveItemForMeasuresColumns(i, 'up')\">\n <i class=\"fa fa-arrow-up\" aria-hidden=\"true\"></i>\n </button>\n\n <button *ngIf=\"i !== queryBulderDataset.queryConfig.columns.length - 1\"\n class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n (click)=\"moveItemForMeasuresColumns(i, 'down')\">\n <i class=\"fa fa-arrow-down\" aria-hidden=\"true\"></i>\n </button>\n </div>\n </div>\n <div class=\"px-1 mt-8 text-center\">\n\n <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\" (click)=\"deleteColumns(i)\"><i\n class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n </button>\n </div>\n </div>\n\n <div class=\"flex flex-row justify-end my-2\">\n <p class=\"text-sm italic text-gray-300 mr-6\">** Please Save Columns And Measures Before Submit\n Dataset\n </p>\n <button class=\"{{commonService.btn_success_sm}} cursor-pointer\"\n (click)=\"saveColumnsAndMasures()\">Save\n Columns</button>\n <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\" (click)=\"addColumns()\">Add\n Columns</button>\n </div>\n </div>\n </div>\n\n\n <ng-container *ngIf=\"isReconColume\">\n <div class=\"flex flex-col flex-auto min-w-0 my-2\">\n <div class=\"text-lg py-2 font-extrabold border-b bg-gray-700 text-white px-2\"> Add Recon Column\n </div>\n <div class=\"pt-2 border-x border-b \">\n <div class=\"my-2 flex justify-between\" *ngFor=\"let item of reconColumeDatasource; let i = index;\">\n\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Value Field(aliasName)</div>\n <dx-text-box [(ngModel)]=\"item.dataField\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> First Key</div>\n <dx-text-box [(ngModel)]=\"item.columeOne\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Second Key</div>\n <dx-text-box [(ngModel)]=\"item.columeTwo\"></dx-text-box>\n </div>\n\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Enrich Name</div>\n <dx-select-box [searchEnabled]=\"true\" [items]=\"kpi_enrichment_name\"\n [(ngModel)]=\"item.enrichFunction\"></dx-select-box>\n </div>\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Recon Type</div>\n <dx-select-box [searchEnabled]=\"true\" [items]=\"['variance','percentage','absolute']\"\n [(ngModel)]=\"item.reconType\"></dx-select-box>\n </div>\n\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Caption</div>\n <dx-text-box [(ngModel)]=\"item.caption\"></dx-text-box>\n </div>\n\n <div class=\"px-1 mt-8 text-center\">\n\n <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n (click)=\"deleteReconColume(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n </button>\n </div>\n </div>\n <div class=\"flex flex-row justify-end my-2\">\n <button class=\"{{commonService.btn_success_sm}} cursor-pointer\"\n (click)=\"saveReconsColume()\">Save To\n Columns</button>\n <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\" (click)=\"addReconColume()\">Add\n </button>\n </div>\n </div>\n </div>\n\n </ng-container>\n\n <ng-container>\n <div class=\"flex flex-col flex-auto min-w-0 my-2\">\n <div class=\"text-lg py-2 font-extrabold border-b bg-gray-700 text-white px-2\"> Add Having Column\n </div>\n <div class=\"pt-2 border-x border-b \">\n <div class=\"my-2 flex justify-between\"\n *ngFor=\"let item of queryBulderDataset.queryConfig.havings; let i = index;\">\n\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Column Name</div>\n <dx-text-box [(ngModel)]=\"item.columnName\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Advanced Column</div>\n <dx-text-box [(ngModel)]=\"item.advancedColumn\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Data Type</div>\n <dx-text-box [(ngModel)]=\"item.dataType\"></dx-text-box>\n </div>\n\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Operator</div>\n <dx-select-box [items]=\"['get','lte']\" [(ngModel)]=\"item.operator\"></dx-select-box>\n </div>\n\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Value</div>\n <dx-text-box [(ngModel)]=\"item.value\"></dx-text-box>\n </div>\n\n <div class=\"px-1 mt-8 text-center\">\n <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n (click)=\"deleteHavingsColume(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n </button>\n </div>\n </div>\n <div class=\"flex flex-row justify-end my-2\">\n <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\" (click)=\"addHavingsColume()\">Add\n Havings\n </button>\n </div>\n </div>\n </div>\n\n </ng-container>\n\n <div class=\"flex flex-col flex-auto min-w-0 my-3\">\n <div class=\"text-lg py-2 font-extrabold border-b bg-gray-700 text-white px-2\"> Sort By\n </div>\n <div class=\"pt-2 border-x border-b \">\n <div class=\"grid grid-cols-2 gap-4 w-full p-2\">\n <div class=\"my-2 flex flex-row px-2 border-r\"\n *ngFor=\"let item of queryBulderDataset.queryConfig.sorters; let i = index;\">\n <div class=\"px-2 mb-2\">\n <div class=\"text-md mb-2\"> Params Name</div>\n <dx-text-box [(ngModel)]=\"item.columnName\"></dx-text-box>\n\n </div>\n <div class=\"px-2 mt-8\">\n\n <dx-check-box text=\"Descending\" [(ngModel)]=\"item.descending\"></dx-check-box>\n </div>\n <div class=\"px-2 mb-2\">\n <div class=\"text-center mt-8\">\n <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n (click)=\"deleteShortColumns(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"flex flex-row my-2 justify-end\">\n <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\" (click)=\"addShortColumns()\">Add\n Column</button>\n\n </div>\n </div>\n </div>\n\n\n <div class=\"flex flex-col flex-auto min-w-0 my-2\">\n <div class=\"text-lg py-2 font-extrabold border-b bg-gray-700 text-white px-2\"> Filter Maping\n </div>\n <div class=\"pt-2 border-x border-b \">\n <div class=\"my-2 flex flex-row justify-between\"\n *ngFor=\"let item of queryBulderDataset.queryConfig.mapedFilters; let i = index;\">\n\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Local Column</div>\n <dx-text-box [(ngModel)]=\"item.localColumn\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Server Column</div>\n <dx-text-box [(ngModel)]=\"item.serverColumn\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Operator</div>\n <dx-select-box [searchEnabled]=\"true\" [items]=\"kpi_operator\"\n [(ngModel)]=\"item.operatorName\"></dx-select-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Datatype</div>\n <dx-select-box [searchEnabled]=\"true\"\n [items]=\"['date','string','timestamp','int', 'double', 'boolean']\"\n [(ngModel)]=\"item.dataType\"></dx-select-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Default Value</div>\n <dx-text-box [(ngModel)]=\"item.defaultValue\"></dx-text-box>\n </div>\n <div class=\"px-1 mt-8\">\n <div class=\"flex flex-row\">\n <button *ngIf=\"i !== 0\" class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n (click)=\"moveItemForColumns(i, 'up')\">\n <i class=\"fa fa-arrow-up\" aria-hidden=\"true\"></i>\n </button>\n\n <button *ngIf=\"i !== queryBulderDataset.queryConfig.mapedFilters.length - 1\"\n class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n (click)=\"moveItemForColumns(i, 'down')\">\n <i class=\"fa fa-arrow-down\" aria-hidden=\"true\"></i>\n </button>\n </div>\n </div>\n <div class=\"px-1 mt-8 text-center\">\n <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n (click)=\"deleteFilterMapingColumns(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n </button>\n </div>\n </div>\n </div>\n <div class=\"flex flex-row\">\n <div class=\"w-1/2\" *ngIf=\"selectedDataSource !== 'mongo'\">\n <div class=\"flex flex-row justify-start my-2\">\n <button class=\"{{commonService.btnOthersPurple}} cursor-pointer\" (click)=\"checkForQuery()\">Check\n Query</button>\n </div>\n </div>\n <div class=\"w-full\">\n <div class=\"flex flex-row justify-end my-2\">\n <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\"\n (click)=\"addFilterMapingColumns()\">Add\n Maping</button>\n </div>\n </div>\n </div>\n\n </div>\n <div class=\"flex w-full justify-end mt-5 border-t\">\n <button class=\"{{commonService.btn_success_md}} cursor-pointer mx-1 my-2\" (click)=\"createDataSet()\">\n Submit DataSet\n </button>\n </div>\n </ng-container>\n\n\n</div>\n\n\n<ng-container *ngIf=\"isModelVisible\">\n <div class=\"fixed inset-0 flex items-center justify-center z-50 bg-black bg-opacity-50\">\n <div class=\"relative p-4 w-full max-w-3xl max-h-full\">\n <div class=\"relative bg-white rounded-lg shadow \">\n <div class=\"flex items-center justify-between p-4 md:p-5 border-b rounded-t \">\n <h3 class=\"text-xl font-semibold text-gray-900 \">\n Query </h3>\n <button type=\"button\" (click)=\"closeModalVisibleModal()\"\n class=\"text-gray-400 bg-transparent hover:bg-gray-200 hover:text-gray-900 rounded-lg text-sm w-8 h-8 ms-auto inline-flex justify-center items-center \"\n data-modal-hide=\"static-modal\">\n <svg class=\"w-3 h-3\" aria-hidden=\"true\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\"\n viewBox=\"0 0 14 14\">\n <path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\"\n d=\"m1 1 6 6m0 0 6 6M7 7l6-6M7 7l-6 6\" />\n </svg>\n <span class=\"sr-only\">Close</span>\n </button>\n </div>\n <!-- Modal body -->\n <div class=\"w-69 p-5\">\n <div class=\"flex flex-row bg-gray-800 text-white text-lg p-4 rounded-md text-wrap\">\n <code>\n {{query_data}}\n </code>\n </div>\n </div>\n <div class=\"flex items-center border-t border-gray-200 rounded-b p-2 justify-end\">\n <span class=\"text-gray-700 px-2\" *ngIf=\"isSqlCopiedText\">Copied</span>\n <button data-modal-hide=\"static-modal\" type=\"button\" class=\"{{commonService.btn_success_sm}} py-2\"\n (click)=\"copySqlFromModal()\">Copy</button>\n </div>\n </div>\n </div>\n </div>\n</ng-container>", styles: [""], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.DxCheckBoxComponent, selector: "dx-check-box", inputs: ["accessKey", "activeStateEnabled", "disabled", "elementAttr", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "iconSize", "isValid", "name", "readOnly", "rtlEnabled", "tabIndex", "text", "validationError", "validationErrors", "validationMessageMode", "validationStatus", "value", "visible", "width"], outputs: ["onContentReady", "onDisposing", "onInitialized", "onOptionChanged", "onValueChanged", "accessKeyChange", "activeStateEnabledChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hintChange", "hoverStateEnabledChange", "iconSizeChange", "isValidChange", "nameChange", "readOnlyChange", "rtlEnabledChange", "tabIndexChange", "textChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationStatusChange", "valueChange", "visibleChange", "widthChange", "onBlur"] }, { kind: "component", type: i6.DxSelectBoxComponent, selector: "dx-select-box", inputs: ["acceptCustomValue", "accessKey", "activeStateEnabled", "buttons", "dataSource", "deferRendering", "disabled", "displayExpr", "displayValue", "dropDownButtonTemplate", "dropDownOptions", "elementAttr", "fieldTemplate", "focusStateEnabled", "grouped", "groupTemplate", "height", "hint", "hoverStateEnabled", "inputAttr", "isValid", "items", "itemTemplate", "label", "labelMode", "maxLength", "minSearchLength", "name", "noDataText", "opened", "openOnFieldClick", "placeholder", "readOnly", "rtlEnabled", "searchEnabled", "searchExpr", "searchMode", "searchTimeout", "selectedItem", "showClearButton", "showDataBeforeSearch", "showDropDownButton", "showSelectionControls", "spellcheck", "stylingMode", "tabIndex", "text", "useItemTextAsTitle", "validationError", "validationErrors", "validationMessageMode", "validationStatus", "value", "valueChangeEvent", "valueExpr", "visible", "width", "wrapItemText"], outputs: ["onChange", "onClosed", "onContentReady", "onCopy", "onCustomItemCreating", "onCut", "onDisposing", "onEnterKey", "onFocusIn", "onFocusOut", "onInitialized", "onInput", "onItemClick", "onKeyDown", "onKeyUp", "onOpened", "onOptionChanged", "onPaste", "onSelectionChanged", "onValueChanged", "acceptCustomValueChange", "accessKeyChange", "activeStateEnabledChange", "buttonsChange", "dataSourceChange", "deferRenderingChange", "disabledChange", "displayExprChange", "displayValueChange", "dropDownButtonTemplateChange", "dropDownOptionsChange", "elementAttrChange", "fieldTemplateChange", "focusStateEnabledChange", "groupedChange", "groupTemplateChange", "heightChange", "hintChange", "hoverStateEnabledChange", "inputAttrChange", "isValidChange", "itemsChange", "itemTemplateChange", "labelChange", "labelModeChange", "maxLengthChange", "minSearchLengthChange", "nameChange", "noDataTextChange", "openedChange", "openOnFieldClickChange", "placeholderChange", "readOnlyChange", "rtlEnabledChange", "searchEnabledChange", "searchExprChange", "searchModeChange", "searchTimeoutChange", "selectedItemChange", "showClearButtonChange", "showDataBeforeSearchChange", "showDropDownButtonChange", "showSelectionControlsChange", "spellcheckChange", "stylingModeChange", "tabIndexChange", "textChange", "useItemTextAsTitleChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationStatusChange", "valueChange", "valueChangeEventChange", "valueExprChange", "visibleChange", "widthChange", "wrapItemTextChange", "onBlur"] }, { kind: "component", type: i7.DxTextBoxComponent, selector: "dx-text-box", inputs: ["accessKey", "activeStateEnabled", "buttons", "disabled", "elementAttr", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "inputAttr", "isValid", "label", "labelMode", "mask", "maskChar", "maskInvalidMessage", "maskRules", "maxLength", "mode", "name", "placeholder", "readOnly", "rtlEnabled", "showClearButton", "showMaskMode", "spellcheck", "stylingMode", "tabIndex", "text", "useMaskedValue", "validationError", "validationErrors", "validationMessageMode", "validationStatus", "value", "valueChangeEvent", "visible", "width"], outputs: ["onChange", "onContentReady", "onCopy", "onCut", "onDisposing", "onEnterKey", "onFocusIn", "onFocusOut", "onInitialized", "onInput", "onKeyDown", "onKeyUp", "onOptionChanged", "onPaste", "onValueChanged", "accessKeyChange", "activeStateEnabledChange", "buttonsChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hintChange", "hoverStateEnabledChange", "inputAttrChange", "isValidChange", "labelChange", "labelModeChange", "maskChange", "maskCharChange", "maskInvalidMessageChange", "maskRulesChange", "maxLengthChange", "modeChange", "nameChange", "placeholderChange", "readOnlyChange", "rtlEnabledChange", "showClearButtonChange", "showMaskModeChange", "spellcheckChange", "stylingModeChange", "tabIndexChange", "textChange", "useMaskedValueChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationStatusChange", "valueChange", "valueChangeEventChange", "visibleChange", "widthChange", "onBlur"] }, { kind: "directive", type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
|
|
400
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: DatasetQueryBulderComponent, decorators: [{
|
|
401
|
+
type: Component,
|
|
402
|
+
args: [{ selector: 'app-dataset-query-bulder', template: "<div class=\"m-2\">\n <div class=\"flex flex-row mb-2\">\n <div class=\"mx-2 w-1/3\">\n <div class=\"text-md mb-2\">End Point</div>\n <dx-text-box [(ngModel)]=\"queryBulderDataset.api\"></dx-text-box>\n </div>\n <div class=\"mx-2 w-1/3\">\n <div class=\"text-md mb-2\">Query Type</div>\n <dx-select-box [dataSource]=\"['Aggregate','Basic']\" (onValueChanged)=\"getQueryForDetailsData($event)\">\n </dx-select-box>\n </div>\n <div class=\"mx-2 w-1/3 mt-6\" *ngIf=\"selectedDataSource == 'mongo'\">\n <dx-check-box [(ngModel)]=\"isReconColume\" text='Recon Column'>\n </dx-check-box>\n </div>\n </div>\n\n <div class=\"flex flex-col flex-auto min-w-0 my-3\">\n <div class=\"text-lg py-2 font-extrabold border-b bg-gray-700 text-white px-2\"> Request Params\n </div>\n <div class=\"pt-2 border-x border-b \">\n <div class=\"grid grid-cols-2 gap-4 w-full p-2\">\n <div class=\"my-2 flex flex-row px-2 border-r\" *ngFor=\"let item of reqFieldsDataSource; let i = index;\">\n <div class=\"px-2 mb-2\">\n <div class=\"text-md mb-2\"> Params Name</div>\n <dx-text-box [(ngModel)]=\"item.name\"></dx-text-box>\n\n </div>\n <div class=\"px-2 mb-2\">\n <div class=\"text-md mb-2\"> Params Value </div>\n <ng-container *ngIf=\"item.name == 'dbConfig'\">\n <dx-select-box [items]=\"['mongo','impala','postgres','mysql','bigquery']\"\n (onValueChanged)=\"getDataConfig($event)\" [(ngModel)]=\"item.value\"></dx-select-box>\n </ng-container>\n <ng-container *ngIf=\"item.name !== 'dbConfig'\">\n <dx-text-box [(ngModel)]=\"item.value\"></dx-text-box>\n </ng-container>\n\n </div>\n <div class=\"px-2 mb-2\">\n <div class=\"text-center mt-8\">\n <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\" (click)=\"deleteParams(i)\"><i\n class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"flex flex-row my-2 justify-end\">\n <p class=\"text-sm italic text-gray-300 mr-6\">** Please Save Request Params Before Submit\n Dataset\n </p>\n <button class=\"{{commonService.btn_success_sm}} cursor-pointer\" (click)=\"saveParams()\">Save\n Params</button>\n <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\" (click)=\"addParams()\">Add\n Params</button>\n\n </div>\n </div>\n </div>\n\n <ng-container *ngIf=\"isQueryTypeSelect\">\n <div class=\"flex flex-col flex-auto min-w-0 my-2\">\n <div class=\"text-lg py-2 font-extrabold border-b bg-gray-700 text-white px-2\"> Columns and Measures\n </div>\n <div class=\"pt-2 border-x border-b \">\n <div class=\"my-2 flex justify-between\"\n *ngFor=\"let item of queryBulderDataset.queryConfig.columns; let i = index;\">\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Measures</div>\n <dx-check-box [value]=\"item.measures\" [(ngModel)]=\"item.measures\"></dx-check-box>\n </div>\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Value Field(aliasName)</div>\n <dx-text-box [(ngModel)]=\"item.dataField\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Server Column Name</div>\n <dx-text-box [(ngModel)]=\"item.columnName\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Function Name</div>\n <dx-select-box [searchEnabled]=\"true\" [items]=\"kpi_function\"\n [(ngModel)]=\"item.functionName\"></dx-select-box>\n </div>\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Enrich Name</div>\n <dx-select-box [searchEnabled]=\"true\" [items]=\"kpi_enrichment_name\"\n [(ngModel)]=\"item.enrichFunction\"></dx-select-box>\n </div>\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Advanced Column</div>\n <dx-text-box [(ngModel)]=\"item.advancedColumn\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Caption</div>\n <dx-text-box [(ngModel)]=\"item.caption\"></dx-text-box>\n </div>\n <div class=\"px-1 mt-8\">\n <div class=\"flex flex-row\">\n <button *ngIf=\"i !== 0\" class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n (click)=\"moveItemForMeasuresColumns(i, 'up')\">\n <i class=\"fa fa-arrow-up\" aria-hidden=\"true\"></i>\n </button>\n\n <button *ngIf=\"i !== queryBulderDataset.queryConfig.columns.length - 1\"\n class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n (click)=\"moveItemForMeasuresColumns(i, 'down')\">\n <i class=\"fa fa-arrow-down\" aria-hidden=\"true\"></i>\n </button>\n </div>\n </div>\n <div class=\"px-1 mt-8 text-center\">\n\n <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\" (click)=\"deleteColumns(i)\"><i\n class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n </button>\n </div>\n </div>\n\n <div class=\"flex flex-row justify-end my-2\">\n <p class=\"text-sm italic text-gray-300 mr-6\">** Please Save Columns And Measures Before Submit\n Dataset\n </p>\n <button class=\"{{commonService.btn_success_sm}} cursor-pointer\"\n (click)=\"saveColumnsAndMasures()\">Save\n Columns</button>\n <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\" (click)=\"addColumns()\">Add\n Columns</button>\n </div>\n </div>\n </div>\n\n\n <ng-container *ngIf=\"isReconColume\">\n <div class=\"flex flex-col flex-auto min-w-0 my-2\">\n <div class=\"text-lg py-2 font-extrabold border-b bg-gray-700 text-white px-2\"> Add Recon Column\n </div>\n <div class=\"pt-2 border-x border-b \">\n <div class=\"my-2 flex justify-between\" *ngFor=\"let item of reconColumeDatasource; let i = index;\">\n\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Value Field(aliasName)</div>\n <dx-text-box [(ngModel)]=\"item.dataField\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> First Key</div>\n <dx-text-box [(ngModel)]=\"item.columeOne\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Second Key</div>\n <dx-text-box [(ngModel)]=\"item.columeTwo\"></dx-text-box>\n </div>\n\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Enrich Name</div>\n <dx-select-box [searchEnabled]=\"true\" [items]=\"kpi_enrichment_name\"\n [(ngModel)]=\"item.enrichFunction\"></dx-select-box>\n </div>\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Recon Type</div>\n <dx-select-box [searchEnabled]=\"true\" [items]=\"['variance','percentage','absolute']\"\n [(ngModel)]=\"item.reconType\"></dx-select-box>\n </div>\n\n <div class=\"px-1 mb-2\">\n <div class=\"text-md mb-2\"> Caption</div>\n <dx-text-box [(ngModel)]=\"item.caption\"></dx-text-box>\n </div>\n\n <div class=\"px-1 mt-8 text-center\">\n\n <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n (click)=\"deleteReconColume(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n </button>\n </div>\n </div>\n <div class=\"flex flex-row justify-end my-2\">\n <button class=\"{{commonService.btn_success_sm}} cursor-pointer\"\n (click)=\"saveReconsColume()\">Save To\n Columns</button>\n <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\" (click)=\"addReconColume()\">Add\n </button>\n </div>\n </div>\n </div>\n\n </ng-container>\n\n <ng-container>\n <div class=\"flex flex-col flex-auto min-w-0 my-2\">\n <div class=\"text-lg py-2 font-extrabold border-b bg-gray-700 text-white px-2\"> Add Having Column\n </div>\n <div class=\"pt-2 border-x border-b \">\n <div class=\"my-2 flex justify-between\"\n *ngFor=\"let item of queryBulderDataset.queryConfig.havings; let i = index;\">\n\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Column Name</div>\n <dx-text-box [(ngModel)]=\"item.columnName\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Advanced Column</div>\n <dx-text-box [(ngModel)]=\"item.advancedColumn\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Data Type</div>\n <dx-text-box [(ngModel)]=\"item.dataType\"></dx-text-box>\n </div>\n\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Operator</div>\n <dx-select-box [items]=\"['get','lte']\" [(ngModel)]=\"item.operator\"></dx-select-box>\n </div>\n\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Value</div>\n <dx-text-box [(ngModel)]=\"item.value\"></dx-text-box>\n </div>\n\n <div class=\"px-1 mt-8 text-center\">\n <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n (click)=\"deleteHavingsColume(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n </button>\n </div>\n </div>\n <div class=\"flex flex-row justify-end my-2\">\n <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\" (click)=\"addHavingsColume()\">Add\n Havings\n </button>\n </div>\n </div>\n </div>\n\n </ng-container>\n\n <div class=\"flex flex-col flex-auto min-w-0 my-3\">\n <div class=\"text-lg py-2 font-extrabold border-b bg-gray-700 text-white px-2\"> Sort By\n </div>\n <div class=\"pt-2 border-x border-b \">\n <div class=\"grid grid-cols-2 gap-4 w-full p-2\">\n <div class=\"my-2 flex flex-row px-2 border-r\"\n *ngFor=\"let item of queryBulderDataset.queryConfig.sorters; let i = index;\">\n <div class=\"px-2 mb-2\">\n <div class=\"text-md mb-2\"> Params Name</div>\n <dx-text-box [(ngModel)]=\"item.columnName\"></dx-text-box>\n\n </div>\n <div class=\"px-2 mt-8\">\n\n <dx-check-box text=\"Descending\" [(ngModel)]=\"item.descending\"></dx-check-box>\n </div>\n <div class=\"px-2 mb-2\">\n <div class=\"text-center mt-8\">\n <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n (click)=\"deleteShortColumns(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"flex flex-row my-2 justify-end\">\n <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\" (click)=\"addShortColumns()\">Add\n Column</button>\n\n </div>\n </div>\n </div>\n\n\n <div class=\"flex flex-col flex-auto min-w-0 my-2\">\n <div class=\"text-lg py-2 font-extrabold border-b bg-gray-700 text-white px-2\"> Filter Maping\n </div>\n <div class=\"pt-2 border-x border-b \">\n <div class=\"my-2 flex flex-row justify-between\"\n *ngFor=\"let item of queryBulderDataset.queryConfig.mapedFilters; let i = index;\">\n\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Local Column</div>\n <dx-text-box [(ngModel)]=\"item.localColumn\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Server Column</div>\n <dx-text-box [(ngModel)]=\"item.serverColumn\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Operator</div>\n <dx-select-box [searchEnabled]=\"true\" [items]=\"kpi_operator\"\n [(ngModel)]=\"item.operatorName\"></dx-select-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Datatype</div>\n <dx-select-box [searchEnabled]=\"true\"\n [items]=\"['date','string','timestamp','int', 'double', 'boolean']\"\n [(ngModel)]=\"item.dataType\"></dx-select-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Default Value</div>\n <dx-text-box [(ngModel)]=\"item.defaultValue\"></dx-text-box>\n </div>\n <div class=\"px-1 mt-8\">\n <div class=\"flex flex-row\">\n <button *ngIf=\"i !== 0\" class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n (click)=\"moveItemForColumns(i, 'up')\">\n <i class=\"fa fa-arrow-up\" aria-hidden=\"true\"></i>\n </button>\n\n <button *ngIf=\"i !== queryBulderDataset.queryConfig.mapedFilters.length - 1\"\n class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n (click)=\"moveItemForColumns(i, 'down')\">\n <i class=\"fa fa-arrow-down\" aria-hidden=\"true\"></i>\n </button>\n </div>\n </div>\n <div class=\"px-1 mt-8 text-center\">\n <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n (click)=\"deleteFilterMapingColumns(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n </button>\n </div>\n </div>\n </div>\n <div class=\"flex flex-row\">\n <div class=\"w-1/2\" *ngIf=\"selectedDataSource !== 'mongo'\">\n <div class=\"flex flex-row justify-start my-2\">\n <button class=\"{{commonService.btnOthersPurple}} cursor-pointer\" (click)=\"checkForQuery()\">Check\n Query</button>\n </div>\n </div>\n <div class=\"w-full\">\n <div class=\"flex flex-row justify-end my-2\">\n <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\"\n (click)=\"addFilterMapingColumns()\">Add\n Maping</button>\n </div>\n </div>\n </div>\n\n </div>\n <div class=\"flex w-full justify-end mt-5 border-t\">\n <button class=\"{{commonService.btn_success_md}} cursor-pointer mx-1 my-2\" (click)=\"createDataSet()\">\n Submit DataSet\n </button>\n </div>\n </ng-container>\n\n\n</div>\n\n\n<ng-container *ngIf=\"isModelVisible\">\n <div class=\"fixed inset-0 flex items-center justify-center z-50 bg-black bg-opacity-50\">\n <div class=\"relative p-4 w-full max-w-3xl max-h-full\">\n <div class=\"relative bg-white rounded-lg shadow \">\n <div class=\"flex items-center justify-between p-4 md:p-5 border-b rounded-t \">\n <h3 class=\"text-xl font-semibold text-gray-900 \">\n Query </h3>\n <button type=\"button\" (click)=\"closeModalVisibleModal()\"\n class=\"text-gray-400 bg-transparent hover:bg-gray-200 hover:text-gray-900 rounded-lg text-sm w-8 h-8 ms-auto inline-flex justify-center items-center \"\n data-modal-hide=\"static-modal\">\n <svg class=\"w-3 h-3\" aria-hidden=\"true\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\"\n viewBox=\"0 0 14 14\">\n <path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\"\n d=\"m1 1 6 6m0 0 6 6M7 7l6-6M7 7l-6 6\" />\n </svg>\n <span class=\"sr-only\">Close</span>\n </button>\n </div>\n <!-- Modal body -->\n <div class=\"w-69 p-5\">\n <div class=\"flex flex-row bg-gray-800 text-white text-lg p-4 rounded-md text-wrap\">\n <code>\n {{query_data}}\n </code>\n </div>\n </div>\n <div class=\"flex items-center border-t border-gray-200 rounded-b p-2 justify-end\">\n <span class=\"text-gray-700 px-2\" *ngIf=\"isSqlCopiedText\">Copied</span>\n <button data-modal-hide=\"static-modal\" type=\"button\" class=\"{{commonService.btn_success_sm}} py-2\"\n (click)=\"copySqlFromModal()\">Copy</button>\n </div>\n </div>\n </div>\n </div>\n</ng-container>" }]
|
|
403
|
+
}], ctorParameters: function () { return [{ type: i1.CommonService }, { type: i2.ToastrService }, { type: i3.ApplicationContentService }]; }, propDecorators: { getQueryBulbderDataSet: [{
|
|
404
|
+
type: Output
|
|
405
|
+
}], bulderDataset: [{
|
|
406
|
+
type: Input,
|
|
407
|
+
args: ['bulderDataset']
|
|
408
|
+
}] } });
|
|
409
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dataset-query-bulder.component.js","sourceRoot":"","sources":["../../../../../../../projects/gamma-app-controller/src/lib/application-controller/application-dataset-component/dataset-query-bulder/dataset-query-bulder.component.ts","../../../../../../../projects/gamma-app-controller/src/lib/application-controller/application-dataset-component/dataset-query-bulder/dataset-query-bulder.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { ToastrService } from 'ngx-toastr';\nimport { ApplicationContentService } from '../../application-content.service';\nimport { CommonService } from '../../common';\n\n@Component({\n  selector: 'app-dataset-query-bulder',\n  templateUrl: './dataset-query-bulder.component.html',\n  styleUrls: ['./dataset-query-bulder.component.scss']\n})\nexport class DatasetQueryBulderComponent implements OnInit {\n\n  // @Input() queryBulderDataset: any;\n  reqFieldsDataSource: any = [];\n  isreqFields: boolean = false;\n  iscdrParams: boolean = false;\n  cdrFieldsDataSource: any = [];\n  kpi_function: any = [\"sum\", \"count\", \"avg\", \"max\", \"min\", \"stddev\", \"count_distinct\"]\n  kpi_operator: any = [\"eq\", \"gte\", \"lte\", \"ne\", \"in\", \"notIn\", \"contains\", \"startsWith\", \"endsWith\"]\n  kpi_enrichment_name: any = [];\n  reqShortDataSource: any = [];\n  filterMapingDatasource: any = [];\n  query_data: any;\n  isModelVisible: boolean = false;\n  isSqlCopiedText: boolean = false;\n  queryBulderDataset: any;\n  isReconColume: boolean = false;\n  @Output() public getQueryBulbderDataSet: EventEmitter<any> = new EventEmitter();\n\n  reconColumeDatasource = [];\n\n  selectedDataSource: any;\n  isQueryTypeSelect: boolean = false;\n\n  @Input('bulderDataset')\n  set bulderDataset(value) {\n\n    if (value.queryConfig.reqFields && value.queryConfig.reqFields.length < 2) {\n      this.reqFieldsDataSource = [\n        {\n          \"name\": \"pageNumber\",\n          \"value\": 1,\n        },\n        {\n          \"name\": \"pageSize\",\n          \"value\": 2010,\n        },\n        {\n          \"name\": \"dbConfig\",\n          \"value\": \"\",\n        },\n        {\n          \"name\": \"databaseName\",\n          \"value\": \"\",\n        },\n        {\n          \"name\": \"tableName\",\n          \"value\": \"\",\n        },\n        {\n          \"name\": \"paginationRequired\",\n          \"value\": \"false\",\n        }\n      ]\n    } else {\n      this.reqFieldsDataSource = this.processParamsformatData(value.queryConfig.reqFields);\n      this.selectedDataSource = value.queryConfig.reqFields.find(item => item.dbConfig !== undefined)?.dbConfig;\n      this.isQueryTypeSelect = true;\n    }\n    if (value.queryConfig.mapedFilters == undefined) {\n      value.queryConfig.mapedFilters = [];\n      value.queryConfig.mapedFilters.push({ \"localColumn\": \"\", \"serverColumn\": \"\", \"operatorName\": \"\", \"defaultValue\": \"\", \"dataType\": \"\" })\n    }\n\n    if (value.queryConfig.sorters == undefined) {\n      value.queryConfig.sorters = [];\n      value.queryConfig.sorters.push({ \"columnName\": \"\", \"descending\": false })\n    }\n    if (value.queryConfig.columns == undefined) {\n      value.queryConfig.columns = [];\n      let obj = {\n        \"measures\": true,\n        \"dataField\": \"\",\n        \"columnName\": \"\",\n        \"functionName\": \"\",\n        \"enrichFunction\": \"\",\n        \"advancedColumn\": \"\",\n        \"caption\": \"\",\n      }\n      value.queryConfig.columns.push(obj);\n    }\n    if (value.queryConfig.havings == undefined) {\n      value.queryConfig.havings = [];\n    }\n\n\n    this.queryBulderDataset = value;\n  }\n\n\n  constructor(public commonService: CommonService, private toastr: ToastrService, private service: ApplicationContentService) { }\n\n  ngOnInit(): void {\n    this.service.listColumnEnrichmentFunctions().subscribe(data => {\n      this.kpi_enrichment_name = data;\n    })\n\n    this.reconColumeDatasource = [\n      {\n        \"dataField\": \"\",\n        \"enrichFunction\": \"\",\n        \"columeOne\": \"\",\n        \"columeTwo\": \"\",\n        \"reconType\": \"\",\n        \"caption\": \"\"\n      }\n    ]\n  }\n\n  processParamsformatData(data) {\n    const formatted_data = data.map(item => {\n      const [name, value] = Object.entries(item)[0];\n\n      return {\n        name,\n        value: name === 'paginationRequired' ? value.toString() : value\n      };\n    });\n\n    return formatted_data;\n  }\n\n\n\n  addColumns() {\n    let obj = {\n      \"measures\": true,\n      \"dataField\": \"\",\n      \"columnName\": \"\",\n      \"functionName\": \"\",\n      \"advancedColumn\": \"\",\n      \"enrichFunction\": \"\",\n      \"caption\": \"\",\n    }\n    this.queryBulderDataset.queryConfig.columns.push(obj);\n  }\n\n\n  deleteColumns(i) {\n    this.queryBulderDataset.queryConfig.columns.splice(i, 1)\n  }\n\n  addReconColume() {\n    let obj = {\n      \"dataField\": \"\",\n      \"columeOne\": \"\",\n      \"columeTwo\": \"\",\n      \"enrichFunction\": \"\",\n      \"reconType\": \"\",\n      \"caption\": \"\"\n    }\n    this.reconColumeDatasource.push(obj);\n  }\n\n  deleteReconColume(i) {\n    this.reconColumeDatasource.splice(i, 1)\n  }\n\n  saveReconsColume() {\n    // { '$divide': [{ '$subtract': ['$cbsCount', '$mscCount'] }, '$cbsCount'] }\n    // { '$subtract': ['$cbsMou', '$mscMou'] }\n\n    this.reconColumeDatasource.forEach(element => {\n      if (element.reconType == \"variance\") {\n        let columeString = \"{'$subtract': ['$\" + element.columeOne + \"','$\" + element.columeTwo + \"']}\";\n        let node = {\n          \"measures\": true,\n          \"dataField\": element.dataField,\n          \"columnName\": element.dataField,\n          \"functionName\": \"\",\n          \"advancedColumn\": columeString,\n          \"enrichFunction\": element.enrichFunction,\n          \"caption\": element.caption,\n          'deriveField': true\n        }\n        this.queryBulderDataset.queryConfig.columns.push(node)\n        console.log(columeString);\n      } else if (element.reconType == \"percentage\") {\n        let columeString = \"{'$cond': { if: { $eq: [ '$\" + element.columeOne + \"', 0 ] }, then: 0, else: {'$divide':[{'$subtract': ['$\" + element.columeOne + \"','$\" + element.columeTwo + \"']},'$\" + element.columeOne + \"']} }}\";\n        let node = {\n          \"measures\": true,\n          \"dataField\": element.dataField,\n          \"columnName\": element.dataField,\n          \"functionName\": \"\",\n          \"advancedColumn\": columeString,\n          \"enrichFunction\": element.enrichFunction,\n          \"caption\": element.caption,\n          'deriveField': true\n        }\n        this.queryBulderDataset.queryConfig.columns.push(node)\n      } else if (element.reconType == \"absolute\") {\n        let columeString = \"{'$abs': {'$cond': { if: { $eq: [ '$\" + element.columeOne + \"', 0 ] }, then: 0, else: {'$divide': [{'$subtract': ['$\" + element.columeOne + \"', '$\" + element.columeTwo + \"']}, '$\" + element.columeOne + \"']}}}}\";\n        let node = {\n          \"measures\": true,\n          \"dataField\": element.dataField,\n          \"columnName\": element.dataField,\n          \"functionName\": \"\",\n          \"advancedColumn\": columeString,\n          \"enrichFunction\": element.enrichFunction,\n          \"caption\": element.caption,\n          'deriveField': true\n        }\n        this.queryBulderDataset.queryConfig.columns.push(node)\n      }\n    })\n  }\n\n\n  saveColumnsAndMasures() {\n    this.queryBulderDataset.queryConfig.measures = [];\n    this.queryBulderDataset.queryConfig.dimensions = [];\n    this.queryBulderDataset.queryConfig.columns.forEach(element => {\n      // Check if element.advancedColumn is an empty string and set it to null\n      const advancedColumnValue = element.advancedColumn === \"\" ? null : element.advancedColumn;\n\n      if (element.measures) {\n        let obj = {\n          columnName: element.columnName,\n          functionName: element.functionName,\n          enrichFunction: element.enrichFunction,\n          advancedColumn: advancedColumnValue,\n          aliasName: element.dataField,\n        }\n        if (element.deriveField) {\n          obj['deriveField'] = element.deriveField\n        }\n        this.queryBulderDataset.queryConfig.measures.push(obj);\n      } else {\n        let obj = {\n          columnName: element.columnName,\n          enrichFunction: element.enrichFunction,\n          aliasName: element.dataField,\n        }\n        this.queryBulderDataset.queryConfig.dimensions.push(obj);\n      }\n    });\n    this.toastr.success('Columns Saved Successfully');\n    // this.saveDataToStore()\n  }\n\n  saveDataToStore() {\n    const buildDate = localStorage.getItem('querybuilder');\n    if (buildDate) {\n      localStorage.removeItem(buildDate);\n    }\n    localStorage.setItem('querybuilder', JSON.stringify(this.queryBulderDataset))\n  }\n\n  transformColumnsForMesurs(inputColumns) {\n    const measure = []\n    inputColumns.forEach(col => {\n\n\n    });\n\n    return measure;\n  }\n\n\n  addFilter() {\n    let obj = {\n      \"type\": \"\",\n      \"value\": \"\",\n      \"key\": \"\",\n      \"display\": \"\",\n      \"placeholder\": \"\"\n    }\n    this.queryBulderDataset.queryConfig.filter.push(obj);\n  }\n\n  deleteFilter(i) {\n    this.queryBulderDataset.queryConfig.filter.splice(i, 1);\n  }\n  addParams() {\n    let obj = {\n      \"name\": \"\",\n      \"value\": \"\",\n    }\n    this.reqFieldsDataSource.push(obj);\n  }\n\n\n  deleteParams(i) {\n    this.reqFieldsDataSource.splice(i, 1)\n  }\n\n  addShortColumns() {\n    this.queryBulderDataset.queryConfig.sorters.push({ \"columnName\": \"\", \"descending\": false })\n  }\n\n\n  deleteShortColumns(i) {\n    this.queryBulderDataset.queryConfig.sorters.splice(i, 1)\n  }\n\n  saveParams() {\n    let paginationRequiredExists = false;\n    this.queryBulderDataset.queryConfig.reqFields = this.reqFieldsDataSource.map(item => {\n      const newObj: any = {};\n      if (item.name === \"paginationRequired\") {\n        paginationRequiredExists = true;\n        newObj[item.name] = item.value === \"true\";\n      } else if (typeof item.value === \"string\" && !isNaN(item.value as any) && item.value.trim() !== \"\") {\n        newObj[item.name] = Number(item.value);\n      } else {\n        newObj[item.name] = item.value;\n      }\n\n      return newObj;\n    });\n\n    if (!paginationRequiredExists) {\n      this.queryBulderDataset.queryConfig.reqFields.push({ paginationRequired: \"false\" });\n    }\n\n    // this.saveDataToStore();\n    this.toastr.success('Pagination Request Params Saved Successfully');\n  }\n\n\n  addFilterMapingColumns() {\n    let obj = { \"localColumn\": \"\", \"serverColumn\": \"\", \"operatorName\": \"\", \"defaultValue\": \"\", \"dataType\": \"\" }\n    this.queryBulderDataset.queryConfig.mapedFilters.push(obj);\n\n  }\n\n  deleteFilterMapingColumns(i) {\n    this.queryBulderDataset.queryConfig.mapedFilters.splice(i, 1)\n  }\n\n  moveItemForColumns(index: number, direction: 'up' | 'down'): void {\n    // Prevent moving beyond array bounds\n    if (index < 0 || index >= this.queryBulderDataset.queryConfig.mapedFilters.length) return;\n    const newPosition = direction === 'up' ? index - 1 : index + 1;\n    // Prevent moving beyond array bounds\n    if (newPosition < 0 || newPosition >= this.queryBulderDataset.queryConfig.mapedFilters.length) return;\n\n    // Move item\n    const itemToMove = this.queryBulderDataset.queryConfig.mapedFilters[index];\n    this.queryBulderDataset.queryConfig.mapedFilters.splice(index, 1); // Remove item from current position\n    this.queryBulderDataset.queryConfig.mapedFilters.splice(newPosition, 0, itemToMove); // Insert item in new position\n  }\n  moveItemForMeasuresColumns(index: number, direction: 'up' | 'down'): void {\n    // Prevent moving beyond array bounds\n    if (index < 0 || index >= this.queryBulderDataset.queryConfig.columns.length) return;\n    const newPosition = direction === 'up' ? index - 1 : index + 1;\n    // Prevent moving beyond array bounds\n    if (newPosition < 0 || newPosition >= this.queryBulderDataset.queryConfig.columns.length) return;\n\n    // Move item\n    const itemToMove = this.queryBulderDataset.queryConfig.columns[index];\n    this.queryBulderDataset.queryConfig.columns.splice(index, 1); // Remove item from current position\n    this.queryBulderDataset.queryConfig.columns.splice(newPosition, 0, itemToMove); // Insert item in new position\n  }\n\n\n\n\n  checkForQuery() {\n    let transformedObject: any = {};\n\n    for (let item of this.queryBulderDataset.queryConfig.reqFields) {\n      const key = Object.keys(item)[0];\n      const value = Object.values(item)[0];\n\n      if (key === 'startDate') {\n        transformedObject.recordDate = value;\n      } else {\n        transformedObject[key] = value;\n      }\n    }\n    transformedObject['dimensions'] = this.queryBulderDataset.queryConfig.dimensions;\n    transformedObject['measures'] = this.queryBulderDataset.queryConfig.measures;\n    transformedObject['filters'] = this.transformDataForMFilter(this.queryBulderDataset.queryConfig.mapedFilters);;\n    transformedObject['sorters'] = this.queryBulderDataset.queryConfig.sorters;\n    transformedObject[\"paginationRequired\"] = true;\n    console.log(transformedObject);\n\n    this.service.validateAggregatePaginatedQuery(transformedObject).subscribe(data => {\n      console.log(data);\n      this.query_data = data.query\n      this.isModelVisible = true;\n    }, err => {\n      this.toastr.error('Unexpected Server Exception. Please contact System Admin.')\n    })\n  }\n\n  closeModalVisibleModal() {\n    this.isModelVisible = false;\n    this.query_data = '';\n  }\n\n  transformDataForMFilter(mapfilter) {\n    let result = [];\n    mapfilter.forEach(mapping => {\n      let resultObj = {\n        columnName: mapping.serverColumn,\n        dataType: mapping.dataType,\n        operator: mapping.operatorName,\n        value: mapping.defaultValue\n      };\n      result.push(resultObj);\n    });\n    return result;\n  }\n\n\n  copySqlFromModal() {\n    const listener = (e: ClipboardEvent) => {\n      e.clipboardData!.setData('text/plain', this.query_data);\n      e.preventDefault();\n    };\n    this.isSqlCopiedText = true;\n    document.addEventListener('copy', listener);\n    document.execCommand('copy');\n    document.removeEventListener('copy', listener);\n  }\n\n  createDataSet() {\n    this.getQueryBulbderDataSet.emit(this.queryBulderDataset)\n  }\n\n  getQueryForDetailsData(e) {\n    if (e.value == 'Basic') {\n      this.queryBulderDataset.api = '/kpi/genericDetailDataResponse'\n      this.queryBulderDataset.queryConfig.columns = [];\n    } else {\n      this.queryBulderDataset.api = '/kpi/genericAggregatePaginatedKpiServiceResponse';\n    }\n  }\n\n\n  getDataConfig(e) {\n\n    if (e.event) {\n      this.selectedDataSource = e.value;\n      this.isQueryTypeSelect = true;\n    }\n\n  }\n\n\n  addHavingsColume() {\n    let obj = {\n      \"columnName\": \"\",\n      \"advancedColumn\": \"\",\n      \"dataType\": \"\",\n      \"operator\": \"\",\n      \"value\": \"\"\n    }\n    this.queryBulderDataset.queryConfig.havings.push(obj);\n  }\n\n  deleteHavingsColume(i) {\n    this.queryBulderDataset.queryConfig.havings.splice(i, 1);\n  }\n\n\n}\n","<div class=\"m-2\">\n    <div class=\"flex flex-row mb-2\">\n        <div class=\"mx-2 w-1/3\">\n            <div class=\"text-md mb-2\">End Point</div>\n            <dx-text-box [(ngModel)]=\"queryBulderDataset.api\"></dx-text-box>\n        </div>\n        <div class=\"mx-2 w-1/3\">\n            <div class=\"text-md mb-2\">Query Type</div>\n            <dx-select-box [dataSource]=\"['Aggregate','Basic']\" (onValueChanged)=\"getQueryForDetailsData($event)\">\n            </dx-select-box>\n        </div>\n        <div class=\"mx-2 w-1/3 mt-6\" *ngIf=\"selectedDataSource == 'mongo'\">\n            <dx-check-box [(ngModel)]=\"isReconColume\" text='Recon Column'>\n            </dx-check-box>\n        </div>\n    </div>\n\n    <div class=\"flex flex-col flex-auto min-w-0 my-3\">\n        <div class=\"text-lg py-2 font-extrabold border-b bg-gray-700 text-white px-2\"> Request Params\n        </div>\n        <div class=\"pt-2 border-x border-b \">\n            <div class=\"grid grid-cols-2 gap-4 w-full p-2\">\n                <div class=\"my-2 flex flex-row px-2 border-r\" *ngFor=\"let item of reqFieldsDataSource; let i = index;\">\n                    <div class=\"px-2 mb-2\">\n                        <div class=\"text-md mb-2\"> Params Name</div>\n                        <dx-text-box [(ngModel)]=\"item.name\"></dx-text-box>\n\n                    </div>\n                    <div class=\"px-2 mb-2\">\n                        <div class=\"text-md mb-2\"> Params Value </div>\n                        <ng-container *ngIf=\"item.name == 'dbConfig'\">\n                            <dx-select-box [items]=\"['mongo','impala','postgres','mysql','bigquery']\"\n                                (onValueChanged)=\"getDataConfig($event)\" [(ngModel)]=\"item.value\"></dx-select-box>\n                        </ng-container>\n                        <ng-container *ngIf=\"item.name !== 'dbConfig'\">\n                            <dx-text-box [(ngModel)]=\"item.value\"></dx-text-box>\n                        </ng-container>\n\n                    </div>\n                    <div class=\"px-2 mb-2\">\n                        <div class=\"text-center mt-8\">\n                            <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\" (click)=\"deleteParams(i)\"><i\n                                    class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n                            </button>\n                        </div>\n                    </div>\n                </div>\n            </div>\n            <div class=\"flex flex-row my-2 justify-end\">\n                <p class=\"text-sm italic text-gray-300 mr-6\">** Please Save Request Params Before Submit\n                    Dataset\n                </p>\n                <button class=\"{{commonService.btn_success_sm}} cursor-pointer\" (click)=\"saveParams()\">Save\n                    Params</button>\n                <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\" (click)=\"addParams()\">Add\n                    Params</button>\n\n            </div>\n        </div>\n    </div>\n\n    <ng-container *ngIf=\"isQueryTypeSelect\">\n        <div class=\"flex flex-col flex-auto min-w-0 my-2\">\n            <div class=\"text-lg py-2 font-extrabold border-b bg-gray-700 text-white px-2\"> Columns and Measures\n            </div>\n            <div class=\"pt-2 border-x border-b \">\n                <div class=\"my-2 flex justify-between\"\n                    *ngFor=\"let item of queryBulderDataset.queryConfig.columns; let i = index;\">\n                    <div class=\"px-1 mb-2\">\n                        <div class=\"text-md mb-2\"> Measures</div>\n                        <dx-check-box [value]=\"item.measures\" [(ngModel)]=\"item.measures\"></dx-check-box>\n                    </div>\n                    <div class=\"px-1 mb-2\">\n                        <div class=\"text-md mb-2\"> Value Field(aliasName)</div>\n                        <dx-text-box [(ngModel)]=\"item.dataField\"></dx-text-box>\n                    </div>\n                    <div class=\"px-1 mb-2\">\n                        <div class=\"text-md mb-2\"> Server Column Name</div>\n                        <dx-text-box [(ngModel)]=\"item.columnName\"></dx-text-box>\n                    </div>\n                    <div class=\"px-1 mb-2\">\n                        <div class=\"text-md mb-2\"> Function Name</div>\n                        <dx-select-box [searchEnabled]=\"true\" [items]=\"kpi_function\"\n                            [(ngModel)]=\"item.functionName\"></dx-select-box>\n                    </div>\n                    <div class=\"px-1 mb-2\">\n                        <div class=\"text-md mb-2\"> Enrich Name</div>\n                        <dx-select-box [searchEnabled]=\"true\" [items]=\"kpi_enrichment_name\"\n                            [(ngModel)]=\"item.enrichFunction\"></dx-select-box>\n                    </div>\n                    <div class=\"px-1 mb-2\">\n                        <div class=\"text-md mb-2\"> Advanced Column</div>\n                        <dx-text-box [(ngModel)]=\"item.advancedColumn\"></dx-text-box>\n                    </div>\n                    <div class=\"px-1 mb-2\">\n                        <div class=\"text-md mb-2\"> Caption</div>\n                        <dx-text-box [(ngModel)]=\"item.caption\"></dx-text-box>\n                    </div>\n                    <div class=\"px-1 mt-8\">\n                        <div class=\"flex flex-row\">\n                            <button *ngIf=\"i !== 0\" class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n                                (click)=\"moveItemForMeasuresColumns(i, 'up')\">\n                                <i class=\"fa fa-arrow-up\" aria-hidden=\"true\"></i>\n                            </button>\n\n                            <button *ngIf=\"i !== queryBulderDataset.queryConfig.columns.length - 1\"\n                                class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n                                (click)=\"moveItemForMeasuresColumns(i, 'down')\">\n                                <i class=\"fa fa-arrow-down\" aria-hidden=\"true\"></i>\n                            </button>\n                        </div>\n                    </div>\n                    <div class=\"px-1 mt-8 text-center\">\n\n                        <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\" (click)=\"deleteColumns(i)\"><i\n                                class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n                        </button>\n                    </div>\n                </div>\n\n                <div class=\"flex flex-row justify-end my-2\">\n                    <p class=\"text-sm italic text-gray-300 mr-6\">** Please Save Columns And Measures Before Submit\n                        Dataset\n                    </p>\n                    <button class=\"{{commonService.btn_success_sm}} cursor-pointer\"\n                        (click)=\"saveColumnsAndMasures()\">Save\n                        Columns</button>\n                    <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\" (click)=\"addColumns()\">Add\n                        Columns</button>\n                </div>\n            </div>\n        </div>\n\n\n        <ng-container *ngIf=\"isReconColume\">\n            <div class=\"flex flex-col flex-auto min-w-0 my-2\">\n                <div class=\"text-lg py-2 font-extrabold border-b bg-gray-700 text-white px-2\"> Add Recon Column\n                </div>\n                <div class=\"pt-2 border-x border-b \">\n                    <div class=\"my-2 flex justify-between\" *ngFor=\"let item of reconColumeDatasource; let i = index;\">\n\n                        <div class=\"px-1 mb-2\">\n                            <div class=\"text-md mb-2\"> Value Field(aliasName)</div>\n                            <dx-text-box [(ngModel)]=\"item.dataField\"></dx-text-box>\n                        </div>\n                        <div class=\"px-1 mb-2\">\n                            <div class=\"text-md mb-2\"> First Key</div>\n                            <dx-text-box [(ngModel)]=\"item.columeOne\"></dx-text-box>\n                        </div>\n                        <div class=\"px-1 mb-2\">\n                            <div class=\"text-md mb-2\"> Second Key</div>\n                            <dx-text-box [(ngModel)]=\"item.columeTwo\"></dx-text-box>\n                        </div>\n\n                        <div class=\"px-1 mb-2\">\n                            <div class=\"text-md mb-2\"> Enrich Name</div>\n                            <dx-select-box [searchEnabled]=\"true\" [items]=\"kpi_enrichment_name\"\n                                [(ngModel)]=\"item.enrichFunction\"></dx-select-box>\n                        </div>\n                        <div class=\"px-1 mb-2\">\n                            <div class=\"text-md mb-2\"> Recon Type</div>\n                            <dx-select-box [searchEnabled]=\"true\" [items]=\"['variance','percentage','absolute']\"\n                                [(ngModel)]=\"item.reconType\"></dx-select-box>\n                        </div>\n\n                        <div class=\"px-1 mb-2\">\n                            <div class=\"text-md mb-2\"> Caption</div>\n                            <dx-text-box [(ngModel)]=\"item.caption\"></dx-text-box>\n                        </div>\n\n                        <div class=\"px-1 mt-8 text-center\">\n\n                            <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n                                (click)=\"deleteReconColume(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n                            </button>\n                        </div>\n                    </div>\n                    <div class=\"flex flex-row justify-end my-2\">\n                        <button class=\"{{commonService.btn_success_sm}} cursor-pointer\"\n                            (click)=\"saveReconsColume()\">Save To\n                            Columns</button>\n                        <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\" (click)=\"addReconColume()\">Add\n                        </button>\n                    </div>\n                </div>\n            </div>\n\n        </ng-container>\n\n        <ng-container>\n            <div class=\"flex flex-col flex-auto min-w-0 my-2\">\n                <div class=\"text-lg py-2 font-extrabold border-b bg-gray-700 text-white px-2\"> Add Having Column\n                </div>\n                <div class=\"pt-2 border-x border-b \">\n                    <div class=\"my-2 flex justify-between\"\n                        *ngFor=\"let item of queryBulderDataset.queryConfig.havings; let i = index;\">\n\n                        <div class=\"px-1 mb-2 w-full\">\n                            <div class=\"text-md mb-2\"> Column Name</div>\n                            <dx-text-box [(ngModel)]=\"item.columnName\"></dx-text-box>\n                        </div>\n                        <div class=\"px-1 mb-2 w-full\">\n                            <div class=\"text-md mb-2\"> Advanced Column</div>\n                            <dx-text-box [(ngModel)]=\"item.advancedColumn\"></dx-text-box>\n                        </div>\n                        <div class=\"px-1 mb-2 w-full\">\n                            <div class=\"text-md mb-2\"> Data Type</div>\n                            <dx-text-box [(ngModel)]=\"item.dataType\"></dx-text-box>\n                        </div>\n\n                        <div class=\"px-1 mb-2 w-full\">\n                            <div class=\"text-md mb-2\"> Operator</div>\n                            <dx-select-box [items]=\"['get','lte']\" [(ngModel)]=\"item.operator\"></dx-select-box>\n                        </div>\n\n                        <div class=\"px-1 mb-2 w-full\">\n                            <div class=\"text-md mb-2\"> Value</div>\n                            <dx-text-box [(ngModel)]=\"item.value\"></dx-text-box>\n                        </div>\n\n                        <div class=\"px-1 mt-8 text-center\">\n                            <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n                                (click)=\"deleteHavingsColume(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n                            </button>\n                        </div>\n                    </div>\n                    <div class=\"flex flex-row justify-end my-2\">\n                        <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\" (click)=\"addHavingsColume()\">Add\n                            Havings\n                        </button>\n                    </div>\n                </div>\n            </div>\n\n        </ng-container>\n\n        <div class=\"flex flex-col flex-auto min-w-0 my-3\">\n            <div class=\"text-lg py-2 font-extrabold border-b bg-gray-700 text-white px-2\"> Sort By\n            </div>\n            <div class=\"pt-2 border-x border-b \">\n                <div class=\"grid grid-cols-2 gap-4 w-full p-2\">\n                    <div class=\"my-2 flex flex-row px-2 border-r\"\n                        *ngFor=\"let item of queryBulderDataset.queryConfig.sorters; let i = index;\">\n                        <div class=\"px-2 mb-2\">\n                            <div class=\"text-md mb-2\"> Params Name</div>\n                            <dx-text-box [(ngModel)]=\"item.columnName\"></dx-text-box>\n\n                        </div>\n                        <div class=\"px-2 mt-8\">\n\n                            <dx-check-box text=\"Descending\" [(ngModel)]=\"item.descending\"></dx-check-box>\n                        </div>\n                        <div class=\"px-2 mb-2\">\n                            <div class=\"text-center mt-8\">\n                                <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n                                    (click)=\"deleteShortColumns(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n                                </button>\n                            </div>\n                        </div>\n                    </div>\n                </div>\n                <div class=\"flex flex-row my-2 justify-end\">\n                    <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\" (click)=\"addShortColumns()\">Add\n                        Column</button>\n\n                </div>\n            </div>\n        </div>\n\n\n        <div class=\"flex flex-col flex-auto min-w-0 my-2\">\n            <div class=\"text-lg py-2 font-extrabold border-b bg-gray-700 text-white px-2\"> Filter Maping\n            </div>\n            <div class=\"pt-2 border-x border-b \">\n                <div class=\"my-2 flex flex-row justify-between\"\n                    *ngFor=\"let item of queryBulderDataset.queryConfig.mapedFilters; let i = index;\">\n\n                    <div class=\"px-1 mb-2 w-full\">\n                        <div class=\"text-md mb-2\"> Local Column</div>\n                        <dx-text-box [(ngModel)]=\"item.localColumn\"></dx-text-box>\n                    </div>\n                    <div class=\"px-1 mb-2 w-full\">\n                        <div class=\"text-md mb-2\"> Server Column</div>\n                        <dx-text-box [(ngModel)]=\"item.serverColumn\"></dx-text-box>\n                    </div>\n                    <div class=\"px-1 mb-2 w-full\">\n                        <div class=\"text-md mb-2\"> Operator</div>\n                        <dx-select-box [searchEnabled]=\"true\" [items]=\"kpi_operator\"\n                            [(ngModel)]=\"item.operatorName\"></dx-select-box>\n                    </div>\n                    <div class=\"px-1 mb-2 w-full\">\n                        <div class=\"text-md mb-2\"> Datatype</div>\n                        <dx-select-box [searchEnabled]=\"true\"\n                            [items]=\"['date','string','timestamp','int', 'double', 'boolean']\"\n                            [(ngModel)]=\"item.dataType\"></dx-select-box>\n                    </div>\n                    <div class=\"px-1 mb-2 w-full\">\n                        <div class=\"text-md mb-2\"> Default Value</div>\n                        <dx-text-box [(ngModel)]=\"item.defaultValue\"></dx-text-box>\n                    </div>\n                    <div class=\"px-1 mt-8\">\n                        <div class=\"flex flex-row\">\n                            <button *ngIf=\"i !== 0\" class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n                                (click)=\"moveItemForColumns(i, 'up')\">\n                                <i class=\"fa fa-arrow-up\" aria-hidden=\"true\"></i>\n                            </button>\n\n                            <button *ngIf=\"i !== queryBulderDataset.queryConfig.mapedFilters.length - 1\"\n                                class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n                                (click)=\"moveItemForColumns(i, 'down')\">\n                                <i class=\"fa fa-arrow-down\" aria-hidden=\"true\"></i>\n                            </button>\n                        </div>\n                    </div>\n                    <div class=\"px-1 mt-8 text-center\">\n                        <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n                            (click)=\"deleteFilterMapingColumns(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n                        </button>\n                    </div>\n                </div>\n            </div>\n            <div class=\"flex flex-row\">\n                <div class=\"w-1/2\" *ngIf=\"selectedDataSource !== 'mongo'\">\n                    <div class=\"flex flex-row justify-start my-2\">\n                        <button class=\"{{commonService.btnOthersPurple}} cursor-pointer\" (click)=\"checkForQuery()\">Check\n                            Query</button>\n                    </div>\n                </div>\n                <div class=\"w-full\">\n                    <div class=\"flex flex-row justify-end my-2\">\n                        <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\"\n                            (click)=\"addFilterMapingColumns()\">Add\n                            Maping</button>\n                    </div>\n                </div>\n            </div>\n\n        </div>\n        <div class=\"flex w-full justify-end mt-5 border-t\">\n            <button class=\"{{commonService.btn_success_md}} cursor-pointer mx-1 my-2\" (click)=\"createDataSet()\">\n                Submit DataSet\n            </button>\n        </div>\n    </ng-container>\n\n\n</div>\n\n\n<ng-container *ngIf=\"isModelVisible\">\n    <div class=\"fixed inset-0 flex items-center justify-center z-50 bg-black bg-opacity-50\">\n        <div class=\"relative p-4 w-full max-w-3xl max-h-full\">\n            <div class=\"relative bg-white rounded-lg shadow  \">\n                <div class=\"flex items-center justify-between p-4 md:p-5 border-b rounded-t \">\n                    <h3 class=\"text-xl font-semibold text-gray-900 \">\n                        Query </h3>\n                    <button type=\"button\" (click)=\"closeModalVisibleModal()\"\n                        class=\"text-gray-400 bg-transparent hover:bg-gray-200 hover:text-gray-900 rounded-lg text-sm w-8 h-8 ms-auto inline-flex justify-center items-center \"\n                        data-modal-hide=\"static-modal\">\n                        <svg class=\"w-3 h-3\" aria-hidden=\"true\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\"\n                            viewBox=\"0 0 14 14\">\n                            <path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\"\n                                d=\"m1 1 6 6m0 0 6 6M7 7l6-6M7 7l-6 6\" />\n                        </svg>\n                        <span class=\"sr-only\">Close</span>\n                    </button>\n                </div>\n                <!-- Modal body -->\n                <div class=\"w-69 p-5\">\n                    <div class=\"flex flex-row bg-gray-800 text-white text-lg p-4 rounded-md text-wrap\">\n                        <code>\n                        {{query_data}}\n                        </code>\n                    </div>\n                </div>\n                <div class=\"flex items-center border-t border-gray-200 rounded-b p-2 justify-end\">\n                    <span class=\"text-gray-700 px-2\" *ngIf=\"isSqlCopiedText\">Copied</span>\n                    <button data-modal-hide=\"static-modal\" type=\"button\" class=\"{{commonService.btn_success_sm}} py-2\"\n                        (click)=\"copySqlFromModal()\">Copy</button>\n                </div>\n            </div>\n        </div>\n    </div>\n</ng-container>"]}
|