ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
163 lines • 14.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @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';
export class NzMessageContainerComponent {
/**
* @param {?} cdr
* @param {?} nzConfigService
* @param {?} defaultConfig
* @param {?} config
*/
constructor(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(Object.assign({}, defaultConfig, config));
}
/**
* @return {?}
*/
ngOnInit() {
this.subscribeConfigChange();
}
/**
* @param {?=} config
* @return {?}
*/
setConfig(config) {
this.config = this.mergeMessageConfig(config);
this.top = toCssPixel(this.config.nzTop);
this.cdr.markForCheck();
}
/**
* Create a new message.
* @param {?} message Parsed message configuration.
* @return {?}
*/
createMessage(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.
* @return {?}
*/
removeMessage(messageId, userAction = false) {
this.messages.some((/**
* @param {?} message
* @param {?} index
* @return {?}
*/
(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.
* @return {?}
*/
removeMessageAll() {
this.messages = [];
this.cdr.detectChanges();
}
/**
* @protected
* @return {?}
*/
subscribeConfigChange() {
this.nzConfigService
.getConfigChangeEventForComponent(trimComponentName(this.constructor.name))
.subscribe((/**
* @return {?}
*/
() => this.setConfig()));
}
/**
* @protected
* @param {?=} config
* @return {?}
*/
mergeMessageConfig(config) {
return Object.assign({}, this.config, config, this.nzConfigService.getConfigForComponent(trimComponentName(this.constructor.name)));
}
/**
* Merge default options and custom message options
* @protected
* @param {?=} options
* @return {?}
*/
_mergeMessageOptions(options) {
/** @type {?} */
const defaultOptions = {
nzDuration: this.config.nzDuration,
nzAnimate: this.config.nzAnimate,
nzPauseOnHover: this.config.nzPauseOnHover
};
return Object.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 = () => [
{ 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,] }] }
];
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"]}