@hmcts/media-viewer
Version:
123 lines • 21.3 kB
JavaScript
import { Component, Input, ViewChild, ViewChildren, } from '@angular/core';
import { select } from '@ngrx/store';
import * as fromActions from '../../store/actions/annotation.actions';
import * as fromSelectors from '../../store/selectors/annotation.selectors';
import * as i0 from "@angular/core";
import * as i1 from "@ngrx/store";
import * as i2 from "./comment/comment.service";
import * as i3 from "./comment-set-render.service";
import * as i4 from "../../toolbar/toolbar-event.service";
import * as i5 from "@angular/common";
import * as i6 from "./comment/comment.component";
export class CommentSetComponent {
constructor(store, commentService, renderService, toolbarEvents) {
this.store = store;
this.commentService = commentService;
this.renderService = renderService;
this.toolbarEvents = toolbarEvents;
this.pageHeights = [];
this.subscriptions = [];
this.clearSelection();
}
ngOnInit() {
this.comments$ = this.store.pipe(select(fromSelectors.getCommentsArray));
this.annoEntities$ = this.store.pipe(select(fromSelectors.getAnnotationEntities));
this.subscriptions.push(this.toolbarEvents.commentsPanelVisible.subscribe(toggle => {
this.redrawComments();
this.showCommentsPanel = toggle;
}));
this.subscriptions.push(this.toolbarEvents.rotateSubject.subscribe(rotate => this.rotateDocument()));
}
ngOnChanges(changes) {
if (changes.annotationSet) {
this.commentService.setCommentSet(this);
}
if (changes.contentScrollTop) {
if (this.container) {
this.container.nativeElement.scrollTo(0, this.contentScrollTop);
}
}
}
ngOnDestroy() {
if (this.subscriptions.length > 0) {
this.subscriptions.forEach(subscription => subscription.unsubscribe());
}
}
onSelect(annotationId) {
this.store.dispatch(new fromActions.SelectedAnnotation(annotationId));
}
onCommentDelete(comment) {
const annotation = this.annotationSet.annotations.find(anno => anno.id === comment.annotationId);
const comments = [];
const annot = {
...annotation,
comments
};
this.onAnnotationUpdate(annot);
this.redrawComments();
}
redrawComments() {
setTimeout(() => {
const componentList = this.commentComponents.map(comment => comment);
this.renderService.redrawComponents(componentList, this.pageHeights, this.rotate, this.zoom);
}, 0);
}
rotateDocument() {
if (this.panel) {
this.panel.nativeElement.style.height = '0';
}
}
onCommentUpdate(payload) {
const annotation = this.annotationSet.annotations.find(anno => anno.id === payload.comment.annotationId);
const comments = [payload.comment];
const tags = payload.tags;
const annot = {
...annotation,
comments,
tags
};
this.onAnnotationUpdate(annot);
}
onAnnotationUpdate(annotation) {
this.store.dispatch(new fromActions.SaveAnnotation(annotation));
}
onContainerClick(e) {
if (e.path && e.path[0] === this.panel.nativeElement) {
this.clearSelection();
}
}
clearSelection() {
this.store.dispatch(new fromActions.SelectedAnnotation({ annotationId: '', editable: false, selected: false }));
}
allCommentsSaved() {
this.commentService.allCommentsSaved();
}
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CommentSetComponent, deps: [{ token: i1.Store }, { token: i2.CommentService }, { token: i3.CommentSetRenderService }, { token: i4.ToolbarEventService }], target: i0.ɵɵFactoryTarget.Component }); }
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CommentSetComponent, selector: "mv-comment-set", inputs: { annotationSet: "annotationSet", zoom: "zoom", rotate: "rotate", height: "height", pageHeights: "pageHeights", contentScrollTop: "contentScrollTop" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }, { propertyName: "panel", first: true, predicate: ["panel"], descendants: true }, { propertyName: "commentComponents", predicate: ["commentComponent"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div #container [ngClass]=\"{'comments': showCommentsPanel}\">\n <div #panel [ngClass]=\"{ 'comments-panel comment-container': true, 'expanded': showCommentsPanel }\"\n [style.height.px]=\"height\"\n (click)=\"onContainerClick($event)\">\n <ng-container *ngFor=\"let comment of (comments$ | async); let i = index;\">\n <mv-anno-comment\n [ngStyle]=\"showCommentsPanel ? {} : {'display':'none'}\"\n #commentComponent\n (commentClick)=\"onSelect($event)\"\n (delete)=\"onCommentDelete($event)\"\n (updated)=\"onCommentUpdate($event)\"\n (changes)=\"allCommentsSaved()\"\n [zoom]=\"zoom\"\n [rotate]=\"rotate\"\n [index]=\"i\"\n [page]=\"comment.page\"\n [comment]=\"comment\"\n [annotation]=\"(annoEntities$ | async)[comment.annotationId]\"\n (renderComments)=\"redrawComments()\">\n </mv-anno-comment>\n </ng-container>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i6.CommentComponent, selector: "mv-anno-comment", inputs: ["rotate", "zoom", "index", "page", "comment", "annotation"], outputs: ["commentClick", "renderComments", "delete", "updated", "changes"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CommentSetComponent, decorators: [{
type: Component,
args: [{ selector: 'mv-comment-set', template: "<div #container [ngClass]=\"{'comments': showCommentsPanel}\">\n <div #panel [ngClass]=\"{ 'comments-panel comment-container': true, 'expanded': showCommentsPanel }\"\n [style.height.px]=\"height\"\n (click)=\"onContainerClick($event)\">\n <ng-container *ngFor=\"let comment of (comments$ | async); let i = index;\">\n <mv-anno-comment\n [ngStyle]=\"showCommentsPanel ? {} : {'display':'none'}\"\n #commentComponent\n (commentClick)=\"onSelect($event)\"\n (delete)=\"onCommentDelete($event)\"\n (updated)=\"onCommentUpdate($event)\"\n (changes)=\"allCommentsSaved()\"\n [zoom]=\"zoom\"\n [rotate]=\"rotate\"\n [index]=\"i\"\n [page]=\"comment.page\"\n [comment]=\"comment\"\n [annotation]=\"(annoEntities$ | async)[comment.annotationId]\"\n (renderComments)=\"redrawComments()\">\n </mv-anno-comment>\n </ng-container>\n </div>\n</div>\n" }]
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.CommentService }, { type: i3.CommentSetRenderService }, { type: i4.ToolbarEventService }], propDecorators: { annotationSet: [{
type: Input
}], zoom: [{
type: Input
}], rotate: [{
type: Input
}], height: [{
type: Input
}], pageHeights: [{
type: Input
}], contentScrollTop: [{
type: Input
}], container: [{
type: ViewChild,
args: ['container', { static: false }]
}], panel: [{
type: ViewChild,
args: ['panel', { static: false }]
}], commentComponents: [{
type: ViewChildren,
args: ['commentComponent']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"comment-set.component.js","sourceRoot":"","sources":["../../../../../../projects/media-viewer/src/lib/annotations/comment-set/comment-set.component.ts","../../../../../../projects/media-viewer/src/lib/annotations/comment-set/comment-set.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  Input, OnChanges,\n  OnDestroy,\n  OnInit,\n  QueryList, SimpleChanges,\n  ViewChild,\n  ViewChildren,\n} from '@angular/core';\nimport { Observable, Subscription } from 'rxjs';\nimport { select, Store } from '@ngrx/store';\n\nimport { AnnotationSet } from '../annotation-set/annotation-set.model';\nimport { Annotation } from '../annotation-set/annotation-view/annotation.model';\nimport { Comment } from './comment/comment.model';\nimport { CommentComponent } from './comment/comment.component';\nimport { CommentService } from './comment/comment.service';\nimport { CommentSetRenderService } from './comment-set-render.service';\nimport * as fromStore from '../../store/reducers/reducers';\nimport * as fromActions from '../../store/actions/annotation.actions';\nimport * as fromSelectors from '../../store/selectors/annotation.selectors';\nimport { TagsModel } from '../models/tags.model';\nimport { SelectionAnnotation } from '../models/event-select.model';\nimport { ToolbarEventService } from '../../toolbar/toolbar-event.service';\n\n@Component({\n  selector: 'mv-comment-set',\n  templateUrl: './comment-set.component.html',\n })\nexport class CommentSetComponent implements OnInit, OnDestroy, OnChanges {\n\n  @Input() annotationSet: AnnotationSet;\n  @Input() zoom: number;\n  @Input() rotate: number;\n  @Input() height: number;\n  @Input() pageHeights = [];\n  @Input() contentScrollTop: number;\n\n  comments: Comment[];\n  tags: TagsModel[];\n  private subscriptions: Subscription[] = [];\n  public comments$: Observable<Annotation[]>;\n  public annoEntities$: Observable<{ [id: string]: Annotation }>;\n\n  @ViewChild('container', {static: false}) container: ElementRef<HTMLDivElement>;\n  @ViewChild('panel', {static: false}) panel: ElementRef<HTMLDivElement>;\n  @ViewChildren('commentComponent') commentComponents: QueryList<CommentComponent>;\n\n  showCommentsPanel: boolean;\n\n  constructor(private store: Store<fromStore.AnnotationSetState>,\n              private readonly commentService: CommentService,\n              private readonly renderService: CommentSetRenderService,\n              private readonly toolbarEvents: ToolbarEventService) {\n    this.clearSelection();\n  }\n\n  ngOnInit() {\n    this.comments$ = this.store.pipe(select(fromSelectors.getCommentsArray));\n    this.annoEntities$ = this.store.pipe(select(fromSelectors.getAnnotationEntities));\n    this.subscriptions.push(\n      this.toolbarEvents.commentsPanelVisible.subscribe(toggle => {\n        this.redrawComments();\n        this.showCommentsPanel = toggle;\n      })\n    );\n    this.subscriptions.push(this.toolbarEvents.rotateSubject.subscribe(rotate => this.rotateDocument()));\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.annotationSet) {\n      this.commentService.setCommentSet(this);\n    }\n    if (changes.contentScrollTop) {\n      if (this.container) {\n        this.container.nativeElement.scrollTo(0, this.contentScrollTop);\n      }\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.subscriptions.length > 0) {\n      this.subscriptions.forEach(subscription => subscription.unsubscribe());\n    }\n  }\n\n  public onSelect(annotationId: SelectionAnnotation) {\n    this.store.dispatch(new fromActions.SelectedAnnotation(annotationId));\n  }\n\n  public onCommentDelete(comment: Comment) {\n    const annotation = this.annotationSet.annotations.find(anno => anno.id === comment.annotationId);\n    const comments = [];\n    const annot = {\n      ...annotation,\n      comments\n    };\n    this.onAnnotationUpdate(annot);\n    this.redrawComments();\n  }\n\n  redrawComments() {\n    setTimeout(() => {\n      const componentList: CommentComponent[] = this.commentComponents.map(comment => comment);\n        this.renderService.redrawComponents(componentList, this.pageHeights, this.rotate, this.zoom);\n    }, 0);\n  }\n\n  private rotateDocument() {\n    if (this.panel) {\n      this.panel.nativeElement.style.height = '0';\n    }\n  }\n\n  public onCommentUpdate(payload: {comment: Comment, tags: TagsModel[]} ) {\n    const annotation = this.annotationSet.annotations.find(anno => anno.id === payload.comment.annotationId);\n    const comments = [payload.comment];\n    const tags = payload.tags;\n    const annot = {\n      ...annotation,\n      comments,\n      tags\n    };\n    this.onAnnotationUpdate(annot);\n  }\n\n  public onAnnotationUpdate(annotation: Annotation) {\n    this.store.dispatch(new fromActions.SaveAnnotation(annotation));\n  }\n\n  onContainerClick(e) {\n    if (e.path && e.path[0] === this.panel.nativeElement) {\n      this.clearSelection();\n    }\n  }\n\n  clearSelection() {\n    this.store.dispatch(new fromActions.SelectedAnnotation({ annotationId: '', editable: false, selected: false}));\n  }\n\n  allCommentsSaved() {\n    this.commentService.allCommentsSaved();\n  }\n}\n","<div #container [ngClass]=\"{'comments': showCommentsPanel}\">\n  <div #panel [ngClass]=\"{ 'comments-panel comment-container': true, 'expanded': showCommentsPanel }\"\n     [style.height.px]=\"height\"\n     (click)=\"onContainerClick($event)\">\n    <ng-container *ngFor=\"let comment of (comments$ | async); let i = index;\">\n      <mv-anno-comment\n        [ngStyle]=\"showCommentsPanel ? {} : {'display':'none'}\"\n        #commentComponent\n        (commentClick)=\"onSelect($event)\"\n        (delete)=\"onCommentDelete($event)\"\n        (updated)=\"onCommentUpdate($event)\"\n        (changes)=\"allCommentsSaved()\"\n        [zoom]=\"zoom\"\n        [rotate]=\"rotate\"\n        [index]=\"i\"\n        [page]=\"comment.page\"\n        [comment]=\"comment\"\n        [annotation]=\"(annoEntities$ | async)[comment.annotationId]\"\n        (renderComments)=\"redrawComments()\">\n      </mv-anno-comment>\n    </ng-container>\n  </div>\n</div>\n"]}