@onecx/angular-accelerator 5.15.0 → 5.16.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/index.mjs +2 -4
- package/esm2022/lib/angular-accelerator.module.mjs +10 -10
- package/esm2022/lib/components/data-list-grid/data-list-grid.component.mjs +1 -1
- package/esm2022/lib/components/data-table/data-table.component.mjs +1 -1
- package/esm2022/lib/components/interactive-data-view/interactive-data-view.component.mjs +115 -71
- package/esm2022/lib/components/search-header/search-header.component.mjs +77 -36
- package/esm2022/lib/directives/if-permission.directive.mjs +20 -8
- package/esm2022/lib/utils/create-remote-component-and-mfe-translate-loader.utils.mjs +12 -0
- package/esm2022/testing/index.mjs +2 -2
- package/esm2022/testing/interactive-data-view.harness.mjs +4 -2
- package/esm2022/testing/search-header.harness.mjs +1 -3
- package/esm2022/testing/slot.harness.mjs +5 -0
- package/fesm2022/onecx-angular-accelerator-testing.mjs +7 -11
- package/fesm2022/onecx-angular-accelerator-testing.mjs.map +1 -1
- package/fesm2022/onecx-angular-accelerator.mjs +247 -214
- package/fesm2022/onecx-angular-accelerator.mjs.map +1 -1
- package/index.d.ts +1 -3
- package/lib/angular-accelerator.module.d.ts +16 -16
- package/lib/components/interactive-data-view/interactive-data-view.component.d.ts +15 -2
- package/lib/components/search-header/search-header.component.d.ts +30 -9
- package/lib/directives/if-permission.directive.d.ts +6 -4
- package/lib/utils/create-remote-component-and-mfe-translate-loader.utils.d.ts +6 -0
- package/package.json +2 -1
- package/testing/index.d.ts +1 -1
- package/testing/interactive-data-view.harness.d.ts +3 -1
- package/testing/search-header.harness.d.ts +0 -2
- package/testing/slot.harness.d.ts +7 -0
- package/esm2022/lib/components/search-config/search-config.component.mjs +0 -34
- package/esm2022/lib/model/search-config-info.mjs +0 -2
- package/esm2022/lib/services/app-config-service.mjs +0 -43
- package/esm2022/testing/search-config.harness.mjs +0 -10
- package/lib/components/search-config/search-config.component.d.ts +0 -16
- package/lib/model/search-config-info.d.ts +0 -4
- package/lib/services/app-config-service.d.ts +0 -18
- package/testing/search-config.harness.d.ts +0 -6
|
@@ -1,11 +1,16 @@
|
|
|
1
|
-
import { Component, ContentChild, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
1
|
+
import { Component, ContentChild, ContentChildren, EventEmitter, Input, Output, QueryList, ViewChild, } from '@angular/core';
|
|
2
|
+
import { FormControlName, FormGroupDirective } from '@angular/forms';
|
|
3
|
+
import { combineLatest, debounceTime, map, of, startWith } from 'rxjs';
|
|
4
|
+
import { getLocation } from '@onecx/accelerator';
|
|
2
5
|
import * as i0 from "@angular/core";
|
|
3
6
|
import * as i1 from "@angular/common";
|
|
4
7
|
import * as i2 from "primeng/tooltip";
|
|
5
8
|
import * as i3 from "primeng/button";
|
|
6
|
-
import * as i4 from "
|
|
7
|
-
import * as i5 from "
|
|
8
|
-
import * as i6 from "
|
|
9
|
+
import * as i4 from "primeng/skeleton";
|
|
10
|
+
import * as i5 from "@onecx/angular-remote-components";
|
|
11
|
+
import * as i6 from "../page-header/page-header.component";
|
|
12
|
+
import * as i7 from "../../directives/if-permission.directive";
|
|
13
|
+
import * as i8 from "@ngx-translate/core";
|
|
9
14
|
/**
|
|
10
15
|
* To trigger the search when Enter key is pressed inside a search parameter field,
|
|
11
16
|
* an EventListener for keyup enter event is added for HTML elements which have an input.
|
|
@@ -13,21 +18,6 @@ import * as i6 from "@ngx-translate/core";
|
|
|
13
18
|
* which do not have an input element.
|
|
14
19
|
*/
|
|
15
20
|
export class SearchHeaderComponent {
|
|
16
|
-
constructor() {
|
|
17
|
-
this.header = '';
|
|
18
|
-
this.viewMode = 'basic';
|
|
19
|
-
this.manualBreadcrumbs = false;
|
|
20
|
-
this._actions = [];
|
|
21
|
-
this.searchButtonDisabled = false;
|
|
22
|
-
this.resetButtonDisabled = false;
|
|
23
|
-
this.searched = new EventEmitter();
|
|
24
|
-
this.resetted = new EventEmitter();
|
|
25
|
-
this.selectedSearchConfigChanged = new EventEmitter();
|
|
26
|
-
this.viewModeChanged = new EventEmitter();
|
|
27
|
-
this.componentStateChanged = new EventEmitter();
|
|
28
|
-
this.hasAdvanced = false;
|
|
29
|
-
this.headerActions = [];
|
|
30
|
-
}
|
|
31
21
|
/**
|
|
32
22
|
* @deprecated Will be replaced by header
|
|
33
23
|
*/
|
|
@@ -37,6 +27,20 @@ export class SearchHeaderComponent {
|
|
|
37
27
|
set headline(value) {
|
|
38
28
|
this.header = value;
|
|
39
29
|
}
|
|
30
|
+
get viewMode() {
|
|
31
|
+
return this._viewMode;
|
|
32
|
+
}
|
|
33
|
+
set viewMode(viewMode) {
|
|
34
|
+
if (this.viewMode !== viewMode) {
|
|
35
|
+
this._viewMode = viewMode;
|
|
36
|
+
this.viewModeChanged?.emit(this.viewMode);
|
|
37
|
+
this.componentStateChanged.emit({
|
|
38
|
+
activeViewMode: this.viewMode,
|
|
39
|
+
});
|
|
40
|
+
this.updateHeaderActions();
|
|
41
|
+
setTimeout(() => this.addKeyUpEventListener());
|
|
42
|
+
}
|
|
43
|
+
}
|
|
40
44
|
get actions() {
|
|
41
45
|
return this._actions;
|
|
42
46
|
}
|
|
@@ -50,17 +54,49 @@ export class SearchHeaderComponent {
|
|
|
50
54
|
get _additionalToolbarContentLeft() {
|
|
51
55
|
return this.additionalToolbarContentLeft;
|
|
52
56
|
}
|
|
57
|
+
get searchConfigChangeObserved() {
|
|
58
|
+
return this.selectedSearchConfigChanged.observed;
|
|
59
|
+
}
|
|
60
|
+
constructor() {
|
|
61
|
+
this.header = '';
|
|
62
|
+
this._viewMode = 'basic';
|
|
63
|
+
this.manualBreadcrumbs = false;
|
|
64
|
+
this._actions = [];
|
|
65
|
+
this.searchButtonDisabled = false;
|
|
66
|
+
this.resetButtonDisabled = false;
|
|
67
|
+
this.pageName = getLocation().applicationPath;
|
|
68
|
+
this.searched = new EventEmitter();
|
|
69
|
+
this.resetted = new EventEmitter();
|
|
70
|
+
this.selectedSearchConfigChanged = new EventEmitter();
|
|
71
|
+
this.viewModeChanged = new EventEmitter();
|
|
72
|
+
this.componentStateChanged = new EventEmitter();
|
|
73
|
+
this.hasAdvanced = false;
|
|
74
|
+
this.headerActions = [];
|
|
75
|
+
this.fieldValues$ = of({});
|
|
76
|
+
this.searchConfigChangedSlotEmitter = new EventEmitter();
|
|
77
|
+
this.searchConfigChangedSlotEmitter.subscribe((config) => {
|
|
78
|
+
this.componentStateChanged.emit({
|
|
79
|
+
selectedSearchConfig: config?.name ?? null,
|
|
80
|
+
});
|
|
81
|
+
this.selectedSearchConfigChanged.emit(config);
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
ngAfterContentInit() {
|
|
85
|
+
if (this.formGroup) {
|
|
86
|
+
this.fieldValues$ = combineLatest([
|
|
87
|
+
this.formGroup.valueChanges.pipe(startWith({})),
|
|
88
|
+
this.visibleFormControls.changes.pipe(startWith(null)),
|
|
89
|
+
]).pipe(debounceTime(100), map(([values, _]) => Object.entries(values ?? {}).reduce((acc, [key, value]) => ({
|
|
90
|
+
...acc,
|
|
91
|
+
[key]: this.isVisible(key) ? value || undefined : undefined,
|
|
92
|
+
}), {})));
|
|
93
|
+
}
|
|
94
|
+
}
|
|
53
95
|
ngAfterViewInit() {
|
|
54
96
|
this.addKeyUpEventListener();
|
|
55
97
|
}
|
|
56
98
|
toggleViewMode() {
|
|
57
99
|
this.viewMode = this.viewMode === 'basic' ? 'advanced' : 'basic';
|
|
58
|
-
this.viewModeChanged?.emit(this.viewMode);
|
|
59
|
-
this.componentStateChanged.emit({
|
|
60
|
-
activeViewMode: this.viewMode
|
|
61
|
-
});
|
|
62
|
-
this.updateHeaderActions();
|
|
63
|
-
setTimeout(() => this.addKeyUpEventListener());
|
|
64
100
|
}
|
|
65
101
|
onResetClicked() {
|
|
66
102
|
this.resetted.emit();
|
|
@@ -99,21 +135,16 @@ export class SearchHeaderComponent {
|
|
|
99
135
|
this.onSearchClicked();
|
|
100
136
|
}
|
|
101
137
|
}
|
|
102
|
-
|
|
103
|
-
this.
|
|
104
|
-
this.componentStateChanged.emit({
|
|
105
|
-
selectedSearchConfig: searchConfig
|
|
106
|
-
});
|
|
138
|
+
isVisible(control) {
|
|
139
|
+
return this.visibleFormControls.some((formControl) => formControl.name !== null && String(formControl.name) === control);
|
|
107
140
|
}
|
|
108
141
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: SearchHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
109
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.6", type: SearchHeaderComponent, selector: "ocx-search-header", inputs: {
|
|
142
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.6", type: SearchHeaderComponent, selector: "ocx-search-header", inputs: { header: "header", headline: "headline", subheader: "subheader", viewMode: "viewMode", manualBreadcrumbs: "manualBreadcrumbs", actions: "actions", searchConfigPermission: "searchConfigPermission", searchButtonDisabled: "searchButtonDisabled", resetButtonDisabled: "resetButtonDisabled", pageName: "pageName" }, outputs: { searched: "searched", resetted: "resetted", selectedSearchConfigChanged: "selectedSearchConfigChanged", viewModeChanged: "viewModeChanged", componentStateChanged: "componentStateChanged" }, providers: [], queries: [{ propertyName: "additionalToolbarContent", first: true, predicate: ["additionalToolbarContent"], descendants: true }, { propertyName: "additionalToolbarContentLeft", first: true, predicate: ["additionalToolbarContentLeft"], descendants: true }, { propertyName: "formGroup", first: true, predicate: FormGroupDirective, descendants: true }, { propertyName: "visibleFormControls", predicate: FormControlName, 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 <ng-container *ngIf=\"searchConfigChangeObserved && pageName\">\n <ocx-slot\n *ocxIfPermission=\"searchConfigPermission\"\n name=\"onecx-shell-search-config\"\n [inputs]=\"{ pageName: pageName, currentFieldValues: fieldValues$ | async, viewMode: viewMode }\"\n [outputs]=\"{ searchConfigSelected: searchConfigChangedSlotEmitter }\"\n >\n <ng-template #skeleton>\n <div class=\"flex\">\n <p-skeleton width=\"18rem\" height=\"3rem\"></p-skeleton>\n </div>\n </ng-template>\n </ocx-slot>\n </ng-container>\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=\"flex row-gap-3 column-gap-6 flex-wrap align-items-center\">\n <div>\n <div #searchParameterFields>\n <ng-content></ng-content>\n </div>\n </div>\n <div class=\"flex flex-wrap gap-2\">\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 pTooltip=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate }}\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n [disabled]=\"resetButtonDisabled\"\n [ariaLabel]=\"'OCX_SEARCH_HEADER.RESET_BUTTON.ARIA_LABEL' | 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 pTooltip=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate }}\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n [disabled]=\"searchButtonDisabled || formGroup?.invalid\"\n [ariaLabel]=\"'OCX_SEARCH_HEADER.SEARCH_BUTTON.ARIA_LABEL' | translate\"\n >\n </p-button>\n </div>\n </div>\n</ocx-page-header>\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: "directive", type: i2.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "component", type: i3.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: i4.Skeleton, selector: "p-skeleton", inputs: ["styleClass", "style", "shape", "animation", "borderRadius", "size", "width", "height"] }, { kind: "component", type: i5.SlotComponent, selector: "ocx-slot[name]", inputs: ["name", "inputs", "outputs"] }, { kind: "component", type: i6.PageHeaderComponent, selector: "ocx-page-header", inputs: ["header", "loading", "figureBackground", "showFigure", "figureImage", "disableDefaultActions", "subheader", "actions", "objectDetails", "showBreadcrumbs", "manualBreadcrumbs", "enableGridView", "gridLayoutDesktopColumns"], outputs: ["save"] }, { kind: "directive", type: i7.IfPermissionDirective, selector: "[ocxIfPermission], [ocxIfNotPermission]", inputs: ["ocxIfPermission", "ocxIfNotPermission", "onMissingPermission", "ocxIfPermissionPermissions", "ocxIfNotPermissionPermissions", "ocxIfPermissionElseTemplate", "ocxIfNotPermissionElseTemplate"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }] }); }
|
|
110
143
|
}
|
|
111
144
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: SearchHeaderComponent, decorators: [{
|
|
112
145
|
type: Component,
|
|
113
|
-
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 [
|
|
114
|
-
}], propDecorators: {
|
|
115
|
-
type: Input
|
|
116
|
-
}], header: [{
|
|
146
|
+
args: [{ selector: 'ocx-search-header', providers: [], 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 <ng-container *ngIf=\"searchConfigChangeObserved && pageName\">\n <ocx-slot\n *ocxIfPermission=\"searchConfigPermission\"\n name=\"onecx-shell-search-config\"\n [inputs]=\"{ pageName: pageName, currentFieldValues: fieldValues$ | async, viewMode: viewMode }\"\n [outputs]=\"{ searchConfigSelected: searchConfigChangedSlotEmitter }\"\n >\n <ng-template #skeleton>\n <div class=\"flex\">\n <p-skeleton width=\"18rem\" height=\"3rem\"></p-skeleton>\n </div>\n </ng-template>\n </ocx-slot>\n </ng-container>\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=\"flex row-gap-3 column-gap-6 flex-wrap align-items-center\">\n <div>\n <div #searchParameterFields>\n <ng-content></ng-content>\n </div>\n </div>\n <div class=\"flex flex-wrap gap-2\">\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 pTooltip=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate }}\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n [disabled]=\"resetButtonDisabled\"\n [ariaLabel]=\"'OCX_SEARCH_HEADER.RESET_BUTTON.ARIA_LABEL' | 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 pTooltip=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate }}\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n [disabled]=\"searchButtonDisabled || formGroup?.invalid\"\n [ariaLabel]=\"'OCX_SEARCH_HEADER.SEARCH_BUTTON.ARIA_LABEL' | translate\"\n >\n </p-button>\n </div>\n </div>\n</ocx-page-header>\n" }]
|
|
147
|
+
}], ctorParameters: () => [], propDecorators: { header: [{
|
|
117
148
|
type: Input
|
|
118
149
|
}], headline: [{
|
|
119
150
|
type: Input
|
|
@@ -125,10 +156,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
|
|
|
125
156
|
type: Input
|
|
126
157
|
}], actions: [{
|
|
127
158
|
type: Input
|
|
159
|
+
}], searchConfigPermission: [{
|
|
160
|
+
type: Input
|
|
128
161
|
}], searchButtonDisabled: [{
|
|
129
162
|
type: Input
|
|
130
163
|
}], resetButtonDisabled: [{
|
|
131
164
|
type: Input
|
|
165
|
+
}], pageName: [{
|
|
166
|
+
type: Input
|
|
132
167
|
}], searched: [{
|
|
133
168
|
type: Output
|
|
134
169
|
}], resetted: [{
|
|
@@ -145,8 +180,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
|
|
|
145
180
|
}], additionalToolbarContentLeft: [{
|
|
146
181
|
type: ContentChild,
|
|
147
182
|
args: ['additionalToolbarContentLeft']
|
|
183
|
+
}], formGroup: [{
|
|
184
|
+
type: ContentChild,
|
|
185
|
+
args: [FormGroupDirective]
|
|
186
|
+
}], visibleFormControls: [{
|
|
187
|
+
type: ContentChildren,
|
|
188
|
+
args: [FormControlName, { descendants: true }]
|
|
148
189
|
}], searchParameterFields: [{
|
|
149
190
|
type: ViewChild,
|
|
150
191
|
args: ['searchParameterFields']
|
|
151
192
|
}] } });
|
|
152
|
-
//# 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\nexport interface SearchHeaderComponentState {\n  activeViewMode?: 'basic' | 'advanced'\n  selectedSearchConfig?: SearchConfigInfo\n}\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})\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  @Output() componentStateChanged: EventEmitter<SearchHeaderComponentState> = 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.componentStateChanged.emit({\n      activeViewMode: this.viewMode\n    })\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    this.componentStateChanged.emit({\n      selectedSearchConfig: searchConfig\n    })\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=\"flex row-gap-3 column-gap-6 flex-wrap align-items-center\">\n    <div>\n      <div #searchParameterFields>\n        <ng-content></ng-content>\n      </div>\n    </div>\n    <div class=\"flex flex-wrap gap-2\">\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        pTooltip=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate }}\"\n        tooltipPosition=\"top\"\n        tooltipEvent=\"hover\"\n        [disabled]=\"resetButtonDisabled\"\n        [ariaLabel]=\"'OCX_SEARCH_HEADER.RESET_BUTTON.ARIA_LABEL' | 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        pTooltip=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate }}\"\n        tooltipPosition=\"top\"\n        tooltipEvent=\"hover\"\n        [disabled]=\"searchButtonDisabled\"\n        [ariaLabel]=\"'OCX_SEARCH_HEADER.SEARCH_BUTTON.ARIA_LABEL' | translate\"\n      >\n      </p-button>\n    </div>\n  </div>\n</ocx-page-header>\n"]}
|
|
193
|
+
//# 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  AfterContentInit,\n  AfterViewInit,\n  Component,\n  ContentChild,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport { Action } from '../page-header/page-header.component'\nimport { FormControlName, FormGroup, FormGroupDirective } from '@angular/forms'\nimport { Observable, combineLatest, debounceTime, map, of, startWith } from 'rxjs'\nimport { getLocation } from '@onecx/accelerator'\n\nexport interface SearchHeaderComponentState {\n  activeViewMode?: 'basic' | 'advanced'\n  selectedSearchConfig?: string | null\n}\n\nexport interface SearchConfigData {\n  name: string | undefined\n  fieldValues: { [key: string]: string }\n  displayedColumnsIds: string[]\n  viewMode: 'basic' | 'advanced'\n}\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  providers: [],\n})\nexport class SearchHeaderComponent implements AfterContentInit, AfterViewInit {\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  _viewMode: 'basic' | 'advanced' = 'basic'\n  @Input()\n  get viewMode(): 'basic' | 'advanced' {\n    return this._viewMode\n  }\n  set viewMode(viewMode: 'basic' | 'advanced') {\n    if (this.viewMode !== viewMode) {\n      this._viewMode = viewMode\n      this.viewModeChanged?.emit(this.viewMode)\n      this.componentStateChanged.emit({\n        activeViewMode: this.viewMode,\n      })\n      this.updateHeaderActions()\n      setTimeout(() => this.addKeyUpEventListener())\n    }\n  }\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() searchConfigPermission: string | undefined\n  @Input() searchButtonDisabled = false\n  @Input() resetButtonDisabled = false\n  @Input() pageName: string | undefined = getLocation().applicationPath\n\n  @Output() searched: EventEmitter<any> = new EventEmitter()\n  @Output() resetted: EventEmitter<any> = new EventEmitter()\n  @Output() selectedSearchConfigChanged: EventEmitter<SearchConfigData | undefined> = new EventEmitter()\n  @Output() viewModeChanged: EventEmitter<'basic' | 'advanced'> = new EventEmitter()\n  @Output() componentStateChanged: EventEmitter<SearchHeaderComponentState> = 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  get searchConfigChangeObserved(): boolean {\n    return this.selectedSearchConfigChanged.observed\n  }\n\n  @ContentChild(FormGroupDirective) formGroup: FormGroup | undefined\n  @ContentChildren(FormControlName, { descendants: true }) visibleFormControls!: QueryList<FormControlName>\n\n  @ViewChild('searchParameterFields') searchParameterFields: ElementRef | undefined\n\n  hasAdvanced = false\n  headerActions: Action[] = []\n\n  fieldValues$: Observable<{ [key: string]: unknown }> | undefined = of({})\n  searchConfigChangedSlotEmitter: EventEmitter<SearchConfigData | undefined> = new EventEmitter()\n\n  constructor() {\n    this.searchConfigChangedSlotEmitter.subscribe((config) => {\n      this.componentStateChanged.emit({\n        selectedSearchConfig: config?.name ?? null,\n      })\n      this.selectedSearchConfigChanged.emit(config)\n    })\n  }\n\n  ngAfterContentInit(): void {\n    if (this.formGroup) {\n      this.fieldValues$ = combineLatest([\n        this.formGroup.valueChanges.pipe(startWith({})),\n        this.visibleFormControls.changes.pipe(startWith(null)),\n      ]).pipe(\n        debounceTime(100),\n        map(([values, _]) =>\n          Object.entries(values ?? {}).reduce(\n            (acc, [key, value]) => ({\n              ...acc,\n              [key]: this.isVisible(key) ? value || undefined : undefined,\n            }),\n            {}\n          )\n        )\n      )\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.addKeyUpEventListener()\n  }\n\n  toggleViewMode() {\n    this.viewMode = this.viewMode === 'basic' ? 'advanced' : 'basic'\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  private isVisible(control: string) {\n    return this.visibleFormControls.some(\n      (formControl) => formControl.name !== null && String(formControl.name) === control\n    )\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    <ng-container *ngIf=\"searchConfigChangeObserved && pageName\">\n      <ocx-slot\n        *ocxIfPermission=\"searchConfigPermission\"\n        name=\"onecx-shell-search-config\"\n        [inputs]=\"{ pageName: pageName, currentFieldValues: fieldValues$ | async, viewMode: viewMode }\"\n        [outputs]=\"{ searchConfigSelected: searchConfigChangedSlotEmitter }\"\n      >\n        <ng-template #skeleton>\n          <div class=\"flex\">\n            <p-skeleton width=\"18rem\" height=\"3rem\"></p-skeleton>\n          </div>\n        </ng-template>\n      </ocx-slot>\n    </ng-container>\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=\"flex row-gap-3 column-gap-6 flex-wrap align-items-center\">\n    <div>\n      <div #searchParameterFields>\n        <ng-content></ng-content>\n      </div>\n    </div>\n    <div class=\"flex flex-wrap gap-2\">\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        pTooltip=\"{{ 'OCX_SEARCH_HEADER.RESET_BUTTON.DETAIL' | translate }}\"\n        tooltipPosition=\"top\"\n        tooltipEvent=\"hover\"\n        [disabled]=\"resetButtonDisabled\"\n        [ariaLabel]=\"'OCX_SEARCH_HEADER.RESET_BUTTON.ARIA_LABEL' | 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        pTooltip=\"{{ 'OCX_SEARCH_HEADER.SEARCH_BUTTON.DETAIL' | translate }}\"\n        tooltipPosition=\"top\"\n        tooltipEvent=\"hover\"\n        [disabled]=\"searchButtonDisabled || formGroup?.invalid\"\n        [ariaLabel]=\"'OCX_SEARCH_HEADER.SEARCH_BUTTON.ARIA_LABEL' | translate\"\n      >\n      </p-button>\n    </div>\n  </div>\n</ocx-page-header>\n"]}
|
|
@@ -19,6 +19,9 @@ export class IfPermissionDirective {
|
|
|
19
19
|
set ocxIfNotPermissionPermissions(value) {
|
|
20
20
|
this.ocxIfPermissionPermissions = value;
|
|
21
21
|
}
|
|
22
|
+
set ocxIfNotPermissionElseTemplate(value) {
|
|
23
|
+
this.ocxIfPermissionElseTemplate = value;
|
|
24
|
+
}
|
|
22
25
|
constructor(renderer, el, viewContainer, hasPermissionChecker, templateRef, userService) {
|
|
23
26
|
this.renderer = renderer;
|
|
24
27
|
this.el = el;
|
|
@@ -35,12 +38,17 @@ export class IfPermissionDirective {
|
|
|
35
38
|
}
|
|
36
39
|
ngOnInit() {
|
|
37
40
|
if (this.permission) {
|
|
38
|
-
if (this.negate === this.hasPermission(this.permission)) {
|
|
39
|
-
if (this.
|
|
40
|
-
this.
|
|
41
|
+
if (this.negate === this.hasPermission(Array.isArray(this.permission) ? this.permission : [this.permission])) {
|
|
42
|
+
if (this.ocxIfPermissionElseTemplate) {
|
|
43
|
+
this.viewContainer.createEmbeddedView(this.ocxIfPermissionElseTemplate);
|
|
41
44
|
}
|
|
42
45
|
else {
|
|
43
|
-
this.
|
|
46
|
+
if (this.onMissingPermission === 'disable') {
|
|
47
|
+
this.renderer.setAttribute(this.el.nativeElement, 'disabled', 'disabled');
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
this.viewContainer.clear();
|
|
51
|
+
}
|
|
44
52
|
}
|
|
45
53
|
}
|
|
46
54
|
else {
|
|
@@ -52,16 +60,16 @@ export class IfPermissionDirective {
|
|
|
52
60
|
}
|
|
53
61
|
hasPermission(permission) {
|
|
54
62
|
if (this.ocxIfPermissionPermissions) {
|
|
55
|
-
const result = this.ocxIfPermissionPermissions
|
|
63
|
+
const result = permission.every((p) => this.ocxIfPermissionPermissions?.includes(p));
|
|
56
64
|
if (!result) {
|
|
57
65
|
console.log('👮♀️ No permission in overwrites for: `', permission);
|
|
58
66
|
}
|
|
59
67
|
return result;
|
|
60
68
|
}
|
|
61
|
-
return this.permissionChecker?.hasPermission(
|
|
69
|
+
return permission.every((p) => this.permissionChecker?.hasPermission(p));
|
|
62
70
|
}
|
|
63
71
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", 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 }); }
|
|
64
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.6", type: IfPermissionDirective, selector: "[ocxIfPermission], [ocxIfNotPermission]", inputs: { permission: ["ocxIfPermission", "permission"], notPermission: ["ocxIfNotPermission", "notPermission"], onMissingPermission: "onMissingPermission", ocxIfPermissionPermissions: "ocxIfPermissionPermissions", ocxIfNotPermissionPermissions: "ocxIfNotPermissionPermissions" }, ngImport: i0 }); }
|
|
72
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.6", type: IfPermissionDirective, selector: "[ocxIfPermission], [ocxIfNotPermission]", inputs: { permission: ["ocxIfPermission", "permission"], notPermission: ["ocxIfNotPermission", "notPermission"], onMissingPermission: "onMissingPermission", ocxIfPermissionPermissions: "ocxIfPermissionPermissions", ocxIfNotPermissionPermissions: "ocxIfNotPermissionPermissions", ocxIfPermissionElseTemplate: "ocxIfPermissionElseTemplate", ocxIfNotPermissionElseTemplate: "ocxIfNotPermissionElseTemplate" }, ngImport: i0 }); }
|
|
65
73
|
}
|
|
66
74
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: IfPermissionDirective, decorators: [{
|
|
67
75
|
type: Directive,
|
|
@@ -87,5 +95,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
|
|
|
87
95
|
type: Input
|
|
88
96
|
}], ocxIfNotPermissionPermissions: [{
|
|
89
97
|
type: Input
|
|
98
|
+
}], ocxIfPermissionElseTemplate: [{
|
|
99
|
+
type: Input
|
|
100
|
+
}], ocxIfNotPermissionElseTemplate: [{
|
|
101
|
+
type: Input
|
|
90
102
|
}] } });
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"if-permission.directive.js","sourceRoot":"","sources":["../../../../../../libs/angular-accelerator/src/lib/directives/if-permission.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  Inject,\n  InjectionToken,\n  Input,\n  OnInit,\n  Optional,\n  Renderer2,\n  TemplateRef,\n  ViewContainerRef,\n} from '@angular/core'\nimport { UserService } from '@onecx/angular-integration-interface'\n\nexport interface HasPermissionChecker {\n  hasPermission(permissionKey: string): boolean\n}\n\n/**\n * This checker always returns true, basically disabling the permission system on the UI side\n */\nexport class AlwaysGrantPermissionChecker implements HasPermissionChecker {\n  hasPermission(_permissionKey: string): boolean {\n    return true\n  }\n}\n\nexport const HAS_PERMISSION_CHECKER = new InjectionToken<HasPermissionChecker>('hasPermission')\n\n@Directive({ selector: '[ocxIfPermission], [ocxIfNotPermission]' })\nexport class IfPermissionDirective implements OnInit {\n  @Input('ocxIfPermission') permission: string | string[] | undefined\n  @Input('ocxIfNotPermission') set notPermission(value: string | string[] | undefined) {\n    this.permission = value\n    this.negate = true\n  }\n\n  @Input() onMissingPermission: 'hide' | 'disable' = 'hide'\n\n  @Input() ocxIfPermissionPermissions: string[] | undefined\n  @Input()\n  set ocxIfNotPermissionPermissions(value: string[] | undefined) {\n    this.ocxIfPermissionPermissions = value\n  }\n\n  @Input()\n  ocxIfPermissionElseTemplate: TemplateRef<any> | undefined\n  @Input()\n  set ocxIfNotPermissionElseTemplate(value: TemplateRef<any> | undefined) {\n    this.ocxIfPermissionElseTemplate = value\n  }\n\n  private permissionChecker: HasPermissionChecker | undefined\n  negate = false\n\n  constructor(\n    private renderer: Renderer2,\n    private el: ElementRef,\n    private viewContainer: ViewContainerRef,\n    @Optional()\n    @Inject(HAS_PERMISSION_CHECKER)\n    private hasPermissionChecker?: HasPermissionChecker,\n    @Optional() private templateRef?: TemplateRef<any>,\n    @Optional() private userService?: UserService\n  ) {\n    if (!(hasPermissionChecker || userService)) {\n      throw 'IfPermission requires UserService or HasPermissionChecker to be provided!'\n    }\n\n    this.permissionChecker = hasPermissionChecker ?? userService\n  }\n\n  ngOnInit() {\n    if (this.permission) {\n      if (this.negate === this.hasPermission(Array.isArray(this.permission) ? this.permission : [this.permission])) {\n        if (this.ocxIfPermissionElseTemplate) {\n          this.viewContainer.createEmbeddedView(this.ocxIfPermissionElseTemplate)\n        } else {\n          if (this.onMissingPermission === 'disable') {\n            this.renderer.setAttribute(this.el.nativeElement, 'disabled', 'disabled')\n          } else {\n            this.viewContainer.clear()\n          }\n        }\n      } else {\n        if (this.templateRef) {\n          this.viewContainer.createEmbeddedView(this.templateRef)\n        }\n      }\n    }\n  }\n\n  hasPermission(permission: string[]) {\n    if (this.ocxIfPermissionPermissions) {\n      const result = permission.every((p) => this.ocxIfPermissionPermissions?.includes(p))\n      if (!result) {\n        console.log('👮‍♀️ No permission in overwrites for: `', permission)\n      }\n      return result\n    }\n    return permission.every((p) => this.permissionChecker?.hasPermission(p))\n  }\n}\n"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { map } from 'rxjs';
|
|
2
|
+
import { AsyncTranslateLoader } from './async-translate-loader.utils';
|
|
3
|
+
import { TranslateCombinedLoader } from './translate.combined.loader';
|
|
4
|
+
import { createRemoteComponentTranslateLoader } from './create-remote-component-translate-loader.utils';
|
|
5
|
+
import { CachingTranslateLoader } from './caching-translate-loader.utils';
|
|
6
|
+
import { Location } from '@angular/common';
|
|
7
|
+
export function createRemoteComponentAndMfeTranslateLoader(httpClient, baseUrl, translationCacheService, appStateService) {
|
|
8
|
+
return new AsyncTranslateLoader(appStateService.currentMfe$.pipe(map((currentMfe) => {
|
|
9
|
+
return new TranslateCombinedLoader(createRemoteComponentTranslateLoader(httpClient, baseUrl, translationCacheService), new CachingTranslateLoader(translationCacheService, httpClient, Location.joinWithSlash(currentMfe.remoteBaseUrl, 'assets/i18n/'), '.json'));
|
|
10
|
+
})));
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLXJlbW90ZS1jb21wb25lbnQtYW5kLW1mZS10cmFuc2xhdGUtbG9hZGVyLnV0aWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLWFjY2VsZXJhdG9yL3NyYy9saWIvdXRpbHMvY3JlYXRlLXJlbW90ZS1jb21wb25lbnQtYW5kLW1mZS10cmFuc2xhdGUtbG9hZGVyLnV0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBaUIsR0FBRyxFQUFFLE1BQU0sTUFBTSxDQUFBO0FBR3pDLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGdDQUFnQyxDQUFBO0FBQ3JFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDZCQUE2QixDQUFBO0FBQ3JFLE9BQU8sRUFBRSxvQ0FBb0MsRUFBRSxNQUFNLGtEQUFrRCxDQUFBO0FBQ3ZHLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLGtDQUFrQyxDQUFBO0FBQ3pFLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQUUxQyxNQUFNLFVBQVUsMENBQTBDLENBQ3hELFVBQXNCLEVBQ3RCLE9BQThCLEVBQzlCLHVCQUFnRCxFQUNoRCxlQUFnQztJQUVoQyxPQUFPLElBQUksb0JBQW9CLENBQzdCLGVBQWUsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUM5QixHQUFHLENBQUMsQ0FBQyxVQUFVLEVBQUUsRUFBRTtRQUNqQixPQUFPLElBQUksdUJBQXVCLENBQ2hDLG9DQUFvQyxDQUFDLFVBQVUsRUFBRSxPQUFPLEVBQUUsdUJBQXVCLENBQUMsRUFDbEYsSUFBSSxzQkFBc0IsQ0FDeEIsdUJBQXVCLEVBQ3ZCLFVBQVUsRUFDVixRQUFRLENBQUMsYUFBYSxDQUFDLFVBQVUsQ0FBQyxhQUFhLEVBQUUsY0FBYyxDQUFDLEVBQ2hFLE9BQU8sQ0FDUixDQUNGLENBQUE7SUFDSCxDQUFDLENBQUMsQ0FDSCxDQUNGLENBQUE7QUFDSCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cENsaWVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJ1xuaW1wb3J0IHsgUmVwbGF5U3ViamVjdCwgbWFwIH0gZnJvbSAncnhqcydcbmltcG9ydCB7IFRyYW5zbGF0aW9uQ2FjaGVTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvdHJhbnNsYXRpb24tY2FjaGUuc2VydmljZSdcbmltcG9ydCB7IEFwcFN0YXRlU2VydmljZSB9IGZyb20gJ0BvbmVjeC9hbmd1bGFyLWludGVncmF0aW9uLWludGVyZmFjZSdcbmltcG9ydCB7IEFzeW5jVHJhbnNsYXRlTG9hZGVyIH0gZnJvbSAnLi9hc3luYy10cmFuc2xhdGUtbG9hZGVyLnV0aWxzJ1xuaW1wb3J0IHsgVHJhbnNsYXRlQ29tYmluZWRMb2FkZXIgfSBmcm9tICcuL3RyYW5zbGF0ZS5jb21iaW5lZC5sb2FkZXInXG5pbXBvcnQgeyBjcmVhdGVSZW1vdGVDb21wb25lbnRUcmFuc2xhdGVMb2FkZXIgfSBmcm9tICcuL2NyZWF0ZS1yZW1vdGUtY29tcG9uZW50LXRyYW5zbGF0ZS1sb2FkZXIudXRpbHMnXG5pbXBvcnQgeyBDYWNoaW5nVHJhbnNsYXRlTG9hZGVyIH0gZnJvbSAnLi9jYWNoaW5nLXRyYW5zbGF0ZS1sb2FkZXIudXRpbHMnXG5pbXBvcnQgeyBMb2NhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbidcblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVJlbW90ZUNvbXBvbmVudEFuZE1mZVRyYW5zbGF0ZUxvYWRlcihcbiAgaHR0cENsaWVudDogSHR0cENsaWVudCxcbiAgYmFzZVVybDogUmVwbGF5U3ViamVjdDxzdHJpbmc+LFxuICB0cmFuc2xhdGlvbkNhY2hlU2VydmljZTogVHJhbnNsYXRpb25DYWNoZVNlcnZpY2UsXG4gIGFwcFN0YXRlU2VydmljZTogQXBwU3RhdGVTZXJ2aWNlXG4pIHtcbiAgcmV0dXJuIG5ldyBBc3luY1RyYW5zbGF0ZUxvYWRlcihcbiAgICBhcHBTdGF0ZVNlcnZpY2UuY3VycmVudE1mZSQucGlwZShcbiAgICAgIG1hcCgoY3VycmVudE1mZSkgPT4ge1xuICAgICAgICByZXR1cm4gbmV3IFRyYW5zbGF0ZUNvbWJpbmVkTG9hZGVyKFxuICAgICAgICAgIGNyZWF0ZVJlbW90ZUNvbXBvbmVudFRyYW5zbGF0ZUxvYWRlcihodHRwQ2xpZW50LCBiYXNlVXJsLCB0cmFuc2xhdGlvbkNhY2hlU2VydmljZSksXG4gICAgICAgICAgbmV3IENhY2hpbmdUcmFuc2xhdGVMb2FkZXIoXG4gICAgICAgICAgICB0cmFuc2xhdGlvbkNhY2hlU2VydmljZSxcbiAgICAgICAgICAgIGh0dHBDbGllbnQsXG4gICAgICAgICAgICBMb2NhdGlvbi5qb2luV2l0aFNsYXNoKGN1cnJlbnRNZmUucmVtb3RlQmFzZVVybCwgJ2Fzc2V0cy9pMThuLycpLFxuICAgICAgICAgICAgJy5qc29uJ1xuICAgICAgICAgIClcbiAgICAgICAgKVxuICAgICAgfSlcbiAgICApXG4gIClcbn1cbiJdfQ==
|
|
@@ -11,9 +11,9 @@ export * from './group-by-count-diagram.harness';
|
|
|
11
11
|
export * from './interactive-data-view.harness';
|
|
12
12
|
export * from './more-actions-menu-button.harness';
|
|
13
13
|
export * from './page-header.harness';
|
|
14
|
-
export * from './
|
|
14
|
+
export * from './slot.harness';
|
|
15
15
|
export * from './search-header.harness';
|
|
16
16
|
export * from '@angular/cdk/testing';
|
|
17
17
|
export * from '@angular/cdk/testing/testbed';
|
|
18
18
|
export * from '@onecx/angular-testing';
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItYWNjZWxlcmF0b3IvdGVzdGluZy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGtDQUFrQyxDQUFBO0FBQ2hELGNBQWMsd0NBQXdDLENBQUE7QUFDdEQsY0FBYyxpQ0FBaUMsQ0FBQTtBQUMvQyxjQUFjLDBCQUEwQixDQUFBO0FBQ3hDLGNBQWMsc0JBQXNCLENBQUE7QUFDcEMsY0FBYyxxQkFBcUIsQ0FBQTtBQUNuQyxjQUFjLDZCQUE2QixDQUFBO0FBQzNDLGNBQWMsNkJBQTZCLENBQUE7QUFDM0MsY0FBYyxtQkFBbUIsQ0FBQTtBQUNqQyxjQUFjLGtDQUFrQyxDQUFBO0FBQ2hELGNBQWMsaUNBQWlDLENBQUE7QUFDL0MsY0FBYyxvQ0FBb0MsQ0FBQTtBQUNsRCxjQUFjLHVCQUF1QixDQUFBO0FBQ3JDLGNBQWMsZ0JBQWdCLENBQUE7QUFDOUIsY0FBYyx5QkFBeUIsQ0FBQTtBQUV2QyxjQUFjLHNCQUFzQixDQUFBO0FBQ3BDLGNBQWMsOEJBQThCLENBQUE7QUFDNUMsY0FBYyx3QkFBd0IsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29sdW1uLWdyb3VwLXNlbGVjdGlvbi5oYXJuZXNzJ1xuZXhwb3J0ICogZnJvbSAnLi9jdXN0b20tZ3JvdXAtY29sdW1uLXNlbGVjdG9yLmhhcm5lc3MnXG5leHBvcnQgKiBmcm9tICcuL2RhdGEtbGF5b3V0LXNlbGVjdGlvbi5oYXJuZXNzJ1xuZXhwb3J0ICogZnJvbSAnLi9kYXRhLWxpc3QtZ3JpZC5oYXJuZXNzJ1xuZXhwb3J0ICogZnJvbSAnLi9kYXRhLXRhYmxlLmhhcm5lc3MnXG5leHBvcnQgKiBmcm9tICcuL2RhdGEtdmlldy5oYXJuZXNzJ1xuZXhwb3J0ICogZnJvbSAnLi9kZWZhdWx0LWdyaWQtaXRlbS5oYXJuZXNzJ1xuZXhwb3J0ICogZnJvbSAnLi9kZWZhdWx0LWxpc3QtaXRlbS5oYXJuZXNzJ1xuZXhwb3J0ICogZnJvbSAnLi9kaWFncmFtLmhhcm5lc3MnXG5leHBvcnQgKiBmcm9tICcuL2dyb3VwLWJ5LWNvdW50LWRpYWdyYW0uaGFybmVzcydcbmV4cG9ydCAqIGZyb20gJy4vaW50ZXJhY3RpdmUtZGF0YS12aWV3Lmhhcm5lc3MnXG5leHBvcnQgKiBmcm9tICcuL21vcmUtYWN0aW9ucy1tZW51LWJ1dHRvbi5oYXJuZXNzJ1xuZXhwb3J0ICogZnJvbSAnLi9wYWdlLWhlYWRlci5oYXJuZXNzJ1xuZXhwb3J0ICogZnJvbSAnLi9zbG90Lmhhcm5lc3MnXG5leHBvcnQgKiBmcm9tICcuL3NlYXJjaC1oZWFkZXIuaGFybmVzcydcblxuZXhwb3J0ICogZnJvbSAnQGFuZ3VsYXIvY2RrL3Rlc3RpbmcnXG5leHBvcnQgKiBmcm9tICdAYW5ndWxhci9jZGsvdGVzdGluZy90ZXN0YmVkJ1xuZXhwb3J0ICogZnJvbSAnQG9uZWN4L2FuZ3VsYXItdGVzdGluZydcbiJdfQ==
|
|
@@ -4,16 +4,18 @@ import { PDropdownHarness } from '@onecx/angular-testing';
|
|
|
4
4
|
import { CustomGroupColumnSelectorHarness } from '.';
|
|
5
5
|
import { DataLayoutSelectionHarness } from './data-layout-selection.harness';
|
|
6
6
|
import { DataViewHarness } from './data-view.harness';
|
|
7
|
+
import { SlotHarness } from './slot.harness';
|
|
7
8
|
export class InteractiveDataViewHarness extends ContentContainerComponentHarness {
|
|
8
9
|
constructor() {
|
|
9
10
|
super(...arguments);
|
|
10
11
|
this.getDataLayoutSelection = this.locatorFor(DataLayoutSelectionHarness);
|
|
11
12
|
this.getColumnGroupSelectionDropdown = this.locatorForOptional(PDropdownHarness.with({ id: 'columnGroupSelectionDropdown' }));
|
|
12
|
-
this.getCustomGroupColumnSelector = this.
|
|
13
|
+
this.getCustomGroupColumnSelector = this.locatorForOptional(CustomGroupColumnSelectorHarness);
|
|
14
|
+
this.getCustomGroupColumnSelectorSlot = this.locatorForOptional(SlotHarness);
|
|
13
15
|
this.getDataListGridSortingDropdown = this.locatorForOptional(PDropdownHarness.with({ id: 'dataListGridSortingDropdown' }));
|
|
14
16
|
this.getDataListGridSortingButton = this.locatorForOptional(PButtonHarness.with({ id: 'dataListGridSortingButton' }));
|
|
15
17
|
this.getDataView = this.locatorFor(DataViewHarness);
|
|
16
18
|
}
|
|
17
19
|
static { this.hostSelector = 'ocx-interactive-data-view'; }
|
|
18
20
|
}
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJhY3RpdmUtZGF0YS12aWV3Lmhhcm5lc3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItYWNjZWxlcmF0b3IvdGVzdGluZy9pbnRlcmFjdGl2ZS1kYXRhLXZpZXcuaGFybmVzcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZ0NBQWdDLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQTtBQUN2RSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sd0JBQXdCLENBQUE7QUFDdkQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sd0JBQXdCLENBQUE7QUFDekQsT0FBTyxFQUFFLGdDQUFnQyxFQUFFLE1BQU0sR0FBRyxDQUFBO0FBQ3BELE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLGlDQUFpQyxDQUFBO0FBQzVFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQTtBQUNyRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUE7QUFFNUMsTUFBTSxPQUFPLDBCQUEyQixTQUFRLGdDQUFnQztJQUFoRjs7UUFHRSwyQkFBc0IsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLDBCQUEwQixDQUFDLENBQUE7UUFDcEUsb0NBQStCLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUN2RCxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsRUFBRSxFQUFFLEVBQUUsOEJBQThCLEVBQUUsQ0FBQyxDQUM5RCxDQUFBO1FBQ0QsaUNBQTRCLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDLGdDQUFnQyxDQUFDLENBQUE7UUFDeEYscUNBQWdDLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDLFdBQVcsQ0FBQyxDQUFBO1FBQ3ZFLG1DQUE4QixHQUFHLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsRUFBRSxFQUFFLEVBQUUsNkJBQTZCLEVBQUUsQ0FBQyxDQUFDLENBQUE7UUFDdEgsaUNBQTRCLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsRUFBRSxFQUFFLEVBQUUsMkJBQTJCLEVBQUUsQ0FBQyxDQUFDLENBQUE7UUFDaEgsZ0JBQVcsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLGVBQWUsQ0FBQyxDQUFBO0lBQ2hELENBQUM7YUFYUSxpQkFBWSxHQUFHLDJCQUEyQixBQUE5QixDQUE4QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbnRlbnRDb250YWluZXJDb21wb25lbnRIYXJuZXNzIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3Rlc3RpbmcnXG5pbXBvcnQgeyBQQnV0dG9uSGFybmVzcyB9IGZyb20gJ0BvbmVjeC9hbmd1bGFyLXRlc3RpbmcnXG5pbXBvcnQgeyBQRHJvcGRvd25IYXJuZXNzIH0gZnJvbSAnQG9uZWN4L2FuZ3VsYXItdGVzdGluZydcbmltcG9ydCB7IEN1c3RvbUdyb3VwQ29sdW1uU2VsZWN0b3JIYXJuZXNzIH0gZnJvbSAnLidcbmltcG9ydCB7IERhdGFMYXlvdXRTZWxlY3Rpb25IYXJuZXNzIH0gZnJvbSAnLi9kYXRhLWxheW91dC1zZWxlY3Rpb24uaGFybmVzcydcbmltcG9ydCB7IERhdGFWaWV3SGFybmVzcyB9IGZyb20gJy4vZGF0YS12aWV3Lmhhcm5lc3MnXG5pbXBvcnQgeyBTbG90SGFybmVzcyB9IGZyb20gJy4vc2xvdC5oYXJuZXNzJ1xuXG5leHBvcnQgY2xhc3MgSW50ZXJhY3RpdmVEYXRhVmlld0hhcm5lc3MgZXh0ZW5kcyBDb250ZW50Q29udGFpbmVyQ29tcG9uZW50SGFybmVzcyB7XG4gIHN0YXRpYyBob3N0U2VsZWN0b3IgPSAnb2N4LWludGVyYWN0aXZlLWRhdGEtdmlldydcblxuICBnZXREYXRhTGF5b3V0U2VsZWN0aW9uID0gdGhpcy5sb2NhdG9yRm9yKERhdGFMYXlvdXRTZWxlY3Rpb25IYXJuZXNzKVxuICBnZXRDb2x1bW5Hcm91cFNlbGVjdGlvbkRyb3Bkb3duID0gdGhpcy5sb2NhdG9yRm9yT3B0aW9uYWwoXG4gICAgUERyb3Bkb3duSGFybmVzcy53aXRoKHsgaWQ6ICdjb2x1bW5Hcm91cFNlbGVjdGlvbkRyb3Bkb3duJyB9KVxuICApXG4gIGdldEN1c3RvbUdyb3VwQ29sdW1uU2VsZWN0b3IgPSB0aGlzLmxvY2F0b3JGb3JPcHRpb25hbChDdXN0b21Hcm91cENvbHVtblNlbGVjdG9ySGFybmVzcylcbiAgZ2V0Q3VzdG9tR3JvdXBDb2x1bW5TZWxlY3RvclNsb3QgPSB0aGlzLmxvY2F0b3JGb3JPcHRpb25hbChTbG90SGFybmVzcylcbiAgZ2V0RGF0YUxpc3RHcmlkU29ydGluZ0Ryb3Bkb3duID0gdGhpcy5sb2NhdG9yRm9yT3B0aW9uYWwoUERyb3Bkb3duSGFybmVzcy53aXRoKHsgaWQ6ICdkYXRhTGlzdEdyaWRTb3J0aW5nRHJvcGRvd24nIH0pKVxuICBnZXREYXRhTGlzdEdyaWRTb3J0aW5nQnV0dG9uID0gdGhpcy5sb2NhdG9yRm9yT3B0aW9uYWwoUEJ1dHRvbkhhcm5lc3Mud2l0aCh7IGlkOiAnZGF0YUxpc3RHcmlkU29ydGluZ0J1dHRvbicgfSkpXG4gIGdldERhdGFWaWV3ID0gdGhpcy5sb2NhdG9yRm9yKERhdGFWaWV3SGFybmVzcylcbn1cbiJdfQ==
|
|
@@ -1,13 +1,11 @@
|
|
|
1
1
|
import { ComponentHarness } from '@angular/cdk/testing';
|
|
2
2
|
import { PButtonHarness } from '@onecx/angular-testing';
|
|
3
3
|
import { PageHeaderHarness } from './page-header.harness';
|
|
4
|
-
import { SearchConfigHarness } from './search-config.harness';
|
|
5
4
|
import { MoreActionsMenuButtonHarness } from './more-actions-menu-button.harness';
|
|
6
5
|
export class SearchHeaderHarness extends ComponentHarness {
|
|
7
6
|
constructor() {
|
|
8
7
|
super(...arguments);
|
|
9
8
|
this.getPageHeader = this.locatorFor(PageHeaderHarness);
|
|
10
|
-
this.getSearchConfig = this.locatorFor(SearchConfigHarness);
|
|
11
9
|
this.getSearchButton = this.locatorFor(PButtonHarness.with({
|
|
12
10
|
id: 'searchButton',
|
|
13
11
|
}));
|
|
@@ -35,4 +33,4 @@ export class SearchHeaderHarness extends ComponentHarness {
|
|
|
35
33
|
}
|
|
36
34
|
}
|
|
37
35
|
}
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhcmNoLWhlYWRlci5oYXJuZXNzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLWFjY2VsZXJhdG9yL3Rlc3Rpbmcvc2VhcmNoLWhlYWRlci5oYXJuZXNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFBO0FBQ3ZELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQTtBQUN2RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQTtBQUN6RCxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQTtBQUVqRixNQUFNLE9BQU8sbUJBQW9CLFNBQVEsZ0JBQWdCO0lBQXpEOztRQUdFLGtCQUFhLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFBO1FBQ2xELG9CQUFlLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FDL0IsY0FBYyxDQUFDLElBQUksQ0FBQztZQUNsQixFQUFFLEVBQUUsY0FBYztTQUNuQixDQUFDLENBQ0gsQ0FBQTtRQUVELG1CQUFjLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FDOUIsY0FBYyxDQUFDLElBQUksQ0FBQztZQUNsQixFQUFFLEVBQUUsYUFBYTtTQUNsQixDQUFDLENBQ0gsQ0FBQTtRQUVELDRCQUF1QixHQUFHLElBQUksQ0FBQyxrQkFBa0IsQ0FDL0MsY0FBYyxDQUFDLElBQUksQ0FBQztZQUNsQixFQUFFLEVBQUUsc0JBQXNCO1NBQzNCLENBQUMsQ0FDSCxDQUFBO1FBRUQsNkJBQXdCLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDLDRCQUE0QixDQUFDLENBQUE7SUFpQmxGLENBQUM7YUF0Q1EsaUJBQVksR0FBRyxtQkFBbUIsQUFBdEIsQ0FBc0I7SUF1QnpDLEtBQUssQ0FBQyxnQkFBZ0I7UUFDcEIsTUFBTSxDQUFDLE1BQU0sSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDLENBQUMsS0FBSyxFQUFFLENBQUE7SUFDN0MsQ0FBQztJQUVELEtBQUssQ0FBQyxpQkFBaUI7UUFDckIsTUFBTSxDQUFDLE1BQU0sSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDLENBQUMsS0FBSyxFQUFFLENBQUE7SUFDOUMsQ0FBQztJQUVELEtBQUssQ0FBQyxvQkFBb0I7UUFDeEIsSUFBSSxNQUFNLElBQUksQ0FBQyx1QkFBdUIsRUFBRSxFQUFFLENBQUM7WUFDekMsTUFBTSxDQUFDLE1BQU0sSUFBSSxDQUFDLHVCQUF1QixFQUFFLENBQUMsRUFBRSxLQUFLLEVBQUUsQ0FBQTtRQUN2RCxDQUFDO2FBQU0sQ0FBQztZQUNOLE9BQU8sQ0FBQyxJQUFJLENBQUMsa0dBQWtHLENBQUMsQ0FBQTtRQUNsSCxDQUFDO0lBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudEhhcm5lc3MgfSBmcm9tICdAYW5ndWxhci9jZGsvdGVzdGluZydcbmltcG9ydCB7IFBCdXR0b25IYXJuZXNzIH0gZnJvbSAnQG9uZWN4L2FuZ3VsYXItdGVzdGluZydcbmltcG9ydCB7IFBhZ2VIZWFkZXJIYXJuZXNzIH0gZnJvbSAnLi9wYWdlLWhlYWRlci5oYXJuZXNzJ1xuaW1wb3J0IHsgTW9yZUFjdGlvbnNNZW51QnV0dG9uSGFybmVzcyB9IGZyb20gJy4vbW9yZS1hY3Rpb25zLW1lbnUtYnV0dG9uLmhhcm5lc3MnXG5cbmV4cG9ydCBjbGFzcyBTZWFyY2hIZWFkZXJIYXJuZXNzIGV4dGVuZHMgQ29tcG9uZW50SGFybmVzcyB7XG4gIHN0YXRpYyBob3N0U2VsZWN0b3IgPSAnb2N4LXNlYXJjaC1oZWFkZXInXG5cbiAgZ2V0UGFnZUhlYWRlciA9IHRoaXMubG9jYXRvckZvcihQYWdlSGVhZGVySGFybmVzcylcbiAgZ2V0U2VhcmNoQnV0dG9uID0gdGhpcy5sb2NhdG9yRm9yKFxuICAgIFBCdXR0b25IYXJuZXNzLndpdGgoe1xuICAgICAgaWQ6ICdzZWFyY2hCdXR0b24nLFxuICAgIH0pXG4gIClcblxuICBnZXRSZXNldEJ1dHRvbiA9IHRoaXMubG9jYXRvckZvcihcbiAgICBQQnV0dG9uSGFybmVzcy53aXRoKHtcbiAgICAgIGlkOiAncmVzZXRCdXR0b24nLFxuICAgIH0pXG4gIClcblxuICBnZXRTaW1wbGVBZHZhbmNlZEJ1dHRvbiA9IHRoaXMubG9jYXRvckZvck9wdGlvbmFsKFxuICAgIFBCdXR0b25IYXJuZXNzLndpdGgoe1xuICAgICAgaWQ6ICdzaW1wbGVBZHZhbmNlZEJ1dHRvbicsXG4gICAgfSlcbiAgKVxuXG4gIGdldE1vcmVBY3Rpb25zTWVudUJ1dHRvbiA9IHRoaXMubG9jYXRvckZvck9wdGlvbmFsKE1vcmVBY3Rpb25zTWVudUJ1dHRvbkhhcm5lc3MpXG5cbiAgYXN5bmMgY2xpY2tSZXNldEJ1dHRvbigpIHtcbiAgICBhd2FpdCAoYXdhaXQgdGhpcy5nZXRSZXNldEJ1dHRvbigpKS5jbGljaygpXG4gIH1cblxuICBhc3luYyBjbGlja1NlYXJjaEJ1dHRvbigpIHtcbiAgICBhd2FpdCAoYXdhaXQgdGhpcy5nZXRTZWFyY2hCdXR0b24oKSkuY2xpY2soKVxuICB9XG5cbiAgYXN5bmMgdG9nZ2xlU2ltcGxlQWR2YW5jZWQoKSB7XG4gICAgaWYgKGF3YWl0IHRoaXMuZ2V0U2ltcGxlQWR2YW5jZWRCdXR0b24oKSkge1xuICAgICAgYXdhaXQgKGF3YWl0IHRoaXMuZ2V0U2ltcGxlQWR2YW5jZWRCdXR0b24oKSk/LmNsaWNrKClcbiAgICB9IGVsc2Uge1xuICAgICAgY29uc29sZS53YXJuKCdObyBTaW1wbGVBZHZhbmNlZEJ1dHRvbiBpcyBiZWluZyBkaXNwbGF5ZWQgdG8gdG9nZ2xlLCBiZWNhdXNlIG5vIGFkdmFuY2VkIGZvcm0gZmllbGQgaXMgZGVmaW5lZC4nKVxuICAgIH1cbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { ContentContainerComponentHarness } from '@angular/cdk/testing';
|
|
2
|
+
export class SlotHarness extends ContentContainerComponentHarness {
|
|
3
|
+
static { this.hostSelector = 'ocx-slot'; }
|
|
4
|
+
}
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xvdC5oYXJuZXNzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLWFjY2VsZXJhdG9yL3Rlc3Rpbmcvc2xvdC5oYXJuZXNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBc0IsZ0NBQWdDLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQTtBQU0zRixNQUFNLE9BQU8sV0FBWSxTQUFRLGdDQUFnQzthQUN4RCxpQkFBWSxHQUFHLFVBQVUsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJhc2VIYXJuZXNzRmlsdGVycywgQ29udGVudENvbnRhaW5lckNvbXBvbmVudEhhcm5lc3MgfSBmcm9tICdAYW5ndWxhci9jZGsvdGVzdGluZydcblxuZXhwb3J0IGludGVyZmFjZSBTbG90SGFybmVzc0ZpbHRlcnMgZXh0ZW5kcyBCYXNlSGFybmVzc0ZpbHRlcnMge1xuICBuYW1lPzogc3RyaW5nXG59XG5cbmV4cG9ydCBjbGFzcyBTbG90SGFybmVzcyBleHRlbmRzIENvbnRlbnRDb250YWluZXJDb21wb25lbnRIYXJuZXNzIHtcbiAgc3RhdGljIGhvc3RTZWxlY3RvciA9ICdvY3gtc2xvdCdcbn1cbiJdfQ==
|
|
@@ -288,12 +288,17 @@ class GroupByCountDiagramHarness extends ComponentHarness {
|
|
|
288
288
|
static { this.hostSelector = 'ocx-group-by-count-diagram'; }
|
|
289
289
|
}
|
|
290
290
|
|
|
291
|
+
class SlotHarness extends ContentContainerComponentHarness {
|
|
292
|
+
static { this.hostSelector = 'ocx-slot'; }
|
|
293
|
+
}
|
|
294
|
+
|
|
291
295
|
class InteractiveDataViewHarness extends ContentContainerComponentHarness {
|
|
292
296
|
constructor() {
|
|
293
297
|
super(...arguments);
|
|
294
298
|
this.getDataLayoutSelection = this.locatorFor(DataLayoutSelectionHarness);
|
|
295
299
|
this.getColumnGroupSelectionDropdown = this.locatorForOptional(PDropdownHarness.with({ id: 'columnGroupSelectionDropdown' }));
|
|
296
|
-
this.getCustomGroupColumnSelector = this.
|
|
300
|
+
this.getCustomGroupColumnSelector = this.locatorForOptional(CustomGroupColumnSelectorHarness);
|
|
301
|
+
this.getCustomGroupColumnSelectorSlot = this.locatorForOptional(SlotHarness);
|
|
297
302
|
this.getDataListGridSortingDropdown = this.locatorForOptional(PDropdownHarness.with({ id: 'dataListGridSortingDropdown' }));
|
|
298
303
|
this.getDataListGridSortingButton = this.locatorForOptional(PButtonHarness.with({ id: 'dataListGridSortingButton' }));
|
|
299
304
|
this.getDataView = this.locatorFor(DataViewHarness);
|
|
@@ -380,19 +385,10 @@ class ObjectDetailItemHarness extends ComponentHarness {
|
|
|
380
385
|
}
|
|
381
386
|
}
|
|
382
387
|
|
|
383
|
-
class SearchConfigHarness extends ContentContainerComponentHarness {
|
|
384
|
-
constructor() {
|
|
385
|
-
super(...arguments);
|
|
386
|
-
this.getSearchConfigDropdown = this.locatorForOptional(PDropdownHarness.with({ id: 'searchConfig' }));
|
|
387
|
-
}
|
|
388
|
-
static { this.hostSelector = 'ocx-search-config'; }
|
|
389
|
-
}
|
|
390
|
-
|
|
391
388
|
class SearchHeaderHarness extends ComponentHarness {
|
|
392
389
|
constructor() {
|
|
393
390
|
super(...arguments);
|
|
394
391
|
this.getPageHeader = this.locatorFor(PageHeaderHarness);
|
|
395
|
-
this.getSearchConfig = this.locatorFor(SearchConfigHarness);
|
|
396
392
|
this.getSearchButton = this.locatorFor(PButtonHarness.with({
|
|
397
393
|
id: 'searchButton',
|
|
398
394
|
}));
|
|
@@ -425,5 +421,5 @@ class SearchHeaderHarness extends ComponentHarness {
|
|
|
425
421
|
* Generated bundle index. Do not edit.
|
|
426
422
|
*/
|
|
427
423
|
|
|
428
|
-
export { ColumnGroupSelectionHarness, CustomGroupColumnSelectorHarness, DataLayoutSelectionHarness, DataListGridHarness, DataTableHarness, DataViewHarness, DefaultGridItemHarness, DefaultListItemHarness, DiagramHarness, GroupByCountDiagramHarness, InteractiveDataViewHarness, MoreActionsMenuButtonHarness, PageHeaderHarness,
|
|
424
|
+
export { ColumnGroupSelectionHarness, CustomGroupColumnSelectorHarness, DataLayoutSelectionHarness, DataListGridHarness, DataTableHarness, DataViewHarness, DefaultGridItemHarness, DefaultListItemHarness, DiagramHarness, GroupByCountDiagramHarness, InteractiveDataViewHarness, MoreActionsMenuButtonHarness, PageHeaderHarness, SearchHeaderHarness, SlotHarness };
|
|
429
425
|
//# sourceMappingURL=onecx-angular-accelerator-testing.mjs.map
|