UNPKG

angular-split-ng6

Version:

Copy of angular-split but with aszechlicki fix, and some other errors patched for angular 6.

1,178 lines (1,168 loc) 37.1 kB
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) | * */ class SplitComponent { /** * @param {?} ngZone * @param {?} elRef * @param {?} cdRef * @param {?} renderer */ constructor(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, }; } /** * @param {?} v * @return {?} */ set direction(v) { v = (v === 'vertical') ? 'vertical' : 'horizontal'; this._direction = v; [...this.displayedAreas, ...this.hidedAreas].forEach(area => { area.comp.setStyleVisibleAndDir(area.comp.visible, this.isDragging, this.direction); }); this.build(false, false); } /** * @return {?} */ get direction() { return this._direction; } /** * @param {?} v * @return {?} */ set useTransition(v) { v = (typeof (v) === 'boolean') ? v : (v === 'false' ? false : true); this._useTransition = v; } /** * @return {?} */ get useTransition() { return this._useTransition; } /** * @param {?} v * @return {?} */ set disabled(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(); } /** * @return {?} */ get disabled() { return this._disabled; } /** * @param {?} v * @return {?} */ set width(v) { v = Number(v); this._width = (!isNaN(v) && v > 0) ? v : null; this.build(false, false); } /** * @return {?} */ get width() { return this._width; } /** * @param {?} v * @return {?} */ set height(v) { v = Number(v); this._height = (!isNaN(v) && v > 0) ? v : null; this.build(false, false); } /** * @return {?} */ get height() { return this._height; } /** * @param {?} v * @return {?} */ set gutterSize(v) { v = Number(v); this._gutterSize = (!isNaN(v) && v > 0) ? v : 11; this.build(false, false); } /** * @return {?} */ get gutterSize() { return this._gutterSize; } /** * @param {?} v * @return {?} */ set gutterColor(v) { this._gutterColor = (typeof v === 'string' && v !== '') ? v : ''; // Force repaint if modified from TS class (instead of the template) this.cdRef.markForCheck(); } /** * @return {?} */ get gutterColor() { return this._gutterColor; } /** * @param {?} v * @return {?} */ set gutterImageH(v) { this._gutterImageH = (typeof v === 'string' && v !== '') ? v : ''; // Force repaint if modified from TS class (instead of the template) this.cdRef.markForCheck(); } /** * @return {?} */ get gutterImageH() { return this._gutterImageH; } /** * @param {?} v * @return {?} */ set gutterImageV(v) { this._gutterImageV = (typeof v === 'string' && v !== '') ? v : ''; // Force repaint if modified from TS class (instead of the template) this.cdRef.markForCheck(); } /** * @return {?} */ get gutterImageV() { return this._gutterImageV; } /** * @param {?} v * @return {?} */ set dir(v) { v = (v === 'rtl') ? 'rtl' : 'ltr'; this._dir = v; } /** * @return {?} */ get dir() { return this._dir; } /** * @return {?} */ get cssFlexdirection() { return (this.direction === 'horizontal') ? 'row' : 'column'; } /** * @return {?} */ get cssWidth() { return this.width ? `${this.width}px` : '100%'; } /** * @return {?} */ get cssHeight() { return this.height ? `${this.height}px` : '100%'; } /** * @return {?} */ get cssMinwidth() { return (this.direction === 'horizontal') ? `${this.getNbGutters() * this.gutterSize}px` : null; } /** * @return {?} */ get cssMinheight() { return (this.direction === 'vertical') ? `${this.getNbGutters() * this.gutterSize}px` : null; } /** * @return {?} */ ngAfterViewInit() { this.isViewInitialized = true; } /** * @param {?} startEvent * @param {?} gutterOrder * @param {?} gutterNum * @return {?} */ startDragging(startEvent, gutterOrder, gutterNum) { startEvent.preventDefault(); // Place code here to allow '(gutterClick)' event even if '[disabled]="true"'. this.currentGutterNum = gutterNum; this.draggingWithoutMove = true; this.ngZone.runOutsideAngular(() => { this.dragListeners.push(this.renderer.listen('document', 'mouseup', (e) => this.stopDragging())); this.dragListeners.push(this.renderer.listen('document', 'touchend', (e) => this.stopDragging())); this.dragListeners.push(this.renderer.listen('document', 'touchcancel', (e) => this.stopDragging())); }); if (this.disabled) { return; } const /** @type {?} */ areaA = this.displayedAreas.find(a => a.order === gutterOrder - 1); const /** @type {?} */ areaB = this.displayedAreas.find(a => a.order === gutterOrder + 1); if (!areaA || !areaB) { return; } const /** @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; let /** @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(() => { this.dragListeners.push(this.renderer.listen('document', 'mousemove', (e) => this.dragEvent(e, start, areaA, areaB))); this.dragListeners.push(this.renderer.listen('document', 'touchmove', (e) => this.dragEvent(e, start, areaA, areaB))); }); areaA.comp.lockEvents(); areaB.comp.lockEvents(); this.isDragging = true; this.notify('start'); } /** * @param {?} type * @return {?} */ notify(type) { const /** @type {?} */ areasSize = this.displayedAreas.map(a => 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 {?} */ ngOnDestroy() { this.stopDragging(); } /** * @param {?} comp * @return {?} */ addArea(comp) { const /** @type {?} */ newArea = { 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 {?} */ removeArea(comp) { if (this.displayedAreas.some(a => a.comp === comp)) { const /** @type {?} */ area = /** @type {?} */ (this.displayedAreas.find(a => a.comp === comp)); this.displayedAreas.splice(this.displayedAreas.indexOf(area), 1); this.build(true, true); } else if (this.hidedAreas.some(a => a.comp === comp)) { const /** @type {?} */ area = /** @type {?} */ (this.hidedAreas.find(a => a.comp === comp)); this.hidedAreas.splice(this.hidedAreas.indexOf(area), 1); } } /** * @param {?} comp * @param {?} resetOrders * @param {?} resetSizes * @return {?} */ updateArea(comp, resetOrders, resetSizes) { // Only refresh if area is displayed (No need to check inside 'hidedAreas') const /** @type {?} */ item = this.displayedAreas.find(a => a.comp === comp); if (item) { this.build(resetOrders, resetSizes); } } /** * @param {?} comp * @return {?} */ showArea(comp) { const /** @type {?} */ area = this.hidedAreas.find(a => a.comp === comp); if (area) { comp.setStyleVisibleAndDir(comp.visible, this.isDragging, this.direction); const /** @type {?} */ areas = this.hidedAreas.splice(this.hidedAreas.indexOf(area), 1); this.displayedAreas.push(...areas); this.build(true, true); } } /** * @param {?} comp * @return {?} */ hideArea(comp) { const /** @type {?} */ area = this.displayedAreas.find(a => a.comp === comp); if (area) { comp.setStyleVisibleAndDir(comp.visible, this.isDragging, this.direction); const /** @type {?} */ areas = this.displayedAreas.splice(this.displayedAreas.indexOf(area), 1); areas.forEach(area => { area.order = 0; area.size = 0; }); this.hidedAreas.push(...areas); this.build(true, true); } } /** * @return {?} */ getNbGutters() { return this.displayedAreas.length - 1; } /** * @param {?} resetOrders * @param {?} resetSizes * @return {?} */ build(resetOrders, resetSizes) { this.stopDragging(); // ¤ AREAS ORDER if (resetOrders === true) { // If user provided 'order' for each area, use it to sort them. if (this.displayedAreas.every(a => a.comp.order !== null)) { this.displayedAreas.sort((a, b) => (/** @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((area, i) => { area.order = i * 2; area.comp.setStyleOrder(area.order); }); } // ¤ AREAS SIZE PERCENT if (resetSizes === true) { const /** @type {?} */ totalUserSize = /** @type {?} */ (this.displayedAreas.reduce((total, s) => 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(a => a.comp.size !== null) && totalUserSize > .999 && totalUserSize < 1.001) { this.displayedAreas.forEach(area => { area.size = /** @type {?} */ (area.comp.size); }); } else { const /** @type {?} */ size = 1 / this.displayedAreas.length; this.displayedAreas.forEach(area => { area.size = size; }); } } // ¤ // If some real area sizes are less than gutterSize, // set them to zero and dispatch size to others. let /** @type {?} */ percentToDispatch = 0; // Get container pixel size let /** @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(area => { if (area.size * containerSizePixel < this.gutterSize) { percentToDispatch += area.size; area.size = 0; } }); if (percentToDispatch > 0 && this.displayedAreas.length > 0) { const /** @type {?} */ nbAreasNotZero = this.displayedAreas.filter(a => a.size !== 0).length; if (nbAreasNotZero > 0) { const /** @type {?} */ percentToAdd = percentToDispatch / nbAreasNotZero; this.displayedAreas.filter(a => a.size !== 0).forEach(area => { area.size += percentToAdd; }); } else { this.displayedAreas[this.displayedAreas.length - 1].size = 1; } } this.refreshStyleSizes(); this.cdRef.markForCheck(); } /** * @return {?} */ refreshStyleSizes() { const /** @type {?} */ sumGutterSize = this.getNbGutters() * this.gutterSize; this.displayedAreas.forEach(area => { area.comp.setStyleFlexbasis(`calc( ${area.size * 100}% - ${area.size * sumGutterSize}px )`, this.isDragging); }); } /** * @param {?} event * @param {?} start * @param {?} areaA * @param {?} areaB * @return {?} */ dragEvent(event, start, areaA, areaB) { if (!this.isDragging) { return; } let /** @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 {?} */ drag(start, end, areaA, areaB) { // ¤ AREAS SIZE PIXEL const /** @type {?} */ devicePixelRatio = window.devicePixelRatio || 1; let /** @type {?} */ offsetPixel = (this.direction === 'horizontal') ? (start.x - end.x) : (start.y - end.y); offsetPixel = offsetPixel / devicePixelRatio; if (this.dir === 'rtl') { offsetPixel = -offsetPixel; } let /** @type {?} */ newSizePixelA = this.dragStartValues.sizePixelA - offsetPixel; let /** @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 {?} */ stopDragging() { if (this.isDragging === false && this.draggingWithoutMove === false) { return; } this.displayedAreas.forEach(area => { area.comp.unlockEvents(); }); while (this.dragListeners.length > 0) { const /** @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: [` :host { display: flex; flex-wrap: nowrap; justify-content: flex-start; align-items: stretch; overflow: hidden; /* Important to keep following rules even if overrided later by 'HostBinding' because if [width] & [height] not provided, when build() is executed, 'HostBinding' hasn't been applied yet so code: this.elRef.nativeElement["offsetHeight"] gives wrong value! */ width: 100%; height: 100%; } split-gutter { flex-grow: 0; flex-shrink: 0; background-position: center center; background-repeat: no-repeat; } `], template: ` <ng-content></ng-content> <ng-template ngFor let-area [ngForOf]="displayedAreas" let-index="index" let-last="last"> <split-gutter *ngIf="last === false" [order]="index*2+1" [direction]="direction" [useTransition]="useTransition" [size]="gutterSize" [color]="gutterColor" [imageH]="gutterImageH" [imageV]="gutterImageV" [disabled]="disabled" (mousedown)="startDragging($event, index*2+1, index+1)" (touchstart)="startDragging($event, index*2+1, index+1)"></split-gutter> </ng-template>`, },] }, ]; /** @nocollapse */ SplitComponent.ctorParameters = () => [ { 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',] }] }; /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ 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 = 0; this._visible = true; this.transitionListener = null; this.lockListeners = []; } /** * @param {?} v * @return {?} */ set order(v) { v = Number(v); this._order = !isNaN(v) ? v : null; this.split.updateArea(this, true, false); } /** * @return {?} */ get order() { return this._order; } /** * @param {?} v * @return {?} */ set size(v) { v = Number(v); this._size = (!isNaN(v) && v >= 0 && v <= 100) ? (v / 100) : null; this.split.updateArea(this, false, true); } /** * @return {?} */ get size() { return this._size; } /** * @param {?} v * @return {?} */ set minSize(v) { v = Number(v); this._minSize = (!isNaN(v) && v > 0 && v < 100) ? v / 100 : 0; this.split.updateArea(this, false, true); } /** * @return {?} */ get minSize() { return this._minSize; } /** * @param {?} v * @return {?} */ set visible(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); } } /** * @return {?} */ get visible() { return this._visible; } /** * @return {?} */ ngOnInit() { 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(() => { this.transitionListener = this.renderer.listen(this.elRef.nativeElement, 'transitionend', (e) => this.onTransitionEnd(e)); }); } /** * @param {?} prop * @return {?} */ getSizePixel(prop) { return this.elRef.nativeElement[prop]; } /** * @param {?} isVisible * @param {?} isDragging * @param {?} direction * @return {?} */ setStyleVisibleAndDir(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 {?} */ setStyleOrder(value) { this.renderer.setStyle(this.elRef.nativeElement, 'order', value); } /** * @param {?} value * @param {?} isDragging * @return {?} */ setStyleFlexbasis(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 {?} */ setStyleTransition(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 {?} */ onTransitionEnd(event) { // Limit only flex-basis transition to trigger the event if (event.propertyName === 'flex-basis') { this.split.notify('transitionEnd'); } } /** * @return {?} */ lockEvents() { this.ngZone.runOutsideAngular(() => { this.lockListeners.push(this.renderer.listen(this.elRef.nativeElement, 'selectstart', (e) => false)); this.lockListeners.push(this.renderer.listen(this.elRef.nativeElement, 'dragstart', (e) => false)); }); } /** * @return {?} */ unlockEvents() { while (this.lockListeners.length > 0) { const /** @type {?} */ 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: 'split-area' },] }, ]; /** @nocollapse */ SplitAreaDirective.ctorParameters = () => [ { type: NgZone }, { type: ElementRef }, { type: Renderer2 }, { type: SplitComponent } ]; SplitAreaDirective.propDecorators = { order: [{ type: Input }], size: [{ type: Input }], minSize: [{ type: Input }], visible: [{ type: Input }] }; /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ class SplitGutterDirective { /** * @param {?} elRef * @param {?} renderer */ constructor(elRef, renderer) { this.elRef = elRef; this.renderer = renderer; this._direction = 'vertical'; this._size = 0; this._color = ''; this._imageH = ''; this._imageV = ''; this._disabled = false; } /** * @param {?} v * @return {?} */ set order(v) { this.renderer.setStyle(this.elRef.nativeElement, 'order', v); } /** * @param {?} v * @return {?} */ set direction(v) { this._direction = v; this.refreshStyle(); } /** * @return {?} */ get direction() { return this._direction; } /** * @param {?} v * @return {?} */ set useTransition(v) { if (v) { this.renderer.setStyle(this.elRef.nativeElement, 'transition', `flex-basis 0.3s`); } else { this.renderer.removeStyle(this.elRef.nativeElement, 'transition'); } } /** * @param {?} v * @return {?} */ set size(v) { this._size = v; this.refreshStyle(); } /** * @return {?} */ get size() { return this._size; } /** * @param {?} v * @return {?} */ set color(v) { this._color = v; this.refreshStyle(); } /** * @return {?} */ get color() { return this._color; } /** * @param {?} v * @return {?} */ set imageH(v) { this._imageH = v; this.refreshStyle(); } /** * @return {?} */ get imageH() { return this._imageH; } /** * @param {?} v * @return {?} */ set imageV(v) { this._imageV = v; this.refreshStyle(); } /** * @return {?} */ get imageV() { return this._imageV; } /** * @param {?} v * @return {?} */ set disabled(v) { this._disabled = v; this.refreshStyle(); } /** * @return {?} */ get disabled() { return this._disabled; } /** * @return {?} */ refreshStyle() { 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`); const /** @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 {?} */ getCursor(state) { switch (state) { case 'horizontal': return 'col-resize'; case 'vertical': return 'row-resize'; case 'disabled': return 'default'; } } /** * @param {?} state * @return {?} */ getImage(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 = () => [ { 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 }] }; const defaultImageH = 'url("")'; const defaultImageV = 'url("")'; /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ class AngularSplitModule { /** * @return {?} */ static forRoot() { return { ngModule: AngularSplitModule, providers: [] }; } /** * @return {?} */ static forChild() { return { ngModule: AngularSplitModule, providers: [] }; } } AngularSplitModule.decorators = [ { type: NgModule, args: [{ imports: [ CommonModule ], declarations: [ SplitComponent, SplitAreaDirective, SplitGutterDirective, ], exports: [ SplitComponent, SplitAreaDirective, ] },] }, ]; /** * @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