@quadrel-enterprise-ui/framework 18.31.4-beta.75.1 → 18.31.4-beta.80.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/lib/page/object-header/page-object-header.component.mjs +6 -3
- package/esm2022/lib/page/page.component.mjs +4 -2
- package/esm2022/lib/page/shared/services/form-group-manager.service.mjs +27 -6
- package/esm2022/lib/page/shared/services/page-submit-action.service.mjs +4 -2
- package/esm2022/lib/table/store/table.reducer.mjs +1 -1
- package/fesm2022/quadrel-enterprise-ui-framework.mjs +36 -8
- package/fesm2022/quadrel-enterprise-ui-framework.mjs.map +1 -1
- package/lib/page/object-header/page-object-header.component.d.ts.map +1 -1
- package/lib/page/page.component.d.ts +1 -0
- package/lib/page/page.component.d.ts.map +1 -1
- package/lib/page/shared/services/form-group-manager.service.d.ts +5 -0
- package/lib/page/shared/services/form-group-manager.service.d.ts.map +1 -1
- package/lib/page/shared/services/page-submit-action.service.d.ts +1 -0
- package/lib/page/shared/services/page-submit-action.service.d.ts.map +1 -1
- package/package.json +1 -1
- package/esm2022/index.mjs +0 -74
- package/esm2022/lib/table/__mocks__/mock-secondary-actions.service.mjs +0 -26
- package/index.d.ts.map +0 -1
- package/lib/table/__mocks__/mock-secondary-actions.service.d.ts +0 -14
- package/lib/table/__mocks__/mock-secondary-actions.service.d.ts.map +0 -1
|
@@ -186,10 +186,13 @@ export class QdPageObjectHeaderComponent {
|
|
|
186
186
|
.$hasValuesChanged()
|
|
187
187
|
.pipe(take(1))
|
|
188
188
|
.subscribe(hasChanged => {
|
|
189
|
-
if (hasChanged)
|
|
189
|
+
if (hasChanged) {
|
|
190
190
|
this.openCancelDialog();
|
|
191
|
-
|
|
191
|
+
}
|
|
192
|
+
else {
|
|
193
|
+
this.formGroupManagerService.cancelPendingAsyncValidation();
|
|
192
194
|
this.pageStoreService.toggleViewonly(true);
|
|
195
|
+
}
|
|
193
196
|
});
|
|
194
197
|
}
|
|
195
198
|
save() {
|
|
@@ -306,4 +309,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
306
309
|
type: HostListener,
|
|
307
310
|
args: ['click']
|
|
308
311
|
}] } });
|
|
309
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-object-header.component.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/page/object-header/page-object-header.component.ts","../../../../../../libs/qd-ui/src/lib/page/object-header/page-object-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  HostBinding,\n  HostListener,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  SimpleChanges\n} from '@angular/core';\nimport { BehaviorSubject, combineLatest, isObservable, Observable, Subject, switchMap } from 'rxjs';\nimport { debounceTime, filter, map, take, takeUntil, tap } from 'rxjs/operators';\nimport { QdMenuButtonActionConfig, QdMenuButtonConfig } from '../../button/model/button-config';\nimport { QdDialogComponent, QdDialogService, QdDialogSize } from '../../dialog/dialog.module';\nimport { QdPageCancelConfirmationDialogComponent } from '../cancel-confirmation-dialog/page-cancel-confirmation-dialog.component';\nimport {\n  QdInspectOperationMode,\n  QdPageConfig,\n  QdPageConfigCreate,\n  QdPageConfigCustom,\n  QdPageConfigInspect,\n  QdPageContextConfig,\n  QdPageSelectedContext,\n  QdPageTypeInspectConfig\n} from '../model/page-config.interface';\nimport {\n  QdFacetOptionMultiSelect,\n  QdFacetOptionSingleSelect,\n  QdPageHeaderFacetConfig\n} from '../model/page-header-facet.interface';\nimport { QD_PAGE_OBJECT_RESOLVER_TOKEN, QdPageObjectResolver } from '../model/page-object-resolver';\nimport { QdContextService } from '../shared/services/context.service';\nimport { QdFormGroupManagerService } from '../shared/services/form-group-manager.service';\nimport { QdPageStoreService } from '../shared/services/page-store.service';\nimport { QdResolverTriggerService } from '../shared/services/resolver-trigger.service';\nimport { QdContextSelectDialogComponent } from './context-select-dialog/context-select-dialog.component';\n\n@Component({\n  selector: 'qd-page-object-header',\n  templateUrl: './page-object-header.component.html',\n  styleUrls: ['./page-object-header.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: { '[style.borderBottom]': 'borderBottomStyle' }\n})\nexport class QdPageObjectHeaderComponent<T extends object> implements OnInit, OnChanges, OnDestroy {\n  @Input({ required: true })\n  config!: QdPageConfig<T>;\n\n  @Input({ required: true })\n  hasNavigation = false;\n\n  @Input('data-test-id') testId = 'page-object-header';\n\n  @HostBinding('class.in-dialog')\n  get isInDialog(): boolean {\n    return !!this.dialogComponent;\n  }\n\n  @HostListener('click')\n  toggleFacets(): void {\n    if (!this.adaptiveMode || (this.headerFacets?.length ?? 0) >= 2) return;\n\n    this.facetsCollapsed = !this.facetsCollapsed;\n  }\n\n  get adaptiveMode(): boolean {\n    return (this.config as QdPageConfigInspect | QdPageConfigCustom).adaptiveMode;\n  }\n\n  private _pageObjectDataSubject = new BehaviorSubject<T>({} as T);\n  private _isLoadingSubject = new BehaviorSubject<boolean>(false);\n  private _customActionsSubject = new BehaviorSubject<QdMenuButtonConfig>({ actions: [] });\n  private _destroyed$ = new Subject<void>();\n\n  pageObjectData$: Observable<T> = this._pageObjectDataSubject.asObservable();\n  isLoading$: Observable<boolean> = this._isLoadingSubject.asObservable().pipe(debounceTime(400));\n  customActions$: Observable<QdMenuButtonConfig> = this._customActionsSubject.asObservable();\n\n  facetsCollapsed = true;\n\n  contexts$!: Observable<\n    {\n      label: string;\n      value: QdPageSelectedContext[];\n      context: QdPageContextConfig;\n      selection: QdPageSelectedContext | QdPageSelectedContext[];\n    }[]\n  >;\n\n  get borderBottomStyle(): string {\n    const pageType = this.config.pageType;\n\n    return pageType === 'create' ||\n      (pageType === 'inspect' && this.hasNavigation) ||\n      (pageType === 'custom' && this.hasNavigation) ||\n      (pageType === 'overview' && this.hasNavigation)\n      ? 'none !important'\n      : '';\n  }\n\n  get showEdit$(): Observable<boolean> {\n    return this.isInspectAndViewMode$.pipe(map(v => v && !this.hideEdit));\n  }\n\n  get showDelete$(): Observable<boolean> {\n    return this.isInspectAndViewMode$.pipe(map(v => v && !!this.deleteButton));\n  }\n\n  get showArchive$(): Observable<boolean> {\n    return this.isInspectAndViewMode$.pipe(map(v => v && !!this.archiveButton));\n  }\n\n  get showCancel$(): Observable<boolean> {\n    return this.isInspectAndViewMode$.pipe(map(v => !v && !!this.cancelButton && !this.isCreate));\n  }\n\n  get showSave$(): Observable<boolean> {\n    return this.isInspectAndViewMode$.pipe(map(v => !v && !!this.saveButton));\n  }\n\n  get headerFacets(): QdPageHeaderFacetConfig<T>[] | undefined {\n    if (this.hasHeaderFacets(this.config)) return this.config.headerFacets;\n  }\n\n  get isInspectAndViewMode$(): Observable<boolean> {\n    return this.pageStoreService.isViewonly$.pipe(\n      takeUntil(this._destroyed$),\n      map(isView => this.config.pageType === 'inspect' && isView)\n    );\n  }\n\n  get isCreate(): boolean {\n    return this.config.pageType === 'create';\n  }\n\n  get isOverview(): boolean {\n    return this.config.pageType === 'overview';\n  }\n\n  get isContextSelectable(): boolean {\n    return this.config.pageType === 'overview' || this.config.pageType === 'custom';\n  }\n\n  get editButton(): QdPageTypeInspectConfig['edit'] {\n    return (this.config.pageTypeConfig as QdPageTypeInspectConfig)?.edit;\n  }\n\n  get deleteButton(): QdPageTypeInspectConfig['delete'] {\n    return (this.config.pageTypeConfig as QdPageTypeInspectConfig)?.delete;\n  }\n\n  get archiveButton(): QdPageTypeInspectConfig['archive'] {\n    return (this.config.pageTypeConfig as QdPageTypeInspectConfig)?.archive;\n  }\n\n  get cancelButton(): QdPageTypeInspectConfig['cancel'] {\n    return (this.config.pageTypeConfig as QdPageTypeInspectConfig)?.cancel;\n  }\n\n  get saveButton(): QdPageTypeInspectConfig['save'] {\n    return (this.config.pageTypeConfig as QdPageTypeInspectConfig)?.save;\n  }\n\n  get hideEdit(): boolean {\n    const config = this.config.pageTypeConfig as QdPageTypeInspectConfig | undefined;\n\n    if (!config) return false;\n    if (config.operationMode !== 'edit') return config.hideEdit === true;\n\n    return false;\n  }\n\n  get hasValuesChanged$(): Observable<boolean> {\n    return this.formGroupManagerService.$hasValuesChanged();\n  }\n\n  get $canSave(): Observable<boolean> {\n    if ((this.config.pageTypeConfig as QdPageTypeInspectConfig)?.save?.hasValidation === false)\n      return this.formGroupManagerService.$hasValuesChanged();\n\n    return combineLatest([\n      this.formGroupManagerService.$areFormGroupsValid(),\n      this.formGroupManagerService.$hasValuesChanged()\n    ]).pipe(map(([isValid, hasChanges]) => isValid && hasChanges));\n  }\n\n  constructor(\n    @Optional() @Inject(QD_PAGE_OBJECT_RESOLVER_TOKEN) private pageObjectResolver: QdPageObjectResolver<T>,\n    @Optional() private formGroupManagerService: QdFormGroupManagerService,\n    @Optional() private dialogComponent: QdDialogComponent,\n    private dialog: QdDialogService,\n    private contextService: QdContextService,\n    private resolverTriggerService: QdResolverTriggerService,\n    private pageStoreService: QdPageStoreService<T>\n  ) {\n    if (pageObjectResolver) {\n      const originalUpdateMetadata = this.pageObjectResolver.updateMetadata?.bind(this.pageObjectResolver);\n      this.pageObjectResolver.updateMetadata = (props: Partial<T>): void => {\n        this.updateMetadata(props);\n        if (originalUpdateMetadata) originalUpdateMetadata(props);\n      };\n\n      this.setupResolverTrigger();\n    }\n\n    this.initContexts();\n  }\n\n  ngOnInit(): void {\n    if (this.pageObjectResolver) this.setupResolverTrigger();\n\n    this.updateCustomActions();\n    this.formGroupManagerService.takeFormGroupsSnapshot();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['config'] && !changes['config'].firstChange) this.updateCustomActions();\n  }\n\n  ngOnDestroy(): void {\n    this.pageStoreService.toggleViewonly(false);\n\n    this._destroyed$.next();\n    this._destroyed$.complete();\n  }\n\n  updateMetadata(metadata: Partial<T>): void {\n    const updatedMetadata = { ...this._pageObjectDataSubject.value, ...metadata };\n    this._pageObjectDataSubject.next(updatedMetadata);\n  }\n\n  handleAction(facet: QdFacetOptionSingleSelect | QdFacetOptionMultiSelect): void {\n    facet?.action?.handler();\n  }\n\n  hasHeaderFacets(\n    config: QdPageConfig<T>\n  ): config is QdPageConfigCreate<T> | QdPageConfigInspect<T> | QdPageConfigCustom<T> {\n    return (this.config as { headerFacets: QdPageHeaderFacetConfig<T>[] }).headerFacets != null;\n  }\n\n  edit(): void {\n    this.formGroupManagerService.takeFormGroupsSnapshot();\n    this.pageStoreService.toggleViewonly(false);\n    if (this.editButton?.handler) this.editButton.handler();\n  }\n\n  cancel(): void {\n    this.formGroupManagerService\n      .$hasValuesChanged()\n      .pipe(take(1))\n      .subscribe(hasChanged => {\n        if (hasChanged) this.openCancelDialog();\n        else this.pageStoreService.toggleViewonly(true);\n      });\n  }\n\n  save(): void {\n    const handleSuccess = (): void => {\n      this.pageStoreService.toggleViewonly(true);\n      this.formGroupManagerService.takeFormGroupsSnapshot();\n    };\n\n    const result = this.saveButton?.handler?.(this.formGroupManagerService.getAllValues());\n\n    isObservable(result) ? result.pipe(take(1)).subscribe((ok: boolean) => ok && handleSuccess()) : handleSuccess();\n  }\n\n  changeContext(\n    context: QdPageContextConfig,\n    selection: QdPageSelectedContext | QdPageSelectedContext[],\n    event: MouseEvent\n  ): void {\n    event.stopPropagation();\n\n    if (context.type === 'custom') {\n      context.open();\n\n      return;\n    }\n\n    const dialogRef = this.dialog.open(QdContextSelectDialogComponent, {\n      data: { config: context, selection },\n      dialogSize: QdDialogSize.Small,\n      title: context.title\n    });\n\n    dialogRef.closed.subscribe((data: { selected: QdPageSelectedContext[] }) => {\n      if (data) this.contextService.setValue(context.id, data.selected);\n    });\n  }\n\n  clearContext(context: QdPageContextConfig): void {\n    this.contextService.clear(context.id);\n  }\n\n  private setupResolverTrigger(): void {\n    this.resolverTriggerService\n      .shouldTriggerResolver(this.pageObjectResolver.config?.triggerOn ?? 'pathParamsChange')\n      .pipe(\n        takeUntil(this._destroyed$),\n        filter(shouldTrigger => shouldTrigger),\n        tap(() => this._isLoadingSubject.next(true)),\n        switchMap(() => this.pageObjectResolver.resolve()),\n        tap(objectData => this._pageObjectDataSubject.next(objectData)),\n        tap(() => this._isLoadingSubject.next(false))\n      )\n      .subscribe();\n  }\n\n  private initContexts(): void {\n    this.contexts$ = this.contextService.contexts$.pipe(\n      map(contexts => contexts.filter(context => context.selection || this.config.pageType === 'overview')),\n      map(contexts =>\n        contexts?.map(({ selection, context }) => ({\n          label: context.label.i18n,\n          value: Array.isArray(selection?.value)\n            ? selection?.value.filter(item => item !== null && item !== undefined)\n            : selection?.value !== null && selection?.value !== undefined\n            ? [selection?.value]\n            : ([] as QdPageSelectedContext[]),\n          context,\n          selection: selection?.value ?? []\n        }))\n      )\n    );\n  }\n\n  private updateCustomActions(): void {\n    if (this.config.pageType === 'inspect') {\n      const operationMode = this.config.pageTypeConfig?.operationMode;\n\n      if (operationMode) this.pageStoreService.toggleViewonly(operationMode === 'view');\n\n      this.pageStoreService.isViewonly$.pipe(takeUntil(this._destroyed$)).subscribe(isViewonly => {\n        const customActions = this.config.pageTypeConfig?.customActions ?? [];\n\n        this._customActionsSubject.next(this.getCustomActionsByMode(customActions, isViewonly ? 'view' : 'edit'));\n      });\n    }\n\n    if (this.config.pageType !== 'inspect')\n      this._customActionsSubject.next({ actions: this.config.pageTypeConfig?.customActions ?? [] });\n  }\n\n  private getCustomActionsByMode(\n    customActions: (QdMenuButtonActionConfig & { operationMode?: QdInspectOperationMode })[],\n    mode: QdInspectOperationMode\n  ): QdMenuButtonConfig {\n    const actions = customActions\n      .filter(action => !action.operationMode || action.operationMode === mode)\n      .map(action => {\n        const menuButtonAction = { ...action };\n        delete menuButtonAction.operationMode;\n        return menuButtonAction;\n      });\n\n    return { actions };\n  }\n\n  private openCancelDialog(): void {\n    this.dialog\n      .open(QdPageCancelConfirmationDialogComponent, {\n        title: { i18n: 'i18n.qd.page.cancel.confirmation.dialog.title' },\n        dialogSize: QdDialogSize.Small,\n        data: this.config.pageTypeConfig\n      })\n      .closed.pipe(takeUntil(this._destroyed$))\n      .subscribe(confirm => {\n        if (confirm) {\n          this.formGroupManagerService.restoreFormGroupsFromSnapshot();\n          this.pageStoreService.toggleViewonly(true);\n        }\n      });\n  }\n}\n","<div class=\"loading-overlay\" *ngIf=\"isLoading$ | async\"><qd-spinner></qd-spinner></div>\n\n<div class=\"object-header-top\">\n  <header class=\"object-header-title\">{{ config.title.i18n | translate }}</header>\n  <div class=\"object-header-toolbar\">\n    <button class=\"button-icon\" data-test-id=\"archive-button\">\n      <qd-icon\n        *ngIf=\"showArchive$ | async\"\n        (click)=\"archiveButton?.handler()\"\n        class=\"header-action-icon\"\n        [icon]=\"'resultNew'\"\n      ></qd-icon>\n    </button>\n\n    <button class=\"button-icon\" data-test-id=\"delete-button\">\n      <qd-icon\n        class=\"header-action-icon\"\n        *ngIf=\"showDelete$ | async\"\n        (click)=\"deleteButton?.handler()\"\n        [icon]=\"'trash'\"\n      ></qd-icon>\n    </button>\n\n    <button *ngIf=\"showEdit$ | async\" qdButton (click)=\"edit()\" data-test-id=\"edit-button\">\n      {{ editButton?.label?.i18n || \"i18n.qd.page.header.edit\" | translate }}\n    </button>\n\n    <button *ngIf=\"showCancel$ | async\" qdButton qdButtonGhost (click)=\"cancel()\" data-test-id=\"cancel-button\">\n      {{ cancelButton.label?.i18n || \"i18n.qd.page.header.cancel\" | translate }}\n    </button>\n\n    <button\n      *ngIf=\"showSave$ | async\"\n      qdButton\n      (click)=\"save()\"\n      data-test-id=\"save-button\"\n      [disabled]=\"($canSave | async) === false\"\n    >\n      {{ saveButton.label?.i18n || \"i18n.qd.page.header.save\" | translate }}\n    </button>\n\n    <ng-container *ngIf=\"customActions$ | async as customActions\">\n      <ng-container *ngIf=\"!adaptiveMode; else adaptive\">\n        <button\n          [qdMenuButton]=\"customActions\"\n          [autoSize]=\"false\"\n          [data-test-id]=\"'page-'\"\n          *ngIf=\"customActions.actions.length > 1; else singleButton\"\n          data-test-id=\"custom-button\"\n        >\n          {{ config?.customActionsLabel?.i18n || \"i18n.qd.page.header.actions\" | translate }}\n        </button>\n\n        <ng-template #singleButton>\n          <ng-container *ngIf=\"(customActions$ | async).actions[0] as singleAction\">\n            <button\n              qdButton\n              *ngIf=\"singleAction.handler && !singleAction.isHidden\"\n              [disabled]=\"singleAction.isDisabled\"\n              (click)=\"singleAction.handler()\"\n              data-test-id=\"custom-button\"\n            >\n              {{ singleAction.label?.i18n | translate }}\n            </button>\n          </ng-container>\n        </ng-template>\n      </ng-container>\n\n      <ng-template #adaptive>\n        <button\n          *ngIf=\"(customActions$ | async)?.actions.length >= 1\"\n          type=\"button\"\n          class=\"adaptive-menu-button\"\n          [qdPopoverOnClick]=\"menu\"\n          [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n          [qdPopoverStopPropagation]=\"true\"\n          [qdPopoverMinWidth]=\"160\"\n        >\n          <qd-icon icon=\"overflowMenuVertical\"></qd-icon>\n        </button>\n\n        <ng-template #menu>\n          <button\n            *ngFor=\"let action of customActions.actions; let i = index\"\n            class=\"adaptive-menu-entry\"\n            type=\"button\"\n            [disabled]=\"action.isDisabled\"\n            (click)=\"action.handler()\"\n          >\n            {{ action.label.i18n | translate }}\n          </button>\n        </ng-template>\n      </ng-template>\n    </ng-container>\n  </div>\n</div>\n\n<div class=\"object-header-facets\" [ngClass]=\"{ amongThemselves: adaptiveMode && !facetsCollapsed }\">\n  <ng-container *ngIf=\"pageObjectData$ | async as data\">\n    <div\n      class=\"object-header-facet\"\n      *ngFor=\"let facet of headerFacets | slice : 0 : (adaptiveMode && facetsCollapsed ? 2 : headerFacets?.length ?? 0)\"\n      [attr.data-test-id]=\"testId + '-facet-' + facet.name\"\n    >\n      <div class=\"facet-label\">{{ facet.label.i18n | translate }}</div>\n      <qd-dynamic-facet class=\"dynamic-facet\" [facet]=\"facet\" [data]=\"data\"></qd-dynamic-facet>\n    </div>\n  </ng-container>\n\n  <ng-container *ngIf=\"!config.hideContexts && contexts$ | async as contexts\">\n    <div\n      class=\"object-header-facet\"\n      *ngFor=\"\n        let context of contexts\n          | slice : 0 : (adaptiveMode && facetsCollapsed ? 2 - (headerFacets?.length ?? 0) : contexts.length);\n        let index = index;\n        let first = first\n      \"\n      [ngClass]=\"{ hasDivider: headerFacets && first }\"\n    >\n      <div class=\"facet-label\">{{ context.label | translate }}</div>\n\n      <span *ngIf=\"context.value.length === 0\" class=\"no-selected-context\">{{\n        \"i18n.qd.page.context.noSelectionPlaceholder\" | translate\n      }}</span>\n\n      <span *ngIf=\"context.value.length !== 0\">\n        <qd-chip state=\"none\" [close]=\"isContextSelectable\" (closeClickEmitter)=\"clearContext(context.context)\">\n          <ng-container *ngFor=\"let val of context.value; let last = last\">\n            {{ val.label.i18n | translate }}<span *ngIf=\"!last\">, </span>\n          </ng-container>\n        </qd-chip>\n      </span>\n\n      <span *ngIf=\"isContextSelectable && (!facetsCollapsed || !adaptiveMode)\" class=\"select-button\">\n        <button\n          qdButton\n          qdButtonLink\n          type=\"button\"\n          (click)=\"changeContext(context.context, context.selection, $event)\"\n          [data-test-id]=\"'object-header-select-context-' + context.context.id\"\n        >\n          {{\n            context.value.length !== 0\n              ? (\"i18n.qd.page.context.button.change\" | translate)\n              : (\"i18n.qd.page.context.button.select\" | translate)\n          }}\n        </button>\n      </span>\n    </div>\n  </ng-container>\n\n  <span class=\"facets-toggler\" *ngIf=\"adaptiveMode && headerFacets.length + (contexts$ | async).length > 2\">\n    <span *ngIf=\"facetsCollapsed\">+{{ headerFacets.length + (contexts$ | async).length - 2 }}</span>\n    <button qdIconButton>\n      <qd-icon [icon]=\"facetsCollapsed ? 'ctrlDown' : 'ctrlTop'\"></qd-icon>\n    </button>\n  </span>\n</div>\n"]}
|
|
312
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-object-header.component.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/page/object-header/page-object-header.component.ts","../../../../../../libs/qd-ui/src/lib/page/object-header/page-object-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  HostBinding,\n  HostListener,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  SimpleChanges\n} from '@angular/core';\nimport { BehaviorSubject, combineLatest, isObservable, Observable, Subject, switchMap } from 'rxjs';\nimport { debounceTime, filter, map, take, takeUntil, tap } from 'rxjs/operators';\nimport { QdMenuButtonActionConfig, QdMenuButtonConfig } from '../../button/model/button-config';\nimport { QdDialogComponent, QdDialogService, QdDialogSize } from '../../dialog/dialog.module';\nimport { QdPageCancelConfirmationDialogComponent } from '../cancel-confirmation-dialog/page-cancel-confirmation-dialog.component';\nimport {\n  QdInspectOperationMode,\n  QdPageConfig,\n  QdPageConfigCreate,\n  QdPageConfigCustom,\n  QdPageConfigInspect,\n  QdPageContextConfig,\n  QdPageSelectedContext,\n  QdPageTypeInspectConfig\n} from '../model/page-config.interface';\nimport {\n  QdFacetOptionMultiSelect,\n  QdFacetOptionSingleSelect,\n  QdPageHeaderFacetConfig\n} from '../model/page-header-facet.interface';\nimport { QD_PAGE_OBJECT_RESOLVER_TOKEN, QdPageObjectResolver } from '../model/page-object-resolver';\nimport { QdContextService } from '../shared/services/context.service';\nimport { QdFormGroupManagerService } from '../shared/services/form-group-manager.service';\nimport { QdPageStoreService } from '../shared/services/page-store.service';\nimport { QdResolverTriggerService } from '../shared/services/resolver-trigger.service';\nimport { QdContextSelectDialogComponent } from './context-select-dialog/context-select-dialog.component';\n\n@Component({\n  selector: 'qd-page-object-header',\n  templateUrl: './page-object-header.component.html',\n  styleUrls: ['./page-object-header.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: { '[style.borderBottom]': 'borderBottomStyle' }\n})\nexport class QdPageObjectHeaderComponent<T extends object> implements OnInit, OnChanges, OnDestroy {\n  @Input({ required: true })\n  config!: QdPageConfig<T>;\n\n  @Input({ required: true })\n  hasNavigation = false;\n\n  @Input('data-test-id') testId = 'page-object-header';\n\n  @HostBinding('class.in-dialog')\n  get isInDialog(): boolean {\n    return !!this.dialogComponent;\n  }\n\n  @HostListener('click')\n  toggleFacets(): void {\n    if (!this.adaptiveMode || (this.headerFacets?.length ?? 0) >= 2) return;\n\n    this.facetsCollapsed = !this.facetsCollapsed;\n  }\n\n  get adaptiveMode(): boolean {\n    return (this.config as QdPageConfigInspect | QdPageConfigCustom).adaptiveMode;\n  }\n\n  private _pageObjectDataSubject = new BehaviorSubject<T>({} as T);\n  private _isLoadingSubject = new BehaviorSubject<boolean>(false);\n  private _customActionsSubject = new BehaviorSubject<QdMenuButtonConfig>({ actions: [] });\n  private _destroyed$ = new Subject<void>();\n\n  pageObjectData$: Observable<T> = this._pageObjectDataSubject.asObservable();\n  isLoading$: Observable<boolean> = this._isLoadingSubject.asObservable().pipe(debounceTime(400));\n  customActions$: Observable<QdMenuButtonConfig> = this._customActionsSubject.asObservable();\n\n  facetsCollapsed = true;\n\n  contexts$!: Observable<\n    {\n      label: string;\n      value: QdPageSelectedContext[];\n      context: QdPageContextConfig;\n      selection: QdPageSelectedContext | QdPageSelectedContext[];\n    }[]\n  >;\n\n  get borderBottomStyle(): string {\n    const pageType = this.config.pageType;\n\n    return pageType === 'create' ||\n      (pageType === 'inspect' && this.hasNavigation) ||\n      (pageType === 'custom' && this.hasNavigation) ||\n      (pageType === 'overview' && this.hasNavigation)\n      ? 'none !important'\n      : '';\n  }\n\n  get showEdit$(): Observable<boolean> {\n    return this.isInspectAndViewMode$.pipe(map(v => v && !this.hideEdit));\n  }\n\n  get showDelete$(): Observable<boolean> {\n    return this.isInspectAndViewMode$.pipe(map(v => v && !!this.deleteButton));\n  }\n\n  get showArchive$(): Observable<boolean> {\n    return this.isInspectAndViewMode$.pipe(map(v => v && !!this.archiveButton));\n  }\n\n  get showCancel$(): Observable<boolean> {\n    return this.isInspectAndViewMode$.pipe(map(v => !v && !!this.cancelButton && !this.isCreate));\n  }\n\n  get showSave$(): Observable<boolean> {\n    return this.isInspectAndViewMode$.pipe(map(v => !v && !!this.saveButton));\n  }\n\n  get headerFacets(): QdPageHeaderFacetConfig<T>[] | undefined {\n    if (this.hasHeaderFacets(this.config)) return this.config.headerFacets;\n  }\n\n  get isInspectAndViewMode$(): Observable<boolean> {\n    return this.pageStoreService.isViewonly$.pipe(\n      takeUntil(this._destroyed$),\n      map(isView => this.config.pageType === 'inspect' && isView)\n    );\n  }\n\n  get isCreate(): boolean {\n    return this.config.pageType === 'create';\n  }\n\n  get isOverview(): boolean {\n    return this.config.pageType === 'overview';\n  }\n\n  get isContextSelectable(): boolean {\n    return this.config.pageType === 'overview' || this.config.pageType === 'custom';\n  }\n\n  get editButton(): QdPageTypeInspectConfig['edit'] {\n    return (this.config.pageTypeConfig as QdPageTypeInspectConfig)?.edit;\n  }\n\n  get deleteButton(): QdPageTypeInspectConfig['delete'] {\n    return (this.config.pageTypeConfig as QdPageTypeInspectConfig)?.delete;\n  }\n\n  get archiveButton(): QdPageTypeInspectConfig['archive'] {\n    return (this.config.pageTypeConfig as QdPageTypeInspectConfig)?.archive;\n  }\n\n  get cancelButton(): QdPageTypeInspectConfig['cancel'] {\n    return (this.config.pageTypeConfig as QdPageTypeInspectConfig)?.cancel;\n  }\n\n  get saveButton(): QdPageTypeInspectConfig['save'] {\n    return (this.config.pageTypeConfig as QdPageTypeInspectConfig)?.save;\n  }\n\n  get hideEdit(): boolean {\n    const config = this.config.pageTypeConfig as QdPageTypeInspectConfig | undefined;\n\n    if (!config) return false;\n    if (config.operationMode !== 'edit') return config.hideEdit === true;\n\n    return false;\n  }\n\n  get hasValuesChanged$(): Observable<boolean> {\n    return this.formGroupManagerService.$hasValuesChanged();\n  }\n\n  get $canSave(): Observable<boolean> {\n    if ((this.config.pageTypeConfig as QdPageTypeInspectConfig)?.save?.hasValidation === false)\n      return this.formGroupManagerService.$hasValuesChanged();\n\n    return combineLatest([\n      this.formGroupManagerService.$areFormGroupsValid(),\n      this.formGroupManagerService.$hasValuesChanged()\n    ]).pipe(map(([isValid, hasChanges]) => isValid && hasChanges));\n  }\n\n  constructor(\n    @Optional() @Inject(QD_PAGE_OBJECT_RESOLVER_TOKEN) private pageObjectResolver: QdPageObjectResolver<T>,\n    @Optional() private formGroupManagerService: QdFormGroupManagerService,\n    @Optional() private dialogComponent: QdDialogComponent,\n    private dialog: QdDialogService,\n    private contextService: QdContextService,\n    private resolverTriggerService: QdResolverTriggerService,\n    private pageStoreService: QdPageStoreService<T>\n  ) {\n    if (pageObjectResolver) {\n      const originalUpdateMetadata = this.pageObjectResolver.updateMetadata?.bind(this.pageObjectResolver);\n      this.pageObjectResolver.updateMetadata = (props: Partial<T>): void => {\n        this.updateMetadata(props);\n        if (originalUpdateMetadata) originalUpdateMetadata(props);\n      };\n\n      this.setupResolverTrigger();\n    }\n\n    this.initContexts();\n  }\n\n  ngOnInit(): void {\n    if (this.pageObjectResolver) this.setupResolverTrigger();\n\n    this.updateCustomActions();\n    this.formGroupManagerService.takeFormGroupsSnapshot();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['config'] && !changes['config'].firstChange) this.updateCustomActions();\n  }\n\n  ngOnDestroy(): void {\n    this.pageStoreService.toggleViewonly(false);\n\n    this._destroyed$.next();\n    this._destroyed$.complete();\n  }\n\n  updateMetadata(metadata: Partial<T>): void {\n    const updatedMetadata = { ...this._pageObjectDataSubject.value, ...metadata };\n    this._pageObjectDataSubject.next(updatedMetadata);\n  }\n\n  handleAction(facet: QdFacetOptionSingleSelect | QdFacetOptionMultiSelect): void {\n    facet?.action?.handler();\n  }\n\n  hasHeaderFacets(\n    config: QdPageConfig<T>\n  ): config is QdPageConfigCreate<T> | QdPageConfigInspect<T> | QdPageConfigCustom<T> {\n    return (this.config as { headerFacets: QdPageHeaderFacetConfig<T>[] }).headerFacets != null;\n  }\n\n  edit(): void {\n    this.formGroupManagerService.takeFormGroupsSnapshot();\n    this.pageStoreService.toggleViewonly(false);\n    if (this.editButton?.handler) this.editButton.handler();\n  }\n\n  cancel(): void {\n    this.formGroupManagerService\n      .$hasValuesChanged()\n      .pipe(take(1))\n      .subscribe(hasChanged => {\n        if (hasChanged) {\n          this.openCancelDialog();\n        } else {\n          this.formGroupManagerService.cancelPendingAsyncValidation();\n          this.pageStoreService.toggleViewonly(true);\n        }\n      });\n  }\n\n  save(): void {\n    const handleSuccess = (): void => {\n      this.pageStoreService.toggleViewonly(true);\n      this.formGroupManagerService.takeFormGroupsSnapshot();\n    };\n\n    const result = this.saveButton?.handler?.(this.formGroupManagerService.getAllValues());\n\n    isObservable(result) ? result.pipe(take(1)).subscribe((ok: boolean) => ok && handleSuccess()) : handleSuccess();\n  }\n\n  changeContext(\n    context: QdPageContextConfig,\n    selection: QdPageSelectedContext | QdPageSelectedContext[],\n    event: MouseEvent\n  ): void {\n    event.stopPropagation();\n\n    if (context.type === 'custom') {\n      context.open();\n\n      return;\n    }\n\n    const dialogRef = this.dialog.open(QdContextSelectDialogComponent, {\n      data: { config: context, selection },\n      dialogSize: QdDialogSize.Small,\n      title: context.title\n    });\n\n    dialogRef.closed.subscribe((data: { selected: QdPageSelectedContext[] }) => {\n      if (data) this.contextService.setValue(context.id, data.selected);\n    });\n  }\n\n  clearContext(context: QdPageContextConfig): void {\n    this.contextService.clear(context.id);\n  }\n\n  private setupResolverTrigger(): void {\n    this.resolverTriggerService\n      .shouldTriggerResolver(this.pageObjectResolver.config?.triggerOn ?? 'pathParamsChange')\n      .pipe(\n        takeUntil(this._destroyed$),\n        filter(shouldTrigger => shouldTrigger),\n        tap(() => this._isLoadingSubject.next(true)),\n        switchMap(() => this.pageObjectResolver.resolve()),\n        tap(objectData => this._pageObjectDataSubject.next(objectData)),\n        tap(() => this._isLoadingSubject.next(false))\n      )\n      .subscribe();\n  }\n\n  private initContexts(): void {\n    this.contexts$ = this.contextService.contexts$.pipe(\n      map(contexts => contexts.filter(context => context.selection || this.config.pageType === 'overview')),\n      map(contexts =>\n        contexts?.map(({ selection, context }) => ({\n          label: context.label.i18n,\n          value: Array.isArray(selection?.value)\n            ? selection?.value.filter(item => item !== null && item !== undefined)\n            : selection?.value !== null && selection?.value !== undefined\n            ? [selection?.value]\n            : ([] as QdPageSelectedContext[]),\n          context,\n          selection: selection?.value ?? []\n        }))\n      )\n    );\n  }\n\n  private updateCustomActions(): void {\n    if (this.config.pageType === 'inspect') {\n      const operationMode = this.config.pageTypeConfig?.operationMode;\n\n      if (operationMode) this.pageStoreService.toggleViewonly(operationMode === 'view');\n\n      this.pageStoreService.isViewonly$.pipe(takeUntil(this._destroyed$)).subscribe(isViewonly => {\n        const customActions = this.config.pageTypeConfig?.customActions ?? [];\n\n        this._customActionsSubject.next(this.getCustomActionsByMode(customActions, isViewonly ? 'view' : 'edit'));\n      });\n    }\n\n    if (this.config.pageType !== 'inspect')\n      this._customActionsSubject.next({ actions: this.config.pageTypeConfig?.customActions ?? [] });\n  }\n\n  private getCustomActionsByMode(\n    customActions: (QdMenuButtonActionConfig & { operationMode?: QdInspectOperationMode })[],\n    mode: QdInspectOperationMode\n  ): QdMenuButtonConfig {\n    const actions = customActions\n      .filter(action => !action.operationMode || action.operationMode === mode)\n      .map(action => {\n        const menuButtonAction = { ...action };\n        delete menuButtonAction.operationMode;\n        return menuButtonAction;\n      });\n\n    return { actions };\n  }\n\n  private openCancelDialog(): void {\n    this.dialog\n      .open(QdPageCancelConfirmationDialogComponent, {\n        title: { i18n: 'i18n.qd.page.cancel.confirmation.dialog.title' },\n        dialogSize: QdDialogSize.Small,\n        data: this.config.pageTypeConfig\n      })\n      .closed.pipe(takeUntil(this._destroyed$))\n      .subscribe(confirm => {\n        if (confirm) {\n          this.formGroupManagerService.restoreFormGroupsFromSnapshot();\n          this.pageStoreService.toggleViewonly(true);\n        }\n      });\n  }\n}\n","<div class=\"loading-overlay\" *ngIf=\"isLoading$ | async\"><qd-spinner></qd-spinner></div>\n\n<div class=\"object-header-top\">\n  <header class=\"object-header-title\">{{ config.title.i18n | translate }}</header>\n  <div class=\"object-header-toolbar\">\n    <button class=\"button-icon\" data-test-id=\"archive-button\">\n      <qd-icon\n        *ngIf=\"showArchive$ | async\"\n        (click)=\"archiveButton?.handler()\"\n        class=\"header-action-icon\"\n        [icon]=\"'resultNew'\"\n      ></qd-icon>\n    </button>\n\n    <button class=\"button-icon\" data-test-id=\"delete-button\">\n      <qd-icon\n        class=\"header-action-icon\"\n        *ngIf=\"showDelete$ | async\"\n        (click)=\"deleteButton?.handler()\"\n        [icon]=\"'trash'\"\n      ></qd-icon>\n    </button>\n\n    <button *ngIf=\"showEdit$ | async\" qdButton (click)=\"edit()\" data-test-id=\"edit-button\">\n      {{ editButton?.label?.i18n || \"i18n.qd.page.header.edit\" | translate }}\n    </button>\n\n    <button *ngIf=\"showCancel$ | async\" qdButton qdButtonGhost (click)=\"cancel()\" data-test-id=\"cancel-button\">\n      {{ cancelButton.label?.i18n || \"i18n.qd.page.header.cancel\" | translate }}\n    </button>\n\n    <button\n      *ngIf=\"showSave$ | async\"\n      qdButton\n      (click)=\"save()\"\n      data-test-id=\"save-button\"\n      [disabled]=\"($canSave | async) === false\"\n    >\n      {{ saveButton.label?.i18n || \"i18n.qd.page.header.save\" | translate }}\n    </button>\n\n    <ng-container *ngIf=\"customActions$ | async as customActions\">\n      <ng-container *ngIf=\"!adaptiveMode; else adaptive\">\n        <button\n          [qdMenuButton]=\"customActions\"\n          [autoSize]=\"false\"\n          [data-test-id]=\"'page-'\"\n          *ngIf=\"customActions.actions.length > 1; else singleButton\"\n          data-test-id=\"custom-button\"\n        >\n          {{ config?.customActionsLabel?.i18n || \"i18n.qd.page.header.actions\" | translate }}\n        </button>\n\n        <ng-template #singleButton>\n          <ng-container *ngIf=\"(customActions$ | async).actions[0] as singleAction\">\n            <button\n              qdButton\n              *ngIf=\"singleAction.handler && !singleAction.isHidden\"\n              [disabled]=\"singleAction.isDisabled\"\n              (click)=\"singleAction.handler()\"\n              data-test-id=\"custom-button\"\n            >\n              {{ singleAction.label?.i18n | translate }}\n            </button>\n          </ng-container>\n        </ng-template>\n      </ng-container>\n\n      <ng-template #adaptive>\n        <button\n          *ngIf=\"(customActions$ | async)?.actions.length >= 1\"\n          type=\"button\"\n          class=\"adaptive-menu-button\"\n          [qdPopoverOnClick]=\"menu\"\n          [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n          [qdPopoverStopPropagation]=\"true\"\n          [qdPopoverMinWidth]=\"160\"\n        >\n          <qd-icon icon=\"overflowMenuVertical\"></qd-icon>\n        </button>\n\n        <ng-template #menu>\n          <button\n            *ngFor=\"let action of customActions.actions; let i = index\"\n            class=\"adaptive-menu-entry\"\n            type=\"button\"\n            [disabled]=\"action.isDisabled\"\n            (click)=\"action.handler()\"\n          >\n            {{ action.label.i18n | translate }}\n          </button>\n        </ng-template>\n      </ng-template>\n    </ng-container>\n  </div>\n</div>\n\n<div class=\"object-header-facets\" [ngClass]=\"{ amongThemselves: adaptiveMode && !facetsCollapsed }\">\n  <ng-container *ngIf=\"pageObjectData$ | async as data\">\n    <div\n      class=\"object-header-facet\"\n      *ngFor=\"let facet of headerFacets | slice : 0 : (adaptiveMode && facetsCollapsed ? 2 : headerFacets?.length ?? 0)\"\n      [attr.data-test-id]=\"testId + '-facet-' + facet.name\"\n    >\n      <div class=\"facet-label\">{{ facet.label.i18n | translate }}</div>\n      <qd-dynamic-facet class=\"dynamic-facet\" [facet]=\"facet\" [data]=\"data\"></qd-dynamic-facet>\n    </div>\n  </ng-container>\n\n  <ng-container *ngIf=\"!config.hideContexts && contexts$ | async as contexts\">\n    <div\n      class=\"object-header-facet\"\n      *ngFor=\"\n        let context of contexts\n          | slice : 0 : (adaptiveMode && facetsCollapsed ? 2 - (headerFacets?.length ?? 0) : contexts.length);\n        let index = index;\n        let first = first\n      \"\n      [ngClass]=\"{ hasDivider: headerFacets && first }\"\n    >\n      <div class=\"facet-label\">{{ context.label | translate }}</div>\n\n      <span *ngIf=\"context.value.length === 0\" class=\"no-selected-context\">{{\n        \"i18n.qd.page.context.noSelectionPlaceholder\" | translate\n      }}</span>\n\n      <span *ngIf=\"context.value.length !== 0\">\n        <qd-chip state=\"none\" [close]=\"isContextSelectable\" (closeClickEmitter)=\"clearContext(context.context)\">\n          <ng-container *ngFor=\"let val of context.value; let last = last\">\n            {{ val.label.i18n | translate }}<span *ngIf=\"!last\">, </span>\n          </ng-container>\n        </qd-chip>\n      </span>\n\n      <span *ngIf=\"isContextSelectable && (!facetsCollapsed || !adaptiveMode)\" class=\"select-button\">\n        <button\n          qdButton\n          qdButtonLink\n          type=\"button\"\n          (click)=\"changeContext(context.context, context.selection, $event)\"\n          [data-test-id]=\"'object-header-select-context-' + context.context.id\"\n        >\n          {{\n            context.value.length !== 0\n              ? (\"i18n.qd.page.context.button.change\" | translate)\n              : (\"i18n.qd.page.context.button.select\" | translate)\n          }}\n        </button>\n      </span>\n    </div>\n  </ng-container>\n\n  <span class=\"facets-toggler\" *ngIf=\"adaptiveMode && headerFacets.length + (contexts$ | async).length > 2\">\n    <span *ngIf=\"facetsCollapsed\">+{{ headerFacets.length + (contexts$ | async).length - 2 }}</span>\n    <button qdIconButton>\n      <qd-icon [icon]=\"facetsCollapsed ? 'ctrlDown' : 'ctrlTop'\"></qd-icon>\n    </button>\n  </span>\n</div>\n"]}
|
|
@@ -444,6 +444,7 @@ export class QdPageComponent {
|
|
|
444
444
|
projectionGuardMessage = 'QD-UI | QdPage - This content is not supported. Please use QdSectionAdapterDirective for custom content projection.';
|
|
445
445
|
_isInitialized = false;
|
|
446
446
|
_destroyed$ = new Subject();
|
|
447
|
+
_cancelSubmitValidation$ = new Subject();
|
|
447
448
|
get isControlPanelVisible() {
|
|
448
449
|
return this.controlPanel !== undefined && this.controlPanel.config?.isHidden !== true;
|
|
449
450
|
}
|
|
@@ -589,9 +590,10 @@ export class QdPageComponent {
|
|
|
589
590
|
.subscribe();
|
|
590
591
|
}
|
|
591
592
|
initSubmitValidation() {
|
|
593
|
+
this._cancelSubmitValidation$.next();
|
|
592
594
|
this.formGroupManagerService
|
|
593
595
|
.$areFormGroupsValid()
|
|
594
|
-
.pipe(takeUntil(this._destroyed$), tap(isValid => {
|
|
596
|
+
.pipe(takeUntil(this._cancelSubmitValidation$), takeUntil(this._destroyed$), tap(isValid => {
|
|
595
597
|
const submitDisabledInfoText = this.config.pageType === 'inspect' ? this.config.pageTypeConfig?.submit?.disabledInfo : undefined;
|
|
596
598
|
this.footerService.updateActions([
|
|
597
599
|
{
|
|
@@ -670,4 +672,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
670
672
|
type: HostBinding,
|
|
671
673
|
args: ['class.has-info-banners']
|
|
672
674
|
}] } });
|
|
673
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page.component.js","sourceRoot":"","sources":["../../../../../libs/qd-ui/src/lib/page/page.component.ts","../../../../../libs/qd-ui/src/lib/page/page.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ContentChild,\n  ContentChildren,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  SimpleChanges\n} from '@angular/core';\nimport { DialogRef } from '@angular/cdk/dialog';\nimport { BehaviorSubject, map, Observable, Subject } from 'rxjs';\nimport { take, takeUntil, tap } from 'rxjs/operators';\n\nimport { QD_SAFE_BOTTOM_OFFSET } from '../core/core.module';\nimport { QdDialogService, QdDialogSize } from '../dialog/dialog.module';\nimport { QdPageStepperAdapterDirective } from '../page-stepper/adaptors/page-stepper-adapter.directive';\nimport { QdPageStepperComponent } from '../page-stepper/page-stepper.component';\nimport { QdPageTabsAdapterDirective } from '../page-tabs/adaptors/page-tabs-adapter.directive';\nimport { QdPageTabsComponent } from '../page-tabs/page-tabs.component';\nimport { QdSectionComponent } from '../section/section.component';\nimport { QdPageCancelConfirmationDialogComponent } from './cancel-confirmation-dialog/page-cancel-confirmation-dialog.component';\nimport { QdPageControlPanelComponent } from './control-panel/page-control-panel.component';\nimport { QdPageInfoBannerComponent } from './info-banner/page-info-banner.component';\nimport {\n  QdInspectOperationMode,\n  QdPageConfig,\n  QdPageTypeCreateConfig,\n  QdPageTypeInspectConfig\n} from './model/page-config.interface';\nimport { QdCreateFooterActionKey, QdFooterActionType, QdPageFooterAction } from './model/page-footer-action.interface';\nimport { QdFormGroupManagerService } from './shared/services/form-group-manager.service';\nimport { QdPageFooterService } from './shared/services/page-footer.service';\nimport { QdPageStoreService } from './shared/services/page-store.service';\nimport { QdPageSubmitActionService } from './shared/services/page-submit-action.service';\nimport { QdResolverTriggerService } from './shared/services/resolver-trigger.service';\n\ntype PartialFooterAction = { actionKey: QdCreateFooterActionKey; partialAction: Partial<QdPageFooterAction> };\n\n// Footer offset (px). Keep in sync with SCSS $page-footer-height!\nconst SAFE_BOTTOM_OFFSET_PX = 64;\n\n/**\n * **QdPage** serves as the central structural element within the hierarchy under the **QdShell**.\n * Integration is done through the Angular Routing Module, and QdPage is designed to be responsive across various screen sizes right out of the box.\n *\n * #### **Page Types**\n *\n * QdPage uses page types to decide how the page looks and works. Each page type has its own settings and actions.\n *\n * - **overview**: Displays a summary or a list of objects, providing an overview of multiple business cases.\n * - **create**: Allows the creation of a new object, representing a business case.\n * - **inspect**: Enables viewing, editing, and executing additional actions related to the object, which also represents a business case.\n * - **custom**: Provides a way to implement unique functionality that doesn’t fit the other predefined page types.\n *\n * **Note that the 'custom' page type should be used only as a fallback for very specific cases. If you encounter such a situation, please contact the Quadrel team.**\n *\n * #### **Facets**\n *\n * These are extra pieces of information shown in the page header. They give context specific to the current object model being viewed or edited. There are several types of facets, including `status`, `value`, `criticality`, `references`, `progress`, `date`, `singleSelect`, and `multiSelect`. Each type has its own options. For more details, see the `QdPageHeaderFacet` interface.\n *\n * #### **Context**\n *\n * The `context` acts as a filter that can be selected on the overview page and provides the business context, which remains consistent throughout the entire application. On create and inspect pages, the context is displayed as read-only. For more details, check the dedicated chapter in Storybook.\n *\n *\n * #### **Page Info Banners**\n *\n * To insert a page info banner under the page header, just put a `qd-page-info-banner` component inside the `qd-page`. Multiple consecutive info banners of the same type will be merged into one banner container. Page info banners have the same appearance like notifications.\n *\n * #### **Control Panel**\n *\n * The control panel is located on the right side of the page and is used to display additional information and functions relevant to a specific business case, which is linked to a specific object model. For further information, please consult the dedicated chapter in Storybook.\n *\n * #### **Actions**\n *\n * These are interactive elements that perform specific functions. Functions for these actions can be set up through configurations. Custom actions can be added to any page type. Additionally, all actions can be configured and customized with your own text, which will override the default texts.\n *\n * Please check the relevant interfaces for each page type: `QdPageConfigOverview`, `QdPageConfigCreate`, `QdPageConfigInspect`, and `QdPageConfigCustom`.\n *\n * #### **Validation/Parameterization**\n *\n * Validation and parameterization are covered in a dedicated chapter in the Storybook. Please check the \"Validation\" section for more information.\n *\n * #### **Resolver**\n *\n * Using a resolver to fetch page object data is essential to the page concept. Add the resolver to the component's providers and use the `QD_PAGE_OBJECT_RESOLVER_TOKEN` token. This approach enables type safety and user feedback by effectively managing the necessary data for the page.\n *\n * ```ts\n * interface MyObjectModel {\n *   // Metadata displayed in the ObjectHeader\n *   state: MyState;\n *   countryOfDestination: MyCountryOfDestination;\n *   // Appears not in the ObjectHeader\n *   payload: MyPayload;\n * }\n *\n * type MyObjectMetadata = 'state' | 'countryOfDestination';\n *\n * @Injectable()\n * class MyObjectModelResolver implements QdPageObjectResolver<MyObjectModel> {\n *   constructor(private http: HttpClient) {}\n *\n *   resolve(): Observable<MyObjectModel> {\n *     return this.http\n *       .get<MyObjectModel>('my-api')\n *       .pipe(tap((data: MyObjectModel) => doSomethingWith(data)));\n *   }\n * }\n *\n * @Component({\n *   selector: 'my-page',\n *   templateUrl: './my-page.component.html',\n *   providers: [\n *     {\n *       provide: QD_PAGE_OBJECT_RESOLVER_TOKEN,\n *       useClass: MyObjectModelResolver\n *     }\n *   ]\n * })\n * class MyPageComponent {\n *   pageConfig: QdPageConfig<Pick<MyObjectModel, MyObjectMetadata>> = {\n *     title: { i18n: 'i18n.page.title' },\n *     pageType: 'inspect',\n *     headerFacets: [\n *       {\n *         name: 'status',\n *         label: {\n *           i18n: 'i18n.status.label'\n *         },\n *         options: {\n *           type: 'status'\n *         }\n *       },\n *       {\n *         name: 'countryOfDestination',\n *         label: {\n *           i18n: 'i18n.countryOfDestination.label'\n *         },\n *         options: {\n *           type: 'value'\n *         }\n *       }\n *     ],\n *     pageTypeConfig: {\n *       cancel: {\n *         handler: () => handleCancel()\n *       },\n *       save: {\n *         handler: (formValues) => handleSave(formValues)\n *       }\n *     }\n *   };\n * }\n * ```\n *\n * #### **Updating Facets**\n *\n * Typically, the values of the facets on a create or inspect page are set to read-only. However, there may be cases where, for example, a status change is needed, such as through a dialog. For this purpose, we have provided an update method. In the resolver service, define an empty method called `updateMetadata`. Inject this service using its type, and then call the `updateMetadata` method with the required parameter.\n *\n * **Please note: These values should not be modified directly within a QdPage.**\n *\n * ```ts\n * @Injectable()\n * class MyObjectModelResolver implements QdPageObjectResolver<MyObjectModel> {\n *   config: QdPageObjectResolverConfig = {\n *     // your configuration options here\n *   }\n *\n *   constructor(private http: HttpClient) {}\n *\n *   resolve(): Observable<MyObjectModel> {\n *     // your implementation here\n *   }\n *\n *   updateMetadata(metadata: Partial<MyObjectModel>) {\n *     // leave empty here & call in your component\n *   }\n * }\n *\n * @Component({\n *   // ...\n *   providers: [\n *     {\n *       provide: QD_PAGE_OBJECT_RESOLVER_TOKEN,\n *       useClass: MyObjectModelResolver\n *     }\n *   ]\n * })\n * class MyPageComponent {\n *   constructor(@Inject(QD_PAGE_OBJECT_RESOLVER_TOKEN) private objectResolver: MyObjectModelResolver) {}\n *\n *   updateStatus() {\n *     this.objectResolver.updateMetadata({ state: 'Updated' });\n *   }\n * }\n * ```\n *\n * #### **Overview Page**\n *\n * On an overview page, a list of business cases can be displayed. Typically, this is done in a **QdTable**, including filters and/or search options. There are actions that handle routing to the related detail pages, where the business cases, represented by a business object model, can be viewed, edited, or newly created.\n *\n * ```ts\n * const overviewPageConfig: QdPageConfig<MyObjectType> = {\n *   title: { i18n: 'i18n.my-page.title' },\n *   pageType: 'overview',\n *   pageTypeConfig: {\n *     customActions: [\n *       {\n *         i18n: 'i18n.custom.action',\n *         handler: () => doSomething()\n *       }\n *     ]\n *   }\n * };\n * ```\n *\n * ```html\n * <qd-page [config]=\"pageConfig\">\n *   <qd-section [config]=\"sectionConfig\">\n *     <qd-table [config]=\"tableConfig\"></qd-table>\n *   </qd-section>\n * </qd-page>\n * ```\n *\n * To configure contexts for a page, you can easily set contexts in the configuration for the overview page. They are then selectable on the overview page:\n *\n * ```ts\n * const overviewPageConfig: QdPageConfig<MyObjectType> = {\n *   // ...\n *   contexts: [\n *     {\n *       id: 'typeOfTraffic',\n *       label: { i18n: 'Verkehrsart' },\n *       type: 'single',\n *       selected: {\n *         label: { i18n: 'Schiene' },\n *         value: 'rail'\n *       },\n *       options: [\n *         {\n *           value: 'rail',\n *           label: { i18n: 'Schiene' }\n *         },\n *         {\n *           value: 'air',\n *           label: { i18n: 'Luft' }\n *         }\n *       ]\n *     }\n *   ]\n *   // ...\n * };\n * ```\n *\n * #### **Create Page**\n *\n * On the create page, a new business case can be created. This page typically includes forms for entering data. The submit button is parameterized with the form data and is validated through the QdPageStepper.\n * The click on the submit button should submit the creation of the business case or object. You can define a specific handler in the submit button's configuration to create the object.\n * If only one step is needed, the single-step mode can be used. In single-step mode, the stepper is visually hidden and behaves like a **QdSection**.\n *\n * ```ts\n * const createPageConfig: QdPageConfig<MyObjectType> = {\n *   title: { i18n: 'i18n.page.title' },\n *   pageType: 'create',\n *   pageTypeConfig: {\n *     submit: {\n *       handler: (formValues) => handleSubmit(formValues)\n *     }\n *   }\n * };\n * ```\n *\n * ```html\n * <!-- For \"Quick Add\" use PageStepper in single-step mode -->\n * <qd-page [config]=\"pageConfig\">\n *   <qd-page-stepper [config]=\"stepperConfig\">\n *     <qd-page-step [config]=\"stepConfigOne\">\n *       <qd-section [config]=\"sectionConfig\">\n *         <qd-grid [config]=\"gridConfig\" [formGroup]=\"myForms\" qdConnectFormStateToPage=\"myForms\">\n *           <!-- your qd-form-components here -->\n *         </qd-grid>\n *       </qd-section>\n *     </qd-page-step>\n *   </qd-page-stepper>\n * </qd-page>\n *\n * <!-- With PageStepper using multiple steps -->\n * <qd-page [config]=\"pageConfig\">\n *   <qd-page-stepper [config]=\"stepperConfig\">\n *     <qd-page-step [config]=\"stepConfigOne\">\n *       <qd-section [config]=\"sectionConfig\">\n *         <qd-grid [config]=\"gridConfig\" [formGroup]=\"myFormsOne\" qdConnectFormStateToPage=\"myFormsOne\">\n *           <!-- your qd-form-components here -->\n *         </qd-grid>\n *       </qd-section>\n *     </qd-page-step>\n *     <qd-page-step [config]=\"stepConfigTwo\">\n *       <qd-section [config]=\"sectionConfig\">\n *         <qd-grid [config]=\"gridConfig\" [formGroup]=\"myFormsTwo\" qdConnectFormStateToPage=\"myFormsTwo\">\n *           <!-- your qd-form-components here -->\n *         </qd-grid>\n *       </qd-section>\n *     </qd-page-step>\n *   </qd-page-stepper>\n * </qd-page>\n * ```\n *\n * To allow resolving asynchronous operations when going to next step, you can provide a resolver of type QdPageStepResolver:\n *\n * ```ts\n * class MyResolver implements QdPageStepResolver {\n *   ...\n *\n *   resolve(index: number): Observable<void> {\n *     return this.http.post(\"next-step.com\");\n *   }\n * }\n *\n * @Component({\n *   selector: 'qd-ui-page-create',\n *   templateUrl: './create.component.html',\n *   providers: [\n *     {\n *       provide: QD_PAGE_STEP_RESOLVER_TOKEN,\n *       useClass: PageStepResolver\n *     }\n *   ]\n * })\n * export class CreateComponent {\n * ```\n *\n * #### **Inspect Page**\n *\n * On an inspect page, a specific business case is displayed and may be edited or submitted. Depending on your needs you can hide the submit button.\n * In contrast to a create page, an existing object is shown and potentially updated.\n *\n * The page operates in one of two modes - `view` or `edit` - as defined by the `operationMode` configuration key.\n *\n * The `viewonly` behavior defined by the operation mode is automatically propagated to all nested QdSection components that are part of a QLS,\n * as well as to functional patterns such as QdTable, QdTree, QdFileCollector, and QdQuickEdit.\n * All forms are rendered either in viewonly or editable mode accordingly.\n *\n * This behavior can be explicitly overridden in each component’s configuration - for example, to allow certain fields to remain editable.\n *\n * - **view**: A submit action can optionally be added for process-related operations such as status updates.\n *   The action receives the current form values and supports validation and parameterization.\n *\n * - **edit**: Typically includes a save button to persist changes made in editable fields.\n *\n * ```ts\n * const inspectPageConfig: QdPageConfig<MyObjectType> = {\n *   title: { i18n: 'i18n.page.title' },\n *   pageType: 'inspect',\n *   pageTypeConfig: {\n *     operationMode: 'edit',\n *     cancel: {\n *       handler: () => handleCancel()\n *     },\n *     save: {\n *       handler: (formValues) => handleSave(formValues)\n *     }\n *   }\n * };\n * ```\n *\n * ```html\n * <!-- with Section -->\n * <qd-page [config]=\"pageConfig\">\n *   <qd-section [config]=\"sectionConfig\">\n *     <qd-grid [config]=\"gridConfig\" [formGroup]=\"myForms\" qdConnectFormStateToPage=\"myForms\">\n *       <!-- your qd-form-components here -->\n *     </qd-grid>\n *   </qd-section>\n * </qd-page>\n *\n * <!-- with PageTabs -->\n * <qd-page [config]=\"pageConfig\">\n *   <qd-page-tabs [config]=\"stepperConfig\">\n *     <qd-page-tab [config]=\"tabConfigOne\">\n *       <qd-section [config]=\"sectionConfig\">\n *         <qd-grid [config]=\"gridConfig\" [formGroup]=\"myFormsOne\" qdConnectFormStateToPage=\"myFormsOne\">\n *           <!-- your qd-form-components here -->\n *         </qd-grid>\n *       </qd-section>\n *     </qd-page-tab>\n *     <qd-page-tab [config]=\"tabConfigTwo\">\n *       <qd-section [config]=\"sectionConfig\">\n *         <qd-grid [config]=\"gridConfig\" [formGroup]=\"myFormsTwo\" qdConnectFormStateToPage=\"myFormsTwo\">\n *           <!-- your qd-form-components here -->\n *         </qd-grid>\n *       </qd-section>\n *     </qd-page-tab>\n *   </qd-page-tabs>\n * </qd-page>\n * ```\n *\n * #### **Custom Page**\n *\n * ```ts\n * const customPageConfig: QdPageConfig<MyObjectType> = {\n *   title: { i18n: 'i18n.page.title' },\n *   pageType: 'custom',\n *   pageTypeConfig: {\n *     customActions: [\n *       {\n *         i18n: 'i18n.custom.action',\n *         handler: () => doSomething()\n *       }\n *     ]\n *   }\n * };\n * ```\n *\n * ```html\n * <qd-page [config]=\"pageConfig\">\n *   <!-- Place content here that doesn’t fit the other page types -->\n * </qd-page>\n * ```\n */\n@Component({\n  selector: 'qd-page',\n  templateUrl: './page.component.html',\n  styleUrls: ['./page.component.scss'],\n  providers: [QdPageFooterService, QdFormGroupManagerService, QdPageSubmitActionService, QdResolverTriggerService],\n  host: { '[class.has-control-panel]': 'isControlPanelVisible', '[class.control-panel-broad]': 'isControlPanelBroad' }\n})\nexport class QdPageComponent<T extends object> implements OnInit, OnChanges, AfterViewInit, OnDestroy {\n  /**\n   * This property defines the configuration for the QdPage component, including the page type,\n   * title, and specific configurations for each type of page.\n   */\n  @Input({ required: true })\n  config!: QdPageConfig<T>;\n\n  /**\n   * A static test ID for integration tests can be set. <br />\n   * The value for the HTML attribute [data-test-id].\n   */\n  @Input('data-test-id') testId? = 'page';\n\n  /**\n   * This event is emitted when the operation mode of the inspect page is changed.\n   */\n  @Output()\n  operationModeChanged = new EventEmitter<QdInspectOperationMode>();\n\n  @ContentChildren(QdSectionComponent)\n  sections!: QueryList<QdSectionComponent>;\n\n  @ContentChild(QdPageControlPanelComponent)\n  controlPanel!: QdPageControlPanelComponent;\n\n  @ContentChild(QdPageStepperComponent, { descendants: true })\n  stepperComponent?: QdPageStepperComponent;\n\n  @ContentChild(QdPageTabsComponent, { descendants: true })\n  tabsComponent?: QdPageTabsComponent;\n\n  @ContentChild(QdPageStepperAdapterDirective, { descendants: true })\n  stepperAdapterDirective?: QdPageStepperAdapterDirective;\n\n  @ContentChild(QdPageTabsAdapterDirective, { descendants: true })\n  tabsAdapterDirective?: QdPageTabsAdapterDirective;\n\n  @ContentChildren(QdPageInfoBannerComponent)\n  infoBanners!: QueryList<QdPageInfoBannerComponent>;\n\n  footerHasContent$: Observable<boolean>;\n  isFooterVisible: boolean | undefined;\n  projectionGuardMessage =\n    'QD-UI | QdPage - This content is not supported. Please use QdSectionAdapterDirective for custom content projection.';\n\n  private _isInitialized = false;\n  private _destroyed$ = new Subject<void>();\n\n  get isControlPanelVisible(): boolean {\n    return this.controlPanel !== undefined && this.controlPanel.config?.isHidden !== true;\n  }\n\n  get isControlPanelBroad(): boolean {\n    return this.controlPanel?.config?.width === 'broad';\n  }\n\n  get hasNavigation(): boolean {\n    return !!(this.stepperComponent || this.tabsComponent || this.stepperAdapterDirective || this.tabsAdapterDirective);\n  }\n\n  @HostBinding('class.has-footer')\n  get footerVisible(): boolean | undefined {\n    return this.isFooterVisible;\n  }\n\n  @HostBinding('class.has-info-banners')\n  get hasInfoBanners(): boolean {\n    return this.infoBanners.length > 0;\n  }\n\n  constructor(\n    private readonly pageStoreService: QdPageStoreService<T>,\n    private readonly footerService: QdPageFooterService,\n    private readonly formGroupManagerService: QdFormGroupManagerService,\n    private readonly submitActionService: QdPageSubmitActionService,\n    private readonly dialog: QdDialogService,\n    @Optional() @Inject(QD_SAFE_BOTTOM_OFFSET) private bottomOffset$?: BehaviorSubject<number>,\n    @Optional() private readonly dialogRef?: DialogRef<unknown>\n  ) {\n    this.footerHasContent$ = this.footerService.footerHasContent$;\n    this.footerHasContent$.pipe(takeUntil(this._destroyed$)).subscribe(isVisible => {\n      this.isFooterVisible = isVisible;\n      this.bottomOffset$?.next(isVisible ? SAFE_BOTTOM_OFFSET_PX : 0);\n    });\n  }\n\n  ngOnInit(): void {\n    this.checkConfigValidity();\n\n    if (this.config) this.pageStoreService.initPageState(this.config);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const configChange = changes['config'];\n\n    if (!configChange) return;\n\n    const { currentValue: curr, previousValue: prev } = configChange;\n\n    if (curr?.pageTypeConfig?.submit?.isHidden !== prev?.pageTypeConfig?.submit?.isHidden)\n      this.footerService.updateActions([\n        { actionKey: 'submit', partialAction: { isVisible: !curr?.pageTypeConfig?.submit?.isHidden } }\n      ]);\n  }\n\n  ngAfterViewInit(): void {\n    if (this.config.pageType === 'create') this.setupCreatePageFooterActions();\n\n    if (this.config.pageType === 'create' && this.config?.pageTypeConfig?.cancel !== undefined)\n      this.handleCancelActionWithFormChanges();\n\n    if (this.config.pageType === 'create' && this.config?.pageTypeConfig?.saveDraft !== undefined)\n      this.initSaveDraftFooterAction();\n\n    if (this.config.pageType === 'inspect')\n      this.pageStoreService.isViewonly$\n        .pipe(takeUntil(this._destroyed$))\n        .subscribe(isViewonly =>\n          this.updateInspectPageOperationMode(\n            this.config.pageTypeConfig as QdPageTypeInspectConfig,\n            isViewonly ? 'view' : 'edit'\n          )\n        );\n\n    this.setupPageDialogCloseContract();\n    this._isInitialized = true;\n  }\n\n  ngOnDestroy(): void {\n    this.dialogRef && this.dialog.clearPageDialogCanClose(this.dialogRef);\n    this.bottomOffset$?.next(0);\n    this._destroyed$.next();\n    this._destroyed$.complete();\n  }\n\n  private checkConfigValidity(): void {\n    if (!this.config) console.warn('QdUi | QdPageComponent - To configure the page you should provide a valid config.');\n  }\n\n  private setupCreatePageFooterActions(): void {\n    const pageTypeConfig = this.config?.pageTypeConfig as QdPageTypeCreateConfig;\n    const actionKeys: QdCreateFooterActionKey[] = ['saveDraft', 'cancel', 'submit'];\n    const actions: PartialFooterAction[] = [];\n\n    for (const actionKey of actionKeys) {\n      const action = pageTypeConfig[actionKey];\n\n      if (!action) continue;\n\n      actions.push({\n        actionKey,\n        partialAction: {\n          ...(action?.label?.i18n ? { titleI18n: action.label.i18n } : {}),\n          handler: this.generateFooterActionHandler(action?.handler)\n        }\n      });\n    }\n\n    this.footerService.updateActions(actions);\n  }\n\n  private handleCancelActionWithFormChanges(): void {\n    this.formGroupManagerService\n      .$hasValuesChanged()\n      .pipe(takeUntil(this._destroyed$))\n      .subscribe(hasChanged => {\n        this.footerService.updateActions([\n          {\n            actionKey: 'cancel',\n            partialAction: {\n              handler: hasChanged\n                ? (): void => this.setupSubmitActionValidation()\n                : (): void => (this.config?.pageTypeConfig as QdPageTypeCreateConfig)?.cancel?.handler()\n            }\n          }\n        ]);\n      });\n  }\n\n  private initSaveDraftFooterAction(): void {\n    const pageTypeConfig = this.config.pageTypeConfig as QdPageTypeCreateConfig;\n\n    this.footerService.setActions([\n      {\n        key: 'saveDraft',\n        action: {\n          titleI18n: pageTypeConfig.saveDraft?.label?.i18n ?? 'i18n.qd.page.footer.saveDraft',\n          type: QdFooterActionType.Secondary,\n          handler: (): void => pageTypeConfig?.saveDraft?.handler(),\n          isVisible: true,\n          isDisabled: false\n        }\n      }\n    ]);\n  }\n\n  private updateInspectPageOperationMode(pageTypeConfig: QdPageTypeInspectConfig, mode: QdInspectOperationMode): void {\n    this.submitActionService.setSubmitActionForInspect(pageTypeConfig, mode === 'view');\n\n    this.footerService.updateActions([\n      { actionKey: 'submit', partialAction: { isVisible: mode === 'view' && !pageTypeConfig?.submit?.isHidden } }\n    ]);\n\n    this.initSubmitValidation();\n\n    if (this._isInitialized) this.operationModeChanged.emit(mode);\n  }\n\n  private generateFooterActionHandler(handler?: (values: unknown) => void): (...args: unknown[]) => void {\n    return (...args) => {\n      if (!handler) return;\n\n      handler(this.formGroupManagerService.hasFormGroups() ? this.formGroupManagerService.getAllValues() : args);\n    };\n  }\n\n  private setupSubmitActionValidation(): void {\n    this.dialog\n      .open(QdPageCancelConfirmationDialogComponent, {\n        title: { i18n: 'i18n.qd.page.cancel.confirmation.dialog.title' },\n        dialogSize: QdDialogSize.Small,\n        data: this.config.pageTypeConfig\n      })\n      .closed.pipe(takeUntil(this._destroyed$))\n      .subscribe();\n  }\n\n  private initSubmitValidation(): void {\n    this.formGroupManagerService\n      .$areFormGroupsValid()\n      .pipe(\n        takeUntil(this._destroyed$),\n        tap(isValid => {\n          const submitDisabledInfoText =\n            this.config.pageType === 'inspect' ? this.config.pageTypeConfig?.submit?.disabledInfo : undefined;\n\n          this.footerService.updateActions([\n            {\n              actionKey: 'submit',\n              partialAction: {\n                additionalInfo: isValid\n                  ? undefined\n                  : {\n                      infoType: 'warning',\n                      message: submitDisabledInfoText ?? { i18n: 'i18n.qd.page.submit.invalidForm' }\n                    }\n              }\n            }\n          ]);\n        })\n      )\n      .subscribe();\n  }\n\n  private setupPageDialogCloseContract(): void {\n    if (!this.dialogRef) return;\n\n    const dialogSize = (this.dialogRef.config as unknown as { dialogSize?: QdDialogSize }).dialogSize;\n    if (dialogSize !== QdDialogSize.FullWidth) return;\n\n    this.dialog.setPageDialogCanClose(\n      () =>\n        this.formGroupManagerService.$hasValuesChanged().pipe(\n          take(1),\n          map(hasChanges => ({\n            canClose: !hasChanges,\n            hasChanges,\n            cause: hasChanges ? 'UNSAVED_CHANGES' : undefined\n          }))\n        ),\n      this.dialogRef\n    );\n  }\n}\n","<main qdSnackbarListener>\n  <qd-page-object-header\n    [data-test-id]=\"testId\"\n    [attr.data-test-id]=\"testId + 'object-header'\"\n    [config]=\"config\"\n    [hasNavigation]=\"hasNavigation\"\n  ></qd-page-object-header>\n\n  <div class=\"page-info-banners\">\n    <ng-content select=\"qd-page-info-banner\"></ng-content>\n  </div>\n\n  <ng-container *ngIf=\"config.pageType === 'create' || config.pageType === 'custom'\">\n    <ng-content select=\"qd-page-stepper\"></ng-content>\n    <ng-content select=\"[qdPageStepperAdapter]\"></ng-content>\n  </ng-container>\n\n  <ng-container *ngIf=\"config.pageType === 'overview' || config.pageType === 'inspect' || config.pageType === 'custom'\">\n    <ng-content select=\"qd-page-tabs\"></ng-content>\n    <ng-content select=\"[qdPageTabsAdapter]\"></ng-content>\n    <ng-content select=\"qd-section\"></ng-content>\n    <ng-content select=\"[qdSectionAdapter]\"></ng-content>\n  </ng-container>\n\n  <ng-container *ngIf=\"config.pageType === 'custom'\">\n    <ng-container *ngTemplateOutlet=\"projectedContent\"></ng-container>\n  </ng-container>\n</main>\n\n<footer *ngIf=\"footerHasContent$ | async\">\n  <qd-page-footer [attr.data-test-id]=\"testId + '-footer'\">\n    <ng-content select=\"[qdPageFooter]\"></ng-content>\n  </qd-page-footer>\n</footer>\n\n<aside *ngIf=\"isControlPanelVisible\">\n  <ng-content select=\"qd-page-control-panel\"></ng-content>\n</aside>\n\n<qd-projection-guard *ngIf=\"config.pageType !== 'custom'\" [warningMessage]=\"projectionGuardMessage\">\n  <ng-container *ngTemplateOutlet=\"projectedContent\"></ng-container>\n</qd-projection-guard>\n\n<ng-template #projectedContent>\n  <ng-content></ng-content>\n</ng-template>\n"]}
|
|
675
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page.component.js","sourceRoot":"","sources":["../../../../../libs/qd-ui/src/lib/page/page.component.ts","../../../../../libs/qd-ui/src/lib/page/page.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ContentChild,\n  ContentChildren,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  SimpleChanges\n} from '@angular/core';\nimport { DialogRef } from '@angular/cdk/dialog';\nimport { BehaviorSubject, map, Observable, Subject } from 'rxjs';\nimport { take, takeUntil, tap } from 'rxjs/operators';\n\nimport { QD_SAFE_BOTTOM_OFFSET } from '../core/core.module';\nimport { QdDialogService, QdDialogSize } from '../dialog/dialog.module';\nimport { QdPageStepperAdapterDirective } from '../page-stepper/adaptors/page-stepper-adapter.directive';\nimport { QdPageStepperComponent } from '../page-stepper/page-stepper.component';\nimport { QdPageTabsAdapterDirective } from '../page-tabs/adaptors/page-tabs-adapter.directive';\nimport { QdPageTabsComponent } from '../page-tabs/page-tabs.component';\nimport { QdSectionComponent } from '../section/section.component';\nimport { QdPageCancelConfirmationDialogComponent } from './cancel-confirmation-dialog/page-cancel-confirmation-dialog.component';\nimport { QdPageControlPanelComponent } from './control-panel/page-control-panel.component';\nimport { QdPageInfoBannerComponent } from './info-banner/page-info-banner.component';\nimport {\n  QdInspectOperationMode,\n  QdPageConfig,\n  QdPageTypeCreateConfig,\n  QdPageTypeInspectConfig\n} from './model/page-config.interface';\nimport { QdCreateFooterActionKey, QdFooterActionType, QdPageFooterAction } from './model/page-footer-action.interface';\nimport { QdFormGroupManagerService } from './shared/services/form-group-manager.service';\nimport { QdPageFooterService } from './shared/services/page-footer.service';\nimport { QdPageStoreService } from './shared/services/page-store.service';\nimport { QdPageSubmitActionService } from './shared/services/page-submit-action.service';\nimport { QdResolverTriggerService } from './shared/services/resolver-trigger.service';\n\ntype PartialFooterAction = { actionKey: QdCreateFooterActionKey; partialAction: Partial<QdPageFooterAction> };\n\n// Footer offset (px). Keep in sync with SCSS $page-footer-height!\nconst SAFE_BOTTOM_OFFSET_PX = 64;\n\n/**\n * **QdPage** serves as the central structural element within the hierarchy under the **QdShell**.\n * Integration is done through the Angular Routing Module, and QdPage is designed to be responsive across various screen sizes right out of the box.\n *\n * #### **Page Types**\n *\n * QdPage uses page types to decide how the page looks and works. Each page type has its own settings and actions.\n *\n * - **overview**: Displays a summary or a list of objects, providing an overview of multiple business cases.\n * - **create**: Allows the creation of a new object, representing a business case.\n * - **inspect**: Enables viewing, editing, and executing additional actions related to the object, which also represents a business case.\n * - **custom**: Provides a way to implement unique functionality that doesn’t fit the other predefined page types.\n *\n * **Note that the 'custom' page type should be used only as a fallback for very specific cases. If you encounter such a situation, please contact the Quadrel team.**\n *\n * #### **Facets**\n *\n * These are extra pieces of information shown in the page header. They give context specific to the current object model being viewed or edited. There are several types of facets, including `status`, `value`, `criticality`, `references`, `progress`, `date`, `singleSelect`, and `multiSelect`. Each type has its own options. For more details, see the `QdPageHeaderFacet` interface.\n *\n * #### **Context**\n *\n * The `context` acts as a filter that can be selected on the overview page and provides the business context, which remains consistent throughout the entire application. On create and inspect pages, the context is displayed as read-only. For more details, check the dedicated chapter in Storybook.\n *\n *\n * #### **Page Info Banners**\n *\n * To insert a page info banner under the page header, just put a `qd-page-info-banner` component inside the `qd-page`. Multiple consecutive info banners of the same type will be merged into one banner container. Page info banners have the same appearance like notifications.\n *\n * #### **Control Panel**\n *\n * The control panel is located on the right side of the page and is used to display additional information and functions relevant to a specific business case, which is linked to a specific object model. For further information, please consult the dedicated chapter in Storybook.\n *\n * #### **Actions**\n *\n * These are interactive elements that perform specific functions. Functions for these actions can be set up through configurations. Custom actions can be added to any page type. Additionally, all actions can be configured and customized with your own text, which will override the default texts.\n *\n * Please check the relevant interfaces for each page type: `QdPageConfigOverview`, `QdPageConfigCreate`, `QdPageConfigInspect`, and `QdPageConfigCustom`.\n *\n * #### **Validation/Parameterization**\n *\n * Validation and parameterization are covered in a dedicated chapter in the Storybook. Please check the \"Validation\" section for more information.\n *\n * #### **Resolver**\n *\n * Using a resolver to fetch page object data is essential to the page concept. Add the resolver to the component's providers and use the `QD_PAGE_OBJECT_RESOLVER_TOKEN` token. This approach enables type safety and user feedback by effectively managing the necessary data for the page.\n *\n * ```ts\n * interface MyObjectModel {\n *   // Metadata displayed in the ObjectHeader\n *   state: MyState;\n *   countryOfDestination: MyCountryOfDestination;\n *   // Appears not in the ObjectHeader\n *   payload: MyPayload;\n * }\n *\n * type MyObjectMetadata = 'state' | 'countryOfDestination';\n *\n * @Injectable()\n * class MyObjectModelResolver implements QdPageObjectResolver<MyObjectModel> {\n *   constructor(private http: HttpClient) {}\n *\n *   resolve(): Observable<MyObjectModel> {\n *     return this.http\n *       .get<MyObjectModel>('my-api')\n *       .pipe(tap((data: MyObjectModel) => doSomethingWith(data)));\n *   }\n * }\n *\n * @Component({\n *   selector: 'my-page',\n *   templateUrl: './my-page.component.html',\n *   providers: [\n *     {\n *       provide: QD_PAGE_OBJECT_RESOLVER_TOKEN,\n *       useClass: MyObjectModelResolver\n *     }\n *   ]\n * })\n * class MyPageComponent {\n *   pageConfig: QdPageConfig<Pick<MyObjectModel, MyObjectMetadata>> = {\n *     title: { i18n: 'i18n.page.title' },\n *     pageType: 'inspect',\n *     headerFacets: [\n *       {\n *         name: 'status',\n *         label: {\n *           i18n: 'i18n.status.label'\n *         },\n *         options: {\n *           type: 'status'\n *         }\n *       },\n *       {\n *         name: 'countryOfDestination',\n *         label: {\n *           i18n: 'i18n.countryOfDestination.label'\n *         },\n *         options: {\n *           type: 'value'\n *         }\n *       }\n *     ],\n *     pageTypeConfig: {\n *       cancel: {\n *         handler: () => handleCancel()\n *       },\n *       save: {\n *         handler: (formValues) => handleSave(formValues)\n *       }\n *     }\n *   };\n * }\n * ```\n *\n * #### **Updating Facets**\n *\n * Typically, the values of the facets on a create or inspect page are set to read-only. However, there may be cases where, for example, a status change is needed, such as through a dialog. For this purpose, we have provided an update method. In the resolver service, define an empty method called `updateMetadata`. Inject this service using its type, and then call the `updateMetadata` method with the required parameter.\n *\n * **Please note: These values should not be modified directly within a QdPage.**\n *\n * ```ts\n * @Injectable()\n * class MyObjectModelResolver implements QdPageObjectResolver<MyObjectModel> {\n *   config: QdPageObjectResolverConfig = {\n *     // your configuration options here\n *   }\n *\n *   constructor(private http: HttpClient) {}\n *\n *   resolve(): Observable<MyObjectModel> {\n *     // your implementation here\n *   }\n *\n *   updateMetadata(metadata: Partial<MyObjectModel>) {\n *     // leave empty here & call in your component\n *   }\n * }\n *\n * @Component({\n *   // ...\n *   providers: [\n *     {\n *       provide: QD_PAGE_OBJECT_RESOLVER_TOKEN,\n *       useClass: MyObjectModelResolver\n *     }\n *   ]\n * })\n * class MyPageComponent {\n *   constructor(@Inject(QD_PAGE_OBJECT_RESOLVER_TOKEN) private objectResolver: MyObjectModelResolver) {}\n *\n *   updateStatus() {\n *     this.objectResolver.updateMetadata({ state: 'Updated' });\n *   }\n * }\n * ```\n *\n * #### **Overview Page**\n *\n * On an overview page, a list of business cases can be displayed. Typically, this is done in a **QdTable**, including filters and/or search options. There are actions that handle routing to the related detail pages, where the business cases, represented by a business object model, can be viewed, edited, or newly created.\n *\n * ```ts\n * const overviewPageConfig: QdPageConfig<MyObjectType> = {\n *   title: { i18n: 'i18n.my-page.title' },\n *   pageType: 'overview',\n *   pageTypeConfig: {\n *     customActions: [\n *       {\n *         i18n: 'i18n.custom.action',\n *         handler: () => doSomething()\n *       }\n *     ]\n *   }\n * };\n * ```\n *\n * ```html\n * <qd-page [config]=\"pageConfig\">\n *   <qd-section [config]=\"sectionConfig\">\n *     <qd-table [config]=\"tableConfig\"></qd-table>\n *   </qd-section>\n * </qd-page>\n * ```\n *\n * To configure contexts for a page, you can easily set contexts in the configuration for the overview page. They are then selectable on the overview page:\n *\n * ```ts\n * const overviewPageConfig: QdPageConfig<MyObjectType> = {\n *   // ...\n *   contexts: [\n *     {\n *       id: 'typeOfTraffic',\n *       label: { i18n: 'Verkehrsart' },\n *       type: 'single',\n *       selected: {\n *         label: { i18n: 'Schiene' },\n *         value: 'rail'\n *       },\n *       options: [\n *         {\n *           value: 'rail',\n *           label: { i18n: 'Schiene' }\n *         },\n *         {\n *           value: 'air',\n *           label: { i18n: 'Luft' }\n *         }\n *       ]\n *     }\n *   ]\n *   // ...\n * };\n * ```\n *\n * #### **Create Page**\n *\n * On the create page, a new business case can be created. This page typically includes forms for entering data. The submit button is parameterized with the form data and is validated through the QdPageStepper.\n * The click on the submit button should submit the creation of the business case or object. You can define a specific handler in the submit button's configuration to create the object.\n * If only one step is needed, the single-step mode can be used. In single-step mode, the stepper is visually hidden and behaves like a **QdSection**.\n *\n * ```ts\n * const createPageConfig: QdPageConfig<MyObjectType> = {\n *   title: { i18n: 'i18n.page.title' },\n *   pageType: 'create',\n *   pageTypeConfig: {\n *     submit: {\n *       handler: (formValues) => handleSubmit(formValues)\n *     }\n *   }\n * };\n * ```\n *\n * ```html\n * <!-- For \"Quick Add\" use PageStepper in single-step mode -->\n * <qd-page [config]=\"pageConfig\">\n *   <qd-page-stepper [config]=\"stepperConfig\">\n *     <qd-page-step [config]=\"stepConfigOne\">\n *       <qd-section [config]=\"sectionConfig\">\n *         <qd-grid [config]=\"gridConfig\" [formGroup]=\"myForms\" qdConnectFormStateToPage=\"myForms\">\n *           <!-- your qd-form-components here -->\n *         </qd-grid>\n *       </qd-section>\n *     </qd-page-step>\n *   </qd-page-stepper>\n * </qd-page>\n *\n * <!-- With PageStepper using multiple steps -->\n * <qd-page [config]=\"pageConfig\">\n *   <qd-page-stepper [config]=\"stepperConfig\">\n *     <qd-page-step [config]=\"stepConfigOne\">\n *       <qd-section [config]=\"sectionConfig\">\n *         <qd-grid [config]=\"gridConfig\" [formGroup]=\"myFormsOne\" qdConnectFormStateToPage=\"myFormsOne\">\n *           <!-- your qd-form-components here -->\n *         </qd-grid>\n *       </qd-section>\n *     </qd-page-step>\n *     <qd-page-step [config]=\"stepConfigTwo\">\n *       <qd-section [config]=\"sectionConfig\">\n *         <qd-grid [config]=\"gridConfig\" [formGroup]=\"myFormsTwo\" qdConnectFormStateToPage=\"myFormsTwo\">\n *           <!-- your qd-form-components here -->\n *         </qd-grid>\n *       </qd-section>\n *     </qd-page-step>\n *   </qd-page-stepper>\n * </qd-page>\n * ```\n *\n * To allow resolving asynchronous operations when going to next step, you can provide a resolver of type QdPageStepResolver:\n *\n * ```ts\n * class MyResolver implements QdPageStepResolver {\n *   ...\n *\n *   resolve(index: number): Observable<void> {\n *     return this.http.post(\"next-step.com\");\n *   }\n * }\n *\n * @Component({\n *   selector: 'qd-ui-page-create',\n *   templateUrl: './create.component.html',\n *   providers: [\n *     {\n *       provide: QD_PAGE_STEP_RESOLVER_TOKEN,\n *       useClass: PageStepResolver\n *     }\n *   ]\n * })\n * export class CreateComponent {\n * ```\n *\n * #### **Inspect Page**\n *\n * On an inspect page, a specific business case is displayed and may be edited or submitted. Depending on your needs you can hide the submit button.\n * In contrast to a create page, an existing object is shown and potentially updated.\n *\n * The page operates in one of two modes - `view` or `edit` - as defined by the `operationMode` configuration key.\n *\n * The `viewonly` behavior defined by the operation mode is automatically propagated to all nested QdSection components that are part of a QLS,\n * as well as to functional patterns such as QdTable, QdTree, QdFileCollector, and QdQuickEdit.\n * All forms are rendered either in viewonly or editable mode accordingly.\n *\n * This behavior can be explicitly overridden in each component’s configuration - for example, to allow certain fields to remain editable.\n *\n * - **view**: A submit action can optionally be added for process-related operations such as status updates.\n *   The action receives the current form values and supports validation and parameterization.\n *\n * - **edit**: Typically includes a save button to persist changes made in editable fields.\n *\n * ```ts\n * const inspectPageConfig: QdPageConfig<MyObjectType> = {\n *   title: { i18n: 'i18n.page.title' },\n *   pageType: 'inspect',\n *   pageTypeConfig: {\n *     operationMode: 'edit',\n *     cancel: {\n *       handler: () => handleCancel()\n *     },\n *     save: {\n *       handler: (formValues) => handleSave(formValues)\n *     }\n *   }\n * };\n * ```\n *\n * ```html\n * <!-- with Section -->\n * <qd-page [config]=\"pageConfig\">\n *   <qd-section [config]=\"sectionConfig\">\n *     <qd-grid [config]=\"gridConfig\" [formGroup]=\"myForms\" qdConnectFormStateToPage=\"myForms\">\n *       <!-- your qd-form-components here -->\n *     </qd-grid>\n *   </qd-section>\n * </qd-page>\n *\n * <!-- with PageTabs -->\n * <qd-page [config]=\"pageConfig\">\n *   <qd-page-tabs [config]=\"stepperConfig\">\n *     <qd-page-tab [config]=\"tabConfigOne\">\n *       <qd-section [config]=\"sectionConfig\">\n *         <qd-grid [config]=\"gridConfig\" [formGroup]=\"myFormsOne\" qdConnectFormStateToPage=\"myFormsOne\">\n *           <!-- your qd-form-components here -->\n *         </qd-grid>\n *       </qd-section>\n *     </qd-page-tab>\n *     <qd-page-tab [config]=\"tabConfigTwo\">\n *       <qd-section [config]=\"sectionConfig\">\n *         <qd-grid [config]=\"gridConfig\" [formGroup]=\"myFormsTwo\" qdConnectFormStateToPage=\"myFormsTwo\">\n *           <!-- your qd-form-components here -->\n *         </qd-grid>\n *       </qd-section>\n *     </qd-page-tab>\n *   </qd-page-tabs>\n * </qd-page>\n * ```\n *\n * #### **Custom Page**\n *\n * ```ts\n * const customPageConfig: QdPageConfig<MyObjectType> = {\n *   title: { i18n: 'i18n.page.title' },\n *   pageType: 'custom',\n *   pageTypeConfig: {\n *     customActions: [\n *       {\n *         i18n: 'i18n.custom.action',\n *         handler: () => doSomething()\n *       }\n *     ]\n *   }\n * };\n * ```\n *\n * ```html\n * <qd-page [config]=\"pageConfig\">\n *   <!-- Place content here that doesn’t fit the other page types -->\n * </qd-page>\n * ```\n */\n@Component({\n  selector: 'qd-page',\n  templateUrl: './page.component.html',\n  styleUrls: ['./page.component.scss'],\n  providers: [QdPageFooterService, QdFormGroupManagerService, QdPageSubmitActionService, QdResolverTriggerService],\n  host: { '[class.has-control-panel]': 'isControlPanelVisible', '[class.control-panel-broad]': 'isControlPanelBroad' }\n})\nexport class QdPageComponent<T extends object> implements OnInit, OnChanges, AfterViewInit, OnDestroy {\n  /**\n   * This property defines the configuration for the QdPage component, including the page type,\n   * title, and specific configurations for each type of page.\n   */\n  @Input({ required: true })\n  config!: QdPageConfig<T>;\n\n  /**\n   * A static test ID for integration tests can be set. <br />\n   * The value for the HTML attribute [data-test-id].\n   */\n  @Input('data-test-id') testId? = 'page';\n\n  /**\n   * This event is emitted when the operation mode of the inspect page is changed.\n   */\n  @Output()\n  operationModeChanged = new EventEmitter<QdInspectOperationMode>();\n\n  @ContentChildren(QdSectionComponent)\n  sections!: QueryList<QdSectionComponent>;\n\n  @ContentChild(QdPageControlPanelComponent)\n  controlPanel!: QdPageControlPanelComponent;\n\n  @ContentChild(QdPageStepperComponent, { descendants: true })\n  stepperComponent?: QdPageStepperComponent;\n\n  @ContentChild(QdPageTabsComponent, { descendants: true })\n  tabsComponent?: QdPageTabsComponent;\n\n  @ContentChild(QdPageStepperAdapterDirective, { descendants: true })\n  stepperAdapterDirective?: QdPageStepperAdapterDirective;\n\n  @ContentChild(QdPageTabsAdapterDirective, { descendants: true })\n  tabsAdapterDirective?: QdPageTabsAdapterDirective;\n\n  @ContentChildren(QdPageInfoBannerComponent)\n  infoBanners!: QueryList<QdPageInfoBannerComponent>;\n\n  footerHasContent$: Observable<boolean>;\n  isFooterVisible: boolean | undefined;\n  projectionGuardMessage =\n    'QD-UI | QdPage - This content is not supported. Please use QdSectionAdapterDirective for custom content projection.';\n\n  private _isInitialized = false;\n  private _destroyed$ = new Subject<void>();\n  private _cancelSubmitValidation$ = new Subject<void>();\n\n  get isControlPanelVisible(): boolean {\n    return this.controlPanel !== undefined && this.controlPanel.config?.isHidden !== true;\n  }\n\n  get isControlPanelBroad(): boolean {\n    return this.controlPanel?.config?.width === 'broad';\n  }\n\n  get hasNavigation(): boolean {\n    return !!(this.stepperComponent || this.tabsComponent || this.stepperAdapterDirective || this.tabsAdapterDirective);\n  }\n\n  @HostBinding('class.has-footer')\n  get footerVisible(): boolean | undefined {\n    return this.isFooterVisible;\n  }\n\n  @HostBinding('class.has-info-banners')\n  get hasInfoBanners(): boolean {\n    return this.infoBanners.length > 0;\n  }\n\n  constructor(\n    private readonly pageStoreService: QdPageStoreService<T>,\n    private readonly footerService: QdPageFooterService,\n    private readonly formGroupManagerService: QdFormGroupManagerService,\n    private readonly submitActionService: QdPageSubmitActionService,\n    private readonly dialog: QdDialogService,\n    @Optional() @Inject(QD_SAFE_BOTTOM_OFFSET) private bottomOffset$?: BehaviorSubject<number>,\n    @Optional() private readonly dialogRef?: DialogRef<unknown>\n  ) {\n    this.footerHasContent$ = this.footerService.footerHasContent$;\n    this.footerHasContent$.pipe(takeUntil(this._destroyed$)).subscribe(isVisible => {\n      this.isFooterVisible = isVisible;\n      this.bottomOffset$?.next(isVisible ? SAFE_BOTTOM_OFFSET_PX : 0);\n    });\n  }\n\n  ngOnInit(): void {\n    this.checkConfigValidity();\n\n    if (this.config) this.pageStoreService.initPageState(this.config);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const configChange = changes['config'];\n\n    if (!configChange) return;\n\n    const { currentValue: curr, previousValue: prev } = configChange;\n\n    if (curr?.pageTypeConfig?.submit?.isHidden !== prev?.pageTypeConfig?.submit?.isHidden)\n      this.footerService.updateActions([\n        { actionKey: 'submit', partialAction: { isVisible: !curr?.pageTypeConfig?.submit?.isHidden } }\n      ]);\n  }\n\n  ngAfterViewInit(): void {\n    if (this.config.pageType === 'create') this.setupCreatePageFooterActions();\n\n    if (this.config.pageType === 'create' && this.config?.pageTypeConfig?.cancel !== undefined)\n      this.handleCancelActionWithFormChanges();\n\n    if (this.config.pageType === 'create' && this.config?.pageTypeConfig?.saveDraft !== undefined)\n      this.initSaveDraftFooterAction();\n\n    if (this.config.pageType === 'inspect')\n      this.pageStoreService.isViewonly$\n        .pipe(takeUntil(this._destroyed$))\n        .subscribe(isViewonly =>\n          this.updateInspectPageOperationMode(\n            this.config.pageTypeConfig as QdPageTypeInspectConfig,\n            isViewonly ? 'view' : 'edit'\n          )\n        );\n\n    this.setupPageDialogCloseContract();\n    this._isInitialized = true;\n  }\n\n  ngOnDestroy(): void {\n    this.dialogRef && this.dialog.clearPageDialogCanClose(this.dialogRef);\n    this.bottomOffset$?.next(0);\n    this._destroyed$.next();\n    this._destroyed$.complete();\n  }\n\n  private checkConfigValidity(): void {\n    if (!this.config) console.warn('QdUi | QdPageComponent - To configure the page you should provide a valid config.');\n  }\n\n  private setupCreatePageFooterActions(): void {\n    const pageTypeConfig = this.config?.pageTypeConfig as QdPageTypeCreateConfig;\n    const actionKeys: QdCreateFooterActionKey[] = ['saveDraft', 'cancel', 'submit'];\n    const actions: PartialFooterAction[] = [];\n\n    for (const actionKey of actionKeys) {\n      const action = pageTypeConfig[actionKey];\n\n      if (!action) continue;\n\n      actions.push({\n        actionKey,\n        partialAction: {\n          ...(action?.label?.i18n ? { titleI18n: action.label.i18n } : {}),\n          handler: this.generateFooterActionHandler(action?.handler)\n        }\n      });\n    }\n\n    this.footerService.updateActions(actions);\n  }\n\n  private handleCancelActionWithFormChanges(): void {\n    this.formGroupManagerService\n      .$hasValuesChanged()\n      .pipe(takeUntil(this._destroyed$))\n      .subscribe(hasChanged => {\n        this.footerService.updateActions([\n          {\n            actionKey: 'cancel',\n            partialAction: {\n              handler: hasChanged\n                ? (): void => this.setupSubmitActionValidation()\n                : (): void => (this.config?.pageTypeConfig as QdPageTypeCreateConfig)?.cancel?.handler()\n            }\n          }\n        ]);\n      });\n  }\n\n  private initSaveDraftFooterAction(): void {\n    const pageTypeConfig = this.config.pageTypeConfig as QdPageTypeCreateConfig;\n\n    this.footerService.setActions([\n      {\n        key: 'saveDraft',\n        action: {\n          titleI18n: pageTypeConfig.saveDraft?.label?.i18n ?? 'i18n.qd.page.footer.saveDraft',\n          type: QdFooterActionType.Secondary,\n          handler: (): void => pageTypeConfig?.saveDraft?.handler(),\n          isVisible: true,\n          isDisabled: false\n        }\n      }\n    ]);\n  }\n\n  private updateInspectPageOperationMode(pageTypeConfig: QdPageTypeInspectConfig, mode: QdInspectOperationMode): void {\n    this.submitActionService.setSubmitActionForInspect(pageTypeConfig, mode === 'view');\n\n    this.footerService.updateActions([\n      { actionKey: 'submit', partialAction: { isVisible: mode === 'view' && !pageTypeConfig?.submit?.isHidden } }\n    ]);\n\n    this.initSubmitValidation();\n\n    if (this._isInitialized) this.operationModeChanged.emit(mode);\n  }\n\n  private generateFooterActionHandler(handler?: (values: unknown) => void): (...args: unknown[]) => void {\n    return (...args) => {\n      if (!handler) return;\n\n      handler(this.formGroupManagerService.hasFormGroups() ? this.formGroupManagerService.getAllValues() : args);\n    };\n  }\n\n  private setupSubmitActionValidation(): void {\n    this.dialog\n      .open(QdPageCancelConfirmationDialogComponent, {\n        title: { i18n: 'i18n.qd.page.cancel.confirmation.dialog.title' },\n        dialogSize: QdDialogSize.Small,\n        data: this.config.pageTypeConfig\n      })\n      .closed.pipe(takeUntil(this._destroyed$))\n      .subscribe();\n  }\n\n  private initSubmitValidation(): void {\n    this._cancelSubmitValidation$.next();\n\n    this.formGroupManagerService\n      .$areFormGroupsValid()\n      .pipe(\n        takeUntil(this._cancelSubmitValidation$),\n        takeUntil(this._destroyed$),\n        tap(isValid => {\n          const submitDisabledInfoText =\n            this.config.pageType === 'inspect' ? this.config.pageTypeConfig?.submit?.disabledInfo : undefined;\n\n          this.footerService.updateActions([\n            {\n              actionKey: 'submit',\n              partialAction: {\n                additionalInfo: isValid\n                  ? undefined\n                  : {\n                      infoType: 'warning',\n                      message: submitDisabledInfoText ?? { i18n: 'i18n.qd.page.submit.invalidForm' }\n                    }\n              }\n            }\n          ]);\n        })\n      )\n      .subscribe();\n  }\n\n  private setupPageDialogCloseContract(): void {\n    if (!this.dialogRef) return;\n\n    const dialogSize = (this.dialogRef.config as unknown as { dialogSize?: QdDialogSize }).dialogSize;\n    if (dialogSize !== QdDialogSize.FullWidth) return;\n\n    this.dialog.setPageDialogCanClose(\n      () =>\n        this.formGroupManagerService.$hasValuesChanged().pipe(\n          take(1),\n          map(hasChanges => ({\n            canClose: !hasChanges,\n            hasChanges,\n            cause: hasChanges ? 'UNSAVED_CHANGES' : undefined\n          }))\n        ),\n      this.dialogRef\n    );\n  }\n}\n","<main qdSnackbarListener>\n  <qd-page-object-header\n    [data-test-id]=\"testId\"\n    [attr.data-test-id]=\"testId + 'object-header'\"\n    [config]=\"config\"\n    [hasNavigation]=\"hasNavigation\"\n  ></qd-page-object-header>\n\n  <div class=\"page-info-banners\">\n    <ng-content select=\"qd-page-info-banner\"></ng-content>\n  </div>\n\n  <ng-container *ngIf=\"config.pageType === 'create' || config.pageType === 'custom'\">\n    <ng-content select=\"qd-page-stepper\"></ng-content>\n    <ng-content select=\"[qdPageStepperAdapter]\"></ng-content>\n  </ng-container>\n\n  <ng-container *ngIf=\"config.pageType === 'overview' || config.pageType === 'inspect' || config.pageType === 'custom'\">\n    <ng-content select=\"qd-page-tabs\"></ng-content>\n    <ng-content select=\"[qdPageTabsAdapter]\"></ng-content>\n    <ng-content select=\"qd-section\"></ng-content>\n    <ng-content select=\"[qdSectionAdapter]\"></ng-content>\n  </ng-container>\n\n  <ng-container *ngIf=\"config.pageType === 'custom'\">\n    <ng-container *ngTemplateOutlet=\"projectedContent\"></ng-container>\n  </ng-container>\n</main>\n\n<footer *ngIf=\"footerHasContent$ | async\">\n  <qd-page-footer [attr.data-test-id]=\"testId + '-footer'\">\n    <ng-content select=\"[qdPageFooter]\"></ng-content>\n  </qd-page-footer>\n</footer>\n\n<aside *ngIf=\"isControlPanelVisible\">\n  <ng-content select=\"qd-page-control-panel\"></ng-content>\n</aside>\n\n<qd-projection-guard *ngIf=\"config.pageType !== 'custom'\" [warningMessage]=\"projectionGuardMessage\">\n  <ng-container *ngTemplateOutlet=\"projectedContent\"></ng-container>\n</qd-projection-guard>\n\n<ng-template #projectedContent>\n  <ng-content></ng-content>\n</ng-template>\n"]}
|