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