@hmcts/annotation-ui-lib
Version:
PDF Viewer and ability to highlight text with and comment tracking
198 lines • 18.3 kB
JavaScript
/**
* @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"]}