@davvidess/angular-split
Version:
Angular UI library to split views and allow dragging to resize areas using CSS flexbox layout.
297 lines • 19.9 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';
export class SplitAreaDirective {
/**
* @param {?} ngZone
* @param {?} elRef
* @param {?} renderer
* @param {?} split
*/
constructor(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');
}
/**
* @param {?} v
* @return {?}
*/
set order(v) {
this._order = getInputPositiveNumber(v, null);
this.split.updateArea(this, true, false);
}
/**
* @return {?}
*/
get order() {
return this._order;
}
/**
* @param {?} v
* @return {?}
*/
set size(v) {
this._size = getInputPositiveNumber(v, null);
this.split.updateArea(this, false, true);
}
/**
* @return {?}
*/
get size() {
return this._size;
}
/**
* @param {?} v
* @return {?}
*/
set minSize(v) {
this._minSize = getInputPositiveNumber(v, null);
this.split.updateArea(this, false, true);
}
/**
* @return {?}
*/
get minSize() {
return this._minSize;
}
/**
* @param {?} v
* @return {?}
*/
set maxSize(v) {
this._maxSize = getInputPositiveNumber(v, null);
this.split.updateArea(this, false, true);
}
/**
* @return {?}
*/
get maxSize() {
return this._maxSize;
}
/**
* @param {?} v
* @return {?}
*/
set lockSize(v) {
this._lockSize = getInputBoolean(v);
this.split.updateArea(this, false, true);
}
/**
* @return {?}
*/
get lockSize() {
return this._lockSize;
}
/**
* @param {?} v
* @return {?}
*/
set visible(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');
}
}
/**
* @return {?}
*/
get visible() {
return this._visible;
}
/**
* @return {?}
*/
ngOnInit() {
this.split.addArea(this);
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
() => {
this.transitionListener = this.renderer.listen(this.elRef.nativeElement, 'transitionend', (/**
* @param {?} event
* @return {?}
*/
(event) => {
// Limit only flex-basis transition to trigger the event
if (event.propertyName === 'flex-basis') {
this.split.notify('transitionEnd', -1);
}
}));
}));
}
/**
* @param {?} value
* @return {?}
*/
setStyleOrder(value) {
this.renderer.setStyle(this.elRef.nativeElement, 'order', value);
}
/**
* @param {?} grow
* @param {?} shrink
* @param {?} basis
* @param {?} isMin
* @param {?} isMax
* @return {?}
*/
setStyleFlex(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 {?}
*/
lockEvents() {
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
() => {
this.lockListeners.push(this.renderer.listen(this.elRef.nativeElement, 'selectstart', (/**
* @param {?} e
* @return {?}
*/
(e) => false)));
this.lockListeners.push(this.renderer.listen(this.elRef.nativeElement, 'dragstart', (/**
* @param {?} e
* @return {?}
*/
(e) => false)));
}));
}
/**
* @return {?}
*/
unlockEvents() {
while (this.lockListeners.length > 0) {
/** @type {?} */
const fct = this.lockListeners.pop();
if (fct)
fct();
}
}
/**
* @return {?}
*/
ngOnDestroy() {
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 = () => [
{ 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 }]
};
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"]}