UNPKG

@hmcts/annotation-ui-lib

Version:

PDF Viewer and ability to highlight text with and comment tracking

198 lines 18.3 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, ChangeDetectorRef, Output, EventEmitter } from '@angular/core'; import { Comment } from '../../../data/annotation-set.model'; import { AnnotationStoreService } from '../../../data/annotation-store.service'; import { PdfService } from '../../../data/pdf.service'; import { EmLoggerService } from '../../../logging/em-logger.service'; import { PdfRenderService } from '../../../data/pdf-render.service'; export class ContextualToolbarComponent { /** * @param {?} annotationStoreService * @param {?} ref * @param {?} pdfRenderService * @param {?} pdfService * @param {?} log */ constructor(annotationStoreService, ref, pdfRenderService, pdfService, log) { this.annotationStoreService = annotationStoreService; this.ref = ref; this.pdfRenderService = pdfRenderService; this.pdfService = pdfService; this.log = log; this.deletedAnnotation = new EventEmitter(); this.log.setClass('ContextualToolbarComponent'); this.toolPos = { left: 0, top: 0 }; } /** * @return {?} */ ngOnInit() { this.contextualToolBarOptions = this.annotationStoreService.getToolbarUpdate() .subscribe(contextualOptions => { if (contextualOptions.annotation != null) { this.showToolBar(contextualOptions.annotation, contextualOptions.showDelete); } else { this.hideToolBar(); } }); this.isShowToolbar = false; } /** * @return {?} */ ngOnDestroy() { this.ref.detach(); if (this.contextualToolBarOptions) { this.contextualToolBarOptions.unsubscribe(); } } /** * @param {?} annotation * @param {?=} showDelete * @return {?} */ showToolBar(annotation, showDelete) { this.annotation = annotation; this.showDelete = showDelete; this.toolPos = this.getRelativePosition(annotation.id); this.isShowToolbar = true; if (!this.ref['destroyed']) { this.ref.detectChanges(); } } /** * @param {?} annotationId * @return {?} */ getRelativePosition(annotationId) { /** @type {?} */ const svgSelector = this.pdfRenderService.getViewerElementRef().nativeElement .querySelector(`g[data-pdf-annotate-id="${annotationId}"]`); /** @type {?} */ const highlightRect = (/** @type {?} */ (svgSelector.getBoundingClientRect())); /** @type {?} */ const wrapper = this.pdfService.getAnnotationWrapper().nativeElement; /** @type {?} */ const wrapperRect = (/** @type {?} */ (wrapper.getBoundingClientRect())); /** @type {?} */ const left = ((highlightRect.x - wrapperRect.left) - 175) + highlightRect.width / 2; // Minus half the toolbar width + half the length of the highlight /** @type {?} */ const top = ((highlightRect.y - wrapperRect.top) - 59) - 5; return { left, top }; } /** * @return {?} */ hideToolBar() { this.annotation = null; this.isShowToolbar = false; this.showDelete = false; if (!this.ref['destroyed']) { this.ref.detectChanges(); } } /** * @return {?} */ handleCommentBtnClick() { if (this.annotation.comments.length === 0) { this.annotationStoreService.addComment(new Comment(null, this.annotation.id, null, null, null, null, null, null, null)); } setTimeout(() => { /** @type {?} */ const tempAnnotation = this.annotation; this.hideToolBar(); this.annotationStoreService.setCommentFocusSubject(tempAnnotation, true); }, 10); } /** * @return {?} */ handleHighlightBtnClick() { this.hideToolBar(); } /** * @return {?} */ handleDeleteBtnClick() { return tslib_1.__awaiter(this, void 0, void 0, function* () { yield this.annotationStoreService.deleteAnnotationById(this.annotation.id, this.annotation.page); this.hideToolBar(); this.deletedAnnotation.emit('deleted annotation'); }); } } ContextualToolbarComponent.decorators = [ { type: Component, args: [{ selector: 'app-contextual-toolbar', template: "<div [hidden]=\"!isShowToolbar\" class=\"toolbar\"\n [style.left.px]=\"toolPos.left\"\n [style.top.px]=\"toolPos.top\">\n\n <button\n [hidden]=\"showDelete\"\n type=\"button\" class=\"aui__toolbar-button aui__toolbar-button--comments contextual-btn leftButton\"\n title=\"Highlight\"\n (click)=\"handleHighlightBtnClick()\"\n ><span>Add Highlight</span></button>\n\n <button\n [hidden]=\"!showDelete\"\n type=\"button\"\n title=\"Delete\" class=\"aui__toolbar-button aui__toolbar-button--comments contextual-btn leftButton\"\n (click)=\"handleDeleteBtnClick()\"\n ><span>Remove Highlight</span></button>\n\n <button type=\"button\" title=\"Comment\" class=\"aui__toolbar-button aui__toolbar-button--comments contextual-btn rightButton\"\n (click)=\"handleCommentBtnClick()\"\n ><span>Comment</span></button>\n\n\n <div class=\"arrow-down\">\n <div class=\"inner-triangle\"></div>\n </div>\n\n</div>\n", styles: [".toolbar{position:absolute;background-color:#fff;height:52px;width:350px;margin:0 auto;text-shadow:1px 1px 0 #fff;z-index:1;border:1px solid #c1c1c1;box-shadow:0 2px #c1c1c1}.toolbar .spacer{display:inline-block;border-left:1px solid #c1c1c1;height:34px;margin:0 5px -11px}.toolbar button span{margin-left:20px}.toolbar button{padding:0;margin-left:2.5%;margin-right:2.5%;margin-top:6px;height:40px;border:0}.toolbar button:hover{border:1px solid #000}.contextual-btn{font-size:16px;background:5px 50%/20px 20px no-repeat #fff}.rightButton{width:124px;background-image:url(/assets/images/icon-document-comments.svg)}.leftButton{background-image:url(/assets/images/annotate-highlight.svg);width:190px}.arrow-down{margin:53px auto 0;width:0;height:0;border-left:12px solid transparent;border-right:12px solid transparent;border-top:12px solid #c1c1c1}.inner-triangle{position:relative;top:-13px;left:-10px;width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-top:10px solid #fff}"] }] } ]; ContextualToolbarComponent.ctorParameters = () => [ { type: AnnotationStoreService }, { type: ChangeDetectorRef }, { type: PdfRenderService }, { type: PdfService }, { type: EmLoggerService } ]; ContextualToolbarComponent.propDecorators = { deletedAnnotation: [{ type: Output }] }; if (false) { /** @type {?} */ ContextualToolbarComponent.prototype.toolPos; /** @type {?} */ ContextualToolbarComponent.prototype.isShowToolbar; /** @type {?} */ ContextualToolbarComponent.prototype.showDelete; /** @type {?} */ ContextualToolbarComponent.prototype.annotation; /** * @type {?} * @private */ ContextualToolbarComponent.prototype.contextualToolBarOptions; /** @type {?} */ ContextualToolbarComponent.prototype.deletedAnnotation; /** * @type {?} * @private */ ContextualToolbarComponent.prototype.annotationStoreService; /** * @type {?} * @private */ ContextualToolbarComponent.prototype.ref; /** * @type {?} * @private */ ContextualToolbarComponent.prototype.pdfRenderService; /** * @type {?} * @private */ ContextualToolbarComponent.prototype.pdfService; /** * @type {?} * @private */ ContextualToolbarComponent.prototype.log; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contextual-toolbar.component.js","sourceRoot":"ng://@hmcts/annotation-ui-lib/","sources":["lib/viewers/annotation-pdf-viewer/contextual-toolbar/contextual-toolbar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnInit, ChangeDetectorRef, OnDestroy, Output, EventEmitter} from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { Annotation, Comment } from '../../../data/annotation-set.model';\nimport { AnnotationStoreService } from '../../../data/annotation-store.service';\nimport { PdfService } from '../../../data/pdf.service';\nimport { EmLoggerService } from '../../../logging/em-logger.service';\nimport { PdfRenderService } from '../../../data/pdf-render.service';\n\n@Component({\n  selector: 'app-contextual-toolbar',\n  templateUrl: './contextual-toolbar.component.html',\n  styleUrls: ['./contextual-toolbar.component.scss']\n})\nexport class ContextualToolbarComponent implements OnInit, OnDestroy {\n\n  toolPos: {left, top};\n  isShowToolbar: boolean;\n  showDelete: boolean;\n  annotation: Annotation;\n  private contextualToolBarOptions: Subscription;\n\n  @Output() deletedAnnotation = new EventEmitter<string>();\n\n  constructor(private annotationStoreService: AnnotationStoreService,\n              private ref: ChangeDetectorRef,\n              private pdfRenderService: PdfRenderService,\n              private pdfService: PdfService,\n              private log: EmLoggerService) {\n    this.log.setClass('ContextualToolbarComponent');\n    this.toolPos = {\n      left: 0,\n      top: 0\n    };\n  }\n\n  ngOnInit() {\n    this.contextualToolBarOptions = this.annotationStoreService.getToolbarUpdate()\n      .subscribe(contextualOptions => {\n        if (contextualOptions.annotation != null) {\n          this.showToolBar(contextualOptions.annotation, contextualOptions.showDelete);\n        } else {\n          this.hideToolBar();\n        }\n      });\n    this.isShowToolbar = false;\n  }\n\n  ngOnDestroy(): void {\n    this.ref.detach();\n    if (this.contextualToolBarOptions) {\n      this.contextualToolBarOptions.unsubscribe();\n    }\n  }\n\n  showToolBar(annotation: Annotation, showDelete?: boolean) {\n    this.annotation = annotation;\n    this.showDelete = showDelete;\n\n    this.toolPos = this.getRelativePosition(annotation.id);\n    this.isShowToolbar = true;\n\n    if (!this.ref['destroyed']) {\n      this.ref.detectChanges();\n    }\n  }\n\n  getRelativePosition(annotationId: string): {left: number; top: number} {\n    const svgSelector = this.pdfRenderService.getViewerElementRef().nativeElement\n                          .querySelector(`g[data-pdf-annotate-id=\"${annotationId}\"]`);\n    const highlightRect = <DOMRect>svgSelector.getBoundingClientRect();\n\n    const wrapper = this.pdfService.getAnnotationWrapper().nativeElement;\n    const wrapperRect = <DOMRect>wrapper.getBoundingClientRect();\n\n    const left = ((highlightRect.x - wrapperRect.left)\n      - 175) + highlightRect.width / 2; // Minus half the toolbar width + half the length of the highlight\n    const top = ((highlightRect.y - wrapperRect.top)\n      - 59) - 5; // Minus height of toolbar + 5px\n\n    return {\n      left,\n      top\n    };\n  }\n\n  hideToolBar() {\n      this.annotation = null;\n      this.isShowToolbar = false;\n      this.showDelete = false;\n\n      if (!this.ref['destroyed']) {\n        this.ref.detectChanges();\n      }\n  }\n\n  handleCommentBtnClick() {\n    if (this.annotation.comments.length === 0 ) {\n        this.annotationStoreService.addComment(new Comment(null, this.annotation.id, null, null, null, null, null, null, null));\n    }\n    setTimeout(() => {\n        const tempAnnotation = this.annotation;\n        this.hideToolBar();\n        this.annotationStoreService.setCommentFocusSubject(tempAnnotation, true);\n        }, 10);\n  }\n\n  handleHighlightBtnClick() {\n    this.hideToolBar();\n  }\n\n  async handleDeleteBtnClick() {\n    await this.annotationStoreService.deleteAnnotationById(this.annotation.id, this.annotation.page);\n    this.hideToolBar();\n    this.deletedAnnotation.emit('deleted annotation');\n  }\n}\n"]}