gamma-app-controller 1.2.28 → 1.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/application-controller/application-content.service.mjs +3 -3
- package/esm2020/lib/application-controller/application-controller.module.mjs +9 -5
- package/esm2020/lib/application-controller/application-dataset-component/create-dataset/create-dataset.component.mjs +2 -2
- package/esm2020/lib/application-controller/application-dataset-component/create-dataset-sql/create-dataset-sql.component.mjs +3 -3
- package/esm2020/lib/application-controller/application-menu-controller/application-create-menu/application-create-menu.component.mjs +15 -39
- package/esm2020/lib/application-controller/application-menu-controller/application-menus/application-menus.component.mjs +5 -5
- package/esm2020/lib/application-controller/application-view-components/create-comp-view/create-comp-view.component.mjs +4 -1
- package/esm2020/lib/application-controller/common.mjs +1 -1
- package/esm2020/lib/application-controller/page-controller/page-controller/page-controller.component.mjs +12 -6
- package/esm2020/lib/application-controller/support-components/dash-chart/dash-chart.component.mjs +19 -4
- package/esm2020/lib/application-controller/support-components/dash-table/dash-table.component.mjs +8 -4
- package/esm2020/lib/application-controller/support-components/dash-today-previous/dash-today-previous.component.mjs +3 -3
- package/esm2020/lib/application-controller/support-components/table-with-bar/table-with-bar.component.mjs +9 -5
- package/esm2020/lib/shared/advanced-component/gamma-advance-chart/gamma-advance-chart.component.mjs +3 -3
- package/esm2020/lib/shared/advanced-component/gamma-advance-operator-table/gamma-advance-operator-table.component.mjs +1 -4
- package/esm2020/lib/shared/gamma-bread-crumbs/bread-crumbs.component.mjs +1 -3
- package/esm2020/lib/shared/permission-helper.mjs +54 -0
- package/esm2020/lib/shared/security_principal.mjs +3 -0
- package/esm2020/lib/shared/shared.module.mjs +119 -0
- package/esm2020/lib/shared/template-dataset-call-service.mjs +376 -0
- package/esm2020/lib/shared/user-access/user-access.component.mjs +51 -0
- package/esm2020/lib/template-module/KpiCreationModule/create-kpi-tree.component.mjs +38 -4
- package/esm2020/lib/template-module/KpiCreationModule/kpiCreation.module.mjs +7 -3
- package/esm2020/lib/template-module/bookmarked-template/bookmarked-dataset-call.service.mjs +12 -344
- package/esm2020/lib/template-module/defaulLandingComponent/landing-component.component.mjs +2 -2
- package/esm2020/lib/template-module/defaulLandingComponent/landing-dataset-call.service.mjs +12 -344
- package/esm2020/lib/template-module/defaulLandingMultiLayoutComponent/defaulLandingMultiLayout.component.mjs +1 -3
- package/esm2020/lib/template-module/defaulLandingMultiLayoutComponent/multi-landing-dataset-call.service.mjs +12 -344
- package/esm2020/lib/template-module/kpiWithMultiLayout/multi-layout-dataset-call.service.mjs +13 -345
- package/esm2020/lib/template-module/kpiWithSingleLayout/kpi-with-dataset.component.mjs +55 -26
- package/esm2020/lib/template-module/kpiWithSingleLayout/single-layout-dataset-call.service.mjs +12 -347
- package/esm2020/public-api.mjs +6 -1
- package/fesm2015/gamma-app-controller.mjs +2925 -3940
- package/fesm2015/gamma-app-controller.mjs.map +1 -1
- package/fesm2020/gamma-app-controller.mjs +1237 -2257
- package/fesm2020/gamma-app-controller.mjs.map +1 -1
- package/lib/application-controller/application-content.service.d.ts +1 -1
- package/lib/application-controller/application-controller.module.d.ts +2 -1
- package/lib/application-controller/application-menu-controller/application-create-menu/application-create-menu.component.d.ts +2 -4
- package/lib/application-controller/page-controller/page-controller/page-controller.component.d.ts +3 -1
- package/lib/application-controller/support-components/dash-chart/dash-chart.component.d.ts +2 -0
- package/lib/application-controller/support-components/dash-table/dash-table.component.d.ts +1 -0
- package/lib/application-controller/support-components/table-with-bar/table-with-bar.component.d.ts +1 -0
- package/lib/shared/permission-helper.d.ts +8 -0
- package/lib/shared/security_principal.d.ts +2 -0
- package/lib/shared/shared.module.d.ts +10 -0
- package/lib/shared/template-dataset-call-service.d.ts +23 -0
- package/lib/shared/user-access/user-access.component.d.ts +20 -0
- package/lib/template-module/KpiCreationModule/create-kpi-tree.component.d.ts +2 -0
- package/lib/template-module/KpiCreationModule/kpiCreation.module.d.ts +2 -1
- package/lib/template-module/bookmarked-template/bookmarked-dataset-call.service.d.ts +6 -13
- package/lib/template-module/defaulLandingComponent/landing-dataset-call.service.d.ts +5 -12
- package/lib/template-module/defaulLandingMultiLayoutComponent/multi-landing-dataset-call.service.d.ts +5 -12
- package/lib/template-module/kpiWithMultiLayout/multi-layout-dataset-call.service.d.ts +6 -13
- package/lib/template-module/kpiWithSingleLayout/kpi-with-dataset.component.d.ts +4 -2
- package/lib/template-module/kpiWithSingleLayout/single-layout-dataset-call.service.d.ts +5 -14
- package/package.json +1 -1
- package/public-api.d.ts +5 -0
|
@@ -139,7 +139,7 @@ export class CreateDatasetComponent {
|
|
|
139
139
|
"serverColumn": "limit",
|
|
140
140
|
"operatorName": "eq",
|
|
141
141
|
"defaultValue": "5000",
|
|
142
|
-
"dataType": "
|
|
142
|
+
"dataType": "int"
|
|
143
143
|
}
|
|
144
144
|
]
|
|
145
145
|
}
|
|
@@ -349,4 +349,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
349
349
|
type: Input,
|
|
350
350
|
args: ['selectedDatasetId']
|
|
351
351
|
}] } });
|
|
352
|
-
//# 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      } else {\n        this.createNeDataSetConfig();\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      } else {\n        this.createNeDataSetConfig();\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>"]}
|
|
352
|
+
//# 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\": \"int\"\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      } else {\n        this.createNeDataSetConfig();\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      } else {\n        this.createNeDataSetConfig();\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>"]}
|
|
@@ -174,14 +174,14 @@ export class CreateDatasetSqlComponent {
|
|
|
174
174
|
}
|
|
175
175
|
}
|
|
176
176
|
CreateDatasetSqlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CreateDatasetSqlComponent, deps: [{ token: i1.ToastrService }, { token: i2.CommonService }, { token: i3.SqlPipe }, { token: i4.ApplicationContentService }], target: i0.ɵɵFactoryTarget.Component });
|
|
177
|
-
CreateDatasetSqlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CreateDatasetSqlComponent, selector: "app-create-dataset-sql", inputs: { sqlBulderDataset: "sqlBulderDataset" }, outputs: { getSqlQueryBulbderDataSet: "getSqlQueryBulbderDataSet" }, providers: [SqlPipe], ngImport: i0, template: "<div class=\"m-2\">\n <div class=\"flex flex-row mb-2\">\n <div class=\"mx-2 w-1/3\">\n <div class=\"text-md mb-2\">End Point</div>\n <dx-text-box [(ngModel)]=\"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>", styles: [""], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { 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.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { 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: "pipe", type: i3.SqlPipe, name: "sql" }] });
|
|
177
|
+
CreateDatasetSqlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CreateDatasetSqlComponent, selector: "app-create-dataset-sql", inputs: { sqlBulderDataset: "sqlBulderDataset" }, outputs: { getSqlQueryBulbderDataSet: "getSqlQueryBulbderDataSet" }, providers: [SqlPipe], ngImport: i0, template: "<div class=\"m-2\">\n <div class=\"flex flex-row mb-2\">\n <div class=\"mx-2 w-1/3\">\n <div class=\"text-md mb-2\">End Point</div>\n <dx-text-box [(ngModel)]=\"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', 'trino', 'trino_mongo']\"\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>", styles: [""], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { 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.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { 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: "pipe", type: i3.SqlPipe, name: "sql" }] });
|
|
178
178
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CreateDatasetSqlComponent, decorators: [{
|
|
179
179
|
type: Component,
|
|
180
|
-
args: [{ selector: 'app-create-dataset-sql', providers: [SqlPipe], template: "<div class=\"m-2\">\n <div class=\"flex flex-row mb-2\">\n <div class=\"mx-2 w-1/3\">\n <div class=\"text-md mb-2\">End Point</div>\n <dx-text-box [(ngModel)]=\"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>" }]
|
|
180
|
+
args: [{ selector: 'app-create-dataset-sql', providers: [SqlPipe], template: "<div class=\"m-2\">\n <div class=\"flex flex-row mb-2\">\n <div class=\"mx-2 w-1/3\">\n <div class=\"text-md mb-2\">End Point</div>\n <dx-text-box [(ngModel)]=\"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', 'trino', 'trino_mongo']\"\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>" }]
|
|
181
181
|
}], ctorParameters: function () { return [{ type: i1.ToastrService }, { type: i2.CommonService }, { type: i3.SqlPipe }, { type: i4.ApplicationContentService }]; }, propDecorators: { getSqlQueryBulbderDataSet: [{
|
|
182
182
|
type: Output
|
|
183
183
|
}], sqlBulderDataset: [{
|
|
184
184
|
type: Input,
|
|
185
185
|
args: ['sqlBulderDataset']
|
|
186
186
|
}] } });
|
|
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: \"int\"\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 = 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>"]}
|
|
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: \"int\"\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 = 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', 'trino', 'trino_mongo']\"\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>"]}
|