UNPKG

ng-zorro-antd

Version:

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

844 lines (832 loc) 27.1 kB
import { __assign, __extends } from 'tslib'; import { Overlay, OverlayModule } from '@angular/cdk/overlay'; import { InjectionToken, Component, ChangeDetectionStrategy, ViewEncapsulation, ChangeDetectorRef, Optional, Inject, NgModule, Injectable, Injector, ComponentFactoryResolver, ApplicationRef, ɵɵdefineInjectable, ɵɵinject, INJECTOR, Input } from '@angular/core'; import { warnDeprecation, toCssPixel, trimComponentName, NzConfigService, NzSingletonService, moveUpMotion, NzAddOnModule } from 'ng-zorro-antd/core'; import { Subject } from 'rxjs'; import { CommonModule } from '@angular/common'; import { NzIconModule } from 'ng-zorro-antd/icon'; /** * @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 */ /** @type {?} */ var globalCounter = 0; /** * @template ContainerClass, MessageData, MessageConfig */ var /** * @template ContainerClass, MessageData, MessageConfig */ NzMessageBaseService = /** @class */ (function () { function NzMessageBaseService(nzSingletonService, overlay, containerClass, injector, cfr, appRef, name) { if (name === void 0) { name = ''; } this.nzSingletonService = nzSingletonService; this.overlay = overlay; this.containerClass = containerClass; this.injector = injector; this.cfr = cfr; this.appRef = appRef; this.name = name; this._container = this.withContainer(); this.nzSingletonService.registerSingletonWithKey(this.name, this._container); } /** * @param {?=} messageId * @return {?} */ NzMessageBaseService.prototype.remove = /** * @param {?=} messageId * @return {?} */ function (messageId) { if (messageId) { this._container.removeMessage(messageId); } else { this._container.removeMessageAll(); } }; /** * @param {?} message * @param {?=} options * @return {?} */ NzMessageBaseService.prototype.createMessage = /** * @param {?} message * @param {?=} options * @return {?} */ function (message, options) { /** @type {?} */ var resultMessage = __assign({}, ((/** @type {?} */ (message))), { createdAt: new Date(), messageId: this._generateMessageId(), options: options }); this._container.createMessage(resultMessage); return resultMessage; }; /** * @param {?} config * @return {?} */ NzMessageBaseService.prototype.config = /** * @param {?} config * @return {?} */ function (config) { this._container.setConfig(config); }; /** * @protected * @return {?} */ NzMessageBaseService.prototype._generateMessageId = /** * @protected * @return {?} */ function () { return this.name + "-" + 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. // 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 {?} */ NzMessageBaseService.prototype.withContainer = // 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 {?} */ function () { /** @type {?} */ var containerInstance = this.nzSingletonService.getSingletonWithKey(this.name); if (containerInstance) { return (/** @type {?} */ (containerInstance)); } /** @type {?} */ var factory = this.cfr.resolveComponentFactory(this.containerClass); /** @type {?} */ var 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 {?} */ var 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; }; return NzMessageBaseService; }()); if (false) { /** * @type {?} * @protected */ NzMessageBaseService.prototype._container; /** * @type {?} * @private */ NzMessageBaseService.prototype.nzSingletonService; /** * @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.name; } /** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @deprecated This interface has been removed to `ng-zorro-antd/core`. Please migrate to that. * @record */ function NzMessageConfigLegacy() { } if (false) { /** @type {?|undefined} */ NzMessageConfigLegacy.prototype.nzAnimate; /** @type {?|undefined} */ NzMessageConfigLegacy.prototype.nzDuration; /** @type {?|undefined} */ NzMessageConfigLegacy.prototype.nzMaxStack; /** @type {?|undefined} */ NzMessageConfigLegacy.prototype.nzPauseOnHover; /** @type {?|undefined} */ NzMessageConfigLegacy.prototype.nzTop; } /** @type {?} */ var NZ_MESSAGE_DEFAULT_CONFIG = new InjectionToken('NZ_MESSAGE_DEFAULT_CONFIG'); /** * @deprecated 9.0.0 - Injection token 'NZ_MESSAGE_CONFIG' is deprecated and will be removed in 9.0.0. Please use 'NzConfigService' instead. * @type {?} */ var NZ_MESSAGE_CONFIG = new InjectionToken('NZ_MESSAGE_CONFIG'); var ɵ0 = { nzAnimate: true, nzDuration: 3000, nzMaxStack: 7, nzPauseOnHover: true, nzTop: 24 }; /** @type {?} */ var NZ_MESSAGE_DEFAULT_CONFIG_PROVIDER = { provide: NZ_MESSAGE_DEFAULT_CONFIG, useValue: ɵ0 }; /** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ 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(__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 __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 __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; }()); if (false) { /** @type {?} */ NzMessageContainerComponent.prototype.messages; /** @type {?} */ NzMessageContainerComponent.prototype.config; /** @type {?} */ NzMessageContainerComponent.prototype.top; /** * @type {?} * @protected */ NzMessageContainerComponent.prototype.cdr; /** * @type {?} * @protected */ NzMessageContainerComponent.prototype.nzConfigService; } /** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ var NzMessageServiceModule = /** @class */ (function () { function NzMessageServiceModule() { } NzMessageServiceModule.decorators = [ { type: NgModule } ]; return NzMessageServiceModule; }()); /** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ var NzMessageService = /** @class */ (function (_super) { __extends(NzMessageService, _super); function NzMessageService(nzSingletonService, overlay, injector, cfr, appRef) { return _super.call(this, nzSingletonService, overlay, NzMessageContainerComponent, injector, cfr, appRef, 'message') || this; } // Shortcut methods // Shortcut methods /** * @param {?} content * @param {?=} options * @return {?} */ NzMessageService.prototype.success = // Shortcut methods /** * @param {?} content * @param {?=} options * @return {?} */ function (content, options) { return this.createMessage({ type: 'success', content: content }, options); }; /** * @param {?} content * @param {?=} options * @return {?} */ NzMessageService.prototype.error = /** * @param {?} content * @param {?=} options * @return {?} */ function (content, options) { return this.createMessage({ type: 'error', content: content }, options); }; /** * @param {?} content * @param {?=} options * @return {?} */ NzMessageService.prototype.info = /** * @param {?} content * @param {?=} options * @return {?} */ function (content, options) { return this.createMessage({ type: 'info', content: content }, options); }; /** * @param {?} content * @param {?=} options * @return {?} */ NzMessageService.prototype.warning = /** * @param {?} content * @param {?=} options * @return {?} */ function (content, options) { return this.createMessage({ type: 'warning', content: content }, options); }; /** * @param {?} content * @param {?=} options * @return {?} */ NzMessageService.prototype.loading = /** * @param {?} content * @param {?=} options * @return {?} */ function (content, options) { return this.createMessage({ type: 'loading', content: content }, options); }; /** * @param {?} type * @param {?} content * @param {?=} options * @return {?} */ NzMessageService.prototype.create = /** * @param {?} type * @param {?} content * @param {?=} options * @return {?} */ function (type, content, options) { return this.createMessage({ type: type, content: content }, options); }; NzMessageService.decorators = [ { type: Injectable, args: [{ providedIn: NzMessageServiceModule },] } ]; /** @nocollapse */ NzMessageService.ctorParameters = function () { return [ { type: NzSingletonService }, { type: Overlay }, { type: Injector }, { type: ComponentFactoryResolver }, { type: ApplicationRef } ]; }; /** @nocollapse */ NzMessageService.ngInjectableDef = ɵɵdefineInjectable({ factory: function NzMessageService_Factory() { return new NzMessageService(ɵɵinject(NzSingletonService), ɵɵinject(Overlay), ɵɵinject(INJECTOR), ɵɵinject(ComponentFactoryResolver), ɵɵinject(ApplicationRef)); }, token: NzMessageService, providedIn: NzMessageServiceModule }); return NzMessageService; }(NzMessageBaseService)); /** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ var NzMessageComponent = /** @class */ (function () { function NzMessageComponent(_messageContainer, cdr) { this._messageContainer = _messageContainer; this.cdr = cdr; // Whether to set a timeout to destroy itself. this._eraseTimer = null; } /** * @return {?} */ NzMessageComponent.prototype.ngOnInit = /** * @return {?} */ function () { // `NzMessageContainer` does its job so all properties cannot be undefined. this._options = (/** @type {?} */ (this.nzMessage.options)); if (this._options.nzAnimate) { this.nzMessage.state = 'enter'; } this._autoErase = this._options.nzDuration > 0; if (this._autoErase) { this._initErase(); this._startEraseTimeout(); } }; /** * @return {?} */ NzMessageComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { if (this._autoErase) { this._clearEraseTimeout(); } }; /** * @return {?} */ NzMessageComponent.prototype.onEnter = /** * @return {?} */ function () { if (this._autoErase && this._options.nzPauseOnHover) { this._clearEraseTimeout(); this._updateTTL(); } }; /** * @return {?} */ NzMessageComponent.prototype.onLeave = /** * @return {?} */ function () { if (this._autoErase && this._options.nzPauseOnHover) { this._startEraseTimeout(); } }; // Remove self // Remove self /** * @protected * @param {?=} userAction * @return {?} */ NzMessageComponent.prototype._destroy = // Remove self /** * @protected * @param {?=} userAction * @return {?} */ function (userAction) { var _this = this; if (userAction === void 0) { userAction = false; } if (this._options.nzAnimate) { this.nzMessage.state = 'leave'; this.cdr.detectChanges(); setTimeout((/** * @return {?} */ function () { return _this._messageContainer.removeMessage(_this.nzMessage.messageId, userAction); }), 200); } else { this._messageContainer.removeMessage(this.nzMessage.messageId, userAction); } }; /** * @private * @return {?} */ NzMessageComponent.prototype._initErase = /** * @private * @return {?} */ function () { this._eraseTTL = this._options.nzDuration; this._eraseTimingStart = Date.now(); }; /** * @private * @return {?} */ NzMessageComponent.prototype._updateTTL = /** * @private * @return {?} */ function () { if (this._autoErase) { this._eraseTTL -= Date.now() - this._eraseTimingStart; } }; /** * @private * @return {?} */ NzMessageComponent.prototype._startEraseTimeout = /** * @private * @return {?} */ function () { var _this = this; if (this._eraseTTL > 0) { this._clearEraseTimeout(); this._eraseTimer = setTimeout((/** * @return {?} */ function () { return _this._destroy(); }), this._eraseTTL); this._eraseTimingStart = Date.now(); } else { this._destroy(); } }; /** * @private * @return {?} */ NzMessageComponent.prototype._clearEraseTimeout = /** * @private * @return {?} */ function () { if (this._eraseTimer !== null) { clearTimeout(this._eraseTimer); this._eraseTimer = null; } }; NzMessageComponent.decorators = [ { type: Component, args: [{ changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, selector: 'nz-message', exportAs: 'nzMessage', preserveWhitespaces: false, animations: [moveUpMotion], template: "<div class=\"ant-message-notice\"\n [@moveUpMotion]=\"nzMessage.state\"\n (mouseenter)=\"onEnter()\"\n (mouseleave)=\"onLeave()\">\n <div class=\"ant-message-notice-content\">\n <div class=\"ant-message-custom-content\" [ngClass]=\"'ant-message-' + nzMessage.type\">\n <ng-container [ngSwitch]=\"nzMessage.type\">\n <i *ngSwitchCase=\"'success'\" nz-icon nzType=\"check-circle\"></i>\n <i *ngSwitchCase=\"'info'\" nz-icon nzType=\"info-circle\"></i>\n <i *ngSwitchCase=\"'warning'\" nz-icon nzType=\"exclamation-circle\"></i>\n <i *ngSwitchCase=\"'error'\" nz-icon nzType=\"close-circle\"></i>\n <i *ngSwitchCase=\"'loading'\" nz-icon nzType=\"loading\"></i>\n </ng-container>\n <ng-container *nzStringTemplateOutlet=\"nzMessage.content\">\n <span [innerHTML]=\"nzMessage.content\"></span>\n </ng-container>\n </div>\n </div>\n</div>\n" }] } ]; /** @nocollapse */ NzMessageComponent.ctorParameters = function () { return [ { type: NzMessageContainerComponent }, { type: ChangeDetectorRef } ]; }; NzMessageComponent.propDecorators = { nzMessage: [{ type: Input }], nzIndex: [{ type: Input }] }; return NzMessageComponent; }()); if (false) { /** @type {?} */ NzMessageComponent.prototype.nzMessage; /** @type {?} */ NzMessageComponent.prototype.nzIndex; /** * @type {?} * @protected */ NzMessageComponent.prototype._options; /** * @type {?} * @private */ NzMessageComponent.prototype._autoErase; /** * @type {?} * @private */ NzMessageComponent.prototype._eraseTimer; /** * @type {?} * @private */ NzMessageComponent.prototype._eraseTimingStart; /** * @type {?} * @private */ NzMessageComponent.prototype._eraseTTL; /** * @type {?} * @private */ NzMessageComponent.prototype._messageContainer; /** * @type {?} * @protected */ NzMessageComponent.prototype.cdr; } /** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ var NzMessageModule = /** @class */ (function () { function NzMessageModule() { } NzMessageModule.decorators = [ { type: NgModule, args: [{ imports: [CommonModule, OverlayModule, NzIconModule, NzAddOnModule, NzMessageServiceModule], declarations: [NzMessageContainerComponent, NzMessageComponent], providers: [NZ_MESSAGE_DEFAULT_CONFIG_PROVIDER], entryComponents: [NzMessageContainerComponent] },] } ]; return NzMessageModule; }()); /** * @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 */ /** * @record */ function NzMessageDataOptions() { } if (false) { /** @type {?|undefined} */ NzMessageDataOptions.prototype.nzDuration; /** @type {?|undefined} */ NzMessageDataOptions.prototype.nzAnimate; /** @type {?|undefined} */ NzMessageDataOptions.prototype.nzPauseOnHover; } /** * Message data for terminal users. * @record */ function NzMessageData() { } if (false) { /** @type {?|undefined} */ NzMessageData.prototype.type; /** @type {?|undefined} */ NzMessageData.prototype.content; } /** * Filled version of NzMessageData (includes more private properties). * @record */ function NzMessageDataFilled() { } if (false) { /** @type {?} */ NzMessageDataFilled.prototype.messageId; /** @type {?} */ NzMessageDataFilled.prototype.createdAt; /** @type {?|undefined} */ NzMessageDataFilled.prototype.options; /** @type {?|undefined} */ NzMessageDataFilled.prototype.state; /** @type {?|undefined} */ NzMessageDataFilled.prototype.onClose; } /** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ export { NZ_MESSAGE_CONFIG, NZ_MESSAGE_DEFAULT_CONFIG, NZ_MESSAGE_DEFAULT_CONFIG_PROVIDER, NzMessageBaseService, NzMessageComponent, NzMessageContainerComponent, NzMessageModule, NzMessageService, NzMessageServiceModule }; //# sourceMappingURL=ng-zorro-antd-message.js.map