UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

222 lines (221 loc) 19.2 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, Input, ViewChild } from '@angular/core'; import { MaterialIconLoader } from './MaterialIconLoader.component'; import { BackgroundProcessManager } from '../../../service/BackgroundProcessManager.service'; import { ObservableManager } from '../../../service/ObservableManager.service'; import { Option } from '../../../decorator/decorators'; import { AbstractHasOptions } from '../../../share/AbstractHasOptions'; const /** @type {?} */ TYPE_NAME = "material-data-icon-loader"; export class MaterialDataIconLoader extends AbstractHasOptions { /** * @param {?} bgProcessMgr * @param {?} obsvMgr */ constructor(bgProcessMgr, obsvMgr) { super(); this.bgProcessMgr = bgProcessMgr; this.obsvMgr = obsvMgr; this.obsvMgr.subscribe(BackgroundProcessManager.PROCESS_START_TOPIC_NAME, (startBGProcess) => { if (startBGProcess.type === 'connection.data' && startBGProcess.userAction === true) { this.runPageLoader(); } }); this.obsvMgr.subscribe(BackgroundProcessManager.PROCESS_END_TOPIC_NAME, (endBGProcess) => { if (endBGProcess.type === 'connection.data' && endBGProcess.userAction === true) { if (this.bgProcessMgr.getRunningProcessesCount('connection.data', null, { "userAction": true }) <= 0) { this.stopPageLoader(); } } }); this.obsvMgr.subscribe(BackgroundProcessManager.PROCESS_ERROR_TOPIC_NAME, (errorBGProcess) => { if (errorBGProcess.type === 'connection.data' && errorBGProcess.userAction === true) { if (this.bgProcessMgr.getRunningProcessesCount('connection.data', null, { "userAction": true }) <= 0) { this.stopPageLoader(); } } }); } /** * @return {?} */ ngOnInit() { } /** * @return {?} */ _getIconName() { if (this.iconName !== null && typeof this.iconName !== 'undefined') { return this.iconName; } return MaterialIconLoader.BALL_CLIP_ROTATE_PULSE; } /** * @return {?} */ runPageLoader() { if (this.dataLoader === null || typeof this.dataLoader === 'undefined') { return; } if (!this.dataLoader.isRunning()) { this.dataLoader.start(); } } /** * @return {?} */ stopPageLoader() { if (this.dataLoader === null || typeof this.dataLoader === 'undefined') { return; } if (this.dataLoader.isRunning()) { this.dataLoader.stop(); } } /** * @return {?} */ getState() { return this.dataLoader.getState(); } /** * @return {?} */ isRunning() { return this.dataLoader.isRunning(); } /** * @return {?} */ getSize() { return this.size; } /** * @param {?} size * @return {?} */ setSize(size) { this.size = size; } /** * @return {?} */ getLoaderClass() { return this.loaderClass; } /** * @param {?} loaderClass * @return {?} */ setLoaderClass(loaderClass) { this.loaderClass = loaderClass; } } MaterialDataIconLoader.TYPE_NAME = TYPE_NAME; MaterialDataIconLoader.BALL_PULSE = MaterialIconLoader.BALL_PULSE; MaterialDataIconLoader.BALL_GRID_PULSE = MaterialIconLoader.BALL_GRID_PULSE; MaterialDataIconLoader.BALL_CLIP_ROTATE_MULTIPLE = MaterialIconLoader.BALL_CLIP_ROTATE_MULTIPLE; MaterialDataIconLoader.BALL_PULSE_RISE = MaterialIconLoader.BALL_PULSE_RISE; MaterialDataIconLoader.BALL_CLIP_ROTATE_PULSE = MaterialIconLoader.BALL_CLIP_ROTATE_PULSE; MaterialDataIconLoader.BALL_CLIP_ROTATE = MaterialIconLoader.BALL_CLIP_ROTATE; MaterialDataIconLoader.BALL_SCALE_RIPPLE_MULTIPLE = MaterialIconLoader.BALL_SCALE_RIPPLE_MULTIPLE; MaterialDataIconLoader.BALL_SCALE_MULTIPLE = MaterialIconLoader.BALL_SCALE_MULTIPLE; MaterialDataIconLoader.BALL_PULSE_SYNC = MaterialIconLoader.BALL_PULSE_SYNC; MaterialDataIconLoader.LINE_SPIN_FADE_LOADER = MaterialIconLoader.LINE_SPIN_FADE_LOADER; MaterialDataIconLoader.LINE_SCALE = MaterialIconLoader.LINE_SCALE; MaterialDataIconLoader.LINE_SCALE_PARTY = MaterialIconLoader.LINE_SCALE_PARTY; MaterialDataIconLoader.LINE_SCALE_PULSE_OUT = MaterialIconLoader.LINE_SCALE_PULSE_OUT; MaterialDataIconLoader.LINE_SCALE_PULSE_OUT_RAPID = MaterialIconLoader.LINE_SCALE_PULSE_OUT_RAPID; MaterialDataIconLoader.SQUARE_SPIN = MaterialIconLoader.SQUARE_SPIN; MaterialDataIconLoader.decorators = [ { type: Component, args: [{ moduleId: module.id, selector: TYPE_NAME, template: `<div class="material-data-icon-loader"> <material-icon-loader #loader [iconName]="_getIconName()" [size]="getSize()" [loaderClass]="getLoaderClass()"></material-icon-loader> </div> ` },] }, ]; /** @nocollapse */ MaterialDataIconLoader.ctorParameters = () => [ { type: BackgroundProcessManager, }, { type: ObservableManager, }, ]; MaterialDataIconLoader.propDecorators = { "iconName": [{ type: Input },], "size": [{ type: Input },], "loaderClass": [{ type: Input },], "dataLoader": [{ type: ViewChild, args: ["loader",] },], }; tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialDataIconLoader.prototype, "iconName", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialDataIconLoader.prototype, "size", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialDataIconLoader.prototype, "loaderClass", void 0); function MaterialDataIconLoader_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ MaterialDataIconLoader.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ MaterialDataIconLoader.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ MaterialDataIconLoader.propDecorators; /** @type {?} */ MaterialDataIconLoader.TYPE_NAME; /** @type {?} */ MaterialDataIconLoader.BALL_PULSE; /** @type {?} */ MaterialDataIconLoader.BALL_GRID_PULSE; /** @type {?} */ MaterialDataIconLoader.BALL_CLIP_ROTATE_MULTIPLE; /** @type {?} */ MaterialDataIconLoader.BALL_PULSE_RISE; /** @type {?} */ MaterialDataIconLoader.BALL_CLIP_ROTATE_PULSE; /** @type {?} */ MaterialDataIconLoader.BALL_CLIP_ROTATE; /** @type {?} */ MaterialDataIconLoader.BALL_SCALE_RIPPLE_MULTIPLE; /** @type {?} */ MaterialDataIconLoader.BALL_SCALE_MULTIPLE; /** @type {?} */ MaterialDataIconLoader.BALL_PULSE_SYNC; /** @type {?} */ MaterialDataIconLoader.LINE_SPIN_FADE_LOADER; /** @type {?} */ MaterialDataIconLoader.LINE_SCALE; /** @type {?} */ MaterialDataIconLoader.LINE_SCALE_PARTY; /** @type {?} */ MaterialDataIconLoader.LINE_SCALE_PULSE_OUT; /** @type {?} */ MaterialDataIconLoader.LINE_SCALE_PULSE_OUT_RAPID; /** @type {?} */ MaterialDataIconLoader.SQUARE_SPIN; /** @type {?} */ MaterialDataIconLoader.prototype.iconName; /** @type {?} */ MaterialDataIconLoader.prototype.size; /** @type {?} */ MaterialDataIconLoader.prototype.loaderClass; /** @type {?} */ MaterialDataIconLoader.prototype.dataLoader; /** @type {?} */ MaterialDataIconLoader.prototype.bgProcessMgr; /** @type {?} */ MaterialDataIconLoader.prototype.obsvMgr; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MaterialDataIconLoader.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/theme/material/component/MaterialDataIconLoader.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ViewChild } from '@angular/core';\nimport { LoaderStatus } from '../../../component/LoaderStatus';\nimport { MaterialIconLoader } from './MaterialIconLoader.component';\nimport { BackgroundProcessManager } from '../../../service/BackgroundProcessManager.service';\nimport { ObservableManager } from '../../../service/ObservableManager.service';\nimport { Option } from '../../../decorator/decorators';\nimport { AbstractHasOptions } from '../../../share/AbstractHasOptions';\n\ndeclare var $: any;\n\nconst TYPE_NAME: string = \"material-data-icon-loader\";\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"material-data-icon-loader\">\n  <material-icon-loader #loader [iconName]=\"_getIconName()\" [size]=\"getSize()\" [loaderClass]=\"getLoaderClass()\"></material-icon-loader>\n</div>\n`\n})\nexport class MaterialDataIconLoader extends AbstractHasOptions implements OnInit {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  public static readonly BALL_PULSE: string = MaterialIconLoader.BALL_PULSE;\n  public static readonly BALL_GRID_PULSE: string = MaterialIconLoader.BALL_GRID_PULSE;\n  public static readonly BALL_CLIP_ROTATE_MULTIPLE: string = MaterialIconLoader.BALL_CLIP_ROTATE_MULTIPLE;\n  public static readonly BALL_PULSE_RISE: string = MaterialIconLoader.BALL_PULSE_RISE;\n  public static readonly BALL_CLIP_ROTATE_PULSE: string = MaterialIconLoader.BALL_CLIP_ROTATE_PULSE;\n  public static readonly BALL_CLIP_ROTATE: string = MaterialIconLoader.BALL_CLIP_ROTATE;\n  public static readonly BALL_SCALE_RIPPLE_MULTIPLE: string = MaterialIconLoader.BALL_SCALE_RIPPLE_MULTIPLE;\n  public static readonly BALL_SCALE_MULTIPLE: string = MaterialIconLoader.BALL_SCALE_MULTIPLE;\n  public static readonly BALL_PULSE_SYNC: string = MaterialIconLoader.BALL_PULSE_SYNC;\n  public static readonly LINE_SPIN_FADE_LOADER: string = MaterialIconLoader.LINE_SPIN_FADE_LOADER;\n  public static readonly LINE_SCALE: string = MaterialIconLoader.LINE_SCALE;\n  public static readonly LINE_SCALE_PARTY: string = MaterialIconLoader.LINE_SCALE_PARTY;\n  public static readonly LINE_SCALE_PULSE_OUT: string = MaterialIconLoader.LINE_SCALE_PULSE_OUT;\n  public static readonly LINE_SCALE_PULSE_OUT_RAPID: string = MaterialIconLoader.LINE_SCALE_PULSE_OUT_RAPID;\n  public static readonly SQUARE_SPIN: string = MaterialIconLoader.SQUARE_SPIN;\n\n  @Input()\n  @Option()\n  private iconName: string;\n  @Input()\n  @Option()\n  private size: string;\n  @Input()\n  @Option()\n  private loaderClass: string;\n\n  @ViewChild(\"loader\")\n  private dataLoader: MaterialIconLoader;\n\n  private bgProcessMgr: BackgroundProcessManager;\n  private obsvMgr: ObservableManager;\n\n  constructor(bgProcessMgr: BackgroundProcessManager, obsvMgr: ObservableManager) {\n    super();\n \n    this.bgProcessMgr = bgProcessMgr;\n    this.obsvMgr = obsvMgr;\n\n    this.obsvMgr.subscribe(BackgroundProcessManager.PROCESS_START_TOPIC_NAME, (startBGProcess: any) => {\n      if (startBGProcess.type === 'connection.data' && startBGProcess.userAction === true) {\n        this.runPageLoader();\n      }\n    });\n    this.obsvMgr.subscribe(BackgroundProcessManager.PROCESS_END_TOPIC_NAME, (endBGProcess: any) => {\n      if (endBGProcess.type === 'connection.data' && endBGProcess.userAction === true) {\n        if (this.bgProcessMgr.getRunningProcessesCount('connection.data', null, {\"userAction\": true}) <= 0) {\n          this.stopPageLoader();\n        }\n      }\n    });\n    this.obsvMgr.subscribe(BackgroundProcessManager.PROCESS_ERROR_TOPIC_NAME, (errorBGProcess: any) => {\n      if (errorBGProcess.type === 'connection.data' && errorBGProcess.userAction === true) {\n        if (this.bgProcessMgr.getRunningProcessesCount('connection.data', null, {\"userAction\": true}) <= 0) {\n          this.stopPageLoader();\n        }\n      }\n    });\n  }\n\n  public ngOnInit(): void {\n  }\n\n  public _getIconName(): string {\n    if(this.iconName !== null && typeof this.iconName !== 'undefined'){\n      return this.iconName;\n    }\n\n    return MaterialIconLoader.BALL_CLIP_ROTATE_PULSE;\n  }\n\n  private runPageLoader(): void {\n    if (this.dataLoader === null || typeof this.dataLoader === 'undefined') {\n      return;\n    }\n\n    if (!this.dataLoader.isRunning()) {\n      this.dataLoader.start();\n    }\n  }\n\n  private stopPageLoader(): void {\n    if (this.dataLoader === null || typeof this.dataLoader === 'undefined') {\n      return;\n    }\n\n    if (this.dataLoader.isRunning()) {\n      this.dataLoader.stop();\n    }\n  }\n\n  public getState(): LoaderStatus {\n    return this.dataLoader.getState();\n  }\n\n  public isRunning(): boolean {\n    return this.dataLoader.isRunning();\n  }\n\n  public getSize(): string {\n    return this.size;\n  }\n\n  public setSize(size: string): void {\n    this.size = size;\n  }\n\n  public getLoaderClass(): string {\n    return this.loaderClass;\n  }\n\n  public setLoaderClass(loaderClass: string): void {\n    this.loaderClass = loaderClass;\n  }\n}\n"]}