@datarailsshared/datarailsshared 1.6.191 → 1.6.199
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.6.199.tgz +0 -0
- package/esm2022/lib/dr-tooltip/components/tooltip-default/tooltip-default.component.mjs +5 -4
- package/esm2022/lib/dr-tooltip/components/tooltip-info/tooltip-info.component.mjs +6 -6
- package/esm2022/lib/dr-tooltip/dr-tooltip.component.mjs +6 -5
- package/esm2022/lib/dr-tooltip/dr-tooltip.directive.mjs +3 -2
- package/esm2022/lib/dr-tooltip/dr-tooltip.module.mjs +6 -9
- package/esm2022/lib/drawer/drawer-config.mjs +3 -1
- package/esm2022/lib/drawer/drawer-container.component.mjs +12 -9
- package/esm2022/lib/drawer/drawer-ref.mjs +5 -1
- package/esm2022/lib/drawer/drawer.service.mjs +82 -1
- package/esm2022/lib/filter-dropdown/filter-dropdown.component.mjs +3 -3
- package/fesm2022/datarailsshared-datarailsshared.mjs +115 -28
- package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
- package/lib/dr-tooltip/components/tooltip-default/tooltip-default.component.d.ts +1 -1
- package/lib/dr-tooltip/components/tooltip-info/tooltip-info.component.d.ts +1 -2
- package/lib/dr-tooltip/dr-tooltip.component.d.ts +1 -1
- package/lib/dr-tooltip/dr-tooltip.directive.d.ts +1 -1
- package/lib/dr-tooltip/dr-tooltip.module.d.ts +5 -6
- package/lib/drawer/drawer-config.d.ts +5 -0
- package/lib/drawer/drawer-container.component.d.ts +1 -1
- package/lib/drawer/drawer-ref.d.ts +2 -0
- package/lib/drawer/drawer.service.d.ts +17 -0
- package/package.json +1 -7
- package/datarailsshared-datarailsshared-1.6.191.tgz +0 -0
- package/esm2022/src/lib/drawer/drDrawer.mjs +0 -5
- package/esm2022/src/lib/drawer/drawer-animation.mjs +0 -18
- package/esm2022/src/lib/drawer/drawer-config.mjs +0 -35
- package/esm2022/src/lib/drawer/drawer-container.component.mjs +0 -179
- package/esm2022/src/lib/drawer/drawer-position-strategy.mjs +0 -14
- package/esm2022/src/lib/drawer/drawer-ref.mjs +0 -106
- package/esm2022/src/lib/drawer/drawer.module.mjs +0 -19
- package/esm2022/src/lib/drawer/drawer.service.mjs +0 -140
- package/esm2022/src/lib/drawer/public-api.mjs +0 -6
- package/fesm2022/drDrawer.mjs +0 -496
- package/fesm2022/drDrawer.mjs.map +0 -1
- package/src/lib/drawer/drawer-animation.d.ts +0 -5
- package/src/lib/drawer/drawer-config.d.ts +0 -68
- package/src/lib/drawer/drawer-container.component.d.ts +0 -45
- package/src/lib/drawer/drawer-position-strategy.d.ts +0 -10
- package/src/lib/drawer/drawer-ref.d.ts +0 -55
- package/src/lib/drawer/drawer.module.d.ts +0 -7
- package/src/lib/drawer/drawer.service.d.ts +0 -62
- package/src/lib/drawer/index.d.ts +0 -5
- package/src/lib/drawer/public-api.d.ts +0 -5
|
@@ -16,6 +16,10 @@ export class DrawerRef {
|
|
|
16
16
|
get componentRef() {
|
|
17
17
|
return this._ref.componentRef;
|
|
18
18
|
}
|
|
19
|
+
/** Gets the overlay element for the drawer. */
|
|
20
|
+
get overlayElement() {
|
|
21
|
+
return this._ref.overlayRef.overlayElement;
|
|
22
|
+
}
|
|
19
23
|
constructor(_ref, config, containerInstance) {
|
|
20
24
|
this._ref = _ref;
|
|
21
25
|
/** Subject for notifying the user that the drawer has been dismissed. */
|
|
@@ -103,4 +107,4 @@ export class DrawerRef {
|
|
|
103
107
|
return this._ref.keydownEvents;
|
|
104
108
|
}
|
|
105
109
|
}
|
|
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"]}
|
|
110
|
+
//# 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    /** Gets the overlay element for the drawer. */\n    get overlayElement(): HTMLElement {\n        return this._ref.overlayRef.overlayElement;\n    }\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"]}
|
|
@@ -7,6 +7,7 @@ import { startWith } from 'rxjs/operators';
|
|
|
7
7
|
import { DrawerConfig } from './drawer-config';
|
|
8
8
|
import { DrawerContainer } from './drawer-container.component';
|
|
9
9
|
import { DrawerRef } from './drawer-ref';
|
|
10
|
+
import { DrSharedUtils } from '../utils/dr-shared-utils';
|
|
10
11
|
import * as i0 from "@angular/core";
|
|
11
12
|
import * as i1 from "@angular/cdk/overlay";
|
|
12
13
|
import * as i2 from "./drawer-config";
|
|
@@ -40,6 +41,7 @@ export class Drawer {
|
|
|
40
41
|
this._openDrawersAtThisLevel = [];
|
|
41
42
|
this._afterAllDismissedAtThisLevel = new Subject();
|
|
42
43
|
this._afterOpenedAtThisLevel = new Subject();
|
|
44
|
+
this._resizeSubscriptions = new Map();
|
|
43
45
|
/**
|
|
44
46
|
* Stream that emits when all open drawer have finished closing.
|
|
45
47
|
* Will emit on subscribe if there are no open drawers to begin with.
|
|
@@ -84,10 +86,17 @@ export class Drawer {
|
|
|
84
86
|
});
|
|
85
87
|
this.openDrawers.push(drawerRef);
|
|
86
88
|
this.afterOpened.next(drawerRef);
|
|
89
|
+
if (_config.observedElement) {
|
|
90
|
+
this._setupResizeObservation(drawerRef, _config);
|
|
91
|
+
}
|
|
87
92
|
drawerRef.afterDismissed().subscribe(() => {
|
|
88
93
|
const index = this.openDrawers.indexOf(drawerRef);
|
|
89
94
|
if (index > -1) {
|
|
90
95
|
this.openDrawers.splice(index, 1);
|
|
96
|
+
if (drawerRef.id && this._resizeSubscriptions.has(drawerRef.id)) {
|
|
97
|
+
this._resizeSubscriptions.get(drawerRef.id).unsubscribe();
|
|
98
|
+
this._resizeSubscriptions.delete(drawerRef.id);
|
|
99
|
+
}
|
|
91
100
|
if (!this.openDrawers.length) {
|
|
92
101
|
this._getAfterAllDismissed().next();
|
|
93
102
|
}
|
|
@@ -112,9 +121,81 @@ export class Drawer {
|
|
|
112
121
|
// Only dismiss the drawers at this level on destroy
|
|
113
122
|
// since the parent service may still be active.
|
|
114
123
|
this._dismissDrawers(this._openDrawersAtThisLevel);
|
|
124
|
+
this._resizeSubscriptions.forEach((subscription) => subscription.unsubscribe());
|
|
125
|
+
this._resizeSubscriptions.clear();
|
|
115
126
|
this._afterAllDismissedAtThisLevel.complete();
|
|
116
127
|
this._afterOpenedAtThisLevel.complete();
|
|
117
128
|
}
|
|
129
|
+
/**
|
|
130
|
+
* Sets up resize observation for the specified element and updates drawer positioning.
|
|
131
|
+
*/
|
|
132
|
+
_setupResizeObservation(drawerRef, config) {
|
|
133
|
+
if (!config.observedElement || !drawerRef.id) {
|
|
134
|
+
return;
|
|
135
|
+
}
|
|
136
|
+
const resizeSubscription = DrSharedUtils.fromResizeObserver(config.observedElement).subscribe(() => {
|
|
137
|
+
this._updateDrawerPosition(drawerRef, config);
|
|
138
|
+
});
|
|
139
|
+
this._resizeSubscriptions.set(drawerRef.id, resizeSubscription);
|
|
140
|
+
// Defer initial position update to avoid conflicts with drawer initialization
|
|
141
|
+
setTimeout(() => {
|
|
142
|
+
this._updateDrawerPosition(drawerRef, config);
|
|
143
|
+
}, 0);
|
|
144
|
+
}
|
|
145
|
+
/**
|
|
146
|
+
* Calculates and applies margins to the drawer to fit within the observed element's boundaries.
|
|
147
|
+
*/
|
|
148
|
+
_updateDrawerPosition(drawerRef, config) {
|
|
149
|
+
if (!config.observedElement || !config.position) {
|
|
150
|
+
return;
|
|
151
|
+
}
|
|
152
|
+
const elementRect = config.observedElement.getBoundingClientRect();
|
|
153
|
+
const margins = this._calculateMarginsToFitWithinElement(config.position, elementRect);
|
|
154
|
+
const overlayElement = drawerRef.overlayElement;
|
|
155
|
+
if (overlayElement) {
|
|
156
|
+
this._applyMarginsToOverlay(overlayElement, margins);
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
/**
|
|
160
|
+
* Calculates margins to position drawer within the observed element's boundaries.
|
|
161
|
+
*/
|
|
162
|
+
_calculateMarginsToFitWithinElement(position, elementRect) {
|
|
163
|
+
const margins = { top: 0, right: 0, bottom: 0, left: 0 };
|
|
164
|
+
const viewportWidth = window.innerWidth;
|
|
165
|
+
const viewportHeight = window.innerHeight;
|
|
166
|
+
switch (position) {
|
|
167
|
+
case 'left':
|
|
168
|
+
margins.left = elementRect.left;
|
|
169
|
+
margins.top = elementRect.top;
|
|
170
|
+
margins.bottom = viewportHeight - elementRect.bottom;
|
|
171
|
+
break;
|
|
172
|
+
case 'right':
|
|
173
|
+
margins.right = viewportWidth - elementRect.right;
|
|
174
|
+
margins.top = elementRect.top;
|
|
175
|
+
margins.bottom = viewportHeight - elementRect.bottom;
|
|
176
|
+
break;
|
|
177
|
+
case 'top':
|
|
178
|
+
margins.top = elementRect.top;
|
|
179
|
+
margins.left = elementRect.left;
|
|
180
|
+
margins.right = viewportWidth - elementRect.right;
|
|
181
|
+
break;
|
|
182
|
+
case 'bottom':
|
|
183
|
+
margins.bottom = viewportHeight - elementRect.bottom;
|
|
184
|
+
margins.left = elementRect.left;
|
|
185
|
+
margins.right = viewportWidth - elementRect.right;
|
|
186
|
+
break;
|
|
187
|
+
}
|
|
188
|
+
return margins;
|
|
189
|
+
}
|
|
190
|
+
/**
|
|
191
|
+
* Applies calculated margins to the overlay element.
|
|
192
|
+
*/
|
|
193
|
+
_applyMarginsToOverlay(overlayElement, margins) {
|
|
194
|
+
overlayElement.style.marginTop = `${margins.top}px`;
|
|
195
|
+
overlayElement.style.marginRight = `${margins.right}px`;
|
|
196
|
+
overlayElement.style.marginBottom = `${margins.bottom}px`;
|
|
197
|
+
overlayElement.style.marginLeft = `${margins.left}px`;
|
|
198
|
+
}
|
|
118
199
|
_dismissDrawers(drawers) {
|
|
119
200
|
let i = drawers.length;
|
|
120
201
|
while (i--) {
|
|
@@ -137,4 +218,4 @@ export class Drawer {
|
|
|
137
218
|
type: Inject,
|
|
138
219
|
args: [DR_DRAWER_DEFAULT_OPTIONS]
|
|
139
220
|
}] }]; }, null); })();
|
|
140
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer.service.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/drawer/drawer.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceCssPixelValue } from '@angular/cdk/coercion';\nimport { Dialog, DialogConfig } from '@angular/cdk/dialog';\nimport { Overlay } from '@angular/cdk/overlay';\nimport { ComponentType } from '@angular/cdk/portal';\nimport { Inject, Injectable, InjectionToken, Injector, OnDestroy, Optional, SkipSelf, TemplateRef } from '@angular/core';\nimport { defer, Observable, Subject } from 'rxjs';\nimport { startWith } from 'rxjs/operators';\nimport { DrawerConfig } from './drawer-config';\nimport { DrawerContainer } from './drawer-container.component';\nimport { DrawerRef } from './drawer-ref';\n\n/** Injection token that can be used to access the data that was passed in to a drawer. */\nexport const DR_DRAWER_DATA = new InjectionToken<any>('DrDrawerData');\n\n/** Injection token that can be used to specify default drawer options. */\nexport const DR_DRAWER_DEFAULT_OPTIONS = new InjectionToken<DrawerConfig>('dr-drawer-default-options');\n\n// Counter for unique drawer ids.\nlet uniqueId = 0;\n\n/**\n * Service to trigger Material Design bottom sheets.\n */\n@Injectable({ providedIn: 'root' })\nexport class Drawer implements OnDestroy {\n    private readonly _openDrawersAtThisLevel: DrawerRef<any>[] = [];\n    private readonly _afterAllDismissedAtThisLevel = new Subject<void>();\n    private readonly _afterOpenedAtThisLevel = new Subject<DrawerRef<any>>();\n    private _dialog: Dialog;\n\n    /** Keeps track of the currently-open dialogs. */\n    get openDrawers(): DrawerRef[] {\n        return this._parentDrawer ? this._parentDrawer.openDrawers : this._openDrawersAtThisLevel;\n    }\n\n    /** Stream that emits when a drawer has been opened. */\n    get afterOpened(): Subject<DrawerRef<any>> {\n        return this._parentDrawer ? this._parentDrawer.afterOpened : this._afterOpenedAtThisLevel;\n    }\n\n    private _getAfterAllDismissed(): Subject<void> {\n        const parent = this._parentDrawer;\n        return parent ? parent._getAfterAllDismissed() : this._afterAllDismissedAtThisLevel;\n    }\n\n    /**\n     * Stream that emits when all open drawer have finished closing.\n     * Will emit on subscribe if there are no open drawers to begin with.\n     */\n    readonly afterAllDismissed: Observable<void> = defer(() =>\n        this.openDrawers.length ? this._getAfterAllDismissed() : this._getAfterAllDismissed().pipe(startWith(undefined)),\n    );\n\n    constructor(\n        private _overlay: Overlay,\n        private _injector: Injector,\n        @Optional() @SkipSelf() private _parentDrawer: Drawer,\n        @Optional()\n        @Inject(DR_DRAWER_DEFAULT_OPTIONS)\n        private _defaultOptions?: DrawerConfig,\n    ) {\n        this._dialog = _injector.get(Dialog);\n    }\n\n    /**\n     * Opens a drawer containing the given component.\n     * @param component Type of the component to load into the drawer.\n     * @param config Extra configuration options.\n     * @returns Reference to the newly-opened drawer.\n     */\n    open<T, D = any, R = any>(component: ComponentType<T>, config?: DrawerConfig<D>): DrawerRef<T, R>;\n\n    /**\n     * Opens a drawer containing the given template.\n     * @param template TemplateRef to instantiate as the drawer content.\n     * @param config Extra configuration options.\n     * @returns Reference to the newly-opened drawer.\n     */\n    open<T, D = any, R = any>(template: TemplateRef<T>, config?: DrawerConfig<D>): DrawerRef<T, R>;\n\n    open<T, D = any, R = any>(\n        componentOrTemplateRef: ComponentType<T> | TemplateRef<T>,\n        config?: DrawerConfig<D>,\n    ): DrawerRef<T, R> {\n        let drawerRef!: DrawerRef<T, R>;\n\n        const _config = { ...(this._defaultOptions || new DrawerConfig()), ...config };\n        _config.id = _config.id || `dr-drawer-${uniqueId++}`;\n\n        _config.width =\n            _config.position === 'left' || _config.position === 'right' ? coerceCssPixelValue(_config.width) : '100vw';\n\n        _config.height =\n            _config.position === 'top' || _config.position === 'bottom' ? coerceCssPixelValue(_config.height) : '100vh';\n\n        this._dialog.open<R, D, T>(componentOrTemplateRef, {\n            ..._config,\n            // Disable closing since we need to sync it up to the animation ourselves.\n            disableClose: true,\n            // Disable closing on detachments so that we can sync up the animation.\n            closeOnOverlayDetachments: false,\n            container: {\n                type: DrawerContainer,\n                providers: () => [\n                    // Provide our config as the CDK config as well since it has the same interface as the\n                    // CDK one, but it contains the actual values passed in by the user for things like\n                    // `disableClose` which we disable for the CDK dialog since we handle it ourselves.\n                    { provide: DrawerConfig, useValue: _config },\n                    { provide: DialogConfig, useValue: _config },\n                ],\n            },\n            scrollStrategy: _config.scrollStrategy || this._overlay.scrollStrategies.block(),\n            positionStrategy: this._overlay.position().global()[_config.position!]('0'),\n            templateContext: () => ({ drawerRef }),\n            providers: (cdkRef, _cdkConfig, container) => {\n                drawerRef = new DrawerRef(cdkRef, _config, container as DrawerContainer);\n                return [\n                    { provide: DrawerRef, useValue: drawerRef },\n                    { provide: DR_DRAWER_DATA, useValue: _config.data },\n                ];\n            },\n        });\n\n        this.openDrawers.push(drawerRef);\n        this.afterOpened.next(drawerRef);\n\n        drawerRef.afterDismissed().subscribe(() => {\n            const index = this.openDrawers.indexOf(drawerRef);\n\n            if (index > -1) {\n                this.openDrawers.splice(index, 1);\n\n                if (!this.openDrawers.length) {\n                    this._getAfterAllDismissed().next();\n                }\n            }\n        });\n\n        return drawerRef;\n    }\n\n    /**\n     * Dismisses all of the currently-open drawers.\n     */\n    dismissAll(): void {\n        this._dismissDrawers(this.openDrawers);\n    }\n\n    /**\n     * Finds an open drawer by its id.\n     * @param id ID to use when looking up the drawer.\n     */\n    getDrawerById(id: string): DrawerRef<any> | undefined {\n        return this.openDrawers.find((drawer) => drawer.id === id);\n    }\n\n    ngOnDestroy() {\n        // Only dismiss the drawers at this level on destroy\n        // since the parent service may still be active.\n        this._dismissDrawers(this._openDrawersAtThisLevel);\n        this._afterAllDismissedAtThisLevel.complete();\n        this._afterOpenedAtThisLevel.complete();\n    }\n\n    private _dismissDrawers(drawers: DrawerRef<any>[]) {\n        let i = drawers.length;\n\n        while (i--) {\n            drawers[i].dismiss();\n        }\n    }\n}\n"]}
|
|
221
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer.service.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/drawer/drawer.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceCssPixelValue } from '@angular/cdk/coercion';\nimport { Dialog, DialogConfig } from '@angular/cdk/dialog';\nimport { Overlay } from '@angular/cdk/overlay';\nimport { ComponentType } from '@angular/cdk/portal';\nimport { Inject, Injectable, InjectionToken, Injector, OnDestroy, Optional, SkipSelf, TemplateRef } from '@angular/core';\nimport { defer, Observable, Subject, Subscription } from 'rxjs';\nimport { startWith } from 'rxjs/operators';\nimport { DrawerConfig } from './drawer-config';\nimport { DrawerContainer } from './drawer-container.component';\nimport { DrawerRef } from './drawer-ref';\nimport { DrSharedUtils } from '../utils/dr-shared-utils';\n\n/** Injection token that can be used to access the data that was passed in to a drawer. */\nexport const DR_DRAWER_DATA = new InjectionToken<any>('DrDrawerData');\n\n/** Injection token that can be used to specify default drawer options. */\nexport const DR_DRAWER_DEFAULT_OPTIONS = new InjectionToken<DrawerConfig>('dr-drawer-default-options');\n\n// Counter for unique drawer ids.\nlet uniqueId = 0;\n\n/**\n * Service to trigger Material Design bottom sheets.\n */\n@Injectable({ providedIn: 'root' })\nexport class Drawer implements OnDestroy {\n    private readonly _openDrawersAtThisLevel: DrawerRef<any>[] = [];\n    private readonly _afterAllDismissedAtThisLevel = new Subject<void>();\n    private readonly _afterOpenedAtThisLevel = new Subject<DrawerRef<any>>();\n    private _dialog: Dialog;\n    private readonly _resizeSubscriptions = new Map<string, Subscription>();\n\n    /** Keeps track of the currently-open dialogs. */\n    get openDrawers(): DrawerRef[] {\n        return this._parentDrawer ? this._parentDrawer.openDrawers : this._openDrawersAtThisLevel;\n    }\n\n    /** Stream that emits when a drawer has been opened. */\n    get afterOpened(): Subject<DrawerRef<any>> {\n        return this._parentDrawer ? this._parentDrawer.afterOpened : this._afterOpenedAtThisLevel;\n    }\n\n    private _getAfterAllDismissed(): Subject<void> {\n        const parent = this._parentDrawer;\n        return parent ? parent._getAfterAllDismissed() : this._afterAllDismissedAtThisLevel;\n    }\n\n    /**\n     * Stream that emits when all open drawer have finished closing.\n     * Will emit on subscribe if there are no open drawers to begin with.\n     */\n    readonly afterAllDismissed: Observable<void> = defer(() =>\n        this.openDrawers.length ? this._getAfterAllDismissed() : this._getAfterAllDismissed().pipe(startWith(undefined)),\n    );\n\n    constructor(\n        private _overlay: Overlay,\n        private _injector: Injector,\n        @Optional() @SkipSelf() private _parentDrawer: Drawer,\n        @Optional()\n        @Inject(DR_DRAWER_DEFAULT_OPTIONS)\n        private _defaultOptions?: DrawerConfig,\n    ) {\n        this._dialog = _injector.get(Dialog);\n    }\n\n    /**\n     * Opens a drawer containing the given component.\n     * @param component Type of the component to load into the drawer.\n     * @param config Extra configuration options.\n     * @returns Reference to the newly-opened drawer.\n     */\n    open<T, D = any, R = any>(component: ComponentType<T>, config?: DrawerConfig<D>): DrawerRef<T, R>;\n\n    /**\n     * Opens a drawer containing the given template.\n     * @param template TemplateRef to instantiate as the drawer content.\n     * @param config Extra configuration options.\n     * @returns Reference to the newly-opened drawer.\n     */\n    open<T, D = any, R = any>(template: TemplateRef<T>, config?: DrawerConfig<D>): DrawerRef<T, R>;\n\n    open<T, D = any, R = any>(\n        componentOrTemplateRef: ComponentType<T> | TemplateRef<T>,\n        config?: DrawerConfig<D>,\n    ): DrawerRef<T, R> {\n        let drawerRef!: DrawerRef<T, R>;\n\n        const _config = { ...(this._defaultOptions || new DrawerConfig()), ...config };\n        _config.id = _config.id || `dr-drawer-${uniqueId++}`;\n\n        _config.width =\n            _config.position === 'left' || _config.position === 'right' ? coerceCssPixelValue(_config.width) : '100vw';\n\n        _config.height =\n            _config.position === 'top' || _config.position === 'bottom' ? coerceCssPixelValue(_config.height) : '100vh';\n\n        this._dialog.open<R, D, T>(componentOrTemplateRef, {\n            ..._config,\n            // Disable closing since we need to sync it up to the animation ourselves.\n            disableClose: true,\n            // Disable closing on detachments so that we can sync up the animation.\n            closeOnOverlayDetachments: false,\n            container: {\n                type: DrawerContainer,\n                providers: () => [\n                    // Provide our config as the CDK config as well since it has the same interface as the\n                    // CDK one, but it contains the actual values passed in by the user for things like\n                    // `disableClose` which we disable for the CDK dialog since we handle it ourselves.\n                    { provide: DrawerConfig, useValue: _config },\n                    { provide: DialogConfig, useValue: _config },\n                ],\n            },\n            scrollStrategy: _config.scrollStrategy || this._overlay.scrollStrategies.block(),\n            positionStrategy: this._overlay.position().global()[_config.position!]('0'),\n            templateContext: () => ({ drawerRef }),\n            providers: (cdkRef, _cdkConfig, container) => {\n                drawerRef = new DrawerRef(cdkRef, _config, container as DrawerContainer);\n                return [\n                    { provide: DrawerRef, useValue: drawerRef },\n                    { provide: DR_DRAWER_DATA, useValue: _config.data },\n                ];\n            },\n        });\n\n        this.openDrawers.push(drawerRef);\n        this.afterOpened.next(drawerRef);\n\n        if (_config.observedElement) {\n            this._setupResizeObservation(drawerRef, _config);\n        }\n\n        drawerRef.afterDismissed().subscribe(() => {\n            const index = this.openDrawers.indexOf(drawerRef);\n\n            if (index > -1) {\n                this.openDrawers.splice(index, 1);\n\n                if (drawerRef.id && this._resizeSubscriptions.has(drawerRef.id)) {\n                    this._resizeSubscriptions.get(drawerRef.id).unsubscribe();\n                    this._resizeSubscriptions.delete(drawerRef.id);\n                }\n\n                if (!this.openDrawers.length) {\n                    this._getAfterAllDismissed().next();\n                }\n            }\n        });\n\n        return drawerRef;\n    }\n\n    /**\n     * Dismisses all of the currently-open drawers.\n     */\n    dismissAll(): void {\n        this._dismissDrawers(this.openDrawers);\n    }\n\n    /**\n     * Finds an open drawer by its id.\n     * @param id ID to use when looking up the drawer.\n     */\n    getDrawerById(id: string): DrawerRef<any> | undefined {\n        return this.openDrawers.find((drawer) => drawer.id === id);\n    }\n\n    ngOnDestroy() {\n        // Only dismiss the drawers at this level on destroy\n        // since the parent service may still be active.\n        this._dismissDrawers(this._openDrawersAtThisLevel);\n\n        this._resizeSubscriptions.forEach((subscription) => subscription.unsubscribe());\n        this._resizeSubscriptions.clear();\n\n        this._afterAllDismissedAtThisLevel.complete();\n        this._afterOpenedAtThisLevel.complete();\n    }\n\n    /**\n     * Sets up resize observation for the specified element and updates drawer positioning.\n     */\n    private _setupResizeObservation(drawerRef: DrawerRef<unknown>, config: DrawerConfig): void {\n        if (!config.observedElement || !drawerRef.id) {\n            return;\n        }\n\n        const resizeSubscription = DrSharedUtils.fromResizeObserver(config.observedElement).subscribe(() => {\n            this._updateDrawerPosition(drawerRef, config);\n        });\n\n        this._resizeSubscriptions.set(drawerRef.id, resizeSubscription);\n\n        // Defer initial position update to avoid conflicts with drawer initialization\n        setTimeout(() => {\n            this._updateDrawerPosition(drawerRef, config);\n        }, 0);\n    }\n\n    /**\n     * Calculates and applies margins to the drawer to fit within the observed element's boundaries.\n     */\n    private _updateDrawerPosition(drawerRef: DrawerRef<any>, config: DrawerConfig): void {\n        if (!config.observedElement || !config.position) {\n            return;\n        }\n\n        const elementRect = config.observedElement.getBoundingClientRect();\n        const margins = this._calculateMarginsToFitWithinElement(config.position, elementRect);\n\n        const overlayElement = drawerRef.overlayElement;\n        if (overlayElement) {\n            this._applyMarginsToOverlay(overlayElement, margins);\n        }\n    }\n\n    /**\n     * Calculates margins to position drawer within the observed element's boundaries.\n     */\n    private _calculateMarginsToFitWithinElement(\n        position: string,\n        elementRect: DOMRect,\n    ): { top: number; right: number; bottom: number; left: number } {\n        const margins = { top: 0, right: 0, bottom: 0, left: 0 };\n        const viewportWidth = window.innerWidth;\n        const viewportHeight = window.innerHeight;\n\n        switch (position) {\n            case 'left':\n                margins.left = elementRect.left;\n                margins.top = elementRect.top;\n                margins.bottom = viewportHeight - elementRect.bottom;\n                break;\n            case 'right':\n                margins.right = viewportWidth - elementRect.right;\n                margins.top = elementRect.top;\n                margins.bottom = viewportHeight - elementRect.bottom;\n                break;\n            case 'top':\n                margins.top = elementRect.top;\n                margins.left = elementRect.left;\n                margins.right = viewportWidth - elementRect.right;\n                break;\n            case 'bottom':\n                margins.bottom = viewportHeight - elementRect.bottom;\n                margins.left = elementRect.left;\n                margins.right = viewportWidth - elementRect.right;\n                break;\n        }\n\n        return margins;\n    }\n\n    /**\n     * Applies calculated margins to the overlay element.\n     */\n    private _applyMarginsToOverlay(\n        overlayElement: HTMLElement,\n        margins: { top: number; right: number; bottom: number; left: number },\n    ): void {\n        overlayElement.style.marginTop = `${margins.top}px`;\n        overlayElement.style.marginRight = `${margins.right}px`;\n        overlayElement.style.marginBottom = `${margins.bottom}px`;\n        overlayElement.style.marginLeft = `${margins.left}px`;\n    }\n\n    private _dismissDrawers(drawers: DrawerRef<any>[]) {\n        let i = drawers.length;\n\n        while (i--) {\n            drawers[i].dismiss();\n        }\n    }\n}\n"]}
|
|
@@ -12,8 +12,8 @@ import { TextOverflowComponent } from '../text-overflow/text-overflow.component'
|
|
|
12
12
|
import { DrListOverflowComponent } from '../dr-list-overflow/dr-list-overflow.component';
|
|
13
13
|
import * as i0 from "@angular/core";
|
|
14
14
|
import * as i1 from "@angular/common";
|
|
15
|
-
import * as i2 from "../dr-tooltip/
|
|
16
|
-
import * as i3 from "../dr-tooltip/
|
|
15
|
+
import * as i2 from "../dr-tooltip/components/tooltip-default/tooltip-default.component";
|
|
16
|
+
import * as i3 from "../dr-tooltip/dr-tooltip.directive";
|
|
17
17
|
import * as i4 from "../dr-popover/dr-popover.directive";
|
|
18
18
|
import * as i5 from "../dr-dropdown/dr-dropdown.component";
|
|
19
19
|
import * as i6 from "../dr-dropdown/dr-dropdown-item/dr-dropdown-item.component";
|
|
@@ -386,7 +386,7 @@ export class FilterDropdownComponent {
|
|
|
386
386
|
i0.ɵɵtextInterpolate1("", ctx.label, ":");
|
|
387
387
|
i0.ɵɵadvance(3);
|
|
388
388
|
i0.ɵɵproperty("ngIf", ctx.hasSelection)("ngIfElse", _r4);
|
|
389
|
-
} }, dependencies: [CommonModule, i1.NgClass, i1.NgForOf, i1.NgIf, i1.NgTemplateOutlet, DrTooltipModule, i2.
|
|
389
|
+
} }, dependencies: [CommonModule, i1.NgClass, i1.NgForOf, i1.NgIf, i1.NgTemplateOutlet, DrTooltipModule, i2.TooltipDefaultComponent, i3.DrTooltipDirective, DrPopoverModule, i4.DrPopoverDirective, DrDropdownModule, i5.DrDropdownComponent, i6.DrDropdownItemComponent, DrInputsModule, i7.CheckboxComponent, i8.DrInputComponent, i9.DrButtonComponent, SearchPipe,
|
|
390
390
|
FormsModule, i10.NgControlStatus, i10.NgModel, LetDirective,
|
|
391
391
|
AutofocusDirective,
|
|
392
392
|
TextOverflowComponent,
|