angular-split-ng6
Version:
Copy of angular-split but with aszechlicki fix, and some other errors patched for angular 6.
1,371 lines (1,362 loc) • 46.7 kB
JavaScript
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Directive, ElementRef, EventEmitter, HostBinding, Input, NgModule, NgZone, Output, Renderer2 } from '@angular/core';
import { CommonModule } from '@angular/common';
import { Subject } from 'rxjs';
import { debounceTime } from 'rxjs/operators';
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
/**
* angular-split
*
* Areas size are set in percentage of the split container.
* Gutters size are set in pixels.
*
* So we set css 'flex-basis' property like this (where 0 <= area.size <= 1):
* calc( { area.size * 100 }% - { area.size * nbGutter * gutterSize }px );
*
* Examples with 3 visible areas and 2 gutters:
*
* | 10px 10px |
* |---------------------[]---------------------[]------------------------------------|
* | calc(20% - 4px) calc(20% - 4px) calc(60% - 12px) |
*
*
* | 10px 10px |
* |--------------------------[]--------------------------[]--------------------------|
* | calc(33.33% - 6.667px) calc(33.33% - 6.667px) calc(33.33% - 6.667px) |
*
*
* |10px 10px |
* |[]----------------------------------------------------[]--------------------------|
* |0 calc(66.66% - 13.333px) calc(33%% - 6.667px) |
*
*
* 10px 10px |
* |[][]------------------------------------------------------------------------------|
* |0 0 calc(100% - 20px) |
*
*/
var SplitComponent = /** @class */ (function () {
function SplitComponent(ngZone, elRef, cdRef, renderer) {
this.ngZone = ngZone;
this.elRef = elRef;
this.cdRef = cdRef;
this.renderer = renderer;
this._direction = 'horizontal';
this._useTransition = false;
this._disabled = false;
this._width = null;
this._height = null;
this._gutterSize = 11;
this._gutterColor = '';
this._gutterImageH = '';
this._gutterImageV = '';
this._dir = 'ltr';
this.dragStart = new EventEmitter(false);
this.dragProgress = new EventEmitter(false);
this.dragEnd = new EventEmitter(false);
this.gutterClick = new EventEmitter(false);
this.transitionEndInternal = new Subject();
this.transitionEnd = (/** @type {?} */ (this.transitionEndInternal.asObservable())).pipe(debounceTime(20));
this.isViewInitialized = false;
this.displayedAreas = [];
this.isDragging = false;
this.draggingWithoutMove = false;
this.currentGutterNum = 0;
this.hidedAreas = [];
this.dragListeners = [];
this.dragStartValues = {
sizePixelContainer: 0,
sizePixelA: 0,
sizePixelB: 0,
sizePercentA: 0,
sizePercentB: 0,
};
}
Object.defineProperty(SplitComponent.prototype, "direction", {
get: /**
* @return {?}
*/
function () {
return this._direction;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
var _this = this;
v = (v === 'vertical') ? 'vertical' : 'horizontal';
this._direction = v;
this.displayedAreas.concat(this.hidedAreas).forEach(function (area) {
area.comp.setStyleVisibleAndDir(area.comp.visible, _this.isDragging, _this.direction);
});
this.build(false, false);
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitComponent.prototype, "useTransition", {
get: /**
* @return {?}
*/
function () {
return this._useTransition;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
v = (typeof (v) === 'boolean') ? v : (v === 'false' ? false : true);
this._useTransition = v;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitComponent.prototype, "disabled", {
get: /**
* @return {?}
*/
function () {
return this._disabled;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
v = (typeof (v) === 'boolean') ? v : (v === 'false' ? false : true);
this._disabled = v;
// Force repaint if modified from TS class (instead of the template)
this.cdRef.markForCheck();
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitComponent.prototype, "width", {
get: /**
* @return {?}
*/
function () {
return this._width;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
v = Number(v);
this._width = (!isNaN(v) && v > 0) ? v : null;
this.build(false, false);
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitComponent.prototype, "height", {
get: /**
* @return {?}
*/
function () {
return this._height;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
v = Number(v);
this._height = (!isNaN(v) && v > 0) ? v : null;
this.build(false, false);
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitComponent.prototype, "gutterSize", {
get: /**
* @return {?}
*/
function () {
return this._gutterSize;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
v = Number(v);
this._gutterSize = (!isNaN(v) && v > 0) ? v : 11;
this.build(false, false);
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitComponent.prototype, "gutterColor", {
get: /**
* @return {?}
*/
function () {
return this._gutterColor;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
this._gutterColor = (typeof v === 'string' && v !== '') ? v : '';
// Force repaint if modified from TS class (instead of the template)
this.cdRef.markForCheck();
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitComponent.prototype, "gutterImageH", {
get: /**
* @return {?}
*/
function () {
return this._gutterImageH;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
this._gutterImageH = (typeof v === 'string' && v !== '') ? v : '';
// Force repaint if modified from TS class (instead of the template)
this.cdRef.markForCheck();
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitComponent.prototype, "gutterImageV", {
get: /**
* @return {?}
*/
function () {
return this._gutterImageV;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
this._gutterImageV = (typeof v === 'string' && v !== '') ? v : '';
// Force repaint if modified from TS class (instead of the template)
this.cdRef.markForCheck();
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitComponent.prototype, "dir", {
get: /**
* @return {?}
*/
function () {
return this._dir;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
v = (v === 'rtl') ? 'rtl' : 'ltr';
this._dir = v;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitComponent.prototype, "cssFlexdirection", {
get: /**
* @return {?}
*/
function () {
return (this.direction === 'horizontal') ? 'row' : 'column';
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitComponent.prototype, "cssWidth", {
get: /**
* @return {?}
*/
function () {
return this.width ? this.width + "px" : '100%';
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitComponent.prototype, "cssHeight", {
get: /**
* @return {?}
*/
function () {
return this.height ? this.height + "px" : '100%';
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitComponent.prototype, "cssMinwidth", {
get: /**
* @return {?}
*/
function () {
return (this.direction === 'horizontal') ? this.getNbGutters() * this.gutterSize + "px" : null;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitComponent.prototype, "cssMinheight", {
get: /**
* @return {?}
*/
function () {
return (this.direction === 'vertical') ? this.getNbGutters() * this.gutterSize + "px" : null;
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
SplitComponent.prototype.ngAfterViewInit = /**
* @return {?}
*/
function () {
this.isViewInitialized = true;
};
/**
* @param {?} startEvent
* @param {?} gutterOrder
* @param {?} gutterNum
* @return {?}
*/
SplitComponent.prototype.startDragging = /**
* @param {?} startEvent
* @param {?} gutterOrder
* @param {?} gutterNum
* @return {?}
*/
function (startEvent, gutterOrder, gutterNum) {
var _this = this;
startEvent.preventDefault();
// Place code here to allow '(gutterClick)' event even if '[disabled]="true"'.
this.currentGutterNum = gutterNum;
this.draggingWithoutMove = true;
this.ngZone.runOutsideAngular(function () {
_this.dragListeners.push(_this.renderer.listen('document', 'mouseup', function (e) { return _this.stopDragging(); }));
_this.dragListeners.push(_this.renderer.listen('document', 'touchend', function (e) { return _this.stopDragging(); }));
_this.dragListeners.push(_this.renderer.listen('document', 'touchcancel', function (e) { return _this.stopDragging(); }));
});
if (this.disabled) {
return;
}
var /** @type {?} */ areaA = this.displayedAreas.find(function (a) { return a.order === gutterOrder - 1; });
var /** @type {?} */ areaB = this.displayedAreas.find(function (a) { return a.order === gutterOrder + 1; });
if (!areaA || !areaB) {
return;
}
var /** @type {?} */ prop = (this.direction === 'horizontal') ? 'offsetWidth' : 'offsetHeight';
this.dragStartValues.sizePixelContainer = this.elRef.nativeElement[prop];
this.dragStartValues.sizePixelA = areaA.comp.getSizePixel(prop);
this.dragStartValues.sizePixelB = areaB.comp.getSizePixel(prop);
this.dragStartValues.sizePercentA = areaA.size;
this.dragStartValues.sizePercentB = areaB.size;
var /** @type {?} */ start;
if (startEvent instanceof MouseEvent) {
start = {
x: startEvent.screenX,
y: startEvent.screenY,
};
}
else if (startEvent instanceof TouchEvent) {
start = {
x: startEvent.touches[0].screenX,
y: startEvent.touches[0].screenY,
};
}
else {
return;
}
this.ngZone.runOutsideAngular(function () {
_this.dragListeners.push(_this.renderer.listen('document', 'mousemove', function (e) { return _this.dragEvent(e, start, areaA, areaB); }));
_this.dragListeners.push(_this.renderer.listen('document', 'touchmove', function (e) { return _this.dragEvent(e, start, areaA, areaB); }));
});
areaA.comp.lockEvents();
areaB.comp.lockEvents();
this.isDragging = true;
this.notify('start');
};
/**
* @param {?} type
* @return {?}
*/
SplitComponent.prototype.notify = /**
* @param {?} type
* @return {?}
*/
function (type) {
var /** @type {?} */ areasSize = this.displayedAreas.map(function (a) { return a.size * 100; });
switch (type) {
case 'start':
return this.dragStart.emit({ gutterNum: this.currentGutterNum, sizes: areasSize });
case 'progress':
return this.dragProgress.emit({ gutterNum: this.currentGutterNum, sizes: areasSize });
case 'end':
return this.dragEnd.emit({ gutterNum: this.currentGutterNum, sizes: areasSize });
case 'click':
return this.gutterClick.emit({ gutterNum: this.currentGutterNum, sizes: areasSize });
case 'transitionEnd':
return this.transitionEndInternal.next(areasSize);
}
};
/**
* @return {?}
*/
SplitComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.stopDragging();
};
/**
* @param {?} comp
* @return {?}
*/
SplitComponent.prototype.addArea = /**
* @param {?} comp
* @return {?}
*/
function (comp) {
var /** @type {?} */ newArea = {
comp: comp,
order: 0,
size: 0,
};
if (comp.visible === true) {
this.displayedAreas.push(newArea);
}
else {
this.hidedAreas.push(newArea);
}
comp.setStyleVisibleAndDir(comp.visible, this.isDragging, this.direction);
this.build(true, true);
};
/**
* @param {?} comp
* @return {?}
*/
SplitComponent.prototype.removeArea = /**
* @param {?} comp
* @return {?}
*/
function (comp) {
if (this.displayedAreas.some(function (a) { return a.comp === comp; })) {
var /** @type {?} */ area = /** @type {?} */ (this.displayedAreas.find(function (a) { return a.comp === comp; }));
this.displayedAreas.splice(this.displayedAreas.indexOf(area), 1);
this.build(true, true);
}
else if (this.hidedAreas.some(function (a) { return a.comp === comp; })) {
var /** @type {?} */ area = /** @type {?} */ (this.hidedAreas.find(function (a) { return a.comp === comp; }));
this.hidedAreas.splice(this.hidedAreas.indexOf(area), 1);
}
};
/**
* @param {?} comp
* @param {?} resetOrders
* @param {?} resetSizes
* @return {?}
*/
SplitComponent.prototype.updateArea = /**
* @param {?} comp
* @param {?} resetOrders
* @param {?} resetSizes
* @return {?}
*/
function (comp, resetOrders, resetSizes) {
// Only refresh if area is displayed (No need to check inside 'hidedAreas')
var /** @type {?} */ item = this.displayedAreas.find(function (a) { return a.comp === comp; });
if (item) {
this.build(resetOrders, resetSizes);
}
};
/**
* @param {?} comp
* @return {?}
*/
SplitComponent.prototype.showArea = /**
* @param {?} comp
* @return {?}
*/
function (comp) {
var /** @type {?} */ area = this.hidedAreas.find(function (a) { return a.comp === comp; });
if (area) {
comp.setStyleVisibleAndDir(comp.visible, this.isDragging, this.direction);
var /** @type {?} */ areas = this.hidedAreas.splice(this.hidedAreas.indexOf(area), 1);
(_a = this.displayedAreas).push.apply(_a, areas);
this.build(true, true);
}
var _a;
};
/**
* @param {?} comp
* @return {?}
*/
SplitComponent.prototype.hideArea = /**
* @param {?} comp
* @return {?}
*/
function (comp) {
var /** @type {?} */ area = this.displayedAreas.find(function (a) { return a.comp === comp; });
if (area) {
comp.setStyleVisibleAndDir(comp.visible, this.isDragging, this.direction);
var /** @type {?} */ areas = this.displayedAreas.splice(this.displayedAreas.indexOf(area), 1);
areas.forEach(function (area) {
area.order = 0;
area.size = 0;
});
(_a = this.hidedAreas).push.apply(_a, areas);
this.build(true, true);
}
var _a;
};
/**
* @return {?}
*/
SplitComponent.prototype.getNbGutters = /**
* @return {?}
*/
function () {
return this.displayedAreas.length - 1;
};
/**
* @param {?} resetOrders
* @param {?} resetSizes
* @return {?}
*/
SplitComponent.prototype.build = /**
* @param {?} resetOrders
* @param {?} resetSizes
* @return {?}
*/
function (resetOrders, resetSizes) {
var _this = this;
this.stopDragging();
// ¤ AREAS ORDER
if (resetOrders === true) {
// If user provided 'order' for each area, use it to sort them.
if (this.displayedAreas.every(function (a) { return a.comp.order !== null; })) {
this.displayedAreas.sort(function (a, b) { return (/** @type {?} */ (a.comp.order)) - (/** @type {?} */ (b.comp.order)); });
}
// Then set real order with multiples of 2, numbers between will be used by gutters.
this.displayedAreas.forEach(function (area, i) {
area.order = i * 2;
area.comp.setStyleOrder(area.order);
});
}
// ¤ AREAS SIZE PERCENT
if (resetSizes === true) {
var /** @type {?} */ totalUserSize = /** @type {?} */ (this.displayedAreas.reduce(function (total, s) { return s.comp.size ? total + s.comp.size : total; }, 0));
// If user provided 'size' for each area and total == 1, use it.
if (this.displayedAreas.every(function (a) { return a.comp.size !== null; }) && totalUserSize > .999 && totalUserSize < 1.001) {
this.displayedAreas.forEach(function (area) {
area.size = /** @type {?} */ (area.comp.size);
});
}
else {
var /** @type {?} */ size_1 = 1 / this.displayedAreas.length;
this.displayedAreas.forEach(function (area) {
area.size = size_1;
});
}
}
// ¤
// If some real area sizes are less than gutterSize,
// set them to zero and dispatch size to others.
var /** @type {?} */ percentToDispatch = 0;
// Get container pixel size
var /** @type {?} */ containerSizePixel = this.getNbGutters() * this.gutterSize;
if (this.direction === 'horizontal') {
containerSizePixel = this.width ? this.width : this.elRef.nativeElement['offsetWidth'];
}
else {
containerSizePixel = this.height ? this.height : this.elRef.nativeElement['offsetHeight'];
}
this.displayedAreas.forEach(function (area) {
if (area.size * containerSizePixel < _this.gutterSize) {
percentToDispatch += area.size;
area.size = 0;
}
});
if (percentToDispatch > 0 && this.displayedAreas.length > 0) {
var /** @type {?} */ nbAreasNotZero = this.displayedAreas.filter(function (a) { return a.size !== 0; }).length;
if (nbAreasNotZero > 0) {
var /** @type {?} */ percentToAdd_1 = percentToDispatch / nbAreasNotZero;
this.displayedAreas.filter(function (a) { return a.size !== 0; }).forEach(function (area) {
area.size += percentToAdd_1;
});
}
else {
this.displayedAreas[this.displayedAreas.length - 1].size = 1;
}
}
this.refreshStyleSizes();
this.cdRef.markForCheck();
};
/**
* @return {?}
*/
SplitComponent.prototype.refreshStyleSizes = /**
* @return {?}
*/
function () {
var _this = this;
var /** @type {?} */ sumGutterSize = this.getNbGutters() * this.gutterSize;
this.displayedAreas.forEach(function (area) {
area.comp.setStyleFlexbasis("calc( " + area.size * 100 + "% - " + area.size * sumGutterSize + "px )", _this.isDragging);
});
};
/**
* @param {?} event
* @param {?} start
* @param {?} areaA
* @param {?} areaB
* @return {?}
*/
SplitComponent.prototype.dragEvent = /**
* @param {?} event
* @param {?} start
* @param {?} areaA
* @param {?} areaB
* @return {?}
*/
function (event, start, areaA, areaB) {
if (!this.isDragging) {
return;
}
var /** @type {?} */ end;
if (event instanceof MouseEvent) {
end = {
x: event.screenX,
y: event.screenY,
};
}
else if (event instanceof TouchEvent) {
end = {
x: event.touches[0].screenX,
y: event.touches[0].screenY,
};
}
else {
return;
}
this.draggingWithoutMove = false;
this.drag(start, end, areaA, areaB);
};
/**
* @param {?} start
* @param {?} end
* @param {?} areaA
* @param {?} areaB
* @return {?}
*/
SplitComponent.prototype.drag = /**
* @param {?} start
* @param {?} end
* @param {?} areaA
* @param {?} areaB
* @return {?}
*/
function (start, end, areaA, areaB) {
// ¤ AREAS SIZE PIXEL
var /** @type {?} */ devicePixelRatio = window.devicePixelRatio || 1;
var /** @type {?} */ offsetPixel = (this.direction === 'horizontal') ? (start.x - end.x) : (start.y - end.y);
offsetPixel = offsetPixel / devicePixelRatio;
if (this.dir === 'rtl') {
offsetPixel = -offsetPixel;
}
var /** @type {?} */ newSizePixelA = this.dragStartValues.sizePixelA - offsetPixel;
var /** @type {?} */ newSizePixelB = this.dragStartValues.sizePixelB + offsetPixel;
if (newSizePixelA < this.gutterSize && newSizePixelB < this.gutterSize) {
// WTF.. get out of here!
return;
}
else if (newSizePixelA < this.gutterSize) {
newSizePixelB += newSizePixelA;
newSizePixelA = 0;
}
else if (newSizePixelB < this.gutterSize) {
newSizePixelA += newSizePixelB;
newSizePixelB = 0;
}
// ¤ AREAS SIZE PERCENT
if (newSizePixelA === 0) {
areaB.size += areaA.size;
areaA.size = 0;
}
else if (newSizePixelB === 0) {
areaA.size += areaB.size;
areaB.size = 0;
}
else {
// NEW_PERCENT = START_PERCENT / START_PIXEL * NEW_PIXEL;
if (this.dragStartValues.sizePercentA === 0) {
areaB.size = this.dragStartValues.sizePercentB / this.dragStartValues.sizePixelB * newSizePixelB;
areaA.size = this.dragStartValues.sizePercentB - areaB.size;
}
else if (this.dragStartValues.sizePercentB === 0) {
areaA.size = this.dragStartValues.sizePercentA / this.dragStartValues.sizePixelA * newSizePixelA;
areaB.size = this.dragStartValues.sizePercentA - areaA.size;
}
else {
areaA.size = this.dragStartValues.sizePercentA / this.dragStartValues.sizePixelA * newSizePixelA;
areaB.size = (this.dragStartValues.sizePercentA + this.dragStartValues.sizePercentB) - areaA.size;
}
}
this.refreshStyleSizes();
this.notify('progress');
};
/**
* @return {?}
*/
SplitComponent.prototype.stopDragging = /**
* @return {?}
*/
function () {
if (this.isDragging === false && this.draggingWithoutMove === false) {
return;
}
this.displayedAreas.forEach(function (area) {
area.comp.unlockEvents();
});
while (this.dragListeners.length > 0) {
var /** @type {?} */ fct = this.dragListeners.pop();
if (fct) {
fct();
}
}
if (this.draggingWithoutMove === true) {
this.notify('click');
}
else {
this.notify('end');
}
this.isDragging = false;
this.draggingWithoutMove = false;
};
SplitComponent.decorators = [
{ type: Component, args: [{
selector: 'split',
changeDetection: ChangeDetectionStrategy.OnPush,
styles: ["\n :host {\n display: flex;\n flex-wrap: nowrap;\n justify-content: flex-start;\n align-items: stretch;\n overflow: hidden;\n /* \n Important to keep following rules even if overrided later by 'HostBinding' \n because if [width] & [height] not provided, when build() is executed,\n 'HostBinding' hasn't been applied yet so code:\n this.elRef.nativeElement[\"offsetHeight\"] gives wrong value! \n */\n width: 100%;\n height: 100%; \n }\n\n split-gutter {\n flex-grow: 0;\n flex-shrink: 0;\n background-position: center center;\n background-repeat: no-repeat;\n }\n "],
template: "\n <ng-content></ng-content>\n <ng-template ngFor let-area [ngForOf]=\"displayedAreas\" let-index=\"index\" let-last=\"last\">\n <split-gutter *ngIf=\"last === false\" \n [order]=\"index*2+1\"\n [direction]=\"direction\"\n [useTransition]=\"useTransition\"\n [size]=\"gutterSize\"\n [color]=\"gutterColor\"\n [imageH]=\"gutterImageH\"\n [imageV]=\"gutterImageV\"\n [disabled]=\"disabled\"\n (mousedown)=\"startDragging($event, index*2+1, index+1)\"\n (touchstart)=\"startDragging($event, index*2+1, index+1)\"></split-gutter>\n </ng-template>",
},] },
];
/** @nocollapse */
SplitComponent.ctorParameters = function () { return [
{ type: NgZone },
{ type: ElementRef },
{ type: ChangeDetectorRef },
{ type: Renderer2 }
]; };
SplitComponent.propDecorators = {
direction: [{ type: Input }],
useTransition: [{ type: Input }],
disabled: [{ type: Input }],
width: [{ type: Input }],
height: [{ type: Input }],
gutterSize: [{ type: Input }],
gutterColor: [{ type: Input }],
gutterImageH: [{ type: Input }],
gutterImageV: [{ type: Input }],
dir: [{ type: Input }],
dragStart: [{ type: Output }],
dragProgress: [{ type: Output }],
dragEnd: [{ type: Output }],
gutterClick: [{ type: Output }],
transitionEnd: [{ type: Output }],
cssFlexdirection: [{ type: HostBinding, args: ['style.flex-direction',] }],
cssWidth: [{ type: HostBinding, args: ['style.width',] }],
cssHeight: [{ type: HostBinding, args: ['style.height',] }],
cssMinwidth: [{ type: HostBinding, args: ['style.min-width',] }],
cssMinheight: [{ type: HostBinding, args: ['style.min-height',] }]
};
return SplitComponent;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
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 = 0;
this._visible = true;
this.transitionListener = null;
this.lockListeners = [];
}
Object.defineProperty(SplitAreaDirective.prototype, "order", {
get: /**
* @return {?}
*/
function () {
return this._order;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
v = Number(v);
this._order = !isNaN(v) ? 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) {
v = Number(v);
this._size = (!isNaN(v) && v >= 0 && v <= 100) ? (v / 100) : 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) {
v = Number(v);
this._minSize = (!isNaN(v) && v > 0 && v < 100) ? v / 100 : 0;
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) {
v = (typeof (v) === 'boolean') ? v : (v === 'false' ? false : true);
this._visible = v;
if (this.visible) {
this.split.showArea(this);
}
else {
this.split.hideArea(this);
}
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
SplitAreaDirective.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
this.split.addArea(this);
this.renderer.setStyle(this.elRef.nativeElement, 'flex-grow', '0');
this.renderer.setStyle(this.elRef.nativeElement, 'flex-shrink', '0');
this.ngZone.runOutsideAngular(function () {
_this.transitionListener = _this.renderer.listen(_this.elRef.nativeElement, 'transitionend', function (e) { return _this.onTransitionEnd(e); });
});
};
/**
* @param {?} prop
* @return {?}
*/
SplitAreaDirective.prototype.getSizePixel = /**
* @param {?} prop
* @return {?}
*/
function (prop) {
return this.elRef.nativeElement[prop];
};
/**
* @param {?} isVisible
* @param {?} isDragging
* @param {?} direction
* @return {?}
*/
SplitAreaDirective.prototype.setStyleVisibleAndDir = /**
* @param {?} isVisible
* @param {?} isDragging
* @param {?} direction
* @return {?}
*/
function (isVisible, isDragging, direction) {
if (isVisible === false) {
this.setStyleFlexbasis('0', isDragging);
this.renderer.setStyle(this.elRef.nativeElement, 'overflow-x', 'hidden');
this.renderer.setStyle(this.elRef.nativeElement, 'overflow-y', 'hidden');
if (direction === 'vertical') {
this.renderer.setStyle(this.elRef.nativeElement, 'max-width', '0');
}
}
else {
this.renderer.setStyle(this.elRef.nativeElement, 'overflow-x', 'hidden');
this.renderer.setStyle(this.elRef.nativeElement, 'overflow-y', 'auto');
this.renderer.removeStyle(this.elRef.nativeElement, 'max-width');
}
if (direction === 'horizontal') {
this.renderer.setStyle(this.elRef.nativeElement, 'height', '100%');
this.renderer.removeStyle(this.elRef.nativeElement, 'width');
}
else {
this.renderer.setStyle(this.elRef.nativeElement, 'width', '100%');
this.renderer.removeStyle(this.elRef.nativeElement, 'height');
}
};
/**
* @param {?} value
* @return {?}
*/
SplitAreaDirective.prototype.setStyleOrder = /**
* @param {?} value
* @return {?}
*/
function (value) {
this.renderer.setStyle(this.elRef.nativeElement, 'order', value);
};
/**
* @param {?} value
* @param {?} isDragging
* @return {?}
*/
SplitAreaDirective.prototype.setStyleFlexbasis = /**
* @param {?} value
* @param {?} isDragging
* @return {?}
*/
function (value, isDragging) {
// If component not yet initialized or gutter being dragged, disable transition
if (this.split.isViewInitialized === false || isDragging === true) {
this.setStyleTransition(false);
}
else {
this.setStyleTransition(this.split.useTransition);
}
this.renderer.setStyle(this.elRef.nativeElement, 'flex-basis', value);
};
/**
* @param {?} useTransition
* @return {?}
*/
SplitAreaDirective.prototype.setStyleTransition = /**
* @param {?} useTransition
* @return {?}
*/
function (useTransition) {
if (useTransition) {
this.renderer.setStyle(this.elRef.nativeElement, 'transition', "flex-basis 0.3s");
}
else {
this.renderer.removeStyle(this.elRef.nativeElement, 'transition');
}
};
/**
* @param {?} event
* @return {?}
*/
SplitAreaDirective.prototype.onTransitionEnd = /**
* @param {?} event
* @return {?}
*/
function (event) {
// Limit only flex-basis transition to trigger the event
if (event.propertyName === 'flex-basis') {
this.split.notify('transitionEnd');
}
};
/**
* @return {?}
*/
SplitAreaDirective.prototype.lockEvents = /**
* @return {?}
*/
function () {
var _this = this;
this.ngZone.runOutsideAngular(function () {
_this.lockListeners.push(_this.renderer.listen(_this.elRef.nativeElement, 'selectstart', function (e) { return false; }));
_this.lockListeners.push(_this.renderer.listen(_this.elRef.nativeElement, 'dragstart', function (e) { return false; }));
});
};
/**
* @return {?}
*/
SplitAreaDirective.prototype.unlockEvents = /**
* @return {?}
*/
function () {
while (this.lockListeners.length > 0) {
var /** @type {?} */ 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: 'split-area'
},] },
];
/** @nocollapse */
SplitAreaDirective.ctorParameters = function () { return [
{ type: NgZone },
{ type: ElementRef },
{ type: Renderer2 },
{ type: SplitComponent }
]; };
SplitAreaDirective.propDecorators = {
order: [{ type: Input }],
size: [{ type: Input }],
minSize: [{ type: Input }],
visible: [{ type: Input }]
};
return SplitAreaDirective;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
var SplitGutterDirective = /** @class */ (function () {
////
function SplitGutterDirective(elRef, renderer) {
this.elRef = elRef;
this.renderer = renderer;
this._direction = 'vertical';
this._size = 0;
this._color = '';
this._imageH = '';
this._imageV = '';
this._disabled = false;
}
Object.defineProperty(SplitGutterDirective.prototype, "order", {
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
this.renderer.setStyle(this.elRef.nativeElement, 'order', v);
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitGutterDirective.prototype, "direction", {
get: /**
* @return {?}
*/
function () {
return this._direction;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
this._direction = v;
this.refreshStyle();
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitGutterDirective.prototype, "useTransition", {
////
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
if (v) {
this.renderer.setStyle(this.elRef.nativeElement, 'transition', "flex-basis 0.3s");
}
else {
this.renderer.removeStyle(this.elRef.nativeElement, 'transition');
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitGutterDirective.prototype, "size", {
get: /**
* @return {?}
*/
function () {
return this._size;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
this._size = v;
this.refreshStyle();
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitGutterDirective.prototype, "color", {
get: /**
* @return {?}
*/
function () {
return this._color;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
this._color = v;
this.refreshStyle();
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitGutterDirective.prototype, "imageH", {
get: /**
* @return {?}
*/
function () {
return this._imageH;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
this._imageH = v;
this.refreshStyle();
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitGutterDirective.prototype, "imageV", {
get: /**
* @return {?}
*/
function () {
return this._imageV;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
this._imageV = v;
this.refreshStyle();
},
enumerable: true,
configurable: true
});
Object.defineProperty(SplitGutterDirective.prototype, "disabled", {
get: /**
* @return {?}
*/
function () {
return this._disabled;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
this._disabled = v;
this.refreshStyle();
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
SplitGutterDirective.prototype.refreshStyle = /**
* @return {?}
*/
function () {
this.renderer.setStyle(this.elRef.nativeElement, 'flex-basis', this.size + "px");
// fix safari bug about gutter height when direction is horizontal
this.renderer.setStyle(this.elRef.nativeElement, 'height', (this.direction === 'vertical') ? this.size + "px" : "100%");
this.renderer.setStyle(this.elRef.nativeElement, 'background-color', (this.color !== '') ? this.color : "#eeeeee");
var /** @type {?} */ state = (this.disabled === true) ? 'disabled' : this.direction;
this.renderer.setStyle(this.elRef.nativeElement, 'background-image', this.getImage(state));
this.renderer.setStyle(this.elRef.nativeElement, 'cursor', this.getCursor(state));
};
/**
* @param {?} state
* @return {?}
*/
SplitGutterDirective.prototype.getCursor = /**
* @param {?} state
* @return {?}
*/
function (state) {
switch (state) {
case 'horizontal':
return 'col-resize';
case 'vertical':
return 'row-resize';
case 'disabled':
return 'default';
}
};
/**
* @param {?} state
* @return {?}
*/
SplitGutterDirective.prototype.getImage = /**
* @param {?} state
* @return {?}
*/
function (state) {
switch (state) {
case 'horizontal':
return (this.imageH !== '') ? this.imageH : defaultImageH;
case 'vertical':
return (this.imageV !== '') ? this.imageV : defaultImageV;
case 'disabled':
return '';
}
};
SplitGutterDirective.decorators = [
{ type: Directive, args: [{
selector: 'split-gutter'
},] },
];
/** @nocollapse */
SplitGutterDirective.ctorParameters = function () { return [
{ type: ElementRef },
{ type: Renderer2 }
]; };
SplitGutterDirective.propDecorators = {
order: [{ type: Input }],
direction: [{ type: Input }],
useTransition: [{ type: Input }],
size: [{ type: Input }],
color: [{ type: Input }],
imageH: [{ type: Input }],
imageV: [{ type: Input }],
disabled: [{ type: Input }]
};
return SplitGutterDirective;
}());
var defaultImageH = 'url("")';
var defaultImageV = 'url("")';
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
var AngularSplitModule = /** @class */ (function () {
function AngularSplitModule() {
}
/**
* @return {?}
*/
AngularSplitModule.forRoot = /**
* @return {?}
*/
function () {
return {
ngModule: AngularSplitModule,
providers: []
};
};
/**
* @return {?}
*/
AngularSplitModule.forChild = /**
* @return {?}
*/
function () {
return {
ngModule: AngularSplitModule,
providers: []
};
};
AngularSplitModule.decorators = [
{ type: NgModule, args: [{
imports: [
CommonModule
],
declarations: [
SplitComponent,
SplitAreaDirective,
SplitGutterDirective,
],
exports: [
SplitComponent,
SplitAreaDirective,
]
},] },
];
return AngularSplitModule;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
/**
* Entry point for all public APIs of the package.
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
/**
* Generated bundle index. Do not edit.
*/
export { AngularSplitModule, SplitComponent, SplitAreaDirective, SplitGutterDirective as ɵa };
//# sourceMappingURL=angular-split-ng6.js.map