@onecx/angular-accelerator 5.1.5 → 5.3.0
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/esm2022/lib/components/data-list-grid/data-list-grid.component.mjs +7 -1
- package/esm2022/lib/components/data-table/data-table.component.mjs +8 -1
- package/esm2022/lib/components/search-header/search-header.component.mjs +9 -3
- package/esm2022/lib/directives/if-permission.directive.mjs +16 -5
- package/esm2022/lib/services/breadcrumb.service.mjs +26 -11
- package/fesm2022/onecx-angular-accelerator.mjs +62 -20
- package/fesm2022/onecx-angular-accelerator.mjs.map +1 -1
- package/lib/components/data-list-grid/data-list-grid.component.d.ts +1 -0
- package/lib/components/data-table/data-table.component.d.ts +1 -0
- package/lib/components/search-header/search-header.component.d.ts +3 -1
- package/lib/directives/if-permission.directive.d.ts +7 -4
- package/lib/services/breadcrumb.service.d.ts +1 -1
- package/package.json +1 -1
|
@@ -17,6 +17,8 @@ export class SearchHeaderComponent {
|
|
|
17
17
|
this.viewMode = 'basic';
|
|
18
18
|
this.manualBreadcrumbs = false;
|
|
19
19
|
this._actions = [];
|
|
20
|
+
this.searchButtonDisabled = false;
|
|
21
|
+
this.resetButtonDisabled = false;
|
|
20
22
|
this.searched = new EventEmitter();
|
|
21
23
|
this.resetted = new EventEmitter();
|
|
22
24
|
this.selectedSearchConfigChanged = new EventEmitter();
|
|
@@ -96,11 +98,11 @@ export class SearchHeaderComponent {
|
|
|
96
98
|
this.selectedSearchConfigChanged?.emit(searchConfig);
|
|
97
99
|
}
|
|
98
100
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: SearchHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
99
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.2", type: SearchHeaderComponent, selector: "ocx-search-header", inputs: { searchConfigs: "searchConfigs", header: "header", headline: "headline", subheader: "subheader", viewMode: "viewMode", manualBreadcrumbs: "manualBreadcrumbs", actions: "actions" }, outputs: { searched: "searched", resetted: "resetted", selectedSearchConfigChanged: "selectedSearchConfigChanged", viewModeChanged: "viewModeChanged" }, queries: [{ propertyName: "additionalToolbarContent", first: true, predicate: ["additionalToolbarContent"], descendants: true }, { propertyName: "additionalToolbarContentLeft", first: true, predicate: ["additionalToolbarContentLeft"], descendants: true }], viewQueries: [{ propertyName: "searchParameterFields", first: true, predicate: ["searchParameterFields"], descendants: true }], ngImport: i0, template: "<ocx-page-header\n [header]=\"header || ('OCX_SEARCH_HEADER.HEADER' | translate)\"\n [subheader]=\"subheader\"\n [manualBreadcrumbs]=\"manualBreadcrumbs\"\n [actions]=\"headerActions\"\n>\n <ng-template #additionalToolbarContentLeft>\n <ocx-search-config [searchConfigs]=\"searchConfigs\" (selectedSearchConfigChanged)=\"confirmSearchConfig($event)\">\n </ocx-search-config>\n <ng-container
|
|
101
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.2", type: SearchHeaderComponent, selector: "ocx-search-header", inputs: { searchConfigs: "searchConfigs", header: "header", headline: "headline", subheader: "subheader", viewMode: "viewMode", manualBreadcrumbs: "manualBreadcrumbs", actions: "actions", searchButtonDisabled: "searchButtonDisabled", resetButtonDisabled: "resetButtonDisabled" }, outputs: { searched: "searched", resetted: "resetted", selectedSearchConfigChanged: "selectedSearchConfigChanged", viewModeChanged: "viewModeChanged" }, queries: [{ propertyName: "additionalToolbarContent", first: true, predicate: ["additionalToolbarContent"], descendants: true }, { propertyName: "additionalToolbarContentLeft", first: true, predicate: ["additionalToolbarContentLeft"], descendants: true }], viewQueries: [{ propertyName: "searchParameterFields", first: true, predicate: ["searchParameterFields"], descendants: true }], ngImport: i0, template: "<ocx-page-header\n [header]=\"header || ('OCX_SEARCH_HEADER.HEADER' | translate)\"\n [subheader]=\"subheader\"\n [manualBreadcrumbs]=\"manualBreadcrumbs\"\n [actions]=\"headerActions\"\n>\n <ng-template #additionalToolbarContentLeft>\n <ocx-search-config [searchConfigs]=\"searchConfigs\" (selectedSearchConfigChanged)=\"confirmSearchConfig($event)\">\n </ocx-search-config>\n <ng-container\n *ngIf=\"_additionalToolbarContentLeft\"\n [ngTemplateOutlet]=\"_additionalToolbarContentLeft\"\n ></ng-container>\n </ng-template>\n <ng-template #additionalToolbarContent>\n <ng-container *ngIf=\"_additionalToolbarContent\" [ngTemplateOutlet]=\"_additionalToolbarContent\"></ng-container>\n </ng-template>\n <div class=\"search-criteria-container\">\n <div #searchParameterFields>\n <ng-content></ng-content>\n <div class=\"search-criteria-buttons\">\n <p-button\n id=\"resetButton\"\n *ngIf=\"resetted.observed\"\n (onClick)=\"onResetClicked()\"\n label=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.TEXT' | translate }}\"\n icon=\"pi pi-eraser\"\n [attr.aria-label]=\"'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate\"\n title=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate }}\"\n [disabled]=\"resetButtonDisabled\"\n >\n </p-button>\n\n <p-button\n id=\"searchButton\"\n (onClick)=\"onSearchClicked()\"\n label=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.TEXT' | translate }}\"\n icon=\"pi pi-search\"\n [attr.aria-label]=\"'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate\"\n title=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate }}\"\n [disabled]=\"searchButtonDisabled\"\n >\n </p-button>\n </div>\n </div>\n </div>\n</ocx-page-header>\n", styles: [".search-criteria-buttons{display:flex;flex-flow:row;align-items:flex-start;gap:.5rem;margin-top:.5rem}.search-criteria-container{width:100%;display:flex}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "style", "styleClass", "badgeClass", "ariaLabel", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "component", type: i3.SearchConfigComponent, selector: "ocx-search-config", inputs: ["searchConfigs", "placeholderKey"], outputs: ["selectedSearchConfigChanged"] }, { kind: "component", type: i4.PageHeaderComponent, selector: "ocx-page-header", inputs: ["header", "loading", "figureBackground", "showFigure", "figureImage", "disableDefaultActions", "subheader", "actions", "objectDetails", "showBreadcrumbs", "manualBreadcrumbs", "enableGridView", "gridLayoutDesktopColumns"], outputs: ["save"] }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }] }); }
|
|
100
102
|
}
|
|
101
103
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: SearchHeaderComponent, decorators: [{
|
|
102
104
|
type: Component,
|
|
103
|
-
args: [{ selector: 'ocx-search-header', template: "<ocx-page-header\n [header]=\"header || ('OCX_SEARCH_HEADER.HEADER' | translate)\"\n [subheader]=\"subheader\"\n [manualBreadcrumbs]=\"manualBreadcrumbs\"\n [actions]=\"headerActions\"\n>\n <ng-template #additionalToolbarContentLeft>\n <ocx-search-config [searchConfigs]=\"searchConfigs\" (selectedSearchConfigChanged)=\"confirmSearchConfig($event)\">\n </ocx-search-config>\n <ng-container
|
|
105
|
+
args: [{ selector: 'ocx-search-header', template: "<ocx-page-header\n [header]=\"header || ('OCX_SEARCH_HEADER.HEADER' | translate)\"\n [subheader]=\"subheader\"\n [manualBreadcrumbs]=\"manualBreadcrumbs\"\n [actions]=\"headerActions\"\n>\n <ng-template #additionalToolbarContentLeft>\n <ocx-search-config [searchConfigs]=\"searchConfigs\" (selectedSearchConfigChanged)=\"confirmSearchConfig($event)\">\n </ocx-search-config>\n <ng-container\n *ngIf=\"_additionalToolbarContentLeft\"\n [ngTemplateOutlet]=\"_additionalToolbarContentLeft\"\n ></ng-container>\n </ng-template>\n <ng-template #additionalToolbarContent>\n <ng-container *ngIf=\"_additionalToolbarContent\" [ngTemplateOutlet]=\"_additionalToolbarContent\"></ng-container>\n </ng-template>\n <div class=\"search-criteria-container\">\n <div #searchParameterFields>\n <ng-content></ng-content>\n <div class=\"search-criteria-buttons\">\n <p-button\n id=\"resetButton\"\n *ngIf=\"resetted.observed\"\n (onClick)=\"onResetClicked()\"\n label=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.TEXT' | translate }}\"\n icon=\"pi pi-eraser\"\n [attr.aria-label]=\"'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate\"\n title=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate }}\"\n [disabled]=\"resetButtonDisabled\"\n >\n </p-button>\n\n <p-button\n id=\"searchButton\"\n (onClick)=\"onSearchClicked()\"\n label=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.TEXT' | translate }}\"\n icon=\"pi pi-search\"\n [attr.aria-label]=\"'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate\"\n title=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate }}\"\n [disabled]=\"searchButtonDisabled\"\n >\n </p-button>\n </div>\n </div>\n </div>\n</ocx-page-header>\n", styles: [".search-criteria-buttons{display:flex;flex-flow:row;align-items:flex-start;gap:.5rem;margin-top:.5rem}.search-criteria-container{width:100%;display:flex}\n"] }]
|
|
104
106
|
}], propDecorators: { searchConfigs: [{
|
|
105
107
|
type: Input
|
|
106
108
|
}], header: [{
|
|
@@ -115,6 +117,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
|
|
|
115
117
|
type: Input
|
|
116
118
|
}], actions: [{
|
|
117
119
|
type: Input
|
|
120
|
+
}], searchButtonDisabled: [{
|
|
121
|
+
type: Input
|
|
122
|
+
}], resetButtonDisabled: [{
|
|
123
|
+
type: Input
|
|
118
124
|
}], searched: [{
|
|
119
125
|
type: Output
|
|
120
126
|
}], resetted: [{
|
|
@@ -133,4 +139,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
|
|
|
133
139
|
type: ViewChild,
|
|
134
140
|
args: ['searchParameterFields']
|
|
135
141
|
}] } });
|
|
136
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-header.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/search-header/search-header.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/search-header/search-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ContentChild,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport { Action } from '../page-header/page-header.component'\nimport { SearchConfigInfo } from '../../model/search-config-info'\n\n/**\n * To trigger the search when Enter key is pressed inside a search parameter field,\n * an EventListener for keyup enter event is added for HTML elements which have an input.\n * Please add the EventListener yourself manually, if you want to have that functionality for some other elements\n * which do not have an input element.\n */\n@Component({\n  selector: 'ocx-search-header',\n  templateUrl: './search-header.component.html',\n  styleUrls: ['./search-header.component.scss'],\n})\nexport class SearchHeaderComponent implements AfterViewInit {\n  @Input() searchConfigs: SearchConfigInfo[] | undefined\n  @Input() header = ''\n\n  /**\n   * @deprecated Will be replaced by header\n   */\n  @Input()\n  get headline(): string {\n    return this.header\n  }\n  set headline(value: string) {\n    this.header = value\n  }\n  @Input() subheader: string | undefined\n  @Input() viewMode: 'basic' | 'advanced' = 'basic'\n  @Input() manualBreadcrumbs = false\n  _actions: Action[] = []\n  @Input()\n  get actions() {\n    return this._actions\n  }\n  set actions(value) {\n    this._actions = value\n    this.updateHeaderActions()\n  }\n\n  @Output() searched: EventEmitter<any> = new EventEmitter()\n  @Output() resetted: EventEmitter<any> = new EventEmitter()\n  @Output() selectedSearchConfigChanged: EventEmitter<SearchConfigInfo> = new EventEmitter()\n  @Output() viewModeChanged: EventEmitter<'basic' | 'advanced'> = new EventEmitter()\n  @ContentChild('additionalToolbarContent')\n  additionalToolbarContent: TemplateRef<any> | undefined\n\n  get _additionalToolbarContent(): TemplateRef<any> | undefined {\n    return this.additionalToolbarContent\n  }\n  @ContentChild('additionalToolbarContentLeft')\n  additionalToolbarContentLeft: TemplateRef<any> | undefined\n\n  get _additionalToolbarContentLeft(): TemplateRef<any> | undefined {\n    return this.additionalToolbarContentLeft\n  }\n\n  @ViewChild('searchParameterFields') searchParameterFields: ElementRef | undefined\n\n  hasAdvanced = false\n  headerActions: Action[] = []\n\n  ngAfterViewInit(): void {\n    this.addKeyUpEventListener()\n  }\n\n  toggleViewMode() {\n    this.viewMode = this.viewMode === 'basic' ? 'advanced' : 'basic'\n    this.viewModeChanged?.emit(this.viewMode)\n    this.updateHeaderActions()\n    setTimeout(() => this.addKeyUpEventListener())\n  }\n\n  onResetClicked() {\n    this.resetted.emit()\n  }\n\n  onSearchClicked() {\n    this.searched.emit()\n  }\n\n  updateHeaderActions() {\n    const headerActions: Action[] = []\n    if (this.hasAdvanced) {\n      headerActions.push({\n        id: 'simpleAdvancedButton',\n        labelKey:\n          this.viewMode === 'basic'\n            ? 'OCX_SEARCH_HEADER.TOGGLE_BUTTON.ADVANCED.TEXT'\n            : 'OCX_SEARCH_HEADER.TOGGLE_BUTTON.SIMPLE.TEXT',\n        actionCallback: () => this.toggleViewMode(),\n        show: 'always',\n        titleKey:\n          this.viewMode === 'basic'\n            ? 'OCX_SEARCH_HEADER.TOGGLE_BUTTON.ADVANCED.DETAIL'\n            : 'OCX_SEARCH_HEADER.TOGGLE_BUTTON.SIMPLE.DETAIL',\n      })\n    }\n    this.headerActions = headerActions.concat(this.actions)\n  }\n\n  addKeyUpEventListener() {\n    const inputElements = this.searchParameterFields?.nativeElement.querySelectorAll('input')\n    inputElements.forEach((inputElement: any) => {\n      if (!inputElement.listenerAdded) {\n        inputElement.addEventListener('keyup', (event: any) => this.onSearchKeyup(event))\n        inputElement.listenerAdded = true\n      }\n    })\n  }\n\n  onSearchKeyup(event: any) {\n    if (event.code === 'Enter') {\n      this.onSearchClicked()\n    }\n  }\n\n  confirmSearchConfig(searchConfig: SearchConfigInfo) {\n    this.selectedSearchConfigChanged?.emit(searchConfig)\n  }\n}\n","<ocx-page-header\n  [header]=\"header || ('OCX_SEARCH_HEADER.HEADER' | translate)\"\n  [subheader]=\"subheader\"\n  [manualBreadcrumbs]=\"manualBreadcrumbs\"\n  [actions]=\"headerActions\"\n>\n  <ng-template #additionalToolbarContentLeft>\n    <ocx-search-config [searchConfigs]=\"searchConfigs\" (selectedSearchConfigChanged)=\"confirmSearchConfig($event)\">\n    </ocx-search-config>\n    <ng-container *ngIf=\"_additionalToolbarContentLeft\" [ngTemplateOutlet]=\"_additionalToolbarContentLeft\"></ng-container>\n  </ng-template>\n  <ng-template #additionalToolbarContent>\n    <ng-container *ngIf=\"_additionalToolbarContent\" [ngTemplateOutlet]=\"_additionalToolbarContent\"></ng-container>\n  </ng-template>\n  <div class=\"search-criteria-container\">\n    <div #searchParameterFields>\n      <ng-content></ng-content>\n      <div class=\"search-criteria-buttons\">\n        <p-button\n          id=\"resetButton\"\n          *ngIf=\"resetted.observed\"\n          (onClick)=\"onResetClicked()\"\n          label=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.TEXT' | translate }}\"\n          icon=\"pi pi-eraser\"\n          [attr.aria-label]=\"'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate\"\n          title=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate }}\"\n        >\n        </p-button>\n\n        <p-button\n          id=\"searchButton\"\n          (onClick)=\"onSearchClicked()\"\n          label=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.TEXT' | translate }}\"\n          icon=\"pi pi-search\"\n          [attr.aria-label]=\"'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate\"\n          title=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate }}\"\n        >\n        </p-button>\n      </div>\n    </div>\n  </div>\n</ocx-page-header>\n"]}
|
|
142
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-header.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/search-header/search-header.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/search-header/search-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ContentChild,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport { Action } from '../page-header/page-header.component'\nimport { SearchConfigInfo } from '../../model/search-config-info'\n\n/**\n * To trigger the search when Enter key is pressed inside a search parameter field,\n * an EventListener for keyup enter event is added for HTML elements which have an input.\n * Please add the EventListener yourself manually, if you want to have that functionality for some other elements\n * which do not have an input element.\n */\n@Component({\n  selector: 'ocx-search-header',\n  templateUrl: './search-header.component.html',\n  styleUrls: ['./search-header.component.scss'],\n})\nexport class SearchHeaderComponent implements AfterViewInit {\n  @Input() searchConfigs: SearchConfigInfo[] | undefined\n  @Input() header = ''\n\n  /**\n   * @deprecated Will be replaced by header\n   */\n  @Input()\n  get headline(): string {\n    return this.header\n  }\n  set headline(value: string) {\n    this.header = value\n  }\n  @Input() subheader: string | undefined\n  @Input() viewMode: 'basic' | 'advanced' = 'basic'\n  @Input() manualBreadcrumbs = false\n  _actions: Action[] = []\n  @Input()\n  get actions() {\n    return this._actions\n  }\n  set actions(value) {\n    this._actions = value\n    this.updateHeaderActions()\n  }\n  @Input() searchButtonDisabled = false\n  @Input() resetButtonDisabled = false\n\n  @Output() searched: EventEmitter<any> = new EventEmitter()\n  @Output() resetted: EventEmitter<any> = new EventEmitter()\n  @Output() selectedSearchConfigChanged: EventEmitter<SearchConfigInfo> = new EventEmitter()\n  @Output() viewModeChanged: EventEmitter<'basic' | 'advanced'> = new EventEmitter()\n  @ContentChild('additionalToolbarContent')\n  additionalToolbarContent: TemplateRef<any> | undefined\n\n  get _additionalToolbarContent(): TemplateRef<any> | undefined {\n    return this.additionalToolbarContent\n  }\n  @ContentChild('additionalToolbarContentLeft')\n  additionalToolbarContentLeft: TemplateRef<any> | undefined\n\n  get _additionalToolbarContentLeft(): TemplateRef<any> | undefined {\n    return this.additionalToolbarContentLeft\n  }\n\n  @ViewChild('searchParameterFields') searchParameterFields: ElementRef | undefined\n\n  hasAdvanced = false\n  headerActions: Action[] = []\n\n  ngAfterViewInit(): void {\n    this.addKeyUpEventListener()\n  }\n\n  toggleViewMode() {\n    this.viewMode = this.viewMode === 'basic' ? 'advanced' : 'basic'\n    this.viewModeChanged?.emit(this.viewMode)\n    this.updateHeaderActions()\n    setTimeout(() => this.addKeyUpEventListener())\n  }\n\n  onResetClicked() {\n    this.resetted.emit()\n  }\n\n  onSearchClicked() {\n    this.searched.emit()\n  }\n\n  updateHeaderActions() {\n    const headerActions: Action[] = []\n    if (this.hasAdvanced) {\n      headerActions.push({\n        id: 'simpleAdvancedButton',\n        labelKey:\n          this.viewMode === 'basic'\n            ? 'OCX_SEARCH_HEADER.TOGGLE_BUTTON.ADVANCED.TEXT'\n            : 'OCX_SEARCH_HEADER.TOGGLE_BUTTON.SIMPLE.TEXT',\n        actionCallback: () => this.toggleViewMode(),\n        show: 'always',\n        titleKey:\n          this.viewMode === 'basic'\n            ? 'OCX_SEARCH_HEADER.TOGGLE_BUTTON.ADVANCED.DETAIL'\n            : 'OCX_SEARCH_HEADER.TOGGLE_BUTTON.SIMPLE.DETAIL',\n      })\n    }\n    this.headerActions = headerActions.concat(this.actions)\n  }\n\n  addKeyUpEventListener() {\n    const inputElements = this.searchParameterFields?.nativeElement.querySelectorAll('input')\n    inputElements.forEach((inputElement: any) => {\n      if (!inputElement.listenerAdded) {\n        inputElement.addEventListener('keyup', (event: any) => this.onSearchKeyup(event))\n        inputElement.listenerAdded = true\n      }\n    })\n  }\n\n  onSearchKeyup(event: any) {\n    if (event.code === 'Enter') {\n      this.onSearchClicked()\n    }\n  }\n\n  confirmSearchConfig(searchConfig: SearchConfigInfo) {\n    this.selectedSearchConfigChanged?.emit(searchConfig)\n  }\n}\n","<ocx-page-header\n  [header]=\"header || ('OCX_SEARCH_HEADER.HEADER' | translate)\"\n  [subheader]=\"subheader\"\n  [manualBreadcrumbs]=\"manualBreadcrumbs\"\n  [actions]=\"headerActions\"\n>\n  <ng-template #additionalToolbarContentLeft>\n    <ocx-search-config [searchConfigs]=\"searchConfigs\" (selectedSearchConfigChanged)=\"confirmSearchConfig($event)\">\n    </ocx-search-config>\n    <ng-container\n      *ngIf=\"_additionalToolbarContentLeft\"\n      [ngTemplateOutlet]=\"_additionalToolbarContentLeft\"\n    ></ng-container>\n  </ng-template>\n  <ng-template #additionalToolbarContent>\n    <ng-container *ngIf=\"_additionalToolbarContent\" [ngTemplateOutlet]=\"_additionalToolbarContent\"></ng-container>\n  </ng-template>\n  <div class=\"search-criteria-container\">\n    <div #searchParameterFields>\n      <ng-content></ng-content>\n      <div class=\"search-criteria-buttons\">\n        <p-button\n          id=\"resetButton\"\n          *ngIf=\"resetted.observed\"\n          (onClick)=\"onResetClicked()\"\n          label=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.TEXT' | translate }}\"\n          icon=\"pi pi-eraser\"\n          [attr.aria-label]=\"'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate\"\n          title=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate }}\"\n          [disabled]=\"resetButtonDisabled\"\n        >\n        </p-button>\n\n        <p-button\n          id=\"searchButton\"\n          (onClick)=\"onSearchClicked()\"\n          label=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.TEXT' | translate }}\"\n          icon=\"pi pi-search\"\n          [attr.aria-label]=\"'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate\"\n          title=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate }}\"\n          [disabled]=\"searchButtonDisabled\"\n        >\n        </p-button>\n      </div>\n    </div>\n  </div>\n</ocx-page-header>\n"]}
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import { Directive, ElementRef, Inject, InjectionToken, Input, Optional, Renderer2, TemplateRef, ViewContainerRef, } from '@angular/core';
|
|
2
|
+
import { UserService } from '@onecx/angular-integration-interface';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@onecx/angular-integration-interface";
|
|
3
5
|
/**
|
|
4
6
|
* This checker always returns true, basically disabling the permission system on the UI side
|
|
5
7
|
*/
|
|
@@ -17,14 +19,19 @@ export class IfPermissionDirective {
|
|
|
17
19
|
set ocxIfNotPermissionPermissions(value) {
|
|
18
20
|
this.ocxIfPermissionPermissions = value;
|
|
19
21
|
}
|
|
20
|
-
constructor(renderer, el, viewContainer,
|
|
22
|
+
constructor(renderer, el, viewContainer, hasPermissionChecker, templateRef, userService) {
|
|
21
23
|
this.renderer = renderer;
|
|
22
24
|
this.el = el;
|
|
23
25
|
this.viewContainer = viewContainer;
|
|
24
|
-
this.
|
|
26
|
+
this.hasPermissionChecker = hasPermissionChecker;
|
|
25
27
|
this.templateRef = templateRef;
|
|
28
|
+
this.userService = userService;
|
|
26
29
|
this.onMissingPermission = 'hide';
|
|
27
30
|
this.negate = false;
|
|
31
|
+
if (!(hasPermissionChecker || userService)) {
|
|
32
|
+
throw 'IfPermission requires UserService or HasPermissionChecker to be provided!';
|
|
33
|
+
}
|
|
34
|
+
this.permissionChecker = hasPermissionChecker ?? userService;
|
|
28
35
|
}
|
|
29
36
|
ngOnInit() {
|
|
30
37
|
if (this.permission) {
|
|
@@ -51,19 +58,23 @@ export class IfPermissionDirective {
|
|
|
51
58
|
}
|
|
52
59
|
return result;
|
|
53
60
|
}
|
|
54
|
-
return this.permissionChecker
|
|
61
|
+
return this.permissionChecker?.hasPermission(permission);
|
|
55
62
|
}
|
|
56
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: IfPermissionDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: HAS_PERMISSION_CHECKER }, { token: i0.TemplateRef, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
63
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: IfPermissionDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: HAS_PERMISSION_CHECKER, optional: true }, { token: i0.TemplateRef, optional: true }, { token: i1.UserService, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
57
64
|
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.1.2", type: IfPermissionDirective, selector: "[ocxIfPermission], [ocxIfNotPermission]", inputs: { permission: ["ocxIfPermission", "permission"], notPermission: ["ocxIfNotPermission", "notPermission"], onMissingPermission: "onMissingPermission", ocxIfPermissionPermissions: "ocxIfPermissionPermissions", ocxIfNotPermissionPermissions: "ocxIfNotPermissionPermissions" }, ngImport: i0 }); }
|
|
58
65
|
}
|
|
59
66
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: IfPermissionDirective, decorators: [{
|
|
60
67
|
type: Directive,
|
|
61
68
|
args: [{ selector: '[ocxIfPermission], [ocxIfNotPermission]' }]
|
|
62
69
|
}], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: undefined, decorators: [{
|
|
70
|
+
type: Optional
|
|
71
|
+
}, {
|
|
63
72
|
type: Inject,
|
|
64
73
|
args: [HAS_PERMISSION_CHECKER]
|
|
65
74
|
}] }, { type: i0.TemplateRef, decorators: [{
|
|
66
75
|
type: Optional
|
|
76
|
+
}] }, { type: i1.UserService, decorators: [{
|
|
77
|
+
type: Optional
|
|
67
78
|
}] }], propDecorators: { permission: [{
|
|
68
79
|
type: Input,
|
|
69
80
|
args: ['ocxIfPermission']
|
|
@@ -77,4 +88,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
|
|
|
77
88
|
}], ocxIfNotPermissionPermissions: [{
|
|
78
89
|
type: Input
|
|
79
90
|
}] } });
|
|
80
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWYtcGVybWlzc2lvbi5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItYWNjZWxlcmF0b3Ivc3JjL2xpYi9kaXJlY3RpdmVzL2lmLXBlcm1pc3Npb24uZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxTQUFTLEVBQ1QsVUFBVSxFQUNWLE1BQU0sRUFDTixjQUFjLEVBQ2QsS0FBSyxFQUVMLFFBQVEsRUFDUixTQUFTLEVBQ1QsV0FBVyxFQUNYLGdCQUFnQixHQUNqQixNQUFNLGVBQWUsQ0FBQTtBQUN0QixPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sc0NBQXNDLENBQUE7OztBQU1sRTs7R0FFRztBQUNILE1BQU0sT0FBTyw0QkFBNEI7SUFDdkMsYUFBYSxDQUFDLGNBQXNCO1FBQ2xDLE9BQU8sSUFBSSxDQUFBO0lBQ2IsQ0FBQztDQUNGO0FBRUQsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsSUFBSSxjQUFjLENBQXVCLGVBQWUsQ0FBQyxDQUFBO0FBRy9GLE1BQU0sT0FBTyxxQkFBcUI7SUFFaEMsSUFBaUMsYUFBYSxDQUFDLEtBQXlCO1FBQ3RFLElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFBO1FBQ3ZCLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFBO0lBQ3BCLENBQUM7SUFLRCxJQUNJLDZCQUE2QixDQUFDLEtBQTJCO1FBQzNELElBQUksQ0FBQywwQkFBMEIsR0FBRyxLQUFLLENBQUE7SUFDekMsQ0FBQztJQUtELFlBQ1UsUUFBbUIsRUFDbkIsRUFBYyxFQUNkLGFBQStCLEVBRy9CLG9CQUEyQyxFQUMvQixXQUE4QixFQUM5QixXQUF5QjtRQVByQyxhQUFRLEdBQVIsUUFBUSxDQUFXO1FBQ25CLE9BQUUsR0FBRixFQUFFLENBQVk7UUFDZCxrQkFBYSxHQUFiLGFBQWEsQ0FBa0I7UUFHL0IseUJBQW9CLEdBQXBCLG9CQUFvQixDQUF1QjtRQUMvQixnQkFBVyxHQUFYLFdBQVcsQ0FBbUI7UUFDOUIsZ0JBQVcsR0FBWCxXQUFXLENBQWM7UUFuQnRDLHdCQUFtQixHQUF1QixNQUFNLENBQUE7UUFTekQsV0FBTSxHQUFHLEtBQUssQ0FBQTtRQVlaLElBQUksQ0FBQyxDQUFDLG9CQUFvQixJQUFJLFdBQVcsQ0FBQyxFQUFFLENBQUM7WUFDM0MsTUFBTSwyRUFBMkUsQ0FBQTtRQUNuRixDQUFDO1FBRUQsSUFBSSxDQUFDLGlCQUFpQixHQUFHLG9CQUFvQixJQUFJLFdBQVcsQ0FBQTtJQUM5RCxDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ3BCLElBQUksSUFBSSxDQUFDLE1BQU0sS0FBSyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsRUFBRSxDQUFDO2dCQUN4RCxJQUFJLElBQUksQ0FBQyxtQkFBbUIsS0FBSyxTQUFTLEVBQUUsQ0FBQztvQkFDM0MsSUFBSSxDQUFDLFFBQVEsQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLEVBQUUsVUFBVSxFQUFFLFVBQVUsQ0FBQyxDQUFBO2dCQUMzRSxDQUFDO3FCQUFNLENBQUM7b0JBQ04sSUFBSSxDQUFDLGFBQWEsQ0FBQyxLQUFLLEVBQUUsQ0FBQTtnQkFDNUIsQ0FBQztZQUNILENBQUM7aUJBQU0sQ0FBQztnQkFDTixJQUFJLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztvQkFDckIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUE7Z0JBQ3pELENBQUM7WUFDSCxDQUFDO1FBQ0gsQ0FBQztJQUNILENBQUM7SUFFRCxhQUFhLENBQUMsVUFBa0I7UUFDOUIsSUFBSSxJQUFJLENBQUMsMEJBQTBCLEVBQUUsQ0FBQztZQUNwQyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsMEJBQTBCLENBQUMsUUFBUSxDQUFDLFVBQVUsQ0FBQyxDQUFBO1lBQ25FLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztnQkFDWixPQUFPLENBQUMsR0FBRyxDQUFDLDBDQUEwQyxFQUFFLFVBQVUsQ0FBQyxDQUFBO1lBQ3JFLENBQUM7WUFDRCxPQUFPLE1BQU0sQ0FBQTtRQUNmLENBQUM7UUFDRCxPQUFPLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxhQUFhLENBQUMsVUFBVSxDQUFDLENBQUE7SUFDMUQsQ0FBQzs4R0E1RFUscUJBQXFCLHFHQXVCdEIsc0JBQXNCO2tHQXZCckIscUJBQXFCOzsyRkFBckIscUJBQXFCO2tCQURqQyxTQUFTO21CQUFDLEVBQUUsUUFBUSxFQUFFLHlDQUF5QyxFQUFFOzswQkF1QjdELFFBQVE7OzBCQUNSLE1BQU07MkJBQUMsc0JBQXNCOzswQkFFN0IsUUFBUTs7MEJBQ1IsUUFBUTt5Q0F6QmUsVUFBVTtzQkFBbkMsS0FBSzt1QkFBQyxpQkFBaUI7Z0JBQ1MsYUFBYTtzQkFBN0MsS0FBSzt1QkFBQyxvQkFBb0I7Z0JBS2xCLG1CQUFtQjtzQkFBM0IsS0FBSztnQkFFRywwQkFBMEI7c0JBQWxDLEtBQUs7Z0JBRUYsNkJBQTZCO3NCQURoQyxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgRGlyZWN0aXZlLFxuICBFbGVtZW50UmVmLFxuICBJbmplY3QsXG4gIEluamVjdGlvblRva2VuLFxuICBJbnB1dCxcbiAgT25Jbml0LFxuICBPcHRpb25hbCxcbiAgUmVuZGVyZXIyLFxuICBUZW1wbGF0ZVJlZixcbiAgVmlld0NvbnRhaW5lclJlZixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IFVzZXJTZXJ2aWNlIH0gZnJvbSAnQG9uZWN4L2FuZ3VsYXItaW50ZWdyYXRpb24taW50ZXJmYWNlJ1xuXG5leHBvcnQgaW50ZXJmYWNlIEhhc1Blcm1pc3Npb25DaGVja2VyIHtcbiAgaGFzUGVybWlzc2lvbihwZXJtaXNzaW9uS2V5OiBzdHJpbmcpOiBib29sZWFuXG59XG5cbi8qKlxuICogVGhpcyBjaGVja2VyIGFsd2F5cyByZXR1cm5zIHRydWUsIGJhc2ljYWxseSBkaXNhYmxpbmcgdGhlIHBlcm1pc3Npb24gc3lzdGVtIG9uIHRoZSBVSSBzaWRlXG4gKi9cbmV4cG9ydCBjbGFzcyBBbHdheXNHcmFudFBlcm1pc3Npb25DaGVja2VyIGltcGxlbWVudHMgSGFzUGVybWlzc2lvbkNoZWNrZXIge1xuICBoYXNQZXJtaXNzaW9uKF9wZXJtaXNzaW9uS2V5OiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdHJ1ZVxuICB9XG59XG5cbmV4cG9ydCBjb25zdCBIQVNfUEVSTUlTU0lPTl9DSEVDS0VSID0gbmV3IEluamVjdGlvblRva2VuPEhhc1Blcm1pc3Npb25DaGVja2VyPignaGFzUGVybWlzc2lvbicpXG5cbkBEaXJlY3RpdmUoeyBzZWxlY3RvcjogJ1tvY3hJZlBlcm1pc3Npb25dLCBbb2N4SWZOb3RQZXJtaXNzaW9uXScgfSlcbmV4cG9ydCBjbGFzcyBJZlBlcm1pc3Npb25EaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoJ29jeElmUGVybWlzc2lvbicpIHBlcm1pc3Npb246IHN0cmluZyB8IHVuZGVmaW5lZFxuICBASW5wdXQoJ29jeElmTm90UGVybWlzc2lvbicpIHNldCBub3RQZXJtaXNzaW9uKHZhbHVlOiBzdHJpbmcgfCB1bmRlZmluZWQpIHtcbiAgICB0aGlzLnBlcm1pc3Npb24gPSB2YWx1ZVxuICAgIHRoaXMubmVnYXRlID0gdHJ1ZVxuICB9XG5cbiAgQElucHV0KCkgb25NaXNzaW5nUGVybWlzc2lvbjogJ2hpZGUnIHwgJ2Rpc2FibGUnID0gJ2hpZGUnXG5cbiAgQElucHV0KCkgb2N4SWZQZXJtaXNzaW9uUGVybWlzc2lvbnM6IHN0cmluZ1tdIHwgdW5kZWZpbmVkXG4gIEBJbnB1dCgpXG4gIHNldCBvY3hJZk5vdFBlcm1pc3Npb25QZXJtaXNzaW9ucyh2YWx1ZTogc3RyaW5nW10gfCB1bmRlZmluZWQpIHtcbiAgICB0aGlzLm9jeElmUGVybWlzc2lvblBlcm1pc3Npb25zID0gdmFsdWVcbiAgfVxuXG4gIHByaXZhdGUgcGVybWlzc2lvbkNoZWNrZXI6IEhhc1Blcm1pc3Npb25DaGVja2VyIHwgdW5kZWZpbmVkXG4gIG5lZ2F0ZSA9IGZhbHNlXG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSByZW5kZXJlcjogUmVuZGVyZXIyLFxuICAgIHByaXZhdGUgZWw6IEVsZW1lbnRSZWYsXG4gICAgcHJpdmF0ZSB2aWV3Q29udGFpbmVyOiBWaWV3Q29udGFpbmVyUmVmLFxuICAgIEBPcHRpb25hbCgpXG4gICAgQEluamVjdChIQVNfUEVSTUlTU0lPTl9DSEVDS0VSKVxuICAgIHByaXZhdGUgaGFzUGVybWlzc2lvbkNoZWNrZXI/OiBIYXNQZXJtaXNzaW9uQ2hlY2tlcixcbiAgICBAT3B0aW9uYWwoKSBwcml2YXRlIHRlbXBsYXRlUmVmPzogVGVtcGxhdGVSZWY8YW55PixcbiAgICBAT3B0aW9uYWwoKSBwcml2YXRlIHVzZXJTZXJ2aWNlPzogVXNlclNlcnZpY2VcbiAgKSB7XG4gICAgaWYgKCEoaGFzUGVybWlzc2lvbkNoZWNrZXIgfHwgdXNlclNlcnZpY2UpKSB7XG4gICAgICB0aHJvdyAnSWZQZXJtaXNzaW9uIHJlcXVpcmVzIFVzZXJTZXJ2aWNlIG9yIEhhc1Blcm1pc3Npb25DaGVja2VyIHRvIGJlIHByb3ZpZGVkISdcbiAgICB9XG5cbiAgICB0aGlzLnBlcm1pc3Npb25DaGVja2VyID0gaGFzUGVybWlzc2lvbkNoZWNrZXIgPz8gdXNlclNlcnZpY2VcbiAgfVxuXG4gIG5nT25Jbml0KCkge1xuICAgIGlmICh0aGlzLnBlcm1pc3Npb24pIHtcbiAgICAgIGlmICh0aGlzLm5lZ2F0ZSA9PT0gdGhpcy5oYXNQZXJtaXNzaW9uKHRoaXMucGVybWlzc2lvbikpIHtcbiAgICAgICAgaWYgKHRoaXMub25NaXNzaW5nUGVybWlzc2lvbiA9PT0gJ2Rpc2FibGUnKSB7XG4gICAgICAgICAgdGhpcy5yZW5kZXJlci5zZXRBdHRyaWJ1dGUodGhpcy5lbC5uYXRpdmVFbGVtZW50LCAnZGlzYWJsZWQnLCAnZGlzYWJsZWQnKVxuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHRoaXMudmlld0NvbnRhaW5lci5jbGVhcigpXG4gICAgICAgIH1cbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGlmICh0aGlzLnRlbXBsYXRlUmVmKSB7XG4gICAgICAgICAgdGhpcy52aWV3Q29udGFpbmVyLmNyZWF0ZUVtYmVkZGVkVmlldyh0aGlzLnRlbXBsYXRlUmVmKVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgaGFzUGVybWlzc2lvbihwZXJtaXNzaW9uOiBzdHJpbmcpIHtcbiAgICBpZiAodGhpcy5vY3hJZlBlcm1pc3Npb25QZXJtaXNzaW9ucykge1xuICAgICAgY29uc3QgcmVzdWx0ID0gdGhpcy5vY3hJZlBlcm1pc3Npb25QZXJtaXNzaW9ucy5pbmNsdWRlcyhwZXJtaXNzaW9uKVxuICAgICAgaWYgKCFyZXN1bHQpIHtcbiAgICAgICAgY29uc29sZS5sb2coJ/Cfka7igI3imYDvuI8gTm8gcGVybWlzc2lvbiBpbiBvdmVyd3JpdGVzIGZvcjogYCcsIHBlcm1pc3Npb24pXG4gICAgICB9XG4gICAgICByZXR1cm4gcmVzdWx0XG4gICAgfVxuICAgIHJldHVybiB0aGlzLnBlcm1pc3Npb25DaGVja2VyPy5oYXNQZXJtaXNzaW9uKHBlcm1pc3Npb24pXG4gIH1cbn1cbiJdfQ==
|
|
@@ -3,18 +3,27 @@ import { Injectable } from '@angular/core';
|
|
|
3
3
|
import { ActivatedRoute, NavigationEnd, Router } from '@angular/router';
|
|
4
4
|
import { TranslateService } from '@ngx-translate/core';
|
|
5
5
|
import { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';
|
|
6
|
-
import { BehaviorSubject, filter } from 'rxjs';
|
|
6
|
+
import { BehaviorSubject, filter, map } from 'rxjs';
|
|
7
|
+
import { SyncableTopic } from '@onecx/accelerator';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
9
|
import * as i1 from "@angular/router";
|
|
9
10
|
import * as i2 from "@ngx-translate/core";
|
|
11
|
+
// This topic is defined here and not in integration-interface, because
|
|
12
|
+
// it is not used as framework independent integration but for improving
|
|
13
|
+
// angular specific things
|
|
14
|
+
class ManualBreadcrumbsTopic extends SyncableTopic {
|
|
15
|
+
constructor() {
|
|
16
|
+
super('manualBreadcrumbs', 1);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
10
19
|
let BreadcrumbService = class BreadcrumbService {
|
|
11
20
|
constructor(router, activeRoute, translateService) {
|
|
12
21
|
this.router = router;
|
|
13
22
|
this.activeRoute = activeRoute;
|
|
14
23
|
this.translateService = translateService;
|
|
15
|
-
this.itemsSource = new
|
|
24
|
+
this.itemsSource$ = new ManualBreadcrumbsTopic();
|
|
16
25
|
this.generatedItemsSource = new BehaviorSubject([]);
|
|
17
|
-
this.itemsHandler = this.itemsSource
|
|
26
|
+
this.itemsHandler = this.itemsSource$.pipe(map((manualBreadcrumbs) => manualBreadcrumbs.menuItems));
|
|
18
27
|
this.generateBreadcrumbs(this.activeRoute.snapshot);
|
|
19
28
|
this.router.events
|
|
20
29
|
.pipe(untilDestroyed(this), filter((e) => e instanceof NavigationEnd))
|
|
@@ -87,15 +96,19 @@ let BreadcrumbService = class BreadcrumbService {
|
|
|
87
96
|
];
|
|
88
97
|
if (translationKeys.length) {
|
|
89
98
|
this.translateService.get(translationKeys).subscribe((translations) => {
|
|
90
|
-
this.itemsSource
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
99
|
+
this.itemsSource$.publish({
|
|
100
|
+
menuItems: items.map((i) => ({
|
|
101
|
+
...i,
|
|
102
|
+
label: translations[i.labelKey || ''] || i.label,
|
|
103
|
+
title: translations[i.titleKey || ''] || i.title,
|
|
104
|
+
})),
|
|
105
|
+
});
|
|
95
106
|
});
|
|
96
107
|
}
|
|
97
108
|
else {
|
|
98
|
-
this.itemsSource
|
|
109
|
+
this.itemsSource$.publish({
|
|
110
|
+
menuItems: items,
|
|
111
|
+
});
|
|
99
112
|
}
|
|
100
113
|
}
|
|
101
114
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: BreadcrumbService, deps: [{ token: i1.Router }, { token: i1.ActivatedRoute }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
@@ -103,11 +116,13 @@ let BreadcrumbService = class BreadcrumbService {
|
|
|
103
116
|
};
|
|
104
117
|
BreadcrumbService = __decorate([
|
|
105
118
|
UntilDestroy(),
|
|
106
|
-
__metadata("design:paramtypes", [Router,
|
|
119
|
+
__metadata("design:paramtypes", [Router,
|
|
120
|
+
ActivatedRoute,
|
|
121
|
+
TranslateService])
|
|
107
122
|
], BreadcrumbService);
|
|
108
123
|
export { BreadcrumbService };
|
|
109
124
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: BreadcrumbService, decorators: [{
|
|
110
125
|
type: Injectable,
|
|
111
126
|
args: [{ providedIn: 'any' }]
|
|
112
127
|
}], ctorParameters: () => [{ type: i1.Router }, { type: i1.ActivatedRoute }, { type: i2.TranslateService }] });
|
|
113
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"breadcrumb.service.js","sourceRoot":"","sources":["../../../../../../libs/angular-accelerator/src/lib/services/breadcrumb.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core'\nimport { ActivatedRoute, ActivatedRouteSnapshot, Data, NavigationEnd, ParamMap, Router } from '@angular/router'\nimport { TranslateService } from '@ngx-translate/core'\nimport { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy'\nimport { BehaviorSubject, filter } from 'rxjs'\nimport { MenuItem } from 'primeng/api'\nimport { BreadCrumbMenuItem } from '../model/breadcrumb-menu-item.model'\n\n@Injectable({ providedIn: 'any' })\n@UntilDestroy()\nexport class BreadcrumbService {\n  private itemsSource = new BehaviorSubject<MenuItem[]>([])\n  generatedItemsSource = new BehaviorSubject<MenuItem[]>([])\n\n  itemsHandler = this.itemsSource.asObservable()\n\n  constructor(private router: Router, private activeRoute: ActivatedRoute, private translateService: TranslateService) {\n    this.generateBreadcrumbs(this.activeRoute.snapshot)\n    this.router.events\n      .pipe(\n        untilDestroyed(this),\n        filter((e) => e instanceof NavigationEnd)\n      )\n      .subscribe(() => {\n        const root = this.router.routerState.snapshot.root\n        this.generateBreadcrumbs(root)\n      })\n  }\n\n  private generateBreadcrumbs(route: ActivatedRouteSnapshot | null) {\n    if (route?.data['mfeInfo']) {\n      const breadcrumbs: MenuItem[] = [\n        {\n          label: route.data['mfeInfo'].productName,\n          routerLink: route.data['mfeInfo'].baseHref,\n        },\n      ]\n      const baseUrl: string[] = (route.data['mfeInfo'].baseHref as string).split('/').filter((value) => value)\n      const parentUrl: string[] = route.url.map((url) => url.path)\n      const isUsingMatcher = !parentUrl.every((item) => baseUrl.includes(item))\n      if (isUsingMatcher) {\n        this.createBreadcrumb(route, parentUrl, breadcrumbs)\n      }\n      this.addBreadcrumb(route.firstChild, parentUrl, breadcrumbs)\n      this.generatedItemsSource.next(breadcrumbs)\n    } else if (route?.data['breadcrumb']) {\n      const breadcrumbs: MenuItem[] = []\n      this.addBreadcrumb(route, [], breadcrumbs)\n      this.generatedItemsSource.next(breadcrumbs)\n    } else if (route) {\n      this.generateBreadcrumbs(route.firstChild)\n    }\n  }\n\n  private addBreadcrumb(route: ActivatedRouteSnapshot | null, parentUrl: string[], breadcrumbs: MenuItem[]) {\n    if (route && route.url) {\n      const routeUrl = parentUrl.concat(route.url.map((url) => url.path))\n      if (route.routeConfig?.path) {\n        this.createBreadcrumb(route, routeUrl, breadcrumbs)\n      }\n\n      this.addBreadcrumb(route.firstChild, routeUrl, breadcrumbs)\n    }\n  }\n\n  private createBreadcrumb(route: ActivatedRouteSnapshot, routeUrl: string[], breadcrumbs: MenuItem[]) {\n    if (route.data['breadcrumb']) {\n      const breadcrumb: MenuItem = {\n        label: this.getLabel(route.data, route.paramMap),\n        routerLink: '/' + routeUrl.join('/'),\n      }\n      breadcrumbs.push(breadcrumb)\n    } else {\n      const breadcrumb: MenuItem = {\n        label: 'NA',\n        routerLink: '/' + routeUrl.join('/'),\n      }\n      breadcrumbs.push(breadcrumb)\n    }\n  }\n\n  private getLabel(data: Data, params: ParamMap) {\n    if (typeof data['breadcrumbFn'] === 'function') {\n      return data['breadcrumbFn'](data, params)\n    }\n    return data['breadcrumb']\n  }\n\n  setItems(items: BreadCrumbMenuItem[]) {\n    const translationKeys = [\n      ...items.map((i) => i.labelKey || '').filter((l) => !!l),\n      ...items.map((i) => i.titleKey || '').filter((l) => !!l),\n    ]\n    if (translationKeys.length) {\n      this.translateService.get(translationKeys).subscribe((translations: any) => {\n        this.itemsSource.next(\n          items.map((i) => ({\n            ...i,\n            label: translations[i.labelKey || ''] || i.label,\n            title: translations[i.titleKey || ''] || i.title,\n          }))\n        )\n      })\n    } else {\n      this.itemsSource.next(items)\n    }\n  }\n}\n"]}
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"breadcrumb.service.js","sourceRoot":"","sources":["../../../../../../libs/angular-accelerator/src/lib/services/breadcrumb.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core'\nimport { ActivatedRoute, ActivatedRouteSnapshot, Data, NavigationEnd, ParamMap, Router } from '@angular/router'\nimport { TranslateService } from '@ngx-translate/core'\nimport { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy'\nimport { BehaviorSubject, filter, map } from 'rxjs'\nimport { MenuItem } from 'primeng/api'\nimport { BreadCrumbMenuItem } from '../model/breadcrumb-menu-item.model'\nimport { SyncableTopic } from '@onecx/accelerator'\n\ninterface ManualBreadcrumbs {\n  menuItems: MenuItem[]\n}\n\n// This topic is defined here and not in integration-interface, because\n// it is not used as framework independent integration but for improving\n// angular specific things\nclass ManualBreadcrumbsTopic extends SyncableTopic<ManualBreadcrumbs> {\n  constructor() {\n    super('manualBreadcrumbs', 1)\n  }\n}\n\n@Injectable({ providedIn: 'any' })\n@UntilDestroy()\nexport class BreadcrumbService {\n  private itemsSource$ = new ManualBreadcrumbsTopic()\n  generatedItemsSource = new BehaviorSubject<MenuItem[]>([])\n\n  itemsHandler = this.itemsSource$.pipe(map((manualBreadcrumbs) => manualBreadcrumbs.menuItems))\n\n  constructor(\n    private router: Router,\n    private activeRoute: ActivatedRoute,\n    private translateService: TranslateService\n  ) {\n    this.generateBreadcrumbs(this.activeRoute.snapshot)\n    this.router.events\n      .pipe(\n        untilDestroyed(this),\n        filter((e) => e instanceof NavigationEnd)\n      )\n      .subscribe(() => {\n        const root = this.router.routerState.snapshot.root\n        this.generateBreadcrumbs(root)\n      })\n  }\n\n  private generateBreadcrumbs(route: ActivatedRouteSnapshot | null) {\n    if (route?.data['mfeInfo']) {\n      const breadcrumbs: MenuItem[] = [\n        {\n          label: route.data['mfeInfo'].productName,\n          routerLink: route.data['mfeInfo'].baseHref,\n        },\n      ]\n      const baseUrl: string[] = (route.data['mfeInfo'].baseHref as string).split('/').filter((value) => value)\n      const parentUrl: string[] = route.url.map((url) => url.path)\n      const isUsingMatcher = !parentUrl.every((item) => baseUrl.includes(item))\n      if (isUsingMatcher) {\n        this.createBreadcrumb(route, parentUrl, breadcrumbs)\n      }\n      this.addBreadcrumb(route.firstChild, parentUrl, breadcrumbs)\n      this.generatedItemsSource.next(breadcrumbs)\n    } else if (route?.data['breadcrumb']) {\n      const breadcrumbs: MenuItem[] = []\n      this.addBreadcrumb(route, [], breadcrumbs)\n      this.generatedItemsSource.next(breadcrumbs)\n    } else if (route) {\n      this.generateBreadcrumbs(route.firstChild)\n    }\n  }\n\n  private addBreadcrumb(route: ActivatedRouteSnapshot | null, parentUrl: string[], breadcrumbs: MenuItem[]) {\n    if (route && route.url) {\n      const routeUrl = parentUrl.concat(route.url.map((url) => url.path))\n      if (route.routeConfig?.path) {\n        this.createBreadcrumb(route, routeUrl, breadcrumbs)\n      }\n\n      this.addBreadcrumb(route.firstChild, routeUrl, breadcrumbs)\n    }\n  }\n\n  private createBreadcrumb(route: ActivatedRouteSnapshot, routeUrl: string[], breadcrumbs: MenuItem[]) {\n    if (route.data['breadcrumb']) {\n      const breadcrumb: MenuItem = {\n        label: this.getLabel(route.data, route.paramMap),\n        routerLink: '/' + routeUrl.join('/'),\n      }\n      breadcrumbs.push(breadcrumb)\n    } else {\n      const breadcrumb: MenuItem = {\n        label: 'NA',\n        routerLink: '/' + routeUrl.join('/'),\n      }\n      breadcrumbs.push(breadcrumb)\n    }\n  }\n\n  private getLabel(data: Data, params: ParamMap) {\n    if (typeof data['breadcrumbFn'] === 'function') {\n      return data['breadcrumbFn'](data, params)\n    }\n    return data['breadcrumb']\n  }\n\n  setItems(items: BreadCrumbMenuItem[]) {\n    const translationKeys = [\n      ...items.map((i) => i.labelKey || '').filter((l) => !!l),\n      ...items.map((i) => i.titleKey || '').filter((l) => !!l),\n    ]\n    if (translationKeys.length) {\n      this.translateService.get(translationKeys).subscribe((translations: any) => {\n        this.itemsSource$.publish({\n          menuItems: items.map((i) => ({\n            ...i,\n            label: translations[i.labelKey || ''] || i.label,\n            title: translations[i.titleKey || ''] || i.title,\n          })),\n        })\n      })\n    } else {\n      this.itemsSource$.publish({\n        menuItems: items,\n      })\n    }\n  }\n}\n"]}
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { InjectionToken, Directive,
|
|
2
|
+
import { InjectionToken, Directive, Optional, Inject, Input, HostListener, EventEmitter, Output, Component, Injectable, Injector, LOCALE_ID, Pipe, ViewEncapsulation, ContentChild, ViewChild, NgModule, APP_INITIALIZER, inject } from '@angular/core';
|
|
3
|
+
import * as i3 from '@onecx/angular-integration-interface';
|
|
4
|
+
import { UserService } from '@onecx/angular-integration-interface';
|
|
3
5
|
import * as i1 from '@angular/common/http';
|
|
4
6
|
import * as i4 from '@angular/common';
|
|
5
7
|
import { CurrencyPipe, DecimalPipe, DatePipe, Location, CommonModule } from '@angular/common';
|
|
@@ -13,13 +15,12 @@ import * as i1$1 from '@ngx-translate/core';
|
|
|
13
15
|
import { TranslateService, TranslatePipe, TranslateModule } from '@ngx-translate/core';
|
|
14
16
|
import * as i2$1 from 'primeng/api';
|
|
15
17
|
import { PrimeIcons } from 'primeng/api';
|
|
16
|
-
import { BehaviorSubject, filter, concat, of,
|
|
17
|
-
import * as i3 from '@onecx/angular-integration-interface';
|
|
18
|
-
import { UserService } from '@onecx/angular-integration-interface';
|
|
18
|
+
import { BehaviorSubject, map, filter, concat, of, combineLatest, mergeMap, first, tap, firstValueFrom, skip, defaultIfEmpty, forkJoin } from 'rxjs';
|
|
19
19
|
import { __decorate, __metadata } from 'tslib';
|
|
20
20
|
import * as i1$2 from '@angular/router';
|
|
21
21
|
import { NavigationEnd, Router, ActivatedRoute, RouterModule } from '@angular/router';
|
|
22
22
|
import { untilDestroyed, UntilDestroy } from '@ngneat/until-destroy';
|
|
23
|
+
import { SyncableTopic, isValidDate as isValidDate$1 } from '@onecx/accelerator';
|
|
23
24
|
import * as i5 from 'primeng/breadcrumb';
|
|
24
25
|
import { BreadcrumbModule } from 'primeng/breadcrumb';
|
|
25
26
|
import * as i8 from 'primeng/menu';
|
|
@@ -34,7 +35,6 @@ import * as i6$1 from 'primeng/selectbutton';
|
|
|
34
35
|
import { SelectButtonModule } from 'primeng/selectbutton';
|
|
35
36
|
import * as i7 from 'primeng/dataview';
|
|
36
37
|
import { DataViewModule } from 'primeng/dataview';
|
|
37
|
-
import { isValidDate as isValidDate$1, SyncableTopic } from '@onecx/accelerator';
|
|
38
38
|
import * as i7$1 from 'primeng/table';
|
|
39
39
|
import { TableModule } from 'primeng/table';
|
|
40
40
|
import * as i9 from 'primeng/multiselect';
|
|
@@ -63,14 +63,19 @@ class IfPermissionDirective {
|
|
|
63
63
|
set ocxIfNotPermissionPermissions(value) {
|
|
64
64
|
this.ocxIfPermissionPermissions = value;
|
|
65
65
|
}
|
|
66
|
-
constructor(renderer, el, viewContainer,
|
|
66
|
+
constructor(renderer, el, viewContainer, hasPermissionChecker, templateRef, userService) {
|
|
67
67
|
this.renderer = renderer;
|
|
68
68
|
this.el = el;
|
|
69
69
|
this.viewContainer = viewContainer;
|
|
70
|
-
this.
|
|
70
|
+
this.hasPermissionChecker = hasPermissionChecker;
|
|
71
71
|
this.templateRef = templateRef;
|
|
72
|
+
this.userService = userService;
|
|
72
73
|
this.onMissingPermission = 'hide';
|
|
73
74
|
this.negate = false;
|
|
75
|
+
if (!(hasPermissionChecker || userService)) {
|
|
76
|
+
throw 'IfPermission requires UserService or HasPermissionChecker to be provided!';
|
|
77
|
+
}
|
|
78
|
+
this.permissionChecker = hasPermissionChecker ?? userService;
|
|
74
79
|
}
|
|
75
80
|
ngOnInit() {
|
|
76
81
|
if (this.permission) {
|
|
@@ -97,19 +102,23 @@ class IfPermissionDirective {
|
|
|
97
102
|
}
|
|
98
103
|
return result;
|
|
99
104
|
}
|
|
100
|
-
return this.permissionChecker
|
|
105
|
+
return this.permissionChecker?.hasPermission(permission);
|
|
101
106
|
}
|
|
102
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: IfPermissionDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: HAS_PERMISSION_CHECKER }, { token: i0.TemplateRef, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
107
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: IfPermissionDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: HAS_PERMISSION_CHECKER, optional: true }, { token: i0.TemplateRef, optional: true }, { token: i3.UserService, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
103
108
|
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.1.2", type: IfPermissionDirective, selector: "[ocxIfPermission], [ocxIfNotPermission]", inputs: { permission: ["ocxIfPermission", "permission"], notPermission: ["ocxIfNotPermission", "notPermission"], onMissingPermission: "onMissingPermission", ocxIfPermissionPermissions: "ocxIfPermissionPermissions", ocxIfNotPermissionPermissions: "ocxIfNotPermissionPermissions" }, ngImport: i0 }); }
|
|
104
109
|
}
|
|
105
110
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: IfPermissionDirective, decorators: [{
|
|
106
111
|
type: Directive,
|
|
107
112
|
args: [{ selector: '[ocxIfPermission], [ocxIfNotPermission]' }]
|
|
108
113
|
}], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: undefined, decorators: [{
|
|
114
|
+
type: Optional
|
|
115
|
+
}, {
|
|
109
116
|
type: Inject,
|
|
110
117
|
args: [HAS_PERMISSION_CHECKER]
|
|
111
118
|
}] }, { type: i0.TemplateRef, decorators: [{
|
|
112
119
|
type: Optional
|
|
120
|
+
}] }, { type: i3.UserService, decorators: [{
|
|
121
|
+
type: Optional
|
|
113
122
|
}] }], propDecorators: { permission: [{
|
|
114
123
|
type: Input,
|
|
115
124
|
args: ['ocxIfPermission']
|
|
@@ -243,14 +252,22 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
|
|
|
243
252
|
type: Output
|
|
244
253
|
}] } });
|
|
245
254
|
|
|
255
|
+
// This topic is defined here and not in integration-interface, because
|
|
256
|
+
// it is not used as framework independent integration but for improving
|
|
257
|
+
// angular specific things
|
|
258
|
+
class ManualBreadcrumbsTopic extends SyncableTopic {
|
|
259
|
+
constructor() {
|
|
260
|
+
super('manualBreadcrumbs', 1);
|
|
261
|
+
}
|
|
262
|
+
}
|
|
246
263
|
let BreadcrumbService = class BreadcrumbService {
|
|
247
264
|
constructor(router, activeRoute, translateService) {
|
|
248
265
|
this.router = router;
|
|
249
266
|
this.activeRoute = activeRoute;
|
|
250
267
|
this.translateService = translateService;
|
|
251
|
-
this.itemsSource = new
|
|
268
|
+
this.itemsSource$ = new ManualBreadcrumbsTopic();
|
|
252
269
|
this.generatedItemsSource = new BehaviorSubject([]);
|
|
253
|
-
this.itemsHandler = this.itemsSource
|
|
270
|
+
this.itemsHandler = this.itemsSource$.pipe(map((manualBreadcrumbs) => manualBreadcrumbs.menuItems));
|
|
254
271
|
this.generateBreadcrumbs(this.activeRoute.snapshot);
|
|
255
272
|
this.router.events
|
|
256
273
|
.pipe(untilDestroyed(this), filter((e) => e instanceof NavigationEnd))
|
|
@@ -323,15 +340,19 @@ let BreadcrumbService = class BreadcrumbService {
|
|
|
323
340
|
];
|
|
324
341
|
if (translationKeys.length) {
|
|
325
342
|
this.translateService.get(translationKeys).subscribe((translations) => {
|
|
326
|
-
this.itemsSource
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
343
|
+
this.itemsSource$.publish({
|
|
344
|
+
menuItems: items.map((i) => ({
|
|
345
|
+
...i,
|
|
346
|
+
label: translations[i.labelKey || ''] || i.label,
|
|
347
|
+
title: translations[i.titleKey || ''] || i.title,
|
|
348
|
+
})),
|
|
349
|
+
});
|
|
331
350
|
});
|
|
332
351
|
}
|
|
333
352
|
else {
|
|
334
|
-
this.itemsSource
|
|
353
|
+
this.itemsSource$.publish({
|
|
354
|
+
menuItems: items,
|
|
355
|
+
});
|
|
335
356
|
}
|
|
336
357
|
}
|
|
337
358
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: BreadcrumbService, deps: [{ token: i1$2.Router }, { token: i1$2.ActivatedRoute }, { token: i1$1.TranslateService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
@@ -339,7 +360,9 @@ let BreadcrumbService = class BreadcrumbService {
|
|
|
339
360
|
};
|
|
340
361
|
BreadcrumbService = __decorate([
|
|
341
362
|
UntilDestroy(),
|
|
342
|
-
__metadata("design:paramtypes", [Router,
|
|
363
|
+
__metadata("design:paramtypes", [Router,
|
|
364
|
+
ActivatedRoute,
|
|
365
|
+
TranslateService])
|
|
343
366
|
], BreadcrumbService);
|
|
344
367
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: BreadcrumbService, decorators: [{
|
|
345
368
|
type: Injectable,
|
|
@@ -627,6 +650,8 @@ class SearchHeaderComponent {
|
|
|
627
650
|
this.viewMode = 'basic';
|
|
628
651
|
this.manualBreadcrumbs = false;
|
|
629
652
|
this._actions = [];
|
|
653
|
+
this.searchButtonDisabled = false;
|
|
654
|
+
this.resetButtonDisabled = false;
|
|
630
655
|
this.searched = new EventEmitter();
|
|
631
656
|
this.resetted = new EventEmitter();
|
|
632
657
|
this.selectedSearchConfigChanged = new EventEmitter();
|
|
@@ -706,11 +731,11 @@ class SearchHeaderComponent {
|
|
|
706
731
|
this.selectedSearchConfigChanged?.emit(searchConfig);
|
|
707
732
|
}
|
|
708
733
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: SearchHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
709
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.2", type: SearchHeaderComponent, selector: "ocx-search-header", inputs: { searchConfigs: "searchConfigs", header: "header", headline: "headline", subheader: "subheader", viewMode: "viewMode", manualBreadcrumbs: "manualBreadcrumbs", actions: "actions" }, outputs: { searched: "searched", resetted: "resetted", selectedSearchConfigChanged: "selectedSearchConfigChanged", viewModeChanged: "viewModeChanged" }, queries: [{ propertyName: "additionalToolbarContent", first: true, predicate: ["additionalToolbarContent"], descendants: true }, { propertyName: "additionalToolbarContentLeft", first: true, predicate: ["additionalToolbarContentLeft"], descendants: true }], viewQueries: [{ propertyName: "searchParameterFields", first: true, predicate: ["searchParameterFields"], descendants: true }], ngImport: i0, template: "<ocx-page-header\n [header]=\"header || ('OCX_SEARCH_HEADER.HEADER' | translate)\"\n [subheader]=\"subheader\"\n [manualBreadcrumbs]=\"manualBreadcrumbs\"\n [actions]=\"headerActions\"\n>\n <ng-template #additionalToolbarContentLeft>\n <ocx-search-config [searchConfigs]=\"searchConfigs\" (selectedSearchConfigChanged)=\"confirmSearchConfig($event)\">\n </ocx-search-config>\n <ng-container
|
|
734
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.2", type: SearchHeaderComponent, selector: "ocx-search-header", inputs: { searchConfigs: "searchConfigs", header: "header", headline: "headline", subheader: "subheader", viewMode: "viewMode", manualBreadcrumbs: "manualBreadcrumbs", actions: "actions", searchButtonDisabled: "searchButtonDisabled", resetButtonDisabled: "resetButtonDisabled" }, outputs: { searched: "searched", resetted: "resetted", selectedSearchConfigChanged: "selectedSearchConfigChanged", viewModeChanged: "viewModeChanged" }, queries: [{ propertyName: "additionalToolbarContent", first: true, predicate: ["additionalToolbarContent"], descendants: true }, { propertyName: "additionalToolbarContentLeft", first: true, predicate: ["additionalToolbarContentLeft"], descendants: true }], viewQueries: [{ propertyName: "searchParameterFields", first: true, predicate: ["searchParameterFields"], descendants: true }], ngImport: i0, template: "<ocx-page-header\n [header]=\"header || ('OCX_SEARCH_HEADER.HEADER' | translate)\"\n [subheader]=\"subheader\"\n [manualBreadcrumbs]=\"manualBreadcrumbs\"\n [actions]=\"headerActions\"\n>\n <ng-template #additionalToolbarContentLeft>\n <ocx-search-config [searchConfigs]=\"searchConfigs\" (selectedSearchConfigChanged)=\"confirmSearchConfig($event)\">\n </ocx-search-config>\n <ng-container\n *ngIf=\"_additionalToolbarContentLeft\"\n [ngTemplateOutlet]=\"_additionalToolbarContentLeft\"\n ></ng-container>\n </ng-template>\n <ng-template #additionalToolbarContent>\n <ng-container *ngIf=\"_additionalToolbarContent\" [ngTemplateOutlet]=\"_additionalToolbarContent\"></ng-container>\n </ng-template>\n <div class=\"search-criteria-container\">\n <div #searchParameterFields>\n <ng-content></ng-content>\n <div class=\"search-criteria-buttons\">\n <p-button\n id=\"resetButton\"\n *ngIf=\"resetted.observed\"\n (onClick)=\"onResetClicked()\"\n label=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.TEXT' | translate }}\"\n icon=\"pi pi-eraser\"\n [attr.aria-label]=\"'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate\"\n title=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate }}\"\n [disabled]=\"resetButtonDisabled\"\n >\n </p-button>\n\n <p-button\n id=\"searchButton\"\n (onClick)=\"onSearchClicked()\"\n label=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.TEXT' | translate }}\"\n icon=\"pi pi-search\"\n [attr.aria-label]=\"'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate\"\n title=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate }}\"\n [disabled]=\"searchButtonDisabled\"\n >\n </p-button>\n </div>\n </div>\n </div>\n</ocx-page-header>\n", styles: [".search-criteria-buttons{display:flex;flex-flow:row;align-items:flex-start;gap:.5rem;margin-top:.5rem}.search-criteria-container{width:100%;display:flex}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i6.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "style", "styleClass", "badgeClass", "ariaLabel", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "component", type: SearchConfigComponent, selector: "ocx-search-config", inputs: ["searchConfigs", "placeholderKey"], outputs: ["selectedSearchConfigChanged"] }, { kind: "component", type: PageHeaderComponent, selector: "ocx-page-header", inputs: ["header", "loading", "figureBackground", "showFigure", "figureImage", "disableDefaultActions", "subheader", "actions", "objectDetails", "showBreadcrumbs", "manualBreadcrumbs", "enableGridView", "gridLayoutDesktopColumns"], outputs: ["save"] }, { kind: "pipe", type: i1$1.TranslatePipe, name: "translate" }] }); }
|
|
710
735
|
}
|
|
711
736
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: SearchHeaderComponent, decorators: [{
|
|
712
737
|
type: Component,
|
|
713
|
-
args: [{ selector: 'ocx-search-header', template: "<ocx-page-header\n [header]=\"header || ('OCX_SEARCH_HEADER.HEADER' | translate)\"\n [subheader]=\"subheader\"\n [manualBreadcrumbs]=\"manualBreadcrumbs\"\n [actions]=\"headerActions\"\n>\n <ng-template #additionalToolbarContentLeft>\n <ocx-search-config [searchConfigs]=\"searchConfigs\" (selectedSearchConfigChanged)=\"confirmSearchConfig($event)\">\n </ocx-search-config>\n <ng-container
|
|
738
|
+
args: [{ selector: 'ocx-search-header', template: "<ocx-page-header\n [header]=\"header || ('OCX_SEARCH_HEADER.HEADER' | translate)\"\n [subheader]=\"subheader\"\n [manualBreadcrumbs]=\"manualBreadcrumbs\"\n [actions]=\"headerActions\"\n>\n <ng-template #additionalToolbarContentLeft>\n <ocx-search-config [searchConfigs]=\"searchConfigs\" (selectedSearchConfigChanged)=\"confirmSearchConfig($event)\">\n </ocx-search-config>\n <ng-container\n *ngIf=\"_additionalToolbarContentLeft\"\n [ngTemplateOutlet]=\"_additionalToolbarContentLeft\"\n ></ng-container>\n </ng-template>\n <ng-template #additionalToolbarContent>\n <ng-container *ngIf=\"_additionalToolbarContent\" [ngTemplateOutlet]=\"_additionalToolbarContent\"></ng-container>\n </ng-template>\n <div class=\"search-criteria-container\">\n <div #searchParameterFields>\n <ng-content></ng-content>\n <div class=\"search-criteria-buttons\">\n <p-button\n id=\"resetButton\"\n *ngIf=\"resetted.observed\"\n (onClick)=\"onResetClicked()\"\n label=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.TEXT' | translate }}\"\n icon=\"pi pi-eraser\"\n [attr.aria-label]=\"'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate\"\n title=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate }}\"\n [disabled]=\"resetButtonDisabled\"\n >\n </p-button>\n\n <p-button\n id=\"searchButton\"\n (onClick)=\"onSearchClicked()\"\n label=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.TEXT' | translate }}\"\n icon=\"pi pi-search\"\n [attr.aria-label]=\"'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate\"\n title=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate }}\"\n [disabled]=\"searchButtonDisabled\"\n >\n </p-button>\n </div>\n </div>\n </div>\n</ocx-page-header>\n", styles: [".search-criteria-buttons{display:flex;flex-flow:row;align-items:flex-start;gap:.5rem;margin-top:.5rem}.search-criteria-container{width:100%;display:flex}\n"] }]
|
|
714
739
|
}], propDecorators: { searchConfigs: [{
|
|
715
740
|
type: Input
|
|
716
741
|
}], header: [{
|
|
@@ -725,6 +750,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
|
|
|
725
750
|
type: Input
|
|
726
751
|
}], actions: [{
|
|
727
752
|
type: Input
|
|
753
|
+
}], searchButtonDisabled: [{
|
|
754
|
+
type: Input
|
|
755
|
+
}], resetButtonDisabled: [{
|
|
756
|
+
type: Input
|
|
728
757
|
}], searched: [{
|
|
729
758
|
type: Output
|
|
730
759
|
}], resetted: [{
|
|
@@ -1169,6 +1198,7 @@ class DataListGridComponent extends DataSortBase {
|
|
|
1169
1198
|
return this._data$.getValue();
|
|
1170
1199
|
}
|
|
1171
1200
|
set data(value) {
|
|
1201
|
+
!this._data$.getValue().length ?? this.resetPage();
|
|
1172
1202
|
this._originalData = [...value];
|
|
1173
1203
|
this._data$.next([...value]);
|
|
1174
1204
|
}
|
|
@@ -1176,6 +1206,7 @@ class DataListGridComponent extends DataSortBase {
|
|
|
1176
1206
|
return this._filters$.getValue();
|
|
1177
1207
|
}
|
|
1178
1208
|
set filters(value) {
|
|
1209
|
+
!this._filters$.getValue().length ?? this.resetPage();
|
|
1179
1210
|
this._filters$.next(value);
|
|
1180
1211
|
}
|
|
1181
1212
|
get sortDirection() {
|
|
@@ -1409,6 +1440,10 @@ class DataListGridComponent extends DataSortBase {
|
|
|
1409
1440
|
this.page = page;
|
|
1410
1441
|
this.pageChanged.emit(page);
|
|
1411
1442
|
}
|
|
1443
|
+
resetPage() {
|
|
1444
|
+
this.page = 0;
|
|
1445
|
+
this.pageChanged.emit(this.page);
|
|
1446
|
+
}
|
|
1412
1447
|
fieldIsTruthy(object, key) {
|
|
1413
1448
|
return !!this.resolveFieldData(object, key);
|
|
1414
1449
|
}
|
|
@@ -1719,6 +1754,7 @@ class DataTableComponent extends DataSortBase {
|
|
|
1719
1754
|
return this._rows$.getValue();
|
|
1720
1755
|
}
|
|
1721
1756
|
set rows(value) {
|
|
1757
|
+
!this._rows$.getValue().length ?? this.resetPage();
|
|
1722
1758
|
this._rows$.next(value);
|
|
1723
1759
|
}
|
|
1724
1760
|
get selectedRows() {
|
|
@@ -1731,6 +1767,7 @@ class DataTableComponent extends DataSortBase {
|
|
|
1731
1767
|
return this._filters$.getValue();
|
|
1732
1768
|
}
|
|
1733
1769
|
set filters(value) {
|
|
1770
|
+
!this._filters$.getValue().length ?? this.resetPage();
|
|
1734
1771
|
this._filters$.next(value);
|
|
1735
1772
|
}
|
|
1736
1773
|
get sortDirection() {
|
|
@@ -1933,6 +1970,7 @@ class DataTableComponent extends DataSortBase {
|
|
|
1933
1970
|
this.filters = filters;
|
|
1934
1971
|
}
|
|
1935
1972
|
this.filtered.emit(filters);
|
|
1973
|
+
this.resetPage();
|
|
1936
1974
|
}
|
|
1937
1975
|
getSelectedFilters(columnId) {
|
|
1938
1976
|
return this.filters.filter((filter) => filter.columnId === columnId).map((filter) => filter.value);
|
|
@@ -1967,6 +2005,10 @@ class DataTableComponent extends DataSortBase {
|
|
|
1967
2005
|
this.page = page;
|
|
1968
2006
|
this.pageChanged.emit(page);
|
|
1969
2007
|
}
|
|
2008
|
+
resetPage() {
|
|
2009
|
+
this.page = 0;
|
|
2010
|
+
this.pageChanged.emit(this.page);
|
|
2011
|
+
}
|
|
1970
2012
|
fieldIsTruthy(object, key) {
|
|
1971
2013
|
return !!ObjectUtils.resolveFieldData(object, key);
|
|
1972
2014
|
}
|