@onecx/angular-accelerator 5.28.0 → 5.29.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/assets/i18n/de.json +1 -0
- package/assets/i18n/en.json +1 -0
- package/esm2022/lib/components/data-table/data-table.component.mjs +14 -13
- package/esm2022/lib/components/page-header/page-header.component.mjs +2 -1
- package/fesm2022/onecx-angular-accelerator.mjs +19 -18
- package/fesm2022/onecx-angular-accelerator.mjs.map +1 -1
- package/package.json +5 -5
|
@@ -138,6 +138,7 @@ export class PageHeaderComponent {
|
|
|
138
138
|
});
|
|
139
139
|
this.overflowActions = [
|
|
140
140
|
...allowedActions.map((a) => ({
|
|
141
|
+
id: a.id,
|
|
141
142
|
label: a.labelKey ? translations[a.labelKey] : a.label,
|
|
142
143
|
icon: a.icon,
|
|
143
144
|
tooltipOptions: {
|
|
@@ -234,4 +235,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
|
|
|
234
235
|
type: ContentChild,
|
|
235
236
|
args: ['additionalToolbarContentLeft']
|
|
236
237
|
}] } });
|
|
237
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-header.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/page-header/page-header.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/page-header/page-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ContentChild,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  Type,\n  ViewEncapsulation,\n} from '@angular/core'\nimport { TranslateService } from '@ngx-translate/core'\nimport { MenuItem, PrimeIcons } from 'primeng/api'\nimport { concat, map, Observable, of } from 'rxjs'\nimport { AppStateService } from '@onecx/angular-integration-interface'\nimport { UserService } from '@onecx/angular-integration-interface'\nimport { BreadcrumbService } from '../../services/breadcrumb.service'\nimport { PrimeIcon } from '../../utils/primeicon.utils'\n\n/**\n * Action definition.\n */\nexport interface Action {\n  id?: string\n  label?: string\n  labelKey?: string\n  icon?: string\n  /**\n   * Permission for this action. If the current user does not have this permission, the action will not be shown.\n   */\n  permission?: string\n  title?: string\n  titleKey?: string\n  ariaLabel?: string\n  ariaLabelKey?: string\n  btnClass?: string\n  actionCallback(): void\n  disabled?: boolean\n  show?: 'always' | 'asOverflow'\n  conditional?: boolean\n  // Note: This currently doesn't work with dynamic values, since a passed in Action is just a copy of the original object.\n  // As a workaround, you can manually update/replace the passed in Action if you wish to update a showCondition\n  showCondition?: boolean\n}\n\nexport interface ObjectDetailItem {\n  label: string\n  value?: string\n  /**\n   * @deprecated Use `valueTooltip` instead\n   */\n  tooltip?: string\n  labelTooltip?: string\n  valueTooltip?: string\n  icon?: PrimeIcon\n  iconStyleClass?: string\n  labelPipe?: Type<any>\n  valuePipe?: Type<any>\n  valuePipeArgs?: string\n  valueCssClass?: string\n  actionItemIcon?: PrimeIcon\n  actionItemCallback?: () => void\n  actionItemTooltip?: string\n  actionItemAriaLabelKey?: string\n  actionItemAriaLabel?: string\n}\n\nexport interface HomeItem {\n  menuItem: MenuItem\n  page?: string\n}\n\nexport type GridColumnOptions = 1 | 2 | 3 | 4 | 6 | 12\n\n@Component({\n  selector: 'ocx-page-header',\n  templateUrl: './page-header.component.html',\n  styleUrls: ['./page-header.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class PageHeaderComponent implements OnInit, OnChanges {\n  @Input()\n  public header: string | undefined\n\n  @Input()\n  loading = false\n\n  @Input()\n  figureBackground = true\n\n  @Input()\n  showFigure = true\n\n  //image fot preview in top-header left side\n  @Input()\n  figureImage: string | undefined\n\n  @Input()\n  disableDefaultActions = false\n\n  @Input()\n  subheader: string | undefined\n\n  _actions: Action[] | undefined\n  @Input()\n  get actions() {\n    return this._actions\n  }\n  set actions(value) {\n    this._actions = value\n    this.generateInlineActions()\n    this.generateOverflowActions()\n  }\n\n  @Input()\n  objectDetails: ObjectDetailItem[] | undefined\n\n  @Input()\n  showBreadcrumbs = true\n\n  @Input()\n  manualBreadcrumbs = false\n\n  @Input()\n  enableGridView: undefined | boolean\n\n  @Input()\n  gridLayoutDesktopColumns: undefined | GridColumnOptions\n\n  @Output()\n  save = new EventEmitter()\n\n  @ContentChild('additionalToolbarContent')\n  additionalToolbarContent: TemplateRef<any> | undefined\n\n  @ContentChild('additionalToolbarContentLeft')\n  additionalToolbarContentLeft: TemplateRef<any> | undefined\n\n  overflowActions: MenuItem[] = []\n  inlineActions: Action[] | undefined\n  dd = new Date()\n  breadcrumbs$!: Observable<MenuItem[]>\n\n  home$!: Observable<HomeItem>\n\n  figureImageLoadError = false\n\n  objectPanelGridLayoutClasses = 'grid row-gap-2 m-0'\n  objectPanelColumnLayoutClasses = 'flex flex-row justify-content-between overflow-x-auto'\n\n  objectPanelDefaultLayoutClasses = 'flex flex-column row-gap-2 md:flex-row md:justify-content-between'\n\n  objectInfoGridLayoutClasses = 'col-12 flex gap-4 md:col-6 align-items-center p-0'\n  objectInfoColumnLayoutClasses = 'flex flex-column align-items-center gap-2 min-w-120'\n\n  objectInfoDefaultLayoutClasses = 'flex flex-row md:flex-column md:align-items-center md:gap-2'\n\n  protected breadcrumbs: BreadcrumbService\n\n  constructor(\n    breadcrumbs: BreadcrumbService,\n    private translateService: TranslateService,\n    private appStateService: AppStateService,\n    private userService: UserService\n  ) {\n    this.breadcrumbs = breadcrumbs\n    this.home$ = concat(\n      of({ menuItem: { icon: PrimeIcons.HOME, routerLink: '/' } }),\n      this.appStateService.currentPortal$.pipe(\n        map((portal) => ({\n          menuItem: {\n            icon: PrimeIcons.HOME,\n            routerLink: portal.baseUrl,\n          },\n          page: portal.portalName,\n        }))\n      )\n    )\n  }\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['actions']) {\n      this.generateInlineActions()\n      this.generateOverflowActions()\n    }\n  }\n\n  ngOnInit(): void {\n    if (!this.manualBreadcrumbs) {\n      this.breadcrumbs$ = this.breadcrumbs.generatedItemsSource\n    } else {\n      this.breadcrumbs$ = this.breadcrumbs.itemsHandler\n    }\n    this.generateInlineActions()\n    this.generateOverflowActions()\n  }\n\n  onAction(action: string) {\n    switch (action) {\n      case 'save':\n        this.save.emit()\n        break\n      default:\n        break\n    }\n  }\n\n  handleImageError() {\n    this.figureImageLoadError = true\n  }\n\n  public generateItemStyle(item: ObjectDetailItem): string {\n    let style = ''\n    if (item.icon) style = style.concat(style, ' ', 'gap-1 align-items-center')\n    if (item.valueCssClass) style = style.concat(style, ' ', item.valueCssClass)\n    return style\n  }\n\n  public getObjectPanelLayoutClasses() {\n    if (this.enableGridView) {\n      return this.objectPanelGridLayoutClasses\n    }\n    if (this.enableGridView === false) {\n      return this.objectPanelColumnLayoutClasses\n    }\n    return this.objectPanelDefaultLayoutClasses\n  }\n\n  public getObjectInfoLayoutClasses() {\n    if (this.enableGridView) {\n      return `${this.objectInfoGridLayoutClasses} lg:col-${\n        this.gridLayoutDesktopColumns ? 12 / this.gridLayoutDesktopColumns : 4\n      }`\n    }\n    if (this.enableGridView === false) {\n      return this.objectInfoColumnLayoutClasses\n    }\n    return this.objectInfoDefaultLayoutClasses\n  }\n\n  /**\n   * Generates a list of actions that should be rendered in an overflow menu\n   */\n  private generateOverflowActions() {\n    if (this.actions) {\n      const translationKeys: string[] = [\n        ...this.actions.map((a) => a.labelKey || '').filter((a) => !!a),\n        ...this.actions.map((a) => a.titleKey || '').filter((a) => !!a),\n      ]\n      const translations$ = translationKeys.length ? this.translateService.get(translationKeys) : of([])\n      translations$.subscribe((translations) => {\n        const allowedActions: Action[] = []\n        if (this.actions) {\n          this.actions\n            .filter((a) => a.show === 'asOverflow')\n            .filter((a) => {\n              if (a.conditional) {\n                if (a.showCondition) return a\n                return null\n              } else return a\n            })\n            .forEach((action) => {\n              this.checkActionPermission(allowedActions, action)\n            })\n          this.overflowActions = [\n            ...allowedActions.map<MenuItem>((a) => ({\n              label: a.labelKey ? translations[a.labelKey] : a.label,\n              icon: a.icon,\n              tooltipOptions: {\n                tooltipLabel: a.titleKey ? translations[a.titleKey] : a.title,\n                tooltipEvent: 'hover',\n                tooltipPosition: 'top',\n              },\n              command: a.actionCallback,\n              disabled: a.disabled,\n            })),\n          ]\n        }\n      })\n    }\n  }\n\n  /**\n   * Generates a list of actions that should be rendered as inline buttons\n   */\n  private generateInlineActions() {\n    if (this.actions) {\n      // Temp array to hold all inline actions that should be visible to the current user\n      const allowedActions: Action[] = []\n      // Check permissions for all actions that should be rendered 'always'\n      this.actions\n        .filter((a) => a.show === 'always')\n        .filter((a) => {\n          if (a.conditional) {\n            return a.showCondition ? a : null\n          } else return a\n        })\n        .forEach((action) => {\n          this.checkActionPermission(allowedActions, action)\n        })\n      this.inlineActions = [...allowedActions]\n    }\n  }\n  /**\n   * Adds a given action to a given array if the current user is allowed to see it\n   * @param allowedActions Array that the action should be added to if the current user is allowed to see it\n   * @param action Action for which a permission check should be executed\n   */\n  private checkActionPermission(allowedActions: Action[], action: Action) {\n    if (action.permission) {\n      if (this.userService.hasPermission(action.permission)) {\n        // Push action to allowed array if user has sufficient permissions\n        allowedActions.push(action)\n      }\n    } else {\n      // Push action to allowed array if no permission was specified\n      allowedActions.push(action)\n    }\n  }\n}\n","<div class=\"onecx-page-header mb-4\" name=\"ocx-page-header-wrapper\">\n  <ng-container *ngIf=\"showBreadcrumbs\">\n    <p-breadcrumb\n      [model]=\"items\"\n      *ngIf=\"breadcrumbs$ | async  as items\"\n      [home]=\"(home$ | async)?.menuItem ?? {}\"\n      [homeAriaLabel]=\"(home$ | async)?.page ? ('OCX_PAGE_HEADER.HOME_ARIA_LABEL' | translate: { page: (home$ | async)?.page}) : ('OCX_PAGE_HEADER.HOME_DEFAULT_ARIA_LABEL' | translate)\"\n      [attr.manual]=\"manualBreadcrumbs\"\n    ></p-breadcrumb>\n  </ng-container>\n  <div class=\"title-bar flex flex-row md:justify-content-between p-3\">\n    <div class=\"title-wrap\">\n      <div class=\"figure flex h-2rem w-2rem md:h-3rem md:w-3rem\" *ngIf=\"showFigure\">\n        <div #previewImage class=\"figure-image absolute top-0 left-0 right-0 bottom-0\">\n          <ng-content select=\"[figureImage]\"></ng-content>\n          <img\n            *ngIf=\"figureImage && !figureImageLoadError\"\n            [ocxSrc]=\"figureImage\"\n            alt=\"Figure image\"\n            class=\"w-full\"\n            (error)=\"handleImageError()\"\n          />\n        </div>\n        <div\n          class=\"colorblob flex-1 border-round\"\n          *ngIf=\"previewImage.children.length === 0 || figureImageLoadError\"\n        ></div>\n      </div>\n      <ng-template #skeletonBar>\n        <div class=\"header justify-content-evenly\">\n          <p-skeleton width=\"10rem\"></p-skeleton>\n          <p-skeleton width=\"10rem\"></p-skeleton>\n        </div>\n      </ng-template>\n      <div class=\"header\" *ngIf=\"!loading; else skeletonBar\">\n        <h1 id=\"page-header\" *ngIf=\"!!header\">{{ header }}</h1>\n        <h2 id=\"page-subheader\" *ngIf=\"!!subheader\">{{ subheader }}</h2>\n      </div>\n    </div>\n    <div class=\"action-items-wrap mt-2 md:mt-0\">\n      <ng-container *ngIf=\"additionalToolbarContentLeft\" [ngTemplateOutlet]=\"additionalToolbarContentLeft\">\n      </ng-container>\n\n      <ng-container *ngIf=\"!disableDefaultActions\"> </ng-container>\n      <ng-template #skeletonActions>\n        <div class=\"flex\">\n          <p-skeleton width=\"5rem\" height=\"2rem\" styleClass=\"mr-2\"></p-skeleton>\n          <p-skeleton width=\"2rem\" height=\"2rem\" styleClass=\"mb-2\"></p-skeleton>\n        </div>\n      </ng-template>\n      <ng-container *ngIf=\"!loading; else skeletonActions\">\n        <div *ngIf=\"inlineActions && inlineActions.length > 0\" class=\"toolbar flex flex-wrap gap-1 sm:gap-2\">\n          <ng-container *ngFor=\"let action of inlineActions\">\n            <p-button\n              id=\"{{ action.id }}\"\n              [icon]=\"action.icon ?? ''\"\n              type=\"button\"\n              class=\"action-button\"\n              [label]=\"action.labelKey ? (action.labelKey | translate) : action.label\"\n              (onClick)=\"action.actionCallback()\"\n              [pTooltip]=\"(action.titleKey ? (action.titleKey | translate) : action.title)\"\n              tooltipPosition=\"top\"\n              tooltipEvent=\"hover\"\n              [disabled]=\"action.disabled ? action.disabled : false\"\n              [attr.name]=\"action.icon ? 'ocx-page-header-inline-action-icon-button' : 'ocx-page-header-inline-action-button'\"\n              [ariaLabel]=\" (action.ariaLabelKey ? (action.ariaLabelKey | translate) : action.ariaLabel) || (action.titleKey ? (action.titleKey | translate) : action.title) || (action.labelKey ? (action.labelKey | translate) : action.label)\"\n            ></p-button>\n          </ng-container>\n        </div>\n        <ng-content select=\"[toolbarItems]\"></ng-content>\n        <ng-container>\n          <div *ngIf=\"overflowActions.length !== 0\">\n            <button\n              id=\"pageHeaderMenuButton\"\n              type=\"button\"\n              pButton\n              icon=\"pi pi-ellipsis-v\"\n              pTooltip=\"{{ 'OCX_PAGE_HEADER.MORE_ACTIONS' | translate }}\"\n              tooltipEvent=\"hover\"\n              tooltipPosition=\"top\"\n              class=\"more-actions-menu-button action-button ml-2\"\n              (click)=\"menu.toggle($event)\"\n              name=\"ocx-page-header-overflow-action-button\"\n              [attr.aria-label]=\"('OCX_PAGE_HEADER.MORE_ACTIONS' | translate)\"\n            ></button>\n            <p-menu #menu [popup]=\"true\" [model]=\"overflowActions\" appendTo=\"body\"></p-menu>\n          </div>\n        </ng-container>\n      </ng-container>\n      <ng-container *ngIf=\"additionalToolbarContent\" [ngTemplateOutlet]=\"additionalToolbarContent\"> </ng-container>\n    </div>\n  </div>\n\n  <div class=\"object-panel\" [ngClass]=\"getObjectPanelLayoutClasses()\">\n    <ng-container *ngIf=\"objectDetails\">\n      <div class=\"object-info\" [ngClass]=\"getObjectInfoLayoutClasses()\" *ngFor=\"let item of objectDetails\">\n        <span\n          class=\"flex font-medium text-600 object-info-grid-label\"\n          name=\"object-detail-label\"\n          [pTooltip]=\"item.labelTooltip || ''\"\n          tooltipEvent=\"hover\"\n          tooltipPosition=\"top\"\n          >{{ item.label | dynamicPipe:item.labelPipe }}</span\n        >\n        <span *ngIf=\"item.icon || item.value\" class=\"object-info-grid-value\">\n          <span\n            class=\"flex text-900 align-items-center gap-2 w-max\"\n            [ngClass]=\"generateItemStyle(item)\"\n            name=\"object-detail-value\"\n          >\n            <span\n              class=\"flex align-items-center gap-2\"\n              [pTooltip]=\"item.valueTooltip || item.tooltip || ''\"\n              tooltipEvent=\"hover\"\n              tooltipPosition=\"top\"\n            >\n              <i\n                *ngIf=\"item.icon\"\n                class='{{item.icon + \" \" + (item.iconStyleClass || \"\")}}'\n                name=\"object-detail-icon\"\n              ></i>\n              {{ item.value | dynamicPipe:item.valuePipe:item.valuePipeArgs}}\n            </span>\n            <p-button\n              *ngIf=\"item.actionItemIcon && item.actionItemCallback\"\n              [icon]=\"item.actionItemIcon\"\n              styleClass=\"p-button-text p-0 w-full\"\n              [pTooltip]=\"item.actionItemTooltip || ''\"\n              tooltipPosition=\"top\"\n              tooltipEvent=\"hover\"\n              [ariaLabel]=\"(item.actionItemAriaLabelKey ? (item.actionItemAriaLabelKey | translate) : item.actionItemAriaLabel) || item.actionItemTooltip || ''\"\n              (onClick)=\"item.actionItemCallback()\"\n            ></p-button>\n          </span>\n        </span>\n      </div>\n    </ng-container>\n    <ng-content></ng-content>\n  </div>\n</div>\n"]}
|
|
238
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-header.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/page-header/page-header.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/page-header/page-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ContentChild,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  Type,\n  ViewEncapsulation,\n} from '@angular/core'\nimport { TranslateService } from '@ngx-translate/core'\nimport { MenuItem, PrimeIcons } from 'primeng/api'\nimport { concat, map, Observable, of } from 'rxjs'\nimport { AppStateService } from '@onecx/angular-integration-interface'\nimport { UserService } from '@onecx/angular-integration-interface'\nimport { BreadcrumbService } from '../../services/breadcrumb.service'\nimport { PrimeIcon } from '../../utils/primeicon.utils'\n\n/**\n * Action definition.\n */\nexport interface Action {\n  id?: string\n  label?: string\n  labelKey?: string\n  icon?: string\n  /**\n   * Permission for this action. If the current user does not have this permission, the action will not be shown.\n   */\n  permission?: string\n  title?: string\n  titleKey?: string\n  ariaLabel?: string\n  ariaLabelKey?: string\n  btnClass?: string\n  actionCallback(): void\n  disabled?: boolean\n  show?: 'always' | 'asOverflow'\n  conditional?: boolean\n  // Note: This currently doesn't work with dynamic values, since a passed in Action is just a copy of the original object.\n  // As a workaround, you can manually update/replace the passed in Action if you wish to update a showCondition\n  showCondition?: boolean\n}\n\nexport interface ObjectDetailItem {\n  label: string\n  value?: string\n  /**\n   * @deprecated Use `valueTooltip` instead\n   */\n  tooltip?: string\n  labelTooltip?: string\n  valueTooltip?: string\n  icon?: PrimeIcon\n  iconStyleClass?: string\n  labelPipe?: Type<any>\n  valuePipe?: Type<any>\n  valuePipeArgs?: string\n  valueCssClass?: string\n  actionItemIcon?: PrimeIcon\n  actionItemCallback?: () => void\n  actionItemTooltip?: string\n  actionItemAriaLabelKey?: string\n  actionItemAriaLabel?: string\n}\n\nexport interface HomeItem {\n  menuItem: MenuItem\n  page?: string\n}\n\nexport type GridColumnOptions = 1 | 2 | 3 | 4 | 6 | 12\n\n@Component({\n  selector: 'ocx-page-header',\n  templateUrl: './page-header.component.html',\n  styleUrls: ['./page-header.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class PageHeaderComponent implements OnInit, OnChanges {\n  @Input()\n  public header: string | undefined\n\n  @Input()\n  loading = false\n\n  @Input()\n  figureBackground = true\n\n  @Input()\n  showFigure = true\n\n  //image fot preview in top-header left side\n  @Input()\n  figureImage: string | undefined\n\n  @Input()\n  disableDefaultActions = false\n\n  @Input()\n  subheader: string | undefined\n\n  _actions: Action[] | undefined\n  @Input()\n  get actions() {\n    return this._actions\n  }\n  set actions(value) {\n    this._actions = value\n    this.generateInlineActions()\n    this.generateOverflowActions()\n  }\n\n  @Input()\n  objectDetails: ObjectDetailItem[] | undefined\n\n  @Input()\n  showBreadcrumbs = true\n\n  @Input()\n  manualBreadcrumbs = false\n\n  @Input()\n  enableGridView: undefined | boolean\n\n  @Input()\n  gridLayoutDesktopColumns: undefined | GridColumnOptions\n\n  @Output()\n  save = new EventEmitter()\n\n  @ContentChild('additionalToolbarContent')\n  additionalToolbarContent: TemplateRef<any> | undefined\n\n  @ContentChild('additionalToolbarContentLeft')\n  additionalToolbarContentLeft: TemplateRef<any> | undefined\n\n  overflowActions: MenuItem[] = []\n  inlineActions: Action[] | undefined\n  dd = new Date()\n  breadcrumbs$!: Observable<MenuItem[]>\n\n  home$!: Observable<HomeItem>\n\n  figureImageLoadError = false\n\n  objectPanelGridLayoutClasses = 'grid row-gap-2 m-0'\n  objectPanelColumnLayoutClasses = 'flex flex-row justify-content-between overflow-x-auto'\n\n  objectPanelDefaultLayoutClasses = 'flex flex-column row-gap-2 md:flex-row md:justify-content-between'\n\n  objectInfoGridLayoutClasses = 'col-12 flex gap-4 md:col-6 align-items-center p-0'\n  objectInfoColumnLayoutClasses = 'flex flex-column align-items-center gap-2 min-w-120'\n\n  objectInfoDefaultLayoutClasses = 'flex flex-row md:flex-column md:align-items-center md:gap-2'\n\n  protected breadcrumbs: BreadcrumbService\n\n  constructor(\n    breadcrumbs: BreadcrumbService,\n    private translateService: TranslateService,\n    private appStateService: AppStateService,\n    private userService: UserService\n  ) {\n    this.breadcrumbs = breadcrumbs\n    this.home$ = concat(\n      of({ menuItem: { icon: PrimeIcons.HOME, routerLink: '/' } }),\n      this.appStateService.currentPortal$.pipe(\n        map((portal) => ({\n          menuItem: {\n            icon: PrimeIcons.HOME,\n            routerLink: portal.baseUrl,\n          },\n          page: portal.portalName,\n        }))\n      )\n    )\n  }\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['actions']) {\n      this.generateInlineActions()\n      this.generateOverflowActions()\n    }\n  }\n\n  ngOnInit(): void {\n    if (!this.manualBreadcrumbs) {\n      this.breadcrumbs$ = this.breadcrumbs.generatedItemsSource\n    } else {\n      this.breadcrumbs$ = this.breadcrumbs.itemsHandler\n    }\n    this.generateInlineActions()\n    this.generateOverflowActions()\n  }\n\n  onAction(action: string) {\n    switch (action) {\n      case 'save':\n        this.save.emit()\n        break\n      default:\n        break\n    }\n  }\n\n  handleImageError() {\n    this.figureImageLoadError = true\n  }\n\n  public generateItemStyle(item: ObjectDetailItem): string {\n    let style = ''\n    if (item.icon) style = style.concat(style, ' ', 'gap-1 align-items-center')\n    if (item.valueCssClass) style = style.concat(style, ' ', item.valueCssClass)\n    return style\n  }\n\n  public getObjectPanelLayoutClasses() {\n    if (this.enableGridView) {\n      return this.objectPanelGridLayoutClasses\n    }\n    if (this.enableGridView === false) {\n      return this.objectPanelColumnLayoutClasses\n    }\n    return this.objectPanelDefaultLayoutClasses\n  }\n\n  public getObjectInfoLayoutClasses() {\n    if (this.enableGridView) {\n      return `${this.objectInfoGridLayoutClasses} lg:col-${\n        this.gridLayoutDesktopColumns ? 12 / this.gridLayoutDesktopColumns : 4\n      }`\n    }\n    if (this.enableGridView === false) {\n      return this.objectInfoColumnLayoutClasses\n    }\n    return this.objectInfoDefaultLayoutClasses\n  }\n\n  /**\n   * Generates a list of actions that should be rendered in an overflow menu\n   */\n  private generateOverflowActions() {\n    if (this.actions) {\n      const translationKeys: string[] = [\n        ...this.actions.map((a) => a.labelKey || '').filter((a) => !!a),\n        ...this.actions.map((a) => a.titleKey || '').filter((a) => !!a),\n      ]\n      const translations$ = translationKeys.length ? this.translateService.get(translationKeys) : of([])\n      translations$.subscribe((translations) => {\n        const allowedActions: Action[] = []\n        if (this.actions) {\n          this.actions\n            .filter((a) => a.show === 'asOverflow')\n            .filter((a) => {\n              if (a.conditional) {\n                if (a.showCondition) return a\n                return null\n              } else return a\n            })\n            .forEach((action) => {\n              this.checkActionPermission(allowedActions, action)\n            })\n          this.overflowActions = [\n            ...allowedActions.map<MenuItem>((a) => ({\n              id: a.id,\n              label: a.labelKey ? translations[a.labelKey] : a.label,\n              icon: a.icon,\n              tooltipOptions: {\n                tooltipLabel: a.titleKey ? translations[a.titleKey] : a.title,\n                tooltipEvent: 'hover',\n                tooltipPosition: 'top',\n              },\n              command: a.actionCallback,\n              disabled: a.disabled,\n            })),\n          ]\n        }\n      })\n    }\n  }\n\n  /**\n   * Generates a list of actions that should be rendered as inline buttons\n   */\n  private generateInlineActions() {\n    if (this.actions) {\n      // Temp array to hold all inline actions that should be visible to the current user\n      const allowedActions: Action[] = []\n      // Check permissions for all actions that should be rendered 'always'\n      this.actions\n        .filter((a) => a.show === 'always')\n        .filter((a) => {\n          if (a.conditional) {\n            return a.showCondition ? a : null\n          } else return a\n        })\n        .forEach((action) => {\n          this.checkActionPermission(allowedActions, action)\n        })\n      this.inlineActions = [...allowedActions]\n    }\n  }\n  /**\n   * Adds a given action to a given array if the current user is allowed to see it\n   * @param allowedActions Array that the action should be added to if the current user is allowed to see it\n   * @param action Action for which a permission check should be executed\n   */\n  private checkActionPermission(allowedActions: Action[], action: Action) {\n    if (action.permission) {\n      if (this.userService.hasPermission(action.permission)) {\n        // Push action to allowed array if user has sufficient permissions\n        allowedActions.push(action)\n      }\n    } else {\n      // Push action to allowed array if no permission was specified\n      allowedActions.push(action)\n    }\n  }\n}\n","<div class=\"onecx-page-header mb-4\" name=\"ocx-page-header-wrapper\">\n  <ng-container *ngIf=\"showBreadcrumbs\">\n    <p-breadcrumb\n      [model]=\"items\"\n      *ngIf=\"breadcrumbs$ | async  as items\"\n      [home]=\"(home$ | async)?.menuItem ?? {}\"\n      [homeAriaLabel]=\"(home$ | async)?.page ? ('OCX_PAGE_HEADER.HOME_ARIA_LABEL' | translate: { page: (home$ | async)?.page}) : ('OCX_PAGE_HEADER.HOME_DEFAULT_ARIA_LABEL' | translate)\"\n      [attr.manual]=\"manualBreadcrumbs\"\n    ></p-breadcrumb>\n  </ng-container>\n  <div class=\"title-bar flex flex-row md:justify-content-between p-3\">\n    <div class=\"title-wrap\">\n      <div class=\"figure flex h-2rem w-2rem md:h-3rem md:w-3rem\" *ngIf=\"showFigure\">\n        <div #previewImage class=\"figure-image absolute top-0 left-0 right-0 bottom-0\">\n          <ng-content select=\"[figureImage]\"></ng-content>\n          <img\n            *ngIf=\"figureImage && !figureImageLoadError\"\n            [ocxSrc]=\"figureImage\"\n            alt=\"Figure image\"\n            class=\"w-full\"\n            (error)=\"handleImageError()\"\n          />\n        </div>\n        <div\n          class=\"colorblob flex-1 border-round\"\n          *ngIf=\"previewImage.children.length === 0 || figureImageLoadError\"\n        ></div>\n      </div>\n      <ng-template #skeletonBar>\n        <div class=\"header justify-content-evenly\">\n          <p-skeleton width=\"10rem\"></p-skeleton>\n          <p-skeleton width=\"10rem\"></p-skeleton>\n        </div>\n      </ng-template>\n      <div class=\"header\" *ngIf=\"!loading; else skeletonBar\">\n        <h1 id=\"page-header\" *ngIf=\"!!header\">{{ header }}</h1>\n        <h2 id=\"page-subheader\" *ngIf=\"!!subheader\">{{ subheader }}</h2>\n      </div>\n    </div>\n    <div class=\"action-items-wrap mt-2 md:mt-0\">\n      <ng-container *ngIf=\"additionalToolbarContentLeft\" [ngTemplateOutlet]=\"additionalToolbarContentLeft\">\n      </ng-container>\n\n      <ng-container *ngIf=\"!disableDefaultActions\"> </ng-container>\n      <ng-template #skeletonActions>\n        <div class=\"flex\">\n          <p-skeleton width=\"5rem\" height=\"2rem\" styleClass=\"mr-2\"></p-skeleton>\n          <p-skeleton width=\"2rem\" height=\"2rem\" styleClass=\"mb-2\"></p-skeleton>\n        </div>\n      </ng-template>\n      <ng-container *ngIf=\"!loading; else skeletonActions\">\n        <div *ngIf=\"inlineActions && inlineActions.length > 0\" class=\"toolbar flex flex-wrap gap-1 sm:gap-2\">\n          <ng-container *ngFor=\"let action of inlineActions\">\n            <p-button\n              id=\"{{ action.id }}\"\n              [icon]=\"action.icon ?? ''\"\n              type=\"button\"\n              class=\"action-button\"\n              [label]=\"action.labelKey ? (action.labelKey | translate) : action.label\"\n              (onClick)=\"action.actionCallback()\"\n              [pTooltip]=\"(action.titleKey ? (action.titleKey | translate) : action.title)\"\n              tooltipPosition=\"top\"\n              tooltipEvent=\"hover\"\n              [disabled]=\"action.disabled ? action.disabled : false\"\n              [attr.name]=\"action.icon ? 'ocx-page-header-inline-action-icon-button' : 'ocx-page-header-inline-action-button'\"\n              [ariaLabel]=\" (action.ariaLabelKey ? (action.ariaLabelKey | translate) : action.ariaLabel) || (action.titleKey ? (action.titleKey | translate) : action.title) || (action.labelKey ? (action.labelKey | translate) : action.label)\"\n            ></p-button>\n          </ng-container>\n        </div>\n        <ng-content select=\"[toolbarItems]\"></ng-content>\n        <ng-container>\n          <div *ngIf=\"overflowActions.length !== 0\">\n            <button\n              id=\"pageHeaderMenuButton\"\n              type=\"button\"\n              pButton\n              icon=\"pi pi-ellipsis-v\"\n              pTooltip=\"{{ 'OCX_PAGE_HEADER.MORE_ACTIONS' | translate }}\"\n              tooltipEvent=\"hover\"\n              tooltipPosition=\"top\"\n              class=\"more-actions-menu-button action-button ml-2\"\n              (click)=\"menu.toggle($event)\"\n              name=\"ocx-page-header-overflow-action-button\"\n              [attr.aria-label]=\"('OCX_PAGE_HEADER.MORE_ACTIONS' | translate)\"\n            ></button>\n            <p-menu #menu [popup]=\"true\" [model]=\"overflowActions\" appendTo=\"body\"></p-menu>\n          </div>\n        </ng-container>\n      </ng-container>\n      <ng-container *ngIf=\"additionalToolbarContent\" [ngTemplateOutlet]=\"additionalToolbarContent\"> </ng-container>\n    </div>\n  </div>\n\n  <div class=\"object-panel\" [ngClass]=\"getObjectPanelLayoutClasses()\">\n    <ng-container *ngIf=\"objectDetails\">\n      <div class=\"object-info\" [ngClass]=\"getObjectInfoLayoutClasses()\" *ngFor=\"let item of objectDetails\">\n        <span\n          class=\"flex font-medium text-600 object-info-grid-label\"\n          name=\"object-detail-label\"\n          [pTooltip]=\"item.labelTooltip || ''\"\n          tooltipEvent=\"hover\"\n          tooltipPosition=\"top\"\n          >{{ item.label | dynamicPipe:item.labelPipe }}</span\n        >\n        <span *ngIf=\"item.icon || item.value\" class=\"object-info-grid-value\">\n          <span\n            class=\"flex text-900 align-items-center gap-2 w-max\"\n            [ngClass]=\"generateItemStyle(item)\"\n            name=\"object-detail-value\"\n          >\n            <span\n              class=\"flex align-items-center gap-2\"\n              [pTooltip]=\"item.valueTooltip || item.tooltip || ''\"\n              tooltipEvent=\"hover\"\n              tooltipPosition=\"top\"\n            >\n              <i\n                *ngIf=\"item.icon\"\n                class='{{item.icon + \" \" + (item.iconStyleClass || \"\")}}'\n                name=\"object-detail-icon\"\n              ></i>\n              {{ item.value | dynamicPipe:item.valuePipe:item.valuePipeArgs}}\n            </span>\n            <p-button\n              *ngIf=\"item.actionItemIcon && item.actionItemCallback\"\n              [icon]=\"item.actionItemIcon\"\n              styleClass=\"p-button-text p-0 w-full\"\n              [pTooltip]=\"item.actionItemTooltip || ''\"\n              tooltipPosition=\"top\"\n              tooltipEvent=\"hover\"\n              [ariaLabel]=\"(item.actionItemAriaLabelKey ? (item.actionItemAriaLabelKey | translate) : item.actionItemAriaLabel) || item.actionItemTooltip || ''\"\n              (onClick)=\"item.actionItemCallback()\"\n            ></p-button>\n          </span>\n        </span>\n      </div>\n    </ng-container>\n    <ng-content></ng-content>\n  </div>\n</div>\n"]}
|