@alauda/ui 7.2.1-beta.2 → 7.2.1-beta.20
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/drawer/component/drawer.component.d.ts +18 -49
- package/drawer/component/internal/internal.component.d.ts +31 -0
- package/drawer/drawer-ref.d.ts +13 -0
- package/drawer/drawer.module.d.ts +1 -1
- package/drawer/drawer.service.d.ts +15 -27
- package/drawer/index.d.ts +3 -2
- package/drawer/types.d.ts +19 -0
- package/esm2022/autocomplete/suggestion/suggestion.component.mjs +8 -4
- package/esm2022/drawer/component/drawer.component.mjs +36 -198
- package/esm2022/drawer/component/internal/internal.component.mjs +174 -0
- package/esm2022/drawer/drawer-ref.mjs +30 -0
- package/esm2022/drawer/drawer.module.mjs +3 -3
- package/esm2022/drawer/drawer.service.mjs +69 -22
- package/esm2022/drawer/{component/helper-directives.mjs → helper-directives.mjs} +1 -1
- package/esm2022/drawer/index.mjs +4 -3
- package/esm2022/drawer/types.mjs +2 -0
- package/fesm2022/alauda-ui.mjs +318 -242
- package/fesm2022/alauda-ui.mjs.map +1 -1
- package/package.json +1 -1
- package/drawer/component/drawer-ref.d.ts +0 -27
- package/esm2022/drawer/component/drawer-ref.mjs +0 -9
- /package/drawer/{component/helper-directives.d.ts → helper-directives.d.ts} +0 -0
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { filter, Subject } from 'rxjs';
|
|
2
|
+
export class DrawerRef {
|
|
3
|
+
drawerInstance;
|
|
4
|
+
result;
|
|
5
|
+
afterOpen$ = new Subject();
|
|
6
|
+
afterClosed$ = new Subject();
|
|
7
|
+
get afterOpen() {
|
|
8
|
+
return this.afterOpen$.asObservable();
|
|
9
|
+
}
|
|
10
|
+
get afterClosed() {
|
|
11
|
+
return this.afterClosed$.asObservable();
|
|
12
|
+
}
|
|
13
|
+
constructor(drawerInstance) {
|
|
14
|
+
this.drawerInstance = drawerInstance;
|
|
15
|
+
this.drawerInstance.animationStep$
|
|
16
|
+
.pipe(filter(step => step === 'hideDone'))
|
|
17
|
+
.subscribe(() => {
|
|
18
|
+
this.afterClosed$.next(this.result);
|
|
19
|
+
this.afterClosed$.complete();
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
open() {
|
|
23
|
+
this.drawerInstance.show();
|
|
24
|
+
}
|
|
25
|
+
close(result) {
|
|
26
|
+
this.result = result;
|
|
27
|
+
this.drawerInstance.hide();
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhd2VyLXJlZi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kcmF3ZXIvZHJhd2VyLXJlZi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFjLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUluRCxNQUFNLE9BQU8sU0FBUztJQWNEO0lBYlgsTUFBTSxDQUFJO0lBRUQsVUFBVSxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7SUFDakMsWUFBWSxHQUFHLElBQUksT0FBTyxFQUFLLENBQUM7SUFFakQsSUFBSSxTQUFTO1FBQ1gsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ3hDLENBQUM7SUFFRCxJQUFJLFdBQVc7UUFDYixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDMUMsQ0FBQztJQUVELFlBQW1CLGNBQXVDO1FBQXZDLG1CQUFjLEdBQWQsY0FBYyxDQUF5QjtRQUN4RCxJQUFJLENBQUMsY0FBYyxDQUFDLGNBQWM7YUFDL0IsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksS0FBSyxVQUFVLENBQUMsQ0FBQzthQUN6QyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ2QsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ3BDLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDL0IsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsSUFBSTtRQUNGLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDN0IsQ0FBQztJQUVELEtBQUssQ0FBQyxNQUFVO1FBQ2QsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7UUFDckIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUM3QixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmaWx0ZXIsIE9ic2VydmFibGUsIFN1YmplY3QgfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHsgRHJhd2VySW50ZXJuYWxDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudC9pbnRlcm5hbC9pbnRlcm5hbC5jb21wb25lbnQnO1xuXG5leHBvcnQgY2xhc3MgRHJhd2VyUmVmPFIgPSBhbnk+IHtcbiAgcHJpdmF0ZSByZXN1bHQ6IFI7XG5cbiAgcHJpdmF0ZSByZWFkb25seSBhZnRlck9wZW4kID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcbiAgcHJpdmF0ZSByZWFkb25seSBhZnRlckNsb3NlZCQgPSBuZXcgU3ViamVjdDxSPigpO1xuXG4gIGdldCBhZnRlck9wZW4oKTogT2JzZXJ2YWJsZTx2b2lkPiB7XG4gICAgcmV0dXJuIHRoaXMuYWZ0ZXJPcGVuJC5hc09ic2VydmFibGUoKTtcbiAgfVxuXG4gIGdldCBhZnRlckNsb3NlZCgpOiBPYnNlcnZhYmxlPFI+IHtcbiAgICByZXR1cm4gdGhpcy5hZnRlckNsb3NlZCQuYXNPYnNlcnZhYmxlKCk7XG4gIH1cblxuICBjb25zdHJ1Y3RvcihwdWJsaWMgZHJhd2VySW5zdGFuY2U6IERyYXdlckludGVybmFsQ29tcG9uZW50KSB7XG4gICAgdGhpcy5kcmF3ZXJJbnN0YW5jZS5hbmltYXRpb25TdGVwJFxuICAgICAgLnBpcGUoZmlsdGVyKHN0ZXAgPT4gc3RlcCA9PT0gJ2hpZGVEb25lJykpXG4gICAgICAuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgdGhpcy5hZnRlckNsb3NlZCQubmV4dCh0aGlzLnJlc3VsdCk7XG4gICAgICAgIHRoaXMuYWZ0ZXJDbG9zZWQkLmNvbXBsZXRlKCk7XG4gICAgICB9KTtcbiAgfVxuXG4gIG9wZW4oKSB7XG4gICAgdGhpcy5kcmF3ZXJJbnN0YW5jZS5zaG93KCk7XG4gIH1cblxuICBjbG9zZShyZXN1bHQ/OiBSKTogdm9pZCB7XG4gICAgdGhpcy5yZXN1bHQgPSByZXN1bHQ7XG4gICAgdGhpcy5kcmF3ZXJJbnN0YW5jZS5oaWRlKCk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -4,8 +4,8 @@ import { CommonModule } from '@angular/common';
|
|
|
4
4
|
import { NgModule } from '@angular/core';
|
|
5
5
|
import { IconModule } from '../icon';
|
|
6
6
|
import { DrawerComponent } from './component/drawer.component';
|
|
7
|
-
import { DrawerContentDirective, DrawerFooterDirective, DrawerHeaderDirective, } from './component/helper-directives';
|
|
8
7
|
import { DrawerService } from './drawer.service';
|
|
8
|
+
import { DrawerContentDirective, DrawerFooterDirective, DrawerHeaderDirective, } from './helper-directives';
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
10
|
const COMMON = [
|
|
11
11
|
DrawerComponent,
|
|
@@ -22,7 +22,7 @@ export class DrawerModule {
|
|
|
22
22
|
DrawerHeaderDirective,
|
|
23
23
|
DrawerContentDirective,
|
|
24
24
|
DrawerFooterDirective] });
|
|
25
|
-
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: DrawerModule, providers: [DrawerService], imports: [CommonModule, IconModule, OverlayModule, PortalModule
|
|
25
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: DrawerModule, providers: [DrawerService], imports: [CommonModule, IconModule, OverlayModule, PortalModule] });
|
|
26
26
|
}
|
|
27
27
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: DrawerModule, decorators: [{
|
|
28
28
|
type: NgModule,
|
|
@@ -32,4 +32,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
32
32
|
providers: [DrawerService],
|
|
33
33
|
}]
|
|
34
34
|
}] });
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhd2VyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kcmF3ZXIvZHJhd2VyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDckQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFFckMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQy9ELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNqRCxPQUFPLEVBQ0wsc0JBQXNCLEVBQ3RCLHFCQUFxQixFQUNyQixxQkFBcUIsR0FDdEIsTUFBTSxxQkFBcUIsQ0FBQzs7QUFFN0IsTUFBTSxNQUFNLEdBQUc7SUFDYixlQUFlO0lBQ2YscUJBQXFCO0lBQ3JCLHNCQUFzQjtJQUN0QixxQkFBcUI7Q0FDdEIsQ0FBQztBQU9GLE1BQU0sT0FBTyxZQUFZO3VHQUFaLFlBQVk7d0dBQVosWUFBWSxZQUpiLFlBQVksRUFBRSxVQUFVLEVBQUUsYUFBYSxFQUFFLFlBQVksRUFQL0QsZUFBZTtZQUNmLHFCQUFxQjtZQUNyQixzQkFBc0I7WUFDdEIscUJBQXFCLGFBSHJCLGVBQWU7WUFDZixxQkFBcUI7WUFDckIsc0JBQXNCO1lBQ3RCLHFCQUFxQjt3R0FRVixZQUFZLGFBRlosQ0FBQyxhQUFhLENBQUMsWUFGaEIsWUFBWSxFQUFFLFVBQVUsRUFBRSxhQUFhLEVBQUUsWUFBWTs7MkZBSXBELFlBQVk7a0JBTHhCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLFVBQVUsRUFBRSxhQUFhLEVBQUUsWUFBWSxFQUFFLEdBQUcsTUFBTSxDQUFDO29CQUMzRSxPQUFPLEVBQUUsTUFBTTtvQkFDZixTQUFTLEVBQUUsQ0FBQyxhQUFhLENBQUM7aUJBQzNCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT3ZlcmxheU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcbmltcG9ydCB7IFBvcnRhbE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9wb3J0YWwnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEljb25Nb2R1bGUgfSBmcm9tICcuLi9pY29uJztcblxuaW1wb3J0IHsgRHJhd2VyQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnQvZHJhd2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEcmF3ZXJTZXJ2aWNlIH0gZnJvbSAnLi9kcmF3ZXIuc2VydmljZSc7XG5pbXBvcnQge1xuICBEcmF3ZXJDb250ZW50RGlyZWN0aXZlLFxuICBEcmF3ZXJGb290ZXJEaXJlY3RpdmUsXG4gIERyYXdlckhlYWRlckRpcmVjdGl2ZSxcbn0gZnJvbSAnLi9oZWxwZXItZGlyZWN0aXZlcyc7XG5cbmNvbnN0IENPTU1PTiA9IFtcbiAgRHJhd2VyQ29tcG9uZW50LFxuICBEcmF3ZXJIZWFkZXJEaXJlY3RpdmUsXG4gIERyYXdlckNvbnRlbnREaXJlY3RpdmUsXG4gIERyYXdlckZvb3RlckRpcmVjdGl2ZSxcbl07XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIEljb25Nb2R1bGUsIE92ZXJsYXlNb2R1bGUsIFBvcnRhbE1vZHVsZSwgLi4uQ09NTU9OXSxcbiAgZXhwb3J0czogQ09NTU9OLFxuICBwcm92aWRlcnM6IFtEcmF3ZXJTZXJ2aWNlXSxcbn0pXG5leHBvcnQgY2xhc3MgRHJhd2VyTW9kdWxlIHt9XG4iXX0=
|
|
@@ -1,47 +1,94 @@
|
|
|
1
|
+
import { OverlayConfig } from '@angular/cdk/overlay';
|
|
1
2
|
import { ComponentPortal } from '@angular/cdk/portal';
|
|
2
3
|
import { Injectable } from '@angular/core';
|
|
3
|
-
import { Subject, takeUntil } from 'rxjs';
|
|
4
|
-
import {
|
|
4
|
+
import { debounceTime, filter, fromEvent, Subject, takeUntil } from 'rxjs';
|
|
5
|
+
import { DrawerInternalComponent } from './component/internal/internal.component';
|
|
6
|
+
import { DrawerRef } from './drawer-ref';
|
|
5
7
|
import * as i0 from "@angular/core";
|
|
6
8
|
import * as i1 from "@angular/cdk/overlay";
|
|
9
|
+
const DRAWER_OVERLAY_CLASS = 'aui-drawer-overlay';
|
|
7
10
|
export class DrawerService {
|
|
8
11
|
overlay;
|
|
9
|
-
drawerRef;
|
|
10
12
|
overlayRef;
|
|
11
|
-
|
|
13
|
+
options;
|
|
14
|
+
drawerRef;
|
|
15
|
+
invisible$ = new Subject();
|
|
16
|
+
drawerInternalComponentRef;
|
|
12
17
|
constructor(overlay) {
|
|
13
18
|
this.overlay = overlay;
|
|
14
19
|
}
|
|
15
20
|
open(options) {
|
|
16
|
-
this.drawerRef?.instance?.dispose();
|
|
17
|
-
this.createDrawer();
|
|
18
21
|
this.updateOptions(options);
|
|
19
|
-
|
|
22
|
+
this.createOverlay();
|
|
23
|
+
this.createDrawer();
|
|
24
|
+
this.drawerRef = new DrawerRef(this.drawerInternalComponentRef.instance);
|
|
25
|
+
this.drawerRef.open();
|
|
26
|
+
return this.drawerRef;
|
|
20
27
|
}
|
|
21
28
|
updateOptions(options) {
|
|
22
|
-
|
|
29
|
+
this.options = options;
|
|
30
|
+
}
|
|
31
|
+
createOverlay() {
|
|
32
|
+
if (!this.overlayRef) {
|
|
33
|
+
this.overlayRef = this.overlay.create(this.getOverlayConfig());
|
|
34
|
+
}
|
|
35
|
+
this.overlayRef
|
|
36
|
+
.outsidePointerEvents()
|
|
37
|
+
.pipe(takeUntil(this.invisible$))
|
|
38
|
+
.subscribe(event => {
|
|
39
|
+
if (this.overlayRef &&
|
|
40
|
+
this.options.hideOnClickOutside &&
|
|
41
|
+
event.target instanceof Node &&
|
|
42
|
+
!this.overlayRef.hostElement?.parentNode?.contains(event.target)) {
|
|
43
|
+
event.stopPropagation();
|
|
44
|
+
event.preventDefault();
|
|
45
|
+
this.drawerRef.close();
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
this.overlayRef.getConfig().scrollStrategy.enable();
|
|
49
|
+
if (this.options.mask) {
|
|
50
|
+
fromEvent(window, 'resize')
|
|
51
|
+
.pipe(debounceTime(100), filter(() => document.documentElement.scrollHeight > window.innerHeight), takeUntil(this.invisible$))
|
|
52
|
+
.subscribe(() => {
|
|
53
|
+
this.overlayRef.getConfig().scrollStrategy.enable();
|
|
54
|
+
});
|
|
55
|
+
}
|
|
23
56
|
}
|
|
24
57
|
createDrawer() {
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
58
|
+
if (this.drawerInternalComponentRef) {
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
const drawerInternalComponentRef = this.overlayRef.attach(new ComponentPortal((DrawerInternalComponent)));
|
|
62
|
+
drawerInternalComponentRef.instance.options = this.options;
|
|
63
|
+
drawerInternalComponentRef.instance.animationStep$.subscribe(step => {
|
|
64
|
+
if (step === 'hideDone') {
|
|
65
|
+
this.invisible$.next();
|
|
66
|
+
this.overlayRef?.getConfig().scrollStrategy.disable();
|
|
67
|
+
}
|
|
31
68
|
});
|
|
32
|
-
this.
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
this.
|
|
38
|
-
this.
|
|
69
|
+
this.drawerInternalComponentRef = drawerInternalComponentRef;
|
|
70
|
+
}
|
|
71
|
+
getOverlayConfig() {
|
|
72
|
+
return new OverlayConfig({
|
|
73
|
+
panelClass: DRAWER_OVERLAY_CLASS,
|
|
74
|
+
positionStrategy: this.overlay.position().global(),
|
|
75
|
+
scrollStrategy: this.options.mask
|
|
76
|
+
? this.overlay.scrollStrategies.block()
|
|
77
|
+
: this.overlay.scrollStrategies.noop(),
|
|
39
78
|
});
|
|
40
79
|
}
|
|
80
|
+
ngOnDestroy() {
|
|
81
|
+
this.invisible$.next();
|
|
82
|
+
if (this.overlayRef) {
|
|
83
|
+
this.overlayRef.getConfig().scrollStrategy.disable();
|
|
84
|
+
this.overlayRef.dispose();
|
|
85
|
+
this.overlayRef = null;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
41
88
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: DrawerService, deps: [{ token: i1.Overlay }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
42
89
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: DrawerService });
|
|
43
90
|
}
|
|
44
91
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: DrawerService, decorators: [{
|
|
45
92
|
type: Injectable
|
|
46
93
|
}], ctorParameters: function () { return [{ type: i1.Overlay }]; } });
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer.service.js","sourceRoot":"","sources":["../../../src/drawer/drawer.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { ComponentRef, Injectable } from '@angular/core';\nimport { debounceTime, filter, fromEvent, Subject, takeUntil } from 'rxjs';\n\nimport { DrawerInternalComponent } from './component/internal/internal.component';\nimport { DrawerRef } from './drawer-ref';\nimport { DrawerOptions } from './types';\n\nconst DRAWER_OVERLAY_CLASS = 'aui-drawer-overlay';\n\n@Injectable()\nexport class DrawerService<T = unknown, C extends object = any, R = any> {\n  private overlayRef: OverlayRef;\n  options: DrawerOptions<T, C>;\n  drawerRef: DrawerRef<R>;\n  invisible$ = new Subject<void>();\n  private drawerInternalComponentRef: ComponentRef<\n    DrawerInternalComponent<T, C>\n  >;\n\n  constructor(private readonly overlay: Overlay) {}\n\n  open(options: DrawerOptions<T, C>) {\n    this.updateOptions(options);\n    this.createOverlay();\n    this.createDrawer();\n    this.drawerRef = new DrawerRef(this.drawerInternalComponentRef.instance);\n    this.drawerRef.open();\n\n    return this.drawerRef;\n  }\n\n  updateOptions(options: DrawerOptions<T, C>): void {\n    this.options = options;\n  }\n\n  private createOverlay() {\n    if (!this.overlayRef) {\n      this.overlayRef = this.overlay.create(this.getOverlayConfig());\n    }\n\n    this.overlayRef\n      .outsidePointerEvents()\n      .pipe(takeUntil(this.invisible$))\n      .subscribe(event => {\n        // 判断鼠标点击事件的 target 是否为 overlay-container 的子节点，如果是，则不关闭 drawer。\n        // 为了避免点击 drawer 里的 tooltip 后 drawer 被关闭。\n        if (\n          this.overlayRef &&\n          this.options.hideOnClickOutside &&\n          event.target instanceof Node &&\n          !this.overlayRef.hostElement?.parentNode?.contains(event.target)\n        ) {\n          event.stopPropagation();\n          event.preventDefault();\n          this.drawerRef.close();\n        }\n      });\n\n    this.overlayRef.getConfig().scrollStrategy.enable();\n    if (this.options.mask) {\n      // Issues: https://github.com/angular/components/issues/10841\n      // scrollStrategy 为 Block 时，若创建 Overlay 时，高度不足以出现滚动，则 scrollStrategy 不会生效\n      fromEvent(window, 'resize')\n        .pipe(\n          debounceTime(100),\n          filter(\n            () => document.documentElement.scrollHeight > window.innerHeight,\n          ),\n          takeUntil(this.invisible$),\n        )\n        .subscribe(() => {\n          this.overlayRef.getConfig().scrollStrategy.enable();\n        });\n    }\n  }\n\n  private createDrawer() {\n    if (this.drawerInternalComponentRef) {\n      return;\n    }\n    const drawerInternalComponentRef = this.overlayRef.attach(\n      new ComponentPortal(DrawerInternalComponent<T, C>),\n    );\n    drawerInternalComponentRef.instance.options = this.options;\n    drawerInternalComponentRef.instance.animationStep$.subscribe(step => {\n      if (step === 'hideDone') {\n        this.invisible$.next();\n        this.overlayRef?.getConfig().scrollStrategy.disable();\n      }\n    });\n    this.drawerInternalComponentRef = drawerInternalComponentRef;\n  }\n\n  private getOverlayConfig(): OverlayConfig {\n    return new OverlayConfig({\n      panelClass: DRAWER_OVERLAY_CLASS,\n      positionStrategy: this.overlay.position().global(),\n      scrollStrategy: this.options.mask\n        ? this.overlay.scrollStrategies.block()\n        : this.overlay.scrollStrategies.noop(),\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.invisible$.next();\n    if (this.overlayRef) {\n      this.overlayRef.getConfig().scrollStrategy.disable();\n      this.overlayRef.dispose();\n      this.overlayRef = null;\n    }\n  }\n}\n"]}
|
|
@@ -33,4 +33,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
33
33
|
standalone: true,
|
|
34
34
|
}]
|
|
35
35
|
}] });
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscGVyLWRpcmVjdGl2ZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZHJhd2VyL2hlbHBlci1kaXJlY3RpdmVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUtBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTTFDLE1BQU0sT0FBTyxxQkFBcUI7dUdBQXJCLHFCQUFxQjsyRkFBckIscUJBQXFCOzsyRkFBckIscUJBQXFCO2tCQUpqQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxtQkFBbUI7b0JBQzdCLFVBQVUsRUFBRSxJQUFJO2lCQUNqQjs7QUFPRCxNQUFNLE9BQU8sc0JBQXNCO3VHQUF0QixzQkFBc0I7MkZBQXRCLHNCQUFzQjs7MkZBQXRCLHNCQUFzQjtrQkFKbEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsb0JBQW9CO29CQUM5QixVQUFVLEVBQUUsSUFBSTtpQkFDakI7O0FBT0QsTUFBTSxPQUFPLHFCQUFxQjt1R0FBckIscUJBQXFCOzJGQUFyQixxQkFBcUI7OzJGQUFyQixxQkFBcUI7a0JBSmpDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLG1CQUFtQjtvQkFDN0IsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb25cbiAqIEBtb2R1bGUgcGFnZS1ndWFyZFxuICovXG5cbmltcG9ydCB7IERpcmVjdGl2ZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbYXVpRHJhd2VySGVhZGVyXScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIERyYXdlckhlYWRlckRpcmVjdGl2ZSB7fVxuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbYXVpRHJhd2VyQ29udGVudF0nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBEcmF3ZXJDb250ZW50RGlyZWN0aXZlIHt9XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1thdWlEcmF3ZXJGb290ZXJdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgRHJhd2VyRm9vdGVyRGlyZWN0aXZlIHt9XG4iXX0=
|
package/esm2022/drawer/index.mjs
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
export * from './component/drawer.component';
|
|
2
|
-
export * from './component/drawer-ref';
|
|
3
|
-
export * from './component/helper-directives';
|
|
4
2
|
export * from './drawer.module';
|
|
5
3
|
export * from './drawer.service';
|
|
6
|
-
|
|
4
|
+
export * from './drawer-ref';
|
|
5
|
+
export * from './helper-directives';
|
|
6
|
+
export * from './types';
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZHJhd2VyL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudC9kcmF3ZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZHJhd2VyLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2RyYXdlci5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vZHJhd2VyLXJlZic7XG5leHBvcnQgKiBmcm9tICcuL2hlbHBlci1kaXJlY3RpdmVzJztcbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMnO1xuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZHJhd2VyL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnRUeXBlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3BvcnRhbCc7XG5pbXBvcnQgeyBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgdHlwZSBEcmF3ZXJTaXplID0gJ3NtYWxsJyB8ICdtZWRpdW0nIHwgJ2JpZyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRHJhd2VyT3B0aW9uczxUID0gdW5rbm93biwgQyBleHRlbmRzIG9iamVjdCA9IGFueT4ge1xuICB0aXRsZT86IHN0cmluZyB8IFRlbXBsYXRlUmVmPEM+O1xuICBjb250ZW50PzogQ29tcG9uZW50VHlwZTxUPiB8IFRlbXBsYXRlUmVmPEM+O1xuICBmb290ZXI/OiBzdHJpbmcgfCBUZW1wbGF0ZVJlZjxDPjtcbiAgY29udGVudFBhcmFtcz86IEM7IC8vIOS4jeS7heS9nOS4umNvbnRlbnTnmoTlj4LmlbDvvIzlkIzml7bmmK90aXRsZeWSjGZvb3RlcueahOS4iuS4i+aWh1xuICB3aWR0aD86IG51bWJlcjtcbiAgc2l6ZT86IERyYXdlclNpemU7IC8vIOWGhee9rueahOWuveW6puWwuuWvuO+8jOS5n+WPr+S7peS9v+eUqCB3aWR0aCDoh6rlrprkuYlcbiAgb2Zmc2V0WT86IHN0cmluZztcbiAgZGl2aWRlcj86IGJvb2xlYW47XG4gIGRyYXdlckNsYXNzPzogc3RyaW5nO1xuICB2aXNpYmxlPzogYm9vbGVhbjtcbiAgc2hvd0Nsb3NlPzogYm9vbGVhbjtcbiAgbWFzaz86IGJvb2xlYW47XG4gIG1hc2tDbG9zYWJsZT86IGJvb2xlYW47IC8vIOeCueWHu+iDjOaZr+aYr+WQpuWFs+mXreaKveWxiVxuICBoaWRlT25DbGlja091dHNpZGU/OiBib29sZWFuOyAvLyDlnKjmir3lsYnlpJbngrnlh7vmmK/lkKblhbPpl63mir3lsYnvvIzkuI4gbWFza0Nsb3NhYmxlIOeahOWMuuWIq+aYr+aYr+WQpuaciSBtYXNrXG59XG4iXX0=
|