@hmcts/media-viewer
Version:
91 lines • 14.6 kB
JavaScript
import { Component, Input, ViewEncapsulation } from '@angular/core';
import * as fromActions from '../../../store/actions/annotation.actions';
import * as i0 from "@angular/core";
import * as i1 from "@ngrx/store";
import * as i2 from "../../../toolbar/toolbar-event.service";
import * as i3 from "@angular/router";
export class CommentsNavigateComponent {
constructor(store, toolbarEvents) {
this.store = store;
this.toolbarEvents = toolbarEvents;
this.autoSelect = false;
this.navigationList = [];
this.index = 0;
}
ngOnChanges(changes) {
if (changes.annotationList) {
this.initNavigationList();
}
}
initNavigationList() {
this.index = 0;
this.navigationList = [...this.annotationList || []]
.map(annotation => ({
content: annotation.comments[0].content,
annotationId: annotation.id,
page: annotation.page,
rectangle: this.upperRectangle(annotation.rectangles),
}))
.sort(this.sortComments);
if (this.autoSelect) {
this.toolbarEvents.setPage(Number.parseInt(this.navigationList[0].page, 0));
this.store.dispatch(new fromActions.SelectedAnnotation({
annotationId: this.navigationList[0].annotationId,
editable: false,
selected: true
}));
}
}
sortComments(mappedCommentA, mappedCommentB) {
if (mappedCommentA.page !== mappedCommentB.page) {
return mappedCommentA.page - mappedCommentB.page;
}
else {
const rectA = mappedCommentA.rectangle;
const rectB = mappedCommentB.rectangle;
if (rectA.y !== rectB.y) {
return rectA.y - rectB.y;
}
else {
return rectA.x - rectB.x;
}
}
}
nextItem() {
this.index += 1;
if (this.index === this.annotationList.length) {
this.index = 0;
}
this.toolbarEvents.setPage(Number.parseInt(this.navigationList[this.index].page, 0));
this.store.dispatch(new fromActions.SelectedAnnotation({
annotationId: this.navigationList[this.index].annotationId, editable: false, selected: true
}));
}
prevItem() {
this.index -= 1;
if (this.index < 0) {
this.index = this.navigationList.length - 1;
}
this.toolbarEvents.setPage(Number.parseInt(this.navigationList[this.index].page, 0));
this.store.dispatch(new fromActions.SelectedAnnotation({
annotationId: this.navigationList[this.index].annotationId,
editable: false,
selected: true
}));
}
upperRectangle(rectangles) {
[...rectangles].sort((rect1, rect2) => rect1.y - rect2.y);
return { x: rectangles[0].x, y: rectangles[0].y };
}
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CommentsNavigateComponent, deps: [{ token: i1.Store }, { token: i2.ToolbarEventService }], target: i0.ɵɵFactoryTarget.Component }); }
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CommentsNavigateComponent, selector: "mv-comments-navigate", inputs: { annotationList: "annotationList", autoSelect: "autoSelect" }, usesOnChanges: true, ngImport: i0, template: "<p class=\"comment-search\">\n <span class=\"comment-search__item\">\n Showing {{ index + 1 }} of {{ navigationList.length }}\n </span>\n <a [routerLink]=\"[]\"\n class=\"comment-search__item\"\n title=\"Previous comment\"\n (click)=\"prevItem()\">Prev</a>\n <a [routerLink]=\"[]\"\n class=\"comment-search__item\"\n title=\"Next comment'\"\n (click)=\"nextItem()\">Next</a>\n</p>\n", dependencies: [{ kind: "directive", type: i3.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }], encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CommentsNavigateComponent, decorators: [{
type: Component,
args: [{ selector: 'mv-comments-navigate', encapsulation: ViewEncapsulation.None, template: "<p class=\"comment-search\">\n <span class=\"comment-search__item\">\n Showing {{ index + 1 }} of {{ navigationList.length }}\n </span>\n <a [routerLink]=\"[]\"\n class=\"comment-search__item\"\n title=\"Previous comment\"\n (click)=\"prevItem()\">Prev</a>\n <a [routerLink]=\"[]\"\n class=\"comment-search__item\"\n title=\"Next comment'\"\n (click)=\"nextItem()\">Next</a>\n</p>\n" }]
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.ToolbarEventService }], propDecorators: { annotationList: [{
type: Input
}], autoSelect: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"comments-navigate.component.js","sourceRoot":"","sources":["../../../../../../../projects/media-viewer/src/lib/annotations/comment-set/comment-navigate/comments-navigate.component.ts","../../../../../../../projects/media-viewer/src/lib/annotations/comment-set/comment-navigate/comments-navigate.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnChanges, SimpleChanges, ViewEncapsulation } from '@angular/core';\nimport { Rectangle } from '../../annotation-set/annotation-view/rectangle/rectangle.model';\nimport { Annotation } from '../../annotation-set/annotation-view/annotation.model';\nimport {Store} from '@ngrx/store';\nimport * as fromStore from '../../../store/reducers/reducers';\nimport * as fromActions from '../../../store/actions/annotation.actions';\nimport {ToolbarEventService} from '../../../toolbar/toolbar-event.service';\n\n@Component({\n  selector: 'mv-comments-navigate',\n  templateUrl: './comments-navigate.component.html',\n  encapsulation: ViewEncapsulation.None\n})\nexport class CommentsNavigateComponent implements OnChanges {\n\n  @Input() public annotationList: Annotation[];\n  @Input() autoSelect = false;\n\n  navigationList: any[] = [];\n  index = 0;\n\n  constructor(private store: Store<fromStore.AnnotationSetState>, public readonly toolbarEvents: ToolbarEventService) {}\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.annotationList) {\n      this.initNavigationList();\n    }\n  }\n\n  initNavigationList(): void {\n    this.index = 0;\n    this.navigationList = [...this.annotationList || []]\n      .map(annotation => ({\n        content: annotation.comments[0].content,\n        annotationId: annotation.id,\n        page: annotation.page,\n        rectangle: this.upperRectangle(annotation.rectangles),\n      }))\n      .sort(this.sortComments);\n\n    if (this.autoSelect) {\n      this.toolbarEvents.setPage(Number.parseInt(this.navigationList[0].page, 0));\n      this.store.dispatch(new fromActions.SelectedAnnotation({\n        annotationId: this.navigationList[0].annotationId,\n        editable: false,\n        selected: true\n      }));\n    }\n  }\n\n  sortComments(mappedCommentA, mappedCommentB) {\n    if (mappedCommentA.page !== mappedCommentB.page) {\n      return mappedCommentA.page - mappedCommentB.page;\n    } else {\n      const rectA = mappedCommentA.rectangle;\n      const rectB = mappedCommentB.rectangle;\n      if (rectA.y !== rectB.y) {\n        return rectA.y - rectB.y;\n      } else {\n        return rectA.x - rectB.x;\n      }\n    }\n  }\n\n  nextItem() {\n    this.index += 1;\n    if (this.index === this.annotationList.length) {\n      this.index = 0;\n    }\n\n    this.toolbarEvents.setPage(Number.parseInt(this.navigationList[this.index].page, 0));\n    this.store.dispatch(new fromActions.SelectedAnnotation({\n      annotationId: this.navigationList[this.index].annotationId, editable: false, selected: true\n    }));\n  }\n\n\n  prevItem() {\n    this.index -= 1;\n    if (this.index < 0) {\n      this.index = this.navigationList.length - 1;\n    }\n    this.toolbarEvents.setPage(Number.parseInt(this.navigationList[this.index].page, 0));\n    this.store.dispatch(new fromActions.SelectedAnnotation({\n      annotationId: this.navigationList[this.index].annotationId,\n      editable: false,\n      selected: true\n    }));\n  }\n\n  upperRectangle(rectangles: Rectangle[]) {\n    [...rectangles].sort((rect1, rect2) => rect1.y - rect2.y);\n    return { x: rectangles[0].x, y: rectangles[0].y };\n  }\n}\n","<p class=\"comment-search\">\n  <span class=\"comment-search__item\">\n    Showing {{ index + 1 }} of {{ navigationList.length }}\n  </span>\n  <a [routerLink]=\"[]\"\n     class=\"comment-search__item\"\n     title=\"Previous comment\"\n     (click)=\"prevItem()\">Prev</a>\n  <a [routerLink]=\"[]\"\n     class=\"comment-search__item\"\n     title=\"Next comment'\"\n     (click)=\"nextItem()\">Next</a>\n</p>\n"]}