UNPKG

@hmcts/media-viewer

Version:
118 lines 19.2 kB
import { Component, EventEmitter, Input, Output } from '@angular/core'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; export class CtxToolbarComponent { constructor() { this.createHighlightEvent = new EventEmitter(); this.deleteHighlightEvent = new EventEmitter(); this.addOrEditCommentEvent = new EventEmitter(); this.createBookmarkEvent = new EventEmitter(); this.defaultHeight = 70; this.defaultWidth = 300; } ngOnChanges(changes) { this.setRectangle(); this.top = this.popupTop(); this.left = this.popupLeft(); } set rectangles(rectangles) { if (rectangles) { this._rectangles = rectangles; this.setRectangle(); } } get rectangles() { return this._rectangles; } createHighlight() { this.createHighlightEvent.emit(); this.rectangle = undefined; } deleteHighlight() { this.deleteHighlightEvent.emit(); } addOrEditComment() { this.addOrEditCommentEvent.emit(); setTimeout(() => { if (!location.hash) { document.getElementById('viewerContainer').scrollBy(0, 1); } }, 10); } createBookmark() { this.createBookmarkEvent.emit(this.rectangle); this.rectangle = undefined; } setRectangle() { const rectangle = this.rectangles .reduce((prev, current) => prev.y < current.y ? prev : current); this.rectangle = { ...rectangle }; switch (this.rotate) { case 90: this.rectangle.width = rectangle.height; this.rectangle.height = rectangle.width; this.rectangle.x = (this.pageWidth / this.zoom) - rectangle.y - rectangle.height; this.rectangle.y = rectangle.x; break; case 180: this.rectangle.x = (this.pageWidth / this.zoom) - rectangle.x - rectangle.width; this.rectangle.y = (this.pageHeight / this.zoom) - rectangle.y - rectangle.height; break; case 270: this.rectangle.width = rectangle.height; this.rectangle.height = rectangle.width; this.rectangle.x = rectangle.y; this.rectangle.y = (this.pageHeight / this.zoom) - rectangle.x - rectangle.width; break; } } popupTop() { const popupTop = this.rectangle.y * this.zoom - this.defaultHeight; return popupTop <= 0 ? this.defaultHeight : popupTop; } popupLeft() { const popupLeft = (this.rectangle.x + (this.rectangle.width / 2)) * this.zoom - (this.defaultWidth / 2); if (popupLeft <= 0) { return 0; } else if (popupLeft >= this.pageWidth - this.defaultWidth) { return this.pageWidth - this.defaultWidth; } else { return popupLeft; } } /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CtxToolbarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); } /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CtxToolbarComponent, selector: "mv-ctx-toolbar", inputs: { zoom: "zoom", rotate: "rotate", pageHeight: "pageHeight", pageWidth: "pageWidth", canHighlight: "canHighlight", canBookmark: "canBookmark", canComment: "canComment", canDelete: "canDelete", rectangles: "rectangles" }, outputs: { createHighlightEvent: "createHighlightEvent", deleteHighlightEvent: "deleteHighlightEvent", addOrEditCommentEvent: "addOrEditCommentEvent", createBookmarkEvent: "createBookmarkEvent" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"toolbar\" *ngIf=\"rectangle\"\n [style.top.px]=\"top\"\n [style.left.px]=\"left\">\n <button *ngIf=\"canHighlight\"\n type=\"button\" title=\"Highlight\"\n class=\"aui__toolbar-button aui__toolbar-button--comments contextual-btn leftButton aui__toolbar-button-highlight\"\n (mousedown)=\"createHighlight()\">\n <span>Highlight</span>\n </button>\n <button *ngIf=\"canDelete\"\n type=\"button\" title=\"Delete\"\n class=\"aui__toolbar-button aui__toolbar-button--comments contextual-btn leftButton\"\n (mousedown)=\"deleteHighlight()\">\n <span>Remove</span>\n </button>\n <button *ngIf=\"canComment\"\n type=\"button\" title=\"Comment\"\n class=\"aui__toolbar-button aui__toolbar-button--comments contextual-btn rightButton aui__toolbar-button-comment\"\n (mousedown)=\"addOrEditComment()\">\n <span>Comment</span></button>\n <button *ngIf=\"canBookmark\"\n type=\"button\" title=\"Bookmark\"\n class=\"aui__toolbar-button aui__toolbar-button--comments contextual-btn rightButton aui__toolbar-button-bookmark\"\n id=\"bookmarkButton\"\n (mousedown)=\"createBookmark()\">\n <span>Bookmark</span></button>\n <div class=\"arrow-down\">\n <div class=\"inner-triangle\"></div>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CtxToolbarComponent, decorators: [{ type: Component, args: [{ selector: 'mv-ctx-toolbar', template: "<div class=\"toolbar\" *ngIf=\"rectangle\"\n [style.top.px]=\"top\"\n [style.left.px]=\"left\">\n <button *ngIf=\"canHighlight\"\n type=\"button\" title=\"Highlight\"\n class=\"aui__toolbar-button aui__toolbar-button--comments contextual-btn leftButton aui__toolbar-button-highlight\"\n (mousedown)=\"createHighlight()\">\n <span>Highlight</span>\n </button>\n <button *ngIf=\"canDelete\"\n type=\"button\" title=\"Delete\"\n class=\"aui__toolbar-button aui__toolbar-button--comments contextual-btn leftButton\"\n (mousedown)=\"deleteHighlight()\">\n <span>Remove</span>\n </button>\n <button *ngIf=\"canComment\"\n type=\"button\" title=\"Comment\"\n class=\"aui__toolbar-button aui__toolbar-button--comments contextual-btn rightButton aui__toolbar-button-comment\"\n (mousedown)=\"addOrEditComment()\">\n <span>Comment</span></button>\n <button *ngIf=\"canBookmark\"\n type=\"button\" title=\"Bookmark\"\n class=\"aui__toolbar-button aui__toolbar-button--comments contextual-btn rightButton aui__toolbar-button-bookmark\"\n id=\"bookmarkButton\"\n (mousedown)=\"createBookmark()\">\n <span>Bookmark</span></button>\n <div class=\"arrow-down\">\n <div class=\"inner-triangle\"></div>\n </div>\n</div>\n" }] }], ctorParameters: () => [], propDecorators: { zoom: [{ type: Input }], rotate: [{ type: Input }], pageHeight: [{ type: Input }], pageWidth: [{ type: Input }], canHighlight: [{ type: Input }], canBookmark: [{ type: Input }], canComment: [{ type: Input }], canDelete: [{ type: Input }], createHighlightEvent: [{ type: Output }], deleteHighlightEvent: [{ type: Output }], addOrEditCommentEvent: [{ type: Output }], createBookmarkEvent: [{ type: Output }], rectangles: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ctx-toolbar.component.js","sourceRoot":"","sources":["../../../../../../../projects/media-viewer/src/lib/annotations/annotation-set/ctx-toolbar/ctx-toolbar.component.ts","../../../../../../../projects/media-viewer/src/lib/annotations/annotation-set/ctx-toolbar/ctx-toolbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges\n} from '@angular/core';\nimport { Rectangle } from '../annotation-view/rectangle/rectangle.model';\n\n@Component({\n  selector: 'mv-ctx-toolbar',\n  templateUrl: './ctx-toolbar.component.html'\n})\nexport class CtxToolbarComponent implements OnChanges {\n\n  readonly defaultHeight;\n  readonly defaultWidth;\n\n  @Input() zoom;\n  @Input() rotate;\n  @Input() pageHeight: number;\n  @Input() pageWidth: number;\n\n  @Input() canHighlight: boolean;\n  @Input() canBookmark: boolean;\n  @Input() canComment: boolean;\n  @Input() canDelete: boolean;\n\n  @Output() createHighlightEvent = new EventEmitter();\n  @Output() deleteHighlightEvent = new EventEmitter();\n  @Output() addOrEditCommentEvent = new EventEmitter();\n  @Output() createBookmarkEvent = new EventEmitter<Rectangle>();\n\n  rectangle: Rectangle;\n  _rectangles: Rectangle[];\n  top: number;\n  left: number;\n\n  constructor() {\n    this.defaultHeight = 70;\n    this.defaultWidth = 300;\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    this.setRectangle();\n    this.top = this.popupTop();\n    this.left = this.popupLeft();\n  }\n\n  @Input() set rectangles(rectangles: Rectangle[]) {\n    if (rectangles) {\n      this._rectangles = rectangles;\n      this.setRectangle();\n    }\n  }\n\n  get rectangles() {\n    return this._rectangles;\n  }\n\n  createHighlight() {\n    this.createHighlightEvent.emit();\n    this.rectangle = undefined;\n  }\n\n  deleteHighlight() {\n    this.deleteHighlightEvent.emit();\n  }\n\n  addOrEditComment() {\n    this.addOrEditCommentEvent.emit();\n    setTimeout(() => {\n      if (!location.hash) {\n        document.getElementById('viewerContainer').scrollBy(0, 1);\n      }\n    }, 10);\n  }\n\n  createBookmark() {\n    this.createBookmarkEvent.emit(this.rectangle);\n    this.rectangle = undefined;\n  }\n\n  setRectangle() {\n    const rectangle = this.rectangles\n      .reduce((prev, current) => prev.y < current.y ? prev : current);\n    this.rectangle =  { ...rectangle };\n    switch (this.rotate) {\n      case 90:\n        this.rectangle.width = rectangle.height;\n        this.rectangle.height = rectangle.width;\n        this.rectangle.x = (this.pageWidth / this.zoom) - rectangle.y - rectangle.height;\n        this.rectangle.y = rectangle.x;\n        break;\n      case 180:\n        this.rectangle.x = (this.pageWidth / this.zoom) - rectangle.x - rectangle.width;\n        this.rectangle.y = (this.pageHeight / this.zoom) - rectangle.y - rectangle.height;\n        break;\n      case 270:\n        this.rectangle.width = rectangle.height;\n        this.rectangle.height = rectangle.width;\n        this.rectangle.x = rectangle.y;\n        this.rectangle.y = (this.pageHeight / this.zoom) - rectangle.x - rectangle.width;\n        break;\n    }\n  }\n\n  popupTop() {\n    const popupTop = this.rectangle.y * this.zoom - this.defaultHeight;\n    return popupTop <= 0 ? this.defaultHeight : popupTop;\n  }\n\n  popupLeft() {\n    const popupLeft = (this.rectangle.x + (this.rectangle.width / 2)) * this.zoom - (this.defaultWidth / 2);\n    if (popupLeft <= 0) {\n      return 0;\n    } else if (popupLeft >= this.pageWidth - this.defaultWidth) {\n      return this.pageWidth - this.defaultWidth;\n    } else {\n      return popupLeft;\n    }\n  }\n}\n","<div class=\"toolbar\" *ngIf=\"rectangle\"\n     [style.top.px]=\"top\"\n     [style.left.px]=\"left\">\n  <button *ngIf=\"canHighlight\"\n          type=\"button\" title=\"Highlight\"\n          class=\"aui__toolbar-button aui__toolbar-button--comments contextual-btn leftButton aui__toolbar-button-highlight\"\n          (mousedown)=\"createHighlight()\">\n    <span>Highlight</span>\n  </button>\n  <button *ngIf=\"canDelete\"\n          type=\"button\" title=\"Delete\"\n          class=\"aui__toolbar-button aui__toolbar-button--comments contextual-btn leftButton\"\n          (mousedown)=\"deleteHighlight()\">\n    <span>Remove</span>\n  </button>\n  <button *ngIf=\"canComment\"\n          type=\"button\" title=\"Comment\"\n          class=\"aui__toolbar-button aui__toolbar-button--comments contextual-btn rightButton aui__toolbar-button-comment\"\n          (mousedown)=\"addOrEditComment()\">\n    <span>Comment</span></button>\n  <button *ngIf=\"canBookmark\"\n          type=\"button\" title=\"Bookmark\"\n          class=\"aui__toolbar-button aui__toolbar-button--comments contextual-btn rightButton aui__toolbar-button-bookmark\"\n          id=\"bookmarkButton\"\n          (mousedown)=\"createBookmark()\">\n    <span>Bookmark</span></button>\n  <div class=\"arrow-down\">\n    <div class=\"inner-triangle\"></div>\n  </div>\n</div>\n"]}