UNPKG

ng-zorro-antd

Version:

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

216 lines 16.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 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 { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, Optional, ViewEncapsulation } from '@angular/core'; import { Subject } from 'rxjs'; import { toCssPixel, trimComponentName, warnDeprecation, NzConfigService } from 'ng-zorro-antd/core'; import { NZ_MESSAGE_CONFIG, NZ_MESSAGE_DEFAULT_CONFIG } from './nz-message-config'; var NzMessageContainerComponent = /** @class */ (function () { function NzMessageContainerComponent(cdr, nzConfigService, defaultConfig, config) { this.cdr = cdr; this.nzConfigService = nzConfigService; this.messages = []; if (!!config) { warnDeprecation("Injection token 'NZ_MESSAGE_CONFIG' is deprecated and will be removed in 9.0.0. Please use 'NzConfigService' instead."); } this.setConfig(tslib_1.__assign({}, defaultConfig, config)); } /** * @return {?} */ NzMessageContainerComponent.prototype.ngOnInit = /** * @return {?} */ function () { this.subscribeConfigChange(); }; /** * @param {?=} config * @return {?} */ NzMessageContainerComponent.prototype.setConfig = /** * @param {?=} config * @return {?} */ function (config) { this.config = this.mergeMessageConfig(config); this.top = toCssPixel(this.config.nzTop); this.cdr.markForCheck(); }; /** * Create a new message. * @param message Parsed message configuration. */ /** * Create a new message. * @param {?} message Parsed message configuration. * @return {?} */ NzMessageContainerComponent.prototype.createMessage = /** * Create a new message. * @param {?} message Parsed message configuration. * @return {?} */ function (message) { if (this.messages.length >= this.config.nzMaxStack) { this.messages.splice(0, 1); } message.options = this._mergeMessageOptions(message.options); message.onClose = new Subject(); this.messages.push(message); this.cdr.detectChanges(); }; /** * Remove a message by `messageId`. * @param messageId Id of the message to be removed. * @param userAction Whether this is closed by user interaction. */ /** * Remove a message by `messageId`. * @param {?} messageId Id of the message to be removed. * @param {?=} userAction Whether this is closed by user interaction. * @return {?} */ NzMessageContainerComponent.prototype.removeMessage = /** * Remove a message by `messageId`. * @param {?} messageId Id of the message to be removed. * @param {?=} userAction Whether this is closed by user interaction. * @return {?} */ function (messageId, userAction) { var _this = this; if (userAction === void 0) { userAction = false; } this.messages.some((/** * @param {?} message * @param {?} index * @return {?} */ function (message, index) { if (message.messageId === messageId) { _this.messages.splice(index, 1); _this.cdr.detectChanges(); (/** @type {?} */ (message.onClose)).next(userAction); (/** @type {?} */ (message.onClose)).complete(); return true; } return false; })); }; /** * Remove all messages. */ /** * Remove all messages. * @return {?} */ NzMessageContainerComponent.prototype.removeMessageAll = /** * Remove all messages. * @return {?} */ function () { this.messages = []; this.cdr.detectChanges(); }; /** * @protected * @return {?} */ NzMessageContainerComponent.prototype.subscribeConfigChange = /** * @protected * @return {?} */ function () { var _this = this; this.nzConfigService .getConfigChangeEventForComponent(trimComponentName(this.constructor.name)) .subscribe((/** * @return {?} */ function () { return _this.setConfig(); })); }; /** * @protected * @param {?=} config * @return {?} */ NzMessageContainerComponent.prototype.mergeMessageConfig = /** * @protected * @param {?=} config * @return {?} */ function (config) { return tslib_1.__assign({}, this.config, config, this.nzConfigService.getConfigForComponent(trimComponentName(this.constructor.name))); }; /** * Merge default options and custom message options * @param options */ /** * Merge default options and custom message options * @protected * @param {?=} options * @return {?} */ NzMessageContainerComponent.prototype._mergeMessageOptions = /** * Merge default options and custom message options * @protected * @param {?=} options * @return {?} */ function (options) { /** @type {?} */ var defaultOptions = { nzDuration: this.config.nzDuration, nzAnimate: this.config.nzAnimate, nzPauseOnHover: this.config.nzPauseOnHover }; return tslib_1.__assign({}, defaultOptions, options); }; NzMessageContainerComponent.decorators = [ { type: Component, args: [{ changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, selector: 'nz-message-container', exportAs: 'nzMessageContainer', preserveWhitespaces: false, template: "<div class=\"ant-message\" [style.top]=\"top\">\n <nz-message *ngFor=\"let message of messages; let i = index\" [nzMessage]=\"message\" [nzIndex]=\"i\"></nz-message>\n</div>" }] } ]; /** @nocollapse */ NzMessageContainerComponent.ctorParameters = function () { return [ { type: ChangeDetectorRef }, { type: NzConfigService }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [NZ_MESSAGE_DEFAULT_CONFIG,] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [NZ_MESSAGE_CONFIG,] }] } ]; }; return NzMessageContainerComponent; }()); export { NzMessageContainerComponent }; if (false) { /** @type {?} */ NzMessageContainerComponent.prototype.messages; /** @type {?} */ NzMessageContainerComponent.prototype.config; /** @type {?} */ NzMessageContainerComponent.prototype.top; /** * @type {?} * @protected */ NzMessageContainerComponent.prototype.cdr; /** * @type {?} * @protected */ NzMessageContainerComponent.prototype.nzConfigService; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-message-container.component.js","sourceRoot":"ng://ng-zorro-antd/message/","sources":["nz-message-container.component.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 {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Inject,\n  OnInit,\n  Optional,\n  ViewEncapsulation\n} from '@angular/core';\nimport { Subject } from 'rxjs';\n\nimport { toCssPixel, trimComponentName, warnDeprecation, NzConfigService } from 'ng-zorro-antd/core';\n\nimport { NzMessageConfigLegacy, NZ_MESSAGE_CONFIG, NZ_MESSAGE_DEFAULT_CONFIG } from './nz-message-config';\nimport { NzMessageDataFilled, NzMessageDataOptions } from './nz-message.definitions';\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  selector: 'nz-message-container',\n  exportAs: 'nzMessageContainer',\n  preserveWhitespaces: false,\n  templateUrl: './nz-message-container.component.html'\n})\nexport class NzMessageContainerComponent implements OnInit {\n  messages: NzMessageDataFilled[] = [];\n  config: Required<NzMessageConfigLegacy>;\n  top: string | null;\n\n  constructor(\n    protected cdr: ChangeDetectorRef,\n    protected nzConfigService: NzConfigService,\n    @Optional() @Inject(NZ_MESSAGE_DEFAULT_CONFIG) defaultConfig: NzMessageConfigLegacy,\n    @Optional() @Inject(NZ_MESSAGE_CONFIG) config: NzMessageConfigLegacy\n  ) {\n    if (!!config) {\n      warnDeprecation(\n        `Injection token 'NZ_MESSAGE_CONFIG' is deprecated and will be removed in 9.0.0. Please use 'NzConfigService' instead.`\n      );\n    }\n    this.setConfig({ ...defaultConfig, ...config });\n  }\n\n  ngOnInit(): void {\n    this.subscribeConfigChange();\n  }\n\n  setConfig(config?: NzMessageConfigLegacy): void {\n    this.config = this.mergeMessageConfig(config);\n    this.top = toCssPixel(this.config.nzTop);\n    this.cdr.markForCheck();\n  }\n\n  /**\n   * Create a new message.\n   * @param message Parsed message configuration.\n   */\n  createMessage(message: NzMessageDataFilled): void {\n    if (this.messages.length >= this.config.nzMaxStack) {\n      this.messages.splice(0, 1);\n    }\n    message.options = this._mergeMessageOptions(message.options);\n    message.onClose = new Subject<boolean>();\n    this.messages.push(message);\n    this.cdr.detectChanges();\n  }\n\n  /**\n   * Remove a message by `messageId`.\n   * @param messageId Id of the message to be removed.\n   * @param userAction Whether this is closed by user interaction.\n   */\n  removeMessage(messageId: string, userAction: boolean = false): void {\n    this.messages.some((message, index) => {\n      if (message.messageId === messageId) {\n        this.messages.splice(index, 1);\n        this.cdr.detectChanges();\n        message.onClose!.next(userAction);\n        message.onClose!.complete();\n        return true;\n      }\n      return false;\n    });\n  }\n\n  /**\n   * Remove all messages.\n   */\n  removeMessageAll(): void {\n    this.messages = [];\n    this.cdr.detectChanges();\n  }\n\n  protected subscribeConfigChange(): void {\n    this.nzConfigService\n      .getConfigChangeEventForComponent(trimComponentName(this.constructor.name))\n      .subscribe(() => this.setConfig());\n  }\n\n  protected mergeMessageConfig(config?: NzMessageConfigLegacy): Required<NzMessageConfigLegacy> {\n    return {\n      ...this.config,\n      ...config,\n      ...this.nzConfigService.getConfigForComponent(trimComponentName(this.constructor.name))\n    };\n  }\n\n  /**\n   * Merge default options and custom message options\n   * @param options\n   */\n  protected _mergeMessageOptions(options?: NzMessageDataOptions): NzMessageDataOptions {\n    const defaultOptions: NzMessageDataOptions = {\n      nzDuration: this.config.nzDuration,\n      nzAnimate: this.config.nzAnimate,\n      nzPauseOnHover: this.config.nzPauseOnHover\n    };\n    return { ...defaultOptions, ...options };\n  }\n}\n"]}