UNPKG

ng-zorro-antd-mobile

Version:

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

159 lines 19.8 kB
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; import { Injectable, ApplicationRef, NgZone, ComponentFactoryResolver } from '@angular/core'; import { ToastComponent } from './toast.component'; import { ToastOptions } from './toast-options.provider'; import { first } from 'rxjs/operators'; import * as i0 from "@angular/core"; let ToastService = class ToastService { constructor(_appRef, _cfr, _zone) { this._appRef = _appRef; this._cfr = _cfr; this._zone = _zone; this.timeout = null; this.zone = null; this.compRef = null; this.insertElement = null; this.toastCompFactory = null; this.appRef = null; this.zone = this._zone; this.appRef = this._appRef; this.toastCompFactory = this._cfr.resolveComponentFactory(ToastComponent); } _initConfig(config, options) { const props = {}; const optionalParams = ['content', 'iconType', 'mask', 'position']; config = Object.assign(options, config); optionalParams.forEach(key => { if (config[key] !== undefined) { props[key] = config[key]; } }); 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; } async notice(config, type, timeInterval = 2000, onClose, mask = true, position = 'middle') { // 如果已经存在,在没有遮罩层的情况下,会响应别的toast,需要清除原来的 if (this.compRef) { this.hide(); } const options = new ToastOptions(); options.iconType = type; options.mask = mask; options.position = position; const props = this._initConfig(config, options); this.insertElement = document.body.insertBefore(document.createElement(this.toastCompFactory.selector), document.body.firstChild); let instance; let subject; // 需要等待应用程序稳定后再安装,比如在 ngOnInit 里调用 if (!this._zone.isStable) { await this._appRef.isStable.pipe(first(stable => stable)); } this.compRef = this._appRef.bootstrap(this.toastCompFactory); instance = this.compRef.instance; subject = instance.subject; if (timeInterval) { this.timeout = setTimeout(() => { if (onClose) { onClose(); } this.hide(); }, timeInterval); } Object.assign(instance, props); return subject; } /** * Open info dialog */ info(content, timeInterval, onClose, mask, position) { const config = Object.assign({ iconType: 'info', content: content }); return this.notice(config, 'info', timeInterval, onClose, mask, position); } /** * Open success dialog */ success(content, timeInterval, onClose, mask, position) { const config = Object.assign({ iconType: 'success', content: content }); return this.notice(config, 'success', timeInterval, onClose, mask, position); } show(content, timeInterval, mask, position) { const config = Object.assign({ iconType: 'info', content: content }); return this.notice(config, 'info', timeInterval, () => { }, mask, position); } fail(content, timeInterval, onClose, mask, position) { const config = Object.assign({ iconType: 'fail', content: content }); return this.notice(config, 'fail', timeInterval, onClose, mask, position); } offline(content, timeInterval, onClose, mask, position) { const config = Object.assign({ iconType: 'offline', content: content }); return this.notice(config, 'offline', timeInterval, onClose, mask, position); } loading(content, timeInterval, onClose, mask, position) { const config = Object.assign({ iconType: 'loading', content: content }); return this.notice(config, 'loading', timeInterval, onClose, mask, position); } hide() { if (this.timeout) { clearTimeout(this.timeout); } if (this.compRef) { this._zone.run(() => { this.compRef.destroy(); document.body.removeChild(this.insertElement); }); this.compRef = null; this.insertElement = null; } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ToastService, deps: [{ token: i0.ApplicationRef }, { token: i0.ComponentFactoryResolver }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Injectable }); } static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ToastService, providedIn: 'root' }); } }; ToastService = __decorate([ Injectable(), __metadata("design:paramtypes", [ApplicationRef, ComponentFactoryResolver, NgZone]) ], ToastService); export { ToastService }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ToastService, decorators: [{ type: Injectable, args: [{ providedIn: 'root' }] }, { type: Injectable }], ctorParameters: () => [{ type: i0.ApplicationRef }, { type: i0.ComponentFactoryResolver }, { type: i0.NgZone }] }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.service.js","sourceRoot":"","sources":["../../../components/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';\nimport { first } from 'rxjs/operators';\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  insertElement: HTMLElement = 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  async 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    this.insertElement = document.body.insertBefore(document.createElement(this.toastCompFactory.selector), document.body.firstChild);\n    let instance: any;\n    let subject: any;\n    // 需要等待应用程序稳定后再安装，比如在 ngOnInit 里调用\n    if (!this._zone.isStable) {\n      await this._appRef.isStable.pipe(\n        first(stable => stable)\n      )\n    }\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    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        document.body.removeChild(this.insertElement);\n      });\n      this.compRef = null;\n      this.insertElement = null;\n    }\n  }\n}\n"]}