@datarailsshared/datarailsshared 1.5.548 → 1.5.550
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/datarailsshared-datarailsshared-1.5.550.tgz +0 -0
- package/esm2022/lib/drawer/drawer-container.component.mjs +9 -7
- package/esm2022/lib/drawer/drawer-ref.mjs +10 -2
- package/esm2022/src/lib/drawer/drawer-container.component.mjs +9 -7
- package/esm2022/src/lib/drawer/drawer-ref.mjs +10 -2
- package/fesm2022/datarailsshared-datarailsshared.mjs +17 -7
- package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
- package/fesm2022/drDrawer.mjs +17 -7
- package/fesm2022/drDrawer.mjs.map +1 -1
- package/lib/drawer/drawer-ref.d.ts +3 -1
- package/package.json +1 -1
- package/src/lib/drawer/drawer-ref.d.ts +3 -1
- package/datarailsshared-datarailsshared-1.5.548.tgz +0 -0
|
Binary file
|
|
@@ -17,9 +17,9 @@ import * as i4 from "@angular/cdk/portal";
|
|
|
17
17
|
import * as i5 from "@angular/common";
|
|
18
18
|
const _c0 = ["handleRef"];
|
|
19
19
|
function DrawerContainer_div_0_Template(rf, ctx) { if (rf & 1) {
|
|
20
|
-
i0.ɵɵelement(0, "div",
|
|
20
|
+
i0.ɵɵelement(0, "div", 3, 4);
|
|
21
21
|
} }
|
|
22
|
-
function
|
|
22
|
+
function DrawerContainer_ng_template_2_Template(rf, ctx) { }
|
|
23
23
|
/**
|
|
24
24
|
* Internal component that wraps user-provided drawer content.
|
|
25
25
|
* @docs-private
|
|
@@ -141,12 +141,14 @@ export class DrawerContainer extends CdkDialogContainer {
|
|
|
141
141
|
i0.ɵɵattribute("role", ctx._config.role)("aria-modal", ctx._config.isModal)("aria-label", ctx._config.ariaLabel);
|
|
142
142
|
i0.ɵɵsyntheticHostProperty("@state", ctx._animationState);
|
|
143
143
|
i0.ɵɵclassMap(ctx._drawerPosition);
|
|
144
|
-
} }, standalone: true, features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], decls:
|
|
144
|
+
} }, standalone: true, features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], decls: 3, vars: 1, consts: [["class", "handle", 4, "ngIf"], [1, "dr-drawer-container__wrapper"], ["cdkPortalOutlet", ""], [1, "handle"], ["handleRef", ""]], template: function DrawerContainer_Template(rf, ctx) { if (rf & 1) {
|
|
145
145
|
i0.ɵɵtemplate(0, DrawerContainer_div_0_Template, 2, 0, "div", 0);
|
|
146
|
-
i0.ɵɵ
|
|
146
|
+
i0.ɵɵelementStart(1, "div", 1);
|
|
147
|
+
i0.ɵɵtemplate(2, DrawerContainer_ng_template_2_Template, 0, 0, "ng-template", 2);
|
|
148
|
+
i0.ɵɵelementEnd();
|
|
147
149
|
} if (rf & 2) {
|
|
148
150
|
i0.ɵɵproperty("ngIf", ctx._config.position === "bottom");
|
|
149
|
-
} }, dependencies: [PortalModule, i4.CdkPortalOutlet, DialogModule, MatCommonModule, CommonModule, i5.NgIf], styles: [".dr-drawer-container{display:
|
|
151
|
+
} }, dependencies: [PortalModule, i4.CdkPortalOutlet, DialogModule, MatCommonModule, CommonModule, i5.NgIf], styles: [".dr-drawer-container{display:flex;flex-direction:column;width:100%;overflow:auto;outline:0;box-sizing:border-box;background-color:#fff;box-shadow:0 4px 14px #d8d9de80}.dr-drawer-container__wrapper{flex:1;overflow:auto}.cdk-high-contrast-active .dr-drawer-container{outline:1px solid}.handle{position:relative;height:24px;cursor:pointer}.handle:after{content:\"\";position:absolute;top:16px;left:50%;transform:translate(-50%,-50%);background-color:#dfe0e3;height:4px;width:64px;border-radius:16px}.dr-drawer-right{transform:translate(100%);border-top-left-radius:16px;border-bottom-left-radius:16px}.dr-drawer-left{transform:translate(-100%);border-top-right-radius:16px;border-bottom-right-radius:16px}.dr-drawer-bottom{transform:translateY(100%);border-top-left-radius:16px;border-top-right-radius:16px}.dr-drawer-top{transform:translateY(-100%);border-bottom-left-radius:16px;border-bottom-right-radius:16px}\n"], encapsulation: 2, data: { animation: [drDrawerAnimations.drawerState] } }); }
|
|
150
152
|
}
|
|
151
153
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrawerContainer, [{
|
|
152
154
|
type: Component,
|
|
@@ -161,7 +163,7 @@ export class DrawerContainer extends CdkDialogContainer {
|
|
|
161
163
|
'[@state]': '_animationState',
|
|
162
164
|
'(@state.start)': '_onAnimationStart($event)',
|
|
163
165
|
'(@state.done)': '_onAnimationDone($event)',
|
|
164
|
-
}, standalone: true, imports: [PortalModule, DialogModule, MatCommonModule, CommonModule], template: "<div *ngIf=\"_config.position === 'bottom'\" #handleRef class=\"handle\"></div>\n<ng-template cdkPortalOutlet></ng-template>\n", styles: [".dr-drawer-container{display:
|
|
166
|
+
}, standalone: true, imports: [PortalModule, DialogModule, MatCommonModule, CommonModule], template: "<div *ngIf=\"_config.position === 'bottom'\" #handleRef class=\"handle\"></div>\n<div class=\"dr-drawer-container__wrapper\">\n <ng-template cdkPortalOutlet></ng-template>\n</div>\n", styles: [".dr-drawer-container{display:flex;flex-direction:column;width:100%;overflow:auto;outline:0;box-sizing:border-box;background-color:#fff;box-shadow:0 4px 14px #d8d9de80}.dr-drawer-container__wrapper{flex:1;overflow:auto}.cdk-high-contrast-active .dr-drawer-container{outline:1px solid}.handle{position:relative;height:24px;cursor:pointer}.handle:after{content:\"\";position:absolute;top:16px;left:50%;transform:translate(-50%,-50%);background-color:#dfe0e3;height:4px;width:64px;border-radius:16px}.dr-drawer-right{transform:translate(100%);border-top-left-radius:16px;border-bottom-left-radius:16px}.dr-drawer-left{transform:translate(-100%);border-top-right-radius:16px;border-bottom-right-radius:16px}.dr-drawer-bottom{transform:translateY(100%);border-top-left-radius:16px;border-top-right-radius:16px}.dr-drawer-top{transform:translateY(-100%);border-bottom-left-radius:16px;border-bottom-right-radius:16px}\n"] }]
|
|
165
167
|
}], function () { return [{ type: i0.ElementRef }, { type: i1.FocusTrapFactory }, { type: Document, decorators: [{
|
|
166
168
|
type: Optional
|
|
167
169
|
}, {
|
|
@@ -174,4 +176,4 @@ export class DrawerContainer extends CdkDialogContainer {
|
|
|
174
176
|
type: ViewChild,
|
|
175
177
|
args: ['handleRef']
|
|
176
178
|
}] }); })();
|
|
177
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer-container.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/drawer/drawer-container.component.ts","../../../../../projects/datarailsshared/src/lib/drawer/drawer-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AnimationEvent } from '@angular/animations';\nimport { FocusMonitor, FocusTrapFactory, InteractivityChecker } from '@angular/cdk/a11y';\nimport { CdkDialogContainer, DialogModule } from '@angular/cdk/dialog';\nimport { OverlayRef } from '@angular/cdk/overlay';\nimport { CdkPortalOutlet, PortalModule } from '@angular/cdk/portal';\nimport { CommonModule, DOCUMENT } from '@angular/common';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    inject,\n    Inject,\n    NgZone,\n    OnDestroy,\n    Optional,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { MatCommonModule } from '@angular/material/core';\nimport { distinctUntilChanged, finalize, fromEvent, map, Subject, switchMap, takeUntil, tap } from 'rxjs';\nimport { drDrawerAnimations } from './drawer-animation';\nimport { DrawerConfig } from './drawer-config';\nimport { BottomPositionStrategy, DrawerPositionStrategy } from './drawer-position-strategy';\n\n/**\n * Internal component that wraps user-provided drawer content.\n * @docs-private\n */\n@Component({\n    selector: 'dr-drawer-container',\n    templateUrl: 'drawer-container.component.html',\n    styleUrls: ['drawer-container.component.scss'],\n    // In Ivy embedded views will be change detected from their declaration place, rather than where\n    // they were stamped out. This means that we can't have the drawer container be OnPush,\n    // because it might cause the sheets that were opened from a template not to be out of date.\n    changeDetection: ChangeDetectionStrategy.Default,\n    encapsulation: ViewEncapsulation.None,\n    animations: [drDrawerAnimations.drawerState],\n    host: {\n        class: 'dr-drawer-container',\n        '[class]': '_drawerPosition',\n        tabindex: '-1',\n        '[id]': '_config.id',\n        '[attr.role]': '_config.role',\n        '[attr.aria-modal]': '_config.isModal',\n        '[attr.aria-label]': '_config.ariaLabel',\n        '[@state]': '_animationState',\n        '(@state.start)': '_onAnimationStart($event)',\n        '(@state.done)': '_onAnimationDone($event)',\n    },\n    standalone: true,\n    imports: [PortalModule, DialogModule, MatCommonModule, CommonModule],\n})\nexport class DrawerContainer extends CdkDialogContainer<DrawerConfig> implements OnDestroy, AfterViewInit {\n    /** The portal outlet inside of this container into which the content will be loaded. */\n    @ViewChild(CdkPortalOutlet, { static: true })\n    _portalOutlet!: CdkPortalOutlet;\n\n    @ViewChild('handleRef')\n    _handleRef!: ElementRef<HTMLDivElement>;\n\n    /** The state of the drawer animations. */\n    _animationState: 'void' | 'visible' | 'hidden' = 'void';\n\n    /** Emits whenever the state of the animation changes. */\n    readonly _animationStateChanged = new EventEmitter<AnimationEvent>();\n\n    /** Whether the component has been destroyed. */\n    private _destroyed = false;\n\n    get _drawerPosition() {\n        return `dr-drawer-${this._config.position}`;\n    }\n\n    private readonly _changeDetectorRef = inject(ChangeDetectorRef);\n\n    private readonly destroy$ = new Subject<void>();\n\n    positionStrategy!: DrawerPositionStrategy;\n\n    constructor(\n        elementRef: ElementRef<HTMLElement>,\n        focusTrapFactory: FocusTrapFactory,\n        @Optional() @Inject(DOCUMENT) document: Document,\n        config: DrawerConfig,\n        checker: InteractivityChecker,\n        ngZone: NgZone,\n        private overlayRef: OverlayRef,\n        focusMonitor?: FocusMonitor,\n    ) {\n        super(elementRef, focusTrapFactory, document, config, checker, ngZone, overlayRef, focusMonitor);\n    }\n\n    protected override _contentAttached(): void {\n        // Delegate to the original dialog-container initialization (i.e. saving the\n        // previous element, setting up the focus trap and moving focus to the container).\n        super._contentAttached();\n\n        this.enter();\n    }\n\n    /** Begin animation of bottom sheet entrance into view. */\n    enter(): void {\n        if (!this._destroyed) {\n            this._animationState = 'visible';\n            this._changeDetectorRef.markForCheck();\n            this._changeDetectorRef.detectChanges();\n        }\n    }\n\n    /** Begin animation of the bottom sheet exiting from view. */\n    exit(): void {\n        (this._elementRef.nativeElement as HTMLElement).style.transition = undefined;\n        if (!this._destroyed) {\n            this._animationState = 'hidden';\n            this._changeDetectorRef.markForCheck();\n        }\n    }\n\n    ngAfterViewInit(): void {\n        this.positionStrategy = this.resolvePositionStrategy();\n        if (this.positionStrategy) {\n            this.setupDragListener();\n        }\n    }\n\n    private resolvePositionStrategy(): DrawerPositionStrategy {\n        switch (this._config.position) {\n            case 'bottom':\n                return new BottomPositionStrategy();\n        }\n    }\n\n    private setupDragListener(): void {\n        const mousedown$ = fromEvent(this._handleRef.nativeElement, 'mousedown');\n        const mousemove$ = fromEvent(document, 'mousemove');\n        const mouseup$ = fromEvent(document, 'mouseup');\n\n        let lastPosition = 0;\n        let initPosition = 0;\n        let currentPosition = 0;\n        const container = this._elementRef.nativeElement as HTMLElement;\n\n        setTimeout(() => {\n            lastPosition = this.getContainerPosition(container);\n            initPosition = lastPosition;\n        });\n\n        mousedown$\n            .pipe(\n                switchMap(() =>\n                    mousemove$.pipe(\n                        finalize(() => {\n                            const container = this._elementRef.nativeElement as HTMLElement;\n                            if (this.positionStrategy.shouldClose(currentPosition, initPosition, lastPosition)) {\n                                this.overlayRef.dispose();\n                                return;\n                            }\n                            container.style.transition = 'transform 0.5s cubic-bezier(0.32, 0.72, 0, 1)';\n                            container.style.transform = `translate3d(0px, 0px, 0px)`;\n                        }),\n                        takeUntil(mouseup$),\n                    ),\n                ),\n                map((event: MouseEvent) => this.positionStrategy.extractMousePosition(event)),\n                distinctUntilChanged(),\n                tap((position) => {\n                    let containerPosition = this.getContainerPosition(container);\n\n                    containerPosition = Math.min(containerPosition, lastPosition);\n                    lastPosition = Math.min(containerPosition, lastPosition);\n                    currentPosition = position;\n\n                    container.style.transition = 'none';\n                    container.style.transform = this.positionStrategy.calculateTransform(position, containerPosition);\n                }),\n                takeUntil(this.destroy$),\n            )\n            .subscribe();\n    }\n\n    private getContainerPosition(container: HTMLElement): number {\n        return this._config.position === 'bottom' || this._config.position === 'top'\n            ? container.getBoundingClientRect().top\n            : container.getBoundingClientRect().left;\n    }\n\n    override ngOnDestroy() {\n        super.ngOnDestroy();\n\n        this.destroy$.next();\n        this.destroy$.complete();\n        this._destroyed = true;\n    }\n\n    _onAnimationDone(event: AnimationEvent) {\n        if (event.toState === 'visible') {\n            this._trapFocus();\n        }\n\n        this._animationStateChanged.emit(event);\n    }\n\n    _onAnimationStart(event: AnimationEvent) {\n        this._animationStateChanged.emit(event);\n    }\n\n    protected override _captureInitialFocus(): void {}\n}\n","<div *ngIf=\"_config.position === 'bottom'\" #handleRef class=\"handle\"></div>\n<ng-template cdkPortalOutlet></ng-template>\n"]}
|
|
179
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer-container.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/drawer/drawer-container.component.ts","../../../../../projects/datarailsshared/src/lib/drawer/drawer-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AnimationEvent } from '@angular/animations';\nimport { FocusMonitor, FocusTrapFactory, InteractivityChecker } from '@angular/cdk/a11y';\nimport { CdkDialogContainer, DialogModule } from '@angular/cdk/dialog';\nimport { OverlayRef } from '@angular/cdk/overlay';\nimport { CdkPortalOutlet, PortalModule } from '@angular/cdk/portal';\nimport { CommonModule, DOCUMENT } from '@angular/common';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    inject,\n    Inject,\n    NgZone,\n    OnDestroy,\n    Optional,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { MatCommonModule } from '@angular/material/core';\nimport { distinctUntilChanged, finalize, fromEvent, map, Subject, switchMap, takeUntil, tap } from 'rxjs';\nimport { drDrawerAnimations } from './drawer-animation';\nimport { DrawerConfig } from './drawer-config';\nimport { BottomPositionStrategy, DrawerPositionStrategy } from './drawer-position-strategy';\n\n/**\n * Internal component that wraps user-provided drawer content.\n * @docs-private\n */\n@Component({\n    selector: 'dr-drawer-container',\n    templateUrl: 'drawer-container.component.html',\n    styleUrls: ['drawer-container.component.scss'],\n    // In Ivy embedded views will be change detected from their declaration place, rather than where\n    // they were stamped out. This means that we can't have the drawer container be OnPush,\n    // because it might cause the sheets that were opened from a template not to be out of date.\n    changeDetection: ChangeDetectionStrategy.Default,\n    encapsulation: ViewEncapsulation.None,\n    animations: [drDrawerAnimations.drawerState],\n    host: {\n        class: 'dr-drawer-container',\n        '[class]': '_drawerPosition',\n        tabindex: '-1',\n        '[id]': '_config.id',\n        '[attr.role]': '_config.role',\n        '[attr.aria-modal]': '_config.isModal',\n        '[attr.aria-label]': '_config.ariaLabel',\n        '[@state]': '_animationState',\n        '(@state.start)': '_onAnimationStart($event)',\n        '(@state.done)': '_onAnimationDone($event)',\n    },\n    standalone: true,\n    imports: [PortalModule, DialogModule, MatCommonModule, CommonModule],\n})\nexport class DrawerContainer extends CdkDialogContainer<DrawerConfig> implements OnDestroy, AfterViewInit {\n    /** The portal outlet inside of this container into which the content will be loaded. */\n    @ViewChild(CdkPortalOutlet, { static: true })\n    _portalOutlet!: CdkPortalOutlet;\n\n    @ViewChild('handleRef')\n    _handleRef!: ElementRef<HTMLDivElement>;\n\n    /** The state of the drawer animations. */\n    _animationState: 'void' | 'visible' | 'hidden' = 'void';\n\n    /** Emits whenever the state of the animation changes. */\n    readonly _animationStateChanged = new EventEmitter<AnimationEvent>();\n\n    /** Whether the component has been destroyed. */\n    private _destroyed = false;\n\n    get _drawerPosition() {\n        return `dr-drawer-${this._config.position}`;\n    }\n\n    private readonly _changeDetectorRef = inject(ChangeDetectorRef);\n\n    private readonly destroy$ = new Subject<void>();\n\n    positionStrategy!: DrawerPositionStrategy;\n\n    constructor(\n        elementRef: ElementRef<HTMLElement>,\n        focusTrapFactory: FocusTrapFactory,\n        @Optional() @Inject(DOCUMENT) document: Document,\n        config: DrawerConfig,\n        checker: InteractivityChecker,\n        ngZone: NgZone,\n        private overlayRef: OverlayRef,\n        focusMonitor?: FocusMonitor,\n    ) {\n        super(elementRef, focusTrapFactory, document, config, checker, ngZone, overlayRef, focusMonitor);\n    }\n\n    protected override _contentAttached(): void {\n        // Delegate to the original dialog-container initialization (i.e. saving the\n        // previous element, setting up the focus trap and moving focus to the container).\n        super._contentAttached();\n\n        this.enter();\n    }\n\n    /** Begin animation of bottom sheet entrance into view. */\n    enter(): void {\n        if (!this._destroyed) {\n            this._animationState = 'visible';\n            this._changeDetectorRef.markForCheck();\n            this._changeDetectorRef.detectChanges();\n        }\n    }\n\n    /** Begin animation of the bottom sheet exiting from view. */\n    exit(): void {\n        (this._elementRef.nativeElement as HTMLElement).style.transition = undefined;\n        if (!this._destroyed) {\n            this._animationState = 'hidden';\n            this._changeDetectorRef.markForCheck();\n        }\n    }\n\n    ngAfterViewInit(): void {\n        this.positionStrategy = this.resolvePositionStrategy();\n        if (this.positionStrategy) {\n            this.setupDragListener();\n        }\n    }\n\n    private resolvePositionStrategy(): DrawerPositionStrategy {\n        switch (this._config.position) {\n            case 'bottom':\n                return new BottomPositionStrategy();\n        }\n    }\n\n    private setupDragListener(): void {\n        const mousedown$ = fromEvent(this._handleRef.nativeElement, 'mousedown');\n        const mousemove$ = fromEvent(document, 'mousemove');\n        const mouseup$ = fromEvent(document, 'mouseup');\n\n        let lastPosition = 0;\n        let initPosition = 0;\n        let currentPosition = 0;\n        const container = this._elementRef.nativeElement as HTMLElement;\n\n        setTimeout(() => {\n            lastPosition = this.getContainerPosition(container);\n            initPosition = lastPosition;\n        });\n\n        mousedown$\n            .pipe(\n                switchMap(() =>\n                    mousemove$.pipe(\n                        finalize(() => {\n                            const container = this._elementRef.nativeElement as HTMLElement;\n                            if (this.positionStrategy.shouldClose(currentPosition, initPosition, lastPosition)) {\n                                this.overlayRef.dispose();\n                                return;\n                            }\n                            container.style.transition = 'transform 0.5s cubic-bezier(0.32, 0.72, 0, 1)';\n                            container.style.transform = `translate3d(0px, 0px, 0px)`;\n                        }),\n                        takeUntil(mouseup$),\n                    ),\n                ),\n                map((event: MouseEvent) => this.positionStrategy.extractMousePosition(event)),\n                distinctUntilChanged(),\n                tap((position) => {\n                    let containerPosition = this.getContainerPosition(container);\n\n                    containerPosition = Math.min(containerPosition, lastPosition);\n                    lastPosition = Math.min(containerPosition, lastPosition);\n                    currentPosition = position;\n\n                    container.style.transition = 'none';\n                    container.style.transform = this.positionStrategy.calculateTransform(position, containerPosition);\n                }),\n                takeUntil(this.destroy$),\n            )\n            .subscribe();\n    }\n\n    private getContainerPosition(container: HTMLElement): number {\n        return this._config.position === 'bottom' || this._config.position === 'top'\n            ? container.getBoundingClientRect().top\n            : container.getBoundingClientRect().left;\n    }\n\n    override ngOnDestroy() {\n        super.ngOnDestroy();\n\n        this.destroy$.next();\n        this.destroy$.complete();\n        this._destroyed = true;\n    }\n\n    _onAnimationDone(event: AnimationEvent) {\n        if (event.toState === 'visible') {\n            this._trapFocus();\n        }\n\n        this._animationStateChanged.emit(event);\n    }\n\n    _onAnimationStart(event: AnimationEvent) {\n        this._animationStateChanged.emit(event);\n    }\n\n    protected override _captureInitialFocus(): void {}\n}\n","<div *ngIf=\"_config.position === 'bottom'\" #handleRef class=\"handle\"></div>\n<div class=\"dr-drawer-container__wrapper\">\n    <ng-template cdkPortalOutlet></ng-template>\n</div>\n"]}
|
|
@@ -41,6 +41,8 @@ export class DrawerRef {
|
|
|
41
41
|
});
|
|
42
42
|
_ref.overlayRef.detachments().subscribe(() => {
|
|
43
43
|
this._ref.close(this._result);
|
|
44
|
+
this._afterDismissed.next(this._result);
|
|
45
|
+
this._afterDismissed.complete();
|
|
44
46
|
});
|
|
45
47
|
merge(this.backdropClick(), this.keydownEvents().pipe(filter((event) => event.keyCode === ESCAPE))).subscribe((event) => {
|
|
46
48
|
if (!this.disableClose && (event.type !== 'keydown' || !hasModifierKey(event))) {
|
|
@@ -54,6 +56,8 @@ export class DrawerRef {
|
|
|
54
56
|
* @param result Data to be passed back to the drawer opener.
|
|
55
57
|
*/
|
|
56
58
|
dismiss(result) {
|
|
59
|
+
this._afterDismissed.next(result);
|
|
60
|
+
this._afterDismissed.complete();
|
|
57
61
|
if (this.containerInstance && !this._afterDismissed.closed) {
|
|
58
62
|
// Transition the backdrop in parallel to the drawer.
|
|
59
63
|
this.containerInstance._animationStateChanged
|
|
@@ -74,8 +78,12 @@ export class DrawerRef {
|
|
|
74
78
|
this.containerInstance = null;
|
|
75
79
|
}
|
|
76
80
|
}
|
|
77
|
-
/** Gets an observable that is notified when the drawer is
|
|
81
|
+
/** Gets an observable that is notified when the drawer is dismissed. */
|
|
78
82
|
afterDismissed() {
|
|
83
|
+
return this._afterDismissed;
|
|
84
|
+
}
|
|
85
|
+
/** Gets an observable that is notified when the drawer is finished closing. */
|
|
86
|
+
afterClosed() {
|
|
79
87
|
return this._ref.closed;
|
|
80
88
|
}
|
|
81
89
|
/** Gets an observable that is notified when the drawer has opened and appeared. */
|
|
@@ -95,4 +103,4 @@ export class DrawerRef {
|
|
|
95
103
|
return this._ref.keydownEvents;
|
|
96
104
|
}
|
|
97
105
|
}
|
|
98
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer-ref.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/drawer/drawer-ref.ts"],"names":[],"mappings":"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","sourcesContent":["import { DialogRef } from '@angular/cdk/dialog';\nimport { ESCAPE, hasModifierKey } from '@angular/cdk/keycodes';\nimport { merge, Observable, Subject } from 'rxjs';\nimport { filter, take } from 'rxjs/operators';\nimport { DrawerConfig } from './drawer-config';\nimport { DrawerContainer } from './drawer-container.component';\nimport { ComponentRef } from '@angular/core';\n\n/**\n * Reference to a drawer dispatched from the drawer service.\n */\nexport class DrawerRef<T = any, R = any> {\n    /** Instance of the component making up the content of the drawer. */\n    get instance(): T {\n        return this._ref.componentInstance!;\n    }\n\n    /**\n     * `ComponentRef` of the component opened into the drawer. Will be\n     * null when the drawer is opened using a `TemplateRef`.\n     */\n    get componentRef(): ComponentRef<T> | null {\n        return this._ref.componentRef;\n    }\n\n    /**\n     * Instance of the component into which the drawer content is projected.\n     * @docs-private\n     */\n    containerInstance: DrawerContainer;\n\n    /** Whether the user is allowed to close the drawer. */\n    disableClose: boolean | undefined;\n\n    /** Unique ID for the drawer. */\n    id: string;\n\n    /** Subject for notifying the user that the drawer has been dismissed. */\n    private readonly _afterDismissed = new Subject<R | undefined>();\n\n    /** Subject for notifying the user that the drawer has opened and appeared. */\n    private readonly _afterOpened = new Subject<void>();\n\n    /** Result to be passed down to the `afterDismissed` stream. */\n    private _result: R | undefined;\n\n    /** Handle to the timeout that's running as a fallback in case the exit animation doesn't fire. */\n    private _closeFallbackTimeout: any;\n\n    constructor(\n        private _ref: DialogRef<R, T>,\n        config: DrawerConfig,\n        containerInstance: DrawerContainer,\n    ) {\n        this.containerInstance = containerInstance;\n        this.disableClose = config.disableClose;\n        this.id = _ref.id;\n\n        // Emit when opening animation completes\n        containerInstance._animationStateChanged\n            .pipe(\n                filter((event) => event.phaseName === 'done' && event.toState === 'visible'),\n                take(1),\n            )\n            .subscribe(() => {\n                this._afterOpened.next();\n                this._afterOpened.complete();\n            });\n\n        // Dispose overlay when closing animation is complete\n        containerInstance._animationStateChanged\n            .pipe(\n                filter((event) => event.phaseName === 'done' && event.toState === 'hidden'),\n                take(1),\n            )\n            .subscribe(() => {\n                clearTimeout(this._closeFallbackTimeout);\n                this._ref.close(this._result);\n            });\n\n        _ref.overlayRef.detachments().subscribe(() => {\n            this._ref.close(this._result);\n        });\n\n        merge(this.backdropClick(), this.keydownEvents().pipe(filter((event) => event.keyCode === ESCAPE))).subscribe((event) => {\n            if (!this.disableClose && (event.type !== 'keydown' || !hasModifierKey(event as KeyboardEvent))) {\n                event.preventDefault();\n                this.dismiss();\n            }\n        });\n    }\n\n    /**\n     * Dismisses the drawer.\n     * @param result Data to be passed back to the drawer opener.\n     */\n    dismiss(result?: R): void {\n        if (this.containerInstance && !this._afterDismissed.closed) {\n            // Transition the backdrop in parallel to the drawer.\n            this.containerInstance._animationStateChanged\n                .pipe(\n                    filter((event) => event.phaseName === 'start'),\n                    take(1),\n                )\n                .subscribe((event) => {\n                    // The logic that disposes of the overlay depends on the exit animation completing, however\n                    // it isn't guaranteed if the parent view is destroyed while it's running. Add a fallback\n                    // timeout which will clean everything up if the animation hasn't fired within the specified\n                    // amount of time plus 100ms. We don't need to run this outside the NgZone, because for the\n                    // vast majority of cases the timeout will have been cleared before it has fired.\n                    this._closeFallbackTimeout = setTimeout(() => {\n                        this._ref.close(this._result);\n                    }, event.totalTime + 100);\n\n                    this._ref.overlayRef.detachBackdrop();\n                });\n\n            this._result = result;\n            this.containerInstance.exit();\n            this.containerInstance = null!;\n        }\n    }\n\n    /** Gets an observable that is notified when the drawer is finished closing. */\n    afterDismissed(): Observable<R | undefined> {\n        return this._ref.closed;\n    }\n\n    /** Gets an observable that is notified when the drawer has opened and appeared. */\n    afterOpened(): Observable<void> {\n        return this._afterOpened;\n    }\n\n    /**\n     * Gets an observable that emits when the overlay's backdrop has been clicked.\n     */\n    backdropClick(): Observable<MouseEvent> {\n        return this._ref.backdropClick;\n    }\n\n    /**\n     * Gets an observable that emits when keydown events are targeted on the overlay.\n     */\n    keydownEvents(): Observable<KeyboardEvent> {\n        return this._ref.keydownEvents;\n    }\n}\n"]}
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer-ref.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/drawer/drawer-ref.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC/D,OAAO,EAAE,KAAK,EAAc,OAAO,EAAE,MAAM,MAAM,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAK9C;;GAEG;AACH,MAAM,OAAO,SAAS;IAClB,qEAAqE;IACrE,IAAI,QAAQ;QACR,OAAO,IAAI,CAAC,IAAI,CAAC,iBAAkB,CAAC;IACxC,CAAC;IAED;;;OAGG;IACH,IAAI,YAAY;QACZ,OAAO,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC;IAClC,CAAC;IA0BD,YACY,IAAqB,EAC7B,MAAoB,EACpB,iBAAkC;QAF1B,SAAI,GAAJ,IAAI,CAAiB;QAbjC,yEAAyE;QACxD,oBAAe,GAAG,IAAI,OAAO,EAAiB,CAAC;QAEhE,8EAA8E;QAC7D,iBAAY,GAAG,IAAI,OAAO,EAAQ,CAAC;QAahD,IAAI,CAAC,iBAAiB,GAAG,iBAAiB,CAAC;QAC3C,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,YAAY,CAAC;QACxC,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC;QAElB,wCAAwC;QACxC,iBAAiB,CAAC,sBAAsB;aACnC,IAAI,CACD,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,KAAK,MAAM,IAAI,KAAK,CAAC,OAAO,KAAK,SAAS,CAAC,EAC5E,IAAI,CAAC,CAAC,CAAC,CACV;aACA,SAAS,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;YACzB,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;QACjC,CAAC,CAAC,CAAC;QAEP,qDAAqD;QACrD,iBAAiB,CAAC,sBAAsB;aACnC,IAAI,CACD,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,KAAK,MAAM,IAAI,KAAK,CAAC,OAAO,KAAK,QAAQ,CAAC,EAC3E,IAAI,CAAC,CAAC,CAAC,CACV;aACA,SAAS,CAAC,GAAG,EAAE;YACZ,YAAY,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;YACzC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE;YACzC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC9B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACxC,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;QACpC,CAAC,CAAC,CAAC;QAEH,KAAK,CAAC,IAAI,CAAC,aAAa,EAAE,EAAE,IAAI,CAAC,aAAa,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,KAAK,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACpH,IAAI,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,KAAK,CAAC,IAAI,KAAK,SAAS,IAAI,CAAC,cAAc,CAAC,KAAsB,CAAC,CAAC,EAAE;gBAC7F,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,OAAO,EAAE,CAAC;aAClB;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;OAGG;IACH,OAAO,CAAC,MAAU;QACd,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAClC,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;QAEhC,IAAI,IAAI,CAAC,iBAAiB,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE;YACxD,qDAAqD;YACrD,IAAI,CAAC,iBAAiB,CAAC,sBAAsB;iBACxC,IAAI,CACD,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,KAAK,OAAO,CAAC,EAC9C,IAAI,CAAC,CAAC,CAAC,CACV;iBACA,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;gBACjB,2FAA2F;gBAC3F,yFAAyF;gBACzF,4FAA4F;gBAC5F,2FAA2F;gBAC3F,iFAAiF;gBACjF,IAAI,CAAC,qBAAqB,GAAG,UAAU,CAAC,GAAG,EAAE;oBACzC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;gBAClC,CAAC,EAAE,KAAK,CAAC,SAAS,GAAG,GAAG,CAAC,CAAC;gBAE1B,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,cAAc,EAAE,CAAC;YAC1C,CAAC,CAAC,CAAC;YAEP,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;YACtB,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC;YAC9B,IAAI,CAAC,iBAAiB,GAAG,IAAK,CAAC;SAClC;IACL,CAAC;IAED,wEAAwE;IACxE,cAAc;QACV,OAAO,IAAI,CAAC,eAAe,CAAC;IAChC,CAAC;IAED,+EAA+E;IAC/E,WAAW;QACP,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;IAC5B,CAAC;IAED,mFAAmF;IACnF,WAAW;QACP,OAAO,IAAI,CAAC,YAAY,CAAC;IAC7B,CAAC;IAED;;OAEG;IACH,aAAa;QACT,OAAO,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC;IACnC,CAAC;IAED;;OAEG;IACH,aAAa;QACT,OAAO,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC;IACnC,CAAC;CACJ","sourcesContent":["import { DialogRef } from '@angular/cdk/dialog';\nimport { ESCAPE, hasModifierKey } from '@angular/cdk/keycodes';\nimport { merge, Observable, Subject } from 'rxjs';\nimport { filter, take } from 'rxjs/operators';\nimport { DrawerConfig } from './drawer-config';\nimport { DrawerContainer } from './drawer-container.component';\nimport { ComponentRef } from '@angular/core';\n\n/**\n * Reference to a drawer dispatched from the drawer service.\n */\nexport class DrawerRef<T = any, R = any> {\n    /** Instance of the component making up the content of the drawer. */\n    get instance(): T {\n        return this._ref.componentInstance!;\n    }\n\n    /**\n     * `ComponentRef` of the component opened into the drawer. Will be\n     * null when the drawer is opened using a `TemplateRef`.\n     */\n    get componentRef(): ComponentRef<T> | null {\n        return this._ref.componentRef;\n    }\n\n    /**\n     * Instance of the component into which the drawer content is projected.\n     * @docs-private\n     */\n    containerInstance: DrawerContainer;\n\n    /** Whether the user is allowed to close the drawer. */\n    disableClose: boolean | undefined;\n\n    /** Unique ID for the drawer. */\n    id: string;\n\n    /** Subject for notifying the user that the drawer has been dismissed. */\n    private readonly _afterDismissed = new Subject<R | undefined>();\n\n    /** Subject for notifying the user that the drawer has opened and appeared. */\n    private readonly _afterOpened = new Subject<void>();\n\n    /** Result to be passed down to the `afterDismissed` stream. */\n    private _result: R | undefined;\n\n    /** Handle to the timeout that's running as a fallback in case the exit animation doesn't fire. */\n    private _closeFallbackTimeout: any;\n\n    constructor(\n        private _ref: DialogRef<R, T>,\n        config: DrawerConfig,\n        containerInstance: DrawerContainer,\n    ) {\n        this.containerInstance = containerInstance;\n        this.disableClose = config.disableClose;\n        this.id = _ref.id;\n\n        // Emit when opening animation completes\n        containerInstance._animationStateChanged\n            .pipe(\n                filter((event) => event.phaseName === 'done' && event.toState === 'visible'),\n                take(1),\n            )\n            .subscribe(() => {\n                this._afterOpened.next();\n                this._afterOpened.complete();\n            });\n\n        // Dispose overlay when closing animation is complete\n        containerInstance._animationStateChanged\n            .pipe(\n                filter((event) => event.phaseName === 'done' && event.toState === 'hidden'),\n                take(1),\n            )\n            .subscribe(() => {\n                clearTimeout(this._closeFallbackTimeout);\n                this._ref.close(this._result);\n            });\n\n        _ref.overlayRef.detachments().subscribe(() => {\n            this._ref.close(this._result);\n            this._afterDismissed.next(this._result);\n            this._afterDismissed.complete();\n        });\n\n        merge(this.backdropClick(), this.keydownEvents().pipe(filter((event) => event.keyCode === ESCAPE))).subscribe((event) => {\n            if (!this.disableClose && (event.type !== 'keydown' || !hasModifierKey(event as KeyboardEvent))) {\n                event.preventDefault();\n                this.dismiss();\n            }\n        });\n    }\n\n    /**\n     * Dismisses the drawer.\n     * @param result Data to be passed back to the drawer opener.\n     */\n    dismiss(result?: R): void {\n        this._afterDismissed.next(result);\n        this._afterDismissed.complete();\n\n        if (this.containerInstance && !this._afterDismissed.closed) {\n            // Transition the backdrop in parallel to the drawer.\n            this.containerInstance._animationStateChanged\n                .pipe(\n                    filter((event) => event.phaseName === 'start'),\n                    take(1),\n                )\n                .subscribe((event) => {\n                    // The logic that disposes of the overlay depends on the exit animation completing, however\n                    // it isn't guaranteed if the parent view is destroyed while it's running. Add a fallback\n                    // timeout which will clean everything up if the animation hasn't fired within the specified\n                    // amount of time plus 100ms. We don't need to run this outside the NgZone, because for the\n                    // vast majority of cases the timeout will have been cleared before it has fired.\n                    this._closeFallbackTimeout = setTimeout(() => {\n                        this._ref.close(this._result);\n                    }, event.totalTime + 100);\n\n                    this._ref.overlayRef.detachBackdrop();\n                });\n\n            this._result = result;\n            this.containerInstance.exit();\n            this.containerInstance = null!;\n        }\n    }\n\n    /** Gets an observable that is notified when the drawer is dismissed. */\n    afterDismissed(): Observable<R | undefined> {\n        return this._afterDismissed;\n    }\n\n    /** Gets an observable that is notified when the drawer is finished closing. */\n    afterClosed(): Observable<R | undefined> {\n        return this._ref.closed;\n    }\n\n    /** Gets an observable that is notified when the drawer has opened and appeared. */\n    afterOpened(): Observable<void> {\n        return this._afterOpened;\n    }\n\n    /**\n     * Gets an observable that emits when the overlay's backdrop has been clicked.\n     */\n    backdropClick(): Observable<MouseEvent> {\n        return this._ref.backdropClick;\n    }\n\n    /**\n     * Gets an observable that emits when keydown events are targeted on the overlay.\n     */\n    keydownEvents(): Observable<KeyboardEvent> {\n        return this._ref.keydownEvents;\n    }\n}\n"]}
|
|
@@ -17,9 +17,9 @@ import * as i4 from "@angular/cdk/portal";
|
|
|
17
17
|
import * as i5 from "@angular/common";
|
|
18
18
|
const _c0 = ["handleRef"];
|
|
19
19
|
function DrawerContainer_div_0_Template(rf, ctx) { if (rf & 1) {
|
|
20
|
-
i0.ɵɵelement(0, "div",
|
|
20
|
+
i0.ɵɵelement(0, "div", 3, 4);
|
|
21
21
|
} }
|
|
22
|
-
function
|
|
22
|
+
function DrawerContainer_ng_template_2_Template(rf, ctx) { }
|
|
23
23
|
/**
|
|
24
24
|
* Internal component that wraps user-provided drawer content.
|
|
25
25
|
* @docs-private
|
|
@@ -141,12 +141,14 @@ export class DrawerContainer extends CdkDialogContainer {
|
|
|
141
141
|
i0.ɵɵattribute("role", ctx._config.role)("aria-modal", ctx._config.isModal)("aria-label", ctx._config.ariaLabel);
|
|
142
142
|
i0.ɵɵsyntheticHostProperty("@state", ctx._animationState);
|
|
143
143
|
i0.ɵɵclassMap(ctx._drawerPosition);
|
|
144
|
-
} }, standalone: true, features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], decls:
|
|
144
|
+
} }, standalone: true, features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], decls: 3, vars: 1, consts: [["class", "handle", 4, "ngIf"], [1, "dr-drawer-container__wrapper"], ["cdkPortalOutlet", ""], [1, "handle"], ["handleRef", ""]], template: function DrawerContainer_Template(rf, ctx) { if (rf & 1) {
|
|
145
145
|
i0.ɵɵtemplate(0, DrawerContainer_div_0_Template, 2, 0, "div", 0);
|
|
146
|
-
i0.ɵɵ
|
|
146
|
+
i0.ɵɵelementStart(1, "div", 1);
|
|
147
|
+
i0.ɵɵtemplate(2, DrawerContainer_ng_template_2_Template, 0, 0, "ng-template", 2);
|
|
148
|
+
i0.ɵɵelementEnd();
|
|
147
149
|
} if (rf & 2) {
|
|
148
150
|
i0.ɵɵproperty("ngIf", ctx._config.position === "bottom");
|
|
149
|
-
} }, dependencies: [PortalModule, i4.CdkPortalOutlet, DialogModule, MatCommonModule, CommonModule, i5.NgIf], styles: [".dr-drawer-container{display:
|
|
151
|
+
} }, dependencies: [PortalModule, i4.CdkPortalOutlet, DialogModule, MatCommonModule, CommonModule, i5.NgIf], styles: [".dr-drawer-container{display:flex;flex-direction:column;width:100%;overflow:auto;outline:0;box-sizing:border-box;background-color:#fff;box-shadow:0 4px 14px #d8d9de80}.dr-drawer-container__wrapper{flex:1;overflow:auto}.cdk-high-contrast-active .dr-drawer-container{outline:1px solid}.handle{position:relative;height:24px;cursor:pointer}.handle:after{content:\"\";position:absolute;top:16px;left:50%;transform:translate(-50%,-50%);background-color:#dfe0e3;height:4px;width:64px;border-radius:16px}.dr-drawer-right{transform:translate(100%);border-top-left-radius:16px;border-bottom-left-radius:16px}.dr-drawer-left{transform:translate(-100%);border-top-right-radius:16px;border-bottom-right-radius:16px}.dr-drawer-bottom{transform:translateY(100%);border-top-left-radius:16px;border-top-right-radius:16px}.dr-drawer-top{transform:translateY(-100%);border-bottom-left-radius:16px;border-bottom-right-radius:16px}\n"], encapsulation: 2, data: { animation: [drDrawerAnimations.drawerState] } }); }
|
|
150
152
|
}
|
|
151
153
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrawerContainer, [{
|
|
152
154
|
type: Component,
|
|
@@ -161,7 +163,7 @@ export class DrawerContainer extends CdkDialogContainer {
|
|
|
161
163
|
'[@state]': '_animationState',
|
|
162
164
|
'(@state.start)': '_onAnimationStart($event)',
|
|
163
165
|
'(@state.done)': '_onAnimationDone($event)',
|
|
164
|
-
}, standalone: true, imports: [PortalModule, DialogModule, MatCommonModule, CommonModule], template: "<div *ngIf=\"_config.position === 'bottom'\" #handleRef class=\"handle\"></div>\n<ng-template cdkPortalOutlet></ng-template>\n", styles: [".dr-drawer-container{display:
|
|
166
|
+
}, standalone: true, imports: [PortalModule, DialogModule, MatCommonModule, CommonModule], template: "<div *ngIf=\"_config.position === 'bottom'\" #handleRef class=\"handle\"></div>\n<div class=\"dr-drawer-container__wrapper\">\n <ng-template cdkPortalOutlet></ng-template>\n</div>\n", styles: [".dr-drawer-container{display:flex;flex-direction:column;width:100%;overflow:auto;outline:0;box-sizing:border-box;background-color:#fff;box-shadow:0 4px 14px #d8d9de80}.dr-drawer-container__wrapper{flex:1;overflow:auto}.cdk-high-contrast-active .dr-drawer-container{outline:1px solid}.handle{position:relative;height:24px;cursor:pointer}.handle:after{content:\"\";position:absolute;top:16px;left:50%;transform:translate(-50%,-50%);background-color:#dfe0e3;height:4px;width:64px;border-radius:16px}.dr-drawer-right{transform:translate(100%);border-top-left-radius:16px;border-bottom-left-radius:16px}.dr-drawer-left{transform:translate(-100%);border-top-right-radius:16px;border-bottom-right-radius:16px}.dr-drawer-bottom{transform:translateY(100%);border-top-left-radius:16px;border-top-right-radius:16px}.dr-drawer-top{transform:translateY(-100%);border-bottom-left-radius:16px;border-bottom-right-radius:16px}\n"] }]
|
|
165
167
|
}], function () { return [{ type: i0.ElementRef }, { type: i1.FocusTrapFactory }, { type: Document, decorators: [{
|
|
166
168
|
type: Optional
|
|
167
169
|
}, {
|
|
@@ -174,4 +176,4 @@ export class DrawerContainer extends CdkDialogContainer {
|
|
|
174
176
|
type: ViewChild,
|
|
175
177
|
args: ['handleRef']
|
|
176
178
|
}] }); })();
|
|
177
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer-container.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/drawer/drawer-container.component.ts","../../../../../../projects/datarailsshared/src/lib/drawer/drawer-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AnimationEvent } from '@angular/animations';\nimport { FocusMonitor, FocusTrapFactory, InteractivityChecker } from '@angular/cdk/a11y';\nimport { CdkDialogContainer, DialogModule } from '@angular/cdk/dialog';\nimport { OverlayRef } from '@angular/cdk/overlay';\nimport { CdkPortalOutlet, PortalModule } from '@angular/cdk/portal';\nimport { CommonModule, DOCUMENT } from '@angular/common';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    inject,\n    Inject,\n    NgZone,\n    OnDestroy,\n    Optional,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { MatCommonModule } from '@angular/material/core';\nimport { distinctUntilChanged, finalize, fromEvent, map, Subject, switchMap, takeUntil, tap } from 'rxjs';\nimport { drDrawerAnimations } from './drawer-animation';\nimport { DrawerConfig } from './drawer-config';\nimport { BottomPositionStrategy, DrawerPositionStrategy } from './drawer-position-strategy';\n\n/**\n * Internal component that wraps user-provided drawer content.\n * @docs-private\n */\n@Component({\n    selector: 'dr-drawer-container',\n    templateUrl: 'drawer-container.component.html',\n    styleUrls: ['drawer-container.component.scss'],\n    // In Ivy embedded views will be change detected from their declaration place, rather than where\n    // they were stamped out. This means that we can't have the drawer container be OnPush,\n    // because it might cause the sheets that were opened from a template not to be out of date.\n    changeDetection: ChangeDetectionStrategy.Default,\n    encapsulation: ViewEncapsulation.None,\n    animations: [drDrawerAnimations.drawerState],\n    host: {\n        class: 'dr-drawer-container',\n        '[class]': '_drawerPosition',\n        tabindex: '-1',\n        '[id]': '_config.id',\n        '[attr.role]': '_config.role',\n        '[attr.aria-modal]': '_config.isModal',\n        '[attr.aria-label]': '_config.ariaLabel',\n        '[@state]': '_animationState',\n        '(@state.start)': '_onAnimationStart($event)',\n        '(@state.done)': '_onAnimationDone($event)',\n    },\n    standalone: true,\n    imports: [PortalModule, DialogModule, MatCommonModule, CommonModule],\n})\nexport class DrawerContainer extends CdkDialogContainer<DrawerConfig> implements OnDestroy, AfterViewInit {\n    /** The portal outlet inside of this container into which the content will be loaded. */\n    @ViewChild(CdkPortalOutlet, { static: true })\n    _portalOutlet!: CdkPortalOutlet;\n\n    @ViewChild('handleRef')\n    _handleRef!: ElementRef<HTMLDivElement>;\n\n    /** The state of the drawer animations. */\n    _animationState: 'void' | 'visible' | 'hidden' = 'void';\n\n    /** Emits whenever the state of the animation changes. */\n    readonly _animationStateChanged = new EventEmitter<AnimationEvent>();\n\n    /** Whether the component has been destroyed. */\n    private _destroyed = false;\n\n    get _drawerPosition() {\n        return `dr-drawer-${this._config.position}`;\n    }\n\n    private readonly _changeDetectorRef = inject(ChangeDetectorRef);\n\n    private readonly destroy$ = new Subject<void>();\n\n    positionStrategy!: DrawerPositionStrategy;\n\n    constructor(\n        elementRef: ElementRef<HTMLElement>,\n        focusTrapFactory: FocusTrapFactory,\n        @Optional() @Inject(DOCUMENT) document: Document,\n        config: DrawerConfig,\n        checker: InteractivityChecker,\n        ngZone: NgZone,\n        private overlayRef: OverlayRef,\n        focusMonitor?: FocusMonitor,\n    ) {\n        super(elementRef, focusTrapFactory, document, config, checker, ngZone, overlayRef, focusMonitor);\n    }\n\n    protected override _contentAttached(): void {\n        // Delegate to the original dialog-container initialization (i.e. saving the\n        // previous element, setting up the focus trap and moving focus to the container).\n        super._contentAttached();\n\n        this.enter();\n    }\n\n    /** Begin animation of bottom sheet entrance into view. */\n    enter(): void {\n        if (!this._destroyed) {\n            this._animationState = 'visible';\n            this._changeDetectorRef.markForCheck();\n            this._changeDetectorRef.detectChanges();\n        }\n    }\n\n    /** Begin animation of the bottom sheet exiting from view. */\n    exit(): void {\n        (this._elementRef.nativeElement as HTMLElement).style.transition = undefined;\n        if (!this._destroyed) {\n            this._animationState = 'hidden';\n            this._changeDetectorRef.markForCheck();\n        }\n    }\n\n    ngAfterViewInit(): void {\n        this.positionStrategy = this.resolvePositionStrategy();\n        if (this.positionStrategy) {\n            this.setupDragListener();\n        }\n    }\n\n    private resolvePositionStrategy(): DrawerPositionStrategy {\n        switch (this._config.position) {\n            case 'bottom':\n                return new BottomPositionStrategy();\n        }\n    }\n\n    private setupDragListener(): void {\n        const mousedown$ = fromEvent(this._handleRef.nativeElement, 'mousedown');\n        const mousemove$ = fromEvent(document, 'mousemove');\n        const mouseup$ = fromEvent(document, 'mouseup');\n\n        let lastPosition = 0;\n        let initPosition = 0;\n        let currentPosition = 0;\n        const container = this._elementRef.nativeElement as HTMLElement;\n\n        setTimeout(() => {\n            lastPosition = this.getContainerPosition(container);\n            initPosition = lastPosition;\n        });\n\n        mousedown$\n            .pipe(\n                switchMap(() =>\n                    mousemove$.pipe(\n                        finalize(() => {\n                            const container = this._elementRef.nativeElement as HTMLElement;\n                            if (this.positionStrategy.shouldClose(currentPosition, initPosition, lastPosition)) {\n                                this.overlayRef.dispose();\n                                return;\n                            }\n                            container.style.transition = 'transform 0.5s cubic-bezier(0.32, 0.72, 0, 1)';\n                            container.style.transform = `translate3d(0px, 0px, 0px)`;\n                        }),\n                        takeUntil(mouseup$),\n                    ),\n                ),\n                map((event: MouseEvent) => this.positionStrategy.extractMousePosition(event)),\n                distinctUntilChanged(),\n                tap((position) => {\n                    let containerPosition = this.getContainerPosition(container);\n\n                    containerPosition = Math.min(containerPosition, lastPosition);\n                    lastPosition = Math.min(containerPosition, lastPosition);\n                    currentPosition = position;\n\n                    container.style.transition = 'none';\n                    container.style.transform = this.positionStrategy.calculateTransform(position, containerPosition);\n                }),\n                takeUntil(this.destroy$),\n            )\n            .subscribe();\n    }\n\n    private getContainerPosition(container: HTMLElement): number {\n        return this._config.position === 'bottom' || this._config.position === 'top'\n            ? container.getBoundingClientRect().top\n            : container.getBoundingClientRect().left;\n    }\n\n    override ngOnDestroy() {\n        super.ngOnDestroy();\n\n        this.destroy$.next();\n        this.destroy$.complete();\n        this._destroyed = true;\n    }\n\n    _onAnimationDone(event: AnimationEvent) {\n        if (event.toState === 'visible') {\n            this._trapFocus();\n        }\n\n        this._animationStateChanged.emit(event);\n    }\n\n    _onAnimationStart(event: AnimationEvent) {\n        this._animationStateChanged.emit(event);\n    }\n\n    protected override _captureInitialFocus(): void {}\n}\n","<div *ngIf=\"_config.position === 'bottom'\" #handleRef class=\"handle\"></div>\n<ng-template cdkPortalOutlet></ng-template>\n"]}
|
|
179
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer-container.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/drawer/drawer-container.component.ts","../../../../../../projects/datarailsshared/src/lib/drawer/drawer-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AnimationEvent } from '@angular/animations';\nimport { FocusMonitor, FocusTrapFactory, InteractivityChecker } from '@angular/cdk/a11y';\nimport { CdkDialogContainer, DialogModule } from '@angular/cdk/dialog';\nimport { OverlayRef } from '@angular/cdk/overlay';\nimport { CdkPortalOutlet, PortalModule } from '@angular/cdk/portal';\nimport { CommonModule, DOCUMENT } from '@angular/common';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    inject,\n    Inject,\n    NgZone,\n    OnDestroy,\n    Optional,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { MatCommonModule } from '@angular/material/core';\nimport { distinctUntilChanged, finalize, fromEvent, map, Subject, switchMap, takeUntil, tap } from 'rxjs';\nimport { drDrawerAnimations } from './drawer-animation';\nimport { DrawerConfig } from './drawer-config';\nimport { BottomPositionStrategy, DrawerPositionStrategy } from './drawer-position-strategy';\n\n/**\n * Internal component that wraps user-provided drawer content.\n * @docs-private\n */\n@Component({\n    selector: 'dr-drawer-container',\n    templateUrl: 'drawer-container.component.html',\n    styleUrls: ['drawer-container.component.scss'],\n    // In Ivy embedded views will be change detected from their declaration place, rather than where\n    // they were stamped out. This means that we can't have the drawer container be OnPush,\n    // because it might cause the sheets that were opened from a template not to be out of date.\n    changeDetection: ChangeDetectionStrategy.Default,\n    encapsulation: ViewEncapsulation.None,\n    animations: [drDrawerAnimations.drawerState],\n    host: {\n        class: 'dr-drawer-container',\n        '[class]': '_drawerPosition',\n        tabindex: '-1',\n        '[id]': '_config.id',\n        '[attr.role]': '_config.role',\n        '[attr.aria-modal]': '_config.isModal',\n        '[attr.aria-label]': '_config.ariaLabel',\n        '[@state]': '_animationState',\n        '(@state.start)': '_onAnimationStart($event)',\n        '(@state.done)': '_onAnimationDone($event)',\n    },\n    standalone: true,\n    imports: [PortalModule, DialogModule, MatCommonModule, CommonModule],\n})\nexport class DrawerContainer extends CdkDialogContainer<DrawerConfig> implements OnDestroy, AfterViewInit {\n    /** The portal outlet inside of this container into which the content will be loaded. */\n    @ViewChild(CdkPortalOutlet, { static: true })\n    _portalOutlet!: CdkPortalOutlet;\n\n    @ViewChild('handleRef')\n    _handleRef!: ElementRef<HTMLDivElement>;\n\n    /** The state of the drawer animations. */\n    _animationState: 'void' | 'visible' | 'hidden' = 'void';\n\n    /** Emits whenever the state of the animation changes. */\n    readonly _animationStateChanged = new EventEmitter<AnimationEvent>();\n\n    /** Whether the component has been destroyed. */\n    private _destroyed = false;\n\n    get _drawerPosition() {\n        return `dr-drawer-${this._config.position}`;\n    }\n\n    private readonly _changeDetectorRef = inject(ChangeDetectorRef);\n\n    private readonly destroy$ = new Subject<void>();\n\n    positionStrategy!: DrawerPositionStrategy;\n\n    constructor(\n        elementRef: ElementRef<HTMLElement>,\n        focusTrapFactory: FocusTrapFactory,\n        @Optional() @Inject(DOCUMENT) document: Document,\n        config: DrawerConfig,\n        checker: InteractivityChecker,\n        ngZone: NgZone,\n        private overlayRef: OverlayRef,\n        focusMonitor?: FocusMonitor,\n    ) {\n        super(elementRef, focusTrapFactory, document, config, checker, ngZone, overlayRef, focusMonitor);\n    }\n\n    protected override _contentAttached(): void {\n        // Delegate to the original dialog-container initialization (i.e. saving the\n        // previous element, setting up the focus trap and moving focus to the container).\n        super._contentAttached();\n\n        this.enter();\n    }\n\n    /** Begin animation of bottom sheet entrance into view. */\n    enter(): void {\n        if (!this._destroyed) {\n            this._animationState = 'visible';\n            this._changeDetectorRef.markForCheck();\n            this._changeDetectorRef.detectChanges();\n        }\n    }\n\n    /** Begin animation of the bottom sheet exiting from view. */\n    exit(): void {\n        (this._elementRef.nativeElement as HTMLElement).style.transition = undefined;\n        if (!this._destroyed) {\n            this._animationState = 'hidden';\n            this._changeDetectorRef.markForCheck();\n        }\n    }\n\n    ngAfterViewInit(): void {\n        this.positionStrategy = this.resolvePositionStrategy();\n        if (this.positionStrategy) {\n            this.setupDragListener();\n        }\n    }\n\n    private resolvePositionStrategy(): DrawerPositionStrategy {\n        switch (this._config.position) {\n            case 'bottom':\n                return new BottomPositionStrategy();\n        }\n    }\n\n    private setupDragListener(): void {\n        const mousedown$ = fromEvent(this._handleRef.nativeElement, 'mousedown');\n        const mousemove$ = fromEvent(document, 'mousemove');\n        const mouseup$ = fromEvent(document, 'mouseup');\n\n        let lastPosition = 0;\n        let initPosition = 0;\n        let currentPosition = 0;\n        const container = this._elementRef.nativeElement as HTMLElement;\n\n        setTimeout(() => {\n            lastPosition = this.getContainerPosition(container);\n            initPosition = lastPosition;\n        });\n\n        mousedown$\n            .pipe(\n                switchMap(() =>\n                    mousemove$.pipe(\n                        finalize(() => {\n                            const container = this._elementRef.nativeElement as HTMLElement;\n                            if (this.positionStrategy.shouldClose(currentPosition, initPosition, lastPosition)) {\n                                this.overlayRef.dispose();\n                                return;\n                            }\n                            container.style.transition = 'transform 0.5s cubic-bezier(0.32, 0.72, 0, 1)';\n                            container.style.transform = `translate3d(0px, 0px, 0px)`;\n                        }),\n                        takeUntil(mouseup$),\n                    ),\n                ),\n                map((event: MouseEvent) => this.positionStrategy.extractMousePosition(event)),\n                distinctUntilChanged(),\n                tap((position) => {\n                    let containerPosition = this.getContainerPosition(container);\n\n                    containerPosition = Math.min(containerPosition, lastPosition);\n                    lastPosition = Math.min(containerPosition, lastPosition);\n                    currentPosition = position;\n\n                    container.style.transition = 'none';\n                    container.style.transform = this.positionStrategy.calculateTransform(position, containerPosition);\n                }),\n                takeUntil(this.destroy$),\n            )\n            .subscribe();\n    }\n\n    private getContainerPosition(container: HTMLElement): number {\n        return this._config.position === 'bottom' || this._config.position === 'top'\n            ? container.getBoundingClientRect().top\n            : container.getBoundingClientRect().left;\n    }\n\n    override ngOnDestroy() {\n        super.ngOnDestroy();\n\n        this.destroy$.next();\n        this.destroy$.complete();\n        this._destroyed = true;\n    }\n\n    _onAnimationDone(event: AnimationEvent) {\n        if (event.toState === 'visible') {\n            this._trapFocus();\n        }\n\n        this._animationStateChanged.emit(event);\n    }\n\n    _onAnimationStart(event: AnimationEvent) {\n        this._animationStateChanged.emit(event);\n    }\n\n    protected override _captureInitialFocus(): void {}\n}\n","<div *ngIf=\"_config.position === 'bottom'\" #handleRef class=\"handle\"></div>\n<div class=\"dr-drawer-container__wrapper\">\n    <ng-template cdkPortalOutlet></ng-template>\n</div>\n"]}
|
|
@@ -41,6 +41,8 @@ export class DrawerRef {
|
|
|
41
41
|
});
|
|
42
42
|
_ref.overlayRef.detachments().subscribe(() => {
|
|
43
43
|
this._ref.close(this._result);
|
|
44
|
+
this._afterDismissed.next(this._result);
|
|
45
|
+
this._afterDismissed.complete();
|
|
44
46
|
});
|
|
45
47
|
merge(this.backdropClick(), this.keydownEvents().pipe(filter((event) => event.keyCode === ESCAPE))).subscribe((event) => {
|
|
46
48
|
if (!this.disableClose && (event.type !== 'keydown' || !hasModifierKey(event))) {
|
|
@@ -54,6 +56,8 @@ export class DrawerRef {
|
|
|
54
56
|
* @param result Data to be passed back to the drawer opener.
|
|
55
57
|
*/
|
|
56
58
|
dismiss(result) {
|
|
59
|
+
this._afterDismissed.next(result);
|
|
60
|
+
this._afterDismissed.complete();
|
|
57
61
|
if (this.containerInstance && !this._afterDismissed.closed) {
|
|
58
62
|
// Transition the backdrop in parallel to the drawer.
|
|
59
63
|
this.containerInstance._animationStateChanged
|
|
@@ -74,8 +78,12 @@ export class DrawerRef {
|
|
|
74
78
|
this.containerInstance = null;
|
|
75
79
|
}
|
|
76
80
|
}
|
|
77
|
-
/** Gets an observable that is notified when the drawer is
|
|
81
|
+
/** Gets an observable that is notified when the drawer is dismissed. */
|
|
78
82
|
afterDismissed() {
|
|
83
|
+
return this._afterDismissed;
|
|
84
|
+
}
|
|
85
|
+
/** Gets an observable that is notified when the drawer is finished closing. */
|
|
86
|
+
afterClosed() {
|
|
79
87
|
return this._ref.closed;
|
|
80
88
|
}
|
|
81
89
|
/** Gets an observable that is notified when the drawer has opened and appeared. */
|
|
@@ -95,4 +103,4 @@ export class DrawerRef {
|
|
|
95
103
|
return this._ref.keydownEvents;
|
|
96
104
|
}
|
|
97
105
|
}
|
|
98
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer-ref.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/drawer/drawer-ref.ts"],"names":[],"mappings":"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","sourcesContent":["import { DialogRef } from '@angular/cdk/dialog';\nimport { ESCAPE, hasModifierKey } from '@angular/cdk/keycodes';\nimport { merge, Observable, Subject } from 'rxjs';\nimport { filter, take } from 'rxjs/operators';\nimport { DrawerConfig } from './drawer-config';\nimport { DrawerContainer } from './drawer-container.component';\nimport { ComponentRef } from '@angular/core';\n\n/**\n * Reference to a drawer dispatched from the drawer service.\n */\nexport class DrawerRef<T = any, R = any> {\n    /** Instance of the component making up the content of the drawer. */\n    get instance(): T {\n        return this._ref.componentInstance!;\n    }\n\n    /**\n     * `ComponentRef` of the component opened into the drawer. Will be\n     * null when the drawer is opened using a `TemplateRef`.\n     */\n    get componentRef(): ComponentRef<T> | null {\n        return this._ref.componentRef;\n    }\n\n    /**\n     * Instance of the component into which the drawer content is projected.\n     * @docs-private\n     */\n    containerInstance: DrawerContainer;\n\n    /** Whether the user is allowed to close the drawer. */\n    disableClose: boolean | undefined;\n\n    /** Unique ID for the drawer. */\n    id: string;\n\n    /** Subject for notifying the user that the drawer has been dismissed. */\n    private readonly _afterDismissed = new Subject<R | undefined>();\n\n    /** Subject for notifying the user that the drawer has opened and appeared. */\n    private readonly _afterOpened = new Subject<void>();\n\n    /** Result to be passed down to the `afterDismissed` stream. */\n    private _result: R | undefined;\n\n    /** Handle to the timeout that's running as a fallback in case the exit animation doesn't fire. */\n    private _closeFallbackTimeout: any;\n\n    constructor(\n        private _ref: DialogRef<R, T>,\n        config: DrawerConfig,\n        containerInstance: DrawerContainer,\n    ) {\n        this.containerInstance = containerInstance;\n        this.disableClose = config.disableClose;\n        this.id = _ref.id;\n\n        // Emit when opening animation completes\n        containerInstance._animationStateChanged\n            .pipe(\n                filter((event) => event.phaseName === 'done' && event.toState === 'visible'),\n                take(1),\n            )\n            .subscribe(() => {\n                this._afterOpened.next();\n                this._afterOpened.complete();\n            });\n\n        // Dispose overlay when closing animation is complete\n        containerInstance._animationStateChanged\n            .pipe(\n                filter((event) => event.phaseName === 'done' && event.toState === 'hidden'),\n                take(1),\n            )\n            .subscribe(() => {\n                clearTimeout(this._closeFallbackTimeout);\n                this._ref.close(this._result);\n            });\n\n        _ref.overlayRef.detachments().subscribe(() => {\n            this._ref.close(this._result);\n        });\n\n        merge(this.backdropClick(), this.keydownEvents().pipe(filter((event) => event.keyCode === ESCAPE))).subscribe((event) => {\n            if (!this.disableClose && (event.type !== 'keydown' || !hasModifierKey(event as KeyboardEvent))) {\n                event.preventDefault();\n                this.dismiss();\n            }\n        });\n    }\n\n    /**\n     * Dismisses the drawer.\n     * @param result Data to be passed back to the drawer opener.\n     */\n    dismiss(result?: R): void {\n        if (this.containerInstance && !this._afterDismissed.closed) {\n            // Transition the backdrop in parallel to the drawer.\n            this.containerInstance._animationStateChanged\n                .pipe(\n                    filter((event) => event.phaseName === 'start'),\n                    take(1),\n                )\n                .subscribe((event) => {\n                    // The logic that disposes of the overlay depends on the exit animation completing, however\n                    // it isn't guaranteed if the parent view is destroyed while it's running. Add a fallback\n                    // timeout which will clean everything up if the animation hasn't fired within the specified\n                    // amount of time plus 100ms. We don't need to run this outside the NgZone, because for the\n                    // vast majority of cases the timeout will have been cleared before it has fired.\n                    this._closeFallbackTimeout = setTimeout(() => {\n                        this._ref.close(this._result);\n                    }, event.totalTime + 100);\n\n                    this._ref.overlayRef.detachBackdrop();\n                });\n\n            this._result = result;\n            this.containerInstance.exit();\n            this.containerInstance = null!;\n        }\n    }\n\n    /** Gets an observable that is notified when the drawer is finished closing. */\n    afterDismissed(): Observable<R | undefined> {\n        return this._ref.closed;\n    }\n\n    /** Gets an observable that is notified when the drawer has opened and appeared. */\n    afterOpened(): Observable<void> {\n        return this._afterOpened;\n    }\n\n    /**\n     * Gets an observable that emits when the overlay's backdrop has been clicked.\n     */\n    backdropClick(): Observable<MouseEvent> {\n        return this._ref.backdropClick;\n    }\n\n    /**\n     * Gets an observable that emits when keydown events are targeted on the overlay.\n     */\n    keydownEvents(): Observable<KeyboardEvent> {\n        return this._ref.keydownEvents;\n    }\n}\n"]}
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer-ref.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/drawer/drawer-ref.ts"],"names":[],"mappings":"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","sourcesContent":["import { DialogRef } from '@angular/cdk/dialog';\nimport { ESCAPE, hasModifierKey } from '@angular/cdk/keycodes';\nimport { merge, Observable, Subject } from 'rxjs';\nimport { filter, take } from 'rxjs/operators';\nimport { DrawerConfig } from './drawer-config';\nimport { DrawerContainer } from './drawer-container.component';\nimport { ComponentRef } from '@angular/core';\n\n/**\n * Reference to a drawer dispatched from the drawer service.\n */\nexport class DrawerRef<T = any, R = any> {\n    /** Instance of the component making up the content of the drawer. */\n    get instance(): T {\n        return this._ref.componentInstance!;\n    }\n\n    /**\n     * `ComponentRef` of the component opened into the drawer. Will be\n     * null when the drawer is opened using a `TemplateRef`.\n     */\n    get componentRef(): ComponentRef<T> | null {\n        return this._ref.componentRef;\n    }\n\n    /**\n     * Instance of the component into which the drawer content is projected.\n     * @docs-private\n     */\n    containerInstance: DrawerContainer;\n\n    /** Whether the user is allowed to close the drawer. */\n    disableClose: boolean | undefined;\n\n    /** Unique ID for the drawer. */\n    id: string;\n\n    /** Subject for notifying the user that the drawer has been dismissed. */\n    private readonly _afterDismissed = new Subject<R | undefined>();\n\n    /** Subject for notifying the user that the drawer has opened and appeared. */\n    private readonly _afterOpened = new Subject<void>();\n\n    /** Result to be passed down to the `afterDismissed` stream. */\n    private _result: R | undefined;\n\n    /** Handle to the timeout that's running as a fallback in case the exit animation doesn't fire. */\n    private _closeFallbackTimeout: any;\n\n    constructor(\n        private _ref: DialogRef<R, T>,\n        config: DrawerConfig,\n        containerInstance: DrawerContainer,\n    ) {\n        this.containerInstance = containerInstance;\n        this.disableClose = config.disableClose;\n        this.id = _ref.id;\n\n        // Emit when opening animation completes\n        containerInstance._animationStateChanged\n            .pipe(\n                filter((event) => event.phaseName === 'done' && event.toState === 'visible'),\n                take(1),\n            )\n            .subscribe(() => {\n                this._afterOpened.next();\n                this._afterOpened.complete();\n            });\n\n        // Dispose overlay when closing animation is complete\n        containerInstance._animationStateChanged\n            .pipe(\n                filter((event) => event.phaseName === 'done' && event.toState === 'hidden'),\n                take(1),\n            )\n            .subscribe(() => {\n                clearTimeout(this._closeFallbackTimeout);\n                this._ref.close(this._result);\n            });\n\n        _ref.overlayRef.detachments().subscribe(() => {\n            this._ref.close(this._result);\n            this._afterDismissed.next(this._result);\n            this._afterDismissed.complete();\n        });\n\n        merge(this.backdropClick(), this.keydownEvents().pipe(filter((event) => event.keyCode === ESCAPE))).subscribe((event) => {\n            if (!this.disableClose && (event.type !== 'keydown' || !hasModifierKey(event as KeyboardEvent))) {\n                event.preventDefault();\n                this.dismiss();\n            }\n        });\n    }\n\n    /**\n     * Dismisses the drawer.\n     * @param result Data to be passed back to the drawer opener.\n     */\n    dismiss(result?: R): void {\n        this._afterDismissed.next(result);\n        this._afterDismissed.complete();\n\n        if (this.containerInstance && !this._afterDismissed.closed) {\n            // Transition the backdrop in parallel to the drawer.\n            this.containerInstance._animationStateChanged\n                .pipe(\n                    filter((event) => event.phaseName === 'start'),\n                    take(1),\n                )\n                .subscribe((event) => {\n                    // The logic that disposes of the overlay depends on the exit animation completing, however\n                    // it isn't guaranteed if the parent view is destroyed while it's running. Add a fallback\n                    // timeout which will clean everything up if the animation hasn't fired within the specified\n                    // amount of time plus 100ms. We don't need to run this outside the NgZone, because for the\n                    // vast majority of cases the timeout will have been cleared before it has fired.\n                    this._closeFallbackTimeout = setTimeout(() => {\n                        this._ref.close(this._result);\n                    }, event.totalTime + 100);\n\n                    this._ref.overlayRef.detachBackdrop();\n                });\n\n            this._result = result;\n            this.containerInstance.exit();\n            this.containerInstance = null!;\n        }\n    }\n\n    /** Gets an observable that is notified when the drawer is dismissed. */\n    afterDismissed(): Observable<R | undefined> {\n        return this._afterDismissed;\n    }\n\n    /** Gets an observable that is notified when the drawer is finished closing. */\n    afterClosed(): Observable<R | undefined> {\n        return this._ref.closed;\n    }\n\n    /** Gets an observable that is notified when the drawer has opened and appeared. */\n    afterOpened(): Observable<void> {\n        return this._afterOpened;\n    }\n\n    /**\n     * Gets an observable that emits when the overlay's backdrop has been clicked.\n     */\n    backdropClick(): Observable<MouseEvent> {\n        return this._ref.backdropClick;\n    }\n\n    /**\n     * Gets an observable that emits when keydown events are targeted on the overlay.\n     */\n    keydownEvents(): Observable<KeyboardEvent> {\n        return this._ref.keydownEvents;\n    }\n}\n"]}
|
|
@@ -12683,9 +12683,9 @@ class BottomPositionStrategy {
|
|
|
12683
12683
|
|
|
12684
12684
|
const _c0 = ["handleRef"];
|
|
12685
12685
|
function DrawerContainer_div_0_Template(rf, ctx) { if (rf & 1) {
|
|
12686
|
-
i0.ɵɵelement(0, "div",
|
|
12686
|
+
i0.ɵɵelement(0, "div", 3, 4);
|
|
12687
12687
|
} }
|
|
12688
|
-
function
|
|
12688
|
+
function DrawerContainer_ng_template_2_Template(rf, ctx) { }
|
|
12689
12689
|
/**
|
|
12690
12690
|
* Internal component that wraps user-provided drawer content.
|
|
12691
12691
|
* @docs-private
|
|
@@ -12807,12 +12807,14 @@ class DrawerContainer extends CdkDialogContainer {
|
|
|
12807
12807
|
i0.ɵɵattribute("role", ctx._config.role)("aria-modal", ctx._config.isModal)("aria-label", ctx._config.ariaLabel);
|
|
12808
12808
|
i0.ɵɵsyntheticHostProperty("@state", ctx._animationState);
|
|
12809
12809
|
i0.ɵɵclassMap(ctx._drawerPosition);
|
|
12810
|
-
} }, standalone: true, features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], decls:
|
|
12810
|
+
} }, standalone: true, features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], decls: 3, vars: 1, consts: [["class", "handle", 4, "ngIf"], [1, "dr-drawer-container__wrapper"], ["cdkPortalOutlet", ""], [1, "handle"], ["handleRef", ""]], template: function DrawerContainer_Template(rf, ctx) { if (rf & 1) {
|
|
12811
12811
|
i0.ɵɵtemplate(0, DrawerContainer_div_0_Template, 2, 0, "div", 0);
|
|
12812
|
-
i0.ɵɵ
|
|
12812
|
+
i0.ɵɵelementStart(1, "div", 1);
|
|
12813
|
+
i0.ɵɵtemplate(2, DrawerContainer_ng_template_2_Template, 0, 0, "ng-template", 2);
|
|
12814
|
+
i0.ɵɵelementEnd();
|
|
12813
12815
|
} if (rf & 2) {
|
|
12814
12816
|
i0.ɵɵproperty("ngIf", ctx._config.position === "bottom");
|
|
12815
|
-
} }, dependencies: [PortalModule, i4.CdkPortalOutlet, DialogModule, MatCommonModule, CommonModule, i1.NgIf], styles: [".dr-drawer-container{display:
|
|
12817
|
+
} }, dependencies: [PortalModule, i4.CdkPortalOutlet, DialogModule, MatCommonModule, CommonModule, i1.NgIf], styles: [".dr-drawer-container{display:flex;flex-direction:column;width:100%;overflow:auto;outline:0;box-sizing:border-box;background-color:#fff;box-shadow:0 4px 14px #d8d9de80}.dr-drawer-container__wrapper{flex:1;overflow:auto}.cdk-high-contrast-active .dr-drawer-container{outline:1px solid}.handle{position:relative;height:24px;cursor:pointer}.handle:after{content:\"\";position:absolute;top:16px;left:50%;transform:translate(-50%,-50%);background-color:#dfe0e3;height:4px;width:64px;border-radius:16px}.dr-drawer-right{transform:translate(100%);border-top-left-radius:16px;border-bottom-left-radius:16px}.dr-drawer-left{transform:translate(-100%);border-top-right-radius:16px;border-bottom-right-radius:16px}.dr-drawer-bottom{transform:translateY(100%);border-top-left-radius:16px;border-top-right-radius:16px}.dr-drawer-top{transform:translateY(-100%);border-bottom-left-radius:16px;border-bottom-right-radius:16px}\n"], encapsulation: 2, data: { animation: [drDrawerAnimations.drawerState] } }); }
|
|
12816
12818
|
}
|
|
12817
12819
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrawerContainer, [{
|
|
12818
12820
|
type: Component,
|
|
@@ -12827,7 +12829,7 @@ class DrawerContainer extends CdkDialogContainer {
|
|
|
12827
12829
|
'[@state]': '_animationState',
|
|
12828
12830
|
'(@state.start)': '_onAnimationStart($event)',
|
|
12829
12831
|
'(@state.done)': '_onAnimationDone($event)',
|
|
12830
|
-
}, standalone: true, imports: [PortalModule, DialogModule, MatCommonModule, CommonModule], template: "<div *ngIf=\"_config.position === 'bottom'\" #handleRef class=\"handle\"></div>\n<ng-template cdkPortalOutlet></ng-template>\n", styles: [".dr-drawer-container{display:
|
|
12832
|
+
}, standalone: true, imports: [PortalModule, DialogModule, MatCommonModule, CommonModule], template: "<div *ngIf=\"_config.position === 'bottom'\" #handleRef class=\"handle\"></div>\n<div class=\"dr-drawer-container__wrapper\">\n <ng-template cdkPortalOutlet></ng-template>\n</div>\n", styles: [".dr-drawer-container{display:flex;flex-direction:column;width:100%;overflow:auto;outline:0;box-sizing:border-box;background-color:#fff;box-shadow:0 4px 14px #d8d9de80}.dr-drawer-container__wrapper{flex:1;overflow:auto}.cdk-high-contrast-active .dr-drawer-container{outline:1px solid}.handle{position:relative;height:24px;cursor:pointer}.handle:after{content:\"\";position:absolute;top:16px;left:50%;transform:translate(-50%,-50%);background-color:#dfe0e3;height:4px;width:64px;border-radius:16px}.dr-drawer-right{transform:translate(100%);border-top-left-radius:16px;border-bottom-left-radius:16px}.dr-drawer-left{transform:translate(-100%);border-top-right-radius:16px;border-bottom-right-radius:16px}.dr-drawer-bottom{transform:translateY(100%);border-top-left-radius:16px;border-top-right-radius:16px}.dr-drawer-top{transform:translateY(-100%);border-bottom-left-radius:16px;border-bottom-right-radius:16px}\n"] }]
|
|
12831
12833
|
}], function () { return [{ type: i0.ElementRef }, { type: i1$8.FocusTrapFactory }, { type: Document, decorators: [{
|
|
12832
12834
|
type: Optional
|
|
12833
12835
|
}, {
|
|
@@ -12881,6 +12883,8 @@ class DrawerRef {
|
|
|
12881
12883
|
});
|
|
12882
12884
|
_ref.overlayRef.detachments().subscribe(() => {
|
|
12883
12885
|
this._ref.close(this._result);
|
|
12886
|
+
this._afterDismissed.next(this._result);
|
|
12887
|
+
this._afterDismissed.complete();
|
|
12884
12888
|
});
|
|
12885
12889
|
merge$1(this.backdropClick(), this.keydownEvents().pipe(filter((event) => event.keyCode === ESCAPE))).subscribe((event) => {
|
|
12886
12890
|
if (!this.disableClose && (event.type !== 'keydown' || !hasModifierKey(event))) {
|
|
@@ -12894,6 +12898,8 @@ class DrawerRef {
|
|
|
12894
12898
|
* @param result Data to be passed back to the drawer opener.
|
|
12895
12899
|
*/
|
|
12896
12900
|
dismiss(result) {
|
|
12901
|
+
this._afterDismissed.next(result);
|
|
12902
|
+
this._afterDismissed.complete();
|
|
12897
12903
|
if (this.containerInstance && !this._afterDismissed.closed) {
|
|
12898
12904
|
// Transition the backdrop in parallel to the drawer.
|
|
12899
12905
|
this.containerInstance._animationStateChanged
|
|
@@ -12914,8 +12920,12 @@ class DrawerRef {
|
|
|
12914
12920
|
this.containerInstance = null;
|
|
12915
12921
|
}
|
|
12916
12922
|
}
|
|
12917
|
-
/** Gets an observable that is notified when the drawer is
|
|
12923
|
+
/** Gets an observable that is notified when the drawer is dismissed. */
|
|
12918
12924
|
afterDismissed() {
|
|
12925
|
+
return this._afterDismissed;
|
|
12926
|
+
}
|
|
12927
|
+
/** Gets an observable that is notified when the drawer is finished closing. */
|
|
12928
|
+
afterClosed() {
|
|
12919
12929
|
return this._ref.closed;
|
|
12920
12930
|
}
|
|
12921
12931
|
/** Gets an observable that is notified when the drawer has opened and appeared. */
|