UNPKG

ng-zorro-antd

Version:

An enterprise-class UI components based on Ant Design and Angular

516 lines 29.7 kB
/** * @fileoverview added by tsickle * Generated from: base.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { __assign, __read, __spread } from "tslib"; /** * @license * Copyright Alibaba.com All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE */ import { ComponentPortal } from '@angular/cdk/portal'; import { EventEmitter } from '@angular/core'; import { Subject } from 'rxjs'; /** @type {?} */ var globalCounter = 0; /** * @abstract */ var /** * @abstract */ NzMNService = /** @class */ (function () { function NzMNService(nzSingletonService, overlay, injector) { this.nzSingletonService = nzSingletonService; this.overlay = overlay; this.injector = injector; } /** * @param {?=} id * @return {?} */ NzMNService.prototype.remove = /** * @param {?=} id * @return {?} */ function (id) { if (this.container) { if (id) { this.container.remove(id); } else { this.container.removeAll(); } } }; /** * @protected * @return {?} */ NzMNService.prototype.getInstanceId = /** * @protected * @return {?} */ function () { return this.componentPrefix + "-" + globalCounter++; }; /** * @protected * @template T * @param {?} ctor * @return {?} */ NzMNService.prototype.withContainer = /** * @protected * @template T * @param {?} ctor * @return {?} */ function (ctor) { /** @type {?} */ var containerInstance = this.nzSingletonService.getSingletonWithKey(this.componentPrefix); if (containerInstance) { return (/** @type {?} */ (containerInstance)); } /** @type {?} */ var overlayRef = this.overlay.create({ hasBackdrop: false, scrollStrategy: this.overlay.scrollStrategies.noop(), positionStrategy: this.overlay.position().global() }); /** @type {?} */ var componentPortal = new ComponentPortal(ctor, null, this.injector); /** @type {?} */ var componentRef = overlayRef.attach(componentPortal); /** @type {?} */ var overlayPane = overlayRef.overlayElement; overlayPane.style.zIndex = '1010'; if (!containerInstance) { this.container = containerInstance = componentRef.instance; this.nzSingletonService.registerSingletonWithKey(this.componentPrefix, containerInstance); } return (/** @type {?} */ (containerInstance)); }; return NzMNService; }()); /** * @abstract */ export { NzMNService }; if (false) { /** * @type {?} * @protected */ NzMNService.prototype.componentPrefix; /** * @type {?} * @protected */ NzMNService.prototype.container; /** * @type {?} * @protected */ NzMNService.prototype.nzSingletonService; /** * @type {?} * @protected */ NzMNService.prototype.overlay; /** * @type {?} * @private */ NzMNService.prototype.injector; } /** * @abstract */ var /** * @abstract */ NzMNContainerComponent = /** @class */ (function () { function NzMNContainerComponent(cdr, nzConfigService) { this.cdr = cdr; this.nzConfigService = nzConfigService; this.instances = []; this.destroy$ = new Subject(); this.updateConfig(); } /** * @return {?} */ NzMNContainerComponent.prototype.ngOnInit = /** * @return {?} */ function () { this.subscribeConfigChange(); }; /** * @return {?} */ NzMNContainerComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { this.destroy$.next(); this.destroy$.complete(); }; /** * @param {?} data * @return {?} */ NzMNContainerComponent.prototype.create = /** * @param {?} data * @return {?} */ function (data) { /** @type {?} */ var instance = this.onCreate(data); if (this.instances.length >= (/** @type {?} */ (this.config)).nzMaxStack) { this.instances = this.instances.slice(1); } this.instances = __spread(this.instances, [instance]); this.readyInstances(); return instance; }; /** * @param {?} id * @param {?=} userAction * @return {?} */ NzMNContainerComponent.prototype.remove = /** * @param {?} id * @param {?=} userAction * @return {?} */ function (id, userAction) { var _this = this; if (userAction === void 0) { userAction = false; } this.instances.some((/** * @param {?} instance * @param {?} index * @return {?} */ function (instance, index) { if (instance.messageId === id) { _this.instances.splice(index, 1); _this.instances = __spread(_this.instances); _this.onRemove(instance, userAction); _this.readyInstances(); return true; } return false; })); }; /** * @return {?} */ NzMNContainerComponent.prototype.removeAll = /** * @return {?} */ function () { var _this = this; this.instances.forEach((/** * @param {?} i * @return {?} */ function (i) { return _this.onRemove(i, false); })); this.instances = []; this.readyInstances(); }; /** * @protected * @param {?} instance * @return {?} */ NzMNContainerComponent.prototype.onCreate = /** * @protected * @param {?} instance * @return {?} */ function (instance) { instance.options = this.mergeOptions(instance.options); instance.onClose = new Subject(); return (/** @type {?} */ (instance)); }; /** * @protected * @param {?} instance * @param {?} userAction * @return {?} */ NzMNContainerComponent.prototype.onRemove = /** * @protected * @param {?} instance * @param {?} userAction * @return {?} */ function (instance, userAction) { instance.onClose.next(userAction); instance.onClose.complete(); }; /** * @protected * @return {?} */ NzMNContainerComponent.prototype.readyInstances = /** * @protected * @return {?} */ function () { this.cdr.detectChanges(); }; /** * @protected * @param {?=} options * @return {?} */ NzMNContainerComponent.prototype.mergeOptions = /** * @protected * @param {?=} options * @return {?} */ function (options) { var _a = (/** @type {?} */ (this.config)), nzDuration = _a.nzDuration, nzAnimate = _a.nzAnimate, nzPauseOnHover = _a.nzPauseOnHover; return __assign({ nzDuration: nzDuration, nzAnimate: nzAnimate, nzPauseOnHover: nzPauseOnHover }, options); }; return NzMNContainerComponent; }()); /** * @abstract */ export { NzMNContainerComponent }; if (false) { /** @type {?} */ NzMNContainerComponent.prototype.config; /** @type {?} */ NzMNContainerComponent.prototype.instances; /** * @type {?} * @protected */ NzMNContainerComponent.prototype.destroy$; /** * @type {?} * @protected */ NzMNContainerComponent.prototype.cdr; /** * @type {?} * @protected */ NzMNContainerComponent.prototype.nzConfigService; /** * @abstract * @protected * @return {?} */ NzMNContainerComponent.prototype.updateConfig = function () { }; /** * @abstract * @protected * @return {?} */ NzMNContainerComponent.prototype.subscribeConfigChange = function () { }; } /** * @abstract */ var /** * @abstract */ NzMNComponent = /** @class */ (function () { function NzMNComponent(cdr) { this.cdr = cdr; this.destroyed = new EventEmitter(); this.eraseTimer = null; } /** * @return {?} */ NzMNComponent.prototype.ngOnInit = /** * @return {?} */ function () { this.options = (/** @type {?} */ (this.instance.options)); if (this.options.nzAnimate) { this.instance.state = 'enter'; } this.autoClose = this.options.nzDuration > 0; if (this.autoClose) { this.initErase(); this.startEraseTimeout(); } }; /** * @return {?} */ NzMNComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { if (this.autoClose) { this.clearEraseTimeout(); } }; /** * @return {?} */ NzMNComponent.prototype.onEnter = /** * @return {?} */ function () { if (this.autoClose && this.options.nzPauseOnHover) { this.clearEraseTimeout(); this.updateTTL(); } }; /** * @return {?} */ NzMNComponent.prototype.onLeave = /** * @return {?} */ function () { if (this.autoClose && this.options.nzPauseOnHover) { this.startEraseTimeout(); } }; /** * @protected * @param {?=} userAction * @return {?} */ NzMNComponent.prototype.destroy = /** * @protected * @param {?=} userAction * @return {?} */ function (userAction) { var _this = this; if (userAction === void 0) { userAction = false; } if (this.options.nzAnimate) { this.instance.state = 'leave'; this.cdr.detectChanges(); setTimeout((/** * @return {?} */ function () { _this.destroyed.next({ id: _this.instance.messageId, userAction: userAction }); }), 200); } else { this.destroyed.next({ id: this.instance.messageId, userAction: userAction }); } }; /** * @private * @return {?} */ NzMNComponent.prototype.initErase = /** * @private * @return {?} */ function () { this.eraseTTL = this.options.nzDuration; this.eraseTimingStart = Date.now(); }; /** * @private * @return {?} */ NzMNComponent.prototype.updateTTL = /** * @private * @return {?} */ function () { if (this.autoClose) { this.eraseTTL -= Date.now() - (/** @type {?} */ (this.eraseTimingStart)); } }; /** * @private * @return {?} */ NzMNComponent.prototype.startEraseTimeout = /** * @private * @return {?} */ function () { var _this = this; if (this.eraseTTL > 0) { this.clearEraseTimeout(); this.eraseTimer = setTimeout((/** * @return {?} */ function () { return _this.destroy(); }), this.eraseTTL); this.eraseTimingStart = Date.now(); } else { this.destroy(); } }; /** * @private * @return {?} */ NzMNComponent.prototype.clearEraseTimeout = /** * @private * @return {?} */ function () { if (this.eraseTimer !== null) { clearTimeout(this.eraseTimer); this.eraseTimer = null; } }; return NzMNComponent; }()); /** * @abstract */ export { NzMNComponent }; if (false) { /** @type {?} */ NzMNComponent.prototype.instance; /** @type {?} */ NzMNComponent.prototype.index; /** @type {?} */ NzMNComponent.prototype.destroyed; /** * @type {?} * @protected */ NzMNComponent.prototype.options; /** * @type {?} * @protected */ NzMNComponent.prototype.autoClose; /** * @type {?} * @protected */ NzMNComponent.prototype.eraseTimer; /** * @type {?} * @protected */ NzMNComponent.prototype.eraseTimingStart; /** * @type {?} * @protected */ NzMNComponent.prototype.eraseTTL; /** * @type {?} * @protected */ NzMNComponent.prototype.cdr; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"ng://ng-zorro-antd/message/","sources":["base.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Alibaba.com All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { ComponentType, Overlay } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { ChangeDetectorRef, EventEmitter, Injector, OnDestroy, OnInit } from '@angular/core';\nimport { MessageConfig, NzConfigService } from 'ng-zorro-antd/core/config';\nimport { NzSingletonService } from 'ng-zorro-antd/core/services';\nimport { Subject } from 'rxjs';\n\nimport { NzMessageData, NzMessageDataOptions } from './typings';\n\nlet globalCounter = 0;\n\nexport abstract class NzMNService {\n  protected abstract componentPrefix: string;\n  protected container?: NzMNContainerComponent;\n\n  constructor(protected nzSingletonService: NzSingletonService, protected overlay: Overlay, private injector: Injector) {}\n\n  remove(id?: string): void {\n    if (this.container) {\n      if (id) {\n        this.container.remove(id);\n      } else {\n        this.container.removeAll();\n      }\n    }\n  }\n\n  protected getInstanceId(): string {\n    return `${this.componentPrefix}-${globalCounter++}`;\n  }\n\n  protected withContainer<T extends NzMNContainerComponent>(ctor: ComponentType<T>): T {\n    let containerInstance = this.nzSingletonService.getSingletonWithKey(this.componentPrefix);\n    if (containerInstance) {\n      return containerInstance as T;\n    }\n\n    const overlayRef = this.overlay.create({\n      hasBackdrop: false,\n      scrollStrategy: this.overlay.scrollStrategies.noop(),\n      positionStrategy: this.overlay.position().global()\n    });\n    const componentPortal = new ComponentPortal(ctor, null, this.injector);\n    const componentRef = overlayRef.attach(componentPortal);\n    const overlayPane = overlayRef.overlayElement;\n    overlayPane.style.zIndex = '1010';\n\n    if (!containerInstance) {\n      this.container = containerInstance = componentRef.instance;\n      this.nzSingletonService.registerSingletonWithKey(this.componentPrefix, containerInstance);\n    }\n\n    return containerInstance as T;\n  }\n}\n\nexport abstract class NzMNContainerComponent implements OnInit, OnDestroy {\n  config?: Required<MessageConfig>;\n  instances: Array<Required<NzMessageData>> = [];\n\n  protected readonly destroy$ = new Subject<void>();\n\n  constructor(protected cdr: ChangeDetectorRef, protected nzConfigService: NzConfigService) {\n    this.updateConfig();\n  }\n\n  ngOnInit(): void {\n    this.subscribeConfigChange();\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  create(data: NzMessageData): Required<NzMessageData> {\n    const instance = this.onCreate(data);\n\n    if (this.instances.length >= this.config!.nzMaxStack) {\n      this.instances = this.instances.slice(1);\n    }\n\n    this.instances = [...this.instances, instance];\n\n    this.readyInstances();\n\n    return instance;\n  }\n\n  remove(id: string, userAction: boolean = false): void {\n    this.instances.some((instance, index) => {\n      if (instance.messageId === id) {\n        this.instances.splice(index, 1);\n        this.instances = [...this.instances];\n        this.onRemove(instance, userAction);\n        this.readyInstances();\n        return true;\n      }\n      return false;\n    });\n  }\n\n  removeAll(): void {\n    this.instances.forEach(i => this.onRemove(i, false));\n    this.instances = [];\n\n    this.readyInstances();\n  }\n\n  protected onCreate(instance: NzMessageData): Required<NzMessageData> {\n    instance.options = this.mergeOptions(instance.options);\n    instance.onClose = new Subject<boolean>();\n    return instance as Required<NzMessageData>;\n  }\n\n  protected onRemove(instance: Required<NzMessageData>, userAction: boolean): void {\n    instance.onClose.next(userAction);\n    instance.onClose.complete();\n  }\n\n  protected readyInstances(): void {\n    this.cdr.detectChanges();\n  }\n\n  protected abstract updateConfig(): void;\n\n  protected abstract subscribeConfigChange(): void;\n\n  protected mergeOptions(options?: NzMessageDataOptions): NzMessageDataOptions {\n    const { nzDuration, nzAnimate, nzPauseOnHover } = this.config!;\n    return { nzDuration, nzAnimate, nzPauseOnHover, ...options };\n  }\n}\n\nexport abstract class NzMNComponent implements OnInit, OnDestroy {\n  instance!: Required<NzMessageData>;\n  index?: number;\n\n  readonly destroyed = new EventEmitter<{ id: string; userAction: boolean }>();\n\n  protected options!: Required<NzMessageDataOptions>;\n  protected autoClose?: boolean;\n  protected eraseTimer: number | null = null;\n  protected eraseTimingStart?: number;\n  protected eraseTTL!: number;\n\n  constructor(protected cdr: ChangeDetectorRef) {}\n\n  ngOnInit(): void {\n    this.options = this.instance.options as Required<NzMessageDataOptions>;\n\n    if (this.options.nzAnimate) {\n      this.instance.state = 'enter';\n    }\n\n    this.autoClose = this.options.nzDuration > 0;\n\n    if (this.autoClose) {\n      this.initErase();\n      this.startEraseTimeout();\n    }\n  }\n\n  ngOnDestroy(): void {\n    if (this.autoClose) {\n      this.clearEraseTimeout();\n    }\n  }\n\n  onEnter(): void {\n    if (this.autoClose && this.options.nzPauseOnHover) {\n      this.clearEraseTimeout();\n      this.updateTTL();\n    }\n  }\n\n  onLeave(): void {\n    if (this.autoClose && this.options.nzPauseOnHover) {\n      this.startEraseTimeout();\n    }\n  }\n\n  protected destroy(userAction: boolean = false): void {\n    if (this.options.nzAnimate) {\n      this.instance.state = 'leave';\n      this.cdr.detectChanges();\n      setTimeout(() => {\n        this.destroyed.next({ id: this.instance.messageId, userAction: userAction });\n      }, 200);\n    } else {\n      this.destroyed.next({ id: this.instance.messageId, userAction: userAction });\n    }\n  }\n\n  private initErase(): void {\n    this.eraseTTL = this.options.nzDuration;\n    this.eraseTimingStart = Date.now();\n  }\n\n  private updateTTL(): void {\n    if (this.autoClose) {\n      this.eraseTTL -= Date.now() - this.eraseTimingStart!;\n    }\n  }\n\n  private startEraseTimeout(): void {\n    if (this.eraseTTL > 0) {\n      this.clearEraseTimeout();\n      this.eraseTimer = setTimeout(() => this.destroy(), this.eraseTTL);\n      this.eraseTimingStart = Date.now();\n    } else {\n      this.destroy();\n    }\n  }\n\n  private clearEraseTimeout(): void {\n    if (this.eraseTimer !== null) {\n      clearTimeout(this.eraseTimer);\n      this.eraseTimer = null;\n    }\n  }\n}\n"]}