ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
216 lines • 16.7 kB
JavaScript
/**
* @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"]}