gamma-app-controller 1.1.4 → 1.1.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (21) hide show
  1. package/esm2020/lib/application-controller/application-content.service.mjs +32 -1
  2. package/esm2020/lib/application-controller/application-controller.module.mjs +37 -5
  3. package/esm2020/lib/application-controller/application-dataset-component/application-dataset/application-dataset.component.mjs +4 -4
  4. package/esm2020/lib/application-controller/application-metric-config/all-metrics-config/all-metrics-config.component.mjs +95 -0
  5. package/esm2020/lib/application-controller/application-metric-config/create-metrics/create-metrics.component.mjs +173 -0
  6. package/esm2020/lib/application-controller/application-metric-config/ofline-metrics/ofline-metrics.component.mjs +77 -0
  7. package/esm2020/lib/application-controller/application-metric-config/online-metrics/online-metrics.component.mjs +171 -0
  8. package/esm2020/lib/application-controller/application-view-components/create-comp-view/create-comp-view.component.mjs +4 -4
  9. package/esm2020/public-api.mjs +5 -1
  10. package/fesm2015/gamma-app-controller.mjs +635 -115
  11. package/fesm2015/gamma-app-controller.mjs.map +1 -1
  12. package/fesm2020/gamma-app-controller.mjs +641 -115
  13. package/fesm2020/gamma-app-controller.mjs.map +1 -1
  14. package/lib/application-controller/application-content.service.d.ts +4 -0
  15. package/lib/application-controller/application-controller.module.d.ts +15 -11
  16. package/lib/application-controller/application-metric-config/all-metrics-config/all-metrics-config.component.d.ts +41 -0
  17. package/lib/application-controller/application-metric-config/create-metrics/create-metrics.component.d.ts +136 -0
  18. package/lib/application-controller/application-metric-config/ofline-metrics/ofline-metrics.component.d.ts +42 -0
  19. package/lib/application-controller/application-metric-config/online-metrics/online-metrics.component.d.ts +49 -0
  20. package/package.json +1 -1
  21. package/public-api.d.ts +4 -0
@@ -0,0 +1,173 @@
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/router";
6
+ import * as i4 from "../../application-content.service";
7
+ import * as i5 from "@angular/common";
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
+ import * as i9 from "@angular/material/icon";
12
+ import * as i10 from "../../shared/loading/loading.component";
13
+ import * as i11 from "../online-metrics/online-metrics.component";
14
+ import * as i12 from "../ofline-metrics/ofline-metrics.component";
15
+ export class CreateMetricsComponent {
16
+ constructor(commonService, toastr, router, service) {
17
+ this.commonService = commonService;
18
+ this.toastr = toastr;
19
+ this.router = router;
20
+ this.service = service;
21
+ this.reqFieldsDataSource = [];
22
+ this.isreqFields = false;
23
+ this.iscdrParams = false;
24
+ this.cdrFieldsDataSource = [];
25
+ this.kpi_function = ["sum", "count", "avg", "max", "min", "stddev", "count_distinct"];
26
+ this.kpi_operator = ["eq", "gte", "lte", "ne", "in", "notIn"];
27
+ this.kpi_enrichment_name = [];
28
+ this.reqShortDataSource = [];
29
+ this.filterMapingDatasource = [];
30
+ this.isModelVisible = false;
31
+ this.isSqlCopiedText = false;
32
+ this.isReconColume = false;
33
+ this.reconColumeDatasource = [];
34
+ this.isQueryTypeSelect = false;
35
+ this.mesuresAndDimentionsColumns = [];
36
+ this.metricOnlineObject = {
37
+ "metricName": "msc_voice_day_metric",
38
+ "metricId": "",
39
+ "metricDisplayName": "Metric Voice Day Metric",
40
+ "metricType": "online",
41
+ "source": {
42
+ "datasource": "huawei-msc",
43
+ "eventName": "huawei_msc_fct",
44
+ "filters": [
45
+ { "fieldName": "event_type_key", "operation": "string", "threshold": "1,5,6", "comparator": "in" }
46
+ ],
47
+ "exclusions": [
48
+ { "fieldName": "", "operation": "", "threshold": "", "comparator": "" }
49
+ ],
50
+ "dimensions": [
51
+ { "fieldName": "xdr_date", "aliasName": "record_date", "dataType": "string", "format": "yyyyMMdd" },
52
+ { "fieldName": "event_type_key", "aliasName": "event_type", "dataType": "string" },
53
+ { "fieldName": "srv_type_key", "aliasName": "srv_type", "dataType": "string" },
54
+ { "fieldName": "other_nw_ind_key", "aliasName": "nw_call_type", "dataType": "string" },
55
+ { "fieldName": "xdr_date", "aliasName": "hour", "dataType": "int", "method": "getHour" },
56
+ { "fieldName": "other_msisdn_iso_code", "aliasName": "country", "dataType": "string" },
57
+ { "fieldName": "other_oper", "aliasName": "operator", "dataType": "string" },
58
+ { "fieldName": "event_direction_key", "aliasName": "direction", "dataType": "string" }
59
+ ],
60
+ "measures": [
61
+ { "fieldName": "original_dur", "aliasName": "msc_mou", "dataType": "double", "type": "sum" },
62
+ { "aliasName": "msc_count", "type": "count" }
63
+ ]
64
+ },
65
+ "target": {
66
+ "databaseName": "rafmdb",
67
+ "dbConfig": "mongo",
68
+ "tableName": "msc_daily_metric",
69
+ "partitionColumn": "",
70
+ "dimensionColumns": ["record_date", "event_type", "srv_type", "direction", "nw_call_type", "hour",
71
+ "country", "operator"
72
+ ],
73
+ "measureColumns": [
74
+ "msc_mou", "msc_count"
75
+ ],
76
+ "createTable": false,
77
+ "writeDisposition": "append"
78
+ }
79
+ };
80
+ this.metricMainObject = {
81
+ "metricName": "msc_voice_day_metric",
82
+ "metricId": "",
83
+ "metricDisplayName": "Metric Voice Day Metric",
84
+ "metricType": "online",
85
+ };
86
+ this.metricOflineObject = {
87
+ "metricName": "",
88
+ "metricId": "",
89
+ "metricDisplayName": "",
90
+ "metricType": "offline",
91
+ "runner": "",
92
+ "source": {
93
+ "databaseName": "rafms",
94
+ "dbConfig": "bigquery",
95
+ "queryTemplate": "",
96
+ "queryTemplateFile": ""
97
+ },
98
+ "target": {
99
+ "databaseName": "rafmdb",
100
+ "dbConfig": "mysql",
101
+ "tableName": "",
102
+ "dimensionColumns": [],
103
+ "measureColumns": [],
104
+ "partitionColumn": "",
105
+ "createTable": true,
106
+ "writeDisposition": "append"
107
+ },
108
+ "execution": {
109
+ "type": "scheduled",
110
+ "jobGroupId": "",
111
+ "arguments": [
112
+ {
113
+ "argumentName": "start_date",
114
+ "labelName": "Event Start Date",
115
+ "datatype": "timestamp",
116
+ "runtimeValue": "static",
117
+ "function": "D1_START"
118
+ },
119
+ {
120
+ "argumentName": "end_date",
121
+ "labelName": "Event End Date",
122
+ "runtimeValue": "static",
123
+ "datatype": "timestamp",
124
+ "function": "D1_END"
125
+ }
126
+ ]
127
+ }
128
+ };
129
+ }
130
+ ngOnInit() {
131
+ }
132
+ getMetricType(e) {
133
+ if (e.event) {
134
+ this.metrictype = e.value;
135
+ }
136
+ }
137
+ submittOnlineMetrics(data) {
138
+ data["appName"] = "pronto";
139
+ data["metricId"] = "";
140
+ data["activated"] = false;
141
+ console.log(data);
142
+ this.service.saveOnlineMetricConfig(data).subscribe({
143
+ next: (data) => {
144
+ this.toastr.success("Online Metrics Updates Successfully");
145
+ this.router.navigate(['/apps/controlPanel/metricController']);
146
+ }, error: (err) => {
147
+ this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Create Metrics Config');
148
+ }
149
+ });
150
+ }
151
+ submittOfflineMetrics(data) {
152
+ data["appName"] = "pronto";
153
+ data["metricId"] = "";
154
+ data["activated"] = false;
155
+ console.log(data);
156
+ this.service.editOfflineMetricConfig(data).subscribe({
157
+ next: (data) => {
158
+ this.toastr.success("Offline Metrics Updates Successfully");
159
+ this.router.navigate(['/apps/controlPanel/metricController']);
160
+ }, error: (err) => {
161
+ this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Create Metrics Config');
162
+ }
163
+ });
164
+ console.log(data);
165
+ }
166
+ }
167
+ CreateMetricsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CreateMetricsComponent, deps: [{ token: i1.CommonService }, { token: i2.ToastrService }, { token: i3.Router }, { token: i4.ApplicationContentService }], target: i0.ɵɵFactoryTarget.Component });
168
+ 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: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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"] }, { kind: "component", type: i9.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i10.LoadingComponent, selector: "app-loading" }, { kind: "component", type: i11.OnlineMetricsComponent, selector: "app-online-metrics", inputs: ["onlineMetricData"], outputs: ["getMetRicOnlineDataSet"] }, { kind: "component", type: i12.OflineMetricsComponent, selector: "app-ofline-metrics", inputs: ["onflineMetricData"], outputs: ["getMetRicOflineDataSet"] }] });
169
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CreateMetricsComponent, decorators: [{
170
+ type: Component,
171
+ 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>" }]
172
+ }], ctorParameters: function () { return [{ type: i1.CommonService }, { type: i2.ToastrService }, { type: i3.Router }, { type: i4.ApplicationContentService }]; } });
173
+ //# 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';\nimport { ApplicationContentService } from '../../application-content.service';\nimport { Router } from '@angular/router';\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      \"partitionColumn\": \"\",\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    \"runner\":\"\",\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,\n    private toastr: ToastrService,\n    private router: Router,\n    private service: ApplicationContentService) { }\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[\"appName\"] = \"pronto\";\n    data[\"metricId\"] = \"\";\n    data[\"activated\"] = false;\n    console.log(data);\n    this.service.saveOnlineMetricConfig(data).subscribe({\n      next: (data: any) => {\n        this.toastr.success(\"Online Metrics Updates Successfully\")\n        this.router.navigate(['/apps/controlPanel/metricController'])\n      }, error: (err: any) => {\n        this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Create Metrics Config')\n      }\n    })\n  }\n  submittOfflineMetrics(data) {\n    data[\"appName\"] = \"pronto\";\n    data[\"metricId\"] = \"\";\n    data[\"activated\"] = false;\n    console.log(data);\n    this.service.editOfflineMetricConfig(data).subscribe({\n      next: (data: any) => {\n        this.toastr.success(\"Offline Metrics Updates Successfully\")\n        this.router.navigate(['/apps/controlPanel/metricController'])\n      }, error: (err: any) => {\n        this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Create Metrics Config')\n      }\n    })\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\"> Basic\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\"> Runner</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.runner\"></dx-text-box>\n </div>\n \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\"> 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\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\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\"> Type</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.execution.type\"></dx-text-box>\n </div>\n <div class=\"px-2 mb-2 w-1/2\">\n <div class=\"text-md mb-2\"> Job GroupId</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.execution.jobGroupId\"></dx-text-box>\n </div>\n \n </div>\n\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\"> Basic\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\"> Runner</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.runner\"></dx-text-box>\n </div>\n \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\"> 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\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\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\"> Type</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.execution.type\"></dx-text-box>\n </div>\n <div class=\"px-2 mb-2 w-1/2\">\n <div class=\"text-md mb-2\"> Job GroupId</div>\n <dx-text-box [(ngModel)]=\"metricMainObject.execution.jobGroupId\"></dx-text-box>\n </div>\n \n </div>\n\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\"> Basic\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\"> Runner</div>\n                <dx-text-box [(ngModel)]=\"metricMainObject.runner\"></dx-text-box>\n            </div>\n           \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\"> 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\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\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\"> Type</div>\n                <dx-text-box [(ngModel)]=\"metricMainObject.execution.type\"></dx-text-box>\n            </div>\n            <div class=\"px-2 mb-2 w-1/2\">\n                <div class=\"text-md mb-2\"> Job GroupId</div>\n                <dx-text-box [(ngModel)]=\"metricMainObject.execution.jobGroupId\"></dx-text-box>\n            </div>\n           \n        </div>\n\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>"]}