@energycap/components 0.39.15-ECAP-24619-disable-page-view-button-inputs.20240425-0917 → 0.39.15
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/esm2020/lib/shared/page/page-base/page-base.component.mjs +1 -1
- package/esm2020/lib/shared/page/page-view/page-view.component.mjs +9 -3
- package/fesm2015/energycap-components.mjs +8 -2
- package/fesm2015/energycap-components.mjs.map +1 -1
- package/fesm2020/energycap-components.mjs +8 -2
- package/fesm2020/energycap-components.mjs.map +1 -1
- package/lib/shared/page/page-view/page-view.component.d.ts +5 -1
- package/package.json +1 -1
@@ -376,4 +376,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
376
376
|
type: HostBinding,
|
377
377
|
args: ['class']
|
378
378
|
}] } });
|
379
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/components/src/lib/shared/page/page-base/page-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Directive, HostBinding, Injector, OnDestroy, OnInit } from '@angular/core';\r\nimport { UntypedFormGroup } from '@angular/forms';\r\nimport { ActivatedRoute, NavigationEnd, Router } from '@angular/router';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Observable, ReplaySubject, Subject, Subscription } from 'rxjs';\r\nimport { filter, takeUntil } from 'rxjs/operators';\r\nimport { NavItem } from '../../../controls/navigation/nav-item';\r\nimport { ErrorService } from '../../../core/error.service';\r\nimport { ScrollService } from '../../../core/scroll.service';\r\nimport { DialogService } from '../../../display/dialog/dialog.service';\r\nimport { SplashService } from '../../../display/splash/splash.service';\r\nimport { Help } from '../../../display/help/help-types';\r\nimport { Overlay } from '../../../display/view-overlay/view-overlay.component';\r\nimport { PageStatus, PageStatuses } from '../page-statuses';\r\nimport { RouterHelper } from '../../../core/router-helper.service';\r\n\r\nexport class PageInitResult {\r\n  title?: string = '';\r\n  subTitle?: string = '';\r\n  subTitleUrl?: string = '';\r\n\r\n  breadcrumbs?: NavItem[];\r\n  help?: Help;\r\n}\r\n\r\n@Directive()\r\nexport abstract class PageBaseComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  /** Default css classes applied to host element */\r\n  @HostBinding('class') protected classList = 'd-flex flex-grow';\r\n\r\n  /**\r\n   * Title for the page displayed in the header\r\n   */\r\n  public title?: string = '';\r\n\r\n  /**\r\n   * Sub title for the page displayed in the header\r\n   */\r\n  public subTitle?: string = '';\r\n\r\n  /**\r\n   * Sub title url for the page displayed in the header\r\n   */\r\n  public subTitleUrl?: string = '';\r\n\r\n  /**\r\n   * Status overlay for the page\r\n   */\r\n  public status: Overlay = new Overlay('pending', 'Loading');\r\n\r\n  /**\r\n   * Breadcrumbs displayed in the header\r\n   */\r\n  public breadcrumbs?: NavItem[];\r\n\r\n  /**\r\n   * Result returned from the onInit function\r\n   */\r\n  public initResult!: PageInitResult;\r\n\r\n  /**\r\n   * Help information for the component, which can only be set through onInit\r\n   */\r\n  public help: Help | undefined;\r\n\r\n  /**\r\n   * Form group to be used if needed by the page\r\n   */\r\n  public formGroup: UntypedFormGroup = new UntypedFormGroup({});\r\n\r\n  /**\r\n   * Default invalid form message, override if a more specific message is needed\r\n   */\r\n  public defaultInvalidFormMessage: string = 'PleaseCorrectForm_SC';\r\n\r\n  /**\r\n   * Default unknown save error message, override if a more specific message is needed\r\n   */\r\n  public defaultUnknownSaveError: string = 'PageBaseUnknownSaveError_SC';\r\n\r\n  /**\r\n   * Used to opt out of hiding the splash screen when the page is loaded\r\n   */\r\n  public skipHideSplashOnComplete: boolean = false;\r\n\r\n  /**\r\n   * When set to true any navigation end events that are strictly query param changes will\r\n   * not call the onNavigationEnd function. This allows pages to change the view with query\r\n   * params and not trigger a full refresh.\r\n   */\r\n  public ignoreQueryParamsOnNavigationChange: boolean = false;\r\n\r\n  private previousUrl: string = \"\";\r\n\r\n  /**\r\n   * Used to unsubscribe from observables\r\n   */\r\n  public destroyed: Subject<any> = new Subject<any>();\r\n\r\n  /**\r\n   * Used to know when the page has been loaded, this will be completed\r\n   * after onAfterViewInit\r\n   */\r\n  private _afterViewInitComplete: ReplaySubject<void> = new ReplaySubject();\r\n  public afterViewInitComplete: Observable<void> = this._afterViewInitComplete;\r\n\r\n  /**\r\n   * If defined the form will automatically scroll to the first invalid form control\r\n   * if it's outside of the view\r\n   */\r\n  protected scrollContainerSelector: string | undefined;\r\n\r\n  /**\r\n   * Subscription to the router events NavigationEnd\r\n   * Used to know if already subscribed to\r\n   */\r\n  private navigationEndSubscription?: Subscription;\r\n\r\n  /**\r\n   * Common services used by page-base\r\n   */\r\n  protected errorService: ErrorService;\r\n  protected translateService: TranslateService;\r\n  protected scrollService: ScrollService;\r\n  protected router: Router;\r\n  protected activatedRoute: ActivatedRoute;\r\n  protected dialogService: DialogService;\r\n  protected splashService: SplashService;\r\n  protected routerHelper: RouterHelper;\r\n\r\n  constructor(injector: Injector) {\r\n    this.errorService = injector.get(ErrorService);\r\n    this.translateService = injector.get(TranslateService);\r\n    this.scrollService = injector.get(ScrollService);\r\n    this.router = injector.get(Router);\r\n    this.activatedRoute = injector.get(ActivatedRoute);\r\n    this.dialogService = injector.get(DialogService);\r\n    this.splashService = injector.get(SplashService);\r\n    this.routerHelper = injector.get(RouterHelper);\r\n  }\r\n\r\n  /**\r\n   * Errors to be shown for the component.\r\n   * Automatically populated on promise rejection from save and shared with the UI.\r\n   */\r\n  private _errors: string = '';\r\n  public get errors(): string {\r\n    return this._errors;\r\n  }\r\n\r\n  /**\r\n   * Optional lifecycle hook that is called as part of the Angular ngOnInit lifecycle hook.\r\n   * Called before onInit is called for the first time. Add setup logic here that does\r\n   * not need to be run on every reload.\r\n   */\r\n  protected onFirstInit(): void { }\r\n\r\n  /**\r\n   * This method is called in the derived class as part of the Angular ngOnInit\r\n   * lifecycle hook. It must provide a PageInitResult back to the base class to properly\r\n   * set up the page.\r\n   */\r\n  protected abstract onInit(): Promise<PageInitResult>;\r\n  protected initPromise!: Promise<PageInitResult>;\r\n\r\n  public async ngOnInit() {\r\n    try {\r\n      this.showStatus(PageStatus.Loading);\r\n      this.setUpRouterSubscriptions();\r\n      this.onFirstInit();\r\n      this.initPromise = this.onInit();\r\n\r\n      await this.initPromise;\r\n    } catch (error) {\r\n      this.splashService.hideSplash();\r\n      this.onError(error);\r\n    };\r\n  }\r\n\r\n  /**\r\n   * This method is called just after the Angular Lifecycle event ngOnAfterViewInit.\r\n   * It fires after all sub-components have gone through their initialization phase.\r\n   * It is in this phase that the view components should already exist, so a derived class should\r\n   * load data from the API to populate any view components. The promise that\r\n   * is returned must not resolve until all required data has completely loaded\r\n   */\r\n  protected async onAfterViewInit(): Promise<void> { };\r\n  public async ngAfterViewInit(): Promise<void> {\r\n    try {\r\n      const initResult = await this.initPromise;\r\n      this.parseInitResult(initResult);\r\n\r\n      await this.onAfterViewInit();\r\n\r\n      this._afterViewInitComplete.next();\r\n      this._afterViewInitComplete.complete();\r\n\r\n      await this.onFormLoadComplete();\r\n\r\n      if (this.status.status === 'pending') {\r\n        this.showStatus(PageStatus.Loaded);\r\n      }\r\n\r\n      if (!this.skipHideSplashOnComplete) {\r\n        this.splashService.hideSplash();\r\n      }\r\n\r\n    } catch (error) {\r\n      this.splashService.hideSplash();\r\n      this.onError(error);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * A lifecycle method that executes once all data has been loaded\r\n   * through ngAfterViewInit and from local storage if required.\r\n   * It is at this point that you can subscribe to changes on the form\r\n   * reliably\r\n   *\r\n   * @protected\r\n   * @memberof PageBaseComponent\r\n   */\r\n  protected async onFormLoadComplete(): Promise<any> { }\r\n\r\n  /**\r\n   * A lifecycle hook that is called after every NavigationEnd event.\r\n   */\r\n  protected onNavigationEnd(): void { }\r\n\r\n  /**\r\n   * Reload the component kicking off the ngOnInit and ngAfterViewInit lifecycle hooks.\r\n   * Any state that needs to be reset should be done so before calling this method.\r\n   */\r\n  public reload(): void {\r\n    this._afterViewInitComplete = new ReplaySubject();\r\n\r\n    this.showStatus(PageStatus.Loading);\r\n    this.initPromise = this.onInit();\r\n    this.ngAfterViewInit();\r\n  }\r\n\r\n  /**\r\n   * When overridden in a derived class this method will sync the form state\r\n   * into the object that will be persisted to the API. The value should not\r\n   * actually be sent to the API yet.\r\n   */\r\n  protected async applyModelUpdates(): Promise<void> { };\r\n\r\n  /**\r\n   * Save the model state to the API and return a promise that\r\n   * contains the updated entityID. The promise should be rejected\r\n   * if the save fails and errors and the overlay status will be updated\r\n   * accordingly\r\n   */\r\n  protected async saveToApi(): Promise<number | void> { };\r\n\r\n  /**\r\n   * Called after the save has completed successfully.\r\n   * It is the responsibility of the derived class to navigate\r\n   * to a properties/status page or emit appropriately if within a dialog\r\n   * @param entityId\r\n   */\r\n  protected onSaveComplete(entityId?: number): void { };\r\n\r\n  /**\r\n   * Function called when the user clicks save.  We will first touch all controls to show validation messages\r\n   * if the form is invalid.  If the form is valid we will attempt to save and any errors will be reported\r\n   * back to the user\r\n   * @param event\r\n   */\r\n  public async onSave(event: Event): Promise<void> {\r\n    this.formGroup.markAllAsTouched();\r\n\r\n    if (this.formGroup.valid) {\r\n      await this.save();\r\n    } else {\r\n      // Only show the banner with the generic message if the parent component hasn't already set one\r\n      // by implementing onSave for additional validation\r\n      if (this.errors === '') {\r\n        this.showErrorBanner(this.defaultInvalidFormMessage);\r\n      }\r\n\r\n      if (this.scrollContainerSelector) {\r\n        setTimeout(() => {\r\n          this.scrollService.scrollToItem(this.scrollContainerSelector!, \".ng-invalid\");\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Function available to trigger a save and bypass the form validation checks.\r\n   * This is useful if the user chooses a remove action from within an edit dialog. If the dialog form is invalid\r\n   * that is no concern to the user if they wish to remove the item they are editing.\r\n   * @param event\r\n   */\r\n  public async onSaveWithoutValidate(event: Event): Promise<void> {\r\n    await this.save();\r\n  }\r\n\r\n  /**\r\n   * Function called when the component is destroyed\r\n   */\r\n  public ngOnDestroy(): void {\r\n    this.destroyed.next();\r\n    this.destroyed.unsubscribe();\r\n  }\r\n\r\n  /**\r\n   * Function that will log an error that is passed in to the console\r\n   * @param e\r\n   */\r\n  protected onError(error: Error): void {\r\n    this.errorService.logConsoleError(error);\r\n    this.showErrorOverlay(error);\r\n  }\r\n\r\n  /**\r\n   * Show an error message in a whole-page overlay. This will prevent any more\r\n   * interactions with the page. It can take a string error message or a raw API\r\n   * error that needs to be parsed. If the API error isn't something we can handle\r\n   * a generic message is shown instead\r\n   * @param {(Error | string)} error\r\n   */\r\n  protected showErrorOverlay(error: Error | string) {\r\n    this.getErrorMessage(error).subscribe((translatedMessage: string) => {\r\n      this.status.setStatus('error', translatedMessage);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Show an error in the banner at the top of the screen.  This will not produce a\r\n   * whole-page overlay like the function showError will.  It can take a string error message\r\n   * or raw API error that needs to be parsed.  If the API error isn't something we can handle,\r\n   * a generic message (customizable via unknownErrorDefault) is shown instead.\r\n   * @param error\r\n   * @param unknownErrorDefault\r\n   */\r\n  protected showErrorBanner(error: Error | string, unknownErrorDefault?: string): void {\r\n    this.getErrorMessage(error, unknownErrorDefault).subscribe((translatedMessage: string) => {\r\n      this._errors = translatedMessage;\r\n      this.showStatus(PageStatus.Loaded);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Parses and translates an API error or error string.\r\n   * @param e\r\n   * @param unknownErrorDefault\r\n   */\r\n  protected getErrorMessage(e: Error | string, unknownErrorDefault?: string): Observable<string> {\r\n    let extractedMessage = this.errorService.parseApiError(e, unknownErrorDefault);\r\n    return this.translateService.get(extractedMessage);\r\n  }\r\n\r\n  /**\r\n   * Clear the errors to hide the errors banner.\r\n   */\r\n  protected hideErrorBanner(): void {\r\n    this._errors = '';\r\n  }\r\n\r\n  /**\r\n   * Change the display status to overlay the whole page while loading or saving\r\n   * and clear it when the form is ready\r\n   * @protected\r\n   * @param {PageStatus} status\r\n   * @memberof FormBaseComponent\r\n   */\r\n  protected showStatus(status: PageStatus) {\r\n    let knownStatus = PageStatuses[status];\r\n    if (knownStatus) {\r\n      this.status.setStatus(knownStatus.status, knownStatus.message, undefined, knownStatus.noDataTemplate, knownStatus.overlayClassList);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Allows the component to enter a pending status and execute a function that on completion will return the status\r\n   * to hasData. If an error occurs within the callback an error banner can be shown.\r\n   * @param callback\r\n   * @param pendingMessage - optional custom pending message\r\n   * @returns\r\n   */\r\n  protected async runBlockingAction(callback: () => Promise<any>, pendingMessage?: string): Promise<any> {\r\n    this.hideErrorBanner();\r\n    this.status.setStatus('pending', pendingMessage);\r\n\r\n    return callback().catch(error => {\r\n      this.showErrorBanner(error);\r\n      // Throw the error for any downstream components that may be listening and need to react\r\n      // to any errors happening within this callback\r\n      throw (error);\r\n    }).finally(() => {\r\n      this.showStatus(PageStatus.Loaded);\r\n    });\r\n  };\r\n\r\n  /**\r\n   * Parses the page init result and sets the necessary properties on the page\r\n   * @param result\r\n   */\r\n  private parseInitResult(result: PageInitResult): void {\r\n    this.initResult = result;\r\n    this.title = result.title;\r\n    this.subTitle = result.subTitle;\r\n    this.subTitleUrl = result.subTitleUrl;\r\n    this.breadcrumbs = result.breadcrumbs;\r\n    this.help = result.help;\r\n  }\r\n\r\n  /**\r\n   * Controls the page status, triggers the save action and handles errors thrown.\r\n   */\r\n  private async save(): Promise<void> {\r\n    this.showStatus(PageStatus.Saving);\r\n\r\n    try {\r\n      await this.applyModelUpdates();\r\n      let entityId = await this.saveToApi() || -1;\r\n\r\n      this._errors = '';\r\n\r\n      this.onSaveComplete(entityId);\r\n    } catch (error) {\r\n      //clear the \"saving\" overlay and show the message at the top of the view through the errors property\r\n      this.showErrorBanner(error, this.defaultUnknownSaveError);\r\n      this.splashService.hideSplash();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Sets up the router event subscriptions\r\n   */\r\n  private setUpRouterSubscriptions(): void {\r\n    if (!this.navigationEndSubscription && !this.destroyed.closed) {\r\n      this.previousUrl = this.router.url;\r\n\r\n      // React to navigation events\r\n      this.navigationEndSubscription = this.router.events.pipe(\r\n        takeUntil(this.destroyed),\r\n        filter(e => e instanceof NavigationEnd),\r\n      ).subscribe(e => {\r\n        try {\r\n          let currentUrl: string = (<NavigationEnd>e).url;\r\n\r\n          if (this.ignoreQueryParamsOnNavigationChange) {\r\n            if (this.previousUrl.split('?')[0] !== currentUrl.split('?')[0]) {\r\n              this.navigationEndHandler((<NavigationEnd>e).url);\r\n            }\r\n          } else {\r\n            if (this.previousUrl !== currentUrl) {\r\n              this.navigationEndHandler((<NavigationEnd>e).url);\r\n            }\r\n          }\r\n        } catch (error) {\r\n          this.onError(error);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  private navigationEndHandler(url: string): void {\r\n    this.previousUrl = url;\r\n    this.onNavigationEnd();\r\n  }\r\n}\r\n"]}
|
379
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/components/src/lib/shared/page/page-base/page-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Directive, HostBinding, Injector, OnDestroy, OnInit } from '@angular/core';\r\nimport { UntypedFormGroup } from '@angular/forms';\r\nimport { ActivatedRoute, NavigationEnd, Router } from '@angular/router';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Observable, ReplaySubject, Subject, Subscription } from 'rxjs';\r\nimport { filter, takeUntil } from 'rxjs/operators';\r\nimport { NavItem } from '../../../controls/navigation/nav-item';\r\nimport { ErrorService } from '../../../core/error.service';\r\nimport { ScrollService } from '../../../core/scroll.service';\r\nimport { DialogService } from '../../../display/dialog/dialog.service';\r\nimport { SplashService } from '../../../display/splash/splash.service';\r\nimport { Help } from '../../../display/help/help-types';\r\nimport { Overlay } from '../../../display/view-overlay/view-overlay.component';\r\nimport { PageStatus, PageStatuses } from '../page-statuses';\r\nimport { RouterHelper } from '../../../core/router-helper.service';\r\n\r\nexport class PageInitResult {\r\n  title?: string = '';\r\n  subTitle?: string = '';\r\n  subTitleUrl?: string = '';\r\n  breadcrumbs?: NavItem[];\r\n  help?: Help;\r\n}\r\n\r\n@Directive()\r\nexport abstract class PageBaseComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  /** Default css classes applied to host element */\r\n  @HostBinding('class') protected classList = 'd-flex flex-grow';\r\n\r\n  /**\r\n   * Title for the page displayed in the header\r\n   */\r\n  public title?: string = '';\r\n\r\n  /**\r\n   * Sub title for the page displayed in the header\r\n   */\r\n  public subTitle?: string = '';\r\n\r\n  /**\r\n   * Sub title url for the page displayed in the header\r\n   */\r\n  public subTitleUrl?: string = '';\r\n\r\n  /**\r\n   * Status overlay for the page\r\n   */\r\n  public status: Overlay = new Overlay('pending', 'Loading');\r\n\r\n  /**\r\n   * Breadcrumbs displayed in the header\r\n   */\r\n  public breadcrumbs?: NavItem[];\r\n\r\n  /**\r\n   * Result returned from the onInit function\r\n   */\r\n  public initResult!: PageInitResult;\r\n\r\n  /**\r\n   * Help information for the component, which can only be set through onInit\r\n   */\r\n  public help: Help | undefined;\r\n\r\n  /**\r\n   * Form group to be used if needed by the page\r\n   */\r\n  public formGroup: UntypedFormGroup = new UntypedFormGroup({});\r\n\r\n  /**\r\n   * Default invalid form message, override if a more specific message is needed\r\n   */\r\n  public defaultInvalidFormMessage: string = 'PleaseCorrectForm_SC';\r\n\r\n  /**\r\n   * Default unknown save error message, override if a more specific message is needed\r\n   */\r\n  public defaultUnknownSaveError: string = 'PageBaseUnknownSaveError_SC';\r\n\r\n  /**\r\n   * Used to opt out of hiding the splash screen when the page is loaded\r\n   */\r\n  public skipHideSplashOnComplete: boolean = false;\r\n\r\n  /**\r\n   * When set to true any navigation end events that are strictly query param changes will\r\n   * not call the onNavigationEnd function. This allows pages to change the view with query\r\n   * params and not trigger a full refresh.\r\n   */\r\n  public ignoreQueryParamsOnNavigationChange: boolean = false;\r\n\r\n  private previousUrl: string = \"\";\r\n\r\n  /**\r\n   * Used to unsubscribe from observables\r\n   */\r\n  public destroyed: Subject<any> = new Subject<any>();\r\n\r\n  /**\r\n   * Used to know when the page has been loaded, this will be completed\r\n   * after onAfterViewInit\r\n   */\r\n  private _afterViewInitComplete: ReplaySubject<void> = new ReplaySubject();\r\n  public afterViewInitComplete: Observable<void> = this._afterViewInitComplete;\r\n\r\n  /**\r\n   * If defined the form will automatically scroll to the first invalid form control\r\n   * if it's outside of the view\r\n   */\r\n  protected scrollContainerSelector: string | undefined;\r\n\r\n  /**\r\n   * Subscription to the router events NavigationEnd\r\n   * Used to know if already subscribed to\r\n   */\r\n  private navigationEndSubscription?: Subscription;\r\n\r\n  /**\r\n   * Common services used by page-base\r\n   */\r\n  protected errorService: ErrorService;\r\n  protected translateService: TranslateService;\r\n  protected scrollService: ScrollService;\r\n  protected router: Router;\r\n  protected activatedRoute: ActivatedRoute;\r\n  protected dialogService: DialogService;\r\n  protected splashService: SplashService;\r\n  protected routerHelper: RouterHelper;\r\n\r\n  constructor(injector: Injector) {\r\n    this.errorService = injector.get(ErrorService);\r\n    this.translateService = injector.get(TranslateService);\r\n    this.scrollService = injector.get(ScrollService);\r\n    this.router = injector.get(Router);\r\n    this.activatedRoute = injector.get(ActivatedRoute);\r\n    this.dialogService = injector.get(DialogService);\r\n    this.splashService = injector.get(SplashService);\r\n    this.routerHelper = injector.get(RouterHelper);\r\n  }\r\n\r\n  /**\r\n   * Errors to be shown for the component.\r\n   * Automatically populated on promise rejection from save and shared with the UI.\r\n   */\r\n  private _errors: string = '';\r\n  public get errors(): string {\r\n    return this._errors;\r\n  }\r\n\r\n  /**\r\n   * Optional lifecycle hook that is called as part of the Angular ngOnInit lifecycle hook.\r\n   * Called before onInit is called for the first time. Add setup logic here that does\r\n   * not need to be run on every reload.\r\n   */\r\n  protected onFirstInit(): void { }\r\n\r\n  /**\r\n   * This method is called in the derived class as part of the Angular ngOnInit\r\n   * lifecycle hook. It must provide a PageInitResult back to the base class to properly\r\n   * set up the page.\r\n   */\r\n  protected abstract onInit(): Promise<PageInitResult>;\r\n  protected initPromise!: Promise<PageInitResult>;\r\n\r\n  public async ngOnInit() {\r\n    try {\r\n      this.showStatus(PageStatus.Loading);\r\n      this.setUpRouterSubscriptions();\r\n      this.onFirstInit();\r\n      this.initPromise = this.onInit();\r\n\r\n      await this.initPromise;\r\n    } catch (error) {\r\n      this.splashService.hideSplash();\r\n      this.onError(error);\r\n    };\r\n  }\r\n\r\n  /**\r\n   * This method is called just after the Angular Lifecycle event ngOnAfterViewInit.\r\n   * It fires after all sub-components have gone through their initialization phase.\r\n   * It is in this phase that the view components should already exist, so a derived class should\r\n   * load data from the API to populate any view components. The promise that\r\n   * is returned must not resolve until all required data has completely loaded\r\n   */\r\n  protected async onAfterViewInit(): Promise<void> { };\r\n  public async ngAfterViewInit(): Promise<void> {\r\n    try {\r\n      const initResult = await this.initPromise;\r\n      this.parseInitResult(initResult);\r\n\r\n      await this.onAfterViewInit();\r\n\r\n      this._afterViewInitComplete.next();\r\n      this._afterViewInitComplete.complete();\r\n\r\n      await this.onFormLoadComplete();\r\n\r\n      if (this.status.status === 'pending') {\r\n        this.showStatus(PageStatus.Loaded);\r\n      }\r\n\r\n      if (!this.skipHideSplashOnComplete) {\r\n        this.splashService.hideSplash();\r\n      }\r\n\r\n    } catch (error) {\r\n      this.splashService.hideSplash();\r\n      this.onError(error);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * A lifecycle method that executes once all data has been loaded\r\n   * through ngAfterViewInit and from local storage if required.\r\n   * It is at this point that you can subscribe to changes on the form\r\n   * reliably\r\n   *\r\n   * @protected\r\n   * @memberof PageBaseComponent\r\n   */\r\n  protected async onFormLoadComplete(): Promise<any> { }\r\n\r\n  /**\r\n   * A lifecycle hook that is called after every NavigationEnd event.\r\n   */\r\n  protected onNavigationEnd(): void { }\r\n\r\n  /**\r\n   * Reload the component kicking off the ngOnInit and ngAfterViewInit lifecycle hooks.\r\n   * Any state that needs to be reset should be done so before calling this method.\r\n   */\r\n  public reload(): void {\r\n    this._afterViewInitComplete = new ReplaySubject();\r\n\r\n    this.showStatus(PageStatus.Loading);\r\n    this.initPromise = this.onInit();\r\n    this.ngAfterViewInit();\r\n  }\r\n\r\n  /**\r\n   * When overridden in a derived class this method will sync the form state\r\n   * into the object that will be persisted to the API. The value should not\r\n   * actually be sent to the API yet.\r\n   */\r\n  protected async applyModelUpdates(): Promise<void> { };\r\n\r\n  /**\r\n   * Save the model state to the API and return a promise that\r\n   * contains the updated entityID. The promise should be rejected\r\n   * if the save fails and errors and the overlay status will be updated\r\n   * accordingly\r\n   */\r\n  protected async saveToApi(): Promise<number | void> { };\r\n\r\n  /**\r\n   * Called after the save has completed successfully.\r\n   * It is the responsibility of the derived class to navigate\r\n   * to a properties/status page or emit appropriately if within a dialog\r\n   * @param entityId\r\n   */\r\n  protected onSaveComplete(entityId?: number): void { };\r\n\r\n  /**\r\n   * Function called when the user clicks save.  We will first touch all controls to show validation messages\r\n   * if the form is invalid.  If the form is valid we will attempt to save and any errors will be reported\r\n   * back to the user\r\n   * @param event\r\n   */\r\n  public async onSave(event: Event): Promise<void> {\r\n    this.formGroup.markAllAsTouched();\r\n\r\n    if (this.formGroup.valid) {\r\n      await this.save();\r\n    } else {\r\n      // Only show the banner with the generic message if the parent component hasn't already set one\r\n      // by implementing onSave for additional validation\r\n      if (this.errors === '') {\r\n        this.showErrorBanner(this.defaultInvalidFormMessage);\r\n      }\r\n\r\n      if (this.scrollContainerSelector) {\r\n        setTimeout(() => {\r\n          this.scrollService.scrollToItem(this.scrollContainerSelector!, \".ng-invalid\");\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Function available to trigger a save and bypass the form validation checks.\r\n   * This is useful if the user chooses a remove action from within an edit dialog. If the dialog form is invalid\r\n   * that is no concern to the user if they wish to remove the item they are editing.\r\n   * @param event\r\n   */\r\n  public async onSaveWithoutValidate(event: Event): Promise<void> {\r\n    await this.save();\r\n  }\r\n\r\n  /**\r\n   * Function called when the component is destroyed\r\n   */\r\n  public ngOnDestroy(): void {\r\n    this.destroyed.next();\r\n    this.destroyed.unsubscribe();\r\n  }\r\n\r\n  /**\r\n   * Function that will log an error that is passed in to the console\r\n   * @param e\r\n   */\r\n  protected onError(error: Error): void {\r\n    this.errorService.logConsoleError(error);\r\n    this.showErrorOverlay(error);\r\n  }\r\n\r\n  /**\r\n   * Show an error message in a whole-page overlay. This will prevent any more\r\n   * interactions with the page. It can take a string error message or a raw API\r\n   * error that needs to be parsed. If the API error isn't something we can handle\r\n   * a generic message is shown instead\r\n   * @param {(Error | string)} error\r\n   */\r\n  protected showErrorOverlay(error: Error | string) {\r\n    this.getErrorMessage(error).subscribe((translatedMessage: string) => {\r\n      this.status.setStatus('error', translatedMessage);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Show an error in the banner at the top of the screen.  This will not produce a\r\n   * whole-page overlay like the function showError will.  It can take a string error message\r\n   * or raw API error that needs to be parsed.  If the API error isn't something we can handle,\r\n   * a generic message (customizable via unknownErrorDefault) is shown instead.\r\n   * @param error\r\n   * @param unknownErrorDefault\r\n   */\r\n  protected showErrorBanner(error: Error | string, unknownErrorDefault?: string): void {\r\n    this.getErrorMessage(error, unknownErrorDefault).subscribe((translatedMessage: string) => {\r\n      this._errors = translatedMessage;\r\n      this.showStatus(PageStatus.Loaded);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Parses and translates an API error or error string.\r\n   * @param e\r\n   * @param unknownErrorDefault\r\n   */\r\n  protected getErrorMessage(e: Error | string, unknownErrorDefault?: string): Observable<string> {\r\n    let extractedMessage = this.errorService.parseApiError(e, unknownErrorDefault);\r\n    return this.translateService.get(extractedMessage);\r\n  }\r\n\r\n  /**\r\n   * Clear the errors to hide the errors banner.\r\n   */\r\n  protected hideErrorBanner(): void {\r\n    this._errors = '';\r\n  }\r\n\r\n  /**\r\n   * Change the display status to overlay the whole page while loading or saving\r\n   * and clear it when the form is ready\r\n   * @protected\r\n   * @param {PageStatus} status\r\n   * @memberof FormBaseComponent\r\n   */\r\n  protected showStatus(status: PageStatus) {\r\n    let knownStatus = PageStatuses[status];\r\n    if (knownStatus) {\r\n      this.status.setStatus(knownStatus.status, knownStatus.message, undefined, knownStatus.noDataTemplate, knownStatus.overlayClassList);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Allows the component to enter a pending status and execute a function that on completion will return the status\r\n   * to hasData. If an error occurs within the callback an error banner can be shown.\r\n   * @param callback\r\n   * @param pendingMessage - optional custom pending message\r\n   * @returns\r\n   */\r\n  protected async runBlockingAction(callback: () => Promise<any>, pendingMessage?: string): Promise<any> {\r\n    this.hideErrorBanner();\r\n    this.status.setStatus('pending', pendingMessage);\r\n\r\n    return callback().catch(error => {\r\n      this.showErrorBanner(error);\r\n      // Throw the error for any downstream components that may be listening and need to react\r\n      // to any errors happening within this callback\r\n      throw (error);\r\n    }).finally(() => {\r\n      this.showStatus(PageStatus.Loaded);\r\n    });\r\n  };\r\n\r\n  /**\r\n   * Parses the page init result and sets the necessary properties on the page\r\n   * @param result\r\n   */\r\n  private parseInitResult(result: PageInitResult): void {\r\n    this.initResult = result;\r\n    this.title = result.title;\r\n    this.subTitle = result.subTitle;\r\n    this.subTitleUrl = result.subTitleUrl;\r\n    this.breadcrumbs = result.breadcrumbs;\r\n    this.help = result.help;\r\n  }\r\n\r\n  /**\r\n   * Controls the page status, triggers the save action and handles errors thrown.\r\n   */\r\n  private async save(): Promise<void> {\r\n    this.showStatus(PageStatus.Saving);\r\n\r\n    try {\r\n      await this.applyModelUpdates();\r\n      let entityId = await this.saveToApi() || -1;\r\n\r\n      this._errors = '';\r\n\r\n      this.onSaveComplete(entityId);\r\n    } catch (error) {\r\n      //clear the \"saving\" overlay and show the message at the top of the view through the errors property\r\n      this.showErrorBanner(error, this.defaultUnknownSaveError);\r\n      this.splashService.hideSplash();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Sets up the router event subscriptions\r\n   */\r\n  private setUpRouterSubscriptions(): void {\r\n    if (!this.navigationEndSubscription && !this.destroyed.closed) {\r\n      this.previousUrl = this.router.url;\r\n\r\n      // React to navigation events\r\n      this.navigationEndSubscription = this.router.events.pipe(\r\n        takeUntil(this.destroyed),\r\n        filter(e => e instanceof NavigationEnd),\r\n      ).subscribe(e => {\r\n        try {\r\n          let currentUrl: string = (<NavigationEnd>e).url;\r\n\r\n          if (this.ignoreQueryParamsOnNavigationChange) {\r\n            if (this.previousUrl.split('?')[0] !== currentUrl.split('?')[0]) {\r\n              this.navigationEndHandler((<NavigationEnd>e).url);\r\n            }\r\n          } else {\r\n            if (this.previousUrl !== currentUrl) {\r\n              this.navigationEndHandler((<NavigationEnd>e).url);\r\n            }\r\n          }\r\n        } catch (error) {\r\n          this.onError(error);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  private navigationEndHandler(url: string): void {\r\n    this.previousUrl = url;\r\n    this.onNavigationEnd();\r\n  }\r\n}\r\n"]}
|
@@ -53,6 +53,10 @@ export class PageViewComponent {
|
|
53
53
|
* Prevents content from overflowing the view. Content must manage overflow instead.
|
54
54
|
*/
|
55
55
|
this.fitContent = false;
|
56
|
+
/**
|
57
|
+
* Disables the primary action button
|
58
|
+
*/
|
59
|
+
this.disablePrimaryAction = false;
|
56
60
|
/** Changes the background color for the content and overlay to white */
|
57
61
|
this.bgContent = false;
|
58
62
|
this.onPrimaryAction = new EventEmitter();
|
@@ -73,12 +77,12 @@ export class PageViewComponent {
|
|
73
77
|
}
|
74
78
|
}
|
75
79
|
PageViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: PageViewComponent, deps: [{ token: i1.DialogService }], target: i0.ɵɵFactoryTarget.Component });
|
76
|
-
PageViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: PageViewComponent, selector: "ec-page-view", inputs: { isDialog: "isDialog", readonly: "readonly", status: "status", showHeader: "showHeader", errors: "errors", breadcrumbs: "breadcrumbs", title: "title", titleIcon: "titleIcon", subTitle: "subTitle", subTitleUrl: "subTitleUrl", moreActionsLabel: "moreActionsLabel", moreActions: "moreActions", secondaryActionLabel: "secondaryActionLabel", hideSecondaryAction: "hideSecondaryAction", hideCloseOnPending: "hideCloseOnPending", primaryActionLabel: "primaryActionLabel", hidePrimaryAction: "hidePrimaryAction", customTitleTemplate: "customTitleTemplate", customActionsTemplate: "customActionsTemplate", customHeaderTemplate: "customHeaderTemplate", footerTemplate: "footerTemplate", customErrorBannerTemplate: "customErrorBannerTemplate", stickyFooter: "stickyFooter", fitContent: "fitContent", bgContent: "bgContent" }, outputs: { onPrimaryAction: "onPrimaryAction", onSecondaryAction: "onSecondaryAction" }, host: { properties: { "class.bg-content": "this.bgContent" }, classAttribute: "flex-grow" }, ngImport: i0, template: "<div ecOverlay\r\n [status]=\"status?.status\"\r\n [message]=\"status?.message\"\r\n [displayAsMask]=\"true\"\r\n class=\"flex-grow d-flex\"\r\n [ngClass]=\"{'bg-body': !bgContent, 'bg-content': bgContent}\">\r\n <div id=\"PageViewScrollContainer\"\r\n class=\"d-flex flex-column flex-grow scroll-y\"\r\n [class.is-dialog]=\"isDialog\"\r\n [class.fit-content]=\"fitContent\"\r\n [class.sticky-footer]=\"stickyFooter && !!footerTemplate\"\r\n [class.overlay-visible]=\"status?.status !== 'hasData'\"\r\n [class.footer-visible]=\"!!footerTemplate\">\r\n <section>\r\n <ng-content></ng-content>\r\n </section>\r\n\r\n <footer *ngIf=\"footerTemplate\">\r\n <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\r\n </footer>\r\n\r\n <header *ngIf=\"showHeader\">\r\n <ol id=\"breadcrumbs\"\r\n *ngIf=\"breadcrumbs?.length && !isDialog\">\r\n <li *ngFor=\"let crumb of breadcrumbs; last as isLast\">\r\n <a *ngIf=\"crumb.url; else label\"\r\n [routerLink]=\"crumb.url\">\r\n <ng-container *ngTemplateOutlet=\"label\"></ng-container>\r\n </a>\r\n <ng-template #label>{{crumb.label}}</ng-template>\r\n </li>\r\n </ol>\r\n\r\n <div class=\"titlebar\">\r\n <app-page-title *ngIf=\"!customTitleTemplate; else customTitle\"\r\n [title]=\"title\"\r\n [subTitle]=\"subTitle\"\r\n [subTitleUrl]=\"subTitleUrl\"\r\n [titleIcon]=\"titleIcon\"\r\n class=\"title text-truncate\">\r\n </app-page-title>\r\n\r\n <ng-template #customTitle>\r\n <div class=\"title\">\r\n <ng-container *ngTemplateOutlet=\"customTitleTemplate\"></ng-container>\r\n </div>\r\n </ng-template>\r\n\r\n <div class=\"actions\">\r\n <ec-button id=\"primaryAction\"\r\n class=\"ml-2\"\r\n *ngIf=\"!hidePrimaryAction && onPrimaryAction.observers?.length && !readonly\"\r\n [disabled]=\"status?.status === 'pending'\"\r\n type=\"primary\"\r\n [label]=\"primaryActionLabel\"\r\n (clicked)=\"primaryAction($event)\">\r\n </ec-button>\r\n <ec-button id=\"secondaryAction\"\r\n class=\"ml-2\"\r\n *ngIf=\"!hideSecondaryAction && onSecondaryAction.observers?.length\"\r\n type=\"secondary\"\r\n [label]=\"readonly ? 'Close' : secondaryActionLabel\"\r\n (clicked)=\"secondaryAction($event)\">\r\n </ec-button>\r\n <ec-dropdown id=\"moreActions\"\r\n *ngIf=\"moreActions?.length && !readonly\"\r\n [disabled]=\"status?.status === 'pending'\"\r\n class=\"ml-2\"\r\n buttonType=\"text\"\r\n [label]=\"moreActionsLabel\"\r\n [items]=\"moreActions\">\r\n </ec-dropdown>\r\n <ng-container *ngTemplateOutlet=\"customActionsTemplate\"></ng-container>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"customHeaderTemplate\"\r\n class=\"page-header\">\r\n <ng-container *ngTemplateOutlet=\"customHeaderTemplate\"></ng-container>\r\n </div>\r\n\r\n <ec-banner *ngIf=\"!customErrorBannerTemplate && errors; else customErrorBannerOutlet\"\r\n id=\"pageViewErrors\"\r\n [class.border-bottom-0]=\"!isDialog\">\r\n <div [innerHtml]=\"errors\"></div>\r\n </ec-banner>\r\n\r\n <ng-template #customErrorBannerOutlet>\r\n <ec-banner *ngIf=\"errors\"\r\n id=\"pageViewErrors\"\r\n [class.border-bottom-0]=\"!isDialog\">\r\n <ng-container *ngTemplateOutlet=\"customErrorBannerTemplate\"></ng-container>\r\n </ec-banner>\r\n </ng-template>\r\n </header>\r\n </div>\r\n\r\n <ec-button *ngIf=\"isDialog && ( (status?.status === 'pending' && !hideCloseOnPending) || status?.status === 'error')\"\r\n id=\"pageViewDialogClose\"\r\n type=\"icon\"\r\n icon=\"icon-cancel\"\r\n (clicked)=\"closeDialog()\">\r\n </ec-button>\r\n</div>", styles: [":host{flex:1 1;min-height:0;display:flex}header{background-color:var(--ec-background-color-body);position:sticky;top:0;order:1;padding:1rem 1.5rem .5rem;flex:none;z-index:var(--ec-z-index-sticky-page-header)}ol{font-size:var(--ec-font-size-label);line-height:1rem;grid-column:1/3;grid-row:1/2;list-style:none;padding:0;margin:0 0 .25rem}ol li{display:inline}ol li:not(:last-child):after{content:\" / \";display:inline;color:var(--ec-color-secondary-dark)}div[ecOverlay]{position:relative}.titlebar{display:grid;grid-template-columns:auto max-content;grid-template-rows:max-content max-content;gap:0 1rem}.title{grid-column:1/2;grid-row:2/3;align-self:center}.actions{grid-column:2/3;grid-row:2/3;display:flex;flex-direction:row-reverse}ec-banner{margin-top:1rem}section{padding:var(--ec-page-view-padding-section, .5rem 1.5rem 2rem);order:2;flex:1 0 auto;min-height:0}:not(.is-dialog)>section{z-index:0}footer{background-color:var(--ec-background-color-body);order:3;padding:0 1.5rem;height:4.5rem;flex:none;display:flex;align-items:center}.is-dialog header{padding:0}.is-dialog .titlebar{background-color:var(--ec-background-color);padding:1rem}.is-dialog ec-banner{margin:0}.is-dialog section{padding:var(--ec-page-view-padding-section, 1rem 1rem 1.5rem)}.sticky-footer section{padding-bottom:4.5rem}.sticky-footer footer{position:sticky;bottom:0;z-index:var(--ec-z-index-sticky-page-header)}.fit-content>section{flex:1 1;display:flex}.footer-visible section{padding-bottom:0}.overlay-visible header{z-index:var(--ec-z-index-overlay)1}.overlay-visible ec-banner{display:none}:host(.bg-content) header{background-color:var(--ec-background-color)}:host(.bg-content) section{background-color:var(--ec-background-color)}:host(.bg-content) footer{background-color:var(--ec-background-color)}#pageViewDialogClose{position:absolute;top:1rem;right:1rem;z-index:calc(var(--ec-z-index-overlay) + 1)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i4.ButtonComponent, selector: "ec-button", inputs: ["id", "disabled", "icon", "label", "badge", "tabindex", "type", "pending", "pendingIcon", "customTemplate", "isSubmit", "autofocus"], outputs: ["clicked"] }, { kind: "component", type: i5.ViewOverlayComponent, selector: "[ecOverlay]", inputs: ["status", "message", "action", "noDataTemplate", "displayAsMask", "overlayClassList"] }, { kind: "component", type: i6.BannerComponent, selector: "ec-banner", inputs: ["hidden", "id", "type", "bannerStyle", "title", "text", "list", "showCloseBtn", "autoHideOnClose", "customIcon", "rememberClosed"], outputs: ["closed"] }, { kind: "component", type: i7.DropdownComponent, selector: "ec-dropdown", inputs: ["id", "autofocus", "status", "disabled", "label", "icon", "buttonType", "buttonAlignment", "buttonTitle", "tabindex", "showArrow", "items", "menuTemplateType", "menuTitle", "menuHeight", "menuWidth", "menuMinWidth", "menuPosition", "menuFooter", "popupFixed", "buttonCustomTemplate", "pending"], outputs: ["itemSelected", "popupOpened"] }, { kind: "component", type: i8.PageTitleComponent, selector: "app-page-title", inputs: ["title", "titleIcon", "subTitle", "subTitleUrl"] }] });
|
80
|
+
PageViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: PageViewComponent, selector: "ec-page-view", inputs: { isDialog: "isDialog", readonly: "readonly", status: "status", showHeader: "showHeader", errors: "errors", breadcrumbs: "breadcrumbs", title: "title", titleIcon: "titleIcon", subTitle: "subTitle", subTitleUrl: "subTitleUrl", moreActionsLabel: "moreActionsLabel", moreActions: "moreActions", secondaryActionLabel: "secondaryActionLabel", hideSecondaryAction: "hideSecondaryAction", hideCloseOnPending: "hideCloseOnPending", primaryActionLabel: "primaryActionLabel", hidePrimaryAction: "hidePrimaryAction", customTitleTemplate: "customTitleTemplate", customActionsTemplate: "customActionsTemplate", customHeaderTemplate: "customHeaderTemplate", footerTemplate: "footerTemplate", customErrorBannerTemplate: "customErrorBannerTemplate", stickyFooter: "stickyFooter", fitContent: "fitContent", disablePrimaryAction: "disablePrimaryAction", bgContent: "bgContent" }, outputs: { onPrimaryAction: "onPrimaryAction", onSecondaryAction: "onSecondaryAction" }, host: { properties: { "class.bg-content": "this.bgContent" }, classAttribute: "flex-grow" }, ngImport: i0, template: "<div ecOverlay\r\n [status]=\"status?.status\"\r\n [message]=\"status?.message\"\r\n [displayAsMask]=\"true\"\r\n class=\"flex-grow d-flex\"\r\n [ngClass]=\"{'bg-body': !bgContent, 'bg-content': bgContent}\">\r\n <div id=\"PageViewScrollContainer\"\r\n class=\"d-flex flex-column flex-grow scroll-y\"\r\n [class.is-dialog]=\"isDialog\"\r\n [class.fit-content]=\"fitContent\"\r\n [class.sticky-footer]=\"stickyFooter && !!footerTemplate\"\r\n [class.overlay-visible]=\"status?.status !== 'hasData'\"\r\n [class.footer-visible]=\"!!footerTemplate\">\r\n <section>\r\n <ng-content></ng-content>\r\n </section>\r\n\r\n <footer *ngIf=\"footerTemplate\">\r\n <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\r\n </footer>\r\n\r\n <header *ngIf=\"showHeader\">\r\n <ol id=\"breadcrumbs\"\r\n *ngIf=\"breadcrumbs?.length && !isDialog\">\r\n <li *ngFor=\"let crumb of breadcrumbs; last as isLast\">\r\n <a *ngIf=\"crumb.url; else label\"\r\n [routerLink]=\"crumb.url\">\r\n <ng-container *ngTemplateOutlet=\"label\"></ng-container>\r\n </a>\r\n <ng-template #label>{{crumb.label}}</ng-template>\r\n </li>\r\n </ol>\r\n\r\n <div class=\"titlebar\">\r\n <app-page-title *ngIf=\"!customTitleTemplate; else customTitle\"\r\n [title]=\"title\"\r\n [subTitle]=\"subTitle\"\r\n [subTitleUrl]=\"subTitleUrl\"\r\n [titleIcon]=\"titleIcon\"\r\n class=\"title text-truncate\">\r\n </app-page-title>\r\n\r\n <ng-template #customTitle>\r\n <div class=\"title\">\r\n <ng-container *ngTemplateOutlet=\"customTitleTemplate\"></ng-container>\r\n </div>\r\n </ng-template>\r\n\r\n <div class=\"actions\">\r\n <ec-button id=\"primaryAction\"\r\n class=\"ml-2\"\r\n *ngIf=\"!hidePrimaryAction && onPrimaryAction.observers?.length && !readonly\"\r\n [disabled]=\"status?.status === 'pending' || disablePrimaryAction\"\r\n type=\"primary\"\r\n [label]=\"primaryActionLabel\"\r\n (clicked)=\"primaryAction($event)\">\r\n </ec-button>\r\n <ec-button id=\"secondaryAction\"\r\n class=\"ml-2\"\r\n *ngIf=\"!hideSecondaryAction && onSecondaryAction.observers?.length\"\r\n type=\"secondary\"\r\n [label]=\"readonly ? 'Close' : secondaryActionLabel\"\r\n (clicked)=\"secondaryAction($event)\">\r\n </ec-button>\r\n <ec-dropdown id=\"moreActions\"\r\n *ngIf=\"moreActions?.length && !readonly\"\r\n [disabled]=\"status?.status === 'pending'\"\r\n class=\"ml-2\"\r\n buttonType=\"text\"\r\n [label]=\"moreActionsLabel\"\r\n [items]=\"moreActions\">\r\n </ec-dropdown>\r\n <ng-container *ngTemplateOutlet=\"customActionsTemplate\"></ng-container>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"customHeaderTemplate\"\r\n class=\"page-header\">\r\n <ng-container *ngTemplateOutlet=\"customHeaderTemplate\"></ng-container>\r\n </div>\r\n\r\n <ec-banner *ngIf=\"!customErrorBannerTemplate && errors; else customErrorBannerOutlet\"\r\n id=\"pageViewErrors\"\r\n [class.border-bottom-0]=\"!isDialog\">\r\n <div [innerHtml]=\"errors\"></div>\r\n </ec-banner>\r\n\r\n <ng-template #customErrorBannerOutlet>\r\n <ec-banner *ngIf=\"errors\"\r\n id=\"pageViewErrors\"\r\n [class.border-bottom-0]=\"!isDialog\">\r\n <ng-container *ngTemplateOutlet=\"customErrorBannerTemplate\"></ng-container>\r\n </ec-banner>\r\n </ng-template>\r\n </header>\r\n </div>\r\n\r\n <ec-button *ngIf=\"isDialog && ( (status?.status === 'pending' && !hideCloseOnPending) || status?.status === 'error')\"\r\n id=\"pageViewDialogClose\"\r\n type=\"icon\"\r\n icon=\"icon-cancel\"\r\n (clicked)=\"closeDialog()\">\r\n </ec-button>\r\n</div>", styles: [":host{flex:1 1;min-height:0;display:flex}header{background-color:var(--ec-background-color-body);position:sticky;top:0;order:1;padding:1rem 1.5rem .5rem;flex:none;z-index:var(--ec-z-index-sticky-page-header)}ol{font-size:var(--ec-font-size-label);line-height:1rem;grid-column:1/3;grid-row:1/2;list-style:none;padding:0;margin:0 0 .25rem}ol li{display:inline}ol li:not(:last-child):after{content:\" / \";display:inline;color:var(--ec-color-secondary-dark)}div[ecOverlay]{position:relative}.titlebar{display:grid;grid-template-columns:auto max-content;grid-template-rows:max-content max-content;gap:0 1rem}.title{grid-column:1/2;grid-row:2/3;align-self:center}.actions{grid-column:2/3;grid-row:2/3;display:flex;flex-direction:row-reverse}ec-banner{margin-top:1rem}section{padding:var(--ec-page-view-padding-section, .5rem 1.5rem 2rem);order:2;flex:1 0 auto;min-height:0}:not(.is-dialog)>section{z-index:0}footer{background-color:var(--ec-background-color-body);order:3;padding:0 1.5rem;height:4.5rem;flex:none;display:flex;align-items:center}.is-dialog header{padding:0}.is-dialog .titlebar{background-color:var(--ec-background-color);padding:1rem}.is-dialog ec-banner{margin:0}.is-dialog section{padding:var(--ec-page-view-padding-section, 1rem 1rem 1.5rem)}.sticky-footer section{padding-bottom:4.5rem}.sticky-footer footer{position:sticky;bottom:0;z-index:var(--ec-z-index-sticky-page-header)}.fit-content>section{flex:1 1;display:flex}.footer-visible section{padding-bottom:0}.overlay-visible header{z-index:var(--ec-z-index-overlay)1}.overlay-visible ec-banner{display:none}:host(.bg-content) header{background-color:var(--ec-background-color)}:host(.bg-content) section{background-color:var(--ec-background-color)}:host(.bg-content) footer{background-color:var(--ec-background-color)}#pageViewDialogClose{position:absolute;top:1rem;right:1rem;z-index:calc(var(--ec-z-index-overlay) + 1)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i4.ButtonComponent, selector: "ec-button", inputs: ["id", "disabled", "icon", "label", "badge", "tabindex", "type", "pending", "pendingIcon", "customTemplate", "isSubmit", "autofocus"], outputs: ["clicked"] }, { kind: "component", type: i5.ViewOverlayComponent, selector: "[ecOverlay]", inputs: ["status", "message", "action", "noDataTemplate", "displayAsMask", "overlayClassList"] }, { kind: "component", type: i6.BannerComponent, selector: "ec-banner", inputs: ["hidden", "id", "type", "bannerStyle", "title", "text", "list", "showCloseBtn", "autoHideOnClose", "customIcon", "rememberClosed"], outputs: ["closed"] }, { kind: "component", type: i7.DropdownComponent, selector: "ec-dropdown", inputs: ["id", "autofocus", "status", "disabled", "label", "icon", "buttonType", "buttonAlignment", "buttonTitle", "tabindex", "showArrow", "items", "menuTemplateType", "menuTitle", "menuHeight", "menuWidth", "menuMinWidth", "menuPosition", "menuFooter", "popupFixed", "buttonCustomTemplate", "pending"], outputs: ["itemSelected", "popupOpened"] }, { kind: "component", type: i8.PageTitleComponent, selector: "app-page-title", inputs: ["title", "titleIcon", "subTitle", "subTitleUrl"] }] });
|
77
81
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: PageViewComponent, decorators: [{
|
78
82
|
type: Component,
|
79
83
|
args: [{ selector: 'ec-page-view', host: {
|
80
84
|
class: "flex-grow"
|
81
|
-
}, template: "<div ecOverlay\r\n [status]=\"status?.status\"\r\n [message]=\"status?.message\"\r\n [displayAsMask]=\"true\"\r\n class=\"flex-grow d-flex\"\r\n [ngClass]=\"{'bg-body': !bgContent, 'bg-content': bgContent}\">\r\n <div id=\"PageViewScrollContainer\"\r\n class=\"d-flex flex-column flex-grow scroll-y\"\r\n [class.is-dialog]=\"isDialog\"\r\n [class.fit-content]=\"fitContent\"\r\n [class.sticky-footer]=\"stickyFooter && !!footerTemplate\"\r\n [class.overlay-visible]=\"status?.status !== 'hasData'\"\r\n [class.footer-visible]=\"!!footerTemplate\">\r\n <section>\r\n <ng-content></ng-content>\r\n </section>\r\n\r\n <footer *ngIf=\"footerTemplate\">\r\n <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\r\n </footer>\r\n\r\n <header *ngIf=\"showHeader\">\r\n <ol id=\"breadcrumbs\"\r\n *ngIf=\"breadcrumbs?.length && !isDialog\">\r\n <li *ngFor=\"let crumb of breadcrumbs; last as isLast\">\r\n <a *ngIf=\"crumb.url; else label\"\r\n [routerLink]=\"crumb.url\">\r\n <ng-container *ngTemplateOutlet=\"label\"></ng-container>\r\n </a>\r\n <ng-template #label>{{crumb.label}}</ng-template>\r\n </li>\r\n </ol>\r\n\r\n <div class=\"titlebar\">\r\n <app-page-title *ngIf=\"!customTitleTemplate; else customTitle\"\r\n [title]=\"title\"\r\n [subTitle]=\"subTitle\"\r\n [subTitleUrl]=\"subTitleUrl\"\r\n [titleIcon]=\"titleIcon\"\r\n class=\"title text-truncate\">\r\n </app-page-title>\r\n\r\n <ng-template #customTitle>\r\n <div class=\"title\">\r\n <ng-container *ngTemplateOutlet=\"customTitleTemplate\"></ng-container>\r\n </div>\r\n </ng-template>\r\n\r\n <div class=\"actions\">\r\n <ec-button id=\"primaryAction\"\r\n class=\"ml-2\"\r\n *ngIf=\"!hidePrimaryAction && onPrimaryAction.observers?.length && !readonly\"\r\n [disabled]=\"status?.status === 'pending'\"\r\n type=\"primary\"\r\n [label]=\"primaryActionLabel\"\r\n (clicked)=\"primaryAction($event)\">\r\n </ec-button>\r\n <ec-button id=\"secondaryAction\"\r\n class=\"ml-2\"\r\n *ngIf=\"!hideSecondaryAction && onSecondaryAction.observers?.length\"\r\n type=\"secondary\"\r\n [label]=\"readonly ? 'Close' : secondaryActionLabel\"\r\n (clicked)=\"secondaryAction($event)\">\r\n </ec-button>\r\n <ec-dropdown id=\"moreActions\"\r\n *ngIf=\"moreActions?.length && !readonly\"\r\n [disabled]=\"status?.status === 'pending'\"\r\n class=\"ml-2\"\r\n buttonType=\"text\"\r\n [label]=\"moreActionsLabel\"\r\n [items]=\"moreActions\">\r\n </ec-dropdown>\r\n <ng-container *ngTemplateOutlet=\"customActionsTemplate\"></ng-container>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"customHeaderTemplate\"\r\n class=\"page-header\">\r\n <ng-container *ngTemplateOutlet=\"customHeaderTemplate\"></ng-container>\r\n </div>\r\n\r\n <ec-banner *ngIf=\"!customErrorBannerTemplate && errors; else customErrorBannerOutlet\"\r\n id=\"pageViewErrors\"\r\n [class.border-bottom-0]=\"!isDialog\">\r\n <div [innerHtml]=\"errors\"></div>\r\n </ec-banner>\r\n\r\n <ng-template #customErrorBannerOutlet>\r\n <ec-banner *ngIf=\"errors\"\r\n id=\"pageViewErrors\"\r\n [class.border-bottom-0]=\"!isDialog\">\r\n <ng-container *ngTemplateOutlet=\"customErrorBannerTemplate\"></ng-container>\r\n </ec-banner>\r\n </ng-template>\r\n </header>\r\n </div>\r\n\r\n <ec-button *ngIf=\"isDialog && ( (status?.status === 'pending' && !hideCloseOnPending) || status?.status === 'error')\"\r\n id=\"pageViewDialogClose\"\r\n type=\"icon\"\r\n icon=\"icon-cancel\"\r\n (clicked)=\"closeDialog()\">\r\n </ec-button>\r\n</div>", styles: [":host{flex:1 1;min-height:0;display:flex}header{background-color:var(--ec-background-color-body);position:sticky;top:0;order:1;padding:1rem 1.5rem .5rem;flex:none;z-index:var(--ec-z-index-sticky-page-header)}ol{font-size:var(--ec-font-size-label);line-height:1rem;grid-column:1/3;grid-row:1/2;list-style:none;padding:0;margin:0 0 .25rem}ol li{display:inline}ol li:not(:last-child):after{content:\" / \";display:inline;color:var(--ec-color-secondary-dark)}div[ecOverlay]{position:relative}.titlebar{display:grid;grid-template-columns:auto max-content;grid-template-rows:max-content max-content;gap:0 1rem}.title{grid-column:1/2;grid-row:2/3;align-self:center}.actions{grid-column:2/3;grid-row:2/3;display:flex;flex-direction:row-reverse}ec-banner{margin-top:1rem}section{padding:var(--ec-page-view-padding-section, .5rem 1.5rem 2rem);order:2;flex:1 0 auto;min-height:0}:not(.is-dialog)>section{z-index:0}footer{background-color:var(--ec-background-color-body);order:3;padding:0 1.5rem;height:4.5rem;flex:none;display:flex;align-items:center}.is-dialog header{padding:0}.is-dialog .titlebar{background-color:var(--ec-background-color);padding:1rem}.is-dialog ec-banner{margin:0}.is-dialog section{padding:var(--ec-page-view-padding-section, 1rem 1rem 1.5rem)}.sticky-footer section{padding-bottom:4.5rem}.sticky-footer footer{position:sticky;bottom:0;z-index:var(--ec-z-index-sticky-page-header)}.fit-content>section{flex:1 1;display:flex}.footer-visible section{padding-bottom:0}.overlay-visible header{z-index:var(--ec-z-index-overlay)1}.overlay-visible ec-banner{display:none}:host(.bg-content) header{background-color:var(--ec-background-color)}:host(.bg-content) section{background-color:var(--ec-background-color)}:host(.bg-content) footer{background-color:var(--ec-background-color)}#pageViewDialogClose{position:absolute;top:1rem;right:1rem;z-index:calc(var(--ec-z-index-overlay) + 1)}\n"] }]
|
85
|
+
}, template: "<div ecOverlay\r\n [status]=\"status?.status\"\r\n [message]=\"status?.message\"\r\n [displayAsMask]=\"true\"\r\n class=\"flex-grow d-flex\"\r\n [ngClass]=\"{'bg-body': !bgContent, 'bg-content': bgContent}\">\r\n <div id=\"PageViewScrollContainer\"\r\n class=\"d-flex flex-column flex-grow scroll-y\"\r\n [class.is-dialog]=\"isDialog\"\r\n [class.fit-content]=\"fitContent\"\r\n [class.sticky-footer]=\"stickyFooter && !!footerTemplate\"\r\n [class.overlay-visible]=\"status?.status !== 'hasData'\"\r\n [class.footer-visible]=\"!!footerTemplate\">\r\n <section>\r\n <ng-content></ng-content>\r\n </section>\r\n\r\n <footer *ngIf=\"footerTemplate\">\r\n <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\r\n </footer>\r\n\r\n <header *ngIf=\"showHeader\">\r\n <ol id=\"breadcrumbs\"\r\n *ngIf=\"breadcrumbs?.length && !isDialog\">\r\n <li *ngFor=\"let crumb of breadcrumbs; last as isLast\">\r\n <a *ngIf=\"crumb.url; else label\"\r\n [routerLink]=\"crumb.url\">\r\n <ng-container *ngTemplateOutlet=\"label\"></ng-container>\r\n </a>\r\n <ng-template #label>{{crumb.label}}</ng-template>\r\n </li>\r\n </ol>\r\n\r\n <div class=\"titlebar\">\r\n <app-page-title *ngIf=\"!customTitleTemplate; else customTitle\"\r\n [title]=\"title\"\r\n [subTitle]=\"subTitle\"\r\n [subTitleUrl]=\"subTitleUrl\"\r\n [titleIcon]=\"titleIcon\"\r\n class=\"title text-truncate\">\r\n </app-page-title>\r\n\r\n <ng-template #customTitle>\r\n <div class=\"title\">\r\n <ng-container *ngTemplateOutlet=\"customTitleTemplate\"></ng-container>\r\n </div>\r\n </ng-template>\r\n\r\n <div class=\"actions\">\r\n <ec-button id=\"primaryAction\"\r\n class=\"ml-2\"\r\n *ngIf=\"!hidePrimaryAction && onPrimaryAction.observers?.length && !readonly\"\r\n [disabled]=\"status?.status === 'pending' || disablePrimaryAction\"\r\n type=\"primary\"\r\n [label]=\"primaryActionLabel\"\r\n (clicked)=\"primaryAction($event)\">\r\n </ec-button>\r\n <ec-button id=\"secondaryAction\"\r\n class=\"ml-2\"\r\n *ngIf=\"!hideSecondaryAction && onSecondaryAction.observers?.length\"\r\n type=\"secondary\"\r\n [label]=\"readonly ? 'Close' : secondaryActionLabel\"\r\n (clicked)=\"secondaryAction($event)\">\r\n </ec-button>\r\n <ec-dropdown id=\"moreActions\"\r\n *ngIf=\"moreActions?.length && !readonly\"\r\n [disabled]=\"status?.status === 'pending'\"\r\n class=\"ml-2\"\r\n buttonType=\"text\"\r\n [label]=\"moreActionsLabel\"\r\n [items]=\"moreActions\">\r\n </ec-dropdown>\r\n <ng-container *ngTemplateOutlet=\"customActionsTemplate\"></ng-container>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"customHeaderTemplate\"\r\n class=\"page-header\">\r\n <ng-container *ngTemplateOutlet=\"customHeaderTemplate\"></ng-container>\r\n </div>\r\n\r\n <ec-banner *ngIf=\"!customErrorBannerTemplate && errors; else customErrorBannerOutlet\"\r\n id=\"pageViewErrors\"\r\n [class.border-bottom-0]=\"!isDialog\">\r\n <div [innerHtml]=\"errors\"></div>\r\n </ec-banner>\r\n\r\n <ng-template #customErrorBannerOutlet>\r\n <ec-banner *ngIf=\"errors\"\r\n id=\"pageViewErrors\"\r\n [class.border-bottom-0]=\"!isDialog\">\r\n <ng-container *ngTemplateOutlet=\"customErrorBannerTemplate\"></ng-container>\r\n </ec-banner>\r\n </ng-template>\r\n </header>\r\n </div>\r\n\r\n <ec-button *ngIf=\"isDialog && ( (status?.status === 'pending' && !hideCloseOnPending) || status?.status === 'error')\"\r\n id=\"pageViewDialogClose\"\r\n type=\"icon\"\r\n icon=\"icon-cancel\"\r\n (clicked)=\"closeDialog()\">\r\n </ec-button>\r\n</div>", styles: [":host{flex:1 1;min-height:0;display:flex}header{background-color:var(--ec-background-color-body);position:sticky;top:0;order:1;padding:1rem 1.5rem .5rem;flex:none;z-index:var(--ec-z-index-sticky-page-header)}ol{font-size:var(--ec-font-size-label);line-height:1rem;grid-column:1/3;grid-row:1/2;list-style:none;padding:0;margin:0 0 .25rem}ol li{display:inline}ol li:not(:last-child):after{content:\" / \";display:inline;color:var(--ec-color-secondary-dark)}div[ecOverlay]{position:relative}.titlebar{display:grid;grid-template-columns:auto max-content;grid-template-rows:max-content max-content;gap:0 1rem}.title{grid-column:1/2;grid-row:2/3;align-self:center}.actions{grid-column:2/3;grid-row:2/3;display:flex;flex-direction:row-reverse}ec-banner{margin-top:1rem}section{padding:var(--ec-page-view-padding-section, .5rem 1.5rem 2rem);order:2;flex:1 0 auto;min-height:0}:not(.is-dialog)>section{z-index:0}footer{background-color:var(--ec-background-color-body);order:3;padding:0 1.5rem;height:4.5rem;flex:none;display:flex;align-items:center}.is-dialog header{padding:0}.is-dialog .titlebar{background-color:var(--ec-background-color);padding:1rem}.is-dialog ec-banner{margin:0}.is-dialog section{padding:var(--ec-page-view-padding-section, 1rem 1rem 1.5rem)}.sticky-footer section{padding-bottom:4.5rem}.sticky-footer footer{position:sticky;bottom:0;z-index:var(--ec-z-index-sticky-page-header)}.fit-content>section{flex:1 1;display:flex}.footer-visible section{padding-bottom:0}.overlay-visible header{z-index:var(--ec-z-index-overlay)1}.overlay-visible ec-banner{display:none}:host(.bg-content) header{background-color:var(--ec-background-color)}:host(.bg-content) section{background-color:var(--ec-background-color)}:host(.bg-content) footer{background-color:var(--ec-background-color)}#pageViewDialogClose{position:absolute;top:1rem;right:1rem;z-index:calc(var(--ec-z-index-overlay) + 1)}\n"] }]
|
82
86
|
}], ctorParameters: function () { return [{ type: i1.DialogService }]; }, propDecorators: { isDialog: [{
|
83
87
|
type: Input
|
84
88
|
}], readonly: [{
|
@@ -127,6 +131,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
127
131
|
type: Input
|
128
132
|
}], fitContent: [{
|
129
133
|
type: Input
|
134
|
+
}], disablePrimaryAction: [{
|
135
|
+
type: Input
|
130
136
|
}], bgContent: [{
|
131
137
|
type: HostBinding,
|
132
138
|
args: ['class.bg-content']
|
@@ -137,4 +143,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
137
143
|
}], onSecondaryAction: [{
|
138
144
|
type: Output
|
139
145
|
}] } });
|
140
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-view.component.js","sourceRoot":"","sources":["../../../../../../../projects/components/src/lib/shared/page/page-view/page-view.component.ts","../../../../../../../projects/components/src/lib/shared/page/page-view/page-view.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,EAAe,MAAM,eAAe,CAAC;AAIjG,OAAO,EAAE,OAAO,EAAE,MAAM,sDAAsD,CAAC;AAC/E,OAAO,EAAE,YAAY,EAAE,MAAM,sCAAsC,CAAC;;;;;;;;;;AAUpE,MAAM,OAAO,iBAAiB;IAyG5B,YACU,aAA4B;QAA5B,kBAAa,GAAb,aAAa,CAAe;QAzGtC;;WAEG;QACa,aAAQ,GAAY,KAAK,CAAC;QAE1C;;WAEG;QACa,aAAQ,GAAY,KAAK,CAAC;QAE1C;;WAEG;QACa,WAAM,GAAa,IAAI,OAAO,CAAC,SAAS,CAAC,CAAC;QAE1D;;WAEG;QACa,eAAU,GAAY,IAAI,CAAC;QAoB3C;;WAEG;QACa,qBAAgB,GAAY,SAAS,CAAC;QAMtD;;WAEG;QACa,yBAAoB,GAAY,QAAQ,CAAC;QACzC,wBAAmB,GAAG,KAAK,CAAC;QAE5C,0GAA0G;QAC1F,uBAAkB,GAAY,KAAK,CAAC;QAEpD;;WAEG;QACa,uBAAkB,GAAY,MAAM,CAAC;QACrC,sBAAiB,GAAG,KAAK,CAAC;QA2B1C;;WAEG;QACa,iBAAY,GAAG,IAAI,CAAC;QAEpC;;WAEG;QACa,eAAU,GAAG,KAAK,CAAC;QAEnC,wEAAwE;QAExD,cAAS,GAAG,KAAK,CAAC;QAEjB,oBAAe,GAAsB,IAAI,YAAY,EAAE,CAAC;QACxD,sBAAiB,GAAsB,IAAI,YAAY,EAAE,CAAC;IAIvE,CAAC;IAEE,aAAa,CAAC,KAAU;QAC7B,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAClC;IACH,CAAC;IAEM,eAAe,CAAC,KAAU;QAC/B,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACpC;IACH,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC,IAAI,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC;IAChE,CAAC;;8GA3HU,iBAAiB;kGAAjB,iBAAiB,kiCCf9B,08JAuGM;2FDxFO,iBAAiB;kBAR7B,SAAS;+BACE,cAAc,QAGlB;wBACJ,KAAK,EAAE,WAAW;qBACnB;oGAMe,QAAQ;sBAAvB,KAAK;gBAKU,QAAQ;sBAAvB,KAAK;gBAKU,MAAM;sBAArB,KAAK;gBAKU,UAAU;sBAAzB,KAAK;gBAKU,MAAM;sBAArB,KAAK;gBAKU,WAAW;sBAA1B,KAAK;gBAKU,KAAK;sBAApB,KAAK;gBACU,SAAS;sBAAxB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBAKU,gBAAgB;sBAA/B,KAAK;gBAIU,WAAW;sBAA1B,KAAK;gBAKU,oBAAoB;sBAAnC,KAAK;gBACU,mBAAmB;sBAAlC,KAAK;gBAGU,kBAAkB;sBAAjC,KAAK;gBAKU,kBAAkB;sBAAjC,KAAK;gBACU,iBAAiB;sBAAhC,KAAK;gBAKU,mBAAmB;sBAAlC,KAAK;gBAKU,qBAAqB;sBAApC,KAAK;gBAKU,oBAAoB;sBAAnC,KAAK;gBAKU,cAAc;sBAA7B,KAAK;gBAKU,yBAAyB;sBAAxC,KAAK;gBAKU,YAAY;sBAA3B,KAAK;gBAKU,UAAU;sBAAzB,KAAK;gBAIU,SAAS;sBADxB,WAAW;uBAAC,kBAAkB;;sBAC9B,KAAK;gBAEW,eAAe;sBAA/B,MAAM;gBACU,iBAAiB;sBAAjC,MAAM","sourcesContent":["import { Component, EventEmitter, HostBinding, Input, Output, TemplateRef } from '@angular/core';\r\nimport { DialogService } from '../../../display/dialog/dialog.service';\r\nimport { MenuItem } from '../../../controls/menu/menu.component';\r\nimport { NavItem } from '../../../controls/navigation/nav-item';\r\nimport { Overlay } from '../../../display/view-overlay/view-overlay.component';\r\nimport { DialogResult } from '../../../display/dialog/dialog-types';\r\n\r\n@Component({\r\n  selector: 'ec-page-view',\r\n  templateUrl: './page-view.component.html',\r\n  styleUrls: ['./page-view.component.scss'],\r\n  host: {\r\n    class: \"flex-grow\"\r\n  }\r\n})\r\nexport class PageViewComponent {\r\n  /**\r\n   * Set to true when page-view is inside a dialog to adjust styles and hide breadcrumbs.\r\n   */\r\n  @Input() public isDialog: boolean = false;\r\n\r\n  /**\r\n   * Set to true to enable read only mode. Only a single secondary action will be available\r\n   */\r\n  @Input() public readonly: boolean = false;\r\n\r\n  /**\r\n   * Controls Overlay that masks the page view content. Only the header is not masked when the overlay is visible. Default is pending Overlay with no message\r\n   */\r\n  @Input() public status?: Overlay = new Overlay('pending');\r\n\r\n  /**\r\n   * Set to false to hide the entire header, including breadcrumbs and error banner. Default is true.\r\n   */\r\n  @Input() public showHeader: boolean = true;\r\n\r\n  /**\r\n   * Displays an error banner under the titlebar when provided a value.\r\n   */\r\n  @Input() public errors?: string;\r\n\r\n  /**\r\n   * Breadcrumbs to be displayed in the header.\r\n   */\r\n  @Input() public breadcrumbs?: NavItem[];\r\n\r\n  /**\r\n   * Title settings. Passed to the PageTitleComponent.\r\n   */\r\n  @Input() public title?: string;\r\n  @Input() public titleIcon?: string;\r\n  @Input() public subTitle?: string;\r\n  @Input() public subTitleUrl?: string;\r\n\r\n  /**\r\n   * Label for the actions dropdown in the header. Default is 'Actions'\r\n   */\r\n  @Input() public moreActionsLabel?: string = 'Actions';\r\n  /**\r\n   * Options for the actions dropdown in the header. The dropdown is hidden if not options are provided.\r\n   */\r\n  @Input() public moreActions?: MenuItem[];\r\n\r\n  /**\r\n   * Label for the secondary button in the header. Default is 'Cancel'\r\n   */\r\n  @Input() public secondaryActionLabel?: string = 'Cancel';\r\n  @Input() public hideSecondaryAction = false;\r\n\r\n  /** Flag for hiding the tiny close button in the top-right corner of dialog while in pending state only */\r\n  @Input() public hideCloseOnPending: boolean = false;\r\n\r\n  /**\r\n   * Label for the primary button in the header. Default is 'Save'\r\n   */\r\n  @Input() public primaryActionLabel?: string = 'Save';\r\n  @Input() public hidePrimaryAction = false;\r\n\r\n  /**\r\n   * Replaces the title, subtitle and title icon\r\n   */\r\n  @Input() public customTitleTemplate?: TemplateRef<any>;\r\n\r\n  /**\r\n   * Inserted to the left of the default actions\r\n   */\r\n  @Input() public customActionsTemplate?: TemplateRef<any>;\r\n\r\n  /**\r\n   * Replaces the titlebar and actions of the default header. Breadcrumbs and error banner are not replaced. Cannot contain a <header> element.\r\n   */\r\n  @Input() public customHeaderTemplate?: TemplateRef<any>;\r\n\r\n  /**\r\n   * Content to include in the footer\r\n   */\r\n  @Input() public footerTemplate?: TemplateRef<any>;\r\n\r\n  /**\r\n   * Replaces the Error Banner default template. Useful when we need to show more than text in the banner.\r\n   */\r\n  @Input() public customErrorBannerTemplate?: TemplateRef<any>;\r\n\r\n  /**\r\n   * Pins the footer to the bottom of the view and overlays any overflowing content\r\n   */\r\n  @Input() public stickyFooter = true;\r\n\r\n  /**\r\n   * Prevents content from overflowing the view. Content must manage overflow instead.\r\n   */\r\n  @Input() public fitContent = false;\r\n\r\n  /** Changes the background color for the content and overlay to white */\r\n  @HostBinding('class.bg-content')\r\n  @Input() public bgContent = false;\r\n\r\n  @Output() public onPrimaryAction: EventEmitter<any> = new EventEmitter();\r\n  @Output() public onSecondaryAction: EventEmitter<any> = new EventEmitter();\r\n\r\n  constructor(\r\n    private dialogService: DialogService\r\n  ) { }\r\n\r\n  public primaryAction(event: any) {\r\n    if (this.onPrimaryAction) {\r\n      this.onPrimaryAction.emit(event);\r\n    }\r\n  }\r\n\r\n  public secondaryAction(event: any) {\r\n    if (this.onSecondaryAction) {\r\n      this.onSecondaryAction.emit(event);\r\n    }\r\n  }\r\n\r\n  public closeDialog() {\r\n    this.dialogService.closeLatestDialog(new DialogResult(false));\r\n  }\r\n}\r\n","<div ecOverlay\r\n     [status]=\"status?.status\"\r\n     [message]=\"status?.message\"\r\n     [displayAsMask]=\"true\"\r\n     class=\"flex-grow d-flex\"\r\n     [ngClass]=\"{'bg-body': !bgContent, 'bg-content': bgContent}\">\r\n    <div id=\"PageViewScrollContainer\"\r\n         class=\"d-flex flex-column flex-grow scroll-y\"\r\n         [class.is-dialog]=\"isDialog\"\r\n         [class.fit-content]=\"fitContent\"\r\n         [class.sticky-footer]=\"stickyFooter && !!footerTemplate\"\r\n         [class.overlay-visible]=\"status?.status !== 'hasData'\"\r\n         [class.footer-visible]=\"!!footerTemplate\">\r\n        <section>\r\n            <ng-content></ng-content>\r\n        </section>\r\n\r\n        <footer *ngIf=\"footerTemplate\">\r\n            <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\r\n        </footer>\r\n\r\n        <header *ngIf=\"showHeader\">\r\n            <ol id=\"breadcrumbs\"\r\n                *ngIf=\"breadcrumbs?.length && !isDialog\">\r\n                <li *ngFor=\"let crumb of breadcrumbs; last as isLast\">\r\n                    <a *ngIf=\"crumb.url; else label\"\r\n                       [routerLink]=\"crumb.url\">\r\n                        <ng-container *ngTemplateOutlet=\"label\"></ng-container>\r\n                    </a>\r\n                    <ng-template #label>{{crumb.label}}</ng-template>\r\n                </li>\r\n            </ol>\r\n\r\n            <div class=\"titlebar\">\r\n                <app-page-title *ngIf=\"!customTitleTemplate; else customTitle\"\r\n                                [title]=\"title\"\r\n                                [subTitle]=\"subTitle\"\r\n                                [subTitleUrl]=\"subTitleUrl\"\r\n                                [titleIcon]=\"titleIcon\"\r\n                                class=\"title text-truncate\">\r\n                </app-page-title>\r\n\r\n                <ng-template #customTitle>\r\n                    <div class=\"title\">\r\n                        <ng-container *ngTemplateOutlet=\"customTitleTemplate\"></ng-container>\r\n                    </div>\r\n                </ng-template>\r\n\r\n                <div class=\"actions\">\r\n                    <ec-button id=\"primaryAction\"\r\n                               class=\"ml-2\"\r\n                               *ngIf=\"!hidePrimaryAction && onPrimaryAction.observers?.length && !readonly\"\r\n                               [disabled]=\"status?.status === 'pending'\"\r\n                               type=\"primary\"\r\n                               [label]=\"primaryActionLabel\"\r\n                               (clicked)=\"primaryAction($event)\">\r\n                    </ec-button>\r\n                    <ec-button id=\"secondaryAction\"\r\n                               class=\"ml-2\"\r\n                               *ngIf=\"!hideSecondaryAction && onSecondaryAction.observers?.length\"\r\n                               type=\"secondary\"\r\n                               [label]=\"readonly ? 'Close' : secondaryActionLabel\"\r\n                               (clicked)=\"secondaryAction($event)\">\r\n                    </ec-button>\r\n                    <ec-dropdown id=\"moreActions\"\r\n                                 *ngIf=\"moreActions?.length && !readonly\"\r\n                                 [disabled]=\"status?.status === 'pending'\"\r\n                                 class=\"ml-2\"\r\n                                 buttonType=\"text\"\r\n                                 [label]=\"moreActionsLabel\"\r\n                                 [items]=\"moreActions\">\r\n                    </ec-dropdown>\r\n                    <ng-container *ngTemplateOutlet=\"customActionsTemplate\"></ng-container>\r\n                </div>\r\n            </div>\r\n\r\n            <div *ngIf=\"customHeaderTemplate\"\r\n                 class=\"page-header\">\r\n                <ng-container *ngTemplateOutlet=\"customHeaderTemplate\"></ng-container>\r\n            </div>\r\n\r\n            <ec-banner *ngIf=\"!customErrorBannerTemplate && errors; else customErrorBannerOutlet\"\r\n                       id=\"pageViewErrors\"\r\n                       [class.border-bottom-0]=\"!isDialog\">\r\n                <div [innerHtml]=\"errors\"></div>\r\n            </ec-banner>\r\n\r\n            <ng-template #customErrorBannerOutlet>\r\n                <ec-banner *ngIf=\"errors\"\r\n                           id=\"pageViewErrors\"\r\n                           [class.border-bottom-0]=\"!isDialog\">\r\n                    <ng-container *ngTemplateOutlet=\"customErrorBannerTemplate\"></ng-container>\r\n                </ec-banner>\r\n            </ng-template>\r\n        </header>\r\n    </div>\r\n\r\n    <ec-button *ngIf=\"isDialog && ( (status?.status === 'pending' && !hideCloseOnPending) || status?.status === 'error')\"\r\n               id=\"pageViewDialogClose\"\r\n               type=\"icon\"\r\n               icon=\"icon-cancel\"\r\n               (clicked)=\"closeDialog()\">\r\n    </ec-button>\r\n</div>"]}
|
146
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-view.component.js","sourceRoot":"","sources":["../../../../../../../projects/components/src/lib/shared/page/page-view/page-view.component.ts","../../../../../../../projects/components/src/lib/shared/page/page-view/page-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, HostBinding, Input, Output, TemplateRef } from '@angular/core';\r\nimport { DialogService } from '../../../display/dialog/dialog.service';\r\nimport { MenuItem } from '../../../controls/menu/menu.component';\r\nimport { NavItem } from '../../../controls/navigation/nav-item';\r\nimport { Overlay } from '../../../display/view-overlay/view-overlay.component';\r\nimport { DialogResult } from '../../../display/dialog/dialog-types';\r\n\r\n@Component({\r\n  selector: 'ec-page-view',\r\n  templateUrl: './page-view.component.html',\r\n  styleUrls: ['./page-view.component.scss'],\r\n  host: {\r\n    class: \"flex-grow\"\r\n  }\r\n})\r\nexport class PageViewComponent {\r\n  /**\r\n   * Set to true when page-view is inside a dialog to adjust styles and hide breadcrumbs.\r\n   */\r\n  @Input() public isDialog: boolean = false;\r\n\r\n  /**\r\n   * Set to true to enable read only mode. Only a single secondary action will be available\r\n   */\r\n  @Input() public readonly: boolean = false;\r\n\r\n  /**\r\n   * Controls Overlay that masks the page view content. Only the header is not masked when the overlay is visible. Default is pending Overlay with no message\r\n   */\r\n  @Input() public status?: Overlay = new Overlay('pending');\r\n\r\n  /**\r\n   * Set to false to hide the entire header, including breadcrumbs and error banner. Default is true.\r\n   */\r\n  @Input() public showHeader: boolean = true;\r\n\r\n  /**\r\n   * Displays an error banner under the titlebar when provided a value.\r\n   */\r\n  @Input() public errors?: string;\r\n\r\n  /**\r\n   * Breadcrumbs to be displayed in the header.\r\n   */\r\n  @Input() public breadcrumbs?: NavItem[];\r\n\r\n  /**\r\n   * Title settings. Passed to the PageTitleComponent.\r\n   */\r\n  @Input() public title?: string;\r\n  @Input() public titleIcon?: string;\r\n  @Input() public subTitle?: string;\r\n  @Input() public subTitleUrl?: string;\r\n\r\n  /**\r\n   * Label for the actions dropdown in the header. Default is 'Actions'\r\n   */\r\n  @Input() public moreActionsLabel?: string = 'Actions';\r\n  /**\r\n   * Options for the actions dropdown in the header. The dropdown is hidden if not options are provided.\r\n   */\r\n  @Input() public moreActions?: MenuItem[];\r\n\r\n  /**\r\n   * Label for the secondary button in the header. Default is 'Cancel'\r\n   */\r\n  @Input() public secondaryActionLabel?: string = 'Cancel';\r\n  @Input() public hideSecondaryAction = false;\r\n\r\n  /** Flag for hiding the tiny close button in the top-right corner of dialog while in pending state only */\r\n  @Input() public hideCloseOnPending: boolean = false;\r\n\r\n  /**\r\n   * Label for the primary button in the header. Default is 'Save'\r\n   */\r\n  @Input() public primaryActionLabel?: string = 'Save';\r\n  @Input() public hidePrimaryAction = false;\r\n\r\n  /**\r\n   * Replaces the title, subtitle and title icon\r\n   */\r\n  @Input() public customTitleTemplate?: TemplateRef<any>;\r\n\r\n  /**\r\n   * Inserted to the left of the default actions\r\n   */\r\n  @Input() public customActionsTemplate?: TemplateRef<any>;\r\n\r\n  /**\r\n   * Replaces the titlebar and actions of the default header. Breadcrumbs and error banner are not replaced. Cannot contain a <header> element.\r\n   */\r\n  @Input() public customHeaderTemplate?: TemplateRef<any>;\r\n\r\n  /**\r\n   * Content to include in the footer\r\n   */\r\n  @Input() public footerTemplate?: TemplateRef<any>;\r\n\r\n  /**\r\n   * Replaces the Error Banner default template. Useful when we need to show more than text in the banner.\r\n   */\r\n  @Input() public customErrorBannerTemplate?: TemplateRef<any>;\r\n\r\n  /**\r\n   * Pins the footer to the bottom of the view and overlays any overflowing content\r\n   */\r\n  @Input() public stickyFooter = true;\r\n\r\n  /**\r\n   * Prevents content from overflowing the view. Content must manage overflow instead.\r\n   */\r\n  @Input() public fitContent = false;\r\n\r\n  /**\r\n   * Disables the primary action button\r\n   */\r\n  @Input() public disablePrimaryAction = false;\r\n\r\n  /** Changes the background color for the content and overlay to white */\r\n  @HostBinding('class.bg-content')\r\n  @Input() public bgContent = false;\r\n\r\n  @Output() public onPrimaryAction: EventEmitter<any> = new EventEmitter();\r\n  @Output() public onSecondaryAction: EventEmitter<any> = new EventEmitter();\r\n\r\n  constructor(\r\n    private dialogService: DialogService\r\n  ) { }\r\n\r\n  public primaryAction(event: any) {\r\n    if (this.onPrimaryAction) {\r\n      this.onPrimaryAction.emit(event);\r\n    }\r\n  }\r\n\r\n  public secondaryAction(event: any) {\r\n    if (this.onSecondaryAction) {\r\n      this.onSecondaryAction.emit(event);\r\n    }\r\n  }\r\n\r\n  public closeDialog() {\r\n    this.dialogService.closeLatestDialog(new DialogResult(false));\r\n  }\r\n}\r\n","<div ecOverlay\r\n     [status]=\"status?.status\"\r\n     [message]=\"status?.message\"\r\n     [displayAsMask]=\"true\"\r\n     class=\"flex-grow d-flex\"\r\n     [ngClass]=\"{'bg-body': !bgContent, 'bg-content': bgContent}\">\r\n    <div id=\"PageViewScrollContainer\"\r\n         class=\"d-flex flex-column flex-grow scroll-y\"\r\n         [class.is-dialog]=\"isDialog\"\r\n         [class.fit-content]=\"fitContent\"\r\n         [class.sticky-footer]=\"stickyFooter && !!footerTemplate\"\r\n         [class.overlay-visible]=\"status?.status !== 'hasData'\"\r\n         [class.footer-visible]=\"!!footerTemplate\">\r\n        <section>\r\n            <ng-content></ng-content>\r\n        </section>\r\n\r\n        <footer *ngIf=\"footerTemplate\">\r\n            <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\r\n        </footer>\r\n\r\n        <header *ngIf=\"showHeader\">\r\n            <ol id=\"breadcrumbs\"\r\n                *ngIf=\"breadcrumbs?.length && !isDialog\">\r\n                <li *ngFor=\"let crumb of breadcrumbs; last as isLast\">\r\n                    <a *ngIf=\"crumb.url; else label\"\r\n                       [routerLink]=\"crumb.url\">\r\n                        <ng-container *ngTemplateOutlet=\"label\"></ng-container>\r\n                    </a>\r\n                    <ng-template #label>{{crumb.label}}</ng-template>\r\n                </li>\r\n            </ol>\r\n\r\n            <div class=\"titlebar\">\r\n                <app-page-title *ngIf=\"!customTitleTemplate; else customTitle\"\r\n                                [title]=\"title\"\r\n                                [subTitle]=\"subTitle\"\r\n                                [subTitleUrl]=\"subTitleUrl\"\r\n                                [titleIcon]=\"titleIcon\"\r\n                                class=\"title text-truncate\">\r\n                </app-page-title>\r\n\r\n                <ng-template #customTitle>\r\n                    <div class=\"title\">\r\n                        <ng-container *ngTemplateOutlet=\"customTitleTemplate\"></ng-container>\r\n                    </div>\r\n                </ng-template>\r\n\r\n                <div class=\"actions\">\r\n                    <ec-button id=\"primaryAction\"\r\n                               class=\"ml-2\"\r\n                               *ngIf=\"!hidePrimaryAction && onPrimaryAction.observers?.length && !readonly\"\r\n                               [disabled]=\"status?.status === 'pending' || disablePrimaryAction\"\r\n                               type=\"primary\"\r\n                               [label]=\"primaryActionLabel\"\r\n                               (clicked)=\"primaryAction($event)\">\r\n                    </ec-button>\r\n                    <ec-button id=\"secondaryAction\"\r\n                               class=\"ml-2\"\r\n                               *ngIf=\"!hideSecondaryAction && onSecondaryAction.observers?.length\"\r\n                               type=\"secondary\"\r\n                               [label]=\"readonly ? 'Close' : secondaryActionLabel\"\r\n                               (clicked)=\"secondaryAction($event)\">\r\n                    </ec-button>\r\n                    <ec-dropdown id=\"moreActions\"\r\n                                 *ngIf=\"moreActions?.length && !readonly\"\r\n                                 [disabled]=\"status?.status === 'pending'\"\r\n                                 class=\"ml-2\"\r\n                                 buttonType=\"text\"\r\n                                 [label]=\"moreActionsLabel\"\r\n                                 [items]=\"moreActions\">\r\n                    </ec-dropdown>\r\n                    <ng-container *ngTemplateOutlet=\"customActionsTemplate\"></ng-container>\r\n                </div>\r\n            </div>\r\n\r\n            <div *ngIf=\"customHeaderTemplate\"\r\n                 class=\"page-header\">\r\n                <ng-container *ngTemplateOutlet=\"customHeaderTemplate\"></ng-container>\r\n            </div>\r\n\r\n            <ec-banner *ngIf=\"!customErrorBannerTemplate && errors; else customErrorBannerOutlet\"\r\n                       id=\"pageViewErrors\"\r\n                       [class.border-bottom-0]=\"!isDialog\">\r\n                <div [innerHtml]=\"errors\"></div>\r\n            </ec-banner>\r\n\r\n            <ng-template #customErrorBannerOutlet>\r\n                <ec-banner *ngIf=\"errors\"\r\n                           id=\"pageViewErrors\"\r\n                           [class.border-bottom-0]=\"!isDialog\">\r\n                    <ng-container *ngTemplateOutlet=\"customErrorBannerTemplate\"></ng-container>\r\n                </ec-banner>\r\n            </ng-template>\r\n        </header>\r\n    </div>\r\n\r\n    <ec-button *ngIf=\"isDialog && ( (status?.status === 'pending' && !hideCloseOnPending) || status?.status === 'error')\"\r\n               id=\"pageViewDialogClose\"\r\n               type=\"icon\"\r\n               icon=\"icon-cancel\"\r\n               (clicked)=\"closeDialog()\">\r\n    </ec-button>\r\n</div>"]}
|
@@ -8462,6 +8462,10 @@ class PageViewComponent {
|
|
8462
8462
|
* Prevents content from overflowing the view. Content must manage overflow instead.
|
8463
8463
|
*/
|
8464
8464
|
this.fitContent = false;
|
8465
|
+
/**
|
8466
|
+
* Disables the primary action button
|
8467
|
+
*/
|
8468
|
+
this.disablePrimaryAction = false;
|
8465
8469
|
/** Changes the background color for the content and overlay to white */
|
8466
8470
|
this.bgContent = false;
|
8467
8471
|
this.onPrimaryAction = new EventEmitter();
|
@@ -8482,12 +8486,12 @@ class PageViewComponent {
|
|
8482
8486
|
}
|
8483
8487
|
}
|
8484
8488
|
PageViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: PageViewComponent, deps: [{ token: DialogService }], target: i0.ɵɵFactoryTarget.Component });
|
8485
|
-
PageViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: PageViewComponent, selector: "ec-page-view", inputs: { isDialog: "isDialog", readonly: "readonly", status: "status", showHeader: "showHeader", errors: "errors", breadcrumbs: "breadcrumbs", title: "title", titleIcon: "titleIcon", subTitle: "subTitle", subTitleUrl: "subTitleUrl", moreActionsLabel: "moreActionsLabel", moreActions: "moreActions", secondaryActionLabel: "secondaryActionLabel", hideSecondaryAction: "hideSecondaryAction", hideCloseOnPending: "hideCloseOnPending", primaryActionLabel: "primaryActionLabel", hidePrimaryAction: "hidePrimaryAction", customTitleTemplate: "customTitleTemplate", customActionsTemplate: "customActionsTemplate", customHeaderTemplate: "customHeaderTemplate", footerTemplate: "footerTemplate", customErrorBannerTemplate: "customErrorBannerTemplate", stickyFooter: "stickyFooter", fitContent: "fitContent", bgContent: "bgContent" }, outputs: { onPrimaryAction: "onPrimaryAction", onSecondaryAction: "onSecondaryAction" }, host: { properties: { "class.bg-content": "this.bgContent" }, classAttribute: "flex-grow" }, ngImport: i0, template: "<div ecOverlay\r\n [status]=\"status?.status\"\r\n [message]=\"status?.message\"\r\n [displayAsMask]=\"true\"\r\n class=\"flex-grow d-flex\"\r\n [ngClass]=\"{'bg-body': !bgContent, 'bg-content': bgContent}\">\r\n <div id=\"PageViewScrollContainer\"\r\n class=\"d-flex flex-column flex-grow scroll-y\"\r\n [class.is-dialog]=\"isDialog\"\r\n [class.fit-content]=\"fitContent\"\r\n [class.sticky-footer]=\"stickyFooter && !!footerTemplate\"\r\n [class.overlay-visible]=\"status?.status !== 'hasData'\"\r\n [class.footer-visible]=\"!!footerTemplate\">\r\n <section>\r\n <ng-content></ng-content>\r\n </section>\r\n\r\n <footer *ngIf=\"footerTemplate\">\r\n <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\r\n </footer>\r\n\r\n <header *ngIf=\"showHeader\">\r\n <ol id=\"breadcrumbs\"\r\n *ngIf=\"breadcrumbs?.length && !isDialog\">\r\n <li *ngFor=\"let crumb of breadcrumbs; last as isLast\">\r\n <a *ngIf=\"crumb.url; else label\"\r\n [routerLink]=\"crumb.url\">\r\n <ng-container *ngTemplateOutlet=\"label\"></ng-container>\r\n </a>\r\n <ng-template #label>{{crumb.label}}</ng-template>\r\n </li>\r\n </ol>\r\n\r\n <div class=\"titlebar\">\r\n <app-page-title *ngIf=\"!customTitleTemplate; else customTitle\"\r\n [title]=\"title\"\r\n [subTitle]=\"subTitle\"\r\n [subTitleUrl]=\"subTitleUrl\"\r\n [titleIcon]=\"titleIcon\"\r\n class=\"title text-truncate\">\r\n </app-page-title>\r\n\r\n <ng-template #customTitle>\r\n <div class=\"title\">\r\n <ng-container *ngTemplateOutlet=\"customTitleTemplate\"></ng-container>\r\n </div>\r\n </ng-template>\r\n\r\n <div class=\"actions\">\r\n <ec-button id=\"primaryAction\"\r\n class=\"ml-2\"\r\n *ngIf=\"!hidePrimaryAction && onPrimaryAction.observers?.length && !readonly\"\r\n [disabled]=\"status?.status === 'pending'\"\r\n type=\"primary\"\r\n [label]=\"primaryActionLabel\"\r\n (clicked)=\"primaryAction($event)\">\r\n </ec-button>\r\n <ec-button id=\"secondaryAction\"\r\n class=\"ml-2\"\r\n *ngIf=\"!hideSecondaryAction && onSecondaryAction.observers?.length\"\r\n type=\"secondary\"\r\n [label]=\"readonly ? 'Close' : secondaryActionLabel\"\r\n (clicked)=\"secondaryAction($event)\">\r\n </ec-button>\r\n <ec-dropdown id=\"moreActions\"\r\n *ngIf=\"moreActions?.length && !readonly\"\r\n [disabled]=\"status?.status === 'pending'\"\r\n class=\"ml-2\"\r\n buttonType=\"text\"\r\n [label]=\"moreActionsLabel\"\r\n [items]=\"moreActions\">\r\n </ec-dropdown>\r\n <ng-container *ngTemplateOutlet=\"customActionsTemplate\"></ng-container>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"customHeaderTemplate\"\r\n class=\"page-header\">\r\n <ng-container *ngTemplateOutlet=\"customHeaderTemplate\"></ng-container>\r\n </div>\r\n\r\n <ec-banner *ngIf=\"!customErrorBannerTemplate && errors; else customErrorBannerOutlet\"\r\n id=\"pageViewErrors\"\r\n [class.border-bottom-0]=\"!isDialog\">\r\n <div [innerHtml]=\"errors\"></div>\r\n </ec-banner>\r\n\r\n <ng-template #customErrorBannerOutlet>\r\n <ec-banner *ngIf=\"errors\"\r\n id=\"pageViewErrors\"\r\n [class.border-bottom-0]=\"!isDialog\">\r\n <ng-container *ngTemplateOutlet=\"customErrorBannerTemplate\"></ng-container>\r\n </ec-banner>\r\n </ng-template>\r\n </header>\r\n </div>\r\n\r\n <ec-button *ngIf=\"isDialog && ( (status?.status === 'pending' && !hideCloseOnPending) || status?.status === 'error')\"\r\n id=\"pageViewDialogClose\"\r\n type=\"icon\"\r\n icon=\"icon-cancel\"\r\n (clicked)=\"closeDialog()\">\r\n </ec-button>\r\n</div>", styles: [":host{flex:1 1;min-height:0;display:flex}header{background-color:var(--ec-background-color-body);position:sticky;top:0;order:1;padding:1rem 1.5rem .5rem;flex:none;z-index:var(--ec-z-index-sticky-page-header)}ol{font-size:var(--ec-font-size-label);line-height:1rem;grid-column:1/3;grid-row:1/2;list-style:none;padding:0;margin:0 0 .25rem}ol li{display:inline}ol li:not(:last-child):after{content:\" / \";display:inline;color:var(--ec-color-secondary-dark)}div[ecOverlay]{position:relative}.titlebar{display:grid;grid-template-columns:auto max-content;grid-template-rows:max-content max-content;gap:0 1rem}.title{grid-column:1/2;grid-row:2/3;align-self:center}.actions{grid-column:2/3;grid-row:2/3;display:flex;flex-direction:row-reverse}ec-banner{margin-top:1rem}section{padding:var(--ec-page-view-padding-section, .5rem 1.5rem 2rem);order:2;flex:1 0 auto;min-height:0}:not(.is-dialog)>section{z-index:0}footer{background-color:var(--ec-background-color-body);order:3;padding:0 1.5rem;height:4.5rem;flex:none;display:flex;align-items:center}.is-dialog header{padding:0}.is-dialog .titlebar{background-color:var(--ec-background-color);padding:1rem}.is-dialog ec-banner{margin:0}.is-dialog section{padding:var(--ec-page-view-padding-section, 1rem 1rem 1.5rem)}.sticky-footer section{padding-bottom:4.5rem}.sticky-footer footer{position:sticky;bottom:0;z-index:var(--ec-z-index-sticky-page-header)}.fit-content>section{flex:1 1;display:flex}.footer-visible section{padding-bottom:0}.overlay-visible header{z-index:var(--ec-z-index-overlay)1}.overlay-visible ec-banner{display:none}:host(.bg-content) header{background-color:var(--ec-background-color)}:host(.bg-content) section{background-color:var(--ec-background-color)}:host(.bg-content) footer{background-color:var(--ec-background-color)}#pageViewDialogClose{position:absolute;top:1rem;right:1rem;z-index:calc(var(--ec-z-index-overlay) + 1)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1$1.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: ButtonComponent, selector: "ec-button", inputs: ["id", "disabled", "icon", "label", "badge", "tabindex", "type", "pending", "pendingIcon", "customTemplate", "isSubmit", "autofocus"], outputs: ["clicked"] }, { kind: "component", type: ViewOverlayComponent, selector: "[ecOverlay]", inputs: ["status", "message", "action", "noDataTemplate", "displayAsMask", "overlayClassList"] }, { kind: "component", type: BannerComponent, selector: "ec-banner", inputs: ["hidden", "id", "type", "bannerStyle", "title", "text", "list", "showCloseBtn", "autoHideOnClose", "customIcon", "rememberClosed"], outputs: ["closed"] }, { kind: "component", type: DropdownComponent, selector: "ec-dropdown", inputs: ["id", "autofocus", "status", "disabled", "label", "icon", "buttonType", "buttonAlignment", "buttonTitle", "tabindex", "showArrow", "items", "menuTemplateType", "menuTitle", "menuHeight", "menuWidth", "menuMinWidth", "menuPosition", "menuFooter", "popupFixed", "buttonCustomTemplate", "pending"], outputs: ["itemSelected", "popupOpened"] }, { kind: "component", type: PageTitleComponent, selector: "app-page-title", inputs: ["title", "titleIcon", "subTitle", "subTitleUrl"] }] });
|
8489
|
+
PageViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: PageViewComponent, selector: "ec-page-view", inputs: { isDialog: "isDialog", readonly: "readonly", status: "status", showHeader: "showHeader", errors: "errors", breadcrumbs: "breadcrumbs", title: "title", titleIcon: "titleIcon", subTitle: "subTitle", subTitleUrl: "subTitleUrl", moreActionsLabel: "moreActionsLabel", moreActions: "moreActions", secondaryActionLabel: "secondaryActionLabel", hideSecondaryAction: "hideSecondaryAction", hideCloseOnPending: "hideCloseOnPending", primaryActionLabel: "primaryActionLabel", hidePrimaryAction: "hidePrimaryAction", customTitleTemplate: "customTitleTemplate", customActionsTemplate: "customActionsTemplate", customHeaderTemplate: "customHeaderTemplate", footerTemplate: "footerTemplate", customErrorBannerTemplate: "customErrorBannerTemplate", stickyFooter: "stickyFooter", fitContent: "fitContent", disablePrimaryAction: "disablePrimaryAction", bgContent: "bgContent" }, outputs: { onPrimaryAction: "onPrimaryAction", onSecondaryAction: "onSecondaryAction" }, host: { properties: { "class.bg-content": "this.bgContent" }, classAttribute: "flex-grow" }, ngImport: i0, template: "<div ecOverlay\r\n [status]=\"status?.status\"\r\n [message]=\"status?.message\"\r\n [displayAsMask]=\"true\"\r\n class=\"flex-grow d-flex\"\r\n [ngClass]=\"{'bg-body': !bgContent, 'bg-content': bgContent}\">\r\n <div id=\"PageViewScrollContainer\"\r\n class=\"d-flex flex-column flex-grow scroll-y\"\r\n [class.is-dialog]=\"isDialog\"\r\n [class.fit-content]=\"fitContent\"\r\n [class.sticky-footer]=\"stickyFooter && !!footerTemplate\"\r\n [class.overlay-visible]=\"status?.status !== 'hasData'\"\r\n [class.footer-visible]=\"!!footerTemplate\">\r\n <section>\r\n <ng-content></ng-content>\r\n </section>\r\n\r\n <footer *ngIf=\"footerTemplate\">\r\n <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\r\n </footer>\r\n\r\n <header *ngIf=\"showHeader\">\r\n <ol id=\"breadcrumbs\"\r\n *ngIf=\"breadcrumbs?.length && !isDialog\">\r\n <li *ngFor=\"let crumb of breadcrumbs; last as isLast\">\r\n <a *ngIf=\"crumb.url; else label\"\r\n [routerLink]=\"crumb.url\">\r\n <ng-container *ngTemplateOutlet=\"label\"></ng-container>\r\n </a>\r\n <ng-template #label>{{crumb.label}}</ng-template>\r\n </li>\r\n </ol>\r\n\r\n <div class=\"titlebar\">\r\n <app-page-title *ngIf=\"!customTitleTemplate; else customTitle\"\r\n [title]=\"title\"\r\n [subTitle]=\"subTitle\"\r\n [subTitleUrl]=\"subTitleUrl\"\r\n [titleIcon]=\"titleIcon\"\r\n class=\"title text-truncate\">\r\n </app-page-title>\r\n\r\n <ng-template #customTitle>\r\n <div class=\"title\">\r\n <ng-container *ngTemplateOutlet=\"customTitleTemplate\"></ng-container>\r\n </div>\r\n </ng-template>\r\n\r\n <div class=\"actions\">\r\n <ec-button id=\"primaryAction\"\r\n class=\"ml-2\"\r\n *ngIf=\"!hidePrimaryAction && onPrimaryAction.observers?.length && !readonly\"\r\n [disabled]=\"status?.status === 'pending' || disablePrimaryAction\"\r\n type=\"primary\"\r\n [label]=\"primaryActionLabel\"\r\n (clicked)=\"primaryAction($event)\">\r\n </ec-button>\r\n <ec-button id=\"secondaryAction\"\r\n class=\"ml-2\"\r\n *ngIf=\"!hideSecondaryAction && onSecondaryAction.observers?.length\"\r\n type=\"secondary\"\r\n [label]=\"readonly ? 'Close' : secondaryActionLabel\"\r\n (clicked)=\"secondaryAction($event)\">\r\n </ec-button>\r\n <ec-dropdown id=\"moreActions\"\r\n *ngIf=\"moreActions?.length && !readonly\"\r\n [disabled]=\"status?.status === 'pending'\"\r\n class=\"ml-2\"\r\n buttonType=\"text\"\r\n [label]=\"moreActionsLabel\"\r\n [items]=\"moreActions\">\r\n </ec-dropdown>\r\n <ng-container *ngTemplateOutlet=\"customActionsTemplate\"></ng-container>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"customHeaderTemplate\"\r\n class=\"page-header\">\r\n <ng-container *ngTemplateOutlet=\"customHeaderTemplate\"></ng-container>\r\n </div>\r\n\r\n <ec-banner *ngIf=\"!customErrorBannerTemplate && errors; else customErrorBannerOutlet\"\r\n id=\"pageViewErrors\"\r\n [class.border-bottom-0]=\"!isDialog\">\r\n <div [innerHtml]=\"errors\"></div>\r\n </ec-banner>\r\n\r\n <ng-template #customErrorBannerOutlet>\r\n <ec-banner *ngIf=\"errors\"\r\n id=\"pageViewErrors\"\r\n [class.border-bottom-0]=\"!isDialog\">\r\n <ng-container *ngTemplateOutlet=\"customErrorBannerTemplate\"></ng-container>\r\n </ec-banner>\r\n </ng-template>\r\n </header>\r\n </div>\r\n\r\n <ec-button *ngIf=\"isDialog && ( (status?.status === 'pending' && !hideCloseOnPending) || status?.status === 'error')\"\r\n id=\"pageViewDialogClose\"\r\n type=\"icon\"\r\n icon=\"icon-cancel\"\r\n (clicked)=\"closeDialog()\">\r\n </ec-button>\r\n</div>", styles: [":host{flex:1 1;min-height:0;display:flex}header{background-color:var(--ec-background-color-body);position:sticky;top:0;order:1;padding:1rem 1.5rem .5rem;flex:none;z-index:var(--ec-z-index-sticky-page-header)}ol{font-size:var(--ec-font-size-label);line-height:1rem;grid-column:1/3;grid-row:1/2;list-style:none;padding:0;margin:0 0 .25rem}ol li{display:inline}ol li:not(:last-child):after{content:\" / \";display:inline;color:var(--ec-color-secondary-dark)}div[ecOverlay]{position:relative}.titlebar{display:grid;grid-template-columns:auto max-content;grid-template-rows:max-content max-content;gap:0 1rem}.title{grid-column:1/2;grid-row:2/3;align-self:center}.actions{grid-column:2/3;grid-row:2/3;display:flex;flex-direction:row-reverse}ec-banner{margin-top:1rem}section{padding:var(--ec-page-view-padding-section, .5rem 1.5rem 2rem);order:2;flex:1 0 auto;min-height:0}:not(.is-dialog)>section{z-index:0}footer{background-color:var(--ec-background-color-body);order:3;padding:0 1.5rem;height:4.5rem;flex:none;display:flex;align-items:center}.is-dialog header{padding:0}.is-dialog .titlebar{background-color:var(--ec-background-color);padding:1rem}.is-dialog ec-banner{margin:0}.is-dialog section{padding:var(--ec-page-view-padding-section, 1rem 1rem 1.5rem)}.sticky-footer section{padding-bottom:4.5rem}.sticky-footer footer{position:sticky;bottom:0;z-index:var(--ec-z-index-sticky-page-header)}.fit-content>section{flex:1 1;display:flex}.footer-visible section{padding-bottom:0}.overlay-visible header{z-index:var(--ec-z-index-overlay)1}.overlay-visible ec-banner{display:none}:host(.bg-content) header{background-color:var(--ec-background-color)}:host(.bg-content) section{background-color:var(--ec-background-color)}:host(.bg-content) footer{background-color:var(--ec-background-color)}#pageViewDialogClose{position:absolute;top:1rem;right:1rem;z-index:calc(var(--ec-z-index-overlay) + 1)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1$1.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: ButtonComponent, selector: "ec-button", inputs: ["id", "disabled", "icon", "label", "badge", "tabindex", "type", "pending", "pendingIcon", "customTemplate", "isSubmit", "autofocus"], outputs: ["clicked"] }, { kind: "component", type: ViewOverlayComponent, selector: "[ecOverlay]", inputs: ["status", "message", "action", "noDataTemplate", "displayAsMask", "overlayClassList"] }, { kind: "component", type: BannerComponent, selector: "ec-banner", inputs: ["hidden", "id", "type", "bannerStyle", "title", "text", "list", "showCloseBtn", "autoHideOnClose", "customIcon", "rememberClosed"], outputs: ["closed"] }, { kind: "component", type: DropdownComponent, selector: "ec-dropdown", inputs: ["id", "autofocus", "status", "disabled", "label", "icon", "buttonType", "buttonAlignment", "buttonTitle", "tabindex", "showArrow", "items", "menuTemplateType", "menuTitle", "menuHeight", "menuWidth", "menuMinWidth", "menuPosition", "menuFooter", "popupFixed", "buttonCustomTemplate", "pending"], outputs: ["itemSelected", "popupOpened"] }, { kind: "component", type: PageTitleComponent, selector: "app-page-title", inputs: ["title", "titleIcon", "subTitle", "subTitleUrl"] }] });
|
8486
8490
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: PageViewComponent, decorators: [{
|
8487
8491
|
type: Component,
|
8488
8492
|
args: [{ selector: 'ec-page-view', host: {
|
8489
8493
|
class: "flex-grow"
|
8490
|
-
}, template: "<div ecOverlay\r\n [status]=\"status?.status\"\r\n [message]=\"status?.message\"\r\n [displayAsMask]=\"true\"\r\n class=\"flex-grow d-flex\"\r\n [ngClass]=\"{'bg-body': !bgContent, 'bg-content': bgContent}\">\r\n <div id=\"PageViewScrollContainer\"\r\n class=\"d-flex flex-column flex-grow scroll-y\"\r\n [class.is-dialog]=\"isDialog\"\r\n [class.fit-content]=\"fitContent\"\r\n [class.sticky-footer]=\"stickyFooter && !!footerTemplate\"\r\n [class.overlay-visible]=\"status?.status !== 'hasData'\"\r\n [class.footer-visible]=\"!!footerTemplate\">\r\n <section>\r\n <ng-content></ng-content>\r\n </section>\r\n\r\n <footer *ngIf=\"footerTemplate\">\r\n <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\r\n </footer>\r\n\r\n <header *ngIf=\"showHeader\">\r\n <ol id=\"breadcrumbs\"\r\n *ngIf=\"breadcrumbs?.length && !isDialog\">\r\n <li *ngFor=\"let crumb of breadcrumbs; last as isLast\">\r\n <a *ngIf=\"crumb.url; else label\"\r\n [routerLink]=\"crumb.url\">\r\n <ng-container *ngTemplateOutlet=\"label\"></ng-container>\r\n </a>\r\n <ng-template #label>{{crumb.label}}</ng-template>\r\n </li>\r\n </ol>\r\n\r\n <div class=\"titlebar\">\r\n <app-page-title *ngIf=\"!customTitleTemplate; else customTitle\"\r\n [title]=\"title\"\r\n [subTitle]=\"subTitle\"\r\n [subTitleUrl]=\"subTitleUrl\"\r\n [titleIcon]=\"titleIcon\"\r\n class=\"title text-truncate\">\r\n </app-page-title>\r\n\r\n <ng-template #customTitle>\r\n <div class=\"title\">\r\n <ng-container *ngTemplateOutlet=\"customTitleTemplate\"></ng-container>\r\n </div>\r\n </ng-template>\r\n\r\n <div class=\"actions\">\r\n <ec-button id=\"primaryAction\"\r\n class=\"ml-2\"\r\n *ngIf=\"!hidePrimaryAction && onPrimaryAction.observers?.length && !readonly\"\r\n [disabled]=\"status?.status === 'pending'\"\r\n type=\"primary\"\r\n [label]=\"primaryActionLabel\"\r\n (clicked)=\"primaryAction($event)\">\r\n </ec-button>\r\n <ec-button id=\"secondaryAction\"\r\n class=\"ml-2\"\r\n *ngIf=\"!hideSecondaryAction && onSecondaryAction.observers?.length\"\r\n type=\"secondary\"\r\n [label]=\"readonly ? 'Close' : secondaryActionLabel\"\r\n (clicked)=\"secondaryAction($event)\">\r\n </ec-button>\r\n <ec-dropdown id=\"moreActions\"\r\n *ngIf=\"moreActions?.length && !readonly\"\r\n [disabled]=\"status?.status === 'pending'\"\r\n class=\"ml-2\"\r\n buttonType=\"text\"\r\n [label]=\"moreActionsLabel\"\r\n [items]=\"moreActions\">\r\n </ec-dropdown>\r\n <ng-container *ngTemplateOutlet=\"customActionsTemplate\"></ng-container>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"customHeaderTemplate\"\r\n class=\"page-header\">\r\n <ng-container *ngTemplateOutlet=\"customHeaderTemplate\"></ng-container>\r\n </div>\r\n\r\n <ec-banner *ngIf=\"!customErrorBannerTemplate && errors; else customErrorBannerOutlet\"\r\n id=\"pageViewErrors\"\r\n [class.border-bottom-0]=\"!isDialog\">\r\n <div [innerHtml]=\"errors\"></div>\r\n </ec-banner>\r\n\r\n <ng-template #customErrorBannerOutlet>\r\n <ec-banner *ngIf=\"errors\"\r\n id=\"pageViewErrors\"\r\n [class.border-bottom-0]=\"!isDialog\">\r\n <ng-container *ngTemplateOutlet=\"customErrorBannerTemplate\"></ng-container>\r\n </ec-banner>\r\n </ng-template>\r\n </header>\r\n </div>\r\n\r\n <ec-button *ngIf=\"isDialog && ( (status?.status === 'pending' && !hideCloseOnPending) || status?.status === 'error')\"\r\n id=\"pageViewDialogClose\"\r\n type=\"icon\"\r\n icon=\"icon-cancel\"\r\n (clicked)=\"closeDialog()\">\r\n </ec-button>\r\n</div>", styles: [":host{flex:1 1;min-height:0;display:flex}header{background-color:var(--ec-background-color-body);position:sticky;top:0;order:1;padding:1rem 1.5rem .5rem;flex:none;z-index:var(--ec-z-index-sticky-page-header)}ol{font-size:var(--ec-font-size-label);line-height:1rem;grid-column:1/3;grid-row:1/2;list-style:none;padding:0;margin:0 0 .25rem}ol li{display:inline}ol li:not(:last-child):after{content:\" / \";display:inline;color:var(--ec-color-secondary-dark)}div[ecOverlay]{position:relative}.titlebar{display:grid;grid-template-columns:auto max-content;grid-template-rows:max-content max-content;gap:0 1rem}.title{grid-column:1/2;grid-row:2/3;align-self:center}.actions{grid-column:2/3;grid-row:2/3;display:flex;flex-direction:row-reverse}ec-banner{margin-top:1rem}section{padding:var(--ec-page-view-padding-section, .5rem 1.5rem 2rem);order:2;flex:1 0 auto;min-height:0}:not(.is-dialog)>section{z-index:0}footer{background-color:var(--ec-background-color-body);order:3;padding:0 1.5rem;height:4.5rem;flex:none;display:flex;align-items:center}.is-dialog header{padding:0}.is-dialog .titlebar{background-color:var(--ec-background-color);padding:1rem}.is-dialog ec-banner{margin:0}.is-dialog section{padding:var(--ec-page-view-padding-section, 1rem 1rem 1.5rem)}.sticky-footer section{padding-bottom:4.5rem}.sticky-footer footer{position:sticky;bottom:0;z-index:var(--ec-z-index-sticky-page-header)}.fit-content>section{flex:1 1;display:flex}.footer-visible section{padding-bottom:0}.overlay-visible header{z-index:var(--ec-z-index-overlay)1}.overlay-visible ec-banner{display:none}:host(.bg-content) header{background-color:var(--ec-background-color)}:host(.bg-content) section{background-color:var(--ec-background-color)}:host(.bg-content) footer{background-color:var(--ec-background-color)}#pageViewDialogClose{position:absolute;top:1rem;right:1rem;z-index:calc(var(--ec-z-index-overlay) + 1)}\n"] }]
|
8494
|
+
}, template: "<div ecOverlay\r\n [status]=\"status?.status\"\r\n [message]=\"status?.message\"\r\n [displayAsMask]=\"true\"\r\n class=\"flex-grow d-flex\"\r\n [ngClass]=\"{'bg-body': !bgContent, 'bg-content': bgContent}\">\r\n <div id=\"PageViewScrollContainer\"\r\n class=\"d-flex flex-column flex-grow scroll-y\"\r\n [class.is-dialog]=\"isDialog\"\r\n [class.fit-content]=\"fitContent\"\r\n [class.sticky-footer]=\"stickyFooter && !!footerTemplate\"\r\n [class.overlay-visible]=\"status?.status !== 'hasData'\"\r\n [class.footer-visible]=\"!!footerTemplate\">\r\n <section>\r\n <ng-content></ng-content>\r\n </section>\r\n\r\n <footer *ngIf=\"footerTemplate\">\r\n <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\r\n </footer>\r\n\r\n <header *ngIf=\"showHeader\">\r\n <ol id=\"breadcrumbs\"\r\n *ngIf=\"breadcrumbs?.length && !isDialog\">\r\n <li *ngFor=\"let crumb of breadcrumbs; last as isLast\">\r\n <a *ngIf=\"crumb.url; else label\"\r\n [routerLink]=\"crumb.url\">\r\n <ng-container *ngTemplateOutlet=\"label\"></ng-container>\r\n </a>\r\n <ng-template #label>{{crumb.label}}</ng-template>\r\n </li>\r\n </ol>\r\n\r\n <div class=\"titlebar\">\r\n <app-page-title *ngIf=\"!customTitleTemplate; else customTitle\"\r\n [title]=\"title\"\r\n [subTitle]=\"subTitle\"\r\n [subTitleUrl]=\"subTitleUrl\"\r\n [titleIcon]=\"titleIcon\"\r\n class=\"title text-truncate\">\r\n </app-page-title>\r\n\r\n <ng-template #customTitle>\r\n <div class=\"title\">\r\n <ng-container *ngTemplateOutlet=\"customTitleTemplate\"></ng-container>\r\n </div>\r\n </ng-template>\r\n\r\n <div class=\"actions\">\r\n <ec-button id=\"primaryAction\"\r\n class=\"ml-2\"\r\n *ngIf=\"!hidePrimaryAction && onPrimaryAction.observers?.length && !readonly\"\r\n [disabled]=\"status?.status === 'pending' || disablePrimaryAction\"\r\n type=\"primary\"\r\n [label]=\"primaryActionLabel\"\r\n (clicked)=\"primaryAction($event)\">\r\n </ec-button>\r\n <ec-button id=\"secondaryAction\"\r\n class=\"ml-2\"\r\n *ngIf=\"!hideSecondaryAction && onSecondaryAction.observers?.length\"\r\n type=\"secondary\"\r\n [label]=\"readonly ? 'Close' : secondaryActionLabel\"\r\n (clicked)=\"secondaryAction($event)\">\r\n </ec-button>\r\n <ec-dropdown id=\"moreActions\"\r\n *ngIf=\"moreActions?.length && !readonly\"\r\n [disabled]=\"status?.status === 'pending'\"\r\n class=\"ml-2\"\r\n buttonType=\"text\"\r\n [label]=\"moreActionsLabel\"\r\n [items]=\"moreActions\">\r\n </ec-dropdown>\r\n <ng-container *ngTemplateOutlet=\"customActionsTemplate\"></ng-container>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"customHeaderTemplate\"\r\n class=\"page-header\">\r\n <ng-container *ngTemplateOutlet=\"customHeaderTemplate\"></ng-container>\r\n </div>\r\n\r\n <ec-banner *ngIf=\"!customErrorBannerTemplate && errors; else customErrorBannerOutlet\"\r\n id=\"pageViewErrors\"\r\n [class.border-bottom-0]=\"!isDialog\">\r\n <div [innerHtml]=\"errors\"></div>\r\n </ec-banner>\r\n\r\n <ng-template #customErrorBannerOutlet>\r\n <ec-banner *ngIf=\"errors\"\r\n id=\"pageViewErrors\"\r\n [class.border-bottom-0]=\"!isDialog\">\r\n <ng-container *ngTemplateOutlet=\"customErrorBannerTemplate\"></ng-container>\r\n </ec-banner>\r\n </ng-template>\r\n </header>\r\n </div>\r\n\r\n <ec-button *ngIf=\"isDialog && ( (status?.status === 'pending' && !hideCloseOnPending) || status?.status === 'error')\"\r\n id=\"pageViewDialogClose\"\r\n type=\"icon\"\r\n icon=\"icon-cancel\"\r\n (clicked)=\"closeDialog()\">\r\n </ec-button>\r\n</div>", styles: [":host{flex:1 1;min-height:0;display:flex}header{background-color:var(--ec-background-color-body);position:sticky;top:0;order:1;padding:1rem 1.5rem .5rem;flex:none;z-index:var(--ec-z-index-sticky-page-header)}ol{font-size:var(--ec-font-size-label);line-height:1rem;grid-column:1/3;grid-row:1/2;list-style:none;padding:0;margin:0 0 .25rem}ol li{display:inline}ol li:not(:last-child):after{content:\" / \";display:inline;color:var(--ec-color-secondary-dark)}div[ecOverlay]{position:relative}.titlebar{display:grid;grid-template-columns:auto max-content;grid-template-rows:max-content max-content;gap:0 1rem}.title{grid-column:1/2;grid-row:2/3;align-self:center}.actions{grid-column:2/3;grid-row:2/3;display:flex;flex-direction:row-reverse}ec-banner{margin-top:1rem}section{padding:var(--ec-page-view-padding-section, .5rem 1.5rem 2rem);order:2;flex:1 0 auto;min-height:0}:not(.is-dialog)>section{z-index:0}footer{background-color:var(--ec-background-color-body);order:3;padding:0 1.5rem;height:4.5rem;flex:none;display:flex;align-items:center}.is-dialog header{padding:0}.is-dialog .titlebar{background-color:var(--ec-background-color);padding:1rem}.is-dialog ec-banner{margin:0}.is-dialog section{padding:var(--ec-page-view-padding-section, 1rem 1rem 1.5rem)}.sticky-footer section{padding-bottom:4.5rem}.sticky-footer footer{position:sticky;bottom:0;z-index:var(--ec-z-index-sticky-page-header)}.fit-content>section{flex:1 1;display:flex}.footer-visible section{padding-bottom:0}.overlay-visible header{z-index:var(--ec-z-index-overlay)1}.overlay-visible ec-banner{display:none}:host(.bg-content) header{background-color:var(--ec-background-color)}:host(.bg-content) section{background-color:var(--ec-background-color)}:host(.bg-content) footer{background-color:var(--ec-background-color)}#pageViewDialogClose{position:absolute;top:1rem;right:1rem;z-index:calc(var(--ec-z-index-overlay) + 1)}\n"] }]
|
8491
8495
|
}], ctorParameters: function () { return [{ type: DialogService }]; }, propDecorators: { isDialog: [{
|
8492
8496
|
type: Input
|
8493
8497
|
}], readonly: [{
|
@@ -8536,6 +8540,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
8536
8540
|
type: Input
|
8537
8541
|
}], fitContent: [{
|
8538
8542
|
type: Input
|
8543
|
+
}], disablePrimaryAction: [{
|
8544
|
+
type: Input
|
8539
8545
|
}], bgContent: [{
|
8540
8546
|
type: HostBinding,
|
8541
8547
|
args: ['class.bg-content']
|