angular-resize-element
Version:
An angular 4.0+ directive that allows an element to be resized
204 lines • 29.3 kB
JavaScript
import { Directive, ElementRef, EventEmitter, HostBinding, Input, Output, Renderer2 } from '@angular/core';
import { AngularResizeElementDirection } from './angular-resize-element.enum';
export class AngularResizeElementDirective {
constructor(elementRef, renderer2) {
this.elementRef = elementRef;
this.renderer2 = renderer2;
this.applyClass = 'resizing';
this.resizeStart = new EventEmitter();
this.resize = new EventEmitter();
this.resizeEnd = new EventEmitter();
this.listenMouseDownEvent();
}
ngOnChanges(changes) {
if (changes.useDrag) {
this.listenMouseDownEvent();
}
}
ngOnDestroy() {
if (this.mouseClickListener) {
this.mouseClickListener();
}
if (this.mouseUpListener) {
this.mouseUpListener();
}
if (this.mouseMoveListener) {
this.mouseMoveListener();
}
}
listenMouseDownEvent() {
if (this.mouseClickListener) {
this.mouseClickListener();
}
const event = this.useDrag ? 'dragstart' : 'mousedown';
this.mouseClickListener = this.renderer2.listen(this.elementRef.nativeElement, event, evt => this.onMouseDown(evt));
}
onMouseDown(evt) {
evt.preventDefault();
this.setOriginalData(evt);
this.resizeStart.emit(this.generateValuesForEvent(evt));
this.mouseUpListener = this.renderer2.listen('document', 'mouseup', event => this.onMouseUp(event));
this.mouseMoveListener = this.renderer2.listen('document', 'mousemove', event => this.onMouseMove(event));
this.renderer2.addClass(this.targetNativeElement, this.applyClass);
}
onMouseUp(evt) {
const eventValues = this.generateValuesForEvent(evt);
this.resize.emit(eventValues);
this.mouseMoveListener();
this.mouseUpListener();
this.renderer2.removeClass(this.targetNativeElement, this.applyClass);
this.resizeEnd.emit(eventValues);
}
onMouseMove(evt) {
this.resize.emit(this.generateValuesForEvent(evt));
}
setOriginalData(originalEvent) {
this.originalEvent = originalEvent;
if (this.targetElement) {
const dataSource = this.targetNativeElement;
this.targetElementWidthValue = dataSource.offsetWidth;
this.targetElementHeightValue = dataSource.offsetHeight;
this.targetElementTopValue = dataSource.offsetTop;
this.targetElementLeftValue = dataSource.offsetLeft;
}
else {
this.targetElementWidthValue = 0;
this.targetElementHeightValue = 0;
this.targetElementTopValue = 0;
this.targetElementLeftValue = 0;
}
}
get targetNativeElement() {
return this.targetElement instanceof ElementRef ? this.targetElement.nativeElement : this.targetElement;
}
generateValuesForEvent(evt) {
const originalXValue = this.originalEvent.clientX;
const originalYValue = this.originalEvent.clientY;
let diffWidthValue = evt.clientX - originalXValue;
let diffHeightValue = evt.clientY - originalYValue;
let diffTopValue = diffHeightValue;
let diffLeftValue = diffWidthValue;
switch (this.direction) {
case AngularResizeElementDirection.TOP: {
diffHeightValue *= -1;
diffWidthValue = 0;
diffLeftValue = 0;
break;
}
case AngularResizeElementDirection.TOP_RIGHT: {
diffHeightValue *= -1;
diffLeftValue = 0;
break;
}
case AngularResizeElementDirection.RIGHT: {
diffHeightValue = 0;
diffTopValue = 0;
diffLeftValue = 0;
break;
}
case AngularResizeElementDirection.BOTTOM_RIGHT: {
diffTopValue = 0;
diffLeftValue = 0;
break;
}
case AngularResizeElementDirection.BOTTOM: {
diffWidthValue = 0;
diffLeftValue = 0;
diffTopValue = 0;
break;
}
case AngularResizeElementDirection.BOTTOM_LEFT: {
diffWidthValue *= -1;
diffTopValue = 0;
break;
}
case AngularResizeElementDirection.LEFT: {
diffWidthValue *= -1;
diffHeightValue = 0;
diffTopValue = 0;
break;
}
case AngularResizeElementDirection.TOP_LEFT: {
diffHeightValue *= -1;
diffWidthValue *= -1;
}
}
let currentWidthValue = this.targetElementWidthValue + diffWidthValue;
let currentHeightValue = this.targetElementHeightValue + diffHeightValue;
if (this.proportionalResize) {
if (currentWidthValue > currentHeightValue) {
currentWidthValue = currentHeightValue;
}
else {
currentHeightValue = currentWidthValue;
}
}
if (currentHeightValue <= 1) {
diffTopValue += currentHeightValue;
}
if (currentWidthValue <= 1) {
diffLeftValue += currentWidthValue;
}
if (currentWidthValue <= 0) {
currentWidthValue = 0;
}
if (currentHeightValue <= 0) {
currentHeightValue = 0;
}
let currentTopValue = this.targetElementTopValue + diffTopValue;
let currentLeftValue = this.targetElementLeftValue + diffLeftValue;
if (this.rect) {
if (currentTopValue < this.rect.top) {
currentHeightValue = this.targetElementHeightValue + this.targetElementTopValue - this.rect.top;
currentTopValue = this.rect.top;
}
if (currentHeightValue + currentTopValue > this.rect.height) {
currentHeightValue = this.rect.height - currentTopValue;
}
if (currentLeftValue < this.rect.left) {
currentWidthValue = this.targetElementWidthValue + this.targetElementLeftValue - this.rect.left;
currentLeftValue = this.rect.left;
}
if (currentWidthValue + currentLeftValue > this.rect.width) {
currentWidthValue = this.rect.width - currentLeftValue;
}
}
return {
originalEvent: this.originalEvent,
currentWidthValue,
currentHeightValue,
currentTopValue,
currentLeftValue,
originalWidthValue: this.targetElementWidthValue,
originalHeightValue: this.targetElementHeightValue,
originalTopValue: this.targetElementTopValue,
originalLeftValue: this.targetElementLeftValue,
differenceWidthValue: currentWidthValue - this.targetElementWidthValue,
differenceHeightValue: currentHeightValue - this.targetElementHeightValue,
differenceTopValue: currentTopValue - this.targetElementTopValue,
differenceLeftValue: currentLeftValue - this.targetElementLeftValue,
direction: this.direction,
};
}
}
AngularResizeElementDirective.decorators = [
{ type: Directive, args: [{
selector: '[resize], [resizeStart], [resizeEnd]'
},] }
];
AngularResizeElementDirective.ctorParameters = () => [
{ type: ElementRef },
{ type: Renderer2 }
];
AngularResizeElementDirective.propDecorators = {
targetElement: [{ type: Input }],
direction: [{ type: Input }],
proportionalResize: [{ type: Input }],
rect: [{ type: Input }],
applyClass: [{ type: Input }],
resizeStart: [{ type: Output }],
resize: [{ type: Output }],
resizeEnd: [{ type: Output }],
useDrag: [{ type: Input }, { type: HostBinding, args: ['attr.draggable',] }]
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-resize-element.directive.js","sourceRoot":"D:/angular-libs/projects/angular-resize-element/src/","sources":["lib/angular-resize-element.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Directive,\r\n    ElementRef,\r\n    EventEmitter,\r\n    HostBinding,\r\n    Input,\r\n    OnChanges,\r\n    OnDestroy,\r\n    Output,\r\n    Renderer2,\r\n    SimpleChanges\r\n} from '@angular/core';\r\nimport {AngularResizeElementEvent, Position} from './angular-resize-element-event.interface';\r\nimport {AngularResizeElementDirection} from './angular-resize-element.enum';\r\n\r\n@Directive({\r\n    selector: '[resize], [resizeStart], [resizeEnd]'\r\n})\r\nexport class AngularResizeElementDirective implements OnChanges, OnDestroy {\r\n    private mouseClickListener: () => void;\r\n    private mouseUpListener: () => void;\r\n    private mouseMoveListener: () => void;\r\n\r\n    private targetElementWidthValue: number;\r\n    private targetElementHeightValue: number;\r\n\r\n    private targetElementTopValue: number;\r\n    private targetElementLeftValue: number;\r\n\r\n    private originalEvent: MouseEvent;\r\n\r\n    @Input()\r\n    public targetElement: HTMLElement | ElementRef;\r\n\r\n    @Input()\r\n    public direction: AngularResizeElementDirection;\r\n\r\n    @Input()\r\n    public proportionalResize: boolean;\r\n\r\n    @Input()\r\n    public rect: Position;\r\n\r\n    @Input()\r\n    public applyClass = 'resizing';\r\n\r\n    @Output()\r\n    public readonly resizeStart: EventEmitter<AngularResizeElementEvent> = new EventEmitter();\r\n\r\n    @Output()\r\n    public readonly resize: EventEmitter<AngularResizeElementEvent> = new EventEmitter();\r\n\r\n    @Output()\r\n    public readonly resizeEnd: EventEmitter<AngularResizeElementEvent> = new EventEmitter();\r\n\r\n    @Input()\r\n    @HostBinding('attr.draggable')\r\n    public useDrag;\r\n\r\n    constructor(private readonly elementRef: ElementRef,\r\n                private readonly renderer2: Renderer2\r\n    ) {\r\n        this.listenMouseDownEvent();\r\n    }\r\n\r\n    public ngOnChanges(changes: SimpleChanges) {\r\n        if (changes.useDrag) {\r\n            this.listenMouseDownEvent();\r\n        }\r\n    }\r\n\r\n    public ngOnDestroy() {\r\n        if (this.mouseClickListener) {\r\n            this.mouseClickListener();\r\n        }\r\n        if (this.mouseUpListener) {\r\n            this.mouseUpListener();\r\n        }\r\n        if (this.mouseMoveListener) {\r\n            this.mouseMoveListener();\r\n        }\r\n    }\r\n\r\n    public listenMouseDownEvent(): void {\r\n        if (this.mouseClickListener) {\r\n            this.mouseClickListener();\r\n        }\r\n\r\n        const event = this.useDrag ? 'dragstart' : 'mousedown';\r\n        this.mouseClickListener = this.renderer2.listen(this.elementRef.nativeElement, event, evt => this.onMouseDown(evt));\r\n    }\r\n\r\n    public onMouseDown(evt: MouseEvent): void {\r\n        evt.preventDefault();\r\n\r\n        this.setOriginalData(evt);\r\n\r\n        this.resizeStart.emit(this.generateValuesForEvent(evt));\r\n\r\n        this.mouseUpListener = this.renderer2.listen('document', 'mouseup', event => this.onMouseUp(event));\r\n        this.mouseMoveListener = this.renderer2.listen('document', 'mousemove', event => this.onMouseMove(event));\r\n        this.renderer2.addClass(this.targetNativeElement, this.applyClass);\r\n    }\r\n\r\n\r\n    private onMouseUp(evt: MouseEvent): void {\r\n        const eventValues = this.generateValuesForEvent(evt);\r\n        this.resize.emit(eventValues);\r\n        this.mouseMoveListener();\r\n        this.mouseUpListener();\r\n\r\n        this.renderer2.removeClass(this.targetNativeElement, this.applyClass);\r\n        this.resizeEnd.emit(eventValues);\r\n    }\r\n\r\n\r\n    private onMouseMove(evt: MouseEvent): void {\r\n        this.resize.emit(this.generateValuesForEvent(evt));\r\n    }\r\n\r\n\r\n    private setOriginalData(originalEvent: MouseEvent) {\r\n        this.originalEvent = originalEvent;\r\n\r\n        if (this.targetElement) {\r\n            const dataSource = this.targetNativeElement;\r\n            this.targetElementWidthValue = dataSource.offsetWidth;\r\n            this.targetElementHeightValue = dataSource.offsetHeight;\r\n            this.targetElementTopValue = dataSource.offsetTop;\r\n            this.targetElementLeftValue = dataSource.offsetLeft;\r\n        } else {\r\n            this.targetElementWidthValue = 0;\r\n            this.targetElementHeightValue = 0;\r\n            this.targetElementTopValue = 0;\r\n            this.targetElementLeftValue = 0;\r\n        }\r\n    }\r\n\r\n    private get targetNativeElement(): HTMLElement {\r\n        return this.targetElement instanceof ElementRef ? this.targetElement.nativeElement : this.targetElement;\r\n    }\r\n\r\n    private generateValuesForEvent(evt: MouseEvent): AngularResizeElementEvent {\r\n        const originalXValue = this.originalEvent.clientX;\r\n        const originalYValue = this.originalEvent.clientY;\r\n\r\n        let diffWidthValue = evt.clientX - originalXValue;\r\n        let diffHeightValue = evt.clientY - originalYValue;\r\n        let diffTopValue = diffHeightValue;\r\n        let diffLeftValue = diffWidthValue;\r\n\r\n        switch (this.direction) {\r\n            case AngularResizeElementDirection.TOP: {\r\n                diffHeightValue *= -1;\r\n                diffWidthValue = 0;\r\n                diffLeftValue = 0;\r\n                break;\r\n            }\r\n            case AngularResizeElementDirection.TOP_RIGHT: {\r\n                diffHeightValue *= -1;\r\n                diffLeftValue = 0;\r\n                break;\r\n            }\r\n            case AngularResizeElementDirection.RIGHT: {\r\n                diffHeightValue = 0;\r\n                diffTopValue = 0;\r\n                diffLeftValue = 0;\r\n                break;\r\n            }\r\n            case AngularResizeElementDirection.BOTTOM_RIGHT: {\r\n                diffTopValue = 0;\r\n                diffLeftValue = 0;\r\n                break;\r\n            }\r\n            case AngularResizeElementDirection.BOTTOM: {\r\n                diffWidthValue = 0;\r\n                diffLeftValue = 0;\r\n                diffTopValue = 0;\r\n                break;\r\n            }\r\n            case AngularResizeElementDirection.BOTTOM_LEFT: {\r\n                diffWidthValue *= -1;\r\n                diffTopValue = 0;\r\n                break;\r\n            }\r\n            case AngularResizeElementDirection.LEFT: {\r\n                diffWidthValue *= -1;\r\n                diffHeightValue = 0;\r\n                diffTopValue = 0;\r\n                break;\r\n            }\r\n            case AngularResizeElementDirection.TOP_LEFT: {\r\n                diffHeightValue *= -1;\r\n                diffWidthValue *= -1;\r\n            }\r\n        }\r\n\r\n        let currentWidthValue = this.targetElementWidthValue + diffWidthValue;\r\n        let currentHeightValue = this.targetElementHeightValue + diffHeightValue;\r\n\r\n        if (this.proportionalResize) {\r\n            if (currentWidthValue > currentHeightValue) {\r\n                currentWidthValue = currentHeightValue;\r\n            } else {\r\n                currentHeightValue = currentWidthValue;\r\n            }\r\n        }\r\n\r\n        if (currentHeightValue <= 1) {\r\n            diffTopValue += currentHeightValue;\r\n        }\r\n\r\n        if (currentWidthValue <= 1) {\r\n            diffLeftValue += currentWidthValue;\r\n        }\r\n\r\n        if (currentWidthValue <= 0) {\r\n            currentWidthValue = 0;\r\n        }\r\n\r\n        if (currentHeightValue <= 0) {\r\n            currentHeightValue = 0;\r\n        }\r\n\r\n        let currentTopValue = this.targetElementTopValue + diffTopValue;\r\n        let currentLeftValue = this.targetElementLeftValue + diffLeftValue;\r\n\r\n        if (this.rect) {\r\n            if (currentTopValue < this.rect.top) {\r\n                currentHeightValue = this.targetElementHeightValue + this.targetElementTopValue - this.rect.top;\r\n                currentTopValue = this.rect.top;\r\n            }\r\n            if (currentHeightValue + currentTopValue > this.rect.height) {\r\n                currentHeightValue = this.rect.height - currentTopValue;\r\n            }\r\n\r\n            if (currentLeftValue < this.rect.left) {\r\n                currentWidthValue = this.targetElementWidthValue + this.targetElementLeftValue - this.rect.left;\r\n                currentLeftValue = this.rect.left;\r\n            }\r\n            if (currentWidthValue + currentLeftValue > this.rect.width) {\r\n                currentWidthValue = this.rect.width - currentLeftValue;\r\n            }\r\n        }\r\n\r\n        return {\r\n            originalEvent: this.originalEvent,\r\n            currentWidthValue,\r\n            currentHeightValue,\r\n            currentTopValue,\r\n            currentLeftValue,\r\n            originalWidthValue: this.targetElementWidthValue,\r\n            originalHeightValue: this.targetElementHeightValue,\r\n            originalTopValue: this.targetElementTopValue,\r\n            originalLeftValue: this.targetElementLeftValue,\r\n            differenceWidthValue: currentWidthValue - this.targetElementWidthValue,\r\n            differenceHeightValue: currentHeightValue - this.targetElementHeightValue,\r\n            differenceTopValue: currentTopValue - this.targetElementTopValue,\r\n            differenceLeftValue: currentLeftValue - this.targetElementLeftValue,\r\n            direction: this.direction,\r\n        };\r\n    }\r\n}\r\n\r\n"]}