ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
272 lines • 19.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Injectable, ApplicationRef, NgZone, ComponentFactoryResolver } from '@angular/core';
import { ToastComponent } from './toast.component';
import { ToastOptions } from './toast-options.provider';
/**
* @record
*/
export function ConfigInterface() { }
if (false) {
/** @type {?|undefined} */
ConfigInterface.prototype.content;
/** @type {?|undefined} */
ConfigInterface.prototype.iconType;
/** @type {?|undefined} */
ConfigInterface.prototype.mask;
}
export class ToastService {
/**
* @param {?} _appRef
* @param {?} _cfr
* @param {?} _zone
*/
constructor(_appRef, _cfr, _zone) {
this._appRef = _appRef;
this._cfr = _cfr;
this._zone = _zone;
this.timeout = null;
this.zone = null;
this.compRef = null;
this.toastCompFactory = null;
this.appRef = null;
this.zone = this._zone;
this.appRef = this._appRef;
this.toastCompFactory = this._cfr.resolveComponentFactory(ToastComponent);
}
/**
* @param {?} config
* @param {?} options
* @return {?}
*/
_initConfig(config, options) {
/** @type {?} */
const props = {};
/** @type {?} */
const optionalParams = ['content', 'iconType', 'mask', 'position'];
config = Object.assign(options, config);
optionalParams.forEach((/**
* @param {?} key
* @return {?}
*/
key => {
if (config[key] !== undefined) {
props[key] = config[key];
}
}));
/** @type {?} */
const iconType = {
info: '',
success: 'success',
fail: 'fail',
offline: 'dislike',
loading: 'loading'
}[options.iconType];
props['iconType'] = iconType;
props['mask'] = options.mask;
props['position'] = options.position;
return props;
}
/**
* @param {?} config
* @param {?} type
* @param {?=} timeInterval
* @param {?=} onClose
* @param {?=} mask
* @param {?=} position
* @return {?}
*/
notice(config, type, timeInterval = 2000, onClose, mask = true, position = 'middle') {
// 如果已经存在,在没有遮罩层的情况下,会响应别的toast,需要清除原来的
if (this.compRef) {
this.hide();
}
/** @type {?} */
const options = new ToastOptions();
options.iconType = type;
options.mask = mask;
options.position = position;
/** @type {?} */
const props = this._initConfig(config, options);
document.body.insertBefore(document.createElement(this.toastCompFactory.selector), document.body.firstChild);
/** @type {?} */
let instance;
/** @type {?} */
let subject;
this.compRef = this._appRef.bootstrap(this.toastCompFactory);
instance = this.compRef.instance;
subject = instance.subject;
if (timeInterval) {
this.timeout = setTimeout((/**
* @return {?}
*/
() => {
if (onClose) {
onClose();
}
this.hide();
}), timeInterval);
}
Object.assign(instance, props);
return subject;
}
/**
* Open info dialog
* @param {?=} content
* @param {?=} timeInterval
* @param {?=} onClose
* @param {?=} mask
* @param {?=} position
* @return {?}
*/
info(content, timeInterval, onClose, mask, position) {
/** @type {?} */
const config = Object.assign({
iconType: 'info',
content: content
});
return this.notice(config, 'info', timeInterval, onClose, mask, position);
}
/**
* Open success dialog
* @param {?=} content
* @param {?=} timeInterval
* @param {?=} onClose
* @param {?=} mask
* @param {?=} position
* @return {?}
*/
success(content, timeInterval, onClose, mask, position) {
/** @type {?} */
const config = Object.assign({
iconType: 'success',
content: content
});
return this.notice(config, 'success', timeInterval, onClose, mask, position);
}
/**
* @param {?=} content
* @param {?=} timeInterval
* @param {?=} mask
* @param {?=} position
* @return {?}
*/
show(content, timeInterval, mask, position) {
/** @type {?} */
const config = Object.assign({
iconType: 'info',
content: content
});
return this.notice(config, 'info', timeInterval, (/**
* @return {?}
*/
() => { }), mask, position);
}
/**
* @param {?=} content
* @param {?=} timeInterval
* @param {?=} onClose
* @param {?=} mask
* @param {?=} position
* @return {?}
*/
fail(content, timeInterval, onClose, mask, position) {
/** @type {?} */
const config = Object.assign({
iconType: 'fail',
content: content
});
return this.notice(config, 'fail', timeInterval, onClose, mask, position);
}
/**
* @param {?=} content
* @param {?=} timeInterval
* @param {?=} onClose
* @param {?=} mask
* @param {?=} position
* @return {?}
*/
offline(content, timeInterval, onClose, mask, position) {
/** @type {?} */
const config = Object.assign({
iconType: 'offline',
content: content
});
return this.notice(config, 'offline', timeInterval, onClose, mask, position);
}
/**
* @param {?=} content
* @param {?=} timeInterval
* @param {?=} onClose
* @param {?=} mask
* @param {?=} position
* @return {?}
*/
loading(content, timeInterval, onClose, mask, position) {
/** @type {?} */
const config = Object.assign({
iconType: 'loading',
content: content
});
return this.notice(config, 'loading', timeInterval, onClose, mask, position);
}
/**
* @return {?}
*/
hide() {
if (this.timeout) {
clearTimeout(this.timeout);
}
if (this.compRef) {
this._zone.run((/**
* @return {?}
*/
() => {
this.compRef.destroy();
}));
this.compRef = null;
}
}
}
ToastService.decorators = [
{ type: Injectable, args: [{
providedIn: 'root'
},] },
{ type: Injectable }
];
/** @nocollapse */
ToastService.ctorParameters = () => [
{ type: ApplicationRef },
{ type: ComponentFactoryResolver },
{ type: NgZone }
];
if (false) {
/** @type {?} */
ToastService.prototype.timeout;
/** @type {?} */
ToastService.prototype.zone;
/** @type {?} */
ToastService.prototype.compRef;
/** @type {?} */
ToastService.prototype.toastCompFactory;
/** @type {?} */
ToastService.prototype.appRef;
/**
* @type {?}
* @private
*/
ToastService.prototype._appRef;
/**
* @type {?}
* @private
*/
ToastService.prototype._cfr;
/**
* @type {?}
* @private
*/
ToastService.prototype._zone;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.service.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["toast/toast.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Injectable,\n  ComponentRef,\n  ComponentFactory,\n  ApplicationRef,\n  NgZone,\n  ComponentFactoryResolver\n} from '@angular/core';\nimport { ToastComponent } from './toast.component';\nimport { ToastOptions } from './toast-options.provider';\n\nexport interface ConfigInterface {\n  content?: any;\n  iconType?: string;\n  mask?: boolean;\n}\n@Injectable({\n  providedIn: 'root'\n})\n@Injectable()\nexport class ToastService {\n  timeout = null;\n  zone: NgZone = null;\n  compRef: ComponentRef<any> = null;\n  toastCompFactory: ComponentFactory<ToastComponent> = null;\n  appRef: ApplicationRef = null;\n\n  constructor(private _appRef: ApplicationRef, private _cfr: ComponentFactoryResolver, private _zone: NgZone) {\n    this.zone = this._zone;\n    this.appRef = this._appRef;\n    this.toastCompFactory = this._cfr.resolveComponentFactory(ToastComponent);\n  }\n\n  _initConfig(config: Object, options: ToastOptions): Object {\n    const props = {};\n    const optionalParams: string[] = ['content', 'iconType', 'mask', 'position'];\n\n    config = Object.assign(options, config);\n    optionalParams.forEach(key => {\n      if (config[key] !== undefined) {\n        props[key] = config[key];\n      }\n    });\n\n    const iconType = {\n      info: '',\n      success: 'success',\n      fail: 'fail',\n      offline: 'dislike',\n      loading: 'loading'\n    }[options.iconType];\n\n    props['iconType'] = iconType;\n    props['mask'] = options.mask;\n    props['position'] = options.position;\n    return props;\n  }\n\n  notice(config: ConfigInterface, type, timeInterval = 2000, onClose, mask = true, position = 'middle') {\n    // 如果已经存在，在没有遮罩层的情况下，会响应别的toast，需要清除原来的\n    if (this.compRef) {\n      this.hide();\n    }\n    const options: ToastOptions = new ToastOptions();\n    options.iconType = type;\n    options.mask = mask;\n    options.position = position;\n    const props = this._initConfig(config, options);\n\n    document.body.insertBefore(document.createElement(this.toastCompFactory.selector), document.body.firstChild);\n    let instance: any;\n    let subject: any;\n\n    this.compRef = this._appRef.bootstrap(this.toastCompFactory);\n    instance = this.compRef.instance;\n    subject = instance.subject;\n\n    if (timeInterval) {\n      this.timeout = setTimeout(() => {\n        if (onClose) {\n          onClose();\n        }\n        this.hide();\n      }, timeInterval);\n    }\n\n    Object.assign(instance, props);\n    return subject;\n  }\n\n  /**\n   * Open info dialog\n   */\n  info(content?: string, timeInterval?: number, onClose?: () => void, mask?: boolean, position?: string) {\n    const config = Object.assign({\n      iconType: 'info',\n      content: content\n    });\n    return this.notice(config, 'info', timeInterval, onClose, mask, position);\n  }\n\n  /**\n   * Open success dialog\n   */\n  success(content?: string, timeInterval?: number, onClose?: () => void, mask?: boolean, position?: string) {\n    const config = Object.assign({\n      iconType: 'success',\n      content: content\n    });\n    return this.notice(config, 'success', timeInterval, onClose, mask, position);\n  }\n\n  show(content?: string, timeInterval?: number, mask?: boolean, position?: string) {\n    const config = Object.assign({\n      iconType: 'info',\n      content: content\n    });\n    return this.notice(config, 'info', timeInterval, () => {}, mask, position);\n  }\n\n  fail(content?: string, timeInterval?: number, onClose?: () => void, mask?: boolean, position?: string) {\n    const config = Object.assign({\n      iconType: 'fail',\n      content: content\n    });\n    return this.notice(config, 'fail', timeInterval, onClose, mask, position);\n  }\n\n  offline(content?: string, timeInterval?: number, onClose?: () => void, mask?: boolean, position?: string) {\n    const config = Object.assign({\n      iconType: 'offline',\n      content: content\n    });\n    return this.notice(config, 'offline', timeInterval, onClose, mask, position);\n  }\n\n  loading(content?: string, timeInterval?: number, onClose?: () => void, mask?: boolean, position?: string) {\n    const config = Object.assign({\n      iconType: 'loading',\n      content: content\n    });\n    return this.notice(config, 'loading', timeInterval, onClose, mask, position);\n  }\n\n  hide() {\n    if (this.timeout) {\n      clearTimeout(this.timeout);\n    }\n    if (this.compRef) {\n      this._zone.run(() => {\n        this.compRef.destroy();\n      });\n      this.compRef = null;\n    }\n  }\n}\n"]}