ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
169 lines • 16.2 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 { NzMessageContainerComponent } from 'ng-zorro-antd/message';
import { NZ_NOTIFICATION_CONFIG, NZ_NOTIFICATION_DEFAULT_CONFIG } from './nz-notification-config';
var NzNotificationContainerComponent = /** @class */ (function (_super) {
tslib_1.__extends(NzNotificationContainerComponent, _super);
function NzNotificationContainerComponent(cdr, nzConfigService, defaultConfig, config) {
var _this = _super.call(this, cdr, nzConfigService, defaultConfig, config) || this;
/**
* @override
*/
_this.messages = [];
if (!!config) {
warnDeprecation("Injection token 'NZ_NOTIFICATION_CONFIG' is deprecated and will be removed in 9.0.0. Please use 'NzConfigService' instead.");
}
return _this;
}
/**
* @override
*/
/**
* @override
* @param {?=} config
* @return {?}
*/
NzNotificationContainerComponent.prototype.setConfig = /**
* @override
* @param {?=} config
* @return {?}
*/
function (config) {
/** @type {?} */
var newConfig = (this.config = tslib_1.__assign({}, this.config, config, this.nzConfigService.getConfigForComponent(trimComponentName(this.constructor.name))));
/** @type {?} */
var placement = this.config.nzPlacement;
this.top = placement === 'topLeft' || placement === 'topRight' ? toCssPixel(newConfig.nzTop) : null;
this.bottom = placement === 'bottomLeft' || placement === 'bottomRight' ? toCssPixel(newConfig.nzBottom) : null;
this.cdr.markForCheck();
};
/**
* Create a new notification.
* If there's a notification whose `nzKey` is same with `nzKey` in `NzNotificationDataFilled`,
* replace its content instead of create a new one.
* @override
* @param notification
*/
/**
* Create a new notification.
* If there's a notification whose `nzKey` is same with `nzKey` in `NzNotificationDataFilled`,
* replace its content instead of create a new one.
* @override
* @param {?} notification
* @return {?}
*/
NzNotificationContainerComponent.prototype.createMessage = /**
* Create a new notification.
* If there's a notification whose `nzKey` is same with `nzKey` in `NzNotificationDataFilled`,
* replace its content instead of create a new one.
* @override
* @param {?} notification
* @return {?}
*/
function (notification) {
notification.options = this._mergeMessageOptions(notification.options);
notification.onClose = new Subject();
/** @type {?} */
var key = notification.options.nzKey;
/** @type {?} */
var notificationWithSameKey = this.messages.find((/**
* @param {?} msg
* @return {?}
*/
function (msg) { return msg.options.nzKey === ((/** @type {?} */ (notification.options))).nzKey; }));
if (key && notificationWithSameKey) {
this.replaceNotification(notificationWithSameKey, notification);
}
else {
if (this.messages.length >= this.config.nzMaxStack) {
this.messages.splice(0, 1);
}
this.messages.push((/** @type {?} */ (notification)));
}
this.cdr.detectChanges();
};
/**
* @override
*/
/**
* @override
* @protected
* @return {?}
*/
NzNotificationContainerComponent.prototype.subscribeConfigChange = /**
* @override
* @protected
* @return {?}
*/
function () {
var _this = this;
this.nzConfigService
.getConfigChangeEventForComponent(trimComponentName(this.constructor.name))
.subscribe((/**
* @return {?}
*/
function () { return _this.setConfig(); }));
};
/**
* @private
* @param {?} old
* @param {?} _new
* @return {?}
*/
NzNotificationContainerComponent.prototype.replaceNotification = /**
* @private
* @param {?} old
* @param {?} _new
* @return {?}
*/
function (old, _new) {
old.title = _new.title;
old.content = _new.content;
old.template = _new.template;
old.type = _new.type;
};
NzNotificationContainerComponent.decorators = [
{ type: Component, args: [{
changeDetection: ChangeDetectionStrategy.OnPush,
encapsulation: ViewEncapsulation.None,
selector: 'nz-notification-container',
exportAs: 'nzNotificationContainer',
preserveWhitespaces: false,
template: "<div\n class=\"ant-notification ant-notification-{{config.nzPlacement}}\"\n [style.top]=\"(config.nzPlacement === 'topLeft' || config.nzPlacement === 'topRight') ? top : null\"\n [style.bottom]=\"(config.nzPlacement === 'bottomLeft' || config.nzPlacement === 'bottomRight') ? bottom : null\"\n [style.right]=\"(config.nzPlacement === 'bottomRight' || config.nzPlacement === 'topRight') ? '0px' : null\"\n [style.left]=\"(config.nzPlacement === 'topLeft' || config.nzPlacement === 'bottomLeft') ? '0px' : null\">\n <nz-notification\n *ngFor=\"let message of messages; let i = index\"\n [nzMessage]=\"message\"\n [nzIndex]=\"i\">\n </nz-notification>\n</div>"
}] }
];
/** @nocollapse */
NzNotificationContainerComponent.ctorParameters = function () { return [
{ type: ChangeDetectorRef },
{ type: NzConfigService },
{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [NZ_NOTIFICATION_DEFAULT_CONFIG,] }] },
{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [NZ_NOTIFICATION_CONFIG,] }] }
]; };
return NzNotificationContainerComponent;
}(NzMessageContainerComponent));
export { NzNotificationContainerComponent };
if (false) {
/** @type {?} */
NzNotificationContainerComponent.prototype.config;
/** @type {?} */
NzNotificationContainerComponent.prototype.bottom;
/**
* @override
* @type {?}
*/
NzNotificationContainerComponent.prototype.messages;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-notification-container.component.js","sourceRoot":"ng://ng-zorro-antd/notification/","sources":["nz-notification-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  Optional,\n  ViewEncapsulation\n} from '@angular/core';\nimport { Subject } from 'rxjs';\n\nimport { toCssPixel, trimComponentName, warnDeprecation, NzConfigService } from 'ng-zorro-antd/core';\nimport { NzMessageContainerComponent } from 'ng-zorro-antd/message';\n\nimport {\n  NzNotificationConfigLegacy,\n  NZ_NOTIFICATION_CONFIG,\n  NZ_NOTIFICATION_DEFAULT_CONFIG\n} from './nz-notification-config';\nimport { NzNotificationDataFilled, NzNotificationDataOptions } from './nz-notification.definitions';\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  selector: 'nz-notification-container',\n  exportAs: 'nzNotificationContainer',\n  preserveWhitespaces: false,\n  templateUrl: './nz-notification-container.component.html'\n})\nexport class NzNotificationContainerComponent extends NzMessageContainerComponent {\n  config: Required<NzNotificationConfigLegacy>;\n  bottom: string | null;\n\n  /**\n   * @override\n   */\n  messages: Array<Required<NzNotificationDataFilled>> = [];\n\n  constructor(\n    cdr: ChangeDetectorRef,\n    nzConfigService: NzConfigService,\n    @Optional() @Inject(NZ_NOTIFICATION_DEFAULT_CONFIG) defaultConfig: NzNotificationConfigLegacy,\n    @Optional() @Inject(NZ_NOTIFICATION_CONFIG) config: NzNotificationConfigLegacy\n  ) {\n    super(cdr, nzConfigService, defaultConfig, config);\n    if (!!config) {\n      warnDeprecation(\n        `Injection token 'NZ_NOTIFICATION_CONFIG' is deprecated and will be removed in 9.0.0. Please use 'NzConfigService' instead.`\n      );\n    }\n  }\n\n  /**\n   * @override\n   */\n  setConfig(config?: NzNotificationConfigLegacy): void {\n    const newConfig = (this.config = {\n      ...this.config,\n      ...config,\n      ...this.nzConfigService.getConfigForComponent(trimComponentName(this.constructor.name))\n    });\n    const placement = this.config.nzPlacement;\n\n    this.top = placement === 'topLeft' || placement === 'topRight' ? toCssPixel(newConfig.nzTop) : null;\n    this.bottom = placement === 'bottomLeft' || placement === 'bottomRight' ? toCssPixel(newConfig.nzBottom) : null;\n\n    this.cdr.markForCheck();\n  }\n\n  /**\n   * Create a new notification.\n   * If there's a notification whose `nzKey` is same with `nzKey` in `NzNotificationDataFilled`,\n   * replace its content instead of create a new one.\n   * @override\n   * @param notification\n   */\n  createMessage(notification: NzNotificationDataFilled): void {\n    notification.options = this._mergeMessageOptions(notification.options);\n    notification.onClose = new Subject<boolean>();\n    const key = notification.options.nzKey;\n    const notificationWithSameKey = this.messages.find(\n      msg => msg.options.nzKey === (notification.options as Required<NzNotificationDataOptions>).nzKey\n    );\n\n    if (key && notificationWithSameKey) {\n      this.replaceNotification(notificationWithSameKey, notification);\n    } else {\n      if (this.messages.length >= this.config.nzMaxStack) {\n        this.messages.splice(0, 1);\n      }\n      this.messages.push(notification as Required<NzNotificationDataFilled>);\n    }\n    this.cdr.detectChanges();\n  }\n\n  /**\n   * @override\n   */\n  protected subscribeConfigChange(): void {\n    this.nzConfigService\n      .getConfigChangeEventForComponent(trimComponentName(this.constructor.name))\n      .subscribe(() => this.setConfig());\n  }\n\n  private replaceNotification(old: NzNotificationDataFilled, _new: NzNotificationDataFilled): void {\n    old.title = _new.title;\n    old.content = _new.content;\n    old.template = _new.template;\n    old.type = _new.type;\n  }\n}\n"]}