@alauda/ui 7.2.1-beta.8 → 7.3.0

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.
@@ -0,0 +1,177 @@
1
+ import { animate, state, style, transition, trigger, } from '@angular/animations';
2
+ import { CdkPortalOutlet, ComponentPortal, PortalModule, } from '@angular/cdk/portal';
3
+ import { CdkScrollable } from '@angular/cdk/scrolling';
4
+ import { AsyncPipe, NgClass, NgIf, NgStyle, NgTemplateOutlet, } from '@angular/common';
5
+ import { ChangeDetectionStrategy, Component, InjectionToken, Injector, Type, ViewChild, ViewEncapsulation, } from '@angular/core';
6
+ import { BehaviorSubject, Subject } from 'rxjs';
7
+ import { TimingFunction } from '../../../core/animation/animation-consts';
8
+ import { IconComponent } from '../../../icon/icon.component';
9
+ import { handlePixel, 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
+ const DRAWER_OVERLAY_BACKDROP_CLASS = 'aui-drawer-mask';
20
+ export const duration = '300ms';
21
+ export class DrawerInternalComponent {
22
+ injector;
23
+ bodyPortalOutlet;
24
+ mask;
25
+ animationStep$ = new Subject();
26
+ options;
27
+ showHide$$ = new BehaviorSubject('hide');
28
+ maskVisible$ = new Subject();
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 handlePixel(this.options.width || SIZE_MAPPER[this.options.size || DrawerSize.Medium]);
40
+ }
41
+ isTemplateRef = isTemplateRef;
42
+ constructor(injector) {
43
+ this.injector = injector;
44
+ }
45
+ ngAfterViewInit() {
46
+ this.attachBodyContent();
47
+ }
48
+ attachBodyContent() {
49
+ this.bodyPortalOutlet?.dispose();
50
+ const content = this.options.content;
51
+ if (!(content instanceof Type)) {
52
+ return;
53
+ }
54
+ const componentPortal = new ComponentPortal(content, null, Injector.create({
55
+ providers: [
56
+ {
57
+ provide: DATA,
58
+ useValue: this.options.contentParams,
59
+ },
60
+ ],
61
+ parent: this.injector,
62
+ }));
63
+ const componentRef = this.bodyPortalOutlet?.attachComponentPortal(componentPortal);
64
+ Object.assign(componentRef.instance, this.options.contentParams);
65
+ componentRef.changeDetectorRef.detectChanges();
66
+ }
67
+ onAnimation(event) {
68
+ const { phaseName, toState } = event;
69
+ if (!['show', 'hide'].includes(toState)) {
70
+ return;
71
+ }
72
+ const step = [
73
+ toState,
74
+ phaseName.charAt(0).toUpperCase() + phaseName.slice(1),
75
+ ].join('');
76
+ this.animationStep$.next(step);
77
+ const backdropElement = this.mask?.nativeElement;
78
+ if (!backdropElement) {
79
+ return;
80
+ }
81
+ const enters = [
82
+ `${DRAWER_OVERLAY_BACKDROP_CLASS}-enter`,
83
+ `${DRAWER_OVERLAY_BACKDROP_CLASS}-enter-active`,
84
+ ];
85
+ const leaves = [
86
+ `${DRAWER_OVERLAY_BACKDROP_CLASS}-leave`,
87
+ `${DRAWER_OVERLAY_BACKDROP_CLASS}-leave-active`,
88
+ ];
89
+ switch (step) {
90
+ case 'showStart': {
91
+ backdropElement.classList.add(...enters);
92
+ this.maskVisible$.next(true);
93
+ break;
94
+ }
95
+ case 'hideStart': {
96
+ backdropElement.classList.add(...leaves);
97
+ break;
98
+ }
99
+ case 'showDone': {
100
+ backdropElement.classList.remove(...enters);
101
+ break;
102
+ }
103
+ case 'hideDone': {
104
+ this.maskVisible$.next(false);
105
+ backdropElement.classList.remove(...leaves);
106
+ break;
107
+ }
108
+ }
109
+ }
110
+ show() {
111
+ this.showHide$$.next('show');
112
+ }
113
+ hide() {
114
+ this.showHide$$.next('hide');
115
+ }
116
+ maskClick() {
117
+ if (this.options.maskClosable) {
118
+ this.hide();
119
+ }
120
+ }
121
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: DrawerInternalComponent, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
122
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: DrawerInternalComponent, isStandalone: true, selector: "ng-component", viewQueries: [{ propertyName: "bodyPortalOutlet", first: true, predicate: CdkPortalOutlet, descendants: true }, { propertyName: "mask", first: true, predicate: ["mask"], descendants: true }], ngImport: i0, template: "<div\n #mask\n class=\"aui-drawer-mask\"\n *ngIf=\"options.mask\"\n [class.isOpen]=\"maskVisible$ | async\"\n (click)=\"maskClick()\"\n></div>\n<div\n [style.marginTop]=\"options.offsetY\"\n [ngClass]=\"drawerClasses\"\n [@showHide]=\"showHide$$ | async\"\n (@showHide.start)=\"onAnimation($event)\"\n (@showHide.done)=\"onAnimation($event)\"\n [style.width]=\"width\"\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 normal\"\n [ngTemplateOutlet]=\"options.title\"\n [ngTemplateOutletContext]=\"options.contentParams\"\n ></ng-container>\n <ng-template #normal>\n {{ options.title }}\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\n *ngIf=\"isTemplateRef(options.content)\"\n [ngTemplateOutlet]=\"options.content\"\n [ngTemplateOutletContext]=\"options.contentParams\"\n >\n </ng-container>\n </div>\n\n <div\n *ngIf=\"options.footer\"\n class=\"aui-drawer__footer\"\n >\n <ng-container\n *ngIf=\"isTemplateRef(options.footer); else normal\"\n [ngTemplateOutlet]=\"options.footer\"\n [ngTemplateOutletContext]=\"options.contentParams\"\n ></ng-container>\n <ng-template #normal>\n {{ options.footer }}\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}}.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-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: 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"] }, { kind: "pipe", type: AsyncPipe, name: "async" }], animations: [
123
+ trigger('showHide', [
124
+ state('show', style({
125
+ opacity: 1,
126
+ transform: 'translateX(0)',
127
+ })),
128
+ state('hide, void', style({
129
+ opacity: 0,
130
+ transform: 'translateX(100%)',
131
+ })),
132
+ transition('hide => show, void => show', [
133
+ animate(`${duration} ${TimingFunction.easeOut}`),
134
+ ]),
135
+ transition('show => hide, show => void', [
136
+ animate(`${duration} ${TimingFunction.easeInOut}`),
137
+ ]),
138
+ ]),
139
+ ], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
140
+ }
141
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: DrawerInternalComponent, decorators: [{
142
+ type: Component,
143
+ args: [{ encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
144
+ NgIf,
145
+ NgClass,
146
+ NgStyle,
147
+ NgTemplateOutlet,
148
+ IconComponent,
149
+ CdkScrollable,
150
+ PortalModule,
151
+ AsyncPipe,
152
+ ], animations: [
153
+ trigger('showHide', [
154
+ state('show', style({
155
+ opacity: 1,
156
+ transform: 'translateX(0)',
157
+ })),
158
+ state('hide, void', style({
159
+ opacity: 0,
160
+ transform: 'translateX(100%)',
161
+ })),
162
+ transition('hide => show, void => show', [
163
+ animate(`${duration} ${TimingFunction.easeOut}`),
164
+ ]),
165
+ transition('show => hide, show => void', [
166
+ animate(`${duration} ${TimingFunction.easeInOut}`),
167
+ ]),
168
+ ]),
169
+ ], template: "<div\n #mask\n class=\"aui-drawer-mask\"\n *ngIf=\"options.mask\"\n [class.isOpen]=\"maskVisible$ | async\"\n (click)=\"maskClick()\"\n></div>\n<div\n [style.marginTop]=\"options.offsetY\"\n [ngClass]=\"drawerClasses\"\n [@showHide]=\"showHide$$ | async\"\n (@showHide.start)=\"onAnimation($event)\"\n (@showHide.done)=\"onAnimation($event)\"\n [style.width]=\"width\"\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 normal\"\n [ngTemplateOutlet]=\"options.title\"\n [ngTemplateOutletContext]=\"options.contentParams\"\n ></ng-container>\n <ng-template #normal>\n {{ options.title }}\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\n *ngIf=\"isTemplateRef(options.content)\"\n [ngTemplateOutlet]=\"options.content\"\n [ngTemplateOutletContext]=\"options.contentParams\"\n >\n </ng-container>\n </div>\n\n <div\n *ngIf=\"options.footer\"\n class=\"aui-drawer__footer\"\n >\n <ng-container\n *ngIf=\"isTemplateRef(options.footer); else normal\"\n [ngTemplateOutlet]=\"options.footer\"\n [ngTemplateOutletContext]=\"options.contentParams\"\n ></ng-container>\n <ng-template #normal>\n {{ options.footer }}\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}}.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-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"] }]
170
+ }], ctorParameters: function () { return [{ type: i0.Injector }]; }, propDecorators: { bodyPortalOutlet: [{
171
+ type: ViewChild,
172
+ args: [CdkPortalOutlet, { static: false }]
173
+ }], mask: [{
174
+ type: ViewChild,
175
+ args: ['mask']
176
+ }] } });
177
+ //# 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  state,\n  style,\n  transition,\n  trigger,\n} from '@angular/animations';\nimport {\n  CdkPortalOutlet,\n  ComponentPortal,\n  PortalModule,\n} from '@angular/cdk/portal';\nimport { CdkScrollable } from '@angular/cdk/scrolling';\nimport {\n  AsyncPipe,\n  NgClass,\n  NgIf,\n  NgStyle,\n  NgTemplateOutlet,\n} from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  InjectionToken,\n  Injector,\n  Type,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { BehaviorSubject, Subject } from 'rxjs';\n\nimport { TimingFunction } from '../../../core/animation/animation-consts';\nimport { IconComponent } from '../../../icon/icon.component';\nimport { handlePixel, 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};\nconst DRAWER_OVERLAY_BACKDROP_CLASS = 'aui-drawer-mask';\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    AsyncPipe,\n  ],\n  animations: [\n    trigger('showHide', [\n      state(\n        'show',\n        style({\n          opacity: 1,\n          transform: 'translateX(0)',\n        }),\n      ),\n      state(\n        'hide, void',\n        style({\n          opacity: 0,\n          transform: 'translateX(100%)',\n        }),\n      ),\n      transition('hide => show, void => show', [\n        animate(`${duration} ${TimingFunction.easeOut}`),\n      ]),\n      transition('show => hide, show => void', [\n        animate(`${duration} ${TimingFunction.easeInOut}`),\n      ]),\n    ]),\n  ],\n})\nexport class DrawerInternalComponent<T = unknown, C extends object = object> {\n  @ViewChild(CdkPortalOutlet, { static: false })\n  bodyPortalOutlet: CdkPortalOutlet;\n\n  @ViewChild('mask')\n  mask: ElementRef<HTMLDivElement>;\n\n  animationStep$ = new Subject<Step>();\n\n  options: DrawerOptions<T, C>;\n  showHide$$ = new BehaviorSubject<'show' | 'hide'>('hide');\n  maskVisible$ = new Subject<boolean>();\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 handlePixel(\n      this.options.width || SIZE_MAPPER[this.options.size || DrawerSize.Medium],\n    );\n  }\n\n  isTemplateRef = isTemplateRef;\n\n  constructor(private readonly injector: Injector) {}\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      return;\n    }\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  onAnimation(event: AnimationEvent) {\n    const { phaseName, toState } = event;\n    if (!['show', 'hide'].includes(toState)) {\n      return;\n    }\n\n    const step = [\n      toState,\n      phaseName.charAt(0).toUpperCase() + phaseName.slice(1),\n    ].join('') as Step;\n    this.animationStep$.next(step);\n\n    const backdropElement = this.mask?.nativeElement;\n    if (!backdropElement) {\n      return;\n    }\n\n    const enters = [\n      `${DRAWER_OVERLAY_BACKDROP_CLASS}-enter`,\n      `${DRAWER_OVERLAY_BACKDROP_CLASS}-enter-active`,\n    ];\n    const leaves = [\n      `${DRAWER_OVERLAY_BACKDROP_CLASS}-leave`,\n      `${DRAWER_OVERLAY_BACKDROP_CLASS}-leave-active`,\n    ];\n    switch (step) {\n      case 'showStart': {\n        backdropElement.classList.add(...enters);\n        this.maskVisible$.next(true);\n        break;\n      }\n      case 'hideStart': {\n        backdropElement.classList.add(...leaves);\n        break;\n      }\n      case 'showDone': {\n        backdropElement.classList.remove(...enters);\n        break;\n      }\n      case 'hideDone': {\n        this.maskVisible$.next(false);\n        backdropElement.classList.remove(...leaves);\n        break;\n      }\n    }\n  }\n\n  show() {\n    this.showHide$$.next('show');\n  }\n\n  hide() {\n    this.showHide$$.next('hide');\n  }\n\n  maskClick() {\n    if (this.options.maskClosable) {\n      this.hide();\n    }\n  }\n}\n","<div\n  #mask\n  class=\"aui-drawer-mask\"\n  *ngIf=\"options.mask\"\n  [class.isOpen]=\"maskVisible$ | async\"\n  (click)=\"maskClick()\"\n></div>\n<div\n  [style.marginTop]=\"options.offsetY\"\n  [ngClass]=\"drawerClasses\"\n  [@showHide]=\"showHide$$ | async\"\n  (@showHide.start)=\"onAnimation($event)\"\n  (@showHide.done)=\"onAnimation($event)\"\n  [style.width]=\"width\"\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 normal\"\n            [ngTemplateOutlet]=\"options.title\"\n            [ngTemplateOutletContext]=\"options.contentParams\"\n          ></ng-container>\n          <ng-template #normal>\n            {{ options.title }}\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\n          *ngIf=\"isTemplateRef(options.content)\"\n          [ngTemplateOutlet]=\"options.content\"\n          [ngTemplateOutletContext]=\"options.contentParams\"\n        >\n        </ng-container>\n      </div>\n\n      <div\n        *ngIf=\"options.footer\"\n        class=\"aui-drawer__footer\"\n      >\n        <ng-container\n          *ngIf=\"isTemplateRef(options.footer); else normal\"\n          [ngTemplateOutlet]=\"options.footer\"\n          [ngTemplateOutletContext]=\"options.contentParams\"\n        ></ng-container>\n        <ng-template #normal>\n          {{ options.footer }}\n        </ng-template>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhd2VyLXJlZi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kcmF3ZXIvZHJhd2VyLXJlZi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFjLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUluRCxNQUFNLE9BQU8sU0FBUztJQWNEO0lBYlgsTUFBTSxDQUFJO0lBRUQsVUFBVSxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7SUFDakMsWUFBWSxHQUFHLElBQUksT0FBTyxFQUFLLENBQUM7SUFFakQsSUFBSSxTQUFTO1FBQ1gsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ3hDLENBQUM7SUFFRCxJQUFJLFdBQVc7UUFDYixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDMUMsQ0FBQztJQUVELFlBQW1CLGNBQTZDO1FBQTdDLG1CQUFjLEdBQWQsY0FBYyxDQUErQjtRQUM5RCxJQUFJLENBQUMsY0FBYyxDQUFDLGNBQWM7YUFDL0IsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksS0FBSyxVQUFVLENBQUMsQ0FBQzthQUN6QyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ2QsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ3BDLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDL0IsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsSUFBSTtRQUNGLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDN0IsQ0FBQztJQUVELEtBQUssQ0FBQyxNQUFVO1FBQ2QsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7UUFDckIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUM3QixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmaWx0ZXIsIE9ic2VydmFibGUsIFN1YmplY3QgfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHsgRHJhd2VySW50ZXJuYWxDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudC9pbnRlcm5hbC9pbnRlcm5hbC5jb21wb25lbnQnO1xuXG5leHBvcnQgY2xhc3MgRHJhd2VyUmVmPFQgPSB1bmtub3duLCBDIGV4dGVuZHMgb2JqZWN0ID0gb2JqZWN0LCBSID0gdW5rbm93bj4ge1xuICBwcml2YXRlIHJlc3VsdDogUjtcblxuICBwcml2YXRlIHJlYWRvbmx5IGFmdGVyT3BlbiQgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xuICBwcml2YXRlIHJlYWRvbmx5IGFmdGVyQ2xvc2VkJCA9IG5ldyBTdWJqZWN0PFI+KCk7XG5cbiAgZ2V0IGFmdGVyT3BlbigpOiBPYnNlcnZhYmxlPHZvaWQ+IHtcbiAgICByZXR1cm4gdGhpcy5hZnRlck9wZW4kLmFzT2JzZXJ2YWJsZSgpO1xuICB9XG5cbiAgZ2V0IGFmdGVyQ2xvc2VkKCk6IE9ic2VydmFibGU8Uj4ge1xuICAgIHJldHVybiB0aGlzLmFmdGVyQ2xvc2VkJC5hc09ic2VydmFibGUoKTtcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBkcmF3ZXJJbnN0YW5jZTogRHJhd2VySW50ZXJuYWxDb21wb25lbnQ8VCwgQz4pIHtcbiAgICB0aGlzLmRyYXdlckluc3RhbmNlLmFuaW1hdGlvblN0ZXAkXG4gICAgICAucGlwZShmaWx0ZXIoc3RlcCA9PiBzdGVwID09PSAnaGlkZURvbmUnKSlcbiAgICAgIC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgICB0aGlzLmFmdGVyQ2xvc2VkJC5uZXh0KHRoaXMucmVzdWx0KTtcbiAgICAgICAgdGhpcy5hZnRlckNsb3NlZCQuY29tcGxldGUoKTtcbiAgICAgIH0pO1xuICB9XG5cbiAgb3BlbigpIHtcbiAgICB0aGlzLmRyYXdlckluc3RhbmNlLnNob3coKTtcbiAgfVxuXG4gIGNsb3NlKHJlc3VsdD86IFIpOiB2b2lkIHtcbiAgICB0aGlzLnJlc3VsdCA9IHJlc3VsdDtcbiAgICB0aGlzLmRyYXdlckluc3RhbmNlLmhpZGUoKTtcbiAgfVxufVxuIl19
@@ -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, DrawerComponent] });
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhd2VyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kcmF3ZXIvZHJhd2VyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDckQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFFckMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQy9ELE9BQU8sRUFDTCxzQkFBc0IsRUFDdEIscUJBQXFCLEVBQ3JCLHFCQUFxQixHQUN0QixNQUFNLCtCQUErQixDQUFDO0FBQ3ZDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7QUFFakQsTUFBTSxNQUFNLEdBQUc7SUFDYixlQUFlO0lBQ2YscUJBQXFCO0lBQ3JCLHNCQUFzQjtJQUN0QixxQkFBcUI7Q0FDdEIsQ0FBQztBQU9GLE1BQU0sT0FBTyxZQUFZO3VHQUFaLFlBQVk7d0dBQVosWUFBWSxZQUpiLFlBQVksRUFBRSxVQUFVLEVBQUUsYUFBYSxFQUFFLFlBQVksRUFQL0QsZUFBZTtZQUNmLHFCQUFxQjtZQUNyQixzQkFBc0I7WUFDdEIscUJBQXFCLGFBSHJCLGVBQWU7WUFDZixxQkFBcUI7WUFDckIsc0JBQXNCO1lBQ3RCLHFCQUFxQjt3R0FRVixZQUFZLGFBRlosQ0FBQyxhQUFhLENBQUMsWUFGaEIsWUFBWSxFQUFFLFVBQVUsRUFBRSxhQUFhLEVBQUUsWUFBWSxFQVAvRCxlQUFlOzsyRkFXSixZQUFZO2tCQUx4QixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxVQUFVLEVBQUUsYUFBYSxFQUFFLFlBQVksRUFBRSxHQUFHLE1BQU0sQ0FBQztvQkFDM0UsT0FBTyxFQUFFLE1BQU07b0JBQ2YsU0FBUyxFQUFFLENBQUMsYUFBYSxDQUFDO2lCQUMzQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE92ZXJsYXlNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XG5pbXBvcnQgeyBQb3J0YWxNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvcG9ydGFsJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBJY29uTW9kdWxlIH0gZnJvbSAnLi4vaWNvbic7XG5cbmltcG9ydCB7IERyYXdlckNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50L2RyYXdlci5jb21wb25lbnQnO1xuaW1wb3J0IHtcbiAgRHJhd2VyQ29udGVudERpcmVjdGl2ZSxcbiAgRHJhd2VyRm9vdGVyRGlyZWN0aXZlLFxuICBEcmF3ZXJIZWFkZXJEaXJlY3RpdmUsXG59IGZyb20gJy4vY29tcG9uZW50L2hlbHBlci1kaXJlY3RpdmVzJztcbmltcG9ydCB7IERyYXdlclNlcnZpY2UgfSBmcm9tICcuL2RyYXdlci5zZXJ2aWNlJztcblxuY29uc3QgQ09NTU9OID0gW1xuICBEcmF3ZXJDb21wb25lbnQsXG4gIERyYXdlckhlYWRlckRpcmVjdGl2ZSxcbiAgRHJhd2VyQ29udGVudERpcmVjdGl2ZSxcbiAgRHJhd2VyRm9vdGVyRGlyZWN0aXZlLFxuXTtcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgSWNvbk1vZHVsZSwgT3ZlcmxheU1vZHVsZSwgUG9ydGFsTW9kdWxlLCAuLi5DT01NT05dLFxuICBleHBvcnRzOiBDT01NT04sXG4gIHByb3ZpZGVyczogW0RyYXdlclNlcnZpY2VdLFxufSlcbmV4cG9ydCBjbGFzcyBEcmF3ZXJNb2R1bGUge31cbiJdfQ==
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 { DrawerComponent } from './component/drawer.component';
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
- unsubscribe$ = new Subject();
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
- return this.drawerRef?.instance;
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
- Object.assign(this.drawerRef.instance, options);
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
- this.overlayRef = this.overlay.create();
26
- this.drawerRef = this.overlayRef.attach(new ComponentPortal(DrawerComponent));
27
- this.drawerRef.instance.drawerViewInit
28
- .pipe(takeUntil(this.unsubscribe$))
29
- .subscribe(() => {
30
- this.drawerRef.instance.open();
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.drawerRef.instance.afterClosed
33
- .pipe(takeUntil(this.unsubscribe$))
34
- .subscribe(() => {
35
- this.overlayRef.dispose();
36
- this.drawerRef = null;
37
- this.unsubscribe$.next();
38
- this.unsubscribe$.complete();
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhd2VyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZHJhd2VyL2RyYXdlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxlQUFlLEVBQWlCLE1BQU0scUJBQXFCLENBQUM7QUFDckUsT0FBTyxFQUFnQixVQUFVLEVBQWUsTUFBTSxlQUFlLENBQUM7QUFDdEUsT0FBTyxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFMUMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDhCQUE4QixDQUFDOzs7QUFxQi9ELE1BQU0sT0FBTyxhQUFhO0lBS0s7SUFKckIsU0FBUyxDQUFnQztJQUN6QyxVQUFVLENBQWE7SUFDZCxZQUFZLEdBQUcsSUFBSSxPQUFPLEVBQVEsQ0FBQztJQUVwRCxZQUE2QixPQUFnQjtRQUFoQixZQUFPLEdBQVAsT0FBTyxDQUFTO0lBQUcsQ0FBQztJQUVqRCxJQUFJLENBQWMsT0FBeUI7UUFDekMsSUFBSSxDQUFDLFNBQVMsRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLENBQUM7UUFDcEMsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1FBQ3BCLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDNUIsT0FBTyxJQUFJLENBQUMsU0FBUyxFQUFFLFFBQVEsQ0FBQztJQUNsQyxDQUFDO0lBRUQsYUFBYSxDQUFDLE9BQXNCO1FBQ2xDLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDbEQsQ0FBQztJQUVPLFlBQVk7UUFDbEIsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ3hDLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQ3JDLElBQUksZUFBZSxDQUFDLGVBQWUsQ0FBQyxDQUNyQyxDQUFDO1FBQ0YsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsY0FBYzthQUNuQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQzthQUNsQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ2QsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDakMsQ0FBQyxDQUFDLENBQUM7UUFFTCxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxXQUFXO2FBQ2hDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO2FBQ2xDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDZCxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBQzFCLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDO1lBQ3RCLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDekIsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUMvQixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7dUdBckNVLGFBQWE7MkdBQWIsYUFBYTs7MkZBQWIsYUFBYTtrQkFEekIsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE92ZXJsYXksIE92ZXJsYXlSZWYgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XG5pbXBvcnQgeyBDb21wb25lbnRQb3J0YWwsIENvbXBvbmVudFR5cGUgfSBmcm9tICdAYW5ndWxhci9jZGsvcG9ydGFsJztcbmltcG9ydCB7IENvbXBvbmVudFJlZiwgSW5qZWN0YWJsZSwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN1YmplY3QsIHRha2VVbnRpbCB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBEcmF3ZXJDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudC9kcmF3ZXIuY29tcG9uZW50JztcblxuaW1wb3J0IHsgRHJhd2VyU2l6ZSB9IGZyb20gJy4nO1xuXG5leHBvcnQgaW50ZXJmYWNlIERyYXdlck9wdGlvbnM8VCA9IGFueSwgRCA9IGFueT4ge1xuICB0aXRsZT86IHN0cmluZyB8IFRlbXBsYXRlUmVmPHVua25vd24+O1xuICB3aWR0aD86IG51bWJlcjtcbiAgY29udGVudD86IENvbXBvbmVudFR5cGU8VD4gfCBUZW1wbGF0ZVJlZjxUPjtcbiAgY29udGVudFBhcmFtcz86IEQ7XG4gIGZvb3Rlcj86IHN0cmluZyB8IFRlbXBsYXRlUmVmPHVua25vd24+O1xuICBvZmZzZXRZPzogc3RyaW5nO1xuICBkaXZpZGVyPzogYm9vbGVhbjtcbiAgZHJhd2VyQ2xhc3M/OiBzdHJpbmc7XG4gIHNpemU/OiBEcmF3ZXJTaXplO1xuICB2aXNpYmxlPzogYm9vbGVhbjtcbiAgaGlkZU9uQ2xpY2tPdXRzaWRlPzogYm9vbGVhbjtcbiAgc2hvd0Nsb3NlPzogYm9vbGVhbjtcbiAgbWFzaz86IGJvb2xlYW47XG4gIG1hc2tDbG9zYWJsZT86IGJvb2xlYW47XG59XG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgRHJhd2VyU2VydmljZSB7XG4gIHByaXZhdGUgZHJhd2VyUmVmOiBDb21wb25lbnRSZWY8RHJhd2VyQ29tcG9uZW50PjtcbiAgcHJpdmF0ZSBvdmVybGF5UmVmOiBPdmVybGF5UmVmO1xuICBwcml2YXRlIHJlYWRvbmx5IHVuc3Vic2NyaWJlJCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBvdmVybGF5OiBPdmVybGF5KSB7fVxuXG4gIG9wZW48VCA9IHVua25vd24+KG9wdGlvbnM6IERyYXdlck9wdGlvbnM8VD4pIHtcbiAgICB0aGlzLmRyYXdlclJlZj8uaW5zdGFuY2U/LmRpc3Bvc2UoKTtcbiAgICB0aGlzLmNyZWF0ZURyYXdlcigpO1xuICAgIHRoaXMudXBkYXRlT3B0aW9ucyhvcHRpb25zKTtcbiAgICByZXR1cm4gdGhpcy5kcmF3ZXJSZWY/Lmluc3RhbmNlO1xuICB9XG5cbiAgdXBkYXRlT3B0aW9ucyhvcHRpb25zOiBEcmF3ZXJPcHRpb25zKTogdm9pZCB7XG4gICAgT2JqZWN0LmFzc2lnbih0aGlzLmRyYXdlclJlZi5pbnN0YW5jZSwgb3B0aW9ucyk7XG4gIH1cblxuICBwcml2YXRlIGNyZWF0ZURyYXdlcigpOiB2b2lkIHtcbiAgICB0aGlzLm92ZXJsYXlSZWYgPSB0aGlzLm92ZXJsYXkuY3JlYXRlKCk7XG4gICAgdGhpcy5kcmF3ZXJSZWYgPSB0aGlzLm92ZXJsYXlSZWYuYXR0YWNoKFxuICAgICAgbmV3IENvbXBvbmVudFBvcnRhbChEcmF3ZXJDb21wb25lbnQpLFxuICAgICk7XG4gICAgdGhpcy5kcmF3ZXJSZWYuaW5zdGFuY2UuZHJhd2VyVmlld0luaXRcbiAgICAgIC5waXBlKHRha2VVbnRpbCh0aGlzLnVuc3Vic2NyaWJlJCkpXG4gICAgICAuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgdGhpcy5kcmF3ZXJSZWYuaW5zdGFuY2Uub3BlbigpO1xuICAgICAgfSk7XG5cbiAgICB0aGlzLmRyYXdlclJlZi5pbnN0YW5jZS5hZnRlckNsb3NlZFxuICAgICAgLnBpcGUodGFrZVVudGlsKHRoaXMudW5zdWJzY3JpYmUkKSlcbiAgICAgIC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgICB0aGlzLm92ZXJsYXlSZWYuZGlzcG9zZSgpO1xuICAgICAgICB0aGlzLmRyYXdlclJlZiA9IG51bGw7XG4gICAgICAgIHRoaXMudW5zdWJzY3JpYmUkLm5leHQoKTtcbiAgICAgICAgdGhpcy51bnN1YnNjcmliZSQuY29tcGxldGUoKTtcbiAgICAgIH0pO1xuICB9XG59XG4iXX0=
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<\n  T = unknown,\n  C extends object = object,\n  R = unknown,\n> {\n  private overlayRef: OverlayRef;\n  options: DrawerOptions<T, C>;\n  drawerRef: DrawerRef<T, C, 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<T, C, R>(\n      this.drawerInternalComponentRef.instance,\n    );\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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscGVyLWRpcmVjdGl2ZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZHJhd2VyL2NvbXBvbmVudC9oZWxwZXItZGlyZWN0aXZlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQU0xQyxNQUFNLE9BQU8scUJBQXFCO3VHQUFyQixxQkFBcUI7MkZBQXJCLHFCQUFxQjs7MkZBQXJCLHFCQUFxQjtrQkFKakMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsbUJBQW1CO29CQUM3QixVQUFVLEVBQUUsSUFBSTtpQkFDakI7O0FBT0QsTUFBTSxPQUFPLHNCQUFzQjt1R0FBdEIsc0JBQXNCOzJGQUF0QixzQkFBc0I7OzJGQUF0QixzQkFBc0I7a0JBSmxDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLG9CQUFvQjtvQkFDOUIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOztBQU9ELE1BQU0sT0FBTyxxQkFBcUI7dUdBQXJCLHFCQUFxQjsyRkFBckIscUJBQXFCOzsyRkFBckIscUJBQXFCO2tCQUpqQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxtQkFBbUI7b0JBQzdCLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQHBhY2thZ2VEb2N1bWVudGF0aW9uXG4gKiBAbW9kdWxlIHBhZ2UtZ3VhcmRcbiAqL1xuXG5pbXBvcnQgeyBEaXJlY3RpdmUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2F1aURyYXdlckhlYWRlcl0nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBEcmF3ZXJIZWFkZXJEaXJlY3RpdmUge31cblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2F1aURyYXdlckNvbnRlbnRdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgRHJhd2VyQ29udGVudERpcmVjdGl2ZSB7fVxuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbYXVpRHJhd2VyRm9vdGVyXScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIERyYXdlckZvb3RlckRpcmVjdGl2ZSB7fVxuIl19
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscGVyLWRpcmVjdGl2ZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZHJhd2VyL2hlbHBlci1kaXJlY3RpdmVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUtBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTTFDLE1BQU0sT0FBTyxxQkFBcUI7dUdBQXJCLHFCQUFxQjsyRkFBckIscUJBQXFCOzsyRkFBckIscUJBQXFCO2tCQUpqQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxtQkFBbUI7b0JBQzdCLFVBQVUsRUFBRSxJQUFJO2lCQUNqQjs7QUFPRCxNQUFNLE9BQU8sc0JBQXNCO3VHQUF0QixzQkFBc0I7MkZBQXRCLHNCQUFzQjs7MkZBQXRCLHNCQUFzQjtrQkFKbEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsb0JBQW9CO29CQUM5QixVQUFVLEVBQUUsSUFBSTtpQkFDakI7O0FBT0QsTUFBTSxPQUFPLHFCQUFxQjt1R0FBckIscUJBQXFCOzJGQUFyQixxQkFBcUI7OzJGQUFyQixxQkFBcUI7a0JBSmpDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLG1CQUFtQjtvQkFDN0IsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb25cbiAqIEBtb2R1bGUgcGFnZS1ndWFyZFxuICovXG5cbmltcG9ydCB7IERpcmVjdGl2ZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbYXVpRHJhd2VySGVhZGVyXScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIERyYXdlckhlYWRlckRpcmVjdGl2ZSB7fVxuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbYXVpRHJhd2VyQ29udGVudF0nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBEcmF3ZXJDb250ZW50RGlyZWN0aXZlIHt9XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1thdWlEcmF3ZXJGb290ZXJdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgRHJhd2VyRm9vdGVyRGlyZWN0aXZlIHt9XG4iXX0=
@@ -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
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZHJhd2VyL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxrQkFBa0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50L2RyYXdlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnQvZHJhd2VyLXJlZic7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudC9oZWxwZXItZGlyZWN0aXZlcyc7XG5leHBvcnQgKiBmcm9tICcuL2RyYXdlci5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9kcmF3ZXIuc2VydmljZSc7XG4iXX0=
4
+ export * from './drawer-ref';
5
+ export * from './helper-directives';
6
+ export * from './types';
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZHJhd2VyL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudC9kcmF3ZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZHJhd2VyLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2RyYXdlci5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vZHJhd2VyLXJlZic7XG5leHBvcnQgKiBmcm9tICcuL2hlbHBlci1kaXJlY3RpdmVzJztcbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMnO1xuIl19
@@ -0,0 +1,6 @@
1
+ export const DrawerSize = {
2
+ Small: 'small',
3
+ Medium: 'medium',
4
+ Big: 'big',
5
+ };
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZHJhd2VyL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUtBLE1BQU0sQ0FBQyxNQUFNLFVBQVUsR0FBRztJQUN4QixLQUFLLEVBQUUsT0FBTztJQUNkLE1BQU0sRUFBRSxRQUFRO0lBQ2hCLEdBQUcsRUFBRSxLQUFLO0NBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudFR5cGUgfSBmcm9tICdAYW5ndWxhci9jZGsvcG9ydGFsJztcbmltcG9ydCB7IFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IFZhbHVlT2YgfSBmcm9tICcuLi90eXBlcyc7XG5cbmV4cG9ydCBjb25zdCBEcmF3ZXJTaXplID0ge1xuICBTbWFsbDogJ3NtYWxsJyxcbiAgTWVkaXVtOiAnbWVkaXVtJyxcbiAgQmlnOiAnYmlnJyxcbn0gYXMgY29uc3Q7XG5cbmV4cG9ydCB0eXBlIERyYXdlclNpemUgPSBWYWx1ZU9mPHR5cGVvZiBEcmF3ZXJTaXplPjtcblxuZXhwb3J0IGludGVyZmFjZSBEcmF3ZXJPcHRpb25zPFQgPSB1bmtub3duLCBDIGV4dGVuZHMgb2JqZWN0ID0gb2JqZWN0PiB7XG4gIHRpdGxlPzogc3RyaW5nIHwgVGVtcGxhdGVSZWY8Qz47XG4gIGNvbnRlbnQ/OiBDb21wb25lbnRUeXBlPFQ+IHwgVGVtcGxhdGVSZWY8Qz47XG4gIGZvb3Rlcj86IHN0cmluZyB8IFRlbXBsYXRlUmVmPEM+O1xuICBjb250ZW50UGFyYW1zPzogQzsgLy8g5LiN5LuF5L2c5Li6Y29udGVudOeahOWPguaVsO+8jOWQjOaXtuaYr3RpdGxl5ZKMZm9vdGVy55qE5LiK5LiL5paHXG4gIHdpZHRoPzogbnVtYmVyO1xuICBzaXplPzogRHJhd2VyU2l6ZTsgLy8g5YaF572u55qE5a695bqm5bC65a+477yM5Lmf5Y+v5Lul5L2/55SoIHdpZHRoIOiHquWumuS5iVxuICBvZmZzZXRZPzogc3RyaW5nO1xuICBkaXZpZGVyPzogYm9vbGVhbjtcbiAgZHJhd2VyQ2xhc3M/OiBzdHJpbmc7XG4gIHZpc2libGU/OiBib29sZWFuO1xuICBzaG93Q2xvc2U/OiBib29sZWFuO1xuICBtYXNrPzogYm9vbGVhbjtcbiAgbWFza0Nsb3NhYmxlPzogYm9vbGVhbjsgLy8g54K55Ye76IOM5pmv5piv5ZCm5YWz6Zet5oq95bGJXG4gIGhpZGVPbkNsaWNrT3V0c2lkZT86IGJvb2xlYW47IC8vIOWcqOaKveWxieWklueCueWHu+aYr+WQpuWFs+mXreaKveWxie+8jOS4jiBtYXNrQ2xvc2FibGUg55qE5Yy65Yir5piv5piv5ZCm5pyJIG1hc2tcbn1cbiJdfQ==
@@ -78,11 +78,11 @@ export class FormItemComponent {
78
78
  this.destroy$$.next();
79
79
  }
80
80
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: FormItemComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.FormDirective, optional: true }, { token: i2.NgForm, optional: true }, { token: i2.FormGroupDirective, optional: true }], target: i0.ɵɵFactoryTarget.Component });
81
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: FormItemComponent, isStandalone: true, selector: "aui-form-item", inputs: { labelWidth: "labelWidth", width: "width", labelPosition: "labelPosition", emptyAddon: "emptyAddon", plain: "plain" }, queries: [{ propertyName: "itemLabel", first: true, predicate: FormItemLabelDirective, descendants: true }, { propertyName: "itemControl", first: true, predicate: FormItemControlDirective, descendants: true }, { propertyName: "ngControls", predicate: NgControl, descendants: true }, { propertyName: "addons", predicate: FormItemAddonDirective }, { propertyName: "errors", predicate: FormItemErrorDirective }, { propertyName: "hints", predicate: FormItemHintDirective }], ngImport: i0, template: "<div\n [class]=\"bem.block(labelPosition)\"\n [class.isPlain]=\"plain\"\n [class.hasError]=\"hasError$ | async\"\n>\n <div\n [ngClass]=\"\n bem.element(\n 'label-wrapper',\n { required: !!itemControl?.required },\n labelPosition\n )\n \"\n [class.hasLabel]=\"!!itemLabel\"\n [style.width]=\"labelWidth\"\n >\n <ng-content select=\"label[auiFormItemLabel]\"></ng-content>\n </div>\n <div class=\"aui-form-item__container\">\n <div\n class=\"aui-form-item__content\"\n [ngClass]=\"formItemWidthClass\"\n >\n <ng-content></ng-content>\n <div\n *ngIf=\"emptyAddon || addons?.length\"\n class=\"aui-form-item__addon-wrapper\"\n >\n <ng-content select=\"[auiFormItemAddon]\"></ng-content>\n </div>\n </div>\n <div\n *ngIf=\"(hasError$ | async) && (errorCount$ | async)\"\n class=\"aui-form-item__error-wrapper\"\n >\n <ng-content select=\"[auiFormItemError]\"></ng-content>\n </div>\n <div\n *ngIf=\"hintCount$ | async\"\n class=\"aui-form-item__hint-wrapper\"\n >\n <ng-content select=\"[auiFormItemHint]\"></ng-content>\n </div>\n </div>\n</div>\n", styles: [".aui-form-item{display:flex;align-items:flex-start;margin-bottom:var(--aui-spacing-xl);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-form-item--top{flex-direction:column}.aui-form-item--top .aui-form-item__label-wrapper{line-height:var(--aui-line-height-m);margin-bottom:var(--aui-spacing-xs)}.aui-form-item--top .aui-form-item__label-wrapper:after{display:none}.aui-form-item__label-wrapper{display:flex;align-items:center;line-height:var(--aui-inline-height-m);flex-shrink:0;padding-right:var(--aui-spacing-m);overflow:hidden}.aui-form-item__label-wrapper--required .aui-form-item__label:before{content:\"*\";color:rgb(var(--aui-color-red));margin-right:var(--aui-spacing-s)}.aui-form-item__label-wrapper.hasLabel:after{content:\":\";align-self:flex-start;margin-left:var(--aui-spacing-xs)}.aui-form-item__label-wrapper--left{justify-content:flex-start}.aui-form-item__label-wrapper--left .aui-form-item__label{text-align:start}.aui-form-item__label-wrapper--right{justify-content:flex-end}.aui-form-item__label-wrapper--right .aui-form-item__label{text-align:end}.aui-form-item__label{display:block;line-height:var(--aui-line-height-s)}.aui-form-item__container{width:100%;min-width:0}.aui-form-item__content{display:flex;align-items:center;min-height:var(--aui-inline-height-m)}.aui-form-item__content--large .aui-form-item__control{flex:1;max-width:var(--aui-form-item-width-l)}.aui-form-item__content--medium .aui-form-item__control{flex:1;max-width:var(--aui-form-item-width-m)}.aui-form-item__content--small .aui-form-item__control{flex:1;max-width:var(--aui-form-item-width-s)}.aui-form-item__content+.aui-form-item__hint-wrapper,.aui-form-item__content+.aui-form-item__error-wrapper{margin-top:var(--aui-spacing-s)}.aui-form-item__hint-wrapper,.aui-form-item__error-wrapper{font-size:var(--aui-font-size-s);line-height:var(--aui-line-height-s);font-weight:var(--aui-font-weight-normal)}.aui-form-item__hint-wrapper{color:rgb(var(--aui-color-help-text))}.aui-form-item__error-wrapper{color:rgb(var(--aui-color-red))}.aui-form-item__addon-wrapper{align-self:flex-start;display:flex;align-items:center;flex-shrink:0;box-sizing:content-box;height:var(--aui-inline-height-m);min-width:var(--aui-icon-size-m);padding-left:var(--aui-spacing-m);color:rgb(var(--aui-color-n-4));font-size:var(--aui-font-size-m)}.aui-form-item__addon-wrapper aui-icon{font-size:var(--aui-icon-size-m)}.aui-form-item.isPlain .aui-form-item__label-wrapper{line-height:var(--aui-line-height-m)}.aui-form-item.isPlain .aui-form-item__label-wrapper--required .aui-form-item__label:before{display:none}.aui-form-item.isPlain .aui-form-item__content{min-height:var(--aui-line-height-m)}.aui-form-item.isPlain .aui-form-item__addon-wrapper{height:var(--aui-line-height-m)}.aui-form--inline{display:flex}.aui-form--inline .aui-form-item{margin-bottom:0;margin-right:var(--aui-spacing-m)}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
81
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: FormItemComponent, isStandalone: true, selector: "aui-form-item", inputs: { labelWidth: "labelWidth", width: "width", labelPosition: "labelPosition", emptyAddon: "emptyAddon", plain: "plain" }, queries: [{ propertyName: "itemLabel", first: true, predicate: FormItemLabelDirective, descendants: true }, { propertyName: "itemControl", first: true, predicate: FormItemControlDirective, descendants: true }, { propertyName: "ngControls", predicate: NgControl, descendants: true }, { propertyName: "addons", predicate: FormItemAddonDirective }, { propertyName: "errors", predicate: FormItemErrorDirective }, { propertyName: "hints", predicate: FormItemHintDirective }], ngImport: i0, template: "<div\n [class]=\"bem.block(labelPosition)\"\n [class.isPlain]=\"plain\"\n [class.hasError]=\"hasError$ | async\"\n>\n <div\n [ngClass]=\"\n bem.element(\n 'label-wrapper',\n { required: !!itemControl?.required },\n labelPosition\n )\n \"\n [class.hasLabel]=\"!!itemLabel\"\n [style.width]=\"labelWidth\"\n >\n <ng-content select=\"label[auiFormItemLabel]\"></ng-content>\n </div>\n <div class=\"aui-form-item__container\">\n <div\n class=\"aui-form-item__content\"\n [ngClass]=\"formItemWidthClass\"\n >\n <ng-content></ng-content>\n <div\n *ngIf=\"emptyAddon || addons?.length\"\n class=\"aui-form-item__addon-wrapper\"\n >\n <ng-content select=\"[auiFormItemAddon]\"></ng-content>\n </div>\n </div>\n <div\n *ngIf=\"(hasError$ | async) && (errorCount$ | async)\"\n class=\"aui-form-item__error-wrapper\"\n >\n <ng-content select=\"[auiFormItemError]\"></ng-content>\n </div>\n <div\n *ngIf=\"hintCount$ | async\"\n class=\"aui-form-item__hint-wrapper\"\n >\n <ng-content select=\"[auiFormItemHint]\"></ng-content>\n </div>\n </div>\n</div>\n", styles: [".aui-form-item{display:flex;align-items:flex-start;margin-bottom:var(--aui-spacing-xl);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-form-item--top{flex-direction:column}.aui-form-item--top .aui-form-item__label{line-height:var(--aui-line-height-m)}.aui-form-item--top .aui-form-item__label-wrapper{line-height:var(--aui-line-height-m);margin-bottom:var(--aui-spacing-s)}.aui-form-item--top .aui-form-item__label-wrapper:after{display:none}.aui-form-item__label-wrapper{display:flex;align-items:center;line-height:var(--aui-inline-height-m);flex-shrink:0;padding-right:var(--aui-spacing-m);overflow:hidden}.aui-form-item__label-wrapper--required .aui-form-item__label:before{content:\"*\";color:rgb(var(--aui-color-red));margin-right:var(--aui-spacing-s)}.aui-form-item__label-wrapper.hasLabel:after{content:\":\";align-self:flex-start;margin-left:var(--aui-spacing-xs)}.aui-form-item__label-wrapper--left{justify-content:flex-start}.aui-form-item__label-wrapper--left .aui-form-item__label{text-align:start}.aui-form-item__label-wrapper--right{justify-content:flex-end}.aui-form-item__label-wrapper--right .aui-form-item__label{text-align:end}.aui-form-item__label{display:block;line-height:var(--aui-line-height-s)}.aui-form-item__container{width:100%;min-width:0}.aui-form-item__content{display:flex;align-items:center;min-height:var(--aui-inline-height-m)}.aui-form-item__content--large .aui-form-item__control{flex:1;max-width:var(--aui-form-item-width-l)}.aui-form-item__content--medium .aui-form-item__control{flex:1;max-width:var(--aui-form-item-width-m)}.aui-form-item__content--small .aui-form-item__control{flex:1;max-width:var(--aui-form-item-width-s)}.aui-form-item__content+.aui-form-item__hint-wrapper,.aui-form-item__content+.aui-form-item__error-wrapper{margin-top:var(--aui-spacing-s)}.aui-form-item__hint-wrapper,.aui-form-item__error-wrapper{font-size:var(--aui-font-size-s);line-height:var(--aui-line-height-s);font-weight:var(--aui-font-weight-normal)}.aui-form-item__hint-wrapper{color:rgb(var(--aui-color-help-text))}.aui-form-item__error-wrapper{color:rgb(var(--aui-color-red))}.aui-form-item__addon-wrapper{align-self:flex-start;display:flex;align-items:center;flex-shrink:0;box-sizing:content-box;height:var(--aui-inline-height-m);min-width:var(--aui-icon-size-m);padding-left:var(--aui-spacing-m);color:rgb(var(--aui-color-n-4));font-size:var(--aui-font-size-m)}.aui-form-item__addon-wrapper aui-icon{font-size:var(--aui-icon-size-m)}.aui-form-item.isPlain .aui-form-item__label-wrapper{line-height:var(--aui-line-height-m)}.aui-form-item.isPlain .aui-form-item__label-wrapper--required .aui-form-item__label:before{display:none}.aui-form-item.isPlain .aui-form-item__content{min-height:var(--aui-line-height-m)}.aui-form-item.isPlain .aui-form-item__addon-wrapper{height:var(--aui-line-height-m)}.aui-form--inline{display:flex}.aui-form--inline .aui-form-item{margin-bottom:0;margin-right:var(--aui-spacing-m)}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
82
82
  }
83
83
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: FormItemComponent, decorators: [{
84
84
  type: Component,
85
- args: [{ selector: 'aui-form-item', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, preserveWhitespaces: false, standalone: true, imports: [NgClass, NgIf, AsyncPipe], template: "<div\n [class]=\"bem.block(labelPosition)\"\n [class.isPlain]=\"plain\"\n [class.hasError]=\"hasError$ | async\"\n>\n <div\n [ngClass]=\"\n bem.element(\n 'label-wrapper',\n { required: !!itemControl?.required },\n labelPosition\n )\n \"\n [class.hasLabel]=\"!!itemLabel\"\n [style.width]=\"labelWidth\"\n >\n <ng-content select=\"label[auiFormItemLabel]\"></ng-content>\n </div>\n <div class=\"aui-form-item__container\">\n <div\n class=\"aui-form-item__content\"\n [ngClass]=\"formItemWidthClass\"\n >\n <ng-content></ng-content>\n <div\n *ngIf=\"emptyAddon || addons?.length\"\n class=\"aui-form-item__addon-wrapper\"\n >\n <ng-content select=\"[auiFormItemAddon]\"></ng-content>\n </div>\n </div>\n <div\n *ngIf=\"(hasError$ | async) && (errorCount$ | async)\"\n class=\"aui-form-item__error-wrapper\"\n >\n <ng-content select=\"[auiFormItemError]\"></ng-content>\n </div>\n <div\n *ngIf=\"hintCount$ | async\"\n class=\"aui-form-item__hint-wrapper\"\n >\n <ng-content select=\"[auiFormItemHint]\"></ng-content>\n </div>\n </div>\n</div>\n", styles: [".aui-form-item{display:flex;align-items:flex-start;margin-bottom:var(--aui-spacing-xl);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-form-item--top{flex-direction:column}.aui-form-item--top .aui-form-item__label-wrapper{line-height:var(--aui-line-height-m);margin-bottom:var(--aui-spacing-xs)}.aui-form-item--top .aui-form-item__label-wrapper:after{display:none}.aui-form-item__label-wrapper{display:flex;align-items:center;line-height:var(--aui-inline-height-m);flex-shrink:0;padding-right:var(--aui-spacing-m);overflow:hidden}.aui-form-item__label-wrapper--required .aui-form-item__label:before{content:\"*\";color:rgb(var(--aui-color-red));margin-right:var(--aui-spacing-s)}.aui-form-item__label-wrapper.hasLabel:after{content:\":\";align-self:flex-start;margin-left:var(--aui-spacing-xs)}.aui-form-item__label-wrapper--left{justify-content:flex-start}.aui-form-item__label-wrapper--left .aui-form-item__label{text-align:start}.aui-form-item__label-wrapper--right{justify-content:flex-end}.aui-form-item__label-wrapper--right .aui-form-item__label{text-align:end}.aui-form-item__label{display:block;line-height:var(--aui-line-height-s)}.aui-form-item__container{width:100%;min-width:0}.aui-form-item__content{display:flex;align-items:center;min-height:var(--aui-inline-height-m)}.aui-form-item__content--large .aui-form-item__control{flex:1;max-width:var(--aui-form-item-width-l)}.aui-form-item__content--medium .aui-form-item__control{flex:1;max-width:var(--aui-form-item-width-m)}.aui-form-item__content--small .aui-form-item__control{flex:1;max-width:var(--aui-form-item-width-s)}.aui-form-item__content+.aui-form-item__hint-wrapper,.aui-form-item__content+.aui-form-item__error-wrapper{margin-top:var(--aui-spacing-s)}.aui-form-item__hint-wrapper,.aui-form-item__error-wrapper{font-size:var(--aui-font-size-s);line-height:var(--aui-line-height-s);font-weight:var(--aui-font-weight-normal)}.aui-form-item__hint-wrapper{color:rgb(var(--aui-color-help-text))}.aui-form-item__error-wrapper{color:rgb(var(--aui-color-red))}.aui-form-item__addon-wrapper{align-self:flex-start;display:flex;align-items:center;flex-shrink:0;box-sizing:content-box;height:var(--aui-inline-height-m);min-width:var(--aui-icon-size-m);padding-left:var(--aui-spacing-m);color:rgb(var(--aui-color-n-4));font-size:var(--aui-font-size-m)}.aui-form-item__addon-wrapper aui-icon{font-size:var(--aui-icon-size-m)}.aui-form-item.isPlain .aui-form-item__label-wrapper{line-height:var(--aui-line-height-m)}.aui-form-item.isPlain .aui-form-item__label-wrapper--required .aui-form-item__label:before{display:none}.aui-form-item.isPlain .aui-form-item__content{min-height:var(--aui-line-height-m)}.aui-form-item.isPlain .aui-form-item__addon-wrapper{height:var(--aui-line-height-m)}.aui-form--inline{display:flex}.aui-form--inline .aui-form-item{margin-bottom:0;margin-right:var(--aui-spacing-m)}\n"] }]
85
+ args: [{ selector: 'aui-form-item', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, preserveWhitespaces: false, standalone: true, imports: [NgClass, NgIf, AsyncPipe], template: "<div\n [class]=\"bem.block(labelPosition)\"\n [class.isPlain]=\"plain\"\n [class.hasError]=\"hasError$ | async\"\n>\n <div\n [ngClass]=\"\n bem.element(\n 'label-wrapper',\n { required: !!itemControl?.required },\n labelPosition\n )\n \"\n [class.hasLabel]=\"!!itemLabel\"\n [style.width]=\"labelWidth\"\n >\n <ng-content select=\"label[auiFormItemLabel]\"></ng-content>\n </div>\n <div class=\"aui-form-item__container\">\n <div\n class=\"aui-form-item__content\"\n [ngClass]=\"formItemWidthClass\"\n >\n <ng-content></ng-content>\n <div\n *ngIf=\"emptyAddon || addons?.length\"\n class=\"aui-form-item__addon-wrapper\"\n >\n <ng-content select=\"[auiFormItemAddon]\"></ng-content>\n </div>\n </div>\n <div\n *ngIf=\"(hasError$ | async) && (errorCount$ | async)\"\n class=\"aui-form-item__error-wrapper\"\n >\n <ng-content select=\"[auiFormItemError]\"></ng-content>\n </div>\n <div\n *ngIf=\"hintCount$ | async\"\n class=\"aui-form-item__hint-wrapper\"\n >\n <ng-content select=\"[auiFormItemHint]\"></ng-content>\n </div>\n </div>\n</div>\n", styles: [".aui-form-item{display:flex;align-items:flex-start;margin-bottom:var(--aui-spacing-xl);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-form-item--top{flex-direction:column}.aui-form-item--top .aui-form-item__label{line-height:var(--aui-line-height-m)}.aui-form-item--top .aui-form-item__label-wrapper{line-height:var(--aui-line-height-m);margin-bottom:var(--aui-spacing-s)}.aui-form-item--top .aui-form-item__label-wrapper:after{display:none}.aui-form-item__label-wrapper{display:flex;align-items:center;line-height:var(--aui-inline-height-m);flex-shrink:0;padding-right:var(--aui-spacing-m);overflow:hidden}.aui-form-item__label-wrapper--required .aui-form-item__label:before{content:\"*\";color:rgb(var(--aui-color-red));margin-right:var(--aui-spacing-s)}.aui-form-item__label-wrapper.hasLabel:after{content:\":\";align-self:flex-start;margin-left:var(--aui-spacing-xs)}.aui-form-item__label-wrapper--left{justify-content:flex-start}.aui-form-item__label-wrapper--left .aui-form-item__label{text-align:start}.aui-form-item__label-wrapper--right{justify-content:flex-end}.aui-form-item__label-wrapper--right .aui-form-item__label{text-align:end}.aui-form-item__label{display:block;line-height:var(--aui-line-height-s)}.aui-form-item__container{width:100%;min-width:0}.aui-form-item__content{display:flex;align-items:center;min-height:var(--aui-inline-height-m)}.aui-form-item__content--large .aui-form-item__control{flex:1;max-width:var(--aui-form-item-width-l)}.aui-form-item__content--medium .aui-form-item__control{flex:1;max-width:var(--aui-form-item-width-m)}.aui-form-item__content--small .aui-form-item__control{flex:1;max-width:var(--aui-form-item-width-s)}.aui-form-item__content+.aui-form-item__hint-wrapper,.aui-form-item__content+.aui-form-item__error-wrapper{margin-top:var(--aui-spacing-s)}.aui-form-item__hint-wrapper,.aui-form-item__error-wrapper{font-size:var(--aui-font-size-s);line-height:var(--aui-line-height-s);font-weight:var(--aui-font-weight-normal)}.aui-form-item__hint-wrapper{color:rgb(var(--aui-color-help-text))}.aui-form-item__error-wrapper{color:rgb(var(--aui-color-red))}.aui-form-item__addon-wrapper{align-self:flex-start;display:flex;align-items:center;flex-shrink:0;box-sizing:content-box;height:var(--aui-inline-height-m);min-width:var(--aui-icon-size-m);padding-left:var(--aui-spacing-m);color:rgb(var(--aui-color-n-4));font-size:var(--aui-font-size-m)}.aui-form-item__addon-wrapper aui-icon{font-size:var(--aui-icon-size-m)}.aui-form-item.isPlain .aui-form-item__label-wrapper{line-height:var(--aui-line-height-m)}.aui-form-item.isPlain .aui-form-item__label-wrapper--required .aui-form-item__label:before{display:none}.aui-form-item.isPlain .aui-form-item__content{min-height:var(--aui-line-height-m)}.aui-form-item.isPlain .aui-form-item__addon-wrapper{height:var(--aui-line-height-m)}.aui-form--inline{display:flex}.aui-form--inline .aui-form-item{margin-bottom:0;margin-right:var(--aui-spacing-m)}\n"] }]
86
86
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.FormDirective, decorators: [{
87
87
  type: Optional
88
88
  }] }, { type: i2.NgForm, decorators: [{
@@ -118,4 +118,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
118
118
  type: ContentChildren,
119
119
  args: [FormItemHintDirective]
120
120
  }] } });
121
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-item.component.js","sourceRoot":"","sources":["../../../../src/form/form-item/form-item.component.ts","../../../../src/form/form-item/form-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass, NgIf, AsyncPipe } from '@angular/common';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ContentChildren,\n  Input,\n  OnDestroy,\n  Optional,\n  QueryList,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { FormGroupDirective, NgControl, NgForm } from '@angular/forms';\nimport {\n  Observable,\n  Subject,\n  combineLatest,\n  merge,\n  map,\n  startWith,\n  switchMap,\n  takeUntil,\n} from 'rxjs';\n\nimport { Bem, buildBem, publishRef } from '../../utils';\nimport { FormDirective } from '../form.directive';\nimport { FormItemWidth, LabelPosition } from '../form.types';\nimport {\n  FormItemAddonDirective,\n  FormItemControlDirective,\n  FormItemErrorDirective,\n  FormItemHintDirective,\n  FormItemLabelDirective,\n} from '../helper-directives';\n\n@Component({\n  selector: 'aui-form-item',\n  templateUrl: './form-item.component.html',\n  styleUrls: ['./form-item.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n  standalone: true,\n  imports: [NgClass, NgIf, AsyncPipe],\n})\nexport class FormItemComponent implements AfterContentInit, OnDestroy {\n  bem: Bem = buildBem('aui-form-item');\n\n  @Input()\n  labelWidth: string = null;\n\n  @Input()\n  width: FormItemWidth;\n\n  @Input()\n  labelPosition: LabelPosition = LabelPosition.Right;\n\n  @Input()\n  emptyAddon = false;\n\n  @Input()\n  plain = false;\n\n  @ContentChild(FormItemLabelDirective, { static: false })\n  itemLabel: FormItemLabelDirective;\n\n  @ContentChild(FormItemControlDirective, { static: false })\n  itemControl: FormItemControlDirective;\n\n  @ContentChildren(NgControl, { descendants: true })\n  ngControls: QueryList<NgControl>;\n\n  @ContentChildren(FormItemAddonDirective)\n  addons: QueryList<FormItemAddonDirective>;\n\n  @ContentChildren(FormItemErrorDirective)\n  errors: QueryList<FormItemErrorDirective>;\n\n  @ContentChildren(FormItemHintDirective)\n  hints: QueryList<FormItemHintDirective>;\n\n  hasError$: Observable<boolean>;\n  errorCount$: Observable<number>;\n  hintCount$: Observable<number>;\n  parentForm: NgForm | FormGroupDirective;\n\n  private readonly destroy$$ = new Subject<void>();\n\n  get formItemWidthClass() {\n    return this.width\n      ? this.bem.element('content', { [this.width]: true })\n      : '';\n  }\n\n  constructor(\n    private readonly cdr: ChangeDetectorRef,\n    @Optional() private readonly auiForm: FormDirective,\n    @Optional() ngForm: NgForm,\n    @Optional() formGroup: FormGroupDirective,\n  ) {\n    this.parentForm = formGroup || ngForm;\n    if (this.auiForm) {\n      this.subscribeInputsFromParent();\n    }\n  }\n\n  ngAfterContentInit() {\n    this.hasError$ = this.ngControls.changes.pipe(\n      startWith(this.ngControls),\n      switchMap((controls: QueryList<NgControl>) =>\n        combineLatest(\n          controls.map(control => this.mapControlStatus(control)),\n        ).pipe(map(statuses => statuses.some(Boolean))),\n      ),\n    );\n\n    this.errorCount$ = this.errors.changes.pipe(\n      map(errors => errors.length),\n      startWith(this.errors.length),\n    );\n\n    this.hintCount$ = this.hints.changes.pipe(\n      map(hints => hints.length),\n      startWith(this.hints.length),\n    );\n  }\n\n  subscribeInputsFromParent() {\n    this.auiForm.labelWidth$\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(width => {\n        this.labelWidth = width;\n        this.cdr.markForCheck();\n      });\n    this.auiForm.labelPosition$\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(position => {\n        this.labelPosition = position;\n        this.cdr.markForCheck();\n      });\n    this.auiForm.emptyAddon$\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(emptyAddon => {\n        this.emptyAddon = emptyAddon;\n        this.cdr.markForCheck();\n      });\n  }\n\n  mapControlStatus(control: NgControl) {\n    return (\n      this.parentForm\n        ? combineLatest([\n            control.statusChanges.pipe(startWith(control.status)),\n            merge(\n              this.parentForm.statusChanges.pipe(\n                startWith(this.parentForm.status),\n              ),\n              this.parentForm.ngSubmit,\n            ),\n          ]).pipe(map(([status]: string[]) => status))\n        : control.statusChanges\n    ).pipe(\n      map(\n        (status: string) =>\n          status === 'INVALID' && (control.dirty || this.parentForm?.submitted),\n      ),\n      publishRef(),\n    );\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n  }\n}\n","<div\n  [class]=\"bem.block(labelPosition)\"\n  [class.isPlain]=\"plain\"\n  [class.hasError]=\"hasError$ | async\"\n>\n  <div\n    [ngClass]=\"\n      bem.element(\n        'label-wrapper',\n        { required: !!itemControl?.required },\n        labelPosition\n      )\n    \"\n    [class.hasLabel]=\"!!itemLabel\"\n    [style.width]=\"labelWidth\"\n  >\n    <ng-content select=\"label[auiFormItemLabel]\"></ng-content>\n  </div>\n  <div class=\"aui-form-item__container\">\n    <div\n      class=\"aui-form-item__content\"\n      [ngClass]=\"formItemWidthClass\"\n    >\n      <ng-content></ng-content>\n      <div\n        *ngIf=\"emptyAddon || addons?.length\"\n        class=\"aui-form-item__addon-wrapper\"\n      >\n        <ng-content select=\"[auiFormItemAddon]\"></ng-content>\n      </div>\n    </div>\n    <div\n      *ngIf=\"(hasError$ | async) && (errorCount$ | async)\"\n      class=\"aui-form-item__error-wrapper\"\n    >\n      <ng-content select=\"[auiFormItemError]\"></ng-content>\n    </div>\n    <div\n      *ngIf=\"hintCount$ | async\"\n      class=\"aui-form-item__hint-wrapper\"\n    >\n      <ng-content select=\"[auiFormItemHint]\"></ng-content>\n    </div>\n  </div>\n</div>\n"]}
121
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-item.component.js","sourceRoot":"","sources":["../../../../src/form/form-item/form-item.component.ts","../../../../src/form/form-item/form-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass, NgIf, AsyncPipe } from '@angular/common';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ContentChildren,\n  Input,\n  OnDestroy,\n  Optional,\n  QueryList,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { FormGroupDirective, NgControl, NgForm } from '@angular/forms';\nimport {\n  Observable,\n  Subject,\n  combineLatest,\n  merge,\n  map,\n  startWith,\n  switchMap,\n  takeUntil,\n} from 'rxjs';\n\nimport { Bem, buildBem, publishRef } from '../../utils';\nimport { FormDirective } from '../form.directive';\nimport { FormItemWidth, LabelPosition } from '../form.types';\nimport {\n  FormItemAddonDirective,\n  FormItemControlDirective,\n  FormItemErrorDirective,\n  FormItemHintDirective,\n  FormItemLabelDirective,\n} from '../helper-directives';\n\n@Component({\n  selector: 'aui-form-item',\n  templateUrl: './form-item.component.html',\n  styleUrls: ['./form-item.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n  standalone: true,\n  imports: [NgClass, NgIf, AsyncPipe],\n})\nexport class FormItemComponent implements AfterContentInit, OnDestroy {\n  bem: Bem = buildBem('aui-form-item');\n\n  @Input()\n  labelWidth: string = null;\n\n  @Input()\n  width: FormItemWidth;\n\n  @Input()\n  labelPosition: LabelPosition = LabelPosition.Right;\n\n  @Input()\n  emptyAddon = false;\n\n  @Input()\n  plain = false;\n\n  @ContentChild(FormItemLabelDirective, { static: false })\n  itemLabel: FormItemLabelDirective;\n\n  @ContentChild(FormItemControlDirective, { static: false })\n  itemControl: FormItemControlDirective;\n\n  @ContentChildren(NgControl, { descendants: true })\n  ngControls: QueryList<NgControl>;\n\n  @ContentChildren(FormItemAddonDirective)\n  addons: QueryList<FormItemAddonDirective>;\n\n  @ContentChildren(FormItemErrorDirective)\n  errors: QueryList<FormItemErrorDirective>;\n\n  @ContentChildren(FormItemHintDirective)\n  hints: QueryList<FormItemHintDirective>;\n\n  hasError$: Observable<boolean>;\n  errorCount$: Observable<number>;\n  hintCount$: Observable<number>;\n  parentForm: NgForm | FormGroupDirective;\n\n  private readonly destroy$$ = new Subject<void>();\n\n  get formItemWidthClass() {\n    return this.width\n      ? this.bem.element('content', { [this.width]: true })\n      : '';\n  }\n\n  constructor(\n    private readonly cdr: ChangeDetectorRef,\n    @Optional() private readonly auiForm: FormDirective,\n    @Optional() ngForm: NgForm,\n    @Optional() formGroup: FormGroupDirective,\n  ) {\n    this.parentForm = formGroup || ngForm;\n    if (this.auiForm) {\n      this.subscribeInputsFromParent();\n    }\n  }\n\n  ngAfterContentInit() {\n    this.hasError$ = this.ngControls.changes.pipe(\n      startWith(this.ngControls),\n      switchMap((controls: QueryList<NgControl>) =>\n        combineLatest(\n          controls.map(control => this.mapControlStatus(control)),\n        ).pipe(map(statuses => statuses.some(Boolean))),\n      ),\n    );\n\n    this.errorCount$ = this.errors.changes.pipe(\n      map(errors => errors.length),\n      startWith(this.errors.length),\n    );\n\n    this.hintCount$ = this.hints.changes.pipe(\n      map(hints => hints.length),\n      startWith(this.hints.length),\n    );\n  }\n\n  subscribeInputsFromParent() {\n    this.auiForm.labelWidth$\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(width => {\n        this.labelWidth = width;\n        this.cdr.markForCheck();\n      });\n    this.auiForm.labelPosition$\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(position => {\n        this.labelPosition = position;\n        this.cdr.markForCheck();\n      });\n    this.auiForm.emptyAddon$\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(emptyAddon => {\n        this.emptyAddon = emptyAddon;\n        this.cdr.markForCheck();\n      });\n  }\n\n  mapControlStatus(control: NgControl) {\n    return (\n      this.parentForm\n        ? combineLatest([\n            control.statusChanges.pipe(startWith(control.status)),\n            merge(\n              this.parentForm.statusChanges.pipe(\n                startWith(this.parentForm.status),\n              ),\n              this.parentForm.ngSubmit,\n            ),\n          ]).pipe(map(([status]: string[]) => status))\n        : control.statusChanges\n    ).pipe(\n      map(\n        (status: string) =>\n          status === 'INVALID' && (control.dirty || this.parentForm?.submitted),\n      ),\n      publishRef(),\n    );\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n  }\n}\n","<div\n  [class]=\"bem.block(labelPosition)\"\n  [class.isPlain]=\"plain\"\n  [class.hasError]=\"hasError$ | async\"\n>\n  <div\n    [ngClass]=\"\n      bem.element(\n        'label-wrapper',\n        { required: !!itemControl?.required },\n        labelPosition\n      )\n    \"\n    [class.hasLabel]=\"!!itemLabel\"\n    [style.width]=\"labelWidth\"\n  >\n    <ng-content select=\"label[auiFormItemLabel]\"></ng-content>\n  </div>\n  <div class=\"aui-form-item__container\">\n    <div\n      class=\"aui-form-item__content\"\n      [ngClass]=\"formItemWidthClass\"\n    >\n      <ng-content></ng-content>\n      <div\n        *ngIf=\"emptyAddon || addons?.length\"\n        class=\"aui-form-item__addon-wrapper\"\n      >\n        <ng-content select=\"[auiFormItemAddon]\"></ng-content>\n      </div>\n    </div>\n    <div\n      *ngIf=\"(hasError$ | async) && (errorCount$ | async)\"\n      class=\"aui-form-item__error-wrapper\"\n    >\n      <ng-content select=\"[auiFormItemError]\"></ng-content>\n    </div>\n    <div\n      *ngIf=\"hintCount$ | async\"\n      class=\"aui-form-item__hint-wrapper\"\n    >\n      <ng-content select=\"[auiFormItemHint]\"></ng-content>\n    </div>\n  </div>\n</div>\n"]}