UNPKG

angular-resize-element

Version:

An angular 4.0+ directive that allows an element to be resized

204 lines 29.3 kB
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"]}