@hmcts/media-viewer 4.1.8-exui-2600 → 4.1.8-exui-2489
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/assets/sass/box-highlight.scss +0 -38
- package/esm2022/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.mjs +19 -74
- package/esm2022/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.service.mjs +4 -4
- package/esm2022/lib/annotations/annotation-set/annotation-view/annotation-view.component.mjs +3 -37
- package/esm2022/lib/annotations/annotation-set/annotation-view/rectangle/rectangle.component.mjs +3 -39
- package/esm2022/lib/annotations/annotation-set/metadata-layer/metadata-layer.component.mjs +3 -3
- package/esm2022/lib/annotations/annotations.module.mjs +3 -9
- package/esm2022/lib/store/actions/annotation.actions.mjs +2 -3
- package/esm2022/lib/store/effects/annotation.effects.mjs +3 -14
- package/esm2022/lib/viewers/pdf-viewer/pdf-viewer.component.mjs +28 -3
- package/fesm2022/hmcts-media-viewer.mjs +60 -546
- package/fesm2022/hmcts-media-viewer.mjs.map +1 -1
- package/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.d.ts +2 -16
- package/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.d.ts.map +1 -1
- package/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.service.d.ts +1 -1
- package/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.service.d.ts.map +1 -1
- package/lib/annotations/annotation-set/annotation-view/annotation-view.component.d.ts +2 -8
- package/lib/annotations/annotation-set/annotation-view/annotation-view.component.d.ts.map +1 -1
- package/lib/annotations/annotation-set/annotation-view/rectangle/rectangle.component.d.ts +1 -10
- package/lib/annotations/annotation-set/annotation-view/rectangle/rectangle.component.d.ts.map +1 -1
- package/lib/annotations/annotation-set/metadata-layer/metadata-layer.component.d.ts +1 -2
- package/lib/annotations/annotation-set/metadata-layer/metadata-layer.component.d.ts.map +1 -1
- package/lib/annotations/annotations.module.d.ts +11 -13
- package/lib/annotations/annotations.module.d.ts.map +1 -1
- package/lib/store/actions/annotation.actions.d.ts +1 -2
- package/lib/store/actions/annotation.actions.d.ts.map +1 -1
- package/lib/store/effects/annotation.effects.d.ts +0 -1
- package/lib/store/effects/annotation.effects.d.ts.map +1 -1
- package/lib/viewers/pdf-viewer/pdf-viewer.component.d.ts +1 -0
- package/lib/viewers/pdf-viewer/pdf-viewer.component.d.ts.map +1 -1
- package/package.json +1 -1
- package/esm2022/lib/annotations/annotation-set/annotation-create/box-highlight-create/keyboard-box-draw.directive.mjs +0 -258
- package/esm2022/lib/annotations/annotation-set/annotation-view/rectangle/keyboard-box-move.directive.mjs +0 -122
- package/lib/annotations/annotation-set/annotation-create/box-highlight-create/keyboard-box-draw.directive.d.ts +0 -59
- package/lib/annotations/annotation-set/annotation-create/box-highlight-create/keyboard-box-draw.directive.d.ts.map +0 -1
- package/lib/annotations/annotation-set/annotation-view/rectangle/keyboard-box-move.directive.d.ts +0 -27
- package/lib/annotations/annotation-set/annotation-view/rectangle/keyboard-box-move.directive.d.ts.map +0 -1
|
@@ -7,42 +7,4 @@ mv-box-highlight-create {
|
|
|
7
7
|
z-index: 10;
|
|
8
8
|
opacity: 0.5;
|
|
9
9
|
}
|
|
10
|
-
|
|
11
|
-
// for keyboard users
|
|
12
|
-
.drawing-cursor {
|
|
13
|
-
width: 14px;
|
|
14
|
-
height: 14px;
|
|
15
|
-
margin-left: -7px;
|
|
16
|
-
margin-top: -7px;
|
|
17
|
-
z-index: 15;
|
|
18
|
-
pointer-events: none;
|
|
19
|
-
position: relative;
|
|
20
|
-
background-color: #ffdd00;
|
|
21
|
-
border-radius: 50%;
|
|
22
|
-
border: 1px solid #ffdd00;
|
|
23
|
-
|
|
24
|
-
// vertical line
|
|
25
|
-
&::before {
|
|
26
|
-
content: '';
|
|
27
|
-
position: absolute;
|
|
28
|
-
top: 0;
|
|
29
|
-
left: 50%;
|
|
30
|
-
width: 1px;
|
|
31
|
-
height: 100%;
|
|
32
|
-
background-color: #0b0c0c;
|
|
33
|
-
transform: translateX(-0.5px);
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
// horizontal line
|
|
37
|
-
&::after {
|
|
38
|
-
content: '';
|
|
39
|
-
position: absolute;
|
|
40
|
-
top: 50%;
|
|
41
|
-
left: 0;
|
|
42
|
-
width: 100%;
|
|
43
|
-
height: 1px;
|
|
44
|
-
background-color: #0b0c0c;
|
|
45
|
-
transform: translateY(-0.5px);
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
10
|
}
|
|
@@ -4,8 +4,6 @@ import { HtmlTemplatesHelper } from '../../../../shared/util/helpers/html-templa
|
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "../../../../toolbar/toolbar-event.service";
|
|
6
6
|
import * as i2 from "../highlight-create/highlight-create.service";
|
|
7
|
-
import * as i3 from "@angular/common";
|
|
8
|
-
import * as i4 from "./keyboard-box-draw.directive";
|
|
9
7
|
export class BoxHighlightCreateComponent {
|
|
10
8
|
constructor(toolbarEvents, highlightService) {
|
|
11
9
|
this.toolbarEvents = toolbarEvents;
|
|
@@ -14,8 +12,6 @@ export class BoxHighlightCreateComponent {
|
|
|
14
12
|
this.drawStartX = -1;
|
|
15
13
|
this.drawStartY = -1;
|
|
16
14
|
this.backgroundColor = 'none';
|
|
17
|
-
this.keyboardDrawingMode = false;
|
|
18
|
-
this.showCursor = false;
|
|
19
15
|
this.subscriptions = [];
|
|
20
16
|
}
|
|
21
17
|
ngOnInit() {
|
|
@@ -23,14 +19,6 @@ export class BoxHighlightCreateComponent {
|
|
|
23
19
|
this.toolbarEvents.drawModeSubject.subscribe(drawMode => {
|
|
24
20
|
this.defaultHeight = drawMode ? '100%' : '0px';
|
|
25
21
|
this.defaultWidth = drawMode ? '100%' : '0px';
|
|
26
|
-
this.drawMode = drawMode;
|
|
27
|
-
if (drawMode) {
|
|
28
|
-
setTimeout(() => {
|
|
29
|
-
if (this.drawingContainer?.nativeElement && this.isElementInViewport(this.drawingContainer.nativeElement)) {
|
|
30
|
-
this.drawingContainer.nativeElement.focus();
|
|
31
|
-
}
|
|
32
|
-
}, 100);
|
|
33
|
-
}
|
|
34
22
|
}),
|
|
35
23
|
this.toolbarEvents.redactWholePage.subscribe(() => {
|
|
36
24
|
this.wholePage = true;
|
|
@@ -42,20 +30,13 @@ export class BoxHighlightCreateComponent {
|
|
|
42
30
|
subscription.unsubscribe();
|
|
43
31
|
});
|
|
44
32
|
}
|
|
45
|
-
isElementInViewport(el) {
|
|
46
|
-
const rect = el.getBoundingClientRect();
|
|
47
|
-
const windowHeight = (window.innerHeight || document.documentElement.clientHeight);
|
|
48
|
-
const windowWidth = (window.innerWidth || document.documentElement.clientWidth);
|
|
49
|
-
const verticallyVisible = rect.bottom > 0 && rect.top < windowHeight;
|
|
50
|
-
const horizontallyVisible = rect.right > 0 && rect.left < windowWidth;
|
|
51
|
-
return verticallyVisible && horizontallyVisible;
|
|
52
|
-
}
|
|
53
33
|
initHighlight(event) {
|
|
54
34
|
if (this.wholePage) {
|
|
55
35
|
this.highlightPage();
|
|
56
36
|
return;
|
|
57
37
|
}
|
|
58
38
|
const rect = HtmlTemplatesHelper.getAdjustedBoundingRect(event.target), offsetX = event.clientX - rect.left, offsetY = event.clientY - rect.top;
|
|
39
|
+
console.log(`initHighlight: rect=${JSON.stringify(rect)}, clientX=${event.clientX}, clientY=${event.clientY}, offsetX=${offsetX}, offsetY=${offsetY}`);
|
|
59
40
|
this.position = 'absolute';
|
|
60
41
|
this.backgroundColor = 'yellow';
|
|
61
42
|
this.drawStartX = offsetX;
|
|
@@ -65,7 +46,18 @@ export class BoxHighlightCreateComponent {
|
|
|
65
46
|
this.width = 50;
|
|
66
47
|
this.top = this.drawStartY;
|
|
67
48
|
this.left = this.drawStartX;
|
|
68
|
-
this.
|
|
49
|
+
switch (this.rotate) {
|
|
50
|
+
case 90:
|
|
51
|
+
this.top = this.drawStartY - this.height;
|
|
52
|
+
break;
|
|
53
|
+
case 180:
|
|
54
|
+
this.top = this.drawStartY - this.height;
|
|
55
|
+
this.left = this.drawStartX - this.width;
|
|
56
|
+
break;
|
|
57
|
+
case 270:
|
|
58
|
+
this.left = this.drawStartX - this.width;
|
|
59
|
+
break;
|
|
60
|
+
}
|
|
69
61
|
}
|
|
70
62
|
updateHighlight(event) {
|
|
71
63
|
const rect = HtmlTemplatesHelper.getAdjustedBoundingRect(event.target, false), offsetX = event.clientX - rect.left, offsetY = event.clientY - rect.top;
|
|
@@ -80,56 +72,12 @@ export class BoxHighlightCreateComponent {
|
|
|
80
72
|
if (this.height / this.zoom > 5 || this.width / this.zoom > 5) {
|
|
81
73
|
let rectangle = this.highlightService
|
|
82
74
|
.applyRotation(this.pageHeight, this.pageWidth, this.height, this.width, this.top, this.left, this.rotate, this.zoom);
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
this.saveSelection.emit({ rectangles: [rectangle], page: this.page
|
|
75
|
+
rectangle = { id: uuid(), ...rectangle };
|
|
76
|
+
console.log(`createHighlight: rectangle=${JSON.stringify(rectangle)}`);
|
|
77
|
+
this.saveSelection.emit({ rectangles: [rectangle], page: this.page });
|
|
86
78
|
this.resetHighlight();
|
|
87
79
|
}
|
|
88
80
|
}
|
|
89
|
-
onCursorPositionChanged(position) {
|
|
90
|
-
this.cursorX = position.x;
|
|
91
|
-
this.cursorY = position.y;
|
|
92
|
-
this.showCursor = position.visible;
|
|
93
|
-
}
|
|
94
|
-
onDrawingStarted(event) {
|
|
95
|
-
this.keyboardDrawingMode = true;
|
|
96
|
-
this.position = 'absolute';
|
|
97
|
-
this.backgroundColor = 'yellow';
|
|
98
|
-
this.display = 'block';
|
|
99
|
-
this.drawStartX = event.startX;
|
|
100
|
-
this.drawStartY = event.startY;
|
|
101
|
-
this.width = event.width;
|
|
102
|
-
this.height = event.height;
|
|
103
|
-
this.top = this.drawStartY;
|
|
104
|
-
this.left = this.drawStartX;
|
|
105
|
-
this.adjustForRotation();
|
|
106
|
-
}
|
|
107
|
-
onDrawingUpdated(event) {
|
|
108
|
-
this.width = event.width;
|
|
109
|
-
this.height = event.height;
|
|
110
|
-
}
|
|
111
|
-
onDrawingConfirmed(event) {
|
|
112
|
-
this.keyboardDrawingMode = false;
|
|
113
|
-
this.createHighlight();
|
|
114
|
-
}
|
|
115
|
-
onDrawingCancelled() {
|
|
116
|
-
this.keyboardDrawingMode = false;
|
|
117
|
-
this.resetHighlight();
|
|
118
|
-
}
|
|
119
|
-
adjustForRotation() {
|
|
120
|
-
switch (this.rotate) {
|
|
121
|
-
case 90:
|
|
122
|
-
this.top = this.drawStartY - this.height;
|
|
123
|
-
break;
|
|
124
|
-
case 180:
|
|
125
|
-
this.top = this.drawStartY - this.height;
|
|
126
|
-
this.left = this.drawStartX - this.width;
|
|
127
|
-
break;
|
|
128
|
-
case 270:
|
|
129
|
-
this.left = this.drawStartX - this.width;
|
|
130
|
-
break;
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
81
|
resetHighlight() {
|
|
134
82
|
this.drawStartX = -1;
|
|
135
83
|
this.drawStartY = -1;
|
|
@@ -148,11 +96,11 @@ export class BoxHighlightCreateComponent {
|
|
|
148
96
|
this.createHighlight();
|
|
149
97
|
}
|
|
150
98
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BoxHighlightCreateComponent, deps: [{ token: i1.ToolbarEventService }, { token: i2.HighlightCreateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
151
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: BoxHighlightCreateComponent, selector: "mv-box-highlight-create", inputs: { page: "page", pageHeight: "pageHeight", pageWidth: "pageWidth", rotate: "rotate", zoom: "zoom", container: "container" }, outputs: { saveSelection: "saveSelection" }, viewQueries: [{ propertyName: "highlight", first: true, predicate: ["boxHighlight"], descendants: true }
|
|
99
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: BoxHighlightCreateComponent, selector: "mv-box-highlight-create", inputs: { page: "page", pageHeight: "pageHeight", pageWidth: "pageWidth", rotate: "rotate", zoom: "zoom", container: "container" }, outputs: { saveSelection: "saveSelection" }, viewQueries: [{ propertyName: "highlight", first: true, predicate: ["boxHighlight"], descendants: true }], ngImport: i0, template: "<div [style.height]=\"defaultHeight\"\n [style.width]=\"defaultWidth\"\n (mousedown)=\"initHighlight($event)\"\n (mousemove)=\"updateHighlight($event)\"\n (mouseup)=\"createHighlight()\">\n <div #boxHighlight\n class=\"box-highlight\"\n [style.display]=\"display\"\n [style.position]=\"position\"\n [style.background-color]=\"backgroundColor\"\n [style.height]=\"height ? height + 'px' : '100%'\"\n [style.width]=\"width ? width + 'px' : '100%'\"\n [style.top]=\"top + 'px'\"\n [style.left]=\"left + 'px'\">\n </div>\n</div>\n" }); }
|
|
152
100
|
}
|
|
153
101
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BoxHighlightCreateComponent, decorators: [{
|
|
154
102
|
type: Component,
|
|
155
|
-
args: [{ selector: 'mv-box-highlight-create', template: "<div
|
|
103
|
+
args: [{ selector: 'mv-box-highlight-create', template: "<div [style.height]=\"defaultHeight\"\n [style.width]=\"defaultWidth\"\n (mousedown)=\"initHighlight($event)\"\n (mousemove)=\"updateHighlight($event)\"\n (mouseup)=\"createHighlight()\">\n <div #boxHighlight\n class=\"box-highlight\"\n [style.display]=\"display\"\n [style.position]=\"position\"\n [style.background-color]=\"backgroundColor\"\n [style.height]=\"height ? height + 'px' : '100%'\"\n [style.width]=\"width ? width + 'px' : '100%'\"\n [style.top]=\"top + 'px'\"\n [style.left]=\"left + 'px'\">\n </div>\n</div>\n" }]
|
|
156
104
|
}], ctorParameters: () => [{ type: i1.ToolbarEventService }, { type: i2.HighlightCreateService }], propDecorators: { page: [{
|
|
157
105
|
type: Input
|
|
158
106
|
}], pageHeight: [{
|
|
@@ -170,8 +118,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
170
118
|
}], highlight: [{
|
|
171
119
|
type: ViewChild,
|
|
172
120
|
args: ['boxHighlight', { static: false }]
|
|
173
|
-
}], drawingContainer: [{
|
|
174
|
-
type: ViewChild,
|
|
175
|
-
args: ['drawingContainer', { static: false }]
|
|
176
121
|
}] } });
|
|
177
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"box-highlight-create.component.js","sourceRoot":"","sources":["../../../../../../../../projects/media-viewer/src/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.ts","../../../../../../../../projects/media-viewer/src/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\nimport { v4 as uuid } from 'uuid';\nimport { Subscription } from 'rxjs';\nimport { Rectangle } from '../../annotation-view/rectangle/rectangle.model';\nimport { HighlightCreateService } from '../highlight-create/highlight-create.service';\nimport { ToolbarEventService } from '../../../../toolbar/toolbar-event.service';\nimport { HtmlTemplatesHelper } from '../../../../shared/util/helpers/html-templates.helper';\nimport { KeyboardBoxDrawEvent, CursorPosition } from './keyboard-box-draw.directive';\n\n@Component({\n  selector: 'mv-box-highlight-create',\n  templateUrl: './box-highlight-create.component.html',\n})\nexport class BoxHighlightCreateComponent implements OnInit, OnDestroy {\n\n  @Input() page: number;\n  @Input() pageHeight: number;\n  @Input() pageWidth: number;\n  @Input() rotate: number;\n  @Input() zoom: number;\n  @Input() container: { top: number, left: number };\n\n  @Output() saveSelection = new EventEmitter<{ rectangles: Rectangle[], page: number, annotationId?: string }>();\n\n  @ViewChild('boxHighlight', { static: false }) highlight: ElementRef;\n  @ViewChild('drawingContainer', { static: false }) drawingContainer: ElementRef;\n\n  drawStartX = -1;\n  drawStartY = -1;\n\n  top: number;\n  left: number;\n  height: number;\n  width: number;\n  display: string;\n  position: string;\n  backgroundColor = 'none';\n\n  drawMode: boolean;\n  defaultHeight: string;\n  defaultWidth: string;\n  wholePage: boolean;\n\n  keyboardDrawingMode = false;\n  cursorX: number;\n  cursorY: number;\n  showCursor = false;\n\n  private subscriptions: Subscription[] = [];\n\n  constructor(private readonly toolbarEvents: ToolbarEventService,\n    private readonly highlightService: HighlightCreateService) { }\n\n  ngOnInit(): void {\n    this.subscriptions = [\n      this.toolbarEvents.drawModeSubject.subscribe(drawMode => {\n        this.defaultHeight = drawMode ? '100%' : '0px';\n        this.defaultWidth = drawMode ? '100%' : '0px';\n        this.drawMode = drawMode;\n        if (drawMode) {\n          setTimeout(() => {\n            if (this.drawingContainer?.nativeElement && this.isElementInViewport(this.drawingContainer.nativeElement)) {\n              this.drawingContainer.nativeElement.focus();\n            }\n          }, 100);\n        }\n      }),\n      this.toolbarEvents.redactWholePage.subscribe(() => {\n        this.wholePage = true;\n      })\n    ];\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.forEach(subscription => {\n      subscription.unsubscribe();\n    });\n  }\n\n  private isElementInViewport(el: HTMLElement): boolean {\n    const rect = el.getBoundingClientRect();\n    const windowHeight = (window.innerHeight || document.documentElement.clientHeight);\n    const windowWidth = (window.innerWidth || document.documentElement.clientWidth);\n\n    const verticallyVisible = rect.bottom > 0 && rect.top < windowHeight;\n    const horizontallyVisible = rect.right > 0 && rect.left < windowWidth;\n\n    return verticallyVisible && horizontallyVisible;\n  }\n\n  initHighlight(event: MouseEvent) {\n    if (this.wholePage) {\n      this.highlightPage();\n      return;\n    }\n\n    const rect = HtmlTemplatesHelper.getAdjustedBoundingRect((event.target as HTMLElement)),\n    offsetX = event.clientX - rect.left,\n    offsetY = event.clientY - rect.top;\n\n    this.position = 'absolute';\n    this.backgroundColor = 'yellow';\n    this.drawStartX = offsetX;\n    this.drawStartY = offsetY;\n\n    this.display = 'block';\n    this.height = 50;\n    this.width = 50;\n    this.top = this.drawStartY;\n    this.left = this.drawStartX;\n\n    this.adjustForRotation();\n  }\n\n  updateHighlight(event: MouseEvent) {\n    const rect = HtmlTemplatesHelper.getAdjustedBoundingRect(event.target as HTMLElement, false),\n      offsetX = event.clientX - rect.left,\n      offsetY = event.clientY - rect.top;\n  \n    if (this.drawStartX > 0 && this.drawStartY > 0) {\n      this.height = Math.abs(offsetY - this.drawStartY);\n      this.width = Math.abs(offsetX - this.drawStartX);\n      this.top = Math.min(offsetY, this.drawStartY);\n      this.left = Math.min(offsetX, this.drawStartX);\n    }\n  }\n\n  createHighlight() {\n    if (this.height / this.zoom > 5 || this.width / this.zoom > 5) {\n      let rectangle = this.highlightService\n        .applyRotation(this.pageHeight, this.pageWidth, this.height, this.width, this.top, this.left, this.rotate, this.zoom);\n      const annotationId = uuid();\n      rectangle = { id: annotationId, ...rectangle } as any;\n      this.saveSelection.emit({ rectangles: [rectangle], page: this.page, annotationId });\n      this.resetHighlight();\n    }\n  }\n\n  onCursorPositionChanged(position: CursorPosition): void {\n    this.cursorX = position.x;\n    this.cursorY = position.y;\n    this.showCursor = position.visible;\n  }\n\n  onDrawingStarted(event: KeyboardBoxDrawEvent): void {\n    this.keyboardDrawingMode = true;\n    this.position = 'absolute';\n    this.backgroundColor = 'yellow';\n    this.display = 'block';\n\n    this.drawStartX = event.startX;\n    this.drawStartY = event.startY;\n    this.width = event.width;\n    this.height = event.height;\n    this.top = this.drawStartY;\n    this.left = this.drawStartX;\n\n    this.adjustForRotation();\n  }\n\n  onDrawingUpdated(event: KeyboardBoxDrawEvent): void {\n    this.width = event.width;\n    this.height = event.height;\n  }\n\n  onDrawingConfirmed(event: KeyboardBoxDrawEvent): void {\n    this.keyboardDrawingMode = false;\n    this.createHighlight();\n  }\n\n  onDrawingCancelled(): void {\n    this.keyboardDrawingMode = false;\n    this.resetHighlight();\n  }\n\n  private adjustForRotation(): void {\n    switch (this.rotate) {\n      case 90:\n        this.top = this.drawStartY - this.height;\n        break;\n      case 180:\n        this.top = this.drawStartY - this.height;\n        this.left = this.drawStartX - this.width;\n        break;\n      case 270:\n        this.left = this.drawStartX - this.width;\n        break;\n    }\n  }\n\n  private resetHighlight() {\n    this.drawStartX = -1;\n    this.drawStartY = -1;\n    this.display = 'none';\n    this.width = 0;\n    this.height = 0;\n    this.backgroundColor = 'none';\n    this.position = 'initial';\n    this.wholePage = false;\n  }\n\n  private highlightPage() {\n    this.height = this.pageHeight;\n    this.width = this.pageWidth;\n    this.top = 0;\n    this.left = 0;\n    this.createHighlight();\n  }\n}\n","<div #drawingContainer\n  [style.height]=\"defaultHeight\"\n  [style.width]=\"defaultWidth\"\n  [tabindex]=\"drawMode ? 0 : -1\"\n  mvKeyboardBoxDraw\n  [enabled]=\"drawMode\"\n  (cursorPositionChanged)=\"onCursorPositionChanged($event)\"\n  (drawingStarted)=\"onDrawingStarted($event)\"\n  (drawingUpdated)=\"onDrawingUpdated($event)\"\n  (drawingConfirmed)=\"onDrawingConfirmed($event)\"\n  (drawingCancelled)=\"onDrawingCancelled()\"\n  (mousedown)=\"initHighlight($event)\"\n  (mousemove)=\"updateHighlight($event)\"\n  (mouseup)=\"createHighlight()\">\n\n  <div *ngIf=\"showCursor\"\n    class=\"drawing-cursor\"\n    [style.position]=\"'absolute'\"\n    [style.top]=\"cursorY + 'px'\"\n    [style.left]=\"cursorX + 'px'\">\n  </div>\n\n  <div #boxHighlight\n    class=\"box-highlight\"\n    [style.display]=\"display\"\n    [style.position]=\"position\"\n    [style.background-color]=\"backgroundColor\"\n    [style.height]=\"height ? height + 'px' : '100%'\"\n    [style.width]=\"width ? width + 'px' : '100%'\"\n    [style.top]=\"top + 'px'\"\n    [style.left]=\"left + 'px'\">\n  </div>\n</div>\n"]}
|
|
122
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"box-highlight-create.component.js","sourceRoot":"","sources":["../../../../../../../../projects/media-viewer/src/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.ts","../../../../../../../../projects/media-viewer/src/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\nimport { v4 as uuid } from 'uuid';\nimport { Subscription } from 'rxjs';\nimport { Rectangle } from '../../annotation-view/rectangle/rectangle.model';\nimport { HighlightCreateService } from '../highlight-create/highlight-create.service';\nimport { ToolbarEventService } from '../../../../toolbar/toolbar-event.service';\nimport { HtmlTemplatesHelper } from '../../../../shared/util/helpers/html-templates.helper';\n@Component({\n  selector: 'mv-box-highlight-create',\n  templateUrl: './box-highlight-create.component.html',\n})\nexport class BoxHighlightCreateComponent implements OnInit, OnDestroy {\n\n  @Input() page: number;\n  @Input() pageHeight: number;\n  @Input() pageWidth: number;\n  @Input() rotate: number;\n  @Input() zoom: number;\n  @Input() container: { top: number, left: number };\n\n  @Output() saveSelection = new EventEmitter<{ rectangles: Rectangle[], page: number }>();\n\n  @ViewChild('boxHighlight', { static: false }) highlight: ElementRef;\n\n  drawStartX = -1;\n  drawStartY = -1;\n  top: number;\n  left: number;\n  height: number;\n  width: number;\n  display: string;\n  drawMode: boolean;\n  defaultHeight: string;\n  defaultWidth: string;\n  position: string;\n  backgroundColor = 'none';\n  wholePage: boolean;\n\n  private subscriptions: Subscription[] = [];\n\n  constructor(private readonly toolbarEvents: ToolbarEventService,\n    private readonly highlightService: HighlightCreateService) { }\n\n  ngOnInit(): void {\n    this.subscriptions = [\n      this.toolbarEvents.drawModeSubject.subscribe(drawMode => {\n        this.defaultHeight = drawMode ? '100%' : '0px';\n        this.defaultWidth = drawMode ? '100%' : '0px';\n      }),\n      this.toolbarEvents.redactWholePage.subscribe(() => {\n        this.wholePage = true;\n      })\n    ];\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.forEach(subscription => {\n      subscription.unsubscribe();\n    });\n  }\n\n  initHighlight(event: MouseEvent) {\n    if (this.wholePage) {\n      this.highlightPage();\n      return;\n    }\n\n    const rect = HtmlTemplatesHelper.getAdjustedBoundingRect((event.target as HTMLElement)),\n    offsetX = event.clientX - rect.left,\n    offsetY = event.clientY - rect.top;\n    console.log(`initHighlight: rect=${JSON.stringify(rect)}, clientX=${event.clientX}, clientY=${event.clientY}, offsetX=${offsetX}, offsetY=${offsetY}`);\n\n    this.position = 'absolute';\n    this.backgroundColor = 'yellow';\n    this.drawStartX = offsetX;\n    this.drawStartY = offsetY;\n\n    this.display = 'block';\n    this.height = 50;\n    this.width = 50;\n    this.top = this.drawStartY;\n    this.left = this.drawStartX;\n\n    switch (this.rotate) {\n      case 90:\n        this.top = this.drawStartY - this.height;\n        break;\n      case 180:\n        this.top = this.drawStartY - this.height;\n        this.left = this.drawStartX - this.width;\n        break;\n      case 270:\n        this.left = this.drawStartX - this.width;\n        break;\n    }\n  }\n\n  updateHighlight(event: MouseEvent) {\n    const rect = HtmlTemplatesHelper.getAdjustedBoundingRect(event.target as HTMLElement, false),\n      offsetX = event.clientX - rect.left,\n      offsetY = event.clientY - rect.top;\n    if (this.drawStartX > 0 && this.drawStartY > 0) {\n      this.height = Math.abs(offsetY - this.drawStartY);\n      this.width = Math.abs(offsetX - this.drawStartX);\n      this.top = Math.min(offsetY, this.drawStartY);\n      this.left = Math.min(offsetX, this.drawStartX);\n    }\n  }\n\n  createHighlight() {\n    if (this.height / this.zoom > 5 || this.width / this.zoom > 5) {\n      let rectangle = this.highlightService\n        .applyRotation(this.pageHeight, this.pageWidth, this.height, this.width, this.top, this.left, this.rotate, this.zoom);\n      rectangle = { id: uuid(), ...rectangle } as any;\n      console.log(`createHighlight: rectangle=${JSON.stringify(rectangle)}`);\n      this.saveSelection.emit({ rectangles: [rectangle], page: this.page });\n      this.resetHighlight();\n    }\n  }\n\n  private resetHighlight() {\n    this.drawStartX = -1;\n    this.drawStartY = -1;\n    this.display = 'none';\n    this.width = 0;\n    this.height = 0;\n    this.backgroundColor = 'none';\n    this.position = 'initial';\n    this.wholePage = false;\n  }\n\n  private highlightPage() {\n    this.height = this.pageHeight;\n    this.width = this.pageWidth;\n    this.top = 0;\n    this.left = 0;\n    this.createHighlight();\n  }\n}\n","<div [style.height]=\"defaultHeight\"\n     [style.width]=\"defaultWidth\"\n     (mousedown)=\"initHighlight($event)\"\n     (mousemove)=\"updateHighlight($event)\"\n     (mouseup)=\"createHighlight()\">\n  <div #boxHighlight\n     class=\"box-highlight\"\n     [style.display]=\"display\"\n     [style.position]=\"position\"\n     [style.background-color]=\"backgroundColor\"\n     [style.height]=\"height ? height + 'px' : '100%'\"\n     [style.width]=\"width ? width + 'px' : '100%'\"\n     [style.top]=\"top + 'px'\"\n     [style.left]=\"left + 'px'\">\n  </div>\n</div>\n"]}
|
|
@@ -13,10 +13,10 @@ export class HighlightCreateService {
|
|
|
13
13
|
this.toolBarEvents = toolBarEvents;
|
|
14
14
|
this.store = store;
|
|
15
15
|
}
|
|
16
|
-
saveAnnotation(rectangles, page
|
|
16
|
+
saveAnnotation(rectangles, page) {
|
|
17
17
|
this.store.pipe(select(fromSelectors.getDocumentIdSetId), take(1)).subscribe(anoSetDocId => {
|
|
18
18
|
const anno = {
|
|
19
|
-
id:
|
|
19
|
+
id: uuid(),
|
|
20
20
|
color: 'FFFF00',
|
|
21
21
|
comments: [],
|
|
22
22
|
page: page,
|
|
@@ -31,7 +31,7 @@ export class HighlightCreateService {
|
|
|
31
31
|
lastModifiedDate: '',
|
|
32
32
|
tags: [],
|
|
33
33
|
};
|
|
34
|
-
this.store.dispatch(new fromActions.SaveAnnotation(anno
|
|
34
|
+
this.store.dispatch(new fromActions.SaveAnnotation(anno));
|
|
35
35
|
});
|
|
36
36
|
}
|
|
37
37
|
saveAnnotationSet(searchRectangles) {
|
|
@@ -98,4 +98,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
98
98
|
type: Injectable,
|
|
99
99
|
args: [{ providedIn: 'root' }]
|
|
100
100
|
}], ctorParameters: () => [{ type: i1.ToolbarEventService }, { type: i2.Store }] });
|
|
101
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"highlight-create.service.js","sourceRoot":"","sources":["../../../../../../../../projects/media-viewer/src/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ToolbarEventService } from './../../../../toolbar/toolbar-event.service';\nimport { Injectable } from '@angular/core';\nimport { take} from 'rxjs/operators';\nimport { select, Store } from '@ngrx/store';\nimport { v4 as uuid } from 'uuid';\nimport moment from 'moment-timezone';\n\n\nimport { Rectangle } from '../../annotation-view/rectangle/rectangle.model';\nimport * as fromStore from '../../../../store/reducers/reducers';\nimport * as fromSelectors from '../../../../store/selectors/annotation.selectors';\nimport * as fromActions from '../../../../store/actions/annotation.actions';\nimport { Annotation } from '../../annotation-view/annotation.model';\nimport { RedactRectangle } from '../../../../toolbar/redaction-search-bar/redaction-search.model';\nimport { AnnotationSet } from '../../annotation-set.model';\n\n@Injectable({ providedIn: 'root' })\nexport class HighlightCreateService {\n\n  constructor(private toolBarEvents: ToolbarEventService,\n    private store: Store<fromStore.AnnotationSetState>) { }\n\n  saveAnnotation(rectangles: Rectangle[], page: number, annotationId?: string) {\n    this.store.pipe(select(fromSelectors.getDocumentIdSetId), take(1)).subscribe(anoSetDocId => {\n      const anno: Annotation = {\n        id: annotationId || uuid(),\n        color: 'FFFF00',\n        comments: [],\n        page: page,\n        rectangles: rectangles,\n        type: 'highlight',\n        ...anoSetDocId,\n        createdBy: '',\n        createdByDetails: undefined,\n        createdDate: moment.utc().tz('Europe/London').toISOString(),\n        lastModifiedBy: '',\n        lastModifiedByDetails: undefined,\n        lastModifiedDate: '',\n        tags: [],\n      };\n      this.store.dispatch(new fromActions.SaveAnnotation(anno, !!annotationId));\n    });\n  }\n\n  saveAnnotationSet(searchRectangles: RedactRectangle[]) {\n    this.store.pipe(select(fromSelectors.getDocumentIdSetId), take(1)).subscribe(anoSetDocId => {\n      const annoSet = searchRectangles.map(x => {\n        return {\n          id: uuid(),\n          color: 'FFFF00',\n          comments: [],\n          page: x.page,\n          rectangles: x.rectangles,\n          type: 'highlight',\n          ...anoSetDocId,\n          createdBy: '',\n          createdByDetails: undefined,\n          createdDate: moment.utc().tz('Europe/London').toISOString(),\n          lastModifiedBy: '',\n          lastModifiedByDetails: undefined,\n          lastModifiedDate: '',\n          tags: [],\n        } as Annotation;\n      });\n      this.store.dispatch(new fromActions.SaveAnnotationSet({\n        id: anoSetDocId.annotationSetId, annotations: annoSet, documentId: anoSetDocId.documentId } as AnnotationSet));\n    });\n  }\n\n\n  applyRotation(pageHeight, pageWidth, offsetHeight, offsetWidth, offsetTop, offsetLeft, rotate, zoom) {\n    const { x, y, width, height } = {\n      x: +(offsetLeft / zoom).toFixed(2),\n      y: +(offsetTop / zoom).toFixed(2),\n      width: +(offsetWidth / zoom).toFixed(2),\n      height: +(offsetHeight / zoom).toFixed(2)\n    };\n    const rectangle = { x, y, width, height };\n    switch (rotate) {\n      case 90:\n        rectangle.width = height;\n        rectangle.height = width;\n        rectangle.x = y;\n        rectangle.y = +(pageWidth / zoom - x - width).toFixed(2);\n        break;\n      case 180:\n        rectangle.x = +(pageWidth / zoom - x - width).toFixed(2);\n        rectangle.y = +(pageHeight / zoom - y - height).toFixed(2);\n        break;\n      case 270:\n        rectangle.width = height;\n        rectangle.height = width;\n        rectangle.x = +(pageHeight / zoom - y - height).toFixed(2);\n        rectangle.y = x;\n        break;\n    }\n    return rectangle as any;\n  }\n\n  resetHighlight() {\n    window.getSelection().removeAllRanges();\n    this.toolBarEvents.highlightModeSubject.next(false);\n  }\n}\n"]}
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"highlight-create.service.js","sourceRoot":"","sources":["../../../../../../../../projects/media-viewer/src/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ToolbarEventService } from './../../../../toolbar/toolbar-event.service';\nimport { Injectable } from '@angular/core';\nimport { take} from 'rxjs/operators';\nimport { select, Store } from '@ngrx/store';\nimport { v4 as uuid } from 'uuid';\nimport moment from 'moment-timezone';\n\n\nimport { Rectangle } from '../../annotation-view/rectangle/rectangle.model';\nimport * as fromStore from '../../../../store/reducers/reducers';\nimport * as fromSelectors from '../../../../store/selectors/annotation.selectors';\nimport * as fromActions from '../../../../store/actions/annotation.actions';\nimport { Annotation } from '../../annotation-view/annotation.model';\nimport { RedactRectangle } from '../../../../toolbar/redaction-search-bar/redaction-search.model';\nimport { AnnotationSet } from '../../annotation-set.model';\n\n@Injectable({ providedIn: 'root' })\nexport class HighlightCreateService {\n\n  constructor(private toolBarEvents: ToolbarEventService,\n    private store: Store<fromStore.AnnotationSetState>) { }\n\n  saveAnnotation(rectangles: Rectangle[], page: number) {\n    this.store.pipe(select(fromSelectors.getDocumentIdSetId), take(1)).subscribe(anoSetDocId => {\n      const anno: Annotation = {\n        id: uuid(),\n        color: 'FFFF00',\n        comments: [],\n        page: page,\n        rectangles: rectangles,\n        type: 'highlight',\n        ...anoSetDocId,\n        createdBy: '',\n        createdByDetails: undefined,\n        createdDate: moment.utc().tz('Europe/London').toISOString(),\n        lastModifiedBy: '',\n        lastModifiedByDetails: undefined,\n        lastModifiedDate: '',\n        tags: [],\n      };\n      this.store.dispatch(new fromActions.SaveAnnotation(anno));\n    });\n  }\n\n  saveAnnotationSet(searchRectangles: RedactRectangle[]) {\n    this.store.pipe(select(fromSelectors.getDocumentIdSetId), take(1)).subscribe(anoSetDocId => {\n      const annoSet = searchRectangles.map(x => {\n        return {\n          id: uuid(),\n          color: 'FFFF00',\n          comments: [],\n          page: x.page,\n          rectangles: x.rectangles,\n          type: 'highlight',\n          ...anoSetDocId,\n          createdBy: '',\n          createdByDetails: undefined,\n          createdDate: moment.utc().tz('Europe/London').toISOString(),\n          lastModifiedBy: '',\n          lastModifiedByDetails: undefined,\n          lastModifiedDate: '',\n          tags: [],\n        } as Annotation;\n      });\n      this.store.dispatch(new fromActions.SaveAnnotationSet({\n        id: anoSetDocId.annotationSetId, annotations: annoSet, documentId: anoSetDocId.documentId } as AnnotationSet));\n    });\n  }\n\n\n  applyRotation(pageHeight, pageWidth, offsetHeight, offsetWidth, offsetTop, offsetLeft, rotate, zoom) {\n    const { x, y, width, height } = {\n      x: +(offsetLeft / zoom).toFixed(2),\n      y: +(offsetTop / zoom).toFixed(2),\n      width: +(offsetWidth / zoom).toFixed(2),\n      height: +(offsetHeight / zoom).toFixed(2)\n    };\n    const rectangle = { x, y, width, height };\n    switch (rotate) {\n      case 90:\n        rectangle.width = height;\n        rectangle.height = width;\n        rectangle.x = y;\n        rectangle.y = +(pageWidth / zoom - x - width).toFixed(2);\n        break;\n      case 180:\n        rectangle.x = +(pageWidth / zoom - x - width).toFixed(2);\n        rectangle.y = +(pageHeight / zoom - y - height).toFixed(2);\n        break;\n      case 270:\n        rectangle.width = height;\n        rectangle.height = width;\n        rectangle.x = +(pageHeight / zoom - y - height).toFixed(2);\n        rectangle.y = x;\n        break;\n    }\n    return rectangle as any;\n  }\n\n  resetHighlight() {\n    window.getSelection().removeAllRanges();\n    this.toolBarEvents.highlightModeSubject.next(false);\n  }\n}\n"]}
|
package/esm2022/lib/annotations/annotation-set/annotation-view/annotation-view.component.mjs
CHANGED
|
@@ -2,7 +2,6 @@ import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core
|
|
|
2
2
|
import { v4 as uuid } from 'uuid';
|
|
3
3
|
import moment from 'moment-timezone';
|
|
4
4
|
import * as fromActions from '../../../store/actions/annotation.actions';
|
|
5
|
-
import { debounceTime, Subject } from 'rxjs';
|
|
6
5
|
import * as i0 from "@angular/core";
|
|
7
6
|
import * as i1 from "../../../toolbar/toolbar-event.service";
|
|
8
7
|
import * as i2 from "@ngrx/store";
|
|
@@ -17,41 +16,18 @@ export class AnnotationViewComponent {
|
|
|
17
16
|
if (selectedId) {
|
|
18
17
|
const id = this.anno.id || this.anno.redactionId; // todo make it unique
|
|
19
18
|
this.selected = selectedId.annotationId ? (selectedId.annotationId === id) : false;
|
|
20
|
-
if (this.selected && !this.isKeyboardMoving) {
|
|
21
|
-
this.showToolbarSubject.next(true);
|
|
22
|
-
}
|
|
23
|
-
else {
|
|
24
|
-
this.showToolbarSubject.next(false);
|
|
25
|
-
}
|
|
26
19
|
}
|
|
27
20
|
}
|
|
28
21
|
constructor(toolbarEvents, store) {
|
|
29
22
|
this.toolbarEvents = toolbarEvents;
|
|
30
23
|
this.store = store;
|
|
31
|
-
this.isKeyboardMoving = false;
|
|
32
|
-
this.showToolbar = false;
|
|
33
|
-
this.showToolbarSubject = new Subject();
|
|
34
24
|
this.update = new EventEmitter();
|
|
35
25
|
this.delete = new EventEmitter();
|
|
36
26
|
this.annotationClick = new EventEmitter();
|
|
37
|
-
this.showToolbarSubject
|
|
38
|
-
.pipe(debounceTime(300))
|
|
39
|
-
.subscribe(show => {
|
|
40
|
-
this.showToolbar = show;
|
|
41
|
-
});
|
|
42
|
-
}
|
|
43
|
-
ngOnDestroy() {
|
|
44
|
-
this.showToolbarSubject.complete();
|
|
45
|
-
}
|
|
46
|
-
setShowToolbar(show) {
|
|
47
|
-
this.showToolbarSubject.next(show);
|
|
48
27
|
}
|
|
49
28
|
onSelect() {
|
|
50
29
|
const annotationId = this.anno.id || this.anno.redactionId;
|
|
51
30
|
this.annotationClick.emit({ annotationId, editable: false, selected: true });
|
|
52
|
-
if (!this.isKeyboardMoving) {
|
|
53
|
-
this.setShowToolbar(true);
|
|
54
|
-
}
|
|
55
31
|
}
|
|
56
32
|
onRectangleUpdate(rectangle) {
|
|
57
33
|
const annotation = { ...this.anno };
|
|
@@ -87,22 +63,12 @@ export class AnnotationViewComponent {
|
|
|
87
63
|
this.annotationClick.emit({ annotationId: this.anno.id, editable: true, selected: true });
|
|
88
64
|
this.toolbarEvents.toggleCommentsPanel(true);
|
|
89
65
|
}
|
|
90
|
-
onKeyboardMovingChange(isMoving) {
|
|
91
|
-
this.isKeyboardMoving = isMoving;
|
|
92
|
-
if (isMoving) {
|
|
93
|
-
this.showToolbar = false;
|
|
94
|
-
this.showToolbarSubject.next(false);
|
|
95
|
-
}
|
|
96
|
-
else if (this.selected) {
|
|
97
|
-
this.setShowToolbar(true);
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
66
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AnnotationViewComponent, deps: [{ token: i1.ToolbarEventService }, { token: i2.Store }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
101
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: AnnotationViewComponent, selector: "mv-annotation", inputs: { annotation: "annotation", zoom: "zoom", rotate: "rotate", selectedAnnoId: "selectedAnnoId", pageHeight: "pageHeight", pageWidth: "pageWidth" }, outputs: { update: "update", delete: "delete", annotationClick: "annotationClick" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], ngImport: i0, template: "<div #container [tabindex]=\"
|
|
67
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: AnnotationViewComponent, selector: "mv-annotation", inputs: { annotation: "annotation", zoom: "zoom", rotate: "rotate", selectedAnnoId: "selectedAnnoId", pageHeight: "pageHeight", pageWidth: "pageWidth" }, outputs: { update: "update", delete: "delete", annotationClick: "annotationClick" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], ngImport: i0, template: "<div #container [tabindex]=\"anno.id\">\n <mv-ctx-toolbar *ngIf=\"selected\"\n [canDelete]=\"true\" [canComment]=\"true\"\n [rectangles]=\"anno.rectangles\"\n [zoom]=\"zoom\"\n [rotate]=\"rotate\"\n [pageHeight]=\"pageHeight\"\n [pageWidth]=\"pageWidth\"\n (deleteHighlightEvent)=\"deleteHighlight()\"\n (addOrEditCommentEvent)=\"addOrEditComment()\">\n </mv-ctx-toolbar>\n <ng-container *ngFor=\"let rectangle of anno.rectangles\">\n <mv-anno-rectangle\n (selectEvent)=\"onSelect()\"\n (updateEvent)=\"onRectangleUpdate($event)\"\n [selected]=\"selected\"\n [zoom]=\"zoom\"\n [rotate]=\"rotate\"\n [pageHeight]=\"pageHeight\"\n [pageWidth]=\"pageWidth\"\n [editable]=\"anno.rectangles.length <= 1\"\n [annoRect]=\"rectangle\"\n [color]=\"anno.color\">\n </mv-anno-rectangle>\n </ng-container>\n</div>\n", dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.RectangleComponent, selector: "mv-anno-rectangle", inputs: ["color", "zoom", "rotate", "editable", "pageHeight", "pageWidth", "annoRect", "selected"], outputs: ["selectEvent", "updateEvent"] }, { kind: "component", type: i5.CtxToolbarComponent, selector: "mv-ctx-toolbar", inputs: ["zoom", "rotate", "pageHeight", "pageWidth", "canHighlight", "canBookmark", "canComment", "canDelete", "rectangles"], outputs: ["createHighlightEvent", "deleteHighlightEvent", "addOrEditCommentEvent", "createBookmarkEvent"] }] }); }
|
|
102
68
|
}
|
|
103
69
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AnnotationViewComponent, decorators: [{
|
|
104
70
|
type: Component,
|
|
105
|
-
args: [{ selector: 'mv-annotation', template: "<div #container [tabindex]=\"
|
|
71
|
+
args: [{ selector: 'mv-annotation', template: "<div #container [tabindex]=\"anno.id\">\n <mv-ctx-toolbar *ngIf=\"selected\"\n [canDelete]=\"true\" [canComment]=\"true\"\n [rectangles]=\"anno.rectangles\"\n [zoom]=\"zoom\"\n [rotate]=\"rotate\"\n [pageHeight]=\"pageHeight\"\n [pageWidth]=\"pageWidth\"\n (deleteHighlightEvent)=\"deleteHighlight()\"\n (addOrEditCommentEvent)=\"addOrEditComment()\">\n </mv-ctx-toolbar>\n <ng-container *ngFor=\"let rectangle of anno.rectangles\">\n <mv-anno-rectangle\n (selectEvent)=\"onSelect()\"\n (updateEvent)=\"onRectangleUpdate($event)\"\n [selected]=\"selected\"\n [zoom]=\"zoom\"\n [rotate]=\"rotate\"\n [pageHeight]=\"pageHeight\"\n [pageWidth]=\"pageWidth\"\n [editable]=\"anno.rectangles.length <= 1\"\n [annoRect]=\"rectangle\"\n [color]=\"anno.color\">\n </mv-anno-rectangle>\n </ng-container>\n</div>\n" }]
|
|
106
72
|
}], ctorParameters: () => [{ type: i1.ToolbarEventService }, { type: i2.Store }], propDecorators: { annotation: [{
|
|
107
73
|
type: Input
|
|
108
74
|
}], zoom: [{
|
|
@@ -125,4 +91,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
125
91
|
type: ViewChild,
|
|
126
92
|
args: ['container', { static: false }]
|
|
127
93
|
}] } });
|
|
128
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"annotation-view.component.js","sourceRoot":"","sources":["../../../../../../../projects/media-viewer/src/lib/annotations/annotation-set/annotation-view/annotation-view.component.ts","../../../../../../../projects/media-viewer/src/lib/annotations/annotation-set/annotation-view/annotation-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, ViewChild, ElementRef, OnDestroy } from '@angular/core';\nimport { v4 as uuid } from 'uuid';\nimport { Annotation } from './annotation.model';\nimport { Rectangle } from './rectangle/rectangle.model';\nimport moment from 'moment-timezone';\nimport { Store } from '@ngrx/store';\nimport * as fromStore from '../../../store/reducers/reducers';\nimport * as fromActions from '../../../store/actions/annotation.actions';\nimport { SelectionAnnotation } from '../../models/event-select.model';\nimport { ToolbarEventService } from '../../../toolbar/toolbar-event.service';\nimport { Comment } from '../../comment-set/comment/comment.model';\nimport { debounceTime, Subject } from 'rxjs';\n\n@Component({\n  selector: 'mv-annotation',\n  templateUrl: './annotation-view.component.html'\n})\nexport class AnnotationViewComponent implements OnDestroy {  // todo rename this to selection vew c\n\n  @Input() set annotation(value) {\n    this.anno = { ...value };\n  }\n  anno: Annotation;\n  selected: boolean;\n  isKeyboardMoving = false;\n  showToolbar = false;\n  private showToolbarSubject = new Subject<boolean>();\n\n  @Input() zoom: number;\n  @Input() rotate: number;\n  @Input() set selectedAnnoId(selectedId: { annotationId: string }) {\n    if (selectedId) {\n      const id = this.anno.id || this.anno.redactionId; // todo make it unique\n      this.selected = selectedId.annotationId ? (selectedId.annotationId === id) : false;\n      if (this.selected && !this.isKeyboardMoving) {\n        this.showToolbarSubject.next(true);\n      } else {\n        this.showToolbarSubject.next(false);\n      }\n    }\n  }\n  @Input() pageHeight: number;\n  @Input() pageWidth: number;\n  @Output() update = new EventEmitter<Annotation>();\n  @Output() delete = new EventEmitter<Annotation>();\n  @Output() annotationClick = new EventEmitter<SelectionAnnotation>();\n\n  @ViewChild('container', { static: false }) container: ElementRef;\n\n  constructor(\n    private readonly toolbarEvents: ToolbarEventService,\n    private store: Store<fromStore.AnnotationSetState>\n  ) {\n    this.showToolbarSubject\n      .pipe(debounceTime(300))\n      .subscribe(show => {\n        this.showToolbar = show;\n      });\n  }\n\n  ngOnDestroy(): void {\n    this.showToolbarSubject.complete();\n  }\n\n  private setShowToolbar(show: boolean): void {\n    this.showToolbarSubject.next(show);\n  }\n\n  public onSelect() {\n    const annotationId = this.anno.id || this.anno.redactionId;\n    this.annotationClick.emit({ annotationId, editable: false, selected: true });\n\n    if (!this.isKeyboardMoving) {\n      this.setShowToolbar(true);\n    }\n  }\n\n  public onRectangleUpdate(rectangle: Rectangle) {\n    const annotation = { ...this.anno };\n    annotation.rectangles = annotation.rectangles.filter(r => r.id !== rectangle.id);\n    annotation.rectangles.push(rectangle);\n    this.update.emit(annotation);\n  }\n\n  public deleteHighlight() {\n    this.delete.emit(this.anno);\n  }\n\n  public addOrEditComment() {\n    if (this.anno.comments.length === 0) {\n      const comment: Comment = {\n        annotationId: this.anno.id,\n        content: '',\n        createdBy: this.anno.createdBy,\n        createdByDetails: undefined,\n        createdDate: moment.utc().tz('Europe/London').toISOString(),\n        id: uuid(),\n        lastModifiedBy: '',\n        lastModifiedByDetails: undefined,\n        lastModifiedDate: '',\n        tags: [],\n        page: null,\n        pages: {},\n        pageHeight: null,\n        selected: false,\n        editable: false\n      };\n      this.store.dispatch(new fromActions.AddOrEditComment(comment));\n\n    }\n    this.selected = true;\n    this.annotationClick.emit({ annotationId: this.anno.id, editable: true, selected: true });\n    this.toolbarEvents.toggleCommentsPanel(true);\n  }\n\n  public onKeyboardMovingChange(isMoving: boolean): void {\n    this.isKeyboardMoving = isMoving;\n\n    if (isMoving) {\n      this.showToolbar = false;\n      this.showToolbarSubject.next(false);\n    } else if (this.selected) {\n      this.setShowToolbar(true);\n    }\n  }\n}\n","<div #container [tabindex]=\"-1\">\n  <mv-ctx-toolbar *ngIf=\"selected && showToolbar\"\n                  [canDelete]=\"true\" [canComment]=\"true\"\n                  [rectangles]=\"anno.rectangles\"\n                  [zoom]=\"zoom\"\n                  [rotate]=\"rotate\"\n                  [pageHeight]=\"pageHeight\"\n                  [pageWidth]=\"pageWidth\"\n                  (deleteHighlightEvent)=\"deleteHighlight()\"\n                  (addOrEditCommentEvent)=\"addOrEditComment()\">\n  </mv-ctx-toolbar>\n  <ng-container *ngFor=\"let rectangle of anno.rectangles; let i = index\">\n    <mv-anno-rectangle\n      (selectEvent)=\"onSelect()\"\n      (updateEvent)=\"onRectangleUpdate($event)\"\n      (keyboardMovingChange)=\"onKeyboardMovingChange($event)\"\n      (deleteEvent)=\"deleteHighlight()\"\n      [selected]=\"selected\"\n      [zoom]=\"zoom\"\n      [rotate]=\"rotate\"\n      [pageHeight]=\"pageHeight\"\n      [pageWidth]=\"pageWidth\"\n      [editable]=\"anno.rectangles.length <= 1\"\n      [annoRect]=\"rectangle\"\n      [rectangleTabIndex]=\"i + 1\"\n      [color]=\"anno.color\">\n    </mv-anno-rectangle>\n  </ng-container>\n</div>\n"]}
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"annotation-view.component.js","sourceRoot":"","sources":["../../../../../../../projects/media-viewer/src/lib/annotations/annotation-set/annotation-view/annotation-view.component.ts","../../../../../../../projects/media-viewer/src/lib/annotations/annotation-set/annotation-view/annotation-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, ViewChild, ElementRef } from '@angular/core';\nimport { v4 as uuid } from 'uuid';\nimport { Annotation } from './annotation.model';\nimport { Rectangle } from './rectangle/rectangle.model';\nimport moment from 'moment-timezone';\nimport { Store } from '@ngrx/store';\nimport * as fromStore from '../../../store/reducers/reducers';\nimport * as fromActions from '../../../store/actions/annotation.actions';\nimport { SelectionAnnotation } from '../../models/event-select.model';\nimport { ToolbarEventService } from '../../../toolbar/toolbar-event.service';\nimport { Comment } from '../../comment-set/comment/comment.model';\n\n@Component({\n  selector: 'mv-annotation',\n  templateUrl: './annotation-view.component.html'\n})\nexport class AnnotationViewComponent {  // todo rename this to selection vew c\n\n  @Input() set annotation(value) {\n    this.anno = { ...value };\n  }\n  anno: Annotation;\n  selected: boolean;\n  @Input() zoom: number;\n  @Input() rotate: number;\n  @Input() set selectedAnnoId(selectedId: { annotationId: string }) {\n    if (selectedId) {\n      const id = this.anno.id || this.anno.redactionId; // todo make it unique\n      this.selected = selectedId.annotationId ? (selectedId.annotationId === id) : false;\n    }\n  }\n  @Input() pageHeight: number;\n  @Input() pageWidth: number;\n  @Output() update = new EventEmitter<Annotation>();\n  @Output() delete = new EventEmitter<Annotation>();\n  @Output() annotationClick = new EventEmitter<SelectionAnnotation>();\n\n  @ViewChild('container', { static: false }) container: ElementRef;\n\n  constructor(\n    private readonly toolbarEvents: ToolbarEventService,\n    private store: Store<fromStore.AnnotationSetState>\n  ) { }\n\n  public onSelect() {\n    const annotationId = this.anno.id || this.anno.redactionId;\n    this.annotationClick.emit({ annotationId, editable: false, selected: true });\n  }\n\n  public onRectangleUpdate(rectangle: Rectangle) {\n    const annotation = { ...this.anno };\n    annotation.rectangles = annotation.rectangles.filter(r => r.id !== rectangle.id);\n    annotation.rectangles.push(rectangle);\n    this.update.emit(annotation);\n  }\n\n  public deleteHighlight() {\n    this.delete.emit(this.anno);\n  }\n\n  public addOrEditComment() {\n    if (this.anno.comments.length === 0) {\n      const comment: Comment = {\n        annotationId: this.anno.id,\n        content: '',\n        createdBy: this.anno.createdBy,\n        createdByDetails: undefined,\n        createdDate: moment.utc().tz('Europe/London').toISOString(),\n        id: uuid(),\n        lastModifiedBy: '',\n        lastModifiedByDetails: undefined,\n        lastModifiedDate: '',\n        tags: [],\n        page: null,\n        pages: {},\n        pageHeight: null,\n        selected: false,\n        editable: false\n      };\n      this.store.dispatch(new fromActions.AddOrEditComment(comment));\n\n    }\n    this.selected = true;\n    this.annotationClick.emit({ annotationId: this.anno.id, editable: true, selected: true });\n    this.toolbarEvents.toggleCommentsPanel(true);\n  }\n}\n","<div #container [tabindex]=\"anno.id\">\n  <mv-ctx-toolbar *ngIf=\"selected\"\n                  [canDelete]=\"true\" [canComment]=\"true\"\n                  [rectangles]=\"anno.rectangles\"\n                  [zoom]=\"zoom\"\n                  [rotate]=\"rotate\"\n                  [pageHeight]=\"pageHeight\"\n                  [pageWidth]=\"pageWidth\"\n                  (deleteHighlightEvent)=\"deleteHighlight()\"\n                  (addOrEditCommentEvent)=\"addOrEditComment()\">\n  </mv-ctx-toolbar>\n  <ng-container *ngFor=\"let rectangle of anno.rectangles\">\n    <mv-anno-rectangle\n      (selectEvent)=\"onSelect()\"\n      (updateEvent)=\"onRectangleUpdate($event)\"\n      [selected]=\"selected\"\n      [zoom]=\"zoom\"\n      [rotate]=\"rotate\"\n      [pageHeight]=\"pageHeight\"\n      [pageWidth]=\"pageWidth\"\n      [editable]=\"anno.rectangles.length <= 1\"\n      [annoRect]=\"rectangle\"\n      [color]=\"anno.color\">\n    </mv-anno-rectangle>\n  </ng-container>\n</div>\n"]}
|