com.phloxui
Version:
PhloxUI Ng2+ Framework
165 lines (164 loc) • 14 kB
JavaScript
/**
* @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"]}