gamma-app-controller 1.1.12 → 1.1.14
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-dataset-component/create-dataset/create-dataset.component.mjs +8 -1
- package/esm2020/lib/application-controller/application-dataset-component/create-dataset-sql/create-dataset-sql.component.mjs +17 -7
- package/esm2020/lib/application-controller/application-filter/application-filter.component.mjs +26 -16
- package/esm2020/lib/application-controller/application-view-components/create-comp-view/create-comp-view.component.mjs +1 -2
- package/esm2020/lib/application-controller/page-controller/page-config/page-config.component.mjs +21 -1
- package/fesm2015/gamma-app-controller.mjs +70 -21
- package/fesm2015/gamma-app-controller.mjs.map +1 -1
- package/fesm2020/gamma-app-controller.mjs +67 -21
- package/fesm2020/gamma-app-controller.mjs.map +1 -1
- package/lib/application-controller/application-filter/application-filter.component.d.ts +3 -1
- package/lib/application-controller/page-controller/page-config/page-config.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -133,6 +133,13 @@ export class CreateDatasetComponent {
|
|
|
133
133
|
"operatorName": "lte",
|
|
134
134
|
"defaultValue": "",
|
|
135
135
|
"dataType": "string"
|
|
136
|
+
},
|
|
137
|
+
{
|
|
138
|
+
"localColumn": "limit",
|
|
139
|
+
"serverColumn": "limit",
|
|
140
|
+
"operatorName": "eq",
|
|
141
|
+
"defaultValue": "5000",
|
|
142
|
+
"dataType": "string"
|
|
136
143
|
}
|
|
137
144
|
]
|
|
138
145
|
}
|
|
@@ -346,4 +353,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
346
353
|
type: Input,
|
|
347
354
|
args: ['selectedDatasetId']
|
|
348
355
|
}] } });
|
|
349
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-dataset.component.js","sourceRoot":"","sources":["../../../../../../../projects/gamma-app-controller/src/lib/application-controller/application-dataset-component/create-dataset/create-dataset.component.ts","../../../../../../../projects/gamma-app-controller/src/lib/application-controller/application-dataset-component/create-dataset/create-dataset.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { ApplicationContentService } from '../../application-content.service';\nimport { ToastrService } from 'ngx-toastr';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { CommonService } from '../../common';\n\n@Component({\n  selector: 'app-create-dataset',\n  templateUrl: './create-dataset.component.html',\n  styleUrls: ['./create-dataset.component.scss']\n})\nexport class CreateDatasetComponent implements OnInit {\n  loadingModal: boolean;\n  isDuplidateView: boolean = false;\n  creatDatasetObject = {\n    \"datasetName\": \"\",\n    \"datasetType\": \"\"\n  };\n\n  dataSetTypeContainer = [{ name: \"Query Builder\", value: \"querybuilder\" }, { name: \"Service JSON\", value: \"mongo\" },\n  { name: \"Rest API\", value: \"simpleApi\" }, { name: \"SQL Builder\", value: \"sqlQuery\" }, { name: \"Plain JSON\", value: \"plainjson\" }]\n  mongoDataset = {\n    \"api\": \"/kpi/trends/network/get-metric-data\",\n    \"serviceId\": \"\",\n    \"apiType\": \"post\",\n    \"filterItems\": [\n      {\n        \"apiName\": \"startDate\",\n        \"label\": \"Start Date\",\n        \"filterType\": \"date\",\n        \"operatorName\": \"\",\n        \"defaultFilterType\": \"dynamic\",\n        \"defaultFilterValue\": \"YYYY-MM-DD\",\n        \"momentFunction\": \"subtract\",\n        \"momentFormate\": \"15,days\"\n      },\n      {\n        \"apiName\": \"endDate\",\n        \"label\": \"End Date\",\n        \"filterType\": \"date\",\n        \"operatorName\": \"\",\n        \"defaultFilterType\": \"dynamic\",\n        \"defaultFilterValue\": \"YYYY-MM-DD\",\n        \"momentFunction\": \"subtract\",\n        \"momentFormate\": \"1,days\"\n      }\n    ],\n    \"fixOperationLevles\": []\n  }\n\n  queryBulderDataset = {\n    \"api\": \"/kpi/genericAggregatePaginatedKpiServiceResponse\",\n    \"apiType\": \"post\",\n    \"serviceId\": \"\",\n    \"queryConfig\": {\n      \"mapedFilters\": [\n        {\n          \"localColumn\": \"startDate\",\n          \"serverColumn\": \"record_date\",\n          \"operatorName\": \"gte\",\n          \"defaultValue\": \"\",\n          \"dataType\": \"string\"\n        },\n        {\n          \"localColumn\": \"endDate\",\n          \"serverColumn\": \"record_date\",\n          \"operatorName\": \"lte\",\n          \"defaultValue\": \"\",\n          \"dataType\": \"string\"\n        }\n      ],\n      \"sorters\": [\n\n      ],\n      \"reqFields\": [\n\n      ],\n      \"measures\": [\n\n      ],\n      \"filter\": [\n\n      ],\n      \"havings\": [],\n      \"commonConfig\": {},\n      \"columns\": [\n      ]\n    }\n  }\n\n  restApiDataset = {\n    \"api\": \"\",\n    \"apiType\": \"post\",\n    \"serviceId\": \"\",\n    \"queryConfig\": {\n      \"mapedFilters\": [\n        {\n          \"localColumn\": \"startDate\",\n          \"serverColumn\": \"recordDate\",\n          \"operatorName\": \"gte\",\n          \"defaultValue\": \"\",\n          \"dataType\": \"string\"\n        },\n        {\n          \"localColumn\": \"endDate\",\n          \"serverColumn\": \"recordDate\",\n          \"operatorName\": \"lte\",\n          \"defaultValue\": \"\",\n          \"dataType\": \"string\"\n        }\n      ]\n    }\n  };\n  sqlApiDataset = {\n    \"api\": \"/kpi/genericSqlQueryResponse\",\n    \"apiType\": \"post\",\n    \"serviceId\": \"\",\n    \"queryConfig\": {\n      \"templateQuery\": \"\",\n      \"databaseName\": \"\",\n      \"dbConfig\": \"\",\n      \"enrichments\": [],\n      \"mapedFilters\": [\n        {\n          \"localColumn\": \"startDate\",\n          \"serverColumn\": \"record_date\",\n          \"operatorName\": \"gte\",\n          \"defaultValue\": \"\",\n          \"dataType\": \"string\"\n        },\n        {\n          \"localColumn\": \"endDate\",\n          \"serverColumn\": \"record_date\",\n          \"operatorName\": \"lte\",\n          \"defaultValue\": \"\",\n          \"dataType\": \"string\"\n        }\n      ]\n    }\n  };\n\n  jsonDataset = {\n    \"api\": \"/kpi-config/getJsonDatasetPayload\",\n    \"apiType\": \"get\",\n    \"serviceId\": \"\",\n    \"queryConfig\": {\n      \"mapedFilters\": [\n        {\n          \"localColumn\": \"startDate\",\n          \"serverColumn\": \"recordDate\",\n          \"operatorName\": \"gte\",\n          \"defaultValue\": \"\",\n          \"dataType\": \"string\"\n        },\n        {\n          \"localColumn\": \"endDate\",\n          \"serverColumn\": \"recordDate\",\n          \"operatorName\": \"lte\",\n          \"defaultValue\": \"\",\n          \"dataType\": \"string\"\n        }\n      ]\n    }\n  }\n\n  inputDatasetID: any;\n  @Input() isHeader: boolean = true;\n\n  @Input('selectedDatasetId')\n  set selectedDatasetId(value) {\n    if (value) {\n      this.inputDatasetID = value\n      this.service.getAppDatasetConfig(value).subscribe({\n        next: (data: any) => {\n          this.loadingModal = false;\n          this.creatDatasetObject = data;\n          if (data.datasetType == 'mongo') {\n            this.mongoDataset = data.config\n          } else if (data.datasetType == 'querybuilder') {\n            this.queryBulderDataset = data.config\n          } else if (data.datasetType == 'simpleApi') {\n            this.restApiDataset = data.config;\n          } else if (data.datasetType == 'sqlQuery') {\n            this.sqlApiDataset = data.config;\n          } else if (data.datasetType == 'plainjson') {\n            this.jsonDataset = data.config;\n          }\n        }, error: (err: any) => {\n          this.loadingModal = false;\n          this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Dataset Creation')\n        }\n      })\n    } else {\n\n\n    }\n\n\n  }\n\n  constructor(\n    private service: ApplicationContentService,\n    private toastr: ToastrService,\n    public commonService: CommonService,\n    private router: Router,\n    private activatedRoute: ActivatedRoute\n  ) { }\n\n  ngOnInit(): void {\n    let datasetId = this.activatedRoute.snapshot.queryParams['datasetId'];\n    let contentType = this.activatedRoute.snapshot.queryParams['contentType'];\n    if (contentType == \"clone\") {\n      this.isDuplidateView = true;\n    }\n    if (datasetId) {\n      this.loadingModal = true;\n\n      this.service.getAppDatasetConfig(datasetId).subscribe({\n        next: (data: any) => {\n          this.loadingModal = false;\n          this.creatDatasetObject = data;\n          if (data.datasetType == 'mongo') {\n            this.mongoDataset = data.config\n          } else if (data.datasetType == 'querybuilder') {\n            this.queryBulderDataset = data.config\n          } else if (data.datasetType == 'simpleApi') {\n            this.restApiDataset = data.config;\n          } else if (data.datasetType == 'plainjson') {\n            this.jsonDataset = data.config;\n          } else if (data.datasetType == 'sqlQuery') {\n            this.sqlApiDataset = data.config;\n          }\n        }, error: (err: any) => {\n          this.loadingModal = false;\n          this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Dataset Creation')\n        }\n      })\n\n\n      // this.service.getAppDatasetConfigs().subscribe({\n      //   next: (data: any) => {\n      //     const foundObject = data.find(dataset => dataset.datasetId === datasetId);\n      //     this.loadingModal = false;\n      //     this.creatDatasetObject = foundObject;\n      //     if (foundObject.datasetType == 'mongo') {\n      //       this.mongoDataset = foundObject.config\n      //     } else if (foundObject.datasetType == 'querybuilder') {\n      //       this.queryBulderDataset = foundObject.config\n      //     } else if (foundObject.datasetType == 'simpleApi') {\n      //       this.restApiDataset = foundObject.config;\n      //     }\n      //   }\n      // })\n    }\n\n  }\n\n\n  createMongoServiceDataSet(data) {\n\n    this.creatDatasetObject['config'] = data;\n    console.log(this.creatDatasetObject);\n    this.loadingModal = true;\n    if (this.isDuplidateView) {\n\n      this.createNeDataSetConfig();\n    } else {\n      if (this.creatDatasetObject['datasetId']) {\n        this.updataNewDataSetCongig()\n\n      } else {\n        this.createNeDataSetConfig();\n      }\n    }\n  }\n  createQueryBuilderDataSet(data) {\n\n    this.creatDatasetObject['config'] = data;\n    console.log(this.creatDatasetObject);\n    this.loadingModal = true;\n    if (this.isDuplidateView) {\n\n      this.createNeDataSetConfig();\n    } else {\n      if (this.creatDatasetObject['datasetId']) {\n        this.updataNewDataSetCongig()\n        localStorage.removeItem('querybuilder')\n      } else {\n        this.createNeDataSetConfig();\n        localStorage.removeItem('querybuilder')\n\n      }\n    }\n  }\n\n\n  createSqlQueryBuilderDataSet(data) {\n\n    this.creatDatasetObject['config'] = data;\n    console.log(this.creatDatasetObject);\n    this.loadingModal = true;\n    if (this.isDuplidateView) {\n\n      this.createNeDataSetConfig();\n    } else {\n      if (this.creatDatasetObject['datasetId']) {\n        this.updataNewDataSetCongig()\n        localStorage.removeItem('querybuilder')\n      } else {\n        this.createNeDataSetConfig();\n        localStorage.removeItem('querybuilder')\n\n      }\n    }\n\n  }\n\n\n\n  createRestApiDataSet(data) {\n    this.creatDatasetObject['config'] = data;\n    console.log(this.creatDatasetObject);\n    this.loadingModal = true;\n\n    if (this.isDuplidateView) {\n      this.createNeDataSetConfig();\n    } else {\n      if (this.creatDatasetObject['datasetId']) {\n        this.updataNewDataSetCongig()\n      } else {\n        this.createNeDataSetConfig();\n      }\n    }\n\n  }\n\n\n  createNeDataSetConfig() {\n    this.service.createAppDataset(this.creatDatasetObject).subscribe({\n      next: (data: any) => {\n        // this.isNewDataSetCreateView = false;\n        this.isDuplidateView = false;\n        this.loadingModal = false;\n        this.toastr.success('Dataset Created Successfully')\n        // if (this.isHeader) {\n        //   this.router.navigate(['apps/controlPanel/applicationDataset/'])\n        // }\n\n      }, error: (err: any) => {\n        this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Dataset Creation')\n      }\n    })\n  }\n\n  updataNewDataSetCongig() {\n    this.service.updateAppDatasetConfig(this.creatDatasetObject).subscribe({\n      next: (data: any) => {\n        // this.isNewDataSetCreateView = false;\n        this.loadingModal = false;\n        this.toastr.success('Dataset Updated Successfully')\n        // if (this.isHeader) {\n        //   this.router.navigate(['apps/controlPanel/applicationDataset/'])\n        // }\n      }, error: (err: any) => {\n        this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Dataset Creation')\n      }\n    })\n  }\n\n  gotoAllDatasets() {\n    this.router.navigate(['apps/controlPanel/applicationDataset/'])\n  }\n\n\n  createDataSetWithJson(data) {\n    this.creatDatasetObject['config'] = data;\n    console.log(this.creatDatasetObject);\n    if (this.isDuplidateView) {\n      this.createNeDataSetConfig();\n    } else {\n      if (this.creatDatasetObject['datasetId']) {\n        this.updataNewDataSetCongig()\n      } else {\n        this.createNeDataSetConfig();\n      }\n    }\n\n\n\n  }\n\n}\n","<app-loading *ngIf=\"loadingModal\"></app-loading>\n\n<div class=\"flex flex-col flex-auto min-w-0\">\n\n    <lib-common-header [pageTitle]=\"'Dataset Editor'\" *ngIf=\"isHeader\"></lib-common-header>\n\n\n    <div class=\"p-2 w-full\">\n        <div class=\"m-3 p-4 bg-white border border-gray-200 rounded-lg shadow-md dark:bg-gray-800 dark:border-gray-700\">\n            <h6\n                class=\"mb-2 font-bold text-lg tracking-tight text-gray-900 dark:text-white border-b pb-3 flex items-center\">\n                <i class=\"fa fa-table mr-2\"></i> Dataset Editor\n\n            </h6>\n            <div class=\"flex flex-row my-4\">\n                <div class=\"mx-2 w-1/3\">\n                    <div class=\"text-md mb-2\">Dataset Name</div>\n                    <dx-text-box [(ngModel)]=\"creatDatasetObject.datasetName\"></dx-text-box>\n                </div>\n                <div class=\"mx-2 w-1/3\">\n                    <div class=\"text-md mb-2\">Select Dataset Type</div>\n                    <dx-select-box [items]=\"dataSetTypeContainer\" displayExpr=\"name\" valueExpr=\"value\"\n                        [(ngModel)]=\"creatDatasetObject.datasetType\"></dx-select-box>\n                </div>\n            </div>\n            <div class=\"m-5 border\">\n                <app-dataset-mongo *ngIf=\"creatDatasetObject.datasetType == 'mongo'\" [mongoDataset]=\"mongoDataset\"\n                    (getMongoServiceDataSet)=\"createMongoServiceDataSet($event)\"></app-dataset-mongo>\n\n                <app-dataset-rest-api *ngIf=\"creatDatasetObject.datasetType == 'simpleApi'\"\n                    [restApiDataset]=\"restApiDataset\"\n                    (getRestApiBulbderDataSet)=\"createRestApiDataSet($event)\"></app-dataset-rest-api>\n\n                <app-dataset-query-bulder *ngIf=\"creatDatasetObject.datasetType == 'querybuilder'\"\n                    [bulderDataset]=\"queryBulderDataset\"\n                    (getQueryBulbderDataSet)=\"createQueryBuilderDataSet($event)\"></app-dataset-query-bulder>\n\n                <app-create-dataset-sql *ngIf=\"creatDatasetObject.datasetType == 'sqlQuery'\"\n                    [sqlBulderDataset]=\"sqlApiDataset\"\n                    (getSqlQueryBulbderDataSet)=\"createSqlQueryBuilderDataSet($event)\"></app-create-dataset-sql>\n\n                <app-create-dataset-json *ngIf=\"creatDatasetObject.datasetType == 'plainjson'\"\n                    [jsonDataset]=\"jsonDataset\"\n                    (getJsonDataset)=\"createDataSetWithJson($event)\"></app-create-dataset-json>\n            </div>\n\n\n        </div>\n    </div>\n\n\n</div>"]}
|
|
356
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-dataset.component.js","sourceRoot":"","sources":["../../../../../../../projects/gamma-app-controller/src/lib/application-controller/application-dataset-component/create-dataset/create-dataset.component.ts","../../../../../../../projects/gamma-app-controller/src/lib/application-controller/application-dataset-component/create-dataset/create-dataset.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { ApplicationContentService } from '../../application-content.service';\nimport { ToastrService } from 'ngx-toastr';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { CommonService } from '../../common';\n\n@Component({\n  selector: 'app-create-dataset',\n  templateUrl: './create-dataset.component.html',\n  styleUrls: ['./create-dataset.component.scss']\n})\nexport class CreateDatasetComponent implements OnInit {\n  loadingModal: boolean;\n  isDuplidateView: boolean = false;\n  creatDatasetObject = {\n    \"datasetName\": \"\",\n    \"datasetType\": \"\"\n  };\n\n  dataSetTypeContainer = [{ name: \"Query Builder\", value: \"querybuilder\" }, { name: \"Service JSON\", value: \"mongo\" },\n  { name: \"Rest API\", value: \"simpleApi\" }, { name: \"SQL Builder\", value: \"sqlQuery\" }, { name: \"Plain JSON\", value: \"plainjson\" }]\n  mongoDataset = {\n    \"api\": \"/kpi/trends/network/get-metric-data\",\n    \"serviceId\": \"\",\n    \"apiType\": \"post\",\n    \"filterItems\": [\n      {\n        \"apiName\": \"startDate\",\n        \"label\": \"Start Date\",\n        \"filterType\": \"date\",\n        \"operatorName\": \"\",\n        \"defaultFilterType\": \"dynamic\",\n        \"defaultFilterValue\": \"YYYY-MM-DD\",\n        \"momentFunction\": \"subtract\",\n        \"momentFormate\": \"15,days\"\n      },\n      {\n        \"apiName\": \"endDate\",\n        \"label\": \"End Date\",\n        \"filterType\": \"date\",\n        \"operatorName\": \"\",\n        \"defaultFilterType\": \"dynamic\",\n        \"defaultFilterValue\": \"YYYY-MM-DD\",\n        \"momentFunction\": \"subtract\",\n        \"momentFormate\": \"1,days\"\n      }\n    ],\n    \"fixOperationLevles\": []\n  }\n\n  queryBulderDataset = {\n    \"api\": \"/kpi/genericAggregatePaginatedKpiServiceResponse\",\n    \"apiType\": \"post\",\n    \"serviceId\": \"\",\n    \"queryConfig\": {\n      \"mapedFilters\": [\n        {\n          \"localColumn\": \"startDate\",\n          \"serverColumn\": \"record_date\",\n          \"operatorName\": \"gte\",\n          \"defaultValue\": \"\",\n          \"dataType\": \"string\"\n        },\n        {\n          \"localColumn\": \"endDate\",\n          \"serverColumn\": \"record_date\",\n          \"operatorName\": \"lte\",\n          \"defaultValue\": \"\",\n          \"dataType\": \"string\"\n        }\n      ],\n      \"sorters\": [\n\n      ],\n      \"reqFields\": [\n\n      ],\n      \"measures\": [\n\n      ],\n      \"filter\": [\n\n      ],\n      \"havings\": [],\n      \"commonConfig\": {},\n      \"columns\": [\n      ]\n    }\n  }\n\n  restApiDataset = {\n    \"api\": \"\",\n    \"apiType\": \"post\",\n    \"serviceId\": \"\",\n    \"queryConfig\": {\n      \"mapedFilters\": [\n        {\n          \"localColumn\": \"startDate\",\n          \"serverColumn\": \"recordDate\",\n          \"operatorName\": \"gte\",\n          \"defaultValue\": \"\",\n          \"dataType\": \"string\"\n        },\n        {\n          \"localColumn\": \"endDate\",\n          \"serverColumn\": \"recordDate\",\n          \"operatorName\": \"lte\",\n          \"defaultValue\": \"\",\n          \"dataType\": \"string\"\n        }\n      ]\n    }\n  };\n  sqlApiDataset = {\n    \"api\": \"/kpi/genericSqlQueryResponse\",\n    \"apiType\": \"post\",\n    \"serviceId\": \"\",\n    \"queryConfig\": {\n      \"templateQuery\": \"\",\n      \"databaseName\": \"\",\n      \"dbConfig\": \"\",\n      \"enrichments\": [],\n      \"mapedFilters\": [\n        {\n          \"localColumn\": \"startDate\",\n          \"serverColumn\": \"record_date\",\n          \"operatorName\": \"gte\",\n          \"defaultValue\": \"\",\n          \"dataType\": \"string\"\n        },\n        {\n          \"localColumn\": \"endDate\",\n          \"serverColumn\": \"record_date\",\n          \"operatorName\": \"lte\",\n          \"defaultValue\": \"\",\n          \"dataType\": \"string\"\n        },\n        {\n          \"localColumn\": \"limit\",\n          \"serverColumn\": \"limit\",\n          \"operatorName\": \"eq\",\n          \"defaultValue\": \"5000\",\n          \"dataType\": \"string\"\n        }\n      ]\n    }\n  };\n\n  jsonDataset = {\n    \"api\": \"/kpi-config/getJsonDatasetPayload\",\n    \"apiType\": \"get\",\n    \"serviceId\": \"\",\n    \"queryConfig\": {\n      \"mapedFilters\": [\n        {\n          \"localColumn\": \"startDate\",\n          \"serverColumn\": \"recordDate\",\n          \"operatorName\": \"gte\",\n          \"defaultValue\": \"\",\n          \"dataType\": \"string\"\n        },\n        {\n          \"localColumn\": \"endDate\",\n          \"serverColumn\": \"recordDate\",\n          \"operatorName\": \"lte\",\n          \"defaultValue\": \"\",\n          \"dataType\": \"string\"\n        }\n      ]\n    }\n  }\n\n  inputDatasetID: any;\n  @Input() isHeader: boolean = true;\n\n  @Input('selectedDatasetId')\n  set selectedDatasetId(value) {\n    if (value) {\n      this.inputDatasetID = value\n      this.service.getAppDatasetConfig(value).subscribe({\n        next: (data: any) => {\n          this.loadingModal = false;\n          this.creatDatasetObject = data;\n          if (data.datasetType == 'mongo') {\n            this.mongoDataset = data.config\n          } else if (data.datasetType == 'querybuilder') {\n            this.queryBulderDataset = data.config\n          } else if (data.datasetType == 'simpleApi') {\n            this.restApiDataset = data.config;\n          } else if (data.datasetType == 'sqlQuery') {\n            this.sqlApiDataset = data.config;\n          } else if (data.datasetType == 'plainjson') {\n            this.jsonDataset = data.config;\n          }\n        }, error: (err: any) => {\n          this.loadingModal = false;\n          this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Dataset Creation')\n        }\n      })\n    } else {\n\n\n    }\n\n\n  }\n\n  constructor(\n    private service: ApplicationContentService,\n    private toastr: ToastrService,\n    public commonService: CommonService,\n    private router: Router,\n    private activatedRoute: ActivatedRoute\n  ) { }\n\n  ngOnInit(): void {\n    let datasetId = this.activatedRoute.snapshot.queryParams['datasetId'];\n    let contentType = this.activatedRoute.snapshot.queryParams['contentType'];\n    if (contentType == \"clone\") {\n      this.isDuplidateView = true;\n    }\n    if (datasetId) {\n      this.loadingModal = true;\n\n      this.service.getAppDatasetConfig(datasetId).subscribe({\n        next: (data: any) => {\n          this.loadingModal = false;\n          this.creatDatasetObject = data;\n          if (data.datasetType == 'mongo') {\n            this.mongoDataset = data.config\n          } else if (data.datasetType == 'querybuilder') {\n            this.queryBulderDataset = data.config\n          } else if (data.datasetType == 'simpleApi') {\n            this.restApiDataset = data.config;\n          } else if (data.datasetType == 'plainjson') {\n            this.jsonDataset = data.config;\n          } else if (data.datasetType == 'sqlQuery') {\n            this.sqlApiDataset = data.config;\n          }\n        }, error: (err: any) => {\n          this.loadingModal = false;\n          this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Dataset Creation')\n        }\n      })\n\n\n      // this.service.getAppDatasetConfigs().subscribe({\n      //   next: (data: any) => {\n      //     const foundObject = data.find(dataset => dataset.datasetId === datasetId);\n      //     this.loadingModal = false;\n      //     this.creatDatasetObject = foundObject;\n      //     if (foundObject.datasetType == 'mongo') {\n      //       this.mongoDataset = foundObject.config\n      //     } else if (foundObject.datasetType == 'querybuilder') {\n      //       this.queryBulderDataset = foundObject.config\n      //     } else if (foundObject.datasetType == 'simpleApi') {\n      //       this.restApiDataset = foundObject.config;\n      //     }\n      //   }\n      // })\n    }\n\n  }\n\n\n  createMongoServiceDataSet(data) {\n\n    this.creatDatasetObject['config'] = data;\n    console.log(this.creatDatasetObject);\n    this.loadingModal = true;\n    if (this.isDuplidateView) {\n\n      this.createNeDataSetConfig();\n    } else {\n      if (this.creatDatasetObject['datasetId']) {\n        this.updataNewDataSetCongig()\n\n      } else {\n        this.createNeDataSetConfig();\n      }\n    }\n  }\n  createQueryBuilderDataSet(data) {\n\n    this.creatDatasetObject['config'] = data;\n    console.log(this.creatDatasetObject);\n    this.loadingModal = true;\n    if (this.isDuplidateView) {\n\n      this.createNeDataSetConfig();\n    } else {\n      if (this.creatDatasetObject['datasetId']) {\n        this.updataNewDataSetCongig()\n        localStorage.removeItem('querybuilder')\n      } else {\n        this.createNeDataSetConfig();\n        localStorage.removeItem('querybuilder')\n\n      }\n    }\n  }\n\n\n  createSqlQueryBuilderDataSet(data) {\n\n    this.creatDatasetObject['config'] = data;\n    console.log(this.creatDatasetObject);\n    this.loadingModal = true;\n    if (this.isDuplidateView) {\n\n      this.createNeDataSetConfig();\n    } else {\n      if (this.creatDatasetObject['datasetId']) {\n        this.updataNewDataSetCongig()\n        localStorage.removeItem('querybuilder')\n      } else {\n        this.createNeDataSetConfig();\n        localStorage.removeItem('querybuilder')\n\n      }\n    }\n\n  }\n\n\n\n  createRestApiDataSet(data) {\n    this.creatDatasetObject['config'] = data;\n    console.log(this.creatDatasetObject);\n    this.loadingModal = true;\n\n    if (this.isDuplidateView) {\n      this.createNeDataSetConfig();\n    } else {\n      if (this.creatDatasetObject['datasetId']) {\n        this.updataNewDataSetCongig()\n      } else {\n        this.createNeDataSetConfig();\n      }\n    }\n\n  }\n\n\n  createNeDataSetConfig() {\n    this.service.createAppDataset(this.creatDatasetObject).subscribe({\n      next: (data: any) => {\n        // this.isNewDataSetCreateView = false;\n        this.isDuplidateView = false;\n        this.loadingModal = false;\n        this.toastr.success('Dataset Created Successfully')\n        // if (this.isHeader) {\n        //   this.router.navigate(['apps/controlPanel/applicationDataset/'])\n        // }\n\n      }, error: (err: any) => {\n        this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Dataset Creation')\n      }\n    })\n  }\n\n  updataNewDataSetCongig() {\n    this.service.updateAppDatasetConfig(this.creatDatasetObject).subscribe({\n      next: (data: any) => {\n        // this.isNewDataSetCreateView = false;\n        this.loadingModal = false;\n        this.toastr.success('Dataset Updated Successfully')\n        // if (this.isHeader) {\n        //   this.router.navigate(['apps/controlPanel/applicationDataset/'])\n        // }\n      }, error: (err: any) => {\n        this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Dataset Creation')\n      }\n    })\n  }\n\n  gotoAllDatasets() {\n    this.router.navigate(['apps/controlPanel/applicationDataset/'])\n  }\n\n\n  createDataSetWithJson(data) {\n    this.creatDatasetObject['config'] = data;\n    console.log(this.creatDatasetObject);\n    if (this.isDuplidateView) {\n      this.createNeDataSetConfig();\n    } else {\n      if (this.creatDatasetObject['datasetId']) {\n        this.updataNewDataSetCongig()\n      } else {\n        this.createNeDataSetConfig();\n      }\n    }\n\n\n\n  }\n\n}\n","<app-loading *ngIf=\"loadingModal\"></app-loading>\n\n<div class=\"flex flex-col flex-auto min-w-0\">\n\n    <lib-common-header [pageTitle]=\"'Dataset Editor'\" *ngIf=\"isHeader\"></lib-common-header>\n\n\n    <div class=\"p-2 w-full\">\n        <div class=\"m-3 p-4 bg-white border border-gray-200 rounded-lg shadow-md dark:bg-gray-800 dark:border-gray-700\">\n            <h6\n                class=\"mb-2 font-bold text-lg tracking-tight text-gray-900 dark:text-white border-b pb-3 flex items-center\">\n                <i class=\"fa fa-table mr-2\"></i> Dataset Editor\n\n            </h6>\n            <div class=\"flex flex-row my-4\">\n                <div class=\"mx-2 w-1/3\">\n                    <div class=\"text-md mb-2\">Dataset Name</div>\n                    <dx-text-box [(ngModel)]=\"creatDatasetObject.datasetName\"></dx-text-box>\n                </div>\n                <div class=\"mx-2 w-1/3\">\n                    <div class=\"text-md mb-2\">Select Dataset Type</div>\n                    <dx-select-box [items]=\"dataSetTypeContainer\" displayExpr=\"name\" valueExpr=\"value\"\n                        [(ngModel)]=\"creatDatasetObject.datasetType\"></dx-select-box>\n                </div>\n            </div>\n            <div class=\"m-5 border\">\n                <app-dataset-mongo *ngIf=\"creatDatasetObject.datasetType == 'mongo'\" [mongoDataset]=\"mongoDataset\"\n                    (getMongoServiceDataSet)=\"createMongoServiceDataSet($event)\"></app-dataset-mongo>\n\n                <app-dataset-rest-api *ngIf=\"creatDatasetObject.datasetType == 'simpleApi'\"\n                    [restApiDataset]=\"restApiDataset\"\n                    (getRestApiBulbderDataSet)=\"createRestApiDataSet($event)\"></app-dataset-rest-api>\n\n                <app-dataset-query-bulder *ngIf=\"creatDatasetObject.datasetType == 'querybuilder'\"\n                    [bulderDataset]=\"queryBulderDataset\"\n                    (getQueryBulbderDataSet)=\"createQueryBuilderDataSet($event)\"></app-dataset-query-bulder>\n\n                <app-create-dataset-sql *ngIf=\"creatDatasetObject.datasetType == 'sqlQuery'\"\n                    [sqlBulderDataset]=\"sqlApiDataset\"\n                    (getSqlQueryBulbderDataSet)=\"createSqlQueryBuilderDataSet($event)\"></app-create-dataset-sql>\n\n                <app-create-dataset-json *ngIf=\"creatDatasetObject.datasetType == 'plainjson'\"\n                    [jsonDataset]=\"jsonDataset\"\n                    (getJsonDataset)=\"createDataSetWithJson($event)\"></app-create-dataset-json>\n            </div>\n\n\n        </div>\n    </div>\n\n\n</div>"]}
|
|
@@ -36,6 +36,16 @@ export class CreateDatasetSqlComponent {
|
|
|
36
36
|
if (value.queryConfig.templateQuery != "") {
|
|
37
37
|
this.queryStringData = value.queryConfig.templateQuery;
|
|
38
38
|
}
|
|
39
|
+
const hasLimit = value.queryConfig.mapedFilters.some(filter => filter.serverColumn === 'limit');
|
|
40
|
+
if (!hasLimit) {
|
|
41
|
+
value.queryConfig.mapedFilters.push({
|
|
42
|
+
localColumn: "limit",
|
|
43
|
+
serverColumn: "limit",
|
|
44
|
+
operatorName: "eq",
|
|
45
|
+
defaultValue: "5000",
|
|
46
|
+
dataType: "string"
|
|
47
|
+
});
|
|
48
|
+
}
|
|
39
49
|
this.apiBulderDataset = value;
|
|
40
50
|
}
|
|
41
51
|
ngOnInit() {
|
|
@@ -76,36 +86,36 @@ export class CreateDatasetSqlComponent {
|
|
|
76
86
|
}
|
|
77
87
|
else {
|
|
78
88
|
fval = this.sqlFormatter.transform(val);
|
|
79
|
-
splittedValuesOfQuery =
|
|
80
|
-
return item.trim().replace(/(^,)|(,)|(;)/g, '');
|
|
81
|
-
});
|
|
89
|
+
splittedValuesOfQuery = fval.match(/'[^']*'|\S+/g) || [];
|
|
82
90
|
this.queryStringData = fval;
|
|
83
91
|
const re = /{([^}]+)}/g;
|
|
84
92
|
let m = [];
|
|
85
93
|
while (m = re.exec(fval)) {
|
|
86
94
|
this.duplicateMatches.push(m[1]);
|
|
87
95
|
}
|
|
96
|
+
let limit_key = [];
|
|
97
|
+
limit_key = splittedValuesOfQuery.filter(s => s.toLowerCase().includes('limit'));
|
|
88
98
|
this.matches = this.duplicateMatches.filter((v, i) => this.duplicateMatches.indexOf(v) === i);
|
|
89
99
|
for (let i = 0; i < this.matches.length; i++) {
|
|
90
100
|
let value;
|
|
91
101
|
let key;
|
|
92
102
|
let th_key;
|
|
93
103
|
let keyarr = [];
|
|
94
|
-
let th_keyArr = [];
|
|
95
104
|
value = this.matches[i];
|
|
96
105
|
keyarr = splittedValuesOfQuery.filter(s => s.includes('$P{' + this.matches[i] + '}'));
|
|
97
|
-
th_keyArr = splittedValuesOfQuery.filter(s => s.includes('$T{' + this.matches[i] + '}'));
|
|
98
106
|
if (keyarr.length !== 0) {
|
|
99
107
|
if (keyarr[0].split('=')[0].indexOf('.') > 0) {
|
|
100
108
|
key = keyarr[0].split('=')[0].split('.')[1];
|
|
101
109
|
}
|
|
102
110
|
else {
|
|
103
111
|
key = keyarr[0].split('=')[0];
|
|
104
|
-
let labelName = key.replace(/^./, key[0].toUpperCase());
|
|
105
112
|
}
|
|
106
113
|
}
|
|
107
114
|
this.argumentData.push(key);
|
|
108
115
|
}
|
|
116
|
+
if (limit_key && limit_key.length !== 0) {
|
|
117
|
+
this.argumentData.push(limit_key[0].toLowerCase());
|
|
118
|
+
}
|
|
109
119
|
this.isValidate = false;
|
|
110
120
|
this.isNotValidate = true;
|
|
111
121
|
}
|
|
@@ -174,4 +184,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
174
184
|
type: Input,
|
|
175
185
|
args: ['sqlBulderDataset']
|
|
176
186
|
}] } });
|
|
177
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-dataset-sql.component.js","sourceRoot":"","sources":["../../../../../../../projects/gamma-app-controller/src/lib/application-controller/application-dataset-component/create-dataset-sql/create-dataset-sql.component.ts","../../../../../../../projects/gamma-app-controller/src/lib/application-controller/application-dataset-component/create-dataset-sql/create-dataset-sql.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 { SqlPipe } from './sqlFormatter';\nimport { ApplicationContentService } from '../../application-content.service';\nimport { CommonService } from '../../common';\nimport cloneDeep from 'lodash-es/cloneDeep';\n\n@Component({\n  selector: 'app-create-dataset-sql',\n  templateUrl: './create-dataset-sql.component.html',\n  styleUrls: ['./create-dataset-sql.component.scss'],\n  providers: [SqlPipe],\n\n})\nexport class CreateDatasetSqlComponent implements OnInit {\n  kpi_function: any = [\"sum\", \"count\", \"avg\", \"max\", \"min\", \"stddev\", \"count_distinct\"]\n  kpi_operator: any = [\"eq\", \"gte\", \"lte\", \"ne\", \"in\", \"notIn\", \"contains\", \"startsWith\", \"endsWith\"]\n  @Output() public getSqlQueryBulbderDataSet: EventEmitter<any> = new EventEmitter();\n  apiBulderDataset: any;\n  queryStringData: string;\n  sqlString = '';\n  validateArgumentError: boolean = false;\n  formatButtonStatus: boolean = true;\n  validateStatus: boolean = false;\n\n  isValidate: boolean = true;\n  isNotValidate: boolean = true;\n  argumentData: any = [];\n\n  duplicateMatches: any;\n  matches: any;\n  kpi_enrichment_name: any = [];\n  @Input('sqlBulderDataset')\n  set sqlBulderDataset(value) {\n    if (value.queryConfig.mapedFilters == undefined) {\n      value.queryConfig.mapedFilters = [];\n      value.queryConfig.mapedFilters.push({ \"localColumn\": \"\", \"serverColumn\": \"\", \"operatorName\": \"\", \"defaultValue\": \"\", \"dataType\": \"\",\"formatter\":\"\" })\n    }\n    if (value.queryConfig.templateQuery != \"\") {\n      this.queryStringData = value.queryConfig.templateQuery;\n    }\n\n    this.apiBulderDataset = value;\n  }\n\n  constructor(\n    private toastr: ToastrService,\n    public commonService: CommonService,\n    private sqlFormatter: SqlPipe,\n    private service: ApplicationContentService\n  ) { }\n\n  ngOnInit(): void {\n    this.service.listColumnEnrichmentFunctions().subscribe(data => {\n      this.kpi_enrichment_name = data;\n    })\n  }\n\n  addFilterMapingColumns() {\n    let obj = { \"localColumn\": \"\", \"serverColumn\": \"\", \"operatorName\": \"\", \"defaultValue\": \"\", \"dataType\": \"\",\"formatter\":\"\" }\n    this.apiBulderDataset.queryConfig.mapedFilters.push(obj);\n\n  }\n\n  deleteFilterMapingColumns(i) {\n    this.apiBulderDataset.queryConfig.mapedFilters.splice(i, 1)\n\n  }\n\n  saveColumnMaping() {\n    this.toastr.success('Maped Filter Successfully');\n\n  }\n\n\n\n  moveItemForColumns(index: number, direction: 'up' | 'down'): void {\n    // Prevent moving beyond array bounds\n    if (index < 0 || index >= this.apiBulderDataset.queryConfig.mapedFilters.length) return;\n    const newPosition = direction === 'up' ? index - 1 : index + 1;\n    // Prevent moving beyond array bounds\n    if (newPosition < 0 || newPosition >= this.apiBulderDataset.queryConfig.mapedFilters.length) return;\n\n    // Move item\n    const itemToMove = this.apiBulderDataset.queryConfig.mapedFilters[index];\n    this.apiBulderDataset.queryConfig.mapedFilters.splice(index, 1); // Remove item from current position\n    this.apiBulderDataset.queryConfig.mapedFilters.splice(newPosition, 0, itemToMove); // Insert item in new position\n  }\n\n\n\n  format(): any {\n    this.matches = [];\n    this.duplicateMatches = [];\n    this.argumentData = [];\n    let val: any;\n    let fval: any;\n    let splittedValuesOfQuery: any;\n    // val = document.getElementById('exampleTextarea')['value'];\n    val = this.queryStringData;\n    const newVal = val.trim();\n    if (newVal === '' || newVal === undefined) {\n      // this.toastr.error('Query Empty');\n    } else {\n      fval = this.sqlFormatter.transform(val);\n      splittedValuesOfQuery = val.split(' ').map(function (item): any {\n        return item.trim().replace(/(^,)|(,)|(;)/g, '');\n      });\n      // document.getElementById('exampleTextarea')['value'] = fval;\n      this.queryStringData = fval;\n      // this.toastr.success('Query Formatted');\n      const re = /{([^}]+)}/g;\n      let m = [];\n      while (m = re.exec(fval)) {\n        this.duplicateMatches.push(m[1]);\n      }\n      this.matches = this.duplicateMatches.filter((v, i) => this.duplicateMatches.indexOf(v) === i);\n      for (let i = 0; i < this.matches.length; i++) {\n        let value: any;\n        let key: any;\n        let th_key: any;\n        let keyarr = [];\n        let th_keyArr = [];\n        value = this.matches[i];\n        keyarr = splittedValuesOfQuery.filter(s => s.includes('$P{' + this.matches[i] + '}'));\n        th_keyArr = splittedValuesOfQuery.filter(s => s.includes('$T{' + this.matches[i] + '}'));\n\n\n        if (keyarr.length !== 0) {\n          if (keyarr[0].split('=')[0].indexOf('.') > 0) {\n            key = keyarr[0].split('=')[0].split('.')[1];\n          } else {\n            key = keyarr[0].split('=')[0];\n            let labelName = key.replace(/^./, key[0].toUpperCase());\n\n          }\n        }\n        this.argumentData.push(key)\n\n      }\n\n      this.isValidate = false;\n      this.isNotValidate = true;\n    }\n\n    // console.log(this.argumentData)\n\n\n\n  }\n\n\n  validateNewReport() {\n    const argumentData = cloneDeep(this.argumentData).map(item => item.replace(/.*\\{(.*)\\}.*/, '$1'));\n    const mappedFilterColumns = this.apiBulderDataset.queryConfig.mapedFilters.map(element => element.localColumn);\n\n    this.apiBulderDataset.queryConfig.mapedFilters.forEach(element => {\n      if (argumentData.some(key => element.localColumn == key)) {\n        this.toastr.success('Validate For ' + element.localColumn);\n        this.isNotValidate = false;\n      } else {\n        this.toastr.info('Missing Alias', element.localColumn);\n      }\n    });\n\n    argumentData.forEach(key => {\n      if (!mappedFilterColumns.includes(key)) {\n        this.toastr.info('Extra Argument Data', key);\n      }\n    });\n\n  }\n\n  moveItemForMeasuresColumns(index: number, direction: 'up' | 'down'): void {\n    // Prevent moving beyond array bounds\n    if (index < 0 || index >= this.apiBulderDataset.queryConfig.enrichments.length) return;\n    const newPosition = direction === 'up' ? index - 1 : index + 1;\n    // Prevent moving beyond array bounds\n    if (newPosition < 0 || newPosition >= this.apiBulderDataset.queryConfig.enrichments.length) return;\n\n    // Move item\n    const itemToMove = this.apiBulderDataset.queryConfig.enrichments[index];\n    this.apiBulderDataset.queryConfig.enrichments.splice(index, 1); // Remove item from current position\n    this.apiBulderDataset.queryConfig.enrichments.splice(newPosition, 0, itemToMove); // Insert item in new position\n  }\n\n  addColumns() {\n    if(this.apiBulderDataset.queryConfig.enrichments && this.apiBulderDataset.queryConfig.enrichments.length !== 0 ){\n      let obj = {\n        \"columnName\": \"\",\n        \"enrichFunction\": \"\",\n      }\n      this.apiBulderDataset.queryConfig.enrichments.push(obj);\n    } else {\n      this.apiBulderDataset.queryConfig.enrichments = [];\n      let obj = {\n        \"columnName\": \"\",\n        \"enrichFunction\": \"\",\n      }\n      this.apiBulderDataset.queryConfig.enrichments.push(obj);\n    }\n   \n  }\n\n\n  deleteColumns(i) {\n    this.apiBulderDataset.queryConfig.enrichments.splice(i, 1)\n  }\n\n\n  createDataSet() {\n    this.apiBulderDataset.queryConfig['templateQuery'] = this.queryStringData;\n    this.getSqlQueryBulbderDataSet.emit(this.apiBulderDataset)\n  }\n\n}\n","<div class=\"m-2\">\n    <div class=\"flex flex-row mb-2\">\n        <div class=\"mx-2 w-1/3\">\n            <div class=\"text-md mb-2\">End Point</div>\n            <dx-text-box [(ngModel)]=\"apiBulderDataset.api\"></dx-text-box>\n        </div>\n        <div class=\"mx-2 w-1/3\">\n            <div class=\"text-md mb-2\">Api Type</div>\n            <dx-select-box [dataSource]=\"['get','post']\" [(ngModel)]=\"apiBulderDataset.apiType\">\n            </dx-select-box>\n        </div>\n        <div class=\"mx-2 w-1/3\">\n            <div class=\"text-md mb-2\">Database Name</div>\n            <dx-text-box [(ngModel)]=\"apiBulderDataset.queryConfig.databaseName\">\n            </dx-text-box>\n        </div>\n        <div class=\"mx-2 w-1/3\">\n            <div class=\"text-md mb-2\">DB Config</div>\n            <dx-select-box [items]=\"['impala','postgres','mysql','bigquery']\"\n                [(ngModel)]=\"apiBulderDataset.queryConfig.dbConfig\"></dx-select-box>\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\"> Filter Maping\n        </div>\n        <div class=\"pt-2 border-x border-b \">\n            <div class=\"my-2 flex justify-between\"\n                *ngFor=\"let item of apiBulderDataset.queryConfig.mapedFilters; let i = index;\">\n\n\n                <div class=\"px-1 mb-2\">\n                    <div class=\"text-md mb-2\"> Server Column</div>\n                    <dx-text-box [(ngModel)]=\"item.serverColumn\"></dx-text-box>\n                </div>\n                <div class=\"px-1 mb-2\">\n                    <div class=\"text-md mb-2\"> Local Column(aliasName)</div>\n                    <dx-text-box [(ngModel)]=\"item.localColumn\"></dx-text-box>\n                </div>\n                \n                <div class=\"px-1 mb-2\">\n                    <div class=\"text-md mb-2\"> Operator</div>\n                    <dx-select-box [searchEnabled]=\"true\" [items]=\"kpi_operator\"\n                        [(ngModel)]=\"item.operatorName\"></dx-select-box>\n                </div>\n                <div class=\"px-1 mb-2\">\n                    <div class=\"text-md mb-2\"> Datatype</div>\n                    <dx-select-box [searchEnabled]=\"true\"\n                        [items]=\"['date','string','timestamp','int', 'double', 'boolean']\"\n                        [(ngModel)]=\"item.dataType\"></dx-select-box>\n                </div>\n                <div class=\"px-1 mb-2\">\n                    <div class=\"text-md mb-2\"> Formatter</div>\n                    <dx-text-box [(ngModel)]=\"item.formatter\"></dx-text-box>\n                </div>\n                <div class=\"px-1 mb-2\">\n                    <div class=\"text-md mb-2\"> Default Value</div>\n                    <dx-text-box [(ngModel)]=\"item.defaultValue\"></dx-text-box>\n                </div>\n                <div class=\"px-1 mt-8\">\n                    <div class=\"flex flex-row\">\n                        <button *ngIf=\"i !== 0\" class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n                            (click)=\"moveItemForColumns(i, 'up')\">\n                            <i class=\"fa fa-arrow-up\" aria-hidden=\"true\"></i>\n                        </button>\n\n                        <button *ngIf=\"i !== apiBulderDataset.queryConfig.mapedFilters.length - 1\"\n                            class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n                            (click)=\"moveItemForColumns(i, 'down')\">\n                            <i class=\"fa fa-arrow-down\" aria-hidden=\"true\"></i>\n                        </button>\n                    </div>\n                </div>\n                <div class=\"px-1 mt-8 text-center\">\n                    <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n                        (click)=\"deleteFilterMapingColumns(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n                    </button>\n                </div>\n            </div>\n        </div>\n        <div class=\"flex flex-row\">\n            <div class=\"w-1/2\">\n                <div class=\"flex flex-row justify-end my-2\">\n                    <button class=\"{{commonService.btn_success_sm}} cursor-pointer\" (click)=\"saveColumnMaping()\">Save\n                        Maping</button>\n                    <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\"\n                        (click)=\"addFilterMapingColumns()\">Add\n                        Maping</button>\n                </div>\n            </div>\n        </div>\n\n\n        <div class=\"m-3 p-4 bg-white border border-gray-200 rounded-lg shadow-md dark:bg-gray-800 dark:border-gray-700\">\n            <h6 class=\"mb-2 font-bold tracking-tight text-gray-900 dark:text-white border-b pb-3\">\n                Configure SQL Expression\n            </h6>\n            <div class=\"p-5 font-light border border-b-0 border-gray-200 dark:border-gray-700 dark:bg-gray-900\">\n                <div class=\"mt-5 p-2\">\n                    <textarea id=\"message\" rows=\"20\"\n                        class=\"block p-2.5 w-full text-lg text-gray-900 bg-gray-50 rounded-lg border border-gray-300 focus:ring-blue-500 focus:border-blue-500 dark:bg-gray-700 dark:border-gray-600 dark:placeholder-gray-400 dark:text-white dark:focus:ring-blue-500 dark:focus:border-blue-500\"\n                        placeholder=\"Write your SQL query here...\" [(ngModel)]=\"queryStringData\"\n                        id=\"exampleTextarea\">{{  sqlString | sql }}</textarea>\n\n\n                    <div class=\"row no-margin\" *ngIf=\"validateArgumentError\">\n                        <p class=\"text-red-400\">This query is not valid</p>\n                    </div>\n\n                    <div class=\"flex\">\n                        <button *ngIf=\"formatButtonStatus\" type=\"button\"\n                            class=\"focus:outline-none text-white bg-purple-700 hover:bg-purple-800 focus:ring-4\n                                        focus:ring-purple-300 font-medium dark:bg-purple-600 my-2 px-5 py-2.5 dark:hover:bg-purple-700 dark:focus:ring-purple-900\"\n                            (click)=\"format()\">Format\n                        </button>\n                        <button type=\"button\" *ngIf=\"!formatButtonStatus\"\n                            class=\"focus:outline-none text-white bg-yellow-800 hover:bg-yellow-500 focus:ring-4\n                                        focus:ring-yellow-300 font-medium mr-2 px-5 py-2.5 my-2 dark:focus:ring-yellow-900\" (click)=\"format()\">\n                            Reformat\n                        </button>\n                    </div>\n                </div>\n            </div>\n\n            <div class=\"flex justify-end mt-2\">\n\n            </div>\n        </div>\n        <div class=\"my-2\">\n            <div\n                class=\"m-3 p-4 bg-white border border-gray-200 rounded-lg shadow-md dark:bg-gray-800 dark:border-gray-700 \">\n                <h6 class=\"mb-2 font-bold tracking-tight text-gray-900 dark:text-white border-b pb-3\">\n                    Data Enrichment\n                </h6>\n                <div class=\"grid grid-cols-1 gap-2 w-full\">\n                    <div class=\"p-2 w-full\"\n                        *ngFor=\"let item of apiBulderDataset.queryConfig.enrichments; let i = index;\">\n                        <div class=\"flex flex-row\">\n                            <div class=\"px-1 mb-2 w-full\">\n                                <div class=\"text-md mb-2\"> Value Field(aliasName)</div>\n                                <dx-text-box [(ngModel)]=\"item.columnName\"></dx-text-box>\n                            </div>\n                            <div class=\"px-1 mb-2 w-full\">\n                                <div class=\"text-md mb-2\"> Enrich Type</div>\n                                <dx-select-box [items]=\"['Basic','Lookup']\"></dx-select-box>\n                            </div>\n                            <div class=\"px-1 mb-2 w-full\">\n                                <div class=\"text-md mb-2\"> Enrich Name</div>\n                                <dx-select-box [searchEnabled]=\"true\" [items]=\"kpi_enrichment_name\"\n                                    [(ngModel)]=\"item.enrichFunction\"></dx-select-box>\n                            </div>\n                            <div class=\"px-1 mt-8\">\n                                <div class=\"flex flex-row\">\n                                    <button *ngIf=\"i !== 0\" class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n                                        (click)=\"moveItemForMeasuresColumns(i, 'up')\">\n                                        <i class=\"fa fa-arrow-up\" aria-hidden=\"true\"></i>\n                                    </button>\n\n                                    <button *ngIf=\"i !== apiBulderDataset.queryConfig.enrichments.length - 1\"\n                                        class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n                                        (click)=\"moveItemForMeasuresColumns(i, 'down')\">\n                                        <i class=\"fa fa-arrow-down\" aria-hidden=\"true\"></i>\n                                    </button>\n                                </div>\n                            </div>\n                            <div class=\"px-1 mt-8 text-center\">\n\n                                <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n                                    (click)=\"deleteColumns(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n                                </button>\n                            </div>\n                        </div>\n\n                    </div>\n                </div>\n\n\n                <div class=\"flex justify-end mt-2\">\n                    <button class=\"{{commonService.btn_primary_md}} cursor-pointer\" (click)=\"addColumns()\">Add\n                        Columns</button>\n                </div>\n            </div>\n        </div>\n\n\n\n        <div class=\"flex w-full justify-end mt-5 border-t\">\n            <button type=\"button\" class=\"{{commonService.btn_primary_md}} cursor-pointer mx-1 my-2\"\n                (click)=\"validateNewReport()\" [disabled]=\"isValidate\">\n                Validate\n            </button>\n            <button class=\"{{commonService.btn_success_md}} cursor-pointer mx-1 my-2\" (click)=\"createDataSet()\"\n                [disabled]=\"isNotValidate\">\n                Submit DataSet\n            </button>\n        </div>\n\n    </div>\n</div>"]}
|
|
187
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-dataset-sql.component.js","sourceRoot":"","sources":["../../../../../../../projects/gamma-app-controller/src/lib/application-controller/application-dataset-component/create-dataset-sql/create-dataset-sql.component.ts","../../../../../../../projects/gamma-app-controller/src/lib/application-controller/application-dataset-component/create-dataset-sql/create-dataset-sql.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 { SqlPipe } from './sqlFormatter';\nimport { ApplicationContentService } from '../../application-content.service';\nimport { CommonService } from '../../common';\nimport cloneDeep from 'lodash-es/cloneDeep';\n\n@Component({\n  selector: 'app-create-dataset-sql',\n  templateUrl: './create-dataset-sql.component.html',\n  styleUrls: ['./create-dataset-sql.component.scss'],\n  providers: [SqlPipe],\n\n})\nexport class CreateDatasetSqlComponent implements OnInit {\n  kpi_function: any = [\"sum\", \"count\", \"avg\", \"max\", \"min\", \"stddev\", \"count_distinct\"]\n  kpi_operator: any = [\"eq\", \"gte\", \"lte\", \"ne\", \"in\", \"notIn\", \"contains\", \"startsWith\", \"endsWith\"]\n  @Output() public getSqlQueryBulbderDataSet: EventEmitter<any> = new EventEmitter();\n  apiBulderDataset: any;\n  queryStringData: string;\n  sqlString = '';\n  validateArgumentError: boolean = false;\n  formatButtonStatus: boolean = true;\n  validateStatus: boolean = false;\n\n  isValidate: boolean = true;\n  isNotValidate: boolean = true;\n  argumentData: any = [];\n\n  duplicateMatches: any;\n  matches: any;\n  kpi_enrichment_name: any = [];\n  @Input('sqlBulderDataset')\n  set sqlBulderDataset(value) {\n    if (value.queryConfig.mapedFilters == undefined) {\n      value.queryConfig.mapedFilters = [];\n      value.queryConfig.mapedFilters.push({ \"localColumn\": \"\", \"serverColumn\": \"\", \"operatorName\": \"\", \"defaultValue\": \"\", \"dataType\": \"\", \"formatter\": \"\" })\n    }\n    if (value.queryConfig.templateQuery != \"\") {\n      this.queryStringData = value.queryConfig.templateQuery;\n    }\n\n    const hasLimit = value.queryConfig.mapedFilters.some(filter => filter.serverColumn === 'limit');\n\n    if (!hasLimit) {\n      value.queryConfig.mapedFilters.push({\n        localColumn: \"limit\",\n        serverColumn: \"limit\",\n        operatorName: \"eq\",\n        defaultValue: \"5000\",\n        dataType: \"string\"\n      });\n    }\n    this.apiBulderDataset = value;\n  }\n\n  constructor(\n    private toastr: ToastrService,\n    public commonService: CommonService,\n    private sqlFormatter: SqlPipe,\n    private service: ApplicationContentService\n  ) { }\n\n  ngOnInit(): void {\n    this.service.listColumnEnrichmentFunctions().subscribe(data => {\n      this.kpi_enrichment_name = data;\n    })\n  }\n\n  addFilterMapingColumns() {\n    let obj = { \"localColumn\": \"\", \"serverColumn\": \"\", \"operatorName\": \"\", \"defaultValue\": \"\", \"dataType\": \"\", \"formatter\": \"\" }\n    this.apiBulderDataset.queryConfig.mapedFilters.push(obj);\n\n  }\n\n  deleteFilterMapingColumns(i) {\n    this.apiBulderDataset.queryConfig.mapedFilters.splice(i, 1)\n\n  }\n\n  saveColumnMaping() {\n    this.toastr.success('Maped Filter Successfully');\n\n  }\n\n\n\n  moveItemForColumns(index: number, direction: 'up' | 'down'): void {\n    // Prevent moving beyond array bounds\n    if (index < 0 || index >= this.apiBulderDataset.queryConfig.mapedFilters.length) return;\n    const newPosition = direction === 'up' ? index - 1 : index + 1;\n    // Prevent moving beyond array bounds\n    if (newPosition < 0 || newPosition >= this.apiBulderDataset.queryConfig.mapedFilters.length) return;\n\n    // Move item\n    const itemToMove = this.apiBulderDataset.queryConfig.mapedFilters[index];\n    this.apiBulderDataset.queryConfig.mapedFilters.splice(index, 1); // Remove item from current position\n    this.apiBulderDataset.queryConfig.mapedFilters.splice(newPosition, 0, itemToMove); // Insert item in new position\n  }\n\n\n\n  format(): any {\n    this.matches = [];\n    this.duplicateMatches = [];\n    this.argumentData = [];\n    let val: any;\n    let fval: any;\n    let splittedValuesOfQuery: any;\n    // val = document.getElementById('exampleTextarea')['value'];\n    val = this.queryStringData;\n    const newVal = val.trim();\n    if (newVal === '' || newVal === undefined) {\n      // this.toastr.error('Query Empty');\n    } else {\n\n      fval = this.sqlFormatter.transform(val);\n      splittedValuesOfQuery = fval.match(/'[^']*'|\\S+/g) || [];\n      // document.getElementById('exampleTextarea')['value'] = fval;\n      this.queryStringData = fval;\n      // this.toastr.success('Query Formatted');\n      const re = /{([^}]+)}/g;\n      let m = [];\n      while (m = re.exec(fval)) {\n        this.duplicateMatches.push(m[1]);\n      }\n      let limit_key = [];\n      limit_key = splittedValuesOfQuery.filter(s => s.toLowerCase().includes('limit'));\n      this.matches = this.duplicateMatches.filter((v, i) => this.duplicateMatches.indexOf(v) === i);\n      for (let i = 0; i < this.matches.length; i++) {\n        let value: any;\n        let key: any;\n        let th_key: any;\n        let keyarr = [];\n        value = this.matches[i];\n        keyarr = splittedValuesOfQuery.filter(s => s.includes('$P{' + this.matches[i] + '}'));\n        if (keyarr.length !== 0) {\n          if (keyarr[0].split('=')[0].indexOf('.') > 0) {\n            key = keyarr[0].split('=')[0].split('.')[1];\n          } else {\n            key = keyarr[0].split('=')[0];\n          }\n        }\n        this.argumentData.push(key)\n\n      }\n      if (limit_key && limit_key.length !== 0) {\n        this.argumentData.push(limit_key[0].toLowerCase())\n\n      }\n\n\n      this.isValidate = false;\n      this.isNotValidate = true;\n    }\n\n    // console.log(this.argumentData)\n\n\n\n  }\n\n\n  validateNewReport() {\n    const argumentData = cloneDeep(this.argumentData).map(item => item.replace(/.*\\{(.*)\\}.*/, '$1'));\n    const mappedFilterColumns = this.apiBulderDataset.queryConfig.mapedFilters.map(element => element.localColumn);\n\n    this.apiBulderDataset.queryConfig.mapedFilters.forEach(element => {\n      if (argumentData.some(key => element.localColumn == key)) {\n        this.toastr.success('Validate For ' + element.localColumn);\n        this.isNotValidate = false;\n      } else {\n        this.toastr.info('Missing Alias', element.localColumn);\n      }\n    });\n\n    argumentData.forEach(key => {\n      if (!mappedFilterColumns.includes(key)) {\n        this.toastr.info('Extra Argument Data', key);\n      }\n    });\n\n  }\n\n  moveItemForMeasuresColumns(index: number, direction: 'up' | 'down'): void {\n    // Prevent moving beyond array bounds\n    if (index < 0 || index >= this.apiBulderDataset.queryConfig.enrichments.length) return;\n    const newPosition = direction === 'up' ? index - 1 : index + 1;\n    // Prevent moving beyond array bounds\n    if (newPosition < 0 || newPosition >= this.apiBulderDataset.queryConfig.enrichments.length) return;\n\n    // Move item\n    const itemToMove = this.apiBulderDataset.queryConfig.enrichments[index];\n    this.apiBulderDataset.queryConfig.enrichments.splice(index, 1); // Remove item from current position\n    this.apiBulderDataset.queryConfig.enrichments.splice(newPosition, 0, itemToMove); // Insert item in new position\n  }\n\n  addColumns() {\n    if (this.apiBulderDataset.queryConfig.enrichments && this.apiBulderDataset.queryConfig.enrichments.length !== 0) {\n      let obj = {\n        \"columnName\": \"\",\n        \"enrichFunction\": \"\",\n      }\n      this.apiBulderDataset.queryConfig.enrichments.push(obj);\n    } else {\n      this.apiBulderDataset.queryConfig.enrichments = [];\n      let obj = {\n        \"columnName\": \"\",\n        \"enrichFunction\": \"\",\n      }\n      this.apiBulderDataset.queryConfig.enrichments.push(obj);\n    }\n\n  }\n\n\n  deleteColumns(i) {\n    this.apiBulderDataset.queryConfig.enrichments.splice(i, 1)\n  }\n\n\n  createDataSet() {\n    this.apiBulderDataset.queryConfig['templateQuery'] = this.queryStringData;\n    this.getSqlQueryBulbderDataSet.emit(this.apiBulderDataset)\n  }\n\n}\n","<div class=\"m-2\">\n    <div class=\"flex flex-row mb-2\">\n        <div class=\"mx-2 w-1/3\">\n            <div class=\"text-md mb-2\">End Point</div>\n            <dx-text-box [(ngModel)]=\"apiBulderDataset.api\"></dx-text-box>\n        </div>\n        <div class=\"mx-2 w-1/3\">\n            <div class=\"text-md mb-2\">Api Type</div>\n            <dx-select-box [dataSource]=\"['get','post']\" [(ngModel)]=\"apiBulderDataset.apiType\">\n            </dx-select-box>\n        </div>\n        <div class=\"mx-2 w-1/3\">\n            <div class=\"text-md mb-2\">Database Name</div>\n            <dx-text-box [(ngModel)]=\"apiBulderDataset.queryConfig.databaseName\">\n            </dx-text-box>\n        </div>\n        <div class=\"mx-2 w-1/3\">\n            <div class=\"text-md mb-2\">DB Config</div>\n            <dx-select-box [items]=\"['impala','postgres','mysql','bigquery']\"\n                [(ngModel)]=\"apiBulderDataset.queryConfig.dbConfig\"></dx-select-box>\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\"> Filter Maping\n        </div>\n        <div class=\"pt-2 border-x border-b \">\n            <div class=\"my-2 flex justify-between\"\n                *ngFor=\"let item of apiBulderDataset.queryConfig.mapedFilters; let i = index;\">\n\n\n                <div class=\"px-1 mb-2\">\n                    <div class=\"text-md mb-2\"> Server Column</div>\n                    <dx-text-box [(ngModel)]=\"item.serverColumn\"></dx-text-box>\n                </div>\n                <div class=\"px-1 mb-2\">\n                    <div class=\"text-md mb-2\"> Local Column(aliasName)</div>\n                    <dx-text-box [(ngModel)]=\"item.localColumn\"></dx-text-box>\n                </div>\n                \n                <div class=\"px-1 mb-2\">\n                    <div class=\"text-md mb-2\"> Operator</div>\n                    <dx-select-box [searchEnabled]=\"true\" [items]=\"kpi_operator\"\n                        [(ngModel)]=\"item.operatorName\"></dx-select-box>\n                </div>\n                <div class=\"px-1 mb-2\">\n                    <div class=\"text-md mb-2\"> Datatype</div>\n                    <dx-select-box [searchEnabled]=\"true\"\n                        [items]=\"['date','string','timestamp','int', 'double', 'boolean']\"\n                        [(ngModel)]=\"item.dataType\"></dx-select-box>\n                </div>\n                <div class=\"px-1 mb-2\">\n                    <div class=\"text-md mb-2\"> Formatter</div>\n                    <dx-text-box [(ngModel)]=\"item.formatter\"></dx-text-box>\n                </div>\n                <div class=\"px-1 mb-2\">\n                    <div class=\"text-md mb-2\"> Default Value</div>\n                    <dx-text-box [(ngModel)]=\"item.defaultValue\"></dx-text-box>\n                </div>\n                <div class=\"px-1 mt-8\">\n                    <div class=\"flex flex-row\">\n                        <button *ngIf=\"i !== 0\" class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n                            (click)=\"moveItemForColumns(i, 'up')\">\n                            <i class=\"fa fa-arrow-up\" aria-hidden=\"true\"></i>\n                        </button>\n\n                        <button *ngIf=\"i !== apiBulderDataset.queryConfig.mapedFilters.length - 1\"\n                            class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n                            (click)=\"moveItemForColumns(i, 'down')\">\n                            <i class=\"fa fa-arrow-down\" aria-hidden=\"true\"></i>\n                        </button>\n                    </div>\n                </div>\n                <div class=\"px-1 mt-8 text-center\">\n                    <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n                        (click)=\"deleteFilterMapingColumns(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n                    </button>\n                </div>\n            </div>\n        </div>\n        <div class=\"flex flex-row\">\n            <div class=\"w-1/2\">\n                <div class=\"flex flex-row justify-end my-2\">\n                    <button class=\"{{commonService.btn_success_sm}} cursor-pointer\" (click)=\"saveColumnMaping()\">Save\n                        Maping</button>\n                    <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\"\n                        (click)=\"addFilterMapingColumns()\">Add\n                        Maping</button>\n                </div>\n            </div>\n        </div>\n\n\n        <div class=\"m-3 p-4 bg-white border border-gray-200 rounded-lg shadow-md dark:bg-gray-800 dark:border-gray-700\">\n            <h6 class=\"mb-2 font-bold tracking-tight text-gray-900 dark:text-white border-b pb-3\">\n                Configure SQL Expression\n            </h6>\n            <div class=\"p-5 font-light border border-b-0 border-gray-200 dark:border-gray-700 dark:bg-gray-900\">\n                <div class=\"mt-5 p-2\">\n                    <textarea id=\"message\" rows=\"20\"\n                        class=\"block p-2.5 w-full text-lg text-gray-900 bg-gray-50 rounded-lg border border-gray-300 focus:ring-blue-500 focus:border-blue-500 dark:bg-gray-700 dark:border-gray-600 dark:placeholder-gray-400 dark:text-white dark:focus:ring-blue-500 dark:focus:border-blue-500\"\n                        placeholder=\"Write your SQL query here...\" [(ngModel)]=\"queryStringData\"\n                        id=\"exampleTextarea\">{{  sqlString | sql }}</textarea>\n\n\n                    <div class=\"row no-margin\" *ngIf=\"validateArgumentError\">\n                        <p class=\"text-red-400\">This query is not valid</p>\n                    </div>\n\n                    <div class=\"flex\">\n                        <button *ngIf=\"formatButtonStatus\" type=\"button\"\n                            class=\"focus:outline-none text-white bg-purple-700 hover:bg-purple-800 focus:ring-4\n                                        focus:ring-purple-300 font-medium dark:bg-purple-600 my-2 px-5 py-2.5 dark:hover:bg-purple-700 dark:focus:ring-purple-900\"\n                            (click)=\"format()\">Format\n                        </button>\n                        <button type=\"button\" *ngIf=\"!formatButtonStatus\"\n                            class=\"focus:outline-none text-white bg-yellow-800 hover:bg-yellow-500 focus:ring-4\n                                        focus:ring-yellow-300 font-medium mr-2 px-5 py-2.5 my-2 dark:focus:ring-yellow-900\" (click)=\"format()\">\n                            Reformat\n                        </button>\n                    </div>\n                </div>\n            </div>\n\n            <div class=\"flex justify-end mt-2\">\n\n            </div>\n        </div>\n        <div class=\"my-2\">\n            <div\n                class=\"m-3 p-4 bg-white border border-gray-200 rounded-lg shadow-md dark:bg-gray-800 dark:border-gray-700 \">\n                <h6 class=\"mb-2 font-bold tracking-tight text-gray-900 dark:text-white border-b pb-3\">\n                    Data Enrichment\n                </h6>\n                <div class=\"grid grid-cols-1 gap-2 w-full\">\n                    <div class=\"p-2 w-full\"\n                        *ngFor=\"let item of apiBulderDataset.queryConfig.enrichments; let i = index;\">\n                        <div class=\"flex flex-row\">\n                            <div class=\"px-1 mb-2 w-full\">\n                                <div class=\"text-md mb-2\"> Value Field(aliasName)</div>\n                                <dx-text-box [(ngModel)]=\"item.columnName\"></dx-text-box>\n                            </div>\n                            <div class=\"px-1 mb-2 w-full\">\n                                <div class=\"text-md mb-2\"> Enrich Type</div>\n                                <dx-select-box [items]=\"['Basic','Lookup']\"></dx-select-box>\n                            </div>\n                            <div class=\"px-1 mb-2 w-full\">\n                                <div class=\"text-md mb-2\"> Enrich Name</div>\n                                <dx-select-box [searchEnabled]=\"true\" [items]=\"kpi_enrichment_name\"\n                                    [(ngModel)]=\"item.enrichFunction\"></dx-select-box>\n                            </div>\n                            <div class=\"px-1 mt-8\">\n                                <div class=\"flex flex-row\">\n                                    <button *ngIf=\"i !== 0\" class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n                                        (click)=\"moveItemForMeasuresColumns(i, 'up')\">\n                                        <i class=\"fa fa-arrow-up\" aria-hidden=\"true\"></i>\n                                    </button>\n\n                                    <button *ngIf=\"i !== apiBulderDataset.queryConfig.enrichments.length - 1\"\n                                        class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n                                        (click)=\"moveItemForMeasuresColumns(i, 'down')\">\n                                        <i class=\"fa fa-arrow-down\" aria-hidden=\"true\"></i>\n                                    </button>\n                                </div>\n                            </div>\n                            <div class=\"px-1 mt-8 text-center\">\n\n                                <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n                                    (click)=\"deleteColumns(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n                                </button>\n                            </div>\n                        </div>\n\n                    </div>\n                </div>\n\n\n                <div class=\"flex justify-end mt-2\">\n                    <button class=\"{{commonService.btn_primary_md}} cursor-pointer\" (click)=\"addColumns()\">Add\n                        Columns</button>\n                </div>\n            </div>\n        </div>\n\n\n\n        <div class=\"flex w-full justify-end mt-5 border-t\">\n            <button type=\"button\" class=\"{{commonService.btn_primary_md}} cursor-pointer mx-1 my-2\"\n                (click)=\"validateNewReport()\" [disabled]=\"isValidate\">\n                Validate\n            </button>\n            <button class=\"{{commonService.btn_success_md}} cursor-pointer mx-1 my-2\" (click)=\"createDataSet()\"\n                [disabled]=\"isNotValidate\">\n                Submit DataSet\n            </button>\n        </div>\n\n    </div>\n</div>"]}
|