UNPKG

@santinobch/os-window-angular

Version:

Create windows inside a browser window!

355 lines 50 kB
import { coerceNumberProperty } from '@angular/cdk/coercion'; import { StyleClass } from './Style.class'; export function clamp(v, min = 0, max = Number.MAX_SAFE_INTEGER) { return Math.max(min, Math.min(max, coerceNumberProperty(v))); } export class OsWindowClass { constructor(componentElement, renderer, globalConfigService) { this.componentElement = componentElement; this.renderer = renderer; this.globalConfigService = globalConfigService; this.mousePos = { x: 0, y: 0 }; //Anchor stores temporary point of the current resize CdkDragMove event this.anchor = { x: 0, y: 0 }; this.minHeight = 200; this.minWidth = 200; this.size = { height: { previous: 200, current: 200, unit: 'px', }, width: { previous: 200, current: 200, unit: 'px', }, }; this.position = { resize: { x: 0, y: 0 }, current: { x: 0, y: 0 }, next: { x: 0, y: 0 }, zIndex: { current: 0, next: 1, }, }; this.cdkAnchors = { n: { x: 0, y: 0 }, ne: { x: 0, y: 0 }, e: { x: 0, y: 0 }, se: { x: 0, y: 0 }, s: { x: 0, y: 0 }, sw: { x: 0, y: 0 }, w: { x: 0, y: 0 }, nw: { x: 0, y: 0 }, }; this.state = { minimized: false, maximized: false, }; this.rules = { disableResize: false, minimizable: true, maximizable: true, closable: true, }; this.styleConfig = new StyleClass(componentElement, renderer, globalConfigService, 'window'); } setStyle(_elementRef, property, value) { _elementRef.nativeElement.style.setProperty(property, value); } getStyle(_elementRef, property) { return getComputedStyle(_elementRef.nativeElement).getPropertyValue(property); } clamp(input, max) { return input >= max ? input : max; } clampHeight(_elementRef, _height, _minHeight) { if (_minHeight) { _height = this.clamp(_height, _minHeight); } return _height; } clampWidth(_elementRef, _width, _minWidth) { if (_minWidth) { _width = this.clamp(_width, _minWidth); } return _width; } setDimesions() { this.size.width.current = this.clampWidth(this.componentElement, this.size.width.current, this.minWidth); this.size.height.current = this.clampHeight(this.componentElement, this.size.height.current, this.minHeight); } //////////////////////// // Position // //////////////////////// setPosition(positionStr) { const X = parseInt(positionStr[0]); const Y = parseInt(positionStr[1]); if (!Number.isNaN(X)) { this.position.next.x = X; } else { switch (positionStr[0]) { case 'left': this.position.next.x = 0; break; case 'center': this.position.next.x = window.innerWidth / 2 - this.size.width.current / 2; break; case 'right': this.position.next.x = window.innerWidth - this.size.width.current; break; default: this.position.next.x = 0; break; } } if (!Number.isNaN(Y)) { this.position.next.y = Y + window.innerHeight; } else { //To hide the window element we need to set it top: -100% in scss, //so we later need to calculate everything + innerHeight switch (positionStr[1]) { case 'top': this.position.next.y = window.innerHeight; break; case 'center': this.position.next.y = window.innerHeight + (window.innerHeight / 2 - this.size.height.current / 2); break; case 'bottom': this.position.next.y = window.innerHeight + (window.innerHeight - this.size.height.current); break; default: this.position.next.y = window.innerHeight; break; } } this.position.current = this.position.next; } //////////////////////// // Style // //////////////////////// //////////////////////// // Rules // //////////////////////// loadRules() { //Minimizable? if (!this.rules.minimizable) { this.setStyle(this.componentElement, '--minimizeButton', 'none'); } //Maximizable? if (!this.rules.maximizable) { this.setStyle(this.componentElement, '--maximizeButton', 'none'); } //Closable? if (!this.rules.closable) { this.setStyle(this.componentElement, '--closeButton', 'none'); } //Resizable? if (this.rules.disableResize) { this.setStyle(this.componentElement, '--cursorN', 'auto'); this.setStyle(this.componentElement, '--cursorNE', 'auto'); this.setStyle(this.componentElement, '--cursorE', 'auto'); this.setStyle(this.componentElement, '--cursorSE', 'auto'); this.setStyle(this.componentElement, '--cursorS', 'auto'); this.setStyle(this.componentElement, '--cursorSW', 'auto'); this.setStyle(this.componentElement, '--cursorW', 'auto'); this.setStyle(this.componentElement, '--cursorNW', 'auto'); } } //////////////////////// // Controls // //////////////////////// minimize() { //TODO } maximize() { if (this.rules.maximizable) { if (this.state.maximized == false) { //Saving value for later this.size.height.previous = this.size.height.current; this.size.width.previous = this.size.width.current; this.size.height.current = 100; this.size.height.unit = 'vh'; this.size.width.current = 100; this.size.width.unit = 'vw'; this.position.current = { x: 0, y: window.innerHeight }; this.state.maximized = true; this.rules.disableResize = true; } else { //Restoring window size this.size.height.current = this.size.height.previous; this.size.height.unit = 'px'; this.size.width.current = this.size.width.previous; this.size.width.unit = 'px'; this.position.current = this.position.next; this.state.maximized = false; this.rules.disableResize = false; } } } //When maximized and then dragged the window demaximizes //and puts itself aligned with the mouse position demaximize() { if (this.state.maximized == true) { this.position.next = { x: this.mousePos.x - this.size.width.current / 2, y: this.mousePos.y + window.innerHeight - 20, }; this.maximize(); } } close() { this.componentElement.nativeElement.remove(); } //////////////////////// // Resize & movement // //////////////////////// storeMousePos(event) { this.mousePos = { x: event.x, y: event.y, }; } //Sets some variables when the resize drag starts, we use them later startResize() { this.size.height.previous = this.size.height.current; this.size.width.previous = this.size.width.current; } resize(dragEvent, direction) { let directionSplit = [direction.charAt(0), direction.charAt(1)]; this.anchor = dragEvent.source.getFreeDragPosition(); directionSplit.forEach(dir => { this.resizeDirection(dir); }); //Reset anchor position switch (direction) { case 'n': this.cdkAnchors.n = { x: 0, y: 0 }; break; case 'ne': this.cdkAnchors.n = { x: 0, y: 0 }; break; case 'e': this.cdkAnchors.e = { x: 0, y: 0 }; break; case 'se': this.cdkAnchors.se = { x: 0, y: 0 }; break; case 's': this.cdkAnchors.s = { x: 0, y: 0 }; break; case 'sw': this.cdkAnchors.sw = { x: 0, y: 0 }; break; case 'w': this.cdkAnchors.w = { x: 0, y: 0 }; break; case 'nw': this.cdkAnchors.nw = { x: 0, y: 0 }; break; } } resizeDirection(direction) { this.position.resize = this.position.next; switch (direction) { case 'n': //Checks that the new position and dimesions produce a minHeight lower than the required if (this.size.height.previous - this.anchor.y >= this.minHeight) { this.position.resize = { x: this.position.resize.x, y: this.position.next.y + this.anchor.y, }; this.size.height.current = this.size.height.previous - this.anchor.y; this.size.height.current = this.clampHeight(this.componentElement, this.size.height.current, this.minHeight); this.position.current = { x: this.position.current.x, y: this.position.resize.y, }; } break; case 'e': this.size.width.current = this.size.width.previous + this.anchor.x; this.size.width.current = this.clampWidth(this.componentElement, this.size.width.current, this.minWidth); break; case 's': this.size.height.current = this.size.height.previous + this.anchor.y; this.size.height.current = this.clampHeight(this.componentElement, this.size.height.current, this.minHeight); break; case 'w': //Checks that the new position and dimesions produce a minHeight lower than the required if (this.size.width.previous - this.anchor.x >= this.minWidth) { this.position.resize = { x: this.position.next.x + this.anchor.x, y: this.position.resize.y, }; this.size.width.current = this.size.width.previous - this.anchor.x; this.size.width.current = this.clampWidth(this.componentElement, this.size.width.current, this.minWidth); this.position.current = { x: this.position.resize.x, y: this.position.current.y, }; } break; } } endResize() { this.position.next = this.position.current; } //When releasing the os-window the user may leave it outside of the browser window //which would make it imposible to interact with the component again, //this makes the window 'bounce' back into sight correctEndPosition(event) { this.position.next = event.source.getFreeDragPosition(); //Fix for Y position, the window-bar will always be visible if (this.position.next.y < window.innerHeight) { this.position.next.y = window.innerHeight; } else if (this.position.next.y > window.innerHeight * 2 - 40) { this.position.next.y = window.innerHeight * 2 - 40; } //Fix for X position, a quarter of the window will always be visible if (this.position.next.x < -((this.size.width.current / 4) * 3)) { this.position.next.x = -((this.size.width.current / 4) * 3); } else if (this.position.next.x > window.innerWidth - this.size.width.current / 4) { this.position.next.x = window.innerWidth - this.size.width.current / 4; } this.position.current = this.position.next; } ////////////////////////////// // Other user interaction // ////////////////////////////// //When a window is clicked we want to change it's z-index value and apply some styles focus() { //We get the current global z-index this.position.zIndex.next = this.globalConfigService.getZIndex(); //This will be unequal if another window has been focused on if (this.position.zIndex.current != this.position.zIndex.next) { this.position.zIndex.next++; this.position.zIndex.current = this.position.zIndex.next; //Updating global z-index this.globalConfigService.setZIndex(this.position.zIndex.current); } //After that we remove the 'focused' class from all the windows let focused = document.getElementsByClassName('focused'); let i = 0; while (i < focused.length) { this.renderer.removeClass(focused[i], 'focused'); i++; } //We add the 'focused' class to the current window this.renderer.addClass(this.componentElement.nativeElement.firstChild, 'focused'); } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"OsWindow.class.js","sourceRoot":"","sources":["../../../../../projects/os-window-angular/src/lib/classes/OsWindow.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragEnd, CdkDragMove } from '@angular/cdk/drag-drop';\nimport { ElementRef, Renderer2, SimpleChanges } from '@angular/core';\nimport { coerceNumberProperty } from '@angular/cdk/coercion';\n\nimport { OsConfigService } from '../services/os-config/os-config.service';\nimport { TwoPointModel } from '../models/TwoPoint.model';\nimport { PositionModel } from '../models/Position.model';\nimport { ResizeModel } from '../models/Resize.model';\nimport { StyleClass } from './Style.class';\nimport { SizeModel } from '../models/Size.model';\n\nexport function clamp(v: Number, min = 0, max = Number.MAX_SAFE_INTEGER) {\n  return Math.max(min, Math.min(max, coerceNumberProperty(v)));\n}\n\nexport class OsWindowClass {\n  public styleConfig!: StyleClass;\n\n  constructor(\n    public componentElement: ElementRef<HTMLElement>,\n    public renderer: Renderer2,\n    public globalConfigService: OsConfigService\n  ) {\n    this.styleConfig = new StyleClass(\n      componentElement,\n      renderer,\n      globalConfigService,\n      'window'\n    );\n  }\n\n  private mousePos: TwoPointModel = { x: 0, y: 0 };\n\n  //Anchor stores temporary point of the current resize CdkDragMove event\n  private anchor: TwoPointModel = { x: 0, y: 0 };\n\n  public minHeight: number = 200;\n  public minWidth: number = 200;\n\n  public size: SizeModel = {\n    height: {\n      previous: 200,\n      current: 200,\n      unit: 'px',\n    },\n    width: {\n      previous: 200,\n      current: 200,\n      unit: 'px',\n    },\n  };\n\n  public position: PositionModel = {\n    resize: { x: 0, y: 0 },\n    current: { x: 0, y: 0 },\n    next: { x: 0, y: 0 },\n    zIndex: {\n      current: 0,\n      next: 1,\n    },\n  };\n\n  public cdkAnchors: ResizeModel = {\n    n: { x: 0, y: 0 },\n    ne: { x: 0, y: 0 },\n    e: { x: 0, y: 0 },\n    se: { x: 0, y: 0 },\n    s: { x: 0, y: 0 },\n    sw: { x: 0, y: 0 },\n    w: { x: 0, y: 0 },\n    nw: { x: 0, y: 0 },\n  };\n\n  public state = {\n    minimized: false,\n    maximized: false,\n  };\n\n  public rules = {\n    disableResize: false,\n    minimizable: true,\n    maximizable: true,\n    closable: true,\n  };\n\n  private setStyle(_elementRef: ElementRef, property: string, value: string) {\n    _elementRef.nativeElement.style.setProperty(property, value);\n  }\n\n  private getStyle(_elementRef: ElementRef, property: string) {\n    return getComputedStyle(_elementRef.nativeElement).getPropertyValue(\n      property\n    );\n  }\n\n  private clamp(input: number, max: number) {\n    return input >= max ? input : max;\n  }\n\n  private clampHeight(\n    _elementRef: ElementRef,\n    _height: number,\n    _minHeight?: number\n  ) {\n    if (_minHeight) {\n      _height = this.clamp(_height, _minHeight);\n    }\n\n    return _height;\n  }\n\n  private clampWidth(\n    _elementRef: ElementRef,\n    _width: number,\n    _minWidth?: number\n  ) {\n    if (_minWidth) {\n      _width = this.clamp(_width, _minWidth);\n    }\n\n    return _width;\n  }\n\n  setDimesions() {\n    this.size.width.current = this.clampWidth(\n      this.componentElement,\n      this.size.width.current,\n      this.minWidth\n    );\n    this.size.height.current = this.clampHeight(\n      this.componentElement,\n      this.size.height.current,\n      this.minHeight\n    );\n  }\n\n  ////////////////////////\n  //      Position      //\n  ////////////////////////\n\n  setPosition(positionStr: string[]) {\n    const X = parseInt(positionStr[0]);\n    const Y = parseInt(positionStr[1]);\n\n    if (!Number.isNaN(X)) {\n      this.position.next.x = X;\n    } else {\n      switch (positionStr[0]) {\n        case 'left':\n          this.position.next.x = 0;\n          break;\n\n        case 'center':\n          this.position.next.x =\n            window.innerWidth / 2 - this.size.width.current / 2;\n          break;\n\n        case 'right':\n          this.position.next.x = window.innerWidth - this.size.width.current;\n          break;\n\n        default:\n          this.position.next.x = 0;\n          break;\n      }\n    }\n\n    if (!Number.isNaN(Y)) {\n      this.position.next.y = Y + window.innerHeight;\n    } else {\n      //To hide the window element we need to set it top: -100% in scss,\n      //so we later need to calculate everything + innerHeight\n      switch (positionStr[1]) {\n        case 'top':\n          this.position.next.y = window.innerHeight;\n          break;\n\n        case 'center':\n          this.position.next.y =\n            window.innerHeight +\n            (window.innerHeight / 2 - this.size.height.current / 2);\n          break;\n\n        case 'bottom':\n          this.position.next.y =\n            window.innerHeight +\n            (window.innerHeight - this.size.height.current);\n          break;\n\n        default:\n          this.position.next.y = window.innerHeight;\n          break;\n      }\n    }\n\n    this.position.current = this.position.next;\n  }\n\n  ////////////////////////\n  //       Style        //\n  ////////////////////////\n\n  ////////////////////////\n  //       Rules        //\n  ////////////////////////\n\n  loadRules() {\n    //Minimizable?\n    if (!this.rules.minimizable) {\n      this.setStyle(this.componentElement, '--minimizeButton', 'none');\n    }\n\n    //Maximizable?\n    if (!this.rules.maximizable) {\n      this.setStyle(this.componentElement, '--maximizeButton', 'none');\n    }\n\n    //Closable?\n    if (!this.rules.closable) {\n      this.setStyle(this.componentElement, '--closeButton', 'none');\n    }\n\n    //Resizable?\n    if (this.rules.disableResize) {\n      this.setStyle(this.componentElement, '--cursorN', 'auto');\n      this.setStyle(this.componentElement, '--cursorNE', 'auto');\n      this.setStyle(this.componentElement, '--cursorE', 'auto');\n      this.setStyle(this.componentElement, '--cursorSE', 'auto');\n      this.setStyle(this.componentElement, '--cursorS', 'auto');\n      this.setStyle(this.componentElement, '--cursorSW', 'auto');\n      this.setStyle(this.componentElement, '--cursorW', 'auto');\n      this.setStyle(this.componentElement, '--cursorNW', 'auto');\n    }\n  }\n\n  ////////////////////////\n  //      Controls      //\n  ////////////////////////\n\n  minimize() {\n    //TODO\n  }\n\n  maximize() {\n    if (this.rules.maximizable) {\n      if (this.state.maximized == false) {\n        //Saving value for later\n        this.size.height.previous = this.size.height.current;\n        this.size.width.previous = this.size.width.current;\n\n        this.size.height.current = 100;\n        this.size.height.unit = 'vh';\n        this.size.width.current = 100;\n        this.size.width.unit = 'vw';\n\n        this.position.current = { x: 0, y: window.innerHeight };\n\n        this.state.maximized = true;\n        this.rules.disableResize = true;\n      } else {\n        //Restoring window size\n        this.size.height.current = this.size.height.previous;\n        this.size.height.unit = 'px';\n        this.size.width.current = this.size.width.previous;\n        this.size.width.unit = 'px';\n\n        this.position.current = this.position.next;\n\n        this.state.maximized = false;\n        this.rules.disableResize = false;\n      }\n    }\n  }\n\n  //When maximized and then dragged the window demaximizes\n  //and puts itself aligned with the mouse position\n  demaximize() {\n    if (this.state.maximized == true) {\n      this.position.next = {\n        x: this.mousePos.x - this.size.width.current / 2,\n        y: this.mousePos.y + window.innerHeight - 20,\n      };\n      this.maximize();\n    }\n  }\n\n  close() {\n    this.componentElement.nativeElement.remove();\n  }\n\n  ////////////////////////\n  // Resize & movement  //\n  ////////////////////////\n\n  storeMousePos(event: MouseEvent) {\n    this.mousePos = {\n      x: event.x,\n      y: event.y,\n    };\n  }\n\n  //Sets some variables when the resize drag starts, we use them later\n  startResize() {\n    this.size.height.previous = this.size.height.current;\n    this.size.width.previous = this.size.width.current;\n  }\n\n  resize(dragEvent: CdkDragMove, direction: string) {\n    let directionSplit: string[] = [direction.charAt(0), direction.charAt(1)];\n\n    this.anchor = dragEvent.source.getFreeDragPosition();\n\n    directionSplit.forEach(dir => {\n      this.resizeDirection(dir);\n    });\n\n    //Reset anchor position\n    switch (direction) {\n      case 'n':\n        this.cdkAnchors.n = { x: 0, y: 0 };\n        break;\n\n      case 'ne':\n        this.cdkAnchors.n = { x: 0, y: 0 };\n        break;\n\n      case 'e':\n        this.cdkAnchors.e = { x: 0, y: 0 };\n        break;\n\n      case 'se':\n        this.cdkAnchors.se = { x: 0, y: 0 };\n        break;\n\n      case 's':\n        this.cdkAnchors.s = { x: 0, y: 0 };\n        break;\n\n      case 'sw':\n        this.cdkAnchors.sw = { x: 0, y: 0 };\n        break;\n\n      case 'w':\n        this.cdkAnchors.w = { x: 0, y: 0 };\n        break;\n\n      case 'nw':\n        this.cdkAnchors.nw = { x: 0, y: 0 };\n        break;\n    }\n  }\n\n  resizeDirection(direction: string) {\n    this.position.resize = this.position.next;\n\n    switch (direction) {\n      case 'n':\n        //Checks that the new position and dimesions produce a minHeight lower than the required\n        if (this.size.height.previous - this.anchor.y >= this.minHeight) {\n          this.position.resize = {\n            x: this.position.resize.x,\n            y: this.position.next.y + this.anchor.y,\n          };\n\n          this.size.height.current = this.size.height.previous - this.anchor.y;\n          this.size.height.current = this.clampHeight(\n            this.componentElement,\n            this.size.height.current,\n            this.minHeight\n          );\n\n          this.position.current = {\n            x: this.position.current.x,\n            y: this.position.resize.y,\n          };\n        }\n        break;\n\n      case 'e':\n        this.size.width.current = this.size.width.previous + this.anchor.x;\n        this.size.width.current = this.clampWidth(\n          this.componentElement,\n          this.size.width.current,\n          this.minWidth\n        );\n\n        break;\n\n      case 's':\n        this.size.height.current = this.size.height.previous + this.anchor.y;\n        this.size.height.current = this.clampHeight(\n          this.componentElement,\n          this.size.height.current,\n          this.minHeight\n        );\n\n        break;\n\n      case 'w':\n        //Checks that the new position and dimesions produce a minHeight lower than the required\n        if (this.size.width.previous - this.anchor.x >= this.minWidth) {\n          this.position.resize = {\n            x: this.position.next.x + this.anchor.x,\n            y: this.position.resize.y,\n          };\n\n          this.size.width.current = this.size.width.previous - this.anchor.x;\n          this.size.width.current = this.clampWidth(\n            this.componentElement,\n            this.size.width.current,\n            this.minWidth\n          );\n\n          this.position.current = {\n            x: this.position.resize.x,\n            y: this.position.current.y,\n          };\n        }\n        break;\n    }\n  }\n\n  endResize() {\n    this.position.next = this.position.current;\n  }\n\n  //When releasing the os-window the user may leave it outside of the browser window\n  //which would make it imposible to interact with the component again,\n  //this makes the window 'bounce' back into sight\n  correctEndPosition(event: CdkDragEnd) {\n    this.position.next = event.source.getFreeDragPosition();\n\n    //Fix for Y position, the window-bar will always be visible\n    if (this.position.next.y < window.innerHeight) {\n      this.position.next.y = window.innerHeight;\n    } else if (this.position.next.y > window.innerHeight * 2 - 40) {\n      this.position.next.y = window.innerHeight * 2 - 40;\n    }\n\n    //Fix for X position, a quarter of the window will always be visible\n    if (this.position.next.x < -((this.size.width.current / 4) * 3)) {\n      this.position.next.x = -((this.size.width.current / 4) * 3);\n    } else if (\n      this.position.next.x >\n      window.innerWidth - this.size.width.current / 4\n    ) {\n      this.position.next.x = window.innerWidth - this.size.width.current / 4;\n    }\n\n    this.position.current = this.position.next;\n  }\n\n  //////////////////////////////\n  //  Other user interaction  //\n  //////////////////////////////\n\n  //When a window is clicked we want to change it's z-index value and apply some styles\n  focus() {\n    //We get the current global z-index\n    this.position.zIndex.next = this.globalConfigService.getZIndex();\n\n    //This will be unequal if another window has been focused on\n    if (this.position.zIndex.current != this.position.zIndex.next) {\n      this.position.zIndex.next++;\n      this.position.zIndex.current = this.position.zIndex.next;\n\n      //Updating global z-index\n      this.globalConfigService.setZIndex(this.position.zIndex.current);\n    }\n\n    //After that we remove the 'focused' class from all the windows\n    let focused = document.getElementsByClassName('focused');\n    let i: number = 0;\n    while (i < focused.length) {\n      this.renderer.removeClass(focused[i], 'focused');\n      i++;\n    }\n\n    //We add the 'focused' class to the current window\n    this.renderer.addClass(\n      this.componentElement.nativeElement.firstChild,\n      'focused'\n    );\n  }\n}\n"]}