| /** |
| * @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"]} |