ngx-resizable-touch
Version:
A Resizable Split-Pane Layout for Angular6+
257 lines • 20.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, HostBinding, Input, ElementRef, ViewEncapsulation, Output, EventEmitter } from '@angular/core';
import { NgxResizeableWindowRef } from '../window.service';
var ɵ0 = window;
var ResizableComponent = /** @class */ (function () {
function ResizableComponent(regionElement, windowRef) {
this.regionElement = regionElement;
this.windowRef = windowRef;
this.resizable = true;
this.noTransition = false;
this.rFlex = false;
this.resizeStart = new EventEmitter();
this.resizing = new EventEmitter();
this.resizeEnd = new EventEmitter();
this.vx = 1;
this.vy = 1;
this.info = {};
this.nativeElement = this.regionElement.nativeElement;
}
/**
* @return {?}
*/
ResizableComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
if (!this.rFlex) {
this.resizable = false;
} // Added to permit use of component for all cells
this.flexBasis = 'flexBasis' in this.nativeElement.style ? 'flexBasis' :
'webkitFlexBasis' in this.nativeElement.style ? 'webkitFlexBasis' :
'msFlexPreferredSize' in this.nativeElement.style ? 'msFlexPreferredSize' : 'flexBasis';
};
/**
* @return {?}
*/
ResizableComponent.prototype.ngAfterViewInit = /**
* @return {?}
*/
function () {
this.style = this.windowRef.nativeWindow.getComputedStyle(this.nativeElement);
};
/**
* @private
* @param {?} p
* @return {?}
*/
ResizableComponent.prototype.updateInfo = /**
* @private
* @param {?} p
* @return {?}
*/
function (p) {
this.info['width'] = false;
this.info['height'] = false;
if (this.axis === 'x') {
this.info['width'] = parseInt(this.nativeElement.style[this.rFlex ? this.flexBasis : 'width'], 10);
}
else {
this.info['height'] = parseInt(this.nativeElement.style[this.rFlex ? this.flexBasis : 'height'], 10);
}
this.info['id'] = this.nativeElement.id;
this.info['point'] = p;
};
/**
* @param {?} p
* @param {?} direction
* @return {?}
*/
ResizableComponent.prototype.dragStart = /**
* @param {?} p
* @param {?} direction
* @return {?}
*/
function (p, direction) {
this.dragDir = direction;
this.axis = (this.dragDir === 'left' || this.dragDir === 'right') ? 'x' : 'y';
this.start = (this.axis === 'x' ? p.x : p.y);
this.w = parseInt(this.style.getPropertyValue('width'), 10);
this.h = parseInt(this.style.getPropertyValue('height'), 10);
this.resizeStart.emit({ info: this.info });
// prevent transition while dragging
this.noTransition = true;
};
/**
* @param {?} p
* @return {?}
*/
ResizableComponent.prototype.dragEnd = /**
* @param {?} p
* @return {?}
*/
function (p) {
this.updateInfo(p);
this.resizeEnd.emit({ info: this.info });
this.noTransition = false;
};
/**
* @param {?} p
* @return {?}
*/
ResizableComponent.prototype.dragging = /**
* @param {?} p
* @return {?}
*/
function (p) {
/** @type {?} */
var offset = (this.axis === 'x') ? this.start - p.x : this.start - p.y;
/** @type {?} */
var operand = 1;
switch (this.dragDir) {
case 'top':
operand = -1;
/* falls through */
case 'bottom':
/** @type {?} */
var height = (this.h - offset * this.vy * operand) + 'px';
if (this.rFlex) {
this.flexBasis = height;
}
else {
this.height = height;
}
break;
case 'left':
operand = -1;
/* falls through */
case 'right':
/** @type {?} */
var width = (this.w - offset * this.vx * operand) + 'px';
if (this.rFlex) {
this.flexBasis = width;
}
else {
this.width = width;
}
break;
}
this.updateInfo(p);
this.resizing.emit({ info: this.info });
};
ResizableComponent.decorators = [
{ type: Component, args: [{
selector: 'rsz-layout',
template: "<ng-content></ng-content>\n\n<div *ngFor='let direction of directions'\n [class]=\"'rg-' + direction\"\n rszDragHandle\n (DragStart)=\"dragStart($event, direction);\"\n (DragEnd)=\"dragEnd($event)\"\n (Drag)=\"dragging($event)\">\n <span></span>\n</div>",
providers: [{ provide: 'Window', useValue: ɵ0 }],
encapsulation: ViewEncapsulation.None,
styles: [".content{display:-webkit-box;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;flex-flow:column nowrap}.row{-webkit-box-flex:1;flex:1;display:-webkit-box;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;flex-flow:row nowrap}.row.resizable{-webkit-box-flex:0;flex:0 0 360px}.cell{box-sizing:border-box;background:#fff;border:4px solid #f0f0f0;-webkit-box-flex:1;flex:1;min-height:60px}.cell.resizable{-webkit-box-flex:0;flex:0 0 360px}.resizable{position:relative}.resizable.no-transition{-webkit-transition:none!important;transition:none!important}.rg-none{display:none}.rg-bottom,.rg-left,.rg-right,.rg-top{display:block;width:8px;height:8px;line-height:8px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background:0 0;position:absolute;z-index:1}.rg-bottom span,.rg-left span,.rg-right span,.rg-top span{position:absolute;box-sizing:border-box;display:block;border:1px solid #ccc}.rg-left span,.rg-right span{border-width:0 1px;top:50%;margin:-10px 0 0 2px;height:20px;width:4px}.rg-bottom span,.rg-top span{border-width:1px 0;left:50%;margin:2px 0 0 -10px;width:20px;height:4px}.rg-top{cursor:row-resize;width:100%;top:0;left:0;margin-top:-4px}.rg-right{cursor:col-resize;height:100%;right:0;top:0;margin-right:-8px}.rg-bottom{cursor:row-resize;width:100%;bottom:0;left:0;margin-bottom:-4px}.rg-left{cursor:col-resize;height:100%;left:0;top:0;margin-left:-8px}.content.cols{-webkit-box-orient:horizontal;-webkit-box-direction:normal;flex-flow:row nowrap}.content.cols .row{-webkit-box-orient:vertical;-webkit-box-direction:normal;flex-flow:column nowrap}.content.cols .cell{min-width:60px}.content.cols .rg-top{margin-top:-8px}.content.cols .rg-right{margin-right:-4px}.content.cols .rg-bottom{margin-bottom:-8px}.content.cols .rg-left{margin-left:-4px}"]
}] }
];
/** @nocollapse */
ResizableComponent.ctorParameters = function () { return [
{ type: ElementRef },
{ type: NgxResizeableWindowRef }
]; };
ResizableComponent.propDecorators = {
resizable: [{ type: HostBinding, args: ['class.resizable',] }],
noTransition: [{ type: HostBinding, args: ['class.no-transition',] }],
width: [{ type: HostBinding, args: ['style.width',] }],
height: [{ type: HostBinding, args: ['style.height',] }],
flexBasis: [{ type: HostBinding, args: ['style.flex-basis',] }],
directions: [{ type: Input }],
rFlex: [{ type: Input }],
resizeStart: [{ type: Output }],
resizing: [{ type: Output }],
resizeEnd: [{ type: Output }]
};
return ResizableComponent;
}());
export { ResizableComponent };
if (false) {
/** @type {?} */
ResizableComponent.prototype.resizable;
/** @type {?} */
ResizableComponent.prototype.noTransition;
/** @type {?} */
ResizableComponent.prototype.width;
/** @type {?} */
ResizableComponent.prototype.height;
/** @type {?} */
ResizableComponent.prototype.flexBasis;
/** @type {?} */
ResizableComponent.prototype.directions;
/** @type {?} */
ResizableComponent.prototype.rFlex;
/** @type {?} */
ResizableComponent.prototype.resizeStart;
/** @type {?} */
ResizableComponent.prototype.resizing;
/** @type {?} */
ResizableComponent.prototype.resizeEnd;
/**
* @type {?}
* @private
*/
ResizableComponent.prototype.nativeElement;
/**
* @type {?}
* @private
*/
ResizableComponent.prototype.style;
/**
* @type {?}
* @private
*/
ResizableComponent.prototype.w;
/**
* @type {?}
* @private
*/
ResizableComponent.prototype.h;
/**
* @type {?}
* @private
*/
ResizableComponent.prototype.vx;
/**
* @type {?}
* @private
*/
ResizableComponent.prototype.vy;
/**
* @type {?}
* @private
*/
ResizableComponent.prototype.start;
/**
* @type {?}
* @private
*/
ResizableComponent.prototype.dragDir;
/**
* @type {?}
* @private
*/
ResizableComponent.prototype.axis;
/**
* @type {?}
* @private
*/
ResizableComponent.prototype.info;
/**
* @type {?}
* @private
*/
ResizableComponent.prototype.regionElement;
/**
* @type {?}
* @private
*/
ResizableComponent.prototype.windowRef;
}
export { ɵ0 };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resizable.component.js","sourceRoot":"ng://ngx-resizable-touch/","sources":["lib/resizable/resizable.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, HostBinding, Input, ElementRef, ViewEncapsulation, Output, EventEmitter, AfterViewInit } from '@angular/core';\nimport { NgxResizeableWindowRef } from '../window.service';\nimport { Point } from './drag.directive';\n\n@Component({\n  selector: 'rsz-layout',\n  templateUrl: 'resizable.component.html',\n  styleUrls: ['resizable.component.scss'],\n  providers: [ { provide: 'Window', useValue: window } ],\n  encapsulation: ViewEncapsulation.None\n})\nexport class ResizableComponent implements OnInit, AfterViewInit {\n\n  @HostBinding('class.resizable') resizable = true;\n  @HostBinding('class.no-transition') noTransition = false;\n  @HostBinding('style.width') width;\n  @HostBinding('style.height') height;\n  @HostBinding('style.flex-basis') flexBasis;\n\n  @Input() directions;\n  @Input() rFlex = false;\n\n  @Output() resizeStart = new EventEmitter();\n  @Output() resizing = new EventEmitter();\n  @Output() resizeEnd = new EventEmitter();\n\n  private nativeElement;\n\n  private style;\n\n  private w;\n  private h;\n\n  private vx = 1;\n  private vy = 1;\n\n  private start;\n\n  private dragDir;\n\n  private axis;\n\n  private info = {};\n\n  constructor(private regionElement: ElementRef, private windowRef: NgxResizeableWindowRef) {\n    this.nativeElement = this.regionElement.nativeElement;\n  }\n\n  ngOnInit() {\n    if (!this.rFlex) { this.resizable = false; } // Added to permit use of component for all cells\n    this.flexBasis = 'flexBasis' in this.nativeElement.style ? 'flexBasis' :\n      'webkitFlexBasis' in this.nativeElement.style ? 'webkitFlexBasis' :\n      'msFlexPreferredSize' in this.nativeElement.style ? 'msFlexPreferredSize' : 'flexBasis';\n  }\n\n  ngAfterViewInit() {\n    this.style = this.windowRef.nativeWindow.getComputedStyle(this.nativeElement);\n  }\n\n  private updateInfo(p: Point) {\n    this.info['width'] = false; this.info['height'] = false;\n    if (this.axis === 'x') {\n      this.info['width'] = parseInt(this.nativeElement.style[this.rFlex ? this.flexBasis : 'width'], 10);\n    } else {\n      this.info['height'] = parseInt(this.nativeElement.style[this.rFlex ? this.flexBasis : 'height'], 10);\n    }\n    this.info['id'] = this.nativeElement.id;\n    this.info['point'] = p;\n  }\n\n  public dragStart(p: Point, direction) {\n    this.dragDir = direction;\n    this.axis = (this.dragDir === 'left' || this.dragDir === 'right') ? 'x' : 'y';\n    this.start = (this.axis === 'x' ? p.x : p.y);\n    this.w = parseInt(this.style.getPropertyValue('width'), 10);\n    this.h = parseInt(this.style.getPropertyValue('height'), 10);\n\n    this.resizeStart.emit({ info: this.info });\n\n    // prevent transition while dragging\n    this.noTransition = true;\n  }\n\n  public dragEnd(p: Point) {\n    this.updateInfo(p);\n    this.resizeEnd.emit({ info: this.info });\n    this.noTransition = false;\n  }\n\n  public dragging(p: Point) {\n    const offset = (this.axis === 'x') ? this.start - p.x : this.start - p.y;\n\n    let operand = 1;\n    switch (this.dragDir) {\n      case 'top':\n        operand = -1;\n        /* falls through */\n      case 'bottom':\n        const height = (this.h - offset * this.vy * operand) + 'px';\n        if (this.rFlex) {\n          this.flexBasis = height;\n        } else {\n          this.height = height;\n        }\n        break;\n      case 'left':\n        operand = -1;\n        /* falls through */\n      case 'right':\n        const width = (this.w - offset * this.vx * operand) + 'px';\n        if (this.rFlex) {\n          this.flexBasis = width;\n        } else {\n          this.width = width;\n        }\n        break;\n    }\n    this.updateInfo(p);\n    this.resizing.emit({ info: this.info });\n  }\n}\n"]}