@davvidess/angular-split
Version:
Angular UI library to split views and allow dragging to resize areas using CSS flexbox layout.
343 lines • 22.1 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Directive, Input, ElementRef, Renderer2, NgZone } from '@angular/core';
import { SplitComponent } from '../component/split.component';
import { getInputPositiveNumber, getInputBoolean } from '../utils';
var SplitAreaDirective = /** @class */ (function () {
function SplitAreaDirective(ngZone, elRef, renderer, split) {
this.ngZone = ngZone;
this.elRef = elRef;
this.renderer = renderer;
this.split = split;
this._order = null;
////
this._size = null;
////
this._minSize = null;
////
this._maxSize = null;
////
this._lockSize = false;
////
this._visible = true;
this.lockListeners = [];
this.renderer.addClass(this.elRef.nativeElement, 'as-split-area');
}
Object.defineProperty(SplitAreaDirective.prototype, "order", {
get: /**
* @return {?}
*/
function () {
return this._order;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
this._order = getInputPositiveNumber(v, null);
this.split.updateArea(this, true, false);
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitAreaDirective.prototype, "size", {
get: /**
* @return {?}
*/
function () {
return this._size;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
this._size = getInputPositiveNumber(v, null);
this.split.updateArea(this, false, true);
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitAreaDirective.prototype, "minSize", {
get: /**
* @return {?}
*/
function () {
return this._minSize;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
this._minSize = getInputPositiveNumber(v, null);
this.split.updateArea(this, false, true);
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitAreaDirective.prototype, "maxSize", {
get: /**
* @return {?}
*/
function () {
return this._maxSize;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
this._maxSize = getInputPositiveNumber(v, null);
this.split.updateArea(this, false, true);
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitAreaDirective.prototype, "lockSize", {
get: /**
* @return {?}
*/
function () {
return this._lockSize;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
this._lockSize = getInputBoolean(v);
this.split.updateArea(this, false, true);
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitAreaDirective.prototype, "visible", {
get: /**
* @return {?}
*/
function () {
return this._visible;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
this._visible = getInputBoolean(v);
if (this._visible) {
this.split.showArea(this);
this.renderer.removeClass(this.elRef.nativeElement, 'as-hidden');
}
else {
this.split.hideArea(this);
this.renderer.addClass(this.elRef.nativeElement, 'as-hidden');
}
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
SplitAreaDirective.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
this.split.addArea(this);
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
function () {
_this.transitionListener = _this.renderer.listen(_this.elRef.nativeElement, 'transitionend', (/**
* @param {?} event
* @return {?}
*/
function (event) {
// Limit only flex-basis transition to trigger the event
if (event.propertyName === 'flex-basis') {
_this.split.notify('transitionEnd', -1);
}
}));
}));
};
/**
* @param {?} value
* @return {?}
*/
SplitAreaDirective.prototype.setStyleOrder = /**
* @param {?} value
* @return {?}
*/
function (value) {
this.renderer.setStyle(this.elRef.nativeElement, 'order', value);
};
/**
* @param {?} grow
* @param {?} shrink
* @param {?} basis
* @param {?} isMin
* @param {?} isMax
* @return {?}
*/
SplitAreaDirective.prototype.setStyleFlex = /**
* @param {?} grow
* @param {?} shrink
* @param {?} basis
* @param {?} isMin
* @param {?} isMax
* @return {?}
*/
function (grow, shrink, basis, isMin, isMax) {
// Need 3 separated properties to work on IE11 (https://github.com/angular/flex-layout/issues/323)
this.renderer.setStyle(this.elRef.nativeElement, 'flex-grow', grow);
this.renderer.setStyle(this.elRef.nativeElement, 'flex-shrink', shrink);
this.renderer.setStyle(this.elRef.nativeElement, 'flex-basis', basis);
if (isMin === true)
this.renderer.addClass(this.elRef.nativeElement, 'as-min');
else
this.renderer.removeClass(this.elRef.nativeElement, 'as-min');
if (isMax === true)
this.renderer.addClass(this.elRef.nativeElement, 'as-max');
else
this.renderer.removeClass(this.elRef.nativeElement, 'as-max');
};
/**
* @return {?}
*/
SplitAreaDirective.prototype.lockEvents = /**
* @return {?}
*/
function () {
var _this = this;
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
function () {
_this.lockListeners.push(_this.renderer.listen(_this.elRef.nativeElement, 'selectstart', (/**
* @param {?} e
* @return {?}
*/
function (e) { return false; })));
_this.lockListeners.push(_this.renderer.listen(_this.elRef.nativeElement, 'dragstart', (/**
* @param {?} e
* @return {?}
*/
function (e) { return false; })));
}));
};
/**
* @return {?}
*/
SplitAreaDirective.prototype.unlockEvents = /**
* @return {?}
*/
function () {
while (this.lockListeners.length > 0) {
/** @type {?} */
var fct = this.lockListeners.pop();
if (fct)
fct();
}
};
/**
* @return {?}
*/
SplitAreaDirective.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.unlockEvents();
if (this.transitionListener) {
this.transitionListener();
}
this.split.removeArea(this);
};
SplitAreaDirective.decorators = [
{ type: Directive, args: [{
selector: 'as-split-area, [as-split-area]',
exportAs: 'asSplitArea',
},] }
];
/** @nocollapse */
SplitAreaDirective.ctorParameters = function () { return [
{ type: NgZone },
{ type: ElementRef },
{ type: Renderer2 },
{ type: SplitComponent }
]; };
SplitAreaDirective.propDecorators = {
order: [{ type: Input }],
size: [{ type: Input }],
minSize: [{ type: Input }],
maxSize: [{ type: Input }],
lockSize: [{ type: Input }],
visible: [{ type: Input }]
};
return SplitAreaDirective;
}());
export { SplitAreaDirective };
if (false) {
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._order;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._size;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._minSize;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._maxSize;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._lockSize;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._visible;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.transitionListener;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.lockListeners;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.ngZone;
/** @type {?} */
SplitAreaDirective.prototype.elRef;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.renderer;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.split;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"splitArea.directive.js","sourceRoot":"ng://@davvidess/angular-split/","sources":["lib/directive/splitArea.directive.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,UAAU,EAAE,SAAS,EAAqB,MAAM,EAAE,MAAM,eAAe,CAAA;AAElG,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAA;AAC7D,OAAO,EAAE,sBAAsB,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAElE;IAkGE,4BACU,MAAc,EACf,KAAiB,EAChB,QAAmB,EACnB,KAAqB;QAHrB,WAAM,GAAN,MAAM,CAAQ;QACf,UAAK,GAAL,KAAK,CAAY;QAChB,aAAQ,GAAR,QAAQ,CAAW;QACnB,UAAK,GAAL,KAAK,CAAgB;QAjGvB,WAAM,GAAkB,IAAI,CAAA;;QAc5B,UAAK,GAAkB,IAAI,CAAA;;QAc3B,aAAQ,GAAkB,IAAI,CAAA;;QAc9B,aAAQ,GAAkB,IAAI,CAAA;;QAc9B,cAAS,GAAY,KAAK,CAAA;;QAc1B,aAAQ,GAAY,IAAI,CAAA;QAqBf,kBAAa,GAAoB,EAAE,CAAA;QAQlD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,eAAe,CAAC,CAAA;IACnE,CAAC;IAlGD,sBAAa,qCAAK;;;;QAMlB;YACE,OAAO,IAAI,CAAC,MAAM,CAAA;QACpB,CAAC;;;;;QARD,UAAmB,CAAgB;YACjC,IAAI,CAAC,MAAM,GAAG,sBAAsB,CAAC,CAAC,EAAE,IAAI,CAAC,CAAA;YAE7C,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,CAAA;QAC1C,CAAC;;;OAAA;IAUD,sBAAa,oCAAI;;;;QAMjB;YACE,OAAO,IAAI,CAAC,KAAK,CAAA;QACnB,CAAC;;;;;QARD,UAAkB,CAAgB;YAChC,IAAI,CAAC,KAAK,GAAG,sBAAsB,CAAC,CAAC,EAAE,IAAI,CAAC,CAAA;YAE5C,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAA;QAC1C,CAAC;;;OAAA;IAUD,sBAAa,uCAAO;;;;QAMpB;YACE,OAAO,IAAI,CAAC,QAAQ,CAAA;QACtB,CAAC;;;;;QARD,UAAqB,CAAgB;YACnC,IAAI,CAAC,QAAQ,GAAG,sBAAsB,CAAC,CAAC,EAAE,IAAI,CAAC,CAAA;YAE/C,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAA;QAC1C,CAAC;;;OAAA;IAUD,sBAAa,uCAAO;;;;QAMpB;YACE,OAAO,IAAI,CAAC,QAAQ,CAAA;QACtB,CAAC;;;;;QARD,UAAqB,CAAgB;YACnC,IAAI,CAAC,QAAQ,GAAG,sBAAsB,CAAC,CAAC,EAAE,IAAI,CAAC,CAAA;YAE/C,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAA;QAC1C,CAAC;;;OAAA;IAUD,sBAAa,wCAAQ;;;;QAMrB;YACE,OAAO,IAAI,CAAC,SAAS,CAAA;QACvB,CAAC;;;;;QARD,UAAsB,CAAU;YAC9B,IAAI,CAAC,SAAS,GAAG,eAAe,CAAC,CAAC,CAAC,CAAA;YAEnC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAA;QAC1C,CAAC;;;OAAA;IAUD,sBAAa,uCAAO;;;;QAYpB;YACE,OAAO,IAAI,CAAC,QAAQ,CAAA;QACtB,CAAC;;;;;QAdD,UAAqB,CAAU;YAC7B,IAAI,CAAC,QAAQ,GAAG,eAAe,CAAC,CAAC,CAAC,CAAA;YAElC,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAA;gBACzB,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,WAAW,CAAC,CAAA;aACjE;iBAAM;gBACL,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAA;gBACzB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,WAAW,CAAC,CAAA;aAC9D;QACH,CAAC;;;OAAA;;;;IAoBM,qCAAQ;;;IAAf;QAAA,iBAeC;QAdC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;QAExB,IAAI,CAAC,MAAM,CAAC,iBAAiB;;;QAAC;YAC5B,KAAI,CAAC,kBAAkB,GAAG,KAAI,CAAC,QAAQ,CAAC,MAAM,CAC5C,KAAI,CAAC,KAAK,CAAC,aAAa,EACxB,eAAe;;;;YACf,UAAC,KAAsB;gBACrB,wDAAwD;gBACxD,IAAI,KAAK,CAAC,YAAY,KAAK,YAAY,EAAE;oBACvC,KAAI,CAAC,KAAK,CAAC,MAAM,CAAC,eAAe,EAAE,CAAC,CAAC,CAAC,CAAA;iBACvC;YACH,CAAC,EACF,CAAA;QACH,CAAC,EAAC,CAAA;IACJ,CAAC;;;;;IAEM,0CAAa;;;;IAApB,UAAqB,KAAa;QAChC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,OAAO,EAAE,KAAK,CAAC,CAAA;IAClE,CAAC;;;;;;;;;IAEM,yCAAY;;;;;;;;IAAnB,UAAoB,IAAY,EAAE,MAAc,EAAE,KAAa,EAAE,KAAc,EAAE,KAAc;QAC7F,kGAAkG;QAClG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,WAAW,EAAE,IAAI,CAAC,CAAA;QACnE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,aAAa,EAAE,MAAM,CAAC,CAAA;QACvE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,YAAY,EAAE,KAAK,CAAC,CAAA;QAErE,IAAI,KAAK,KAAK,IAAI;YAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAA;;YACzE,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAA;QAElE,IAAI,KAAK,KAAK,IAAI;YAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAA;;YACzE,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAA;IACpE,CAAC;;;;IAEM,uCAAU;;;IAAjB;QAAA,iBAKC;QAJC,IAAI,CAAC,MAAM,CAAC,iBAAiB;;;QAAC;YAC5B,KAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAI,CAAC,KAAK,CAAC,aAAa,EAAE,aAAa;;;;YAAE,UAAC,CAAQ,IAAK,OAAA,KAAK,EAAL,CAAK,EAAC,CAAC,CAAA;YAC3G,KAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAI,CAAC,KAAK,CAAC,aAAa,EAAE,WAAW;;;;YAAE,UAAC,CAAQ,IAAK,OAAA,KAAK,EAAL,CAAK,EAAC,CAAC,CAAA;QAC3G,CAAC,EAAC,CAAA;IACJ,CAAC;;;;IAEM,yCAAY;;;IAAnB;QACE,OAAO,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE;;gBAC9B,GAAG,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,EAAE;YACpC,IAAI,GAAG;gBAAE,GAAG,EAAE,CAAA;SACf;IACH,CAAC;;;;IAEM,wCAAW;;;IAAlB;QACE,IAAI,CAAC,YAAY,EAAE,CAAA;QAEnB,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC3B,IAAI,CAAC,kBAAkB,EAAE,CAAA;SAC1B;QAED,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,CAAA;IAC7B,CAAC;;gBAnKF,SAAS,SAAC;oBACT,QAAQ,EAAE,gCAAgC;oBAC1C,QAAQ,EAAE,aAAa;iBACxB;;;;gBARoE,MAAM;gBAAhD,UAAU;gBAAE,SAAS;gBAEvC,cAAc;;;wBAUpB,KAAK;uBAcL,KAAK;0BAcL,KAAK;0BAcL,KAAK;2BAcL,KAAK;0BAcL,KAAK;;IAuFR,yBAAC;CAAA,AApKD,IAoKC;SAhKY,kBAAkB;;;;;;IAC7B,oCAAoC;;;;;IAcpC,mCAAmC;;;;;IAcnC,sCAAsC;;;;;IActC,sCAAsC;;;;;IActC,uCAAkC;;;;;IAclC,sCAAgC;;;;;IAoBhC,gDAAoC;;;;;IACpC,2CAAoD;;;;;IAGlD,oCAAsB;;IACtB,mCAAwB;;;;;IACxB,sCAA2B;;;;;IAC3B,mCAA6B","sourcesContent":["import { Directive, Input, ElementRef, Renderer2, OnInit, OnDestroy, NgZone } from '@angular/core'\n\nimport { SplitComponent } from '../component/split.component'\nimport { getInputPositiveNumber, getInputBoolean } from '../utils'\n\n@Directive({\n  selector: 'as-split-area, [as-split-area]',\n  exportAs: 'asSplitArea',\n})\nexport class SplitAreaDirective implements OnInit, OnDestroy {\n  private _order: number | null = null\n\n  @Input() set order(v: number | null) {\n    this._order = getInputPositiveNumber(v, null)\n\n    this.split.updateArea(this, true, false)\n  }\n\n  get order(): number | null {\n    return this._order\n  }\n\n  ////\n\n  private _size: number | null = null\n\n  @Input() set size(v: number | null) {\n    this._size = getInputPositiveNumber(v, null)\n\n    this.split.updateArea(this, false, true)\n  }\n\n  get size(): number | null {\n    return this._size\n  }\n\n  ////\n\n  private _minSize: number | null = null\n\n  @Input() set minSize(v: number | null) {\n    this._minSize = getInputPositiveNumber(v, null)\n\n    this.split.updateArea(this, false, true)\n  }\n\n  get minSize(): number | null {\n    return this._minSize\n  }\n\n  ////\n\n  private _maxSize: number | null = null\n\n  @Input() set maxSize(v: number | null) {\n    this._maxSize = getInputPositiveNumber(v, null)\n\n    this.split.updateArea(this, false, true)\n  }\n\n  get maxSize(): number | null {\n    return this._maxSize\n  }\n\n  ////\n\n  private _lockSize: boolean = false\n\n  @Input() set lockSize(v: boolean) {\n    this._lockSize = getInputBoolean(v)\n\n    this.split.updateArea(this, false, true)\n  }\n\n  get lockSize(): boolean {\n    return this._lockSize\n  }\n\n  ////\n\n  private _visible: boolean = true\n\n  @Input() set visible(v: boolean) {\n    this._visible = getInputBoolean(v)\n\n    if (this._visible) {\n      this.split.showArea(this)\n      this.renderer.removeClass(this.elRef.nativeElement, 'as-hidden')\n    } else {\n      this.split.hideArea(this)\n      this.renderer.addClass(this.elRef.nativeElement, 'as-hidden')\n    }\n  }\n\n  get visible(): boolean {\n    return this._visible\n  }\n\n  ////\n\n  private transitionListener: Function\n  private readonly lockListeners: Array<Function> = []\n\n  constructor(\n    private ngZone: NgZone,\n    public elRef: ElementRef,\n    private renderer: Renderer2,\n    private split: SplitComponent,\n  ) {\n    this.renderer.addClass(this.elRef.nativeElement, 'as-split-area')\n  }\n\n  public ngOnInit(): void {\n    this.split.addArea(this)\n\n    this.ngZone.runOutsideAngular(() => {\n      this.transitionListener = this.renderer.listen(\n        this.elRef.nativeElement,\n        'transitionend',\n        (event: TransitionEvent) => {\n          // Limit only flex-basis transition to trigger the event\n          if (event.propertyName === 'flex-basis') {\n            this.split.notify('transitionEnd', -1)\n          }\n        },\n      )\n    })\n  }\n\n  public setStyleOrder(value: number): void {\n    this.renderer.setStyle(this.elRef.nativeElement, 'order', value)\n  }\n\n  public setStyleFlex(grow: number, shrink: number, basis: string, isMin: boolean, isMax: boolean): void {\n    // Need 3 separated properties to work on IE11 (https://github.com/angular/flex-layout/issues/323)\n    this.renderer.setStyle(this.elRef.nativeElement, 'flex-grow', grow)\n    this.renderer.setStyle(this.elRef.nativeElement, 'flex-shrink', shrink)\n    this.renderer.setStyle(this.elRef.nativeElement, 'flex-basis', basis)\n\n    if (isMin === true) this.renderer.addClass(this.elRef.nativeElement, 'as-min')\n    else this.renderer.removeClass(this.elRef.nativeElement, 'as-min')\n\n    if (isMax === true) this.renderer.addClass(this.elRef.nativeElement, 'as-max')\n    else this.renderer.removeClass(this.elRef.nativeElement, 'as-max')\n  }\n\n  public lockEvents(): void {\n    this.ngZone.runOutsideAngular(() => {\n      this.lockListeners.push(this.renderer.listen(this.elRef.nativeElement, 'selectstart', (e: Event) => false))\n      this.lockListeners.push(this.renderer.listen(this.elRef.nativeElement, 'dragstart', (e: Event) => false))\n    })\n  }\n\n  public unlockEvents(): void {\n    while (this.lockListeners.length > 0) {\n      const fct = this.lockListeners.pop()\n      if (fct) fct()\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.unlockEvents()\n\n    if (this.transitionListener) {\n      this.transitionListener()\n    }\n\n    this.split.removeArea(this)\n  }\n}\n"]}