@skyux/core 9.0.0-alpha.7 → 9.0.0-alpha.9
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/documentation.json +1139 -1056
- package/esm2022/index.mjs +3 -3
- package/esm2022/lib/modules/dock/dock.component.mjs +16 -23
- package/esm2022/lib/modules/dock/dock.module.mjs +7 -11
- package/esm2022/lib/modules/dock/dock.service.mjs +3 -3
- package/esm2022/lib/modules/dynamic-component/dynamic-component.service.mjs +18 -3
- package/esm2022/lib/modules/numeric/numeric.service.mjs +3 -3
- package/esm2022/lib/modules/overlay/overlay-config.mjs +1 -1
- package/esm2022/lib/modules/overlay/overlay.component.mjs +39 -40
- package/esm2022/lib/modules/overlay/overlay.module.mjs +7 -9
- package/esm2022/lib/modules/overlay/overlay.service.mjs +27 -5
- package/esm2022/lib/modules/shared/sky-core-resources.module.mjs +4 -2
- package/fesm2022/skyux-core.mjs +314 -285
- package/fesm2022/skyux-core.mjs.map +1 -1
- package/index.d.ts +2 -2
- package/lib/modules/dock/dock.component.d.ts +2 -4
- package/lib/modules/dock/dock.module.d.ts +4 -3
- package/lib/modules/dynamic-component/dynamic-component.service.d.ts +9 -0
- package/lib/modules/overlay/overlay-config.d.ts +5 -0
- package/lib/modules/overlay/overlay.component.d.ts +4 -8
- package/lib/modules/overlay/overlay.module.d.ts +4 -3
- package/lib/modules/overlay/overlay.service.d.ts +12 -0
- package/package.json +2 -2
@@ -1,14 +1,14 @@
|
|
1
|
-
import {
|
2
|
-
import {
|
1
|
+
import { CommonModule } from '@angular/common';
|
2
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EnvironmentInjector, HostBinding, ViewChild, ViewContainerRef, createEnvironmentInjector, inject, } from '@angular/core';
|
3
|
+
import { NavigationStart, Router } from '@angular/router';
|
3
4
|
import { BehaviorSubject, ReplaySubject, Subject, fromEvent, } from 'rxjs';
|
4
5
|
import { takeUntil } from 'rxjs/operators';
|
6
|
+
import { SkyCoreAdapterService } from '../adapter-service/adapter.service';
|
7
|
+
import { SkyIdService } from '../id/id.service';
|
5
8
|
import { SKY_STACKING_CONTEXT } from '../stacking-context/stacking-context-token';
|
9
|
+
import { SkyOverlayContext } from './overlay-context';
|
6
10
|
import * as i0 from "@angular/core";
|
7
|
-
import * as i1 from "
|
8
|
-
import * as i2 from "./overlay-context";
|
9
|
-
import * as i3 from "../id/id.service";
|
10
|
-
import * as i4 from "@angular/router";
|
11
|
-
import * as i5 from "@angular/common";
|
11
|
+
import * as i1 from "@angular/common";
|
12
12
|
const POSITION_DEFAULT = 'fixed';
|
13
13
|
/**
|
14
14
|
* Omnibar is 1000.
|
@@ -36,16 +36,17 @@ export class SkyOverlayComponent {
|
|
36
36
|
}
|
37
37
|
#backdropClick;
|
38
38
|
#backdropClickObs;
|
39
|
-
#changeDetector;
|
40
39
|
#closed;
|
41
40
|
#closedObs;
|
41
|
+
#ngUnsubscribe;
|
42
|
+
#routerSubscription;
|
43
|
+
#changeDetector;
|
42
44
|
#context;
|
43
45
|
#coreAdapter;
|
44
|
-
#
|
45
|
-
#
|
46
|
+
#environmentInjector;
|
47
|
+
#idSvc;
|
46
48
|
#router;
|
47
|
-
|
48
|
-
constructor(changeDetector, injector, coreAdapter, context, idSvc, router) {
|
49
|
+
constructor() {
|
49
50
|
this.wrapperClass = '';
|
50
51
|
this.enablePointerEvents = false;
|
51
52
|
this.showBackdrop = false;
|
@@ -53,12 +54,13 @@ export class SkyOverlayComponent {
|
|
53
54
|
this.clipPath$ = new ReplaySubject(1);
|
54
55
|
this.position = POSITION_DEFAULT;
|
55
56
|
this.#ngUnsubscribe = new Subject();
|
56
|
-
this.#changeDetector =
|
57
|
-
this.#
|
58
|
-
this.#coreAdapter =
|
59
|
-
this.#
|
60
|
-
this.#
|
61
|
-
this
|
57
|
+
this.#changeDetector = inject(ChangeDetectorRef);
|
58
|
+
this.#context = inject(SkyOverlayContext);
|
59
|
+
this.#coreAdapter = inject(SkyCoreAdapterService);
|
60
|
+
this.#environmentInjector = inject(EnvironmentInjector);
|
61
|
+
this.#idSvc = inject(SkyIdService);
|
62
|
+
this.#router = inject(Router, { optional: true });
|
63
|
+
this.id = this.#idSvc.generateId();
|
62
64
|
this.#backdropClick = new Subject();
|
63
65
|
this.#closed = new Subject();
|
64
66
|
this.#backdropClickObs = this.#backdropClick.asObservable();
|
@@ -87,22 +89,19 @@ export class SkyOverlayComponent {
|
|
87
89
|
throw new Error('[SkyOverlayComponent] Could not attach the component because the target element could not be found.');
|
88
90
|
}
|
89
91
|
this.targetRef.clear();
|
90
|
-
const
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
.pipe(takeUntil(this.#ngUnsubscribe)),
|
98
|
-
},
|
92
|
+
const environmentInjector = createEnvironmentInjector([
|
93
|
+
{
|
94
|
+
provide: SKY_STACKING_CONTEXT,
|
95
|
+
useValue: {
|
96
|
+
zIndex: new BehaviorSubject(parseInt(this.zIndex, 10))
|
97
|
+
.asObservable()
|
98
|
+
.pipe(takeUntil(this.#ngUnsubscribe)),
|
99
99
|
},
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
});
|
100
|
+
},
|
101
|
+
...providers,
|
102
|
+
], this.#environmentInjector);
|
104
103
|
const componentRef = this.targetRef.createComponent(component, {
|
105
|
-
|
104
|
+
environmentInjector,
|
106
105
|
});
|
107
106
|
// Run an initial change detection cycle after the component has been created.
|
108
107
|
componentRef.changeDetectorRef.detectChanges();
|
@@ -114,7 +113,9 @@ export class SkyOverlayComponent {
|
|
114
113
|
throw new Error('[SkyOverlayComponent] Could not attach the template because the target element could not be found.');
|
115
114
|
}
|
116
115
|
this.targetRef.clear();
|
117
|
-
return this.targetRef.createEmbeddedView(templateRef, context
|
116
|
+
return this.targetRef.createEmbeddedView(templateRef, context, {
|
117
|
+
injector: this.#environmentInjector,
|
118
|
+
});
|
118
119
|
}
|
119
120
|
updateClipPath(clipPath) {
|
120
121
|
this.clipPath$.next(clipPath);
|
@@ -160,15 +161,13 @@ export class SkyOverlayComponent {
|
|
160
161
|
this.#routerSubscription = undefined;
|
161
162
|
}
|
162
163
|
}
|
163
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyOverlayComponent, deps: [
|
164
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.1", type: SkyOverlayComponent, selector: "sky-overlay", host: { properties: { "id": "this.id" } }, viewQueries: [{ propertyName: "overlayContentRef", first: true, predicate: ["overlayContentRef"], descendants: true, read: ElementRef, static: true }, { propertyName: "overlayRef", first: true, predicate: ["overlayRef"], descendants: true, read: ElementRef, static: true }, { propertyName: "targetRef", first: true, predicate: ["target"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: "<div\n [class]=\"'sky-overlay-position-' + position + ' ' + wrapperClass\"\n [style.z-index]=\"zIndex\"\n [style.clip-path]=\"clipPath$ | async\"\n [ngClass]=\"{\n 'enable-pointer-events-pass-through': enablePointerEvents,\n 'sky-overlay': true\n }\"\n #overlayRef\n>\n <div class=\"sky-overlay-content\" #overlayContentRef>\n <ng-template #target> </ng-template>\n </div>\n <div *ngIf=\"showBackdrop\" class=\"sky-overlay-backdrop\"></div>\n</div>\n", styles: [".sky-overlay{inset:0;width:100%;height:100%;display:flex;pointer-events:auto}.sky-overlay-position-absolute{position:absolute}.sky-overlay-position-fixed{position:fixed}.sky-overlay-content{position:relative;z-index:1;display:inline-flex;align-self:start;pointer-events:auto}.sky-overlay-backdrop{background:rgba(0,0,0,.5);inset:0;width:100%;height:100%;position:absolute}.enable-pointer-events-pass-through,.enable-pointer-events-pass-through .sky-overlay-backdrop{pointer-events:none}.enable-pointer-events-pass-through .sky-overlay-content{pointer-events:auto}\n"], dependencies: [{ kind: "directive", type:
|
164
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyOverlayComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
165
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.1", type: SkyOverlayComponent, isStandalone: true, selector: "sky-overlay", host: { properties: { "id": "this.id" } }, viewQueries: [{ propertyName: "overlayContentRef", first: true, predicate: ["overlayContentRef"], descendants: true, read: ElementRef, static: true }, { propertyName: "overlayRef", first: true, predicate: ["overlayRef"], descendants: true, read: ElementRef, static: true }, { propertyName: "targetRef", first: true, predicate: ["target"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: "<div\n [class]=\"'sky-overlay-position-' + position + ' ' + wrapperClass\"\n [style.z-index]=\"zIndex\"\n [style.clip-path]=\"clipPath$ | async\"\n [ngClass]=\"{\n 'enable-pointer-events-pass-through': enablePointerEvents,\n 'sky-overlay': true\n }\"\n #overlayRef\n>\n <div class=\"sky-overlay-content\" #overlayContentRef>\n <ng-template #target> </ng-template>\n </div>\n <div *ngIf=\"showBackdrop\" class=\"sky-overlay-backdrop\"></div>\n</div>\n", styles: [".sky-overlay{inset:0;width:100%;height:100%;display:flex;pointer-events:auto}.sky-overlay-position-absolute{position:absolute}.sky-overlay-position-fixed{position:fixed}.sky-overlay-content{position:relative;z-index:1;display:inline-flex;align-self:start;pointer-events:auto}.sky-overlay-backdrop{background:rgba(0,0,0,.5);inset:0;width:100%;height:100%;position:absolute}.enable-pointer-events-pass-through,.enable-pointer-events-pass-through .sky-overlay-backdrop{pointer-events:none}.enable-pointer-events-pass-through .sky-overlay-content{pointer-events:auto}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
165
166
|
}
|
166
167
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyOverlayComponent, decorators: [{
|
167
168
|
type: Component,
|
168
|
-
args: [{ selector: 'sky-overlay', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n [class]=\"'sky-overlay-position-' + position + ' ' + wrapperClass\"\n [style.z-index]=\"zIndex\"\n [style.clip-path]=\"clipPath$ | async\"\n [ngClass]=\"{\n 'enable-pointer-events-pass-through': enablePointerEvents,\n 'sky-overlay': true\n }\"\n #overlayRef\n>\n <div class=\"sky-overlay-content\" #overlayContentRef>\n <ng-template #target> </ng-template>\n </div>\n <div *ngIf=\"showBackdrop\" class=\"sky-overlay-backdrop\"></div>\n</div>\n", styles: [".sky-overlay{inset:0;width:100%;height:100%;display:flex;pointer-events:auto}.sky-overlay-position-absolute{position:absolute}.sky-overlay-position-fixed{position:fixed}.sky-overlay-content{position:relative;z-index:1;display:inline-flex;align-self:start;pointer-events:auto}.sky-overlay-backdrop{background:rgba(0,0,0,.5);inset:0;width:100%;height:100%;position:absolute}.enable-pointer-events-pass-through,.enable-pointer-events-pass-through .sky-overlay-backdrop{pointer-events:none}.enable-pointer-events-pass-through .sky-overlay-content{pointer-events:auto}\n"] }]
|
169
|
-
}], ctorParameters: function () { return [
|
170
|
-
type: Optional
|
171
|
-
}] }]; }, propDecorators: { id: [{
|
169
|
+
args: [{ standalone: true, selector: 'sky-overlay', changeDetection: ChangeDetectionStrategy.OnPush, imports: [CommonModule], template: "<div\n [class]=\"'sky-overlay-position-' + position + ' ' + wrapperClass\"\n [style.z-index]=\"zIndex\"\n [style.clip-path]=\"clipPath$ | async\"\n [ngClass]=\"{\n 'enable-pointer-events-pass-through': enablePointerEvents,\n 'sky-overlay': true\n }\"\n #overlayRef\n>\n <div class=\"sky-overlay-content\" #overlayContentRef>\n <ng-template #target> </ng-template>\n </div>\n <div *ngIf=\"showBackdrop\" class=\"sky-overlay-backdrop\"></div>\n</div>\n", styles: [".sky-overlay{inset:0;width:100%;height:100%;display:flex;pointer-events:auto}.sky-overlay-position-absolute{position:absolute}.sky-overlay-position-fixed{position:fixed}.sky-overlay-content{position:relative;z-index:1;display:inline-flex;align-self:start;pointer-events:auto}.sky-overlay-backdrop{background:rgba(0,0,0,.5);inset:0;width:100%;height:100%;position:absolute}.enable-pointer-events-pass-through,.enable-pointer-events-pass-through .sky-overlay-backdrop{pointer-events:none}.enable-pointer-events-pass-through .sky-overlay-content{pointer-events:auto}\n"] }]
|
170
|
+
}], ctorParameters: function () { return []; }, propDecorators: { id: [{
|
172
171
|
type: HostBinding,
|
173
172
|
args: ['id']
|
174
173
|
}], overlayContentRef: [{
|
@@ -190,4 +189,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImpor
|
|
190
189
|
static: true,
|
191
190
|
}]
|
192
191
|
}] } });
|
193
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/overlay/overlay.component.ts","../../../../../../../../libs/components/core/src/lib/modules/overlay/overlay.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ComponentRef,\n  ElementRef,\n  EmbeddedViewRef,\n  HostBinding,\n  Injector,\n  OnDestroy,\n  OnInit,\n  Optional,\n  StaticProvider,\n  TemplateRef,\n  Type,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport { NavigationStart, Router } from '@angular/router';\n\nimport {\n  BehaviorSubject,\n  Observable,\n  ReplaySubject,\n  Subject,\n  Subscription,\n  fromEvent,\n} from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyCoreAdapterService } from '../adapter-service/adapter.service';\nimport { SkyIdService } from '../id/id.service';\nimport { SKY_STACKING_CONTEXT } from '../stacking-context/stacking-context-token';\n\nimport { SkyOverlayConfig } from './overlay-config';\nimport { SkyOverlayContext } from './overlay-context';\nimport { SkyOverlayPosition } from './overlay-position';\n\nconst POSITION_DEFAULT: SkyOverlayPosition = 'fixed';\n\n/**\n * Omnibar is 1000.\n * See: https://github.com/blackbaud/auth-client/blob/master/src/omnibar/omnibar.ts#L139\n * ---\n * Modals start their z-indexes at 1040. However, each modal's z-index is a multiple of 10, so it\n * will be difficult to reliably predict a z-index that will always appear above all other\n * layers. Starting the z-index for overlays at a number much greater than modals will accommodate\n * the most reasonable of scenarios.\n * See: https://github.com/blackbaud/skyux-modals/blob/master/src/app/public/modules/modal/modal-host.service.ts#L22\n * (NOTE: It should be noted that modals do not use the overlay service, which is something we\n * should do in the near future to make sure z-indexes are predictable across all component\n * libraries.)\n */\nlet uniqueZIndex = 5000;\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-overlay',\n  templateUrl: './overlay.component.html',\n  styleUrls: ['./overlay.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyOverlayComponent implements OnInit, OnDestroy {\n  public wrapperClass = '';\n\n  public get backdropClick(): Observable<void> {\n    return this.#backdropClickObs;\n  }\n\n  public get closed(): Observable<void> {\n    return this.#closedObs;\n  }\n\n  public enablePointerEvents = false;\n\n  @HostBinding('id')\n  public id: string;\n\n  public showBackdrop = false;\n\n  public zIndex = `${++uniqueZIndex}`;\n\n  protected clipPath$ = new ReplaySubject<string | undefined>(1);\n\n  protected position = POSITION_DEFAULT;\n\n  @ViewChild('overlayContentRef', {\n    read: ElementRef,\n    static: true,\n  })\n  public overlayContentRef: ElementRef | undefined;\n\n  @ViewChild('overlayRef', {\n    read: ElementRef,\n    static: true,\n  })\n  public overlayRef: ElementRef | undefined;\n\n  @ViewChild('target', {\n    read: ViewContainerRef,\n    static: true,\n  })\n  public targetRef: ViewContainerRef | undefined;\n\n  #backdropClick: Subject<void>;\n\n  #backdropClickObs: Observable<void>;\n\n  #changeDetector: ChangeDetectorRef;\n\n  #closed: Subject<void>;\n\n  #closedObs: Observable<void>;\n\n  #context: SkyOverlayContext;\n\n  #coreAdapter: SkyCoreAdapterService;\n\n  #injector: Injector;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #router: Router | undefined;\n\n  #routerSubscription: Subscription | undefined;\n\n  constructor(\n    changeDetector: ChangeDetectorRef,\n    injector: Injector,\n    coreAdapter: SkyCoreAdapterService,\n    context: SkyOverlayContext,\n    idSvc: SkyIdService,\n    @Optional() router?: Router\n  ) {\n    this.#changeDetector = changeDetector;\n    this.#injector = injector;\n    this.#coreAdapter = coreAdapter;\n    this.#context = context;\n    this.#router = router;\n\n    this.id = idSvc.generateId();\n\n    this.#backdropClick = new Subject<void>();\n    this.#closed = new Subject<void>();\n\n    this.#backdropClickObs = this.#backdropClick.asObservable();\n    this.#closedObs = this.#closed.asObservable();\n  }\n\n  public ngOnInit(): void {\n    this.#applyConfig(this.#context.config);\n\n    setTimeout(() => {\n      this.#addBackdropClickListener();\n    });\n\n    if (this.#context.config.closeOnNavigation) {\n      this.#addRouteListener();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.#removeRouteListener();\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n\n    this.#backdropClick.complete();\n\n    this.#closed.next();\n    this.#closed.complete();\n  }\n\n  public attachComponent<C>(\n    component: Type<C>,\n    providers: StaticProvider[] = []\n  ): ComponentRef<C> {\n    /*istanbul ignore if: untestable*/\n    if (!this.targetRef) {\n      throw new Error(\n        '[SkyOverlayComponent] Could not attach the component because the target element could not be found.'\n      );\n    }\n\n    this.targetRef.clear();\n\n    const injector = Injector.create({\n      providers: [\n        {\n          provide: SKY_STACKING_CONTEXT,\n          useValue: {\n            zIndex: new BehaviorSubject(parseInt(this.zIndex, 10))\n              .asObservable()\n              .pipe(takeUntil(this.#ngUnsubscribe)),\n          },\n        },\n        ...providers,\n      ],\n      parent: this.#injector,\n    });\n\n    const componentRef = this.targetRef.createComponent<C>(component, {\n      injector,\n    });\n\n    // Run an initial change detection cycle after the component has been created.\n    componentRef.changeDetectorRef.detectChanges();\n\n    return componentRef;\n  }\n\n  public attachTemplate<T>(\n    templateRef: TemplateRef<T>,\n    context: T\n  ): EmbeddedViewRef<T> {\n    /*istanbul ignore if: untestable*/\n    if (!this.targetRef) {\n      throw new Error(\n        '[SkyOverlayComponent] Could not attach the template because the target element could not be found.'\n      );\n    }\n\n    this.targetRef.clear();\n\n    return this.targetRef.createEmbeddedView(templateRef, context);\n  }\n\n  public updateClipPath(clipPath: string | undefined): void {\n    this.clipPath$.next(clipPath);\n  }\n\n  #applyConfig(config: SkyOverlayConfig): void {\n    this.wrapperClass = config.wrapperClass || '';\n    this.showBackdrop = !!config.showBackdrop;\n    this.enablePointerEvents = !!config.enablePointerEvents;\n    this.position = config.position || POSITION_DEFAULT;\n    this.#changeDetector.markForCheck();\n  }\n\n  #addBackdropClickListener(): void {\n    fromEvent<MouseEvent>(window.document, 'click')\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((event) => {\n        if (event.target && this.overlayContentRef && this.overlayRef) {\n          const isChild = this.overlayContentRef.nativeElement.contains(\n            event.target\n          );\n\n          const isAbove = this.#coreAdapter.isTargetAboveElement(\n            event.target,\n            this.overlayRef.nativeElement\n          );\n\n          /* istanbul ignore else */\n          if (!isChild && !isAbove) {\n            this.#backdropClick.next();\n            if (this.#context.config.enableClose) {\n              this.#closed.next();\n            }\n          }\n        }\n      });\n  }\n\n  #addRouteListener(): void {\n    /*istanbul ignore else*/\n    if (this.#router) {\n      this.#routerSubscription = this.#router.events.subscribe((event) => {\n        /* istanbul ignore else */\n        if (event instanceof NavigationStart) {\n          this.#closed.next();\n        }\n      });\n    }\n  }\n\n  #removeRouteListener(): void {\n    if (this.#routerSubscription) {\n      this.#routerSubscription.unsubscribe();\n      this.#routerSubscription = undefined;\n    }\n  }\n}\n","<div\n  [class]=\"'sky-overlay-position-' + position + ' ' + wrapperClass\"\n  [style.z-index]=\"zIndex\"\n  [style.clip-path]=\"clipPath$ | async\"\n  [ngClass]=\"{\n    'enable-pointer-events-pass-through': enablePointerEvents,\n    'sky-overlay': true\n  }\"\n  #overlayRef\n>\n  <div class=\"sky-overlay-content\" #overlayContentRef>\n    <ng-template #target> </ng-template>\n  </div>\n  <div *ngIf=\"showBackdrop\" class=\"sky-overlay-backdrop\"></div>\n</div>\n"]}
|
192
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/overlay/overlay.component.ts","../../../../../../../../libs/components/core/src/lib/modules/overlay/overlay.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ComponentRef,\n  ElementRef,\n  EmbeddedViewRef,\n  EnvironmentInjector,\n  HostBinding,\n  OnDestroy,\n  OnInit,\n  StaticProvider,\n  TemplateRef,\n  Type,\n  ViewChild,\n  ViewContainerRef,\n  createEnvironmentInjector,\n  inject,\n} from '@angular/core';\nimport { NavigationStart, Router } from '@angular/router';\n\nimport {\n  BehaviorSubject,\n  Observable,\n  ReplaySubject,\n  Subject,\n  Subscription,\n  fromEvent,\n} from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyCoreAdapterService } from '../adapter-service/adapter.service';\nimport { SkyIdService } from '../id/id.service';\nimport { SKY_STACKING_CONTEXT } from '../stacking-context/stacking-context-token';\n\nimport { SkyOverlayConfig } from './overlay-config';\nimport { SkyOverlayContext } from './overlay-context';\nimport { SkyOverlayPosition } from './overlay-position';\n\nconst POSITION_DEFAULT: SkyOverlayPosition = 'fixed';\n\n/**\n * Omnibar is 1000.\n * See: https://github.com/blackbaud/auth-client/blob/master/src/omnibar/omnibar.ts#L139\n * ---\n * Modals start their z-indexes at 1040. However, each modal's z-index is a multiple of 10, so it\n * will be difficult to reliably predict a z-index that will always appear above all other\n * layers. Starting the z-index for overlays at a number much greater than modals will accommodate\n * the most reasonable of scenarios.\n * See: https://github.com/blackbaud/skyux-modals/blob/master/src/app/public/modules/modal/modal-host.service.ts#L22\n * (NOTE: It should be noted that modals do not use the overlay service, which is something we\n * should do in the near future to make sure z-indexes are predictable across all component\n * libraries.)\n */\nlet uniqueZIndex = 5000;\n\n/**\n * @internal\n */\n@Component({\n  standalone: true,\n  selector: 'sky-overlay',\n  templateUrl: './overlay.component.html',\n  styleUrls: ['./overlay.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [CommonModule],\n})\nexport class SkyOverlayComponent implements OnInit, OnDestroy {\n  public wrapperClass = '';\n\n  public get backdropClick(): Observable<void> {\n    return this.#backdropClickObs;\n  }\n\n  public get closed(): Observable<void> {\n    return this.#closedObs;\n  }\n\n  public enablePointerEvents = false;\n\n  @HostBinding('id')\n  public id: string;\n\n  public showBackdrop = false;\n\n  public zIndex = `${++uniqueZIndex}`;\n\n  protected clipPath$ = new ReplaySubject<string | undefined>(1);\n\n  protected position = POSITION_DEFAULT;\n\n  @ViewChild('overlayContentRef', {\n    read: ElementRef,\n    static: true,\n  })\n  public overlayContentRef: ElementRef | undefined;\n\n  @ViewChild('overlayRef', {\n    read: ElementRef,\n    static: true,\n  })\n  public overlayRef: ElementRef | undefined;\n\n  @ViewChild('target', {\n    read: ViewContainerRef,\n    static: true,\n  })\n  public targetRef: ViewContainerRef | undefined;\n\n  #backdropClick: Subject<void>;\n\n  #backdropClickObs: Observable<void>;\n\n  #closed: Subject<void>;\n\n  #closedObs: Observable<void>;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #routerSubscription: Subscription | undefined;\n\n  readonly #changeDetector = inject(ChangeDetectorRef);\n  readonly #context = inject(SkyOverlayContext);\n  readonly #coreAdapter = inject(SkyCoreAdapterService);\n  readonly #environmentInjector = inject(EnvironmentInjector);\n  readonly #idSvc = inject(SkyIdService);\n  readonly #router = inject(Router, { optional: true });\n\n  constructor() {\n    this.id = this.#idSvc.generateId();\n\n    this.#backdropClick = new Subject<void>();\n    this.#closed = new Subject<void>();\n\n    this.#backdropClickObs = this.#backdropClick.asObservable();\n    this.#closedObs = this.#closed.asObservable();\n  }\n\n  public ngOnInit(): void {\n    this.#applyConfig(this.#context.config);\n\n    setTimeout(() => {\n      this.#addBackdropClickListener();\n    });\n\n    if (this.#context.config.closeOnNavigation) {\n      this.#addRouteListener();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.#removeRouteListener();\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n\n    this.#backdropClick.complete();\n\n    this.#closed.next();\n    this.#closed.complete();\n  }\n\n  public attachComponent<C>(\n    component: Type<C>,\n    providers: StaticProvider[] = []\n  ): ComponentRef<C> {\n    /*istanbul ignore if: untestable*/\n    if (!this.targetRef) {\n      throw new Error(\n        '[SkyOverlayComponent] Could not attach the component because the target element could not be found.'\n      );\n    }\n\n    this.targetRef.clear();\n\n    const environmentInjector = createEnvironmentInjector(\n      [\n        {\n          provide: SKY_STACKING_CONTEXT,\n          useValue: {\n            zIndex: new BehaviorSubject(parseInt(this.zIndex, 10))\n              .asObservable()\n              .pipe(takeUntil(this.#ngUnsubscribe)),\n          },\n        },\n        ...providers,\n      ],\n      this.#environmentInjector\n    );\n\n    const componentRef = this.targetRef.createComponent<C>(component, {\n      environmentInjector,\n    });\n\n    // Run an initial change detection cycle after the component has been created.\n    componentRef.changeDetectorRef.detectChanges();\n\n    return componentRef;\n  }\n\n  public attachTemplate<T>(\n    templateRef: TemplateRef<T>,\n    context: T\n  ): EmbeddedViewRef<T> {\n    /*istanbul ignore if: untestable*/\n    if (!this.targetRef) {\n      throw new Error(\n        '[SkyOverlayComponent] Could not attach the template because the target element could not be found.'\n      );\n    }\n\n    this.targetRef.clear();\n\n    return this.targetRef.createEmbeddedView(templateRef, context, {\n      injector: this.#environmentInjector,\n    });\n  }\n\n  public updateClipPath(clipPath: string | undefined): void {\n    this.clipPath$.next(clipPath);\n  }\n\n  #applyConfig(config: SkyOverlayConfig): void {\n    this.wrapperClass = config.wrapperClass || '';\n    this.showBackdrop = !!config.showBackdrop;\n    this.enablePointerEvents = !!config.enablePointerEvents;\n    this.position = config.position || POSITION_DEFAULT;\n    this.#changeDetector.markForCheck();\n  }\n\n  #addBackdropClickListener(): void {\n    fromEvent<MouseEvent>(window.document, 'click')\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((event) => {\n        if (event.target && this.overlayContentRef && this.overlayRef) {\n          const isChild = this.overlayContentRef.nativeElement.contains(\n            event.target\n          );\n\n          const isAbove = this.#coreAdapter.isTargetAboveElement(\n            event.target,\n            this.overlayRef.nativeElement\n          );\n\n          /* istanbul ignore else */\n          if (!isChild && !isAbove) {\n            this.#backdropClick.next();\n            if (this.#context.config.enableClose) {\n              this.#closed.next();\n            }\n          }\n        }\n      });\n  }\n\n  #addRouteListener(): void {\n    /*istanbul ignore else*/\n    if (this.#router) {\n      this.#routerSubscription = this.#router.events.subscribe((event) => {\n        /* istanbul ignore else */\n        if (event instanceof NavigationStart) {\n          this.#closed.next();\n        }\n      });\n    }\n  }\n\n  #removeRouteListener(): void {\n    if (this.#routerSubscription) {\n      this.#routerSubscription.unsubscribe();\n      this.#routerSubscription = undefined;\n    }\n  }\n}\n","<div\n  [class]=\"'sky-overlay-position-' + position + ' ' + wrapperClass\"\n  [style.z-index]=\"zIndex\"\n  [style.clip-path]=\"clipPath$ | async\"\n  [ngClass]=\"{\n    'enable-pointer-events-pass-through': enablePointerEvents,\n    'sky-overlay': true\n  }\"\n  #overlayRef\n>\n  <div class=\"sky-overlay-content\" #overlayContentRef>\n    <ng-template #target> </ng-template>\n  </div>\n  <div *ngIf=\"showBackdrop\" class=\"sky-overlay-backdrop\"></div>\n</div>\n"]}
|
@@ -1,17 +1,15 @@
|
|
1
|
-
import { CommonModule } from '@angular/common';
|
2
1
|
import { NgModule } from '@angular/core';
|
3
|
-
import { SkyOverlayComponent } from './overlay.component';
|
4
2
|
import * as i0 from "@angular/core";
|
3
|
+
/**
|
4
|
+
* @deprecated The `SkyOverlayModule` is no longer needed and can be removed from your application.
|
5
|
+
*/
|
5
6
|
export class SkyOverlayModule {
|
6
7
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyOverlayModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
7
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.1", ngImport: i0, type: SkyOverlayModule
|
8
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyOverlayModule
|
8
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.1", ngImport: i0, type: SkyOverlayModule }); }
|
9
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyOverlayModule }); }
|
9
10
|
}
|
10
11
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyOverlayModule, decorators: [{
|
11
12
|
type: NgModule,
|
12
|
-
args: [{
|
13
|
-
imports: [CommonModule],
|
14
|
-
declarations: [SkyOverlayComponent],
|
15
|
-
}]
|
13
|
+
args: [{}]
|
16
14
|
}] });
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3ZlcmxheS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvY29yZS9zcmMvbGliL21vZHVsZXMvb3ZlcmxheS9vdmVybGF5Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUV6Qzs7R0FFRztBQUVILE1BQU0sT0FBTyxnQkFBZ0I7OEdBQWhCLGdCQUFnQjsrR0FBaEIsZ0JBQWdCOytHQUFoQixnQkFBZ0I7OzJGQUFoQixnQkFBZ0I7a0JBRDVCLFFBQVE7bUJBQUMsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogQGRlcHJlY2F0ZWQgVGhlIGBTa3lPdmVybGF5TW9kdWxlYCBpcyBubyBsb25nZXIgbmVlZGVkIGFuZCBjYW4gYmUgcmVtb3ZlZCBmcm9tIHlvdXIgYXBwbGljYXRpb24uXG4gKi9cbkBOZ01vZHVsZSh7fSlcbmV4cG9ydCBjbGFzcyBTa3lPdmVybGF5TW9kdWxlIHt9XG4iXX0=
|
@@ -1,10 +1,10 @@
|
|
1
1
|
import { ApplicationRef, EnvironmentInjector, Injectable, inject, } from '@angular/core';
|
2
|
-
import { SkyDynamicComponentService } from '../dynamic-component/dynamic-component.service';
|
3
2
|
import { SkyOverlayAdapterService } from './overlay-adapter.service';
|
4
3
|
import { SkyOverlayContext } from './overlay-context';
|
5
4
|
import { SkyOverlayInstance } from './overlay-instance';
|
6
5
|
import { SkyOverlayComponent } from './overlay.component';
|
7
6
|
import * as i0 from "@angular/core";
|
7
|
+
import * as i1 from "../dynamic-component/dynamic-component.service";
|
8
8
|
/**
|
9
9
|
* This service is used to create new overlays.
|
10
10
|
* @internal
|
@@ -13,8 +13,11 @@ export class SkyOverlayService {
|
|
13
13
|
static { this.overlays = []; }
|
14
14
|
#adapter = inject(SkyOverlayAdapterService);
|
15
15
|
#applicationRef = inject(ApplicationRef);
|
16
|
-
#dynamicComponentSvc
|
16
|
+
#dynamicComponentSvc;
|
17
17
|
#environmentInjector = inject(EnvironmentInjector);
|
18
|
+
constructor(dynamicComponentSvc) {
|
19
|
+
this.#dynamicComponentSvc = dynamicComponentSvc;
|
20
|
+
}
|
18
21
|
/**
|
19
22
|
* Creates an empty overlay. Use the returned `SkyOverlayInstance` to append content.
|
20
23
|
* @param config Configuration for the overlay.
|
@@ -98,7 +101,7 @@ export class SkyOverlayService {
|
|
98
101
|
}
|
99
102
|
}
|
100
103
|
}
|
101
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyOverlayService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
104
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyOverlayService, deps: [{ token: i1.SkyDynamicComponentService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
102
105
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyOverlayService, providedIn: 'root' }); }
|
103
106
|
}
|
104
107
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyOverlayService, decorators: [{
|
@@ -106,5 +109,24 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImpor
|
|
106
109
|
args: [{
|
107
110
|
providedIn: 'root',
|
108
111
|
}]
|
109
|
-
}] });
|
110
|
-
|
112
|
+
}], ctorParameters: function () { return [{ type: i1.SkyDynamicComponentService }]; } });
|
113
|
+
/**
|
114
|
+
* This service is used to create new overlays.
|
115
|
+
* @internal
|
116
|
+
* @deprecated Use `SkyOverlayService` to open a standalone component instead.
|
117
|
+
*/
|
118
|
+
export class SkyOverlayLegacyService extends SkyOverlayService {
|
119
|
+
/* istanbul ignore next */
|
120
|
+
constructor(dynamicComponentSvc) {
|
121
|
+
super(dynamicComponentSvc);
|
122
|
+
}
|
123
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyOverlayLegacyService, deps: [{ token: i1.SkyDynamicComponentLegacyService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
124
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyOverlayLegacyService, providedIn: 'any' }); }
|
125
|
+
}
|
126
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyOverlayLegacyService, decorators: [{
|
127
|
+
type: Injectable,
|
128
|
+
args: [{
|
129
|
+
providedIn: 'any',
|
130
|
+
}]
|
131
|
+
}], ctorParameters: function () { return [{ type: i1.SkyDynamicComponentLegacyService }]; } });
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/overlay/overlay.service.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,cAAc,EAEd,mBAAmB,EACnB,UAAU,EACV,MAAM,GACP,MAAM,eAAe,CAAC;AAOvB,OAAO,EAAE,wBAAwB,EAAE,MAAM,2BAA2B,CAAC;AAErE,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;;;AAE1D;;;GAGG;AAIH,MAAM,OAAO,iBAAiB;aACb,aAAQ,GAAyB,EAAE,AAA3B,CAA4B;IAE1C,QAAQ,GAAG,MAAM,CAAC,wBAAwB,CAAC,CAAC;IAC5C,eAAe,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;IACzC,oBAAoB,CAA6B;IACjD,oBAAoB,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;IAE5D,YAAY,mBAA+C;QACzD,IAAI,CAAC,oBAAoB,GAAG,mBAAmB,CAAC;IAClD,CAAC;IAED;;;OAGG;IACI,MAAM,CAAC,MAAyB;QACrC,MAAM,QAAQ,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;QAE7C,IAAI,QAAQ,CAAC,YAAY,KAAK,KAAK,EAAE;YACnC,IAAI,CAAC,QAAQ,CAAC,kBAAkB,EAAE,CAAC;SACpC;QAED,MAAM,YAAY,GAAG,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QACnD,MAAM,QAAQ,GAAG,IAAI,kBAAkB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC;QAEhE,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,EAAE;YAC7B,wEAAwE;YACxE,sGAAsG;YACtG,IAAI,iBAAiB,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,EAAE;gBACrD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;aACtB;QACH,CAAC,CAAC,CAAC;QAEH,iBAAiB,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAE1C,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED;;;OAGG;IACI,KAAK,CAAC,QAA4B;QACvC,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;QAC/B,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,QAAQ,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAChE,QAAQ,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;QAEhC,yFAAyF;QACzF,2FAA2F;QAC3F,gCAAgC;QAChC,2DAA2D;QAC3D,kGAAkG;QAClG,iFAAiF;QACjF,MAAM,gBAAgB,GAAG,QAAQ,CAAC,YAAY,CAAC,QAAQ,CAAC,aAAa,CAAC;QACtE,wBAAwB;QACxB,IAAI,gBAAgB,CAAC,UAAU,KAAK,IAAI,EAAE;YACxC,gBAAgB,CAAC,UAAU,CAAC,WAAW,CAAC,gBAAgB,CAAC,CAAC;SAC3D;IACH,CAAC;IAED;;OAEG;IACI,QAAQ;QACb,wFAAwF;QACxF,4CAA4C;QAC5C,OAAO,iBAAiB,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;YAC5C,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;SAC3C;IACH,CAAC;IAED,cAAc,CAAC,MAAwB;QACrC,OAAO,IAAI,CAAC,oBAAoB,CAAC,eAAe,CAAC,mBAAmB,EAAE;YACpE,mBAAmB,EAAE,IAAI,CAAC,oBAAoB;YAC9C,SAAS,EAAE;gBACT;oBACE,OAAO,EAAE,iBAAiB;oBAC1B,QAAQ,EAAE,IAAI,iBAAiB,CAAC,MAAM,CAAC;iBACxC;aACF;SACF,CAAC,CAAC;IACL,CAAC;IAED,cAAc,CAAC,SAA2B,EAAE;QAC1C,MAAM,QAAQ,GAAqB;YACjC,iBAAiB,EAAE,IAAI;YACvB,WAAW,EAAE,KAAK;YAClB,mBAAmB,EAAE,KAAK;YAC1B,YAAY,EAAE,IAAI;YAClB,YAAY,EAAE,KAAK;YACnB,YAAY,EAAE,EAAE;SACjB,CAAC;QAEF,OAAO,EAAE,GAAG,QAAQ,EAAE,GAAG,MAAM,EAAE,CAAC;IACpC,CAAC;IAED,eAAe,CAAC,QAA4B;QAC1C,iBAAiB,CAAC,QAAQ,CAAC,MAAM,CAC/B,iBAAiB,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,EAC5C,CAAC,CACF,CAAC;QAEF,IAAI,QAAQ,CAAC,MAAM,CAAC,YAAY,KAAK,KAAK,EAAE;YAC1C,6EAA6E;YAC7E,MAAM,4BAA4B,GAAG,iBAAiB,CAAC,QAAQ,CAAC,IAAI,CAClE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,YAAY,CAC9B,CAAC;YACF,IAAI,CAAC,4BAA4B,EAAE;gBACjC,IAAI,CAAC,QAAQ,CAAC,iBAAiB,EAAE,CAAC;aACnC;SACF;IACH,CAAC;8GAhHU,iBAAiB;kHAAjB,iBAAiB,cAFhB,MAAM;;2FAEP,iBAAiB;kBAH7B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB;;AAoHD;;;;GAIG;AAIH,MAAM,OAAO,uBAAwB,SAAQ,iBAAiB;IAC5D,0BAA0B;IAC1B,YAAY,mBAAqD;QAC/D,KAAK,CAAC,mBAAmB,CAAC,CAAC;IAC7B,CAAC;8GAJU,uBAAuB;kHAAvB,uBAAuB,cAFtB,KAAK;;2FAEN,uBAAuB;kBAHnC,UAAU;mBAAC;oBACV,UAAU,EAAE,KAAK;iBAClB","sourcesContent":["import {\n  ApplicationRef,\n  ComponentRef,\n  EnvironmentInjector,\n  Injectable,\n  inject,\n} from '@angular/core';\n\nimport {\n  SkyDynamicComponentLegacyService,\n  SkyDynamicComponentService,\n} from '../dynamic-component/dynamic-component.service';\n\nimport { SkyOverlayAdapterService } from './overlay-adapter.service';\nimport { SkyOverlayConfig } from './overlay-config';\nimport { SkyOverlayContext } from './overlay-context';\nimport { SkyOverlayInstance } from './overlay-instance';\nimport { SkyOverlayComponent } from './overlay.component';\n\n/**\n * This service is used to create new overlays.\n * @internal\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class SkyOverlayService {\n  private static overlays: SkyOverlayInstance[] = [];\n\n  readonly #adapter = inject(SkyOverlayAdapterService);\n  readonly #applicationRef = inject(ApplicationRef);\n  readonly #dynamicComponentSvc: SkyDynamicComponentService;\n  readonly #environmentInjector = inject(EnvironmentInjector);\n\n  constructor(dynamicComponentSvc: SkyDynamicComponentService) {\n    this.#dynamicComponentSvc = dynamicComponentSvc;\n  }\n\n  /**\n   * Creates an empty overlay. Use the returned `SkyOverlayInstance` to append content.\n   * @param config Configuration for the overlay.\n   */\n  public create(config?: SkyOverlayConfig): SkyOverlayInstance {\n    const settings = this.#prepareConfig(config);\n\n    if (settings.enableScroll === false) {\n      this.#adapter.restrictBodyScroll();\n    }\n\n    const componentRef = this.#createOverlay(settings);\n    const instance = new SkyOverlayInstance(settings, componentRef);\n\n    instance.closed.subscribe(() => {\n      // Only execute the service's close method if the instance still exists.\n      // This is needed to address a race condition if the deprecated instance.close method is used instead.\n      if (SkyOverlayService.overlays.indexOf(instance) > -1) {\n        this.close(instance);\n      }\n    });\n\n    SkyOverlayService.overlays.push(instance);\n\n    return instance;\n  }\n\n  /**\n   * Closes (and destroys) an overlay instance.\n   * @param instance The instance to close.\n   */\n  public close(instance: SkyOverlayInstance): void {\n    this.#destroyOverlay(instance);\n    this.#applicationRef.detachView(instance.componentRef.hostView);\n    instance.componentRef.destroy();\n\n    // In some cases, Angular keeps dynamically-generated component's nodes in the DOM during\n    // unit tests. This can make querying difficult because the older DOM nodes still exist and\n    // produce inconsistent results.\n    // Angular Material's overlay appears to do the same thing:\n    // https://github.com/angular/components/blob/master/src/cdk/portal/dom-portal-outlet.ts#L143-L145\n    // (Ignoring coverage since this branch will only be hit by consumer unit tests.)\n    const componentElement = instance.componentRef.location.nativeElement;\n    /* istanbul ignore if */\n    if (componentElement.parentNode !== null) {\n      componentElement.parentNode.removeChild(componentElement);\n    }\n  }\n\n  /**\n   * Closes all overlay instances.\n   */\n  public closeAll(): void {\n    // The `close` event handler for each instance alters the array's length asynchronously,\n    // so the only \"safe\" index to call is zero.\n    while (SkyOverlayService.overlays.length > 0) {\n      this.close(SkyOverlayService.overlays[0]);\n    }\n  }\n\n  #createOverlay(config: SkyOverlayConfig): ComponentRef<SkyOverlayComponent> {\n    return this.#dynamicComponentSvc.createComponent(SkyOverlayComponent, {\n      environmentInjector: this.#environmentInjector,\n      providers: [\n        {\n          provide: SkyOverlayContext,\n          useValue: new SkyOverlayContext(config),\n        },\n      ],\n    });\n  }\n\n  #prepareConfig(config: SkyOverlayConfig = {}): SkyOverlayConfig {\n    const defaults: SkyOverlayConfig = {\n      closeOnNavigation: true,\n      enableClose: false,\n      enablePointerEvents: false,\n      enableScroll: true,\n      showBackdrop: false,\n      wrapperClass: '',\n    };\n\n    return { ...defaults, ...config };\n  }\n\n  #destroyOverlay(instance: SkyOverlayInstance): void {\n    SkyOverlayService.overlays.splice(\n      SkyOverlayService.overlays.indexOf(instance),\n      1\n    );\n\n    if (instance.config.enableScroll === false) {\n      // Only release the body scroll if no other overlay wishes it to be disabled.\n      const anotherOverlayDisablesScroll = SkyOverlayService.overlays.some(\n        (o) => !o.config.enableScroll\n      );\n      if (!anotherOverlayDisablesScroll) {\n        this.#adapter.releaseBodyScroll();\n      }\n    }\n  }\n}\n\n/**\n * This service is used to create new overlays.\n * @internal\n * @deprecated Use `SkyOverlayService` to open a standalone component instead.\n */\n@Injectable({\n  providedIn: 'any',\n})\nexport class SkyOverlayLegacyService extends SkyOverlayService {\n  /* istanbul ignore next */\n  constructor(dynamicComponentSvc: SkyDynamicComponentLegacyService) {\n    super(dynamicComponentSvc);\n  }\n}\n"]}
|
@@ -1,3 +1,4 @@
|
|
1
|
+
/* istanbul ignore file */
|
1
2
|
/**
|
2
3
|
* NOTICE: DO NOT MODIFY THIS FILE!
|
3
4
|
* The contents of this file were automatically generated by
|
@@ -5,7 +6,7 @@
|
|
5
6
|
* To update this file, simply rerun the command.
|
6
7
|
*/
|
7
8
|
import { NgModule } from '@angular/core';
|
8
|
-
import { SKY_LIB_RESOURCES_PROVIDERS, SkyI18nModule, getLibStringForLocale, } from '@skyux/i18n';
|
9
|
+
import { SKY_LIB_RESOURCES_PROVIDERS, SkyI18nModule, SkyLibResourcesService, getLibStringForLocale, } from '@skyux/i18n';
|
9
10
|
import * as i0 from "@angular/core";
|
10
11
|
const RESOURCES = {
|
11
12
|
'EN-US': {
|
@@ -15,6 +16,7 @@ const RESOURCES = {
|
|
15
16
|
skyux_numeric_trillions_symbol: { message: 'T' },
|
16
17
|
},
|
17
18
|
};
|
19
|
+
SkyLibResourcesService.addResources(RESOURCES);
|
18
20
|
export class SkyCoreResourcesProvider {
|
19
21
|
getString(localeInfo, name) {
|
20
22
|
return getLibStringForLocale(RESOURCES, localeInfo.locale, name);
|
@@ -47,4 +49,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImpor
|
|
47
49
|
],
|
48
50
|
}]
|
49
51
|
}] });
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2t5LWNvcmUtcmVzb3VyY2VzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9jb3JlL3NyYy9saWIvbW9kdWxlcy9zaGFyZWQvc2t5LWNvcmUtcmVzb3VyY2VzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSwwQkFBMEI7QUFFMUI7Ozs7O0dBS0c7QUFDSCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFDTCwyQkFBMkIsRUFFM0IsYUFBYSxFQUdiLHNCQUFzQixFQUN0QixxQkFBcUIsR0FDdEIsTUFBTSxhQUFhLENBQUM7O0FBRXJCLE1BQU0sU0FBUyxHQUEwQztJQUN2RCxPQUFPLEVBQUU7UUFDUCw2QkFBNkIsRUFBRSxFQUFFLE9BQU8sRUFBRSxHQUFHLEVBQUU7UUFDL0MsNkJBQTZCLEVBQUUsRUFBRSxPQUFPLEVBQUUsR0FBRyxFQUFFO1FBQy9DLDhCQUE4QixFQUFFLEVBQUUsT0FBTyxFQUFFLEdBQUcsRUFBRTtRQUNoRCw4QkFBOEIsRUFBRSxFQUFFLE9BQU8sRUFBRSxHQUFHLEVBQUU7S0FDakQ7Q0FDRixDQUFDO0FBRUYsc0JBQXNCLENBQUMsWUFBWSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBRS9DLE1BQU0sT0FBTyx3QkFBd0I7SUFDNUIsU0FBUyxDQUNkLFVBQTRCLEVBQzVCLElBQVk7UUFFWixPQUFPLHFCQUFxQixDQUFDLFNBQVMsRUFBRSxVQUFVLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ25FLENBQUM7Q0FDRjtBQUVEOztHQUVHO0FBV0gsTUFBTSxPQUFPLHNCQUFzQjs4R0FBdEIsc0JBQXNCOytHQUF0QixzQkFBc0IsWUFUdkIsYUFBYTsrR0FTWixzQkFBc0IsYUFSdEI7WUFDVDtnQkFDRSxPQUFPLEVBQUUsMkJBQTJCO2dCQUNwQyxRQUFRLEVBQUUsd0JBQXdCO2dCQUNsQyxLQUFLLEVBQUUsSUFBSTthQUNaO1NBQ0YsWUFQUyxhQUFhOzsyRkFTWixzQkFBc0I7a0JBVmxDLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsYUFBYSxDQUFDO29CQUN4QixTQUFTLEVBQUU7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLDJCQUEyQjs0QkFDcEMsUUFBUSxFQUFFLHdCQUF3Qjs0QkFDbEMsS0FBSyxFQUFFLElBQUk7eUJBQ1o7cUJBQ0Y7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBpc3RhbmJ1bCBpZ25vcmUgZmlsZSAqL1xuXG4vKipcbiAqIE5PVElDRTogRE8gTk9UIE1PRElGWSBUSElTIEZJTEUhXG4gKiBUaGUgY29udGVudHMgb2YgdGhpcyBmaWxlIHdlcmUgYXV0b21hdGljYWxseSBnZW5lcmF0ZWQgYnlcbiAqIHRoZSAnbmcgZ2VuZXJhdGUgQHNreXV4L2kxOG46bGliLXJlc291cmNlcy1tb2R1bGUgbGliL21vZHVsZXMvc2hhcmVkL3NreS1jb3JlJyBzY2hlbWF0aWMuXG4gKiBUbyB1cGRhdGUgdGhpcyBmaWxlLCBzaW1wbHkgcmVydW4gdGhlIGNvbW1hbmQuXG4gKi9cbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1xuICBTS1lfTElCX1JFU09VUkNFU19QUk9WSURFUlMsXG4gIFNreUFwcExvY2FsZUluZm8sXG4gIFNreUkxOG5Nb2R1bGUsXG4gIFNreUxpYlJlc291cmNlcyxcbiAgU2t5TGliUmVzb3VyY2VzUHJvdmlkZXIsXG4gIFNreUxpYlJlc291cmNlc1NlcnZpY2UsXG4gIGdldExpYlN0cmluZ0ZvckxvY2FsZSxcbn0gZnJvbSAnQHNreXV4L2kxOG4nO1xuXG5jb25zdCBSRVNPVVJDRVM6IHsgW2xvY2FsZTogc3RyaW5nXTogU2t5TGliUmVzb3VyY2VzIH0gPSB7XG4gICdFTi1VUyc6IHtcbiAgICBza3l1eF9udW1lcmljX2JpbGxpb25zX3N5bWJvbDogeyBtZXNzYWdlOiAnQicgfSxcbiAgICBza3l1eF9udW1lcmljX21pbGxpb25zX3N5bWJvbDogeyBtZXNzYWdlOiAnTScgfSxcbiAgICBza3l1eF9udW1lcmljX3Rob3VzYW5kc19zeW1ib2w6IHsgbWVzc2FnZTogJ0snIH0sXG4gICAgc2t5dXhfbnVtZXJpY190cmlsbGlvbnNfc3ltYm9sOiB7IG1lc3NhZ2U6ICdUJyB9LFxuICB9LFxufTtcblxuU2t5TGliUmVzb3VyY2VzU2VydmljZS5hZGRSZXNvdXJjZXMoUkVTT1VSQ0VTKTtcblxuZXhwb3J0IGNsYXNzIFNreUNvcmVSZXNvdXJjZXNQcm92aWRlciBpbXBsZW1lbnRzIFNreUxpYlJlc291cmNlc1Byb3ZpZGVyIHtcbiAgcHVibGljIGdldFN0cmluZyhcbiAgICBsb2NhbGVJbmZvOiBTa3lBcHBMb2NhbGVJbmZvLFxuICAgIG5hbWU6IHN0cmluZ1xuICApOiBzdHJpbmcgfCB1bmRlZmluZWQge1xuICAgIHJldHVybiBnZXRMaWJTdHJpbmdGb3JMb2NhbGUoUkVTT1VSQ0VTLCBsb2NhbGVJbmZvLmxvY2FsZSwgbmFtZSk7XG4gIH1cbn1cblxuLyoqXG4gKiBJbXBvcnQgaW50byBhbnkgY29tcG9uZW50IGxpYnJhcnkgbW9kdWxlIHRoYXQgbmVlZHMgdG8gdXNlIHJlc291cmNlIHN0cmluZ3MuXG4gKi9cbkBOZ01vZHVsZSh7XG4gIGV4cG9ydHM6IFtTa3lJMThuTW9kdWxlXSxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogU0tZX0xJQl9SRVNPVVJDRVNfUFJPVklERVJTLFxuICAgICAgdXNlQ2xhc3M6IFNreUNvcmVSZXNvdXJjZXNQcm92aWRlcixcbiAgICAgIG11bHRpOiB0cnVlLFxuICAgIH0sXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIFNreUNvcmVSZXNvdXJjZXNNb2R1bGUge31cbiJdfQ==
|