@onecx/angular-accelerator 5.8.0 → 5.9.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/LICENSE +201 -0
- package/esm2022/lib/components/column-group-selection/column-group-selection.component.mjs +17 -2
- package/esm2022/lib/components/custom-group-column-selector/custom-group-column-selector.component.mjs +30 -4
- package/esm2022/lib/components/data-layout-selection/data-layout-selection.component.mjs +11 -2
- package/esm2022/lib/components/data-list-grid/data-list-grid.component.mjs +26 -3
- package/esm2022/lib/components/data-list-grid-sorting/data-list-grid-sorting.component.mjs +17 -3
- package/esm2022/lib/components/data-table/data-table.component.mjs +45 -3
- package/esm2022/lib/components/data-view/data-view.component.mjs +33 -4
- package/esm2022/lib/components/diagram/diagram.component.mjs +8 -2
- package/esm2022/lib/components/group-by-count-diagram/group-by-count-diagram.component.mjs +8 -2
- package/esm2022/lib/components/interactive-data-view/interactive-data-view.component.mjs +76 -9
- package/esm2022/lib/components/search-header/search-header.component.mjs +11 -2
- package/esm2022/lib/utils/rxjs-utils.mjs +13 -0
- package/fesm2022/onecx-angular-accelerator.mjs +279 -22
- package/fesm2022/onecx-angular-accelerator.mjs.map +1 -1
- package/lib/components/column-group-selection/column-group-selection.component.d.ts +6 -1
- package/lib/components/custom-group-column-selector/custom-group-column-selector.component.d.ts +13 -3
- package/lib/components/data-layout-selection/data-layout-selection.component.d.ts +5 -1
- package/lib/components/data-list-grid/data-list-grid.component.d.ts +8 -1
- package/lib/components/data-list-grid-sorting/data-list-grid-sorting.component.d.ts +12 -2
- package/lib/components/data-table/data-table.component.d.ts +11 -1
- package/lib/components/data-view/data-view.component.d.ts +10 -4
- package/lib/components/diagram/diagram.component.d.ts +5 -1
- package/lib/components/group-by-count-diagram/group-by-count-diagram.component.d.ts +5 -1
- package/lib/components/interactive-data-view/interactive-data-view.component.d.ts +27 -7
- package/lib/components/search-header/search-header.component.d.ts +6 -1
- package/lib/utils/rxjs-utils.d.ts +3 -0
- package/package.json +1 -1
|
@@ -23,6 +23,7 @@ export class SearchHeaderComponent {
|
|
|
23
23
|
this.resetted = new EventEmitter();
|
|
24
24
|
this.selectedSearchConfigChanged = new EventEmitter();
|
|
25
25
|
this.viewModeChanged = new EventEmitter();
|
|
26
|
+
this.componentStateChanged = new EventEmitter();
|
|
26
27
|
this.hasAdvanced = false;
|
|
27
28
|
this.headerActions = [];
|
|
28
29
|
}
|
|
@@ -54,6 +55,9 @@ export class SearchHeaderComponent {
|
|
|
54
55
|
toggleViewMode() {
|
|
55
56
|
this.viewMode = this.viewMode === 'basic' ? 'advanced' : 'basic';
|
|
56
57
|
this.viewModeChanged?.emit(this.viewMode);
|
|
58
|
+
this.componentStateChanged.emit({
|
|
59
|
+
activeViewMode: this.viewMode
|
|
60
|
+
});
|
|
57
61
|
this.updateHeaderActions();
|
|
58
62
|
setTimeout(() => this.addKeyUpEventListener());
|
|
59
63
|
}
|
|
@@ -96,9 +100,12 @@ export class SearchHeaderComponent {
|
|
|
96
100
|
}
|
|
97
101
|
confirmSearchConfig(searchConfig) {
|
|
98
102
|
this.selectedSearchConfigChanged?.emit(searchConfig);
|
|
103
|
+
this.componentStateChanged.emit({
|
|
104
|
+
selectedSearchConfig: searchConfig
|
|
105
|
+
});
|
|
99
106
|
}
|
|
100
107
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: SearchHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
101
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", 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=\"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 [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</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: "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" }] }); }
|
|
108
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", 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", componentStateChanged: "componentStateChanged" }, 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=\"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 [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</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: "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" }] }); }
|
|
102
109
|
}
|
|
103
110
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: SearchHeaderComponent, decorators: [{
|
|
104
111
|
type: Component,
|
|
@@ -129,6 +136,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
129
136
|
type: Output
|
|
130
137
|
}], viewModeChanged: [{
|
|
131
138
|
type: Output
|
|
139
|
+
}], componentStateChanged: [{
|
|
140
|
+
type: Output
|
|
132
141
|
}], additionalToolbarContent: [{
|
|
133
142
|
type: ContentChild,
|
|
134
143
|
args: ['additionalToolbarContent']
|
|
@@ -139,4 +148,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
139
148
|
type: ViewChild,
|
|
140
149
|
args: ['searchParameterFields']
|
|
141
150
|
}] } });
|
|
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})\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=\"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        [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</ocx-page-header>\n"]}
|
|
151
|
+
//# 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        [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</ocx-page-header>\n"]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export function orderValuesByTimestamp(valuesWithTimestamp) {
|
|
2
|
+
return valuesWithTimestamp.sort((a, b) => b.timestamp - a.timestamp).map((obj) => obj.value);
|
|
3
|
+
}
|
|
4
|
+
function mergeValues(values) {
|
|
5
|
+
return values.reduce((acc, curr) => {
|
|
6
|
+
return { ...acc, ...curr };
|
|
7
|
+
});
|
|
8
|
+
}
|
|
9
|
+
export function orderAndMergeValuesByTimestamp(valuesWithTimestamp) {
|
|
10
|
+
const sortedValues = valuesWithTimestamp.sort((a, b) => a.timestamp - b.timestamp).map((obj) => obj.value);
|
|
11
|
+
return mergeValues(sortedValues);
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnhqcy11dGlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci1hY2NlbGVyYXRvci9zcmMvbGliL3V0aWxzL3J4anMtdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxVQUFVLHNCQUFzQixDQUFDLG1CQUFxQztJQUMxRSxPQUFPLG1CQUFtQixDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxTQUFTLEdBQUcsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFBO0FBQzlGLENBQUM7QUFFRCxTQUFTLFdBQVcsQ0FBQyxNQUFhO0lBQ2hDLE9BQU8sTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxJQUFJLEVBQUUsRUFBRTtRQUNqQyxPQUFPLEVBQUUsR0FBRyxHQUFHLEVBQUUsR0FBRyxJQUFJLEVBQUUsQ0FBQTtJQUM1QixDQUFDLENBQUMsQ0FBQTtBQUNKLENBQUM7QUFFRCxNQUFNLFVBQVUsOEJBQThCLENBQUMsbUJBQXFDO0lBQ2xGLE1BQU0sWUFBWSxHQUFHLG1CQUFtQixDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxTQUFTLEdBQUcsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFBO0lBQzFHLE9BQU8sV0FBVyxDQUFDLFlBQVksQ0FBQyxDQUFBO0FBQ2xDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUaW1lc3RhbXAgfSBmcm9tICdyeGpzJ1xuXG5leHBvcnQgZnVuY3Rpb24gb3JkZXJWYWx1ZXNCeVRpbWVzdGFtcCh2YWx1ZXNXaXRoVGltZXN0YW1wOiBUaW1lc3RhbXA8YW55PltdKSB7XG4gIHJldHVybiB2YWx1ZXNXaXRoVGltZXN0YW1wLnNvcnQoKGEsIGIpID0+IGIudGltZXN0YW1wIC0gYS50aW1lc3RhbXApLm1hcCgob2JqKSA9PiBvYmoudmFsdWUpXG59XG5cbmZ1bmN0aW9uIG1lcmdlVmFsdWVzKHZhbHVlczogYW55W10pIHtcbiAgcmV0dXJuIHZhbHVlcy5yZWR1Y2UoKGFjYywgY3VycikgPT4ge1xuICAgIHJldHVybiB7IC4uLmFjYywgLi4uY3VyciB9XG4gIH0pXG59XG5cbmV4cG9ydCBmdW5jdGlvbiBvcmRlckFuZE1lcmdlVmFsdWVzQnlUaW1lc3RhbXAodmFsdWVzV2l0aFRpbWVzdGFtcDogVGltZXN0YW1wPGFueT5bXSkge1xuICBjb25zdCBzb3J0ZWRWYWx1ZXMgPSB2YWx1ZXNXaXRoVGltZXN0YW1wLnNvcnQoKGEsIGIpID0+IGEudGltZXN0YW1wIC0gYi50aW1lc3RhbXApLm1hcCgob2JqKSA9PiBvYmoudmFsdWUpXG4gIHJldHVybiBtZXJnZVZhbHVlcyhzb3J0ZWRWYWx1ZXMpXG59XG4iXX0=
|