UNPKG

@covalent/core

Version:

Core Teradata UI Platform for layouts, icons, custom components and themes. This should be added as a dependency for any project that wants to use layouts, icons and themes for Angular Material.

222 lines 34.3 kB
import { merge, fromEvent } from 'rxjs'; var corners; (function (corners) { corners["topRight"] = "topRight"; corners["bottomRight"] = "bottomRight"; corners["bottomLeft"] = "bottomLeft"; corners["topLeft"] = "topLeft"; })(corners || (corners = {})); var cursors; (function (cursors) { cursors["nesw"] = "nesw-resize"; cursors["nwse"] = "nwse-resize"; })(cursors || (cursors = {})); var verticalAlignment; (function (verticalAlignment) { verticalAlignment["top"] = "top"; verticalAlignment["bottom"] = "bottom"; })(verticalAlignment || (verticalAlignment = {})); var horizontalAlignment; (function (horizontalAlignment) { horizontalAlignment["right"] = "right"; horizontalAlignment["left"] = "left"; })(horizontalAlignment || (horizontalAlignment = {})); const cornerWidth = '16px'; const offset = '0px'; const minWidth = 200; const minHeight = 200; function getPixels(sizeString) { return parseFloat((sizeString || '').replace('px', '')); } function clamp(min, num, max) { return Math.min(Math.max(num, min), max); } export class ResizableDraggableDialog { _document; _renderer2; _dialogRef; _dragRef; cornerElements = []; pointerDownSubs = []; constructor(_document, _renderer2, _dialogRef, _dragRef) { this._document = _document; this._renderer2 = _renderer2; this._dialogRef = _dialogRef; this._dragRef = _dragRef; this._initialPositionReset(); this._attachCorners(); } attach() { this.detach(); this._attachCorners(); } detach() { this.pointerDownSubs.forEach((sub) => sub.unsubscribe()); this.pointerDownSubs = []; this.cornerElements.forEach((elem) => this._renderer2.removeChild(this._getDialogWrapper(), elem)); this.cornerElements = []; } _getDialogWrapper() { return (this._document.getElementById(this._dialogRef.id) || {}).parentElement; } _getViewportDimensions() { return this._getDialogWrapper()?.parentElement?.getBoundingClientRect(); } _getDialogWrapperDimensions() { const wrapper = this._getDialogWrapper(); if (!wrapper) { return { width: 0, height: 0 }; } const dimensions = getComputedStyle(wrapper); return { width: getPixels(dimensions.width), height: getPixels(dimensions.height), }; } _initialPositionReset() { const viewportWidth = this._getViewportDimensions()?.right ?? 0; const viewportHeight = this._getViewportDimensions()?.bottom ?? 0; const { width, height } = this._getDialogWrapperDimensions(); const wrapperStyle = this._getDialogWrapper()?.style; const originalDialogRight = wrapperStyle?.marginRight; const originalDialogLeft = wrapperStyle?.marginLeft; const originalDialogBottom = wrapperStyle?.marginBottom; const originalDialogTop = wrapperStyle?.marginTop; let x; if (originalDialogLeft) { x = getPixels(originalDialogLeft); } else if (originalDialogRight) { x = viewportWidth - getPixels(originalDialogRight) - width; } else { x = (viewportWidth - width) / 2; } 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 }); } _attachCorners() { Object.values(corners).forEach((corner) => { 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.setStyle(element, 'z-index', 1); this._renderer2.appendChild(this._getDialogWrapper(), element); let cursor; let topBottom; 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; const icon = this._renderer2.createElement('i'); this._renderer2.addClass(icon, 'material-symbols-outlined'); 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); this._renderer2.setStyle(icon, 'z-index', 1); } else if (corner === corners.bottomLeft) { cursor = cursors.nesw; topBottom = verticalAlignment.bottom; rightLeft = horizontalAlignment.left; } else { 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); const pointerDownSub = fromEvent(element, 'pointerdown').subscribe((event) => { this._handleMouseDown(event, corner); }); this.pointerDownSubs = [...this.pointerDownSubs, pointerDownSub]; }); } _handleMouseDown(event, corner) { this._renderer2.setStyle(this._document.body, 'user-select', 'none'); const { width: originalWidth, height: originalHeight } = this._getDialogWrapperDimensions(); const originalMouseX = event.pageX; const originalMouseY = event.pageY; const { x: currentTransformX, y: currentTransformY } = this._dragRef.getFreeDragPosition(); const wrapper = this._getDialogWrapper()?.getBoundingClientRect(); const distanceFromBottom = wrapper?.bottom ?? 0; const distanceFromRight = wrapper?.right ?? 0; const viewportWidth = this._getViewportDimensions()?.right ?? 0; const viewportHeight = this._getViewportDimensions()?.bottom ?? 0; const mouseMoveSub = fromEvent(window, 'pointermove').subscribe((e) => { e.preventDefault(); // prevent highlighting of text when dragging const yDelta = clamp(0, e.pageY, viewportHeight) - originalMouseY; const xDelta = clamp(0, e.pageX, viewportWidth) - originalMouseX; let newHeight; let newWidth; let newTransformY = 0; 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 { 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, }); }); const mouseUpSub = merge(fromEvent(window, 'pointerup'), fromEvent(window, 'pointercancel')).subscribe(() => { this._renderer2.removeStyle(this._document.body, 'user-select'); mouseMoveSub.unsubscribe(); mouseUpSub.unsubscribe(); }); } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resizable-draggable-dialog.js","sourceRoot":"","sources":["../../../../../../libs/angular/dialogs/src/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';\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 = '16px';\nconst offset = '0px';\nconst minWidth = 200;\nconst minHeight = 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) =>\n      this._renderer2.removeChild(this._getDialogWrapper(), elem)\n    );\n    this.cornerElements = [];\n  }\n\n  private _getDialogWrapper(): HTMLElement | null {\n    return (\n      <HTMLElement>this._document.getElementById(this._dialogRef.id) || {}\n    ).parentElement;\n  }\n\n  private _getViewportDimensions(): ClientRect | undefined {\n    return this._getDialogWrapper()?.parentElement?.getBoundingClientRect();\n  }\n\n  private _getDialogWrapperDimensions(): { width: number; height: number } {\n    const wrapper = this._getDialogWrapper();\n    if (!wrapper) {\n      return { width: 0, height: 0 };\n    }\n    const dimensions: CSSStyleDeclaration = getComputedStyle(wrapper);\n    return {\n      width: getPixels(dimensions.width),\n      height: getPixels(dimensions.height),\n    };\n  }\n\n  private _initialPositionReset(): void {\n    const viewportWidth = this._getViewportDimensions()?.right ?? 0;\n    const viewportHeight = this._getViewportDimensions()?.bottom ?? 0;\n    const { width, height } = this._getDialogWrapperDimensions();\n    const wrapperStyle = this._getDialogWrapper()?.style;\n    const originalDialogRight = wrapperStyle?.marginRight;\n    const originalDialogLeft = wrapperStyle?.marginLeft;\n    const originalDialogBottom = wrapperStyle?.marginBottom;\n    const originalDialogTop = wrapperStyle?.marginTop;\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({\n      top: '0px',\n      right: '0px',\n      bottom: '0px',\n      left: '0px',\n    });\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.setStyle(element, 'z-index', 1);\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-symbols-outlined');\n        this._renderer2.appendChild(\n          icon,\n          this._renderer2.createText('filter_list')\n        );\n        this._renderer2.appendChild(element, icon);\n        this._renderer2.setStyle(\n          icon,\n          'transform',\n          `rotate(${315}deg) translate(0px, ${offset})`\n        );\n        this._renderer2.setStyle(icon, 'font-size', cornerWidth);\n        this._renderer2.setStyle(icon, 'z-index', 1);\n      } else if (corner === corners.bottomLeft) {\n        cursor = cursors.nesw;\n        topBottom = verticalAlignment.bottom;\n        rightLeft = horizontalAlignment.left;\n      } else {\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<PointerEvent>(\n        element,\n        'pointerdown'\n      ).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(\n      <HTMLElement>this._document.body,\n      'user-select',\n      'none'\n    );\n    const { width: originalWidth, height: originalHeight } =\n      this._getDialogWrapperDimensions();\n    const originalMouseX: number = event.pageX;\n    const originalMouseY: number = event.pageY;\n    const { x: currentTransformX, y: currentTransformY }: Point =\n      this._dragRef.getFreeDragPosition();\n    const wrapper = this._getDialogWrapper()?.getBoundingClientRect();\n    const distanceFromBottom = wrapper?.bottom ?? 0;\n    const distanceFromRight = wrapper?.right ?? 0;\n    const viewportWidth = this._getViewportDimensions()?.right ?? 0;\n    const viewportHeight = this._getViewportDimensions()?.bottom ?? 0;\n\n    const mouseMoveSub: Subscription = fromEvent<PointerEvent>(\n      window,\n      'pointermove'\n    ).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 = 0;\n      let newTransformX = 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(\n          0,\n          currentTransformY + yDelta,\n          distanceFromBottom - newHeight\n        );\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(\n          0,\n          currentTransformX + xDelta,\n          distanceFromRight - newWidth\n        );\n      }\n      // top left\n      else {\n        newHeight = clamp(minHeight, originalHeight - yDelta, viewportHeight);\n        newWidth = clamp(minWidth, originalWidth - xDelta, viewportWidth);\n\n        newTransformX = clamp(\n          0,\n          currentTransformX + xDelta,\n          distanceFromRight - newWidth\n        );\n        newTransformY = clamp(\n          0,\n          currentTransformY + yDelta,\n          distanceFromBottom - newHeight\n        );\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(\n        <HTMLElement>this._document.body,\n        'user-select'\n      );\n      mouseMoveSub.unsubscribe();\n      mouseUpSub.unsubscribe();\n    });\n  }\n}\n"]}