UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

165 lines (164 loc) 14 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { Directive, ElementRef, Input } from '@angular/core'; import { UUID } from 'angular2-uuid'; var /** @type {?} */ NAME = 'preload'; var /** @type {?} */ PREFIX_CLASSNAME = 'phx-preload'; var Preload = /** @class */ (function () { function Preload(elementRef) { this.elementRef = elementRef; this.preloadAutoSize = true; this.uuid = UUID.UUID(); this.showing = false; } /** * @return {?} */ Preload.prototype.ngOnInit = /** * @return {?} */ function () { if (this.conponent === undefined || this.conponent === null) { return; } var /** @type {?} */ loaded = true; if (typeof this.conponent['isLoaded'] === 'function') { loaded = this.conponent.isLoaded() && this.conponent.isLoadingEnabled(); } if (!loaded) { this.show(); } }; /** * @return {?} */ Preload.prototype.isShowing = /** * @return {?} */ function () { return this.showing; }; /** * @return {?} */ Preload.prototype.show = /** * @return {?} */ function () { if (this.showing) { // To prevent calling twice. return; } this.showing = true; var /** @type {?} */ ele = this.elementRef.nativeElement; var /** @type {?} */ preLoadDom = document.createElement("div"); var /** @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)) { try { for (var _a = tslib_1.__values(this.preloadClass), _b = _a.next(); !_b.done; _b = _a.next()) { var item = _b.value; className += " " + item; } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (_b && !_b.done && (_c = _a.return)) _c.call(_a); } finally { if (e_1) throw e_1.error; } } } } preLoadDom.setAttribute("class", className); preLoadDom.setAttribute("id", this.uuid); var /** @type {?} */ styleText = ""; if (this.preloadAutoSize) { var /** @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); var e_1, _c; }; /** * @return {?} */ Preload.prototype.hide = /** * @return {?} */ function () { 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 = function () { return [ { type: ElementRef, }, ]; }; Preload.propDecorators = { "conponent": [{ type: Input, args: ['phxPreload',] },], "preloadClass": [{ type: Input, args: ['preloadClass',] },], "preloadAutoSize": [{ type: Input, args: ['preloadAutoSize',] },], "preloadOutline": [{ type: Input, args: ['preloadOutline',] },], }; return Preload; }()); export { Preload }; 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"]}