gamma-app-controller 1.1.4 → 1.1.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/application-controller/application-controller.module.mjs +20 -5
- package/esm2020/lib/application-controller/application-dataset-component/application-dataset/application-dataset.component.mjs +4 -4
- package/esm2020/lib/application-controller/application-metric-config/create-metrics/create-metrics.component.mjs +152 -0
- package/esm2020/lib/application-controller/application-metric-config/ofline-metrics/ofline-metrics.component.mjs +77 -0
- package/esm2020/lib/application-controller/application-metric-config/online-metrics/online-metrics.component.mjs +169 -0
- package/esm2020/public-api.mjs +4 -1
- package/fesm2015/gamma-app-controller.mjs +401 -29
- package/fesm2015/gamma-app-controller.mjs.map +1 -1
- package/fesm2020/gamma-app-controller.mjs +407 -29
- package/fesm2020/gamma-app-controller.mjs.map +1 -1
- package/lib/application-controller/application-controller.module.d.ts +14 -11
- package/lib/application-controller/application-metric-config/create-metrics/create-metrics.component.d.ts +130 -0
- package/lib/application-controller/application-metric-config/ofline-metrics/ofline-metrics.component.d.ts +42 -0
- package/lib/application-controller/application-metric-config/online-metrics/online-metrics.component.d.ts +49 -0
- package/package.json +1 -1
- package/public-api.d.ts +3 -0
|
@@ -0,0 +1,169 @@
|
|
|
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 OnlineMetricsComponent {
|
|
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"];
|
|
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.getMetRicOnlineDataSet = new EventEmitter();
|
|
29
|
+
this.reconColumeDatasource = [];
|
|
30
|
+
this.isQueryTypeSelect = false;
|
|
31
|
+
this.mesuresAndDimentionsColumns = [];
|
|
32
|
+
this.metricMainObject = {};
|
|
33
|
+
}
|
|
34
|
+
set onlineMetricData(value) {
|
|
35
|
+
this.metricMainObject = value;
|
|
36
|
+
value.source.dimensions.forEach(dimension => {
|
|
37
|
+
this.mesuresAndDimentionsColumns.push({
|
|
38
|
+
...dimension,
|
|
39
|
+
measures: false
|
|
40
|
+
});
|
|
41
|
+
});
|
|
42
|
+
value.source.measures.forEach(measure => {
|
|
43
|
+
this.mesuresAndDimentionsColumns.push({
|
|
44
|
+
...measure,
|
|
45
|
+
measures: true
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
ngOnInit() {
|
|
50
|
+
this.service.listColumnEnrichmentFunctions().subscribe(data => {
|
|
51
|
+
this.kpi_enrichment_name = data;
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
addColumns() {
|
|
55
|
+
let obj = {
|
|
56
|
+
"measures": true,
|
|
57
|
+
"fieldName": "",
|
|
58
|
+
"aliasName": "",
|
|
59
|
+
"dataType": "",
|
|
60
|
+
"type": ""
|
|
61
|
+
};
|
|
62
|
+
this.mesuresAndDimentionsColumns.push(obj);
|
|
63
|
+
}
|
|
64
|
+
deleteColumns(i) {
|
|
65
|
+
this.mesuresAndDimentionsColumns.splice(i, 1);
|
|
66
|
+
}
|
|
67
|
+
addFilterMapingColumns() {
|
|
68
|
+
let obj = {
|
|
69
|
+
"fieldName": "",
|
|
70
|
+
"operation": "",
|
|
71
|
+
"threshold": "",
|
|
72
|
+
"comparator": "",
|
|
73
|
+
};
|
|
74
|
+
this.metricMainObject.source.filters.push(obj);
|
|
75
|
+
}
|
|
76
|
+
deleteFilterMapingColumns(i) {
|
|
77
|
+
this.metricMainObject.source.filters.splice(i, 1);
|
|
78
|
+
}
|
|
79
|
+
addExclusionsMapingColumns() {
|
|
80
|
+
let obj = {
|
|
81
|
+
"fieldName": "",
|
|
82
|
+
"operation": "",
|
|
83
|
+
"threshold": "",
|
|
84
|
+
"comparator": "",
|
|
85
|
+
};
|
|
86
|
+
this.metricMainObject.source.exclusions.push(obj);
|
|
87
|
+
}
|
|
88
|
+
deleteExclusionsMapingColumns(i) {
|
|
89
|
+
this.metricMainObject.source.exclusions.splice(i, 1);
|
|
90
|
+
}
|
|
91
|
+
transformDataForMFilter(mapfilter) {
|
|
92
|
+
let result = [];
|
|
93
|
+
mapfilter.forEach(mapping => {
|
|
94
|
+
let resultObj = {
|
|
95
|
+
columnName: mapping.serverColumn,
|
|
96
|
+
dataType: mapping.dataType,
|
|
97
|
+
operator: mapping.operatorName,
|
|
98
|
+
value: mapping.defaultValue
|
|
99
|
+
};
|
|
100
|
+
result.push(resultObj);
|
|
101
|
+
});
|
|
102
|
+
return result;
|
|
103
|
+
}
|
|
104
|
+
createOnlineMetrics() {
|
|
105
|
+
this.metricMainObject.source.measures = [];
|
|
106
|
+
this.metricMainObject.source.dimensions = [];
|
|
107
|
+
this.mesuresAndDimentionsColumns.forEach(element => {
|
|
108
|
+
if (element.measures) {
|
|
109
|
+
let obj = {
|
|
110
|
+
fieldName: element.fieldName,
|
|
111
|
+
aliasName: element.aliasName,
|
|
112
|
+
dataType: element.dataType,
|
|
113
|
+
type: element.type,
|
|
114
|
+
};
|
|
115
|
+
this.metricMainObject.source.measures.push(obj);
|
|
116
|
+
}
|
|
117
|
+
else {
|
|
118
|
+
let obj = {
|
|
119
|
+
fieldName: element.fieldName,
|
|
120
|
+
aliasName: element.aliasName,
|
|
121
|
+
dataType: element.dataType,
|
|
122
|
+
type: element.type,
|
|
123
|
+
};
|
|
124
|
+
this.metricMainObject.source.dimensions.push(obj);
|
|
125
|
+
}
|
|
126
|
+
});
|
|
127
|
+
this.getMetRicOnlineDataSet.emit(this.metricMainObject);
|
|
128
|
+
}
|
|
129
|
+
getQueryForDetailsData(e) {
|
|
130
|
+
if (e.value == 'Basic') {
|
|
131
|
+
this.queryBulderDataset.api = '/kpi/genericDetailDataResponse';
|
|
132
|
+
this.queryBulderDataset.queryConfig.columns = [];
|
|
133
|
+
}
|
|
134
|
+
else {
|
|
135
|
+
this.queryBulderDataset.api = '/kpi/genericAggregatePaginatedKpiServiceResponse';
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
getDataConfig(e) {
|
|
139
|
+
if (e.event) {
|
|
140
|
+
this.selectedDataSource = e.value;
|
|
141
|
+
this.isQueryTypeSelect = true;
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
addHavingsColume() {
|
|
145
|
+
let obj = {
|
|
146
|
+
"columnName": "",
|
|
147
|
+
"advancedColumn": "",
|
|
148
|
+
"dataType": "",
|
|
149
|
+
"operator": "",
|
|
150
|
+
"value": ""
|
|
151
|
+
};
|
|
152
|
+
this.queryBulderDataset.queryConfig.havings.push(obj);
|
|
153
|
+
}
|
|
154
|
+
deleteHavingsColume(i) {
|
|
155
|
+
this.queryBulderDataset.queryConfig.havings.splice(i, 1);
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
OnlineMetricsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: OnlineMetricsComponent, deps: [{ token: i1.CommonService }, { token: i2.ToastrService }, { token: i3.ApplicationContentService }], target: i0.ɵɵFactoryTarget.Component });
|
|
159
|
+
OnlineMetricsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: OnlineMetricsComponent, selector: "app-online-metrics", inputs: { onlineMetricData: "onlineMetricData" }, outputs: { getMetRicOnlineDataSet: "getMetRicOnlineDataSet" }, ngImport: i0, template: "<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\"> Target\n </div>\n <div class=\"pt-2 border-x border-b \">\n <div class=\"flex flex-wrap p-2\">\n <div class=\"px-2 mb-2 w-1/2\">\n <div class=\"text-md mb-2\"> Database Name</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.target.databaseName\"></dx-text-box>\n </div>\n <div class=\"px-2 mb-2 w-1/2\">\n <div class=\"text-md mb-2\"> DB Config </div>\n <dx-select-box [items]=\"['mongo','impala','postgres','mysql','bigquery']\"\n (onValueChanged)=\"getDataConfig($event)\"\n [(ngModel)]=\"metricMainObject.target.dbConfig\"></dx-select-box>\n </div>\n <div class=\"px-2 mb-2 w-1/2\">\n <div class=\"text-md mb-2\"> Table Name</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.target.tableName\"></dx-text-box>\n </div>\n <div class=\"px-2 mb-2 w-1/2\">\n <div class=\"text-md mb-2\"> Dimension Columns</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.target.dimensionColumns\"></dx-text-box>\n </div>\n <div class=\"px-2 mb-2 w-1/3\">\n <div class=\"text-md mb-2\"> Measure Columns</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.target.measureColumns\"></dx-text-box>\n </div>\n <div class=\"px-2 mb-2 w-1/3\">\n <div class=\"text-md mb-2\"> Write Disposition</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.target.writeDisposition\"></dx-text-box>\n </div>\n <div class=\"px-2 mb-2 w-1/3\">\n <div class=\"text-md mb-2 mt-8\"></div>\n <dx-check-box text=\"Create Table\" [(ngModel)]=\"metricMainObject.target.createTable\"></dx-check-box>\n </div>\n </div>\n </div>\n</div>\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\"> Source\n </div>\n <div class=\"pt-2 border-x border-b \">\n <div class=\"flex flex-wrap p-2\">\n <div class=\"px-2 mb-2 w-1/2\">\n <div class=\"text-md mb-2\"> Data Source Name</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.source.datasource\"></dx-text-box>\n </div>\n <div class=\"px-2 mb-2 w-1/2\">\n <div class=\"text-md mb-2\"> Event Name</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.source.eventName\"></dx-text-box>\n </div>\n </div>\n </div>\n</div>\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\">Measures and\n Dimensions\n </div>\n <div class=\"pt-2 border-x border-b \">\n <div class=\"my-2 flex justify-between\" *ngFor=\"let item of mesuresAndDimentionsColumns; 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 w-full\">\n <div class=\"text-md mb-2\"> Value Field(aliasName)</div>\n <dx-text-box [(ngModel)]=\"item.aliasName\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Server Column Name</div>\n <dx-text-box [(ngModel)]=\"item.fieldName\"></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 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\"> Datatype</div>\n <dx-select-box [searchEnabled]=\"true\" [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\"> Type</div>\n <dx-select-box [searchEnabled]=\"true\" [items]=\"kpi_function\" [(ngModel)]=\"item.type\"></dx-select-box>\n </div>\n\n <div class=\"px-1 mt-7 text-center\">\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 <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\" (click)=\"addColumns()\">Add\n Columns</button>\n </div>\n </div>\n</div>\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 metricMainObject.source.filters; let i = index;\">\n\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Field Name</div>\n <dx-text-box [(ngModel)]=\"item.fieldName\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Operation</div>\n <dx-text-box [(ngModel)]=\"item.operation\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Threshold</div>\n <dx-text-box [(ngModel)]=\"item.threshold\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Comparator</div>\n <dx-select-box [(ngModel)]=\"item.comparator\" [items]=\"kpi_operator\"></dx-select-box>\n </div>\n\n <div class=\"px-1 mt-7 text-center\">\n <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\" (click)=\"deleteFilterMapingColumns(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\">\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 </div>\n</div>\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\"> Exclusions\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 metricMainObject.source.exclusions; let i = index;\">\n\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Field Name</div>\n <dx-text-box [(ngModel)]=\"item.fieldName\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Operation</div>\n <dx-text-box [(ngModel)]=\"item.operation\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Threshold</div>\n <dx-text-box [(ngModel)]=\"item.threshold\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Comparator</div>\n <dx-select-box [(ngModel)]=\"item.comparator\" [items]=\"kpi_operator\"></dx-select-box>\n\n </div>\n\n <div class=\"px-1 mt-7 text-center\">\n <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n (click)=\"deleteExclusionsMapingColumns(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n </button>\n </div>\n </div>\n\n <div class=\"flex flex-row\">\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)=\"addExclusionsMapingColumns()\">Add\n Exclusions</button>\n </div>\n </div>\n </div>\n </div>\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)=\"createOnlineMetrics()\">\n Save Online Metrics\n </button>\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { 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"] }] });
|
|
160
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: OnlineMetricsComponent, decorators: [{
|
|
161
|
+
type: Component,
|
|
162
|
+
args: [{ selector: 'app-online-metrics', template: "<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\"> Target\n </div>\n <div class=\"pt-2 border-x border-b \">\n <div class=\"flex flex-wrap p-2\">\n <div class=\"px-2 mb-2 w-1/2\">\n <div class=\"text-md mb-2\"> Database Name</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.target.databaseName\"></dx-text-box>\n </div>\n <div class=\"px-2 mb-2 w-1/2\">\n <div class=\"text-md mb-2\"> DB Config </div>\n <dx-select-box [items]=\"['mongo','impala','postgres','mysql','bigquery']\"\n (onValueChanged)=\"getDataConfig($event)\"\n [(ngModel)]=\"metricMainObject.target.dbConfig\"></dx-select-box>\n </div>\n <div class=\"px-2 mb-2 w-1/2\">\n <div class=\"text-md mb-2\"> Table Name</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.target.tableName\"></dx-text-box>\n </div>\n <div class=\"px-2 mb-2 w-1/2\">\n <div class=\"text-md mb-2\"> Dimension Columns</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.target.dimensionColumns\"></dx-text-box>\n </div>\n <div class=\"px-2 mb-2 w-1/3\">\n <div class=\"text-md mb-2\"> Measure Columns</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.target.measureColumns\"></dx-text-box>\n </div>\n <div class=\"px-2 mb-2 w-1/3\">\n <div class=\"text-md mb-2\"> Write Disposition</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.target.writeDisposition\"></dx-text-box>\n </div>\n <div class=\"px-2 mb-2 w-1/3\">\n <div class=\"text-md mb-2 mt-8\"></div>\n <dx-check-box text=\"Create Table\" [(ngModel)]=\"metricMainObject.target.createTable\"></dx-check-box>\n </div>\n </div>\n </div>\n</div>\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\"> Source\n </div>\n <div class=\"pt-2 border-x border-b \">\n <div class=\"flex flex-wrap p-2\">\n <div class=\"px-2 mb-2 w-1/2\">\n <div class=\"text-md mb-2\"> Data Source Name</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.source.datasource\"></dx-text-box>\n </div>\n <div class=\"px-2 mb-2 w-1/2\">\n <div class=\"text-md mb-2\"> Event Name</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.source.eventName\"></dx-text-box>\n </div>\n </div>\n </div>\n</div>\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\">Measures and\n Dimensions\n </div>\n <div class=\"pt-2 border-x border-b \">\n <div class=\"my-2 flex justify-between\" *ngFor=\"let item of mesuresAndDimentionsColumns; 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 w-full\">\n <div class=\"text-md mb-2\"> Value Field(aliasName)</div>\n <dx-text-box [(ngModel)]=\"item.aliasName\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Server Column Name</div>\n <dx-text-box [(ngModel)]=\"item.fieldName\"></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 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\"> Datatype</div>\n <dx-select-box [searchEnabled]=\"true\" [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\"> Type</div>\n <dx-select-box [searchEnabled]=\"true\" [items]=\"kpi_function\" [(ngModel)]=\"item.type\"></dx-select-box>\n </div>\n\n <div class=\"px-1 mt-7 text-center\">\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 <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\" (click)=\"addColumns()\">Add\n Columns</button>\n </div>\n </div>\n</div>\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 metricMainObject.source.filters; let i = index;\">\n\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Field Name</div>\n <dx-text-box [(ngModel)]=\"item.fieldName\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Operation</div>\n <dx-text-box [(ngModel)]=\"item.operation\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Threshold</div>\n <dx-text-box [(ngModel)]=\"item.threshold\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Comparator</div>\n <dx-select-box [(ngModel)]=\"item.comparator\" [items]=\"kpi_operator\"></dx-select-box>\n </div>\n\n <div class=\"px-1 mt-7 text-center\">\n <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\" (click)=\"deleteFilterMapingColumns(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\">\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 </div>\n</div>\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\"> Exclusions\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 metricMainObject.source.exclusions; let i = index;\">\n\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Field Name</div>\n <dx-text-box [(ngModel)]=\"item.fieldName\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Operation</div>\n <dx-text-box [(ngModel)]=\"item.operation\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Threshold</div>\n <dx-text-box [(ngModel)]=\"item.threshold\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Comparator</div>\n <dx-select-box [(ngModel)]=\"item.comparator\" [items]=\"kpi_operator\"></dx-select-box>\n\n </div>\n\n <div class=\"px-1 mt-7 text-center\">\n <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n (click)=\"deleteExclusionsMapingColumns(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n </button>\n </div>\n </div>\n\n <div class=\"flex flex-row\">\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)=\"addExclusionsMapingColumns()\">Add\n Exclusions</button>\n </div>\n </div>\n </div>\n </div>\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)=\"createOnlineMetrics()\">\n Save Online Metrics\n </button>\n</div>" }]
|
|
163
|
+
}], ctorParameters: function () { return [{ type: i1.CommonService }, { type: i2.ToastrService }, { type: i3.ApplicationContentService }]; }, propDecorators: { getMetRicOnlineDataSet: [{
|
|
164
|
+
type: Output
|
|
165
|
+
}], onlineMetricData: [{
|
|
166
|
+
type: Input,
|
|
167
|
+
args: ['onlineMetricData']
|
|
168
|
+
}] } });
|
|
169
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"online-metrics.component.js","sourceRoot":"","sources":["../../../../../../../projects/gamma-app-controller/src/lib/application-controller/application-metric-config/online-metrics/online-metrics.component.ts","../../../../../../../projects/gamma-app-controller/src/lib/application-controller/application-metric-config/online-metrics/online-metrics.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-online-metrics',\n  templateUrl: './online-metrics.component.html',\n  styleUrls: ['./online-metrics.component.scss']\n})\nexport class OnlineMetricsComponent implements OnInit {\n  loadingModal: boolean;\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\"]\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 getMetRicOnlineDataSet: EventEmitter<any> = new EventEmitter();\n\n  reconColumeDatasource = [];\n\n  selectedDataSource: any;\n  isQueryTypeSelect: boolean = false;\n\n  mesuresAndDimentionsColumns = [];\n  metricMainObject: any = {};\n\n  metrictype: any;\n\n\n  @Input('onlineMetricData')\n  set onlineMetricData(value) {\n    this.metricMainObject = value;\n    value.source.dimensions.forEach(dimension => {\n      this.mesuresAndDimentionsColumns.push({\n        ...dimension,\n        measures: false\n      });\n    });\n    value.source.measures.forEach(measure => {\n      this.mesuresAndDimentionsColumns.push({\n        ...measure,\n        measures: true\n      });\n    });\n  }\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\n  addColumns() {\n    let obj = {\n      \"measures\": true,\n      \"fieldName\": \"\",\n      \"aliasName\": \"\",\n      \"dataType\": \"\",\n      \"type\": \"\"\n    }\n    this.mesuresAndDimentionsColumns.push(obj);\n  }\n\n\n  deleteColumns(i) {\n    this.mesuresAndDimentionsColumns.splice(i, 1)\n  }\n\n  addFilterMapingColumns() {\n    let obj = {\n      \"fieldName\": \"\",\n      \"operation\": \"\",\n      \"threshold\": \"\",\n      \"comparator\": \"\",\n    }\n    this.metricMainObject.source.filters.push(obj);\n  }\n\n  deleteFilterMapingColumns(i) {\n    this.metricMainObject.source.filters.splice(i, 1);\n  }\n\n  addExclusionsMapingColumns() {\n    let obj = {\n      \"fieldName\": \"\",\n      \"operation\": \"\",\n      \"threshold\": \"\",\n      \"comparator\": \"\",\n    }\n    this.metricMainObject.source.exclusions.push(obj);\n  }\n\n  deleteExclusionsMapingColumns(i) {\n    this.metricMainObject.source.exclusions.splice(i, 1);\n  }\n\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\n  createOnlineMetrics() {\n    this.metricMainObject.source.measures = [];\n    this.metricMainObject.source.dimensions = [];\n\n    this.mesuresAndDimentionsColumns.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          fieldName: element.fieldName,\n          aliasName: element.aliasName,\n          dataType: element.dataType,\n          type: element.type,\n        }\n\n        this.metricMainObject.source.measures.push(obj);\n      } else {\n        let obj = {\n          fieldName: element.fieldName,\n          aliasName: element.aliasName,\n          dataType: element.dataType,\n          type: element.type,\n        }\n        this.metricMainObject.source.dimensions.push(obj);\n      }\n    });\n\n    this.getMetRicOnlineDataSet.emit(this.metricMainObject)\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    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=\"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\"> Target\n    </div>\n    <div class=\"pt-2 border-x border-b \">\n        <div class=\"flex flex-wrap p-2\">\n            <div class=\"px-2 mb-2 w-1/2\">\n                <div class=\"text-md mb-2\"> Database Name</div>\n                <dx-text-box [(ngModel)]=\"metricMainObject.target.databaseName\"></dx-text-box>\n            </div>\n            <div class=\"px-2 mb-2 w-1/2\">\n                <div class=\"text-md mb-2\"> DB Config </div>\n                <dx-select-box [items]=\"['mongo','impala','postgres','mysql','bigquery']\"\n                    (onValueChanged)=\"getDataConfig($event)\"\n                    [(ngModel)]=\"metricMainObject.target.dbConfig\"></dx-select-box>\n            </div>\n            <div class=\"px-2 mb-2 w-1/2\">\n                <div class=\"text-md mb-2\"> Table Name</div>\n                <dx-text-box [(ngModel)]=\"metricMainObject.target.tableName\"></dx-text-box>\n            </div>\n            <div class=\"px-2 mb-2 w-1/2\">\n                <div class=\"text-md mb-2\"> Dimension Columns</div>\n                <dx-text-box [(ngModel)]=\"metricMainObject.target.dimensionColumns\"></dx-text-box>\n            </div>\n            <div class=\"px-2 mb-2 w-1/3\">\n                <div class=\"text-md mb-2\"> Measure Columns</div>\n                <dx-text-box [(ngModel)]=\"metricMainObject.target.measureColumns\"></dx-text-box>\n            </div>\n            <div class=\"px-2 mb-2 w-1/3\">\n                <div class=\"text-md mb-2\"> Write Disposition</div>\n                <dx-text-box [(ngModel)]=\"metricMainObject.target.writeDisposition\"></dx-text-box>\n            </div>\n            <div class=\"px-2 mb-2 w-1/3\">\n                <div class=\"text-md mb-2 mt-8\"></div>\n                <dx-check-box text=\"Create Table\" [(ngModel)]=\"metricMainObject.target.createTable\"></dx-check-box>\n            </div>\n        </div>\n    </div>\n</div>\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\"> Source\n    </div>\n    <div class=\"pt-2 border-x border-b \">\n        <div class=\"flex flex-wrap p-2\">\n            <div class=\"px-2 mb-2 w-1/2\">\n                <div class=\"text-md mb-2\"> Data Source Name</div>\n                <dx-text-box [(ngModel)]=\"metricMainObject.source.datasource\"></dx-text-box>\n            </div>\n            <div class=\"px-2 mb-2 w-1/2\">\n                <div class=\"text-md mb-2\"> Event Name</div>\n                <dx-text-box [(ngModel)]=\"metricMainObject.source.eventName\"></dx-text-box>\n            </div>\n        </div>\n    </div>\n</div>\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\">Measures and\n        Dimensions\n    </div>\n    <div class=\"pt-2 border-x border-b \">\n        <div class=\"my-2 flex justify-between\" *ngFor=\"let item of mesuresAndDimentionsColumns; 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 w-full\">\n                <div class=\"text-md mb-2\"> Value Field(aliasName)</div>\n                <dx-text-box [(ngModel)]=\"item.aliasName\"></dx-text-box>\n            </div>\n            <div class=\"px-1 mb-2 w-full\">\n                <div class=\"text-md mb-2\"> Server Column Name</div>\n                <dx-text-box [(ngModel)]=\"item.fieldName\"></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 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\"> Datatype</div>\n                <dx-select-box [searchEnabled]=\"true\" [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\"> Type</div>\n                <dx-select-box [searchEnabled]=\"true\" [items]=\"kpi_function\" [(ngModel)]=\"item.type\"></dx-select-box>\n            </div>\n\n            <div class=\"px-1 mt-7 text-center\">\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            <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\" (click)=\"addColumns()\">Add\n                Columns</button>\n        </div>\n    </div>\n</div>\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 metricMainObject.source.filters; let i = index;\">\n\n            <div class=\"px-1 mb-2 w-full\">\n                <div class=\"text-md mb-2\"> Field Name</div>\n                <dx-text-box [(ngModel)]=\"item.fieldName\"></dx-text-box>\n            </div>\n            <div class=\"px-1 mb-2 w-full\">\n                <div class=\"text-md mb-2\"> Operation</div>\n                <dx-text-box [(ngModel)]=\"item.operation\"></dx-text-box>\n            </div>\n            <div class=\"px-1 mb-2 w-full\">\n                <div class=\"text-md mb-2\"> Threshold</div>\n                <dx-text-box [(ngModel)]=\"item.threshold\"></dx-text-box>\n            </div>\n            <div class=\"px-1 mb-2 w-full\">\n                <div class=\"text-md mb-2\"> Comparator</div>\n                <dx-select-box [(ngModel)]=\"item.comparator\" [items]=\"kpi_operator\"></dx-select-box>\n            </div>\n\n            <div class=\"px-1 mt-7 text-center\">\n                <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\" (click)=\"deleteFilterMapingColumns(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\">\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    </div>\n</div>\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\"> Exclusions\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 metricMainObject.source.exclusions; let i = index;\">\n\n            <div class=\"px-1 mb-2 w-full\">\n                <div class=\"text-md mb-2\"> Field Name</div>\n                <dx-text-box [(ngModel)]=\"item.fieldName\"></dx-text-box>\n            </div>\n            <div class=\"px-1 mb-2 w-full\">\n                <div class=\"text-md mb-2\"> Operation</div>\n                <dx-text-box [(ngModel)]=\"item.operation\"></dx-text-box>\n            </div>\n            <div class=\"px-1 mb-2 w-full\">\n                <div class=\"text-md mb-2\"> Threshold</div>\n                <dx-text-box [(ngModel)]=\"item.threshold\"></dx-text-box>\n            </div>\n            <div class=\"px-1 mb-2 w-full\">\n                <div class=\"text-md mb-2\"> Comparator</div>\n                <dx-select-box [(ngModel)]=\"item.comparator\" [items]=\"kpi_operator\"></dx-select-box>\n\n            </div>\n\n            <div class=\"px-1 mt-7 text-center\">\n                <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n                    (click)=\"deleteExclusionsMapingColumns(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n                </button>\n            </div>\n        </div>\n\n        <div class=\"flex flex-row\">\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)=\"addExclusionsMapingColumns()\">Add\n                        Exclusions</button>\n                </div>\n            </div>\n        </div>\n    </div>\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)=\"createOnlineMetrics()\">\n        Save Online Metrics\n    </button>\n</div>"]}
|
package/esm2020/public-api.mjs
CHANGED
|
@@ -36,6 +36,9 @@ export * from './lib/application-controller/shared/advanced-component/gamma-geo-
|
|
|
36
36
|
export * from './lib/application-controller/page-controller/page-config/page-config.component';
|
|
37
37
|
export * from './lib/application-controller/page-controller/page-config-multi-layout/page-config-multi-layout.component';
|
|
38
38
|
export * from './lib/application-controller/page-controller/page-controller/page-controller.component';
|
|
39
|
+
export * from './lib/application-controller/application-metric-config/create-metrics/create-metrics.component';
|
|
40
|
+
export * from './lib/application-controller/application-metric-config/ofline-metrics/ofline-metrics.component';
|
|
41
|
+
export * from './lib/application-controller/application-metric-config/online-metrics/online-metrics.component';
|
|
39
42
|
export * from './lib/application-controller/application-dataset-call.service';
|
|
40
43
|
export * from './lib/application-controller/application-content.service';
|
|
41
44
|
export * from './lib/application-controller/kpi-service';
|
|
@@ -51,4 +54,4 @@ export * from './lib/application-controller/environment';
|
|
|
51
54
|
export * from './lib/application-controller/support-components/dash-chart/dash-chart.component';
|
|
52
55
|
export * from './lib/application-controller/support-components/dash-table/dash-table.component';
|
|
53
56
|
export * from './lib/application-controller/moment-helper';
|
|
54
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"public-api.js","sourceRoot":"","sources":["../../../projects/gamma-app-controller/src/public-api.ts"],"names":[],"mappings":"AAIA,cAAc,oCAAoC,CAAC;AACnD,cAAc,sCAAsC,CAAC;AACrD,cAAc,mCAAmC,CAAC;AAClD,cAAc,oBAAoB,CAAC;AACnC,cAAc,4DAA4D,CAAC;AAO3E,cAAc,mCAAmC,CAAC;AAClD,cAAc,4DAA4D,CAAC;AAC3E,cAAc,oDAAoD,CAAC;AACnE,cAAc,wDAAwD,CAAC;AAGvE,cAAc,8EAA8E,CAAC;AAC7F,cAAc,8GAA8G,CAAC;AAC7H,cAAc,4GAA4G,CAAC;AAC3H,cAAc,oGAAoG,CAAC;AACnH,cAAc,wGAAwG,CAAC;AACvH,cAAc,sGAAsG,CAAC;AACrH,cAAc,oEAAoE,CAAC;AACnF,cAAc,6EAA6E,CAAC;AAC5F,cAAc,4HAA4H,CAAC;AAC3I,cAAc,gGAAgG,CAAC;AAC/G,cAAc,kHAAkH,CAAC;AACjI,cAAc,0GAA0G,CAAC;AACzH,cAAc,4HAA4H,CAAC;AAC3I,cAAc,0HAA0H,CAAC;AACzI,cAAc,4GAA4G,CAAC;AAC3H,cAAc,gGAAgG,CAAC;AAC/G,cAAc,0HAA0H,CAAC;AACzI,cAAc,mEAAmE,CAAC;AAClF,cAAc,yEAAyE,CAAC;AACxF,cAAc,yFAAyF,CAAC;AACxG,cAAc,+EAA+E,CAAC;AAC9F,cAAc,6DAA6D,CAAC;AAC5E,cAAc,yFAAyF,CAAC;AACxG,cAAc,2EAA2E,CAAC;AAC1F,cAAc,gGAAgG,CAAC;AAC/G,cAAc,kGAAkG,CAAC;AAEjH,cAAc,gFAAgF,CAAC;AAC/F,cAAc,0GAA0G,CAAC;AACzH,cAAc,wFAAwF,CAAC;AAGvG,cAAc,gGAAgG,CAAC;AAC/G,cAAc,gGAAgG,CAAC;AAC/G,cAAc,gGAAgG,CAAC;AAK/G,cAAc,+DAA+D,CAAC;AAC9E,cAAc,0DAA0D,CAAC;AACzE,cAAc,0CAA0C,CAAC;AAEzD,cAAc,+CAA+C,CAAC;AAC9D,cAAc,oCAAoC,CAAC;AAGnD,cAAc,kDAAkD,CAAC;AACjE,cAAc,4FAA4F,CAAC;AAC3G,cAAc,oGAAoG,CAAC;AAGnH,cAAc,sCAAsC,CAAC;AACrD,cAAc,oBAAoB,CAAC;AACnC,cAAc,qCAAqC,CAAC;AACpD,cAAc,0CAA0C,CAAC;AAGzD,cAAc,iFAAiF,CAAA;AAC/F,cAAc,iFAAiF,CAAA;AAG/F,cAAc,4CAA4C,CAAA","sourcesContent":["/*\n * Public API Surface of gamma-app-controller\n */\n\nexport * from './lib/gamma-app-controller.service';\nexport * from './lib/gamma-app-controller.component';\nexport * from './lib/gamma-app-controller.module';\nexport * from './lib/icons.module';\nexport * from './lib/application-controller/application-controller.module';\n// export * from './lib/application-controller/application-content.service';\n// export * from './lib/application-controller/application-dataset-call.service';\n// export * from './lib/application-controller/environment';\n\n\n// Export Modules\nexport * from './lib/gamma-app-controller.module';\nexport * from './lib/application-controller/application-controller.module';\nexport * from './lib/application-controller/loading/loadingModule';\nexport * from './lib/application-controller/loading/loading.component';\n\n// Export Components\nexport * from './lib/application-controller/application-filter/application-filter.component';\nexport * from './lib/application-controller/application-dataset-component/create-dataset-json/create-dataset-json.component';\nexport * from './lib/application-controller/application-dataset-component/create-dataset-sql/create-dataset-sql.component';\nexport * from './lib/application-controller/application-dataset-component/create-dataset/create-dataset.component';\nexport * from './lib/application-controller/application-view-components/application-views/application-views.component';\nexport * from './lib/application-controller/application-view-components/create-comp-view/create-comp-view.component';\nexport * from './lib/application-controller/common-header/common-header.component';\nexport * from './lib/application-controller/page-templates/cdr-config/cdr-config.component';\nexport * from './lib/application-controller/shared/advanced-component/advance-widget-header-filter/advance-widget-header-filter.component';\nexport * from './lib/application-controller/shared/advanced-component/app-advance-header/app-header.component';\nexport * from './lib/application-controller/shared/advanced-component/gamm-single-number-card/gamm-single-number-card.component';\nexport * from './lib/application-controller/shared/advanced-component/gamma-advance-chart/gamma-advance-chart.component';\nexport * from './lib/application-controller/shared/advanced-component/gamma-advance-operator-table/gamma-advance-operator-table.component';\nexport * from './lib/application-controller/shared/advanced-component/gamma-table-with-percentage/gamma-table-with-percentage.component';\nexport * from './lib/application-controller/shared/advanced-component/gamma-today-previous/gamma-today-previous.component';\nexport * from './lib/application-controller/shared/advanced-component/google-geo-map/google-geo-map.component';\nexport * from './lib/application-controller/shared/advanced-component/gamma-table-clumn-bar-chart/gamma-table-clumn-bar-chart.component';\nexport * from './lib/application-controller/shared/app-title/app-title.component';\nexport * from './lib/application-controller/shared/gamam-widget/gamam-widget.component';\nexport * from './lib/application-controller/shared/gamma-advance-filter/gamma-advance-filter.component';\nexport * from './lib/application-controller/shared/gamma-bread-crumbs/bread-crumbs.component';\nexport * from './lib/application-controller/shared/loader/loader.component';\nexport * from './lib/application-controller/support-components/table-with-bar/table-with-bar.component';\nexport * from './lib/application-controller/support-components/geo-map/geo-map.component';\nexport * from './lib/application-controller/shared/advanced-component/google-geo-map/google-geo-map.component';\nexport * from './lib/application-controller/shared/advanced-component/gamma-geo-chart/gamma-geo-chart.component';\n\nexport * from './lib/application-controller/page-controller/page-config/page-config.component';\nexport * from './lib/application-controller/page-controller/page-config-multi-layout/page-config-multi-layout.component';\nexport * from './lib/application-controller/page-controller/page-controller/page-controller.component';\n\n//metric component\nexport * from './lib/application-controller/application-metric-config/create-metrics/create-metrics.component';\nexport * from './lib/application-controller/application-metric-config/ofline-metrics/ofline-metrics.component';\nexport * from './lib/application-controller/application-metric-config/online-metrics/online-metrics.component';\n\n\n\n// Export Services\nexport * from './lib/application-controller/application-dataset-call.service';\nexport * from './lib/application-controller/application-content.service';\nexport * from './lib/application-controller/kpi-service';\n// export * from './lib/application-controller/kpi-comon-service';\nexport * from './lib/application-controller/app.http.service';\nexport * from './lib/gamma-app-controller.service';\n\n// Export Pipes\nexport * from './lib/application-controller/shared/safeHtmlPipe';\nexport * from './lib/application-controller/application-dataset-component/create-dataset-sql/sqlFormatter';\nexport * from './lib/application-controller/shared/advanced-component/gamma-table-with-percentage/contentSafeHtml';\n\n// Export Miscellaneous\nexport * from './lib/gamma-app-controller.component';\nexport * from './lib/icons.module';\nexport * from './lib/application-controller/common';\nexport * from './lib/application-controller/environment';\n\n// support component\nexport * from './lib/application-controller/support-components/dash-chart/dash-chart.component'\nexport * from './lib/application-controller/support-components/dash-table/dash-table.component'\n\n//moment\nexport * from './lib/application-controller/moment-helper'\n\n\n\n"]}
|