UNPKG

@hmcts/annotation-ui-lib

Version:

PDF Viewer and ability to highlight text with and comment tracking

411 lines 40.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Input, Output, EventEmitter, ViewChild, ChangeDetectorRef, ElementRef, Renderer2 } from '@angular/core'; import { NgForm } from '@angular/forms'; import { Annotation, Comment } from '../../../../data/annotation-set.model'; import { AnnotationStoreService } from '../../../../data/annotation-store.service'; import { PdfService } from '../../../../data/pdf.service'; import { Utils } from '../../../../data/utils'; import { EmLoggerService } from '../../../../logging/em-logger.service'; import { PdfRenderService } from '../../../../data/pdf-render.service'; export class CommentItemComponent { /** * @param {?} annotationStoreService * @param {?} pdfService * @param {?} pdfRenderService * @param {?} ref * @param {?} renderer * @param {?} utils * @param {?} log */ constructor(annotationStoreService, pdfService, pdfRenderService, ref, renderer, utils, log) { this.annotationStoreService = annotationStoreService; this.pdfService = pdfService; this.pdfRenderService = pdfRenderService; this.ref = ref; this.renderer = renderer; this.utils = utils; this.log = log; this.commentSubmitted = new EventEmitter(); this.commentRendered = new EventEmitter(); this.model = new Comment(null, null, null, null, null, null, null, null, null); this.log.setClass('CommentItemComponent'); } /** * @return {?} */ ngOnInit() { this.hideButton = true; this.focused = false; this.sliceComment = this.comment.content; this.commentFocusSub = this.annotationStoreService.getCommentFocusSubject() .subscribe((options) => { if (options.annotation.id === this.comment.annotationId) { if (options.showButton) { this.onEdit(); } else { this.handleShowBtn(); } this.ref.detectChanges(); } else { this.onBlur(); } }); this.commentBtnSub = this.annotationStoreService.getCommentBtnSubject() .subscribe((commentId) => { (commentId === this.comment.id) ? this.handleShowBtn() : this.handleHideBtn(); }); this.dataLoadedSub = this.pdfRenderService.getDataLoadedSub() .subscribe((dataLoaded) => { if (dataLoaded) { this.annotationTopPos = this.getRelativePosition(this.comment.annotationId); this.commentTopPos = this.annotationTopPos; this.utils.sortByX(this.annotation.rectangles, true); this.annotationHeight = this.utils.getAnnotationLineHeight(this.annotation.rectangles); this.annotationLeftPos = this.annotation.rectangles[0].x; this.commentRendered.emit(true); this.collapseComment(); } }); this.commentItem.statusChanges.subscribe(() => { if (this.focused) { this.expandComment(); } }); } /** * @return {?} */ setHeight() { this.renderer.setStyle(this.commentArea.nativeElement, 'height', 'fit-content'); this.renderer.setStyle(this.commentArea.nativeElement, 'height', (this.commentArea.nativeElement.scrollHeight) + 'px'); this.commentHeight = this.commentSelector.nativeElement.getBoundingClientRect().height; this.commentRendered.emit(true); if (!this.ref['destroyed']) { this.ref.detectChanges(); } } /** * @return {?} */ ngOnDestroy() { if (this.commentFocusSub) { this.commentFocusSub.unsubscribe(); } if (this.commentBtnSub) { this.commentBtnSub.unsubscribe(); } if (this.dataLoadedSub) { this.dataLoadedSub.unsubscribe(); } } /** * @return {?} */ onSubmit() { /** @type {?} */ const comment = this.convertFormToComment(this.commentItem); this.annotationStoreService.editComment(comment); this.commentSubmitted.emit(this.annotation); this.viewOnly(); } /** * @return {?} */ onEdit() { this.editOnly(); } /** * @return {?} */ onCancel() { this.renderer.setProperty(this.commentArea.nativeElement, 'value', this.comment.content); this.viewOnly(); } /** * @return {?} */ viewOnly() { this.renderer.addClass(this.commentArea.nativeElement, 'view-mode'); this.focused = false; } /** * @return {?} */ editOnly() { this.focused = true; this.renderer.removeClass(this.commentArea.nativeElement, 'view-mode'); } /** * @return {?} */ isModified() { if (this.comment.createdDate === null) { return false; } else if (this.comment.lastModifiedBy === null) { return false; } else if (this.comment.createdDate === this.comment.lastModifiedDate) { return false; } else { return true; } } /** * @return {?} */ onBlur() { if (!this.ref['destroyed']) { this.ref.detectChanges(); } } /** * @param {?} commentForm * @return {?} */ convertFormToComment(commentForm) { return new Comment(this.comment.id, this.comment.annotationId, null, null, new Date(), null, null, null, commentForm.value.content); } /** * @return {?} */ handleDeleteComment() { this.annotationStoreService.deleteComment(this.comment.id); } /** * @param {?} event * @return {?} */ handleCommentClick(event) { event.stopPropagation(); this.annotationStoreService.setCommentBtnSubject(this.comment.id); this.annotationStoreService.setAnnotationFocusSubject(this.annotation); } /** * @return {?} */ handleShowBtn() { new Promise(resolve => { this.hideButton = false; this.expandComment(); resolve('Success'); }).then(() => { this.setHeight(); setTimeout(() => { this.commentArea.nativeElement.focus(); }); }); } /** * @return {?} */ handleHideBtn() { new Promise(resolve => { if (!this.commentItem.value.content) { this.annotationStoreService.deleteComment(this.comment.id); } this.focused = false; this.hideButton = true; this.collapseComment(); resolve('Success'); }).then(() => { this.setHeight(); }); } /** * @return {?} */ collapseComment() { new Promise(resolve => { this.expandComment(); resolve('Success'); }).then(() => { if (!this.isCommentEmpty()) { this.shrinkComment(); } this.renderer.addClass(this.commentArea.nativeElement, 'collapsed'); this.renderer.removeClass(this.commentArea.nativeElement, 'expanded'); this.renderer.addClass(this.detailsWrapper.nativeElement, 'collapsed'); this.renderer.addClass(this.commentArea.nativeElement, 'view-mode'); this.setHeight(); }); } /** * @return {?} */ isCommentEmpty() { return this.comment.content === null; } /** * @return {?} */ isShrinkable() { return this.commentArea.nativeElement.scrollHeight > 31; } /** * @return {?} */ shrinkComment() { if (this.isShrinkable()) { this.sliceComment = this.removeMultipleLines().slice(0, 20) + '...'; } } /** * @return {?} */ removeMultipleLines() { return this.comment.content.split('\n').join(' '); } /** * @return {?} */ expandComment() { this.renderer.addClass(this.commentArea.nativeElement, 'expanded'); this.renderer.removeClass(this.commentArea.nativeElement, 'collapsed'); this.renderer.removeClass(this.detailsWrapper.nativeElement, 'collapsed'); this.renderer.addClass(this.detailsWrapper.nativeElement, 'expanded'); this.sliceComment = this.comment.content; this.setHeight(); } /** * @param {?} annotationId * @return {?} */ getRelativePosition(annotationId) { /** @type {?} */ const svgSelector = this.pdfRenderService.getViewerElementRef().nativeElement .querySelector(`g[data-pdf-annotate-id="${annotationId}"]`); if (svgSelector === null) { return null; } else { /** @type {?} */ const highlightRect = (/** @type {?} */ (svgSelector.getBoundingClientRect())); /** @type {?} */ const wrapperRect = (/** @type {?} */ (this.pdfService.getAnnotationWrapper().nativeElement.getBoundingClientRect())); return (highlightRect.y - wrapperRect.top); } } } CommentItemComponent.decorators = [ { type: Component, args: [{ selector: 'app-comment-item', template: "<form class=\"aui-comment comment-list-item\"\n (ngSubmit)=\"onSubmit()\"\n #commentSelector\n #commentItem=\"ngForm\"\n (click)=\"handleCommentClick($event)\"\n [style.top.px]=\"commentTopPos\">\n <div #detailsWrapper id=\"detailsWrapper\" class=\"aui-comment__header\">\n <span *ngIf=\"comment.createdByDetails\" class=\"aui-comment__author\">{{comment.createdByDetails.forename}} {{comment.createdByDetails.surname}}</span>\n <time #commentDate class=\"aui-comment__meta\" ng-controller=\"datCtrl\">{{ comment.createdDate | date: 'd MMMM y h:mm a' }}</time>\n <div *ngIf=\"false\">\n <span>modified By: {{comment.lastModifiedByDetails.forename}} {{comment.lastModifiedByDetails.surname}}</span>\n <time class=\"aui-comment__meta\" ng-controller=\"datCtrl\"><br>{{ comment.lastModifiedDate | date: 'd MMMM y h:mm a' }}</time>\n </div>\n </div>\n\n <textarea\n #commentArea\n (blur)=\"onBlur()\"\n type=\"text\"\n [class.mimic-focus]=\"focused\"\n class=\"aui-comment__content form-control mimic-focus view-mode\"\n required\n [ngModel]=\"sliceComment\" name=\"content\"\n value=\"comment.content\"\n [readonly]=\"!focused\"></textarea>\n\n <div [hidden]=\"hideButton\" class=\"aui-comment__footer commentBtns\">\n <button *ngIf=\"focused\" type=\"submit\" class=\"govuk-button\" role=\"button\">Save</button>\n <button *ngIf=\"!focused\" (click)=\"onEdit()\" class=\"govuk-button\" role=\"button\">Edit</button>\n <button\n *ngIf=\"!focused\"\n class=\"govuk-button hmcts hmcts-button--secondary\"\n role=\"button\"\n (click)=\"handleDeleteComment()\">Delete</button>\n <button\n *ngIf=\"focused\"\n class=\"govuk-button hmcts hmcts-button--secondary\"\n role=\"button\"\n (click)=\"onCancel()\">Cancel</button>\n </div>\n</form>\n", styles: ["form{width:95%;margin-bottom:5px;position:absolute;background-color:#fff;padding:20px 20px 0}form textarea{width:95%;padding:2px;border:none;font-size:17px;font-family:nta,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-weight:400;overflow:hidden;resize:none}.mimic-focus{outline-offset:-2px;outline:#0b0c0c auto 5px}textarea.view-mode:focus{outline:0}#detailsWrapper{padding:0}#detailsWrapper.expanded{margin-bottom:15px}.commentBtns{height:50px}.expanded{margin-top:0}.collapsed{height:30px}textarea.expanded{margin-bottom:10px}textarea.collapsed{margin-top:-25px;max-height:20px}.collapsed>time{display:none}"] }] } ]; CommentItemComponent.ctorParameters = () => [ { type: AnnotationStoreService }, { type: PdfService }, { type: PdfRenderService }, { type: ChangeDetectorRef }, { type: Renderer2 }, { type: Utils }, { type: EmLoggerService } ]; CommentItemComponent.propDecorators = { comment: [{ type: Input }], annotation: [{ type: Input }], commentSubmitted: [{ type: Output }], commentRendered: [{ type: Output }], commentSelector: [{ type: ViewChild, args: ['commentSelector',] }], commentArea: [{ type: ViewChild, args: ['commentArea',] }], commentItem: [{ type: ViewChild, args: ['commentItem',] }], detailsWrapper: [{ type: ViewChild, args: ['detailsWrapper',] }], commentDate: [{ type: ViewChild, args: ['commentDate',] }] }; if (false) { /** * @type {?} * @private */ CommentItemComponent.prototype.commentBtnSub; /** * @type {?} * @private */ CommentItemComponent.prototype.commentFocusSub; /** * @type {?} * @private */ CommentItemComponent.prototype.dataLoadedSub; /** @type {?} */ CommentItemComponent.prototype.hideButton; /** @type {?} */ CommentItemComponent.prototype.focused; /** @type {?} */ CommentItemComponent.prototype.sliceComment; /** @type {?} */ CommentItemComponent.prototype.comment; /** @type {?} */ CommentItemComponent.prototype.annotation; /** @type {?} */ CommentItemComponent.prototype.commentSubmitted; /** @type {?} */ CommentItemComponent.prototype.commentRendered; /** @type {?} */ CommentItemComponent.prototype.commentSelector; /** @type {?} */ CommentItemComponent.prototype.commentArea; /** @type {?} */ CommentItemComponent.prototype.commentItem; /** @type {?} */ CommentItemComponent.prototype.detailsWrapper; /** @type {?} */ CommentItemComponent.prototype.commentDate; /** @type {?} */ CommentItemComponent.prototype.model; /** @type {?} */ CommentItemComponent.prototype.commentTopPos; /** @type {?} */ CommentItemComponent.prototype.commentHeight; /** @type {?} */ CommentItemComponent.prototype.annotationTopPos; /** @type {?} */ CommentItemComponent.prototype.annotationLeftPos; /** @type {?} */ CommentItemComponent.prototype.annotationHeight; /** * @type {?} * @private */ CommentItemComponent.prototype.annotationStoreService; /** * @type {?} * @private */ CommentItemComponent.prototype.pdfService; /** * @type {?} * @private */ CommentItemComponent.prototype.pdfRenderService; /** * @type {?} * @private */ CommentItemComponent.prototype.ref; /** * @type {?} * @private */ CommentItemComponent.prototype.renderer; /** * @type {?} * @private */ CommentItemComponent.prototype.utils; /** * @type {?} * @private */ CommentItemComponent.prototype.log; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"comment-item.component.js","sourceRoot":"ng://@hmcts/annotation-ui-lib/","sources":["lib/viewers/annotation-pdf-viewer/comments/comment-item/comment-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnInit, Input, Output, EventEmitter, ViewChild, OnDestroy, ChangeDetectorRef, ElementRef, Renderer2} from '@angular/core';\nimport {NgForm} from '@angular/forms';\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 { Utils } from '../../../../data/utils';\nimport { EmLoggerService } from '../../../../logging/em-logger.service';\nimport { PdfRenderService } from '../../../../data/pdf-render.service';\n\n@Component({\n    selector: 'app-comment-item',\n    templateUrl: './comment-item.component.html',\n    styleUrls: ['./comment-item.component.scss']\n})\nexport class CommentItemComponent implements OnInit, OnDestroy {\n\n    private commentBtnSub: Subscription;\n    private commentFocusSub: Subscription;\n    private dataLoadedSub: Subscription;\n    hideButton: boolean;\n    focused: boolean;\n    sliceComment: string;\n\n    @Input() comment: Comment;\n    @Input() annotation: Annotation;\n\n    @Output() commentSubmitted: EventEmitter<any> = new EventEmitter<any>();\n    @Output() commentRendered: EventEmitter<any> = new EventEmitter<any>();\n    @ViewChild('commentSelector') commentSelector: ElementRef;\n    @ViewChild('commentArea') commentArea: ElementRef;\n    @ViewChild('commentItem') commentItem: NgForm;\n    @ViewChild('detailsWrapper') detailsWrapper: ElementRef;\n    @ViewChild('commentDate') commentDate: ElementRef;\n    \n    model = new Comment(null, null, null, null, null, null, null, null, null);\n    commentTopPos: number;\n    commentHeight: number;\n    annotationTopPos: number;\n    annotationLeftPos: number;\n    annotationHeight: number;\n    \n    constructor(private annotationStoreService: AnnotationStoreService,\n                private pdfService: PdfService,\n                private pdfRenderService: PdfRenderService,\n                private ref: ChangeDetectorRef,\n                private renderer: Renderer2,\n                private utils: Utils,\n                private log: EmLoggerService) {\n        this.log.setClass('CommentItemComponent');\n    }\n\n    ngOnInit() {\n        this.hideButton = true;\n        this.focused = false;\n        this.sliceComment = this.comment.content;\n\n        this.commentFocusSub = this.annotationStoreService.getCommentFocusSubject()\n            .subscribe((options) => {\n                if (options.annotation.id === this.comment.annotationId) {\n\n                    if (options.showButton) {\n                        this.onEdit();\n                    } else {\n                        this.handleShowBtn();\n                    }\n                    \n                    this.ref.detectChanges();\n                } else {\n                    this.onBlur();\n                }\n        });\n\n        this.commentBtnSub = this.annotationStoreService.getCommentBtnSubject()\n            .subscribe((commentId) => {\n                (commentId === this.comment.id) ? this.handleShowBtn() : this.handleHideBtn();\n          });\n\n        this.dataLoadedSub = this.pdfRenderService.getDataLoadedSub()\n            .subscribe( (dataLoaded: boolean) => {\n                if (dataLoaded) {\n                    this.annotationTopPos = this.getRelativePosition(this.comment.annotationId);\n                    this.commentTopPos = this.annotationTopPos;\n                    this.utils.sortByX(this.annotation.rectangles, true);\n                    this.annotationHeight = this.utils.getAnnotationLineHeight(this.annotation.rectangles);\n                    this.annotationLeftPos = this.annotation.rectangles[0].x;\n                    this.commentRendered.emit(true);\n                    this.collapseComment();\n                }\n            });\n\n        this.commentItem.statusChanges.subscribe(\n                () => {\n                    if (this.focused) {\n                        this.expandComment();\n                    }\n                }\n            );\n    }\n\n    setHeight() {\n        this.renderer.setStyle(this.commentArea.nativeElement, 'height', 'fit-content');\n        this.renderer.setStyle(this.commentArea.nativeElement, 'height', (this.commentArea.nativeElement.scrollHeight) + 'px');\n        this.commentHeight =  this.commentSelector.nativeElement.getBoundingClientRect().height;\n        this.commentRendered.emit(true);\n        if (!this.ref['destroyed']) {\n            this.ref.detectChanges();\n        }\n    }\n\n    ngOnDestroy() {\n        if (this.commentFocusSub) {\n            this.commentFocusSub.unsubscribe();\n        }\n        if (this.commentBtnSub) {\n            this.commentBtnSub.unsubscribe();\n        }\n        if (this.dataLoadedSub) {\n            this.dataLoadedSub.unsubscribe();\n        }\n    }\n\n    onSubmit() {\n        const comment = this.convertFormToComment(this.commentItem);\n        this.annotationStoreService.editComment(comment);\n        this.commentSubmitted.emit(this.annotation);\n\n        this.viewOnly();\n    }\n\n    onEdit() {\n        this.editOnly();\n    }\n\n    onCancel() {\n        this.renderer.setProperty(this.commentArea.nativeElement, 'value', this.comment.content);\n        this.viewOnly();\n    }\n\n    viewOnly() {\n        this.renderer.addClass(this.commentArea.nativeElement, 'view-mode');\n        this.focused = false;\n    }\n\n    editOnly() {\n        this.focused = true;\n        this.renderer.removeClass(this.commentArea.nativeElement, 'view-mode');\n    }\n\n    isModified(): boolean {\n        if (this.comment.createdDate === null) {\n            return false;\n        } else if (this.comment.lastModifiedBy === null) {\n            return false;\n        } else if (this.comment.createdDate === this.comment.lastModifiedDate) {\n            return false;\n        } else {\n            return true;\n        }\n    }\n\n    onBlur() {\n        if (!this.ref['destroyed']) {\n            this.ref.detectChanges();\n        }\n    }\n\n    convertFormToComment(commentForm: NgForm): Comment {\n        return new Comment(\n            this.comment.id,\n            this.comment.annotationId,\n            null,\n            null,\n            new Date(),\n            null,\n            null,\n            null,\n            commentForm.value.content\n        );\n    }\n\n    handleDeleteComment() {\n        this.annotationStoreService.deleteComment(this.comment.id);\n    }\n\n    handleCommentClick(event: any) {\n        event.stopPropagation();\n        this.annotationStoreService.setCommentBtnSubject(this.comment.id);\n        this.annotationStoreService.setAnnotationFocusSubject(this.annotation);\n    }\n\n    handleShowBtn() {\n        new Promise(resolve => {\n            this.hideButton = false;\n            this.expandComment();\n            resolve('Success');\n        }).then(() => {\n            this.setHeight();\n            setTimeout(() => {\n                this.commentArea.nativeElement.focus();\n            });\n        });\n    }\n\n    handleHideBtn() {\n        new Promise(resolve => {\n            if (!this.commentItem.value.content) {\n                this.annotationStoreService.deleteComment(this.comment.id);\n            }\n            this.focused = false;\n            this.hideButton = true;\n            this.collapseComment();\n            resolve('Success');\n        }).then(() => {\n            this.setHeight();\n        });\n    }\n\n    collapseComment() {\n        new Promise(resolve => {\n            this.expandComment();\n            resolve('Success');\n        }).then(() => {\n            if (!this.isCommentEmpty()) {\n                this.shrinkComment();\n            }\n            this.renderer.addClass(this.commentArea.nativeElement, 'collapsed');\n            this.renderer.removeClass(this.commentArea.nativeElement, 'expanded');\n            this.renderer.addClass(this.detailsWrapper.nativeElement, 'collapsed');\n            this.renderer.addClass(this.commentArea.nativeElement, 'view-mode');\n\n            this.setHeight();\n        });\n    }\n\n    isCommentEmpty(): boolean {\n        return this.comment.content === null;\n    }\n    \n    isShrinkable(): boolean {\n        return this.commentArea.nativeElement.scrollHeight > 31;\n    }\n\n    shrinkComment() {\n        if (this.isShrinkable()) {\n            this.sliceComment = this.removeMultipleLines().slice(0, 20) + '...';\n        }\n    }\n\n    removeMultipleLines(): string {\n        return this.comment.content.split('\\n').join(' ');\n    }\n\n    expandComment() {\n        this.renderer.addClass(this.commentArea.nativeElement, 'expanded');\n        this.renderer.removeClass(this.commentArea.nativeElement, 'collapsed');\n        this.renderer.removeClass(this.detailsWrapper.nativeElement, 'collapsed');\n        this.renderer.addClass(this.detailsWrapper.nativeElement, 'expanded');\n\n        this.sliceComment = this.comment.content;\n        this.setHeight();\n    }\n\n    getRelativePosition(annotationId: string): number {\n        const svgSelector = this.pdfRenderService.getViewerElementRef().nativeElement\n                                .querySelector(`g[data-pdf-annotate-id=\"${annotationId}\"]`);\n        if (svgSelector === null) {\n            return null;\n        } else {\n            const highlightRect = <DOMRect> svgSelector.getBoundingClientRect();\n            const wrapperRect = <DOMRect> this.pdfService.getAnnotationWrapper().nativeElement.getBoundingClientRect();\n\n            return (highlightRect.y - wrapperRect.top);\n        }\n    }\n}\n"]}