gamma-app-controller 1.1.0 → 1.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/application-controller/application-controller.module.mjs +14 -5
- package/esm2020/lib/application-controller/application-dataset-call.service.mjs +3 -3
- package/esm2020/lib/application-controller/application-dataset-component/dataset-query-bulder/dataset-query-bulder.component.mjs +4 -3
- package/esm2020/lib/application-controller/application-filter/application-filter.component.mjs +2 -2
- package/esm2020/lib/application-controller/common.mjs +7 -12
- package/esm2020/lib/application-controller/page-controller/page-config/page-config.component.mjs +5 -3
- package/esm2020/lib/application-controller/page-controller/page-config-multi-layout/page-config-multi-layout.component.mjs +984 -0
- package/esm2020/lib/application-controller/page-controller/page-controller/page-controller.component.mjs +9 -2
- package/esm2020/lib/application-controller/shared/advanced-component/app-advance-header/app-header.component.mjs +23 -6
- package/esm2020/lib/application-controller/shared/advanced-component/gamma-advance-operator-table/gamma-advance-operator-table.component.mjs +14 -3
- package/esm2020/lib/application-controller/shared/advanced-component/gamma-table-clumn-bar-chart/gamma-table-clumn-bar-chart.component.mjs +14 -3
- package/esm2020/lib/application-controller/shared/advanced-component/gamma-table-with-percentage/gamma-table-with-percentage.component.mjs +113 -124
- package/esm2020/lib/application-controller/support-components/dash-table/dash-table.component.mjs +4 -3
- package/esm2020/lib/application-controller/support-components/table-with-bar/table-with-bar.component.mjs +5 -3
- package/esm2020/public-api.mjs +4 -1
- package/fesm2015/gamma-app-controller.mjs +1179 -184
- package/fesm2015/gamma-app-controller.mjs.map +1 -1
- package/fesm2020/gamma-app-controller.mjs +1177 -184
- package/fesm2020/gamma-app-controller.mjs.map +1 -1
- package/lib/application-controller/application-controller.module.d.ts +12 -11
- package/lib/application-controller/page-controller/page-config/page-config.component.d.ts +1 -1
- package/lib/application-controller/page-controller/page-config-multi-layout/page-config-multi-layout.component.d.ts +190 -0
- package/lib/application-controller/shared/advanced-component/app-advance-header/app-header.component.d.ts +3 -1
- package/lib/application-controller/shared/advanced-component/gamma-advance-operator-table/gamma-advance-operator-table.component.d.ts +2 -0
- package/lib/application-controller/shared/advanced-component/gamma-table-clumn-bar-chart/gamma-table-clumn-bar-chart.component.d.ts +2 -0
- package/lib/application-controller/shared/advanced-component/gamma-table-with-percentage/gamma-table-with-percentage.component.d.ts +17 -12
- 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/package.json +1 -1
- package/public-api.d.ts +3 -0
|
@@ -36,9 +36,11 @@ export class PageControlerComponent {
|
|
|
36
36
|
this.templateDataSource = [];
|
|
37
37
|
this.componentTemplates = [
|
|
38
38
|
{ "compName": "KpiWithDataSetTestComponent", "item": "Default KPI Layout" },
|
|
39
|
+
{ "compName": "KpiWithMultilayoutSetTestComponent", "item": "Multiple Layout KPI" },
|
|
39
40
|
{ "compName": "LandingComponentComponent", "item": "Default Page" },
|
|
40
41
|
{ "compName": "CdrConfigComponent", "item": "CDR Config" },
|
|
41
42
|
{ "compName": "CreateKpiTreeComponent", "item": "Create KPI Config" },
|
|
43
|
+
{ "compName": "CreateMetricsComponent", "item": "Create Metrics" },
|
|
42
44
|
];
|
|
43
45
|
}
|
|
44
46
|
ngOnInit() {
|
|
@@ -149,7 +151,12 @@ export class PageControlerComponent {
|
|
|
149
151
|
'contentType': "edit",
|
|
150
152
|
}
|
|
151
153
|
};
|
|
152
|
-
|
|
154
|
+
if (item.pageTemplate == "KpiWithMultilayoutSetTestComponent") {
|
|
155
|
+
this.router.navigate(['/apps/controlPanel/multiPageConfigController'], navigation);
|
|
156
|
+
}
|
|
157
|
+
else {
|
|
158
|
+
this.router.navigate(['/apps/controlPanel/pageConfigController'], navigation);
|
|
159
|
+
}
|
|
153
160
|
}
|
|
154
161
|
getCreateDashboard() {
|
|
155
162
|
this.router.navigateByUrl('/apps/controlPanel/pageConfigController');
|
|
@@ -169,4 +176,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
169
176
|
type: ViewChild,
|
|
170
177
|
args: ['scrollContainer']
|
|
171
178
|
}] } });
|
|
172
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-controller.component.js","sourceRoot":"","sources":["../../../../../../../projects/gamma-app-controller/src/lib/application-controller/page-controller/page-controller/page-controller.component.ts","../../../../../../../projects/gamma-app-controller/src/lib/application-controller/page-controller/page-controller/page-controller.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, OnInit, ViewChild } from '@angular/core';\nimport { NavigationExtras, Router } from '@angular/router';\nimport { ToastrService } from 'ngx-toastr';\nimport { confirm } from 'devextreme/ui/dialog';\nimport { ApplicationContentService } from '../../application-content.service';\nimport { DynamicRouteService } from '../../page-templates/dynamic-route-service';\nimport { CommonService } from '../../common';\n\n\n@Component({\n  selector: 'app-dashbord-controller',\n  templateUrl: './page-controller.component.html',\n  styleUrls: ['./page-controller.component.scss']\n})\nexport class PageControlerComponent implements OnInit {\n  dashboardConfig = {\n    pageName: \"\",\n    pageTitle: \"\",\n    pageUrl: \"\",\n    pageTemplate: \"\",\n    pageDocumentationUrl: \"\",\n    widgets: [],\n    filterId: \"\"\n  }\n  isNewTampleteCreate: boolean = false;\n  isLoader: boolean = false;\n\n  templateDataSource: any = [];\n\n  filterDataSource: any;\n\n  componentTemplates = [\n    { \"compName\": \"KpiWithDataSetTestComponent\", \"item\": \"Default KPI Layout\" },\n    { \"compName\": \"LandingComponentComponent\", \"item\": \"Default Page\" },\n    { \"compName\": \"CdrConfigComponent\", \"item\": \"CDR Config\" },\n    { \"compName\": \"CreateKpiTreeComponent\", \"item\": \"Create KPI Config\" },\n  ]\n\n  @ViewChild('scrollContainer') private scrollContainer: ElementRef;\n\n  constructor(\n    private router: Router, public commonService: CommonService, private service: ApplicationContentService,\n    private toastr: ToastrService, private dynamicRouteService: DynamicRouteService\n  ) {\n\n  }\n\n  ngOnInit(): void {\n    this.getAppPageConfigs();\n    this.getFilterDataSet();\n  }\n  getFilterDataSet() {\n    this.service.getAppFilterConfigs().subscribe({\n      next: (data: any) => {\n        this.filterDataSource = data;\n        this.isLoader = false;\n      }, error: (err: any) => {\n        this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Page Creation')\n\n      }\n    })\n  }\n  getAppPageConfigs() {\n    this.service.getAppPageConfigs().subscribe({\n      next: (data: any) => {\n        this.templateDataSource = data;\n        this.isLoader = false;\n      }, error: (err: any) => {\n        this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Page Creation')\n\n      }\n    })\n  }\n\n  createNewTamplete() {\n    this.isNewTampleteCreate = true;\n    this.dashboardConfig = {\n      pageName: \"\",\n      pageTitle: \"\",\n      pageUrl: \"\",\n      pageTemplate: \"\",\n      pageDocumentationUrl: \"\",\n      widgets: [],\n      filterId: \"\"\n    }\n    setTimeout(() => {\n      this.scrollToBottom();\n    }, 100);\n  }\n\n  viewsPage(item) {\n    let navigationExtras: NavigationExtras = {\n      queryParams: {\n        \"pageId\": item.pageId\n      }\n    }\n    this.router.navigate([item.pageUrl], navigationExtras)\n  }\n  deleteTamplete(item) {\n    let result = confirm(\"<i>Are You Sure?</i>\", \"Delete Filter\");\n    result.then((dialogResult) => {\n      if (dialogResult) {\n        this.isLoader = true;\n        this.service.deleteAppPageConfig(item.pageId).subscribe((val: any) => {\n          this.getAppPageConfigs();\n          this.isLoader = false;\n          this.toastr.success('Page Deleted Successfully')\n        }, err => {\n          console.log(err);\n          this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Rule Module');\n        })\n      }\n    });\n  }\n\n  editTemplate(item) {\n    this.dashboardConfig = item;\n    this.isNewTampleteCreate = true;\n    this.scrollToBottom();\n  }\n\n  getSaveChartConfig() {\n\n    if (this.dashboardConfig['pageId']) {\n      this.service.editAppPageConfig(this.dashboardConfig).subscribe({\n        next: (data: any) => {\n          this.isNewTampleteCreate = false;\n          this.getAppPageConfigs();\n          this.toastr.success('Page Update Successfully')\n        }, error: (err: any) => {\n          this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Page Creation')\n        }\n      })\n    } else {\n      this.service.createAppPageConfig(this.dashboardConfig).subscribe({\n        next: (data: any) => {\n          this.isNewTampleteCreate = false;\n          this.getAppPageConfigs();\n          this.toastr.success('Page Created Successfully')\n        }, error: (err: any) => {\n          this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Page Creation')\n        }\n      })\n    }\n  }\n\n  viewConfiguredTemplate(item) {\n    let navigation: NavigationExtras = {\n      queryParams: {\n        'pageId': item.pageId,\n        'contentType': \"view\",\n\n      }\n    };\n    this.router.navigate(['/apps/controlPanel/pageConfigController'], navigation);\n  }\n\n  configuredTemplate(item) {\n    let navigation: NavigationExtras = {\n      queryParams: {\n        'pageId': item.pageId,\n        'contentType': \"edit\",\n\n      }\n    };\n    this.router.navigate(['/apps/controlPanel/pageConfigController'], navigation);\n  }\n\n\n  getCreateDashboard() {\n    this.router.navigateByUrl('/apps/controlPanel/pageConfigController')\n  }\n\n  scrollToBottom() {\n    setTimeout(() => {\n      this.scrollContainer.nativeElement.scrollIntoView({ behavior: 'smooth', block: 'end' });\n    }, 0);\n  }\n\n  // scrollToBottom(): void {\n  //   this.scrollContainer.nativeElement.scrollTop = this.scrollContainer.nativeElement.scrollHeight;\n  // }\n\n\n\n  // addRoutesAndNavigate(routeConfig) {\n  //   const componentMap = {\n  //     'KpiTreeViewComponent': KpiTreeViewComponent,\n  //     'BookmarkedTemplateComponent': BookmarkedTemplateComponent\n  //   };\n  //   const dynamicRoute = {\n  //     path: routeConfig.path,\n  //     component: componentMap[routeConfig.compName],\n  //   };\n\n  //   // Find the parent route (e.g., MainLayoutComponent)\n  //   const mainLayoutRoute = this.router.config.find(route => route.component === LayoutComponent);\n\n  //   if (mainLayoutRoute) {\n  //     if (!mainLayoutRoute.children) {\n  //       mainLayoutRoute.children = [];\n  //     }\n\n  //     // Add the dynamic route as a child of the main layout route\n  //     mainLayoutRoute.children.push(dynamicRoute);\n  //   } else {\n  //     // Fallback: Add the route directly (this may cause issues if the layout is missing)\n  //     this.router.config.push(dynamicRoute);\n  //   }\n\n  //   // Navigate to the newly added route\n  //   this.router.navigate([routeConfig.path]);\n  // }\n\n}\n","<div class=\"flex flex-col flex-auto min-w-0\">\n\n    <lib-common-header [pageTitle]=\"' Application Pages'\"></lib-common-header>\n\n\n\n    <div class=\"p-4 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 class=\"mb-2 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> Manage Pages\n                <div class=\"ml-auto\">\n                    <button class=\"{{commonService.btn_primary_md}}\" (click)=\"createNewTamplete()\">\n                        Create New Page\n                    </button>\n                </div>\n            </h6>\n            <app-loader *ngIf=\"isLoader\"></app-loader>\n            <dx-data-grid [columnAutoWidth]=\"true\" [dataSource]=\"templateDataSource\" [hoverStateEnabled]=\"true\"\n                *ngIf=\"!isLoader\" [selectedRowKeys]=\"[]\" [showBorders]=\"true\" [showColumnLines]=\"true\"\n                [showRowLines]=\"true\">\n                <dxo-paging [pageSize]=\"10\"></dxo-paging>\n                <dxo-export [enabled]=\"true\"></dxo-export>\n                <dxo-search-panel [highlightCaseSensitive]=\"true\" [visible]=\"true\">\n                </dxo-search-panel>\n\n                <dxi-column dataField=\"pageName\"></dxi-column>\n                <dxi-column dataField=\"pageTitle\"></dxi-column>\n                <!-- <dxi-column dataField=\"pageTemplate\"></dxi-column> -->\n                <dxi-column dataField=\"pageId\"></dxi-column>\n                <dxi-column dataField=\"pageUrl\"></dxi-column>\n                <!-- <dxi-column dataField=\"createdBy\"></dxi-column> -->\n                <!-- <dxi-column dataField=\"creationDate\"></dxi-column> -->\n                <dxi-column dataField=\"Configured\" cellTemplate=\"cellTemplate2\"></dxi-column>\n                <dxi-column dataField=\"action\" cellTemplate=\"cellTemplate\"></dxi-column>\n                <div *dxTemplate=\"let data of 'cellTemplate'\">\n                    <button class=\"{{commonService.btn_primary_md}}\" (click)=\"editTemplate(data.data)\">\n                        Edit\n                    </button>\n                    <button class=\"{{commonService.btn_success_md}}\" (click)=\"viewsPage(data.data)\">\n                        View Page\n                    </button>\n                    <button class=\"{{commonService.btn_danger_md}}\" (click)=\"deleteTamplete(data.data)\">\n                        Delete\n                    </button>\n                </div>\n                <div *dxTemplate=\"let data of 'cellTemplate2'\">\n\n                    <button class=\"{{commonService.btn_success_md}}\" (click)=\"configuredTemplate(data.data)\">\n                        Configure\n                    </button>\n\n                </div>\n\n\n\n            </dx-data-grid>\n        </div>\n    </div>\n\n    <div #scrollContainer>\n        <div class=\"p-2\" *ngIf=\"isNewTampleteCreate\">\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\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> Create Page\n                </h6>\n\n                <!-- Flex container for form fields -->\n                <!-- <div class=\"flex flex-wrap w-full\">\n                    <div class=\"w-1/2 px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page Name</div>\n                        <dx-text-box [(ngModel)]=\"dashboardConfig.pageName\"></dx-text-box>\n                    </div>\n                    <div class=\"w-1/2 px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page Title</div>\n                        <dx-text-box [(ngModel)]=\"dashboardConfig.pageTitle\"></dx-text-box>\n                    </div>\n                    <div class=\"w-1/2 px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page URL</div>\n                        <dx-text-box [(ngModel)]=\"dashboardConfig.pageUrl\"></dx-text-box>\n                    </div>\n                    <div class=\"w-1/2 px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page Template</div>\n                        <dx-select-box [items]=\"componentTemplates\" displayExpr=\"item\" valueExpr=\"compName\"\n                            [(ngModel)]=\"dashboardConfig.pageTemplate\" searchEnabled=\"true\"></dx-select-box>\n                    </div>\n                    <div class=\"w-1/2 px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page Documentation Url</div>\n                        <dx-text-box [(ngModel)]=\"dashboardConfig.pageDocumentationUrl\"></dx-text-box>\n                    </div>\n                    <div class=\"w-1/2 px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page Filter</div>\n                        <dx-select-box [items]=\"filterDataSource\" displayExpr=\"filterName\" valueExpr=\"filterId\"\n                            [(ngModel)]=\"dashboardConfig.filterId\"></dx-select-box>\n                    </div>\n                </div> -->\n                <div class=\"grid grid-cols-2 gap-4 w-full\">\n                    <div class=\"px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page Name</div>\n                        <dx-text-box [(ngModel)]=\"dashboardConfig.pageName\"></dx-text-box>\n                    </div>\n                    <div class=\"px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page Title</div>\n                        <dx-text-box [(ngModel)]=\"dashboardConfig.pageTitle\"></dx-text-box>\n                    </div>\n                    <div class=\"px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page URL</div>\n                        <dx-text-box [(ngModel)]=\"dashboardConfig.pageUrl\"></dx-text-box>\n                    </div>\n                    <div class=\"px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page Template</div>\n                        <dx-select-box [items]=\"componentTemplates\" displayExpr=\"item\" valueExpr=\"compName\"\n                            [(ngModel)]=\"dashboardConfig.pageTemplate\" [searchEnabled]=\"true\"></dx-select-box>\n                    </div>\n                    <div class=\"px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page Documentation Url</div>\n                        <dx-text-box [(ngModel)]=\"dashboardConfig.pageDocumentationUrl\"></dx-text-box>\n                    </div>\n                    <div class=\"px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page Filter</div>\n                        <dx-select-box [items]=\"filterDataSource\" displayExpr=\"filterName\" valueExpr=\"filterId\"\n                            [(ngModel)]=\"dashboardConfig.filterId\"></dx-select-box>\n                    </div>\n                </div>\n\n                <!-- Submit button -->\n                <div class=\"flex justify-end mx-1 flex-grow\">\n                    <button class=\"{{commonService.btn_success_md}} cursor-pointer mt-2\"\n                        (click)=\"getSaveChartConfig()\">Submit Template</button>\n                </div>\n            </div>\n        </div>\n    </div>\n\n\n\n</div>"]}
|
|
179
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-controller.component.js","sourceRoot":"","sources":["../../../../../../../projects/gamma-app-controller/src/lib/application-controller/page-controller/page-controller/page-controller.component.ts","../../../../../../../projects/gamma-app-controller/src/lib/application-controller/page-controller/page-controller/page-controller.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, OnInit, ViewChild } from '@angular/core';\nimport { NavigationExtras, Router } from '@angular/router';\nimport { ToastrService } from 'ngx-toastr';\nimport { confirm } from 'devextreme/ui/dialog';\nimport { ApplicationContentService } from '../../application-content.service';\nimport { DynamicRouteService } from '../../page-templates/dynamic-route-service';\nimport { CommonService } from '../../common';\n\n\n@Component({\n  selector: 'app-dashbord-controller',\n  templateUrl: './page-controller.component.html',\n  styleUrls: ['./page-controller.component.scss']\n})\nexport class PageControlerComponent implements OnInit {\n  dashboardConfig = {\n    pageName: \"\",\n    pageTitle: \"\",\n    pageUrl: \"\",\n    pageTemplate: \"\",\n    pageDocumentationUrl: \"\",\n    widgets: [],\n    filterId: \"\"\n  }\n  isNewTampleteCreate: boolean = false;\n  isLoader: boolean = false;\n\n  templateDataSource: any = [];\n\n  filterDataSource: any;\n\n  componentTemplates = [\n    { \"compName\": \"KpiWithDataSetTestComponent\", \"item\": \"Default KPI Layout\" },\n    { \"compName\": \"KpiWithMultilayoutSetTestComponent\", \"item\": \"Multiple Layout KPI\" },\n    { \"compName\": \"LandingComponentComponent\", \"item\": \"Default Page\" },\n    { \"compName\": \"CdrConfigComponent\", \"item\": \"CDR Config\" },\n    { \"compName\": \"CreateKpiTreeComponent\", \"item\": \"Create KPI Config\" },\n    { \"compName\": \"CreateMetricsComponent\", \"item\": \"Create Metrics\" },\n  ]\n\n  @ViewChild('scrollContainer') private scrollContainer: ElementRef;\n\n  constructor(\n    private router: Router, public commonService: CommonService, private service: ApplicationContentService,\n    private toastr: ToastrService, private dynamicRouteService: DynamicRouteService\n  ) {\n\n  }\n\n  ngOnInit(): void {\n    this.getAppPageConfigs();\n    this.getFilterDataSet();\n  }\n  getFilterDataSet() {\n    this.service.getAppFilterConfigs().subscribe({\n      next: (data: any) => {\n        this.filterDataSource = data;\n        this.isLoader = false;\n      }, error: (err: any) => {\n        this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Page Creation')\n\n      }\n    })\n  }\n  getAppPageConfigs() {\n    this.service.getAppPageConfigs().subscribe({\n      next: (data: any) => {\n        this.templateDataSource = data;\n        this.isLoader = false;\n      }, error: (err: any) => {\n        this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Page Creation')\n\n      }\n    })\n  }\n\n  createNewTamplete() {\n    this.isNewTampleteCreate = true;\n    this.dashboardConfig = {\n      pageName: \"\",\n      pageTitle: \"\",\n      pageUrl: \"\",\n      pageTemplate: \"\",\n      pageDocumentationUrl: \"\",\n      widgets: [],\n      filterId: \"\"\n    }\n    setTimeout(() => {\n      this.scrollToBottom();\n    }, 100);\n  }\n\n  viewsPage(item) {\n    let navigationExtras: NavigationExtras = {\n      queryParams: {\n        \"pageId\": item.pageId\n      }\n    }\n    this.router.navigate([item.pageUrl], navigationExtras)\n  }\n  deleteTamplete(item) {\n    let result = confirm(\"<i>Are You Sure?</i>\", \"Delete Filter\");\n    result.then((dialogResult) => {\n      if (dialogResult) {\n        this.isLoader = true;\n        this.service.deleteAppPageConfig(item.pageId).subscribe((val: any) => {\n          this.getAppPageConfigs();\n          this.isLoader = false;\n          this.toastr.success('Page Deleted Successfully')\n        }, err => {\n          console.log(err);\n          this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Rule Module');\n        })\n      }\n    });\n  }\n\n  editTemplate(item) {\n    this.dashboardConfig = item;\n    this.isNewTampleteCreate = true;\n    this.scrollToBottom();\n  }\n\n  getSaveChartConfig() {\n\n    if (this.dashboardConfig['pageId']) {\n      this.service.editAppPageConfig(this.dashboardConfig).subscribe({\n        next: (data: any) => {\n          this.isNewTampleteCreate = false;\n          this.getAppPageConfigs();\n          this.toastr.success('Page Update Successfully')\n        }, error: (err: any) => {\n          this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Page Creation')\n        }\n      })\n    } else {\n      this.service.createAppPageConfig(this.dashboardConfig).subscribe({\n        next: (data: any) => {\n          this.isNewTampleteCreate = false;\n          this.getAppPageConfigs();\n          this.toastr.success('Page Created Successfully')\n        }, error: (err: any) => {\n          this.toastr.error('Unexpected Server Exception. Please contact System Admin.', 'Page Creation')\n        }\n      })\n    }\n  }\n\n  viewConfiguredTemplate(item) {\n    let navigation: NavigationExtras = {\n      queryParams: {\n        'pageId': item.pageId,\n        'contentType': \"view\",\n\n      }\n    };\n    this.router.navigate(['/apps/controlPanel/pageConfigController'], navigation);\n  }\n\n  configuredTemplate(item) {\n    \n    let navigation: NavigationExtras = {\n      queryParams: {\n        'pageId': item.pageId,\n        'contentType': \"edit\",\n\n      }\n    };\n    if(item.pageTemplate == \"KpiWithMultilayoutSetTestComponent\"){\n      this.router.navigate(['/apps/controlPanel/multiPageConfigController'], navigation);\n    } else {\n      this.router.navigate(['/apps/controlPanel/pageConfigController'], navigation);\n    }\n  }\n\n\n  getCreateDashboard() {\n    this.router.navigateByUrl('/apps/controlPanel/pageConfigController')\n  }\n\n  scrollToBottom() {\n    setTimeout(() => {\n      this.scrollContainer.nativeElement.scrollIntoView({ behavior: 'smooth', block: 'end' });\n    }, 0);\n  }\n\n  // scrollToBottom(): void {\n  //   this.scrollContainer.nativeElement.scrollTop = this.scrollContainer.nativeElement.scrollHeight;\n  // }\n\n\n\n  // addRoutesAndNavigate(routeConfig) {\n  //   const componentMap = {\n  //     'KpiTreeViewComponent': KpiTreeViewComponent,\n  //     'BookmarkedTemplateComponent': BookmarkedTemplateComponent\n  //   };\n  //   const dynamicRoute = {\n  //     path: routeConfig.path,\n  //     component: componentMap[routeConfig.compName],\n  //   };\n\n  //   // Find the parent route (e.g., MainLayoutComponent)\n  //   const mainLayoutRoute = this.router.config.find(route => route.component === LayoutComponent);\n\n  //   if (mainLayoutRoute) {\n  //     if (!mainLayoutRoute.children) {\n  //       mainLayoutRoute.children = [];\n  //     }\n\n  //     // Add the dynamic route as a child of the main layout route\n  //     mainLayoutRoute.children.push(dynamicRoute);\n  //   } else {\n  //     // Fallback: Add the route directly (this may cause issues if the layout is missing)\n  //     this.router.config.push(dynamicRoute);\n  //   }\n\n  //   // Navigate to the newly added route\n  //   this.router.navigate([routeConfig.path]);\n  // }\n\n}\n","<div class=\"flex flex-col flex-auto min-w-0\">\n\n    <lib-common-header [pageTitle]=\"' Application Pages'\"></lib-common-header>\n\n\n\n    <div class=\"p-4 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 class=\"mb-2 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> Manage Pages\n                <div class=\"ml-auto\">\n                    <button class=\"{{commonService.btn_primary_md}}\" (click)=\"createNewTamplete()\">\n                        Create New Page\n                    </button>\n                </div>\n            </h6>\n            <app-loader *ngIf=\"isLoader\"></app-loader>\n            <dx-data-grid [columnAutoWidth]=\"true\" [dataSource]=\"templateDataSource\" [hoverStateEnabled]=\"true\"\n                *ngIf=\"!isLoader\" [selectedRowKeys]=\"[]\" [showBorders]=\"true\" [showColumnLines]=\"true\"\n                [showRowLines]=\"true\">\n                <dxo-paging [pageSize]=\"10\"></dxo-paging>\n                <dxo-export [enabled]=\"true\"></dxo-export>\n                <dxo-search-panel [highlightCaseSensitive]=\"true\" [visible]=\"true\">\n                </dxo-search-panel>\n\n                <dxi-column dataField=\"pageName\"></dxi-column>\n                <dxi-column dataField=\"pageTitle\"></dxi-column>\n                <!-- <dxi-column dataField=\"pageTemplate\"></dxi-column> -->\n                <dxi-column dataField=\"pageId\"></dxi-column>\n                <dxi-column dataField=\"pageUrl\"></dxi-column>\n                <!-- <dxi-column dataField=\"createdBy\"></dxi-column> -->\n                <!-- <dxi-column dataField=\"creationDate\"></dxi-column> -->\n                <dxi-column dataField=\"Configured\" cellTemplate=\"cellTemplate2\"></dxi-column>\n                <dxi-column dataField=\"action\" cellTemplate=\"cellTemplate\"></dxi-column>\n                <div *dxTemplate=\"let data of 'cellTemplate'\">\n                    <button class=\"{{commonService.btn_primary_md}}\" (click)=\"editTemplate(data.data)\">\n                        Edit\n                    </button>\n                    <button class=\"{{commonService.btn_success_md}}\" (click)=\"viewsPage(data.data)\">\n                        View Page\n                    </button>\n                    <button class=\"{{commonService.btn_danger_md}}\" (click)=\"deleteTamplete(data.data)\">\n                        Delete\n                    </button>\n                </div>\n                <div *dxTemplate=\"let data of 'cellTemplate2'\">\n\n                    <button class=\"{{commonService.btn_success_md}}\" (click)=\"configuredTemplate(data.data)\">\n                        Configure\n                    </button>\n\n                </div>\n\n\n\n            </dx-data-grid>\n        </div>\n    </div>\n\n    <div #scrollContainer>\n        <div class=\"p-2\" *ngIf=\"isNewTampleteCreate\">\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\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> Create Page\n                </h6>\n\n                <!-- Flex container for form fields -->\n                <!-- <div class=\"flex flex-wrap w-full\">\n                    <div class=\"w-1/2 px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page Name</div>\n                        <dx-text-box [(ngModel)]=\"dashboardConfig.pageName\"></dx-text-box>\n                    </div>\n                    <div class=\"w-1/2 px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page Title</div>\n                        <dx-text-box [(ngModel)]=\"dashboardConfig.pageTitle\"></dx-text-box>\n                    </div>\n                    <div class=\"w-1/2 px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page URL</div>\n                        <dx-text-box [(ngModel)]=\"dashboardConfig.pageUrl\"></dx-text-box>\n                    </div>\n                    <div class=\"w-1/2 px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page Template</div>\n                        <dx-select-box [items]=\"componentTemplates\" displayExpr=\"item\" valueExpr=\"compName\"\n                            [(ngModel)]=\"dashboardConfig.pageTemplate\" searchEnabled=\"true\"></dx-select-box>\n                    </div>\n                    <div class=\"w-1/2 px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page Documentation Url</div>\n                        <dx-text-box [(ngModel)]=\"dashboardConfig.pageDocumentationUrl\"></dx-text-box>\n                    </div>\n                    <div class=\"w-1/2 px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page Filter</div>\n                        <dx-select-box [items]=\"filterDataSource\" displayExpr=\"filterName\" valueExpr=\"filterId\"\n                            [(ngModel)]=\"dashboardConfig.filterId\"></dx-select-box>\n                    </div>\n                </div> -->\n                <div class=\"grid grid-cols-2 gap-4 w-full\">\n                    <div class=\"px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page Name</div>\n                        <dx-text-box [(ngModel)]=\"dashboardConfig.pageName\"></dx-text-box>\n                    </div>\n                    <div class=\"px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page Title</div>\n                        <dx-text-box [(ngModel)]=\"dashboardConfig.pageTitle\"></dx-text-box>\n                    </div>\n                    <div class=\"px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page URL</div>\n                        <dx-text-box [(ngModel)]=\"dashboardConfig.pageUrl\"></dx-text-box>\n                    </div>\n                    <div class=\"px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page Template</div>\n                        <dx-select-box [items]=\"componentTemplates\" displayExpr=\"item\" valueExpr=\"compName\"\n                            [(ngModel)]=\"dashboardConfig.pageTemplate\" [searchEnabled]=\"true\"></dx-select-box>\n                    </div>\n                    <div class=\"px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page Documentation Url</div>\n                        <dx-text-box [(ngModel)]=\"dashboardConfig.pageDocumentationUrl\"></dx-text-box>\n                    </div>\n                    <div class=\"px-2 mb-2\">\n                        <div class=\"text-md mb-1\">Page Filter</div>\n                        <dx-select-box [items]=\"filterDataSource\" displayExpr=\"filterName\" valueExpr=\"filterId\"\n                            [(ngModel)]=\"dashboardConfig.filterId\"></dx-select-box>\n                    </div>\n                </div>\n\n                <!-- Submit button -->\n                <div class=\"flex justify-end mx-1 flex-grow\">\n                    <button class=\"{{commonService.btn_success_md}} cursor-pointer mt-2\"\n                        (click)=\"getSaveChartConfig()\">Submit Template</button>\n                </div>\n            </div>\n        </div>\n    </div>\n\n\n\n</div>"]}
|
|
@@ -5,9 +5,10 @@ import * as i1 from "@angular/router";
|
|
|
5
5
|
import * as i2 from "@angular/common";
|
|
6
6
|
import * as i3 from "devextreme-angular/core";
|
|
7
7
|
import * as i4 from "devextreme-angular/ui/popup";
|
|
8
|
-
import * as i5 from "
|
|
9
|
-
import * as i6 from "
|
|
10
|
-
import * as i7 from "../../gamma-
|
|
8
|
+
import * as i5 from "devextreme-angular/ui/select-box";
|
|
9
|
+
import * as i6 from "@angular/material/icon";
|
|
10
|
+
import * as i7 from "../../gamma-advance-filter/gamma-advance-filter.component";
|
|
11
|
+
import * as i8 from "../../gamma-bread-crumbs/bread-crumbs.component";
|
|
11
12
|
export class AppAdvanceHeaderComponent {
|
|
12
13
|
constructor(activatedRoute, route) {
|
|
13
14
|
this.activatedRoute = activatedRoute;
|
|
@@ -91,6 +92,19 @@ export class AppAdvanceHeaderComponent {
|
|
|
91
92
|
}
|
|
92
93
|
}
|
|
93
94
|
}
|
|
95
|
+
set contextFilterItems(value) {
|
|
96
|
+
if (!value) {
|
|
97
|
+
this.contextFilterItemsForFilter = value;
|
|
98
|
+
}
|
|
99
|
+
else {
|
|
100
|
+
this.contextFilterItemsForFilter = [];
|
|
101
|
+
value.forEach(element => {
|
|
102
|
+
if (element.filterType == "context") {
|
|
103
|
+
this.contextFilterItemsForFilter.push(element);
|
|
104
|
+
}
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
}
|
|
94
108
|
ngOnInit() {
|
|
95
109
|
}
|
|
96
110
|
pageAutoloadStopRun() {
|
|
@@ -178,10 +192,10 @@ export class AppAdvanceHeaderComponent {
|
|
|
178
192
|
}
|
|
179
193
|
}
|
|
180
194
|
AppAdvanceHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: AppAdvanceHeaderComponent, deps: [{ token: i1.ActivatedRoute }, { token: i1.Router }], target: i0.ɵɵFactoryTarget.Component });
|
|
181
|
-
AppAdvanceHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: AppAdvanceHeaderComponent, selector: "app-advance-header", inputs: { pageTitle: "pageTitle", bread_crumbs_container: "bread_crumbs_container", isEditButton: "isEditButton", isAdvanceButton: "isAdvanceButton", selectedDates: "selectedDates", filterItems: "filterItems" }, outputs: { toggleEvent: "toggleEvent", selectedDateRangeOrServtype: "selectedDateRangeOrServtype", getFilterPageConfig: "getFilterPageConfig" }, ngImport: i0, template: "<div class=\"flex flex-col mb-2\">\n <div class=\"flex justify-between border-b dark:bg-transparent\">\n <div class=\"flex flex-col ml-1\">\n <div class=\"flex items-center float-start\">\n <div class=\"flex items-center overflow-hidden\">\n <mat-icon class=\"icon-size-2\" [svgIcon]=\"'heroicons_solid:template'\"></mat-icon>\n </div>\n <h2\n class=\"text-2xl md:text-2xl py-3 font-extrabold items-center ml-2 tracking-tight leading-5 truncate capitalize\">\n {{ pageTitle }}\n </h2>\n </div>\n <div class=\"\">\n <!-- INCOMING -->\n <gamma-bread-crumbs [kpi_data_container]=\"bread_crumbs_container\"></gamma-bread-crumbs>\n </div>\n </div>\n <div class=\"flex justify-between items-center border-l-2 p-0 m-0\">\n\n <div class=\"mx-2\" *ngIf=\"isEditButton\">\n <div (click)=\"editKpi()\"\n class=\"bg-blue-700 cursor-pointer dark:bg-blue-600 dark:focus:ring-blue-800 dark:hover:bg-blue-700 focus:outline-none focus:ring-4 focus:ring-blue-300 font-medium hover:bg-blue-800 mr-2 px-2.5 py-2 rounded text-sm text-white ng-star-inserted\">\n Edit\n </div>\n </div>\n <div class=\"w-1 h-full border-l-2\" *ngIf=\"
|
|
195
|
+
AppAdvanceHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: AppAdvanceHeaderComponent, selector: "app-advance-header", inputs: { pageTitle: "pageTitle", bread_crumbs_container: "bread_crumbs_container", isEditButton: "isEditButton", isAdvanceButton: "isAdvanceButton", selectedDates: "selectedDates", filterItems: "filterItems", contextFilterItems: "contextFilterItems" }, outputs: { toggleEvent: "toggleEvent", selectedDateRangeOrServtype: "selectedDateRangeOrServtype", getFilterPageConfig: "getFilterPageConfig" }, ngImport: i0, template: "<div class=\"flex flex-col mb-2\">\n <div class=\"flex justify-between border-b dark:bg-transparent\">\n <div class=\"flex flex-col ml-1\">\n <div class=\"flex items-center float-start\">\n <div class=\"flex items-center overflow-hidden\">\n <mat-icon class=\"icon-size-2\" [svgIcon]=\"'heroicons_solid:template'\"></mat-icon>\n </div>\n <h2\n class=\"text-2xl md:text-2xl py-3 font-extrabold items-center ml-2 tracking-tight leading-5 truncate capitalize\">\n {{ pageTitle }}\n </h2>\n </div>\n <div class=\"\">\n <!-- INCOMING -->\n <gamma-bread-crumbs [kpi_data_container]=\"bread_crumbs_container\"></gamma-bread-crumbs>\n </div>\n </div>\n <div class=\"flex justify-between items-center border-l-2 p-0 m-0\">\n\n <div class=\"mx-2\" *ngIf=\"isEditButton\">\n <div (click)=\"editKpi()\"\n class=\"bg-blue-700 cursor-pointer dark:bg-blue-600 dark:focus:ring-blue-800 dark:hover:bg-blue-700 focus:outline-none focus:ring-4 focus:ring-blue-300 font-medium hover:bg-blue-800 mr-2 px-2.5 py-2 rounded text-sm text-white ng-star-inserted\">\n Edit\n </div>\n </div>\n <div class=\"w-1 h-full border-l-2\"></div>\n <ng-container *ngIf=\"contextFilterItemsForFilter && contextFilterItemsForFilter.length !== 0\">\n <div class=\"mx-2\">\n <dx-select-box [dataSource]=\"contextFilterItemsForFilter\" displayExpr=\"label\" value=\"defaultFilterValue\"></dx-select-box>\n </div>\n </ng-container>\n \n <div class=\"w-1 h-full border-l-2\"></div>\n <div class=\"mx-2\">\n <div class=\"cursor-pointer\" (click)=\"advanceFilterKpi()\"> {{selectedDetesforView}}</div>\n </div>\n <div class=\"w-1 h-full border-l-2\"></div>\n <div class=\"mx-2\" *ngIf=\"isAdvanceButton\">\n <button class=\"mat-focus-indicator mat-menu-trigger mat-icon-button mat-button-base\"\n aria-haspopup=\"menu\" (click)=\"advanceFilterKpi()\">\n <span class=\"mat-button-wrapper\">\n <span class=\"relative\">\n <mat-icon title=\"Filters\" [svgIcon]=\"'heroicons_outline:adjustments'\">\n </mat-icon>\n </span>\n </span>\n </button>\n </div>\n\n\n <div class=\"w-1 h-full border-l-2\"></div>\n \n\n </div>\n </div>\n</div>\n\n<dx-popup [(visible)]=\"isAdvanceFilter\" [closeOnOutsideClick]=\"false\" [dragEnabled]=\"false\" [width]=\"600\"\n [height]=\"'auto'\" [showTitle]=\"true\" class=\"popup\" title=\"Filter\">\n <div *dxTemplate=\"let data of 'content'\">\n <app-gamma-advance-filter [kpiId]=\"'231212'\" [filterOperatorData]=\"filterItemsForFilter\"\n [isButtonDesiable]=\"isAdvanceFilter\" [filterStartDate]=\"filterStartDate\" [filterEndDate]=\"filterEndDate\"\n (filterDataObject)=\"getSerchFilter($event)\"></app-gamma-advance-filter>\n </div>\n</dx-popup>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DxTemplateDirective, selector: "[dxTemplate]", inputs: ["dxTemplateOf"] }, { kind: "component", type: i4.DxPopupComponent, selector: "dx-popup", inputs: ["accessKey", "animation", "closeOnOutsideClick", "container", "contentTemplate", "copyRootClassesToWrapper", "deferRendering", "disabled", "dragAndResizeArea", "dragEnabled", "dragOutsideBoundary", "elementAttr", "focusStateEnabled", "fullScreen", "height", "hideOnOutsideClick", "hideOnParentScroll", "hint", "hoverStateEnabled", "maxHeight", "maxWidth", "minHeight", "minWidth", "position", "resizeEnabled", "restorePosition", "rtlEnabled", "shading", "shadingColor", "showCloseButton", "showTitle", "tabIndex", "title", "titleTemplate", "toolbarItems", "visible", "width", "wrapperAttr"], outputs: ["onContentReady", "onDisposing", "onHidden", "onHiding", "onInitialized", "onOptionChanged", "onResize", "onResizeEnd", "onResizeStart", "onShowing", "onShown", "onTitleRendered", "accessKeyChange", "animationChange", "closeOnOutsideClickChange", "containerChange", "contentTemplateChange", "copyRootClassesToWrapperChange", "deferRenderingChange", "disabledChange", "dragAndResizeAreaChange", "dragEnabledChange", "dragOutsideBoundaryChange", "elementAttrChange", "focusStateEnabledChange", "fullScreenChange", "heightChange", "hideOnOutsideClickChange", "hideOnParentScrollChange", "hintChange", "hoverStateEnabledChange", "maxHeightChange", "maxWidthChange", "minHeightChange", "minWidthChange", "positionChange", "resizeEnabledChange", "restorePositionChange", "rtlEnabledChange", "shadingChange", "shadingColorChange", "showCloseButtonChange", "showTitleChange", "tabIndexChange", "titleChange", "titleTemplateChange", "toolbarItemsChange", "visibleChange", "widthChange", "wrapperAttrChange"] }, { kind: "component", type: i5.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: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i7.GammaAdvanceFilterComponent, selector: "app-gamma-advance-filter", inputs: ["kpiId", "filterStartDate", "filterEndDate", "browser_api_config", "isButtonDesiable", "filterOperatorData"], outputs: ["filterDataObject"] }, { kind: "component", type: i8.BreadCrumbsComponent, selector: "gamma-bread-crumbs", inputs: ["kpi_data_container"] }] });
|
|
182
196
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: AppAdvanceHeaderComponent, decorators: [{
|
|
183
197
|
type: Component,
|
|
184
|
-
args: [{ selector: 'app-advance-header', template: "<div class=\"flex flex-col mb-2\">\n <div class=\"flex justify-between border-b dark:bg-transparent\">\n <div class=\"flex flex-col ml-1\">\n <div class=\"flex items-center float-start\">\n <div class=\"flex items-center overflow-hidden\">\n <mat-icon class=\"icon-size-2\" [svgIcon]=\"'heroicons_solid:template'\"></mat-icon>\n </div>\n <h2\n class=\"text-2xl md:text-2xl py-3 font-extrabold items-center ml-2 tracking-tight leading-5 truncate capitalize\">\n {{ pageTitle }}\n </h2>\n </div>\n <div class=\"\">\n <!-- INCOMING -->\n <gamma-bread-crumbs [kpi_data_container]=\"bread_crumbs_container\"></gamma-bread-crumbs>\n </div>\n </div>\n <div class=\"flex justify-between items-center border-l-2 p-0 m-0\">\n\n <div class=\"mx-2\" *ngIf=\"isEditButton\">\n <div (click)=\"editKpi()\"\n class=\"bg-blue-700 cursor-pointer dark:bg-blue-600 dark:focus:ring-blue-800 dark:hover:bg-blue-700 focus:outline-none focus:ring-4 focus:ring-blue-300 font-medium hover:bg-blue-800 mr-2 px-2.5 py-2 rounded text-sm text-white ng-star-inserted\">\n Edit\n </div>\n </div>\n <div class=\"w-1 h-full border-l-2\" *ngIf=\"
|
|
198
|
+
args: [{ selector: 'app-advance-header', template: "<div class=\"flex flex-col mb-2\">\n <div class=\"flex justify-between border-b dark:bg-transparent\">\n <div class=\"flex flex-col ml-1\">\n <div class=\"flex items-center float-start\">\n <div class=\"flex items-center overflow-hidden\">\n <mat-icon class=\"icon-size-2\" [svgIcon]=\"'heroicons_solid:template'\"></mat-icon>\n </div>\n <h2\n class=\"text-2xl md:text-2xl py-3 font-extrabold items-center ml-2 tracking-tight leading-5 truncate capitalize\">\n {{ pageTitle }}\n </h2>\n </div>\n <div class=\"\">\n <!-- INCOMING -->\n <gamma-bread-crumbs [kpi_data_container]=\"bread_crumbs_container\"></gamma-bread-crumbs>\n </div>\n </div>\n <div class=\"flex justify-between items-center border-l-2 p-0 m-0\">\n\n <div class=\"mx-2\" *ngIf=\"isEditButton\">\n <div (click)=\"editKpi()\"\n class=\"bg-blue-700 cursor-pointer dark:bg-blue-600 dark:focus:ring-blue-800 dark:hover:bg-blue-700 focus:outline-none focus:ring-4 focus:ring-blue-300 font-medium hover:bg-blue-800 mr-2 px-2.5 py-2 rounded text-sm text-white ng-star-inserted\">\n Edit\n </div>\n </div>\n <div class=\"w-1 h-full border-l-2\"></div>\n <ng-container *ngIf=\"contextFilterItemsForFilter && contextFilterItemsForFilter.length !== 0\">\n <div class=\"mx-2\">\n <dx-select-box [dataSource]=\"contextFilterItemsForFilter\" displayExpr=\"label\" value=\"defaultFilterValue\"></dx-select-box>\n </div>\n </ng-container>\n \n <div class=\"w-1 h-full border-l-2\"></div>\n <div class=\"mx-2\">\n <div class=\"cursor-pointer\" (click)=\"advanceFilterKpi()\"> {{selectedDetesforView}}</div>\n </div>\n <div class=\"w-1 h-full border-l-2\"></div>\n <div class=\"mx-2\" *ngIf=\"isAdvanceButton\">\n <button class=\"mat-focus-indicator mat-menu-trigger mat-icon-button mat-button-base\"\n aria-haspopup=\"menu\" (click)=\"advanceFilterKpi()\">\n <span class=\"mat-button-wrapper\">\n <span class=\"relative\">\n <mat-icon title=\"Filters\" [svgIcon]=\"'heroicons_outline:adjustments'\">\n </mat-icon>\n </span>\n </span>\n </button>\n </div>\n\n\n <div class=\"w-1 h-full border-l-2\"></div>\n \n\n </div>\n </div>\n</div>\n\n<dx-popup [(visible)]=\"isAdvanceFilter\" [closeOnOutsideClick]=\"false\" [dragEnabled]=\"false\" [width]=\"600\"\n [height]=\"'auto'\" [showTitle]=\"true\" class=\"popup\" title=\"Filter\">\n <div *dxTemplate=\"let data of 'content'\">\n <app-gamma-advance-filter [kpiId]=\"'231212'\" [filterOperatorData]=\"filterItemsForFilter\"\n [isButtonDesiable]=\"isAdvanceFilter\" [filterStartDate]=\"filterStartDate\" [filterEndDate]=\"filterEndDate\"\n (filterDataObject)=\"getSerchFilter($event)\"></app-gamma-advance-filter>\n </div>\n</dx-popup>" }]
|
|
185
199
|
}], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i1.Router }]; }, propDecorators: { pageTitle: [{
|
|
186
200
|
type: Input
|
|
187
201
|
}], bread_crumbs_container: [{
|
|
@@ -201,5 +215,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
201
215
|
}], filterItems: [{
|
|
202
216
|
type: Input,
|
|
203
217
|
args: ['filterItems']
|
|
218
|
+
}], contextFilterItems: [{
|
|
219
|
+
type: Input,
|
|
220
|
+
args: ['contextFilterItems']
|
|
204
221
|
}] } });
|
|
205
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app-header.component.js","sourceRoot":"","sources":["../../../../../../../../projects/gamma-app-controller/src/lib/application-controller/shared/advanced-component/app-advance-header/app-header.component.ts","../../../../../../../../projects/gamma-app-controller/src/lib/application-controller/shared/advanced-component/app-advance-header/app-header.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAE/E,OAAO,MAAM,MAAM,0BAA0B,CAAC;;;;;;;;;AAM9C,MAAM,OAAO,yBAAyB;IA6GlC,YACY,cAA8B,EAC9B,KAAa;QADb,mBAAc,GAAd,cAAc,CAAgB;QAC9B,UAAK,GAAL,KAAK,CAAQ;QA5GhB,iBAAY,GAAY,IAAI,CAAC;QAK5B,gBAAW,GAAyB,IAAI,YAAY,EAAU,CAAC;QASzE,oBAAe,GAAG,IAAI,CAAC;QAEvB,gBAAW,GAAG,eAAe,CAAC;QAEvB,cAAS,GAAQ,EAAE,CAAC;QACpB,sBAAiB,GAAQ;YAC5B,MAAM,EAAE,EAAE,MAAM,EAAE,YAAY,EAAE;YAChC,mBAAmB,EAAE,IAAI;YACzB,oBAAoB,EAAE,IAAI;YAC1B,MAAM,EAAE;gBACJ,KAAK,EAAE,CAAC,MAAM,EAAE,EAAE,MAAM,EAAE,CAAC;gBAE3B,cAAc,EAAE,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;gBACzD,cAAc,EAAE,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;gBACzD,cAAc,EAAE,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;gBAC1D,eAAe,EAAE,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;gBAC3D,gBAAgB,EAAE;oBACd,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC;oBAC/C,MAAM,EAAE;iBACX;gBACD,YAAY,EAAE,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;aACrE;SACJ,CAAC;QAEF,sBAAiB,GAAQ,EAAE,CAAC;QAC5B,wBAAmB,GAAQ,EAAE,CAAC;QAEb,gCAA2B,GAAsB,IAAI,YAAY,EAAE,CAAC;QACpE,wBAAmB,GAAsB,IAAI,YAAY,EAAE,CAAC;IAqE7E,CAAC;IAhED,IACI,WAAW,CAAC,KAAK;QACjB,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;YAC3C,OAAO;SACV;aAAM;YAEH,IAAI,gBAAgB,GAAG,EAAE,CAAC;YAC1B,IAAI,cAAc,GAAG,EAAE,CAAC;YACxB,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;YAClC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;gBACpB,IAAI,OAAO,CAAC,UAAU,KAAK,MAAM,IAAI,OAAO,CAAC,UAAU,KAAK,UAAU,EAAE;oBAEpE,IAAI,OAAO,CAAC,iBAAiB,KAAK,SAAS,IAAI,OAAO,CAAC,cAAc,KAAK,EAAE,IAAI,OAAO,CAAC,kBAAkB,KAAK,EAAE,IAAI,OAAO,CAAC,YAAY,KAAK,EAAE,EAAE;wBAC9I,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,OAAO,CAAC,kBAAkB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;wBAC1D,IAAI,aAAa,GAAG,MAAM,EAAE,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;wBACzG,IAAI,OAAO,CAAC,OAAO,KAAK,WAAW,EAAE;4BACjC,IAAI,OAAO,CAAC,OAAO,EAAE;gCACjB,gBAAgB,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;6BAC1D;yBACJ;wBACD,IAAI,OAAO,CAAC,OAAO,KAAK,SAAS,EAAE;4BAC/B,IAAI,OAAO,CAAC,OAAO,EAAE;gCACjB,cAAc,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;6BACxD;yBACJ;qBACJ;yBAAM,IAAI,OAAO,CAAC,iBAAiB,KAAK,QAAQ,IAAI,OAAO,CAAC,kBAAkB,KAAK,EAAE,EAAE;wBAEpF,IAAI,OAAO,CAAC,OAAO,KAAK,WAAW,EAAE;4BACjC,IAAI,OAAO,CAAC,OAAO,EAAE;gCACjB,gBAAgB,GAAG,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;6BAC/F;yBACJ;wBACD,IAAI,OAAO,CAAC,OAAO,KAAK,SAAS,EAAE;4BAC/B,IAAI,OAAO,CAAC,OAAO,EAAE;gCACjB,cAAc,GAAG,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;6BAC7F;yBACJ;qBACJ;iBACJ;YACL,CAAC,CAAC,CAAC;YAIH,IAAI,gBAAgB,IAAI,cAAc,EAAE;gBACpC,IAAI,CAAC,oBAAoB,GAAG,GAAG,gBAAgB,MAAM,cAAc,EAAE,CAAC;aACzE;iBAAM,IAAI,gBAAgB,EAAE;gBACzB,IAAI,CAAC,oBAAoB,GAAG,gBAAgB,CAAC;aAChD;iBAAM,IAAI,cAAc,EAAE;gBACvB,IAAI,CAAC,oBAAoB,GAAG,cAAc,CAAC;aAC9C;iBAAM;gBACH,IAAI,CAAC,oBAAoB,GAAG,EAAE,CAAC;aAClC;SACJ;IAGL,CAAC;IAYD,QAAQ;IAGR,CAAC;IAID,mBAAmB;QACf,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,EAAE;YAC9B,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;YAC7B,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YAChC,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;SACxB;aAAM,IAAI,IAAI,CAAC,eAAe,IAAI,KAAK,EAAE;YACtC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;YAC5B,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;SAExB;IACL,CAAC;IAED,qBAAqB;IAErB,CAAC;IAGD,6BAA6B,CAAC,IAAS;QACnC,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IAC/C,CAAC;IAGD,OAAO;QACH,MAAM,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;QAClE,IAAI,gBAAgB,GAAqB;YACrC,WAAW,EAAE;gBACT,MAAM,EAAE,MAAM;gBACd,WAAW,EAAE,MAAM;aACtB;SACJ,CAAC;QACF,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,yCAAyC,CAAC,EAAE,gBAAgB,CAAC,CAAC;IACvF,CAAC;IAGD,gBAAgB;QACZ,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;IAChC,CAAC;IAED,cAAc,CAAC,MAAM;QAEjB,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC7B,IAAI,gBAAgB,GAAG,EAAE,CAAC;QAC1B,IAAI,cAAc,GAAG,EAAE,CAAC;QAExB,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;YACxC,IAAI,OAAO,CAAC,UAAU,KAAK,MAAM,IAAI,OAAO,CAAC,UAAU,KAAK,UAAU,EAAE;gBACpE,IAAI,OAAO,CAAC,iBAAiB,KAAK,SAAS,IAAI,OAAO,CAAC,cAAc,KAAK,EAAE,IAAI,OAAO,CAAC,kBAAkB,KAAK,EAAE,IAAI,OAAO,CAAC,YAAY,KAAK,EAAE,EAAE;oBAC9I,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,OAAO,CAAC,kBAAkB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;oBAC1D,IAAI,OAAO,CAAC,OAAO,KAAK,WAAW,EAAE;wBACjC,IAAI,OAAO,CAAC,OAAO,EAAE;4BACjB,MAAM,CAAC,SAAS,GAAG,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;4BACzE,gBAAgB,GAAG,MAAM,CAAC,SAAS,CAAC;yBACvC;6BAAM;4BACH,MAAM,CAAC,SAAS,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;yBACzH;qBACJ;oBACD,IAAI,OAAO,CAAC,OAAO,KAAK,SAAS,EAAE;wBAC/B,MAAM,CAAC,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;wBACrE,IAAI,OAAO,CAAC,OAAO,EAAE;4BACjB,cAAc,GAAG,MAAM,CAAC,OAAO,CAAC;yBACnC;qBACJ;iBACJ;qBAAM,IAAI,OAAO,CAAC,iBAAiB,KAAK,QAAQ,IAAI,OAAO,CAAC,kBAAkB,KAAK,EAAE,EAAE;oBAEpF,IAAI,OAAO,CAAC,OAAO,KAAK,WAAW,EAAE;wBACjC,IAAI,OAAO,CAAC,OAAO,EAAE;4BACjB,gBAAgB,GAAG,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;4BAC5F,MAAM,CAAC,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;yBAC/F;qBACJ;oBACD,IAAI,OAAO,CAAC,OAAO,KAAK,SAAS,EAAE;wBAC/B,IAAI,OAAO,CAAC,OAAO,EAAE;4BACjB,cAAc,GAAG,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;4BAC1F,MAAM,CAAC,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;yBAC7F;qBACJ;iBACJ;aAEJ;QAEL,CAAC,CAAC,CAAC;QAEH,IAAI,gBAAgB,IAAI,cAAc,EAAE;YACpC,IAAI,CAAC,oBAAoB,GAAG,GAAG,gBAAgB,MAAM,cAAc,EAAE,CAAC;SACzE;aAAM,IAAI,gBAAgB,EAAE;YACzB,IAAI,CAAC,oBAAoB,GAAG,gBAAgB,CAAC;SAChD;aAAM,IAAI,cAAc,EAAE;YACvB,IAAI,CAAC,oBAAoB,GAAG,cAAc,CAAC;SAC9C;aAAM;YACH,IAAI,CAAC,oBAAoB,GAAG,EAAE,CAAC;SAClC;QAID,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;IACzC,CAAC;;sHA3NQ,yBAAyB;0GAAzB,yBAAyB,+ZCRtC,qnHAsEW;2FD9DE,yBAAyB;kBALrC,SAAS;+BACI,oBAAoB;0HAKrB,SAAS;sBAAjB,KAAK;gBACG,sBAAsB;sBAA9B,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBAEG,aAAa;sBAArB,KAAK;gBAEI,WAAW;sBAApB,MAAM;gBAoCU,2BAA2B;sBAA3C,MAAM;gBACU,mBAAmB;sBAAnC,MAAM;gBAMH,WAAW;sBADd,KAAK;uBAAC,aAAa","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { ActivatedRoute, NavigationExtras, Router } from '@angular/router';\nimport moment from './../../../moment-helper';\n@Component({\n    selector: 'app-advance-header',\n    templateUrl: './app-header.component.html',\n    styleUrls: ['./app-header.component.scss'],\n})\nexport class AppAdvanceHeaderComponent implements OnInit {\n    @Input() pageTitle: string;\n    @Input() bread_crumbs_container: any;\n    @Input() isEditButton: boolean = true;\n    @Input() isAdvanceButton: boolean;\n\n    @Input() selectedDates: any;\n\n    @Output() toggleEvent: EventEmitter<string> = new EventEmitter<string>();\n    isAdvanceFilter: boolean;\n    browser_config: any;\n    kpi_id: any;\n\n    filterStartDate;\n    filterEndDate;\n    filterOptions;\n\n    autoload_button = true;\n    private time_out_id;\n    toolTipText = 'By Date Range';\n\n    public daterange: any = {};\n    public daterange_options: any = {\n        locale: { format: 'YYYY-MM-DD' },\n        alwaysShowCalendars: true,\n        showCustomRangeLabel: true,\n        ranges: {\n            Today: [moment(), moment()],\n            // Yesterday: [moment().subtract(1, 'days'), moment().subtract(1, 'days')],\n            'Last 1 Month': [moment().subtract(30, 'days'), moment()],\n            'Last 3 Month': [moment().subtract(91, 'days'), moment()],\n            'Last 6 Month': [moment().subtract(182, 'days'), moment()],\n            'Last 12 Month': [moment().subtract(365, 'days'), moment()],\n            'Last 13 Months': [\n                moment().subtract(12, 'month').startOf('month'),\n                moment(),\n            ],\n            'This Month': [moment().startOf('month'), moment().endOf('month')],\n        },\n    };\n\n    srvTypeDataSource: any = [];\n    srvTypeDisplayValue: any = [];\n    selectedDetesforView: any;\n    @Output() public selectedDateRangeOrServtype: EventEmitter<any> = new EventEmitter();\n    @Output() public getFilterPageConfig: EventEmitter<any> = new EventEmitter();\n\n\n    filterItemsForFilter: any;\n\n    @Input('filterItems')\n    set filterItems(value) {\n        if (value === undefined || value.length === 0) {\n            return;\n        } else {\n\n            let displayStartDate = '';\n            let displayEndDate = '';\n            this.filterItemsForFilter = value;\n            value.forEach(element => {\n                if (element.filterType === 'date' || element.filterType === 'datetime') {\n                    \n                    if (element.defaultFilterType === \"dynamic\" && element.momentFunction !== \"\" && element.defaultFilterValue !== \"\" && element.momentFormat !== \"\") {\n                        let [count, unit] = element.defaultFilterValue.split(',');\n                        let formattedDate = moment()[element.momentFunction](parseInt(count), unit).format(element.momentFormat);\n                        if (element.apiName === \"startDate\") {\n                            if (element.display) {\n                                displayStartDate = this.selectedDates[element.apiName];\n                            }\n                        }\n                        if (element.apiName === \"endDate\") {\n                            if (element.display) {\n                                displayEndDate = this.selectedDates[element.apiName];\n                            }\n                        }\n                    } else if (element.defaultFilterType === \"static\" && element.defaultFilterValue !== \"\") {\n                       \n                        if (element.apiName === \"startDate\") {\n                            if (element.display) {\n                                displayStartDate = moment(this.selectedDates[element.apiName]).format(element.momentFormat);\n                            }\n                        }\n                        if (element.apiName === \"endDate\") {\n                            if (element.display) {\n                                displayEndDate = moment(this.selectedDates[element.apiName]).format(element.momentFormat);\n                            }\n                        }\n                    }\n                }\n            });\n\n            // this.getFilterPageConfig.emit(filter_config)\n\n            if (displayStartDate && displayEndDate) {\n                this.selectedDetesforView = `${displayStartDate} - ${displayEndDate}`;\n            } else if (displayStartDate) {\n                this.selectedDetesforView = displayStartDate;\n            } else if (displayEndDate) {\n                this.selectedDetesforView = displayEndDate;\n            } else {\n                this.selectedDetesforView = '';\n            }\n        }\n\n\n    }\n\n\n\n    constructor(\n        private activatedRoute: ActivatedRoute,\n        private route: Router,\n    ) {\n\n    }\n\n\n    ngOnInit(): void {\n\n\n    }\n\n\n\n    pageAutoloadStopRun() {\n        if (this.autoload_button == true) {\n            this.autoload_button = false;\n            clearInterval(this.time_out_id);\n            this.time_out_id = 0;\n        } else if (this.autoload_button == false) {\n            this.autoload_button = true;\n            this.time_out_id = 1;\n            // this.datesUpdated(this.selected);\n        }\n    }\n\n    callPageDocumentation() {\n\n    }\n\n\n    getDateOrServeTypeValueChange(node: any) {\n        this.selectedDateRangeOrServtype.emit(node)\n    }\n\n\n    editKpi() {\n        const pageId = this.activatedRoute.snapshot.queryParams['pageId'];\n        let navigationExtras: NavigationExtras = {\n            queryParams: {\n                pageId: pageId,\n                contentType: \"edit\"\n            },\n        };\n        this.route.navigate(['/apps/controlPanel/pageConfigController'], navigationExtras);\n    }\n\n\n    advanceFilterKpi() {\n        this.isAdvanceFilter = true;\n    }\n\n    getSerchFilter(filter) {\n\n        this.isAdvanceFilter = false;\n        let displayStartDate = '';\n        let displayEndDate = '';\n\n        this.filterItemsForFilter.forEach(element => {\n            if (element.filterType === 'date' || element.filterType === 'datetime') {\n                if (element.defaultFilterType === \"dynamic\" && element.momentFunction !== \"\" && element.defaultFilterValue !== \"\" && element.momentFormat !== \"\") {\n                    let [count, unit] = element.defaultFilterValue.split(',');\n                    if (element.apiName === \"startDate\") {\n                        if (element.display) {\n                            filter.startDate = moment(filter.startDate).format(element.momentFormat);\n                            displayStartDate = filter.startDate;\n                        } else {\n                            filter.startDate = moment(filter.endDate)[element.momentFunction](parseInt(count), unit).format(element.momentFormat);\n                        }\n                    }\n                    if (element.apiName === \"endDate\") {\n                        filter.endDate = moment(filter.endDate).format(element.momentFormat);\n                        if (element.display) {\n                            displayEndDate = filter.endDate;\n                        }\n                    }\n                } else if (element.defaultFilterType === \"static\" && element.defaultFilterValue !== \"\") {\n                       \n                    if (element.apiName === \"startDate\") {\n                        if (element.display) {\n                            displayStartDate = moment(this.selectedDates[element.apiName]).format(element.momentFormat);\n                            filter.startDate = moment(this.selectedDates[element.apiName]).format(element.momentFormat);\n                        }\n                    }\n                    if (element.apiName === \"endDate\") {\n                        if (element.display) {\n                            displayEndDate = moment(this.selectedDates[element.apiName]).format(element.momentFormat);\n                            filter.endDate = moment(this.selectedDates[element.apiName]).format(element.momentFormat);\n                        }\n                    }\n                }\n\n            }\n\n        });\n\n        if (displayStartDate && displayEndDate) {\n            this.selectedDetesforView = `${displayStartDate} - ${displayEndDate}`;\n        } else if (displayStartDate) {\n            this.selectedDetesforView = displayStartDate;\n        } else if (displayEndDate) {\n            this.selectedDetesforView = displayEndDate;\n        } else {\n            this.selectedDetesforView = '';\n        }\n\n\n\n        this.getFilterPageConfig.emit(filter)\n    }\n}\n","<div class=\"flex flex-col mb-2\">\n    <div class=\"flex justify-between border-b dark:bg-transparent\">\n        <div class=\"flex flex-col ml-1\">\n            <div class=\"flex items-center float-start\">\n                <div class=\"flex items-center overflow-hidden\">\n                    <mat-icon class=\"icon-size-2\" [svgIcon]=\"'heroicons_solid:template'\"></mat-icon>\n                </div>\n                <h2\n                    class=\"text-2xl md:text-2xl py-3 font-extrabold items-center ml-2 tracking-tight leading-5 truncate capitalize\">\n                    {{ pageTitle }}\n                </h2>\n            </div>\n            <div class=\"\">\n                <!-- INCOMING -->\n                <gamma-bread-crumbs [kpi_data_container]=\"bread_crumbs_container\"></gamma-bread-crumbs>\n            </div>\n        </div>\n        <div class=\"flex justify-between items-center border-l-2 p-0 m-0\">\n\n            <div class=\"mx-2\" *ngIf=\"isEditButton\">\n                <div (click)=\"editKpi()\"\n                    class=\"bg-blue-700 cursor-pointer dark:bg-blue-600 dark:focus:ring-blue-800 dark:hover:bg-blue-700 focus:outline-none focus:ring-4 focus:ring-blue-300 font-medium hover:bg-blue-800 mr-2 px-2.5 py-2 rounded text-sm text-white ng-star-inserted\">\n                    Edit\n                </div>\n            </div>\n            <div class=\"w-1 h-full border-l-2\" *ngIf=\"isEditButton\"></div>\n            <div class=\"mx-2\">\n                <div class=\"cursor-pointer\" (click)=\"advanceFilterKpi()\"> {{selectedDetesforView}}</div>\n            </div>\n            <div class=\"w-1 h-full border-l-2\"></div>\n            <div class=\"mx-2\" *ngIf=\"isAdvanceButton\">\n                <button class=\"mat-focus-indicator mat-menu-trigger mat-icon-button mat-button-base\"\n                    aria-haspopup=\"menu\" (click)=\"advanceFilterKpi()\">\n                    <span class=\"mat-button-wrapper\">\n                        <span class=\"relative\">\n                            <mat-icon title=\"Filters\" [svgIcon]=\"'heroicons_outline:adjustments'\">\n                            </mat-icon>\n                        </span>\n                    </span>\n                </button>\n            </div>\n\n\n            <div class=\"w-1 h-full border-l-2\"></div>\n            <!-- <div class=\"mx-2\">\n                <button class=\"mat-focus-indicator mat-menu-trigger mat-icon-button mat-button-base\"\n                    aria-haspopup=\"menu\">\n                    <span class=\"mat-button-wrapper\">\n                        <span class=\"relative\">\n                            <mat-icon (click)=\"callPageDocumentation()\" title=\"Add Filters\" [svgIcon]=\"\n                                    'heroicons_outline:question-mark-circle'\n                                \">\n                            </mat-icon>\n                        </span>\n                    </span>\n                    <span class=\"mat-button-focus-overlay\"></span>\n                </button>\n            </div> -->\n\n        </div>\n    </div>\n</div>\n\n<dx-popup [(visible)]=\"isAdvanceFilter\" [closeOnOutsideClick]=\"false\" [dragEnabled]=\"false\" [width]=\"600\"\n    [height]=\"'auto'\" [showTitle]=\"true\" class=\"popup\" title=\"Filter\">\n    <div *dxTemplate=\"let data of 'content'\">\n        <app-gamma-advance-filter [kpiId]=\"'231212'\" [filterOperatorData]=\"filterItemsForFilter\"\n            [isButtonDesiable]=\"isAdvanceFilter\" [filterStartDate]=\"filterStartDate\" [filterEndDate]=\"filterEndDate\"\n            (filterDataObject)=\"getSerchFilter($event)\"></app-gamma-advance-filter>\n    </div>\n</dx-popup>"]}
|
|
222
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app-header.component.js","sourceRoot":"","sources":["../../../../../../../../projects/gamma-app-controller/src/lib/application-controller/shared/advanced-component/app-advance-header/app-header.component.ts","../../../../../../../../projects/gamma-app-controller/src/lib/application-controller/shared/advanced-component/app-advance-header/app-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { ActivatedRoute, NavigationExtras, Router } from '@angular/router';\nimport moment from './../../../moment-helper';\n@Component({\n    selector: 'app-advance-header',\n    templateUrl: './app-header.component.html',\n    styleUrls: ['./app-header.component.scss'],\n})\nexport class AppAdvanceHeaderComponent implements OnInit {\n    @Input() pageTitle: string;\n    @Input() bread_crumbs_container: any;\n    @Input() isEditButton: boolean = true;\n    @Input() isAdvanceButton: boolean;\n\n    @Input() selectedDates: any;\n\n    @Output() toggleEvent: EventEmitter<string> = new EventEmitter<string>();\n    isAdvanceFilter: boolean;\n    browser_config: any;\n    kpi_id: any;\n\n    filterStartDate;\n    filterEndDate;\n    filterOptions;\n\n    autoload_button = true;\n    private time_out_id;\n    toolTipText = 'By Date Range';\n\n    public daterange: any = {};\n    public daterange_options: any = {\n        locale: { format: 'YYYY-MM-DD' },\n        alwaysShowCalendars: true,\n        showCustomRangeLabel: true,\n        ranges: {\n            Today: [moment(), moment()],\n            // Yesterday: [moment().subtract(1, 'days'), moment().subtract(1, 'days')],\n            'Last 1 Month': [moment().subtract(30, 'days'), moment()],\n            'Last 3 Month': [moment().subtract(91, 'days'), moment()],\n            'Last 6 Month': [moment().subtract(182, 'days'), moment()],\n            'Last 12 Month': [moment().subtract(365, 'days'), moment()],\n            'Last 13 Months': [\n                moment().subtract(12, 'month').startOf('month'),\n                moment(),\n            ],\n            'This Month': [moment().startOf('month'), moment().endOf('month')],\n        },\n    };\n\n    srvTypeDataSource: any = [];\n    srvTypeDisplayValue: any = [];\n    selectedDetesforView: any;\n    @Output() public selectedDateRangeOrServtype: EventEmitter<any> = new EventEmitter();\n    @Output() public getFilterPageConfig: EventEmitter<any> = new EventEmitter();\n\n\n    filterItemsForFilter: any;\n\n    @Input('filterItems')\n    set filterItems(value) {\n        if (value === undefined || value.length === 0) {\n            return;\n        } else {\n\n            let displayStartDate = '';\n            let displayEndDate = '';\n            this.filterItemsForFilter = value;\n            value.forEach(element => {\n                if (element.filterType === 'date' || element.filterType === 'datetime') {\n                    \n                    if (element.defaultFilterType === \"dynamic\" && element.momentFunction !== \"\" && element.defaultFilterValue !== \"\" && element.momentFormat !== \"\") {\n                        let [count, unit] = element.defaultFilterValue.split(',');\n                        let formattedDate = moment()[element.momentFunction](parseInt(count), unit).format(element.momentFormat);\n                        if (element.apiName === \"startDate\") {\n                            if (element.display) {\n                                displayStartDate = this.selectedDates[element.apiName];\n                            }\n                        }\n                        if (element.apiName === \"endDate\") {\n                            if (element.display) {\n                                displayEndDate = this.selectedDates[element.apiName];\n                            }\n                        }\n                    } else if (element.defaultFilterType === \"static\" && element.defaultFilterValue !== \"\") {\n                       \n                        if (element.apiName === \"startDate\") {\n                            if (element.display) {\n                                displayStartDate = moment(this.selectedDates[element.apiName]).format(element.momentFormat);\n                            }\n                        }\n                        if (element.apiName === \"endDate\") {\n                            if (element.display) {\n                                displayEndDate = moment(this.selectedDates[element.apiName]).format(element.momentFormat);\n                            }\n                        }\n                    }\n                }\n            });\n\n            // this.getFilterPageConfig.emit(filter_config)\n\n            if (displayStartDate && displayEndDate) {\n                this.selectedDetesforView = `${displayStartDate} - ${displayEndDate}`;\n            } else if (displayStartDate) {\n                this.selectedDetesforView = displayStartDate;\n            } else if (displayEndDate) {\n                this.selectedDetesforView = displayEndDate;\n            } else {\n                this.selectedDetesforView = '';\n            }\n        }\n\n\n    }\n\n    contextFilterItemsForFilter:any;\n    @Input('contextFilterItems')\n    set contextFilterItems(value) {\n        \n        if (!value) {\n            this.contextFilterItemsForFilter = value;\n        } else {\n            this.contextFilterItemsForFilter = [];\n            value.forEach(element=>{\n                if(element.filterType == \"context\"){\n                    this.contextFilterItemsForFilter.push(element);\n                }\n            })\n            \n        }\n\n\n    }\n\n    constructor(\n        private activatedRoute: ActivatedRoute,\n        private route: Router,\n    ) {\n\n    }\n\n\n    ngOnInit(): void {\n\n\n    }\n\n\n\n    pageAutoloadStopRun() {\n        if (this.autoload_button == true) {\n            this.autoload_button = false;\n            clearInterval(this.time_out_id);\n            this.time_out_id = 0;\n        } else if (this.autoload_button == false) {\n            this.autoload_button = true;\n            this.time_out_id = 1;\n            // this.datesUpdated(this.selected);\n        }\n    }\n\n    callPageDocumentation() {\n\n    }\n\n\n    getDateOrServeTypeValueChange(node: any) {\n        this.selectedDateRangeOrServtype.emit(node)\n    }\n\n\n    editKpi() {\n        const pageId = this.activatedRoute.snapshot.queryParams['pageId'];\n        let navigationExtras: NavigationExtras = {\n            queryParams: {\n                pageId: pageId,\n                contentType: \"edit\"\n            },\n        };\n        this.route.navigate(['/apps/controlPanel/pageConfigController'], navigationExtras);\n    }\n\n\n    advanceFilterKpi() {\n        this.isAdvanceFilter = true;\n    }\n\n    getSerchFilter(filter) {\n\n        this.isAdvanceFilter = false;\n        let displayStartDate = '';\n        let displayEndDate = '';\n\n        this.filterItemsForFilter.forEach(element => {\n            if (element.filterType === 'date' || element.filterType === 'datetime') {\n                if (element.defaultFilterType === \"dynamic\" && element.momentFunction !== \"\" && element.defaultFilterValue !== \"\" && element.momentFormat !== \"\") {\n                    let [count, unit] = element.defaultFilterValue.split(',');\n                    if (element.apiName === \"startDate\") {\n                        if (element.display) {\n                            filter.startDate = moment(filter.startDate).format(element.momentFormat);\n                            displayStartDate = filter.startDate;\n                        } else {\n                            filter.startDate = moment(filter.endDate)[element.momentFunction](parseInt(count), unit).format(element.momentFormat);\n                        }\n                    }\n                    if (element.apiName === \"endDate\") {\n                        filter.endDate = moment(filter.endDate).format(element.momentFormat);\n                        if (element.display) {\n                            displayEndDate = filter.endDate;\n                        }\n                    }\n                } else if (element.defaultFilterType === \"static\" && element.defaultFilterValue !== \"\") {\n                       \n                    if (element.apiName === \"startDate\") {\n                        if (element.display) {\n                            displayStartDate = moment(this.selectedDates[element.apiName]).format(element.momentFormat);\n                            filter.startDate = moment(this.selectedDates[element.apiName]).format(element.momentFormat);\n                        }\n                    }\n                    if (element.apiName === \"endDate\") {\n                        if (element.display) {\n                            displayEndDate = moment(this.selectedDates[element.apiName]).format(element.momentFormat);\n                            filter.endDate = moment(this.selectedDates[element.apiName]).format(element.momentFormat);\n                        }\n                    }\n                }\n\n            }\n\n        });\n\n        if (displayStartDate && displayEndDate) {\n            this.selectedDetesforView = `${displayStartDate} - ${displayEndDate}`;\n        } else if (displayStartDate) {\n            this.selectedDetesforView = displayStartDate;\n        } else if (displayEndDate) {\n            this.selectedDetesforView = displayEndDate;\n        } else {\n            this.selectedDetesforView = '';\n        }\n\n\n\n        this.getFilterPageConfig.emit(filter)\n    }\n}\n","<div class=\"flex flex-col mb-2\">\n    <div class=\"flex justify-between border-b dark:bg-transparent\">\n        <div class=\"flex flex-col ml-1\">\n            <div class=\"flex items-center float-start\">\n                <div class=\"flex items-center overflow-hidden\">\n                    <mat-icon class=\"icon-size-2\" [svgIcon]=\"'heroicons_solid:template'\"></mat-icon>\n                </div>\n                <h2\n                    class=\"text-2xl md:text-2xl py-3 font-extrabold items-center ml-2 tracking-tight leading-5 truncate capitalize\">\n                    {{ pageTitle }}\n                </h2>\n            </div>\n            <div class=\"\">\n                <!-- INCOMING -->\n                <gamma-bread-crumbs [kpi_data_container]=\"bread_crumbs_container\"></gamma-bread-crumbs>\n            </div>\n        </div>\n        <div class=\"flex justify-between items-center border-l-2 p-0 m-0\">\n\n            <div class=\"mx-2\" *ngIf=\"isEditButton\">\n                <div (click)=\"editKpi()\"\n                    class=\"bg-blue-700 cursor-pointer dark:bg-blue-600 dark:focus:ring-blue-800 dark:hover:bg-blue-700 focus:outline-none focus:ring-4 focus:ring-blue-300 font-medium hover:bg-blue-800 mr-2 px-2.5 py-2 rounded text-sm text-white ng-star-inserted\">\n                    Edit\n                </div>\n            </div>\n            <div class=\"w-1 h-full border-l-2\"></div>\n            <ng-container *ngIf=\"contextFilterItemsForFilter &&  contextFilterItemsForFilter.length !== 0\">\n                <div class=\"mx-2\">\n                    <dx-select-box [dataSource]=\"contextFilterItemsForFilter\" displayExpr=\"label\" value=\"defaultFilterValue\"></dx-select-box>\n                </div>\n            </ng-container>\n           \n            <div class=\"w-1 h-full border-l-2\"></div>\n            <div class=\"mx-2\">\n                <div class=\"cursor-pointer\" (click)=\"advanceFilterKpi()\"> {{selectedDetesforView}}</div>\n            </div>\n            <div class=\"w-1 h-full border-l-2\"></div>\n            <div class=\"mx-2\" *ngIf=\"isAdvanceButton\">\n                <button class=\"mat-focus-indicator mat-menu-trigger mat-icon-button mat-button-base\"\n                    aria-haspopup=\"menu\" (click)=\"advanceFilterKpi()\">\n                    <span class=\"mat-button-wrapper\">\n                        <span class=\"relative\">\n                            <mat-icon title=\"Filters\" [svgIcon]=\"'heroicons_outline:adjustments'\">\n                            </mat-icon>\n                        </span>\n                    </span>\n                </button>\n            </div>\n\n\n            <div class=\"w-1 h-full border-l-2\"></div>\n            \n\n        </div>\n    </div>\n</div>\n\n<dx-popup [(visible)]=\"isAdvanceFilter\" [closeOnOutsideClick]=\"false\" [dragEnabled]=\"false\" [width]=\"600\"\n    [height]=\"'auto'\" [showTitle]=\"true\" class=\"popup\" title=\"Filter\">\n    <div *dxTemplate=\"let data of 'content'\">\n        <app-gamma-advance-filter [kpiId]=\"'231212'\" [filterOperatorData]=\"filterItemsForFilter\"\n            [isButtonDesiable]=\"isAdvanceFilter\" [filterStartDate]=\"filterStartDate\" [filterEndDate]=\"filterEndDate\"\n            (filterDataObject)=\"getSerchFilter($event)\"></app-gamma-advance-filter>\n    </div>\n</dx-popup>"]}
|