@alauda/ui 7.2.0 → 7.2.1-beta.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.
|
@@ -3,7 +3,7 @@ import { CdkPortalOutlet, ComponentPortal, TemplatePortal, PortalModule, } from
|
|
|
3
3
|
import { CdkScrollable } from '@angular/cdk/scrolling';
|
|
4
4
|
import { NgIf, NgClass, NgStyle, NgTemplateOutlet } from '@angular/common';
|
|
5
5
|
import { ChangeDetectionStrategy, Component, ContentChild, EventEmitter, InjectionToken, Injector, Input, Output, TemplateRef, Type, ViewChild, ViewEncapsulation, } from '@angular/core';
|
|
6
|
-
import { Subject, takeUntil } from 'rxjs';
|
|
6
|
+
import { Subject, debounceTime, filter, fromEvent, takeUntil, } from 'rxjs';
|
|
7
7
|
import { IconComponent } from '../../icon/icon.component';
|
|
8
8
|
import { isTemplateRef } from '../../utils';
|
|
9
9
|
import { DrawerRef, DrawerSize } from './drawer-ref';
|
|
@@ -85,6 +85,13 @@ export class DrawerComponent extends DrawerRef {
|
|
|
85
85
|
this.attachOverlay();
|
|
86
86
|
this.updateBodyOverflow();
|
|
87
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
|
+
}
|
|
88
95
|
this.cdr.detectChanges();
|
|
89
96
|
}
|
|
90
97
|
ngOnChanges(changes) {
|
|
@@ -131,7 +138,9 @@ export class DrawerComponent extends DrawerRef {
|
|
|
131
138
|
return new OverlayConfig({
|
|
132
139
|
panelClass: DRAWER_OVERLAY_CLASS,
|
|
133
140
|
positionStrategy: this.overlay.position().global(),
|
|
134
|
-
scrollStrategy: this.
|
|
141
|
+
scrollStrategy: this.mask
|
|
142
|
+
? this.overlay.scrollStrategies.block()
|
|
143
|
+
: this.overlay.scrollStrategies.noop(),
|
|
135
144
|
});
|
|
136
145
|
}
|
|
137
146
|
attachBodyContent() {
|
|
@@ -253,4 +262,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
253
262
|
type: ContentChild,
|
|
254
263
|
args: [DrawerFooterDirective, { read: TemplateRef }]
|
|
255
264
|
}] } });
|
|
256
|
-
//# 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 { Observable, Subject, takeUntil } 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    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.overlay.scrollStrategies.block(),\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"]}
|
|
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      // scrollStrategy 为 Block 时，若打开 Drawer 时，高度不足以出现滚动，则 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"]}
|
package/fesm2022/alauda-ui.mjs
CHANGED
|
@@ -6874,6 +6874,13 @@ class DrawerComponent extends DrawerRef {
|
|
|
6874
6874
|
this.attachOverlay();
|
|
6875
6875
|
this.updateBodyOverflow();
|
|
6876
6876
|
this.templateContext = { $implicit: this.contentParams };
|
|
6877
|
+
if (this.mask) {
|
|
6878
|
+
fromEvent(window, 'resize')
|
|
6879
|
+
.pipe(debounceTime(100), filter(() => document.documentElement.scrollHeight > window.innerHeight), takeUntil(this.onDestroy$))
|
|
6880
|
+
.subscribe(() => {
|
|
6881
|
+
this.overlayRef.getConfig().scrollStrategy.enable();
|
|
6882
|
+
});
|
|
6883
|
+
}
|
|
6877
6884
|
this.cdr.detectChanges();
|
|
6878
6885
|
}
|
|
6879
6886
|
ngOnChanges(changes) {
|
|
@@ -6920,7 +6927,9 @@ class DrawerComponent extends DrawerRef {
|
|
|
6920
6927
|
return new OverlayConfig({
|
|
6921
6928
|
panelClass: DRAWER_OVERLAY_CLASS,
|
|
6922
6929
|
positionStrategy: this.overlay.position().global(),
|
|
6923
|
-
scrollStrategy: this.
|
|
6930
|
+
scrollStrategy: this.mask
|
|
6931
|
+
? this.overlay.scrollStrategies.block()
|
|
6932
|
+
: this.overlay.scrollStrategies.noop(),
|
|
6924
6933
|
});
|
|
6925
6934
|
}
|
|
6926
6935
|
attachBodyContent() {
|