@hmcts/media-viewer 4.1.8 → 4.1.9-exui-1580

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 (34) hide show
  1. package/assets/all.scss +1 -0
  2. package/assets/sass/pdf-viewer.scss +79 -1
  3. package/assets/sass/tooltip.scss +50 -0
  4. package/esm2022/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.directive.mjs +80 -21
  5. package/esm2022/lib/annotations/annotation-set/annotation-create/highlight-create/keyboard-text-highlight.directive.mjs +354 -0
  6. package/esm2022/lib/annotations/annotation-set/annotation-view/annotation-view.component.mjs +1 -1
  7. package/esm2022/lib/annotations/annotation-set/ctx-toolbar/ctx-toolbar.component.mjs +31 -5
  8. package/esm2022/lib/annotations/annotation-set/metadata-layer/metadata-layer.component.mjs +17 -4
  9. package/esm2022/lib/media-viewer.module.mjs +4 -1
  10. package/esm2022/lib/shared/directives/tooltip-dismiss.directive.mjs +36 -0
  11. package/esm2022/lib/toolbar/highlight-toolbar/highlight-toolbar.component.mjs +6 -4
  12. package/esm2022/lib/toolbar/main-toolbar/main-toolbar.component.mjs +5 -4
  13. package/esm2022/lib/toolbar/redaction-toolbar/redaction-toolbar.component.mjs +5 -4
  14. package/esm2022/lib/toolbar/toolbar.module.mjs +7 -4
  15. package/esm2022/lib/viewers/pdf-viewer/pdf-viewer.component.mjs +45 -7
  16. package/fesm2022/hmcts-media-viewer.mjs +1448 -926
  17. package/fesm2022/hmcts-media-viewer.mjs.map +1 -1
  18. package/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.directive.d.ts +6 -2
  19. package/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.directive.d.ts.map +1 -1
  20. package/lib/annotations/annotation-set/annotation-create/highlight-create/keyboard-text-highlight.directive.d.ts +63 -0
  21. package/lib/annotations/annotation-set/annotation-create/highlight-create/keyboard-text-highlight.directive.d.ts.map +1 -0
  22. package/lib/annotations/annotation-set/ctx-toolbar/ctx-toolbar.component.d.ts +6 -2
  23. package/lib/annotations/annotation-set/ctx-toolbar/ctx-toolbar.component.d.ts.map +1 -1
  24. package/lib/annotations/annotation-set/metadata-layer/metadata-layer.component.d.ts +3 -0
  25. package/lib/annotations/annotation-set/metadata-layer/metadata-layer.component.d.ts.map +1 -1
  26. package/lib/media-viewer.module.d.ts +19 -18
  27. package/lib/media-viewer.module.d.ts.map +1 -1
  28. package/lib/shared/directives/tooltip-dismiss.directive.d.ts +11 -0
  29. package/lib/shared/directives/tooltip-dismiss.directive.d.ts.map +1 -0
  30. package/lib/toolbar/toolbar.module.d.ts +7 -6
  31. package/lib/toolbar/toolbar.module.d.ts.map +1 -1
  32. package/lib/viewers/pdf-viewer/pdf-viewer.component.d.ts +20 -0
  33. package/lib/viewers/pdf-viewer/pdf-viewer.component.d.ts.map +1 -1
  34. package/package.json +2 -2
package/assets/all.scss CHANGED
@@ -26,6 +26,7 @@
26
26
  @import "sass/tags";
27
27
  @import "sass/toolbar/main";
28
28
  @import 'sass/tabs';
29
+ @import 'sass/tooltip';
29
30
  @import 'sass/comment-filter';
30
31
  @import 'sass/angular-tree-component';
31
32
  @import 'sass/redaction';
@@ -101,6 +101,84 @@ mv-pdf-viewer {
101
101
  width: 100%;
102
102
  transition-duration: 600ms;
103
103
  transition-timing-function: ease;
104
+
105
+ &.highlightMode {
106
+ position: relative;
107
+ }
108
+ }
109
+
110
+ // keyboard cursor for text highlighting (before selection)
111
+ .selection-start-cursor {
112
+ width: 14px;
113
+ height: 14px;
114
+ margin-left: -7px;
115
+ margin-top: -7px;
116
+ pointer-events: none;
117
+ background-color: #ffdd00;
118
+ border-radius: 50%;
119
+ border: 1px solid #ffdd00;
120
+
121
+ // vertical line
122
+ &::before {
123
+ content: '';
124
+ position: absolute;
125
+ top: 0;
126
+ left: 50%;
127
+ width: 1px;
128
+ height: 100%;
129
+ background-color: #0b0c0c;
130
+ transform: translateX(-0.5px);
131
+ }
132
+
133
+ // horizontal line
134
+ &::after {
135
+ content: '';
136
+ position: absolute;
137
+ top: 50%;
138
+ left: 0;
139
+ width: 100%;
140
+ height: 1px;
141
+ background-color: #0b0c0c;
142
+ transform: translateY(-0.5px);
143
+ }
144
+ }
145
+
146
+ // keyboard cursor for text highlighting (during selection)
147
+ .selection-end-cursor {
148
+ width: 1px;
149
+ height: 12px;
150
+ margin-left: -1px;
151
+ margin-top: -10px;
152
+ pointer-events: none;
153
+ background-color: #0b0c0c;
154
+ border-radius: 0;
155
+ box-shadow: -1px 0 0 #ffffff, 1px 0 0 #ffffff;
156
+
157
+ // I-beam top
158
+ &::before {
159
+ content: '';
160
+ position: absolute;
161
+ top: -1px;
162
+ left: 50%;
163
+ width: 5px;
164
+ height: 1px;
165
+ background-color: #0b0c0c;
166
+ transform: translateX(-50%);
167
+ box-shadow: 0 -1px 0 #ffffff, 0 1px 0 #ffffff;
168
+ }
169
+
170
+ // I-beam bottom
171
+ &::after {
172
+ content: '';
173
+ position: absolute;
174
+ bottom: -1px;
175
+ left: 50%;
176
+ width: 5px;
177
+ height: 1px;
178
+ background-color: #0b0c0c;
179
+ transform: translateX(-50%);
180
+ box-shadow: 0 -1px 0 #ffffff, 0 1px 0 #ffffff;
181
+ }
104
182
  }
105
183
 
106
184
  .show-comments-panel {
@@ -128,4 +206,4 @@ mv-pdf-viewer {
128
206
  .splitToolbarButton.left {
129
207
  float: left;
130
208
  }
131
- }
209
+ }
@@ -0,0 +1,50 @@
1
+ .mv-tooltip {
2
+ /* default: place below */
3
+ --tooltip-offset-y: 100%;
4
+ }
5
+
6
+ .mv-tooltip::before {
7
+ content: attr(data-tooltip); /* Tooltip text comes from attribute */
8
+ position: absolute;
9
+ top: var(--tooltip-offset-y);
10
+ left: 50%;
11
+ transform: translateX(-50%);
12
+ background: #e3e2e1;
13
+ color: #444444;
14
+ border: 1px solid #d1d1d1;
15
+ font-size: 11px;
16
+ font-family: system-ui, sans-serif;
17
+ padding: 3px 6px;
18
+ border-radius: 2px;
19
+ /* Dynamic sizing */
20
+ white-space: nowrap;
21
+ width: max-content;
22
+ max-width: 300px;
23
+ z-index: 999;
24
+ opacity: 0;
25
+ visibility: hidden;
26
+ transition: opacity 0.2s ease-in-out;
27
+ box-shadow: 0px 2px 4px rgba(0,0,0,0.3);
28
+ }
29
+
30
+ /* Show tooltip on hover and focus */
31
+ .mv-tooltip:hover::after,
32
+ .mv-tooltip:focus::after,
33
+ .mv-tooltip:hover::before,
34
+ /* Show tooltip on hover or keyboard focus */
35
+ .mv-tooltip:focus::before,
36
+ .mv-tooltip:focus-within::before {
37
+ opacity: 1;
38
+ visibility: visible;
39
+ }
40
+
41
+ /* Hide tooltip when dismissed, even if focussed */
42
+ .mv-tooltip[data-tooltip-dismissed]::before {
43
+ opacity: 0;
44
+ visibility: hidden;
45
+ }
46
+
47
+ /* place above */
48
+ .mv-tooltip[data-placement="above"] {
49
+ --tooltip-offset-y: -50%;
50
+ }
@@ -1,5 +1,6 @@
1
1
  import { Directive, HostListener } from '@angular/core';
2
2
  import { v4 as uuid } from 'uuid';
3
+ import { debounceTime, filter } from 'rxjs';
3
4
  import * as fromDocument from '../../../../store/selectors/document.selectors';
4
5
  import * as fromAnnotationActions from '../../../../store/actions/annotation.actions';
5
6
  import { HtmlTemplatesHelper } from '../../../../shared/util/helpers/html-templates.helper';
@@ -15,18 +16,20 @@ export class HighlightCreateDirective {
15
16
  this.viewerEvents = viewerEvents;
16
17
  this.highlightService = highlightService;
17
18
  this.store = store;
19
+ this.$subscriptions = [];
18
20
  }
19
21
  ngOnInit() {
20
- this.$subscription = this.store.select(fromDocument.getPages).subscribe((pages) => {
22
+ this.$subscriptions.push(this.store.select(fromDocument.getPages).subscribe((pages) => {
21
23
  if (pages[1]) {
22
24
  this.allPages = pages;
23
25
  }
24
- });
26
+ }));
27
+ this.$subscriptions.push(this.toolbarEvents.highlightModeSubject.pipe(filter(enabled => enabled && !!this.element.nativeElement), debounceTime(100)).subscribe(() => {
28
+ this.element.nativeElement.focus();
29
+ }));
25
30
  }
26
31
  ngOnDestroy() {
27
- if (this.$subscription) {
28
- this.$subscription.unsubscribe();
29
- }
32
+ this.$subscriptions.forEach(sub => sub.unsubscribe());
30
33
  }
31
34
  onMouseUp(mouseEvent) {
32
35
  let page;
@@ -45,6 +48,56 @@ export class HighlightCreateDirective {
45
48
  this.viewerEvents.textSelected({ page, rectangles });
46
49
  }
47
50
  }
51
+ onKeyboardSelectionConfirmed() {
52
+ if (this.toolbarEvents.highlightModeSubject.getValue()) {
53
+ const selection = window.getSelection();
54
+ if (selection && selection.rangeCount && !selection.isCollapsed) {
55
+ const page = this.getCurrentPageFromSelection(selection);
56
+ const rectangles = this.getRectanglesFromSelection(selection, page);
57
+ if (rectangles && rectangles.length > 0) {
58
+ this.viewerEvents.textSelected({ page, rectangles });
59
+ }
60
+ }
61
+ }
62
+ }
63
+ getCurrentPageFromSelection(selection) {
64
+ const range = selection.getRangeAt(0);
65
+ let currentElement = range.startContainer;
66
+ if (currentElement.nodeType === Node.TEXT_NODE) {
67
+ currentElement = currentElement.parentElement;
68
+ }
69
+ while (currentElement && currentElement.offsetParent) {
70
+ currentElement = currentElement.offsetParent;
71
+ if (currentElement.getAttribute) {
72
+ const page = parseInt(currentElement.getAttribute('data-page-number'), 10);
73
+ if (page) {
74
+ return page;
75
+ }
76
+ }
77
+ }
78
+ return 1;
79
+ }
80
+ getRectanglesFromSelection(selection, page) {
81
+ if (!this.allPages || !this.allPages[page]) {
82
+ return [];
83
+ }
84
+ this.setPageProperties(page);
85
+ const range = selection.getRangeAt(0).cloneRange();
86
+ const clientRects = range.getClientRects();
87
+ if (!clientRects || clientRects.length === 0) {
88
+ return [];
89
+ }
90
+ let textLayerElement = range.startContainer;
91
+ if (textLayerElement.nodeType === Node.TEXT_NODE) {
92
+ textLayerElement = textLayerElement.parentElement;
93
+ }
94
+ const textLayer = textLayerElement.closest('.textLayer');
95
+ if (!textLayer) {
96
+ return [];
97
+ }
98
+ this.removeEnhancedTextModeStyling(textLayerElement);
99
+ return this.processClientRects(clientRects, textLayer);
100
+ }
48
101
  onPdfViewerClick(event) {
49
102
  this.store.dispatch(new fromAnnotationActions.SelectedAnnotation({
50
103
  annotationId: '',
@@ -54,10 +107,7 @@ export class HighlightCreateDirective {
54
107
  this.viewerEvents.clearCtxToolbar();
55
108
  }
56
109
  getRectangles(event, page) {
57
- this.pageHeight = this.allPages[page].styles.height;
58
- this.pageWidth = this.allPages[page].styles.width;
59
- this.zoom = parseFloat(this.allPages[page].scaleRotation.scale);
60
- this.rotate = parseInt(this.allPages[page].scaleRotation.rotation, 10);
110
+ this.setPageProperties(page);
61
111
  const selection = window.getSelection();
62
112
  if (selection) {
63
113
  const localElement = event.target;
@@ -66,17 +116,8 @@ export class HighlightCreateDirective {
66
116
  const range = selection.getRangeAt(0).cloneRange();
67
117
  const clientRects = range.getClientRects();
68
118
  if (clientRects) {
69
- const parentRect = HtmlTemplatesHelper
70
- .getAdjustedBoundingRect(localElement.closest(".textLayer"));
71
- const selectionRectangles = [];
72
- for (let i = 0; i < clientRects.length; i++) {
73
- const selectionRectangle = this.createTextRectangle(clientRects[i], parentRect);
74
- const findSelecttionRectangle = selectionRectangles.find((rect) => rect.width === selectionRectangle.width && rect.x === selectionRectangle.x);
75
- if (!findSelecttionRectangle) {
76
- selectionRectangles.push(selectionRectangle);
77
- }
78
- }
79
- return selectionRectangles;
119
+ const textLayer = localElement.closest(".textLayer");
120
+ return this.processClientRects(clientRects, textLayer);
80
121
  }
81
122
  }
82
123
  }
@@ -102,6 +143,24 @@ export class HighlightCreateDirective {
102
143
  }
103
144
  }
104
145
  }
146
+ setPageProperties(page) {
147
+ this.pageHeight = this.allPages[page].styles.height;
148
+ this.pageWidth = this.allPages[page].styles.width;
149
+ this.zoom = parseFloat(this.allPages[page].scaleRotation.scale);
150
+ this.rotate = parseInt(this.allPages[page].scaleRotation.rotation, 10);
151
+ }
152
+ processClientRects(clientRects, textLayer) {
153
+ const parentRect = HtmlTemplatesHelper.getAdjustedBoundingRect(textLayer);
154
+ const selectionRectangles = [];
155
+ for (let i = 0; i < clientRects.length; i++) {
156
+ const selectionRectangle = this.createTextRectangle(clientRects[i], parentRect);
157
+ const findSelectionRectangle = selectionRectangles.find((rect) => rect.width === selectionRectangle.width && rect.x === selectionRectangle.x);
158
+ if (!findSelectionRectangle) {
159
+ selectionRectangles.push(selectionRectangle);
160
+ }
161
+ }
162
+ return selectionRectangles;
163
+ }
105
164
  /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: HighlightCreateDirective, deps: [{ token: i0.ElementRef }, { token: i1.ToolbarEventService }, { token: i2.ViewerEventService }, { token: i3.HighlightCreateService }, { token: i4.Store }], target: i0.ɵɵFactoryTarget.Directive }); }
106
165
  /** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: HighlightCreateDirective, selector: "[mvCreateTextHighlight]", host: { listeners: { "mouseup": "onMouseUp($event)", "mousedown": "onPdfViewerClick($event)" } }, ngImport: i0 }); }
107
166
  }
@@ -117,4 +176,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
117
176
  type: HostListener,
118
177
  args: ['mousedown', ['$event']]
119
178
  }] } });
120
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"highlight-create.directive.js","sourceRoot":"","sources":["../../../../../../../../projects/media-viewer/src/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, HostListener, OnDestroy, OnInit } from '@angular/core';\nimport { v4 as uuid } from 'uuid';\nimport { Store } from '@ngrx/store';\nimport { Subscription } from 'rxjs';\n\nimport { Rectangle } from '../../annotation-view/rectangle/rectangle.model';\nimport * as fromStore from '../../../../store/reducers/reducers';\nimport * as fromDocument from '../../../../store/selectors/document.selectors';\nimport { ViewerEventService } from '../../../../viewers/viewer-event.service';\nimport * as fromAnnotationActions from '../../../../store/actions/annotation.actions';\nimport { HighlightCreateService } from './highlight-create.service';\nimport { ToolbarEventService } from '../../../../toolbar/toolbar-event.service';\nimport { HtmlTemplatesHelper } from '../../../../shared/util/helpers/html-templates.helper';\n\n@Directive({\n  selector: '[mvCreateTextHighlight]'\n})\nexport class HighlightCreateDirective implements OnInit, OnDestroy {\n  pageHeight: number;\n  pageWidth: number;\n  zoom: number;\n  rotate: number;\n  allPages: object;\n\n  $subscription: Subscription;\n\n  constructor(\n    private element: ElementRef<HTMLElement>,\n    private toolbarEvents: ToolbarEventService,\n    private viewerEvents: ViewerEventService,\n    private highlightService: HighlightCreateService,\n    private store: Store<fromStore.AnnotationSetState>\n  ) { }\n\n  ngOnInit() {\n    this.$subscription = this.store.select(fromDocument.getPages).subscribe((pages) => {\n      if (pages[1]) {\n        this.allPages = pages;\n      }\n    });\n  }\n\n  ngOnDestroy() {\n    if (this.$subscription) {\n      this.$subscription.unsubscribe();\n    }\n  }\n\n  @HostListener('mouseup', ['$event'])\n  onMouseUp(mouseEvent: MouseEvent) {\n    let page: number;\n    let currentElement = mouseEvent.target as HTMLElement;\n    while (currentElement.offsetParent) {\n      currentElement = currentElement.offsetParent as HTMLElement;\n      if (currentElement.getAttribute) {\n        page = parseInt(currentElement.getAttribute('data-page-number'), 10);\n        if (page) {\n          break;\n        }\n      }\n    }\n    if (this.toolbarEvents.highlightModeSubject.getValue()) {\n      const rectangles = this.getRectangles(mouseEvent, page);\n      this.viewerEvents.textSelected({ page, rectangles });\n    }\n  }\n\n  @HostListener('mousedown', ['$event'])\n  onPdfViewerClick(event: MouseEvent) {\n    this.store.dispatch(\n      new fromAnnotationActions.SelectedAnnotation({\n        annotationId: '',\n        selected: false,\n        editable: false,\n      })\n    );\n    this.viewerEvents.clearCtxToolbar();\n  }\n\n  private getRectangles(event: MouseEvent, page) {\n    this.pageHeight = this.allPages[page].styles.height;\n    this.pageWidth = this.allPages[page].styles.width;\n    this.zoom = parseFloat(this.allPages[page].scaleRotation.scale);\n    this.rotate = parseInt(this.allPages[page].scaleRotation.rotation, 10);\n    const selection = window.getSelection();\n    if (selection) {\n      const localElement = <HTMLElement>event.target;\n\n      this.removeEnhancedTextModeStyling(localElement);\n\n      if (selection.rangeCount && !selection.isCollapsed) {\n        const range = selection.getRangeAt(0).cloneRange();\n        const clientRects = range.getClientRects();\n\n        if (clientRects) {\n\n          const parentRect = HtmlTemplatesHelper\n            .getAdjustedBoundingRect(localElement.closest(\".textLayer\"));\n          const selectionRectangles: Rectangle[] = [];\n          for (let i = 0; i < clientRects.length; i++) {\n            const selectionRectangle = this.createTextRectangle(clientRects[i], parentRect);\n            const findSelecttionRectangle = selectionRectangles.find(\n              (rect) => rect.width === selectionRectangle.width && rect.x === selectionRectangle.x\n            );\n            if (!findSelecttionRectangle) {\n              selectionRectangles.push(selectionRectangle);\n            }\n          }\n          return selectionRectangles;\n        }\n      }\n    }\n  }\n\n  private createTextRectangle(rect: any, parentRect: any): Rectangle {\n    const height = rect.bottom - rect.top;\n    const width = rect.right - rect.left;\n    const top = rect.top - parentRect.top;\n    const left = rect.left - parentRect.left;\n    let rectangle = this.highlightService.applyRotation(\n      this.pageHeight,\n      this.pageWidth,\n      height,\n      width,\n      top,\n      left,\n      this.rotate,\n      this.zoom\n    );\n    rectangle = { id: uuid(), ...rectangle };\n\n    return rectangle as Rectangle;\n  }\n\n  private removeEnhancedTextModeStyling(element: HTMLElement) {\n    if (element.parentElement.children) {\n      for (let i = 0; i < element.parentElement.children.length; i++) {\n        const child = <HTMLElement>element.parentElement.children[i];\n\n        child.style.padding = '0';\n        // regex will be targeting the translate style in string\n        // e.g. scaleX(0.969918) translateX(-110.684px) translateY(-105.274px) will become scaleX(0.969918)\n        const translateCSSRegex = /translate[XYZ]\\(-?\\d*(\\.\\d+)?(px)?\\)/g;\n        child.style.transform = child.style.transform.replace(translateCSSRegex, '').trim();\n      }\n    }\n  }\n}\n"]}
179
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"highlight-create.directive.js","sourceRoot":"","sources":["../../../../../../../../projects/media-viewer/src/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, HostListener, OnDestroy, OnInit } from '@angular/core';\nimport { v4 as uuid } from 'uuid';\nimport { Store } from '@ngrx/store';\nimport { debounceTime, filter, Subscription } from 'rxjs';\n\nimport { Rectangle } from '../../annotation-view/rectangle/rectangle.model';\nimport * as fromStore from '../../../../store/reducers/reducers';\nimport * as fromDocument from '../../../../store/selectors/document.selectors';\nimport { ViewerEventService } from '../../../../viewers/viewer-event.service';\nimport * as fromAnnotationActions from '../../../../store/actions/annotation.actions';\nimport { HighlightCreateService } from './highlight-create.service';\nimport { ToolbarEventService } from '../../../../toolbar/toolbar-event.service';\nimport { HtmlTemplatesHelper } from '../../../../shared/util/helpers/html-templates.helper';\n\n@Directive({\n  selector: '[mvCreateTextHighlight]'\n})\nexport class HighlightCreateDirective implements OnInit, OnDestroy {\n  pageHeight: number;\n  pageWidth: number;\n  zoom: number;\n  rotate: number;\n  allPages: object;\n\n  private $subscriptions: Subscription[] = [];\n\n  constructor(\n    private element: ElementRef<HTMLElement>,\n    private toolbarEvents: ToolbarEventService,\n    private viewerEvents: ViewerEventService,\n    private highlightService: HighlightCreateService,\n    private store: Store<fromStore.AnnotationSetState>\n  ) { }\n\n  ngOnInit() {\n    this.$subscriptions.push(this.store.select(fromDocument.getPages).subscribe((pages) => {\n      if (pages[1]) {\n        this.allPages = pages;\n      }\n    }));\n\n    this.$subscriptions.push(\n      this.toolbarEvents.highlightModeSubject.pipe(\n        filter(enabled => enabled && !!this.element.nativeElement),\n        debounceTime(100)\n      ).subscribe(() => {\n        this.element.nativeElement.focus();\n      })\n    );\n  }\n\n  ngOnDestroy() {\n    this.$subscriptions.forEach(sub => sub.unsubscribe());\n  }\n\n  @HostListener('mouseup', ['$event'])\n  onMouseUp(mouseEvent: MouseEvent) {\n    let page: number;\n    let currentElement = mouseEvent.target as HTMLElement;\n    while (currentElement.offsetParent) {\n      currentElement = currentElement.offsetParent as HTMLElement;\n      if (currentElement.getAttribute) {\n        page = parseInt(currentElement.getAttribute('data-page-number'), 10);\n        if (page) {\n          break;\n        }\n      }\n    }\n    if (this.toolbarEvents.highlightModeSubject.getValue()) {\n      const rectangles = this.getRectangles(mouseEvent, page);\n      this.viewerEvents.textSelected({ page, rectangles });\n    }\n  }\n\n  public onKeyboardSelectionConfirmed(): void {\n    if (this.toolbarEvents.highlightModeSubject.getValue()) {\n      const selection = window.getSelection();\n      if (selection && selection.rangeCount && !selection.isCollapsed) {\n        const page = this.getCurrentPageFromSelection(selection);\n        const rectangles = this.getRectanglesFromSelection(selection, page);\n        if (rectangles && rectangles.length > 0) {\n          this.viewerEvents.textSelected({ page, rectangles });\n        }\n      }\n    }\n  }\n\n  private getCurrentPageFromSelection(selection: Selection): number {\n    const range = selection.getRangeAt(0);\n    let currentElement = range.startContainer as HTMLElement;\n\n    if (currentElement.nodeType === Node.TEXT_NODE) {\n      currentElement = currentElement.parentElement;\n    }\n\n    while (currentElement && currentElement.offsetParent) {\n      currentElement = currentElement.offsetParent as HTMLElement;\n      if (currentElement.getAttribute) {\n        const page = parseInt(currentElement.getAttribute('data-page-number'), 10);\n        if (page) {\n          return page;\n        }\n      }\n    }\n    return 1;\n  }\n\n  private getRectanglesFromSelection(selection: Selection, page: number): Rectangle[] {\n    if (!this.allPages || !this.allPages[page]) {\n      return [];\n    }\n\n    this.setPageProperties(page);\n\n    const range = selection.getRangeAt(0).cloneRange();\n    const clientRects = range.getClientRects();\n\n    if (!clientRects || clientRects.length === 0) {\n      return [];\n    }\n\n    let textLayerElement = range.startContainer as HTMLElement;\n    if (textLayerElement.nodeType === Node.TEXT_NODE) {\n      textLayerElement = textLayerElement.parentElement;\n    }\n    const textLayer = textLayerElement.closest('.textLayer') as HTMLElement;\n\n    if (!textLayer) {\n      return [];\n    }\n\n    this.removeEnhancedTextModeStyling(textLayerElement);\n\n    return this.processClientRects(clientRects, textLayer);\n  }\n\n  @HostListener('mousedown', ['$event'])\n  onPdfViewerClick(event: MouseEvent) {\n    this.store.dispatch(\n      new fromAnnotationActions.SelectedAnnotation({\n        annotationId: '',\n        selected: false,\n        editable: false,\n      })\n    );\n    this.viewerEvents.clearCtxToolbar();\n  }\n\n  private getRectangles(event: MouseEvent, page) {\n    this.setPageProperties(page);\n\n    const selection = window.getSelection();\n    if (selection) {\n      const localElement = <HTMLElement>event.target;\n\n      this.removeEnhancedTextModeStyling(localElement);\n\n      if (selection.rangeCount && !selection.isCollapsed) {\n        const range = selection.getRangeAt(0).cloneRange();\n        const clientRects = range.getClientRects();\n\n        if (clientRects) {\n          const textLayer = localElement.closest(\".textLayer\") as HTMLElement;\n          return this.processClientRects(clientRects, textLayer);\n        }\n      }\n    }\n  }\n\n  private createTextRectangle(rect: any, parentRect: any): Rectangle {\n    const height = rect.bottom - rect.top;\n    const width = rect.right - rect.left;\n    const top = rect.top - parentRect.top;\n    const left = rect.left - parentRect.left;\n    let rectangle = this.highlightService.applyRotation(\n      this.pageHeight,\n      this.pageWidth,\n      height,\n      width,\n      top,\n      left,\n      this.rotate,\n      this.zoom\n    );\n    rectangle = { id: uuid(), ...rectangle };\n\n    return rectangle as Rectangle;\n  }\n\n  private removeEnhancedTextModeStyling(element: HTMLElement) {\n    if (element.parentElement.children) {\n      for (let i = 0; i < element.parentElement.children.length; i++) {\n        const child = <HTMLElement>element.parentElement.children[i];\n\n        child.style.padding = '0';\n        // regex will be targeting the translate style in string\n        // e.g. scaleX(0.969918) translateX(-110.684px) translateY(-105.274px) will become scaleX(0.969918)\n        const translateCSSRegex = /translate[XYZ]\\(-?\\d*(\\.\\d+)?(px)?\\)/g;\n        child.style.transform = child.style.transform.replace(translateCSSRegex, '').trim();\n      }\n    }\n  }\n\n  private setPageProperties(page: number): void {\n    this.pageHeight = this.allPages[page].styles.height;\n    this.pageWidth = this.allPages[page].styles.width;\n    this.zoom = parseFloat(this.allPages[page].scaleRotation.scale);\n    this.rotate = parseInt(this.allPages[page].scaleRotation.rotation, 10);\n  }\n\n  private processClientRects(clientRects: DOMRectList, textLayer: HTMLElement): Rectangle[] {\n    const parentRect = HtmlTemplatesHelper.getAdjustedBoundingRect(textLayer);\n    const selectionRectangles: Rectangle[] = [];\n\n    for (let i = 0; i < clientRects.length; i++) {\n      const selectionRectangle = this.createTextRectangle(clientRects[i], parentRect);\n      const findSelectionRectangle = selectionRectangles.find(\n        (rect) => rect.width === selectionRectangle.width && rect.x === selectionRectangle.x\n      );\n      if (!findSelectionRectangle) {\n        selectionRectangles.push(selectionRectangle);\n      }\n    }\n\n    return selectionRectangles;\n  }\n}\n"]}