@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.
- package/assets/all.scss +1 -0
- package/assets/sass/pdf-viewer.scss +79 -1
- package/assets/sass/tooltip.scss +50 -0
- package/esm2022/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.directive.mjs +80 -21
- package/esm2022/lib/annotations/annotation-set/annotation-create/highlight-create/keyboard-text-highlight.directive.mjs +354 -0
- package/esm2022/lib/annotations/annotation-set/annotation-view/annotation-view.component.mjs +1 -1
- package/esm2022/lib/annotations/annotation-set/ctx-toolbar/ctx-toolbar.component.mjs +31 -5
- package/esm2022/lib/annotations/annotation-set/metadata-layer/metadata-layer.component.mjs +17 -4
- package/esm2022/lib/media-viewer.module.mjs +4 -1
- package/esm2022/lib/shared/directives/tooltip-dismiss.directive.mjs +36 -0
- package/esm2022/lib/toolbar/highlight-toolbar/highlight-toolbar.component.mjs +6 -4
- package/esm2022/lib/toolbar/main-toolbar/main-toolbar.component.mjs +5 -4
- package/esm2022/lib/toolbar/redaction-toolbar/redaction-toolbar.component.mjs +5 -4
- package/esm2022/lib/toolbar/toolbar.module.mjs +7 -4
- package/esm2022/lib/viewers/pdf-viewer/pdf-viewer.component.mjs +45 -7
- package/fesm2022/hmcts-media-viewer.mjs +1448 -926
- package/fesm2022/hmcts-media-viewer.mjs.map +1 -1
- package/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.directive.d.ts +6 -2
- package/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.directive.d.ts.map +1 -1
- package/lib/annotations/annotation-set/annotation-create/highlight-create/keyboard-text-highlight.directive.d.ts +63 -0
- package/lib/annotations/annotation-set/annotation-create/highlight-create/keyboard-text-highlight.directive.d.ts.map +1 -0
- package/lib/annotations/annotation-set/ctx-toolbar/ctx-toolbar.component.d.ts +6 -2
- package/lib/annotations/annotation-set/ctx-toolbar/ctx-toolbar.component.d.ts.map +1 -1
- package/lib/annotations/annotation-set/metadata-layer/metadata-layer.component.d.ts +3 -0
- package/lib/annotations/annotation-set/metadata-layer/metadata-layer.component.d.ts.map +1 -1
- package/lib/media-viewer.module.d.ts +19 -18
- package/lib/media-viewer.module.d.ts.map +1 -1
- package/lib/shared/directives/tooltip-dismiss.directive.d.ts +11 -0
- package/lib/shared/directives/tooltip-dismiss.directive.d.ts.map +1 -0
- package/lib/toolbar/toolbar.module.d.ts +7 -6
- package/lib/toolbar/toolbar.module.d.ts.map +1 -1
- package/lib/viewers/pdf-viewer/pdf-viewer.component.d.ts +20 -0
- package/lib/viewers/pdf-viewer/pdf-viewer.component.d.ts.map +1 -1
- package/package.json +2 -2
package/assets/all.scss
CHANGED
|
@@ -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.$
|
|
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
|
-
|
|
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.
|
|
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
|
|
70
|
-
|
|
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":"AAAA,OAAO,EAAE,SAAS,EAAc,YAAY,EAAqB,MAAM,eAAe,CAAC;AACvF,OAAO,EAAE,EAAE,IAAI,IAAI,EAAE,MAAM,MAAM,CAAC;AAElC,OAAO,EAAE,YAAY,EAAE,MAAM,EAAgB,MAAM,MAAM,CAAC;AAI1D,OAAO,KAAK,YAAY,MAAM,gDAAgD,CAAC;AAE/E,OAAO,KAAK,qBAAqB,MAAM,8CAA8C,CAAC;AAGtF,OAAO,EAAE,mBAAmB,EAAE,MAAM,uDAAuD,CAAC;;;;;;AAK5F,MAAM,OAAO,wBAAwB;IASnC,YACU,OAAgC,EAChC,aAAkC,EAClC,YAAgC,EAChC,gBAAwC,EACxC,KAA0C;QAJ1C,YAAO,GAAP,OAAO,CAAyB;QAChC,kBAAa,GAAb,aAAa,CAAqB;QAClC,iBAAY,GAAZ,YAAY,CAAoB;QAChC,qBAAgB,GAAhB,gBAAgB,CAAwB;QACxC,UAAK,GAAL,KAAK,CAAqC;QAP5C,mBAAc,GAAmB,EAAE,CAAC;IAQxC,CAAC;IAEL,QAAQ;QACN,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACpF,IAAI,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;gBACb,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;YACxB,CAAC;QACH,CAAC,CAAC,CAAC,CAAC;QAEJ,IAAI,CAAC,cAAc,CAAC,IAAI,CACtB,IAAI,CAAC,aAAa,CAAC,oBAAoB,CAAC,IAAI,CAC1C,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,IAAI,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,EAC1D,YAAY,CAAC,GAAG,CAAC,CAClB,CAAC,SAAS,CAAC,GAAG,EAAE;YACf,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QACrC,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,WAAW;QACT,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC,CAAC;IACxD,CAAC;IAGD,SAAS,CAAC,UAAsB;QAC9B,IAAI,IAAY,CAAC;QACjB,IAAI,cAAc,GAAG,UAAU,CAAC,MAAqB,CAAC;QACtD,OAAO,cAAc,CAAC,YAAY,EAAE,CAAC;YACnC,cAAc,GAAG,cAAc,CAAC,YAA2B,CAAC;YAC5D,IAAI,cAAc,CAAC,YAAY,EAAE,CAAC;gBAChC,IAAI,GAAG,QAAQ,CAAC,cAAc,CAAC,YAAY,CAAC,kBAAkB,CAAC,EAAE,EAAE,CAAC,CAAC;gBACrE,IAAI,IAAI,EAAE,CAAC;oBACT,MAAM;gBACR,CAAC;YACH,CAAC;QACH,CAAC;QACD,IAAI,IAAI,CAAC,aAAa,CAAC,oBAAoB,CAAC,QAAQ,EAAE,EAAE,CAAC;YACvD,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;YACxD,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;QACvD,CAAC;IACH,CAAC;IAEM,4BAA4B;QACjC,IAAI,IAAI,CAAC,aAAa,CAAC,oBAAoB,CAAC,QAAQ,EAAE,EAAE,CAAC;YACvD,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;YACxC,IAAI,SAAS,IAAI,SAAS,CAAC,UAAU,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;gBAChE,MAAM,IAAI,GAAG,IAAI,CAAC,2BAA2B,CAAC,SAAS,CAAC,CAAC;gBACzD,MAAM,UAAU,GAAG,IAAI,CAAC,0BAA0B,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;gBACpE,IAAI,UAAU,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBACxC,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;gBACvD,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAEO,2BAA2B,CAAC,SAAoB;QACtD,MAAM,KAAK,GAAG,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QACtC,IAAI,cAAc,GAAG,KAAK,CAAC,cAA6B,CAAC;QAEzD,IAAI,cAAc,CAAC,QAAQ,KAAK,IAAI,CAAC,SAAS,EAAE,CAAC;YAC/C,cAAc,GAAG,cAAc,CAAC,aAAa,CAAC;QAChD,CAAC;QAED,OAAO,cAAc,IAAI,cAAc,CAAC,YAAY,EAAE,CAAC;YACrD,cAAc,GAAG,cAAc,CAAC,YAA2B,CAAC;YAC5D,IAAI,cAAc,CAAC,YAAY,EAAE,CAAC;gBAChC,MAAM,IAAI,GAAG,QAAQ,CAAC,cAAc,CAAC,YAAY,CAAC,kBAAkB,CAAC,EAAE,EAAE,CAAC,CAAC;gBAC3E,IAAI,IAAI,EAAE,CAAC;oBACT,OAAO,IAAI,CAAC;gBACd,CAAC;YACH,CAAC;QACH,CAAC;QACD,OAAO,CAAC,CAAC;IACX,CAAC;IAEO,0BAA0B,CAAC,SAAoB,EAAE,IAAY;QACnE,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;YAC3C,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QAE7B,MAAM,KAAK,GAAG,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,UAAU,EAAE,CAAC;QACnD,MAAM,WAAW,GAAG,KAAK,CAAC,cAAc,EAAE,CAAC;QAE3C,IAAI,CAAC,WAAW,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC7C,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,IAAI,gBAAgB,GAAG,KAAK,CAAC,cAA6B,CAAC;QAC3D,IAAI,gBAAgB,CAAC,QAAQ,KAAK,IAAI,CAAC,SAAS,EAAE,CAAC;YACjD,gBAAgB,GAAG,gBAAgB,CAAC,aAAa,CAAC;QACpD,CAAC;QACD,MAAM,SAAS,GAAG,gBAAgB,CAAC,OAAO,CAAC,YAAY,CAAgB,CAAC;QAExE,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,IAAI,CAAC,6BAA6B,CAAC,gBAAgB,CAAC,CAAC;QAErD,OAAO,IAAI,CAAC,kBAAkB,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;IACzD,CAAC;IAGD,gBAAgB,CAAC,KAAiB;QAChC,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,IAAI,qBAAqB,CAAC,kBAAkB,CAAC;YAC3C,YAAY,EAAE,EAAE;YAChB,QAAQ,EAAE,KAAK;YACf,QAAQ,EAAE,KAAK;SAChB,CAAC,CACH,CAAC;QACF,IAAI,CAAC,YAAY,CAAC,eAAe,EAAE,CAAC;IACtC,CAAC;IAEO,aAAa,CAAC,KAAiB,EAAE,IAAI;QAC3C,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QAE7B,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;QACxC,IAAI,SAAS,EAAE,CAAC;YACd,MAAM,YAAY,GAAgB,KAAK,CAAC,MAAM,CAAC;YAE/C,IAAI,CAAC,6BAA6B,CAAC,YAAY,CAAC,CAAC;YAEjD,IAAI,SAAS,CAAC,UAAU,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;gBACnD,MAAM,KAAK,GAAG,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,UAAU,EAAE,CAAC;gBACnD,MAAM,WAAW,GAAG,KAAK,CAAC,cAAc,EAAE,CAAC;gBAE3C,IAAI,WAAW,EAAE,CAAC;oBAChB,MAAM,SAAS,GAAG,YAAY,CAAC,OAAO,CAAC,YAAY,CAAgB,CAAC;oBACpE,OAAO,IAAI,CAAC,kBAAkB,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;gBACzD,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAEO,mBAAmB,CAAC,IAAS,EAAE,UAAe;QACpD,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC;QACtC,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC;QACrC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC;QACtC,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,GAAG,UAAU,CAAC,IAAI,CAAC;QACzC,IAAI,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,aAAa,CACjD,IAAI,CAAC,UAAU,EACf,IAAI,CAAC,SAAS,EACd,MAAM,EACN,KAAK,EACL,GAAG,EACH,IAAI,EACJ,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,IAAI,CACV,CAAC;QACF,SAAS,GAAG,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,GAAG,SAAS,EAAE,CAAC;QAEzC,OAAO,SAAsB,CAAC;IAChC,CAAC;IAEO,6BAA6B,CAAC,OAAoB;QACxD,IAAI,OAAO,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;YACnC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,aAAa,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC/D,MAAM,KAAK,GAAgB,OAAO,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;gBAE7D,KAAK,CAAC,KAAK,CAAC,OAAO,GAAG,GAAG,CAAC;gBAC1B,wDAAwD;gBACxD,mGAAmG;gBACnG,MAAM,iBAAiB,GAAG,uCAAuC,CAAC;gBAClE,KAAK,CAAC,KAAK,CAAC,SAAS,GAAG,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,OAAO,CAAC,iBAAiB,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;YACtF,CAAC;QACH,CAAC;IACH,CAAC;IAEO,iBAAiB,CAAC,IAAY;QACpC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC;QACpD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;QAClD,IAAI,CAAC,IAAI,GAAG,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAChE,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,aAAa,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;IACzE,CAAC;IAEO,kBAAkB,CAAC,WAAwB,EAAE,SAAsB;QACzE,MAAM,UAAU,GAAG,mBAAmB,CAAC,uBAAuB,CAAC,SAAS,CAAC,CAAC;QAC1E,MAAM,mBAAmB,GAAgB,EAAE,CAAC;QAE5C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAC5C,MAAM,kBAAkB,GAAG,IAAI,CAAC,mBAAmB,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC;YAChF,MAAM,sBAAsB,GAAG,mBAAmB,CAAC,IAAI,CACrD,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,KAAK,kBAAkB,CAAC,KAAK,IAAI,IAAI,CAAC,CAAC,KAAK,kBAAkB,CAAC,CAAC,CACrF,CAAC;YACF,IAAI,CAAC,sBAAsB,EAAE,CAAC;gBAC5B,mBAAmB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;YAC/C,CAAC;QACH,CAAC;QAED,OAAO,mBAAmB,CAAC;IAC7B,CAAC;kIAhNU,wBAAwB;sHAAxB,wBAAwB;;4FAAxB,wBAAwB;kBAHpC,SAAS;mBAAC;oBACT,QAAQ,EAAE,yBAAyB;iBACpC;2MAwCC,SAAS;sBADR,YAAY;uBAAC,SAAS,EAAE,CAAC,QAAQ,CAAC;gBAkFnC,gBAAgB;sBADf,YAAY;uBAAC,WAAW,EAAE,CAAC,QAAQ,CAAC","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"]}
|