@alauda/ui 7.2.1-beta.7 → 7.2.1-beta.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/drawer/component/drawer.component.d.ts +14 -47
- package/drawer/component/internal/internal.component.d.ts +32 -0
- package/drawer/drawer-ref.d.ts +12 -0
- package/drawer/drawer.module.d.ts +1 -1
- package/drawer/drawer.service.d.ts +14 -23
- package/drawer/index.d.ts +3 -2
- package/drawer/types.d.ts +23 -0
- package/esm2022/autocomplete/suggestion/suggestion.component.mjs +8 -4
- package/esm2022/drawer/component/drawer.component.mjs +31 -196
- package/esm2022/drawer/component/internal/internal.component.mjs +161 -0
- package/esm2022/drawer/drawer-ref.mjs +27 -0
- package/esm2022/drawer/drawer.module.mjs +3 -3
- package/esm2022/drawer/drawer.service.mjs +97 -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 +7 -0
- package/esm2022/form/form-item/form-item.component.mjs +3 -3
- package/fesm2022/alauda-ui.mjs +326 -236
- 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
|
@@ -1,28 +1,12 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import { Subject, debounceTime, filter, fromEvent, takeUntil, } from 'rxjs';
|
|
7
|
-
import { IconComponent } from '../../icon/icon.component';
|
|
8
|
-
import { isTemplateRef } from '../../utils';
|
|
9
|
-
import { DrawerRef, DrawerSize } from './drawer-ref';
|
|
10
|
-
import { DrawerContentDirective, DrawerFooterDirective, DrawerHeaderDirective, } from './helper-directives';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ContentChild, EventEmitter, Input, Output, TemplateRef, } from '@angular/core';
|
|
2
|
+
import { first } from 'rxjs';
|
|
3
|
+
import { DrawerService } from '../drawer.service';
|
|
4
|
+
import { DrawerContentDirective, DrawerFooterDirective, DrawerHeaderDirective, } from '../helper-directives';
|
|
5
|
+
import { DrawerSize } from '../types';
|
|
11
6
|
import * as i0 from "@angular/core";
|
|
12
|
-
import * as i1 from "
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
const DRAWER_OVERLAY_CLASS = 'aui-drawer-overlay';
|
|
16
|
-
const SIZE_MAPPER = {
|
|
17
|
-
[DrawerSize.Small]: 400,
|
|
18
|
-
[DrawerSize.Medium]: 600,
|
|
19
|
-
[DrawerSize.Big]: 800,
|
|
20
|
-
};
|
|
21
|
-
export class DrawerComponent extends DrawerRef {
|
|
22
|
-
viewContainerRef;
|
|
23
|
-
overlay;
|
|
24
|
-
injector;
|
|
25
|
-
cdr;
|
|
7
|
+
import * as i1 from "../drawer.service";
|
|
8
|
+
export class DrawerComponent {
|
|
9
|
+
drawerService;
|
|
26
10
|
title;
|
|
27
11
|
footer;
|
|
28
12
|
size = DrawerSize.Medium;
|
|
@@ -35,64 +19,12 @@ export class DrawerComponent extends DrawerRef {
|
|
|
35
19
|
mask;
|
|
36
20
|
maskClosable;
|
|
37
21
|
divider = true;
|
|
38
|
-
_value = SIZE_MAPPER[DrawerSize.Medium];
|
|
39
|
-
set width(value) {
|
|
40
|
-
this._value = value;
|
|
41
|
-
}
|
|
42
|
-
get width() {
|
|
43
|
-
return this._value;
|
|
44
|
-
}
|
|
45
|
-
get drawerClasses() {
|
|
46
|
-
return {
|
|
47
|
-
'aui-drawer': true,
|
|
48
|
-
hasDivider: this.divider,
|
|
49
|
-
...(this.drawerClass ? { [this.drawerClass]: true } : null),
|
|
50
|
-
};
|
|
51
|
-
}
|
|
52
|
-
afterClosed$ = new Subject();
|
|
53
|
-
get afterClosed() {
|
|
54
|
-
return this.afterClosed$.asObservable();
|
|
55
|
-
}
|
|
56
|
-
afterOpen$ = new Subject();
|
|
57
|
-
get afterOpen() {
|
|
58
|
-
return this.afterOpen$.asObservable();
|
|
59
|
-
}
|
|
60
|
-
drawerViewInit = new EventEmitter();
|
|
61
22
|
close = new EventEmitter();
|
|
62
|
-
drawerTemplate;
|
|
63
|
-
bodyPortalOutlet;
|
|
64
23
|
titleTemplate;
|
|
65
|
-
|
|
24
|
+
contentTemplateOrComponent;
|
|
66
25
|
footerTemplate;
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
componentInstance = null;
|
|
70
|
-
contentParams;
|
|
71
|
-
overlayRef;
|
|
72
|
-
portal;
|
|
73
|
-
templateContext = {};
|
|
74
|
-
get transform() {
|
|
75
|
-
return `translateX(${this.visible ? 0 : '100%'})`;
|
|
76
|
-
}
|
|
77
|
-
constructor(viewContainerRef, overlay, injector, cdr) {
|
|
78
|
-
super();
|
|
79
|
-
this.viewContainerRef = viewContainerRef;
|
|
80
|
-
this.overlay = overlay;
|
|
81
|
-
this.injector = injector;
|
|
82
|
-
this.cdr = cdr;
|
|
83
|
-
}
|
|
84
|
-
ngOnInit() {
|
|
85
|
-
this.attachOverlay();
|
|
86
|
-
this.updateBodyOverflow();
|
|
87
|
-
this.templateContext = { $implicit: this.contentParams };
|
|
88
|
-
if (this.mask) {
|
|
89
|
-
fromEvent(window, 'resize')
|
|
90
|
-
.pipe(debounceTime(100), filter(() => document.documentElement.scrollHeight > window.innerHeight), takeUntil(this.onDestroy$))
|
|
91
|
-
.subscribe(() => {
|
|
92
|
-
this.overlayRef.getConfig().scrollStrategy.enable();
|
|
93
|
-
});
|
|
94
|
-
}
|
|
95
|
-
this.cdr.detectChanges();
|
|
26
|
+
constructor(drawerService) {
|
|
27
|
+
this.drawerService = drawerService;
|
|
96
28
|
}
|
|
97
29
|
ngOnChanges(changes) {
|
|
98
30
|
const { visible } = changes;
|
|
@@ -102,121 +34,34 @@ export class DrawerComponent extends DrawerRef {
|
|
|
102
34
|
this.open();
|
|
103
35
|
}
|
|
104
36
|
else if (!visible.firstChange) {
|
|
105
|
-
this.
|
|
37
|
+
this.drawerService.close();
|
|
106
38
|
}
|
|
107
39
|
}
|
|
108
40
|
}
|
|
109
41
|
ngAfterViewInit() {
|
|
110
|
-
this.
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
}, 0);
|
|
114
|
-
}
|
|
115
|
-
attachOverlay() {
|
|
116
|
-
if (!this.overlayRef) {
|
|
117
|
-
this.portal = new TemplatePortal(this.drawerTemplate, this.viewContainerRef);
|
|
118
|
-
this.overlayRef = this.overlay.create(this.getOverlayConfig());
|
|
119
|
-
}
|
|
120
|
-
if (this.overlayRef) {
|
|
121
|
-
this.overlayRef.attach(this.portal);
|
|
122
|
-
this.overlayRef
|
|
123
|
-
.outsidePointerEvents()
|
|
124
|
-
.pipe(takeUntil(this.onDestroy$))
|
|
125
|
-
.subscribe(event => {
|
|
126
|
-
if (this.visible &&
|
|
127
|
-
this.hideOnClickOutside &&
|
|
128
|
-
event.target instanceof Node &&
|
|
129
|
-
!this.overlayRef.hostElement?.parentNode?.contains(event.target)) {
|
|
130
|
-
event.stopPropagation();
|
|
131
|
-
event.preventDefault();
|
|
132
|
-
this.dispose();
|
|
133
|
-
}
|
|
134
|
-
});
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
getOverlayConfig() {
|
|
138
|
-
return new OverlayConfig({
|
|
139
|
-
panelClass: DRAWER_OVERLAY_CLASS,
|
|
140
|
-
positionStrategy: this.overlay.position().global(),
|
|
141
|
-
scrollStrategy: this.mask
|
|
142
|
-
? this.overlay.scrollStrategies.block()
|
|
143
|
-
: this.overlay.scrollStrategies.noop(),
|
|
144
|
-
});
|
|
145
|
-
}
|
|
146
|
-
attachBodyContent() {
|
|
147
|
-
this.bodyPortalOutlet?.dispose();
|
|
148
|
-
const content = this.content || this.contentTemplate;
|
|
149
|
-
if (content instanceof Type) {
|
|
150
|
-
const componentPortal = new ComponentPortal(content, null, Injector.create({
|
|
151
|
-
providers: [
|
|
152
|
-
{
|
|
153
|
-
provide: DATA,
|
|
154
|
-
useValue: this.contentParams,
|
|
155
|
-
},
|
|
156
|
-
],
|
|
157
|
-
parent: this.injector,
|
|
158
|
-
}));
|
|
159
|
-
const componentRef = this.bodyPortalOutlet?.attachComponentPortal(componentPortal);
|
|
160
|
-
this.componentInstance = componentRef.instance;
|
|
161
|
-
Object.assign(componentRef.instance, this.contentParams);
|
|
162
|
-
componentRef.changeDetectorRef.detectChanges();
|
|
163
|
-
}
|
|
164
|
-
}
|
|
165
|
-
updateBodyOverflow() {
|
|
166
|
-
if (this.overlayRef) {
|
|
167
|
-
if (this.visible) {
|
|
168
|
-
this.overlayRef.getConfig().scrollStrategy.enable();
|
|
169
|
-
}
|
|
170
|
-
else {
|
|
171
|
-
this.overlayRef.getConfig().scrollStrategy.disable();
|
|
172
|
-
}
|
|
173
|
-
}
|
|
42
|
+
this.title = this.title || this.titleTemplate;
|
|
43
|
+
this.content = this.content || this.contentTemplateOrComponent;
|
|
44
|
+
this.footer = this.footer || this.footerTemplate;
|
|
174
45
|
}
|
|
175
46
|
open() {
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
this.cdr.markForCheck();
|
|
181
|
-
}
|
|
182
|
-
dispose(result = null) {
|
|
183
|
-
this.visible = false;
|
|
184
|
-
this.close.emit();
|
|
185
|
-
this.afterClosed$.next(result);
|
|
186
|
-
this.afterClosed$.complete();
|
|
187
|
-
this.updateBodyOverflow();
|
|
188
|
-
this.cdr.markForCheck();
|
|
189
|
-
}
|
|
190
|
-
disposeOverlay() {
|
|
191
|
-
if (this.overlayRef) {
|
|
192
|
-
this.overlayRef.dispose();
|
|
193
|
-
}
|
|
194
|
-
this.overlayRef = null;
|
|
195
|
-
}
|
|
196
|
-
maskClick() {
|
|
197
|
-
if (this.maskClosable && this.mask) {
|
|
198
|
-
this.dispose();
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
ngOnDestroy() {
|
|
202
|
-
this.onDestroy$.next();
|
|
203
|
-
this.disposeOverlay();
|
|
47
|
+
const ref = this.drawerService.open(this);
|
|
48
|
+
ref.afterClosed.pipe(first()).subscribe(res => {
|
|
49
|
+
this.close.emit(res);
|
|
50
|
+
});
|
|
204
51
|
}
|
|
205
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: DrawerComponent, deps: [{ token:
|
|
206
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: DrawerComponent, isStandalone: true, selector: "aui-drawer", inputs: { title: "title", footer: "footer", size: "size", offsetY: "offsetY", visible: "visible", content: "content", hideOnClickOutside: "hideOnClickOutside", showClose: "showClose", drawerClass: "drawerClass", mask: "mask", maskClosable: "maskClosable", divider: "divider"
|
|
52
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: DrawerComponent, deps: [{ token: i1.DrawerService }], target: i0.ɵɵFactoryTarget.Component });
|
|
53
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: DrawerComponent, isStandalone: true, selector: "aui-drawer", inputs: { title: "title", footer: "footer", size: "size", offsetY: "offsetY", visible: "visible", content: "content", hideOnClickOutside: "hideOnClickOutside", showClose: "showClose", drawerClass: "drawerClass", mask: "mask", maskClosable: "maskClosable", divider: "divider" }, outputs: { close: "close" }, providers: [DrawerService], queries: [{ propertyName: "titleTemplate", first: true, predicate: DrawerHeaderDirective, descendants: true, read: TemplateRef }, { propertyName: "contentTemplateOrComponent", first: true, predicate: DrawerContentDirective, descendants: true, read: TemplateRef }, { propertyName: "footerTemplate", first: true, predicate: DrawerFooterDirective, descendants: true, read: TemplateRef }], usesOnChanges: true, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
207
54
|
}
|
|
208
55
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: DrawerComponent, decorators: [{
|
|
209
56
|
type: Component,
|
|
210
|
-
args: [{
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
], template: "<ng-template #drawerTemplate>\n <div\n *ngIf=\"mask\"\n class=\"aui-drawer-mask\"\n [class.isOpen]=\"visible\"\n (click)=\"maskClick()\"\n ></div>\n <div\n [style.marginTop]=\"offsetY\"\n [ngClass]=\"drawerClasses\"\n [class.isOpen]=\"visible\"\n [ngStyle]=\"{\n transform: transform,\n width: width + 'px'\n }\"\n >\n <div class=\"aui-drawer__content\">\n <div class=\"aui-drawer__body-wrapper\">\n <div class=\"aui-drawer__header\">\n <div class=\"aui-drawer__title\">\n <ng-container\n *ngIf=\"!isTemplateRef(title || titleTemplate); else elseTemplate\"\n >\n {{ title }}\n </ng-container>\n <ng-template #elseTemplate>\n <ng-container\n *ngIf=\"title || titleTemplate\"\n [ngTemplateOutlet]=\"$any(title || titleTemplate)\"\n [ngTemplateOutletContext]=\"templateContext\"\n ></ng-container>\n </ng-template>\n </div>\n <aui-icon\n *ngIf=\"showClose\"\n class=\"aui-drawer__close\"\n icon=\"xmark\"\n (click)=\"dispose()\"\n ></aui-icon>\n </div>\n\n <div\n class=\"aui-drawer__body\"\n cdkScrollable\n >\n <ng-template cdkPortalOutlet></ng-template>\n <ng-container *ngIf=\"isTemplateRef(content || contentTemplate)\">\n <ng-container\n *ngTemplateOutlet=\"\n $any(content || contentTemplate);\n context: templateContext\n \"\n >\n </ng-container>\n </ng-container>\n </div>\n\n <div\n *ngIf=\"footer || footerTemplate\"\n class=\"aui-drawer__footer\"\n >\n <ng-container\n *ngIf=\"!isTemplateRef(footer || footerTemplate); else elseTemplate\"\n >\n {{ footer }}\n </ng-container>\n <ng-template #elseTemplate>\n <ng-container\n *ngIf=\"footer || footerTemplate\"\n [ngTemplateOutlet]=\"$any(footer || footerTemplate)\"\n [ngTemplateOutletContext]=\"templateContext\"\n ></ng-container>\n </ng-template>\n </div>\n </div>\n </div>\n </div>\n</ng-template>\n", styles: [".aui-drawer-mask{position:absolute;top:0;left:0;width:100%;height:0}:root .aui-drawer-mask{background-color:rgba(var(--aui-color-origin-shadow),.4)}html[aui-theme-mode=light] .aui-drawer-mask{background-color:rgba(var(--aui-color-origin-shadow),.4)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-drawer-mask{background-color:rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .aui-drawer-mask{background-color:rgba(var(--aui-color-origin-shadow),.75)}.aui-drawer-mask.isOpen{height:100%}.aui-drawer{position:fixed;top:0;bottom:0;right:0;z-index:9999;transition:transform .3s,opacity .3s,box-shaow .3s;font-size:var(--aui-font-size-m);line-height:var(--aui-line-height-m);font-weight:var(--aui-font-weight-normal);color:rgb(var(--aui-color-main-text))}:root .aui-drawer.isOpen .aui-drawer__content{box-shadow:-2px 0 8px 0 rgba(var(--aui-color-origin-shadow),.2)}html[aui-theme-mode=light] .aui-drawer.isOpen .aui-drawer__content{box-shadow:-2px 0 8px 0 rgba(var(--aui-color-origin-shadow),.2)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-drawer.isOpen .aui-drawer__content{box-shadow:-2px 0 8px 0 rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .aui-drawer.isOpen .aui-drawer__content{box-shadow:-2px 0 8px 0 rgba(var(--aui-color-origin-shadow),.75)}.aui-drawer__content{background-color:rgb(var(--aui-color-n-10));position:absolute;height:100%;right:0;width:100%}.aui-drawer__header{padding:20px;display:flex;flex-shrink:0;justify-content:space-between}.aui-drawer__title{flex:1;font-size:var(--aui-font-size-xxl);line-height:var(--aui-line-height-xxl);font-weight:var(--aui-font-weight-bolder);color:rgb(var(--aui-color-main-text));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.aui-drawer__close{z-index:10;flex-shrink:0;margin-top:2px;margin-left:var(--aui-spacing-xl);display:flex;justify-content:center;align-items:center;width:24px;height:24px;font-size:var(--aui-icon-size-l);color:rgb(var(--aui-color-secondary-text));border-radius:var(--aui-border-radius-m);cursor:pointer}.aui-drawer__close:hover{color:rgb(var(--aui-color-primary));background-color:rgb(var(--aui-color-p-6))}.aui-drawer__close:active{color:rgb(var(--aui-color-p-0));background-color:rgb(var(--aui-color-p-5))}.aui-drawer__body-wrapper{width:100%;height:100%;display:flex;flex-flow:column nowrap;position:relative;z-index:1}.aui-drawer__body{padding:0 20px;overflow:hidden;overflow-y:auto;height:100%}.aui-drawer__footer{padding:20px}.aui-drawer.hasDivider .aui-drawer__header{padding-bottom:16px;border-bottom:1px solid rgb(var(--aui-color-n-8))}.aui-drawer.hasDivider .aui-drawer__body{padding:16px 20px}.aui-drawer.hasDivider .aui-drawer__footer{padding-top:16px;border-top:1px solid rgb(var(--aui-color-n-8))}\n"] }]
|
|
219
|
-
}], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i1.Overlay }, { type: i0.Injector }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { title: [{
|
|
57
|
+
args: [{
|
|
58
|
+
selector: 'aui-drawer',
|
|
59
|
+
template: '',
|
|
60
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
61
|
+
standalone: true,
|
|
62
|
+
providers: [DrawerService],
|
|
63
|
+
}]
|
|
64
|
+
}], ctorParameters: function () { return [{ type: i1.DrawerService }]; }, propDecorators: { title: [{
|
|
220
65
|
type: Input
|
|
221
66
|
}], footer: [{
|
|
222
67
|
type: Input
|
|
@@ -240,26 +85,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
240
85
|
type: Input
|
|
241
86
|
}], divider: [{
|
|
242
87
|
type: Input
|
|
243
|
-
}], width: [{
|
|
244
|
-
type: Input
|
|
245
|
-
}], drawerViewInit: [{
|
|
246
|
-
type: Output
|
|
247
88
|
}], close: [{
|
|
248
89
|
type: Output
|
|
249
|
-
}], drawerTemplate: [{
|
|
250
|
-
type: ViewChild,
|
|
251
|
-
args: ['drawerTemplate', { static: true }]
|
|
252
|
-
}], bodyPortalOutlet: [{
|
|
253
|
-
type: ViewChild,
|
|
254
|
-
args: [CdkPortalOutlet, { static: false }]
|
|
255
90
|
}], titleTemplate: [{
|
|
256
91
|
type: ContentChild,
|
|
257
92
|
args: [DrawerHeaderDirective, { read: TemplateRef }]
|
|
258
|
-
}],
|
|
93
|
+
}], contentTemplateOrComponent: [{
|
|
259
94
|
type: ContentChild,
|
|
260
95
|
args: [DrawerContentDirective, { read: TemplateRef }]
|
|
261
96
|
}], footerTemplate: [{
|
|
262
97
|
type: ContentChild,
|
|
263
98
|
args: [DrawerFooterDirective, { read: TemplateRef }]
|
|
264
99
|
}] } });
|
|
265
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer.component.js","sourceRoot":"","sources":["../../../../src/drawer/component/drawer.component.ts","../../../../src/drawer/component/drawer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentType,\n  Overlay,\n  OverlayConfig,\n  OverlayRef,\n} from '@angular/cdk/overlay';\nimport {\n  CdkPortalOutlet,\n  ComponentPortal,\n  TemplatePortal,\n  PortalModule,\n} from '@angular/cdk/portal';\nimport { CdkScrollable } from '@angular/cdk/scrolling';\nimport { NgIf, NgClass, NgStyle, NgTemplateOutlet } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  EventEmitter,\n  InjectionToken,\n  Injector,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  Type,\n  ViewChild,\n  ViewContainerRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  Observable,\n  Subject,\n  debounceTime,\n  filter,\n  fromEvent,\n  takeUntil,\n} from 'rxjs';\n\nimport { IconComponent } from '../../icon/icon.component';\nimport { isTemplateRef } from '../../utils';\n\nimport { DrawerRef, DrawerSize } from './drawer-ref';\nimport {\n  DrawerContentDirective,\n  DrawerFooterDirective,\n  DrawerHeaderDirective,\n} from './helper-directives';\n\nexport const DATA = new InjectionToken('drawer-data');\n\nconst DRAWER_OVERLAY_CLASS = 'aui-drawer-overlay';\n\nconst SIZE_MAPPER = {\n  [DrawerSize.Small]: 400,\n  [DrawerSize.Medium]: 600,\n  [DrawerSize.Big]: 800,\n};\n\n@Component({\n  selector: 'aui-drawer',\n  templateUrl: './drawer.component.html',\n  styleUrls: ['./drawer.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    NgIf,\n    NgClass,\n    NgStyle,\n    NgTemplateOutlet,\n    IconComponent,\n    CdkScrollable,\n    PortalModule,\n  ],\n})\nexport class DrawerComponent<\n    T = ComponentType<unknown>,\n    R = unknown,\n    D = unknown,\n  >\n  extends DrawerRef<T, R>\n  implements OnInit, AfterViewInit, OnChanges, OnDestroy\n{\n  @Input()\n  title: string | TemplateRef<unknown>;\n\n  @Input()\n  footer: string | TemplateRef<unknown>;\n\n  @Input()\n  size: DrawerSize = DrawerSize.Medium;\n\n  @Input()\n  offsetY = '0px';\n\n  @Input() visible: boolean;\n\n  @Input()\n  content: TemplateRef<T> | ComponentType<T>;\n\n  @Input()\n  hideOnClickOutside = false;\n\n  @Input()\n  showClose = true;\n\n  @Input()\n  drawerClass: string;\n\n  @Input()\n  mask: boolean;\n\n  @Input()\n  maskClosable: boolean;\n\n  @Input()\n  divider = true;\n\n  private _value = SIZE_MAPPER[DrawerSize.Medium];\n  @Input()\n  set width(value: number) {\n    this._value = value;\n  }\n\n  get width() {\n    return this._value;\n  }\n\n  get drawerClasses(): Record<string, boolean> {\n    return {\n      'aui-drawer': true,\n      hasDivider: this.divider,\n      ...(this.drawerClass ? { [this.drawerClass]: true } : null),\n    };\n  }\n\n  private readonly afterClosed$ = new Subject<R>();\n\n  get afterClosed(): Observable<R> {\n    return this.afterClosed$.asObservable();\n  }\n\n  private readonly afterOpen$ = new Subject<void>();\n\n  get afterOpen(): Observable<void> {\n    return this.afterOpen$.asObservable();\n  }\n\n  @Output()\n  drawerViewInit = new EventEmitter<void>();\n\n  @Output() readonly close = new EventEmitter<MouseEvent>();\n\n  @ViewChild('drawerTemplate', { static: true })\n  drawerTemplate: TemplateRef<void>;\n\n  @ViewChild(CdkPortalOutlet, { static: false })\n  bodyPortalOutlet: CdkPortalOutlet;\n\n  @ContentChild(DrawerHeaderDirective, { read: TemplateRef })\n  titleTemplate: TemplateRef<T>;\n\n  @ContentChild(DrawerContentDirective, { read: TemplateRef })\n  contentTemplate: TemplateRef<T> | ComponentType<T>;\n\n  @ContentChild(DrawerFooterDirective, { read: TemplateRef })\n  footerTemplate: TemplateRef<T>;\n\n  onDestroy$ = new Subject<void>();\n\n  isTemplateRef = isTemplateRef;\n\n  componentInstance: T | null = null;\n\n  contentParams: D;\n  overlayRef: OverlayRef;\n  portal: TemplatePortal;\n  templateContext = {};\n  get transform() {\n    return `translateX(${this.visible ? 0 : '100%'})`;\n  }\n\n  constructor(\n    private readonly viewContainerRef: ViewContainerRef,\n    private readonly overlay: Overlay,\n    private readonly injector: Injector,\n    private readonly cdr: ChangeDetectorRef,\n  ) {\n    super();\n  }\n\n  ngOnInit() {\n    this.attachOverlay();\n    this.updateBodyOverflow();\n    this.templateContext = { $implicit: this.contentParams };\n\n    if (this.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.onDestroy$),\n        )\n        .subscribe(() => {\n          this.overlayRef.getConfig().scrollStrategy.enable();\n        });\n    }\n\n    this.cdr.detectChanges();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const { visible } = changes;\n    if (visible) {\n      const value = visible.currentValue;\n      if (value) {\n        this.open();\n      } else if (!visible.firstChange) {\n        // 不希望默认关闭时，drawer 渲染后就触发 close 事件\n        this.dispose();\n      }\n    }\n  }\n\n  ngAfterViewInit() {\n    this.attachBodyContent();\n    setTimeout(() => {\n      this.drawerViewInit.emit();\n    }, 0);\n  }\n\n  private attachOverlay() {\n    if (!this.overlayRef) {\n      this.portal = new TemplatePortal(\n        this.drawerTemplate,\n        this.viewContainerRef,\n      );\n      this.overlayRef = this.overlay.create(this.getOverlayConfig());\n    }\n    if (this.overlayRef) {\n      this.overlayRef.attach(this.portal);\n      this.overlayRef\n        .outsidePointerEvents()\n        .pipe(takeUntil(this.onDestroy$))\n        .subscribe(event => {\n          // 判断鼠标点击事件的 target 是否为 overlay-container 的子节点，如果是，则不关闭 drawer。\n          // 为了避免点击 drawer 里的 tooltip 后 drawer 被关闭。\n          if (\n            this.visible &&\n            this.hideOnClickOutside &&\n            event.target instanceof Node &&\n            !this.overlayRef.hostElement?.parentNode?.contains(event.target)\n          ) {\n            event.stopPropagation();\n            event.preventDefault();\n            this.dispose();\n          }\n        });\n    }\n  }\n\n  private getOverlayConfig(): OverlayConfig {\n    return new OverlayConfig({\n      panelClass: DRAWER_OVERLAY_CLASS,\n      positionStrategy: this.overlay.position().global(),\n      scrollStrategy: this.mask\n        ? this.overlay.scrollStrategies.block()\n        : this.overlay.scrollStrategies.noop(),\n    });\n  }\n\n  private attachBodyContent(): void {\n    this.bodyPortalOutlet?.dispose();\n    const content = this.content || this.contentTemplate;\n    if (content instanceof Type) {\n      const componentPortal = new ComponentPortal<T>(\n        content,\n        null,\n        Injector.create({\n          providers: [\n            {\n              provide: DATA,\n              useValue: this.contentParams,\n            },\n          ],\n          parent: this.injector,\n        }),\n      );\n      const componentRef =\n        this.bodyPortalOutlet?.attachComponentPortal(componentPortal);\n      this.componentInstance = componentRef.instance;\n      Object.assign(componentRef.instance, this.contentParams);\n      componentRef.changeDetectorRef.detectChanges();\n    }\n  }\n\n  private updateBodyOverflow(): void {\n    if (this.overlayRef) {\n      if (this.visible) {\n        this.overlayRef.getConfig().scrollStrategy.enable();\n      } else {\n        this.overlayRef.getConfig().scrollStrategy.disable();\n      }\n    }\n  }\n\n  open() {\n    this.visible = true;\n    this.afterOpen$.next();\n    this.afterOpen$.complete();\n    this.updateBodyOverflow();\n    this.cdr.markForCheck();\n  }\n\n  dispose(result: R = null) {\n    this.visible = false;\n    this.close.emit();\n    this.afterClosed$.next(result);\n    this.afterClosed$.complete();\n    this.updateBodyOverflow();\n    this.cdr.markForCheck();\n  }\n\n  private disposeOverlay(): void {\n    if (this.overlayRef) {\n      this.overlayRef.dispose();\n    }\n    this.overlayRef = null;\n  }\n\n  maskClick() {\n    if (this.maskClosable && this.mask) {\n      this.dispose();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.onDestroy$.next();\n    this.disposeOverlay();\n  }\n}\n","<ng-template #drawerTemplate>\n  <div\n    *ngIf=\"mask\"\n    class=\"aui-drawer-mask\"\n    [class.isOpen]=\"visible\"\n    (click)=\"maskClick()\"\n  ></div>\n  <div\n    [style.marginTop]=\"offsetY\"\n    [ngClass]=\"drawerClasses\"\n    [class.isOpen]=\"visible\"\n    [ngStyle]=\"{\n      transform: transform,\n      width: width + 'px'\n    }\"\n  >\n    <div class=\"aui-drawer__content\">\n      <div class=\"aui-drawer__body-wrapper\">\n        <div class=\"aui-drawer__header\">\n          <div class=\"aui-drawer__title\">\n            <ng-container\n              *ngIf=\"!isTemplateRef(title || titleTemplate); else elseTemplate\"\n            >\n              {{ title }}\n            </ng-container>\n            <ng-template #elseTemplate>\n              <ng-container\n                *ngIf=\"title || titleTemplate\"\n                [ngTemplateOutlet]=\"$any(title || titleTemplate)\"\n                [ngTemplateOutletContext]=\"templateContext\"\n              ></ng-container>\n            </ng-template>\n          </div>\n          <aui-icon\n            *ngIf=\"showClose\"\n            class=\"aui-drawer__close\"\n            icon=\"xmark\"\n            (click)=\"dispose()\"\n          ></aui-icon>\n        </div>\n\n        <div\n          class=\"aui-drawer__body\"\n          cdkScrollable\n        >\n          <ng-template cdkPortalOutlet></ng-template>\n          <ng-container *ngIf=\"isTemplateRef(content || contentTemplate)\">\n            <ng-container\n              *ngTemplateOutlet=\"\n                $any(content || contentTemplate);\n                context: templateContext\n              \"\n            >\n            </ng-container>\n          </ng-container>\n        </div>\n\n        <div\n          *ngIf=\"footer || footerTemplate\"\n          class=\"aui-drawer__footer\"\n        >\n          <ng-container\n            *ngIf=\"!isTemplateRef(footer || footerTemplate); else elseTemplate\"\n          >\n            {{ footer }}\n          </ng-container>\n          <ng-template #elseTemplate>\n            <ng-container\n              *ngIf=\"footer || footerTemplate\"\n              [ngTemplateOutlet]=\"$any(footer || footerTemplate)\"\n              [ngTemplateOutletContext]=\"templateContext\"\n            ></ng-container>\n          </ng-template>\n        </div>\n      </div>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhd2VyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9kcmF3ZXIvY29tcG9uZW50L2RyYXdlci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUVMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLFlBQVksRUFDWixLQUFLLEVBRUwsTUFBTSxFQUVOLFdBQVcsR0FDWixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBRTdCLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNsRCxPQUFPLEVBQ0wsc0JBQXNCLEVBQ3RCLHFCQUFxQixFQUNyQixxQkFBcUIsR0FDdEIsTUFBTSxzQkFBc0IsQ0FBQztBQUM5QixPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sVUFBVSxDQUFDOzs7QUFTdEMsTUFBTSxPQUFPLGVBQWU7SUFtREc7SUFqRDdCLEtBQUssQ0FBZ0M7SUFHckMsTUFBTSxDQUFnQztJQUd0QyxJQUFJLEdBQWUsVUFBVSxDQUFDLE1BQU0sQ0FBQztJQUdyQyxPQUFPLEdBQUcsS0FBSyxDQUFDO0lBR2hCLE9BQU8sQ0FBVTtJQUdqQixPQUFPLENBQWdEO0lBR3ZELGtCQUFrQixHQUFHLEtBQUssQ0FBQztJQUczQixTQUFTLEdBQUcsSUFBSSxDQUFDO0lBR2pCLFdBQVcsQ0FBUztJQUdwQixJQUFJLENBQVU7SUFHZCxZQUFZLENBQVU7SUFHdEIsT0FBTyxHQUFHLElBQUksQ0FBQztJQUdOLEtBQUssR0FBRyxJQUFJLFlBQVksRUFBYyxDQUFDO0lBRy9CLGFBQWEsQ0FBdUI7SUFHcEMsMEJBQTBCLENBRWhCO0lBR1YsY0FBYyxDQUF1QjtJQUV0RCxZQUE2QixhQUE0QjtRQUE1QixrQkFBYSxHQUFiLGFBQWEsQ0FBZTtJQUFHLENBQUM7SUFFN0QsV0FBVyxDQUFDLE9BQXNCO1FBQ2hDLE1BQU0sRUFBRSxPQUFPLEVBQUUsR0FBRyxPQUFPLENBQUM7UUFDNUIsSUFBSSxPQUFPLEVBQUU7WUFDWCxNQUFNLEtBQUssR0FBRyxPQUFPLENBQUMsWUFBWSxDQUFDO1lBQ25DLElBQUksS0FBSyxFQUFFO2dCQUNULElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQzthQUNiO2lCQUFNLElBQUksQ0FBQyxPQUFPLENBQUMsV0FBVyxFQUFFO2dCQUUvQixJQUFJLENBQUMsYUFBYSxDQUFDLEtBQUssRUFBRSxDQUFDO2FBQzVCO1NBQ0Y7SUFDSCxDQUFDO0lBRUQsZUFBZTtRQUNiLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDO1FBQzlDLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLE9BQU8sSUFBSSxJQUFJLENBQUMsMEJBQTBCLENBQUM7UUFDL0QsSUFBSSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxJQUFJLElBQUksQ0FBQyxjQUFjLENBQUM7SUFDbkQsQ0FBQztJQUVPLElBQUk7UUFDVixNQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUMxQyxHQUFHLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsRUFBRTtZQUM1QyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUN2QixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7dUdBN0VVLGVBQWU7MkZBQWYsZUFBZSw0V0FGZixDQUFDLGFBQWEsQ0FBQyxxRUEwQ1oscUJBQXFCLDJCQUFVLFdBQVcsMEVBRzFDLHNCQUFzQiwyQkFBVSxXQUFXLDhEQUszQyxxQkFBcUIsMkJBQVUsV0FBVyxrREFyRDlDLEVBQUU7OzJGQUtELGVBQWU7a0JBUDNCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLFlBQVk7b0JBQ3RCLFFBQVEsRUFBRSxFQUFFO29CQUNaLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO29CQUMvQyxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsU0FBUyxFQUFFLENBQUMsYUFBYSxDQUFDO2lCQUMzQjtvR0FHQyxLQUFLO3NCQURKLEtBQUs7Z0JBSU4sTUFBTTtzQkFETCxLQUFLO2dCQUlOLElBQUk7c0JBREgsS0FBSztnQkFJTixPQUFPO3NCQUROLEtBQUs7Z0JBSU4sT0FBTztzQkFETixLQUFLO2dCQUlOLE9BQU87c0JBRE4sS0FBSztnQkFJTixrQkFBa0I7c0JBRGpCLEtBQUs7Z0JBSU4sU0FBUztzQkFEUixLQUFLO2dCQUlOLFdBQVc7c0JBRFYsS0FBSztnQkFJTixJQUFJO3NCQURILEtBQUs7Z0JBSU4sWUFBWTtzQkFEWCxLQUFLO2dCQUlOLE9BQU87c0JBRE4sS0FBSztnQkFJRyxLQUFLO3NCQURiLE1BQU07Z0JBSVUsYUFBYTtzQkFEN0IsWUFBWTt1QkFBQyxxQkFBcUIsRUFBRSxFQUFFLElBQUksRUFBRSxXQUFXLEVBQUU7Z0JBSXpDLDBCQUEwQjtzQkFEMUMsWUFBWTt1QkFBQyxzQkFBc0IsRUFBRSxFQUFFLElBQUksRUFBRSxXQUFXLEVBQUU7Z0JBTTFDLGNBQWM7c0JBRDlCLFlBQVk7dUJBQUMscUJBQXFCLEVBQUUsRUFBRSxJQUFJLEVBQUUsV0FBVyxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50VHlwZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcbmltcG9ydCB7XG4gIEFmdGVyVmlld0luaXQsXG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIENvbnRlbnRDaGlsZCxcbiAgRXZlbnRFbWl0dGVyLFxuICBJbnB1dCxcbiAgT25DaGFuZ2VzLFxuICBPdXRwdXQsXG4gIFNpbXBsZUNoYW5nZXMsXG4gIFRlbXBsYXRlUmVmLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGZpcnN0IH0gZnJvbSAncnhqcyc7XG5cbmltcG9ydCB7IERyYXdlclNlcnZpY2UgfSBmcm9tICcuLi9kcmF3ZXIuc2VydmljZSc7XG5pbXBvcnQge1xuICBEcmF3ZXJDb250ZW50RGlyZWN0aXZlLFxuICBEcmF3ZXJGb290ZXJEaXJlY3RpdmUsXG4gIERyYXdlckhlYWRlckRpcmVjdGl2ZSxcbn0gZnJvbSAnLi4vaGVscGVyLWRpcmVjdGl2ZXMnO1xuaW1wb3J0IHsgRHJhd2VyU2l6ZSB9IGZyb20gJy4uL3R5cGVzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXVpLWRyYXdlcicsXG4gIHRlbXBsYXRlOiAnJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHByb3ZpZGVyczogW0RyYXdlclNlcnZpY2VdLFxufSlcbmV4cG9ydCBjbGFzcyBEcmF3ZXJDb21wb25lbnQgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0LCBPbkNoYW5nZXMge1xuICBASW5wdXQoKVxuICB0aXRsZTogc3RyaW5nIHwgVGVtcGxhdGVSZWY8dW5rbm93bj47XG5cbiAgQElucHV0KClcbiAgZm9vdGVyOiBzdHJpbmcgfCBUZW1wbGF0ZVJlZjx1bmtub3duPjtcblxuICBASW5wdXQoKVxuICBzaXplOiBEcmF3ZXJTaXplID0gRHJhd2VyU2l6ZS5NZWRpdW07XG5cbiAgQElucHV0KClcbiAgb2Zmc2V0WSA9ICcwcHgnO1xuXG4gIEBJbnB1dCgpXG4gIHZpc2libGU6IGJvb2xlYW47XG5cbiAgQElucHV0KClcbiAgY29udGVudDogVGVtcGxhdGVSZWY8dW5rbm93bj4gfCBDb21wb25lbnRUeXBlPHVua25vd24+O1xuXG4gIEBJbnB1dCgpXG4gIGhpZGVPbkNsaWNrT3V0c2lkZSA9IGZhbHNlO1xuXG4gIEBJbnB1dCgpXG4gIHNob3dDbG9zZSA9IHRydWU7XG5cbiAgQElucHV0KClcbiAgZHJhd2VyQ2xhc3M6IHN0cmluZztcblxuICBASW5wdXQoKVxuICBtYXNrOiBib29sZWFuO1xuXG4gIEBJbnB1dCgpXG4gIG1hc2tDbG9zYWJsZTogYm9vbGVhbjtcblxuICBASW5wdXQoKVxuICBkaXZpZGVyID0gdHJ1ZTtcblxuICBAT3V0cHV0KClcbiAgcmVhZG9ubHkgY2xvc2UgPSBuZXcgRXZlbnRFbWl0dGVyPE1vdXNlRXZlbnQ+KCk7XG5cbiAgQENvbnRlbnRDaGlsZChEcmF3ZXJIZWFkZXJEaXJlY3RpdmUsIHsgcmVhZDogVGVtcGxhdGVSZWYgfSlcbiAgcHJpdmF0ZSByZWFkb25seSB0aXRsZVRlbXBsYXRlOiBUZW1wbGF0ZVJlZjx1bmtub3duPjtcblxuICBAQ29udGVudENoaWxkKERyYXdlckNvbnRlbnREaXJlY3RpdmUsIHsgcmVhZDogVGVtcGxhdGVSZWYgfSlcbiAgcHJpdmF0ZSByZWFkb25seSBjb250ZW50VGVtcGxhdGVPckNvbXBvbmVudDpcbiAgICB8IFRlbXBsYXRlUmVmPHVua25vd24+XG4gICAgfCBDb21wb25lbnRUeXBlPHVua25vd24+O1xuXG4gIEBDb250ZW50Q2hpbGQoRHJhd2VyRm9vdGVyRGlyZWN0aXZlLCB7IHJlYWQ6IFRlbXBsYXRlUmVmIH0pXG4gIHByaXZhdGUgcmVhZG9ubHkgZm9vdGVyVGVtcGxhdGU6IFRlbXBsYXRlUmVmPHVua25vd24+O1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgZHJhd2VyU2VydmljZTogRHJhd2VyU2VydmljZSkge31cblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XG4gICAgY29uc3QgeyB2aXNpYmxlIH0gPSBjaGFuZ2VzO1xuICAgIGlmICh2aXNpYmxlKSB7XG4gICAgICBjb25zdCB2YWx1ZSA9IHZpc2libGUuY3VycmVudFZhbHVlO1xuICAgICAgaWYgKHZhbHVlKSB7XG4gICAgICAgIHRoaXMub3BlbigpO1xuICAgICAgfSBlbHNlIGlmICghdmlzaWJsZS5maXJzdENoYW5nZSkge1xuICAgICAgICAvLyDkuI3luIzmnJvpu5jorqTlhbPpl63ml7bvvIxkcmF3ZXIg5riy5p+T5ZCO5bCx6Kem5Y+RIGNsb3NlIOS6i+S7tlxuICAgICAgICB0aGlzLmRyYXdlclNlcnZpY2UuY2xvc2UoKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBuZ0FmdGVyVmlld0luaXQoKSB7XG4gICAgdGhpcy50aXRsZSA9IHRoaXMudGl0bGUgfHwgdGhpcy50aXRsZVRlbXBsYXRlO1xuICAgIHRoaXMuY29udGVudCA9IHRoaXMuY29udGVudCB8fCB0aGlzLmNvbnRlbnRUZW1wbGF0ZU9yQ29tcG9uZW50O1xuICAgIHRoaXMuZm9vdGVyID0gdGhpcy5mb290ZXIgfHwgdGhpcy5mb290ZXJUZW1wbGF0ZTtcbiAgfVxuXG4gIHByaXZhdGUgb3BlbigpIHtcbiAgICBjb25zdCByZWYgPSB0aGlzLmRyYXdlclNlcnZpY2Uub3Blbih0aGlzKTtcbiAgICByZWYuYWZ0ZXJDbG9zZWQucGlwZShmaXJzdCgpKS5zdWJzY3JpYmUocmVzID0+IHtcbiAgICAgIHRoaXMuY2xvc2UuZW1pdChyZXMpO1xuICAgIH0pO1xuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
import { animate, keyframes, style, transition, trigger, } from '@angular/animations';
|
|
2
|
+
import { CdkPortalOutlet, ComponentPortal, PortalModule, } from '@angular/cdk/portal';
|
|
3
|
+
import { CdkScrollable } from '@angular/cdk/scrolling';
|
|
4
|
+
import { NgClass, NgIf, NgStyle, NgTemplateOutlet } from '@angular/common';
|
|
5
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, InjectionToken, Injector, Output, Type, ViewChild, ViewEncapsulation, } from '@angular/core';
|
|
6
|
+
import { Subject } from 'rxjs';
|
|
7
|
+
import { TimingFunction } from '../../../core/animation/animation-consts';
|
|
8
|
+
import { IconComponent } from '../../../icon/icon.component';
|
|
9
|
+
import { isTemplateRef } from '../../../utils';
|
|
10
|
+
import { DrawerSize } from '../../types';
|
|
11
|
+
import * as i0 from "@angular/core";
|
|
12
|
+
import * as i1 from "@angular/cdk/portal";
|
|
13
|
+
export const DATA = new InjectionToken('drawer-data');
|
|
14
|
+
const SIZE_MAPPER = {
|
|
15
|
+
[DrawerSize.Small]: 400,
|
|
16
|
+
[DrawerSize.Medium]: 600,
|
|
17
|
+
[DrawerSize.Big]: 800,
|
|
18
|
+
};
|
|
19
|
+
export const duration = '300ms';
|
|
20
|
+
export class DrawerInternalComponent {
|
|
21
|
+
cdr;
|
|
22
|
+
injector;
|
|
23
|
+
maskClick = new EventEmitter();
|
|
24
|
+
closeClick = new EventEmitter();
|
|
25
|
+
bodyPortalOutlet;
|
|
26
|
+
animationStep$ = new Subject();
|
|
27
|
+
options;
|
|
28
|
+
showHide = 'hide';
|
|
29
|
+
get drawerClasses() {
|
|
30
|
+
return {
|
|
31
|
+
'aui-drawer': true,
|
|
32
|
+
hasDivider: this.options.divider,
|
|
33
|
+
...(this.options.drawerClass
|
|
34
|
+
? { [this.options.drawerClass]: true }
|
|
35
|
+
: null),
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
get width() {
|
|
39
|
+
return (this.options.width || SIZE_MAPPER[this.options.size || DrawerSize.Medium]);
|
|
40
|
+
}
|
|
41
|
+
isTemplateRef = isTemplateRef;
|
|
42
|
+
constructor(cdr, injector) {
|
|
43
|
+
this.cdr = cdr;
|
|
44
|
+
this.injector = injector;
|
|
45
|
+
}
|
|
46
|
+
ngAfterViewInit() {
|
|
47
|
+
this.attachBodyContent();
|
|
48
|
+
}
|
|
49
|
+
attachBodyContent() {
|
|
50
|
+
this.bodyPortalOutlet?.dispose();
|
|
51
|
+
const content = this.options.content;
|
|
52
|
+
if (content instanceof Type) {
|
|
53
|
+
const componentPortal = new ComponentPortal(content, null, Injector.create({
|
|
54
|
+
providers: [
|
|
55
|
+
{
|
|
56
|
+
provide: DATA,
|
|
57
|
+
useValue: this.options.contentParams,
|
|
58
|
+
},
|
|
59
|
+
],
|
|
60
|
+
parent: this.injector,
|
|
61
|
+
}));
|
|
62
|
+
const componentRef = this.bodyPortalOutlet?.attachComponentPortal(componentPortal);
|
|
63
|
+
Object.assign(componentRef.instance, this.options.contentParams);
|
|
64
|
+
componentRef.changeDetectorRef.detectChanges();
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
onAnimation(event) {
|
|
68
|
+
const { phaseName, toState } = event;
|
|
69
|
+
if (['show', 'hide'].includes(toState)) {
|
|
70
|
+
const step = [
|
|
71
|
+
toState,
|
|
72
|
+
phaseName.charAt(0).toUpperCase() + phaseName.slice(1),
|
|
73
|
+
].join('');
|
|
74
|
+
this.animationStep$.next(step);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
show() {
|
|
78
|
+
this.showHide = 'show';
|
|
79
|
+
this.cdr.markForCheck();
|
|
80
|
+
}
|
|
81
|
+
hide() {
|
|
82
|
+
this.showHide = 'hide';
|
|
83
|
+
this.cdr.markForCheck();
|
|
84
|
+
}
|
|
85
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: DrawerInternalComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
|
|
86
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: DrawerInternalComponent, isStandalone: true, selector: "ng-component", outputs: { maskClick: "maskClick", closeClick: "closeClick" }, viewQueries: [{ propertyName: "bodyPortalOutlet", first: true, predicate: CdkPortalOutlet, descendants: true }], ngImport: i0, template: "<div\n [style.marginTop]=\"options.offsetY\"\n [ngClass]=\"drawerClasses\"\n [@showHide]=\"showHide\"\n (@showHide.start)=\"onAnimation($event)\"\n (@showHide.done)=\"onAnimation($event)\"\n [ngStyle]=\"{\n width: width + 'px'\n }\"\n>\n <div class=\"aui-drawer__content\">\n <div class=\"aui-drawer__body-wrapper\">\n <div class=\"aui-drawer__header\">\n <div class=\"aui-drawer__title\">\n <ng-container\n *ngIf=\"!isTemplateRef(options.title); else elseTemplate\"\n >\n {{ options.title }}\n </ng-container>\n <ng-template #elseTemplate>\n <ng-container\n *ngIf=\"options.title\"\n [ngTemplateOutlet]=\"$any(options.title)\"\n [ngTemplateOutletContext]=\"{ $implicit: options.contentParams }\"\n ></ng-container>\n </ng-template>\n </div>\n <aui-icon\n *ngIf=\"options.showClose\"\n class=\"aui-drawer__close\"\n icon=\"xmark\"\n (click)=\"hide()\"\n ></aui-icon>\n </div>\n\n <div\n class=\"aui-drawer__body\"\n cdkScrollable\n >\n <ng-template cdkPortalOutlet></ng-template>\n <ng-container *ngIf=\"isTemplateRef(options.content)\">\n <ng-container\n *ngTemplateOutlet=\"\n $any(options.content);\n context: { $implicit: options.contentParams }\n \"\n >\n </ng-container>\n </ng-container>\n </div>\n\n <div\n *ngIf=\"options.footer\"\n class=\"aui-drawer__footer\"\n >\n <ng-container *ngIf=\"!isTemplateRef(options.footer); else elseTemplate\">\n {{ options.footer }}\n </ng-container>\n <ng-template #elseTemplate>\n <ng-container\n *ngIf=\"options.footer\"\n [ngTemplateOutlet]=\"$any(options.footer)\"\n [ngTemplateOutletContext]=\"{ $implicit: options.contentParams }\"\n ></ng-container>\n </ng-template>\n </div>\n </div>\n </div>\n</div>\n", styles: ["@keyframes aui-fade-in{0%{opacity:0}to{opacity:1}}@keyframes aui-fade-out{0%{opacity:1}to{opacity:0}}@keyframes aui-zoom-in{0%{transform:scale(.2);opacity:0}to{transform:scale(1);opacity:1}}@keyframes aui-zoom-out{0%{transform:scale(1)}to{transform:scale(.2);opacity:0}}:root .cdk-overlay-backdrop.cdk-overlay-backdrop-showing.aui-drawer-mask{background-color:rgba(var(--aui-color-origin-shadow),.4)}html[aui-theme-mode=light] .cdk-overlay-backdrop.cdk-overlay-backdrop-showing.aui-drawer-mask{background-color:rgba(var(--aui-color-origin-shadow),.4)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .cdk-overlay-backdrop.cdk-overlay-backdrop-showing.aui-drawer-mask{background-color:rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .cdk-overlay-backdrop.cdk-overlay-backdrop-showing.aui-drawer-mask{background-color:rgba(var(--aui-color-origin-shadow),.75)}.aui-drawer-mask-enter,.aui-drawer-mask-leave{animation-duration:.3s;animation-fill-mode:both;animation-play-state:paused}.aui-drawer-mask-enter.aui-drawer-mask-enter-active,.aui-drawer-mask-leave.aui-drawer-mask-leave-active{animation-play-state:running;pointer-events:none}.aui-drawer-mask-enter.aui-drawer-mask-enter-active{animation-name:aui-fade-in}.aui-drawer-mask-leave.aui-drawer-mask-leave-active{animation-name:aui-fade-out}.aui-drawer-mask-enter{opacity:0;animation-timing-function:linear}.aui-drawer-mask-leave{animation-timing-function:linear}.aui-drawer{position:fixed;top:0;bottom:0;right:0;z-index:9999;font-size:var(--aui-font-size-m);line-height:var(--aui-line-height-m);font-weight:var(--aui-font-weight-normal);color:rgb(var(--aui-color-main-text))}.aui-drawer__content{background-color:rgb(var(--aui-color-n-10));position:absolute;height:100%;right:0;width:100%}:root .aui-drawer__content{box-shadow:-2px 0 8px 0 rgba(var(--aui-color-origin-shadow),.2)}html[aui-theme-mode=light] .aui-drawer__content{box-shadow:-2px 0 8px 0 rgba(var(--aui-color-origin-shadow),.2)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-drawer__content{box-shadow:-2px 0 8px 0 rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .aui-drawer__content{box-shadow:-2px 0 8px 0 rgba(var(--aui-color-origin-shadow),.75)}.aui-drawer__header{padding:20px;display:flex;flex-shrink:0;justify-content:space-between}.aui-drawer__title{flex:1;font-size:var(--aui-font-size-xxl);line-height:var(--aui-line-height-xxl);font-weight:var(--aui-font-weight-bolder);color:rgb(var(--aui-color-main-text));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.aui-drawer__close{z-index:10;flex-shrink:0;margin-top:2px;margin-left:var(--aui-spacing-xl);display:flex;justify-content:center;align-items:center;width:24px;height:24px;font-size:var(--aui-icon-size-l);color:rgb(var(--aui-color-secondary-text));border-radius:var(--aui-border-radius-m);cursor:pointer}.aui-drawer__close:hover{color:rgb(var(--aui-color-primary));background-color:rgb(var(--aui-color-p-6))}.aui-drawer__close:active{color:rgb(var(--aui-color-p-0));background-color:rgb(var(--aui-color-p-5))}.aui-drawer__body-wrapper{width:100%;height:100%;display:flex;flex-flow:column nowrap;position:relative;z-index:1}.aui-drawer__body{padding:0 20px;overflow:hidden;overflow-y:auto;height:100%}.aui-drawer__footer{padding:20px}.aui-drawer.hasDivider .aui-drawer__header{padding-bottom:16px;border-bottom:1px solid rgb(var(--aui-color-n-8))}.aui-drawer.hasDivider .aui-drawer__body{padding:16px 20px}.aui-drawer.hasDivider .aui-drawer__footer{padding-top:16px;border-top:1px solid rgb(var(--aui-color-n-8))}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: IconComponent, selector: "aui-icon", inputs: ["icon", "light", "dark", "link", "margin", "size", "color", "background", "backgroundColor"] }, { kind: "directive", type: CdkScrollable, selector: "[cdk-scrollable], [cdkScrollable]" }, { kind: "ngmodule", type: PortalModule }, { kind: "directive", type: i1.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }], animations: [
|
|
87
|
+
trigger('showHide', [
|
|
88
|
+
transition('hide => show, void => show', [
|
|
89
|
+
animate(`${duration} ${TimingFunction.easeOut}`, keyframes([
|
|
90
|
+
style({
|
|
91
|
+
opacity: 0,
|
|
92
|
+
transform: 'translateX(100%)',
|
|
93
|
+
}),
|
|
94
|
+
style({
|
|
95
|
+
opacity: 1,
|
|
96
|
+
transform: 'translateX(0)',
|
|
97
|
+
}),
|
|
98
|
+
])),
|
|
99
|
+
]),
|
|
100
|
+
transition('show => hide, show => void', [
|
|
101
|
+
animate(`${duration} ${TimingFunction.easeInOut}`, keyframes([
|
|
102
|
+
style({
|
|
103
|
+
opacity: 1,
|
|
104
|
+
transform: 'translateX(0)',
|
|
105
|
+
}),
|
|
106
|
+
style({
|
|
107
|
+
opacity: 0,
|
|
108
|
+
transform: 'translateX(100%)',
|
|
109
|
+
}),
|
|
110
|
+
])),
|
|
111
|
+
]),
|
|
112
|
+
]),
|
|
113
|
+
], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
114
|
+
}
|
|
115
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: DrawerInternalComponent, decorators: [{
|
|
116
|
+
type: Component,
|
|
117
|
+
args: [{ encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
|
|
118
|
+
NgIf,
|
|
119
|
+
NgClass,
|
|
120
|
+
NgStyle,
|
|
121
|
+
NgTemplateOutlet,
|
|
122
|
+
IconComponent,
|
|
123
|
+
CdkScrollable,
|
|
124
|
+
PortalModule,
|
|
125
|
+
], animations: [
|
|
126
|
+
trigger('showHide', [
|
|
127
|
+
transition('hide => show, void => show', [
|
|
128
|
+
animate(`${duration} ${TimingFunction.easeOut}`, keyframes([
|
|
129
|
+
style({
|
|
130
|
+
opacity: 0,
|
|
131
|
+
transform: 'translateX(100%)',
|
|
132
|
+
}),
|
|
133
|
+
style({
|
|
134
|
+
opacity: 1,
|
|
135
|
+
transform: 'translateX(0)',
|
|
136
|
+
}),
|
|
137
|
+
])),
|
|
138
|
+
]),
|
|
139
|
+
transition('show => hide, show => void', [
|
|
140
|
+
animate(`${duration} ${TimingFunction.easeInOut}`, keyframes([
|
|
141
|
+
style({
|
|
142
|
+
opacity: 1,
|
|
143
|
+
transform: 'translateX(0)',
|
|
144
|
+
}),
|
|
145
|
+
style({
|
|
146
|
+
opacity: 0,
|
|
147
|
+
transform: 'translateX(100%)',
|
|
148
|
+
}),
|
|
149
|
+
])),
|
|
150
|
+
]),
|
|
151
|
+
]),
|
|
152
|
+
], template: "<div\n [style.marginTop]=\"options.offsetY\"\n [ngClass]=\"drawerClasses\"\n [@showHide]=\"showHide\"\n (@showHide.start)=\"onAnimation($event)\"\n (@showHide.done)=\"onAnimation($event)\"\n [ngStyle]=\"{\n width: width + 'px'\n }\"\n>\n <div class=\"aui-drawer__content\">\n <div class=\"aui-drawer__body-wrapper\">\n <div class=\"aui-drawer__header\">\n <div class=\"aui-drawer__title\">\n <ng-container\n *ngIf=\"!isTemplateRef(options.title); else elseTemplate\"\n >\n {{ options.title }}\n </ng-container>\n <ng-template #elseTemplate>\n <ng-container\n *ngIf=\"options.title\"\n [ngTemplateOutlet]=\"$any(options.title)\"\n [ngTemplateOutletContext]=\"{ $implicit: options.contentParams }\"\n ></ng-container>\n </ng-template>\n </div>\n <aui-icon\n *ngIf=\"options.showClose\"\n class=\"aui-drawer__close\"\n icon=\"xmark\"\n (click)=\"hide()\"\n ></aui-icon>\n </div>\n\n <div\n class=\"aui-drawer__body\"\n cdkScrollable\n >\n <ng-template cdkPortalOutlet></ng-template>\n <ng-container *ngIf=\"isTemplateRef(options.content)\">\n <ng-container\n *ngTemplateOutlet=\"\n $any(options.content);\n context: { $implicit: options.contentParams }\n \"\n >\n </ng-container>\n </ng-container>\n </div>\n\n <div\n *ngIf=\"options.footer\"\n class=\"aui-drawer__footer\"\n >\n <ng-container *ngIf=\"!isTemplateRef(options.footer); else elseTemplate\">\n {{ options.footer }}\n </ng-container>\n <ng-template #elseTemplate>\n <ng-container\n *ngIf=\"options.footer\"\n [ngTemplateOutlet]=\"$any(options.footer)\"\n [ngTemplateOutletContext]=\"{ $implicit: options.contentParams }\"\n ></ng-container>\n </ng-template>\n </div>\n </div>\n </div>\n</div>\n", styles: ["@keyframes aui-fade-in{0%{opacity:0}to{opacity:1}}@keyframes aui-fade-out{0%{opacity:1}to{opacity:0}}@keyframes aui-zoom-in{0%{transform:scale(.2);opacity:0}to{transform:scale(1);opacity:1}}@keyframes aui-zoom-out{0%{transform:scale(1)}to{transform:scale(.2);opacity:0}}:root .cdk-overlay-backdrop.cdk-overlay-backdrop-showing.aui-drawer-mask{background-color:rgba(var(--aui-color-origin-shadow),.4)}html[aui-theme-mode=light] .cdk-overlay-backdrop.cdk-overlay-backdrop-showing.aui-drawer-mask{background-color:rgba(var(--aui-color-origin-shadow),.4)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .cdk-overlay-backdrop.cdk-overlay-backdrop-showing.aui-drawer-mask{background-color:rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .cdk-overlay-backdrop.cdk-overlay-backdrop-showing.aui-drawer-mask{background-color:rgba(var(--aui-color-origin-shadow),.75)}.aui-drawer-mask-enter,.aui-drawer-mask-leave{animation-duration:.3s;animation-fill-mode:both;animation-play-state:paused}.aui-drawer-mask-enter.aui-drawer-mask-enter-active,.aui-drawer-mask-leave.aui-drawer-mask-leave-active{animation-play-state:running;pointer-events:none}.aui-drawer-mask-enter.aui-drawer-mask-enter-active{animation-name:aui-fade-in}.aui-drawer-mask-leave.aui-drawer-mask-leave-active{animation-name:aui-fade-out}.aui-drawer-mask-enter{opacity:0;animation-timing-function:linear}.aui-drawer-mask-leave{animation-timing-function:linear}.aui-drawer{position:fixed;top:0;bottom:0;right:0;z-index:9999;font-size:var(--aui-font-size-m);line-height:var(--aui-line-height-m);font-weight:var(--aui-font-weight-normal);color:rgb(var(--aui-color-main-text))}.aui-drawer__content{background-color:rgb(var(--aui-color-n-10));position:absolute;height:100%;right:0;width:100%}:root .aui-drawer__content{box-shadow:-2px 0 8px 0 rgba(var(--aui-color-origin-shadow),.2)}html[aui-theme-mode=light] .aui-drawer__content{box-shadow:-2px 0 8px 0 rgba(var(--aui-color-origin-shadow),.2)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-drawer__content{box-shadow:-2px 0 8px 0 rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .aui-drawer__content{box-shadow:-2px 0 8px 0 rgba(var(--aui-color-origin-shadow),.75)}.aui-drawer__header{padding:20px;display:flex;flex-shrink:0;justify-content:space-between}.aui-drawer__title{flex:1;font-size:var(--aui-font-size-xxl);line-height:var(--aui-line-height-xxl);font-weight:var(--aui-font-weight-bolder);color:rgb(var(--aui-color-main-text));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.aui-drawer__close{z-index:10;flex-shrink:0;margin-top:2px;margin-left:var(--aui-spacing-xl);display:flex;justify-content:center;align-items:center;width:24px;height:24px;font-size:var(--aui-icon-size-l);color:rgb(var(--aui-color-secondary-text));border-radius:var(--aui-border-radius-m);cursor:pointer}.aui-drawer__close:hover{color:rgb(var(--aui-color-primary));background-color:rgb(var(--aui-color-p-6))}.aui-drawer__close:active{color:rgb(var(--aui-color-p-0));background-color:rgb(var(--aui-color-p-5))}.aui-drawer__body-wrapper{width:100%;height:100%;display:flex;flex-flow:column nowrap;position:relative;z-index:1}.aui-drawer__body{padding:0 20px;overflow:hidden;overflow-y:auto;height:100%}.aui-drawer__footer{padding:20px}.aui-drawer.hasDivider .aui-drawer__header{padding-bottom:16px;border-bottom:1px solid rgb(var(--aui-color-n-8))}.aui-drawer.hasDivider .aui-drawer__body{padding:16px 20px}.aui-drawer.hasDivider .aui-drawer__footer{padding-top:16px;border-top:1px solid rgb(var(--aui-color-n-8))}\n"] }]
|
|
153
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.Injector }]; }, propDecorators: { maskClick: [{
|
|
154
|
+
type: Output
|
|
155
|
+
}], closeClick: [{
|
|
156
|
+
type: Output
|
|
157
|
+
}], bodyPortalOutlet: [{
|
|
158
|
+
type: ViewChild,
|
|
159
|
+
args: [CdkPortalOutlet, { static: false }]
|
|
160
|
+
}] } });
|
|
161
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"internal.component.js","sourceRoot":"","sources":["../../../../../src/drawer/component/internal/internal.component.ts","../../../../../src/drawer/component/internal/internal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  animate,\n  AnimationEvent,\n  keyframes,\n  style,\n  transition,\n  trigger,\n} from '@angular/animations';\nimport { ComponentType } from '@angular/cdk/overlay';\nimport {\n  CdkPortalOutlet,\n  ComponentPortal,\n  PortalModule,\n} from '@angular/cdk/portal';\nimport { CdkScrollable } from '@angular/cdk/scrolling';\nimport { NgClass, NgIf, NgStyle, NgTemplateOutlet } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  InjectionToken,\n  Injector,\n  Output,\n  Type,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { Subject } from 'rxjs';\n\nimport { TimingFunction } from '../../../core/animation/animation-consts';\nimport { IconComponent } from '../../../icon/icon.component';\nimport { isTemplateRef } from '../../../utils';\nimport { DrawerOptions, DrawerSize } from '../../types';\n\nexport const DATA = new InjectionToken('drawer-data');\n\nconst SIZE_MAPPER = {\n  [DrawerSize.Small]: 400,\n  [DrawerSize.Medium]: 600,\n  [DrawerSize.Big]: 800,\n};\nexport const duration = '300ms';\n\ntype Step = 'showStart' | 'showDone' | 'hideStart' | 'hideDone';\n\n@Component({\n  templateUrl: './internal.component.html',\n  styleUrls: ['./internal.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    NgIf,\n    NgClass,\n    NgStyle,\n    NgTemplateOutlet,\n    IconComponent,\n    CdkScrollable,\n    PortalModule,\n  ],\n  animations: [\n    trigger('showHide', [\n      transition('hide => show, void => show', [\n        animate(\n          `${duration} ${TimingFunction.easeOut}`,\n          keyframes([\n            style({\n              opacity: 0,\n              transform: 'translateX(100%)',\n            }),\n            style({\n              opacity: 1,\n              transform: 'translateX(0)',\n            }),\n          ]),\n        ),\n      ]),\n      transition('show => hide, show => void', [\n        animate(\n          `${duration} ${TimingFunction.easeInOut}`,\n          keyframes([\n            style({\n              opacity: 1,\n              transform: 'translateX(0)',\n            }),\n            style({\n              opacity: 0,\n              transform: 'translateX(100%)',\n            }),\n          ]),\n        ),\n      ]),\n    ]),\n  ],\n})\nexport class DrawerInternalComponent<T = ComponentType<unknown>> {\n  @Output()\n  maskClick = new EventEmitter<MouseEvent>();\n\n  @Output()\n  closeClick = new EventEmitter();\n\n  @ViewChild(CdkPortalOutlet, { static: false })\n  bodyPortalOutlet: CdkPortalOutlet;\n\n  animationStep$ = new Subject<Step>();\n\n  options: DrawerOptions;\n  showHide = 'hide';\n\n  get drawerClasses(): Record<string, boolean> {\n    return {\n      'aui-drawer': true,\n      hasDivider: this.options.divider,\n      ...(this.options.drawerClass\n        ? { [this.options.drawerClass]: true }\n        : null),\n    };\n  }\n\n  get width() {\n    return (\n      this.options.width || SIZE_MAPPER[this.options.size || DrawerSize.Medium]\n    );\n  }\n\n  isTemplateRef = isTemplateRef;\n\n  constructor(\n    private readonly cdr: ChangeDetectorRef,\n    private readonly injector: Injector,\n  ) {}\n\n  ngAfterViewInit() {\n    this.attachBodyContent();\n  }\n\n  private attachBodyContent(): void {\n    this.bodyPortalOutlet?.dispose();\n    const content = this.options.content;\n    if (content instanceof Type) {\n      const componentPortal = new ComponentPortal<T>(\n        content,\n        null,\n        Injector.create({\n          providers: [\n            {\n              provide: DATA,\n              useValue: this.options.contentParams,\n            },\n          ],\n          parent: this.injector,\n        }),\n      );\n      const componentRef =\n        this.bodyPortalOutlet?.attachComponentPortal(componentPortal);\n      Object.assign(componentRef.instance, this.options.contentParams);\n      componentRef.changeDetectorRef.detectChanges();\n    }\n  }\n\n  onAnimation(event: AnimationEvent) {\n    const { phaseName, toState } = event;\n    if (['show', 'hide'].includes(toState)) {\n      const step = [\n        toState,\n        phaseName.charAt(0).toUpperCase() + phaseName.slice(1),\n      ].join('') as Step;\n      this.animationStep$.next(step);\n    }\n  }\n\n  show() {\n    this.showHide = 'show';\n    this.cdr.markForCheck();\n  }\n\n  hide() {\n    this.showHide = 'hide';\n    this.cdr.markForCheck();\n  }\n}\n","<div\n  [style.marginTop]=\"options.offsetY\"\n  [ngClass]=\"drawerClasses\"\n  [@showHide]=\"showHide\"\n  (@showHide.start)=\"onAnimation($event)\"\n  (@showHide.done)=\"onAnimation($event)\"\n  [ngStyle]=\"{\n    width: width + 'px'\n  }\"\n>\n  <div class=\"aui-drawer__content\">\n    <div class=\"aui-drawer__body-wrapper\">\n      <div class=\"aui-drawer__header\">\n        <div class=\"aui-drawer__title\">\n          <ng-container\n            *ngIf=\"!isTemplateRef(options.title); else elseTemplate\"\n          >\n            {{ options.title }}\n          </ng-container>\n          <ng-template #elseTemplate>\n            <ng-container\n              *ngIf=\"options.title\"\n              [ngTemplateOutlet]=\"$any(options.title)\"\n              [ngTemplateOutletContext]=\"{ $implicit: options.contentParams }\"\n            ></ng-container>\n          </ng-template>\n        </div>\n        <aui-icon\n          *ngIf=\"options.showClose\"\n          class=\"aui-drawer__close\"\n          icon=\"xmark\"\n          (click)=\"hide()\"\n        ></aui-icon>\n      </div>\n\n      <div\n        class=\"aui-drawer__body\"\n        cdkScrollable\n      >\n        <ng-template cdkPortalOutlet></ng-template>\n        <ng-container *ngIf=\"isTemplateRef(options.content)\">\n          <ng-container\n            *ngTemplateOutlet=\"\n              $any(options.content);\n              context: { $implicit: options.contentParams }\n            \"\n          >\n          </ng-container>\n        </ng-container>\n      </div>\n\n      <div\n        *ngIf=\"options.footer\"\n        class=\"aui-drawer__footer\"\n      >\n        <ng-container *ngIf=\"!isTemplateRef(options.footer); else elseTemplate\">\n          {{ options.footer }}\n        </ng-container>\n        <ng-template #elseTemplate>\n          <ng-container\n            *ngIf=\"options.footer\"\n            [ngTemplateOutlet]=\"$any(options.footer)\"\n            [ngTemplateOutletContext]=\"{ $implicit: options.contentParams }\"\n          ></ng-container>\n        </ng-template>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -0,0 +1,27 @@
|
|
|
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
|
+
dispose(result = null) {
|
|
23
|
+
this.result = result;
|
|
24
|
+
this.drawerInstance.hide();
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhd2VyLXJlZi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kcmF3ZXIvZHJhd2VyLXJlZi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFjLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUluRCxNQUFNLE9BQU8sU0FBUztJQWNEO0lBYlgsTUFBTSxDQUFJO0lBRUQsVUFBVSxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7SUFDakMsWUFBWSxHQUFHLElBQUksT0FBTyxFQUFLLENBQUM7SUFFakQsSUFBSSxTQUFTO1FBQ1gsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ3hDLENBQUM7SUFFRCxJQUFJLFdBQVc7UUFDYixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDMUMsQ0FBQztJQUVELFlBQW1CLGNBQXVDO1FBQXZDLG1CQUFjLEdBQWQsY0FBYyxDQUF5QjtRQUN4RCxJQUFJLENBQUMsY0FBYyxDQUFDLGNBQWM7YUFDL0IsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksS0FBSyxVQUFVLENBQUMsQ0FBQzthQUN6QyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ2QsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ3BDLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDL0IsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsT0FBTyxDQUFDLFNBQVksSUFBSTtRQUN0QixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUNyQixJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzdCLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGZpbHRlciwgT2JzZXJ2YWJsZSwgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBEcmF3ZXJJbnRlcm5hbENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50L2ludGVybmFsL2ludGVybmFsLmNvbXBvbmVudCc7XG5cbmV4cG9ydCBjbGFzcyBEcmF3ZXJSZWY8UiA9IGFueT4ge1xuICBwcml2YXRlIHJlc3VsdDogUjtcblxuICBwcml2YXRlIHJlYWRvbmx5IGFmdGVyT3BlbiQgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xuICBwcml2YXRlIHJlYWRvbmx5IGFmdGVyQ2xvc2VkJCA9IG5ldyBTdWJqZWN0PFI+KCk7XG5cbiAgZ2V0IGFmdGVyT3BlbigpOiBPYnNlcnZhYmxlPHZvaWQ+IHtcbiAgICByZXR1cm4gdGhpcy5hZnRlck9wZW4kLmFzT2JzZXJ2YWJsZSgpO1xuICB9XG5cbiAgZ2V0IGFmdGVyQ2xvc2VkKCk6IE9ic2VydmFibGU8Uj4ge1xuICAgIHJldHVybiB0aGlzLmFmdGVyQ2xvc2VkJC5hc09ic2VydmFibGUoKTtcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBkcmF3ZXJJbnN0YW5jZTogRHJhd2VySW50ZXJuYWxDb21wb25lbnQpIHtcbiAgICB0aGlzLmRyYXdlckluc3RhbmNlLmFuaW1hdGlvblN0ZXAkXG4gICAgICAucGlwZShmaWx0ZXIoc3RlcCA9PiBzdGVwID09PSAnaGlkZURvbmUnKSlcbiAgICAgIC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgICB0aGlzLmFmdGVyQ2xvc2VkJC5uZXh0KHRoaXMucmVzdWx0KTtcbiAgICAgICAgdGhpcy5hZnRlckNsb3NlZCQuY29tcGxldGUoKTtcbiAgICAgIH0pO1xuICB9XG5cbiAgZGlzcG9zZShyZXN1bHQ6IFIgPSBudWxsKTogdm9pZCB7XG4gICAgdGhpcy5yZXN1bHQgPSByZXN1bHQ7XG4gICAgdGhpcy5kcmF3ZXJJbnN0YW5jZS5oaWRlKCk7XG4gIH1cbn1cbiJdfQ==
|