@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.
Files changed (37) hide show
  1. package/assets/sass/box-highlight.scss +0 -38
  2. package/esm2022/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.mjs +19 -74
  3. package/esm2022/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.service.mjs +4 -4
  4. package/esm2022/lib/annotations/annotation-set/annotation-view/annotation-view.component.mjs +3 -37
  5. package/esm2022/lib/annotations/annotation-set/annotation-view/rectangle/rectangle.component.mjs +3 -39
  6. package/esm2022/lib/annotations/annotation-set/metadata-layer/metadata-layer.component.mjs +3 -3
  7. package/esm2022/lib/annotations/annotations.module.mjs +3 -9
  8. package/esm2022/lib/store/actions/annotation.actions.mjs +2 -3
  9. package/esm2022/lib/store/effects/annotation.effects.mjs +3 -14
  10. package/esm2022/lib/viewers/pdf-viewer/pdf-viewer.component.mjs +28 -3
  11. package/fesm2022/hmcts-media-viewer.mjs +60 -546
  12. package/fesm2022/hmcts-media-viewer.mjs.map +1 -1
  13. package/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.d.ts +2 -16
  14. package/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.d.ts.map +1 -1
  15. package/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.service.d.ts +1 -1
  16. package/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.service.d.ts.map +1 -1
  17. package/lib/annotations/annotation-set/annotation-view/annotation-view.component.d.ts +2 -8
  18. package/lib/annotations/annotation-set/annotation-view/annotation-view.component.d.ts.map +1 -1
  19. package/lib/annotations/annotation-set/annotation-view/rectangle/rectangle.component.d.ts +1 -10
  20. package/lib/annotations/annotation-set/annotation-view/rectangle/rectangle.component.d.ts.map +1 -1
  21. package/lib/annotations/annotation-set/metadata-layer/metadata-layer.component.d.ts +1 -2
  22. package/lib/annotations/annotation-set/metadata-layer/metadata-layer.component.d.ts.map +1 -1
  23. package/lib/annotations/annotations.module.d.ts +11 -13
  24. package/lib/annotations/annotations.module.d.ts.map +1 -1
  25. package/lib/store/actions/annotation.actions.d.ts +1 -2
  26. package/lib/store/actions/annotation.actions.d.ts.map +1 -1
  27. package/lib/store/effects/annotation.effects.d.ts +0 -1
  28. package/lib/store/effects/annotation.effects.d.ts.map +1 -1
  29. package/lib/viewers/pdf-viewer/pdf-viewer.component.d.ts +1 -0
  30. package/lib/viewers/pdf-viewer/pdf-viewer.component.d.ts.map +1 -1
  31. package/package.json +1 -1
  32. package/esm2022/lib/annotations/annotation-set/annotation-create/box-highlight-create/keyboard-box-draw.directive.mjs +0 -258
  33. package/esm2022/lib/annotations/annotation-set/annotation-view/rectangle/keyboard-box-move.directive.mjs +0 -122
  34. package/lib/annotations/annotation-set/annotation-create/box-highlight-create/keyboard-box-draw.directive.d.ts +0 -59
  35. package/lib/annotations/annotation-set/annotation-create/box-highlight-create/keyboard-box-draw.directive.d.ts.map +0 -1
  36. package/lib/annotations/annotation-set/annotation-view/rectangle/keyboard-box-move.directive.d.ts +0 -27
  37. 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.adjustForRotation();
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
- const annotationId = uuid();
84
- rectangle = { id: annotationId, ...rectangle };
85
- this.saveSelection.emit({ rectangles: [rectangle], page: this.page, annotationId });
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 }, { propertyName: "drawingContainer", first: true, predicate: ["drawingContainer"], descendants: true }], ngImport: i0, template: "<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", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.KeyboardBoxDrawDirective, selector: "[mvKeyboardBoxDraw]", inputs: ["enabled", "minBoxSize", "incrementSmall", "incrementMedium", "incrementLarge"], outputs: ["drawingStarted", "drawingUpdated", "drawingConfirmed", "drawingCancelled", "cursorPositionChanged"] }] }); }
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 #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" }]
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":"AAAA,OAAO,EAAE,SAAS,EAAc,YAAY,EAAE,KAAK,EAAqB,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACjH,OAAO,EAAE,EAAE,IAAI,IAAI,EAAE,MAAM,MAAM,CAAC;AAKlC,OAAO,EAAE,mBAAmB,EAAE,MAAM,uDAAuD,CAAC;;;;;;AAO5F,MAAM,OAAO,2BAA2B;IAqCtC,YAA6B,aAAkC,EAC5C,gBAAwC;QAD9B,kBAAa,GAAb,aAAa,CAAqB;QAC5C,qBAAgB,GAAhB,gBAAgB,CAAwB;QA7BjD,kBAAa,GAAG,IAAI,YAAY,EAAoE,CAAC;QAK/G,eAAU,GAAG,CAAC,CAAC,CAAC;QAChB,eAAU,GAAG,CAAC,CAAC,CAAC;QAQhB,oBAAe,GAAG,MAAM,CAAC;QAOzB,wBAAmB,GAAG,KAAK,CAAC;QAG5B,eAAU,GAAG,KAAK,CAAC;QAEX,kBAAa,GAAmB,EAAE,CAAC;IAGoB,CAAC;IAEhE,QAAQ;QACN,IAAI,CAAC,aAAa,GAAG;YACnB,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE;gBACtD,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC;gBAC/C,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC;gBAC9C,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;gBACzB,IAAI,QAAQ,EAAE,CAAC;oBACb,UAAU,CAAC,GAAG,EAAE;wBACd,IAAI,IAAI,CAAC,gBAAgB,EAAE,aAAa,IAAI,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,EAAE,CAAC;4BAC1G,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;wBAC9C,CAAC;oBACH,CAAC,EAAE,GAAG,CAAC,CAAC;gBACV,CAAC;YACH,CAAC,CAAC;YACF,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,SAAS,CAAC,GAAG,EAAE;gBAChD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YACxB,CAAC,CAAC;SACH,CAAC;IACJ,CAAC;IAED,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE;YACxC,YAAY,CAAC,WAAW,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,mBAAmB,CAAC,EAAe;QACzC,MAAM,IAAI,GAAG,EAAE,CAAC,qBAAqB,EAAE,CAAC;QACxC,MAAM,YAAY,GAAG,CAAC,MAAM,CAAC,WAAW,IAAI,QAAQ,CAAC,eAAe,CAAC,YAAY,CAAC,CAAC;QACnF,MAAM,WAAW,GAAG,CAAC,MAAM,CAAC,UAAU,IAAI,QAAQ,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;QAEhF,MAAM,iBAAiB,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,GAAG,GAAG,YAAY,CAAC;QACrE,MAAM,mBAAmB,GAAG,IAAI,CAAC,KAAK,GAAG,CAAC,IAAI,IAAI,CAAC,IAAI,GAAG,WAAW,CAAC;QAEtE,OAAO,iBAAiB,IAAI,mBAAmB,CAAC;IAClD,CAAC;IAED,aAAa,CAAC,KAAiB;QAC7B,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,OAAO;QACT,CAAC;QAED,MAAM,IAAI,GAAG,mBAAmB,CAAC,uBAAuB,CAAE,KAAK,CAAC,MAAsB,CAAC,EACvF,OAAO,GAAG,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,IAAI,EACnC,OAAO,GAAG,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC;QAEnC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;QAC3B,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC;QAChC,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC;QAC1B,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC;QAE1B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;QACjB,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QAChB,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,UAAU,CAAC;QAC3B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC;QAE5B,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAED,eAAe,CAAC,KAAiB;QAC/B,MAAM,IAAI,GAAG,mBAAmB,CAAC,uBAAuB,CAAC,KAAK,CAAC,MAAqB,EAAE,KAAK,CAAC,EAC1F,OAAO,GAAG,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,IAAI,EACnC,OAAO,GAAG,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC;QAErC,IAAI,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,IAAI,CAAC,UAAU,GAAG,CAAC,EAAE,CAAC;YAC/C,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC;YAClD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC;YACjD,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;YAC9C,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;QACjD,CAAC;IACH,CAAC;IAED,eAAe;QACb,IAAI,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,GAAG,CAAC,IAAI,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,GAAG,CAAC,EAAE,CAAC;YAC9D,IAAI,SAAS,GAAG,IAAI,CAAC,gBAAgB;iBAClC,aAAa,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YACxH,MAAM,YAAY,GAAG,IAAI,EAAE,CAAC;YAC5B,SAAS,GAAG,EAAE,EAAE,EAAE,YAAY,EAAE,GAAG,SAAS,EAAS,CAAC;YACtD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,UAAU,EAAE,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,YAAY,EAAE,CAAC,CAAC;YACpF,IAAI,CAAC,cAAc,EAAE,CAAC;QACxB,CAAC;IACH,CAAC;IAED,uBAAuB,CAAC,QAAwB;QAC9C,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,CAAC,CAAC;QAC1B,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,CAAC,CAAC;QAC1B,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC,OAAO,CAAC;IACrC,CAAC;IAED,gBAAgB,CAAC,KAA2B;QAC1C,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;QAChC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;QAC3B,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC;QAChC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QAEvB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,MAAM,CAAC;QAC/B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,MAAM,CAAC;QAC/B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;QACzB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;QAC3B,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,UAAU,CAAC;QAC3B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC;QAE5B,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAED,gBAAgB,CAAC,KAA2B;QAC1C,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;QACzB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;IAC7B,CAAC;IAED,kBAAkB,CAAC,KAA2B;QAC5C,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;QACjC,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;QACjC,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEO,iBAAiB;QACvB,QAAQ,IAAI,CAAC,MAAM,EAAE,CAAC;YACpB,KAAK,EAAE;gBACL,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC;gBACzC,MAAM;YACR,KAAK,GAAG;gBACN,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC;gBACzC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC;gBACzC,MAAM;YACR,KAAK,GAAG;gBACN,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC;gBACzC,MAAM;QACV,CAAC;IACH,CAAC;IAEO,cAAc;QACpB,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;QACrB,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;QACrB,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;QACtB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;QACf,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;QAChB,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC;QAC9B,IAAI,CAAC,QAAQ,GAAG,SAAS,CAAC;QAC1B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IAEO,aAAa;QACnB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC;QAC9B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC;QAC5B,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC;QACb,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;QACd,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;kIAlMU,2BAA2B;sHAA3B,2BAA2B,kcCbxC,mlCAiCA;;4FDpBa,2BAA2B;kBAJvC,SAAS;+BACE,yBAAyB;6HAK1B,IAAI;sBAAZ,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBAEI,aAAa;sBAAtB,MAAM;gBAEuC,SAAS;sBAAtD,SAAS;uBAAC,cAAc,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBACM,gBAAgB;sBAAjE,SAAS;uBAAC,kBAAkB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE","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, annotationId) {
16
+ saveAnnotation(rectangles, page) {
17
17
  this.store.pipe(select(fromSelectors.getDocumentIdSetId), take(1)).subscribe(anoSetDocId => {
18
18
  const anno = {
19
- id: annotationId || uuid(),
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, !!annotationId));
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"]}
@@ -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]=\"-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", 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", "rectangleTabIndex", "annoRect", "selected"], outputs: ["selectEvent", "updateEvent", "deleteEvent", "keyboardMovingChange"] }, { kind: "component", type: i5.CtxToolbarComponent, selector: "mv-ctx-toolbar", inputs: ["zoom", "rotate", "pageHeight", "pageWidth", "canHighlight", "canBookmark", "canComment", "canDelete", "rectangles"], outputs: ["createHighlightEvent", "deleteHighlightEvent", "addOrEditCommentEvent", "createBookmarkEvent"] }] }); }
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]=\"-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" }]
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"]}