ng-zorro-antd-yj
Version:
An enterprise-class UI components based on Ant Design and Angular
207 lines • 16 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Overlay } from '@angular/cdk/overlay';
import { ApplicationRef, ComponentFactoryResolver, Injectable, Injector } from '@angular/core';
import { NzMessageContainerComponent } from './nz-message-container.component';
import * as i0 from "@angular/core";
import * as i1 from "./public-api";
import * as i2 from "@angular/cdk/overlay";
/** @type {?} */
let globalCounter = 0;
/**
* @template ContainerClass, MessageData, MessageConfig
*/
export class NzMessageBaseService {
/**
* @param {?} overlay
* @param {?} containerClass
* @param {?} injector
* @param {?} cfr
* @param {?} appRef
* @param {?=} _idPrefix
*/
constructor(overlay, containerClass, injector, cfr, appRef, _idPrefix = '') {
this.overlay = overlay;
this.containerClass = containerClass;
this.injector = injector;
this.cfr = cfr;
this.appRef = appRef;
this._idPrefix = _idPrefix;
this._container = this.createContainer();
}
/**
* @param {?=} messageId
* @return {?}
*/
remove(messageId) {
if (messageId) {
this._container.removeMessage(messageId);
}
else {
this._container.removeMessageAll();
}
}
/**
* @param {?} message
* @param {?=} options
* @return {?}
*/
createMessage(message, options) {
/** @type {?} */
const resultMessage = Object.assign({}, ((/** @type {?} */ (message))), {
createdAt: new Date(),
messageId: this._generateMessageId(),
options
});
this._container.createMessage(resultMessage);
return resultMessage;
}
/**
* @param {?} config
* @return {?}
*/
config(config) {
this._container.setConfig(config);
}
/**
* @protected
* @return {?}
*/
_generateMessageId() {
return this._idPrefix + globalCounter++;
}
// Manually creating container for overlay to avoid multi-checking error, see: https://github.com/NG-ZORRO/ng-zorro-antd/issues/391
// NOTE: we never clean up the container component and it's overlay resources, if we should, we need to do it by our own codes.
/**
* @private
* @return {?}
*/
createContainer() {
/** @type {?} */
const factory = this.cfr.resolveComponentFactory(this.containerClass);
/** @type {?} */
const componentRef = factory.create(this.injector);
componentRef.changeDetectorRef.detectChanges(); // Immediately change detection to avoid multi-checking error
this.appRef.attachView(componentRef.hostView); // Load view into app root
// Load view into app root
/** @type {?} */
const overlayPane = this.overlay.create().overlayElement;
overlayPane.style.zIndex = '1010'; // Patching: assign the same zIndex of ant-message to it's parent overlay panel, to the ant-message's zindex work.
overlayPane.appendChild((/** @type {?} */ (((/** @type {?} */ (componentRef.hostView))).rootNodes[0])));
return componentRef.instance;
}
}
if (false) {
/**
* @type {?}
* @protected
*/
NzMessageBaseService.prototype._container;
/**
* @type {?}
* @private
*/
NzMessageBaseService.prototype.overlay;
/**
* @type {?}
* @private
*/
NzMessageBaseService.prototype.containerClass;
/**
* @type {?}
* @private
*/
NzMessageBaseService.prototype.injector;
/**
* @type {?}
* @private
*/
NzMessageBaseService.prototype.cfr;
/**
* @type {?}
* @private
*/
NzMessageBaseService.prototype.appRef;
/**
* @type {?}
* @private
*/
NzMessageBaseService.prototype._idPrefix;
}
export class NzMessageService extends NzMessageBaseService {
/**
* @param {?} overlay
* @param {?} injector
* @param {?} cfr
* @param {?} appRef
*/
constructor(overlay, injector, cfr, appRef) {
super(overlay, NzMessageContainerComponent, injector, cfr, appRef, 'message-');
}
// Shortcut methods
/**
* @param {?} content
* @param {?=} options
* @return {?}
*/
success(content, options) {
return this.createMessage({ type: 'success', content }, options);
}
/**
* @param {?} content
* @param {?=} options
* @return {?}
*/
error(content, options) {
return this.createMessage({ type: 'error', content }, options);
}
/**
* @param {?} content
* @param {?=} options
* @return {?}
*/
info(content, options) {
return this.createMessage({ type: 'info', content }, options);
}
/**
* @param {?} content
* @param {?=} options
* @return {?}
*/
warning(content, options) {
return this.createMessage({ type: 'warning', content }, options);
}
/**
* @param {?} content
* @param {?=} options
* @return {?}
*/
loading(content, options) {
return this.createMessage({ type: 'loading', content }, options);
}
/**
* @param {?} type
* @param {?} content
* @param {?=} options
* @return {?}
*/
create(type, content, options) {
return this.createMessage({ type, content }, options);
}
}
NzMessageService.decorators = [
{ type: Injectable, args: [{
providedIn: 'root'
},] }
];
/** @nocollapse */
NzMessageService.ctorParameters = () => [
{ type: Overlay },
{ type: Injector },
{ type: ComponentFactoryResolver },
{ type: ApplicationRef }
];
/** @nocollapse */ NzMessageService.ngInjectableDef = i0.defineInjectable({ factory: function NzMessageService_Factory() { return new i1.NzMessageService(i0.inject(i2.Overlay), i0.inject(i0.INJECTOR), i0.inject(i0.ComponentFactoryResolver), i0.inject(i0.ApplicationRef)); }, token: i1.NzMessageService, providedIn: "root" });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-message.service.js","sourceRoot":"ng://ng-zorro-antd-yj/","sources":["message/nz-message.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay } from '@angular/cdk/overlay';\nimport {\n  ApplicationRef,\n  ComponentFactoryResolver,\n  EmbeddedViewRef,\n  Injectable,\n  Injector,\n  TemplateRef,\n  Type\n} from '@angular/core';\n\nimport { NzMessageConfig } from './nz-message-config';\nimport { NzMessageContainerComponent } from './nz-message-container.component';\nimport { NzMessageData, NzMessageDataFilled, NzMessageDataOptions } from './nz-message.definitions';\n\nlet globalCounter = 0;\n\nexport class NzMessageBaseService<\n  ContainerClass extends NzMessageContainerComponent,\n  MessageData,\n  MessageConfig extends NzMessageConfig\n> {\n  protected _container: ContainerClass;\n\n  constructor(\n    private overlay: Overlay,\n    private containerClass: Type<ContainerClass>,\n    private injector: Injector,\n    private cfr: ComponentFactoryResolver,\n    private appRef: ApplicationRef,\n    private _idPrefix: string = ''\n  ) {\n    this._container = this.createContainer();\n  }\n\n  remove(messageId?: string): void {\n    if (messageId) {\n      this._container.removeMessage(messageId);\n    } else {\n      this._container.removeMessageAll();\n    }\n  }\n\n  createMessage(message: MessageData, options?: NzMessageDataOptions): NzMessageDataFilled {\n    const resultMessage: NzMessageDataFilled = {\n      ...(message as NzMessageData),\n      ...{\n        createdAt: new Date(),\n        messageId: this._generateMessageId(),\n        options\n      }\n    };\n    this._container.createMessage(resultMessage);\n\n    return resultMessage;\n  }\n\n  config(config: MessageConfig): void {\n    this._container.setConfig(config);\n  }\n\n  protected _generateMessageId(): string {\n    return this._idPrefix + globalCounter++;\n  }\n\n  // Manually creating container for overlay to avoid multi-checking error, see: https://github.com/NG-ZORRO/ng-zorro-antd/issues/391\n  // NOTE: we never clean up the container component and it's overlay resources, if we should, we need to do it by our own codes.\n  private createContainer(): ContainerClass {\n    const factory = this.cfr.resolveComponentFactory(this.containerClass);\n    const componentRef = factory.create(this.injector); // Use root injector\n    componentRef.changeDetectorRef.detectChanges(); // Immediately change detection to avoid multi-checking error\n    this.appRef.attachView(componentRef.hostView); // Load view into app root\n    const overlayPane = this.overlay.create().overlayElement;\n    overlayPane.style.zIndex = '1010'; // Patching: assign the same zIndex of ant-message to it's parent overlay panel, to the ant-message's zindex work.\n    overlayPane.appendChild((componentRef.hostView as EmbeddedViewRef<{}>).rootNodes[0] as HTMLElement);\n\n    return componentRef.instance;\n  }\n}\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class NzMessageService extends NzMessageBaseService<\n  NzMessageContainerComponent,\n  NzMessageData,\n  NzMessageConfig\n> {\n  constructor(overlay: Overlay, injector: Injector, cfr: ComponentFactoryResolver, appRef: ApplicationRef) {\n    super(overlay, NzMessageContainerComponent, injector, cfr, appRef, 'message-');\n  }\n\n  // Shortcut methods\n  success(content: string | TemplateRef<void>, options?: NzMessageDataOptions): NzMessageDataFilled {\n    return this.createMessage({ type: 'success', content }, options);\n  }\n\n  error(content: string | TemplateRef<void>, options?: NzMessageDataOptions): NzMessageDataFilled {\n    return this.createMessage({ type: 'error', content }, options);\n  }\n\n  info(content: string | TemplateRef<void>, options?: NzMessageDataOptions): NzMessageDataFilled {\n    return this.createMessage({ type: 'info', content }, options);\n  }\n\n  warning(content: string | TemplateRef<void>, options?: NzMessageDataOptions): NzMessageDataFilled {\n    return this.createMessage({ type: 'warning', content }, options);\n  }\n\n  loading(content: string | TemplateRef<void>, options?: NzMessageDataOptions): NzMessageDataFilled {\n    return this.createMessage({ type: 'loading', content }, options);\n  }\n\n  create(\n    type: 'success' | 'info' | 'warning' | 'error' | 'loading' | string,\n    content: string | TemplateRef<void>,\n    options?: NzMessageDataOptions\n  ): NzMessageDataFilled {\n    return this.createMessage({ type, content }, options);\n  }\n}\n"]}