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,152 @@
|
|
|
1
|
+
import { Component } 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 "@angular/common";
|
|
6
|
+
import * as i4 from "devextreme-angular/ui/select-box";
|
|
7
|
+
import * as i5 from "devextreme-angular/ui/text-box";
|
|
8
|
+
import * as i6 from "@angular/forms";
|
|
9
|
+
import * as i7 from "@angular/material/icon";
|
|
10
|
+
import * as i8 from "../../shared/loading/loading.component";
|
|
11
|
+
import * as i9 from "../online-metrics/online-metrics.component";
|
|
12
|
+
import * as i10 from "../ofline-metrics/ofline-metrics.component";
|
|
13
|
+
export class CreateMetricsComponent {
|
|
14
|
+
constructor(commonService, toastr) {
|
|
15
|
+
this.commonService = commonService;
|
|
16
|
+
this.toastr = toastr;
|
|
17
|
+
this.reqFieldsDataSource = [];
|
|
18
|
+
this.isreqFields = false;
|
|
19
|
+
this.iscdrParams = false;
|
|
20
|
+
this.cdrFieldsDataSource = [];
|
|
21
|
+
this.kpi_function = ["sum", "count", "avg", "max", "min", "stddev", "count_distinct"];
|
|
22
|
+
this.kpi_operator = ["eq", "gte", "lte", "ne", "in", "notIn"];
|
|
23
|
+
this.kpi_enrichment_name = [];
|
|
24
|
+
this.reqShortDataSource = [];
|
|
25
|
+
this.filterMapingDatasource = [];
|
|
26
|
+
this.isModelVisible = false;
|
|
27
|
+
this.isSqlCopiedText = false;
|
|
28
|
+
this.isReconColume = false;
|
|
29
|
+
this.reconColumeDatasource = [];
|
|
30
|
+
this.isQueryTypeSelect = false;
|
|
31
|
+
this.mesuresAndDimentionsColumns = [];
|
|
32
|
+
this.metricOnlineObject = {
|
|
33
|
+
"metricName": "msc_voice_day_metric",
|
|
34
|
+
"metricId": "",
|
|
35
|
+
"metricDisplayName": "Metric Voice Day Metric",
|
|
36
|
+
"metricType": "online",
|
|
37
|
+
"source": {
|
|
38
|
+
"datasource": "huawei-msc",
|
|
39
|
+
"eventName": "huawei_msc_fct",
|
|
40
|
+
"filters": [
|
|
41
|
+
{ "fieldName": "event_type_key", "operation": "string", "threshold": "1,5,6", "comparator": "in" }
|
|
42
|
+
],
|
|
43
|
+
"exclusions": [
|
|
44
|
+
{ "fieldName": "", "operation": "", "threshold": "", "comparator": "" }
|
|
45
|
+
],
|
|
46
|
+
"dimensions": [
|
|
47
|
+
{ "fieldName": "xdr_date", "aliasName": "record_date", "dataType": "string", "format": "yyyyMMdd" },
|
|
48
|
+
{ "fieldName": "event_type_key", "aliasName": "event_type", "dataType": "string" },
|
|
49
|
+
{ "fieldName": "srv_type_key", "aliasName": "srv_type", "dataType": "string" },
|
|
50
|
+
{ "fieldName": "other_nw_ind_key", "aliasName": "nw_call_type", "dataType": "string" },
|
|
51
|
+
{ "fieldName": "xdr_date", "aliasName": "hour", "dataType": "int", "method": "getHour" },
|
|
52
|
+
{ "fieldName": "other_msisdn_iso_code", "aliasName": "country", "dataType": "string" },
|
|
53
|
+
{ "fieldName": "other_oper", "aliasName": "operator", "dataType": "string" },
|
|
54
|
+
{ "fieldName": "event_direction_key", "aliasName": "direction", "dataType": "string" }
|
|
55
|
+
],
|
|
56
|
+
"measures": [
|
|
57
|
+
{ "fieldName": "original_dur", "aliasName": "msc_mou", "dataType": "double", "type": "sum" },
|
|
58
|
+
{ "aliasName": "msc_count", "type": "count" }
|
|
59
|
+
]
|
|
60
|
+
},
|
|
61
|
+
"target": {
|
|
62
|
+
"databaseName": "rafmdb",
|
|
63
|
+
"dbConfig": "mongo",
|
|
64
|
+
"tableName": "msc_daily_metric",
|
|
65
|
+
"dimensionColumns": ["record_date", "event_type", "srv_type", "direction", "nw_call_type", "hour",
|
|
66
|
+
"country", "operator"
|
|
67
|
+
],
|
|
68
|
+
"measureColumns": [
|
|
69
|
+
"msc_mou", "msc_count"
|
|
70
|
+
],
|
|
71
|
+
"createTable": false,
|
|
72
|
+
"writeDisposition": "append"
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
this.metricMainObject = {
|
|
76
|
+
"metricName": "msc_voice_day_metric",
|
|
77
|
+
"metricId": "",
|
|
78
|
+
"metricDisplayName": "Metric Voice Day Metric",
|
|
79
|
+
"metricType": "online",
|
|
80
|
+
};
|
|
81
|
+
this.metricOflineObject = {
|
|
82
|
+
"metricName": "",
|
|
83
|
+
"metricId": "",
|
|
84
|
+
"metricDisplayName": "",
|
|
85
|
+
"metricType": "offline",
|
|
86
|
+
"source": {
|
|
87
|
+
"databaseName": "rafms",
|
|
88
|
+
"dbConfig": "bigquery",
|
|
89
|
+
"queryTemplate": "",
|
|
90
|
+
"queryTemplateFile": ""
|
|
91
|
+
},
|
|
92
|
+
"target": {
|
|
93
|
+
"databaseName": "rafmdb",
|
|
94
|
+
"dbConfig": "mysql",
|
|
95
|
+
"tableName": "",
|
|
96
|
+
"dimensionColumns": [],
|
|
97
|
+
"measureColumns": [],
|
|
98
|
+
"partitionColumn": "",
|
|
99
|
+
"createTable": true,
|
|
100
|
+
"writeDisposition": "append"
|
|
101
|
+
},
|
|
102
|
+
"execution": {
|
|
103
|
+
"type": "scheduled",
|
|
104
|
+
"jobGroupId": "",
|
|
105
|
+
"arguments": [
|
|
106
|
+
{
|
|
107
|
+
"argumentName": "start_date",
|
|
108
|
+
"labelName": "Event Start Date",
|
|
109
|
+
"datatype": "timestamp",
|
|
110
|
+
"runtimeValue": "static",
|
|
111
|
+
"function": "D1_START"
|
|
112
|
+
},
|
|
113
|
+
{
|
|
114
|
+
"argumentName": "end_date",
|
|
115
|
+
"labelName": "Event End Date",
|
|
116
|
+
"runtimeValue": "static",
|
|
117
|
+
"datatype": "timestamp",
|
|
118
|
+
"function": "D1_END"
|
|
119
|
+
}
|
|
120
|
+
]
|
|
121
|
+
}
|
|
122
|
+
};
|
|
123
|
+
}
|
|
124
|
+
ngOnInit() {
|
|
125
|
+
}
|
|
126
|
+
getMetricType(e) {
|
|
127
|
+
if (e.event) {
|
|
128
|
+
this.metrictype = e.value;
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
submittOnlineMetrics(data) {
|
|
132
|
+
data["metricName"] = this.metricMainObject['metricName'];
|
|
133
|
+
data["metricId"] = this.metricMainObject['metricId'];
|
|
134
|
+
data["metricDisplayName"] = this.metricMainObject['metricDisplayName'];
|
|
135
|
+
data["metricType"] = this.metricMainObject.metricType;
|
|
136
|
+
console.log(data);
|
|
137
|
+
}
|
|
138
|
+
submittOfflineMetrics(data) {
|
|
139
|
+
data["metricName"] = this.metricMainObject['metricName'];
|
|
140
|
+
data["metricId"] = this.metricMainObject['metricId'];
|
|
141
|
+
data["metricDisplayName"] = this.metricMainObject['metricDisplayName'];
|
|
142
|
+
data["metricType"] = this.metricMainObject.metricType;
|
|
143
|
+
console.log(data);
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
CreateMetricsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CreateMetricsComponent, deps: [{ token: i1.CommonService }, { token: i2.ToastrService }], target: i0.ɵɵFactoryTarget.Component });
|
|
147
|
+
CreateMetricsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CreateMetricsComponent, selector: "app-create-metrics", ngImport: i0, template: "<app-loading *ngIf=\"loadingModal\"></app-loading>\n<div class=\"flex flex-col flex-auto w-full\">\n <div class=\"flex flex-col\">\n <div class=\"flex justify-between border-b dark:bg-transparent\">\n <div class=\"flex flex-col ml-1\">\n <div class=\"flex items-center float-start\">\n <div class=\"flex items-center overflow-hidden\">\n <mat-icon class=\"icon-size-2\" [svgIcon]=\"'heroicons_solid:template'\"></mat-icon>\n </div>\n <h2\n class=\"text-2xl md:text-2xl py-3 font-extrabold items-center ml-2 tracking-tight leading-5 truncate capitalize\">\n Create Metrics\n </h2>\n </div>\n <div class=\"\">\n </div>\n </div>\n <!-- <div class=\"flex justify-between items-center border-l-2 p-0 m-0 relative\">\n <div class=\"mx-4\">\n <div class=\"text-lg font-bold mx-4 corsur-pointer\" (click)=\"openDateFilter()\">\n {{selectedDateAndTime}}\n <i class=\"fa fa-calendar\"></i>\n </div>\n </div>\n </div> -->\n </div>\n\n </div>\n\n <div class=\"flex\">\n <div class=\"w-full border-r\">\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\">Metric Name</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.metricName\"></dx-text-box>\n </div>\n <div class=\"mx-2 w-1/3\">\n <div class=\"text-md mb-2\">Metric Display Name</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.metricDisplayName\"></dx-text-box>\n </div>\n <div class=\"mx-2 w-1/3\">\n <div class=\"text-md mb-2\">Metric Id</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.metricId\"></dx-text-box>\n </div>\n <div class=\"mx-2 w-1/3\">\n <div class=\"text-md mb-2\">Metric Type</div>\n <dx-select-box [items]=\"['online','ofline']\" [(ngModel)]=\"metricMainObject.metricType\"\n (onValueChanged)=\"getMetricType($event)\"></dx-select-box>\n </div>\n </div>\n <ng-container *ngIf=\"metricMainObject.metricType == 'online'\">\n <app-online-metrics [onlineMetricData]=\"metricOnlineObject\"\n (getMetRicOnlineDataSet)=\"submittOnlineMetrics($event)\"></app-online-metrics>\n </ng-container>\n <ng-container *ngIf=\"metricMainObject.metricType == 'ofline'\">\n <app-ofline-metrics [onflineMetricData]=\"metricOflineObject\"\n (getMetRicOflineDataSet)=\"submittOfflineMetrics($event)\"></app-ofline-metrics>\n </ng-container>\n\n\n </div>\n </div>\n </div>\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.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: i5.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: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i7.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i8.LoadingComponent, selector: "app-loading" }, { kind: "component", type: i9.OnlineMetricsComponent, selector: "app-online-metrics", inputs: ["onlineMetricData"], outputs: ["getMetRicOnlineDataSet"] }, { kind: "component", type: i10.OflineMetricsComponent, selector: "app-ofline-metrics", inputs: ["onflineMetricData"], outputs: ["getMetRicOflineDataSet"] }] });
|
|
148
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CreateMetricsComponent, decorators: [{
|
|
149
|
+
type: Component,
|
|
150
|
+
args: [{ selector: 'app-create-metrics', template: "<app-loading *ngIf=\"loadingModal\"></app-loading>\n<div class=\"flex flex-col flex-auto w-full\">\n <div class=\"flex flex-col\">\n <div class=\"flex justify-between border-b dark:bg-transparent\">\n <div class=\"flex flex-col ml-1\">\n <div class=\"flex items-center float-start\">\n <div class=\"flex items-center overflow-hidden\">\n <mat-icon class=\"icon-size-2\" [svgIcon]=\"'heroicons_solid:template'\"></mat-icon>\n </div>\n <h2\n class=\"text-2xl md:text-2xl py-3 font-extrabold items-center ml-2 tracking-tight leading-5 truncate capitalize\">\n Create Metrics\n </h2>\n </div>\n <div class=\"\">\n </div>\n </div>\n <!-- <div class=\"flex justify-between items-center border-l-2 p-0 m-0 relative\">\n <div class=\"mx-4\">\n <div class=\"text-lg font-bold mx-4 corsur-pointer\" (click)=\"openDateFilter()\">\n {{selectedDateAndTime}}\n <i class=\"fa fa-calendar\"></i>\n </div>\n </div>\n </div> -->\n </div>\n\n </div>\n\n <div class=\"flex\">\n <div class=\"w-full border-r\">\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\">Metric Name</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.metricName\"></dx-text-box>\n </div>\n <div class=\"mx-2 w-1/3\">\n <div class=\"text-md mb-2\">Metric Display Name</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.metricDisplayName\"></dx-text-box>\n </div>\n <div class=\"mx-2 w-1/3\">\n <div class=\"text-md mb-2\">Metric Id</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.metricId\"></dx-text-box>\n </div>\n <div class=\"mx-2 w-1/3\">\n <div class=\"text-md mb-2\">Metric Type</div>\n <dx-select-box [items]=\"['online','ofline']\" [(ngModel)]=\"metricMainObject.metricType\"\n (onValueChanged)=\"getMetricType($event)\"></dx-select-box>\n </div>\n </div>\n <ng-container *ngIf=\"metricMainObject.metricType == 'online'\">\n <app-online-metrics [onlineMetricData]=\"metricOnlineObject\"\n (getMetRicOnlineDataSet)=\"submittOnlineMetrics($event)\"></app-online-metrics>\n </ng-container>\n <ng-container *ngIf=\"metricMainObject.metricType == 'ofline'\">\n <app-ofline-metrics [onflineMetricData]=\"metricOflineObject\"\n (getMetRicOflineDataSet)=\"submittOfflineMetrics($event)\"></app-ofline-metrics>\n </ng-container>\n\n\n </div>\n </div>\n </div>\n</div>" }]
|
|
151
|
+
}], ctorParameters: function () { return [{ type: i1.CommonService }, { type: i2.ToastrService }]; } });
|
|
152
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-metrics.component.js","sourceRoot":"","sources":["../../../../../../../projects/gamma-app-controller/src/lib/application-controller/application-metric-config/create-metrics/create-metrics.component.ts","../../../../../../../projects/gamma-app-controller/src/lib/application-controller/application-metric-config/create-metrics/create-metrics.component.html"],"names":[],"mappings":"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","sourcesContent":["\n\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { ToastrService } from 'ngx-toastr';\nimport { CommonService } from '../../common';\n\n@Component({\n  selector: 'app-create-metrics',\n  templateUrl: './create-metrics.component.html',\n  styleUrls: ['./create-metrics.component.scss']\n})\nexport class CreateMetricsComponent 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 getQueryBulbderDataSet: EventEmitter<any> = new EventEmitter();\n\n  reconColumeDatasource = [];\n\n  selectedDataSource: any;\n  isQueryTypeSelect: boolean = false;\n\n  mesuresAndDimentionsColumns = [];\n  metricOnlineObject = {\n    \"metricName\": \"msc_voice_day_metric\",\n    \"metricId\": \"\",\n    \"metricDisplayName\": \"Metric Voice Day Metric\",\n    \"metricType\": \"online\",\n    \"source\": {\n      \"datasource\": \"huawei-msc\",\n      \"eventName\": \"huawei_msc_fct\",\n      \"filters\": [\n        { \"fieldName\": \"event_type_key\", \"operation\": \"string\", \"threshold\": \"1,5,6\", \"comparator\": \"in\" }\n      ],\n      \"exclusions\": [\n        { \"fieldName\": \"\", \"operation\": \"\", \"threshold\": \"\", \"comparator\": \"\" }\n      ],\n      \"dimensions\": [\n        { \"fieldName\": \"xdr_date\", \"aliasName\": \"record_date\", \"dataType\": \"string\", \"format\": \"yyyyMMdd\" },\n        { \"fieldName\": \"event_type_key\", \"aliasName\": \"event_type\", \"dataType\": \"string\" },\n        { \"fieldName\": \"srv_type_key\", \"aliasName\": \"srv_type\", \"dataType\": \"string\" },\n        { \"fieldName\": \"other_nw_ind_key\", \"aliasName\": \"nw_call_type\", \"dataType\": \"string\" },\n        { \"fieldName\": \"xdr_date\", \"aliasName\": \"hour\", \"dataType\": \"int\", \"method\": \"getHour\" },\n        { \"fieldName\": \"other_msisdn_iso_code\", \"aliasName\": \"country\", \"dataType\": \"string\" },\n        { \"fieldName\": \"other_oper\", \"aliasName\": \"operator\", \"dataType\": \"string\" },\n        { \"fieldName\": \"event_direction_key\", \"aliasName\": \"direction\", \"dataType\": \"string\" }\n      ],\n      \"measures\": [\n        { \"fieldName\": \"original_dur\", \"aliasName\": \"msc_mou\", \"dataType\": \"double\", \"type\": \"sum\" },\n        { \"aliasName\": \"msc_count\", \"type\": \"count\" }\n      ]\n    },\n    \"target\": {\n      \"databaseName\": \"rafmdb\",\n      \"dbConfig\": \"mongo\",\n      \"tableName\": \"msc_daily_metric\",\n      \"dimensionColumns\": [\"record_date\", \"event_type\", \"srv_type\", \"direction\", \"nw_call_type\", \"hour\",\n        \"country\", \"operator\"\n      ],\n      \"measureColumns\": [\n        \"msc_mou\", \"msc_count\"\n      ],\n      \"createTable\": false,\n      \"writeDisposition\": \"append\"\n    }\n  }\n  metricMainObject: any = {\n    \"metricName\": \"msc_voice_day_metric\",\n    \"metricId\": \"\",\n    \"metricDisplayName\": \"Metric Voice Day Metric\",\n    \"metricType\": \"online\",\n  };\n\n  metricOflineObject = {\n    \"metricName\": \"\",\n    \"metricId\": \"\",\n    \"metricDisplayName\": \"\",\n    \"metricType\": \"offline\",\n    \"source\": {\n      \"databaseName\": \"rafms\",\n      \"dbConfig\": \"bigquery\",\n      \"queryTemplate\": \"\",\n      \"queryTemplateFile\": \"\"\n    },\n    \"target\": {\n      \"databaseName\": \"rafmdb\",\n      \"dbConfig\": \"mysql\",\n      \"tableName\": \"\",\n      \"dimensionColumns\": [],\n      \"measureColumns\": [],\n      \"partitionColumn\": \"\",\n      \"createTable\": true,\n      \"writeDisposition\": \"append\"\n    },\n    \"execution\": {\n      \"type\": \"scheduled\",\n      \"jobGroupId\": \"\",\n      \"arguments\": [\n        {\n          \"argumentName\": \"start_date\",\n          \"labelName\": \"Event Start Date\",\n          \"datatype\": \"timestamp\",\n          \"runtimeValue\": \"static\",\n          \"function\": \"D1_START\"\n        },\n        {\n          \"argumentName\": \"end_date\",\n          \"labelName\": \"Event End Date\",\n          \"runtimeValue\": \"static\",\n          \"datatype\": \"timestamp\",\n          \"function\": \"D1_END\"\n        }\n      ]\n    }\n  }\n\n  metrictype: any;\n\n  constructor(public commonService: CommonService, private toastr: ToastrService) { }\n\n  ngOnInit(): void {\n\n  }\n\n\n  getMetricType(e) {\n    if (e.event) {\n      this.metrictype = e.value;\n    }\n  }\n\n  submittOnlineMetrics(data) {\n    data[\"metricName\"] = this.metricMainObject['metricName'];\n    data[\"metricId\"] = this.metricMainObject['metricId'];\n    data[\"metricDisplayName\"] = this.metricMainObject['metricDisplayName'];\n    data[\"metricType\"] = this.metricMainObject.metricType;\n    console.log(data);\n  }\n  submittOfflineMetrics(data) {\n    data[\"metricName\"] = this.metricMainObject['metricName'];\n    data[\"metricId\"] = this.metricMainObject['metricId'];\n    data[\"metricDisplayName\"] = this.metricMainObject['metricDisplayName'];\n    data[\"metricType\"] = this.metricMainObject.metricType;\n    console.log(data);\n  }\n\n\n}\n","<app-loading *ngIf=\"loadingModal\"></app-loading>\n<div class=\"flex flex-col flex-auto w-full\">\n    <div class=\"flex flex-col\">\n        <div class=\"flex justify-between border-b  dark:bg-transparent\">\n            <div class=\"flex  flex-col ml-1\">\n                <div class=\"flex  items-center float-start\">\n                    <div class=\"flex items-center overflow-hidden\">\n                        <mat-icon class=\"icon-size-2\" [svgIcon]=\"'heroicons_solid:template'\"></mat-icon>\n                    </div>\n                    <h2\n                        class=\"text-2xl md:text-2xl py-3 font-extrabold items-center ml-2 tracking-tight leading-5 truncate capitalize\">\n                        Create Metrics\n                    </h2>\n                </div>\n                <div class=\"\">\n                </div>\n            </div>\n            <!-- <div class=\"flex justify-between items-center border-l-2 p-0 m-0 relative\">\n                <div class=\"mx-4\">\n                    <div class=\"text-lg font-bold mx-4 corsur-pointer\" (click)=\"openDateFilter()\">\n                        {{selectedDateAndTime}}\n                        <i class=\"fa fa-calendar\"></i>\n                    </div>\n                </div>\n            </div> -->\n        </div>\n\n    </div>\n\n    <div class=\"flex\">\n        <div class=\"w-full border-r\">\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\">Metric Name</div>\n                        <dx-text-box [(ngModel)]=\"metricMainObject.metricName\"></dx-text-box>\n                    </div>\n                    <div class=\"mx-2 w-1/3\">\n                        <div class=\"text-md mb-2\">Metric Display Name</div>\n                        <dx-text-box [(ngModel)]=\"metricMainObject.metricDisplayName\"></dx-text-box>\n                    </div>\n                    <div class=\"mx-2 w-1/3\">\n                        <div class=\"text-md mb-2\">Metric Id</div>\n                        <dx-text-box [(ngModel)]=\"metricMainObject.metricId\"></dx-text-box>\n                    </div>\n                    <div class=\"mx-2 w-1/3\">\n                        <div class=\"text-md mb-2\">Metric Type</div>\n                        <dx-select-box [items]=\"['online','ofline']\" [(ngModel)]=\"metricMainObject.metricType\"\n                            (onValueChanged)=\"getMetricType($event)\"></dx-select-box>\n                    </div>\n                </div>\n                <ng-container *ngIf=\"metricMainObject.metricType == 'online'\">\n                    <app-online-metrics [onlineMetricData]=\"metricOnlineObject\"\n                        (getMetRicOnlineDataSet)=\"submittOnlineMetrics($event)\"></app-online-metrics>\n                </ng-container>\n                <ng-container *ngIf=\"metricMainObject.metricType == 'ofline'\">\n                    <app-ofline-metrics [onflineMetricData]=\"metricOflineObject\"\n                        (getMetRicOflineDataSet)=\"submittOfflineMetrics($event)\"></app-ofline-metrics>\n                </ng-container>\n\n\n            </div>\n        </div>\n    </div>\n</div>"]}
|
|
@@ -0,0 +1,77 @@
|
|
|
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 OflineMetricsComponent {
|
|
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.getMetRicOflineDataSet = new EventEmitter();
|
|
29
|
+
this.functionNameContainer = ["LASTDAY_START", "D_1_START", "LASTDAY_END", "D_1_END", "LASTDAY2_START", "D_2_START", "LASTDAY2_END", "D_2_END", "D_7_START", "D_7_END", "TODAY_START", "TODAY_END", "WEEK_START", "WEEK_END", "MONTH_START", "MONTH_END", "HOUR_START", "HOUR_END", "LASTHOUR_START", "LASTHOUR_END"];
|
|
30
|
+
this.reconColumeDatasource = [];
|
|
31
|
+
this.isQueryTypeSelect = false;
|
|
32
|
+
this.mesuresAndDimentionsColumns = [];
|
|
33
|
+
this.metricMainObject = {};
|
|
34
|
+
}
|
|
35
|
+
set onflineMetricData(value) {
|
|
36
|
+
this.metricMainObject = value;
|
|
37
|
+
}
|
|
38
|
+
ngOnInit() {
|
|
39
|
+
this.service.listColumnEnrichmentFunctions().subscribe(data => {
|
|
40
|
+
this.kpi_enrichment_name = data;
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
addArguments() {
|
|
44
|
+
let obj = {
|
|
45
|
+
"argumentName": "",
|
|
46
|
+
"labelName": "",
|
|
47
|
+
"runtimeValue": "",
|
|
48
|
+
"dataType": "",
|
|
49
|
+
"function": ""
|
|
50
|
+
};
|
|
51
|
+
this.metricMainObject.execution.arguments.push(obj);
|
|
52
|
+
}
|
|
53
|
+
deleteArguments(i) {
|
|
54
|
+
this.metricMainObject.execution.arguments.splice(i, 1);
|
|
55
|
+
}
|
|
56
|
+
createOflineMetrics() {
|
|
57
|
+
this.getMetRicOflineDataSet.emit(this.metricMainObject);
|
|
58
|
+
}
|
|
59
|
+
getDataConfig(e) {
|
|
60
|
+
if (e.event) {
|
|
61
|
+
this.selectedDataSource = e.value;
|
|
62
|
+
this.isQueryTypeSelect = true;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
OflineMetricsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: OflineMetricsComponent, deps: [{ token: i1.CommonService }, { token: i2.ToastrService }, { token: i3.ApplicationContentService }], target: i0.ɵɵFactoryTarget.Component });
|
|
67
|
+
OflineMetricsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: OflineMetricsComponent, selector: "app-ofline-metrics", inputs: { onflineMetricData: "onflineMetricData" }, outputs: { getMetRicOflineDataSet: "getMetRicOflineDataSet" }, 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\"> Partition Column</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.target.partitionColumn\"></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\"> Database Name</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.source.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\"> Query Template</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.source.queryTemplate\"></dx-text-box>\n </div>\n <div class=\"px-2 mb-2 w-1/2\">\n <div class=\"text-md mb-2\"> Query Template File</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.source.queryTemplateFile\"></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\">Execution\n </div>\n <div class=\"pt-2 border-x border-b \">\n <div class=\"my-2 flex justify-between\"\n *ngFor=\"let item of metricMainObject.execution.arguments; let i = index;\">\n\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Argument Name</div>\n <dx-text-box [(ngModel)]=\"item.argumentName\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Label Name</div>\n <dx-text-box [(ngModel)]=\"item.labelName\"></dx-text-box>\n </div>\n\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\"> Function</div>\n <dx-select-box [searchEnabled]=\"true\" [items]=\"functionNameContainer\"\n [(ngModel)]=\"item.function\"></dx-select-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> runtimeValue</div>\n <dx-select-box [searchEnabled]=\"true\" [items]=\"['static','dynamic']\"\n [(ngModel)]=\"item.runtimeValue\"></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)=\"deleteArguments(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)=\"addArguments()\">Add\n Columns</button>\n </div>\n </div>\n</div>\n\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)=\"createOflineMetrics()\">\n Save Ofline 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"] }] });
|
|
68
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: OflineMetricsComponent, decorators: [{
|
|
69
|
+
type: Component,
|
|
70
|
+
args: [{ selector: 'app-ofline-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\"> Partition Column</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.target.partitionColumn\"></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\"> Database Name</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.source.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\"> Query Template</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.source.queryTemplate\"></dx-text-box>\n </div>\n <div class=\"px-2 mb-2 w-1/2\">\n <div class=\"text-md mb-2\"> Query Template File</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.source.queryTemplateFile\"></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\">Execution\n </div>\n <div class=\"pt-2 border-x border-b \">\n <div class=\"my-2 flex justify-between\"\n *ngFor=\"let item of metricMainObject.execution.arguments; let i = index;\">\n\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Argument Name</div>\n <dx-text-box [(ngModel)]=\"item.argumentName\"></dx-text-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> Label Name</div>\n <dx-text-box [(ngModel)]=\"item.labelName\"></dx-text-box>\n </div>\n\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\"> Function</div>\n <dx-select-box [searchEnabled]=\"true\" [items]=\"functionNameContainer\"\n [(ngModel)]=\"item.function\"></dx-select-box>\n </div>\n <div class=\"px-1 mb-2 w-full\">\n <div class=\"text-md mb-2\"> runtimeValue</div>\n <dx-select-box [searchEnabled]=\"true\" [items]=\"['static','dynamic']\"\n [(ngModel)]=\"item.runtimeValue\"></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)=\"deleteArguments(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)=\"addArguments()\">Add\n Columns</button>\n </div>\n </div>\n</div>\n\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)=\"createOflineMetrics()\">\n Save Ofline Metrics\n </button>\n</div>" }]
|
|
71
|
+
}], ctorParameters: function () { return [{ type: i1.CommonService }, { type: i2.ToastrService }, { type: i3.ApplicationContentService }]; }, propDecorators: { getMetRicOflineDataSet: [{
|
|
72
|
+
type: Output
|
|
73
|
+
}], onflineMetricData: [{
|
|
74
|
+
type: Input,
|
|
75
|
+
args: ['onflineMetricData']
|
|
76
|
+
}] } });
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ofline-metrics.component.js","sourceRoot":"","sources":["../../../../../../../projects/gamma-app-controller/src/lib/application-controller/application-metric-config/ofline-metrics/ofline-metrics.component.ts","../../../../../../../projects/gamma-app-controller/src/lib/application-controller/application-metric-config/ofline-metrics/ofline-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-ofline-metrics',\n  templateUrl: './ofline-metrics.component.html',\n  styleUrls: ['./ofline-metrics.component.scss']\n})\nexport class OflineMetricsComponent 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 getMetRicOflineDataSet: EventEmitter<any> = new EventEmitter();\n  functionNameContainer = [\"LASTDAY_START\", \"D_1_START\", \"LASTDAY_END\", \"D_1_END\", \"LASTDAY2_START\", \"D_2_START\", \"LASTDAY2_END\", \"D_2_END\", \"D_7_START\", \"D_7_END\", \"TODAY_START\", \"TODAY_END\", \"WEEK_START\", \"WEEK_END\", \"MONTH_START\", \"MONTH_END\", \"HOUR_START\", \"HOUR_END\", \"LASTHOUR_START\", \"LASTHOUR_END\"];\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('onflineMetricData')\n  set onflineMetricData(value) {\n    this.metricMainObject = value;\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  addArguments() {\n    let obj = {\n      \"argumentName\": \"\",\n      \"labelName\": \"\",\n      \"runtimeValue\": \"\",\n      \"dataType\": \"\",\n      \"function\": \"\"\n    }\n    this.metricMainObject.execution.arguments.push(obj);\n  }\n\n\n  deleteArguments(i) {\n    this.metricMainObject.execution.arguments.splice(i, 1)\n  }\n\n\n\n  createOflineMetrics() {\n\n\n    this.getMetRicOflineDataSet.emit(this.metricMainObject)\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}\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\"> Partition Column</div>\n                <dx-text-box [(ngModel)]=\"metricMainObject.target.partitionColumn\"></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\"> Database Name</div>\n                <dx-text-box [(ngModel)]=\"metricMainObject.source.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\"> Query Template</div>\n                <dx-text-box [(ngModel)]=\"metricMainObject.source.queryTemplate\"></dx-text-box>\n            </div>\n            <div class=\"px-2 mb-2 w-1/2\">\n                <div class=\"text-md mb-2\"> Query Template File</div>\n                <dx-text-box [(ngModel)]=\"metricMainObject.source.queryTemplateFile\"></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\">Execution\n    </div>\n    <div class=\"pt-2 border-x border-b \">\n        <div class=\"my-2 flex justify-between\"\n            *ngFor=\"let item of metricMainObject.execution.arguments; let i = index;\">\n\n            <div class=\"px-1 mb-2 w-full\">\n                <div class=\"text-md mb-2\"> Argument Name</div>\n                <dx-text-box [(ngModel)]=\"item.argumentName\"></dx-text-box>\n            </div>\n            <div class=\"px-1 mb-2 w-full\">\n                <div class=\"text-md mb-2\"> Label Name</div>\n                <dx-text-box [(ngModel)]=\"item.labelName\"></dx-text-box>\n            </div>\n\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\"> Function</div>\n                <dx-select-box [searchEnabled]=\"true\" [items]=\"functionNameContainer\"\n                    [(ngModel)]=\"item.function\"></dx-select-box>\n            </div>\n            <div class=\"px-1 mb-2 w-full\">\n                <div class=\"text-md mb-2\"> runtimeValue</div>\n                <dx-select-box [searchEnabled]=\"true\" [items]=\"['static','dynamic']\"\n                    [(ngModel)]=\"item.runtimeValue\"></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)=\"deleteArguments(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)=\"addArguments()\">Add\n                Columns</button>\n        </div>\n    </div>\n</div>\n\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)=\"createOflineMetrics()\">\n        Save Ofline Metrics\n    </button>\n</div>"]}
|