blob: c9894f84dc842301d1252327bfa8cbec6d846113 [file] [log] [blame]
/**
* @fileoverview added by tsickle
* Generated from: resizable-draggable-dialog/resizable-draggable-dialog.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { merge, fromEvent } from 'rxjs';
/** @enum {string} */
const corners = {
topRight: "topRight",
bottomRight: "bottomRight",
bottomLeft: "bottomLeft",
topLeft: "topLeft",
};
/** @enum {string} */
const cursors = {
nesw: "nesw-resize",
nwse: "nwse-resize",
};
/** @enum {string} */
const verticalAlignment = {
top: "top",
bottom: "bottom",
};
/** @enum {string} */
const horizontalAlignment = {
right: "right",
left: "left",
};
/** @type {?} */
const cornerWidth = '16px';
/** @type {?} */
const offset = '0px';
/** @type {?} */
const minWidth = 200;
/** @type {?} */
const minHeight = 200;
/**
* @param {?} sizeString
* @return {?}
*/
function getPixels(sizeString) {
return parseFloat((sizeString || '').replace('px', ''));
}
/**
* @param {?} min
* @param {?} num
* @param {?} max
* @return {?}
*/
function clamp(min, num, max) {
return Math.min(Math.max(num, min), max);
}
export class ResizableDraggableDialog {
/**
* @param {?} _document
* @param {?} _renderer2
* @param {?} _dialogRef
* @param {?} _dragRef
*/
constructor(_document, _renderer2, _dialogRef, _dragRef) {
this._document = _document;
this._renderer2 = _renderer2;
this._dialogRef = _dialogRef;
this._dragRef = _dragRef;
this.cornerElements = [];
this.pointerDownSubs = [];
this._initialPositionReset();
this._attachCorners();
}
/**
* @return {?}
*/
attach() {
this.detach();
this._attachCorners();
}
/**
* @return {?}
*/
detach() {
this.pointerDownSubs.forEach((/**
* @param {?} sub
* @return {?}
*/
(sub) => sub.unsubscribe()));
this.pointerDownSubs = [];
this.cornerElements.forEach((/**
* @param {?} elem
* @return {?}
*/
(elem) => this._renderer2.removeChild(this._getDialogWrapper(), elem)));
this.cornerElements = [];
}
/**
* @private
* @return {?}
*/
_getDialogWrapper() {
return ((/** @type {?} */ (this._document.getElementById(this._dialogRef.id))) || {}).parentElement;
}
/**
* @private
* @return {?}
*/
_getViewportDimensions() {
return this._getDialogWrapper().parentElement.getBoundingClientRect();
}
/**
* @private
* @return {?}
*/
_getDialogWrapperDimensions() {
/** @type {?} */
const dimensions = getComputedStyle(this._getDialogWrapper());
return {
width: getPixels(dimensions.width),
height: getPixels(dimensions.height),
};
}
/**
* @private
* @return {?}
*/
_initialPositionReset() {
const { right: viewportWidth, bottom: viewportHeight } = this._getViewportDimensions();
const { width, height } = this._getDialogWrapperDimensions();
const { marginRight: originalDialogRight, marginLeft: originalDialogLeft, marginBottom: originalDialogBottom, marginTop: originalDialogTop, } = this._getDialogWrapper().style;
/** @type {?} */
let x;
if (originalDialogLeft) {
x = getPixels(originalDialogLeft);
}
else if (originalDialogRight) {
x = viewportWidth - getPixels(originalDialogRight) - width;
}
else {
x = (viewportWidth - width) / 2;
}
/** @type {?} */
let y;
if (originalDialogTop) {
y = getPixels(originalDialogTop);
}
else if (originalDialogBottom) {
y = viewportHeight - getPixels(originalDialogBottom) - height;
}
else {
y = (viewportHeight - height) / 2;
}
// use drag ref's mechanisms for positioning instead of the dialog's
this._dialogRef.updatePosition({ top: '0px', right: '0px', bottom: '0px', left: '0px' });
this._dragRef.setFreeDragPosition({ x, y });
}
/**
* @private
* @return {?}
*/
_attachCorners() {
Object.values(corners).forEach((/**
* @param {?} corner
* @return {?}
*/
(corner) => {
/** @type {?} */
const element = this._renderer2.createElement('div');
this.cornerElements = [...this.cornerElements, element];
this._renderer2.setStyle(element, 'position', 'absolute');
this._renderer2.setStyle(element, 'width', cornerWidth);
this._renderer2.setStyle(element, 'height', cornerWidth);
this._renderer2.appendChild(this._getDialogWrapper(), element);
/** @type {?} */
let cursor;
/** @type {?} */
let topBottom;
/** @type {?} */
let rightLeft;
if (corner === corners.topRight) {
cursor = cursors.nesw;
topBottom = verticalAlignment.top;
rightLeft = horizontalAlignment.right;
}
else if (corner === corners.bottomRight) {
cursor = cursors.nwse;
topBottom = verticalAlignment.bottom;
rightLeft = horizontalAlignment.right;
/** @type {?} */
const icon = this._renderer2.createElement('i');
this._renderer2.addClass(icon, 'material-icons');
this._renderer2.appendChild(icon, this._renderer2.createText('filter_list'));
this._renderer2.appendChild(element, icon);
this._renderer2.setStyle(icon, 'transform', `rotate(${315}deg) translate(0px, ${offset})`);
this._renderer2.setStyle(icon, 'font-size', cornerWidth);
}
else if (corner === corners.bottomLeft) {
cursor = cursors.nesw;
topBottom = verticalAlignment.bottom;
rightLeft = horizontalAlignment.left;
}
else if (corner === corners.topLeft) {
cursor = cursors.nwse;
topBottom = verticalAlignment.top;
rightLeft = horizontalAlignment.left;
}
this._renderer2.setStyle(element, topBottom, offset);
this._renderer2.setStyle(element, rightLeft, offset);
this._renderer2.setStyle(element, 'cursor', cursor);
/** @type {?} */
const pointerDownSub = fromEvent(element, 'pointerdown').subscribe((/**
* @param {?} event
* @return {?}
*/
(event) => {
this._handleMouseDown(event, corner);
}));
this.pointerDownSubs = [...this.pointerDownSubs, pointerDownSub];
}));
}
/**
* @private
* @param {?} event
* @param {?} corner
* @return {?}
*/
_handleMouseDown(event, corner) {
this._renderer2.setStyle((/** @type {?} */ (this._document.body)), 'user-select', 'none');
const { width: originalWidth, height: originalHeight } = this._getDialogWrapperDimensions();
/** @type {?} */
const originalMouseX = event.pageX;
/** @type {?} */
const originalMouseY = event.pageY;
const { x: currentTransformX, y: currentTransformY } = this._dragRef.getFreeDragPosition();
const { bottom: distanceFromBottom, right: distanceFromRight } = this._getDialogWrapper().getBoundingClientRect();
const { right: viewportWidth, bottom: viewportHeight } = this._getViewportDimensions();
/** @type {?} */
const mouseMoveSub = fromEvent(window, 'pointermove').subscribe((/**
* @param {?} e
* @return {?}
*/
(e) => {
e.preventDefault(); // prevent highlighting of text when dragging
// prevent highlighting of text when dragging
/** @type {?} */
const yDelta = clamp(0, e.pageY, viewportHeight) - originalMouseY;
/** @type {?} */
const xDelta = clamp(0, e.pageX, viewportWidth) - originalMouseX;
/** @type {?} */
let newHeight;
/** @type {?} */
let newWidth;
/** @type {?} */
let newTransformY = 0;
/** @type {?} */
let newTransformX = 0;
// top right
if (corner === corners.topRight) {
newHeight = clamp(minHeight, originalHeight - yDelta, viewportHeight);
newWidth = clamp(minWidth, originalWidth + xDelta, viewportWidth);
newTransformY = clamp(0, currentTransformY + yDelta, distanceFromBottom - newHeight);
newTransformX = currentTransformX;
}
// bottom right
else if (corner === corners.bottomRight) {
newHeight = clamp(minHeight, originalHeight + yDelta, viewportHeight);
newWidth = clamp(minWidth, originalWidth + xDelta, viewportWidth);
newTransformY = currentTransformY;
newTransformX = currentTransformX;
}
// bottom left
else if (corner === corners.bottomLeft) {
newHeight = clamp(minHeight, originalHeight + yDelta, viewportHeight);
newWidth = clamp(minWidth, originalWidth - xDelta, viewportWidth);
newTransformY = currentTransformY;
newTransformX = clamp(0, currentTransformX + xDelta, distanceFromRight - newWidth);
}
// top left
else if (corner === corners.topLeft) {
newHeight = clamp(minHeight, originalHeight - yDelta, viewportHeight);
newWidth = clamp(minWidth, originalWidth - xDelta, viewportWidth);
newTransformX = clamp(0, currentTransformX + xDelta, distanceFromRight - newWidth);
newTransformY = clamp(0, currentTransformY + yDelta, distanceFromBottom - newHeight);
}
this._dialogRef.updateSize(`${newWidth}px`, `${newHeight}px`);
this._dragRef.setFreeDragPosition({
x: newTransformX,
y: newTransformY,
});
}));
/** @type {?} */
const mouseUpSub = merge(fromEvent(window, 'pointerup'), fromEvent(window, 'pointercancel')).subscribe((/**
* @return {?}
*/
() => {
this._renderer2.removeStyle((/** @type {?} */ (this._document.body)), 'user-select');
mouseMoveSub.unsubscribe();
mouseUpSub.unsubscribe();
}));
}
}
if (false) {
/** @type {?} */
ResizableDraggableDialog.prototype.cornerElements;
/** @type {?} */
ResizableDraggableDialog.prototype.pointerDownSubs;
/**
* @type {?}
* @private
*/
ResizableDraggableDialog.prototype._document;
/**
* @type {?}
* @private
*/
ResizableDraggableDialog.prototype._renderer2;
/**
* @type {?}
* @private
*/
ResizableDraggableDialog.prototype._dialogRef;
/**
* @type {?}
* @private
*/
ResizableDraggableDialog.prototype._dragRef;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resizable-draggable-dialog.js","sourceRoot":"../../../../../src/platform/core/dialogs/","sources":["resizable-draggable-dialog/resizable-draggable-dialog.ts"],"names":[],"mappings":"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","sourcesContent":["import { Renderer2 } from '@angular/core';\nimport { MatDialogRef } from '@angular/material/dialog';\nimport { DragRef } from '@angular/cdk/drag-drop';\nimport { merge, Subscription, fromEvent } from 'rxjs';\nimport { Point } from '@angular/cdk/drag-drop/drag-ref';\n\nenum corners {\n  topRight = 'topRight',\n  bottomRight = 'bottomRight',\n  bottomLeft = 'bottomLeft',\n  topLeft = 'topLeft',\n}\nenum cursors {\n  nesw = 'nesw-resize',\n  nwse = 'nwse-resize',\n}\nenum verticalAlignment {\n  top = 'top',\n  bottom = 'bottom',\n}\nenum horizontalAlignment {\n  right = 'right',\n  left = 'left',\n}\n\nconst cornerWidth: string = '16px';\nconst offset: string = '0px';\nconst minWidth: number = 200;\nconst minHeight: number = 200;\n\nfunction getPixels(sizeString: string): number {\n  return parseFloat((sizeString || '').replace('px', ''));\n}\n\nfunction clamp(min: number, num: number, max: number): number {\n  return Math.min(Math.max(num, min), max);\n}\n\nexport class ResizableDraggableDialog {\n  cornerElements: HTMLElement[] = [];\n  pointerDownSubs: Subscription[] = [];\n\n  constructor(\n    private _document: any,\n    private _renderer2: Renderer2,\n    private _dialogRef: MatDialogRef<any>,\n    private _dragRef: DragRef,\n  ) {\n    this._initialPositionReset();\n    this._attachCorners();\n  }\n\n  public attach(): void {\n    this.detach();\n    this._attachCorners();\n  }\n\n  public detach(): void {\n    this.pointerDownSubs.forEach((sub: Subscription) => sub.unsubscribe());\n    this.pointerDownSubs = [];\n    this.cornerElements.forEach((elem: HTMLElement) => this._renderer2.removeChild(this._getDialogWrapper(), elem));\n    this.cornerElements = [];\n  }\n\n  private _getDialogWrapper(): HTMLElement {\n    return (<HTMLElement>this._document.getElementById(this._dialogRef.id) || {}).parentElement;\n  }\n\n  private _getViewportDimensions(): ClientRect {\n    return this._getDialogWrapper().parentElement.getBoundingClientRect();\n  }\n\n  private _getDialogWrapperDimensions(): { width: number; height: number } {\n    const dimensions: CSSStyleDeclaration = getComputedStyle(this._getDialogWrapper());\n    return {\n      width: getPixels(dimensions.width),\n      height: getPixels(dimensions.height),\n    };\n  }\n\n  private _initialPositionReset(): void {\n    const { right: viewportWidth, bottom: viewportHeight }: ClientRect = this._getViewportDimensions();\n    const { width, height } = this._getDialogWrapperDimensions();\n    const {\n      marginRight: originalDialogRight,\n      marginLeft: originalDialogLeft,\n      marginBottom: originalDialogBottom,\n      marginTop: originalDialogTop,\n    } = this._getDialogWrapper().style;\n    let x: number;\n    if (originalDialogLeft) {\n      x = getPixels(originalDialogLeft);\n    } else if (originalDialogRight) {\n      x = viewportWidth - getPixels(originalDialogRight) - width;\n    } else {\n      x = (viewportWidth - width) / 2;\n    }\n    let y: number;\n    if (originalDialogTop) {\n      y = getPixels(originalDialogTop);\n    } else if (originalDialogBottom) {\n      y = viewportHeight - getPixels(originalDialogBottom) - height;\n    } else {\n      y = (viewportHeight - height) / 2;\n    }\n    // use drag ref's mechanisms for positioning instead of the dialog's\n    this._dialogRef.updatePosition({ top: '0px', right: '0px', bottom: '0px', left: '0px' });\n    this._dragRef.setFreeDragPosition({ x, y });\n  }\n\n  private _attachCorners(): void {\n    Object.values(corners).forEach((corner: corners) => {\n      const element: HTMLElement = this._renderer2.createElement('div');\n      this.cornerElements = [...this.cornerElements, element];\n      this._renderer2.setStyle(element, 'position', 'absolute');\n      this._renderer2.setStyle(element, 'width', cornerWidth);\n      this._renderer2.setStyle(element, 'height', cornerWidth);\n      this._renderer2.appendChild(this._getDialogWrapper(), element);\n\n      let cursor: cursors;\n      let topBottom: verticalAlignment;\n      let rightLeft: horizontalAlignment;\n\n      if (corner === corners.topRight) {\n        cursor = cursors.nesw;\n        topBottom = verticalAlignment.top;\n        rightLeft = horizontalAlignment.right;\n      } else if (corner === corners.bottomRight) {\n        cursor = cursors.nwse;\n        topBottom = verticalAlignment.bottom;\n        rightLeft = horizontalAlignment.right;\n\n        const icon: HTMLElement = this._renderer2.createElement('i');\n        this._renderer2.addClass(icon, 'material-icons');\n        this._renderer2.appendChild(icon, this._renderer2.createText('filter_list'));\n        this._renderer2.appendChild(element, icon);\n        this._renderer2.setStyle(icon, 'transform', `rotate(${315}deg) translate(0px, ${offset})`);\n        this._renderer2.setStyle(icon, 'font-size', cornerWidth);\n      } else if (corner === corners.bottomLeft) {\n        cursor = cursors.nesw;\n        topBottom = verticalAlignment.bottom;\n        rightLeft = horizontalAlignment.left;\n      } else if (corner === corners.topLeft) {\n        cursor = cursors.nwse;\n        topBottom = verticalAlignment.top;\n        rightLeft = horizontalAlignment.left;\n      }\n      this._renderer2.setStyle(element, topBottom, offset);\n      this._renderer2.setStyle(element, rightLeft, offset);\n      this._renderer2.setStyle(element, 'cursor', cursor);\n\n      const pointerDownSub: Subscription = fromEvent(element, 'pointerdown').subscribe((event: PointerEvent) => {\n        this._handleMouseDown(event, corner);\n      });\n      this.pointerDownSubs = [...this.pointerDownSubs, pointerDownSub];\n    });\n  }\n\n  private _handleMouseDown(event: PointerEvent, corner: corners): void {\n    this._renderer2.setStyle(<HTMLElement>this._document.body, 'user-select', 'none');\n    const { width: originalWidth, height: originalHeight } = this._getDialogWrapperDimensions();\n    const originalMouseX: number = event.pageX;\n    const originalMouseY: number = event.pageY;\n    const { x: currentTransformX, y: currentTransformY }: Point = this._dragRef.getFreeDragPosition();\n    const { bottom: distanceFromBottom, right: distanceFromRight }: ClientRect =\n      this._getDialogWrapper().getBoundingClientRect();\n    const { right: viewportWidth, bottom: viewportHeight }: ClientRect = this._getViewportDimensions();\n\n    const mouseMoveSub: Subscription = fromEvent(window, 'pointermove').subscribe((e: PointerEvent) => {\n      e.preventDefault(); // prevent highlighting of text when dragging\n\n      const yDelta: number = clamp(0, e.pageY, viewportHeight) - originalMouseY;\n      const xDelta: number = clamp(0, e.pageX, viewportWidth) - originalMouseX;\n      let newHeight: number;\n      let newWidth: number;\n      let newTransformY: number = 0;\n      let newTransformX: number = 0;\n\n      // top right\n      if (corner === corners.topRight) {\n        newHeight = clamp(minHeight, originalHeight - yDelta, viewportHeight);\n        newWidth = clamp(minWidth, originalWidth + xDelta, viewportWidth);\n        newTransformY = clamp(0, currentTransformY + yDelta, distanceFromBottom - newHeight);\n        newTransformX = currentTransformX;\n      }\n      // bottom right\n      else if (corner === corners.bottomRight) {\n        newHeight = clamp(minHeight, originalHeight + yDelta, viewportHeight);\n        newWidth = clamp(minWidth, originalWidth + xDelta, viewportWidth);\n        newTransformY = currentTransformY;\n        newTransformX = currentTransformX;\n      }\n      // bottom left\n      else if (corner === corners.bottomLeft) {\n        newHeight = clamp(minHeight, originalHeight + yDelta, viewportHeight);\n        newWidth = clamp(minWidth, originalWidth - xDelta, viewportWidth);\n        newTransformY = currentTransformY;\n        newTransformX = clamp(0, currentTransformX + xDelta, distanceFromRight - newWidth);\n      }\n      // top left\n      else if (corner === corners.topLeft) {\n        newHeight = clamp(minHeight, originalHeight - yDelta, viewportHeight);\n        newWidth = clamp(minWidth, originalWidth - xDelta, viewportWidth);\n\n        newTransformX = clamp(0, currentTransformX + xDelta, distanceFromRight - newWidth);\n        newTransformY = clamp(0, currentTransformY + yDelta, distanceFromBottom - newHeight);\n      }\n      this._dialogRef.updateSize(`${newWidth}px`, `${newHeight}px`);\n      this._dragRef.setFreeDragPosition({\n        x: newTransformX,\n        y: newTransformY,\n      });\n    });\n\n    const mouseUpSub: Subscription = merge(\n      fromEvent(window, 'pointerup'),\n      fromEvent(window, 'pointercancel'),\n    ).subscribe(() => {\n      this._renderer2.removeStyle(<HTMLElement>this._document.body, 'user-select');\n      mouseMoveSub.unsubscribe();\n      mouseUpSub.unsubscribe();\n    });\n  }\n}\n"]}