UNPKG

@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
/** * @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":"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","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"]}