@skyux/modals 10.44.0 → 10.44.2

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.
@@ -284,4 +284,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
284
284
  type: HostListener,
285
285
  args: ['document:keydown', ['$event']]
286
286
  }] } });
287
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/modal/modal.component.ts","../../../../../../../../libs/components/modals/src/lib/modules/modal/modal.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAEL,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,WAAW,EACX,YAAY,EACZ,KAAK,EAIL,SAAS,EACT,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,eAAe,EACf,qBAAqB,EACrB,eAAe,EACf,cAAc,EACd,WAAW,EACX,uBAAuB,EACvB,kCAAkC,EAClC,wBAAwB,GAEzB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAC5C,OAAO,EAAE,QAAQ,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAEzD,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,EAAE,wBAAwB,EAAE,MAAM,uCAAuC,CAAC;AAEjF,OAAO,EAAE,+BAA+B,EAAE,MAAM,mCAAmC,CAAC;AACpF,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAE9D,OAAO,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAC/D,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;AACnE,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;;;;;;;AAE3D,MAAM,iBAAiB,GAAG,QAAQ,CAAC;AAEnC;;;;GAIG;AAqBH,MAAM,OAAO,iBAAiB;IAI5B;;OAEG;IACH,IACW,UAAU,CAAC,KAAkC;QACtD,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IA8BD;;;OAGG;IACH,IACW,QAAQ,CAAC,KAAyB;QAC3C,IAAI,CAAC,iBAAiB,GAAG,KAAK,IAAI,iBAAiB,CAAC;IACtD,CAAC;IAWD;;;;OAIG;IACH,IACW,eAAe,CAAC,EAAsB;QAC/C,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;IAC9B,CAAC;IAED,IAAW,eAAe;QACxB,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IAED;;;;OAIG;IACH,IACW,cAAc,CAAC,EAAsB;QAC9C,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;IAC7B,CAAC;IAED,IAAW,cAAc;QACvB,OAAO,IAAI,CAAC,gBAAgB,CAAC;IAC/B,CAAC;IAyBD,cAAc,CAAuB;IAErC,iBAAiB,CAAqB;IACtC,gBAAgB,CAAqB;IAE5B,eAAe,CAA6B;IAC5C,iBAAiB,CAA2C;IAC5D,YAAY,CAAiC;IAC7C,YAAY,CAA0C;IACtD,MAAM,CAAsB;IAC5B,UAAU,CAAiC;IAC3C,YAAY,CAA+B;IAC3C,iBAAiB,CAAmC;IACpD,kBAAkB,CAExB;IACM,UAAU,CAA2B;IAE9C;;;;;OAKG;IACM,OAAO,CAEc;IACrB,SAAS,CAA+C;IAEjE;QAzFO,sBAAiB,GAAG,iBAAiB,CAAC;QAqCtC,aAAQ,GAAkB,IAAI,CAAC;QAO/B,eAAU,GAAG,IAAI,CAAC;QAIlB,iBAAY,GAA6B;YAC9C,YAAY,EAAE,MAAM;YACpB,SAAS,EAAE,MAAM;SAClB,CAAC;QAOQ,wBAAmB,GAAG,KAAK,CAAC;QAEtC,mBAAc,GAAG,IAAI,OAAO,EAAQ,CAAC;QAK5B,oBAAe,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAC5C,sBAAiB,GAAG,MAAM,CAAC,+BAA+B,CAAC,CAAC;QAC5D,iBAAY,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;QAC7C,iBAAY,GAAG,MAAM,CAAC,cAAc,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;QACtD,WAAM,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAC5B,eAAU,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;QAC3C,iBAAY,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;QAC3C,sBAAiB,GAAG,MAAM,CAAC,uBAAuB,CAAC,CAAC;QACpD,uBAAkB,GAAG,MAAM,CAAC,kCAAkC,EAAE;YACvE,QAAQ,EAAE,IAAI;SACf,CAAC,CAAC;QACM,eAAU,GAAG,MAAM,CAAC,eAAe,CAAC,CAAC;QAE9C;;;;;WAKG;QACM,YAAO,GACd,MAAM,CAAC,qBAAqB,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;YACjD,IAAI,qBAAqB,EAAE,CAAC;QACrB,cAAS,GAAG,MAAM,CAAC,eAAe,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QAG/D,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC;QACpD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC;QAClD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC;QACtC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC;QAC1C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC;QACxC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC;QAE9C,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ;YAC/B,CAAC,CAAC,WAAW;YACb,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,WAAW,EAAE,IAAI,QAAQ,CAAC;QAEjD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;IAC9C,CAAC;IAGM,eAAe,CAAC,KAAoB;QACzC,0BAA0B;QAC1B,kBAAkB;QAClB,IAAI,mBAAmB,CAAC,cAAc,GAAG,CAAC,EAAE,CAAC;YAC3C,MAAM,QAAQ,GAAG,mBAAmB,CAAC,QAAQ,CAAC;YAC9C,IAAI,QAAQ,IAAI,QAAQ,KAAK,IAAI,CAAC,YAAY,EAAE,CAAC;gBAC/C,IAAI,KAAK,CAAC,KAAK,KAAK,EAAE,EAAE,CAAC;oBACvB,gBAAgB;oBAChB,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBAC1B,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAGM,iBAAiB,CAAC,KAAoB;QAC3C,0BAA0B;QAC1B,kBAAkB;QAClB,IAAI,mBAAmB,CAAC,cAAc,GAAG,CAAC,EAAE,CAAC;YAC3C,MAAM,QAAQ,GAAG,mBAAmB,CAAC,QAAQ,CAAC;YAC9C,IAAI,QAAQ,IAAI,QAAQ,KAAK,IAAI,CAAC,YAAY,EAAE,CAAC;gBAC/C,IAAI,KAAK,CAAC,KAAK,KAAK,CAAC,EAAE,CAAC;oBACtB,cAAc;oBACd,IAAI,YAAY,GAAG,KAAK,CAAC;oBAEzB,MAAM,gBAAgB,GAAG,IAAI,CAAC,YAAY,CAAC,oBAAoB,CAC7D,IAAI,CAAC,MAAM,CAAC,aAAa,CAC1B,CAAC;oBAEF,IACE,KAAK,CAAC,QAAQ;wBACd,CAAC,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,CACxC,KAAK,EACL,gBAAgB,CACjB;4BACC,IAAI,CAAC,iBAAiB,CAAC,cAAc,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,EAC5D,CAAC;wBACD,YAAY;4BACV,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,CAAC;oBAC9D,CAAC;yBAAM,IACL,CAAC,KAAK,CAAC,QAAQ;wBACf,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,KAAK,EAAE,gBAAgB,CAAC,EACjE,CAAC;wBACD,YAAY;4BACV,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,CAAC;oBAC/D,CAAC;oBAED,IAAI,YAAY,EAAE,CAAC;wBACjB,KAAK,CAAC,cAAc,EAAE,CAAC;wBACvB,KAAK,CAAC,eAAe,EAAE,CAAC;oBAC1B,CAAC;gBACH,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAEM,QAAQ;QACb,IAAI,CAAC,iBAAiB,CAAC,uBAAuB;aAC3C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;aACpC,SAAS,CAAC,CAAC,OAAO,EAAE,EAAE;YACrB,IAAI,OAAO,EAAE,EAAE,EAAE,CAAC;gBAChB,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,EAAE,CAAC;gBAC3B,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;YACtC,CAAC;QACH,CAAC,CAAC,CAAC;QAEL,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,CAAC,SAAS,CAAC,cAAc;iBAC1B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;iBACpC,SAAS,CAAC,CAAC,aAAa,EAAE,EAAE;gBAC3B,IAAI,CAAC,mBAAmB;oBACtB,aAAa,CAAC,eAAe,CAAC,KAAK,KAAK,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC;YACpE,CAAC,CAAC,CAAC;QACP,CAAC;IACH,CAAC;IAEM,eAAe;QACpB,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAEvD,yEAAyE;QACzE,+CAA+C;QAC/C,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,UAAU,CAAC,GAAG,EAAE;YAC3C,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAClD,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC;YAC/B,QAAQ,EAAE,eAAe,CAAC,aAAa;YACvC,WAAW,EAAE,IAAI,CAAC,0BAA2B,CAAC,aAAa;YAC3D,MAAM,EAAE,CAAC;SACV,CAAC,CAAC;QAEH,0BAA0B;QAC1B,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC5B,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,IAAI,CAAC,0BAA2B,EAAE;gBAChE,uBAAuB,EAAE,IAAI;aAC9B,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAEM,WAAW;QAChB,0BAA0B;QAC1B,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC5B,IAAI,CAAC,kBAAkB,CAAC,SAAS,EAAE,CAAC;QACtC,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;QAC3B,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC;IACjC,CAAC;IAED;;OAEG;IACI,eAAe;QACpB,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACnD,CAAC;IACH,CAAC;IAEM,gBAAgB;QACrB,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;IAC9B,CAAC;IAEM,YAAY;QACjB,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACzD,CAAC;IAEM,kBAAkB,CAAC,IAA8B;QACtD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;IAC3B,CAAC;IAEM,iBAAiB;QACtB,OAAO,IAAI,CAAC,iBAAiB,CAAC,oCAAoC,CAChE,IAAI,CAAC,MAAM,CACZ,CAAC;IACJ,CAAC;+GAhSU,iBAAiB;mGAAjB,iBAAiB,ufAfjB;YACT,+BAA+B;YAC/B,qBAAqB;YACrB,cAAc;SACf,wIAmHyC,UAAU,6BC7KtD,swFAgGA,+3JDpCI,YAAY,qTACZ,mBAAmB,wPACnB,aAAa,mKACb,WAAW,6GACX,uBAAuB,6DACvB,wBAAwB,+HACxB,wBAAwB;;4FAGf,iBAAiB;kBApB7B,SAAS;iCACI,IAAI,YACN,WAAW,aAGV;wBACT,+BAA+B;wBAC/B,qBAAqB;wBACrB,cAAc;qBACf,WACQ;wBACP,YAAY;wBACZ,mBAAmB;wBACnB,aAAa;wBACb,WAAW;wBACX,uBAAuB;wBACvB,wBAAwB;wBACxB,wBAAwB;qBACzB;wDAIM,YAAY;sBADlB,WAAW;uBAAC,OAAO;gBAOT,UAAU;sBADpB,KAAK;gBASC,WAAW;sBADjB,KAAK;gBAQC,OAAO;sBADb,KAAK;gBASC,kBAAkB;sBADxB,KAAK;gBAQC,gBAAgB;sBADtB,KAAK;gBAQK,QAAQ;sBADlB,KAAK;gBAYC,SAAS;sBADf,KAAK;gBASK,eAAe;sBADzB,KAAK;gBAeK,cAAc;sBADxB,KAAK;gBA4BC,0BAA0B;sBADhC,SAAS;uBAAC,qBAAqB,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;gBAkD/C,eAAe;sBADrB,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC;gBAiBnC,iBAAiB;sBADvB,YAAY;uBAAC,kBAAkB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  TemplateRef,\n  ViewChild,\n  inject,\n} from '@angular/core';\nimport {\n  SkyAppWindowRef,\n  SkyCoreAdapterService,\n  SkyDockLocation,\n  SkyDockService,\n  SkyIdModule,\n  SkyLiveAnnouncerService,\n  SkyResizeObserverMediaQueryService,\n  SkyScrollShadowDirective,\n  SkyScrollShadowEventArgs,\n} from '@skyux/core';\nimport { SkyHelpInlineModule } from '@skyux/help-inline';\nimport { SkyIconModule } from '@skyux/icon';\nimport { SkyTheme, SkyThemeService } from '@skyux/theme';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyModalsResourcesModule } from '../shared/sky-modals-resources.module';\n\nimport { SkyModalComponentAdapterService } from './modal-component-adapter.service';\nimport { SkyModalConfiguration } from './modal-configuration';\nimport { SkyModalError } from './modal-error';\nimport { SkyModalErrorsService } from './modal-errors.service';\nimport { SkyModalHeaderComponent } from './modal-header.component';\nimport { SkyModalHostService } from './modal-host.service';\n\nconst ARIA_ROLE_DEFAULT = 'dialog';\n\n/**\n * Provides a common look-and-feel for modal content with options to display\n * a common modal header, specify body content, and display a common modal footer\n * and buttons.\n */\n@Component({\n  standalone: true,\n  selector: 'sky-modal',\n  templateUrl: './modal.component.html',\n  styleUrls: ['./modal.component.scss'],\n  providers: [\n    SkyModalComponentAdapterService,\n    SkyModalErrorsService,\n    SkyDockService,\n  ],\n  imports: [\n    CommonModule,\n    SkyHelpInlineModule,\n    SkyIconModule,\n    SkyIdModule,\n    SkyModalHeaderComponent,\n    SkyScrollShadowDirective,\n    SkyModalsResourcesModule,\n  ],\n})\nexport class SkyModalComponent implements AfterViewInit, OnDestroy, OnInit {\n  @HostBinding('class')\n  public wrapperClass: string | undefined;\n\n  /**\n   * A list of form-level errors to display to the user.\n   */\n  @Input()\n  public set formErrors(value: SkyModalError[] | undefined) {\n    this.#errorsSvc.updateErrors(value);\n  }\n\n  /**\n   * The text to display as the modal's heading.\n   */\n  @Input()\n  public headingText: string | undefined;\n\n  /**\n   * A help key that identifies the global help content to display. When specified, a [help inline](https://developer.blackbaud.com/skyux/components/help-inline) button is\n   * added to the modal header. Clicking the button invokes global help as configured by the application.\n   */\n  @Input()\n  public helpKey: string | undefined;\n\n  /**\n   * The content of the help popover. When specified, a [help inline](https://developer.blackbaud.com/skyux/components/help-inline)\n   * button is added to the modal header. The help inline button displays a [popover](https://developer.blackbaud.com/skyux/components/popover)\n   * when clicked using the specified content and optional title.\n   */\n  @Input()\n  public helpPopoverContent: string | TemplateRef<unknown> | undefined;\n\n  /**\n   * The title of the help popover. This property only applies when `helpPopoverContent` is\n   * also specified.\n   */\n  @Input()\n  public helpPopoverTitle: string | undefined;\n\n  /**\n   * Used by the confirm component to set a different role for the modal.\n   * @internal\n   */\n  @Input()\n  public set ariaRole(value: string | undefined) {\n    this.ariaRoleOrDefault = value || ARIA_ROLE_DEFAULT;\n  }\n\n  public ariaRoleOrDefault = ARIA_ROLE_DEFAULT;\n\n  /**\n   * @internal\n   * @deprecated\n   */\n  @Input()\n  public tiledBody: boolean | undefined;\n\n  /**\n   * Used by the confirm component to set descriptive text without using a\n   * modal header.\n   * @internal\n   */\n  @Input()\n  public set ariaDescribedBy(id: string | undefined) {\n    this.#_ariaDescribedBy = id;\n  }\n\n  public get ariaDescribedBy(): string | undefined {\n    return this.#_ariaDescribedBy;\n  }\n\n  /**\n   * Used by the confirm component to set descriptive text without using a\n   * modal header.\n   * @internal\n   */\n  @Input()\n  public set ariaLabelledBy(id: string | undefined) {\n    this.#_ariaLabelledBy = id;\n  }\n\n  public get ariaLabelledBy(): string | undefined {\n    return this.#_ariaLabelledBy;\n  }\n\n  public ariaOwns: string | null = null;\n\n  /**\n   * @deprecated\n   */\n  public legacyHelpKey: string | undefined;\n\n  public modalState = 'in';\n\n  public modalZIndex: number | undefined;\n\n  public scrollShadow: SkyScrollShadowEventArgs = {\n    bottomShadow: 'none',\n    topShadow: 'none',\n  };\n\n  public size: string;\n\n  @ViewChild('modalContentWrapper', { read: ElementRef })\n  public modalContentWrapperElement: ElementRef | undefined;\n\n  protected scrollShadowEnabled = false;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #_ariaDescribedBy: string | undefined;\n  #_ariaLabelledBy: string | undefined;\n\n  readonly #changeDetector = inject(ChangeDetectorRef);\n  readonly #componentAdapter = inject(SkyModalComponentAdapterService);\n  readonly #coreAdapter = inject(SkyCoreAdapterService);\n  readonly #dockService = inject(SkyDockService, { host: true });\n  readonly #elRef = inject(ElementRef);\n  readonly #errorsSvc = inject(SkyModalErrorsService);\n  readonly #hostService = inject(SkyModalHostService);\n  readonly #liveAnnouncerSvc = inject(SkyLiveAnnouncerService);\n  readonly #mediaQueryService = inject(SkyResizeObserverMediaQueryService, {\n    optional: true,\n  });\n  readonly #windowRef = inject(SkyAppWindowRef);\n\n  /**\n   * This provider is optional to account for situations where a modal component\n   * is implemented without the modal service. For example, when a consumer tests\n   * a component that uses the modal component but doesn't launch the modal from\n   * the modal service before executing assertions.\n   */\n  readonly #config =\n    inject(SkyModalConfiguration, { optional: true }) ??\n    new SkyModalConfiguration();\n  readonly #themeSvc = inject(SkyThemeService, { optional: true });\n\n  constructor() {\n    this.ariaDescribedBy = this.#config.ariaDescribedBy;\n    this.ariaLabelledBy = this.#config.ariaLabelledBy;\n    this.ariaRole = this.#config.ariaRole;\n    this.legacyHelpKey = this.#config.helpKey;\n    this.tiledBody = this.#config.tiledBody;\n    this.wrapperClass = this.#config.wrapperClass;\n\n    this.size = this.#config.fullPage\n      ? 'full-page'\n      : this.#config.size?.toLowerCase() || 'medium';\n\n    this.modalZIndex = this.#hostService.zIndex;\n  }\n\n  @HostListener('document:keyup', ['$event'])\n  public onDocumentKeyUp(event: KeyboardEvent): void {\n    /* istanbul ignore else */\n    /* sanity check */\n    if (SkyModalHostService.openModalCount > 0) {\n      const topModal = SkyModalHostService.topModal;\n      if (topModal && topModal === this.#hostService) {\n        if (event.which === 27) {\n          // Escape key up\n          event.preventDefault();\n          this.closeButtonClick();\n        }\n      }\n    }\n  }\n\n  @HostListener('document:keydown', ['$event'])\n  public onDocumentKeyDown(event: KeyboardEvent): void {\n    /* istanbul ignore else */\n    /* sanity check */\n    if (SkyModalHostService.openModalCount > 0) {\n      const topModal = SkyModalHostService.topModal;\n      if (topModal && topModal === this.#hostService) {\n        if (event.which === 9) {\n          // Tab pressed\n          let focusChanged = false;\n\n          const focusElementList = this.#coreAdapter.getFocusableChildren(\n            this.#elRef.nativeElement,\n          );\n\n          if (\n            event.shiftKey &&\n            (this.#componentAdapter.isFocusInFirstItem(\n              event,\n              focusElementList,\n            ) ||\n              this.#componentAdapter.isModalFocused(event, this.#elRef))\n          ) {\n            focusChanged =\n              this.#componentAdapter.focusLastElement(focusElementList);\n          } else if (\n            !event.shiftKey &&\n            this.#componentAdapter.isFocusInLastItem(event, focusElementList)\n          ) {\n            focusChanged =\n              this.#componentAdapter.focusFirstElement(focusElementList);\n          }\n\n          if (focusChanged) {\n            event.preventDefault();\n            event.stopPropagation();\n          }\n        }\n      }\n    }\n  }\n\n  public ngOnInit(): void {\n    this.#liveAnnouncerSvc.announcerElementChanged\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((element) => {\n        if (element?.id) {\n          this.ariaOwns = element.id;\n          this.#changeDetector.markForCheck();\n        }\n      });\n\n    if (this.#themeSvc) {\n      this.#themeSvc.settingsChange\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe((themeSettings) => {\n          this.scrollShadowEnabled =\n            themeSettings.currentSettings.theme === SkyTheme.presets.modern;\n        });\n    }\n  }\n\n  public ngAfterViewInit(): void {\n    this.#componentAdapter.handleWindowChange(this.#elRef);\n\n    // Adding a timeout to avoid ExpressionChangedAfterItHasBeenCheckedError.\n    // https://stackoverflow.com/questions/40562845\n    this.#windowRef.nativeWindow.setTimeout(() => {\n      this.#componentAdapter.modalOpened(this.#elRef);\n    });\n\n    this.#dockService.setDockOptions({\n      location: SkyDockLocation.ElementBottom,\n      referenceEl: this.modalContentWrapperElement!.nativeElement,\n      zIndex: 5,\n    });\n\n    /* istanbul ignore next */\n    if (this.#mediaQueryService) {\n      this.#mediaQueryService.observe(this.modalContentWrapperElement!, {\n        updateResponsiveClasses: true,\n      });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    /* istanbul ignore next */\n    if (this.#mediaQueryService) {\n      this.#mediaQueryService.unobserve();\n    }\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  /**\n   * @deprecated\n   */\n  public helpButtonClick(): void {\n    if (this.legacyHelpKey) {\n      this.#hostService.onOpenHelp(this.legacyHelpKey);\n    }\n  }\n\n  public closeButtonClick(): void {\n    this.#hostService.onClose();\n  }\n\n  public windowResize(): void {\n    this.#componentAdapter.handleWindowChange(this.#elRef);\n  }\n\n  public scrollShadowChange(args: SkyScrollShadowEventArgs): void {\n    this.scrollShadow = args;\n  }\n\n  public viewkeeperEnabled(): boolean {\n    return this.#componentAdapter.modalContentHasDirectChildViewkeeper(\n      this.#elRef,\n    );\n  }\n}\n","<div\n  class=\"sky-modal-dialog\"\n  aria-modal=\"true\"\n  [attr.aria-describedby]=\"ariaDescribedBy || modalContentId.id\"\n  [attr.aria-labelledby]=\"ariaLabelledBy || headerId.id\"\n  [attr.aria-owns]=\"ariaOwns\"\n  [attr.role]=\"ariaRoleOrDefault\"\n  (window:resize)=\"windowResize()\"\n>\n  <div\n    class=\"sky-modal sky-shadow sky-box sky-elevation-16 sky-modal-{{ size }}\"\n    tabindex=\"-1\"\n    [ngClass]=\"{\n      'sky-modal-tiled': tiledBody,\n      'sky-modal-viewkeeper': viewkeeperEnabled()\n    }\"\n    [ngStyle]=\"{\n      zIndex: modalZIndex\n    }\"\n  >\n    <div\n      class=\"sky-modal-header\"\n      [ngStyle]=\"{\n        'box-shadow': scrollShadow?.topShadow\n      }\"\n    >\n      <div\n        class=\"sky-modal-header-content\"\n        skyId\n        [ngClass]=\"{\n          'sky-font-heading-2': size === 'full-page'\n        }\"\n        #headerId=\"skyId\"\n      >\n        @if (headingText) {\n          <sky-modal-header>\n            {{ headingText }}\n            @if (helpKey || helpPopoverContent) {\n              <sky-help-inline\n                class=\"sky-control-help\"\n                [helpKey]=\"helpKey\"\n                [labelText]=\"headingText\"\n                [popoverContent]=\"helpPopoverContent\"\n                [popoverTitle]=\"helpPopoverTitle\"\n              />\n            }\n          </sky-modal-header>\n        } @else {\n          <ng-content select=\"sky-modal-header\" />\n        }\n      </div>\n      <div class=\"sky-modal-header-buttons\">\n        <button\n          *ngIf=\"legacyHelpKey\"\n          class=\"sky-btn sky-modal-btn-help\"\n          name=\"help-button\"\n          type=\"button\"\n          [attr.aria-label]=\"'skyux_modal_open_help' | skyLibResources\"\n          (click)=\"helpButtonClick()\"\n        >\n          <sky-icon icon=\"question-circle\" />\n        </button>\n\n        <button\n          type=\"button\"\n          class=\"sky-btn sky-modal-btn-close\"\n          [attr.aria-label]=\"'skyux_modal_close' | skyLibResources\"\n          (click)=\"closeButtonClick()\"\n        >\n          <sky-icon icon=\"close\" />\n        </button>\n      </div>\n    </div>\n    <div\n      class=\"sky-modal-content sky-padding-even-large\"\n      role=\"region\"\n      tabindex=\"0\"\n      skyId\n      [attr.aria-labelledby]=\"headerId.id\"\n      (skyScrollShadow)=\"scrollShadowChange($event)\"\n      [skyScrollShadowEnabled]=\"scrollShadowEnabled\"\n      #modalContentId=\"skyId\"\n      #modalContentWrapper\n    >\n      <ng-content select=\"sky-modal-content\" />\n    </div>\n    <div\n      class=\"sky-modal-footer\"\n      [ngStyle]=\"{\n        'box-shadow': scrollShadow?.bottomShadow\n      }\"\n    >\n      <ng-content select=\"sky-modal-footer\" />\n    </div>\n  </div>\n</div>\n"]}
287
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/modal/modal.component.ts","../../../../../../../../libs/components/modals/src/lib/modules/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  TemplateRef,\n  ViewChild,\n  inject,\n} from '@angular/core';\nimport {\n  SkyAppWindowRef,\n  SkyCoreAdapterService,\n  SkyDockLocation,\n  SkyDockService,\n  SkyIdModule,\n  SkyLiveAnnouncerService,\n  SkyResizeObserverMediaQueryService,\n  SkyScrollShadowDirective,\n  SkyScrollShadowEventArgs,\n} from '@skyux/core';\nimport { SkyHelpInlineModule } from '@skyux/help-inline';\nimport { SkyIconModule } from '@skyux/icon';\nimport { SkyTheme, SkyThemeService } from '@skyux/theme';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyModalsResourcesModule } from '../shared/sky-modals-resources.module';\n\nimport { SkyModalComponentAdapterService } from './modal-component-adapter.service';\nimport { SkyModalConfiguration } from './modal-configuration';\nimport { SkyModalError } from './modal-error';\nimport { SkyModalErrorsService } from './modal-errors.service';\nimport { SkyModalHeaderComponent } from './modal-header.component';\nimport { SkyModalHostService } from './modal-host.service';\n\nconst ARIA_ROLE_DEFAULT = 'dialog';\n\n/**\n * Provides a common look-and-feel for modal content with options to display\n * a common modal header, specify body content, and display a common modal footer\n * and buttons.\n */\n@Component({\n  standalone: true,\n  selector: 'sky-modal',\n  templateUrl: './modal.component.html',\n  styleUrls: ['./modal.component.scss'],\n  providers: [\n    SkyModalComponentAdapterService,\n    SkyModalErrorsService,\n    SkyDockService,\n  ],\n  imports: [\n    CommonModule,\n    SkyHelpInlineModule,\n    SkyIconModule,\n    SkyIdModule,\n    SkyModalHeaderComponent,\n    SkyScrollShadowDirective,\n    SkyModalsResourcesModule,\n  ],\n})\nexport class SkyModalComponent implements AfterViewInit, OnDestroy, OnInit {\n  @HostBinding('class')\n  public wrapperClass: string | undefined;\n\n  /**\n   * A list of form-level errors to display to the user.\n   */\n  @Input()\n  public set formErrors(value: SkyModalError[] | undefined) {\n    this.#errorsSvc.updateErrors(value);\n  }\n\n  /**\n   * The text to display as the modal's heading.\n   */\n  @Input()\n  public headingText: string | undefined;\n\n  /**\n   * A help key that identifies the global help content to display. When specified, a [help inline](https://developer.blackbaud.com/skyux/components/help-inline) button is\n   * added to the modal header. Clicking the button invokes global help as configured by the application. This property only applies when `headingText` is also specified.\n   */\n  @Input()\n  public helpKey: string | undefined;\n\n  /**\n   * The content of the help popover. When specified, a [help inline](https://developer.blackbaud.com/skyux/components/help-inline)\n   * button is added to the modal header. The help inline button displays a [popover](https://developer.blackbaud.com/skyux/components/popover)\n   * when clicked using the specified content and optional title. This property only applies when `headingText` is also specified.\n   */\n  @Input()\n  public helpPopoverContent: string | TemplateRef<unknown> | undefined;\n\n  /**\n   * The title of the help popover. This property only applies when `helpPopoverContent` is\n   * also specified.\n   */\n  @Input()\n  public helpPopoverTitle: string | undefined;\n\n  /**\n   * Used by the confirm component to set a different role for the modal.\n   * @internal\n   */\n  @Input()\n  public set ariaRole(value: string | undefined) {\n    this.ariaRoleOrDefault = value || ARIA_ROLE_DEFAULT;\n  }\n\n  public ariaRoleOrDefault = ARIA_ROLE_DEFAULT;\n\n  /**\n   * @internal\n   * @deprecated\n   */\n  @Input()\n  public tiledBody: boolean | undefined;\n\n  /**\n   * Used by the confirm component to set descriptive text without using a\n   * modal header.\n   * @internal\n   */\n  @Input()\n  public set ariaDescribedBy(id: string | undefined) {\n    this.#_ariaDescribedBy = id;\n  }\n\n  public get ariaDescribedBy(): string | undefined {\n    return this.#_ariaDescribedBy;\n  }\n\n  /**\n   * Used by the confirm component to set descriptive text without using a\n   * modal header.\n   * @internal\n   */\n  @Input()\n  public set ariaLabelledBy(id: string | undefined) {\n    this.#_ariaLabelledBy = id;\n  }\n\n  public get ariaLabelledBy(): string | undefined {\n    return this.#_ariaLabelledBy;\n  }\n\n  public ariaOwns: string | null = null;\n\n  /**\n   * @deprecated\n   */\n  public legacyHelpKey: string | undefined;\n\n  public modalState = 'in';\n\n  public modalZIndex: number | undefined;\n\n  public scrollShadow: SkyScrollShadowEventArgs = {\n    bottomShadow: 'none',\n    topShadow: 'none',\n  };\n\n  public size: string;\n\n  @ViewChild('modalContentWrapper', { read: ElementRef })\n  public modalContentWrapperElement: ElementRef | undefined;\n\n  protected scrollShadowEnabled = false;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #_ariaDescribedBy: string | undefined;\n  #_ariaLabelledBy: string | undefined;\n\n  readonly #changeDetector = inject(ChangeDetectorRef);\n  readonly #componentAdapter = inject(SkyModalComponentAdapterService);\n  readonly #coreAdapter = inject(SkyCoreAdapterService);\n  readonly #dockService = inject(SkyDockService, { host: true });\n  readonly #elRef = inject(ElementRef);\n  readonly #errorsSvc = inject(SkyModalErrorsService);\n  readonly #hostService = inject(SkyModalHostService);\n  readonly #liveAnnouncerSvc = inject(SkyLiveAnnouncerService);\n  readonly #mediaQueryService = inject(SkyResizeObserverMediaQueryService, {\n    optional: true,\n  });\n  readonly #windowRef = inject(SkyAppWindowRef);\n\n  /**\n   * This provider is optional to account for situations where a modal component\n   * is implemented without the modal service. For example, when a consumer tests\n   * a component that uses the modal component but doesn't launch the modal from\n   * the modal service before executing assertions.\n   */\n  readonly #config =\n    inject(SkyModalConfiguration, { optional: true }) ??\n    new SkyModalConfiguration();\n  readonly #themeSvc = inject(SkyThemeService, { optional: true });\n\n  constructor() {\n    this.ariaDescribedBy = this.#config.ariaDescribedBy;\n    this.ariaLabelledBy = this.#config.ariaLabelledBy;\n    this.ariaRole = this.#config.ariaRole;\n    this.legacyHelpKey = this.#config.helpKey;\n    this.tiledBody = this.#config.tiledBody;\n    this.wrapperClass = this.#config.wrapperClass;\n\n    this.size = this.#config.fullPage\n      ? 'full-page'\n      : this.#config.size?.toLowerCase() || 'medium';\n\n    this.modalZIndex = this.#hostService.zIndex;\n  }\n\n  @HostListener('document:keyup', ['$event'])\n  public onDocumentKeyUp(event: KeyboardEvent): void {\n    /* istanbul ignore else */\n    /* sanity check */\n    if (SkyModalHostService.openModalCount > 0) {\n      const topModal = SkyModalHostService.topModal;\n      if (topModal && topModal === this.#hostService) {\n        if (event.which === 27) {\n          // Escape key up\n          event.preventDefault();\n          this.closeButtonClick();\n        }\n      }\n    }\n  }\n\n  @HostListener('document:keydown', ['$event'])\n  public onDocumentKeyDown(event: KeyboardEvent): void {\n    /* istanbul ignore else */\n    /* sanity check */\n    if (SkyModalHostService.openModalCount > 0) {\n      const topModal = SkyModalHostService.topModal;\n      if (topModal && topModal === this.#hostService) {\n        if (event.which === 9) {\n          // Tab pressed\n          let focusChanged = false;\n\n          const focusElementList = this.#coreAdapter.getFocusableChildren(\n            this.#elRef.nativeElement,\n          );\n\n          if (\n            event.shiftKey &&\n            (this.#componentAdapter.isFocusInFirstItem(\n              event,\n              focusElementList,\n            ) ||\n              this.#componentAdapter.isModalFocused(event, this.#elRef))\n          ) {\n            focusChanged =\n              this.#componentAdapter.focusLastElement(focusElementList);\n          } else if (\n            !event.shiftKey &&\n            this.#componentAdapter.isFocusInLastItem(event, focusElementList)\n          ) {\n            focusChanged =\n              this.#componentAdapter.focusFirstElement(focusElementList);\n          }\n\n          if (focusChanged) {\n            event.preventDefault();\n            event.stopPropagation();\n          }\n        }\n      }\n    }\n  }\n\n  public ngOnInit(): void {\n    this.#liveAnnouncerSvc.announcerElementChanged\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((element) => {\n        if (element?.id) {\n          this.ariaOwns = element.id;\n          this.#changeDetector.markForCheck();\n        }\n      });\n\n    if (this.#themeSvc) {\n      this.#themeSvc.settingsChange\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe((themeSettings) => {\n          this.scrollShadowEnabled =\n            themeSettings.currentSettings.theme === SkyTheme.presets.modern;\n        });\n    }\n  }\n\n  public ngAfterViewInit(): void {\n    this.#componentAdapter.handleWindowChange(this.#elRef);\n\n    // Adding a timeout to avoid ExpressionChangedAfterItHasBeenCheckedError.\n    // https://stackoverflow.com/questions/40562845\n    this.#windowRef.nativeWindow.setTimeout(() => {\n      this.#componentAdapter.modalOpened(this.#elRef);\n    });\n\n    this.#dockService.setDockOptions({\n      location: SkyDockLocation.ElementBottom,\n      referenceEl: this.modalContentWrapperElement!.nativeElement,\n      zIndex: 5,\n    });\n\n    /* istanbul ignore next */\n    if (this.#mediaQueryService) {\n      this.#mediaQueryService.observe(this.modalContentWrapperElement!, {\n        updateResponsiveClasses: true,\n      });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    /* istanbul ignore next */\n    if (this.#mediaQueryService) {\n      this.#mediaQueryService.unobserve();\n    }\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  /**\n   * @deprecated\n   */\n  public helpButtonClick(): void {\n    if (this.legacyHelpKey) {\n      this.#hostService.onOpenHelp(this.legacyHelpKey);\n    }\n  }\n\n  public closeButtonClick(): void {\n    this.#hostService.onClose();\n  }\n\n  public windowResize(): void {\n    this.#componentAdapter.handleWindowChange(this.#elRef);\n  }\n\n  public scrollShadowChange(args: SkyScrollShadowEventArgs): void {\n    this.scrollShadow = args;\n  }\n\n  public viewkeeperEnabled(): boolean {\n    return this.#componentAdapter.modalContentHasDirectChildViewkeeper(\n      this.#elRef,\n    );\n  }\n}\n","<div\n  class=\"sky-modal-dialog\"\n  aria-modal=\"true\"\n  [attr.aria-describedby]=\"ariaDescribedBy || modalContentId.id\"\n  [attr.aria-labelledby]=\"ariaLabelledBy || headerId.id\"\n  [attr.aria-owns]=\"ariaOwns\"\n  [attr.role]=\"ariaRoleOrDefault\"\n  (window:resize)=\"windowResize()\"\n>\n  <div\n    class=\"sky-modal sky-shadow sky-box sky-elevation-16 sky-modal-{{ size }}\"\n    tabindex=\"-1\"\n    [ngClass]=\"{\n      'sky-modal-tiled': tiledBody,\n      'sky-modal-viewkeeper': viewkeeperEnabled()\n    }\"\n    [ngStyle]=\"{\n      zIndex: modalZIndex\n    }\"\n  >\n    <div\n      class=\"sky-modal-header\"\n      [ngStyle]=\"{\n        'box-shadow': scrollShadow?.topShadow\n      }\"\n    >\n      <div\n        class=\"sky-modal-header-content\"\n        skyId\n        [ngClass]=\"{\n          'sky-font-heading-2': size === 'full-page'\n        }\"\n        #headerId=\"skyId\"\n      >\n        @if (headingText) {\n          <sky-modal-header>\n            {{ headingText }}\n            @if (helpKey || helpPopoverContent) {\n              <sky-help-inline\n                class=\"sky-control-help\"\n                [helpKey]=\"helpKey\"\n                [labelText]=\"headingText\"\n                [popoverContent]=\"helpPopoverContent\"\n                [popoverTitle]=\"helpPopoverTitle\"\n              />\n            }\n          </sky-modal-header>\n        } @else {\n          <ng-content select=\"sky-modal-header\" />\n        }\n      </div>\n      <div class=\"sky-modal-header-buttons\">\n        <button\n          *ngIf=\"legacyHelpKey\"\n          class=\"sky-btn sky-modal-btn-help\"\n          name=\"help-button\"\n          type=\"button\"\n          [attr.aria-label]=\"'skyux_modal_open_help' | skyLibResources\"\n          (click)=\"helpButtonClick()\"\n        >\n          <sky-icon icon=\"question-circle\" />\n        </button>\n\n        <button\n          type=\"button\"\n          class=\"sky-btn sky-modal-btn-close\"\n          [attr.aria-label]=\"'skyux_modal_close' | skyLibResources\"\n          (click)=\"closeButtonClick()\"\n        >\n          <sky-icon icon=\"close\" />\n        </button>\n      </div>\n    </div>\n    <div\n      class=\"sky-modal-content sky-padding-even-large\"\n      role=\"region\"\n      tabindex=\"0\"\n      skyId\n      [attr.aria-labelledby]=\"headerId.id\"\n      (skyScrollShadow)=\"scrollShadowChange($event)\"\n      [skyScrollShadowEnabled]=\"scrollShadowEnabled\"\n      #modalContentId=\"skyId\"\n      #modalContentWrapper\n    >\n      <ng-content select=\"sky-modal-content\" />\n    </div>\n    <div\n      class=\"sky-modal-footer\"\n      [ngStyle]=\"{\n        'box-shadow': scrollShadow?.bottomShadow\n      }\"\n    >\n      <ng-content select=\"sky-modal-footer\" />\n    </div>\n  </div>\n</div>\n"]}