UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

142 lines (141 loc) 13 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import { Directive, ElementRef, Input } from '@angular/core'; import { UUID } from 'angular2-uuid'; const /** @type {?} */ NAME = 'preload'; const /** @type {?} */ PREFIX_CLASSNAME = 'phx-preload'; export class Preload { /** * @param {?} elementRef */ constructor(elementRef) { this.elementRef = elementRef; this.preloadAutoSize = true; this.uuid = UUID.UUID(); this.showing = false; } /** * @return {?} */ ngOnInit() { if (this.conponent === undefined || this.conponent === null) { return; } let /** @type {?} */ loaded = true; if (typeof this.conponent['isLoaded'] === 'function') { loaded = this.conponent.isLoaded() && this.conponent.isLoadingEnabled(); } if (!loaded) { this.show(); } } /** * @return {?} */ isShowing() { return this.showing; } /** * @return {?} */ show() { if (this.showing) { // To prevent calling twice. return; } this.showing = true; let /** @type {?} */ ele = this.elementRef.nativeElement; let /** @type {?} */ preLoadDom = document.createElement("div"); let /** @type {?} */ className = ""; className += PREFIX_CLASSNAME; if (this.preloadClass !== undefined && this.preloadClass !== null) { if (typeof this.preloadClass === 'string') { className += " " + this.preloadClass; } else if (Array.isArray(this.preloadClass)) { for (let /** @type {?} */ item of this.preloadClass) { className += " " + item; } } } preLoadDom.setAttribute("class", className); preLoadDom.setAttribute("id", this.uuid); let /** @type {?} */ styleText = ""; if (this.preloadAutoSize) { let /** @type {?} */ outlineSize = this.preloadOutline === undefined ? 0 : this.preloadOutline; styleText += "width:" + (ele.clientWidth + outlineSize * 2) + "px; height:" + (ele.clientHeight + outlineSize * 2) + "px;"; styleText += " left:" + (ele.offsetLeft - outlineSize) + "px; top:" + (ele.offsetTop - outlineSize) + "px;"; } else { styleText += " left:" + ele.offsetLeft + "px; top:" + ele.offsetTop + "px;"; } preLoadDom.setAttribute("style", styleText); // Add preload dom $(ele.parentElement).append(preLoadDom); // Hide original dom $(ele).css("opacity", 0); } /** * @return {?} */ hide() { if (!this.showing) { // To prevent calling twice. return; } this.showing = false; // Remove preload dom $(this.elementRef.nativeElement.parentElement).find("#" + this.uuid).remove(); // Show original dom $(this.elementRef.nativeElement).css("opacity", 1); } } Preload.NAME = NAME; Preload.PREFIX_CLASSNAME = PREFIX_CLASSNAME; Preload.decorators = [ { type: Directive, args: [{ selector: '[phxPreload]' },] }, ]; /** @nocollapse */ Preload.ctorParameters = () => [ { type: ElementRef, }, ]; Preload.propDecorators = { "conponent": [{ type: Input, args: ['phxPreload',] },], "preloadClass": [{ type: Input, args: ['preloadClass',] },], "preloadAutoSize": [{ type: Input, args: ['preloadAutoSize',] },], "preloadOutline": [{ type: Input, args: ['preloadOutline',] },], }; function Preload_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ Preload.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ Preload.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ Preload.propDecorators; /** @type {?} */ Preload.NAME; /** @type {?} */ Preload.PREFIX_CLASSNAME; /** @type {?} */ Preload.prototype.conponent; /** @type {?} */ Preload.prototype.preloadClass; /** @type {?} */ Preload.prototype.preloadAutoSize; /** @type {?} */ Preload.prototype.preloadOutline; /** @type {?} */ Preload.prototype.elementRef; /** @type {?} */ Preload.prototype.uuid; /** @type {?} */ Preload.prototype.showing; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Preload.directive.js","sourceRoot":"ng://com.phloxui/","sources":["lib/directive/Preload.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, OnInit } from '@angular/core';\nimport { UUID } from 'angular2-uuid';\n\ndeclare var $: any;\n\nconst NAME: string = 'preload';\nconst PREFIX_CLASSNAME: string = 'phx-preload';\n\n@Directive({\n  selector: '[phxPreload]'\n})\nexport class Preload implements OnInit {\n\n  public static readonly NAME: string = NAME;\n  public static readonly PREFIX_CLASSNAME: string = PREFIX_CLASSNAME;\n\n  @Input('phxPreload')\n  private conponent: any;\n  @Input('preloadClass')\n  private preloadClass: any;\n  @Input('preloadAutoSize')\n  private preloadAutoSize: boolean;\n  @Input('preloadOutline')\n  private preloadOutline: number;\n  private elementRef: ElementRef;\n  private uuid: string;\n  private showing: boolean;\n\n  constructor(elementRef: ElementRef) {\n    this.elementRef = elementRef;\n    this.preloadAutoSize = true;\n    this.uuid = UUID.UUID();\n    this.showing = false;\n  }\n\n  public ngOnInit(): void {\n    if (this.conponent === undefined || this.conponent === null) {\n      return;\n    }\n\n    let loaded: boolean = true;\n    if (typeof this.conponent['isLoaded'] === 'function') {\n      loaded = this.conponent.isLoaded() && this.conponent.isLoadingEnabled();\n    }\n\n    if (!loaded) {\n      this.show();\n    }\n  }\n\n  public isShowing(): boolean {\n    return this.showing;\n  }\n\n  public show(): void {\n    if (this.showing) {\n      // To prevent calling twice.\n      return;\n    }\n\n    this.showing = true;\n\n    let ele = this.elementRef.nativeElement;\n    let preLoadDom: HTMLElement = document.createElement(\"div\");\n    let className: string = \"\";\n\n    className += PREFIX_CLASSNAME;\n\n    if (this.preloadClass !== undefined && this.preloadClass !== null) {\n      if (typeof this.preloadClass === 'string') {\n        className += \" \" + this.preloadClass;\n      } else if (Array.isArray(this.preloadClass)) {\n        for (let item of this.preloadClass) {\n          className += \" \" + item;\n        }\n      }\n    }\n\n    preLoadDom.setAttribute(\"class\", className);\n    preLoadDom.setAttribute(\"id\", this.uuid);\n\n    let styleText = \"\";\n    if (this.preloadAutoSize) {\n      let outlineSize: number = this.preloadOutline === undefined ? 0 : this.preloadOutline;\n      styleText += \"width:\" + (ele.clientWidth + outlineSize * 2) + \"px; height:\" + (ele.clientHeight + outlineSize * 2) + \"px;\"\n      styleText += \" left:\" + (ele.offsetLeft - outlineSize) + \"px; top:\" + (ele.offsetTop - outlineSize) + \"px;\";\n    } else {\n      styleText += \" left:\" + ele.offsetLeft + \"px; top:\" + ele.offsetTop + \"px;\";\n    }\n\n    preLoadDom.setAttribute(\"style\", styleText);\n\n    // Add preload dom\n    $(ele.parentElement).append(preLoadDom);\n\n    // Hide original dom\n    $(ele).css(\"opacity\", 0);\n  }\n\n  public hide(): void {\n    if (!this.showing) {\n      // To prevent calling twice.\n      return;\n    }\n\n    this.showing = false;\n\n    // Remove preload dom\n    $(this.elementRef.nativeElement.parentElement).find(\"#\" + this.uuid).remove();\n\n    // Show original dom\n    $(this.elementRef.nativeElement).css(\"opacity\", 1);\n  }\n}\n"]}